/* ============================================================
   DE VOCAȚIE AVOCAT — EDITORIAL COMPONENTS v2
   Unique per-section layouts, no repeated patterns
   ============================================================ */

/* ════════════════════════════════════════════════════════════
   HEADER v2 — Premium editorial
   ════════════════════════════════════════════════════════════ */

/* ── Scroll progress bar ─────────────────────────────────── */
.header-progress {
  position: absolute; bottom: 0; left: 0; height: 2px; width: 0%;
  background: linear-gradient(90deg, var(--gold), var(--gold-light));
  transition: width 0.08s linear; z-index: 2; pointer-events: none;
  opacity: 0; transition: opacity var(--ease), width 0.08s linear;
}
.site-header.scrolled .header-progress { opacity: 1; }

/* ── Micro-strip ─────────────────────────────────────────── */
.header-micro {
  background: var(--navy); overflow: hidden;
  max-height: 36px; transition: max-height 0.4s ease, opacity 0.3s ease;
}
.site-header.scrolled .header-micro { max-height: 0; opacity: 0; }
.header-micro__inner {
  display: flex; align-items: center; justify-content: space-between;
  padding-block: 0.5rem;
}
.header-micro__contacts {
  display: flex; gap: var(--s-5); list-style: none;
}
.header-micro__contacts li {
  display: flex; align-items: center; gap: 6px;
  font-size: 0.68rem; font-weight: 500; letter-spacing: 0.06em;
  color: rgba(244,239,230,0.45);
}
.header-micro__contacts a {
  color: rgba(244,239,230,0.45); transition: color var(--ease-fast);
}
.header-micro__contacts a:hover { color: var(--gold); }
.header-micro__contacts svg { color: rgba(198,168,107,0.5); flex-shrink: 0; }
.header-micro__hours { display: none; }
.header-micro__tagline {
  font-size: 0.62rem; font-weight: 600; letter-spacing: 0.24em;
  text-transform: uppercase; color: rgba(198,168,107,0.35);
}

/* ── Main bar ────────────────────────────────────────────── */
.site-header {
  position: fixed; top: 0; left: 0; width: 100%; z-index: 900;
  transition: background var(--ease), box-shadow var(--ease);
}
.site-header__bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0.6rem clamp(1.25rem, 4vw, 3rem);
  transition: padding var(--ease), background var(--ease), border-color var(--ease);
  border-bottom: 1px solid transparent; position: relative;
}
.site-header.scrolled {
  background: rgba(255,255,255,0.97);
  backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px);
  box-shadow: 0 1px 0 var(--border-light);
}
.site-header.scrolled .site-header__bar {
  padding-top: 0.75rem; padding-bottom: 0.75rem;
}
.site-header--solid {
  background: rgba(255,255,255,0.99);
  box-shadow: 0 1px 0 var(--border-light);
}

/* ── Homepage hero dark — button overrides ───────────────── */
.home-hero .btn--primary {
  background: var(--gold); color: var(--navy); border-color: var(--gold);
}
.home-hero .btn--primary:hover {
  background: var(--gold-dim); border-color: var(--gold-dim); color: var(--navy);
}
.home-hero .btn--outline {
  color: rgba(244,239,230,0.8); border-color: rgba(244,239,230,0.3);
}
.home-hero .btn--outline:hover {
  background: rgba(244,239,230,0.08); border-color: var(--ivory); color: var(--ivory);
}

/* Pe homepage, CTA din footer se dublează cu home-cta */
.home .footer-cta-band { display: none; }

/* ── Homepage — transparent header over dark hero ────────── */
.home .site-header:not(.scrolled) {
  background: transparent;
  box-shadow: none;
}
/* Hide micro-strip on homepage until scrolled (hero is full-height) */
.home .site-header:not(.scrolled) .header-micro {
  max-height: 0; opacity: 0; pointer-events: none;
}
/* Logo light */
.home .site-header:not(.scrolled) .dva-logo__mark { color: var(--ivory); }
.home .site-header:not(.scrolled) .dva-logo__sub  { color: rgba(198,168,107,0.65); }
/* Nav links light */
.home .site-header:not(.scrolled) .header-nav__list > li > a {
  color: rgba(244,239,230,0.75);
}
.home .site-header:not(.scrolled) .header-nav__list > li > a:hover,
.home .site-header:not(.scrolled) .header-nav__list > li.current-menu-item > a {
  color: var(--ivory);
}
/* CTA button — solid gold on dark hero */
.home .site-header:not(.scrolled) .header-cta-btn {
  background: var(--gold);
  border-color: var(--gold);
  color: var(--navy-dark);
}
.home .site-header:not(.scrolled) .header-cta-btn:hover {
  background: var(--gold-light);
  border-color: var(--gold-light);
  color: var(--navy-dark);
  transform: translateY(-1px);
}
/* Phone link light */
.home .site-header:not(.scrolled) .header-phone { color: rgba(244,239,230,0.6); }
/* Hamburger lines light */
.home .site-header:not(.scrolled) .nav-toggle__line { background: var(--ivory); }
/* Progress bar still visible */
.home .site-header:not(.scrolled) .header-progress { opacity: 0; }
/* Bar bottom border transparent */
.home .site-header:not(.scrolled) .site-header__bar { border-bottom-color: transparent; }

/* ── Logo ────────────────────────────────────────────────── */
.header-logo { text-decoration: none; flex-shrink: 0; display: flex; align-items: center; }
.header-logo .dva-logo__mark {
  font-size: 6rem; letter-spacing: 0.22em; transition: color var(--ease-fast);
}
.header-logo .dva-logo__sub { font-size: 0.65rem; letter-spacing: 0.32em; }
.header-logo:hover .dva-logo__mark { color: var(--gold-dim); }

/* Custom logo images — sizing normalisation */
.header-logo__img {
  display: block;
  height: 72px;
  width: auto;
  max-width: 200px;
  object-fit: contain;
  object-position: left center;
}

/* Default (dark bg — transparent header on homepage): show dark logo */
.header-logo__img--dark  { display: block; }
.header-logo__img--light { display: none; }

/* Scrolled state (ivory bg): swap to light logo */
.site-header.scrolled .header-logo__img--dark  { display: none; }
.site-header.scrolled .header-logo__img--light { display: block; }

/* Solid header on inner pages (ivory bg): show light logo */
.site-header--solid .header-logo__img--dark  { display: none; }
.site-header--solid .header-logo__img--light { display: block; }

/* Footer logo */
.footer-logo__img {
  display: block;
  height: 48px;
  width: auto;
  max-width: 200px;
  object-fit: contain;
  object-position: left center;
}

/* ── Desktop nav ─────────────────────────────────────────── */
.header-nav { flex: 1; display: flex; justify-content: center; }
.header-nav__list { display: flex; list-style: none; align-items: center; }
.header-nav__list > li { position: relative; }
.header-nav__list > li > a {
  display: flex; align-items: center; gap: 5px;
  padding: 0.45rem 0.875rem;
  font-family: var(--serif); font-size: 1.15rem; font-weight: 400;
  letter-spacing: 0.04em; text-transform: none; color: var(--charcoal);
  position: relative; transition: color var(--ease-fast);
}
/* Gold dot indicator */
.header-nav__list > li > a::before {
  content: ''; position: absolute; bottom: 2px; left: 50%;
  transform: translateX(-50%) scale(0);
  width: 3px; height: 3px; border-radius: 50%; background: var(--gold);
  transition: transform var(--ease-spring);
}
.header-nav__list > li > a:hover,
.header-nav__list > li.current-menu-item > a,
.header-nav__list > li.current-menu-ancestor > a { color: var(--navy); }
.header-nav__list > li > a:hover::before,
.header-nav__list > li.current-menu-item > a::before,
.header-nav__list > li.current-menu-ancestor > a::before { transform: translateX(-50%) scale(1); }

/* Dropdown */
.header-nav__list .sub-menu {
  position: absolute; top: calc(100% + 8px); left: 50%; transform: translateX(-50%) translateY(6px);
  min-width: 200px; background: var(--white);
  border: 1px solid var(--border); border-top: 1px solid var(--gold);
  box-shadow: 0 16px 40px rgba(11,31,58,0.1); list-style: none;
  opacity: 0; visibility: hidden;
  transition: opacity var(--ease), visibility var(--ease), transform var(--ease);
  z-index: 100;
}
.header-nav__list li:hover > .sub-menu {
  opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0);
}
.sub-menu li a {
  display: block; padding: 0.55rem 1rem;
  font-size: 0.72rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--charcoal); transition: color var(--ease-fast), background var(--ease-fast);
  border-bottom: 1px solid rgba(224,217,206,0.35);
}
.sub-menu li:last-child a { border: none; }
.sub-menu li a:hover { color: var(--gold-dim); background: var(--ivory); }

/* ── Right side ──────────────────────────────────────────── */
.header-right {
  display: flex; align-items: center; gap: var(--s-4); flex-shrink: 0;
}
/* Phone — hidden until scrolled */
.header-phone {
  display: flex; align-items: center; gap: 6px;
  font-size: 0.7rem; font-weight: 600; letter-spacing: 0.06em;
  color: var(--navy); opacity: 0; pointer-events: none;
  transition: opacity var(--ease), color var(--ease-fast);
  white-space: nowrap;
}
.header-phone:hover { color: var(--gold-dim); }
.site-header.scrolled .header-phone { opacity: 1; pointer-events: auto; }
.site-header--solid .header-phone { opacity: 1; pointer-events: auto; }
/* Vertical separator */
.header-sep {
  width: 1px; height: 18px; background: var(--border);
  opacity: 0; transition: opacity var(--ease); flex-shrink: 0;
}
.site-header.scrolled .header-sep,
.site-header--solid .header-sep { opacity: 1; }
/* CTA btn — compact */
.header-cta-btn { padding: 0.65em 1.4em; font-size: 0.68rem; letter-spacing: 0.1em; }

/* ── Language Switcher ───────────────────────────────────── */
.lang-switch { display: flex; align-items: center; }
.lang-switch ul {
  display: flex !important; flex-direction: row !important; flex-wrap: nowrap !important;
  align-items: center; gap: 0;
  list-style: none !important; margin: 0 !important; padding: 0 !important;
}
.lang-switch li { display: flex !important; flex-direction: row; align-items: center; }
.lang-switch li + li::before {
  content: '|';
  font-size: 0.5rem; line-height: 1;
  color: var(--ivory); opacity: 0.25;
  margin: 0 5px;
  display: inline;
}
.lang-switch a {
  font-family: var(--sans); font-size: 0.58rem; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ivory); opacity: 0.38;
  text-decoration: none;
  transition: opacity var(--ease-fast);
  white-space: nowrap;
}
.lang-switch a:hover { opacity: 0.75; }
.lang-switch .current-lang a { opacity: 1; }
/* Solid / scrolled header — navy text */
.site-header--solid .lang-switch a,
.site-header.scrolled .lang-switch a { color: var(--navy); }
.site-header--solid .lang-switch li + li::before,
.site-header.scrolled .lang-switch li + li::before { color: var(--navy); }
/* Mobile nav (inside slide-out menu) */
.lang-switch--mobile { margin-bottom: var(--s-5); display: flex; }
.lang-switch--mobile ul { gap: 0; }
.lang-switch--mobile li + li::before { color: var(--ivory); opacity: 0.25; }
.lang-switch--mobile a { color: var(--ivory); opacity: 0.45; font-size: 0.62rem; }
.lang-switch--mobile .current-lang a { opacity: 1; }

/* ── Mobile language switcher (header bar, ≤1024px only) ─── */
.mob-lang { display: none; }
@media (max-width: 1024px) {
  .mob-lang {
    display: flex; align-items: center; margin-left: auto; margin-right: 12px;
  }
  .mob-lang ul {
    display: flex; flex-direction: row; align-items: center;
    list-style: none; margin: 0; padding: 0; gap: 0;
  }
  .mob-lang li { display: flex; align-items: center; }
  .mob-lang li + li::before {
    content: '|'; font-size: 0.45rem; opacity: 0.22; margin: 0 5px; color: currentColor;
  }
  .mob-lang a {
    font-family: var(--sans); font-size: 0.56rem; font-weight: 700;
    letter-spacing: 0.13em; text-transform: uppercase; text-decoration: none;
    color: var(--ivory); opacity: 0.38;
    transition: opacity 0.2s;
  }
  .mob-lang a:hover { opacity: 0.75; }
  .mob-lang .current-lang a { opacity: 1; }
  .site-header--solid .mob-lang a,
  .site-header.scrolled .mob-lang a { color: var(--navy); }
  .site-header--solid .mob-lang li + li::before,
  .site-header.scrolled .mob-lang li + li::before { color: var(--navy); }
}

/* ── Hamburger ───────────────────────────────────────────── */
.nav-toggle {
  display: none; flex-direction: column; justify-content: center; align-items: flex-end;
  gap: 5px; width: 44px; height: 44px; padding: 8px 6px;
  background: none; border: none; cursor: pointer; z-index: 1100;
}
.nav-toggle__line {
  height: 1.5px; background: var(--navy);
  transition: transform var(--ease), opacity var(--ease-fast), width var(--ease);
  transform-origin: right; display: block;
}
.nav-toggle__line:nth-child(1) { width: 22px; }
.nav-toggle__line:nth-child(2) { width: 16px; }
.nav-toggle__line:nth-child(3) { width: 22px; }
.nav-toggle.open .nav-toggle__line:nth-child(1) { width: 22px; transform: translateY(6.5px) rotate(-45deg); }
.nav-toggle.open .nav-toggle__line:nth-child(2) { opacity: 0; width: 0; }
.nav-toggle.open .nav-toggle__line:nth-child(3) { width: 22px; transform: translateY(-6.5px) rotate(45deg); }

/* ── Mobile nav — full-screen editorial ─────────────────── */
.mobile-nav {
  position: fixed; inset: 0; z-index: 1050;
  background: var(--white);
  display: flex; flex-direction: column;
  padding: 0;
  transform: translateX(101%);
  transition: transform 0.6s cubic-bezier(0.77, 0, 0.175, 1);
  overflow: hidden;
}
.mobile-nav.open { transform: translateX(0); }
/* DVA watermark inside mobile nav */
.mobile-nav__watermark {
  position: absolute; bottom: -5%; right: -3%;
  font-family: var(--serif); font-size: clamp(10rem, 30vw, 18rem);
  font-weight: 400; color: rgba(198,168,107,0.04);
  letter-spacing: -0.05em; line-height: 0.9;
  pointer-events: none; user-select: none;
}
/* Header row inside mobile nav */
.mobile-nav__header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1rem clamp(1.5rem, 5vw, 3rem);
  border-bottom: 1px solid var(--border-light);
  flex-shrink: 0;
}
.mobile-nav__logo { display: flex; align-items: center; }
.mobile-nav__logo-img { height: 48px; width: auto; display: block; }
.mobile-nav__close {
  display: flex; align-items: center; justify-content: center;
  width: 44px; height: 44px;
  background: none; border: 1px solid var(--border-light);
  color: var(--navy); cursor: pointer;
  transition: background var(--ease-fast), border-color var(--ease-fast);
  flex-shrink: 0;
}
.mobile-nav__close:hover { background: var(--cream); border-color: var(--border); }
/* Nav list */
.mobile-nav__menu { flex: 1; overflow-y: auto; padding: 0 clamp(1.5rem, 5vw, 3rem); }
.mobile-nav__list { list-style: none; padding: var(--s-4) 0; }
.mobile-nav__list > li {
  border-bottom: 1px solid var(--border-light);
  opacity: 0; transform: translateX(20px);
  transition: opacity 0.4s ease, transform 0.4s ease;
}
/* Stagger animation when open */
.mobile-nav.open .mobile-nav__list > li:nth-child(1) { opacity: 1; transform: none; transition-delay: 0.12s; }
.mobile-nav.open .mobile-nav__list > li:nth-child(2) { opacity: 1; transform: none; transition-delay: 0.18s; }
.mobile-nav.open .mobile-nav__list > li:nth-child(3) { opacity: 1; transform: none; transition-delay: 0.24s; }
.mobile-nav.open .mobile-nav__list > li:nth-child(4) { opacity: 1; transform: none; transition-delay: 0.30s; }
.mobile-nav.open .mobile-nav__list > li:nth-child(5) { opacity: 1; transform: none; transition-delay: 0.36s; }
.mobile-nav.open .mobile-nav__list > li:nth-child(6) { opacity: 1; transform: none; transition-delay: 0.42s; }
.mobile-nav.open .mobile-nav__list > li:nth-child(7) { opacity: 1; transform: none; transition-delay: 0.48s; }
.mobile-nav__list > li > a {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0.85rem 0;
  font-family: var(--serif); font-size: clamp(1.1rem, 3.5vw, 1.4rem); font-weight: 400;
  color: var(--navy); transition: color var(--ease-fast), padding-left var(--ease-fast);
}
.mobile-nav__list > li > a::after {
  content: '→'; font-family: var(--sans); font-size: 0.875rem; color: var(--gold);
  opacity: 0; transform: translateX(-6px); transition: opacity var(--ease-fast), transform var(--ease);
}
.mobile-nav__list > li > a:hover { color: var(--gold-dim); padding-left: var(--s-3); }
.mobile-nav__list > li > a:hover::after { opacity: 1; transform: translateX(0); }
/* Footer */
.mobile-nav__foot {
  flex-shrink: 0;
  padding: var(--s-6) clamp(1.5rem, 5vw, 3rem);
  border-top: 1px solid var(--border-light);
  background: var(--ivory);
  display: flex; flex-direction: column; gap: var(--s-4);
  position: relative; z-index: 1;
}
.mobile-nav__contacts {
  display: flex; gap: var(--s-5); flex-wrap: wrap; margin-top: var(--s-2);
}
.mobile-nav__contact-item {
  display: flex; align-items: center; gap: 6px;
  font-size: var(--t-sm); font-weight: 500; color: var(--gray);
  transition: color var(--ease-fast);
}
.mobile-nav__contact-item svg { color: var(--gold); flex-shrink: 0; }
.mobile-nav__contact-item:hover { color: var(--navy); }

