:root{
  --primary:#124487;
  --primary-dark:#0d3269;
  --primary-soft:#eef3fa;
  --dark-text:#455873;
  --darkest:#2E3A4C;
  --medium:#7488A6;
  --frame-gradient: linear-gradient(180deg, #FFF 0%, #E9EDF1 50%, #FFF 100%);
  --ease: cubic-bezier(.19,1,.22,1);
  --shadow-sm: 0 4px 14px rgba(46,58,76,.06);
  --shadow-md: 0 14px 34px rgba(18,68,135,.10);
  --shadow-lg: 0 24px 60px rgba(18,68,135,.14);
}
*{ font-family:'Dubai','Segoe UI',sans-serif; box-sizing:border-box; }
html{ scroll-behavior:smooth; scroll-padding-top: 96px; }
body{ color:var(--dark-text); background:#fff; overflow-x:hidden; font-size:.98rem; line-height:1.75; }
h1,h2,h3,h4,h5,.headline{ color:var(--darkest); font-weight:800; letter-spacing:-.01em; }
a{ text-decoration:none; }
::selection{ background:var(--primary); color:#fff; }
.text-primary-brand{ color:var(--primary) !important; }
.bg-primary-brand{ background-color:var(--primary) !important; }

/* ---- Reveal on scroll ---- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); will-change:transform,opacity; }
.reveal.show{ opacity:1; transform:translateY(0); }
.reveal-d1{ transition-delay:.08s; }
.reveal-d2{ transition-delay:.16s; }
.reveal-d3{ transition-delay:.24s; }
.reveal-d4{ transition-delay:.32s; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1 !important; transform:none !important; transition:none !important; }
  .iso-badge, .float-anim{ animation:none !important; }
}

/* ---- Buttons ---- */
.btn-brand{
  background:var(--primary); color:#fff; border:1.5px solid var(--primary);
  border-radius:10px; padding:.75rem 1.75rem; font-weight:700; transition:.3s var(--ease);
  position:relative; overflow:hidden;
}
.btn-brand:hover{ background:var(--primary-dark); border-color:var(--primary-dark); color:#fff; transform:translateY(-3px); box-shadow:var(--shadow-md); }
.btn-brand:active{ transform:translateY(-1px); }
.btn-brand-outline{
  background:#fff; color:var(--primary); border:1.5px solid var(--medium);
  border-radius:10px; padding:.75rem 1.75rem; font-weight:700; transition:.3s var(--ease);
}
.btn-brand-outline:hover{ border-color:var(--primary); background:var(--primary-soft); color:var(--primary); transform:translateY(-3px); box-shadow:var(--shadow-sm); }
.btn-brand-light{
  background:#fff; color:var(--darkest); border:1.5px solid transparent;
  border-radius:10px; padding:.75rem 1.75rem; font-weight:700; transition:.3s var(--ease);
}
.btn-brand-light:hover{ background:#eef2f7; transform:translateY(-3px); box-shadow:var(--shadow-sm); }

/* ---- Navbar ---- */
.navbar-brand-custom{ font-weight:800; color:var(--darkest); font-size:1.35rem; letter-spacing:.5px; display:flex; align-items:center; gap:.6rem; }
.navbar-mark{
  width:38px; height:38px; border-radius:10px; background:var(--primary); color:#fff; display:flex;
  align-items:center; justify-content:center; font-size:.95rem; font-weight:800; flex-shrink:0;
}
.navbar-brand-custom small{ display:block; font-size:.6rem; font-weight:500; color:var(--medium); letter-spacing:2px; }
.navbar{ background:rgba(255,255,255,.92); backdrop-filter:saturate(180%) blur(8px); box-shadow:0 1px 0 rgba(46,58,76,.06); padding:1rem 0; transition:.3s var(--ease); }
.navbar.navbar-scrolled{ padding:.6rem 0; box-shadow:var(--shadow-sm); }
.navbar .nav-link{ color:var(--darkest); font-weight:600; margin:0 .35rem; position:relative; transition:.2s; }
.navbar .nav-link:not(.dropdown-toggle)::after{
  content:""; position:absolute; bottom:-2px; inset-inline-start:0; width:0; height:2px; background:var(--primary);
  transition:width .3s var(--ease);
}
.navbar .nav-link:hover{ color:var(--primary); }
.navbar .nav-link:not(.dropdown-toggle):hover::after{ width:100%; }
.navbar .nav-link.verify-link{ display:flex; align-items:center; gap:.3rem; color:var(--primary); }
.lang-switch{
  border:1.5px solid var(--medium); border-radius:8px; background:#fff; color:var(--darkest);
  font-weight:700; padding:.5rem 1rem; font-size:.85rem; line-height:1.2; display:flex; align-items:center; gap:.4rem;
  transition:.2s;
}
.lang-switch:hover{ border-color:var(--primary); color:var(--primary); }
.navbar .btn-brand{
  padding:.5rem 1.25rem; font-size:.85rem; line-height:1.2; border-radius:8px; display:flex; align-items:center;
}

/* ---- Hero ---- */
.hero{
  position:relative; padding:6rem 0 4rem;
  /* background-image:url('../assets/hero-pattern.svg'); */
  background-image:url('../assets/HeroSection.svg');
  background-size:cover; background-position:center; background-repeat:no-repeat;
  overflow:hidden;
}
.hero-content{ position:relative; z-index:2; }
.eyebrow{
  display:inline-flex; align-items:center; gap:.5rem; color:var(--primary); font-weight:700;
  font-size:.85rem; letter-spacing:1px; background:rgba(18,68,135,.08); padding:.45rem 1.1rem; border-radius:30px;
}
.hero h1{ font-size:2.6rem; line-height:1.35; margin:1.2rem 0 1rem; }
.hero p.lead-text{ font-size:1.08rem; color:var(--dark-text); max-width:560px; }
.hero-badge-wrap{ position:relative; display:flex; align-items:center; justify-content:center; height:100%; }
.iso-badge{ animation: spin 46s linear infinite; }
@keyframes spin{ from{ transform:rotate(0deg);} to{ transform:rotate(360deg);} }
.iso-badge-static{ animation: floaty 5s ease-in-out infinite; transform-origin:center; }
@keyframes floaty{ 0%,100%{ transform:translateY(0);} 50%{ transform:translateY(-10px);} }

/* ---- Stat strip ---- */
.stat-strip{ border-top:1px solid var(--medium); border-bottom:1px solid var(--medium); background:#fff; }
.stat-item{ display:flex; align-items:center; gap:.85rem; padding:1.4rem .5rem; }
.stat-item i{ font-size:1.5rem; color:var(--primary); }
.stat-item .stat-num{ font-weight:800; color:var(--darkest); font-size:1.05rem; display:block; }
.stat-item .stat-label{ font-size:.8rem; color:var(--dark-text); }

/* ---- Section frame ---- */
.section{ padding:5.5rem 0; position:relative; }
.section-stripe{ background:#F7F9FB; }
.section-eyebrow{
  color:var(--primary); font-weight:700; font-size:.82rem; letter-spacing:1.5px; text-transform:uppercase;
  display:inline-block; margin-bottom:.5rem;
}
.section-title{ font-size:2rem; margin-bottom:.6rem; }
.section-sub{ color:var(--dark-text); max-width:680px; }

/* ---- About ---- */
.about-frame{
  border-radius:20px; overflow:hidden; border:1px solid var(--medium);
  position:relative; min-height:340px; box-shadow:var(--shadow-sm); transition:.4s var(--ease);
}
.about-frame img{ width:100%; height:100%; min-height:340px; object-fit:cover; display:block; }
.about-frame:hover{ box-shadow:var(--shadow-md); transform:translateY(-4px); }
.about-subhead{ font-size:1.15rem; color:var(--darkest); font-weight:700; margin-top:1.6rem; margin-bottom:.5rem; }

/* ---- Cards (services / steps / certs) ---- */
.service-card, .step-card, .cert-card{
  border:1px solid var(--medium); border-radius:16px; background:#fff; height:100%; position:relative;
  transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease);
}
.service-card{ padding:2.2rem; }
.service-card:hover, .step-card:hover, .cert-card:hover{ border-color:var(--primary); box-shadow:var(--shadow-md); transform:translateY(-6px); }
.service-icon{
  width:52px; height:52px; border-radius:12px; background:var(--frame-gradient); border:1px solid var(--medium);
  display:flex; align-items:center; justify-content:center; color:var(--primary); font-size:1.4rem; margin-bottom:1.2rem;
  transition:.3s var(--ease);
}
.service-card:hover .service-icon{ background:var(--primary); color:#fff; border-color:var(--primary); transform:scale(1.08) rotate(-4deg); }
.service-card h3{ font-size:1.2rem; }

.step-card{ padding:2rem 1.6rem 1.6rem; }
.step-num{
  width:42px; height:42px; border-radius:50%; background:var(--darkest); color:#fff; font-weight:800;
  display:flex; align-items:center; justify-content:center; margin-bottom:1.1rem; font-size:1.05rem; transition:.3s var(--ease);
}
.step-card:hover .step-num{ background:var(--primary); transform:scale(1.1); }
.step-card h4{ font-size:1.05rem; }
.step-connector{ display:none; }
@media (min-width: 992px){
  .step-track{ position:relative; }
  .step-track::before{
    content:""; position:absolute; top:21px; inset-inline-start:12.5%; inset-inline-end:12.5%; height:1px;
    background:repeating-linear-gradient(90deg, var(--medium) 0 8px, transparent 8px 16px); z-index:0;
  }
  .step-card{ position:relative; z-index:1; }
}

/* ---- Quote form ---- */
.quote-section{ background:linear-gradient(160deg, var(--darkest) 0%, #1c2534 100%); position:relative; overflow:hidden; }
.quote-section .content{ position:relative; z-index:2; }
.quote-section h2, .quote-section p{ color:#fff; }
.quote-section p{ color:#c3ccdb; }
.form-control-brand{
  background:rgba(255,255,255,.03); border:1.5px solid var(--medium); color:#fff; border-radius:10px;
  padding:.85rem 1rem; transition:.25s var(--ease);
}
.form-control-brand::placeholder{ color:#9fb0c9; }
.form-control-brand:focus{ background:rgba(255,255,255,.06); color:#fff; border-color:#fff; box-shadow:0 0 0 .2rem rgba(255,255,255,.1); }
.form-label-brand{ color:#dfe6f0; font-size:.85rem; margin-bottom:.4rem; font-weight:600; }

/* ---- FAQ ---- */
.accordion-item{ border:1px solid var(--medium); border-radius:12px !important; margin-bottom:.9rem; overflow:hidden; transition:.3s; }
.accordion-item:hover{ border-color:var(--primary); }
.accordion-button{ font-weight:700; color:var(--darkest); background:#fff; padding:1.2rem 1.4rem; transition:.25s; }
.accordion-button:not(.collapsed){ color:var(--primary); background:var(--primary-soft); box-shadow:none; }
.accordion-button:focus{ box-shadow:none; border-color:var(--medium); }
.accordion-body{ color:var(--dark-text); padding:0 1.4rem 1.4rem; }
.accordion-button::after{ margin-inline-start:0; margin-inline-end:auto; transition:transform .3s var(--ease); }

/* ---- Certificates ---- */
.filter-pill{
  border:1.5px solid var(--medium); border-radius:30px; padding:.5rem 1.2rem; background:#fff;
  color:var(--darkest); font-weight:600; font-size:.85rem; cursor:pointer; transition:.25s var(--ease); white-space:nowrap;
}
.filter-pill.active, .filter-pill:hover{ background:var(--primary); color:#fff; border-color:var(--primary); transform:translateY(-2px); }
.cert-card{ padding:1.8rem; }
.cert-item{ transition:opacity .35s var(--ease), transform .35s var(--ease); }
.cert-tag{
  display:inline-block; background:var(--frame-gradient); border:1px solid var(--medium); color:var(--primary);
  font-weight:800; font-size:.85rem; padding:.35rem .9rem; border-radius:8px; margin-bottom:1rem; transition:.3s var(--ease);
}
.cert-card:hover .cert-tag{ background:var(--primary); color:#fff; border-color:var(--primary); }
.cert-card h4{ font-size:1.05rem; margin-bottom:.5rem; }
.cert-card p{ font-size:.9rem; margin:0; }
.subgroup-title{ font-weight:800; color:var(--darkest); font-size:1.25rem; margin:.5rem 0 1.6rem; display:flex; align-items:center; gap:.6rem; }
.subgroup-title::before{ content:""; width:6px; height:22px; border-radius:3px; background:var(--primary); display:inline-block; }

/* ---- Verify page ---- */
.verify-hero{
  background-image:url('../assets/hero-pattern.svg');
  background-size:cover; background-position:center; background-repeat:no-repeat;
  padding:5.5rem 0 4rem; position:relative; overflow:hidden;
}
.verify-card{
  background:#fff; border:1px solid var(--medium); border-radius:20px; padding:2.4rem; box-shadow:var(--shadow-md);
  max-width:700px; margin:0 auto; position:relative; z-index:2;
}
.verify-input-group{ position:relative; }
.verify-input-group .form-control{
  padding:1rem 1.2rem; border:1.5px solid var(--medium); border-radius:12px; font-weight:600; letter-spacing:.5px;
  transition:.25s var(--ease);
}
.verify-input-group .form-control:focus{ border-color:var(--primary); box-shadow:0 0 0 .2rem rgba(18,68,135,.12); }
.demo-chip{
  border:1px dashed var(--medium); border-radius:8px; padding:.35rem .8rem; font-size:.78rem; color:var(--dark-text);
  background:#fff; cursor:pointer; transition:.2s;
}
.demo-chip:hover{ border-color:var(--primary); color:var(--primary); background:var(--primary-soft); }
.result-card{
  border-radius:18px; border:1px solid var(--medium); background:#fff; padding:2rem; margin-top:2rem;
  box-shadow:var(--shadow-sm); animation: pop .5s var(--ease);
}
@keyframes pop{ from{ opacity:0; transform:translateY(14px) scale(.98);} to{ opacity:1; transform:translateY(0) scale(1);} }
.status-badge{
  display:inline-flex; align-items:center; gap:.4rem; font-weight:800; font-size:.85rem; padding:.4rem 1rem; border-radius:30px;
}
.status-valid{ background:#e7f6ee; color:#137a4b; }
.status-expired{ background:#fdecec; color:#b3261e; }
.status-notfound{ background:#f3f4f6; color:var(--dark-text); }
.verify-detail-row{ display:flex; justify-content:space-between; padding:.7rem 0; border-bottom:1px dashed var(--medium); font-size:.92rem; }
.verify-detail-row:last-child{ border-bottom:none; }
.verify-detail-row span:first-child{ color:var(--dark-text); }
.verify-detail-row span:last-child{ color:var(--darkest); font-weight:700; }
.how-step{ text-align:center; padding:1.5rem; }
.how-step .how-icon{
  width:64px; height:64px; border-radius:50%; background:var(--frame-gradient); border:1px solid var(--medium);
  display:flex; align-items:center; justify-content:center; color:var(--primary); font-size:1.6rem; margin:0 auto 1rem;
  transition:.3s var(--ease);
}
.how-step:hover .how-icon{ background:var(--primary); color:#fff; transform:scale(1.08); }

/* ---- Footer ---- */
footer{ background:var(--darkest); color:#c3ccdb; padding:3.5rem 0 1.5rem; }
footer h5{ color:#fff; font-weight:800; }
footer a{ color:#c3ccdb; transition:.2s; }
footer a:hover{ color:#fff; padding-inline-start:2px; }
.footer-divider{ border-color:rgba(255,255,255,.12); margin:2rem 0 1.2rem; }
.social-icon{
  width:38px; height:38px; border-radius:50%; border:1px solid rgba(255,255,255,.2); display:flex;
  align-items:center; justify-content:center; color:#fff; transition:.25s var(--ease);
}
.social-icon:hover{ background:var(--primary); border-color:var(--primary); transform:translateY(-3px); }

@media (max-width: 767px){
  .hero h1{ font-size:1.9rem; }
  .section{ padding:3.5rem 0; }
  .verify-card{ padding:1.6rem; }
}

.navbar .dropdown-menu{
  border:1px solid var(--medium); border-radius:14px; box-shadow:var(--shadow-md);
  padding:.5rem; margin-top:.85rem !important; min-width:190px;
  animation: dropdownPop .18s var(--ease);
}
.navbar .dropdown-item{
  border-radius:9px; padding:.65rem .9rem; font-weight:600; color:var(--darkest);
  display:flex; align-items:center; gap:.6rem; transition:.2s var(--ease);
}
.navbar .dropdown-item i{ color:var(--primary); font-size:1rem; width:1.1rem; text-align:center; }
.navbar .dropdown-item:hover, .navbar .dropdown-item:focus{ background:var(--primary-soft); color:var(--primary); }
.navbar .dropdown-item.text-danger:hover{ background:#fdecec; color:#b3261e; }
.navbar .dropdown-item.text-danger:hover i{ color:#b3261e; }
.navbar .dropdown-divider{ border-color:var(--medium); margin:.4rem .2rem; opacity:1; }

.accordion-item:not(:first-of-type){ border: 1px solid var(--medium) !important; }