:root {
      --accent: #30336b;
      --accent2: #30336b;
      --glass: rgba(255,255,255,0.86);
      --glass2: rgba(240,245,252,0.93);
      --text: #232d39;
      --muted: #7A9FBF;
      --radius: 22px;
      --shadow: 0 6px 24px -6px rgba(90,169,230,0.3);
    }
    html {
      scroll-behavior: smooth;
    }
    body {
      background: #f4f7fb;
      color: var(--text);
      font-family: 'Inter', 'Segoe UI', Arial, sans-serif;
      font-size: 1.09rem;
      letter-spacing: 0.01em;
      overflow-x: hidden;
    }
    a {
      text-decoration: none;
      color: var(--accent);
    }
    a.btn.btn-rounded.btn-review.animate__animated.animate__pulse.animate__infinite {
      border: 1px solid var(--accent);
      border-radius: 20px;
    }
    .navbar {
      background: var(--glass2)!important;
      box-shadow: 0 2px 16px -10px #b8c3d2;
      border-bottom: 1.5px solid #e4ebf2;
    }
    .navbar-brand {
      letter-spacing: -1.5px;
      font-weight: 800;
      font-size: 2rem;
      color: var(--accent);
    }
    .navbar-toggler {
      border: none!important;
      background: none!important;
      outline: none!important;
      box-shadow: none!important;
    }

    .call-info {
      font-family: 'Inter', sans-serif;
      font-weight: bold;
    }
    .call-label {
      color: #C0392B;
      font-size: 0.9rem;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.05em;
      font-weight: bolder;
    }
    .call-numbers {
      color: var(--text);
      font-size: 1.1rem;
      line-height: 1.2;
      font-weight: bolder;
    }
    .edgy-btn {
      background: var(--accent);
      color: #fff;
      font-weight: 700;
      border: none;
      border-radius: 28px;
      box-shadow: var(--shadow);
      text-transform: uppercase;
      letter-spacing: 0.09em;
      padding: .6rem 1.45rem;
      transition: background .18s, color .18s, box-shadow .18s, transform .13s;
    }
    .edgy-btn:hover {
      background: var(--accent2);
      color: #dff9fb;
      box-shadow: 0 8px 32px -10px var(--accent2);
      transform: translateY(-2px) scale(1.03);
    }
    .offcanvas-backdrop.show {
      opacity: 0.37!important;
      background: #dbe5ef!important;
      transition: opacity 0.32s;
    }
    .edgy-offcanvas {
      background: rgba(255,255,255,0.5);
      backdrop-filter: blur(14px) saturate(120%);
      border-left: 2.5px solid #c3d2e8;
      min-width: 270px;
      max-width: 85vw;
    }
    .edgy-mobile-nav .nav-link {
      color: var(--text)!important;
      font-size: 1.19rem;
      letter-spacing: 0.08em;
      font-weight: 700;
      margin-bottom: 1rem;
      text-transform: uppercase;
      border-radius: 0 var(--radius) var(--radius) 0;
      transition: background .12s, color .12s, padding .15s;
      padding-left: 12px;
      text-align: left;
    }
    .edgy-mobile-nav .nav-link:hover {
      color: var(--accent)!important;
      background: #eaf1f8;
      padding-left: 28px;
    }
    .edgy-close {
      font-size: 1.25rem;
      opacity: .7;
    }
    /* HERO */
    .hero {
      position: relative;
      min-height: 62vh;
      display: flex;
      align-items: center;
      background: #e6eef8;
      overflow: hidden;
    }
    .hero img {
      position: absolute;
      left: 50%; top: 50%;
      min-width: 100%; min-height: 100%;
      width: auto; height: auto;
      z-index: 1;
      transform: translate(-50%,-50%);
      filter: blur(2px) brightness(0.82) grayscale(0.12);
      object-fit: cover;
    }
    .hero-overlay {
      position: absolute; inset: 0; z-index: 2;
      background: linear-gradient(90deg, #f4f7fb 65%, rgba(245,247,251,0.53) 90%);
      pointer-events:none;
    }
    .hero-content {
      z-index: 3;
      position: relative;
      max-width: 800px;
      padding: 5rem 2rem 4rem 1rem;
      margin-left: 1em;
    }
    .hero-title { color: var(--accent); }
    .hero-tagline { color: var(--accent2); }
    .hero-title {
      font-size: 2.6rem;
      font-weight: 900;
      text-transform: uppercase;
      letter-spacing: 0.01em;
      color: var(--accent);
      background: none;
      -webkit-text-fill-color: unset;
    }
    .hero-tagline {
      color: var(--accent2);
      font-size: 1.23rem;
      font-weight: 700;
      letter-spacing: .07em;
      text-transform: uppercase;
      margin-bottom: 0.7em;
    }
    @media (max-width: 767.98px) {
      .hero-content { max-width: 99vw; padding: 2.7rem 0.6rem 2rem 0.6rem; margin-left: auto; }
      .hero-title { font-size: 1.25rem; }
      .hero { min-height: 38vh; }

    }
    /* CARD/GLASS SECTIONS */
    .glass-card {
      background: var(--glass);
      border-radius: var(--radius);
      border: none;
      box-shadow: var(--shadow);
      padding: 1.8rem 1.2rem 1.8rem 1.2rem;
      margin-bottom: 1.4rem;
      transition: box-shadow .19s, transform .17s;
    }
    /* .glass-card:hover { box-shadow: 0 8px 24px -8px var(--accent2); transform: translateY(-1px) scale(1.012);} */
    .section-title {
      font-size: 2rem;
      font-weight: 900;
      letter-spacing: 0.04em;
      text-transform: uppercase;      
      color: var(--accent);
      margin-bottom: .6rem;
      position: relative;
    }
    .section-title.special {
      
      padding-bottom: 1rem; 
    }
    .section-title.special::after {
      content: "";
      position: absolute;
      left: 50%;
      bottom: 0;
      transform: translateX(-50%);
      width: 10em;             
      height: 2px;              
      background: linear-gradient(135deg,#e9e6fa 0%,#dbedfd 100%);
      border-radius: 2px;       
    }
    .section-subtitle {
      color: var(--accent2);
      font-size: 1.11rem;
      font-weight: 700;
      letter-spacing: 0.07em;
      text-transform: uppercase;
      margin-bottom: 1.1rem;
    }
     /* Practice Areas */
    .grouped-practice-section {
      padding: 5rem 0 2.5rem 0;
      background: #f4f7fb;
    }
    .practice-group-row {
      display: flex;
      flex-wrap: wrap;
      gap: 2rem;
      justify-content: center;
    }
    .practice-group-card {
      flex: 1 1 320px;
      max-width: 390px;
      min-width: 280px;
      background: var(--practice-bg, linear-gradient(135deg,#e3edfa 0%,#f4f7fb 100%));
      color: var(--text);
      border-radius: 26px;
      box-shadow: 0 8px 28px -8px rgba(64,74,137,0.12),0 2px 12px -4px #bcd4e8;
      padding: 2.5rem 2rem 2.1rem 2rem;
      margin-bottom: 1.5rem;
      border: none;
      position: relative;
      overflow: hidden;
      opacity: 0;
      transform: translateY(56px) scale(.97);
      transition: opacity 0.7s cubic-bezier(.68,-0.55,.27,1.55), transform 0.7s cubic-bezier(.68,-0.55,.27,1.55);
      z-index: 1;
    }

    .practice-group-card.visible {
      opacity: 1;
      transform: translateY(0) scale(1.03);
    }
    .practice-group-icon {
      display: flex;
      align-items: center;
      justify-content: center;
      margin-bottom: 1.2rem;
      filter: drop-shadow(0 2px 8px rgba(100,120,200,0.08));
    }
    .practice-group-title {
      font-weight: 800;
      font-size: 1.23rem;
      letter-spacing: 0.04em;
      text-transform: uppercase;
      margin-bottom: 0.55rem;
      color: #18488b;
    }
    .practice-group-list {
      list-style: none;
      padding: 0;
      margin: 0;
    }
    .practice-group-list li {
      margin-bottom: .5em;
      font-size: 1.06rem;
      font-weight: 500;
      color: #37445e;
      position: relative;
      padding-left: 1.5em;
    }
    .practice-group-list li::before {
      content: '•';
      position: absolute;
      left: 0;
      color: var(--practice-dot, #18488b);
      font-size: 1.3em;
      line-height: 1;
    }
    @media (max-width: 991.98px) {
      .practice-group-row {
        flex-direction: column;
        gap: 1.5rem;
      }
      .practice-group-card {
        width: 90vw;
        margin-left: auto;
        margin-right: auto;
        height: auto !important;
        overflow: visible !important;
        padding: 2rem 1.5rem !important;
      }
    }

    /* General card/grid styling */
    .grouped-practice-section {
      padding: 5rem 0 2.5rem 0;
      background: #f4f7fb;
    }
    .practice-group-row {
      display: flex;
      flex-wrap: wrap;
      gap: 2rem;
      justify-content: center;
    }
    .practice-group-card {
      flex: 1 1 320px;
      max-width: 390px;
      min-width: 280px;
      background: var(--practice-bg, linear-gradient(135deg,#e3edfa 0%,#f4f7fb 100%));
      color: var(--text);
      border-radius: 26px;
      box-shadow: 0 8px 28px -8px rgba(64,74,137,0.12),0 2px 12px -4px #bcd4e8;
      padding: 2.5rem 2rem 2.1rem 2rem;
      margin-bottom: 1.5rem;
      border: none;
      position: relative;
      overflow: hidden;
      opacity: 0;
      transform: translateY(56px) scale(.97);
      transition: opacity 0.7s cubic-bezier(.68,-0.55,.27,1.55), transform 0.7s cubic-bezier(.68,-0.55,.27,1.55);
      z-index: 1;
    }
    .practice-group-card.visible {
      opacity: 1;
      transform: translateY(0) scale(1.03);
    }
    .practice-group-icon {
      display: flex;
      align-items: center;
      justify-content: center;
      margin-bottom: 1.2rem;
      filter: drop-shadow(0 2px 8px rgba(100,120,200,0.08));
    }
    .practice-group-title {
      font-weight: 800;
      font-size: 1.23rem;
      letter-spacing: 0.04em;
      text-transform: uppercase;
      margin-bottom: 0.55rem;
      color: #18488b;
    }
    .practice-group-list {
      list-style: none;
      padding: 0;
      margin: 0;
    }
    .practice-group-list li {
      margin-bottom: .5em;
      font-size: 1.06rem;
      font-weight: 500;
      color: #37445e;
      position: relative;
      padding-left: 1.5em;
    }
    .practice-group-list li::before {
      content: '•';
      position: absolute;
      left: 0;
      color: var(--practice-dot, #18488b);
      font-size: 1.3em;
      line-height: 1;
    }
    @media (max-width: 991.98px) {
      .practice-group-row {
        flex-direction: column;
        gap: 1.5rem;
      }
      .practice-group-card {
        max-width: 99vw;
        margin-left: auto;
        margin-right: auto;
      }
    }

    /* Testimonials, etc. */
    .testimonials-google {
      background: var(--glass);
      border-radius: 1.3rem;
      box-shadow: var(--shadow);
      padding: 2.1rem 0.4rem 2.1rem 0.4rem;
    }
    .review-card {
      background: var(--glass2);
      border-radius: 16px;
      box-shadow: 0 3px 12px -6px #ccd4e8;
      padding: 1.6rem 1.1rem 1.2rem 1.2rem;
      margin: 0 auto;
      min-width: 300px; max-width: 90%;
      font-size: 1.08rem;
      border: 1.5px solid #f4f7fb;
      transition: box-shadow .14s;
      position: relative;
    }
    .review-stars { color: #ffc107; font-size: 1.03rem;}
    .reviewer-avatar {
      width: 44px; height: 44px; background: var(--accent2);
      color: #fff; border-radius: 50%;
      display: flex; align-items: center; justify-content: center;
      font-size: 1.29rem; font-weight: 700; box-shadow: 0 1px 6px #bac6db30;
    }
    .reviewer-details { margin-left: 1rem;}
    .carousel-indicators [data-bs-target] {
      width: 10px; height: 10px; border-radius: 50%;
      background: var(--accent2); opacity: .35; border: none;
    }

    .carousel-indicators .active { opacity: .85; background: var(--accent);}

    #googleReviewsCarousel > .carousel-control-prev,
    #googleReviewsCarousel > .carousel-control-next {
      display: none;
    }

    .text-accent { color: var(--accent) !important; }

    .contact-bg {
      background: var(--glass2);
      color: var(--text);
      border-radius: 1.6rem;
      box-shadow: var(--shadow);
      padding: 2.2rem 1.2rem 2rem 1.2rem;
    }
    .contact-section {
      font-size: smaller;
    }
    .form-control,
    .form-control:focus {
      background: #f7faff;
      border: 1.3px solid #d5deea;
      color: var(--text);
      border-radius: 7px;
      outline: none;
      box-shadow: none;
    }

    /* Testimonials */
    .testimonials-section {
      color: #000;
     
    }
    .testimonial-quote-bg {
      position: absolute; left: 8%; top: 10%; font-size: 11em; opacity: 0.08;
      pointer-events: none; z-index: 1;
    }
    p.mb-2.quote, h5.mb-0 {
        color: #000;
    }
    .carousel-inner { min-height: 200px; }
    .carousel-item blockquote { font-size: 1em; }
    .carousel-control-prev, .carousel-control-next {
      position: static!important; filter: drop-shadow(0 2px 6px #00336688);
    }

    .footer {
      background: #e4ebf2;
      color: var(--accent2);
      padding: 2rem 0 1.2rem 0;
    }
    
    .footer a { color: var(--accent); text-decoration: none; }
    .footer a:hover { color: var(--accent2);}
    .social-icon { font-size: 1.3rem; margin-right: 1rem; color: var(--accent2);}
    .fade-in { opacity: 0; transform: translateY(38px) scale(0.98); transition: all 0.49s cubic-bezier(.68,-0.55,.27,1.55);}
    .fade-in.visible { opacity: 1; transform: translateY(0) scale(1); }
 
 h2.mb-4 {
    font-size: 1.5em;
}
    h3#desc-label {
    font-size: 1.25em;
}