/* ── Height spacer ───────────────────────────────────────── */
.h-spacer { height: 84px; } /* micro-strip 36 + bar ~48 */
/* On homepage, hero is full-height behind transparent header — no spacer */
.home .h-spacer { display: none; }

/* ════════════════════════════════════════════════════════════
   FOOTER v2 — Premium editorial
   ════════════════════════════════════════════════════════════ */

/* ── Pre-footer CTA band ─────────────────────────────────── */
.footer-cta-band {
  background: var(--navy);
  border-top: 1px solid rgba(198,168,107,0.18);
  position: relative; overflow: hidden;
}
.footer-cta-band::before { display: none; }
.footer-cta-band__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: clamp(2rem, 5vw, 4rem);
  padding: clamp(3rem, 6vw, 5rem) 0;
  position: relative; z-index: 1;
}
.footer-cta-band__heading {
  font-family: var(--serif);
  font-size: clamp(1.5rem, 3vw, 2.5rem);
  font-weight: 400; color: var(--ivory);
  line-height: 1.25; max-width: 38ch;
}
.footer-cta-band__actions {
  display: flex; align-items: center;
  gap: clamp(1.25rem, 3vw, 2.5rem); flex-shrink: 0;
}
.footer-cta-band__phone {
  display: flex; align-items: center; gap: var(--s-2);
  font-size: var(--t-sm); color: rgba(244,239,230,0.5);
  font-weight: 500; letter-spacing: 0.03em;
  transition: color var(--ease-fast);
}
.footer-cta-band__phone:hover { color: var(--gold); }
.footer-cta-band__phone svg { color: var(--gold); opacity: 0.7; flex-shrink: 0; }

/* ── Main footer body ────────────────────────────────────── */
.footer-body {
  background: #06142a;
  position: relative; overflow: hidden;
  padding: clamp(4rem, 8vw, 7rem) 0 clamp(2.5rem, 5vw, 4rem);
}
.footer-body__overlay {
  position: absolute; inset: 0;
  pointer-events: none; z-index: 0;
}
.footer-body::after {
  content: '';
  position: absolute; top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(198,168,107,0.25) 30%, rgba(198,168,107,0.25) 70%, transparent 100%);
}

/* Large DVA watermark */
.footer-watermark {
  display: none;
}

/* ── Main footer grid: brand left | nav right ────────────── */
.footer-main-grid {
  display: grid;
  grid-template-columns: 1.5fr 2fr;
  gap: clamp(3rem, 7vw, 7rem);
  align-items: start;
}

/* Brand column */
.footer-brand-col { display: flex; flex-direction: column; gap: var(--s-6); }

.footer-logo-link { display: inline-flex; text-decoration: none; }

.footer-brand-col .dva-logo__mark {
  font-size: 5.5rem; font-weight: 300; color: var(--ivory);
  letter-spacing: 0.18em; line-height: 1;
}
.footer-brand-col .dva-logo__sub {
  font-size: 0.62rem; letter-spacing: 0.3em;
  color: rgba(198,168,107,0.85);
}

.footer-logo__img {
  height: 130px; width: auto; max-width: 340px;
  object-fit: contain; object-position: left center; display: block;
}

.footer-brand-tagline {
  font-family: var(--serif); font-size: var(--t-md); font-weight: 300;
  font-style: italic; color: rgba(244,239,230,0.88);
  line-height: 1.55; border-left: 2px solid rgba(198,168,107,0.6);
  padding-left: var(--s-4); max-width: 28ch;
}

.footer-brand-desc {
  font-size: var(--t-sm); color: rgba(244,239,230,0.62);
  line-height: 1.85; max-width: 34ch;
}

.footer-social { display: flex; gap: var(--s-3); margin-top: var(--s-2); }
.footer-social__link {
  display: flex; align-items: center; justify-content: center;
  width: 38px; height: 38px;
  border: 1px solid rgba(244,239,230,0.22);
  color: rgba(244,239,230,0.6);
  transition: all var(--ease-fast);
}
.footer-social__link:hover {
  border-color: var(--gold);
  color: var(--gold);
  background: rgba(198,168,107,0.1);
}

/* Navigation columns */
.footer-nav-cols {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: clamp(1.5rem, 3vw, 3rem);
}

.footer-nav-col__head {
  font-size: var(--t-xs); font-weight: 600;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--gold);
  margin-bottom: var(--s-5);
}

.footer-nav-col__list {
  list-style: none; display: flex; flex-direction: column; gap: var(--s-3);
}
.footer-nav-col__list a {
  font-size: var(--t-sm); color: rgba(244,239,230,0.68);
  transition: color var(--ease-fast), padding-left var(--ease-fast);
  display: block; line-height: 1.4;
}
.footer-nav-col__list a:hover { color: var(--ivory); padding-left: 6px; }

/* ANPC banners in Legal col */
.footer-anpc {
  display: flex; flex-wrap: wrap; gap: var(--s-3);
  margin-top: var(--s-6);
}
.footer-anpc__img {
  height: 40px; width: auto; display: block;
  opacity: 0.85; transition: opacity var(--ease-fast);
}
.footer-anpc__link:hover .footer-anpc__img { opacity: 1; }

/* Contact list in footer */
.footer-contact-list { list-style: none; display: flex; flex-direction: column; gap: var(--s-5); }
.footer-contact-item {
  display: flex; align-items: flex-start; gap: var(--s-3);
}
.footer-contact-item svg {
  color: var(--gold); opacity: 0.85; flex-shrink: 0; margin-top: 3px;
}
.footer-contact-item > div { display: flex; flex-direction: column; gap: 2px; }
.footer-contact-item > div span:first-child {
  font-size: var(--t-xs); font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(244,239,230,0.45);
}
.footer-contact-item > div span:last-child,
.footer-contact-item > div a {
  font-size: var(--t-sm); color: rgba(244,239,230,0.82);
  transition: color var(--ease-fast);
}
.footer-contact-item > div a:hover { color: var(--gold); }

/* ── Bottom bar ──────────────────────────────────────────── */
.footer-bottom {
  background: #04101f;
  position: relative; z-index: 1;
}
.footer-bottom::before {
  content: '';
  display: block; height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(198,168,107,0.15) 50%, transparent 100%);
}
.footer-bottom__inner {
  display: flex; align-items: center;
  justify-content: space-between;
  gap: var(--s-5); flex-wrap: wrap;
  padding: var(--s-5) 0;
}
.footer-copy {
  font-size: var(--t-xs); color: rgba(244,239,230,0.45);
  letter-spacing: 0.05em;
}
.footer-copy strong { font-weight: 500; color: rgba(244,239,230,0.6); }

/* Legal links nav menu */
.footer-legal-links {
  display: flex; gap: var(--s-5);
  list-style: none; flex-wrap: wrap; margin: 0; padding: 0;
}
.footer-legal-links li a,
.footer-legal-links a {
  font-size: var(--t-xs); color: rgba(244,239,230,0.45);
  transition: color var(--ease-fast); letter-spacing: 0.04em;
}
.footer-legal-links li a:hover,
.footer-legal-links a:hover { color: var(--gold); }

/* ── Footer responsive ───────────────────────────────────── */
@media (max-width: 1024px) {
  .footer-main-grid { grid-template-columns: 1fr; gap: clamp(2.5rem, 5vw, 4rem); }
  .footer-nav-cols { grid-template-columns: repeat(3, 1fr); }
  .footer-brand-desc { max-width: 100%; }
}
@media (max-width: 720px) {
  .footer-cta-band__inner { flex-direction: column; align-items: flex-start; }
  .footer-cta-band__actions { flex-direction: column; align-items: flex-start; }
  .footer-nav-cols { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .footer-bottom__inner { flex-direction: column; align-items: flex-start; }
}

/* ════════════════════════════════════════════════════════════
   CLIENT ROUTES — Three distinct layouts
   ════════════════════════════════════════════════════════════ */
.client-route__label-row {
  display: flex; align-items: center; gap: var(--s-5);
}

.client-route__body {
  display: grid; grid-template-columns: 0.9fr 1.1fr;
  gap: clamp(3rem, 6vw, 6rem); align-items: start;
}

@media (max-width: 780px) {
  .client-route__body { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════════════════════════════
   HOMEPAGE — EDITORIAL SECTIONS
   ════════════════════════════════════════════════════════════ */

/* ── [1] Hero ────────────────────────────────────────────── */
.home-hero {
  min-height: 100svh; background: var(--navy);
  display: flex; flex-direction: column;
  justify-content: space-between;
  position: relative; overflow: hidden;
  padding: 72px clamp(1.25rem, 4vw, 3rem) 0;
}
.home-hero::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 70% 30%, rgba(198,168,107,0.06) 0%, transparent 55%);
  pointer-events: none;
}
.home-hero__overlay {
  position: absolute; inset: 0;
  pointer-events: none; z-index: 0;
}
.home-hero__watermark {
  display: none;
}
.home-hero__gold-line { display: none; }

/* Top eyebrow row */
.home-hero__top {
  position: relative; z-index: 1;
  padding-top: clamp(1.5rem, 4vw, 3rem);
}
.home-hero__eyebrow { color: rgba(198,168,107,0.65); }

/* Stage: huge heading + narrow aside bottom-aligned */
.home-hero__stage {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: clamp(2rem, 5vw, 5rem);
  padding-bottom: clamp(2rem, 4vw, 3rem);
  flex: 1; position: relative; z-index: 1;
}
.home-hero__heading {
  font-family: var(--serif);
  font-size: clamp(3.5rem, 8vw, 9rem);
  font-weight: 400; line-height: 0.92; letter-spacing: -0.04em;
  color: var(--ivory); flex: 1;
}
.home-hero__heading em { font-style: italic; color: var(--gold); display: block; }

/* Aside — right column, bottom-aligned */
.home-hero__aside {
  width: clamp(240px, 28vw, 360px); flex-shrink: 0;
  display: flex; flex-direction: column; gap: var(--s-6);
  padding-bottom: var(--s-3);
}
.home-hero__positioning {
  font-family: var(--sans); font-size: var(--t-lg); font-weight: 400;
  color: rgba(244,239,230,0.8); line-height: 1.65;
}
.home-hero__actions { display: flex; flex-direction: row; gap: var(--s-3); align-items: center; flex-shrink: 0; }
.home-hero__actions .btn { justify-content: center; white-space: nowrap; }

/* Bottom footer strip */
.home-hero__footer {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s-6); flex-wrap: wrap;
  border-top: none;
  padding: var(--s-5) 0 clamp(2rem, 4vw, 3.5rem);
  position: relative; z-index: 1;
}
.home-hero__creds { display: flex; align-items: center; gap: clamp(2rem, 5vw, 4rem); }
.hero-cred { display: flex; flex-direction: column; gap: 4px; }
.hero-cred__val {
  font-family: var(--serif); font-size: var(--t-2xl); font-weight: 400;
  color: var(--ivory); line-height: 1;
}
.hero-cred__val sup { font-size: 0.5em; color: var(--gold); vertical-align: super; }
.hero-cred__label {
  font-size: var(--t-xs); color: rgba(244,239,230,0.35);
  font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em;
}
.hero-cred__sep { display: none; }

/* Baroul badge */
.home-hero__barou {
  display: flex; align-items: center; gap: var(--s-2);
  font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.1em;
  text-transform: uppercase; color: rgba(244,239,230,0.3);
}
.home-hero__barou svg { color: var(--gold); flex-shrink: 0; opacity: 0.7; }

/* ── [2] Manifesto ───────────────────────────────────────── */
.home-manifesto {
  background: var(--white);
  padding-block: clamp(4rem, 7vw, 6.5rem);
  border-top: 1px solid var(--border-light);
  position: relative;
}

/* Two-column grid */
.home-manifesto__inner {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: clamp(3rem, 6vw, 7rem);
  align-items: center;
}

/* Left: quote */
.home-manifesto__quote {
  margin: 0;
  font-family: var(--serif);
  font-size: clamp(1.5rem, 2.2vw, 2.4rem);
  font-weight: 400; font-style: italic;
  color: var(--navy);
  line-height: 1.2; letter-spacing: -0.01em;
}
.home-manifesto__quote p { margin: 0; line-height: 1.2; }

.home-manifesto__cite {
  display: block; margin-top: 1.5rem;
  font-family: var(--sans); font-size: 0.68rem; font-weight: 700;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--gold); font-style: normal; opacity: 0.85;
}

/* Right: eyebrow + rule + text + CTA */
.home-manifesto__aside { display: flex; flex-direction: column; align-items: flex-start; }
.home-manifesto__eyebrow { color: var(--gold) !important; opacity: 0.85; }
.home-manifesto__rule {
  display: none;
}
.home-manifesto__aside-text {
  font-size: var(--t-base); color: var(--gray);
  line-height: 1.85; max-width: 38ch;
}
.home-manifesto__aside .btn--link:hover { border-bottom-color: transparent; }

/* ── [3] Practice Areas — Full-bleed split ───────────────── */
.home-practices { position: relative; overflow: hidden; }

.home-practices__inner {
  display: grid;
  grid-template-columns: 0.6fr 1.4fr;
  min-height: clamp(680px, 80vh, 1080px);
}

/* Left — warm ivory editorial panel */
.home-practices__left {
  background: var(--cream);
  display: flex; align-items: center;
  position: sticky; top: 0;
  overflow: hidden;
  padding-bottom: clamp(4rem, 8vw, 7rem);
}
.home-practices__left-overlay {
  position: absolute; inset: 0; pointer-events: none;
}
.home-practices__left-inner {
  padding: clamp(3rem, 6vw, 6rem) clamp(2rem, 4vw, 4rem);
  position: relative; z-index: 1;
}
.home-practices__eyebrow {
  display: block; margin-bottom: var(--s-5);
  color: var(--gold);
}
.home-practices__intro-title {
  font-family: var(--serif); font-size: clamp(1.75rem, 3vw, 2.75rem);
  font-weight: 400; color: var(--navy); line-height: 1.15;
  margin-bottom: var(--s-10);
}
.home-practices__intro-text {
  font-size: var(--t-base); color: var(--navy);
  line-height: 1.85;
}

/* When background image is set — keep cream base removed, text stays dark */
.home-practices__left--has-image { background: transparent; border-right-color: transparent; }

/* Left panel CTA */
.home-practices__left-cta { margin-top: var(--s-10); }

/* Right — luxury practice grid */
.practices-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: repeat(5, 1fr);
  background: var(--white);
  align-self: stretch;
  padding: clamp(1.5rem, 3vw, 3rem) clamp(3rem, 5vw, 5rem) clamp(1.5rem, 3vw, 3rem) clamp(3rem, 5vw, 5rem);
  gap: 0;
}

.practice-item {
  display: flex;
  align-items: center;
  padding: clamp(1.75rem, 2.8vw, 2.75rem) clamp(1rem, 2vw, 2rem);
  border-bottom: 1px solid rgba(198,168,107,0.18);
  position: relative;
  overflow: hidden;
}
/* Remove bottom border from last row */
.practice-item:nth-last-child(-n+2) { border-bottom: none; }
/* Subtle column divider on right-column items only */
.practice-item:nth-child(even) { border-left: 1px solid rgba(198,168,107,0.18); }

/* Large number — visible on background, behind title */
.practice-item__num {
  position: absolute;
  right: clamp(0.75rem, 2vw, 2rem);
  top: 50%;
  transform: translateY(-50%);
  font-family: var(--serif);
  font-size: clamp(4rem, 6.5vw, 7rem);
  font-weight: 300;
  color: rgba(198,168,107,0.28);
  line-height: 1;
  letter-spacing: -0.04em;
  pointer-events: none;
  user-select: none;
}

.practice-item__title {
  font-family: var(--serif);
  font-size: clamp(1.1rem, 1.7vw, 1.65rem);
  font-weight: 400;
  color: var(--navy);
  line-height: 1.25;
  position: relative;
  z-index: 1;
  max-width: 75%;
}

/* ── [4] Team — Profilul Avocatei ───────────────────────── */
.home-team {
  background: var(--white);
  padding-top: var(--s-section);
  padding-bottom: var(--s-section);
  overflow: hidden;
}

.home-team__header {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 6vw, 6rem);
  align-items: end;
  margin-bottom: clamp(3rem, 6vw, 5rem);
}

.home-team__title {
  font-family: var(--serif);
  font-size: var(--t-4xl);
  font-weight: 300;
  color: var(--navy);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin-top: var(--s-4);
}

.home-team__intro {
  font-size: var(--t-base);
  color: var(--gray);
  line-height: 1.85;
  align-self: end;
}

.home-team__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(0.75rem, 1.5vw, 1.25rem);
  padding-inline: clamp(1.25rem, 4vw, 3rem);
}

.team-card__image {
  position: relative;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  background: var(--navy);
  margin-bottom: 0;
}
.team-card__image img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: top center;
  display: block;
  transition: transform 0.7s var(--ease);
}
.team-card:hover .team-card__image img { transform: scale(1.04); }

/* Navy gradient — doar la baza imaginii */
.team-card__image::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 55%;
  background: linear-gradient(
    to top,
    rgba(11,31,58,0.92) 0%,
    rgba(11,31,58,0.6) 50%,
    transparent 100%
  );
  pointer-events: none;
}

.team-card__placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--serif);
  font-size: var(--t-4xl);
  font-weight: 300;
  color: rgba(198,168,107,0.25);
  letter-spacing: 0.08em;
}

/* Text overlaid at the bottom of the image */
.team-card__body {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: var(--s-8) var(--s-8) var(--s-10);
  z-index: 1;
}

.team-card__name {
  font-family: var(--serif);
  font-size: var(--t-2xl);
  font-weight: 300;
  color: var(--ivory);
  line-height: 1.1;
  margin-bottom: var(--s-3);
}

.team-card__role {
  display: block;
  font-family: var(--sans);
  font-size: var(--t-xs);
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gold-light);
}

.team-card__cta { margin-top: var(--s-5); color: var(--gold-light); }

