/* ===================================================================
   Discounter Travel — go.discounter.agency
   Faithful rebuild from design mockups. Palette sampled from refs.
   =================================================================== */
:root{
  /* deep navy hero (sampled #00102f → #0c3a82) */
  --navy-1:#00102f; --navy-2:#062a6e; --navy-3:#0c3a82;
  --blue:#2f6fe0; --blue-2:#3d8bff; --cyan:#21c7d6;
  /* vivid orange (sampled #fb6300 / #fa6302) */
  --orange:#fb6a05; --orange-2:#ff8c2e; --orange-d:#ef5c00;
  --ink:#0f2444; --ink-2:#22365c; --muted:#5a6b85; --muted-2:#8a98ad;
  --line:#e6edf6; --bg:#eef2f9; --bg-2:#f6f9fd; --card:#ffffff;
  --green:#16b187; --purple:#7b61ff; --pink:#ff5c8a;
  --radius:22px; --radius-sm:14px;
  --shadow:0 16px 44px rgba(13,40,84,.10); --shadow-sm:0 8px 20px rgba(13,40,84,.07);
  --shadow-lg:0 30px 70px rgba(8,30,70,.20);
  --maxw:1200px;
  --ff:'Onest','Manrope',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--ff);color:var(--ink);background:#fff;line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 26px}
section{position:relative}

h1,h2,h3,h4{line-height:1.08;letter-spacing:-.025em;font-weight:800;color:var(--ink)}
h1{font-size:clamp(36px,5.6vw,64px)}
h2{font-size:clamp(28px,4.2vw,48px)}
h3{font-size:22px}
.lead{font-size:clamp(16px,1.5vw,19px);color:var(--muted);font-weight:500}

