/* ============================================================
   SkyPrime Global — style.css
   Premium Blue / White / Gold theme, extracted from the
   official logo. Built on top of Bootstrap 5 utilities.
   ============================================================ */

:root{
  /* Brand palette — sampled from the SkyPrime Global logo */
  --navy:        #0B2A56;
  --navy-deep:   #071B3B;
  --navy-soft:   #1E3F71;
  --gold:        #C7962E;
  --gold-light:  #E8C873;
  --gold-deep:   #9C7322;
  --ivory:       #FAF8F3;
  --white:       #FFFFFF;
  --ink:         #1F2A3C;
  --ink-soft:    #5B6678;
  --line:        #E7E2D6;
  --success:     #1F8A55;
  --danger:      #C0392B;

  --font-display: "Playfair Display", Georgia, serif;
  --font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --radius-lg: 22px;
  --radius-md: 14px;
  --radius-sm: 10px;
  --shadow-soft: 0 20px 50px -20px rgba(11,42,86,.25);
  --shadow-card: 0 12px 30px -14px rgba(11,42,86,.18);
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--white);
  line-height: 1.65;
  overflow-x: hidden;
}
h1,h2,h3,h4{
  font-family: var(--font-display);
  color: var(--navy);
  font-weight: 700;
  line-height: 1.2;
}
a{ text-decoration: none; }
img{ max-width: 100%; }
section{ position: relative; }
.section-pad{ padding: 96px 0; }
.bg-ivory{ background: var(--ivory); }
@media (max-width: 768px){ .section-pad{ padding: 64px 0; } }

.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-size: 13px; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  color: var(--gold-deep); margin-bottom: 14px;
}
.eyebrow::before{ content:""; width:26px; height:2px; background: var(--gold); display:inline-block; border-radius:2px; }
.section-title{ font-size: clamp(28px, 3.6vw, 42px); margin-bottom: 14px; }
.section-sub{ color: var(--ink-soft); font-size: 17px; max-width: 620px; }