@media (max-width: 960px) {
  .home-team__header { grid-template-columns: 1fr; gap: var(--s-6); }
  .home-team__grid { grid-template-columns: repeat(2, 1fr); padding-inline: clamp(1.25rem, 4vw, 3rem); }
}
@media (max-width: 480px) {
  .home-team__grid { grid-template-columns: 1fr 1fr; }
  .team-card__body { padding: var(--s-3) var(--s-3) var(--s-4); }
  .team-card__name { font-size: var(--t-lg); margin-bottom: var(--s-1); }
  .team-card__role { font-size: 0.55rem; letter-spacing: 0.1em; }
}

/* ── [5] Client Pathways — Immersive cards ───────────────── */
.home-pathways {
  background: var(--white); padding-top: clamp(2.5rem, 5vw, 5rem);
  padding-bottom: 0;
}

/* Asymmetric header */
.home-pathways__header {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 6vw, 6rem); align-items: end;
  padding-bottom: var(--s-12);
  margin-inline: clamp(1.25rem, 4vw, 3rem);
}
.home-pathways__title {
  font-family: var(--serif); font-size: var(--t-4xl); font-weight: 400;
  color: var(--navy); line-height: 1.1; letter-spacing: -0.02em;
}
.home-pathways__title em { font-style: italic; color: var(--gold-dim); }
.home-pathways__header-right p {
  font-size: var(--t-base); color: var(--gray); line-height: 1.8;
}

/* Cards grid — full browser width, no container */
.pathways-cards {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1px; background: var(--border-light);
  margin-top: 0;
}

.pathway-card {
  position: relative; overflow: hidden;
  padding: clamp(2.5rem, 5vw, 4rem) clamp(2rem, 4vw, 3.5rem);
  min-height: 560px;
  display: flex; flex-direction: column;
  transition: background var(--ease);
}
.pathway-card--light { background: var(--white); }
.pathway-card--dark  { background: var(--navy); }
.pathway-card--tone  { background: var(--ivory); }

/* Large background numeral */
.pathway-card__num {
  position: absolute; bottom: 1.5rem; right: 2rem;
  font-family: var(--serif);
  font-size: clamp(6rem, 10vw, 12rem);
  font-weight: 700; line-height: 0.85; letter-spacing: -0.05em;
  color: rgba(11,31,58,0.08);
  pointer-events: none; user-select: none;
}
.pathway-card--dark .pathway-card__num { color: rgba(255,255,255,0.07); }

.pathway-card__inner {
  display: flex; flex-direction: column; gap: var(--s-5);
  flex: 1; position: relative; z-index: 1;
}
.pathway-card__tag {
  font-size: var(--t-xs); font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--gold); opacity: 0.8;
}
.pathway-card__title {
  font-family: var(--serif); font-size: var(--t-3xl); font-weight: 400;
  color: var(--navy); line-height: 1.1;
}
.pathway-card--dark .pathway-card__title { color: var(--ivory); }

.pathway-card__rule {
  width: 28px; height: 1px;
  background: var(--gold); opacity: 0.55;
}
.pathway-card__desc {
  font-size: var(--t-sm); color: var(--gray); line-height: 1.85; flex: 1;
}
.pathway-card--dark .pathway-card__desc { color: rgba(244,239,230,0.55); }

.pathway-card__list {
  list-style: none; display: flex; flex-direction: column; gap: var(--s-2);
}
.pathway-card__list li {
  font-size: var(--t-sm); color: var(--charcoal);
  display: flex; align-items: flex-start; gap: var(--s-3); line-height: 1.4;
}
.pathway-card__list li::before {
  content: '—'; color: var(--gold); opacity: 0.6; flex-shrink: 0;
  font-size: 0.7em; margin-top: 0.25em;
}
.pathway-card--dark .pathway-card__list li { color: rgba(244,239,230,0.5); }

.pathway-card__cta {
  margin-top: auto; padding-top: var(--s-8); align-self: flex-start;
  border-bottom: none;
}
.pathway-card__cta:hover { border-bottom: none; }
.pathway-card--dark .pathway-card__cta { color: var(--gold); }
.pathway-card--dark .pathway-card__cta:hover { color: var(--ivory); }

/* ── [5] About Preview — Editorial Portrait ──────────────── */
.home-about {
  background: var(--white); padding-block: var(--s-section);
  overflow: hidden; position: relative;
}
/* Large faint bg text */
.home-about__bg-text {
  position: absolute; right: -2%; top: 50%;
  transform: translateY(-50%);
  font-family: var(--serif); font-size: clamp(10rem, 18vw, 20rem);
  font-weight: 700; color: rgba(11,31,58,0.025);
  line-height: 1; letter-spacing: 0.1em;
  pointer-events: none; user-select: none;
}
.home-about__inner {
  display: grid; grid-template-columns: 0.75fr 1fr;
  gap: clamp(3rem, 7vw, 7rem); align-items: center;
  position: relative; z-index: 1;
}
/* Portrait column (now LEFT) */
.home-about__image-col { position: relative; }
.home-about__portrait {
  width: 100%; aspect-ratio: 3/4; overflow: hidden; background: var(--ivory);
  position: relative;
}
.home-about__portrait img {
  width: 100%; height: 100%; object-fit: cover; object-position: top center;
  transition: transform var(--ease-slow);
}
.home-about__portrait:hover img { transform: scale(1.03); }
.home-about__portrait-placeholder {
  width: 100%; height: 100%; background: var(--ivory);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--serif); font-size: clamp(5rem, 10vw, 9rem);
  font-weight: 400; color: rgba(198,168,107,0.18); letter-spacing: 0.1em;
}
/* Portrait caption */
.home-about__portrait-caption {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(11,31,58,0.85));
  padding: var(--s-8) var(--s-5) var(--s-5);
  display: flex; flex-direction: column; gap: 3px;
}
.home-about__portrait-name {
  font-family: var(--serif); font-size: var(--t-xl); font-weight: 400;
  color: var(--ivory); letter-spacing: 0.02em;
}
.home-about__portrait-role {
  font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--gold); opacity: 0.85;
}
/* Gold corner accent */
.home-about__image-col::after {
  content: ''; position: absolute; bottom: -20px; right: -20px;
  width: 45%; height: 45%; border: 1px solid rgba(198,168,107,0.18); z-index: -1;
}
/* Text column */
.home-about__text-col { display: flex; flex-direction: column; }
.home-about__eyebrow { display: block; margin-bottom: var(--s-4); }
.home-about__name {
  font-family: var(--serif); font-size: var(--t-5xl); font-weight: 400;
  color: var(--navy); line-height: 1.0; letter-spacing: -0.03em; margin-bottom: var(--s-5);
}
.home-about__name em { font-style: italic; color: var(--gold-dim); display: block; }
.home-about__gold-rule {
  width: 40px; height: 1px; background: var(--gold); margin-bottom: var(--s-7);
}
.home-about__bio { font-size: var(--t-base); color: var(--gray); line-height: 1.8; margin-bottom: var(--s-4); }

/* Credential tags */
.home-about__creds {
  display: flex; flex-wrap: wrap; gap: var(--s-2); margin-bottom: var(--s-2);
}
.home-about__cred-tag {
  font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--navy);
  border: 1px solid var(--border); padding: var(--s-1) var(--s-3);
  transition: all var(--ease-fast);
}
.home-about__cred-tag:hover { border-color: var(--gold); color: var(--gold-dim); }

/* ── [6] Process — Interactive step panels ───────────────── */
.home-process {
  background: var(--white);
  padding-top: var(--s-section);
  padding-bottom: clamp(3rem, 6vw, 5rem);
  border-top: 1px solid var(--border-light);
}

/* Header */
.home-process__header {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 6vw, 6rem); align-items: end;
  margin-bottom: var(--s-12);
}
.home-process__eyebrow { display: block; margin-bottom: var(--s-4); }
.home-process__title {
  font-family: var(--serif); font-size: var(--t-4xl); font-weight: 400;
  color: var(--navy); line-height: 1.1;
}
.home-process__title em { font-style: italic; color: var(--gold-dim); }
.home-process__header-right p {
  font-size: var(--t-base); color: var(--gray); line-height: 1.8;
}

/* Step selector nav */
.process-nav {
  display: flex; align-items: stretch;
  border: 1px solid var(--border-light);
  position: relative; overflow: hidden;
}
.process-nav__item {
  flex: 1; display: flex; flex-direction: column; align-items: center;
  gap: var(--s-2); padding: var(--s-5) var(--s-3);
  border: none; background: transparent; cursor: pointer;
  border-right: 1px solid var(--border-light);
  transition: background var(--ease-fast), color var(--ease-fast);
}
.process-nav__item:last-of-type { border-right: none; }
.process-nav__num {
  font-family: var(--serif); font-size: var(--t-xl); font-weight: 400;
  color: rgba(198,168,107,0.35); line-height: 1;
  transition: color var(--ease-fast);
}
.process-nav__label {
  font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--gray-muted);
  transition: color var(--ease-fast);
}
.process-nav__item:hover { background: var(--ivory); }
.process-nav__item:hover .process-nav__num { color: var(--gold); }
.process-nav__item:hover .process-nav__label { color: var(--navy); }
.process-nav__item.active { background: var(--navy); }
.process-nav__item.active .process-nav__num { color: var(--gold); }
.process-nav__item.active .process-nav__label { color: var(--ivory); }

/* Auto-advance progress bar */
.process-nav__progress {
  position: absolute; bottom: 0; left: 0; right: 0; height: 2px;
  background: transparent; pointer-events: none;
}
.process-nav__progress-fill {
  height: 100%; width: 0%; background: rgba(198,168,107,0.25);
  transition: width linear;
}

/* Content panels — open, no box */
.process-panels {
  position: relative; overflow: hidden;
}
.process-panel {
  display: none; grid-template-columns: clamp(80px, 15vw, 200px) 1fr clamp(120px, 18vw, 220px);
  gap: clamp(2rem, 5vw, 5rem); align-items: center;
  padding: clamp(2.5rem, 5vw, 4rem) 0;
  animation: fadeInUp 0.35s ease both;
}
.process-panel.active { display: grid; }

/* Large decorative number */
.process-panel__num {
  font-family: var(--serif); font-size: clamp(5rem, 10vw, 10rem);
  font-weight: 400; color: rgba(198,168,107,0.18);
  line-height: 1; letter-spacing: -0.04em;
  user-select: none;
}
.process-panel__body { display: flex; flex-direction: column; gap: var(--s-5); }
.process-panel__tag {
  font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--gold); opacity: 0.75;
}
.process-panel__title {
  font-family: var(--serif); font-size: var(--t-3xl); font-weight: 400;
  color: var(--navy); line-height: 1.1;
}
.process-panel__desc {
  font-size: var(--t-base); color: var(--gray); line-height: 1.85;
  max-width: 55ch;
}

/* Right column — step info + dots */
.process-panel__step-info {
  display: flex; flex-direction: column;
  align-items: flex-end; gap: var(--s-4);
  padding-left: var(--s-6);
}
.process-panel__step-count {
  font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--gray-muted);
  writing-mode: vertical-rl; transform: rotate(180deg);
}
.process-panel__dots {
  display: flex; flex-direction: column; gap: var(--s-2);
}
.process-panel__dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--border); transition: background var(--ease-fast);
}
.process-panel__dot.active { background: var(--gold); transform: scale(1.4); }
.process-panel__cta:hover { border-bottom-color: transparent; }

/* ── [7] Blog — Editorial Journal ────────────────────────── */
.home-journal {
  background: var(--white); padding-block: var(--s-section);
}
.home-journal__header {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: var(--s-6); margin-bottom: var(--s-12);
}
.home-journal__eyebrow { display: block; margin-bottom: var(--s-3); }
.home-journal__title {
  font-family: var(--serif); font-size: var(--t-4xl); font-weight: 400; color: var(--navy);
}

/* Cards grid — adapts by post count */
.journal-cards {
  display: grid; gap: clamp(1.5rem, 3vw, 2.5rem);
  grid-template-columns: repeat(3, 1fr);
}
.journal-cards--1 { grid-template-columns: 1fr 1fr; }
.journal-cards--1 .jcard { grid-column: 1; }
.journal-cards--2 { grid-template-columns: 1fr 1fr; }

/* Base card */
.jcard {
  display: flex; flex-direction: column;
  text-decoration: none; position: relative;
  transition: transform var(--ease-fast);
}
.jcard:hover { transform: translateY(-3px); }

.jcard__image {
  overflow: hidden; aspect-ratio: 3/2;
  background: var(--ivory); position: relative; margin-bottom: var(--s-5);
}
.jcard__image img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.5s ease;
}
.jcard:hover .jcard__image img { transform: scale(1.04); }

.jcard__placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--serif); font-size: clamp(3rem, 6vw, 5rem);
  color: rgba(198,168,107,0.18); letter-spacing: 0.1em;
}

.jcard__body { display: flex; flex-direction: column; flex: 1; gap: var(--s-3); }

.jcard__meta {
  display: flex; align-items: center; gap: var(--s-3);
}
.jcard__cat {
  font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--gold);
}
.jcard__time {
  font-size: var(--t-xs); color: var(--gray-muted);
  font-weight: 500; letter-spacing: 0.05em;
}
.jcard__time::before { content: '·'; margin-right: var(--s-2); opacity: 0.4; }

.jcard__title {
  font-family: var(--serif); font-size: var(--t-xl); font-weight: 400;
  color: var(--navy); line-height: 1.25;
  transition: color var(--ease-fast);
}
.jcard:hover .jcard__title { color: var(--gold-dim); }

.jcard__excerpt {
  font-size: var(--t-sm); color: var(--gray); line-height: 1.8;
}

.jcard__footer {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: auto; padding-top: var(--s-4);
  border-top: 1px solid var(--border-light);
}
.jcard__date {
  font-size: var(--t-xs); color: var(--gray-muted); letter-spacing: 0.04em;
}
.jcard__read {
  display: inline-flex; align-items: center; gap: var(--s-2);
  font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--navy);
  transition: color var(--ease-fast), gap var(--ease-fast);
}
.jcard:hover .jcard__read { color: var(--gold); gap: var(--s-3); }

/* Featured card — larger image + excerpt visible */
.jcard--featured .jcard__image { aspect-ratio: 16/10; }
.jcard--featured .jcard__title { font-size: var(--t-2xl); }

/* ── Pagina Consultație ──────────────────────────────────── */
/* ── Consultation page ───────────────────────────────────── */

/* Hero */
.consult-hero {
  background: var(--navy);
  padding-top: calc(76px + clamp(2.5rem, 5vw, 3.5rem));
  padding-bottom: clamp(2.5rem, 5vw, 3.5rem);
  position: relative; overflow: hidden;
}
.consult-hero::after {
  content: '';
  position: absolute; bottom: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(198,168,107,0.35) 30%, rgba(198,168,107,0.35) 70%, transparent);
}
.consult-hero__watermark {
  position: absolute; right: -2%; bottom: -20%;
  font-family: var(--serif); font-size: clamp(7rem, 16vw, 14rem);
  font-weight: 400; color: rgba(244,239,230,0.04);
  letter-spacing: -0.04em; line-height: 0.85;
  pointer-events: none; user-select: none;
}
.consult-hero .container { text-align: center; }
.consult-hero__eyebrow {
  color: rgba(198,168,107,0.75); margin-bottom: var(--s-3);
}
.consult-hero__title {
  font-family: var(--serif);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 300; color: var(--ivory);
  line-height: 1.1; letter-spacing: -0.02em;
  margin-bottom: var(--s-4);
}
.consult-hero__sub {
  font-size: var(--t-sm); color: rgba(244,239,230,0.5);
  line-height: 1.75; max-width: 56ch;
  margin-inline: auto;
}

/* Body */
.consult-body {
  padding-block: clamp(4rem, 8vw, 7rem);
  background: var(--white);
}

/* Form container */
.consult-form {
  max-width: 860px;
  margin-inline: auto;
}

/* Checkbox group */
.cform-checks {
  display: flex; flex-direction: column; gap: var(--s-4);
}

/* Meeting toggle label */
.consult-meeting-label {
  font-size: var(--t-xs); font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--gray-muted); margin-bottom: var(--s-3);
}
.consult-meeting-label span { color: var(--gold); }

/* Meeting toggle cards */
.consult-meeting {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-4);
}

.consult-meeting__input { position: absolute; opacity: 0; width: 0; height: 0; }
.consult-meeting__card { cursor: pointer; display: flex; flex-direction: column; }

.consult-meeting__face {
  display: flex; align-items: center; gap: var(--s-4);
  padding: var(--s-5) var(--s-6);
  flex: 1;
  border: 1px solid var(--border);
  transition: border-color 0.25s var(--ease), background 0.25s var(--ease), box-shadow 0.25s var(--ease);
}
.consult-meeting__card:hover .consult-meeting__face {
  border-color: rgba(198,168,107,0.6);
  background: rgba(198,168,107,0.04);
  box-shadow: 0 4px 16px rgba(11,31,58,0.06);
}
.consult-meeting__input:checked + .consult-meeting__face {
  border-color: var(--gold);
  background: rgba(198,168,107,0.06);
}

.consult-meeting__icon {
  color: var(--gold); flex-shrink: 0; opacity: 0.6;
  transition: opacity var(--ease-fast);
}
.consult-meeting__card:hover .consult-meeting__icon { opacity: 0.85; }
.consult-meeting__input:checked + .consult-meeting__face .consult-meeting__icon { opacity: 1; }

.consult-meeting__title {
  font-family: var(--serif); font-size: var(--t-base); font-weight: 400;
  color: var(--navy); display: block; line-height: 1.2; margin-bottom: 2px;
}
.consult-meeting__sub {
  font-size: var(--t-xs); color: var(--gray-muted); display: block;
}

/* Wide submit */
.cform-submit--wide {
  width: 100%; justify-content: center;
  padding: 1.25rem 3rem;
  font-size: var(--t-sm);
}

