    /* ── Breadcrumb ── */
    .breadcrumb {
      background: var(--cream-dark);
      border-bottom: 1px solid var(--border);
      padding: 12px 0;
      font-size: 0.82rem;
      color: var(--ink-lighter);
    }
    .breadcrumb a { color: var(--gold); text-decoration: none; }
    .breadcrumb a:hover { text-decoration: underline; }
    .breadcrumb span { margin: 0 6px; }

    /* ── Hero ── */
    .firm-hero {
      background: #0a0c12;
      padding: 56px 0 48px;
      color: var(--white);
      position: relative;
      overflow: hidden;
    }
    .firm-hero-bg {
      position: absolute;
      inset: 0;
      background-size: cover;
      background-position: center 40%;
      opacity: 0.18;
      transition: opacity 0.5s;
    }
    .firm-hero-overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(135deg,
        rgba(10,12,18,0.75) 0%,
        rgba(10,12,18,0.45) 50%,
        rgba(10,12,18,0.80) 100%);
    }
    /* Gold left-edge accent */
    .firm-hero::before {
      content: '';
      position: absolute;
      top: 0; bottom: 0; left: 0;
      width: 4px;
    }
    .firm-hero-inner {
      display: grid;
      grid-template-columns: 1fr auto;
      gap: 40px;
      align-items: start;
      position: relative;
      z-index: 2;
    }
    .firm-hero-logo {
      width: 80px; height: 80px;
      border-radius: var(--radius-lg);
      border: 3px solid rgba(255,255,255,0.2);
      box-shadow: 0 4px 20px rgba(0,0,0,0.35);
      overflow: hidden;
      flex-shrink: 0;
      margin-bottom: 20px;
    }
    .firm-hero-logo svg { display: block; width: 100%; height: 100%; }
    .firm-hero h1 {
      font-family: var(--font-display);
      font-size: clamp(1.6rem, 3.5vw, 2.4rem);
      font-weight: 700;
      line-height: 1.2;
      margin-bottom: 12px;
      display: flex;
      align-items: center;
      gap: 10px;
      flex-wrap: wrap;
    }
    .firm-hero-meta {
      display: flex;
      flex-wrap: wrap;
      gap: 16px;
      font-size: 0.9rem;
      color: rgba(255,255,255,0.7);
      margin-bottom: 20px;
      align-items: center;
    }
    .firm-hero-meta strong { color: var(--white); }
    .firm-hero-meta .sep { color: rgba(255,255,255,0.25); }

    .firm-status-badge {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 6px 14px;
      border-radius: var(--radius-full);
      font-size: 0.8rem;
      font-weight: 600;
    }
    .firm-status-open  { background: rgba(45,122,74,0.25);  color: #6ee7a0; border: 1px solid rgba(45,122,74,0.4); }
    .firm-status-closed { background: rgba(185,28,28,0.2);  color: #fca5a5; border: 1px solid rgba(185,28,28,0.3); }
    .firm-status-dot { width: 7px; height: 7px; border-radius: 50%; background: currentColor; animation: pulse 2s ease-in-out infinite; }
    @keyframes pulse { 0%,100% { opacity:1; } 50% { opacity:0.4; } }

    .firm-hero-badges {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
    }
    .fh-badge {
      padding: 5px 12px;
      border-radius: var(--radius-full);
      font-size: 0.78rem;
      font-weight: 600;
      border: 1px solid rgba(255,255,255,0.15);
      color: rgba(255,255,255,0.85);
      background: rgba(255,255,255,0.07);
    }
    .fh-badge.gold { background: rgba(200,146,42,0.2); color: var(--gold-light); border-color: rgba(200,146,42,0.3); }

    /* ── Quick book card (sticky) ── */
    .firm-book-card {
      background: var(--white);
      border-radius: var(--radius-xl);
      padding: 28px;
      box-shadow: var(--shadow-xl);
      width: 340px;
      flex-shrink: 0;
    }
    .firm-book-card .price-big {
      font-family: var(--font-display);
      font-size: 2rem;
      font-weight: 700;
      color: var(--ink);
      margin-bottom: 4px;
    }
    .firm-book-card .price-sub {
      font-size: 0.82rem;
      color: var(--ink-lighter);
      margin-bottom: 20px;
    }
    .book-field { margin-bottom: 14px; }
    .book-field label {
      display: block;
      font-size: 0.8rem;
      font-weight: 600;
      color: var(--ink-soft);
      margin-bottom: 6px;
      text-transform: uppercase;
      letter-spacing: 0.05em;
    }
    .book-field select,
    .book-field input[type="text"] {
      width: 100%;
      padding: 10px 14px;
      border: 1.5px solid var(--border);
      border-radius: var(--radius);
      background: var(--cream);
      font-family: var(--font-body);
      font-size: 0.9rem;
      color: var(--ink);
      outline: none;
      transition: border-color var(--ease);
    }
    .book-field select:focus,
    .book-field input:focus { border-color: var(--gold); }

    .mode-toggle {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 8px;
    }
    .mode-btn {
      padding: 9px;
      border: 1.5px solid var(--border);
      border-radius: var(--radius);
      background: var(--cream);
      font-family: var(--font-body);
      font-size: 0.82rem;
      font-weight: 500;
      color: var(--ink-soft);
      cursor: pointer;
      text-align: center;
      transition: all var(--ease);
    }
    .mode-btn:hover, .mode-btn.active {
      background: var(--ink);
      border-color: var(--ink);
      color: var(--white);
    }

    .book-submit-btn {
      width: 100%;
      padding: 14px;
      background: var(--gold);
      color: var(--white);
      border: none;
      border-radius: var(--radius);
      font-family: var(--font-display);
      font-size: 1rem;
      font-weight: 700;
      cursor: pointer;
      transition: background var(--ease);
      margin-top: 8px;
    }
    .book-submit-btn:hover { background: var(--ink); }

    .book-trust {
      text-align: center;
      font-size: 0.75rem;
      color: var(--ink-lighter);
      margin-top: 12px;
    }

    /* ── Main content layout ── */
    .firm-content {
      padding: 56px 0 80px;
    }
    .firm-content-grid {
      display: grid;
      grid-template-columns: 1fr 340px;
      gap: 48px;
      align-items: start;
    }
    .firm-content-left {}

    .firm-section {
      margin-bottom: 48px;
    }
    .firm-section-title {
      font-family: var(--font-display);
      font-size: 1.3rem;
      font-weight: 700;
      color: var(--ink);
      margin-bottom: 20px;
      padding-bottom: 12px;
      border-bottom: 2px solid var(--border);
      display: flex;
      align-items: center;
      gap: 10px;
    }

    /* About */
    .firm-about-text {
      font-size: 0.95rem;
      line-height: 1.75;
      color: var(--ink-soft);
    }
    .firm-stats-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 16px;
      margin-top: 24px;
    }
    .firm-stat-box {
      background: var(--cream);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 16px;
      text-align: center;
    }
    .firm-stat-box strong {
      display: block;
      font-family: var(--font-display);
      font-size: 1.5rem;
      color: var(--ink);
    }
    .firm-stat-box span {
      font-size: 0.78rem;
      color: var(--ink-lighter);
    }

    /* Services */
    .services-list {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
      gap: 12px;
    }
    .service-item {
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 12px 16px;
      background: var(--cream);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      font-size: 0.88rem;
      color: var(--ink-soft);
    }
    .service-item::before {
      content: '✓';
      color: var(--gold);
      font-weight: 700;
      flex-shrink: 0;
    }

    /* Modes */
    .modes-row { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 4px; }
    .mode-chip {
      display: flex; align-items: center; gap: 8px;
      padding: 10px 18px;
      border-radius: var(--radius);
      background: var(--cream);
      border: 1px solid var(--border);
      font-size: 0.88rem;
      font-weight: 500;
    }

    /* Hours */
    .hours-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
      gap: 10px;
    }
    .hours-row {
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 10px 14px;
      border-radius: var(--radius);
      background: var(--cream);
      border: 1px solid var(--border);
      font-size: 0.88rem;
    }
    .hours-row.today {
      background: var(--gold-pale);
      border-color: rgba(200,146,42,0.3);
    }
    .hours-day   { font-weight: 600; color: var(--ink); }
    .hours-time  { color: var(--ink-soft); }
    .hours-closed { color: var(--ink-lighter); font-style: italic; }

    /* Reviews */
    .reviews-summary {
      display: flex;
      align-items: center;
      gap: 32px;
      padding: 24px;
      background: var(--cream);
      border: 1px solid var(--border);
      border-radius: var(--radius-lg);
      margin-bottom: 28px;
      flex-wrap: wrap;
    }
    .reviews-big-rating {
      text-align: center;
    }
    .reviews-big-rating .score {
      font-family: var(--font-display);
      font-size: 3.5rem;
      font-weight: 700;
      color: var(--ink);
      line-height: 1;
    }
    .reviews-big-rating .stars { color: var(--gold); font-size: 1.2rem; letter-spacing: 2px; }
    .reviews-big-rating .sub  { font-size: 0.82rem; color: var(--ink-lighter); margin-top: 4px; }

    .reviews-bars { flex: 1; min-width: 200px; }
    .rev-bar-row { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; font-size: 0.8rem; }
    .rev-bar-label { width: 28px; text-align: right; color: var(--ink-soft); font-weight: 500; }
    .rev-bar-track { flex: 1; background: var(--border); border-radius: var(--radius-full); height: 6px; }
    .rev-bar-fill  { height: 100%; background: var(--gold); border-radius: var(--radius-full); }
    .rev-bar-count { width: 24px; color: var(--ink-lighter); }

    .review-card {
      background: var(--white);
      border: 1.5px solid var(--border);
      border-radius: var(--radius-lg);
      padding: 22px;
      margin-bottom: 16px;
    }
    .review-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      margin-bottom: 12px;
      flex-wrap: wrap;
      gap: 8px;
    }
    .reviewer-info { display: flex; align-items: center; gap: 10px; }
    .reviewer-avatar {
      width: 38px; height: 38px;
      border-radius: 50%;
      background: var(--ink);
      color: var(--white);
      font-weight: 700;
      font-size: 0.85rem;
      display: flex; align-items: center; justify-content: center;
    }
    .reviewer-name { font-weight: 600; font-size: 0.92rem; color: var(--ink); }
    .reviewer-date { font-size: 0.78rem; color: var(--ink-lighter); }
    .review-stars  { color: var(--gold); letter-spacing: 1px; font-size: 0.9rem; }
    .review-body   { font-size: 0.9rem; color: var(--ink-soft); line-height: 1.65; }

    /* Map placeholder */
    .firm-map {
      background: var(--cream);
      border: 1px solid var(--border);
      border-radius: var(--radius-lg);
      overflow: hidden;
    }
    .firm-map-placeholder {
      height: 220px;
      background: linear-gradient(135deg, var(--cream-dark) 0%, var(--cream) 100%);
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      color: var(--ink-lighter);
      font-size: 0.9rem;
      gap: 8px;
    }
    .firm-map-placeholder .map-pin { font-size: 2.5rem; }
    .firm-map-address {
      padding: 14px 18px;
      font-size: 0.88rem;
      color: var(--ink-soft);
      border-top: 1px solid var(--border);
    }

    /* Sticky sidebar */
    .firm-sidebar-sticky {
      position: sticky;
      top: calc(var(--nav-h) + 24px);
    }

    @media (max-width: 960px) {
      .firm-hero-inner    { grid-template-columns: 1fr; }
      .firm-book-card     { width: 100%; }
      .firm-content-grid  { grid-template-columns: 1fr; }
      .firm-sidebar-sticky { position: static; }
      .firm-stats-grid    { grid-template-columns: repeat(2,1fr); }
    }
    @media (max-width: 600px) {
      .reviews-summary { flex-direction: column; }
    }
