/* ============================================================
   LegalFirms.in — LP Pages CSS v2
   Premium redesign: Inter font, refined hierarchy, mobile-first
   ============================================================ */

/* ── Google Fonts: Inter ──────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

/* ── Reset ──────────────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
    overflow-x:hidden;
    font-family:'Inter',system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
    background:#f8fafc;
    color:#0f172a;
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
}
img { max-width:100%; height:auto; }
a { color:inherit; }

/* ── CSS Variables ───────────────────────────────────────── */
:root {
    --primary:       #1d4ed8;
    --primary-light: #3b82f6;
    --primary-hover: #1e40af;
    --accent:        #7c3aed;
    --success:       #059669;
    --warning:       #d97706;
    --danger:        #dc2626;
    --gold:          #d97706;
    --gold-bg:       #fef3c7;
    --dark:          #0a0f1e;
    --dark-2:        #111827;
    --text:          #0f172a;
    --text-2:        #374151;
    --text-3:        #6b7280;
    --text-4:        #9ca3af;
    --border:        #e5e7eb;
    --border-2:      #f1f5f9;
    --surface:       #ffffff;
    --surface-2:     #f8fafc;
    --surface-3:     #f1f5f9;
    --shadow-xs:     0 1px 2px rgba(0,0,0,.05);
    --shadow-sm:     0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06);
    --shadow:        0 4px 6px -1px rgba(0,0,0,.08),0 2px 4px -1px rgba(0,0,0,.06);
    --shadow-md:     0 10px 15px -3px rgba(0,0,0,.08),0 4px 6px -2px rgba(0,0,0,.04);
    --shadow-lg:     0 20px 25px -5px rgba(0,0,0,.08),0 10px 10px -5px rgba(0,0,0,.04);
    --shadow-blue:   0 8px 24px rgba(29,78,216,.25);
    --shadow-blue-lg:0 16px 40px rgba(29,78,216,.35);
    --radius-sm:     8px;
    --radius:        12px;
    --radius-lg:     16px;
    --radius-xl:     20px;
    --max-w:         1280px;
    --max-w-text:    720px;
}

/* ════════════════════════════════════════════════════════════
   HEADER
════════════════════════════════════════════════════════════ */
.public-header {
    position:sticky; top:0; z-index:1000;
    background:rgba(10,15,30,0.96);
    border-bottom:1px solid rgba(255,255,255,.07);
    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);
    transition:background .3s,box-shadow .3s,border-color .3s;
}
.public-header.scrolled {
    background:rgba(5,7,15,0.98);
    box-shadow:0 4px 30px rgba(0,0,0,.5);
    border-color:rgba(255,255,255,.05);
}
.header-container {
    max-width:var(--max-w); margin:0 auto;
    padding:0 1.5rem;
    display:flex; align-items:center; justify-content:space-between;
    gap:1rem; height:72px;
}
/* height shrink removed — caused layout reflow shake */
.logo { display:flex; align-items:center; text-decoration:none; flex-shrink:0; }
.logo img {
    height:42px; width:auto; object-fit:contain; display:block;
}
/* logo shrink removed — caused reflow */