/* Error banner */
.consult-form__error {
  background: rgba(200,50,50,0.06); border-left: 3px solid #c83232;
  padding: var(--s-4) var(--s-5); font-size: var(--t-sm);
  color: #a02020; margin-bottom: var(--s-8);
}

/* Success state */
.consult-success {
  max-width: 520px; margin-inline: auto;
  text-align: center; padding: clamp(4rem, 8vw, 7rem) 0;
}
.consult-success__icon { color: var(--gold); margin-bottom: var(--s-6); }
.consult-success__title {
  font-family: var(--serif); font-size: var(--t-3xl); font-weight: 300;
  color: var(--navy); margin-bottom: var(--s-5);
}
.consult-success__text { font-size: var(--t-base); color: var(--gray); line-height: 1.8; }

@media (max-width: 640px) {
  .consult-hero { padding-top: calc(76px + clamp(1rem, 3vw, 1.5rem)); padding-bottom: clamp(1rem, 3vw, 1.5rem); }
  .consult-body { padding-top: clamp(1.5rem, 4vw, 2.5rem); }
  .consult-meeting { grid-template-columns: 1fr; gap: var(--s-3); }
  .consult-hero__title { font-size: clamp(1.75rem, 8vw, 2.5rem); }
  .cform-section__num { font-size: var(--t-2xl); }
}

/* ── [8] Final CTA ───────────────────────────────────────── */
.home-cta {
  background: var(--navy); padding-block: var(--s-section);
  text-align: center; position: relative; overflow: hidden;
}
.home-cta::before { display: none; }
/* Background image overlay (replaces the DVA monogram) */
.home-cta__bg-image {
  position: absolute; inset: 0;
  background-size: auto 70%;
  background-position: left bottom;
  background-repeat: no-repeat;
  pointer-events: none;
  transition: opacity 0.3s ease;
}
.home-cta__eyebrow { display: block; margin-bottom: var(--s-5); position: relative; z-index: 1; }
.home-cta__title {
  font-family: var(--serif); font-size: clamp(2.25rem, 4.5vw, 4rem);
  font-weight: 400; color: var(--ivory); line-height: 1.15;
  max-width: 28ch; margin: 0 auto var(--s-6); position: relative; z-index: 1;
}
.home-cta__sub {
  font-size: var(--t-md); color: rgba(244,239,230,0.55);
  max-width: 50ch; margin: 0 auto var(--s-10);
  line-height: 1.7; position: relative; z-index: 1;
}
.home-cta__actions {
  display: flex; gap: var(--s-4); justify-content: center;
  flex-wrap: wrap; position: relative; z-index: 1;
}

/* ════════════════════════════════════════════════════════════
   ABOUT PAGE — EDITORIAL PROFILE
   ════════════════════════════════════════════════════════════ */
/* Hero — split text / image */
.about-hero {
  background: var(--white);
  position: relative;
  overflow: hidden;
}
.about-hero__watermark {
  position: absolute; left: 0; bottom: -10%;
  font-family: var(--serif); font-size: clamp(12rem, 22vw, 20rem);
  font-weight: 400; letter-spacing: -0.06em; color: rgba(198,168,107,0.04);
  line-height: 0.9; pointer-events: none; user-select: none; z-index: 0;
}
.about-hero__top {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: calc(100vh - 84px);
}
.about-hero__text-col {
  position: relative; z-index: 1;
  padding-left: clamp(1.25rem, 4vw, 3rem);
  padding-right: clamp(2.5rem, 5vw, 5rem);
  padding-top: clamp(2.5rem, 5vw, 4rem);
  padding-bottom: clamp(2.5rem, 5vw, 4rem);
  display: flex; align-items: center;
}
.about-hero__inner { max-width: 520px; }
.about-hero__eyebrow { display: block; margin-bottom: var(--s-4); }
.about-hero__title {
  font-family: var(--serif); font-size: clamp(1.75rem, 3.5vw, 3rem); font-weight: 500;
  color: var(--navy); line-height: 1.1; letter-spacing: -0.025em; margin-bottom: var(--s-5);
}
.about-hero__lead {
  font-size: var(--t-base); color: var(--gray); line-height: 1.75;
  margin-bottom: var(--s-3);
}
.about-hero__lead:last-child { margin-bottom: 0; }
.about-hero__img-col {
  overflow: hidden; position: relative;
}
.about-hero__img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center top;
  display: block;
}

/* Fallback when no image: text col spans full width */
.about-hero__top:not(:has(.about-hero__img-col)) {
  grid-template-columns: 1fr;
}
.about-hero__top:not(:has(.about-hero__img-col)) .about-hero__text-col {
  padding-right: clamp(1.25rem, 4vw, 3rem);
}
.about-hero__top:not(:has(.about-hero__img-col)) .about-hero__inner {
  max-width: 800px;
}

/* Pull-quote band */
.about-pullquote {
  background: var(--navy); padding-block: var(--s-section-sm);
}
.about-pullquote__inner { display: flex; align-items: center; gap: clamp(2rem, 5vw, 5rem); }
.about-pullquote__rule { width: 40px; height: 1px; background: var(--gold); opacity: 0.6; flex-shrink: 0; }
.about-pullquote__text {
  font-family: var(--serif); font-size: clamp(1.1rem, 2vw, 1.625rem);
  font-weight: 400; font-style: italic; color: var(--ivory); line-height: 1.55;
  flex: 1;
}
.about-pullquote__cite {
  display: block; margin-top: var(--s-4); font-size: var(--t-xs); font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--gold);
  font-style: normal; font-family: var(--sans);
}

/* Zigzag member profiles */
.about-members { background: var(--white); }

.about-member {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: clamp(480px, 62vh, 760px);
}

/* Default: image left, text right */
.about-member__text  { order: 2; }
.about-member__image { order: 1; }

/* Reverse: text left, image right */
.about-member--reverse .about-member__text  { order: 1; }
.about-member--reverse .about-member__image { order: 2; }

.about-member__text {
  background: var(--cream);
  display: flex;
  align-items: center;
  padding: clamp(3rem, 6vw, 6rem) clamp(1.5rem, 3vw, 3rem) clamp(3rem, 6vw, 6rem) clamp(2.5rem, 5vw, 5.5rem);
}

.about-member__text-inner { width: 100%; }

.about-member__eyebrow {
  display: block;
  margin-bottom: var(--s-5);
  color: var(--gold);
}

.about-member__name {
  font-family: var(--serif);
  font-size: clamp(2rem, 3.5vw, 3rem);
  font-weight: 300;
  color: var(--navy);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin-bottom: var(--s-6);
}

.about-member__bio {
  font-size: var(--t-base);
  color: var(--gray);
  line-height: 1.85;
}
.about-member__bio p { margin-top: 0; margin-bottom: 1.25em; }
.about-member__bio p + p { margin-top: 0; }
.about-member__bio p:last-child { margin-bottom: 0; }

.about-member__image {
  position: relative;
  overflow: hidden;
  background: var(--navy);
}

.about-member__image img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: top center;
  display: block;
}

.about-member__placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--serif); font-size: var(--t-4xl);
  font-weight: 300; color: rgba(198,168,107,0.2); letter-spacing: 0.08em;
}

@media (max-width: 768px) {
  .about-hero__top { grid-template-columns: 1fr; min-height: 0; }
  .about-hero__text-col {
    padding-left: clamp(1.25rem, 4vw, 3rem);
    padding-right: clamp(1.25rem, 4vw, 3rem);
    padding-bottom: clamp(2rem, 5vw, 3rem);
  }
  .about-hero__img-col { min-height: 280px; aspect-ratio: 4 / 3; }
  .about-member { grid-template-columns: 1fr; }
  /* Single column — all members: image on top, text below */
  .about-member--reverse .about-member__text  { order: 2; }
  .about-member--reverse .about-member__image { order: 1; }
  .about-member__image { min-height: 340px; }
  .about-member__text { padding-inline: clamp(1.25rem, 4vw, 3rem); }
}

/* Mission & Vision — full-bleed split */
.about-mv { position: relative; }
.about-mv__inner {
  display: grid; grid-template-columns: 1fr 1fr;
  height: calc(100vh * 2 / 3);
}
.about-mv__col {
  display: flex; align-items: center;
  padding: clamp(3.5rem, 7vw, 6rem) clamp(3rem, 6vw, 6rem);
}
.about-mv__col--mission { background: var(--navy); }
.about-mv__col--vision  { background: var(--navy); border-left: 1px solid rgba(198,168,107,0.15); }

.about-mv__col-inner { max-width: 520px; }

.about-mv__eyebrow { display: block; margin-bottom: var(--s-5); }
.about-mv__col--mission .about-mv__eyebrow { color: var(--gold); }
.about-mv__col--vision  .about-mv__eyebrow { color: var(--gold); }

.about-mv__title {
  font-family: var(--serif); font-size: clamp(1.5rem, 2.5vw, 2.25rem);
  font-weight: 400; line-height: 1.2; margin-bottom: var(--s-6);
}
.about-mv__col--mission .about-mv__title { color: var(--ivory); }
.about-mv__col--vision  .about-mv__title { color: var(--ivory); }

.about-mv__rule {
  width: 36px; height: 1px; background: var(--gold);
  opacity: 0.6; margin-bottom: var(--s-6);
}

.about-mv__text { font-size: var(--t-base); line-height: 1.85; }
.about-mv__col--mission .about-mv__text { color: rgba(244,239,230,0.6); }
.about-mv__col--vision  .about-mv__text { color: rgba(244,239,230,0.6); }

@media (max-width: 768px) {
  .about-mv__inner { grid-template-columns: 1fr; height: auto; }
  .about-mv__col--vision { border-left: none; border-top: 1px solid rgba(198,168,107,0.15); }
  .about-mv__col { padding-inline: clamp(1.25rem, 4vw, 3rem); }
}

/* Biography section */
.about-biography {
  background: var(--ivory); padding-block: var(--s-section);
}
.about-biography__inner {
  display: grid; grid-template-columns: 0.75fr 1.25fr;
  gap: clamp(3rem, 7vw, 7rem); align-items: start;
}
.about-biography__portrait-col { position: relative; }
.about-biography__portrait {
  aspect-ratio: 3/4; overflow: hidden; background: var(--cream);
}
.about-biography__portrait img {
  width: 100%; height: 100%; object-fit: cover; object-position: top;
}
.about-biography__portrait-blank {
  width: 100%; height: 100%; background: var(--ivory);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--serif); font-size: 8rem; font-weight: 400;
  color: rgba(198,168,107,0.2); letter-spacing: 0.1em;
}
.about-biography__portrait-accent {
  position: absolute; bottom: -1.25rem; right: -1.25rem;
  width: 55%; height: 55%; border: 1px solid rgba(198,168,107,0.2); z-index: -1;
}
.about-biography__content-col {}
.about-biography__name {
  font-family: var(--serif); font-size: var(--t-4xl); font-weight: 500;
  letter-spacing: -0.02em; color: var(--navy); margin-bottom: var(--s-2);
}
.about-biography__role {
  font-size: var(--t-sm); font-weight: 600; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--gold); display: block; margin-bottom: var(--s-6);
}
.about-biography__rule { width: 40px; height: 1px; background: var(--gold); display: block; margin-bottom: var(--s-6); }
.about-biography__text { font-size: var(--t-md); color: var(--gray); line-height: 1.8; margin-bottom: var(--s-4); }
.about-biography__credentials {
  margin-top: var(--s-8); padding-top: var(--s-8);
  border-top: 1px solid var(--border); display: flex; flex-direction: column; gap: var(--s-4);
}
.about-credential { display: grid; grid-template-columns: 140px 1fr; gap: var(--s-4); align-items: baseline; font-size: var(--t-base); }
.about-credential__key { font-size: var(--t-xs); font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; color: var(--gold); }
.about-credential__val { color: var(--charcoal); font-size: var(--t-base); }

/* Values — editorial statements */
.about-values { background: var(--white); padding-block: var(--s-section); }
.about-values__inner { display: grid; grid-template-columns: 0.45fr 1fr; gap: clamp(3rem, 7vw, 7rem); align-items: start; }
.about-values__left-col { position: sticky; top: 105px; }
.about-values__list { display: flex; flex-direction: column; gap: 0; }
.value-statement { padding: var(--s-6) 0; border-top: 1px solid var(--border); display: grid; grid-template-columns: 56px 1fr; gap: var(--s-5); align-items: start; }
.value-statement:first-child { border-top: none; }
.value-statement:last-child { border-bottom: none; }
.value-statement__num { font-family: var(--serif); font-size: var(--t-2xl); font-weight: 400; color: rgba(198,168,107,0.45); line-height: 1; padding-top: 4px; min-width: 2.5ch; }
.value-statement__title { font-family: var(--serif); font-size: var(--t-xl); font-weight: 500; color: var(--navy); margin-bottom: var(--s-3); }
.value-statement__text { font-size: var(--t-base); color: var(--gray); line-height: 1.8; }

/* Experience timeline */
.about-timeline { background: var(--white); padding-block: var(--s-section); }
.about-timeline__inner { display: grid; grid-template-columns: 0.4fr 1fr; gap: clamp(3rem, 6vw, 6rem); align-items: start; }
.about-timeline__heading-col { position: sticky; top: 105px; }
.about-timeline__track { display: flex; flex-direction: column; gap: 0; }
.timeline-entry { display: grid; grid-template-columns: 56px 1fr; gap: var(--s-5); padding: var(--s-6) 0; border-bottom: 1px solid var(--border); position: relative; transition: padding-left var(--ease-fast); }
.timeline-entry:first-child { border-top: 1px solid var(--border); }
.timeline-entry:hover { padding-left: var(--s-3); }
.timeline-entry::before { content: ''; position: absolute; left: 80px; top: 50%; width: var(--s-4); height: 1px; background: var(--gold); opacity: 0; transition: opacity var(--ease-fast); }
.timeline-entry:hover::before { opacity: 1; }
.timeline-entry__year { font-family: var(--serif); font-size: var(--t-xl); font-weight: 400; color: rgba(198,168,107,0.45); line-height: 1; padding-top: 4px; }
.timeline-entry__title { font-family: var(--serif); font-size: var(--t-md); font-weight: 600; color: var(--navy); margin-bottom: var(--s-2); letter-spacing: -0.01em; }
.timeline-entry__desc { font-size: var(--t-base); color: var(--gray); line-height: 1.75; }

/* ════════════════════════════════════════════════════════════
   SERVICES PAGE — LEGAL ATLAS
   ════════════════════════════════════════════════════════════ */
.services-hero {
  background: var(--white); padding-top: calc(76px + clamp(4rem, 8vw, 7rem));
  padding-bottom: clamp(3rem, 6vw, 5rem); position: relative; overflow: hidden;
  border-bottom: 1px solid var(--border-light);
}
.services-hero__watermark {
  position: absolute; right: -2%; top: 50%; transform: translateY(-50%);
  font-family: var(--serif); font-size: clamp(14rem, 24vw, 22rem);
  font-weight: 400; color: rgba(198,168,107,0.045); letter-spacing: -0.06em; line-height: 0.9; pointer-events: none; user-select: none;
}
.services-hero__inner { max-width: 100%; position: relative; z-index: 1; }
.services-hero__inner .page-hero__title { max-width: none; }
/* ── Services Intro ──────────────────────────────────────── */
.services-intro { background: var(--white); padding-top: clamp(4rem, 7vw, 6rem); overflow: hidden; }
.services-intro__grid {
  display: grid; grid-template-columns: 1fr 1.1fr;
  gap: clamp(3rem, 6vw, 7rem); align-items: start;
  padding-bottom: clamp(3rem, 5vw, 4.5rem);
  border-bottom: 1px solid var(--border-light);
}
.services-intro__title {
  font-family: var(--serif); font-size: clamp(1.9rem, 3.2vw, 3.2rem);
  font-weight: 400; color: var(--navy); line-height: 1.2;
  margin-top: var(--s-4);
}
.services-intro__right p { font-size: var(--t-base); color: var(--gray); line-height: 1.85; margin-bottom: var(--s-4); }
.services-intro__right p:last-child { margin-bottom: 0; }

/* Full-width ivory features bar */
.services-features-bar { background: var(--ivory); border-top: 1px solid var(--border-light); border-bottom: 1px solid var(--border-light); }
.services-features-bar__inner {
  display: grid; grid-template-columns: repeat(3, 1fr);
}
.services-feature-item {
  display: flex; gap: var(--s-5); align-items: flex-start;
  padding: clamp(2rem, 3.5vw, 3rem) clamp(2rem, 3vw, 3rem);
  border-right: 1px solid var(--border-light);
  border-bottom: 1px solid var(--border-light);
  font-size: var(--t-base); color: var(--charcoal);
  line-height: 1.6;
  transition: background var(--ease-fast);
}
.services-feature-item:hover { background: var(--white); }
.services-feature-item__num {
  font-family: var(--serif); font-size: 1.3rem;
  color: var(--gold); opacity: 0.7; flex-shrink: 0; line-height: 1.4;
  transition: opacity var(--ease-fast);
}
.services-feature-item:hover .services-feature-item__num { opacity: 1; }

/* ── Services Checkerboard Grid ──────────────────────────── */
.svc-grid-section { background: var(--white); }

.svc-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
}

/* Each card */
.svc-card {
  position: relative; overflow: hidden;
  padding: clamp(3.5rem, 6vw, 6rem) clamp(3rem, 5vw, 5.5rem);
  min-height: clamp(340px, 40vw, 480px);
  display: flex; flex-direction: column; justify-content: flex-end;
  transition: filter var(--ease-fast);
}
.svc-card--full { grid-column: span 2; min-height: clamp(260px, 25vw, 340px); }

/* Light variant */
.svc-card--light { background: var(--ivory); }
.svc-card--light .svc-card__num    { color: rgba(198,168,107,0.5); }
.svc-card--light .svc-card__tagline { color: var(--gold); }
.svc-card--light .svc-card__title  { color: var(--navy); }
.svc-card--light .svc-card__desc   { color: var(--gray); }
.svc-card--light .svc-card__link   { color: var(--navy); border-color: rgba(10,25,56,0.25); }
.svc-card--light .svc-card__link:hover { background: var(--navy); color: var(--ivory); border-color: var(--navy); }
.svc-card--light .svc-card__bg-num { color: rgba(10,25,56,0.09); }

