:root{
      --sahaz-primary:#1f3d5a;
      --sahaz-secondary:#d63b45;
      --sahaz-dark:#132739;
      --sahaz-light:#f4f7fb;
      --sahaz-text:#25384c;
      --sahaz-muted:#667687;
      --sahaz-accent:#e4ebf2;
    }

    body{
      font-family: 'Inter', sans-serif;
      color: var(--sahaz-text);
      background: #ffffff;
    }

    .navbar{
      background: rgba(255,255,255,.92);
      backdrop-filter: blur(10px);
      box-shadow: 0 8px 24px rgba(16,42,29,.06);
    }

    .navbar-brand{
      display: inline-flex;
      align-items: center;
      gap: .55rem;
      padding-top: .2rem;
      padding-bottom: .2rem;
      color: var(--sahaz-primary) !important;
    }

    .brand-logo{
      height: 50px;
      width: auto;
      display: block;
    }

    .brand-name{
      font-weight: 800;
      letter-spacing: .08em;
      color: var(--sahaz-primary);
      font-size: 1.85rem;
      line-height: 1;
    }

    .nav-link{
      color: #324c63 !important;
      font-weight: 500;
    }

    .nav-link:hover{
      color: var(--sahaz-secondary) !important;
    }

    .nav-link.active{
      color: var(--sahaz-primary) !important;
      font-weight: 700;
    }

    .btn-brand.active,
    .btn-brand[aria-current="page"]{
      background: var(--sahaz-primary);
      border-color: var(--sahaz-primary);
      color: #fff;
    }

    .btn-brand{
      background: var(--sahaz-secondary);
      border-color: var(--sahaz-secondary);
      color: #fff;
      border-radius: 12px;
      padding: .8rem 1.2rem;
      font-weight: 600;
    }

    .btn-brand:hover{
      background: var(--sahaz-primary);
      border-color: var(--sahaz-primary);
      color: #fff;
    }

    .btn-outline-brand{
      border: 1px solid rgba(255,255,255,.45);
      color: #fff;
      border-radius: 12px;
      padding: .8rem 1.2rem;
      font-weight: 600;
    }

    .btn-outline-brand:hover{
      background: #fff;
      color: var(--sahaz-primary);
    }

    .hero{
      position: relative;
      margin-top: 72px;
    }

    .home-hero .hero-carousel .carousel-item img{
      height: clamp(420px, 78vh, 760px);
      filter: saturate(.9) contrast(1.02);
    }

    .hero-overlay{
      position: absolute;
      inset: 0;
      background:
        radial-gradient(circle at 72% 28%, rgba(255,255,255,.28) 0%, rgba(255,255,255,.04) 38%, rgba(0,0,0,0) 62%),
        linear-gradient(95deg, rgba(19,39,57,.84) 0%, rgba(31,61,90,.72) 45%, rgba(31,61,90,.24) 100%);
      pointer-events: none;
      z-index: 1;
    }

    .home-hero-content{
      position: absolute;
      inset: 0;
      z-index: 2;
      display: flex;
      align-items: center;
      color: #fff;
      padding-top: 2rem;
      padding-bottom: 8.5rem;
    }

    .home-hero-content h1{
      font-size: clamp(2.2rem, 6vw, 5rem);
      line-height: 1.02;
      font-weight: 800;
      margin-bottom: 1rem;
      max-width: 760px;
    }

    .home-hero-content p{
      font-size: clamp(1rem, 2vw, 1.75rem);
      color: rgba(255,255,255,.92);
      max-width: 780px;
    }

    .hero-badge-box{
      margin-top: 1.1rem;
      display: inline-block;
      background: rgba(255,255,255,.12);
      border: 1px solid rgba(255,255,255,.2);
      border-radius: 16px;
      padding: .85rem 1rem;
      color: #fff;
      max-width: 470px;
    }

    .hero-badge-box strong{
      display: block;
      margin-bottom: .25rem;
    }

    .btn-ghost-light{
      border: 1px solid rgba(255,255,255,.42);
      color: #fff;
      background: rgba(255,255,255,.08);
      border-radius: 12px;
      padding: .8rem 1.2rem;
      font-weight: 600;
    }

    .btn-ghost-light:hover{
      background: #fff;
      color: var(--sahaz-primary);
      border-color: #fff;
    }

    .home-summary-wrap{
      margin-top: -12px;
      position: relative;
      z-index: 3;
    }

    .home-summary-card{
      border-radius: 24px;
      box-shadow: 0 22px 48px rgba(14,34,52,.2);
    }

    .home-link-card{
      border: 1px solid #dde6ef;
      border-radius: 16px;
      padding: 1.1rem;
      height: 100%;
      background: #fff;
    }

    .hero-badge{
      display:inline-flex;
      align-items:center;
      gap:.5rem;
      background: rgba(255,255,255,.12);
      border: 1px solid rgba(255,255,255,.15);
      padding: .5rem .9rem;
      border-radius: 999px;
      font-size: .9rem;
      font-weight: 600;
    }

    .hero h1{
      font-weight: 800;
      font-size: clamp(2.3rem, 5vw, 4rem);
      line-height: 1.08;
      margin-top: 1rem;
      margin-bottom: 1.25rem;
    }

    .hero p{
      font-size: 1.08rem;
      color: rgba(255,255,255,.88);
      max-width: 610px;
    }

    .hero-card{
      background: rgba(255,255,255,.1);
      border: 1px solid rgba(255,255,255,.14);
      backdrop-filter: blur(10px);
      border-radius: 24px;
      padding: 1.5rem;
      box-shadow: 0 20px 40px rgba(0,0,0,.12);
    }

    .hero-carousel{
      border-radius: 0;
      overflow: hidden;
      box-shadow: none;
    }

    .hero-carousel .carousel-item img{
      width: 100%;
      height: clamp(260px, 46vh, 460px);
      object-fit: cover;
      object-position: center;
    }

    .hero-carousel .carousel-indicators{
      margin-bottom: 1rem;
    }

    .hero-carousel .carousel-indicators [data-bs-target]{
      width: 8px;
      height: 8px;
      border-radius: 50%;
    }

    .hero-image-note{
      font-size: .83rem;
      color: rgba(255,255,255,.85);
      margin: 0;
    }

    .stat-card{
      background: #fff;
      border-radius: 20px;
      box-shadow: 0 18px 36px rgba(16,42,29,.08);
      padding: 1.3rem;
      height: 100%;
    }

    .stat-number{
      font-size: 1.8rem;
      font-weight: 800;
      color: var(--sahaz-primary);
    }

    .section{
      padding: 5rem 0;
    }

    .section-title{
      font-weight: 800;
      color: var(--sahaz-primary);
      margin-bottom: .75rem;
    }

    .section-subtitle{
      color: var(--sahaz-muted);
      max-width: 700px;
      margin: 0 auto;
    }

    .service-card{
      background: #fff;
      border: 1px solid #e2e8ef;
      border-radius: 22px;
      padding: 1.6rem;
      height: 100%;
      box-shadow: 0 16px 32px rgba(16,42,29,.05);
      transition: transform .25s ease, box-shadow .25s ease;
    }

    .service-card:hover{
      transform: translateY(-4px);
      box-shadow: 0 20px 40px rgba(16,42,29,.10);
    }

    .service-icon{
      width: 54px;
      height: 54px;
      border-radius: 50%;
      display:flex;
      align-items:center;
      justify-content:center;
      background: var(--sahaz-secondary);
      color: #fff;
      font-size: 1.15rem;
      margin-bottom: 1rem;
      font-weight: 800;
    }

    .service-icon svg{
      width: 28px;
      height: 28px;
      stroke: currentColor;
      stroke-width: 2;
      fill: none;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    .about-box{
      background: linear-gradient(180deg, #ffffff 0%, #f5f8fc 100%);
      border: 1px solid #e0e8f0;
      border-radius: 24px;
      padding: 2rem;
      box-shadow: 0 20px 40px rgba(16,42,29,.05);
    }

    .form-shell{
      background: #fff;
      border: 1px solid #e0e8f0;
      border-radius: 20px;
      padding: 1.5rem;
      box-shadow: 0 14px 30px rgba(16,42,29,.06);
      height: 100%;
    }

    .form-title{
      font-size: 1.2rem;
      font-weight: 700;
      color: var(--sahaz-primary);
      margin-bottom: 1rem;
    }

    .form-label{
      font-weight: 600;
      color: #2f465f;
      margin-bottom: .4rem;
    }

    .form-control,
    .form-select{
      border-radius: 12px;
      border: 1px solid #d6e0ea;
      padding: .68rem .85rem;
    }

    .form-control:focus,
    .form-select:focus{
      border-color: #d88c91;
      box-shadow: 0 0 0 .2rem rgba(214,59,69,.15);
    }

    .helper-list{
      margin: 0;
      padding-left: 1rem;
      color: var(--sahaz-muted);
      font-size: .95rem;
    }

    .hp-field{
      position: absolute !important;
      left: -9999px !important;
      top: auto !important;
      width: 1px !important;
      height: 1px !important;
      overflow: hidden !important;
    }

    .feature-item{
      display:flex;
      gap: .9rem;
      margin-bottom: 1rem;
    }

    .feature-dot{
      width: 12px;
      height: 12px;
      border-radius: 50%;
      background: var(--sahaz-secondary);
      margin-top: .45rem;
      flex-shrink: 0;
    }

    .feature-icon{
      width: 54px;
      height: 54px;
      border-radius: 50%;
      background: var(--sahaz-secondary);
      display: flex;
      align-items: center;
      justify-content: center;
      margin-top: .1rem;
      flex-shrink: 0;
    }

    .feature-icon svg{
      width: 28px;
      height: 28px;
      stroke: #fff;
      stroke-width: 2;
      fill: none;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    .process-card{
      background: var(--sahaz-light);
      border-radius: 20px;
      padding: 1.4rem;
      border: 1px solid #dde6ef;
      height: 100%;
    }

    .process-step{
      font-size: .9rem;
      font-weight: 700;
      color: var(--sahaz-secondary);
      text-transform: uppercase;
      letter-spacing: .08em;
      margin-bottom: .55rem;
    }

    .cta{
      background: linear-gradient(135deg, #162d42 0%, #2a4f73 100%);
      color: #fff;
      border-radius: 28px;
      padding: 2.5rem;
      box-shadow: 0 20px 45px rgba(16,42,29,.18);
    }

    .contact-card{
      background: #fff;
      border: 1px solid #dde6ef;
      border-radius: 20px;
      padding: 1.4rem;
      height: 100%;
      box-shadow: 0 16px 32px rgba(16,42,29,.05);
    }

    .info-line{
      display: flex;
      align-items: flex-start;
      gap: .65rem;
      margin-bottom: .7rem;
    }

    .mini-icon-circle{
      width: 28px;
      height: 28px;
      border-radius: 50%;
      background: var(--sahaz-secondary);
      color: #fff;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      margin-top: .1rem;
    }

    .mini-icon-circle svg{
      width: 14px;
      height: 14px;
      stroke: currentColor;
      stroke-width: 2;
      fill: none;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    .footer{
      background: #112334;
      color: rgba(255,255,255,.75);
      padding: 1.5rem 0;
    }

    .placeholder-visual{
      min-height: 360px;
      background:
        linear-gradient(180deg, rgba(255,255,255,.2), rgba(255,255,255,.06)),
        url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='900' height='700' viewBox='0 0 900 700'%3E%3Crect width='900' height='700' fill='%23dfeae3'/%3E%3Crect x='70' y='220' width='230' height='280' rx='12' fill='%23a4bcae'/%3E%3Crect x='335' y='170' width='250' height='330' rx='12' fill='%2389ac97'/%3E%3Crect x='625' y='250' width='200' height='250' rx='12' fill='%23769b86'/%3E%3Crect x='0' y='510' width='900' height='190' fill='%23bdcec3'/%3E%3C/svg%3E") center/cover no-repeat;
      border-radius: 24px;
      border: 1px solid rgba(255,255,255,.18);
      box-shadow: inset 0 0 0 1px rgba(255,255,255,.08);
      position: relative;
      overflow: hidden;
    }

    .placeholder-label{
      position: absolute;
      bottom: 16px;
      left: 16px;
      background: rgba(15,81,50,.88);
      color: #fff;
      padding: .7rem .9rem;
      border-radius: 12px;
      font-size: .92rem;
      font-weight: 600;
      max-width: 80%;
    }

    .small-muted{
      color: var(--sahaz-muted);
      font-size: .95rem;
    }

    @media (max-width: 991.98px){
      .hero{
        margin-top: 64px;
      }
      .brand-logo{
        height: 44px;
      }
      .brand-name{
        font-size: 1.45rem;
      }
      .hero-carousel .carousel-item img{
        height: clamp(210px, 36vh, 320px);
      }
      .home-hero .hero-carousel .carousel-item img{
        height: clamp(420px, 66vh, 620px);
      }
      .home-hero-content{
        align-items: flex-end;
        padding-top: 1.5rem;
        padding-bottom: 6rem;
      }
      .home-summary-wrap{
        margin-top: 0;
      }
    }

    @media (max-width: 575.98px){
      .home-hero-content{
        padding-bottom: 4.5rem;
      }

      .hero-badge-box{
        max-width: 100%;
      }

      .home-summary-wrap{
        margin-top: 0;
      }
    }