.nav-menu { display:flex; align-items:center; gap:.25rem; list-style:none; }
/* Mobile: hidden by default, shown via .active */
@media(max-width:900px){
    .nav-menu { display:none; }
    .nav-menu.active { display:flex; }
}
.nav-menu a {
    position:relative; text-decoration:none;
    color:rgba(255,255,255,.75);
    font-size:.8rem; font-weight:600;
    letter-spacing:.06em; text-transform:uppercase;
    padding:.5rem .75rem; border-radius:7px;
    transition:color .2s,background .2s;
}
.nav-menu a:hover { color:#fff; background:rgba(255,255,255,.06); }
.nav-menu a.active { color:#fff; background:none; }

.btn-primary {
    display:inline-flex; align-items:center; justify-content:center;
    padding:.6rem 1.25rem; border-radius:9px;
    background:linear-gradient(135deg,var(--primary-light),var(--primary));
    color:#fff; font-size:.8rem; font-weight:700;
    letter-spacing:.04em; text-transform:uppercase;
    border:1px solid rgba(255,255,255,.1);
    box-shadow:0 4px 14px rgba(59,130,246,.3);
    text-decoration:none; cursor:pointer; font-family:inherit;
    transition:transform .2s,box-shadow .2s,opacity .2s;
    white-space:nowrap; min-width:0; width:auto;
    margin-left:.5rem;
}
.btn-primary:hover {
    transform:translateY(-1px);
    box-shadow:0 8px 20px rgba(59,130,246,.4);
}
.mobile-toggle {
    display:none; width:42px; height:42px; border:none;
    border-radius:9px; background:rgba(255,255,255,.07);
    color:#fff; cursor:pointer; font-size:1rem;
    transition:background .2s;
    align-items:center; justify-content:center;
    flex-shrink:0;
}
.mobile-toggle:hover { background:rgba(255,255,255,.14); }

/* ── Breadcrumb ──────────────────────────────────────────── */
.lp-breadcrumb {
    background:#fff; border-bottom:1px solid var(--border);
    padding:.5rem 0;
}
.lp-breadcrumb-inner {
    max-width:var(--max-w); margin:0 auto; padding:0 1.5rem;
    display:flex; align-items:center; flex-wrap:wrap;
    gap:.25rem; font-size:.75rem; color:var(--text-3);
}
.lp-breadcrumb-inner a { color:var(--primary); text-decoration:none; font-weight:500; }
.lp-breadcrumb-inner a:hover { text-decoration:underline; }
.lp-breadcrumb-inner .sep { color:var(--border); margin:0 .125rem; }

/* ════════════════════════════════════════════════════════════
   HERO — premium dark with legal visual language
════════════════════════════════════════════════════════════ */
.lp-hero {
    position:relative; overflow:hidden;
    background:linear-gradient(160deg, #050c1a 0%, #0d1f3c 45%, #0a1628 100%);
    color:#fff;
    padding:5rem 1.5rem 4.5rem;
}
/* Subtle legal-pattern overlay */
.lp-hero::before {
    content:'';
    position:absolute; inset:0; pointer-events:none;
    background:
        radial-gradient(ellipse 80% 60% at 70% 40%, rgba(59,130,246,.12) 0%, transparent 70%),
        radial-gradient(ellipse 40% 40% at 20% 80%, rgba(124,58,237,.08) 0%, transparent 60%);
}
/* Gold accent line at top */
.lp-hero::after {
    content:'';
    position:absolute; top:0; left:0; right:0; height:3px;
    background:linear-gradient(90deg, transparent, #d97706 30%, #f59e0b 50%, #d97706 70%, transparent);
}
.lp-hero-inner {
    max-width:var(--max-w-text); margin:0 auto;
    position:relative; text-align:center;
}
.lp-hero-eyebrow {
    display:inline-flex; align-items:center; gap:.5rem;
    background:rgba(217,119,6,.15); color:#fbbf24;
    border:1px solid rgba(217,119,6,.3); border-radius:999px;
    padding:.35rem 1rem; font-size:.72rem; font-weight:700;
    letter-spacing:.1em; text-transform:uppercase; margin-bottom:1.75rem;
}
.lp-hero-eyebrow i { font-size:.65rem; }

.lp-hero h1 {
    font-size:clamp(1.875rem, 5vw, 3rem);
    font-weight:900; line-height:1.1;
    margin-bottom:1.25rem; color:#fff;
    letter-spacing:-.035em;
}
.lp-hero h1 em {
    font-style:normal;
    background:linear-gradient(135deg,#60a5fa,#818cf8);
    -webkit-background-clip:text; -webkit-text-fill-color:transparent;
    background-clip:text;
}
.lp-hero-sub {
    font-size:1.0625rem; color:rgba(255,255,255,.72);
    margin:0 auto 2.5rem; line-height:1.8;
    max-width:540px; font-weight:400;
}
.lp-hero-actions {
    display:flex; gap:.875rem; justify-content:center;
    flex-wrap:wrap; margin-bottom:3rem;
}
.lp-hero-btn {
    display:inline-flex; align-items:center; gap:.5rem;
    padding:.875rem 1.875rem; border-radius:var(--radius);
    font-size:.9375rem; font-weight:700; text-decoration:none;
    letter-spacing:.01em; transition:all .25s ease;
    cursor:pointer; border:none; font-family:inherit;
    white-space:nowrap;
}
.lp-hero-btn--primary {
    background:linear-gradient(135deg,#2563eb,#1d4ed8);
    color:#fff;
    box-shadow:var(--shadow-blue-lg);
}
.lp-hero-btn--primary:hover {
    transform:translateY(-2px);
    box-shadow:0 20px 48px rgba(29,78,216,.5);
}
.lp-hero-btn--ghost {
    background:rgba(255,255,255,.07); color:rgba(255,255,255,.9);
    border:1.5px solid rgba(255,255,255,.18);
}
.lp-hero-btn--ghost:hover {
    background:rgba(255,255,255,.13);
    border-color:rgba(255,255,255,.3);
}
/* Trust strip below CTA */
.lp-hero-trust {
    display:flex; flex-wrap:wrap; gap:1.25rem 2rem;
    justify-content:center; font-size:.8rem;
    color:rgba(255,255,255,.55);
    padding-top:2.5rem;
    border-top:1px solid rgba(255,255,255,.08);
}
.lp-hero-trust-item {
    display:flex; align-items:center; gap:.4rem;
    font-weight:500;
}
.lp-hero-trust-item i { color:#34d399; font-size:.8rem; }

/* ── Stats bar ──────────────────────────────────────────── */
.lp-stats-bar {
    background:#fff;
    border-bottom:2px solid var(--border-2);
    padding:.875rem 1.5rem;
}
.lp-stats-inner {
    max-width:var(--max-w); margin:0 auto;
    display:flex; flex-wrap:wrap; gap:1.5rem 3rem;
    justify-content:center; align-items:center;
}
.lp-stat { display:flex; align-items:center; gap:.625rem; }
.lp-stat-num {
    font-size:1.375rem; font-weight:900; color:var(--text);
    line-height:1; letter-spacing:-.02em;
}
.lp-stat-label { font-size:.8125rem; color:var(--text-3); font-weight:500; line-height:1.3; }
.lp-stat-sep { width:1px; height:28px; background:var(--border); }

/* ════════════════════════════════════════════════════════════
   SECTION SYSTEM
════════════════════════════════════════════════════════════ */
.lp-section { padding:4rem 1.5rem; }
.lp-section--alt { background:#fff; }
.lp-section--dark {
    background:linear-gradient(160deg,#0a0f1e,#0d1a30);
    color:#fff;
}
.lp-wrap { max-width:var(--max-w); margin:0 auto; }

.lp-section-label {
    display:inline-flex; align-items:center; gap:.4rem;
    font-size:.7rem; font-weight:700; letter-spacing:.1em;
    text-transform:uppercase; color:var(--primary);
    margin-bottom:.625rem;
}
.lp-section-label::before {
    content:''; display:block;
    width:18px; height:2px;
    background:var(--primary); border-radius:999px;
}
.lp-section-head { margin-bottom:2.5rem; }
.lp-section-head h2 {
    font-size:clamp(1.375rem,3vw,1.875rem);
    font-weight:800; color:var(--text);
    letter-spacing:-.03em; margin-bottom:.5rem; line-height:1.2;
}
.lp-section--dark .lp-section-head h2 { color:#fff; }
.lp-section-head p { font-size:.9375rem; color:var(--text-3); line-height:1.7; }
.lp-section--dark .lp-section-head p { color:rgba(255,255,255,.65); }

/* ── CTA Inline ─────────────────────────────────────────── */
.lp-cta-inline {
    background:linear-gradient(135deg,#eff6ff,#f5f3ff);
    border-top:1px solid #dbeafe; border-bottom:1px solid #dbeafe;
    padding:3rem 1.5rem;
}
.lp-cta-inline-inner {
    max-width:600px; margin:0 auto; text-align:center;
}
.lp-cta-inline-inner h2 {
    font-size:1.5rem; font-weight:800; color:var(--text);
    margin-bottom:.625rem; letter-spacing:-.03em;
}
.lp-cta-inline-inner p {
    font-size:.9375rem; color:var(--text-3);
    margin-bottom:1.75rem; line-height:1.7;
}
.lp-cta-btn {
    display:inline-flex; align-items:center; gap:.5rem;
    padding:.9rem 2.25rem; border-radius:var(--radius); border:none;
    cursor:pointer; font-family:inherit;
    background:linear-gradient(135deg,#2563eb,#1d4ed8); color:#fff;
    font-size:.9375rem; font-weight:700;
    box-shadow:var(--shadow-blue);
    transition:transform .2s,box-shadow .2s;
}
.lp-cta-btn:hover {
    transform:translateY(-2px);
    box-shadow:var(--shadow-blue-lg);
}
.lp-cta-note { font-size:.75rem; color:var(--text-4); margin-top:.625rem; }

/* ════════════════════════════════════════════════════════════
   ADVOCATE / FIRM CARDS
════════════════════════════════════════════════════════════ */
.lp-grid {
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
    gap:1.25rem;
}
.lp-card {
    background:#fff; border-radius:var(--radius-lg);
    border:1.5px solid var(--border);
    padding:1.5rem; position:relative;
    display:flex; flex-direction:column;
    transition:box-shadow .25s,transform .25s,border-color .25s;
}
.lp-card:hover {
    box-shadow:var(--shadow-lg);
    transform:translateY(-3px);
    border-color:#cbd5e1;
}
/* Verified accent bar */
.lp-card--verified::before {
    content:''; position:absolute; top:0; left:0; right:0;
    height:3px; border-radius:var(--radius-lg) var(--radius-lg) 0 0;
    background:linear-gradient(90deg,var(--primary),var(--accent));
}
.lp-card-head {
    display:flex; gap:.875rem; align-items:flex-start;
    margin-bottom:1rem;
}
.lp-card-avatar {
    width:60px; height:60px; border-radius:50%; flex-shrink:0;
    object-fit:cover;
    border:2px solid var(--border-2);
}
.lp-card-avatar-placeholder {
    width:60px; height:60px; border-radius:50%; flex-shrink:0;
    background:linear-gradient(135deg,var(--primary),var(--accent));
    display:flex; align-items:center; justify-content:center;
    color:#fff; font-size:1.25rem; font-weight:800;
}
.lp-card-info { flex:1; min-width:0; }
.lp-card-name {
    font-size:1rem; font-weight:700; color:var(--text);
    margin-bottom:.25rem; line-height:1.3;
    white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.lp-card-meta {
    font-size:.78rem; color:var(--text-3);
    display:flex; flex-wrap:wrap; gap:.2rem .5rem; align-items:center;
    margin-bottom:.5rem; line-height:1.5;
}
.lp-card-meta i { color:var(--text-4); font-size:.7rem; }
.lp-card-badges { display:flex; flex-wrap:wrap; gap:.3rem; }

/* Badges */
.lp-badge {
    display:inline-flex; align-items:center; gap:.2rem;
    padding:.18rem .5rem; border-radius:5px;
    font-size:.67rem; font-weight:700; line-height:1.4;
    white-space:nowrap;
}
.lp-badge--gold      { background:#fef3c7; color:#92400e; border:1px solid #fde68a; }
.lp-badge--verified  { background:#ecfdf5; color:#065f46; border:1px solid #a7f3d0; }
.lp-badge--premium   { background:#ede9fe; color:#5b21b6; border:1px solid #ddd6fe; }
.lp-badge--free      { background:#f0fdf4; color:#166534; border:1px solid #bbf7d0; }
.lp-badge--barcouncil{ background:#eff6ff; color:#1e40af; border:1px solid #bfdbfe; }
.lp-badge--new       { background:#fff7ed; color:#9a3412; border:1px solid #fed7aa; }

.lp-card-about {
    font-size:.8125rem; color:#475569; line-height:1.65;
    display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;
    overflow:hidden; margin-bottom:1.125rem; flex:1;
}
.lp-card-actions { display:flex; gap:.5rem; margin-top:auto; }
.lp-btn-contact {
    flex:1; padding:.625rem 1rem;
    background:var(--primary); color:#fff; border:none;
    border-radius:var(--radius-sm);
    font-size:.8125rem; font-weight:700; cursor:pointer;
    display:flex; align-items:center; justify-content:center; gap:.375rem;
    transition:background .15s; text-decoration:none; font-family:inherit;
}
.lp-btn-contact:hover { background:var(--primary-hover); }
.lp-btn-outline {
    padding:.625rem .875rem;
    border:1.5px solid var(--border); color:var(--text-2);
    border-radius:var(--radius-sm);
    font-size:.8125rem; font-weight:600; cursor:pointer;
    display:flex; align-items:center; gap:.35rem;
    transition:border-color .15s,color .15s; background:#fff;
    text-decoration:none; white-space:nowrap; font-family:inherit;
}
.lp-btn-outline:hover { border-color:var(--primary); color:var(--primary); }

.lp-load-more { text-align:center; margin-top:2rem; }
.lp-load-more a {
    display:inline-flex; align-items:center; gap:.5rem;
    padding:.75rem 2rem; border-radius:var(--radius);
    border:1.5px solid var(--border); color:var(--text-2);
    font-size:.875rem; font-weight:700; text-decoration:none;
    transition:all .2s; background:#fff;
}
.lp-load-more a:hover { border-color:var(--primary); color:var(--primary); background:#eff6ff; }

/* ════════════════════════════════════════════════════════════
   PROCESS STEPS — redesigned horizontal with connectors
════════════════════════════════════════════════════════════ */
.lp-steps {
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:0;
    position:relative;
}
.lp-steps::before {
    content:''; position:absolute;
    top:42px; left:calc(16.666% + 26px); right:calc(16.666% + 26px);
    height:2px;
    background:linear-gradient(90deg,var(--primary),var(--accent));
    opacity:.25;
    pointer-events:none;
}
.lp-step {
    text-align:center; padding:1.5rem 1.5rem 0;
    position:relative;
}
.lp-step-num {
    width:52px; height:52px; border-radius:50%;
    background:linear-gradient(135deg,var(--primary),var(--accent));
    color:#fff; font-size:1.125rem; font-weight:800;
    display:flex; align-items:center; justify-content:center;
    margin:0 auto 1.25rem;
    box-shadow:0 8px 20px rgba(29,78,216,.3);
    position:relative; z-index:1;
}
.lp-step h3 {
    font-size:.9375rem; font-weight:700; color:var(--text);
    margin-bottom:.5rem; letter-spacing:-.01em;
}
.lp-step p { font-size:.8375rem; color:var(--text-3); line-height:1.7; }

/* ════════════════════════════════════════════════════════════
   TRUST SIGNALS — tighter, icon-forward
════════════════════════════════════════════════════════════ */
.lp-trust-grid {
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:1rem;
}
.lp-trust-item {
    display:flex; align-items:flex-start; gap:.875rem;
    background:#fff; border-radius:var(--radius);
    border:1.5px solid var(--border-2);
    padding:1.25rem; transition:box-shadow .2s,border-color .2s;
}
.lp-trust-item:hover { box-shadow:var(--shadow-md); border-color:#dbeafe; }
.lp-trust-icon {
    width:42px; height:42px; border-radius:10px;
    background:linear-gradient(135deg,#eff6ff,#dbeafe);
    display:flex; align-items:center; justify-content:center;
    flex-shrink:0; font-size:.9375rem; color:var(--primary);
}
.lp-trust-title { font-size:.875rem; font-weight:700; color:var(--text); margin-bottom:.25rem; }
.lp-trust-desc { font-size:.775rem; color:var(--text-3); line-height:1.6; }

/* ════════════════════════════════════════════════════════════
   FAQs — clean accordion
════════════════════════════════════════════════════════════ */
.lp-faq-wrap { max-width:820px; }
.lp-faq-list { display:flex; flex-direction:column; gap:.5rem; }
.lp-faq-item {
    border:1.5px solid var(--border); border-radius:var(--radius);
    overflow:hidden; background:#fff;
    transition:border-color .2s,box-shadow .2s;
}
.lp-faq-item:has(.lp-faq-q[aria-expanded="true"]) {
    border-color:#bfdbfe;
    box-shadow:0 4px 12px rgba(29,78,216,.08);
}
.lp-faq-q {
    width:100%; background:none; border:none; text-align:left;
    padding:1.125rem 1.375rem; cursor:pointer;
    display:flex; align-items:center; justify-content:space-between; gap:1rem;
    font-size:.9rem; font-weight:600; color:var(--text);
    line-height:1.5; transition:background .15s; font-family:inherit;
}
.lp-faq-q:hover { background:var(--surface-2); }
.lp-faq-icon {
    flex-shrink:0; color:var(--text-4); font-size:.8rem;
    transition:transform .25s,color .2s;
}
.lp-faq-q[aria-expanded="true"] .lp-faq-icon {
    transform:rotate(180deg); color:var(--primary);
}
.lp-faq-a {
    display:none; padding:0 1.375rem 1.25rem;
    font-size:.875rem; color:#475569; line-height:1.85;
    border-top:1px solid var(--border-2); padding-top:1rem;
}
.lp-faq-a.open { display:block; }

/* ════════════════════════════════════════════════════════════
   Q&A LIST
════════════════════════════════════════════════════════════ */
.lp-q-list { display:flex; flex-direction:column; gap:.5rem; }
.lp-q-item {
    display:block; background:#fff; border:1.5px solid var(--border);
    border-radius:var(--radius); padding:1rem 1.25rem;
    text-decoration:none;
    transition:border-color .15s,box-shadow .15s,transform .15s;
}
.lp-q-item:hover {
    border-color:var(--primary);
    box-shadow:0 4px 12px rgba(29,78,216,.08);
    transform:translateX(2px);
}
.lp-q-title {
    font-size:.875rem; font-weight:600; color:var(--text);
    margin-bottom:.3rem; line-height:1.45;
}
.lp-q-meta { font-size:.75rem; color:var(--text-3); display:flex; align-items:center; gap:.625rem; flex-wrap:wrap; }
.lp-q-answers { color:var(--success); font-weight:600; }

/* ════════════════════════════════════════════════════════════
   RELATED TAGS
════════════════════════════════════════════════════════════ */
.lp-tags { display:flex; flex-wrap:wrap; gap:.5rem; margin-top:1.5rem; }
.lp-tag {
    display:inline-flex; align-items:center; gap:.35rem;
    padding:.4rem .875rem; border-radius:999px;
    font-size:.8rem; font-weight:600;
    text-decoration:none; transition:all .2s; white-space:nowrap;
}
.lp-tag--city { background:#fff; border:1.5px solid var(--border); color:var(--text-2); }
.lp-tag--city:hover { border-color:var(--primary); color:var(--primary); background:#eff6ff; }
.lp-tag--practice { background:#eff6ff; border:1.5px solid #bfdbfe; color:#1e40af; }
.lp-tag--practice:hover { background:#dbeafe; }

/* ════════════════════════════════════════════════════════════
   PRACTICE INFO
════════════════════════════════════════════════════════════ */
.lp-practice-intro {
    max-width:800px;
    font-size:.9375rem; color:#475569; line-height:1.85;
}

/* ════════════════════════════════════════════════════════════
   NRI CTA BANNER
════════════════════════════════════════════════════════════ */
.lp-nri-banner {
    background:linear-gradient(135deg,#0d1f3c,#0a0f1e);
    border-radius:var(--radius-xl);
    padding:3rem 2rem;
    text-align:center; color:#fff;
    position:relative; overflow:hidden;
    border:1px solid rgba(255,255,255,.07);
}
.lp-nri-banner::before {
    content:'';
    position:absolute; top:-40%; right:-10%;
    width:400px; height:400px; border-radius:50%;
    background:radial-gradient(circle,rgba(59,130,246,.12),transparent 70%);
    pointer-events:none;
}
.lp-nri-badge {
    display:inline-flex; align-items:center; gap:.4rem;
    background:rgba(217,119,6,.15); color:#fbbf24;
    border:1px solid rgba(217,119,6,.3); border-radius:999px;
    padding:.3rem .875rem; font-size:.7rem; font-weight:700;
    letter-spacing:.08em; text-transform:uppercase; margin-bottom:1.125rem;
}
.lp-nri-banner h3 {
    font-size:1.5rem; font-weight:800; margin-bottom:.75rem;
    color:#fff; letter-spacing:-.025em;
}
.lp-nri-banner p {
    color:rgba(255,255,255,.68); font-size:.9375rem;
    margin-bottom:1.75rem; line-height:1.75;
    max-width:480px; margin-left:auto; margin-right:auto;
}
.lp-nri-btn {
    display:inline-flex; align-items:center; gap:.5rem;
    padding:.875rem 2rem; border-radius:var(--radius); border:none;
    cursor:pointer; font-family:inherit;
    background:#d97706; color:#fff;
    font-size:.9375rem; font-weight:700;
    box-shadow:0 8px 24px rgba(217,119,6,.4);
    transition:transform .2s,box-shadow .2s;
}
.lp-nri-btn:hover { transform:translateY(-2px); box-shadow:0 14px 32px rgba(217,119,6,.55); }

/* ════════════════════════════════════════════════════════════
   BOTTOM CTA BANNER
════════════════════════════════════════════════════════════ */
.lp-cta-banner {
    padding:5rem 1.5rem;
    background:linear-gradient(160deg,#050c1a 0%,#0d1f3c 100%);
    text-align:center; color:#fff;
    position:relative; overflow:hidden;
}
.lp-cta-banner::before {
    content:''; position:absolute; inset:0;
    background:radial-gradient(ellipse 70% 60% at 50% 100%, rgba(59,130,246,.15), transparent);
    pointer-events:none;
}
.lp-cta-banner h2 {
    font-size:clamp(1.5rem,4vw,2.25rem);
    font-weight:800; margin-bottom:.875rem; color:#fff;
    letter-spacing:-.035em; position:relative;
}
.lp-cta-banner p {
    color:rgba(255,255,255,.68); font-size:1rem;
    margin:0 auto 2.25rem; line-height:1.75;
    max-width:500px; position:relative;
}
.lp-cta-btn--gold {
    display:inline-flex; align-items:center; gap:.5rem;
    padding:.9rem 2.5rem; border-radius:var(--radius); border:none;
    cursor:pointer; font-family:inherit;
    background:linear-gradient(135deg,#f59e0b,#d97706);
    color:#0a0f1e; font-size:.9375rem; font-weight:800;
    box-shadow:0 8px 24px rgba(217,119,6,.4);
    transition:transform .2s,box-shadow .2s;
    position:relative;
}
.lp-cta-btn--gold:hover {
    transform:translateY(-2px);
    box-shadow:0 16px 40px rgba(217,119,6,.55);
}

/* ════════════════════════════════════════════════════════════
   LEAD MODAL — compact, no-scroll, premium
════════════════════════════════════════════════════════════ */
/* The modal HTML is now generated by LFLead widget (lead-modal.js)
   These styles are kept for any legacy fallback references */
.lp-modal-overlay {
    position:fixed; inset:0; background:rgba(0,0,0,.65);
    z-index:9000; display:none; align-items:flex-end; justify-content:center;
    backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px);
}
.lp-modal-overlay.is-open { display:flex; }
.lp-modal {
    background:#fff; border-radius:var(--radius-xl) var(--radius-xl) 0 0;
    width:100%; max-width:480px;
    max-height:90dvh; overflow-y:auto;
    animation:slideUp .3s cubic-bezier(.34,1.26,.64,1);
}
@keyframes slideUp {
    from { transform:translateY(100%); opacity:0; }
    to   { transform:translateY(0);    opacity:1; }
}
.lp-modal-header {
    padding:1.25rem 1.375rem .875rem;
    position:sticky; top:0; background:#fff; z-index:1;
    border-bottom:1px solid var(--border-2);
}
.lp-modal-close {
    position:absolute; top:.875rem; right:.875rem;
    width:30px; height:30px; border-radius:50%;
    background:var(--surface-3); border:none; cursor:pointer;
    display:flex; align-items:center; justify-content:center;
    color:var(--text-3); font-size:.8rem;
    transition:background .15s; font-family:inherit;
}
.lp-modal-close:hover { background:var(--border); color:var(--text); }
.lp-modal-title { font-size:1.0625rem; font-weight:800; color:var(--text); padding-right:2.5rem; }
.lp-modal-sub { font-size:.78rem; color:var(--text-3); margin-top:.2rem; }
.lp-modal-body { padding:1rem 1.375rem 1.375rem; }
.lp-field { margin-bottom:.875rem; }
.lp-field label { display:block; font-size:.78rem; font-weight:600; color:var(--text-2); margin-bottom:.3rem; }
.lp-field label .req { color:var(--danger); }
.lp-field label .opt { color:var(--text-4); font-weight:400; }
.lp-input, .lp-textarea, .lp-select {
    width:100%; padding:.625rem .875rem;
    border:1.5px solid var(--border); border-radius:var(--radius-sm);
    font-size:.875rem; color:var(--text); background:#fff;
    font-family:inherit; outline:none;
    transition:border-color .15s,box-shadow .15s;
}
.lp-input:focus, .lp-textarea:focus, .lp-select:focus {
    border-color:var(--primary);
    box-shadow:0 0 0 3px rgba(29,78,216,.1);
}
.lp-textarea { resize:vertical; min-height:80px; }
.lp-field-row { display:grid; grid-template-columns:1fr 1fr; gap:.75rem; }
.lp-phone-row { display:flex; gap:.5rem; }
.lp-phone-row .lp-select { width:90px; flex-shrink:0; }
.lp-phone-row .lp-input { flex:1; }
.lp-honeypot { display:none!important; }
.lp-form-errors {
    background:#fef2f2; border:1px solid #fecaca; border-radius:var(--radius-sm);
    padding:.625rem .875rem; margin-bottom:.875rem;
    font-size:.8rem; color:#991b1b; display:none;
}
.lp-form-errors p { margin:0 0 .2rem; }
.lp-form-errors p:last-child { margin:0; }
.lp-btn-submit {
    width:100%; padding:.8rem; border-radius:var(--radius-sm);
    border:none; cursor:pointer; font-family:inherit;
    background:linear-gradient(135deg,var(--primary-light),var(--primary));
    color:#fff; font-size:.9375rem; font-weight:700;
    display:flex; align-items:center; justify-content:center; gap:.5rem;
    transition:opacity .15s,transform .15s;
}
.lp-btn-submit:hover { opacity:.92; transform:translateY(-1px); }
.lp-btn-submit:disabled { opacity:.5; cursor:not-allowed; transform:none; }
.lp-form-note { font-size:.72rem; color:var(--text-4); text-align:center; margin-top:.5rem; }

/* Success step */
.lp-success-wrap { text-align:center; padding:1.5rem 0; display:none; }
.lp-success-icon {
    width:64px; height:64px; border-radius:50%;
    background:#d1fae5; color:#059669;
    font-size:1.75rem; display:flex; align-items:center; justify-content:center;
    margin:0 auto 1.125rem;
}
.lp-success-wrap h3 { font-size:1.125rem; font-weight:800; color:var(--text); margin-bottom:.5rem; }
.lp-success-wrap p { font-size:.875rem; color:var(--text-3); line-height:1.65; margin-bottom:1.25rem; }
.lp-success-link {
    display:inline-block; padding:.625rem 1.5rem;
    background:#eff6ff; color:var(--primary); border-radius:var(--radius-sm);
    font-size:.875rem; font-weight:700; text-decoration:none;
    transition:background .15s;
}
.lp-success-link:hover { background:#dbeafe; }

/* ════════════════════════════════════════════════════════════
   FOOTER
════════════════════════════════════════════════════════════ */
.site-footer {
    background:#070b14;
    color:#fff; margin-top:0;
    border-top:1px solid rgba(255,255,255,.06);
}
.footer-container { max-width:var(--max-w); margin:0 auto; padding:4rem 1.5rem 2rem; }
.footer-top {
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:2.5rem; padding-bottom:3rem;
    border-bottom:1px solid rgba(255,255,255,.06);
    margin-bottom:2.5rem;
}
.footer-column h3 {
    font-size:.75rem; font-weight:700; letter-spacing:.1em;
    text-transform:uppercase; margin-bottom:1.25rem;
    color:rgba(255,255,255,.5);
}
.footer-links { display:flex; flex-direction:column; gap:.875rem; }
.footer-links a {
    color:rgba(255,255,255,.65); text-decoration:none;
    font-size:.875rem; transition:color .2s;
}
.footer-links a:hover { color:#fff; }
.footer-disclaimer {
    margin-bottom:2rem;
    padding:1.125rem 1.25rem;
    background:rgba(255,255,255,.03);
    border:1px solid rgba(255,255,255,.06);
    border-radius:var(--radius);
}
.footer-disclaimer p { margin:0; color:rgba(255,255,255,.45); font-size:.78rem; line-height:1.85; }
.footer-social {
    display:flex; align-items:center; justify-content:center;
    gap:.875rem; flex-wrap:wrap; padding-bottom:2rem;
}
.footer-social a {
    width:40px; height:40px; border-radius:10px;
    display:flex; align-items:center; justify-content:center;
    text-decoration:none; background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.08); color:rgba(255,255,255,.7);
    font-size:.875rem; transition:all .2s;
}
.footer-social a:hover { background:rgba(255,255,255,.12); color:#fff; transform:translateY(-2px); }
.footer-bottom {
    border-top:1px solid rgba(255,255,255,.06);
    padding-top:1.5rem; text-align:center;
}
.footer-bottom p { margin:0; color:rgba(255,255,255,.38); font-size:.8rem; }

/* ════════════════════════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════════════════════════ */
@media(max-width:1024px) {
    .header-container { padding:0 1.25rem; }
    .nav-menu { gap:0; }
    .nav-menu a { padding:.45rem .625rem; font-size:.75rem; }
    .lp-steps::before { display:none; }
    .lp-steps { gap:1.5rem; }
}

@media(max-width:900px) {
    .mobile-toggle { display:flex; }
    .nav-menu {
        position:absolute; top:100%; left:0; right:0;
        display:none; flex-direction:column; align-items:stretch;
        gap:0; padding:.5rem 1rem 1rem;
        background:rgba(5,7,15,.98);
        border-top:1px solid rgba(255,255,255,.06);
        box-shadow:0 20px 40px rgba(0,0,0,.5);
    }
    .nav-menu.active { display:flex; }
    .nav-menu li { border-bottom:1px solid rgba(255,255,255,.05); }
    .nav-menu li:last-child { border-bottom:none; }
    .nav-menu a {
        width:100%; padding:.875rem .25rem;
        font-size:.84rem; border-radius:0;
        background:none!important;
    }
    .btn-primary { width:100%; margin-top:.75rem; justify-content:center; padding:.875rem; }
    .lp-steps { grid-template-columns:1fr; max-width:400px; margin:0 auto; }
    .footer-top { grid-template-columns:repeat(2,1fr); gap:2rem; }
    .lp-field-row { grid-template-columns:1fr; }
    .lp-hero { padding:4rem 1.25rem 3.5rem; }
}

@media(max-width:768px) {
    .lp-grid { grid-template-columns:1fr; }
    .lp-trust-grid { grid-template-columns:repeat(2,1fr); }
    .lp-trust-grid--local { grid-template-columns:repeat(2,1fr); }
    .lp-trust-grid--nri { grid-template-columns:1fr; }
    .lp-section { padding:3rem 1.125rem; }
    .footer-top { grid-template-columns:1fr; gap:2rem; }
    .lp-stats-inner { gap:1rem 2rem; }
    .lp-cta-banner { padding:3.5rem 1.25rem; }
    .lp-nri-banner { padding:2rem 1.25rem; border-radius:var(--radius-lg); }
    .lp-section-head { margin-bottom:1.75rem; }
}

@media(max-width:480px) {
    .header-container { height:64px; }
    .logo img { height:36px; }
    .mobile-toggle { width:38px; height:38px; }
    .lp-hero { padding:3rem 1rem 2.75rem; }
    .lp-hero h1 { font-size:1.75rem; letter-spacing:-.025em; }
    .lp-hero-actions { flex-direction:column; align-items:stretch; }
    .lp-hero-btn { width:100%; justify-content:center; }
    .lp-hero-trust { gap:1rem 1.5rem; font-size:.75rem; }
    .lp-cta-btn,.lp-cta-btn--gold { width:100%; justify-content:center; }
    .lp-trust-grid { grid-template-columns:1fr; }
    .lp-trust-grid--local { grid-template-columns:1fr; }
    .lp-trust-grid--nri { grid-template-columns:1fr; }
    .lp-phone-row { flex-direction:column; }
    .lp-phone-row .lp-select { width:100%; }
    .lp-stats-inner { gap:.875rem 1.5rem; }
    .lp-stat-num { font-size:1.125rem; }
    .lp-modal { border-radius:var(--radius-lg) var(--radius-lg) 0 0; }
    .lp-nri-btn { width:100%; justify-content:center; }
    .footer-social a { width:38px; height:38px; }
    .lp-hero-eyebrow { font-size:.67rem; }
}

@media(min-width:640px) {
    .lp-modal {
        border-radius:var(--radius-xl);
        max-width:480px;
    }
    .lp-modal-overlay {
        align-items:center;
        padding:1rem;
    }
    @keyframes slideUp {
        from { transform:translateY(16px); opacity:0; }
        to   { transform:translateY(0);    opacity:1; }
    }
}

/* ════════════════════════════════════════════════════════════
   ACCESSIBILITY & PERFORMANCE
════════════════════════════════════════════════════════════ */
@media(prefers-reduced-motion:reduce) {
    *, *::before, *::after {
        animation-duration:.01ms!important;
        transition-duration:.01ms!important;
    }
}
:focus-visible {
    outline:2px solid var(--primary);
    outline-offset:3px;
    border-radius:4px;
}
.lp-card-actions .lp-btn-contact:focus-visible,
.lp-hero-btn:focus-visible,
.lp-cta-btn:focus-visible {
    outline-color:#fff;
}

/* ── Breadcrumb below hero (inside main) ────────────────── */
.lp-breadcrumb--below-hero {
    background:var(--surface-2);
    border-bottom:1px solid var(--border);
    border-top:none;
}
.lp-breadcrumb--below-hero .lp-breadcrumb-inner {
    font-size:.76rem;
}

/* ── Trust grid variants ─────────────────────────────────── */
/* NRI: 2×2 on desktop, full-width items */
.lp-trust-grid--nri {
    grid-template-columns:repeat(2,1fr);
    gap:1.25rem;
}
.lp-trust-grid--nri .lp-trust-item {
    padding:1.5rem;
    border-radius:var(--radius-lg);
    border-width:1.5px;
    align-items:flex-start;
}
.lp-trust-grid--nri .lp-trust-icon {
    width:48px; height:48px; border-radius:12px;
    background:linear-gradient(135deg,#eff6ff,#dbeafe);
    font-size:1.0625rem;
}
.lp-trust-grid--nri .lp-trust-title {
    font-size:.9375rem; font-weight:700; margin-bottom:.375rem;
}
.lp-trust-grid--nri .lp-trust-desc {
    font-size:.8375rem; line-height:1.7;
}
/* Local: strict 3 columns × 2 rows */
.lp-trust-grid--local {
    grid-template-columns:repeat(3,1fr);
    gap:1.125rem;
}
/* Stats bar with icons */
.lp-stat-icon {
    width:36px; height:36px; border-radius:8px;
    background:linear-gradient(135deg,#eff6ff,#dbeafe);
    display:flex; align-items:center; justify-content:center;
    font-size:.8125rem; color:var(--primary);
    flex-shrink:0;
}
/* Practice info section tighter spacing */
.lp-section:has(.lp-practice-intro) {
    padding-top:2.5rem;
    padding-bottom:2.5rem;
}
.lp-practice-intro {
    font-size:.9375rem; line-height:1.85;
    color:#374151;
    border-left:3px solid var(--primary);
    padding-left:1.25rem;
    margin-top:.5rem;
}
/* Section label for trust/process */
.lp-section-label {
    display:inline-flex; align-items:center; gap:.4rem;
    font-size:.7rem; font-weight:700; letter-spacing:.1em;
    text-transform:uppercase; color:var(--primary);
    margin-bottom:.5rem;
}
.lp-section-label::before {
    content:''; display:block; width:16px; height:2px;
    background:var(--primary); border-radius:999px;
}

/* ── Single hero CTA ─────────────────────────────────────── */
.lp-hero-actions--single {
    justify-content:center;
}
.lp-hero-actions--single .lp-hero-btn--primary {
    padding:.9rem 2.25rem;
    font-size:1rem;
    min-width:0;
    width:auto;
}
@media(max-width:480px){
    .lp-hero-actions--single .lp-hero-btn--primary { min-width:0; }
}

/* ════════════════════════════════════════════════════════════
   CTA INLINE — revamped
════════════════════════════════════════════════════════════ */
.lp-cta-inline {
    background: linear-gradient(135deg, #0a0f1e 0%, #0d1f3c 50%, #0a1628 100%);
    padding: 4rem 1.5rem;
    position: relative;
    overflow: hidden;
}
/* Subtle radial glow */
.lp-cta-inline::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 70% 80% at 50% 50%,
        rgba(37,99,235,.18) 0%, transparent 70%);
    pointer-events: none;
}
/* Gold top line */
.lp-cta-inline::after {
    content: '';
    position: absolute; top: 0; left: 0; right: 0; height: 2px;
    background: linear-gradient(90deg, transparent, #d97706 30%, #f59e0b 50%, #d97706 70%, transparent);
}
.lp-cta-inline-inner {
    max-width: 640px;
    margin: 0 auto;
    text-align: center;
    position: relative;
}
/* Eyebrow pill */
.lp-cta-inline-eyebrow {
    display: inline-flex; align-items: center; gap: .4rem;
    background: rgba(217,119,6,.15);
    color: #fbbf24;
    border: 1px solid rgba(217,119,6,.3);
    border-radius: 999px;
    padding: .3rem .875rem;
    font-size: .7rem; font-weight: 700;
    letter-spacing: .1em; text-transform: uppercase;
    margin-bottom: 1.25rem;
}
/* Heading */
.lp-cta-inline-inner h2 {
    font-size: clamp(1.375rem, 3vw, 1.875rem);
    font-weight: 800;
    color: #fff;
    letter-spacing: -.03em;
    margin-bottom: 1.375rem;
    line-height: 1.2;
}
/* Trust row */
.lp-cta-inline-trust {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: .5rem 1.5rem;
    margin-bottom: 2rem;
    font-size: .825rem;
    color: rgba(255,255,255,.72);
    font-weight: 500;
}
.lp-cta-inline-trust span {
    display: flex; align-items: center; gap: .35rem;
}
.lp-cta-inline-trust i {
    color: #34d399; font-size: .75rem;
}
/* Button */
.lp-cta-inline .lp-cta-btn {
    background: linear-gradient(135deg, #2563eb, #1d4ed8);
    box-shadow: 0 8px 28px rgba(29,78,216,.45);
    padding: .9rem 2.5rem;
    font-size: 1rem;
    border-radius: var(--radius);
    margin-bottom: 1rem;
}
.lp-cta-inline .lp-cta-btn:hover {
    box-shadow: 0 14px 40px rgba(29,78,216,.6);
    transform: translateY(-2px);
}
/* Note */
.lp-cta-inline .lp-cta-note {
    color: rgba(255,255,255,.45);
    font-size: .775rem;
    display: flex; align-items: center; justify-content: center; gap: .35rem;
    margin-top: 0;
}
@media(max-width:480px){
    .lp-cta-inline { padding: 3rem 1.125rem; }
    .lp-cta-inline-trust { gap: .5rem 1rem; font-size: .78rem; }
    .lp-cta-inline .lp-cta-btn { width: 100%; justify-content: center; }
}

/* ════════════════════════════════════════════════════════════
   DYNAMIC SERVICES MODULE
════════════════════════════════════════════════════════════ */
.lp-services-section { background:#fff; }

.lp-services-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.125rem;
}
.lp-service-card {
    display: flex;
    align-items: flex-start;
    gap: .875rem;
    padding: 1.25rem;
    border: 1.5px solid var(--border);
    border-radius: var(--radius);
    background: var(--surface-2);
    transition: border-color .2s, box-shadow .2s, background .2s;
}
.lp-service-card:hover {
    border-color: #bfdbfe;
    background: #fff;
    box-shadow: 0 4px 16px rgba(29,78,216,.07);
}
.lp-service-icon {
    width: 40px; height: 40px;
    border-radius: 10px;
    background: linear-gradient(135deg, #eff6ff, #dbeafe);
    display: flex; align-items: center; justify-content: center;
    font-size: .875rem; color: var(--primary);
    flex-shrink: 0;
    transition: background .2s;
}
.lp-service-card:hover .lp-service-icon {
    background: linear-gradient(135deg, #dbeafe, #bfdbfe);
}
.lp-service-body h3 {
    font-size: .875rem;
    font-weight: 700;
    color: var(--text);
    margin: 0 0 .3rem;
    line-height: 1.3;
}
.lp-service-body p {
    font-size: .78rem;
    color: var(--text-3);
    line-height: 1.6;
    margin: 0;
}
/* Outline dark CTA button */
.lp-cta-btn--outline-dark {
    background: transparent;
    border: 2px solid var(--primary);
    color: var(--primary);
    box-shadow: none;
    padding: .8rem 2.25rem;
    font-size: .9375rem;
    border-radius: var(--radius);
    cursor: pointer;
    font-family: inherit;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    transition: background .2s, color .2s, box-shadow .2s;
}
.lp-cta-btn--outline-dark:hover {
    background: var(--primary);
    color: #fff;
    box-shadow: var(--shadow-blue);
}

@media(max-width:900px) {
    .lp-services-grid { grid-template-columns: repeat(2, 1fr); }
}
@media(max-width:480px) {
    .lp-services-grid { grid-template-columns: 1fr; gap: .75rem; }
    .lp-service-card { padding: 1rem; }
}

/* ── Mobile nav override (definitive) ──────────────────── */
@media(max-width:900px){
    ul.nav-menu { display:none !important; }
    ul.nav-menu.active { display:flex !important; flex-direction:column; align-items:stretch; }
}

/* ============================================================
   LP CSS PATCH — Add these 3 rules to END of your lp.css
   They override the existing rules above
   ============================================================ */

/* 1. GET LEGAL ADVICE button — separate from nav links */
.header-container .btn-primary {
    margin-left: 1rem;
}

/* 2. NRI SERVICES active state — underline only, no dark box */
.nav-menu a.active {
    color: #fff;
    background: none !important;
    border-bottom: 2px solid rgba(255,255,255,.55);
    padding-bottom: calc(.5rem - 2px);
}

/* 3. Mobile nav */
@media(max-width:900px){
    ul.nav-menu { display:none !important; }
    ul.nav-menu.active { display:flex !important; flex-direction:column; align-items:stretch; }
}
/* ═══════════════════════════════════════════════════════════
   MOBILE HEADER: logo center, hamburger right
═══════════════════════════════════════════════════════════ */
.mobile-nav-spacer { display:none; }

.header-container { position:relative; }

@media(max-width:900px){
    .header-container {
        display:grid;
        grid-template-columns:42px 1fr 42px;
        align-items:center;
        gap:.5rem;
        padding:0 1rem;
    }
    .mobile-nav-spacer { display:block; width:42px; }
    .logo { justify-self:center; }
    .mobile-toggle { justify-self:end; display:flex; }
    ul.nav-menu {
        position:absolute; top:100%; left:0; right:0;
        display:none !important;
        flex-direction:column; align-items:stretch;
        background:rgba(5,7,15,.98);
        border-top:1px solid rgba(255,255,255,.06);
        padding:.5rem 1rem 1rem;
        box-shadow:0 16px 32px rgba(0,0,0,.4);
        z-index:999;
    }
    ul.nav-menu.active { display:flex !important; }
    ul.nav-menu li { border-bottom:1px solid rgba(255,255,255,.05); }
    ul.nav-menu li:last-child { border-bottom:none; }
    ul.nav-menu a,
    ul.nav-menu button {
        width:100%; padding:.875rem .25rem;
        font-size:.875rem; border-radius:0;
        background:none !important; text-align:left;
    }
    .btn-primary {
        margin-left:0 !important; width:100%;
        justify-content:center; padding:.875rem;
        margin-top:.5rem;
    }
}


/* ════════════════════════════════════════════════════════════
   SERVICE GRID — practice-info widget
════════════════════════════════════════════════════════════ */
.lp-service-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
    margin-top: 2rem;
}
.lp-service-card {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.375rem 1.25rem;
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    transition: box-shadow .2s, transform .2s;
}
.lp-service-card:hover {
    box-shadow: 0 8px 24px rgba(0,0,0,.08);
    transform: translateY(-2px);
}
.lp-service-icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: linear-gradient(135deg, var(--navy), #1e3a8a);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: #fbbf24;
    font-size: .9rem;
}
.lp-service-body h3 {
    font-size: .875rem;
    font-weight: 700;
    color: var(--text);
    margin: 0 0 .3rem;
    line-height: 1.35;
}
.lp-service-body p {
    font-size: .8125rem;
    color: var(--muted);
    margin: 0;
    line-height: 1.6;
}
@media(max-width:900px) {
    .lp-service-grid { grid-template-columns: repeat(2, 1fr); }
}
@media(max-width:580px) {
    .lp-service-grid { grid-template-columns: 1fr; gap: .875rem; }
    .lp-service-card { padding: 1rem; }
}

/* ════════════════════════════════════════════════════════════
   GLOBAL SIDE TAB — right edge sticky CTA
════════════════════════════════════════════════════════════ */
#lp-side-tab {
    position: fixed;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    z-index: 990;
}
#lp-side-btn {
    display: flex;
    align-items: center;
    gap: .5rem;
    background: linear-gradient(180deg, #1d4ed8, #2563eb);
    color: #fff;
    border: none;
    border-radius: 10px 0 0 10px;
    padding: 1rem .75rem;
    cursor: pointer;
    font-family: inherit;
    font-size: .74rem;
    font-weight: 700;
    letter-spacing: .05em;
    writing-mode: vertical-rl;
    text-orientation: mixed;
    /* After rotate(180deg): CSS top-right/bottom-right = visual left rounded corners */
    transform: rotate(180deg);
    white-space: nowrap;
    box-shadow: -4px 2px 18px rgba(29,78,216,.4);
    transition: transform .2s, box-shadow .2s, background .2s;
    border-radius: 0 10px 10px 0;
}
#lp-side-btn:hover {
    transform: rotate(180deg) translateY(4px);
    box-shadow: -6px 2px 24px rgba(29,78,216,.55);
    background: #1d4ed8;
}
#lp-side-btn .lp-tab-icon {
    writing-mode: horizontal-tb;
    transform: rotate(180deg);
    font-size: .875rem;
    flex-shrink: 0;
}
/* Mobile: bottom-center pill */
@media(max-width:768px) {
    #lp-side-tab {
        top: auto;
        right: auto;
        bottom: 1.25rem;
        left: 50%;
        transform: translateX(-50%);
    }
    #lp-side-btn {
        writing-mode: horizontal-tb;
        text-orientation: mixed;
        transform: none;
        border-radius: 999px;
        padding: .75rem 1.5rem;
        font-size: .8375rem;
        letter-spacing: .03em;
        box-shadow: 0 6px 20px rgba(29,78,216,.4);
        background: linear-gradient(135deg, #1d4ed8, #2563eb);
    }
    #lp-side-btn:hover { transform: none; }
    #lp-side-btn .lp-tab-icon { transform: none; }
}
/* Hide while modal open */
body.lf-modal-open #lp-side-tab { opacity: 0; pointer-events: none; }

/* ════════════════════════════════════════════════════════════
   CITY GRID — state hub pages
════════════════════════════════════════════════════════════ */
.lp-city-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    margin-top: 2rem;
}
.lp-city-card {
    display: flex;
    align-items: center;
    gap: .875rem;
    background: #fff;
    border: 1.5px solid var(--border);
    border-radius: var(--radius);
    padding: 1rem 1.125rem;
    text-decoration: none;
    color: var(--text);
    transition: border-color .2s, box-shadow .2s, transform .15s;
}
.lp-city-card:hover {
    border-color: var(--gold);
    box-shadow: 0 6px 20px rgba(0,0,0,.08);
    transform: translateY(-2px);
    color: var(--navy);
}
.lp-city-icon {
    width: 38px;
    height: 38px;
    border-radius: 10px;
    background: linear-gradient(135deg, var(--navy), #1e3a8a);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--gold);
    font-size: .875rem;
    flex-shrink: 0;
}
.lp-city-body {
    flex: 1;
    min-width: 0;
}
.lp-city-name {
    display: block;
    font-weight: 700;
    font-size: .9rem;
    color: var(--navy);
    line-height: 1.3;
}
.lp-city-sub {
    display: block;
    font-size: .75rem;
    color: var(--muted);
    margin-top: .1rem;
}
.lp-city-arrow {
    font-size: .65rem;
    color: var(--muted);
    flex-shrink: 0;
}
.lp-city-card:hover .lp-city-arrow {
    color: var(--gold);
}
@media(max-width:900px) {
    .lp-city-grid { grid-template-columns: repeat(2, 1fr); }
}
@media(max-width:480px) {
    .lp-city-grid { grid-template-columns: 1fr; gap: .625rem; }
    .lp-city-card { padding: .875rem 1rem; }
}

/* ════════════════════════════════════════════════════════════
   COURT INFO — court page meta badges
════════════════════════════════════════════════════════════ */
.lp-court-meta {
    display: flex;
    flex-wrap: wrap;
    gap: .625rem;
    margin: 1rem 0 1.25rem;
}
.lp-court-badge {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    background: linear-gradient(135deg, var(--navy), #1e3a8a);
    color: rgba(255,255,255,.9);
    border-radius: 999px;
    padding: .4rem 1rem;
    font-size: .8125rem;
    font-weight: 600;
}
.lp-court-badge i {
    color: var(--gold);
    font-size: .75rem;
}
.lp-court-about {
    font-size: .9625rem;
    line-height: 1.85;
    color: var(--text);
    margin-top: 1rem;
}