/* Dark variant */
.svc-card--dark { background: var(--navy); }
.svc-card--dark .svc-card__num    { color: rgba(198,168,107,0.45); }
.svc-card--dark .svc-card__tagline { color: var(--gold); opacity: 0.8; }
.svc-card--dark .svc-card__title  { color: var(--ivory); }
.svc-card--dark .svc-card__desc   { color: rgba(244,239,230,0.5); }
.svc-card--dark .svc-card__link   { color: var(--gold); border-color: rgba(198,168,107,0.35); }
.svc-card--dark .svc-card__link:hover { background: var(--gold); color: var(--navy); border-color: var(--gold); }
.svc-card--dark .svc-card__bg-num { color: rgba(255,255,255,0.08); }

/* Decorative huge background number */
.svc-card__bg-num {
  position: absolute; bottom: 1.5rem; right: 2rem;
  font-family: var(--serif); font-size: clamp(7rem, 12vw, 14rem);
  font-weight: 700; line-height: 1;
  pointer-events: none; user-select: none; letter-spacing: -0.06em;
}

/* Card content */
.svc-card__inner { position: relative; z-index: 1; }
.svc-card__num {
  display: block; font-family: var(--sans); font-size: 0.72rem;
  font-weight: 700; letter-spacing: 0.18em;
  margin-bottom: var(--s-4);
}
.svc-card__tagline {
  font-size: var(--t-xs); letter-spacing: 0.08em;
  margin-bottom: var(--s-3); opacity: 0.85;
}
.svc-card__title {
  font-family: var(--serif); font-size: clamp(1.75rem, 3vw, 3rem);
  font-weight: 400; line-height: 1.1;
  margin-bottom: var(--s-5);
}
.svc-card__desc {
  font-size: var(--t-sm); line-height: 1.8;
  margin-bottom: var(--s-8); max-width: 44ch;
}
.svc-card--full .svc-card__desc { max-width: 60ch; }

.svc-card__link {
  display: inline-flex; align-items: center; gap: var(--s-3);
  font-size: var(--t-xs); font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
  padding: 0.75em 1.5em; border: 1px solid;
  transition: background var(--ease-fast), color var(--ease-fast), border-color var(--ease-fast);
}
.svc-card__link svg { transition: transform var(--ease-fast); }
.svc-card__link:hover svg { transform: translateX(3px); }

.svc-grid__footer {
  padding: clamp(3rem, 5vw, 4rem) clamp(3rem, 5vw, 5.5rem);
  background: var(--white);
  border-top: 1px solid var(--border-light);
}

/* ── Interactive Split-screen Panel ─────────────────────── */
.services-panel-section {
  display: grid; grid-template-columns: 280px 1fr;
  min-height: 560px;
  border-top: 1px solid var(--border-light);
}

/* Left nav — slim dark sidebar */
.services-panel__nav {
  background: var(--navy);
  position: sticky; top: 110px; align-self: start;
  max-height: calc(100vh - 110px); overflow-y: auto;
}
.services-panel__nav-inner {
  padding: clamp(3rem, 5vw, 4.5rem) clamp(2rem, 3vw, 2.5rem);
  display: flex; flex-direction: column; min-height: 500px;
}
.services-panel__eyebrow {
  display: block; margin-bottom: clamp(2rem, 3.5vw, 3rem);
  color: rgba(198,168,107,0.65) !important;
}
.services-panel__list { display: flex; flex-direction: column; flex: 1; gap: var(--s-1); }

.services-panel__btn {
  display: flex; align-items: center; gap: var(--s-5);
  padding: 1.1rem 1rem; background: none; border: none;
  cursor: pointer; text-align: left; width: 100%;
  border-radius: 4px;
  transition: background var(--ease-fast), padding-left var(--ease-fast);
  position: relative;
}
.services-panel__btn::before {
  content: ''; position: absolute; left: 0; top: 15%; bottom: 15%;
  width: 2px; background: var(--gold);
  border-radius: 2px;
  transform: scaleY(0); transform-origin: center;
  transition: transform 0.3s ease;
}
.services-panel__btn.is-active::before { transform: scaleY(1); }
.services-panel__btn.is-active { background: rgba(198,168,107,0.1); padding-left: 1.25rem; }
.services-panel__btn:hover:not(.is-active) { background: rgba(255,255,255,0.04); padding-left: 1.1rem; }

.services-panel__btn-num {
  font-family: var(--serif); font-size: 0.75rem;
  color: rgba(198,168,107,0.3); font-weight: 400; flex-shrink: 0;
  transition: color var(--ease-fast); line-height: 1;
}
.services-panel__btn.is-active .services-panel__btn-num { color: var(--gold); }

.services-panel__btn-name {
  font-family: var(--serif); font-size: 1.15rem; font-weight: 400;
  color: rgba(244,239,230,0.5); flex: 1;
  transition: color var(--ease-fast);
}
.services-panel__btn.is-active .services-panel__btn-name { color: var(--ivory); }
.services-panel__btn:hover .services-panel__btn-name { color: rgba(244,239,230,0.8); }

.services-panel__btn-arrow {
  color: var(--gold); opacity: 0; flex-shrink: 0;
  transition: opacity var(--ease-fast);
}
.services-panel__btn.is-active .services-panel__btn-arrow { opacity: 1; }

.services-panel__nav-bottom { padding-top: var(--s-10); margin-top: auto; }

/* Right content */
.services-panel__content { background: var(--white); position: relative; overflow: hidden; }

.services-panel__pane { display: none; }
.services-panel__pane.is-active {
  display: block;
  animation: spaneIn 0.35s ease both;
}
@keyframes spaneIn {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

.services-panel__pane-inner {
  padding: clamp(4rem, 6vw, 6rem) clamp(4rem, 6vw, 7rem);
}

.services-panel__pane-header {
  display: flex; align-items: flex-end; gap: var(--s-7);
  padding-bottom: clamp(2rem, 3.5vw, 3rem);
  border-bottom: 1px solid var(--border-light);
  margin-bottom: clamp(2.5rem, 4vw, 4rem);
}
.services-panel__pane-num {
  font-family: var(--serif); font-size: clamp(4rem, 6vw, 6rem);
  font-weight: 400; color: rgba(198,168,107,0.15); line-height: 1; flex-shrink: 0;
}
.services-panel__pane-title {
  font-family: var(--serif); font-size: clamp(2rem, 3.2vw, 3.2rem);
  font-weight: 400; color: var(--navy); margin-bottom: var(--s-3); line-height: 1.15;
}
.services-panel__pane-tagline {
  font-size: var(--t-sm); color: var(--gold); letter-spacing: 0.06em; opacity: 0.85;
}

.services-panel__pane-desc {
  font-size: clamp(1rem, 1.2vw, 1.1rem); color: var(--gray); line-height: 1.9;
  margin-bottom: clamp(2.5rem, 4vw, 4rem); max-width: 60ch;
}

.services-panel__pane-situations { margin-bottom: clamp(3rem, 5vw, 4.5rem); }
.services-panel__pane-situations-label {
  font-size: var(--t-xs); font-weight: 700; letter-spacing: 0.15em;
  text-transform: uppercase; color: var(--gold); margin-bottom: var(--s-6);
}
.services-panel__pane-situations ul {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-4); list-style: none;
}
.services-panel__pane-situations li {
  font-size: var(--t-base); color: var(--charcoal);
  display: flex; align-items: center; gap: var(--s-4); padding: var(--s-3) 0;
  border-bottom: 1px solid var(--border-light);
}
.services-panel__pane-situations li::before {
  content: ''; width: 5px; height: 5px; background: var(--gold);
  border-radius: 50%; flex-shrink: 0;
}
.services-panel__pane-actions { display: flex; gap: var(--s-5); align-items: center; flex-wrap: wrap; margin-top: var(--s-2); }

/* ── Services FAQ ────────────────────────────────────────── */
.services-faq { background: var(--white); padding-block: clamp(4rem, 8vw, 7rem); }
.services-faq__inner {
  display: grid; grid-template-columns: 0.6fr 1fr;
  gap: clamp(3rem, 7vw, 8rem); align-items: start;
}
.services-faq__heading { position: sticky; top: 105px; }
.services-faq__title {
  font-family: var(--serif); font-size: clamp(1.75rem, 3vw, 2.75rem);
  font-weight: 400; color: var(--navy); line-height: 1.25; margin-top: var(--s-3);
}
.services-faq__sub {
  font-size: var(--t-sm); color: var(--gray); line-height: 1.8; margin-top: var(--s-5); max-width: 30ch;
}

/* ════════════════════════════════════════════════════════════
   BLOG — EDITORIAL JOURNAL
   ════════════════════════════════════════════════════════════ */
.journal-hero {
  background: var(--white); padding-top: calc(76px + clamp(4rem, 8vw, 7rem));
  padding-bottom: clamp(2.5rem, 5vw, 4rem); border-bottom: 1px solid var(--border);
}
.journal-hero__top {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: var(--s-6); flex-wrap: wrap;
}
.journal-hero__title {
  font-family: var(--serif); font-size: var(--t-7xl); font-weight: 400;
  color: var(--navy); letter-spacing: -0.03em; line-height: 1.0;
}
.journal-hero__issue {
  font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--gray-muted); text-align: right;
}
.journal-hero__issue span { display: block; color: var(--gold); }
/* Category nav */
.journal-cats {
  display: flex; align-items: center; gap: var(--s-2);
  padding-top: var(--s-5); flex-wrap: wrap;
}
.journal-cats__label { font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gray-muted); margin-right: var(--s-3); }
.journal-cat {
  font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase;
  padding: var(--s-2) var(--s-4); border: 1px solid var(--border); color: var(--gray);
  transition: all var(--ease-fast); background: none; cursor: pointer;
}
.journal-cat:hover, .journal-cat.active {
  background: var(--navy); color: var(--ivory); border-color: var(--navy);
}
/* Main grid */
.journal-layout { background: var(--white); padding-block: var(--s-section); }
.journal-main-grid {
  display: grid; grid-template-columns: repeat(12, 1fr); gap: var(--s-6);
}
/* Featured post — large */
.journal-post--featured {
  grid-column: 1 / 8; display: flex; flex-direction: column; gap: var(--s-5);
}
.journal-post--featured .jpost__image { aspect-ratio: 16/10; }
.journal-post--featured .jpost__title {
  font-family: var(--serif); font-size: var(--t-3xl); font-weight: 400;
  color: var(--navy); line-height: 1.2; transition: color var(--ease-fast);
}
/* Secondary posts */
.journal-post--secondary { grid-column: span 5; display: flex; flex-direction: column; gap: var(--s-4); }
.journal-post--secondary .jpost__image { aspect-ratio: 3/2; }
.journal-post--secondary .jpost__title {
  font-family: var(--serif); font-size: var(--t-xl); font-weight: 500;
  color: var(--navy); line-height: 1.25; transition: color var(--ease-fast);
}
/* Tertiary — bottom row */
.journal-post--tertiary {
  grid-column: span 4; display: flex; gap: var(--s-4);
  border-top: 1px solid var(--border); padding-top: var(--s-5);
}
.journal-post--tertiary .jpost__image { flex-shrink: 0; width: 90px; height: 90px; }
.journal-post--tertiary .jpost__title {
  font-family: var(--serif); font-size: var(--t-md); font-weight: 500;
  color: var(--navy); line-height: 1.3; transition: color var(--ease-fast);
}
/* Shared post parts */
.jpost__image { overflow: hidden; background: var(--border-light); position: relative; }
.jpost__image img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--ease-slow); }
.jpost:hover .jpost__image img { transform: scale(1.03); }
.jpost:hover .jpost__title { color: var(--gold-dim); }
.jpost__cat { font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gold); margin-bottom: var(--s-2); display: block; }
.jpost__meta { font-size: var(--t-xs); color: var(--gray-muted); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: var(--s-2); }
.jpost__excerpt { font-size: var(--t-sm); color: var(--gray); line-height: 1.75; margin-top: var(--s-3); }
.jpost__read { display: inline-flex; align-items: center; gap: var(--s-2); font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--navy); margin-top: var(--s-3); transition: color var(--ease-fast), gap var(--ease-fast); }
.jpost:hover .jpost__read { color: var(--gold-dim); gap: var(--s-4); }

/* ════════════════════════════════════════════════════════════
   CONTACT — EDITORIAL REDESIGN
   ════════════════════════════════════════════════════════════ */

/* ── Split layout ── */
.cpage-layout {
  display: grid; grid-template-columns: 420px 1fr;
  height: calc(100vh - 84px);
  overflow: hidden;
}
.cpage-info     { overflow-y: auto; }
.cpage-form-wrap { overflow-y: auto; }

/* ── Info panel (left) ── */
.cpage-info {
  background: var(--ivory); position: relative; overflow: hidden;
  padding: clamp(3rem, 5vw, 5rem) clamp(2rem, 4vw, 4rem);
  display: flex; flex-direction: column;
  border-right: 1px solid var(--border-light);
}
.cpage-info::before { display: none; }
.cpage-info__inner {
  position: relative; z-index: 1;
  display: flex; flex-direction: column; gap: var(--s-8); flex: 1;
}
.cpage-info__heading { }
.cpage-info__eyebrow { display: block; margin-bottom: var(--s-4); color: var(--gold-dim); }
.cpage-info__title {
  font-family: var(--serif); font-size: clamp(2rem, 3.5vw, 3rem);
  font-weight: 500; color: var(--navy); line-height: 1.1;
  letter-spacing: -0.02em;
}
.cpage-info__title em { font-style: italic; color: var(--gold); }
.cpage-info__lead {
  font-size: var(--t-md); color: var(--gray);
  line-height: 1.75; max-width: 36ch;
}
.cpage-info__details {
  display: flex; flex-direction: column; gap: var(--s-6);
  border-top: 1px solid var(--border-light);
  padding-top: var(--s-8);
}
.cpage-info__item {
  display: flex; align-items: flex-start; gap: var(--s-4);
  color: inherit; text-decoration: none;
}
.cpage-info__item-icon {
  width: 32px; height: 32px; display: flex; align-items: center; justify-content: center;
  border: 1px solid rgba(198,168,107,0.4); color: var(--gold); flex-shrink: 0;
  margin-top: 2px;
}
.cpage-info__item-label {
  font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--gray-muted); margin-bottom: 4px;
}
.cpage-info__item-value {
  font-size: var(--t-sm); color: var(--navy); line-height: 1.5;
}
.cpage-info__quote {
  font-family: var(--serif); font-style: italic;
  font-size: clamp(1rem, 1.4vw, 1.15rem); font-weight: 400;
  color: var(--gray-muted); line-height: 1.6;
  margin-top: auto; padding-top: var(--s-8);
  border-top: 1px solid var(--border-light);
}
.cpage-info__social {
  display: flex; gap: var(--s-3);
}
.cpage-info__social-link {
  font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--gray);
  border-bottom: 1px solid var(--border);
  padding-bottom: 2px; transition: color var(--ease-fast), border-color var(--ease-fast);
}
.cpage-info__social-link:hover { color: var(--gold); border-color: var(--gold); }

/* ── Form panel (right) ── */
.cpage-form-wrap {
  background: var(--white);
  padding: clamp(2.5rem, 4vw, 4.5rem) clamp(2.5rem, 6vw, 7rem);
  display: flex; flex-direction: column; justify-content: center;
}
.cpage-form-header { margin-bottom: clamp(2rem, 4vw, 3.5rem); }
.cpage-form-header__title {
  font-family: var(--serif); font-size: clamp(1.8rem, 3vw, 2.8rem);
  font-weight: 500; color: var(--navy); line-height: 1.2; margin-bottom: var(--s-3);
}
.cpage-form-header__sub {
  font-size: var(--t-sm); color: var(--gray); line-height: 1.7;
}

/* ── cform: underline-only fields ── */
.cform { display: flex; flex-direction: column; gap: clamp(1.25rem, 2.5vw, 1.75rem); }
.cform-row { margin: 0; }
.cform-row--2col {
  display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.25rem, 3vw, 2.5rem);
}
.cform-row--half { max-width: calc(50% - clamp(0.75rem, 2vw, 1.5rem)); }
.cform-field--half { max-width: calc(50% - clamp(0.75rem, 2vw, 1.5rem)); }
.cform-row--urgency { margin: 0; }
.cform-row--gdpr { margin: 0; }
.cform-row--submit { margin-top: var(--s-4); }

/* Field wrapper */
.cform-field {
  position: relative;
  padding-top: 1.75rem;
}

/* The input / textarea / select itself */
.cform-field__input {
  width: 100%; background: transparent; border: none; border-bottom: 1px solid rgba(10,25,56,0.18);
  padding: 0.6rem 0 0.7rem; font-family: var(--sans); font-size: var(--t-md);
  color: var(--navy); outline: none; transition: border-color 0.25s ease;
  display: block; line-height: 1.5;
  /* remove browser default appearance */
  -webkit-appearance: none; appearance: none;
}
.cform-field__input:focus { border-color: transparent; }

/* Floating label */
.cform-field__label {
  position: absolute; top: 1.75rem; left: 0;
  font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--gray-muted);
  pointer-events: none; transform-origin: left top;
  transition: top 0.22s ease, font-size 0.22s ease, color 0.22s ease;
}
.cform-field__label span { color: var(--gold); margin-left: 2px; }

/* Animated gold underline */
.cform-field__line {
  position: absolute; bottom: 0; left: 0; width: 0; height: 1px;
  background: var(--gold); transition: width 0.35s ease; display: block;
}
.cform-field:focus-within .cform-field__line { width: 100%; }

/* Float label up when focused or has value (placeholder=" " trick) */
.cform-field__input:focus ~ .cform-field__label,
.cform-field__input:not(:placeholder-shown) ~ .cform-field__label,
.cform-field__input:-webkit-autofill ~ .cform-field__label {
  top: 0.25rem; font-size: 0.6rem; color: var(--gray-muted);
}
.cform-field__input:focus ~ .cform-field__label { color: var(--gold); }

