/* ══════════════════════════════════════
   THREE SIXTY HR CONSULTANCY FZE LLC
   Main Stylesheet
══════════════════════════════════════ */

/* ── DESIGN TOKENS ── */
:root {
  --gold-primary:    #D4AF37;
  --gold-light:      #FBF5B7;
  --gold-dark:       #AA771C;
  --gold-gradient:   linear-gradient(135deg, #BF953F, #FCF6BA, #B38728, #FBF5B7, #AA771C);
  --gold-grad-btn:   linear-gradient(135deg, #BF953F 0%, #D4AF37 40%, #FCF6BA 60%, #B38728 80%, #AA771C 100%);
  --gold-grad-simple:linear-gradient(135deg, #D4AF37, #FCF6BA, #AA771C);
  --black-bg:        #050505;
  --black-card:      #111111;
  --black-light:     #1a1a1a;
  --text-white:      #ffffff;
  --text-grey:       #b3b3b3;
  --text-grey2:      #888888;
  --border-gold:     rgba(212,175,55,.22);
  --border-gold2:    rgba(212,175,55,.45);
  --ff: 'Montserrat', sans-serif;
  --r:  10px;
  --r2: 6px;
}

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:var(--ff); background:var(--black-bg); color:var(--text-white); overflow-x:hidden; line-height:1.6; }
img  { max-width:100%; display:block; }
a    { text-decoration:none; color:inherit; }
button { font-family:var(--ff); cursor:pointer; }

/* ── UTILITIES ── */
.gold-text { background:var(--gold-gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.gold-rule { width:56px; height:3px; background:var(--gold-grad-simple); border-radius:2px; margin:16px 0 30px; }
.wrap  { max-width:1220px; margin:0 auto; padding:0 64px; }
.sec   { padding:96px 0; }
.sec--alt   { background:var(--black-card); }
.sec--light { background:var(--black-light); }
.eyebrow { font-size:10.5px; font-weight:700; letter-spacing:.25em; text-transform:uppercase; display:inline-flex; align-items:center; gap:10px; margin-bottom:14px; background:var(--gold-gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.eyebrow::before { content:''; width:28px; height:2px; background:var(--gold-grad-simple); flex-shrink:0; }
.heading  { font-size:clamp(32px,3.8vw,52px); font-weight:800; line-height:1.1; margin-bottom:18px; }
.subtext  { font-size:15px; color:var(--text-grey); line-height:1.85; max-width:580px; font-weight:400; }

/* ── BUTTONS ── */
.btn { display:inline-flex; align-items:center; gap:8px; padding:13px 32px; border-radius:var(--r2); font-family:var(--ff); font-size:13px; font-weight:700; letter-spacing:.08em; border:none; cursor:pointer; transition:all .25s; text-transform:uppercase; }
.btn-gold { background:var(--gold-grad-btn); color:var(--black-bg); box-shadow:0 4px 20px rgba(212,175,55,.4); }
.btn-gold:hover { transform:translateY(-2px); box-shadow:0 8px 30px rgba(212,175,55,.55); }
.btn-outline { background:transparent; color:var(--text-white); border:1.5px solid rgba(255,255,255,.35); }
.btn-outline:hover { border-color:var(--gold-primary); color:var(--gold-primary); }
.btn-outline-gold { background:transparent; color:var(--gold-primary); border:1.5px solid var(--gold-primary); }
.btn-outline-gold:hover { background:var(--gold-grad-btn); color:var(--black-bg); }

/* ══════════════════════════════════════
   TOPBAR
══════════════════════════════════════ */
.topbar { background:var(--black-light); border-bottom:1px solid var(--border-gold); padding:9px 64px; display:flex; justify-content:space-between; align-items:center; font-size:12px; color:var(--text-grey); font-weight:500; letter-spacing:.03em; }
.topbar a { color:var(--gold-primary); transition:color .2s; }
.topbar a:hover { color:var(--gold-light); }
.tb-left, .tb-right { display:flex; align-items:center; gap:24px; }
.tb-item { display:flex; align-items:center; gap:6px; }
.tb-item .fa-solid, .tb-item .fa-regular { font-size:12px; color:var(--gold-primary); }

/* ══════════════════════════════════════
   NAVIGATION
══════════════════════════════════════ */
nav { position:sticky; top:0; z-index:2000; background:rgba(5,5,5,.97); backdrop-filter:blur(18px); border-bottom:1px solid var(--border-gold); height:76px; display:flex; align-items:center; justify-content:space-between; padding:0 64px; }
.nav-logo img { height:54px; width:auto; object-fit:contain; }
.nav-links { display:flex; align-items:center; gap:34px; list-style:none; }
.nav-links a { color:var(--text-grey); font-size:13px; font-weight:600; letter-spacing:.06em; text-transform:uppercase; position:relative; transition:color .2s; padding-bottom:10px;}
.nav-links a::after { content:''; position:absolute; bottom:-4px; left:0; width:0; height:2px; background:var(--gold-grad-simple); transition:width .3s; }
.nav-links a:hover, .nav-links a.active { color:var(--gold-primary); }
.nav-links a:hover::after, .nav-links a.active::after { width:100%; }
.nav-cta { background:var(--gold-grad-btn) !important; color:var(--black-bg) !important; padding:10px 24px !important; border-radius:var(--r2); font-weight:700 !important; letter-spacing:.08em; text-transform:uppercase !important; box-shadow:0 4px 18px rgba(212,175,55,.4); transition:all .2s !important; border:none !important; }
.nav-cta::after { display:none !important; }
.nav-cta:hover { transform:translateY(-1px) !important; box-shadow:0 8px 28px rgba(212,175,55,.55) !important; }

/* ══════════════════════════════════════
   HAMBURGER & MOBILE MENU
══════════════════════════════════════ */
.hamburger { display:none; flex-direction:column; justify-content:center; gap:5px; width:40px; height:40px; background:none; border:1px solid var(--border-gold2); border-radius:var(--r2); padding:8px; cursor:pointer; z-index:2100; transition:border-color .2s; }
.hamburger:hover { border-color:var(--gold-primary); }
.hamburger span { display:block; width:100%; height:2px; background:var(--gold-primary); border-radius:2px; transition:all .3s; transform-origin:center; }
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

.mobile-overlay { position:fixed; inset:0; background:rgba(0,0,0,.7); z-index:2040; opacity:0; pointer-events:none; transition:opacity .35s; backdrop-filter:blur(4px); }
.mobile-overlay.open { opacity:1; pointer-events:all; }
.mobile-menu { position:fixed; top:0; right:-100%; width:min(360px,100vw); height:100vh; background:rgba(5,5,5,.97); border-left:1px solid var(--border-gold); z-index:2050; transition:right .38s cubic-bezier(.77,0,.18,1); display:flex; flex-direction:column; padding:32px 32px 40px; overflow-y:auto; }
.mobile-menu.open { right:0; }
.mobile-close { position:absolute; top:22px; right:24px; width:38px; height:38px; border-radius:50%; background:rgba(212,175,55,.1); border:1px solid var(--border-gold2); color:var(--gold-primary); font-size:20px; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:all .2s; }
.mobile-close:hover { background:var(--gold-grad-btn); color:var(--black-bg); border-color:transparent; }
.mobile-logo { margin-bottom:36px; }
.mobile-logo img { height:48px; width:auto; object-fit:contain; }
.mobile-nav-links { list-style:none; display:flex; flex-direction:column; gap:4px; margin-bottom:36px; }
.mobile-nav-links li a { display:flex; align-items:center;  padding:13px 16px; border-radius:var(--r2); font-size:14px; font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:var(--text-grey); transition:all .2s; border:1px solid transparent; }
.mobile-nav-links li a:hover, .mobile-nav-links li a.active { color:var(--gold-primary); background:rgba(212,175,55,.06); border-color:var(--border-gold); }
.mobile-nav-links li a .arr { font-size:10px; color:var(--gold-primary); opacity:.6; }
.mobile-cta-wrap { margin-top:auto; padding-top:24px; border-top:1px solid var(--border-gold); display:flex; flex-direction:column; gap:12px; }
.mobile-contact-item { display:flex; align-items:center; gap:10px; font-size:12.5px; color:var(--text-grey2); font-weight:500; }
.mobile-contact-item a { color:var(--gold-primary); }
.mobile-contact-item .fa-solid, .mobile-contact-item .fa-brands { font-size:13px; color:var(--gold-primary); }
.arr .fa-solid { font-size:10px; }

/* ══════════════════════════════════════
   FOOTER
══════════════════════════════════════ */
footer { background:#020202; border-top:1px solid var(--border-gold); padding:64px 0 28px; }
.footer-top { display:grid; grid-template-columns:2.2fr 1fr 1fr 1fr; gap:40px; margin-bottom:52px; }
.footer-brand img { height:64px; width:auto; object-fit:contain; margin-bottom:18px; }
.footer-brand p { font-size:13px; color:var(--text-grey2); line-height:1.85; max-width:300px; font-weight:400; }
.footer-brand .social-links { display:flex; gap:12px; margin-top:20px; }
.social-link { width:36px; height:36px; border-radius:50%; background:rgba(212,175,55,.08); border:1px solid var(--border-gold); display:flex; align-items:center; justify-content:center; font-size:14px; transition:all .25s; color:var(--gold-primary); }
.social-link:hover { background:var(--gold-grad-btn); color:var(--black-bg); border-color:transparent; }
.social-link .fa-brands, .social-link .fa-solid { font-size:15px; }
.fcol h5 { font-size:10.5px; letter-spacing:.2em; text-transform:uppercase; font-weight:800; margin-bottom:20px; background:var(--gold-gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.fcol ul { list-style:none; display:flex; flex-direction:column; gap:11px; }
.fcol ul li a { font-size:13px; color:var(--text-grey2); font-weight:400; transition:color .2s; display:flex; align-items:center; gap:6px; }
.fcol ul li a::before { content:'›'; color:var(--gold-primary); font-size:14px; }
.fcol ul li a:hover { color:var(--gold-primary); }
.footer-hr { border:none; border-top:1px solid rgba(255,255,255,.06); margin-bottom:24px; }
.footer-btm { display:flex; justify-content:space-between; align-items:center; font-size:12px; color:var(--text-grey2); font-weight:500; }
.footer-btm b { color:var(--gold-primary); }

/* WhatsApp float */
.wa-btn { position:fixed; bottom:30px; right:30px; width:58px; height:58px; border-radius:50%; background:#25d366; display:flex; align-items:center; justify-content:center; font-size:26px; z-index:999; box-shadow:0 6px 24px rgba(37,211,102,.4); animation:waPulse 2.5s infinite; }
.wa-btn .fa-brands { font-size:28px; color:#fff; }
@keyframes waPulse { 0%,100%{ box-shadow:0 6px 24px rgba(37,211,102,.4); } 50%{ box-shadow:0 6px 44px rgba(37,211,102,.7); } }

/* ══════════════════════════════════════
   PAGE HERO (shared across inner pages)
══════════════════════════════════════ */
.page-hero { position:relative; height:460px; background-size:cover; background-position:center; display:flex; align-items:center; overflow:hidden; }
.page-hero-ov { position:absolute; inset:0; background:linear-gradient(120deg,rgba(5,5,5,.93) 0%,rgba(5,5,5,.72) 60%,rgba(5,5,5,.38) 100%); }
.page-hero-cnt { position:relative; z-index:2; padding:0 64px; max-width:860px; }
.breadcrumb { display:flex; align-items:center; gap:8px; font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--text-grey2); margin-bottom:18px; }
.breadcrumb a { color:var(--gold-primary); transition:color .2s; }
.breadcrumb a:hover { color:var(--gold-light); }
.page-hero-cnt h1 { font-size:clamp(40px,5.5vw,70px); font-weight:900; line-height:1.06; color:#fff; margin-bottom:16px; letter-spacing:-.5px; }
.page-hero-cnt p { font-size:16px; color:rgba(200,210,228,.82); line-height:1.78; max-width:600px; font-weight:400; }

/* ══════════════════════════════════════
   CTA BAND (shared)
══════════════════════════════════════ */
.cta-band { position:relative; overflow:hidden; background:var(--black-light); border-top:1px solid var(--border-gold); border-bottom:1px solid var(--border-gold); padding:88px 64px; text-align:center; }
.cta-band::before { content:'360°'; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); font-size:300px; font-weight:900; line-height:1; pointer-events:none; background:var(--gold-gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; opacity:.04; white-space:nowrap; }
.cta-band h2 { font-size:clamp(34px,3.8vw,54px); font-weight:900; margin-bottom:18px; position:relative; z-index:1; }
.cta-band p { font-size:15.5px; color:var(--text-grey); max-width:520px; margin:0 auto 40px; line-height:1.82; position:relative; z-index:1; }
.cta-btns { display:flex; gap:16px; justify-content:center; position:relative; z-index:1; }

/* ══════════════════════════════════════
   HERO SLIDER (index only)
══════════════════════════════════════ */
.hero-slider { position:relative; width:100%; overflow:hidden; height:100vh; min-height:640px; }
.slides-wrap { display:flex; width:300%; height:100%; transition:transform .78s cubic-bezier(.77,0,.18,1); }
.slide { flex:0 0 33.333%; height:100%; position:relative; background-size:cover; background-position:center; }
.slide-ov { position:absolute; inset:0; background:linear-gradient(115deg,rgba(5,5,5,.94) 0%,rgba(5,5,5,.75) 50%,rgba(5,5,5,.35) 100%); }
.slide-cnt { position:absolute; top:50%; left:64px; transform:translateY(-50%) translateX(-36px); max-width:660px; z-index:2; opacity:0; transition:opacity .65s .3s,transform .65s .3s; }
.slide.active .slide-cnt { opacity:1; transform:translateY(-50%) translateX(0); }
.slide-badge-wrap { display:inline-flex; align-items:center; gap:8px; border:1px solid rgba(212,175,55,.5); padding:7px 20px; border-radius:30px; font-size:10.5px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; margin-bottom:26px; color:var(--gold-primary); background:rgba(212,175,55,.07); }
.slide-cnt h1 { font-size:clamp(44px,5.5vw,76px); font-weight:900; line-height:1.06; color:#fff; margin-bottom:20px; letter-spacing:-.5px; }
.slide-cnt p { font-size:15.5px; color:rgba(200,210,228,.82); line-height:1.85; margin-bottom:38px; max-width:520px; font-weight:400; }
.slide-btns { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:44px; }
.slide-stats { display:flex; align-items:center; gap:24px; background:rgba(5,5,5,.6); border:1px solid var(--border-gold); backdrop-filter:blur(12px); padding:16px 28px; border-radius:var(--r); width:fit-content; }
.sstat { text-align:center; }
.sstat strong { display:block; font-size:22px; font-weight:900; line-height:1; background:var(--gold-gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.sstat span { font-size:10px; color:var(--text-grey); margin-top:4px; display:block; letter-spacing:.06em; font-weight:600; }
.sdiv { width:1px; height:34px; background:var(--border-gold); }
.s-arrow { position:absolute; top:50%; transform:translateY(-50%); z-index:10; width:52px; height:52px; border-radius:50%; background:rgba(5,5,5,.55); border:1px solid var(--border-gold2); color:var(--gold-primary); font-size:18px; display:flex; align-items:center; justify-content:center; backdrop-filter:blur(6px); transition:all .22s; }
.s-arrow:hover { background:var(--gold-grad-btn); color:var(--black-bg); border-color:transparent; }
.s-arrow.prev { left:24px; } .s-arrow.next { right:24px; }
.s-dots { position:absolute; bottom:28px; left:50%; transform:translateX(-50%); z-index:10; display:flex; gap:10px; }
.sdot { width:10px; height:10px; border-radius:5px; background:rgba(255,255,255,.25); border:none; cursor:pointer; transition:all .3s; padding:0; }
.sdot.active { width:28px; background:var(--gold-primary); }

/* ══════════════════════════════════════
   ABOUT SECTION (index)
══════════════════════════════════════ */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center; }
.about-visual { background:var(--black-card); border:1px solid var(--border-gold); border-radius:var(--r); padding:48px 36px; text-align:center; position:relative; overflow:hidden; box-shadow:0 0 60px rgba(212,175,55,.07); }
.about-visual::before { content:'360°'; position:absolute; bottom:-24px; right:-8px; font-size:130px; font-weight:900; line-height:1; background:var(--gold-gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; opacity:.08; pointer-events:none; }
.orbit-wrap { position:relative; width:180px; height:180px; margin:0 auto 32px; }
.orbit-ring1 { position:absolute; inset:-24px; border-radius:50%; border:1px dashed rgba(212,175,55,.25); animation:spin 20s linear infinite; }
.orbit-dot { position:absolute; top:-5px; left:50%; transform:translateX(-50%); width:10px; height:10px; border-radius:50%; background:var(--gold-primary); }
.orbit-ring2 { position:absolute; inset:-8px; border-radius:50%; border:1px solid rgba(212,175,55,.35); }
.orbit-core { width:180px; height:180px; border-radius:50%; border:2px solid var(--gold-primary); background:radial-gradient(circle,rgba(212,175,55,.08) 0%,transparent 70%); display:flex; align-items:center; justify-content:center; box-shadow:0 0 40px rgba(212,175,55,.12); }
.orbit-num { font-size:48px; font-weight:900; line-height:1; background:var(--gold-gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
@keyframes spin { to { transform:rotate(360deg); } }
.vtypes { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-top:24px; }
.vtype { background:rgba(212,175,55,.05); border:1px solid var(--border-gold); border-radius:var(--r2); padding:13px 12px; display:flex; flex-direction:column; align-items:center; gap:5px; font-size:11px; font-weight:600; color:var(--text-grey); letter-spacing:.04em; transition:all .25s; text-transform:uppercase; }
.vtype:hover { border-color:var(--gold-primary); background:rgba(212,175,55,.1); color:var(--gold-primary); }
.vtype .fa-solid { font-size:18px; color:var(--gold-primary); }
.chks { display:flex; flex-direction:column; gap:14px; margin-bottom:32px; }
.chk { display:flex; gap:13px; align-items:flex-start; font-size:14.5px; color:var(--text-grey); line-height:1.6; font-weight:400; }
.chk-dot { width:22px; height:22px; border-radius:50%; flex-shrink:0; margin-top:1px; background:rgba(212,175,55,.12); border:1px solid var(--gold-primary); display:flex; align-items:center; justify-content:center; font-size:10px; font-weight:800; color:var(--gold-primary); }

/* ══════════════════════════════════════
   SERVICES GRID (index)
══════════════════════════════════════ */
.svc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:52px; }
.svc-card { background:var(--black-card); border:1px solid var(--border-gold); border-radius:var(--r); padding:36px 28px; position:relative; overflow:hidden; transition:all .3s; }
.svc-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--gold-grad-simple); opacity:0; transition:opacity .3s; }
.svc-card:hover { border-color:var(--gold-primary); transform:translateY(-6px); background:var(--black-light); }
.svc-card:hover::before { opacity:1; }
.svc-ico { width:56px; height:56px; border-radius:var(--r2); background:rgba(212,175,55,.08); border:1px solid var(--border-gold2); display:flex; align-items:center; justify-content:center; font-size:24px; margin-bottom:22px; transition:all .3s; }
.svc-ico .fa-solid { font-size:22px; color:var(--gold-primary); }
.svc-card:hover .svc-ico { background:rgba(212,175,55,.15); border-color:var(--gold-primary); }
.svc-card h3 { font-size:17px; font-weight:700; margin-bottom:10px; color:#fff; }
.svc-card p { font-size:13px; color:var(--text-grey); line-height:1.82; margin-bottom:20px; font-weight:400; }
.svc-list { list-style:none; display:flex; flex-direction:column; gap:8px; }
.svc-list li { font-size:12.5px; color:var(--text-grey2); display:flex; gap:9px; align-items:center; font-weight:500; }
.svc-list li::before { content:'✓'; color:var(--gold-primary); font-size:12px; font-weight:800; flex-shrink:0; }

/* ══════════════════════════════════════
   DESTINATIONS (index)
══════════════════════════════════════ */
.dest-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:16px; margin-top:52px; }
.dest-card { background:var(--black-light); border:1px solid var(--border-gold); border-radius:var(--r); padding:28px 14px; text-align:center; transition:all .28s; }
.dest-card:hover { border-color:var(--gold-primary); background:rgba(212,175,55,.05); transform:translateY(-5px); box-shadow:0 20px 50px rgba(0,0,0,.4); }
.dest-card:hover .dest-name { color:var(--gold-primary); }
.dest-flag { font-size:36px; margin-bottom:12px; display:block; }
.dest-name { font-size:14px; font-weight:700; color:#fff; margin-bottom:5px; transition:color .25s; }
.dest-type { font-size:10px; color:var(--text-grey2); letter-spacing:.06em; font-weight:500; }

/* ══════════════════════════════════════
   PROCESS (index)
══════════════════════════════════════ */
.process-wrap { margin-top:64px; position:relative; }
.process-line { position:absolute; top:44px; left:9%; right:9%; height:1px; background:linear-gradient(90deg,transparent,var(--gold-primary),transparent); }
.process-steps { display:grid; grid-template-columns:repeat(5,1fr); }
.pstep { text-align:center; padding:0 14px; }
.pnum-wrap { width:88px; height:88px; border-radius:50%; background:var(--black-card); border:2px solid var(--gold-primary); display:flex; align-items:center; justify-content:center; margin:0 auto 24px; position:relative; z-index:1; transition:all .3s; box-shadow:0 0 24px rgba(212,175,55,.15); }
.pstep:hover .pnum-wrap { background:rgba(212,175,55,.12); box-shadow:0 0 36px rgba(212,175,55,.3); }
.pnum { font-size:26px; font-weight:900; background:var(--gold-gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.pstep h4 { font-size:14px; font-weight:700; margin-bottom:10px; color:#fff; letter-spacing:.04em; text-transform:uppercase; }
.pstep p { font-size:12.5px; color:var(--text-grey); line-height:1.72; }

/* ══════════════════════════════════════
   STATS BAND (index)
══════════════════════════════════════ */
.stats-band { background:var(--black-card); border-top:1px solid var(--border-gold); border-bottom:1px solid var(--border-gold); }
.stats-inner { display:grid; grid-template-columns:repeat(4,1fr); }
.stat-item { padding:52px 24px; text-align:center; border-right:1px solid var(--border-gold); position:relative; transition:background .3s; }
.stat-item:last-child { border-right:none; }
.stat-item:hover { background:rgba(212,175,55,.04); }
.stat-item::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--gold-grad-simple); opacity:0; transition:opacity .3s; }
.stat-item:hover::before { opacity:1; }
.stat-num { font-size:52px; font-weight:900; line-height:1; margin-bottom:10px; background:var(--gold-gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.stat-lbl { font-size:12px; color:var(--text-grey); font-weight:600; letter-spacing:.1em; text-transform:uppercase; }

/* ══════════════════════════════════════
   TESTIMONIALS (index)
══════════════════════════════════════ */
.testi-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:52px; }
.tcard { background:var(--black-card); border:1px solid var(--border-gold); border-radius:var(--r); padding:34px 28px; display:flex; flex-direction:column; gap:20px; transition:all .28s; position:relative; overflow:hidden; }
.tcard::before { content:'"'; position:absolute; top:16px; right:22px; font-size:80px; line-height:1; font-weight:900; background:var(--gold-gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; opacity:.15; }
.tcard:hover { border-color:var(--gold-primary); transform:translateY(-4px); box-shadow:0 20px 48px rgba(0,0,0,.4); }
.tcard-stars { display:flex; gap:3px; }
.tstar .fa-solid { font-size:13px; color:var(--gold-primary); }
.tcard-quote { font-size:14px; color:var(--text-grey); line-height:1.88; flex:1; font-style:italic; }
.tcard-author { display:flex; align-items:center; gap:14px; padding-top:18px; border-top:1px solid var(--border-gold); }
.tavatar { width:44px; height:44px; border-radius:50%; flex-shrink:0; background:var(--gold-grad-simple); display:flex; align-items:center; justify-content:center; font-size:17px; font-weight:900; color:var(--black-bg); }
.tname { font-size:13.5px; font-weight:700; color:#fff; }
.trole { font-size:11px; color:var(--gold-primary); margin-top:2px; font-weight:600; }

/* ══════════════════════════════════════
   CONTACT FORM (index + contact page)
══════════════════════════════════════ */
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start; }
.ci-list { display:flex; flex-direction:column; gap:26px; margin-bottom:36px; }
.ci { display:flex; gap:16px; align-items:flex-start; }
.ci-ico { width:48px; height:48px; border-radius:var(--r2); flex-shrink:0; background:rgba(212,175,55,.08); border:1px solid var(--border-gold2); display:flex; align-items:center; justify-content:center; font-size:19px; color:var(--gold-primary); transition:all .25s; }
.ci:hover .ci-ico { background:rgba(212,175,55,.15); border-color:var(--gold-primary); }
.ci strong { display:block; font-size:13.5px; font-weight:700; margin-bottom:3px; color:#fff; letter-spacing:.04em; text-transform:uppercase; }
.ci span { font-size:13.5px; color:var(--text-grey); line-height:1.55; }
.ci span a { color:var(--text-grey); transition:color .2s; }
.ci span a:hover { color:var(--gold-primary); }
.form-grid { display:flex; flex-direction:column; gap:16px; }
.form-row2 { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.fg { display:flex; flex-direction:column; gap:7px; }
.fg label { font-size:10.5px; color:var(--text-grey); letter-spacing:.12em; text-transform:uppercase; font-weight:700; }
.fg input, .fg select, .fg textarea { background:var(--black-light); border:1px solid var(--border-gold); border-radius:var(--r2); padding:12px 16px; color:#fff; font-family:var(--ff); font-size:13.5px; outline:none; transition:border-color .2s, box-shadow .2s; -webkit-appearance:none; }
.fg input:focus, .fg select:focus, .fg textarea:focus { border-color:var(--gold-primary); box-shadow:0 0 0 3px rgba(212,175,55,.12); }
.fg input::placeholder, .fg textarea::placeholder { color:rgba(255,255,255,.2); }
.fg select option { background:var(--black-card); }
.fg textarea { resize:vertical; min-height:120px; line-height:1.65; }
.submit-btn { background:var(--gold-grad-btn); color:var(--black-bg); border:none; padding:14px 44px; border-radius:var(--r2); font-family:var(--ff); font-size:13px; font-weight:800; cursor:pointer; transition:all .25s; letter-spacing:.1em; text-transform:uppercase; box-shadow:0 4px 20px rgba(212,175,55,.4); }
.submit-btn:hover { transform:translateY(-2px); box-shadow:0 8px 30px rgba(212,175,55,.55); }

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media(max-width:1024px) {
  .wrap, .topbar, nav, .cta-band { padding-left:24px; padding-right:24px; }
  .nav-links { display:none; }
  .hamburger { display:flex; }
  .about-grid, .contact-grid { grid-template-columns:1fr; gap:48px; }
  .svc-grid { grid-template-columns:1fr 1fr; }
  .dest-grid { grid-template-columns:repeat(3,1fr); }
  .process-steps { grid-template-columns:1fr 1fr; gap:40px; }
  .process-line { display:none; }
  .stats-inner { grid-template-columns:1fr 1fr; }
  .stat-item { border:none; border-bottom:1px solid var(--border-gold); }
  .testi-grid { grid-template-columns:1fr; }
  .footer-top { grid-template-columns:1fr 1fr; gap:32px; }
  .slide-cnt { left:24px; right:24px; max-width:100%; }
  .page-hero-cnt { padding:0 24px; }
}
@media(max-width:640px) {
    .stat-num{
        font-size:35px;
    }
  .svc-grid, .form-row2 { grid-template-columns:1fr; }
  .dest-grid { grid-template-columns:1fr 1fr; }
  .stats-inner { grid-template-columns:1fr 1fr; }
  .slide-btns, .cta-btns { flex-direction:column; align-items:flex-start; }
  .cta-btns { align-items:center; }
  .footer-top { grid-template-columns:1fr; }
  .footer-btm { flex-direction:column; gap:8px; text-align:center; }
  .topbar { display:none; }
}

/* ══════════════════════════════════════
   DROPDOWN SUBMENU
══════════════════════════════════════ */

/* Parent li needs relative positioning */
.nav-links li { position: relative; list-style: none; }

/* Dropdown trigger arrow */
.nav-links li.has-dropdown > a .drop-arrow {
  display: inline-flex;
  align-items: center;
  margin-left: 5px;
  font-size: 9px;
  color: var(--gold-primary);
  transition: transform .3s;
}
.nav-links li.has-dropdown:hover > a .drop-arrow {
  transform: rotate(180deg);
}

/* ── MEGA DROPDOWN PANEL ── */
.dropdown {
  position: absolute;
  top: calc(100% + 14px);
  left: 50%;
  transform: translateX(-50%);
  width: 300px;
  background: var(--black-card);
  border: 1px solid var(--border-gold);
  border-radius: var(--r);
  box-shadow: 0 24px 64px rgba(0,0,0,.6), 0 0 0 1px rgba(212,175,55,.08);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .25s, transform .25s, visibility .25s;
  transform: translateX(-50%) translateY(10px);
  z-index: 3000;
}
.nav-links li.has-dropdown:hover .dropdown {
  opacity: 1;
  visibility: visible;
  pointer-events: all;
  transform: translateX(-50%) translateY(0);
}

/* Arrow notch pointing up */
.dropdown::before {
  content: '';
  position: absolute;
  top: -7px;
  left: 50%;
  transform: translateX(-50%);
  width: 14px;
  height: 14px;
  background: var(--black-card);
  border-left: 1px solid var(--border-gold);
  border-top: 1px solid var(--border-gold);
  transform: translateX(-50%) rotate(45deg);
}

/* ── DROPDOWN INNER LAYOUT ── */
.dropdown-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  padding: 10px 0 10px;
}

/* Column header */
.drop-col-head {
  padding: 0 28px 14px;
  font-size: 9.5px;
  font-weight: 800;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold-primary);
  display: flex;
  align-items: center;
  gap: 8px;
  border-bottom: 1px solid var(--border-gold);
  margin-bottom: 10px;
}
.drop-col-head i { font-size: 12px; }

/* Left column = visa categories */
.drop-col { padding: 0 12px 0 20px; }
.drop-col:last-child { padding: 0 20px 0 12px; border-left: 1px solid var(--border-gold); }

/* Each dropdown link item */
.drop-item {
  display: flex;
  align-items: flex-start;
  gap: 13px;
  padding: 10px 10px;
  border-radius: var(--r2);
  text-decoration: none;
  transition: all .22s;
  margin-bottom: 2px;
}
.drop-item:hover {
  background: rgba(212,175,55,.07);
}
.drop-item:hover .drop-item-icon { background: rgba(212,175,55,.2); border-color: var(--gold-primary); }
.drop-item:hover .drop-item-title { color: var(--gold-primary); }

.drop-item-icon {
  width: 38px;
  height: 38px;
  border-radius: var(--r2);
  background: rgba(212,175,55,.08);
  border: 1px solid var(--border-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: all .22s;
}
.drop-item-icon i { font-size: 16px; color: var(--gold-primary); }

.drop-item-text { flex: 1; }
.drop-item-title {
  display: block;
  font-size: 13px;
  font-weight: 700;
  color: var(--text-white);
  margin-bottom: 2px;
  transition: color .22s;
  letter-spacing: .02em;
}
.drop-item-desc {
  font-size: 11px;
  color: var(--text-grey2);
  font-weight: 400;
  line-height: 1.5;
}

/* ── DROPDOWN FOOTER CTA ── */
.drop-footer {
  margin: 14px 20px 8px;
  padding: 14px 18px;
  background: rgba(212,175,55,.06);
  border: 1px solid var(--border-gold);
  border-radius: var(--r2);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.drop-footer-text { font-size: 12.5px; color: var(--text-grey); font-weight: 500; }
.drop-footer-text strong { display: block; color: var(--text-white); font-size: 13px; margin-bottom: 2px; }
.drop-footer-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: var(--gold-grad-btn);
  color: var(--black-bg);
  padding: 9px 18px;
  border-radius: var(--r2);
  font-size: 11.5px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  white-space: nowrap;
  transition: all .2s;
  flex-shrink: 0;
}
.drop-footer-btn:hover { opacity: .88; transform: translateY(-1px); }
.drop-footer-btn i { font-size: 11px; }

/* ══════════════════════════════════════
   MOBILE ACCORDION SUBMENU
══════════════════════════════════════ */

/* Mobile: parent link row with toggle */
.mobile-nav-links li.has-mobile-sub > a {
  justify-content: space-between;
}
.mob-sub-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: rgba(212,175,55,.1);
  border: 1px solid var(--border-gold);
  color: var(--gold-primary);
  font-size: 10px;
  transition: all .3s;
  flex-shrink: 0;
  cursor: pointer;
}
.mobile-nav-links li.has-mobile-sub.open .mob-sub-toggle {
  transform: rotate(180deg);
  background: var(--gold-grad-btn);
  color: var(--black-bg);
  border-color: transparent;
}

/* Mobile submenu list */
.mobile-sub {
  list-style: none;
  max-height: 0;
  overflow: hidden;
  transition: max-height .38s cubic-bezier(.77,0,.18,1);
  padding-left: 16px;
  margin-top: 5px;
  margin-bottom:20px;
}
.mobile-nav-links li.has-mobile-sub.open .mobile-sub {
  max-height: 600px;
}
.mobile-sub li a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: var(--r2);
  font-size: 12.5px;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--text-grey2);
  transition: all .2s;
  text-decoration: none;
  margin-bottom: 2px;
  border-left: 2px solid var(--border-gold);
}
.mobile-sub li a i { font-size: 13px; color: var(--gold-primary); width: 16px; text-align: center; flex-shrink: 0; }
.mobile-sub li a:hover { color: var(--gold-primary); background: rgba(212,175,55,.06); border-left-color: var(--gold-primary); }