/* ============================================
   PEARL TRAVELS — Home & component styles
============================================ */

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:linear-gradient(135deg,#0c254d 0%,#13335f 55%,#1a4170 100%)}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg .blob{position:absolute;border-radius:50%;filter:blur(90px);opacity:.5}
.hero-bg .b1{width:620px;height:620px;background:rgba(85,165,237,.4);top:-160px;right:-120px;animation:drift 16s var(--ease) infinite alternate}
.hero-bg .b2{width:460px;height:460px;background:rgba(254,174,76,.28);bottom:-140px;left:-100px;animation:drift 13s var(--ease) infinite alternate-reverse}
.hero-bg .b3{width:300px;height:300px;background:rgba(248,109,85,.22);top:40%;left:42%;animation:drift 19s var(--ease) infinite}
@keyframes drift{from{transform:translate(0,0) scale(1)}to{transform:translate(48px,34px) scale(1.12)}}
.hero-grid{position:absolute;inset:0;z-index:1;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:58px 58px}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;width:100%;padding:130px 0 90px}
.hero-badge{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:100px;padding:8px 18px;font-size:13px;font-weight:600;color:#dce8f6;margin-bottom:26px;animation:fadeUp .8s var(--ease) both}
.hero-badge .dot{width:8px;height:8px;border-radius:50%;background:var(--sunset);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}
.hero h1{font-size:clamp(44px,5.4vw,76px);color:#fff;margin-bottom:18px;animation:fadeUp .8s .1s var(--ease) both}
.hero h1 em{font-style:italic;color:var(--sunset)}
.hero h1 .line2{color:#bcd3ec}
.hero-sub{font-size:18px;color:#c2d3e8;max-width:500px;margin-bottom:34px;line-height:1.7;animation:fadeUp .8s .2s var(--ease) both}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;animation:fadeUp .8s .3s var(--ease) both}
.hero-trust{display:flex;gap:22px;margin-top:36px;flex-wrap:wrap;animation:fadeUp .8s .4s var(--ease) both}
.hero-trust .item{display:flex;align-items:center;gap:8px;font-size:13px;color:#9fb6d2}
.hero-trust .item b{color:#fff;font-weight:700}

/* hero visual collage */
.hero-visual{position:relative;height:520px;animation:fadeUp 1s .3s var(--ease) both}
.hv-card{position:absolute;border-radius:20px;overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,.4);border:3px solid rgba(255,255,255,.1)}
.hv-1{width:60%;height:62%;top:0;right:0;z-index:2}
.hv-2{width:50%;height:46%;bottom:0;left:0;z-index:3}
.hv-3{width:38%;height:34%;top:36%;right:8%;z-index:4}
.hv-card img{width:100%;height:100%;object-fit:cover}
.hv-badge{position:absolute;z-index:5;background:#fff;border-radius:14px;padding:14px 18px;box-shadow:var(--shadow);display:flex;align-items:center;gap:12px;bottom:14%;right:-2%}
.hv-badge .ic{width:42px;height:42px;border-radius:10px;background:var(--sunset);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.hv-badge .t{font-size:11px;color:var(--text-muted);font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.hv-badge .n{font-family:var(--serif);font-size:18px;font-weight:600;color:var(--navy);line-height:1.1}

/* ---------- trust strip ---------- */
.trust-strip{background:var(--navy);padding:22px 0;border-top:1px solid rgba(255,255,255,.08)}
.trust-strip .wrap{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.trust-strip .ts{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:600;color:#bcd0e8}
.trust-strip .ts span{font-size:20px}
.trust-strip .ts b{color:var(--sunset);font-weight:700}

/* ---------- stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat{text-align:center;padding:30px 18px;background:var(--paper);border-radius:var(--r);border:1px solid var(--line);transition:all .3s var(--ease)}
.stat:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--bright)}
.stat .num{font-family:var(--serif);font-size:46px;font-weight:600;color:var(--navy);line-height:1}
.stat .num em{color:var(--sunset);font-style:normal}
.stat .lbl{font-size:13px;font-weight:600;color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase;margin-top:8px}

/* ---------- about ---------- */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.about-visual{position:relative}
.about-visual .main-img{border-radius:22px;overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/5}
.about-visual .main-img img{width:100%;height:100%;object-fit:cover}
.about-visual .float-img{position:absolute;bottom:-30px;right:-30px;width:46%;border-radius:16px;overflow:hidden;border:5px solid #fff;box-shadow:var(--shadow);aspect-ratio:1}
.about-visual .float-img img{width:100%;height:100%;object-fit:cover}
.about-visual .exp-badge{position:absolute;top:-24px;left:-24px;background:var(--sunset);color:var(--navy);border-radius:16px;padding:18px 22px;box-shadow:var(--shadow);text-align:center}
.about-visual .exp-badge .n{font-family:var(--serif);font-size:34px;font-weight:700;line-height:1}
.about-visual .exp-badge .t{font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-top:2px}
.about-points{margin-top:28px;display:flex;flex-direction:column;gap:16px}
.about-point{display:flex;gap:15px;align-items:flex-start}
.about-point .ic{width:46px;height:46px;border-radius:11px;background:var(--paper-2);display:flex;align-items:center;justify-content:center;font-size:21px;flex-shrink:0}
.about-point h4{font-family:var(--sans);font-size:15px;font-weight:700;margin-bottom:3px}
.about-point p{font-size:14px;color:var(--text-muted);line-height:1.6}
.cac-note{margin-top:26px;padding:16px 20px;background:rgba(254,174,76,.1);border:1px solid rgba(254,174,76,.3);border-radius:12px;font-size:14px;color:var(--navy);line-height:1.6}
.cac-note b{color:var(--sky)}

/* ---------- mission vision ---------- */
.mv{background:linear-gradient(135deg,#0c254d,#16396a);position:relative;overflow:hidden}
.mv::before{content:'';position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(85,165,237,.25),transparent 70%);top:-200px;right:-100px}
.mv::after{content:'';position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(254,174,76,.15),transparent 70%);bottom:-180px;left:-80px}
.mv .wrap{position:relative;z-index:2}
.mv .eyebrow{color:var(--sunset)}
.mv .h-sec{color:#fff}
.mv-cards{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:44px}
.mv-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:40px 36px;backdrop-filter:blur(10px);transition:all .35s var(--ease)}
.mv-card:hover{transform:translateY(-5px);background:rgba(255,255,255,.09);border-color:rgba(254,174,76,.4)}
.mv-card .ic{width:64px;height:64px;border-radius:16px;background:var(--sunset);display:flex;align-items:center;justify-content:center;font-size:30px;margin-bottom:22px}
.mv-card.vision .ic{background:var(--bright)}
.mv-card h3{font-size:26px;color:#fff;margin-bottom:14px}
.mv-card p{font-size:15.5px;color:#c8d8ec;line-height:1.75}
.values{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:30px}
.value{text-align:center;padding:26px 16px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:14px;transition:all .3s}
.value:hover{background:rgba(255,255,255,.09);transform:translateY(-3px)}
.value .ic{font-size:28px;margin-bottom:10px}
.value h4{font-family:var(--sans);font-size:15px;font-weight:700;color:#fff;margin-bottom:6px}
.value p{font-size:12.5px;color:#a7bdd6;line-height:1.55}

/* ---------- services ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.svc-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:32px 28px;position:relative;overflow:hidden;transition:all .35s var(--ease)}
.svc-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--sky),var(--sunset));transform:scaleY(0);transform-origin:top;transition:transform .35s var(--ease)}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.svc-card:hover::before{transform:scaleY(1)}
.svc-card .top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:18px}
.svc-card .ic{width:56px;height:56px;border-radius:14px;background:var(--paper-2);display:flex;align-items:center;justify-content:center;font-size:26px;transition:all .3s}
.svc-card:hover .ic{background:var(--sunset)}
.svc-card .no{font-family:var(--serif);font-size:42px;font-weight:600;color:var(--paper-2)}
.svc-card h3{font-family:var(--sans);font-size:18px;font-weight:700;margin-bottom:10px}
.svc-card p{font-size:14px;color:var(--text-muted);line-height:1.65}
.svc-card .tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:16px}
.svc-card .tag{font-size:11px;font-weight:600;background:var(--paper);border:1px solid var(--line);border-radius:100px;padding:4px 11px;color:var(--sky)}

/* ---------- fliers gallery ---------- */
.flier-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.flier{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);cursor:pointer;position:relative;background:#fff;border:1px solid var(--line);transition:all .35s var(--ease)}
.flier:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.flier img{width:100%;height:auto;display:block;transition:transform .5s var(--ease)}
.flier:hover img{transform:scale(1.03)}
.flier .ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(12,37,77,.85),transparent 45%);opacity:0;transition:opacity .3s;display:flex;align-items:flex-end;padding:20px}
.flier:hover .ov{opacity:1}
.flier .ov span{color:#fff;font-weight:700;font-size:14px;display:flex;align-items:center;gap:8px}
.flier-cat{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin-bottom:36px}
.flier-cat button{background:#fff;border:1.5px solid var(--line);color:var(--text-muted);font-size:13px;font-weight:600;padding:9px 20px;border-radius:100px;transition:all .25s}
.flier-cat button.on,.flier-cat button:hover{background:var(--navy);border-color:var(--navy);color:#fff}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:1000;background:rgba(10,26,48,.94);display:none;align-items:center;justify-content:center;padding:30px}
.lightbox.open{display:flex}
.lightbox img{max-width:92%;max-height:92vh;border-radius:12px;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.lightbox .close{position:absolute;top:24px;right:30px;width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;font-size:24px;display:flex;align-items:center;justify-content:center;transition:background .2s}
.lightbox .close:hover{background:var(--coral)}
.lightbox .nav-arrow{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;font-size:26px;display:flex;align-items:center;justify-content:center;transition:background .2s}
.lightbox .nav-arrow:hover{background:var(--sunset);color:var(--navy)}
.lightbox .prev{left:24px}
.lightbox .next{right:24px}

/* ---------- destinations ---------- */
.dest-layout{display:grid;grid-template-columns:330px 1fr;gap:54px;align-items:start}
.dest-tabs{display:flex;flex-direction:column;gap:9px;margin-top:30px}
.dest-tab{display:flex;align-items:center;gap:13px;padding:14px 18px;border-radius:12px;font-weight:600;font-size:14px;color:var(--text-muted);background:transparent;border:1px solid transparent;transition:all .25s;text-align:left}
.dest-tab:hover{background:var(--paper);color:var(--navy)}
.dest-tab.on{background:var(--navy);color:#fff;border-color:var(--navy)}
.dest-tab .fl{font-size:18px}
.dest-tab .ct{margin-left:auto;font-size:12px;background:rgba(0,0,0,.06);border-radius:100px;padding:2px 9px}
.dest-tab.on .ct{background:rgba(255,255,255,.2)}
.dest-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(165px,1fr));gap:13px}
.dest-c{display:flex;align-items:center;gap:13px;padding:16px 15px;background:#fff;border:1px solid var(--line);border-radius:13px;transition:all .25s var(--ease)}
.dest-c:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--bright)}
.dest-c .fl{font-size:30px}
.dest-c .nm{font-size:14px;font-weight:700;color:var(--navy)}
.dest-c .ty{font-size:11.5px;color:var(--text-muted);margin-top:1px}

/* ---------- process ---------- */
.proc{background:var(--paper)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative;margin-top:20px}
.step{text-align:center;position:relative;z-index:2}
.step .orb{width:74px;height:74px;border-radius:50%;background:#fff;border:2px solid var(--line);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:28px;font-weight:600;color:var(--sky);margin:0 auto 20px;transition:all .3s var(--ease);box-shadow:0 8px 24px rgba(12,37,77,.06)}
.step:hover .orb{background:var(--navy);border-color:var(--sunset);color:#fff;transform:scale(1.06)}
.step h4{font-family:var(--sans);font-size:15px;font-weight:700;margin-bottom:8px}
.step p{font-size:13.5px;color:var(--text-muted);line-height:1.6}

/* ---------- video ---------- */
.video-band{background:var(--navy);position:relative;overflow:hidden}
.video-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.video-grid .eyebrow{color:var(--sunset)}
.video-grid h2{color:#fff}
.video-grid .lead{color:#c2d3e8}
.video-frame{border-radius:20px;overflow:hidden;box-shadow:var(--shadow-lg);border:3px solid rgba(255,255,255,.1);position:relative;background:#000}
.video-frame video{width:100%;display:block}

/* ---------- payment ---------- */
.pay{background:var(--paper)}
.pay-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:stretch}
.pay-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:40px;box-shadow:var(--shadow)}
.pay-card.fee{background:linear-gradient(135deg,var(--navy),#173e72);color:#fff;border:none;display:flex;flex-direction:column;justify-content:center}
.pay-card.fee .amt{font-family:var(--serif);font-size:62px;font-weight:700;line-height:1;color:var(--sunset)}
.pay-card.fee .amt small{font-size:22px;color:#bcd3ec}
.pay-card.fee h3{color:#fff;font-size:24px;margin-bottom:8px}
.pay-card.fee p{color:#c2d3e8;font-size:15px;line-height:1.7;margin-bottom:22px}
.pay-card.fee .note{font-size:12.5px;color:#9fb6d2;margin-top:18px;line-height:1.6}
.pay-methods h3{font-size:22px;margin-bottom:6px}
.pay-methods>p{font-size:14px;color:var(--text-muted);margin-bottom:24px}
.pay-method{display:flex;align-items:center;gap:16px;padding:18px;border:1px solid var(--line);border-radius:13px;margin-bottom:14px;transition:all .25s}
.pay-method:hover{border-color:var(--bright);box-shadow:var(--shadow)}
.pay-method .ic{width:50px;height:50px;border-radius:12px;background:var(--paper-2);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
.pay-method h4{font-family:var(--sans);font-size:15px;font-weight:700;margin-bottom:2px}
.pay-method p{font-size:13px;color:var(--text-muted)}
.pay-steps{margin-top:8px;padding-left:0;list-style:none;counter-reset:s}
.pay-steps li{counter-increment:s;font-size:14px;color:var(--text-muted);padding:8px 0 8px 38px;position:relative;line-height:1.6}
.pay-steps li::before{content:counter(s);position:absolute;left:0;top:7px;width:26px;height:26px;border-radius:50%;background:var(--sunset);color:var(--navy);font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center;font-family:var(--sans)}

/* ---------- testimonials ---------- */
.tst-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.tst{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px;transition:all .3s var(--ease);position:relative}
.tst:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.tst .quote{font-size:46px;font-family:var(--serif);color:var(--paper-2);line-height:.6;margin-bottom:6px}
.tst .stars{color:var(--sunset);font-size:15px;letter-spacing:2px;margin-bottom:14px}
.tst p{font-size:14.5px;color:#3a4d63;line-height:1.7;font-style:italic;margin-bottom:22px}
.tst .who{display:flex;align-items:center;gap:13px}
.tst .av{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--sky),var(--sunset));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:17px;flex-shrink:0}
.tst .nm{font-family:var(--sans);font-size:15px;font-weight:700;color:var(--navy)}
.tst .loc{font-size:12.5px;color:var(--text-muted);display:flex;align-items:center;gap:5px}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(135deg,var(--sunset),var(--coral));position:relative;overflow:hidden;text-align:center}
.cta-band::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.08) 1px,transparent 1px);background-size:50px 50px}
.cta-band .wrap{position:relative;z-index:2}
.cta-band h2{font-size:clamp(30px,3.6vw,46px);color:var(--navy);margin-bottom:14px}
.cta-band p{font-size:18px;color:#5a3410;max-width:560px;margin:0 auto 30px;font-weight:500}
.cta-band .btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .hero-inner{grid-template-columns:1fr;gap:0;padding:120px 0 70px}
  .hero-visual{display:none}
  .stats{grid-template-columns:1fr 1fr;gap:16px}
  .about-grid{grid-template-columns:1fr;gap:80px}
  .mv-cards{grid-template-columns:1fr}
  .values{grid-template-columns:1fr 1fr}
  .svc-grid{grid-template-columns:1fr 1fr}
  .flier-grid{grid-template-columns:1fr 1fr}
  .dest-layout{grid-template-columns:1fr}
  .dest-tabs{flex-direction:row;flex-wrap:wrap}
  .steps{grid-template-columns:1fr 1fr;gap:30px}
  .video-grid{grid-template-columns:1fr;gap:30px}
  .pay-grid{grid-template-columns:1fr}
  .tst-grid{grid-template-columns:1fr}
  .trust-strip .wrap{justify-content:center;gap:16px}
}
@media(max-width:600px){
  .stats{grid-template-columns:1fr 1fr}
  .svc-grid,.flier-grid{grid-template-columns:1fr}
  .values{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .dest-cards{grid-template-columns:1fr 1fr}
}