/* Autofill — kill yellow bg, keep text color */
.cform-field__input:-webkit-autofill,
.cform-field__input:-webkit-autofill:hover,
.cform-field__input:-webkit-autofill:focus {
  -webkit-box-shadow: 0 0 0 1000px #fff inset;
  -webkit-text-fill-color: var(--navy);
  caret-color: var(--navy);
  transition: background-color 9999s ease;
}

/* Select specific */
.cform-field--select .cform-field__input { cursor: pointer; padding-right: 1.5rem; padding-left: var(--s-3); }
.cform-field__select-arrow {
  position: absolute; right: 0; bottom: 0.9rem;
  color: var(--gray-muted); pointer-events: none; transition: color 0.2s;
}
.cform-field:focus-within .cform-field__select-arrow { color: var(--gold); }

/* Select label always floated — select always shows text */
.cform-field--select .cform-field__label {
  top: 0.25rem; font-size: 0.6rem;
}
.cform-field--select:focus-within .cform-field__label { color: var(--gold); }

/* Select option colors — override browser defaults where possible */
.cform-field__select option {
  color: var(--navy);
  background: #fff;
  font-family: var(--sans);
}
.cform-field__select option[value=""] {
  color: var(--gray-muted);
}
/* Hide the placeholder option in the open list (it's already selected) */
.cform-field__select option:disabled {
  color: var(--gray-muted);
}

/* Textarea */
.cform-field--textarea .cform-field__input { resize: vertical; min-height: 100px; }

/* GDPR checkbox */
.cform-check {
  display: flex; align-items: flex-start; gap: var(--s-3); cursor: pointer;
}
.cform-check__input {
  position: absolute; opacity: 0; width: 0; height: 0;
}
.cform-check__box {
  flex-shrink: 0; width: 18px; height: 18px; margin-top: 2px;
  border: 1px solid rgba(10,25,56,0.25); background: transparent;
  transition: background 0.2s, border-color 0.2s; position: relative;
}
.cform-check__input:checked + .cform-check__box {
  background: var(--navy); border-color: var(--navy);
}
.cform-check__input:checked + .cform-check__box::after {
  content: '';
  position: absolute; left: 5px; top: 2px;
  width: 5px; height: 9px;
  border: 1.5px solid var(--gold); border-left: none; border-top: none;
  transform: rotate(45deg);
}
.cform-check__text {
  font-size: var(--t-xs); color: var(--gray); line-height: 1.6;
}
.cform-check__text a { color: var(--navy); text-decoration: underline; text-underline-offset: 2px; }
.cform-check__text a:hover { color: var(--gold); }

/* Urgency checkbox variant */
.cform-check--urgent .cform-check__box {
  border-color: rgba(185,28,28,0.3);
}
.cform-check--urgent .cform-check__input:checked + .cform-check__box {
  background: #b91c1c; border-color: #b91c1c;
}
.cform-check--urgent .cform-check__input:checked + .cform-check__box::after {
  border-color: #fff;
}
.cform-check--urgent .cform-check__text {
  font-size: var(--t-sm); font-weight: 500; color: var(--navy);
}
.cform-check--urgent .cform-check__input:checked ~ .cform-check__text {
  color: #b91c1c;
}

/* Submit button */
.cform-submit {
  display: inline-flex; align-items: center; gap: var(--s-3);
  background: var(--navy); color: var(--ivory);
  padding: 1rem 2.5rem; border: none; cursor: pointer;
  font-family: var(--sans); font-size: var(--t-sm); font-weight: 600;
  letter-spacing: 0.08em; text-transform: uppercase;
  position: relative; overflow: hidden;
  transition: background 0.3s ease, color 0.3s ease;
}
.cform-submit::before {
  content: ''; position: absolute; inset: 0;
  background: var(--gold); transform: scaleX(0); transform-origin: left;
  transition: transform 0.35s ease;
}
.cform-submit:hover::before { transform: scaleX(1); }
.cform-submit__label,
.cform-submit__icon { position: relative; z-index: 1; }
.cform-submit__icon { transition: transform 0.2s ease; }
.cform-submit:hover .cform-submit__icon { transform: translateX(4px); }
.cform-submit:hover { color: var(--navy); }

/* ── Bottom: FAQ only ── */
.cpage-faq {
  background: var(--ivory); padding-block: clamp(4rem, 7vw, 6rem);
  border-top: 1px solid var(--border-light);
}
.cpage-faq__grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 0 clamp(3rem, 6vw, 6rem);
  max-width: 960px;
}

/* Legacy form classes kept for backward compat */
.form-2col { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-5); }
.form-1col { margin-top: var(--s-5); }

/* ════════════════════════════════════════════════════════════
   SINGLE POST — EDITORIAL ARTICLE
   ════════════════════════════════════════════════════════════ */
.article-header {
  background: var(--white); padding-top: calc(76px + clamp(3rem, 6vw, 5rem));
  padding-bottom: clamp(1.5rem, 3vw, 2.5rem); position: relative; overflow: hidden;
}
.article-header__inner { max-width: 100%; }
.article-header__cats { margin-bottom: var(--s-5); display: flex; gap: var(--s-3); flex-wrap: wrap; }
.article-cat {
  font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--navy); border: 1px solid var(--border); padding: var(--s-1) var(--s-3);
  transition: all var(--ease-fast);
}
.article-cat:hover { background: var(--navy); color: var(--ivory); }
.article-header__title {
  font-family: var(--serif); font-size: var(--t-5xl); font-weight: 500;
  color: var(--navy); line-height: 1.1; letter-spacing: -0.025em; margin-bottom: var(--s-6);
}
.article-header__byline {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s-5); flex-wrap: wrap;
  border-top: 1px solid var(--border); padding-top: var(--s-5);
}
.article-header__author { display: flex; align-items: center; gap: var(--s-3); }
.article-header__author img { border-radius: 50%; }
.article-header__author-name { font-weight: 600; font-size: var(--t-sm); color: var(--charcoal); }
.article-header__author-role { font-size: var(--t-xs); color: var(--gray-muted); text-transform: uppercase; letter-spacing: 0.06em; }
.article-header__meta { display: flex; gap: var(--s-4); align-items: center; font-size: var(--t-sm); color: var(--gray-muted); }
.article-header__meta span { display: flex; align-items: center; gap: var(--s-2); }
/* Image */
.article-cover { max-height: 600px; overflow: hidden; }
.article-cover img { width: 100%; object-fit: cover; }
.article-cover + .article-header { padding-top: clamp(1.5rem, 3vw, 2.5rem); }
/* Layout */
.article-body-wrap { background: var(--white); padding-block: clamp(2rem, 4vw, 3.5rem) clamp(3rem, 6vw, 5rem); }
.article-body-grid {
  display: grid; grid-template-columns: 1fr 260px;
  gap: clamp(3rem, 5vw, 5rem); align-items: start;
}
/* Sidebar */
.article-sidebar { position: sticky; top: 100px; display: flex; flex-direction: column; gap: var(--s-5); }
.aside-block { border: 1px solid var(--border); padding: var(--s-5); background: var(--ivory); }
.aside-block__title { font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase; color: var(--gold); margin-bottom: var(--s-4); padding-bottom: var(--s-3); border-bottom: 1px solid var(--border); }
.aside-links { list-style: none; display: flex; flex-direction: column; gap: var(--s-2); }
.aside-links a { font-size: var(--t-sm); color: var(--navy); transition: all var(--ease-fast); display: flex; align-items: center; gap: var(--s-2); padding: var(--s-1) 0; }
.aside-links a:hover { color: var(--gold-dim); padding-left: var(--s-2); }
.aside-cta { background: var(--navy); padding: var(--s-6); }
.aside-cta__text { font-size: var(--t-sm); color: rgba(244,239,230,0.65); line-height: 1.65; margin-bottom: var(--s-4); }
.aside-recent { list-style: none; display: flex; flex-direction: column; gap: var(--s-4); }
.aside-recent__item { display: flex; gap: var(--s-3); align-items: flex-start; padding-bottom: var(--s-4); border-bottom: 1px solid var(--border); }
.aside-recent__item:last-child { border: none; padding-bottom: 0; }
.aside-recent__thumb { flex-shrink: 0; width: 56px; height: 56px; overflow: hidden; }
.aside-recent__thumb img { width: 100%; height: 100%; object-fit: cover; }
.aside-recent__title { font-size: var(--t-sm); font-weight: 500; color: var(--navy); line-height: 1.35; margin-bottom: var(--s-1); }
.aside-recent__date { font-size: var(--t-xs); color: var(--gray-muted); }

/* ── Aside author ── */
.aside-author { display: flex; align-items: center; gap: var(--s-4); }
.aside-author__avatar { border-radius: 50%; flex-shrink: 0; }
.aside-author__name { font-weight: 600; font-size: var(--t-sm); color: var(--charcoal); margin-bottom: 2px; display: block; }
.aside-author__role { font-size: var(--t-xs); color: var(--gray-muted); text-transform: uppercase; letter-spacing: 0.06em; display: block; }

/* ── Aside CTA eyebrow ── */
.aside-cta__eyebrow { display: block; font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase; color: rgba(198,168,107,0.7); margin-bottom: var(--s-2); }

/* ── Article prose (wp_content) ── */
.article-prose { font-size: var(--t-base); color: var(--charcoal); line-height: 1.85; }
.article-prose > * + * { margin-top: 1.4em; }
.article-prose h2 { font-family: var(--serif); font-size: clamp(1.25rem, 2vw, 1.7rem); font-weight: 500; color: var(--navy); line-height: 1.2; margin-top: clamp(2.5rem, 5vw, 3.5rem); }
.article-prose h3 { font-family: var(--serif); font-size: clamp(1.1rem, 1.6vw, 1.35rem); font-weight: 500; color: var(--navy); line-height: 1.3; margin-top: 2.25rem; }
.article-prose h4 { font-size: var(--t-base); font-weight: 600; color: var(--navy); margin-top: 2rem; }
.article-prose p { margin-bottom: 1.5em; }
.article-prose p:last-child { margin-bottom: 0; }
.article-prose ul, .article-prose ol { padding-left: 1.5rem; margin-bottom: 1.5em; }
.article-prose li { margin-bottom: 0.5em; line-height: 1.75; }
.article-prose strong { font-weight: 600; color: var(--navy); }
.article-prose em { font-style: italic; }
.article-prose a { color: var(--gold-dim); text-decoration: underline; text-decoration-color: rgba(198,168,107,0.4); text-underline-offset: 3px; transition: color var(--ease-fast); }
.article-prose a:hover { color: var(--navy); }
.article-prose blockquote { margin: clamp(1.5rem, 3vw, 2.5rem) 0; padding: var(--s-5) var(--s-6); border-left: 3px solid var(--gold); background: var(--cream); }
.article-prose blockquote p { font-family: var(--serif); font-size: var(--t-md); font-style: italic; color: var(--navy); line-height: 1.6; margin-bottom: 0; }
.article-prose img { width: 100%; height: auto; display: block; }
.article-prose figure { margin: clamp(2rem, 4vw, 3rem) 0; }
.article-prose figcaption { font-size: var(--t-xs); color: var(--gray-muted); margin-top: var(--s-3); text-align: center; font-style: italic; }
.article-prose hr { border: none; border-top: 1px solid var(--border-light); margin: clamp(2rem, 4vw, 3rem) 0; }
.article-prose table { width: 100%; border-collapse: collapse; margin-bottom: 1.5em; font-size: var(--t-sm); overflow-x: auto; display: block; }
.article-prose th { text-align: left; padding: var(--s-3) var(--s-4); background: var(--cream); color: var(--navy); font-weight: 600; border-bottom: 2px solid var(--border); }
.article-prose td { padding: var(--s-3) var(--s-4); color: var(--gray); border-bottom: 1px solid var(--border-light); }
.article-prose pre { background: #f1ede4; padding: var(--s-5); overflow-x: auto; margin-bottom: 1.5em; border-left: 3px solid var(--gold); font-size: 0.88em; }
.article-prose code { font-size: 0.88em; background: rgba(198,168,107,0.1); padding: 0.1em 0.4em; border-radius: 2px; }
.article-prose pre code { background: none; padding: 0; }

/* ── Centered (no-sidebar) modifiers ── */
.article-prose--centered,
.article-tags--centered,
.article-nav--centered { max-width: 100%; }

/* ── Article tags ── */
.article-tags { display: flex; flex-wrap: wrap; gap: var(--s-2); margin-top: var(--s-8); padding-top: var(--s-6); border-top: 1px solid var(--border-light); }
.article-tag { font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; padding: var(--s-1) var(--s-3); border: 1px solid var(--border); color: var(--gray); transition: all var(--ease-fast); }
.article-tag:hover { border-color: var(--gold); color: var(--gold); }

/* ── Article prev/next nav ── */
.article-nav { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-4); margin-top: var(--s-12); padding-top: var(--s-8); border-top: 1px solid var(--border-light); }
.article-nav__item { display: flex; flex-direction: column; gap: var(--s-2); padding: var(--s-5); border: 1px solid var(--border-light); text-decoration: none; transition: border-color var(--ease-fast), background var(--ease-fast); }
.article-nav__item:hover { border-color: rgba(198,168,107,0.4); background: var(--cream); }
.article-nav__item--next { text-align: right; }
.article-nav__dir { font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gray-muted); }
.article-nav__title { font-family: var(--serif); font-size: var(--t-base); color: var(--navy); line-height: 1.35; }

/* ── Article bottom CTA (navy band) ── */
.article-bottom-cta { background: var(--navy); padding-block: clamp(4rem, 8vw, 6rem); position: relative; overflow: hidden; }
.article-bottom-cta__inner { display: flex; align-items: center; justify-content: space-between; gap: clamp(2rem, 5vw, 4rem); flex-wrap: wrap; }
.article-bottom-cta__text { max-width: 50ch; }
.article-bottom-cta__title { font-family: var(--serif); font-size: clamp(1.5rem, 2.5vw, 2.25rem); font-weight: 400; color: var(--ivory); line-height: 1.2; margin-bottom: var(--s-4); }
.article-bottom-cta__sub { font-size: var(--t-sm); color: rgba(244,239,230,0.5); line-height: 1.7; }
.article-bottom-cta__actions { display: flex; gap: var(--s-4); flex-wrap: wrap; flex-shrink: 0; }
@media (max-width: 640px) {
  .article-nav { grid-template-columns: 1fr; }
  .article-bottom-cta__inner { flex-direction: column; }
  .article-bottom-cta__actions { width: 100%; }
  .article-bottom-cta__actions .btn { flex: 1; justify-content: center; }
}

/* ── Featured post category badge ── */
.journal-featured__cat {
  position: absolute; top: var(--s-4); left: var(--s-4);
  font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase;
  background: var(--navy); color: var(--ivory); padding: var(--s-1) var(--s-3);
}

/* ── jpost placeholder (no image) ── */
.jpost__placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--serif); font-size: 5rem; color: rgba(198,168,107,0.12);
  letter-spacing: 0.1em;
  background: var(--cream);
}

/* ── Journal rest (more articles list) ── */
.journal-rest { margin-top: var(--s-section); }
.journal-rest__head { font-family: var(--serif); font-size: var(--t-2xl); font-weight: 300; color: var(--navy); margin-bottom: var(--s-8); padding-bottom: var(--s-5); border-bottom: 1px solid var(--border); }
.journal-rest__list { display: flex; flex-direction: column; }
.journal-rest__item { display: grid; grid-template-columns: 160px 1fr; gap: var(--s-5); padding: var(--s-5) 0; border-bottom: 1px solid var(--border-light); text-decoration: none; transition: padding-left var(--ease-fast); }
.journal-rest__item:hover { padding-left: var(--s-3); }
.journal-rest__item:last-child { border-bottom: none; }
.journal-rest__thumb { height: 110px; overflow: hidden; background: var(--border-light); }
.journal-rest__thumb img { width: 100%; height: 100%; object-fit: cover; }
.journal-rest__body { display: flex; flex-direction: column; gap: var(--s-2); justify-content: center; }
.journal-rest__title { font-family: var(--serif); font-size: var(--t-lg); font-weight: 500; color: var(--navy); line-height: 1.3; transition: color var(--ease-fast); }
.journal-rest__item:hover .journal-rest__title { color: var(--gold-dim); }
.journal-rest__meta { font-size: var(--t-xs); color: var(--gray-muted); letter-spacing: 0.04em; }
@media (max-width: 480px) {
  .journal-rest__item { grid-template-columns: 100px 1fr; }
  .journal-rest__thumb { height: 80px; }
}

/* ── Journal pagination ── */
.journal-pagination { display: flex; justify-content: center; align-items: center; gap: var(--s-1); margin-top: var(--s-12); padding-top: var(--s-8); border-top: 1px solid var(--border-light); flex-wrap: wrap; }
.journal-pagination a, .journal-pagination span { display: inline-flex; align-items: center; justify-content: center; min-width: 40px; height: 40px; padding: 0 var(--s-3); font-size: var(--t-sm); font-weight: 500; color: var(--navy); border: 1px solid var(--border-light); transition: all var(--ease-fast); text-decoration: none; }
.journal-pagination a:hover { background: var(--cream); border-color: rgba(198,168,107,0.4); }
.journal-pagination .current { background: var(--navy); color: var(--ivory); border-color: var(--navy); }
.journal-pagination .dots { border: none; color: var(--gray-muted); pointer-events: none; }

/* ── Journal empty state ── */
.journal-empty { text-align: center; padding: clamp(4rem, 8vw, 7rem) 0; }
.journal-empty p { font-size: var(--t-lg); color: var(--gray); }

