        @font-face {
  font-family: 'OpenSans';
  src: url('../fonts/OpenSans-Regular.ttf') format('opentype');
  font-style: normal;
}
    
 *{
    margin:0;
    padding:0;
    box-sizing:border-box;
    font-family: 'OpenSans';
}

.hero-section{
    position:relative;
    width:100%;
    height:100vh;

    display:flex;
    align-items:center;
        justify-content: center;

    padding:0 8%;
    overflow:hidden;
}

/* Background Images */

.hero-img{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
    z-index:1;
}

.mobile-img{
    display:none;
}

/* Overlay */

.hero-overlay{
    position:absolute;
    inset:0;
    background:rgba(0,0,0,.35);
    z-index:2;
}

/* Content */

.hero-content{
    width:auto;
    color:#fff;
    z-index:3;
    padding: 0px 10px;

    display:flex;
    flex-direction:column;
     align-items:center;
        justify-content: center;
    gap:2vh;
}

.hero-content h1{
    font-size:3.5rem;
    line-height:1.1;
        text-align: center;
}

.offer-text{
    text-align:center;
}

.offer-text p{
    display:inline-block;
    position:relative;
    padding:0.3em 2em;
    font-size:1.7rem;
    line-height:1.6;
    color:#000;
    margin-bottom:1.5rem;
    z-index:1;
}

.offer-text p::before{
    content:"";
    position:absolute;
    top:50%;
    left:50%;
    transform:translate(-50%,-50%);
    width:140%;
    height:100%;
    background:linear-gradient(
        90deg,
        rgba(255,255,255,0) 0%,
        rgba(255,255,255,0.75) 20%,
        rgba(255,255,255,1) 50%,
        rgba(255,255,255,0.75) 80%,
        rgba(255,255,255,0) 100%
    );
    z-index:-1;
}

.hero-btn{
    width:auto;
    min-width:10rem;
    height:7vh;

    display:flex;
    align-items:center;
    justify-content:center;

    text-decoration:none;
    background:#43397c;
    color:#fff;
    font-size:1.4rem;
    font-weight:700;
    border-radius:.4rem;
    padding: 1.25rem 1.65rem;
    cursor: pointer;
}

.quality-standards{
    width:100%;
    background:#000;
    padding:3vh 4vw;
}

.quality-container{
    width:100%;
    display:flex;
    justify-content:space-between;
    align-items:center;
    flex-wrap:wrap;
    gap:2vh 2vw;
}

.quality-item{
    flex:1;
    min-width:20%;
    text-align:center;
}

.quality-item p{
    color:#fff;
    font-size:clamp(0.95rem,1.2vw,1.2rem);
    font-weight:500;
    line-height:1.5em;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:0.5em;
}

.quality-item p::before{
display:none;
    content:none;
}


/* Tablet */

@media (max-width:991px){

    .hero-content{
        width:60%;
    }

    .hero-content h1{
        font-size:2.8rem;
    }

    .hero-btn{
        width:22vw;
    }
}

/* Mobile */

@media (max-width:767px){

    .desktop-img{
        display:none;
    }

    .mobile-img{
                height: 100vh;
        display: block;
        object-position: 100% 100%;
    }

    .hero-section{
        height:90vh;
        justify-content:center;
        padding:0 5%;
    }

    .hero-content{
                width: 100%;
        text-align: center;
        align-items: center;
        padding: 0px 0px;
    }

    .hero-content h1{
        font-size:2rem;
    }

    .hero-content p{
        font-size: 1.2rem;
    }

    .hero-btn{
              width: 65%;
        height: 6.5vh;
        font-size: 1.25rem;
    }
    
      .quality-standards{
        padding:4vh 4vw;
    }

    .quality-container{
        display:grid;
        grid-template-columns:repeat(2,1fr);
        gap:1rem;
        width:100%;
    }

    .quality-item{
        width:100%;
        min-width:unset;
        background:rgba(255,255,255,0.06);
        border:1px solid rgba(255,255,255,0.12);
        border-radius:0.75rem;
        padding:1rem 0.75rem;
        display:flex;
        align-items:center;
        justify-content:center;
        min-height:80px;
    }

    .quality-item p{
        font-size:1rem;
        line-height:1.4;
        text-align:center;
        justify-content:center;
        flex-direction:column;
        gap:0.5rem;
    }
}

