  :root {
      --rg-orange: #f47920;
      --rg-orange-dark: #d96800;
      --rg-dark: #1a1d2e;
      --rg-dark2: #23263a;
      --rg-cream: #faf8f4;
      --rg-gray: #6b7280;
      --rg-light: #f5f4f0;
    }

    * { box-sizing: border-box; }

    body {
       font-family: "Lato";
      color: #1a1d2e;
      background: #fff;
    }

    h1, h2, h3, h4, h5, h6, .font-display {
      /*font-family: 'Sora', sans-serif;*/
       font-family: "Playfair Display", serif;
    }

    a.navbar-brand img {
    width: 250px;
}

    /* ─── Navbar ─────────────────────────────────────────── */
    .rg-navbar {
      background: #fff;
      border-bottom: 1px solid #ede9e0;
      padding: 0.75rem 0;
      position: sticky;
      top: 0;
      z-index: 1030;
    }
    .rg-navbar .navbar-brand {
      /*font-family: 'Sora', sans-serif;*/
       font-family: "Playfair Display", serif;
      font-weight: 800;
      font-size: 1.1rem;
      color: var(--rg-dark);
      letter-spacing: -0.3px;
    }
    .rg-navbar .navbar-brand span { color: var(--rg-orange); }
    .rg-navbar .nav-link {
    font-family: 'Lato';
    font-size: 0.875rem;
    font-weight: 800;
    color: #374151;
    padding: 0.4rem 0.85rem !important;
    }
    .rg-navbar .nav-link:hover { color: var(--rg-orange); }
    .rg-navbar .btn-login {
      font-family: Lato;
      font-size: 0.875rem;
      font-weight: 800;
      color: #374151;
      border: none;
      background: none;
      padding: 0.4rem 0.85rem;
      border: 1px solid #fd7600;
    padding: 6px 23px;
    border-radius: 5px;
    }
    .rg-navbar .btn-phone {
      background: var(--rg-orange);
      color: #fff;
      border: none;
      border-radius: 6px;
      font-size: 0.85rem;
      font-weight: 600;
      padding: 0.45rem 1rem;
      white-space: nowrap;
          font-size: 16px;
    line-height: 19px;
    font-weight: 700;
    font-family: Lato;
    font-style: normal;
    }
    .rg-navbar .btn-phone:hover { background: var(--rg-orange-dark); color:#fff; }

    /* ─── Buttons ─────────────────────────────────────────── */
    .btn-rg-primary {
      background: var(--rg-orange);
      color: #fff;
      border: none;
      border-radius: 6px;
     /* font-family: 'Sora', sans-serif;*/
       font-family: "Lato";
      font-weight: 600;
      font-size: 0.9rem;
      padding: 0.65rem 1.4rem;
      transition: background 0.2s, transform 0.15s;
    }
    .btn-rg-primary:hover { background: var(--rg-orange-dark); color:#fff; transform: translateY(-1px); }

    .btn-rg-outline {
      background: transparent;
      color: var(--rg-dark);
      border: 2px solid var(--rg-dark);
      border-radius: 6px;
      /*font-family: 'Sora', sans-serif;*/
       font-family: "Lato";
      font-weight: 600;
      font-size: 0.9rem;
      padding: 0.63rem 1.4rem;
      transition: all 0.2s;
    }
    .btn-rg-outline:hover { background: var(--rg-dark); color: #fff; }

    .btn-rg-white {
      background: #fff;
      color: var(--rg-dark);
      border: none;
      border-radius: 6px;
     /* font-family: 'Sora', sans-serif;*/
       font-family: "Lato";
      font-weight: 800;
      font-size: 0.9rem;
      padding: 0.65rem 1.4rem;
      transition: background 0.2s;
    }
    .btn-rg-white:hover { background: #f0ede6; color: var(--rg-dark); }

    /* ─── Hero ─────────────────────────────────────────────── */
    .hero-section {
      background: var(--rg-cream);
      padding: 5rem 0 3.5rem;
      overflow: hidden;
    }
    .hero-section h1 {
      font-size: clamp(2rem, 4vw, 3rem);
      font-weight: 800;
      line-height: 1.15;
      letter-spacing: -0.5px;
      color: var(--rg-dark);
    }
    .hero-list {

      list-style: none;
      padding: 0;
      margin: 1.25rem 0 1.75rem;
    }
    .hero-list li {
            font-family: 'Lato';
      font-size: 1.2rem;
      color: #374151;
      padding: 0.3rem 0;
      display: flex;
      align-items: center;
      gap: 0.5rem;
    }
    .hero-list li::before {
      content: '';
      width: 7px; height: 7px;
      background: var(--rg-orange);
      border-radius: 50%;
      flex-shrink: 0;
    }
    .hero-img-wrap {
      position: relative;
    }
    .hero-img-wrap img {
      border-radius: 16px;
      width: 100%;
      max-width: 500px;
    }
    .hero-floating-card {
      position: absolute;
      background: #fff;
      border-radius: 10px;
      box-shadow: 0 8px 32px rgba(0,0,0,0.12);
      padding: 0.65rem 1rem;
      font-size: 0.78rem;
      font-weight: 600;
      display: flex;
      align-items: center;
      gap: 0.5rem;
      white-space: nowrap;
    }
    .hero-floating-card .dot {
      width: 8px; height: 8px;
      border-radius: 50%;
      background: #22c55e;
    }
    .hero-card-top { top: 10%; right: -4%; }
    .hero-card-bottom { bottom: 15%; left: -4%; }
    .hero-trust {
      font-size: 0.78rem;
      color: var(--rg-gray);
      margin-top: 1.5rem;
    }

    /* ─── Trust logos bar ─────────────────────────────────── */
    .trust-bar {
      background: #fff;
      border-top: 1px solid #ede9e0;
      border-bottom: 1px solid #ede9e0;
      padding: 1.1rem 0;
    }
    .trust-bar .trust-logo {
      display: flex;
      align-items: center;
      gap: 0.4rem;
      /*font-family: 'Sora', sans-serif;*/
       font-family: "Playfair Display", serif;
      font-weight: 700;
      font-size: 0.95rem;
      color: #374151;
      opacity: 0.7;
    }
    .trust-bar .trust-logo i { font-size: 1.2rem; color: #374151; }

    /* ─── Section titles ─────────────────────────────────── */
    .section-label {
      font-size: 0.8rem;
      font-weight: 700;
      letter-spacing: 1.5px;
      text-transform: uppercase;
      color: var(--rg-orange);
    }
    .section-title {
      /*font-family: 'Sora', sans-serif;*/
       font-family: "Playfair Display", serif;
      font-weight: 800;
      font-size: clamp(1.6rem, 3vw, 2.3rem);
      line-height: 1.2;
      letter-spacing: -0.3px;
      color: var(--rg-dark);
    }
    .section-title span { color: var(--rg-orange); }

    /* ─── Feature split sections ──────────────────────────── */
    .feature-section { padding: 4.5rem 0; }
    .feature-section.bg-cream { background: var(--rg-cream); }
    .feature-img {
      border-radius: 14px;
      overflow: hidden;
      box-shadow: 0 12px 40px rgba(0,0,0,0.10);
    }
    .feature-img img { width: 100%; display: block; }
    .feature-text h3 {
      font-family: "Lato";
      font-size: clamp(1.4rem, 2.5vw, 1.9rem);
      font-weight: 800;
      letter-spacing: -0.3px;
    }
    .feature-text p {
       font-family: "Lato";
      color: #4b5563;
      line-height: 1.7;
      font-size: 0.95rem;
    }

    /* ─── As Seen In ─────────────────────────────────────── */
    .seen-in-section {
      background: var(--rg-cream);
      padding: 2rem 0;
      border-top: 1px solid #ede9e0;
      border-bottom: 1px solid #ede9e0;
    }
    .seen-in-section .label {
      font-size: 0.78rem;
      font-weight: 700;
      letter-spacing: 1.5px;
      text-transform: uppercase;
      color: #9ca3af;
      white-space: nowrap;
    }
    .seen-in-logo {
      /*font-family: 'Sora', sans-serif;*/
       font-family: "Playfair Display", serif;
      font-weight: 800;
      font-size: clamp(1rem, 2vw, 1.5rem);
      color: #374151;
      opacity: 0.55;
      letter-spacing: -0.5px;
    }
    .seen-in-logo.serif { font-family: Georgia, serif; font-style: italic; }

    /* ─── Services ───────────────────────────────────────── */
    .services-section { padding: 5rem 0; background: #fff; }
    .service-card {
      border: 1px solid #e5e7eb;
      border-radius: 12px;
      padding: 1.75rem 1.5rem;
      height: 100%;
      transition: box-shadow 0.2s, transform 0.2s;
      background: #fff;
    }
    .service-card:hover {
      box-shadow: 0 10px 36px rgba(0,0,0,0.09);
      transform: translateY(-3px);
    }
    .service-icon {
      width: 44px; height: 44px;
      background: #fff4ea;
      border-radius: 10px;
      display: flex; align-items: center; justify-content: center;
      margin-bottom: 1rem;
    }
    .service-icon i { font-size: 1.2rem; color: var(--rg-orange); }
    .service-card h5 {
      font-family: "Lato";
      font-size: 0.95rem;
      font-weight: 700;
      margin-bottom: 0.5rem;
    }
    .service-card p {
      font-family: "Lato";
      font-size: 0.85rem;
      color: #6b7280;
      margin: 0;
      line-height: 1.6;
    }

    /* ─── CTA Banner ─────────────────────────────────────── */
    .cta-banner {
      background: var(--rg-dark);
      padding: 3rem 0;
    }
    .cta-banner h3 {
      font-family: "Lato";
      font-size: clamp(1.2rem, 2.5vw, 1.7rem);
      font-weight: 700;
      color: #fff;
      line-height: 1.3;
    }
    .cta-banner h3 span { color: var(--rg-orange); }
    .cta-banner p { font-family: "Lato"; color: #9ca3af; font-size: 0.9rem; margin: 0.5rem 0 0; }
    .rating-badge {
      display: flex; align-items: center; gap: 0.35rem;
      font-size: 0.8rem; font-weight: 600; color: #fff;
    }
    .rating-badge .stars { color: #fbbf24; font-size: 0.9rem; }

    /* ─── How It Works ───────────────────────────────────── */
    .how-section { padding: 5rem 0; background: var(--rg-cream); }
    .how-section p{
      font-family: "Lato"; 
    }
    .step-card {
      font-family: "Lato"; 
      background: #fff;
      border-radius: 14px;
      padding: 2rem 1.75rem;
      height: 100%;
      box-shadow: 0 4px 20px rgba(0,0,0,0.06);
      position: relative;
    }
    .step-number {
      font-family: "Lato"; 
      width: 40px; height: 40px;
      background: #fff4ea;
      border-radius: 10px;
      display: flex; align-items: center; justify-content: center;
   /*   font-family: 'Sora', sans-serif;*/
       font-family: "Playfair Display", serif;
      font-weight: 800;
      font-size: 1rem;
      color: var(--rg-orange);
      margin-bottom: 1rem;
    }
    .step-card h5 {
      font-family: "Lato"; 
      font-weight: 700;
      font-size: 1rem;
      margin-bottom: 0.6rem;
    }
    .step-card p { font-family: "Lato"; font-size: 0.875rem; color: #6b7280; line-height: 1.6; margin: 0; }

    /* ─── Social Proof ───────────────────────────────────── */
    .proof-section {
      padding: 5rem 0;
      background: #fff;
    }
    .proof-section h2 {
      font-family: "Lato";
      font-size: clamp(1.6rem, 3vw, 2.4rem);
      font-weight: 800;
      line-height: 1.25;
      letter-spacing: -0.3px;
    }
    .proof-section p{
      font-family: "Lato";
    }
    .proof-section h2 .highlight { color: var(--rg-orange); }
    .client-logo-row {
      display: flex; flex-wrap: wrap;
      gap: 1.5rem;
      align-items: center;
      margin-top: 1.5rem;
    }
    .client-logo {
     /* font-family: 'Sora', sans-serif;*/
       font-family: "Playfair Display", serif;
      font-weight: 800;
      font-size: 1.1rem;
      color: #374151;
      opacity: 0.5;
      letter-spacing: -0.5px;
    }

    /* ─── Experts ────────────────────────────────────────── */
    .experts-section {
      padding: 5rem 0;
      background: var(--rg-cream);
    }
    .experts-section h2 {
      font-family: "Lato";
      font-size: clamp(1.6rem, 3vw, 2.2rem);
      font-weight: 800;
      line-height: 1.25;
    }
    .experts-section p {
      font-family: "Lato";
    }
    .experts-section h2 span { color: var(--rg-orange); }
    .stat-item { text-align: center; }
    .stat-item .num {
      /*font-family: 'Sora', sans-serif;*/
       font-family: "Playfair Display", serif;
      font-size: 1.8rem;
      font-weight: 800;
      color: var(--rg-dark);
      line-height: 1;
    }
    .stat-item .num span { color: var(--rg-orange); }
    .stat-item .lbl {
       font-family: "Lato";
      font-size: 0.8rem;
      color: #6b7280;
      margin-top: 0.3rem;
      line-height: 1.4;
    }
    .stat-icon {
      width: 36px; height: 36px;
      background: var(--rg-orange);
      border-radius: 8px;
      display: flex; align-items: center; justify-content: center;
      margin: 0 auto 0.5rem;
    }
    .stat-icon i { color: #fff; font-size: 1rem; }

    /* ─── Bottom CTA ─────────────────────────────────────── */
    .bottom-cta {
      background: var(--rg-dark);
      padding: 3.5rem 0;
    }
    .bottom-cta h2 {
      font-family: "Lato";
      font-size: clamp(1.4rem, 3vw, 2rem);
      font-weight: 800;
      color: #fff;
      line-height: 1.25;
    }
    .bottom-cta h2 span { color: var(--rg-orange); }

    /* ─── Testimonials ───────────────────────────────────── */
    .testimonials-section { padding: 5rem 0; background: #fff; }
    .testi-card {
      background: var(--rg-cream);
      border-radius: 14px;
      padding: 1.75rem;
      height: 100%;
      border: 1px solid #ede9e0;
    }
    .testi-card .stars { color: #fbbf24; font-size: 0.9rem; margin-bottom: 0.75rem; }
    .testi-card .text {
       font-family: "Lato";
      font-size: 0.875rem;
      color: #374151;
      line-height: 1.65;
      margin-bottom: 1rem;
    }
    .testi-card .author {
       font-family: "Lato";
      font-weight: 700;
      font-size: 0.875rem;
      color: var(--rg-dark);
    }
    .testi-card .role {  font-family: "Lato"; font-size: 0.8rem; color: #9ca3af; }

    /* ─── FAQ ────────────────────────────────────────────── */
    .faq-section { padding: 5rem 0; background: var(--rg-cream); }
    .faq-section h2{
      font-family: "Lato";
    }
    .accordion-item {
      background: #fff;
      border: 1px solid #e5e7eb !important;
      border-radius: 10px !important;
      margin-bottom: 0.75rem;
      overflow: hidden;
    }
    .accordion-button {
      /*font-family: 'Sora', sans-serif;*/
       font-family: "Playfair Display", serif;
      font-weight: 600;
      font-size: 0.95rem;
      color: var(--rg-dark) !important;
      background: #fff !important;
      box-shadow: none !important;
      padding: 1.2rem 1.5rem;
    }
    .accordion-button:not(.collapsed) { color: var(--rg-orange) !important; }
    .accordion-button::after {
      filter: none !important;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23f47920'%3E%3Cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E") !important;
    }
    .accordion-body {
      font-family: "Lato";
      font-size: 0.9rem;
      color: #4b5563;
      line-height: 1.7;
      padding: 0 1.5rem 1.25rem;
    }

    /* ─── Trust badges ───────────────────────────────────── */
    .badge-section {
      background: #fff;
      padding: 2.5rem 0;
      border-top: 1px solid #ede9e0;
      border-bottom: 1px solid #ede9e0;
    }
    .badge-card {
      display: flex; align-items: center; gap: 0.75rem;
      padding: 0.75rem 1.25rem;
      border: 1px solid #e5e7eb;
      border-radius: 10px;
    }
    .badge-card .badge-icon { font-size: 1.8rem; color: #374151; }
    .badge-card .badge-title {
      /*font-family: 'Sora', sans-serif;*/
       font-family: "Playfair Display", serif;
      font-weight: 700; font-size: 0.9rem;
    }
    .badge-card .badge-sub { font-size: 0.75rem; color: #9ca3af; }

    /* ─── Final CTA ───────────────────────────────────────── */
    .final-cta {
      background: var(--rg-dark);
      padding: 4rem 0;
    }
    .final-cta h2 {
      font-size: clamp(1.5rem, 3vw, 2.2rem);
      font-weight: 800;
      color: #fff;
      line-height: 1.25;
    }
    .final-cta h2 span { color: var(--rg-orange); }
    .final-cta p { color: #9ca3af; font-size: 0.9rem; }

    /* ─── Footer ─────────────────────────────────────────── */
    .rg-footer {
      font-family: "Lato";
      background: #111827;
      color: #9ca3af;
      padding: 3rem 0 1.5rem;
      font-size: 0.875rem;
    }
    .rg-footer .brand {
      /*font-family: 'Sora', sans-serif;*/
       font-family: "Playfair Display", serif;
      font-weight: 800;
      font-size: 1.1rem;
      color: #fff;
    }
    .rg-footer .brand span { color: var(--rg-orange); }
    .rg-footer address { font-style: normal; line-height: 1.8; }
    .rg-footer a { color: #9ca3af; text-decoration: none; }
    .rg-footer a:hover { color: #fff; }
    .rg-footer .footer-heading { font-weight: 700; color: #fff; margin-bottom: 0.75rem; font-size: 0.875rem; }
    .rg-footer .divider { border-color: #1f2937; margin: 2rem 0 1rem; }

    /* ─── Misc Helpers ───────────────────────────────────── */
    .orange-line {
      width: 48px; height: 4px;
      background: var(--rg-orange);
      border-radius: 2px;
      margin-bottom: 1.25rem;
    }
    .proof-img {
      border-radius: 16px;
      width: 100%;
      object-fit: cover;
      box-shadow: 0 12px 40px rgba(0,0,0,0.10);
    }

    /*----------- Modal ----------*/
  /* Overlay backdrop */
.modal_close {
  float: right;
  position: absolute;
  right: 0px;
  top: 0px;
}
.modal_close button {
  border: 2px solid #000;
  width: 20px;
  line-height: 26px;
  text-align: center;
  display: block;
  position: relative;
  z-index: 99;
  cursor: pointer;
  -moz-border-radius: 30px;
  -webkit-border-radius: 30px;
  -khtml-border-radius: 30px;
  border-radius: 30px;
}

    /* Modal container */
    .quote-modal {
      position: fixed;
      inset: 0;
      z-index: 1050;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 16px;
    }

    .quote-card {
      background: #fff;
      border-radius: 8px;
      overflow: hidden;
      width: 100%;
      max-width: 800px;
      box-shadow: 0 20px 60px rgba(0,0,0,0.3);
      display: flex;
      max-height: 92vh;
      overflow-y: auto;
    }

    /* Left panel */
    .quote-left {
      background: #f0ede8;
      padding: 48px 36px;
      flex: 0 0 310px;
      display: flex;
      flex-direction: column;
      justify-content: flex-start;
    }

    .quote-left h2 {
      font-size: 2.6rem;
      font-weight: 800;
      color: #1a1a1a;
      line-height: 1.15;
      margin-bottom: 16px;
    }

    .quote-left p {
      font-size: 0.95rem;
      color: #333;
      line-height: 1.5;
      margin-bottom: 28px;
    }

    .feature-list {
      list-style: none;
      padding: 0;
      margin: 0 0 28px 0;
    }

    .feature-list li {
      display: flex;
      align-items: center;
      gap: 10px;
      margin-bottom: 14px;
      font-size: 0.9rem;
      color: #e07b2a;
      font-weight: 500;
    }

    .feature-list li .check-icon {
      width: 24px;
      height: 24px;
      background: #e07b2a;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
    }

    .feature-list li .check-icon i {
      color: #fff;
      font-size: 13px;
    }

    .phone-line {
      display: flex;
      align-items: center;
      gap: 10px;
      color: #1a1a1a;
      font-weight: 700;
      font-size: 1rem;
    }

    .phone-line i {
      color: #e07b2a;
      font-size: 1.1rem;
    }

    /* Right panel */
    .quote-right {
      flex: 1;
      padding: 36px 36px 32px;
      position: relative;
      background: #fff;
    }

    .close-btn {
      position: absolute;
      top: 12px;
      right: 14px;
      background: #222;
      color: #fff;
      border: none;
      border-radius: 50%;
      width: 28px;
      height: 28px;
      font-size: 14px;
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      line-height: 1;
    }

    .close-btn:hover {
      background: #444;
    }

    .form-label {
      font-size: 0.85rem;
      font-weight: 600;
      color: #1a1a1a;
      margin-bottom: 6px;
    }

    .form-control {
      background: #f4f4f4;
      border: 1px solid #e8e8e8;
      border-radius: 6px;
      font-size: 0.92rem;
      color: #333;
      padding: 10px 14px;
    }

    .form-control:focus {
      background: #f4f4f4;
      border-color: #e07b2a;
      box-shadow: 0 0 0 0.2rem rgba(224,123,42,0.15);
    }

    textarea.form-control {
      min-height: 100px;
      resize: vertical;
    }

    .consent-text {
      font-size: 0.73rem;
      color: #555;
      line-height: 1.5;
    }

    .consent-text a {
      color: #555;
      text-decoration: underline;
    }

    .btn-submit {
      background: #e07b2a;
      color: #fff;
      font-weight: 700;
      font-size: 1rem;
      border: none;
      border-radius: 8px;
      padding: 14px;
      width: 100%;
      letter-spacing: 0.3px;
      transition: background 0.2s;
    }

    .btn-submit:hover {
      background: #c96a1e;
      color: #fff;
    }

    .privacy-note {
      font-size: 0.78rem;
      color: #666;
      text-align: center;
      margin-top: 10px;
    }

    .privacy-note i {
      color: #e07b2a;
      margin-right: 4px;
    }

    .privacy-note a {
      color: #666;
      text-decoration: underline;
    }

    @media (max-width: 640px) {
      .quote-card {
        flex-direction: column;
        max-height: 95vh;
      }
      .quote-left {
        flex: none;
        padding: 28px 24px;
      }
      .quote-left h2 {
        font-size: 2rem;
      }
      .quote-right {
        padding: 24px 20px;
      }
    }

    @media (max-width: 767px) {
      .hero-card-top, .hero-card-bottom { display: none; }
      .hero-section { padding: 3rem 0 2.5rem; }
    }