/* ── Journal bottom CTA ── */
.journal-bottom-cta { background: var(--ivory); padding-block: clamp(3rem, 6vw, 5rem); border-top: 1px solid var(--border-light); }
.journal-bottom-cta__inner { display: flex; align-items: center; justify-content: space-between; gap: var(--s-6); flex-wrap: wrap; }
.journal-bottom-cta__title { font-family: var(--serif); font-size: clamp(1.25rem, 2.5vw, 2rem); font-weight: 300; color: var(--navy); line-height: 1.3; }
.journal-bottom-cta__sub { font-size: var(--t-sm); color: var(--gray); margin-top: var(--s-2); }
@media (max-width: 640px) {
  .journal-bottom-cta__inner { flex-direction: column; align-items: flex-start; }
}

/* ── Category hero ── */
.cat-hero { background: var(--white); padding-top: calc(76px + clamp(3rem, 6vw, 5rem)); padding-bottom: clamp(2.5rem, 5vw, 4rem); border-bottom: 1px solid var(--border-light); position: relative; overflow: hidden; }
.cat-hero__breadcrumb { display: flex; align-items: center; gap: var(--s-2); font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gray-muted); margin-bottom: var(--s-5); flex-wrap: wrap; }
.cat-hero__breadcrumb a { color: var(--gold); transition: opacity var(--ease-fast); }
.cat-hero__breadcrumb a:hover { opacity: 0.75; }
.cat-hero__breadcrumb__sep { opacity: 0.35; }
.cat-hero__eyebrow { display: block; font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase; color: var(--gold); margin-bottom: var(--s-3); }
.cat-hero__title { font-family: var(--serif); font-size: var(--t-6xl); font-weight: 400; color: var(--navy); line-height: 1.0; letter-spacing: -0.03em; margin-bottom: var(--s-5); }
.cat-hero__desc { font-size: var(--t-md); color: var(--gray); line-height: 1.75; max-width: 60ch; }
.cat-hero__meta { display: flex; align-items: center; gap: var(--s-4); margin-top: var(--s-6); padding-top: var(--s-5); border-top: 1px solid var(--border-light); font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--gray-muted); }
.journal-cat__count { opacity: 0.6; font-weight: 400; margin-left: 2px; }

/* ════════════════════════════════════════════════════════════
   SERVICE SINGLE — LEGAL GUIDE
   ════════════════════════════════════════════════════════════ */
.service-guide__layout { background: var(--white); padding-block: var(--s-section); }
.service-guide__inner {
  display: grid; grid-template-columns: 1fr 300px;
  gap: clamp(3rem, 6vw, 6rem); align-items: start;
}
.service-sticky { position: sticky; top: 100px; display: flex; flex-direction: column; gap: var(--s-5); }
.service-sticky-box { background: var(--ivory); border: 1px solid var(--border); padding: var(--s-6); }
.service-sticky-box__title { font-family: var(--serif); font-size: var(--t-md); font-weight: 500; color: var(--navy); margin-bottom: var(--s-5); padding-bottom: var(--s-4); border-bottom: 1px solid var(--border); }

/* ════════════════════════════════════════════════════════════
   PAGE HERO (generic)
   ════════════════════════════════════════════════════════════ */
.page-hero {
  background: var(--white); padding-top: calc(76px + clamp(4rem, 8vw, 7rem));
  padding-bottom: clamp(3rem, 6vw, 5rem); position: relative; overflow: hidden;
  border-bottom: 1px solid var(--border-light);
}
.page-hero::after {
  content: ''; position: absolute; bottom: 0; left: 0; width: 100%; height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold) 35%, var(--gold) 65%, transparent);
  opacity: 0.3;
}
.page-hero__watermark {
  position: absolute; right: -1%; bottom: -8%;
  font-family: var(--serif); font-size: clamp(12rem, 20vw, 18rem);
  font-weight: 400; color: rgba(198,168,107,0.05);
  letter-spacing: -0.06em; line-height: 0.9; pointer-events: none; user-select: none;
}
.page-hero__eyebrow { display: block; margin-bottom: var(--s-5); }
.page-hero__title {
  font-family: var(--serif); font-size: var(--t-6xl); font-weight: 500;
  color: var(--navy); line-height: 1.0; letter-spacing: -0.025em; margin-bottom: var(--s-5); max-width: 14ch;
}
.page-hero__sub { font-size: var(--t-md); color: var(--gray); max-width: 55ch; line-height: 1.7; }

/* ════════════════════════════════════════════════════════════
   MEDIA PAGE
   ════════════════════════════════════════════════════════════ */
.media-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: clamp(1.5rem, 3vw, 2.5rem); margin-top: var(--s-10);
}
.media-video-card {
  display: flex; flex-direction: column; text-decoration: none;
  transition: transform var(--ease-fast);
}
.media-video-card:hover { transform: translateY(-3px); }
.media-video-card__thumb {
  aspect-ratio: 16/9; overflow: hidden;
  background: var(--navy); position: relative; margin-bottom: var(--s-4);
}
.media-video-card__thumb img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.5s ease; opacity: 0.82;
}
.media-video-card:hover .media-video-card__thumb img { transform: scale(1.04); opacity: 1; }
.media-video-card__play {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
}
.media-video-card__play-btn {
  width: 52px; height: 52px; border-radius: 50%;
  background: rgba(255,255,255,0.92); display: flex; align-items: center; justify-content: center;
  transition: transform var(--ease-fast);
}
.media-video-card:hover .media-video-card__play-btn { transform: scale(1.12); }
.media-video-card__source {
  font-size: var(--t-sm); font-weight: 600; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--gold); margin-bottom: var(--s-2); display: block;
}
.media-video-card__title {
  font-family: var(--serif); font-size: var(--t-xl); font-weight: 400;
  color: var(--navy); line-height: 1.3; transition: color var(--ease-fast);
}
.media-video-card:hover .media-video-card__title { color: var(--gold-dim); }

.media-link-list { list-style: none; margin-top: var(--s-10); }
.media-link-item {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s-6); padding: var(--s-6) 0;
  border-bottom: 1px solid var(--border-light); text-decoration: none;
  transition: padding-left var(--ease-fast);
}
.media-link-item:first-child { border-top: 1px solid var(--border-light); }
.media-link-item:hover { padding-left: var(--s-3); }
.media-link-item__body { flex: 1; }
.media-link-item__source {
  font-size: var(--t-sm); font-weight: 600; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--gold); margin-bottom: var(--s-2); display: block;
}
.media-link-item__title {
  font-family: var(--serif); font-size: var(--t-xl); font-weight: 400;
  color: var(--navy); line-height: 1.35; transition: color var(--ease-fast);
}
.media-link-item:hover .media-link-item__title { color: var(--gold-dim); }
.media-link-item__arrow { flex-shrink: 0; color: var(--gold-dim); transition: transform var(--ease-fast); }
.media-link-item:hover .media-link-item__arrow { transform: translateX(4px); }

/* ════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════ */
@media (max-width: 1100px) {
  .home-hero__aside { width: clamp(200px, 32vw, 300px); }
  .home-hero__actions { flex-direction: row; }
  .home-practices__inner { grid-template-columns: 1fr; min-height: auto; }
  .home-practices__left { position: static; padding-bottom: 0; align-items: flex-start; }
  .home-practices__left-inner { padding: clamp(2.5rem, 6vw, 4rem) clamp(1.5rem, 5vw, 3rem); }
  .practices-list { grid-template-columns: 1fr; grid-template-rows: auto; padding-inline: clamp(1.5rem, 4vw, 3rem); }
  .practice-item:nth-child(even) { border-left: none; }
  .practice-item:nth-last-child(-n+2) { border-bottom: 1px solid rgba(198,168,107,0.18); }
  .practice-item:last-child { border-bottom: none; }
  .practice-item__num { font-size: clamp(2rem, 5vw, 2.75rem); }
  .practice-item__title { font-size: clamp(1.2rem, 4vw, 1.45rem); max-width: 80%; }
  .home-manifesto__inner { grid-template-columns: 1fr; gap: 2.5rem; }
  .home-about__inner { grid-template-columns: 1fr 1.2fr; }
  .article-body-grid { grid-template-columns: 1fr 220px; }
  .service-guide__inner { grid-template-columns: 1fr 260px; }
  .cpage-layout { grid-template-columns: 340px 1fr; }
}

@media (max-width: 900px) {
  .home-hero__stage { flex-direction: column; align-items: flex-start; gap: var(--s-8); justify-content: flex-end; }
  .home-hero__aside { width: 100%; max-width: 480px; }
  .home-hero__heading { font-size: clamp(3.5rem, 10vw, 7rem); flex: none; }
  .home-hero__creds { flex-wrap: wrap; gap: var(--s-6); }
  .home-about__inner { grid-template-columns: 1fr; gap: 2.5rem; }
  .home-about__image-col::after { display: none; }
  .pathways-cards { grid-template-columns: 1fr 1fr; }
  .pathway-card:last-child { grid-column: 1 / -1; min-height: 380px; }
  .home-pathways__header { grid-template-columns: 1fr; gap: var(--s-6); }
  .about-biography__inner { grid-template-columns: 1fr; gap: 2.5rem; }
  .about-values__inner { grid-template-columns: 1fr; }
  .about-values__left-col { position: static; }
  .about-timeline__inner { grid-template-columns: 1fr; }
  .about-timeline__heading-col { position: static; }
  .contact-layout { grid-template-columns: 1fr; }
  .contact-layout__info { min-height: 0; padding-block: clamp(3rem, 6vw, 5rem); }
  .cpage-layout { grid-template-columns: 1fr; height: auto; }
  .cpage-info { min-height: 0; border-right: none; border-bottom: 1px solid var(--border-light); padding-top: clamp(5rem, 12vw, 8rem); padding-bottom: clamp(3.5rem, 8vw, 6rem); }
  .cpage-info__quote { margin-top: var(--s-6); }
  .cpage-faq__grid { grid-template-columns: 1fr; }
  .journal-hero__top { flex-direction: column; align-items: flex-start; gap: var(--s-5); }
  .journal-hero__issue { text-align: left; }
  .media-grid { grid-template-columns: 1fr 1fr; }
  .journal-main-grid { grid-template-columns: 1fr 1fr; }
  .journal-post--featured { grid-column: 1 / -1; }
  .journal-post--secondary { grid-column: span 1; }
  .journal-post--tertiary { grid-column: span 1; }
  .services-intro__grid { grid-template-columns: 1fr; }
  .services-features-bar__inner { grid-template-columns: 1fr 1fr; }
  .services-panel-section { grid-template-columns: 1fr; }
  .services-panel__nav { position: static; max-height: none; }
  .services-panel__nav-inner { min-height: auto; }
  .services-faq__inner { grid-template-columns: 1fr; }
  .services-faq__heading { position: static; }
  .page-hero__title { font-size: clamp(1.75rem, 5.5vw, 3rem); }
  .svc-grid { grid-template-columns: 1fr; }
  .svc-card--full { grid-column: span 1; }
  .svc-card { padding-inline: clamp(1.25rem, 4vw, 3rem); }
  .svc-grid__footer { padding-inline: clamp(1.25rem, 4vw, 3rem); }
  /* Re-alternate colors on single column — PHP computes checkerboard for 2 cols */
  .svc-grid .svc-card:nth-child(odd) { background: var(--ivory); }
  .svc-grid .svc-card:nth-child(odd) .svc-card__title  { color: var(--navy); }
  .svc-grid .svc-card:nth-child(odd) .svc-card__desc   { color: var(--gray); }
  .svc-grid .svc-card:nth-child(odd) .svc-card__bg-num { color: rgba(10,25,56,0.09); }
  .svc-grid .svc-card:nth-child(even) { background: var(--navy); }
  .svc-grid .svc-card:nth-child(even) .svc-card__title  { color: var(--ivory); }
  .svc-grid .svc-card:nth-child(even) .svc-card__desc   { color: rgba(244,239,230,0.5); }
  .svc-grid .svc-card:nth-child(even) .svc-card__bg-num { color: rgba(255,255,255,0.08); }
  .article-cover { aspect-ratio: 4 / 3; max-height: none; }
  .article-cover img { height: 100%; }
  .article-header { padding-bottom: var(--s-5); }
  .article-header__title { font-size: clamp(1.6rem, 6vw, 2.25rem); }
  .article-body-wrap { padding-top: var(--s-6); }
  .lpage-hero { padding-top: calc(76px + var(--s-5)); }
  .article-body-grid { grid-template-columns: 1fr; }
  .article-sidebar { position: static; }
  .service-guide__inner { grid-template-columns: 1fr; }
  .service-sticky { position: static; }
  .home-journal__header { flex-direction: column; align-items: flex-start; }
  .journal-cards { grid-template-columns: 1fr 1fr; }
  .journal-cards--1 { grid-template-columns: 1fr; }
  .home-process__header { grid-template-columns: 1fr; gap: var(--s-5); }
  .process-panel { grid-template-columns: 1fr; gap: var(--s-5); }
  .process-panel__num { font-size: clamp(4rem, 12vw, 7rem); }
  .process-panel__step-info { flex-direction: row; align-items: center; border-left: none; border-top: 1px solid var(--border-light); padding-left: 0; padding-top: var(--s-4); }
  .process-panel__step-count { writing-mode: horizontal-tb; transform: none; }
  .process-panel__dots { flex-direction: row; }
}

@media (max-width: 640px) {
  .services-hero { padding-top: calc(76px + clamp(1rem, 3vw, 1.5rem)); padding-bottom: clamp(1.5rem, 4vw, 2.5rem); }
  /* Hero — heading at bottom, stacked buttons, stacked creds */
  .home-hero { padding-bottom: clamp(1rem, 3vh, 2rem); }
  .home-hero__stage { justify-content: flex-end; }
  .home-hero__heading { font-size: clamp(3rem, 13vw, 5rem); flex: none; margin-top: 0; }
  /* Stats — stacked vertically, larger */
  .home-hero__creds { flex-direction: column; flex-wrap: nowrap; gap: var(--s-4); align-items: flex-start; }
  .hero-cred { flex-direction: row; align-items: center; gap: var(--s-3); }
  .hero-cred__val { font-size: var(--t-2xl); }
  .hero-cred__label { font-size: var(--t-xs); letter-spacing: 0.06em; }
  /* Buttons stacked vertically */
  .home-hero__actions { width: 100%; flex-direction: column; gap: var(--s-2); }
  .home-hero__actions .btn { flex: none; width: 100%; justify-content: center; }
  .home-hero__barou { display: none; }
  .process-nav {
    flex-direction: column;
    flex-wrap: nowrap;
    overflow: visible;
  }
  .process-nav__item {
    flex: none;
    flex-direction: row;
    align-items: center;
    gap: var(--s-4);
    padding: var(--s-4) var(--s-4);
    border-right: none;
    border-bottom: 1px solid var(--border-light);
    text-align: left;
  }
  .process-nav__item:last-of-type { border-bottom: none; }
  .process-nav__num { font-size: var(--t-xl); flex-shrink: 0; }
  .process-nav__label { text-align: left; font-size: var(--t-xs); letter-spacing: 0.1em; }
  .home-manifesto__inner { grid-template-columns: 1fr; gap: 2rem; }
  .home-about__bg-text { display: none; }
  .home-pathways { padding-top: clamp(2rem, 6vw, 3.5rem); }
  .pathways-cards { grid-template-columns: 1fr; gap: 1px; }
  .pathway-card:last-child { grid-column: auto; min-height: 0; }
  .pathway-card { min-height: 400px; }
  .home-pathways__header { margin-inline: clamp(1.25rem, 4vw, 3rem); }
  .about-biography__portrait-accent { display: none; }
  .form-2col { grid-template-columns: 1fr; }
  .cform-row--2col { grid-template-columns: 1fr; }
  .services-features-bar__inner { grid-template-columns: 1fr; }
  .services-panel__pane-situations ul { grid-template-columns: 1fr; }
  .svc-card__bg-num { font-size: 8rem; }
  .media-grid { grid-template-columns: 1fr; }
  .journal-hero { padding-top: calc(62px + clamp(2rem, 6vw, 3.5rem)); padding-bottom: clamp(1.5rem, 4vw, 2.5rem); }
  .journal-hero__title { font-size: clamp(1.75rem, 7vw, 2.5rem); }
  .journal-hero__issue { display: none; }
  .journal-cats { gap: var(--s-2); padding-top: var(--s-4); }
  .journal-cat { font-size: 0.65rem; padding: var(--s-1) var(--s-3); }
  .journal-cats__label { display: none; }
  .journal-main-grid { grid-template-columns: 1fr; }
  .journal-post--tertiary { border-top: none; padding-top: 0; }
  .journal-rest__item { grid-template-columns: 80px 1fr; gap: var(--s-3); }
  .journal-rest__thumb { height: 70px; }
  .journal-cards,
  .journal-cards--2 { grid-template-columns: 1fr; }
  .home-cta__actions { flex-direction: column; align-items: center; }
}

@media (max-width: 1024px) {
  .header-nav, .header-right { display: none; }
  .nav-toggle { display: flex; }
  .h-spacer { height: 69px; }
  .header-micro__hours { display: none; }
}
@media (max-width: 480px) {
  .header-micro { display: none; }
  .h-spacer { height: 62px; }
}

/* ════════════════════════════════════════════════════════════
   STANDARD PAGE — Termeni, Cookies, GDPR, etc.
   ════════════════════════════════════════════════════════════ */
.lpage-hero {
  background: var(--navy);
  padding-top: calc(76px + clamp(1.5rem, 3vw, 2.5rem));
  padding-bottom: clamp(1.5rem, 3vw, 2.5rem);
  position: relative; overflow: hidden;
}
.lpage-hero__watermark {
  position: absolute; right: -1%; bottom: -10%;
  font-family: var(--serif); font-size: clamp(10rem, 20vw, 18rem);
  font-weight: 400; letter-spacing: -0.06em;
  color: rgba(198,168,107,0.07);
  line-height: 0.9; pointer-events: none; user-select: none;
}
.lpage-hero__inner { max-width: 760px; }
.lpage-hero__eyebrow { display: block; margin-bottom: var(--s-5); color: var(--gold); }
.lpage-hero__title {
  font-family: var(--serif); font-size: clamp(2rem, 4vw, 3.5rem);
  font-weight: 400; color: var(--ivory); line-height: 1.1;
  letter-spacing: -0.02em; margin-bottom: 0;
}