/* Mobile */
@media (max-width: 480px){
      .quality-container{
        grid-template-columns:repeat(2,1fr);
        gap:0.8rem;
    }

    .quality-item{
        min-height:75px;
        padding:0.9rem 0.6rem;
    }

    .quality-item p{
        font-size:0.9rem;
    }
}
    
      /* ================= FOOTER ================= */
    footer {
      height: 7vh;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 0.9rem;
      background: #000;
    }

    footer a {
      color: #fff;
      text-decoration: none;
    }
    
    
        /* ── SECTION ── */
    .faq {
      width: min(720px, 92vw);
      margin: 0 auto;
      padding: 8vh 0 10vh;
    }

    /* ── HEADER ── */
    .faq__header {
      margin-bottom: 5vh;
    }

    .faq__label {
      display: inline-block;
      font-size: 0.68rem;
      font-weight: 500;
      letter-spacing: 0.2em;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 0.9rem;
    }

    .faq__title {
      font-size: clamp(2rem, 4.5vw, 3rem);
      font-weight: 700;
      line-height: 1.15;
      color: var(--ink);
      margin-bottom: 0.85rem;
          text-align: center;
    }

    .faq__desc {
      font-size: clamp(0.88rem, 1.6vw, 0.97rem);
      color: var(--muted);
      font-weight: 300;
      max-width: 52ch;
    }

    /* ── LIST ── */
    .faq__list {
      list-style: none;
      border-top: 1px solid var(--line);
    }

    /* ── ITEM ── */
    .faq__item {
      border-bottom: 1px solid var(--line);
      transition: background 0.2s;
    }

    /* ── BUTTON ── */
    .faq__btn {
      width: 100%;
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      gap: 1.5rem;
      padding: 1.4em 0;
      background: none;
      border: none;
      color: var(--ink);
      font-size: clamp(0.9rem, 2vw, 1.02rem);
      font-weight: 500;
      text-align: left;
      cursor: pointer;
      transition: color 0.2s;
    }

    .faq__btn:hover { color: var(--accent); }
    .faq__item.open .faq__btn { color: var(--accent); }

    .faq__q {
      display: flex;
      align-items: flex-start;
      gap: 0.85rem;
    }

    .faq__n {
      flex-shrink: 0;
      font-size: 0.78rem;
      color: var(--gold);
      margin-top: 0.18em;
      font-weight: 600;
    }

    /* ── ICON ── */
    .faq__icon {
      flex-shrink: 0;
      margin-top: 0.2em;
      width: 1.5rem;
      height: 1.5rem;
      border-radius: 50%;
      border: 1.5px solid var(--line);
      display: grid;
      place-items: center;
      transition: transform 0.35s cubic-bezier(.4,0,.2,1),
                  border-color 0.25s, background 0.25s;
    }

    .faq__item.open .faq__icon {
      transform: rotate(45deg);
      border-color: var(--accent);
      background: var(--accent-lt);
    }

    /* ── ANSWER ── */
    .faq__answer {
      max-height: 0;
      overflow: hidden;
      transition: max-height 0.4s cubic-bezier(.4,0,.2,1);
    }

    .faq__item.open .faq__answer { max-height: 25rem; }

    .faq__body {
      padding: 0 0 1.5em 2.6em;
      font-size: clamp(0.85rem, 1.6vw, 0.93rem);
      color: var(--muted);
      font-weight: 300;
      line-height: 1.85;
    }

    .faq__body strong { color: var(--ink); font-weight: 500; }

    /* ── FOOTER NOTE ── */
    .faq__foot {
      margin-top: 4vh;
      padding-top: 2.5vh;
      border-top: 1px solid var(--line);
      display: flex;
      align-items: center;
      justify-content: space-between;
      flex-wrap: wrap;
      gap: 1rem;
    }

    .faq__foot-text {
      font-size: 0.85rem;
      color: var(--muted);
      font-weight: 300;
    }

    .faq__foot-link {
      display: inline-flex;
      align-items: center;
      gap: 0.4rem;
      font-size: 0.85rem;
      font-weight: 500;
      color: var(--accent);
      text-decoration: none;
      border-bottom: 1px solid transparent;
      transition: border-color 0.2s;
    }

    .faq__foot-link:hover { border-color: var(--accent); }

    /* ── STAGGER ANIMATION ── */
    .faq__item {
      opacity: 0;
      transform: translateY(12px);
      animation: fadeUp 0.45s ease forwards;
    }

    @keyframes fadeUp {
      to { opacity: 1; transform: none; }
    }

    .faq__item:nth-child(1) { animation-delay: 0.05s; }
    .faq__item:nth-child(2) { animation-delay: 0.10s; }
    .faq__item:nth-child(3) { animation-delay: 0.15s; }
    .faq__item:nth-child(4) { animation-delay: 0.20s; }
    .faq__item:nth-child(5) { animation-delay: 0.25s; }
    .faq__item:nth-child(6) { animation-delay: 0.30s; }
    .faq__item:nth-child(7) { animation-delay: 0.35s; }

    @media (max-width: 500px) {
      .faq__body { padding-left: 1.8em; }
      .faq__btn  { padding: 1.2em 0; }
    }