/* ---------- Buttons ---------- */
.btn-gold{
  background: linear-gradient(135deg, var(--gold-light), var(--gold) 55%, var(--gold-deep));
  color: var(--navy-deep); font-weight: 700; border: none;
  padding: 13px 30px; border-radius: 999px; letter-spacing:.01em;
  box-shadow: 0 12px 26px -10px rgba(199,150,46,.55);
  transition: transform .18s ease, box-shadow .18s ease;
}
.btn-gold:hover{ transform: translateY(-2px); box-shadow: 0 16px 30px -10px rgba(199,150,46,.65); color: var(--navy-deep); }
.btn-navy{
  background: var(--navy); color: #fff; font-weight:700; border: none;
  padding: 13px 30px; border-radius: 999px;
  transition: transform .18s ease, background .18s ease;
}
.btn-navy:hover{ background: var(--navy-deep); color:#fff; transform: translateY(-2px); }
.btn-outline-navy{
  background: transparent; color: var(--navy); font-weight:700;
  border: 1.5px solid var(--navy); padding: 12px 28px; border-radius: 999px;
  transition: background .18s ease, color .18s ease;
}
.btn-outline-navy:hover{ background: var(--navy); color:#fff; }
.btn-outline-white{
  background: transparent; color:#fff; font-weight:700;
  border: 1.5px solid rgba(255,255,255,.6); padding: 12px 28px; border-radius: 999px;
}
.btn-outline-white:hover{ background: rgba(255,255,255,.12); color:#fff; border-color:#fff; }

/* ============================================================
   NAVIGATION
   ============================================================ */
.navbar-skyprime{
  position: sticky; top:0; z-index: 1030;
  background: rgba(255,255,255,.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line);
  transition: box-shadow .2s ease, padding .2s ease;
  padding: 10px 0;
}
.navbar-skyprime.scrolled{ box-shadow: 0 8px 24px -16px rgba(11,42,86,.35); padding: 4px 0; }
.navbar-skyprime .navbar-brand img{ height: 58px; transition: height .2s ease; }
.navbar-skyprime.scrolled .navbar-brand img{ height: 46px; }

/* Brand name beside the logo (added without altering existing navbar rules above) */
.navbar-skyprime .navbar-brand{ display:flex; align-items:center; gap:14px; }
.navbar-skyprime .navbar-brand-text{
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1;
  color: var(--navy);
  letter-spacing: .01em;
  white-space: nowrap;
  transition: font-size .2s ease;
}
.navbar-skyprime .navbar-brand-text .brand-gold{ color: var(--gold); }
.navbar-skyprime.scrolled .navbar-brand-text{ font-size: 1.3rem; }
@media (max-width: 991px){
  .navbar-skyprime .navbar-brand{ gap: 10px; }
  .navbar-skyprime .navbar-brand-text{ font-size: 1.2rem; }
}
@media (max-width: 380px){
  .navbar-skyprime .navbar-brand-text{ font-size: 1.02rem; }
}
.navbar-skyprime .nav-link{
  font-weight: 600; color: var(--navy) !important; padding: 10px 18px !important;
  position: relative;
}
.navbar-skyprime .nav-link.active::after{
  content:""; position:absolute; left:18px; right:18px; bottom:4px; height:2px;
  background: var(--gold); border-radius:2px;
}
.navbar-skyprime .btn-gold{ padding: 10px 24px; font-size: 14.5px; }
.navbar-toggler{ border:none; }
.navbar-toggler:focus{ box-shadow: none; }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position: relative;
  min-height: 92vh;
  display:flex; align-items:center;
  background:
    linear-gradient(120deg, rgba(7,27,59,.92) 0%, rgba(11,42,86,.85) 45%, rgba(11,42,86,.65) 100%),
    radial-gradient(circle at 80% 20%, rgba(199,150,46,.35), transparent 45%),
    var(--navy-deep);
  overflow: hidden;
}
.hero::before{
  content:"";
  position:absolute; inset:0;
  background-image: url('../assets/images/hero-bg.jpg');
  background-size: cover; background-position: center;
  opacity: .55; mix-blend-mode: overlay;
}
.hero::after{
  content:"";
  position:absolute; right:-10%; top:-15%; width:560px; height:560px;
  border-radius:50%; border: 1px dashed rgba(255,255,255,.15);
}
.hero-content{ position:relative; z-index:2; padding: 60px 0; }
.hero .badge-glass{
  display:inline-flex; align-items:center; gap:8px;
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.25);
  backdrop-filter: blur(6px);
  color:#fff; font-size: 13px; font-weight:600; letter-spacing:.06em;
  padding: 8px 18px; border-radius: 999px; margin-bottom: 22px;
}
.hero h1{
  color:#fff; font-size: clamp(34px, 5vw, 58px); margin-bottom: 20px;
}
.hero h1 span{ color: var(--gold-light); }
.hero p.lede{ color: rgba(255,255,255,.82); font-size: 18.5px; max-width: 540px; margin-bottom: 34px; }
.hero-actions{ display:flex; gap:16px; flex-wrap:wrap; }
.hero-stats{ display:flex; gap: 38px; margin-top: 50px; flex-wrap:wrap; }
.hero-stat strong{ display:block; color:#fff; font-family: var(--font-display); font-size: 28px; }
.hero-stat span{ color: rgba(255,255,255,.68); font-size: 13px; text-transform:uppercase; letter-spacing:.08em; }

/* Glassmorphism trust card floating in hero */
.hero-glass-card{
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.28);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border-radius: var(--radius-lg);
  padding: 28px;
  color: #fff;
  box-shadow: var(--shadow-soft);
}
.hero-glass-card .glass-row{ display:flex; align-items:center; gap:14px; padding: 12px 0; border-bottom: 1px solid rgba(255,255,255,.16); }
.hero-glass-card .glass-row:last-child{ border-bottom:none; }
.hero-glass-card .glass-icon{
  width:44px; height:44px; border-radius:12px; flex-shrink:0;
  background: linear-gradient(135deg, var(--gold-light), var(--gold));
  display:flex; align-items:center; justify-content:center; color: var(--navy-deep); font-size:18px;
}
.hero-glass-card .glass-row strong{ display:block; font-size:14.5px; }
.hero-glass-card .glass-row small{ color: rgba(255,255,255,.7); font-size:12.5px; }

@media (max-width: 991px){
  .hero{ min-height: auto; padding-top: 30px; }
  .hero-glass-card{ margin-top: 36px; }
}

/* ============================================================
   FEATURE / WHY CHOOSE US CARDS
   ============================================================ */
.feature-card{
  background:#fff; border:1px solid var(--line); border-radius: var(--radius-md);
  padding: 32px 28px; height:100%; box-shadow: var(--shadow-card);
  transition: transform .2s ease, box-shadow .2s ease;
}
.feature-card:hover{ transform: translateY(-6px); box-shadow: var(--shadow-soft); }
.feature-icon{
  width:58px; height:58px; border-radius: 16px;
  background: linear-gradient(135deg, var(--navy), var(--navy-soft));
  color: var(--gold-light);
  display:flex; align-items:center; justify-content:center; font-size:24px;
  margin-bottom: 20px;
}
.feature-card h3{ font-size: 19px; margin-bottom:10px; }
.feature-card p{ color: var(--ink-soft); margin:0; font-size:15px; }

/* ============================================================
   COUNTRY / VISA CARDS
   ============================================================ */
.country-card{
  background:#fff; border-radius: var(--radius-md); overflow:hidden;
  box-shadow: var(--shadow-card); border: 1px solid var(--line);
  height:100%; transition: transform .2s ease, box-shadow .2s ease;
}
.country-card:hover{ transform: translateY(-6px); box-shadow: var(--shadow-soft); }
.country-card-top{
  background: linear-gradient(135deg, var(--navy) 0%, var(--navy-soft) 100%);
  padding: 30px 26px 22px; color:#fff; position:relative;
}
.country-flag{
  width:56px; height:56px; border-radius:50%; overflow:hidden;
  border: 3px solid var(--gold-light); display:flex; align-items:center; justify-content:center;
  font-size: 26px; background:#fff; margin-bottom: 16px;
}
.country-card-top h3{ color:#fff; font-size:21px; margin-bottom:4px; }
.country-card-top .tag{
  display:inline-block; background: rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.3);
  font-size:12px; letter-spacing:.06em; text-transform:uppercase; padding:5px 12px; border-radius:999px;
}
.country-card-body{ padding: 22px 26px 26px; }
.country-card-body p{ color: var(--ink-soft); font-size:14.5px; min-height: 64px; }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testimonial-card{
  background:#fff; border-radius: var(--radius-md); padding: 34px 30px;
  box-shadow: var(--shadow-card); border:1px solid var(--line); height:100%;
}
.testimonial-stars{ color: var(--gold); font-size:14px; margin-bottom:14px; }
.testimonial-card p.quote{ font-size:15.5px; color: var(--ink); margin-bottom:22px; }
.testimonial-person{ display:flex; align-items:center; gap:14px; }
.testimonial-avatar{
  width:46px; height:46px; border-radius:50%; background: linear-gradient(135deg,var(--navy),var(--navy-soft));
  color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700; font-family:var(--font-display);
}
.testimonial-person strong{ display:block; font-size:14.5px; color: var(--navy); }
.testimonial-person span{ font-size:12.5px; color: var(--ink-soft); }

/* ============================================================
   FAQ ACCORDION
   ============================================================ */
.accordion-skyprime .accordion-item{
  border: none; border-bottom: 1px solid var(--line); background:transparent;
}
.accordion-skyprime .accordion-button{
  font-family: var(--font-display); font-weight:700; color: var(--navy);
  font-size:17px; padding: 22px 4px; background:transparent; box-shadow:none;
}
.accordion-skyprime .accordion-button:not(.collapsed){ color: var(--gold-deep); background:transparent; }
.accordion-skyprime .accordion-button:focus{ box-shadow:none; }
.accordion-skyprime .accordion-button::after{ flex-shrink:0; }
.accordion-skyprime .accordion-body{ color: var(--ink-soft); padding: 0 4px 24px; font-size:15px; }

/* ============================================================
   CTA BANNER
   ============================================================ */
.cta-banner{
  background: linear-gradient(120deg, var(--navy-deep), var(--navy) 60%, var(--navy-soft));
  border-radius: var(--radius-lg);
  padding: 56px 48px; color:#fff; position:relative; overflow:hidden;
}
.cta-banner::before{
  content:""; position:absolute; right:-70px; top:-70px; width:240px; height:240px;
  border-radius:50%; background: radial-gradient(circle, rgba(199,150,46,.35), transparent 70%);
}
.cta-banner h2{ color:#fff; font-size: clamp(24px,3vw,32px); }
.cta-banner p{ color: rgba(255,255,255,.78); max-width: 460px; margin-bottom:0; }
@media (max-width: 768px){ .cta-banner{ padding: 40px 26px; } }

/* ============================================================
   FORMS
   ============================================================ */
.form-panel{
  background:#fff; border-radius: var(--radius-lg); padding: 40px;
  box-shadow: var(--shadow-soft); border: 1px solid var(--line);
}
.form-panel .form-label{ font-weight:600; color: var(--navy); font-size:14px; margin-bottom:7px; }
.form-panel .form-label .req{ color: var(--danger); }
.form-panel .form-control,
.form-panel .form-select{
  border-radius: var(--radius-sm); border: 1.5px solid var(--line);
  padding: 11px 14px; font-size: 14.5px;
}
.form-panel .form-control:focus,
.form-panel .form-select:focus{
  border-color: var(--gold); box-shadow: 0 0 0 3px rgba(199,150,46,.18);
}
.upload-box{
  border: 1.5px dashed var(--line); border-radius: var(--radius-sm);
  padding: 18px; background: var(--ivory);
  transition: border-color .15s ease, background .15s ease;
}
.upload-box.has-file{ border-color: var(--gold); background: #FFF8EA; }
.upload-box label{ font-weight:600; color: var(--navy); font-size:14px; }
.upload-box .hint{ font-size:12px; color: var(--ink-soft); margin: 2px 0 8px; }
.upload-filename{ font-size:12px; color: var(--gold-deep); font-weight:600; }
.honeypot-field{ position:absolute; left:-9999px; top:-9999px; opacity:0; height:0; width:0; }

.note-box{
  background: var(--ivory); border-left:3px solid var(--gold);
  border-radius: var(--radius-sm); padding: 14px 18px; font-size:13.5px; color: var(--ink-soft);
}

/* Loading spinner inside submit buttons */
.btn-loading .btn-text{ display:none; }
.btn-loading .btn-spinner{ display:inline-flex !important; }
.btn-spinner{ display:none; }

/* Toast / success popup */
.sp-toast{
  position: fixed; top: 90px; right: 24px; z-index: 2000;
  max-width: 380px; background:#fff; border-radius: var(--radius-md);
  box-shadow: var(--shadow-soft); border-left: 5px solid var(--success);
  padding: 18px 20px; display:flex; gap:14px; align-items:flex-start;
  transform: translateX(120%); transition: transform .3s ease;
}
.sp-toast.show{ transform: translateX(0); }
.sp-toast.error{ border-left-color: var(--danger); }
.sp-toast .sp-toast-icon{ font-size: 22px; color: var(--success); flex-shrink:0; margin-top:2px; }
.sp-toast.error .sp-toast-icon{ color: var(--danger); }
.sp-toast h5{ font-size:15px; margin:0 0 4px; color: var(--navy); font-family: var(--font-body); font-weight:700; }
.sp-toast p{ font-size:13.5px; color: var(--ink-soft); margin:0; }
.sp-toast .sp-toast-close{ margin-left:auto; cursor:pointer; color: var(--ink-soft); background:none; border:none; font-size:16px; }
@media (max-width: 576px){ .sp-toast{ left:16px; right:16px; max-width:none; } }

/* ============================================================
   FLOATING BUTTONS
   ============================================================ */
.float-btn{
  position: fixed; right: 24px; z-index: 1500;
  width: 56px; height:56px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:24px; box-shadow: 0 14px 30px -10px rgba(0,0,0,.35);
  transition: transform .2s ease, opacity .2s ease;
}
.float-whatsapp{ bottom: 24px; background: #25D366; }
.float-whatsapp:hover{ transform: scale(1.08); color:#fff; }
.float-totop{
  bottom: 92px; background: var(--navy); opacity:0; pointer-events:none; transform: translateY(10px);
}
.float-totop.show{ opacity:1; pointer-events:auto; transform: translateY(0); }
.float-totop:hover{ background: var(--navy-deep); color:#fff; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer-skyprime{ background: var(--navy-deep); color: rgba(255,255,255,.75); padding-top: 70px; }
.footer-logo-chip{
  display:inline-flex; background:#fff; border-radius: 14px; padding: 8px 16px; margin-bottom: 18px;
}
.footer-logo-chip img{ height: 40px; }
.footer-skyprime p{ color: rgba(255,255,255,.6); font-size:14.5px; }
.footer-skyprime h5{ color:#fff; font-family: var(--font-body); font-weight:700; font-size:14px; letter-spacing:.06em; text-transform:uppercase; margin-bottom:20px; }
.footer-skyprime ul{ list-style:none; padding:0; margin:0; }
.footer-skyprime ul li{ margin-bottom:12px; }
.footer-skyprime ul li a{ color: rgba(255,255,255,.68); font-size:14.5px; }
.footer-skyprime ul li a:hover{ color: var(--gold-light); }
.social-icons{ display:flex; gap:10px; margin-top:18px; }
.social-icons a{
  width:38px; height:38px; border-radius:50%; border:1px solid rgba(255,255,255,.25);
  display:flex; align-items:center; justify-content:center; color:#fff;
  transition: background .15s ease, border-color .15s ease;
}
.social-icons a:hover{ background: var(--gold); border-color: var(--gold); color: var(--navy-deep); }
.footer-bottom{ border-top: 1px solid rgba(255,255,255,.12); margin-top: 50px; padding: 22px 0; font-size:13px; }
.footer-bottom a{ color: rgba(255,255,255,.7); }

/* ============================================================
   PAGE HEADER (non-home pages)
   ============================================================ */
.page-header{
  background: linear-gradient(120deg, var(--navy-deep), var(--navy) 70%);
  padding: 130px 0 70px; color:#fff; position:relative; overflow:hidden;
}
.page-header::after{
  content:""; position:absolute; right:6%; top:30%; width:200px; height:200px;
  border-radius:50%; border: 1px dashed rgba(255,255,255,.18);
}
.page-header h1{ color:#fff; font-size: clamp(30px,4vw,44px); }
.page-header p{ color: rgba(255,255,255,.78); max-width:560px; }
.breadcrumb-sp a{ color: rgba(255,255,255,.7); }
.breadcrumb-sp{ font-size:13px; letter-spacing:.05em; text-transform:uppercase; margin-bottom:16px; }

/* ============================================================
   ANIMATION HELPERS (fallback for no-JS / reduced motion)
   ============================================================ */
@media (prefers-reduced-motion: reduce){
  *{ animation-duration: .001ms !important; transition-duration: .001ms !important; scroll-behavior: auto !important; }
}
[data-aos]{ opacity: 0; transition-property: opacity, transform; }
[data-aos].aos-animate{ opacity: 1; }
[data-aos="fade-up"]{ transform: translateY(24px); }
[data-aos="fade-up"].aos-animate{ transform: translateY(0); }
[data-aos="fade-right"]{ transform: translateX(-24px); }
[data-aos="fade-right"].aos-animate{ transform: translateX(0); }
[data-aos="fade-left"]{ transform: translateX(24px); }
[data-aos="fade-left"].aos-animate{ transform: translateX(0); }
[data-aos="zoom-in"]{ transform: scale(.94); }
[data-aos="zoom-in"].aos-animate{ transform: scale(1); }