.lpage-content { padding-block: clamp(2rem, 4vw, 3rem); }
.lpage-content__inner { max-width: 760px; }

/* Prose — stilizare conținut WordPress editor */
.lpage-prose { color: var(--navy); font-size: var(--t-base); line-height: 1.85; }

.lpage-prose h2 {
  font-family: var(--serif); font-size: clamp(1.25rem, 2vw, 1.625rem);
  font-weight: 500; color: var(--navy); line-height: 1.25;
  margin-top: clamp(2.5rem, 5vw, 3.5rem); margin-bottom: var(--s-4);
  padding-bottom: var(--s-3); border-bottom: 1px solid var(--line);
}
.lpage-prose h3 {
  font-family: var(--serif); font-size: clamp(1.1rem, 1.6vw, 1.25rem);
  font-weight: 500; color: var(--navy); line-height: 1.3;
  margin-top: clamp(1.75rem, 3vw, 2.5rem); margin-bottom: var(--s-3);
}
.lpage-prose h4 {
  font-size: var(--t-base); font-weight: 600; color: var(--navy);
  margin-top: var(--s-6); margin-bottom: var(--s-2);
}
.lpage-prose p { margin-bottom: 1.4em; color: var(--gray); }
.lpage-prose p:last-child { margin-bottom: 0; }

.lpage-prose ul, .lpage-prose ol {
  margin-bottom: 1.4em; padding-left: 1.5rem; color: var(--gray);
}
.lpage-prose li { margin-bottom: 0.5em; line-height: 1.75; }

.lpage-prose strong { color: var(--navy); font-weight: 600; }
.lpage-prose em { font-style: italic; }

.lpage-prose a {
  color: var(--gold); text-decoration: underline;
  text-decoration-color: rgba(198,168,107,0.4); text-underline-offset: 3px;
}
.lpage-prose a:hover { color: var(--navy); text-decoration-color: var(--navy); }

.lpage-prose blockquote {
  margin: clamp(1.5rem, 3vw, 2.5rem) 0;
  padding: var(--s-5) var(--s-6);
  border-left: 3px solid var(--gold);
  background: var(--cream);
}
.lpage-prose blockquote p { color: var(--navy); font-style: italic; margin-bottom: 0; }

.lpage-prose hr {
  border: none; border-top: 1px solid var(--line);
  margin: clamp(2rem, 4vw, 3rem) 0;
}

.lpage-prose table {
  width: 100%; border-collapse: collapse;
  margin-bottom: 1.4em; font-size: var(--t-sm);
}
.lpage-prose th {
  text-align: left; padding: var(--s-3) var(--s-4);
  background: var(--cream); color: var(--navy);
  font-weight: 600; border-bottom: 2px solid var(--line);
}
.lpage-prose td {
  padding: var(--s-3) var(--s-4); color: var(--gray);
  border-bottom: 1px solid var(--line);
}

@media (max-width: 768px) {
  .lpage-prose table { font-size: 0.8rem; }
  .lpage-prose th, .lpage-prose td { padding: var(--s-2) var(--s-3); }
}

/* ════════════════════════════════════════════════════════════
   CLIENT TYPES PAGE — Editorial premium redesign
   ════════════════════════════════════════════════════════════ */

/* ── Hero ──────────────────────────────────────────────────── */
.ct-hero {
  background: var(--white);
  min-height: 100vh;
  padding-top: calc(76px + clamp(4rem, 8vw, 7rem));
  padding-bottom: clamp(4rem, 7vw, 7rem);
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
}

/* Background image — full width, anchored top right */
.ct-hero__bg {
  position: absolute;
  inset: 0;
  background-position: top right;
  background-size: cover;
  background-repeat: no-repeat;
  pointer-events: none;
}

/* Color overlay on top of the image */
.ct-hero__overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.ct-hero__bg-num {
  position: absolute;
  right: -3%; bottom: -15%;
  font-family: var(--serif);
  font-size: clamp(18rem, 30vw, 28rem);
  font-weight: 400;
  color: rgba(198,168,107,0.03);
  letter-spacing: -0.06em;
  line-height: 0.9;
  pointer-events: none;
  user-select: none;
}
.ct-hero__eyebrow { display: block; margin-bottom: var(--s-8); }
.ct-hero__title {
  font-family: var(--serif);
  font-size: var(--t-6xl);
  font-weight: 300;
  color: var(--navy);
  line-height: 1.0;
  letter-spacing: -0.03em;
  margin-bottom: var(--s-6);
  max-width: 18ch;
}
.ct-hero__sub {
  font-size: var(--t-md);
  color: var(--gray);
  max-width: 48ch;
  line-height: 1.8;
  margin-bottom: 0;
}

/* Single-column headline block */
.ct-hero .container { width: 100%; }
.ct-hero__text {
  max-width: 72ch;
  margin-bottom: clamp(3rem, 6vw, 5rem);
}

/* 3-column route grid */
.ct-hero__routes {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
}
.ct-hero__route {
  display: flex;
  align-items: center;
  gap: var(--s-5);
  padding: clamp(1.5rem, 3vw, 2rem) clamp(1.5rem, 3vw, 2.5rem);
  text-decoration: none;
  position: relative;
  transition: padding-left var(--ease);
  border-left: 1px solid var(--border);
}
.ct-hero__route:first-child { border-left: none; }
.ct-hero__route::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 0;
  background: var(--gold);
  opacity: 0;
  transition: width 0.28s ease, opacity 0.28s ease;
}
.ct-hero__route:hover { padding-left: var(--s-5); }
.ct-hero__route:hover::before { width: 2px; opacity: 0.5; }
.ct-hero__route-num {
  font-family: var(--serif);
  font-size: var(--t-xl);
  font-weight: 300;
  font-style: italic;
  color: var(--gold);
  opacity: 0.9;
  flex-shrink: 0;
  line-height: 1;
  transition: opacity var(--ease-fast);
  min-width: 2.6ch;
}
.ct-hero__route:hover .ct-hero__route-num { opacity: 1; }
.ct-hero__route-name {
  font-family: var(--serif);
  font-size: var(--t-3xl);
  font-weight: 300;
  color: var(--navy);
  line-height: 1.15;
  flex: 1;
  transition: color var(--ease-fast);
}
.ct-hero__route:hover .ct-hero__route-name { color: var(--gold-dim); }
.ct-hero__route-arrow {
  font-size: var(--t-base);
  color: var(--gold);
  opacity: 0;
  transform: translateX(-6px);
  transition: opacity var(--ease-fast), transform var(--ease-fast);
  flex-shrink: 0;
}
.ct-hero__route:hover .ct-hero__route-arrow {
  opacity: 0.65;
  transform: translateX(0);
}

/* ── Sticky Section Nav ─────────────────────────────────────── */
.ct-nav {
  position: sticky;
  top: 76px;
  z-index: 90;
  background: rgba(255,255,255,0.95);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--border);
  transition: box-shadow var(--ease);
}
.ct-nav.is-stuck { box-shadow: 0 4px 24px rgba(11,31,58,0.07); }
.ct-nav__tabs {
  display: flex;
  overflow-x: auto;
  scrollbar-width: none;
}
.ct-nav__tabs::-webkit-scrollbar { display: none; }
.ct-nav__tab {
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  padding: 1.1rem var(--s-6);
  font-family: var(--sans);
  font-size: var(--t-xs);
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gray-muted);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  white-space: nowrap;
  transition: color var(--ease-fast), border-color var(--ease-fast);
}
.ct-nav__tab:hover { color: var(--navy); }
.ct-nav__tab.is-active { color: var(--navy); border-bottom-color: var(--gold); }
.ct-nav__num {
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.1em;
  color: var(--gold);
  opacity: 0.55;
  transition: opacity var(--ease-fast);
}
.ct-nav__tab:hover .ct-nav__num,
.ct-nav__tab.is-active .ct-nav__num { opacity: 1; }

/* ── Section base ───────────────────────────────────────────── */
.ct-section {
  position: relative;
  padding-block: var(--s-section);
  overflow: hidden;
}
.ct-section--light { background: var(--white); }
.ct-section--navy  { background: var(--navy); }
.ct-section--ivory { background: var(--ivory); }

/* Giant faint background number */
.ct-section__bg-num {
  position: absolute;
  bottom: 0; right: -2%;
  font-family: var(--serif);
  font-size: clamp(14rem, 22vw, 22rem);
  font-weight: 300;
  color: rgba(198,168,107,0.09);
  line-height: 0.85;
  letter-spacing: -0.06em;
  pointer-events: none;
  user-select: none;
}
.ct-section--navy .ct-section__bg-num { color: rgba(198,168,107,0.13); }
.ct-section--ivory .ct-section__bg-num { color: rgba(198,168,107,0.11); }

/* Section label: italic number + eyebrow, no rule */
.ct-section__label {
  display: flex;
  align-items: baseline;
  gap: var(--s-5);
  margin-bottom: var(--s-8);
}
.ct-section__label-num {
  font-family: var(--serif);
  font-size: var(--t-4xl);
  font-weight: 300;
  font-style: italic;
  color: rgba(198,168,107,0.28);
  line-height: 1;
}

/* Full-viewport-width split: text left (aligns with container), image bleeds right to edge */
.ct-section__top {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: stretch;
  margin-bottom: clamp(4rem, 7vw, 6rem);
  overflow: hidden;
}

/* Left col: replicate container centering so text stays aligned */
.ct-section__intro-col {
  padding-left:  calc(max(0px, (100vw - 1320px) / 2) + clamp(1.25rem, 4vw, 3rem));
  padding-right: clamp(3rem, 5vw, 5rem);
  padding-top:   0;
  padding-bottom: 0;
  display: flex;
  align-items: center;
}

/* Right col: image fills full height, no right padding → bleeds to edge */
.ct-section__img-wrap {
  overflow: hidden;
  min-height: 480px;
}
.ct-section__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.7s ease;
}
.ct-section__img-wrap:hover .ct-section__img { transform: scale(1.04); }

/* Services block — full container width, below the top split */
.ct-section__services { padding-top: clamp(3rem, 5vw, 4rem); }
.ct-section__svc-eyebrow { display: block; margin-bottom: clamp(2rem, 4vw, 3rem); }

/* Left column */
.ct-section__icon {
  width: 48px; height: 48px;
  border-radius: 50%;
  border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  color: var(--gold);
  margin-bottom: var(--s-8);
  flex-shrink: 0;
}
.ct-section__icon--gold {
  background: rgba(198,168,107,0.1);
  border-color: rgba(198,168,107,0.2);
}
.ct-section__heading {
  font-family: var(--serif);
  font-size: var(--t-4xl);
  font-weight: 300;
  color: var(--navy);
  line-height: 1.15;
  letter-spacing: -0.025em;
  margin-bottom: var(--s-6);
}
.ct-section__heading--light { color: var(--ivory); }
.ct-section__text {
  font-size: var(--t-md);
  color: var(--gray);
  line-height: 1.85;
  margin-bottom: var(--s-4);
}
.ct-section__text--light { color: rgba(244,239,230,0.65); }

.ct-section__promises {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  margin: var(--s-8) 0;
}
.ct-section__promise {
  display: flex;
  align-items: flex-start;
  gap: var(--s-3);
  font-size: var(--t-sm);
  color: var(--gray);
  line-height: 1.6;
}
.ct-section__promise svg { flex-shrink: 0; color: var(--gold); margin-top: 1px; }
.ct-section__promise--light { color: rgba(244,239,230,0.65); }
.ct-section__promise--light svg { color: var(--gold); }

/* Right column — always-visible services, no accordion */
.ct-section__services { padding-top: 4px; }
.ct-section__svc-eyebrow {
  display: block;
  margin-bottom: clamp(2.5rem, 4vw, 3.5rem);
}
.ct-svcs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(2rem, 4vw, 3rem);
}

/* Individual domain — hover: gold left sliver slides in */
.ct-svc {
  position: relative;
  padding-left: 0;
  transition: padding-left var(--ease);
}
.ct-svc::before {
  content: '';
  position: absolute;
  left: 0; top: 0.15em;
  width: 0; height: calc(var(--t-xl) * 1.15);
  background: var(--gold);
  opacity: 0;
  transition: width 0.28s ease, opacity 0.28s ease;
}
.ct-svc:hover { padding-left: var(--s-5); }
.ct-svc:hover::before { width: 2px; opacity: 0.5; }

.ct-svc__head {
  display: flex;
  align-items: baseline;
  gap: var(--s-3);
  margin-bottom: var(--s-4);
}
.ct-svc__num {
  font-family: var(--serif);
  font-size: var(--t-sm);
  font-style: italic;
  color: var(--gold);
  opacity: 0.5;
  flex-shrink: 0;
  line-height: 1;
  transition: opacity var(--ease-fast);
}
.ct-svc:hover .ct-svc__num { opacity: 1; }
.ct-svc__name {
  font-family: var(--serif);
  font-size: var(--t-2xl);
  font-weight: 300;
  color: var(--navy);
  line-height: 1.2;
  transition: color var(--ease-fast);
}
.ct-svc:hover .ct-svc__name { color: var(--gold-dim); }

/* Dark variant (section 02) */
.ct-svc--dark .ct-svc__name { color: var(--ivory); }
.ct-svc--dark:hover .ct-svc__name { color: var(--gold-light); }
.ct-svc--dark::before { background: var(--gold); }

.ct-svc__items {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
.ct-svc__items li {
  font-size: var(--t-base);
  color: var(--gray);
  line-height: 1.65;
  padding-left: var(--s-5);
  position: relative;
}
.ct-svc__items li::before {
  content: '';
  position: absolute;
  left: 0; top: 0.68em;
  width: 12px; height: 1px;
  background: var(--gold);
  opacity: 0.28;
}
.ct-svc--dark .ct-svc__items li { color: rgba(244,239,230,0.5); }
.ct-svc--dark .ct-svc__items li::before { opacity: 0.45; }

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width: 900px) {
  .ct-section__top { grid-template-columns: 1fr; }
  .ct-section__intro-col {
    padding-left: clamp(1.25rem, 4vw, 3rem);
    padding-right: clamp(1.25rem, 4vw, 3rem);
  }
  .ct-section__img-wrap { min-height: 0; aspect-ratio: 1 / 1; margin-top: clamp(2rem, 5vw, 3rem); }
}
@media (max-width: 900px) {
  .ct-hero__routes { grid-template-columns: 1fr; }
  .ct-hero__route { border-left: none; border-top: 1px solid var(--border); }
  .ct-hero__route:first-child { border-top: none; }
  .ct-svcs { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .ct-hero { padding-top: calc(76px + clamp(1rem, 3vw, 1.5rem)); padding-bottom: clamp(1.5rem, 4vw, 2.5rem); min-height: 0; }
  .ct-hero__title { font-size: var(--t-4xl); }
  .ct-svcs { grid-template-columns: 1fr; }
  .ct-section__label-num { font-size: var(--t-3xl); }
  .ct-section__heading { font-size: var(--t-3xl); }
  .ct-svc__name { font-size: var(--t-xl); }
}

/* ═══════════════════════════════════════════════════════════
   MOBILE / TABLET OPTIMIZATIONS
   ═══════════════════════════════════════════════════════════ */

/* ── Tablet (≤1024px) ─────────────────────────────────────── */
@media (max-width: 1024px) {
  .header-micro__tagline { display: none; }
  .header-micro__hours { display: none; }
  .header-logo__img { height: 58px; max-width: 180px; }
}

/* ── Small tablet / large phone (≤768px) ──────────────────── */
@media (max-width: 768px) {
  .site-header__bar { padding-block: 10px; }
  .header-logo__img { height: 58px; }

  /* Footer logo */
  .footer-logo__img { height: 150px; }
  .footer-brand-col .dva-logo__mark { font-size: 4rem; }

  /* CTA band buttons — stretch to full width on mobile */
  .footer-cta-band__actions .btn { width: 100%; justify-content: center; }
}

/* ── Phone landscape / large phone (≤640px) ─────────────────── */
@media (max-width: 640px) {
  /* Footer body — reduce excess padding on phone */
  .footer-body { padding-top: clamp(2.5rem, 7vw, 3.5rem); padding-bottom: clamp(1.5rem, 4vw, 2.5rem); }

  /* Footer logo */
  .footer-logo__img { height: 130px; }
  .footer-brand-tagline { max-width: 100%; }

  /* CTA band — tappable phone link */
  .footer-cta-band__phone { min-height: 44px; }

  /* Contact links — touch target */
  .footer-contact-item > div a { min-height: 40px; display: flex; align-items: center; }
}

/* ── Phone (≤480px) ───────────────────────────────────────── */
@media (max-width: 480px) {
  /* Header */
  .site-header__bar { padding-block: 8px; }
  .header-logo__img { height: 52px; max-width: 160px; }
  .header-cta-btn { display: none; }

  /* Mobile nav */
  .mobile-nav__contacts { flex-direction: column; gap: 6px; align-items: flex-start; }
  .mobile-nav__contact-item { font-size: 0.8rem; }
  .mobile-nav__foot { padding: 16px 20px; }

  /* Footer body — compact on small phones */
  .footer-body { padding-top: 2rem; padding-bottom: 1.5rem; }

  /* Footer logo */
  .footer-logo__img { height: 110px; }
  .footer-brand-col .dva-logo__mark { font-size: 3.2rem; line-height: 1.1; }

  /* Footer social links — 44px touch target */
  .footer-social__link { width: 44px; height: 44px; }

  /* Footer nav links — easier to tap */
  .footer-nav-col__list a { padding: 4px 0; min-height: 36px; display: flex; align-items: center; }

  /* Footer contact links — 44px touch target */
  .footer-contact-item > div a { min-height: 44px; }

  /* Footer CTA band compact */
  .footer-cta-band__inner { padding: 2rem 0; }
  .footer-cta-band__heading { font-size: clamp(1.2rem, 5vw, 1.8rem); }
}