.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--orange);background:rgba(251,106,5,.10);border:1px solid rgba(251,106,5,.22);padding:9px 16px;border-radius:100px}
.eyebrow.on-dark{color:#ffc08f;background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.22)}
.eyebrow i{font-size:11px}
.grad-orange{color:var(--orange)}
.u-wave{position:relative;white-space:nowrap;color:var(--orange)}
.u-wave::after{content:'';position:absolute;left:0;right:0;bottom:-4px;height:9px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='10' viewBox='0 0 100 10'%3E%3Cpath d='M0 6 Q 12.5 0 25 6 T 50 6 T 75 6 T 100 6' fill='none' stroke='%23fb6a05' stroke-width='3'/%3E%3C/svg%3E") repeat-x;background-size:auto 9px}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-weight:700;font-size:16px;border:none;cursor:pointer;border-radius:100px;padding:16px 30px;transition:.25s;font-family:inherit;line-height:1;white-space:nowrap}
.btn-orange{background:linear-gradient(135deg,var(--orange) 0%,var(--orange-2) 100%);color:#fff;box-shadow:0 14px 30px rgba(251,106,5,.36)}
.btn-orange:hover{transform:translateY(-2px);box-shadow:0 20px 42px rgba(251,106,5,.48)}
.btn-white{background:#fff;color:var(--ink)}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(0,0,0,.16)}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1.5px solid rgba(255,255,255,.45)}
.btn-ghost:hover{background:rgba(255,255,255,.2)}
.btn-lg{padding:18px 38px;font-size:17px}

/* ===================== HEADER ===================== */
.header{position:fixed;top:0;left:0;right:0;z-index:100;transition:.3s;padding:18px 0}
.header .container{display:flex;align-items:center;gap:26px}
.logo{display:flex;align-items:center;gap:12px;text-decoration:none;position:relative}
.logo .lm{height:42px;width:auto;display:block;transition:filter .3s,transform .3s}
.header:not(.scrolled) .logo .lm{filter:drop-shadow(0 0 16px rgba(130,185,255,.45)) drop-shadow(0 6px 12px rgba(0,0,0,.28))}
.logo .lm-light{display:none}
.logo-wm{display:flex;align-items:baseline;font-size:20px;letter-spacing:-.025em;line-height:1;font-weight:800}
.logo-wm .w1{color:#fff;transition:color .3s}
.logo-wm .w2{color:var(--orange);text-shadow:0 0 18px rgba(251,106,5,.35)}
.logo-wm .w3{color:rgba(255,255,255,.62);font-weight:600;font-size:14px;letter-spacing:.01em;transition:color .3s}
/* hide ".agency" suffix on laptops so the logo never crowds the nav */
@media(max-width:1440px){.logo-wm .w3{display:none}}
.header.scrolled .logo .lm-dark{display:none}
.header.scrolled .logo .lm-light{display:block}
.header.scrolled .logo .lm{filter:none}
.header.scrolled .logo-wm .w1{color:var(--ink)}
.header.scrolled .logo-wm .w3{color:var(--muted)}
.nav-menu{display:flex;align-items:center;gap:18px;margin-left:6px}
.nav-menu a{font-size:14px;font-weight:600;color:rgba(255,255,255,.82);transition:.2s;position:relative;white-space:nowrap}
.nav-menu a:hover,.nav-menu a.active{color:#fff}
.nav-menu a.active::after{content:'';position:absolute;left:0;right:0;bottom:-7px;height:2px;background:var(--orange);border-radius:2px}
.header-right{margin-left:auto;display:flex;align-items:center;gap:14px}
.lang{display:flex;gap:2px;background:rgba(255,255,255,.14);border-radius:100px;padding:3px}
.lang button{border:none;background:transparent;color:rgba(255,255,255,.72);font-weight:700;font-size:13px;padding:6px 11px;border-radius:100px;cursor:pointer;font-family:inherit;transition:.2s}
.lang button.active{background:#fff;color:var(--ink)}
.header .btn-orange{padding:11px 20px;font-size:14px}
.hamburger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:44px;height:44px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);border-radius:12px;cursor:pointer;z-index:120;flex:none;transition:.2s}
.hamburger span{width:20px;height:2.5px;background:#fff;border-radius:2px;transition:.3s}
.header.scrolled .hamburger{background:var(--bg);border-color:var(--line)}
.header.scrolled{background:rgba(255,255,255,.94);backdrop-filter:blur(14px);box-shadow:0 6px 24px rgba(13,40,84,.09);padding:11px 0}
.header.scrolled .logo{color:var(--ink)}
.header.scrolled .nav-menu a{color:var(--ink-2)}
.header.scrolled .nav-menu a:hover,.header.scrolled .nav-menu a.active{color:var(--blue)}
.header.scrolled .lang{background:var(--bg)}
.header.scrolled .lang button{color:var(--muted)}
.header.scrolled .lang button.active{background:var(--blue);color:#fff}
.header.scrolled .hamburger span{background:var(--ink)}

/* ===================== HERO (themed) ===================== */
.hero{position:relative;overflow:hidden;padding:148px 0 64px;color:#fff}
/* home — deep navy + cyan glow */
.hero--home{background:
  radial-gradient(1000px 560px at 8% 0%,rgba(61,139,255,.30),transparent 58%),
  radial-gradient(820px 520px at 96% 8%,rgba(33,199,214,.16),transparent 55%),
  linear-gradient(120deg,var(--navy-1) 0%,var(--navy-2) 48%,var(--navy-3) 100%)}
/* hotels — vivid orange */
.hero--hotels{background:
  radial-gradient(900px 520px at 90% 6%,rgba(255,180,90,.4),transparent 55%),
  linear-gradient(120deg,#e85600 0%,#fb6a05 50%,#ff8326 100%)}
/* flights — royal blue sky */
.hero--flights{background:
  radial-gradient(900px 560px at 88% 4%,rgba(120,180,255,.45),transparent 55%),
  linear-gradient(125deg,#0a2db0 0%,#1b54d6 50%,#2f74ec 100%)}

/* destinations — teal / cyan */
.hero--dest{background:
  radial-gradient(900px 540px at 86% 4%,rgba(80,240,230,.34),transparent 55%),
  radial-gradient(700px 460px at 4% 96%,rgba(30,140,200,.4),transparent 55%),
  linear-gradient(125deg,#053246 0%,#0a6c84 46%,#13a3a0 100%)}
.hero--dest .hero-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(100deg,#075a6e 2%,rgba(10,108,132,.2) 40%,transparent 62%)}
/* how it works — indigo */
.hero--how{background:
  radial-gradient(900px 540px at 86% 4%,rgba(140,150,255,.4),transparent 55%),
  linear-gradient(125deg,#171a5a 0%,#2b2f9e 46%,#4b4fd6 100%)}
.hero--how .hero-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(100deg,#22267e 2%,rgba(43,47,158,.2) 40%,transparent 62%)}
/* cases / reviews — emerald */
.hero--cases{background:
  radial-gradient(900px 540px at 86% 4%,rgba(120,255,200,.34),transparent 55%),
  linear-gradient(125deg,#053b2e 0%,#0a7a52 46%,#16b074 100%)}
.hero--cases .hero-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(100deg,#06614a 2%,rgba(10,122,82,.2) 40%,transparent 62%)}
/* blog — slate navy */
.hero--blog{background:
  radial-gradient(900px 540px at 86% 4%,rgba(90,150,255,.3),transparent 55%),
  linear-gradient(125deg,#0c1830 0%,#1a2b50 50%,#26406e 100%)}
.hero--blog .hero-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(100deg,#14223f 2%,rgba(26,43,80,.2) 40%,transparent 62%)}
/* contacts — coral/orange */
.hero--contacts{background:
  radial-gradient(900px 520px at 90% 6%,rgba(255,180,90,.4),transparent 55%),
  linear-gradient(120deg,#e2491a 0%,#fb6a05 50%,#ff8c2e 100%)}
.hero--contacts .hero-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(100deg,#fb6a05 2%,rgba(251,106,5,.2) 40%,transparent 62%)}
.hero--dest .hero-trust .ht i,.hero--cases .hero-trust .ht i{color:#fff;background:rgba(255,255,255,.18)}

/* tours — violet / magenta */
.hero--tours{background:
  radial-gradient(900px 540px at 86% 4%,rgba(255,150,225,.4),transparent 55%),
  radial-gradient(700px 460px at 4% 96%,rgba(120,80,255,.4),transparent 55%),
  linear-gradient(125deg,#34106a 0%,#6a1fa8 46%,#a52fb6 100%)}
.hero--tours .hero-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(100deg,#5a1796 2%,rgba(106,31,168,.2) 40%,transparent 62%)}
.hero-photo{position:absolute;top:0;right:0;width:47%;height:100%;background-size:cover;background-position:center;
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 32%);mask-image:linear-gradient(90deg,transparent 0,#000 32%)}
.hero--home .hero-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(100deg,var(--navy-2) 2%,rgba(6,42,110,.18) 38%,transparent 60%)}
.hero--hotels .hero-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(100deg,#fb6a05 2%,rgba(251,106,5,.2) 40%,transparent 62%)}
.hero-plane{position:absolute;top:16%;right:18%;font-size:30px;color:rgba(255,255,255,.5);transform:rotate(-18deg);z-index:2}
.hero .container{position:relative;z-index:3}
.hero-top{display:grid;grid-template-columns:1.06fr .94fr;gap:46px;align-items:center}
.hero-copy .eyebrow{margin-bottom:22px}
.hero h1{color:#fff;margin-bottom:20px}
.hero h1 .br{display:block}
.hero-sub{color:rgba(255,255,255,.86);font-size:18px;max-width:48ch;margin-bottom:26px;font-weight:500}
.hero-sub b{color:#fff;font-weight:700}
.hero-tabs{display:flex;flex-wrap:wrap;gap:11px}
.tab{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.11);border:1px solid rgba(255,255,255,.2);color:#fff;font-weight:600;font-size:15px;padding:13px 22px;border-radius:13px;cursor:pointer;transition:.2s}
.tab i{opacity:.9}
.tab:hover{background:rgba(255,255,255,.2)}
.tab.active{background:linear-gradient(135deg,var(--orange),var(--orange-2));border-color:transparent;box-shadow:0 12px 26px rgba(251,106,5,.42)}
.hero-tabs-row2{margin-top:11px}
.hero-cta-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:6px}

/* hero form */
.hero-form{background:#fff;border-radius:22px;padding:28px;box-shadow:var(--shadow-lg);color:var(--ink)}
.hf-head{display:flex;align-items:center;gap:12px;margin-bottom:4px}
.hf-ico{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,var(--blue),var(--blue-2));display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;flex:none}
.hero--hotels .hf-ico,.hero--flights .hf-ico{background:linear-gradient(135deg,var(--orange),var(--orange-2))}
.hero-form h3{font-size:22px}
.hf-note{font-size:13px;color:var(--muted);margin-bottom:18px}
.field{margin-bottom:13px}
.field label{display:block;font-size:12.5px;font-weight:700;color:var(--ink-2);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;border:1.5px solid var(--line);border-radius:12px;padding:13px 14px;font-size:15px;font-family:inherit;color:var(--ink);background:#fff;transition:.2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 4px rgba(47,111,224,.12)}
.field-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.iti{width:100%}
.hero-form .btn{width:100%;margin-top:6px}
.hf-trust{display:flex;align-items:center;gap:10px;margin-top:15px}
.hf-avatars{display:flex}
.hf-avatars span{width:30px;height:30px;border-radius:50%;border:2px solid #fff;margin-left:-9px;background-size:cover;background-position:center}
.hf-avatars span:first-child{margin-left:0}
.hf-trust small{font-size:12px;color:var(--muted);font-weight:600;line-height:1.3}
.hf-trust small b{color:var(--ink);font-size:13px}
.form-message{display:none;margin-top:10px;font-size:14px;font-weight:600;padding:10px 12px;border-radius:10px}
.form-message.success{display:block;background:#e7f8f0;color:#15805c}
.form-message.error{display:block;background:#fdecec;color:#c0392b}

/* hero bottom */
.hero-bottom{margin-top:50px;display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:center}
.hero-stats{display:flex;gap:34px;flex-wrap:wrap}
.hero-stats .hs b{display:block;font-size:34px;font-weight:800;color:#fff;line-height:1}
.hero-stats .hs.c-orange b{color:#ffb066}.hero-stats .hs.c-cyan b{color:#6fe3ed}.hero-stats .hs.c-gold b{color:#ffd479}
.hero-stats .hs span{font-size:12.5px;color:rgba(255,255,255,.65);font-weight:600}
.hero-trust{display:grid;grid-template-columns:1fr 1fr;gap:16px 24px}
.hero-trust .ht{display:flex;align-items:center;gap:11px;color:#fff}
.hero-trust .ht i{width:40px;height:40px;border-radius:11px;background:rgba(255,255,255,.13);display:flex;align-items:center;justify-content:center;font-size:16px;color:#bcdcff;flex:none}
.hero--hotels .hero-trust .ht i{color:#fff;background:rgba(255,255,255,.2)}
.hero-trust .ht b{font-size:14px;font-weight:700;display:block}
.hero-trust .ht small{font-size:12px;color:rgba(255,255,255,.62)}

/* brand strip (flights) */
.brand-strip{margin-top:30px;display:flex;flex-wrap:wrap;align-items:center;gap:10px 26px;opacity:.92}
.brand-strip .bl{font-weight:800;font-size:15px;color:rgba(255,255,255,.85);letter-spacing:.02em}
.hero-chips{margin-top:18px;display:flex;flex-wrap:wrap;gap:8px}
.hero-chips .hc{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:100px;padding:6px 13px;font-size:12.5px;font-weight:700}
.hero-chips .hc b{color:#ffd479}

/* ===================== SECTIONS ===================== */
.sec{padding:86px 0}
.sec-light{background:var(--bg)}
.sec-soft{background:linear-gradient(180deg,#fff,var(--bg-2))}
.sec-white{background:#fff}
.sec-head{text-align:center;max-width:740px;margin:0 auto 46px}
.sec-head .eyebrow{margin-bottom:18px}
.sec-head h2{margin-bottom:14px}
.sec-head p{color:var(--muted);font-size:17px}

/* chips + stat cards */
.uncut{position:relative;overflow:hidden;background:var(--bg)}
.uncut::before{content:'';position:absolute;inset:0;background:url('../img/photo-1436491865332-7a61a109cc05.jpg') center/cover;opacity:.05}
.chips{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:42px;position:relative}
.chip{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:100px;padding:9px 16px;font-size:13.5px;font-weight:700;color:var(--ink-2);box-shadow:var(--shadow-sm)}
.chip i{font-size:13px}.chip .pct{color:var(--orange);font-weight:800}
.chip.c-b i{color:var(--blue)}.chip.c-o i{color:var(--orange)}.chip.c-g i{color:var(--green)}.chip.c-p i{color:var(--purple)}.chip.c-c i{color:var(--cyan)}
.stat-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;position:relative}
.stat-card{background:#fff;border-radius:var(--radius);padding:30px 26px;box-shadow:var(--shadow);transition:.25s}
.stat-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.stat-card .sc-ico{width:54px;height:54px;border-radius:15px;display:flex;align-items:center;justify-content:center;font-size:23px;margin-bottom:20px}
.sc-blue{background:rgba(47,111,224,.12);color:var(--blue)}
.sc-orange{background:rgba(251,106,5,.13);color:var(--orange)}
.sc-green{background:rgba(22,177,135,.13);color:var(--green)}
.sc-purple{background:rgba(123,97,255,.13);color:var(--purple)}
.stat-card b{display:block;font-size:42px;font-weight:800;line-height:1;letter-spacing:-.03em;margin-bottom:8px}
.stat-card.t-blue b{color:var(--blue)}.stat-card.t-orange b{color:var(--orange)}.stat-card.t-green b{color:var(--green)}.stat-card.t-purple b{color:var(--purple)}
.stat-card span{font-size:14px;color:var(--muted);font-weight:600}

/* destinations */
.dest-wrap{display:grid;grid-template-columns:.82fr 1.18fr;gap:48px;align-items:center}
.dest-copy .eyebrow{margin-bottom:18px}
.dest-copy h2{margin-bottom:16px}
.dest-copy p{color:var(--muted);font-size:16px;margin-bottom:24px;max-width:42ch}
.dest-pcts{display:flex;gap:28px;margin-bottom:28px}
.dest-pcts .dp b{display:block;font-size:30px;font-weight:800;color:var(--orange);line-height:1}
.dest-pcts .dp span{font-size:13px;color:var(--muted);font-weight:600}
.dest-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.dest-card{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:1/.8;box-shadow:var(--shadow);transition:.3s}
.dest-card img{width:100%;height:100%;object-fit:cover;transition:.5s}
.dest-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.dest-card:hover img{transform:scale(1.07)}
.dest-card::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(6,24,52,.84) 6%,rgba(6,24,52,.1) 52%,transparent)}
.dest-card .dc-info{position:absolute;left:18px;bottom:16px;right:18px;z-index:2;color:#fff}
.dest-card .dc-info b{font-size:19px;font-weight:800;display:block}
.dest-card .dc-info small{font-size:12.5px;opacity:.86;font-weight:600}
.dest-card .dc-badge{position:absolute;top:14px;right:14px;z-index:2;background:var(--orange);color:#fff;font-size:12px;font-weight:800;padding:6px 12px;border-radius:100px;box-shadow:0 6px 16px rgba(251,106,5,.42)}

/* why / how-we-save */
.why-wrap{display:grid;grid-template-columns:.95fr 1.05fr;gap:54px;align-items:center}
.why-visual{position:relative}
.why-visual .wv-photo{border-radius:24px;overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:1/1.04}
.why-visual .wv-photo img{width:100%;height:100%;object-fit:cover}
.why-badge-tl{position:absolute;top:18px;left:18px;background:var(--blue);color:#fff;border-radius:14px;padding:12px 16px;display:flex;gap:10px;align-items:center;box-shadow:var(--shadow);z-index:2}
.why-badge-tl i{font-size:18px}.why-badge-tl b{font-size:13px;display:block}.why-badge-tl small{font-size:11px;opacity:.85}
.why-card{position:absolute;left:50%;transform:translateX(-50%);bottom:-22px;background:#fff;border-radius:16px;padding:14px 26px;box-shadow:var(--shadow-lg);text-align:center;z-index:2}
.why-card .lbl{font-size:10px;font-weight:800;letter-spacing:.12em;color:var(--muted-2);text-transform:uppercase}
.why-card b{font-size:30px;font-weight:800;color:var(--orange);display:block;line-height:1.1}
.why-card span{font-size:12px;color:var(--muted)}
.why-note{position:absolute;top:-12px;right:14px;font-family:'Caveat',cursive;font-size:22px;color:#fff;transform:rotate(-6deg);z-index:3}
.why-side h2{margin-bottom:14px}
.why-list{display:flex;flex-direction:column;gap:13px;margin-top:8px}
.why-item{display:flex;gap:16px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px 20px;transition:.25s;position:relative}
.why-item:hover{box-shadow:var(--shadow);transform:translateX(4px)}
.why-item .wi-ico{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;flex:none}
.wi-1{background:linear-gradient(135deg,#2f6fe0,#3d8bff)}.wi-2{background:linear-gradient(135deg,#16b187,#36d6a3)}
.wi-3{background:linear-gradient(135deg,#7b61ff,#9a7bff)}.wi-4{background:linear-gradient(135deg,#fb6a05,#ff8c2e)}
.why-item h4{font-size:16.5px;margin-bottom:3px}
.why-item p{font-size:13.5px;color:var(--muted);line-height:1.5}
.why-item .wi-num{position:absolute;top:16px;right:18px;font-size:13px;font-weight:800;color:var(--line)}
.why-cta{margin-top:22px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.why-cta small{font-size:13px;color:var(--muted)}

/* steps */
.stepper{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative;margin-bottom:6px}
.stepper::before{content:'';position:absolute;top:27px;left:12%;right:12%;height:3px;background:linear-gradient(90deg,#2f6fe0,#7b61ff,#ff5c8a,#fb6a05);border-radius:3px;opacity:.5}
.step-num{width:56px;height:56px;border-radius:50%;background:#fff;border:3px solid;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;margin:0 auto 22px;position:relative;z-index:2;box-shadow:var(--shadow-sm)}
.s1{border-color:#2f6fe0;color:#2f6fe0}.s2{border-color:#7b61ff;color:#7b61ff}.s3{border-color:#ff5c8a;color:#ff5c8a}.s4{border-color:#fb6a05;color:#fb6a05}
.step-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.step-card{background:#fff;border-radius:var(--radius);padding:26px 22px;box-shadow:var(--shadow);text-align:center;transition:.25s}
.step-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.step-card .stc-ico{width:58px;height:58px;border-radius:16px;background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:24px;margin:0 auto 18px;color:var(--blue)}
.step-card h4{font-size:17px;margin-bottom:8px}
.step-card p{font-size:14px;color:var(--muted);line-height:1.5}
.steps-cta{text-align:center;margin-top:42px}

/* reviews */
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.rev-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:.25s;display:flex;flex-direction:column}
.rev-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.rev-card .rev-body{padding:26px 24px 14px}
.rev-stars{color:#ffb400;font-size:15px;margin-bottom:12px;letter-spacing:2px}
.rev-quote{font-size:15px;color:var(--ink-2);line-height:1.6;margin-bottom:18px}
.rev-quote .qm{color:var(--orange);font-size:28px;font-weight:800;line-height:0;vertical-align:-6px;margin-right:4px}
.rev-person{display:flex;align-items:center;gap:12px}
.rev-person .av{width:44px;height:44px;border-radius:50%;background-size:cover;background-position:center;flex:none}
.rev-person b{font-size:15px;display:block}.rev-person small{font-size:12.5px;color:var(--muted)}
.rev-card .rev-photo{height:120px;background-size:cover;background-position:center;margin-top:auto}

/* faq */
.faq-sec{background:linear-gradient(125deg,var(--navy-1),var(--navy-2) 60%,var(--navy-3));color:#fff;overflow:hidden}
.faq-sec .eyebrow{background:rgba(255,255,255,.1);color:#bcdcff;border-color:rgba(255,255,255,.2)}
.faq-sec .sec-head h2{color:#fff}.faq-sec .sec-head p{color:rgba(255,255,255,.7)}
.faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq-item{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:16px;overflow:hidden;transition:.25s}
.faq-item.open{background:rgba(255,255,255,.12)}
.faq-q{display:flex;align-items:center;gap:14px;padding:20px 22px;cursor:pointer;font-weight:700;font-size:16.5px}
.faq-q .qi{width:38px;height:38px;border-radius:11px;background:rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;color:#8fd0ff;flex:none}
.faq-q .qx{margin-left:auto;font-size:18px;transition:.3s;color:rgba(255,255,255,.6)}
.faq-item.open .qx{transform:rotate(45deg);color:var(--orange)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-a div{padding:0 22px 20px 74px;color:rgba(255,255,255,.78);font-size:15px;line-height:1.6}

/* ===================== COMPARISON TABLE (flights) ===================== */
.cmp-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-bottom:36px}
.cmp-chip{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:100px;padding:11px 20px;font-size:14px;font-weight:700;color:var(--ink-2);box-shadow:var(--shadow-sm)}
.cmp-chip i{font-size:14px}.cmp-chip.c-b i{color:var(--blue)}.cmp-chip.c-o i{color:var(--orange)}.cmp-chip.c-p i{color:var(--purple)}.cmp-chip.c-gold i{color:#ffb400}
.cmp-table{background:#fff;border-radius:24px;box-shadow:var(--shadow-lg);overflow:hidden;max-width:980px;margin:0 auto}
.cmp-row{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;align-items:center;padding:16px 26px;border-bottom:1px solid var(--line)}
.cmp-row:last-child{border-bottom:none}
.cmp-head{background:linear-gradient(120deg,var(--navy-1),var(--navy-2));color:#fff;font-weight:700;font-size:13px;letter-spacing:.04em;text-transform:uppercase}
.cmp-head>span:first-child{display:flex;align-items:center;gap:10px}
.cmp-head .ci{width:32px;height:32px;border-radius:9px;background:rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;color:#8fd0ff}
.cmp-route{display:flex;align-items:center;gap:14px}
.cmp-route .rt-img{width:64px;height:46px;border-radius:10px;background-size:cover;background-position:center;flex:none;box-shadow:var(--shadow-sm)}
.cmp-route b{font-size:15px;display:block}.cmp-route .cls{font-size:11px;font-weight:700;color:var(--purple);background:rgba(123,97,255,.1);padding:2px 8px;border-radius:6px;display:inline-block;margin-top:3px}
.cmp-old{color:var(--muted-2);text-decoration:line-through;font-weight:600;font-size:15px}
.cmp-new{color:var(--green);font-weight:800;font-size:18px}
.cmp-save{justify-self:start}
.cmp-save span{background:rgba(22,177,135,.12);color:var(--green);font-weight:800;font-size:14px;padding:6px 12px;border-radius:100px}
.cmp-note{text-align:center;margin-top:22px;font-size:13px;color:var(--muted)}
.cmp-note b{color:var(--ink)}

/* ===================== PREMIUM POLISH (depth, glow) ===================== */
.sec-light,.sec-soft{position:relative;overflow:hidden}
.sec-light::after{content:'';position:absolute;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(47,111,224,.07),transparent 70%);top:-160px;right:-120px;pointer-events:none}
.sec-soft::after{content:'';position:absolute;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(251,106,5,.06),transparent 70%);bottom:-200px;left:-140px;pointer-events:none}
.hero::after{content:'';position:absolute;left:-6%;bottom:-30%;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.08),transparent 70%);pointer-events:none;z-index:1}
.stat-card,.step-card,.rev-card,.dest-card{position:relative}
.btn-orange{position:relative;overflow:hidden}
.btn-orange::after{content:'';position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(110deg,transparent,rgba(255,255,255,.45),transparent);transform:skewX(-18deg);transition:.6s}
.btn-orange:hover::after{left:140%}

/* orange CTA */
.cta-band{background:linear-gradient(120deg,var(--orange-d) 0%,var(--orange) 55%,var(--orange-2) 100%);overflow:hidden;position:relative}
.cta-band::before{content:'';position:absolute;top:-40%;right:-5%;width:420px;height:420px;border-radius:50%;background:rgba(255,255,255,.1)}
.cta-band::after{content:'';position:absolute;bottom:-50%;left:-8%;width:360px;height:360px;border-radius:50%;background:rgba(255,255,255,.08)}
.cta-wrap{display:grid;grid-template-columns:1.2fr .8fr;gap:40px;align-items:center;padding:62px 0;position:relative;z-index:2}
.cta-wrap .eyebrow{background:rgba(255,255,255,.18);color:#fff;border-color:rgba(255,255,255,.3);margin-bottom:20px}
.cta-wrap h2{color:#fff;margin-bottom:16px}
.cta-wrap .u-wave{color:#fff}.cta-wrap .u-wave::after{filter:brightness(0) invert(1)}
.cta-wrap p{color:rgba(255,255,255,.94);font-size:17px;margin-bottom:26px;max-width:46ch;font-weight:500}
.cta-calc{justify-self:center;width:230px;height:230px;border-radius:32px;background:linear-gradient(160deg,#fff,#ffeede);box-shadow:var(--shadow-lg);position:relative;display:flex;align-items:center;justify-content:center;transform:rotate(6deg)}
.cta-calc .cc-screen{font-size:34px;font-weight:800;color:var(--ink)}
.cta-calc .cc-badge{position:absolute;top:-18px;left:-18px;background:var(--blue);color:#fff;font-weight:800;font-size:20px;width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 28px rgba(15,47,92,.35);transform:rotate(-6deg)}
.cta-calc .cc-coin{position:absolute;bottom:-16px;right:-12px;width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,#ffd479,#ffb347);display:flex;align-items:center;justify-content:center;font-weight:800;color:#7a4a00;font-size:22px;box-shadow:0 10px 24px rgba(0,0,0,.18)}

/* ===================== FOOTER (dark, 3 cols) ===================== */
.footer{background:linear-gradient(180deg,#03152a,#020e1d);color:#fff;padding:70px 0 30px;position:relative;overflow:hidden}
.footer::before{content:'\f072';font-family:'Font Awesome 6 Free';font-weight:900;position:absolute;top:30px;right:6%;font-size:120px;color:rgba(255,255,255,.03);transform:rotate(-18deg)}
.footer-main{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.1fr;gap:34px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer .logo{margin-bottom:16px}
.footer-brand p{font-size:14px;opacity:.66;max-width:32ch;margin-bottom:20px;line-height:1.6}
.footer-social{display:flex;gap:10px}
.footer-social a{width:40px;height:40px;border-radius:11px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;font-size:16px;transition:.2s}
.footer-social a:hover{background:var(--orange);transform:translateY(-3px)}
.footer-col h4{font-size:13px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:18px;color:var(--blue-2)}
.footer-links{display:flex;flex-direction:column;gap:13px}
.footer-links a{font-size:14px;opacity:.74;transition:.2s;display:flex;align-items:center;gap:10px}
.footer-links a i{font-size:13px;opacity:.6;width:16px}
.footer-links a:hover{opacity:1;color:var(--orange-2)}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;padding-top:24px;font-size:13px;opacity:.6}
.footer-bottom .heart{color:var(--pink)}
.footer-bottom a{color:var(--blue-2)}

/* fab / modal / marquee / progress */
.dt-fab{position:fixed;right:22px;bottom:24px;z-index:90;display:flex;flex-direction:column;gap:12px}
.dt-fab a{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;box-shadow:0 10px 26px rgba(0,0,0,.24);transition:.25s;position:relative}
.dt-fab .dt-tg{background:#2aabee}.dt-fab .dt-wa{background:#25d366}
.dt-fab a:hover{transform:scale(1.08)}
.dt-tip{position:absolute;right:64px;top:50%;transform:translateY(-50%);white-space:nowrap;background:#fff;color:var(--ink);font-size:13px;font-weight:700;padding:8px 14px;border-radius:10px;box-shadow:var(--shadow-sm);opacity:0;pointer-events:none;transition:.2s}
.dt-fab a:hover .dt-tip{opacity:1;right:68px}
.modal-overlay{position:fixed;inset:0;background:rgba(6,20,44,.55);backdrop-filter:blur(5px);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:.3s}
.modal-overlay.open{opacity:1;visibility:visible}
.modal{background:#fff;border-radius:22px;padding:34px;max-width:440px;width:100%;position:relative;max-height:92vh;overflow:auto;transform:translateY(18px);transition:.3s}
.modal-overlay.open .modal{transform:none}
.modal-close{position:absolute;top:16px;right:18px;background:var(--bg);border:none;width:34px;height:34px;border-radius:50%;font-size:20px;cursor:pointer;color:var(--muted)}
.messenger-choice{margin-top:6px}.messenger-choice-label{font-size:13px;font-weight:700;color:var(--ink-2);display:block;margin-bottom:8px}
.messenger-options{display:flex;gap:10px}.messenger-option{flex:1}.messenger-option input{display:none}
.messenger-option label{display:flex;align-items:center;justify-content:center;gap:8px;border:1.5px solid var(--line);border-radius:12px;padding:12px;font-size:14px;font-weight:700;cursor:pointer;transition:.2s}
.messenger-tg input:checked+label{border-color:#2aabee;background:rgba(42,171,238,.08);color:#2aabee}
.messenger-wa input:checked+label{border-color:#25d366;background:rgba(37,211,102,.08);color:#1faa52}
.form-privacy{font-size:12px;color:var(--muted-2);text-align:center;margin-top:12px}
.dt-marquee-wrap{background:var(--navy-1);overflow:hidden;padding:13px 0}
.dt-marquee{overflow:hidden;white-space:nowrap}
.dt-marquee-track{display:inline-flex;align-items:center;animation:marq 38s linear infinite}
.dt-marquee-track>span{display:inline-flex;align-items:center;color:rgba(255,255,255,.9);font-weight:700;font-size:14px;padding:0 4px}
.dt-marquee-track .lead{color:#ffb877;margin-right:8px}.dt-marquee-track .brand{color:#fff;opacity:.92}
.dt-marquee-track .dot{width:5px;height:5px;border-radius:50%;background:var(--orange);margin:0 16px;flex:none}
.dt-marquee-track b{color:var(--orange-2);margin-right:5px}
@keyframes marq{to{transform:translateX(-50%)}}
#dt-progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--orange),var(--orange-2));z-index:300;transition:width .1s}
#dt-top{position:fixed;right:22px;bottom:90px;width:46px;height:46px;border-radius:50%;background:var(--blue);color:#fff;border:none;font-size:20px;cursor:pointer;opacity:0;visibility:hidden;transition:.3s;z-index:90;box-shadow:var(--shadow)}
#dt-top.show{opacity:1;visibility:visible}
.animate{opacity:0;transform:translateY(26px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.animate.visible{opacity:1;transform:none}

/* ===================== MOTION + DECOR ===================== */
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-18px)}}
@keyframes floatY2{0%,100%{transform:translateY(0) rotate(-6deg)}50%{transform:translateY(-22px) rotate(-6deg)}}
@keyframes kenburns{0%{transform:scale(1)}100%{transform:scale(1.1)}}
@keyframes spinSlow{to{transform:rotate(360deg)}}
@keyframes pulseGlow{0%,100%{opacity:.5}50%{opacity:1}}
@keyframes shimmerLogo{0%{transform:translateX(-120%) skewX(-18deg)}60%,100%{transform:translateX(260%) skewX(-18deg)}}
@media(prefers-reduced-motion:no-preference){
  .hero-photo{animation:kenburns 20s ease-in-out infinite alternate}
}
.hero-deco{position:absolute;inset:0;z-index:2;pointer-events:none;overflow:hidden}
.hero-deco .d{position:absolute;display:flex;align-items:center;justify-content:center;border-radius:18px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(6px);
  color:#fff;box-shadow:0 18px 40px rgba(0,0,0,.18);animation:floatY 7s ease-in-out infinite}
.hero-deco .d.r{border-radius:50%}
.hero-deco .d i{font-size:20px;opacity:.92}
.hero-deco .d.big{width:74px;height:74px}.hero-deco .d.big i{font-size:28px}
.hero-deco .d.sm{width:46px;height:46px}.hero-deco .d.sm i{font-size:16px}
.hero-deco .d.glow{background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.35),rgba(255,255,255,.06));border:none}
.hero-deco .ring{position:absolute;border:1.5px dashed rgba(255,255,255,.22);border-radius:50%;animation:spinSlow 60s linear infinite}
/* logo shine */
.logo .lm{position:relative}
.logo:hover .lm{animation:floatY 2.4s ease-in-out infinite}
/* card hover micro */
.stat-card,.step-card,.rev-card,.why-item,.dest-card,.blog-card,.case-card,.contact-card{will-change:transform}
/* reveal stagger helpers */
.animate.d1{transition-delay:.08s}.animate.d2{transition-delay:.16s}.animate.d3{transition-delay:.24s}.animate.d4{transition-delay:.32s}

/* ===================== PAGE: DESTINATIONS (big grid) ===================== */
.dest-grid-lg{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.dest-grid-lg .dest-card{aspect-ratio:1/1.12}
.dest-grid-lg .dest-card.wide{grid-column:span 2;aspect-ratio:auto}
.region-tabs{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:36px}
.region-tabs button{border:1px solid var(--line);background:#fff;color:var(--ink-2);font-weight:700;font-size:14px;padding:11px 20px;border-radius:100px;cursor:pointer;font-family:inherit;transition:.2s;box-shadow:var(--shadow-sm)}
.region-tabs button.active,.region-tabs button:hover{background:var(--blue);color:#fff;border-color:transparent}

/* ===================== PAGE: HOW IT WORKS (timeline) ===================== */
.hiw-time{max-width:860px;margin:0 auto;position:relative}
.hiw-time::before{content:'';position:absolute;left:31px;top:10px;bottom:10px;width:2px;background:linear-gradient(180deg,var(--blue),var(--purple),var(--pink),var(--orange))}
.hiw-step{display:flex;gap:26px;align-items:flex-start;padding:0 0 38px;position:relative}
.hiw-step .hn{width:64px;height:64px;border-radius:50%;background:#fff;border:3px solid var(--blue);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:800;color:var(--blue);flex:none;z-index:2;box-shadow:var(--shadow)}
.hiw-step:nth-child(2) .hn{border-color:var(--purple);color:var(--purple)}
.hiw-step:nth-child(3) .hn{border-color:var(--pink);color:var(--pink)}
.hiw-step:nth-child(4) .hn{border-color:var(--orange);color:var(--orange)}
.hiw-step .hc{background:#fff;border:1px solid var(--line);border-radius:18px;padding:22px 24px;box-shadow:var(--shadow);flex:1}
.hiw-step .hc h4{font-size:19px;margin-bottom:6px}.hiw-step .hc p{color:var(--muted);font-size:15px}

/* ===================== PAGE: CASES (before/after) ===================== */
.case-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.case-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:.25s;display:flex;flex-direction:column}
.case-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.case-card .cc-img{height:180px;background-size:cover;background-position:center;position:relative}
.case-card .cc-img .cc-flag{position:absolute;top:14px;left:14px;background:rgba(8,24,52,.7);backdrop-filter:blur(6px);color:#fff;font-size:12px;font-weight:700;padding:7px 13px;border-radius:100px}
.case-card .cc-img .cc-save{position:absolute;bottom:-16px;right:18px;background:var(--green);color:#fff;font-weight:800;font-size:18px;width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 26px rgba(22,177,135,.4)}
.case-card .cc-body{padding:24px}
.case-card .cc-body h4{font-size:18px;margin-bottom:14px}
.case-prices{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.case-prices .was{color:var(--muted-2);text-decoration:line-through;font-weight:700;font-size:17px}
.case-prices .arr{color:var(--muted-2)}
.case-prices .now{color:var(--green);font-weight:800;font-size:24px}
.case-card .cc-quote{font-size:14px;color:var(--muted);line-height:1.6;border-top:1px solid var(--line);padding-top:14px}

/* ===================== PAGE: BLOG ===================== */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.blog-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:.25s;display:flex;flex-direction:column}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.blog-card .bc-img{display:block;height:200px;background-size:cover;background-position:center;transition:.5s}
.blog-card h4 a{color:inherit;text-decoration:none}
.blog-card h4 a:hover{color:var(--blue)}
.blog-card:hover .bc-img{transform:scale(1.06)}
.blog-card .bc-body{padding:24px;flex:1;display:flex;flex-direction:column}
.blog-card .bc-tag{align-self:flex-start;background:rgba(47,111,224,.1);color:var(--blue);font-size:12px;font-weight:800;padding:5px 12px;border-radius:100px;margin-bottom:14px}
.blog-card h4{font-size:19px;margin-bottom:10px;line-height:1.25}
.blog-card p{font-size:14px;color:var(--muted);line-height:1.6;margin-bottom:16px;flex:1}
.blog-card .bc-meta{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted-2);font-weight:600}
.blog-card .bc-meta .rd{color:var(--blue);font-weight:700;margin-left:auto;text-decoration:none}
/* ---- blog article ---- */
.hero--article{min-height:auto;padding-bottom:54px}
.hero--article .article-head{max-width:820px}
.crumbs{display:flex;flex-wrap:wrap;align-items:center;gap:9px;font-size:13px;font-weight:600;margin-bottom:22px}
.crumbs a{color:rgba(255,255,255,.78);text-decoration:none}
.crumbs a:hover{color:#fff}
.crumbs span{color:rgba(255,255,255,.4)}
.crumbs .crumb-now{color:#fff}
.article-head h1{font-size:clamp(30px,4.4vw,50px);line-height:1.1;margin:14px 0 18px}
.article-meta{display:flex;flex-wrap:wrap;gap:22px;color:rgba(255,255,255,.85);font-size:14px;font-weight:600}
.article-meta i{margin-right:6px;opacity:.85}
.article-body{max-width:760px;margin:0 auto;font-size:18px;line-height:1.78;color:#243049}
.article-body p{margin:0 0 22px}
.article-body p:first-of-type{font-size:21px;line-height:1.7;color:#1a2336;font-weight:500}
.article-cta{margin-top:42px;background:linear-gradient(135deg,#fff7f0,#ffeede);border:1px solid rgba(251,106,5,.2);border-radius:var(--radius);padding:30px 32px;display:flex;align-items:center;justify-content:space-between;gap:26px;flex-wrap:wrap}
.article-cta .ac-text h3{font-size:22px;margin-bottom:6px}
.article-cta .ac-text p{font-size:15px;color:var(--muted);margin:0;line-height:1.55}
@media(max-width:640px){.article-body{font-size:17px}.article-cta{padding:24px}.article-cta .btn{width:100%;justify-content:center}}

/* ===================== PAGE: CONTACTS ===================== */
.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.contact-cards{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px;box-shadow:var(--shadow-sm);transition:.25s;text-align:center}
.contact-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.contact-card .ci{width:58px;height:58px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:24px;margin:0 auto 16px;color:#fff}
.contact-card.tg .ci{background:#2aabee}.contact-card.wa .ci{background:#25d366}.contact-card.em .ci{background:linear-gradient(135deg,var(--blue),var(--blue-2))}.contact-card.tm .ci{background:linear-gradient(135deg,var(--orange),var(--orange-2))}
.contact-card h4{font-size:17px;margin-bottom:6px}.contact-card p{font-size:14px;color:var(--muted)}
.contact-card a{color:var(--blue);font-weight:700;font-size:15px}
.contact-form{background:#fff;border-radius:var(--radius);padding:34px;box-shadow:var(--shadow)}
.contact-form h3{font-size:24px;margin-bottom:8px}

/* ===================== RESPONSIVE ===================== */
@media(max-width:1200px){
  .nav-menu,.header-right .lang{display:none}
  .hamburger{display:flex}
  .nav-menu.open{display:flex;position:fixed;inset:0;background:var(--navy-1);flex-direction:column;justify-content:center;gap:24px;padding:40px;z-index:110}
  .nav-menu.open a{font-size:22px;color:#fff}
  .logo-wm .w3{display:none}
}
@media(max-width:1040px){
  .hero-top{grid-template-columns:1fr;gap:34px}
  .hero-bottom{grid-template-columns:1fr;gap:28px}
  .dest-wrap,.why-wrap{grid-template-columns:1fr;gap:40px}
  .why-card{position:static;transform:none;display:inline-block;margin-top:14px}
  .cta-wrap{grid-template-columns:1fr;text-align:center}.cta-wrap .eyebrow,.cta-wrap p{margin-inline:auto}
  .rev-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .stat-cards{grid-template-columns:1fr 1fr;gap:16px}
  .stepper,.step-cards{grid-template-columns:1fr 1fr;gap:16px}.stepper::before{display:none}
  .rev-grid{grid-template-columns:1fr}
  .footer-main{grid-template-columns:1fr 1fr}
  .hero-photo{width:100%;opacity:.22}
  .hero--hotels .hero-photo,.hero--home .hero-photo{opacity:.3}
}
@media(max-width:560px){
  .container{padding:0 18px}
  .hero{padding:116px 0 50px}
  .stat-cards,.dest-grid,.step-cards{grid-template-columns:1fr}
  .hero-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:18px 20px}
  .hero-stats .hs b{font-size:28px}
  .hero-trust{grid-template-columns:1fr;gap:14px}
  .stat-card b{font-size:36px}
  .footer-main{grid-template-columns:1fr}.hero-form{padding:22px}
  .field-2{grid-template-columns:1fr}
  .logo-wm{font-size:18px}.logo .lm{height:36px}
  .header .btn-orange{display:none}
  .header-right{gap:8px}
  .contact-cards{grid-template-columns:1fr!important}
  .cta-calc{width:188px;height:188px}.cta-calc .cc-screen{font-size:30px}
  h1{font-size:33px}
  .hero-cta-row .btn{width:100%}
}
/* new page grids responsive */
@media(max-width:1040px){
  .dest-grid-lg{grid-template-columns:repeat(2,1fr)}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
  .contact-wrap{grid-template-columns:1fr;gap:34px}
  .cmp-row{grid-template-columns:1.8fr 1fr 1fr .9fr;padding:14px 18px}
  .hero-deco{display:none}
}
@media(max-width:760px){
  .dest-grid-lg,.case-grid,.blog-grid,.contact-cards{grid-template-columns:1fr}
  .dest-grid-lg .dest-card.wide{grid-column:span 1}
  .cmp-route .rt-img{width:46px;height:34px}
  .cmp-row{font-size:13px}.cmp-new{font-size:15px}
  .cmp-head{font-size:11px}
}
