
/* ── Homepage overrides (CP10.17 Booking-aligned redesign) ─────────────── */
body.kgl-home main{max-width:100%;padding:0}
/* Homepage header uses the same full-bleed kgl-hdr as everywhere else */

/* ── Hero (CP10.40 — deep-space serif redesign 2026-05-29) ─────────────── */
.kgl-hero{position:relative;overflow:hidden;
  background:radial-gradient(ellipse 90% 70% at 50% 30%,#0A2C5C 0%,#051A3A 55%,#020A1F 100%);
  color:#fff;padding:36px 24px 40px;text-align:center}
/* Layer 1: nebula-like radial gradients */
.kgl-hero::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 70% 50% at 80% 15%,rgba(126,200,255,.18) 0%,transparent 60%),
    radial-gradient(ellipse 60% 50% at 12% 80%,rgba(86,160,255,.10) 0%,transparent 60%),
    radial-gradient(ellipse 40% 30% at 50% 60%,rgba(0,103,224,.18) 0%,transparent 70%)}
/* Layer 2: 2 stylised airplane SVGs flying diagonally */
.kgl-hero::after{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23BAE0FF' stroke-width='0.7' stroke-linecap='round' stroke-linejoin='round'><path d='M17.8 19.2 16 11l3.5-3.5C21 6 21.5 4 21 3c-1-.5-3 0-4.5 1.5L13 8 4.8 6.2c-.5-.1-.9.1-1.1.5l-.3.5c-.2.5-.1 1 .3 1.3L9 12l-2 3H4l-1 1 3 2 2 3 1-1v-3l3-2 3.5 5.3c.3.4.8.5 1.3.3l.5-.2c.4-.3.6-.7.5-1.2z'/></svg>"),
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2390CDFF' stroke-width='0.7' stroke-linecap='round' stroke-linejoin='round'><path d='M17.8 19.2 16 11l3.5-3.5C21 6 21.5 4 21 3c-1-.5-3 0-4.5 1.5L13 8 4.8 6.2c-.5-.1-.9.1-1.1.5l-.3.5c-.2.5-.1 1 .3 1.3L9 12l-2 3H4l-1 1 3 2 2 3 1-1v-3l3-2 3.5 5.3c.3.4.8.5 1.3.3l.5-.2c.4-.3.6-.7.5-1.2z'/></svg>");
  background-size:230px 230px,170px 170px;
  background-position:88% 18%,8% 65%;
  background-repeat:no-repeat,no-repeat;
  opacity:.14}
.kgl-hero > *{position:relative;z-index:1}
.kgl-hero-badge{display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;border-radius:999px;
  background:rgba(16,185,129,.10);border:1px solid rgba(110,231,183,.30);
  color:#A7F3D0;font-size:12.5px;font-weight:600;letter-spacing:.03em;
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);margin-bottom:16px}
.kgl-hero-badge::before{content:"";display:inline-block;width:8px;height:8px;
  border-radius:50%;background:#10B981;
  box-shadow:0 0 0 0 rgba(16,185,129,.6),0 0 12px rgba(16,185,129,.6);
  animation:kgl-hero-pulse 2.2s ease-out infinite}
@keyframes kgl-hero-pulse{
  0%{box-shadow:0 0 0 0 rgba(16,185,129,.6),0 0 12px rgba(16,185,129,.6)}
  70%{box-shadow:0 0 0 10px rgba(16,185,129,0),0 0 12px rgba(16,185,129,.6)}
  100%{box-shadow:0 0 0 0 rgba(16,185,129,0),0 0 12px rgba(16,185,129,.6)}}
/* H1: elegant serif, condensed leading */
.kgl-hero h1{font-family:Georgia,"Times New Roman","Tinos",serif;
  font-size:clamp(30px,4.6vw,52px);font-weight:600;line-height:1.05;
  margin:0 0 14px;color:#fff;letter-spacing:-.02em;max-width:980px;
  margin-left:auto;margin-right:auto;text-shadow:0 2px 20px rgba(0,80,180,.40)}
.kgl-hero h1 span{font-family:Georgia,"Times New Roman","Tinos",serif;
  font-style:italic;font-weight:600;color:#7CC1FF;
  background:linear-gradient(135deg,#BAE0FF 0%,#7CC1FF 60%,#5BA9FF 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text}
.kgl-hero-sub{font-size:clamp(15px,1.8vw,18px);color:#B7CFEA;
  max-width:760px;margin:0 auto 20px;line-height:1.5;font-weight:400}
.kgl-hero-sub b{color:#fff;font-weight:700;font-variant-numeric:tabular-nums;
  font-size:1.08em}
.kgl-hero-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;
  margin:0 auto 26px}
.kgl-hero-btn{display:inline-flex;align-items:center;gap:10px;
  padding:12px 24px;border-radius:999px;text-decoration:none!important;
  font-size:14.5px;font-weight:600;letter-spacing:-.005em;cursor:pointer;
  border:1.5px solid transparent;
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease}
.kgl-hero-btn-primary{background:linear-gradient(135deg,#0067E0 0%,#0050B8 100%)!important;
  color:#fff!important;
  box-shadow:0 10px 30px rgba(0,103,224,.40),inset 0 1px 0 rgba(255,255,255,.15)}
.kgl-hero-btn-primary:hover{transform:translateY(-2px);
  box-shadow:0 14px 40px rgba(0,103,224,.55),inset 0 1px 0 rgba(255,255,255,.20);
  background:linear-gradient(135deg,#0073F5 0%,#005AC9 100%)!important}
.kgl-hero-btn-ghost{background:rgba(255,255,255,.04)!important;color:#fff!important;
  border-color:rgba(124,193,255,.40)!important;
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.kgl-hero-btn-ghost:hover{background:rgba(124,193,255,.10)!important;
  border-color:rgba(124,193,255,.65)!important;transform:translateY(-2px)}
.kgl-hero-btn-arrow{transition:transform .18s ease;display:inline-block;font-size:17px}
.kgl-hero-btn:hover .kgl-hero-btn-arrow{transform:translateX(3px)}
/* Stat cards: vertical layout, large icon tile + big number */
.kgl-hero-stats{display:grid;
  grid-template-columns:repeat(auto-fit,minmax(195px,1fr));
  gap:14px;max-width:980px;margin:0 auto}
.kgl-hero-stat{position:relative;background:rgba(255,255,255,.04);
  border:1px solid rgba(124,193,255,.18);
  border-radius:14px;padding:14px 16px 12px;
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;
  transition:background .18s ease,border-color .18s ease,transform .18s ease,box-shadow .18s ease;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06)}
.kgl-hero-stat:hover{background:rgba(255,255,255,.07);
  border-color:rgba(124,193,255,.40);transform:translateY(-3px);
  box-shadow:0 8px 24px rgba(0,103,224,.25),inset 0 1px 0 rgba(255,255,255,.10)}
.kgl-hero-stat-icon{position:relative;display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;border-radius:12px;flex-shrink:0;
  background:linear-gradient(135deg,rgba(var(--st-rgb,56,189,248),.18) 0%,rgba(var(--st-rgb,56,189,248),.04) 100%);
  border:1px solid rgba(var(--st-rgb,56,189,248),.30);
  box-shadow:0 4px 14px rgba(var(--st-rgb,56,189,248),.25),inset 0 1px 0 rgba(255,255,255,.08)}
.kgl-hero-stat-icon svg{display:block;width:22px;height:22px;
  stroke:rgb(var(--st-rgb,56,189,248))!important;color:rgb(var(--st-rgb,56,189,248))!important;
  stroke-width:2;margin:0;flex-shrink:0}
/* per-stat accent palette — 4 distinct glow colors */
.kgl-hero-stat:nth-child(1) .kgl-hero-stat-icon{--st-rgb:56,189,248}
.kgl-hero-stat:nth-child(2) .kgl-hero-stat-icon{--st-rgb:167,139,250}
.kgl-hero-stat:nth-child(3) .kgl-hero-stat-icon{--st-rgb:52,211,153}
.kgl-hero-stat:nth-child(4) .kgl-hero-stat-icon{--st-rgb:251,191,36}
.kgl-hero-stat b{display:block;font-size:26px;font-weight:800;color:#fff;
  font-variant-numeric:tabular-nums;line-height:1;letter-spacing:-.02em}
.kgl-hero-stat span{display:block;font-size:12px;color:#9CB5D2;font-weight:500;
  letter-spacing:.02em;line-height:1.35;margin-top:0}
/* Mobile: fit header + hero into a single viewport (~640-720px tall) */
@media(max-width:640px){
  .kgl-hero{padding:18px 14px 22px;min-height:0}
  .kgl-hero::after{background-size:160px 160px,110px 110px;
    background-position:90% 8%,5% 70%;opacity:.10}
  .kgl-hero-badge{margin-bottom:12px;padding:5px 12px;font-size:11.5px}
  .kgl-hero h1{font-size:26px;line-height:1.08;margin:0 0 10px;letter-spacing:-.01em}
  .kgl-hero-sub{font-size:14px;margin:0 auto 14px;max-width:none}
  .kgl-hero-cta{gap:8px;margin:0 auto 16px}
  .kgl-hero-btn{padding:10px 16px;font-size:13.5px;gap:6px}
  /* Compact stats: 2x2 grid, horizontal mini-card layout */
  .kgl-hero-stats{grid-template-columns:repeat(2,1fr);gap:8px;max-width:none}
  .kgl-hero-stat{flex-direction:row;align-items:center;gap:10px;padding:10px 12px;
    border-radius:12px;text-align:left}
  .kgl-hero-stat-icon{width:38px;height:38px;border-radius:9px;flex-shrink:0}
  .kgl-hero-stat-icon svg{width:18px;height:18px}
  .kgl-hero-stat b{font-size:18px;line-height:1.1}
  .kgl-hero-stat span{font-size:11px;line-height:1.25;margin-top:1px}
  .kgl-hero-stat-text{display:flex;flex-direction:column;gap:0}
}
/* Tighter spacing on phones in landscape / very short viewports */
@media(max-height:680px) and (max-width:900px){
  .kgl-hero{padding:14px 14px 18px}
  .kgl-hero h1{font-size:22px;margin-bottom:8px}
  .kgl-hero-badge{margin-bottom:10px}
  .kgl-hero-cta{margin-bottom:12px}
}

/* ── Section shell ─────────────────────────────────────────────────────── */
.kgl-section{max-width:1200px;margin:0 auto;padding:36px 24px 24px}
.kgl-section + .kgl-section{padding-top:8px}
.kgl-section .kgl-buy-win{margin:0}
.kgl-section-title{font-size:clamp(20px,2.6vw,28px);font-weight:700;color:#1A1A2E;
  margin:0 0 8px;letter-spacing:-.02em;display:flex;align-items:center;gap:12px}
.kgl-section-icon{color:#0067E0;flex-shrink:0}
.kgl-section-sub{font-size:14.5px;color:#6B7680;margin:0 0 18px;line-height:1.55;
  max-width:760px}

/* ── Destination cards (CP10.18 redesign) ──────────────────────────────── */
.kgl-dest-grid{display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.kgl-dest-card{position:relative;background:#fff;border:1px solid #E2EBF7;
  border-radius:14px;padding:0;display:flex;flex-direction:column;
  text-decoration:none;color:inherit;overflow:hidden;
  box-shadow:0 1px 3px rgba(0,60,150,.06);
  transition:box-shadow .22s ease,transform .22s ease,border-color .22s ease}
.kgl-dest-card:hover{box-shadow:0 12px 32px rgba(0,60,150,.16);
  transform:translateY(-4px);border-color:#0067E0}
.kgl-dest-card:focus-visible{outline:3px solid #0067E0;outline-offset:2px}
/* Banner with landmark emoji + flag chip */
.kgl-dest-banner{position:relative;height:78px;
  background:linear-gradient(135deg,#EAF3FE 0%,#F5F9FF 100%);
  display:flex;align-items:center;justify-content:center;
  border-bottom:1px solid #E2EBF7}
.kgl-dest-banner::before{content:"";position:absolute;inset:0;opacity:.55;
  background:radial-gradient(circle at 18% 30%,rgba(0,103,224,.10) 0%,transparent 55%),
             radial-gradient(circle at 82% 70%,rgba(0,103,224,.06) 0%,transparent 60%);
  pointer-events:none}
.kgl-dest-emoji{font-size:40px;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,60,150,.18));
  position:relative;z-index:1;display:inline-flex;align-items:center;justify-content:center}
.kgl-dest-emoji img{width:48px;height:48px;object-fit:contain;
  background:rgba(255,255,255,.92);border-radius:50%;padding:5px;
  box-shadow:0 2px 8px rgba(0,60,150,.18)}
.kgl-dest-flag-chip{position:absolute;top:10px;right:10px;
  background:#fff;border:1px solid #D0E3FF;border-radius:999px;
  padding:3px;line-height:0;
  box-shadow:0 2px 6px rgba(0,60,150,.10);z-index:2}
.kgl-dest-flag-chip svg{display:block;border-radius:50%}
.kgl-dest-best-badge{position:absolute;top:10px;left:10px;
  background:linear-gradient(135deg,#FF9D2A 0%,#FF7A00 100%);
  color:#fff;font-size:10.5px;font-weight:800;letter-spacing:.04em;
  text-transform:uppercase;padding:4px 9px;border-radius:999px;
  box-shadow:0 3px 10px rgba(255,122,0,.32);z-index:2;line-height:1.3}
/* Body */
.kgl-dest-body{padding:14px 16px 0;display:flex;flex-direction:column;gap:2px}
.kgl-dest-city{font-weight:700;font-size:17px;color:#1A1A2E;letter-spacing:-.01em;
  line-height:1.2}
.kgl-dest-route{font-size:12px;color:#6B7680;font-variant-numeric:tabular-nums;
  display:flex;align-items:center;gap:5px;margin-top:2px}
.kgl-dest-iata{font-family:ui-monospace,"SF Mono",Menlo,monospace;
  font-weight:700;color:#003F8C;font-size:11.5px;letter-spacing:.03em;
  background:#EAF3FE;padding:2px 6px;border-radius:5px}
.kgl-dest-route-arrow{color:#0067E0;font-weight:700}
/* Footer */
.kgl-dest-foot{margin-top:auto;padding:12px 16px 14px;
  display:flex;align-items:flex-end;justify-content:space-between;gap:8px}
.kgl-dest-price{display:flex;flex-direction:column;line-height:1}
.kgl-dest-price-from{font-size:11px;color:#6B7680;font-weight:500;
  letter-spacing:.02em;margin-bottom:2px}
.kgl-dest-price-val{font-size:22px;font-weight:800;color:#003F8C;
  font-variant-numeric:tabular-nums;letter-spacing:-.01em}
.kgl-dest-price-unit{font-size:11px;color:#6B7680;font-weight:500;margin-top:3px}
.kgl-dest-arrow{display:inline-flex;align-items:center;justify-content:center;
  width:32px;height:32px;background:#F5F9FF;border:1px solid #D0E3FF;
  border-radius:50%;color:#0067E0;font-size:16px;font-weight:700;
  transition:background .15s ease,transform .15s ease,border-color .15s ease;
  flex-shrink:0}
.kgl-dest-card:hover .kgl-dest-arrow{background:#0067E0;color:#fff;
  border-color:#0067E0;transform:translateX(2px)}

/* ── Seasonal calendar (CP10.19 bar-chart redesign) ────────────────────── */
.kgl-season-grid{display:grid;gap:18px}
.kgl-season-route{background:#fff;border:1px solid #E2EBF7;border-radius:16px;
  padding:22px 24px;box-shadow:0 1px 4px rgba(0,60,150,.06);
  transition:box-shadow .22s ease,border-color .22s ease}
.kgl-season-route:hover{box-shadow:0 8px 24px rgba(0,60,150,.12);border-color:#B3CEED}
/* Header: flagged route name + CTA */
.kgl-season-head{display:flex;justify-content:space-between;align-items:center;
  gap:12px;margin-bottom:16px;flex-wrap:wrap}
.kgl-season-route-name{display:inline-flex;align-items:center;gap:9px;
  text-decoration:none;color:#1A1A2E;font-weight:700;font-size:17px;
  letter-spacing:-.01em}
.kgl-season-route-name:hover{color:#0067E0}
.kgl-season-flag{display:inline-flex;border-radius:50%;border:1px solid #D0E3FF;
  background:#fff;padding:2px;line-height:0;
  box-shadow:0 1px 3px rgba(0,60,150,.08)}
.kgl-season-flag svg{display:block;border-radius:50%}
.kgl-season-arrow{color:#0067E0;font-weight:700;font-size:17px;margin:0 2px}
.kgl-season-cta{font-size:13px;color:#0067E0;text-decoration:none;font-weight:600;
  display:inline-flex;align-items:center;gap:5px;padding:7px 13px;border-radius:8px;
  background:#EAF3FE;white-space:nowrap;
  transition:background .15s ease,color .15s ease,transform .15s ease}
.kgl-season-cta:hover{background:#0067E0;color:#fff;transform:translateX(2px)}
/* Stats triplet */
.kgl-season-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;
  margin-bottom:16px}
.kgl-season-stat{padding:11px 14px;border-radius:10px;border:1px solid;
  display:flex;flex-direction:column;gap:1px}
.kgl-season-stat-label{font-size:10.5px;font-weight:700;text-transform:uppercase;
  letter-spacing:.06em;opacity:.7}
.kgl-season-stat-val{font-size:18px;font-weight:800;font-variant-numeric:tabular-nums;
  letter-spacing:-.01em;line-height:1.15}
.kgl-season-stat-month{font-size:11.5px;font-weight:600;opacity:.78;margin-top:1px}
.kgl-season-stat-min{background:#E8F7EE;border-color:#A8D9B8;color:#0F5C2E}
.kgl-season-stat-avg{background:#EAF3FE;border-color:#B3CEED;color:#1F4E8A}
.kgl-season-stat-max{background:#FEEEEE;border-color:#F4B6B6;color:#7A1A1A}
/* Bar chart */
.kgl-season-bars{display:grid;grid-template-columns:repeat(12,1fr);gap:4px;
  align-items:end;height:160px;padding:18px 6px 6px;
  background:linear-gradient(180deg,#F8FAFD 0%,#F1F5FB 100%);
  border:1px solid #E2EBF7;border-radius:12px;position:relative;overflow:hidden}
.kgl-season-bars::before{content:"";position:absolute;left:0;right:0;
  border-top:1px dashed #D0E3FF;top:28%;pointer-events:none;opacity:.7}
.kgl-season-bars::after{content:"";position:absolute;left:0;right:0;
  border-top:1px dashed #D0E3FF;top:64%;pointer-events:none;opacity:.7}
.kgl-season-bar{display:flex;flex-direction:column;align-items:center;
  justify-content:flex-end;height:100%;position:relative;gap:5px;
  padding-bottom:4px}
.kgl-season-bar-fill{width:74%;border-radius:6px 6px 2px 2px;
  height:var(--h,8%);min-height:10px;
  background:linear-gradient(180deg,var(--bar-top) 0%,var(--bar-bot) 100%);
  box-shadow:inset 0 -2px 0 var(--bar-shadow),0 2px 6px var(--bar-glow);
  transition:transform .15s ease,filter .15s ease;cursor:default;position:relative}
.kgl-season-bar:hover .kgl-season-bar-fill{transform:translateY(-3px);
  filter:brightness(1.08)}
.kgl-season-bar-price{font-size:11px;font-weight:800;color:#1A1A2E;
  font-variant-numeric:tabular-nums;letter-spacing:-.01em;line-height:1}
.kgl-season-bar-month{font-size:10px;color:#6B7680;text-transform:uppercase;
  letter-spacing:.05em;font-weight:600;line-height:1}
.kgl-season-bar.kgl-s-low{--bar-top:#34D399;--bar-bot:#10B981;
  --bar-shadow:#059669;--bar-glow:rgba(16,185,129,.22)}
.kgl-season-bar.kgl-s-mid{--bar-top:#FBBF24;--bar-bot:#F59E0B;
  --bar-shadow:#D97706;--bar-glow:rgba(245,158,11,.20)}
.kgl-season-bar.kgl-s-high{--bar-top:#F87171;--bar-bot:#EF4444;
  --bar-shadow:#DC2626;--bar-glow:rgba(239,68,68,.20)}
.kgl-season-bar.kgl-s-na{--bar-top:#E5E7EB;--bar-bot:#D1D5DB;
  --bar-shadow:#9CA3AF;--bar-glow:transparent}
.kgl-season-bar.is-min .kgl-season-bar-fill::before{content:"★";
  position:absolute;top:-19px;left:50%;transform:translateX(-50%);
  color:#F59E0B;font-size:14px;
  text-shadow:0 1px 3px rgba(245,158,11,.4)}
.kgl-season-bar.is-min .kgl-season-bar-price{color:#0F5C2E}
.kgl-season-bar.is-max .kgl-season-bar-price{color:#7A1A1A}

@media(max-width:680px){
  .kgl-season-route{padding:18px 14px}
  .kgl-season-head{margin-bottom:14px;gap:8px}
  .kgl-season-route-name{font-size:15px;gap:7px}
  .kgl-season-arrow{font-size:15px}
  .kgl-season-cta{font-size:12px;padding:6px 10px}
  .kgl-season-stats{gap:6px;margin-bottom:14px}
  .kgl-season-stat{padding:8px 10px}
  .kgl-season-stat-val{font-size:14.5px}
  .kgl-season-stat-label{font-size:9.5px}
  .kgl-season-stat-month{font-size:10.5px}
  .kgl-season-bars{height:130px;padding:14px 4px 5px;gap:3px}
  .kgl-season-bar-price{font-size:9.5px}
  .kgl-season-bar-month{font-size:8.5px}
  .kgl-season-bar.is-min .kgl-season-bar-fill::before{top:-15px;font-size:11px}
}

/* ── Origin / dest / airport cards (CP10.20 unified redesign) ─────────── */
.kgl-origin-grid{display:grid;
  grid-template-columns:repeat(auto-fill,minmax(205px,1fr));gap:12px}
.kgl-origin-card{position:relative;background:#fff;border:1px solid #E2EBF7;
  border-radius:12px;padding:13px 16px;text-decoration:none;color:#1A1A2E;
  display:grid;grid-template-columns:auto 1fr;align-items:center;gap:13px;
  box-shadow:0 1px 3px rgba(0,60,150,.05);overflow:hidden;
  transition:box-shadow .2s ease,border-color .2s ease,transform .2s ease}
.kgl-origin-card::after{content:"→";position:absolute;top:50%;right:12px;
  transform:translateY(-50%) translateX(-6px);opacity:0;
  font-size:18px;font-weight:700;color:#0067E0;
  transition:opacity .2s ease,transform .2s ease;pointer-events:none}
.kgl-origin-card:hover{box-shadow:0 8px 22px rgba(0,60,150,.14);
  border-color:#0067E0;transform:translateY(-2px)}
.kgl-origin-card:hover::after{opacity:1;transform:translateY(-50%) translateX(0)}
.kgl-origin-card:focus-visible{outline:3px solid #0067E0;outline-offset:2px}
.kgl-origin-icon{display:inline-flex;align-items:center;justify-content:center;
  width:46px;height:46px;
  background:linear-gradient(135deg,#FFFFFF 0%,#F5F9FF 100%);
  border:1px solid #D0E3FF;border-radius:10px;font-size:22px;line-height:1;
  flex-shrink:0;padding:4px;overflow:hidden;
  transition:transform .2s ease,box-shadow .2s ease}
.kgl-origin-icon img{width:100%;height:100%;object-fit:contain;display:block;
  filter:drop-shadow(0 1px 2px rgba(0,60,150,.10))}
.kgl-origin-card:hover .kgl-origin-icon{transform:scale(1.06) rotate(-2deg);
  box-shadow:0 4px 10px rgba(0,103,224,.18)}
.kgl-origin-body{min-width:0;display:flex;flex-direction:column;gap:3px}
.kgl-origin-name{font-weight:700;font-size:15px;color:#1A1A2E;
  letter-spacing:-.01em;line-height:1.2;overflow:hidden;text-overflow:ellipsis;
  white-space:nowrap}
.kgl-origin-hint{font-size:12px;color:#6B7680;line-height:1.3;
  display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.kgl-origin-iata{font-family:ui-monospace,"SF Mono",Menlo,monospace;
  font-weight:700;color:#003F8C;font-size:10.5px;letter-spacing:.04em;
  background:#EAF3FE;padding:2px 6px;border-radius:4px;line-height:1.3;
  flex-shrink:0}
.kgl-origin-count{color:#6B7680;font-weight:500;font-size:12px}
.kgl-origin-count b{color:#0067E0;font-weight:700;font-variant-numeric:tabular-nums}

/* ── Route cards (CP10.22 redesign with flags) ─────────────────────────── */
.kgl-route-grid{display:grid;
  grid-template-columns:repeat(auto-fill,minmax(265px,1fr));gap:14px}
.kgl-route-card{background:#fff;border:1px solid #E2EBF7;border-radius:14px;
  padding:0;overflow:hidden;display:flex;flex-direction:column;
  box-shadow:0 1px 3px rgba(0,60,150,.06);
  transition:box-shadow .2s ease,border-color .2s ease,transform .2s ease}
.kgl-route-card:hover{box-shadow:0 10px 28px rgba(0,60,150,.14);
  transform:translateY(-3px);border-color:#B3CEED}
.kgl-route-header{padding:14px 16px 12px;display:flex;align-items:center;gap:9px;
  background:linear-gradient(135deg,#F5F9FF 0%,#FFFFFF 100%);
  border-bottom:1px solid #E2EBF7}
.kgl-route-flag{display:inline-flex;border-radius:50%;border:1px solid #D0E3FF;
  background:#fff;padding:2px;line-height:0;flex-shrink:0;
  box-shadow:0 1px 3px rgba(0,60,150,.10)}
.kgl-route-flag svg{display:block;border-radius:50%}
.kgl-route-cities{display:flex;align-items:center;gap:5px;font-weight:700;
  font-size:14.5px;color:#1A1A2E;flex:1;min-width:0;letter-spacing:-.01em}
.kgl-route-cities-arrow{color:#0067E0;font-weight:700;font-size:13px;flex-shrink:0}
.kgl-route-city{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.kgl-route-iata{padding:8px 16px;display:flex;align-items:center;gap:6px;
  font-family:ui-monospace,"SF Mono",Menlo,monospace;font-size:11px;
  font-weight:700;color:#003F8C;letter-spacing:.05em;
  background:#F8FAFD;border-bottom:1px solid #E2EBF7}
.kgl-route-iata-code{background:#EAF3FE;padding:2px 7px;border-radius:5px;
  line-height:1.4;border:1px solid #D0E3FF}
.kgl-route-iata-sep{color:#0067E0;font-weight:600;font-size:13px;
  font-family:system-ui,-apple-system,"Segoe UI",sans-serif}
.kgl-route-price-wrap{padding:14px 16px 12px}
.kgl-route-price-label{font-size:10.5px;color:#6B7680;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;margin-bottom:4px}
.kgl-route-price{font-size:26px;font-weight:800;color:#003F8C;
  font-variant-numeric:tabular-nums;letter-spacing:-.02em;line-height:1}
.kgl-route-price small{font-size:13px;font-weight:500;color:#6B7680;
  margin-left:3px;font-variant-numeric:normal}
.kgl-route-price-pending{font-size:17px;font-weight:700;color:#6B7680;
  line-height:1.2;display:flex;align-items:center;gap:7px}
.kgl-route-price-pending::before{content:"";display:inline-block;width:8px;height:8px;
  border-radius:50%;background:#FBBF24;animation:kgl-route-pulse 2s infinite;
  box-shadow:0 0 0 0 rgba(251,191,36,.4)}
@keyframes kgl-route-pulse{
  0%{box-shadow:0 0 0 0 rgba(251,191,36,.5)}
  70%{box-shadow:0 0 0 8px rgba(251,191,36,0)}
  100%{box-shadow:0 0 0 0 rgba(251,191,36,0)}}
.kgl-route-actions{padding:0 16px 16px;display:flex;flex-direction:column;gap:10px;
  margin-top:auto}
.kgl-route-links{display:flex;gap:6px;flex-wrap:wrap}
.kgl-route-links a{font-size:12px;color:#0067E0;text-decoration:none;font-weight:600;
  background:#EAF3FE;padding:6px 10px;border-radius:6px;line-height:1.3;
  display:inline-flex;align-items:center;gap:5px;
  transition:background .15s ease,color .15s ease,transform .15s ease}
.kgl-route-links a:hover{background:#0067E0;color:#fff;transform:translateY(-1px)}
.kgl-route-aff{display:inline-flex;align-items:center;justify-content:center;gap:7px;
  padding:11px 14px;background:linear-gradient(135deg,#0067E0 0%,#0052CC 100%)!important;
  color:#fff!important;font-weight:700;font-size:13.5px;border-radius:9px;
  text-decoration:none!important;width:100%;letter-spacing:-.01em;
  box-shadow:0 4px 12px rgba(0,103,224,.28);
  transition:box-shadow .2s ease,transform .2s ease}
.kgl-route-aff:hover{transform:translateY(-1px);
  box-shadow:0 8px 20px rgba(0,103,224,.40)}
.kgl-route-aff:focus-visible{outline:3px solid #BAE0FF;outline-offset:2px}
.kgl-route-aff-arrow{transition:transform .15s ease;display:inline-block;font-size:15px}
.kgl-route-aff:hover .kgl-route-aff-arrow{transform:translateX(3px)}

/* ── Country guides (CP10.23 redesign with real flags + data pills) ───── */
.kgl-country-grid{display:grid;
  grid-template-columns:repeat(auto-fill,minmax(225px,1fr));gap:14px}
.kgl-country-card{position:relative;background:#fff;border:1px solid #E2EBF7;
  border-radius:14px;padding:0;overflow:hidden;
  display:flex;flex-direction:column;
  text-decoration:none;color:inherit;
  box-shadow:0 1px 3px rgba(0,60,150,.06);
  transition:box-shadow .22s ease,border-color .22s ease,transform .22s ease}
.kgl-country-card:hover{box-shadow:0 12px 32px rgba(0,60,150,.16);
  transform:translateY(-4px);border-color:#0067E0}
.kgl-country-card:focus-visible{outline:3px solid #0067E0;outline-offset:2px}
.kgl-country-banner{position:relative;height:84px;display:flex;align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,#EAF3FE 0%,#F5F9FF 100%);
  border-bottom:1px solid #E2EBF7;overflow:hidden}
.kgl-country-banner::before{content:"";position:absolute;inset:0;opacity:.6;
  background:radial-gradient(circle at 20% 30%,rgba(0,103,224,.12) 0%,transparent 55%),
             radial-gradient(circle at 80% 70%,rgba(0,103,224,.08) 0%,transparent 60%);
  pointer-events:none}
.kgl-country-flag-wrap{position:relative;z-index:1;display:inline-flex;
  border-radius:50%;background:#fff;padding:4px;border:1px solid #D0E3FF;
  box-shadow:0 4px 14px rgba(0,60,150,.18);line-height:0}
.kgl-country-flag-wrap svg{display:block;border-radius:50%}
.kgl-country-body{padding:14px 16px 12px;display:flex;flex-direction:column;gap:3px}
.kgl-country-name{font-weight:700;font-size:17px;color:#1A1A2E;
  letter-spacing:-.01em;line-height:1.2}
.kgl-country-sub{font-size:11.5px;color:#6B7680;font-weight:500;
  letter-spacing:.02em;margin-top:1px}
.kgl-country-meta{display:flex;flex-direction:column;gap:7px;margin-top:10px;
  font-size:12.5px;color:#3A3A4A}
.kgl-country-meta-row{display:flex;align-items:center;gap:8px;line-height:1.3}
.kgl-country-meta-icon{display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;flex-shrink:0;color:#0067E0;background:#EAF3FE;
  border-radius:6px;font-size:11.5px;font-weight:700;line-height:1}
.kgl-country-meta-val{font-weight:700;color:#003F8C;font-variant-numeric:tabular-nums}
.kgl-country-cta{margin-top:auto;padding:11px 16px;font-size:13px;
  font-weight:600;color:#0067E0;display:flex;align-items:center;
  justify-content:space-between;
  border-top:1px solid #E2EBF7;background:#F8FAFD;
  transition:background .15s ease,color .15s ease}
.kgl-country-cta-arrow{font-size:15px;font-weight:700;
  transition:transform .15s ease}
.kgl-country-card:hover .kgl-country-cta{background:#0067E0;color:#fff}
.kgl-country-card:hover .kgl-country-cta-arrow{transform:translateX(3px)}

/* ── Airport cards (CP10.25 redesign with real logos) ─────────────────── */
.kgl-airport-grid{display:grid;
  grid-template-columns:repeat(auto-fill,minmax(225px,1fr));gap:14px}
.kgl-airport-card{position:relative;background:#fff;border:1px solid #E2EBF7;
  border-radius:14px;padding:0;overflow:hidden;
  display:flex;flex-direction:column;
  text-decoration:none;color:inherit;
  box-shadow:0 1px 3px rgba(0,60,150,.06);
  transition:box-shadow .22s ease,border-color .22s ease,transform .22s ease}
.kgl-airport-card:hover{box-shadow:0 12px 30px rgba(0,60,150,.16);
  transform:translateY(-3px);border-color:#0067E0}
.kgl-airport-card:focus-visible{outline:3px solid #0067E0;outline-offset:2px}
.kgl-airport-banner{position:relative;padding:18px 16px 14px;display:flex;
  align-items:center;justify-content:center;
  background:linear-gradient(135deg,#EAF3FE 0%,#F5F9FF 100%);
  border-bottom:1px solid #E2EBF7;min-height:96px}
.kgl-airport-banner::before{content:"";position:absolute;inset:0;opacity:.5;
  background:radial-gradient(circle at 15% 25%,rgba(0,103,224,.10) 0%,transparent 55%),
             radial-gradient(circle at 85% 75%,rgba(0,103,224,.08) 0%,transparent 60%);
  pointer-events:none}
.kgl-airport-logo{position:relative;z-index:1;display:inline-flex;
  align-items:center;justify-content:center;
  height:60px;max-width:170px;background:#fff;border-radius:10px;
  padding:8px 14px;border:1px solid #D0E3FF;
  box-shadow:0 4px 12px rgba(0,60,150,.14)}
.kgl-airport-logo img{display:block;max-height:42px;max-width:100%;
  object-fit:contain;width:auto;height:auto}
.kgl-airport-emoji{font-size:32px;line-height:1}
.kgl-airport-body{padding:14px 16px 12px;display:flex;flex-direction:column;gap:2px}
.kgl-airport-name{font-weight:700;font-size:16px;color:#1A1A2E;
  letter-spacing:-.01em;line-height:1.2;display:flex;align-items:center;gap:8px}
.kgl-airport-iata{font-family:ui-monospace,"SF Mono",Menlo,monospace;
  font-weight:700;color:#003F8C;font-size:11px;letter-spacing:.04em;
  background:#EAF3FE;padding:2px 7px;border-radius:5px;line-height:1.4;
  border:1px solid #D0E3FF}
.kgl-airport-city{font-size:12.5px;color:#6B7680;font-weight:500;
  display:flex;align-items:center;gap:5px;margin-top:2px}
.kgl-airport-city::before{content:"📍";font-size:11px;opacity:.7}
.kgl-airport-hint{font-size:12px;color:#6B7680;margin-top:8px;line-height:1.4}
.kgl-airport-cta{margin-top:auto;padding:11px 16px;font-size:13px;
  font-weight:600;color:#0067E0;display:flex;align-items:center;
  justify-content:space-between;
  border-top:1px solid #E2EBF7;background:#F8FAFD;
  transition:background .15s ease,color .15s ease}
.kgl-airport-cta-arrow{font-size:15px;font-weight:700;
  transition:transform .15s ease}
.kgl-airport-card:hover .kgl-airport-cta{background:#0067E0;color:#fff}
.kgl-airport-card:hover .kgl-airport-cta-arrow{transform:translateX(3px)}

/* ── Yearly destination reports (CP10.24 redesign) ────────────────────── */
.kgl-yearly-grid{display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.kgl-yearly-card{position:relative;background:#fff;border:1px solid #E2EBF7;
  border-radius:14px;padding:0;overflow:hidden;
  display:flex;flex-direction:column;
  text-decoration:none;color:inherit;
  box-shadow:0 1px 3px rgba(0,60,150,.06);
  transition:box-shadow .22s ease,border-color .22s ease,transform .22s ease}
.kgl-yearly-card:hover{box-shadow:0 12px 32px rgba(0,60,150,.16);
  transform:translateY(-3px);border-color:#0067E0}
.kgl-yearly-card:focus-visible{outline:3px solid #0067E0;outline-offset:2px}
.kgl-yearly-head{display:flex;align-items:center;gap:12px;padding:14px 16px;
  background:linear-gradient(135deg,#F5F9FF 0%,#FFFFFF 100%);
  border-bottom:1px solid #E2EBF7}
.kgl-yearly-flag{display:inline-flex;width:44px;height:44px;
  background:linear-gradient(135deg,#FFFFFF 0%,#F5F9FF 100%);
  border:1px solid #D0E3FF;border-radius:10px;padding:4px;
  align-items:center;justify-content:center;flex-shrink:0;
  box-shadow:0 2px 6px rgba(0,60,150,.10)}
.kgl-yearly-flag img,.kgl-yearly-flag svg{width:100%;height:100%;
  object-fit:contain;border-radius:50%;display:block}
.kgl-yearly-emoji{font-size:22px;line-height:1}
.kgl-yearly-title{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1}
.kgl-yearly-city{font-weight:700;font-size:16px;color:#1A1A2E;
  letter-spacing:-.01em;line-height:1.2;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.kgl-yearly-sub{font-size:11.5px;color:#0067E0;font-weight:600;
  letter-spacing:.04em;text-transform:uppercase;line-height:1}
.kgl-yearly-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;
  padding:14px 16px 4px}
.kgl-yearly-stat{display:flex;flex-direction:column;align-items:center;
  text-align:center;padding:9px 4px;border-radius:8px;
  border:1px solid #E2EBF7;background:#F8FAFD;gap:2px;line-height:1.1}
.kgl-yearly-stat-label{font-size:9.5px;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;color:#6B7680}
.kgl-yearly-stat-val{font-size:14.5px;font-weight:800;color:#003F8C;
  font-variant-numeric:tabular-nums;letter-spacing:-.01em;margin-top:2px}
.kgl-yearly-stat.is-low{background:#F0FDF4;border-color:#A8D9B8}
.kgl-yearly-stat.is-low .kgl-yearly-stat-label{color:#0F5C2E}
.kgl-yearly-stat.is-low .kgl-yearly-stat-val{color:#0F5C2E}
.kgl-yearly-stat.is-high{background:#FEF2F2;border-color:#F4B6B6}
.kgl-yearly-stat.is-high .kgl-yearly-stat-label{color:#7A1A1A}
.kgl-yearly-stat.is-high .kgl-yearly-stat-val{color:#7A1A1A}
.kgl-yearly-stat.is-best{background:#FFFBEB;border-color:#FCD34D}
.kgl-yearly-stat.is-best .kgl-yearly-stat-label{color:#854D0E}
.kgl-yearly-stat.is-best .kgl-yearly-stat-val{color:#854D0E;font-size:13px}
.kgl-yearly-cta{margin-top:auto;padding:11px 16px;font-size:13px;
  font-weight:600;color:#0067E0;display:flex;align-items:center;
  justify-content:space-between;border-top:1px solid #E2EBF7;
  background:#F8FAFD;transition:background .15s ease,color .15s ease}
.kgl-yearly-cta-arrow{font-size:15px;font-weight:700;
  transition:transform .15s ease}
.kgl-yearly-card:hover .kgl-yearly-cta{background:#0067E0;color:#fff}
.kgl-yearly-card:hover .kgl-yearly-cta-arrow{transform:translateX(3px)}

/* ── Seasonal event cards (CP10.26 redesign) ──────────────────────────── */
.kgl-event-grid{display:grid;
  grid-template-columns:repeat(auto-fill,minmax(245px,1fr));gap:14px}
.kgl-event-card{position:relative;background:#fff;border:1px solid #E2EBF7;
  border-radius:14px;padding:0;overflow:hidden;
  display:flex;flex-direction:column;
  text-decoration:none;color:inherit;
  box-shadow:0 1px 3px rgba(0,60,150,.06);
  transition:box-shadow .22s ease,border-color .22s ease,transform .22s ease}
.kgl-event-card:hover{box-shadow:0 12px 32px rgba(0,60,150,.16);
  transform:translateY(-4px);border-color:#0067E0}
.kgl-event-card:focus-visible{outline:3px solid #0067E0;outline-offset:2px}
.kgl-event-banner{position:relative;padding:18px 16px;min-height:96px;
  display:flex;align-items:center;justify-content:center;
  background:var(--event-bg,linear-gradient(135deg,#EAF3FE 0%,#F5F9FF 100%));
  border-bottom:1px solid #E2EBF7;overflow:hidden}
.kgl-event-banner::before{content:"";position:absolute;inset:0;opacity:.4;
  background:radial-gradient(circle at 78% 22%,rgba(255,255,255,.55) 0%,transparent 55%),
             radial-gradient(circle at 18% 78%,rgba(255,255,255,.25) 0%,transparent 50%);
  pointer-events:none}
.kgl-event-emoji{font-size:48px;line-height:1;position:relative;z-index:1;
  filter:drop-shadow(0 4px 10px rgba(0,0,0,.20))}
.kgl-event-date{position:absolute;top:10px;left:10px;
  background:rgba(255,255,255,.92);color:#1A1A2E;
  padding:4px 10px;border-radius:999px;font-size:11px;font-weight:700;
  letter-spacing:.03em;box-shadow:0 2px 6px rgba(0,0,0,.10);z-index:2;
  font-variant-numeric:tabular-nums;line-height:1.4}
.kgl-event-body{padding:14px 16px;display:flex;flex-direction:column;gap:4px}
.kgl-event-name{font-weight:700;font-size:16px;color:#1A1A2E;
  letter-spacing:-.01em;line-height:1.2}
.kgl-event-hint{font-size:12px;color:#6B7680;line-height:1.4;margin-top:2px}
.kgl-event-strategy{display:flex;align-items:center;gap:7px;
  background:#FFFBEB;border:1px solid #FCD34D;color:#854D0E;
  padding:8px 11px;border-radius:8px;font-size:11.5px;font-weight:600;
  line-height:1.3;margin-top:10px}
.kgl-event-strategy::before{content:"⏱";font-size:13px;flex-shrink:0}
.kgl-event-cta{margin-top:auto;padding:11px 16px;font-size:13px;
  font-weight:600;color:#0067E0;display:flex;align-items:center;
  justify-content:space-between;border-top:1px solid #E2EBF7;
  background:#F8FAFD;transition:background .15s ease,color .15s ease}
.kgl-event-cta-arrow{font-size:15px;font-weight:700;
  transition:transform .15s ease}
.kgl-event-card:hover .kgl-event-cta{background:#0067E0;color:#fff}
.kgl-event-card:hover .kgl-event-cta-arrow{transform:translateX(3px)}
/* Theme variants */
.kgl-event-mayskie{--event-bg:linear-gradient(135deg,#D1FAE5 0%,#ECFDF5 100%)}
.kgl-event-ng{--event-bg:linear-gradient(135deg,#FECACA 0%,#FEF2F2 60%,#DCFCE7 100%)}
.kgl-event-marta{--event-bg:linear-gradient(135deg,#FCE7F3 0%,#FBCFE8 50%,#FDF2F8 100%)}
.kgl-event-leto{--event-bg:linear-gradient(135deg,#FEF3C7 0%,#FDE68A 50%,#FEF9E6 100%)}
.kgl-event-fevralya{--event-bg:linear-gradient(135deg,#D6E4D6 0%,#A7C4A0 60%,#EBF2EB 100%)}
.kgl-event-bf{--event-bg:linear-gradient(135deg,#111827 0%,#1F2937 50%,#374151 100%)}
.kgl-event-bf .kgl-event-date{background:rgba(255,255,255,.22);color:#fff;
  border:1px solid rgba(255,255,255,.30);backdrop-filter:blur(4px)}

/* ── Carrier cards (CP10.27 lowcosters redesign) ──────────────────────── */
.kgl-carrier-grid{display:grid;
  grid-template-columns:repeat(auto-fill,minmax(225px,1fr));gap:14px}
.kgl-carrier-card{position:relative;background:#fff;border:1px solid #E2EBF7;
  border-radius:14px;padding:0;overflow:hidden;
  display:flex;flex-direction:column;
  text-decoration:none;color:inherit;
  box-shadow:0 1px 3px rgba(0,60,150,.06);
  transition:box-shadow .22s ease,border-color .22s ease,transform .22s ease}
.kgl-carrier-card:hover{box-shadow:0 12px 30px rgba(0,60,150,.16);
  transform:translateY(-3px);border-color:#0067E0}
.kgl-carrier-card:focus-visible{outline:3px solid #0067E0;outline-offset:2px}
.kgl-carrier-banner{position:relative;padding:18px 16px 14px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#EAF3FE 0%,#F5F9FF 100%);
  border-bottom:1px solid #E2EBF7;min-height:96px}
.kgl-carrier-banner::before{content:"";position:absolute;inset:0;opacity:.5;
  background:radial-gradient(circle at 18% 25%,rgba(0,103,224,.10) 0%,transparent 55%),
             radial-gradient(circle at 82% 75%,rgba(0,103,224,.08) 0%,transparent 60%);
  pointer-events:none}
.kgl-carrier-logo{position:relative;z-index:1;display:inline-flex;
  align-items:center;justify-content:center;
  height:60px;max-width:160px;background:#fff;border-radius:10px;
  padding:8px 14px;border:1px solid #D0E3FF;
  box-shadow:0 4px 12px rgba(0,60,150,.14)}
.kgl-carrier-logo img{display:block;max-height:42px;max-width:100%;
  object-fit:contain;width:auto;height:auto}
.kgl-carrier-flag-chip{position:absolute;top:10px;right:10px;
  display:inline-flex;border-radius:50%;border:1px solid #D0E3FF;
  background:#fff;padding:2px;line-height:0;z-index:2;
  box-shadow:0 2px 6px rgba(0,60,150,.10)}
.kgl-carrier-flag-chip svg{display:block;border-radius:50%}
.kgl-carrier-type{position:absolute;top:10px;left:10px;z-index:2;
  font-size:9.5px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  padding:3px 8px;border-radius:5px;line-height:1.4;
  background:rgba(255,255,255,.95);color:#0067E0;
  box-shadow:0 2px 6px rgba(0,60,150,.10)}
.kgl-carrier-type.is-lcc{background:#FEF3C7;color:#854D0E}
.kgl-carrier-type.is-regional{background:#DBEAFE;color:#003F8C}
.kgl-carrier-type.is-hub{background:#E0E7FF;color:#3730A3}
.kgl-carrier-body{padding:14px 16px 12px;display:flex;flex-direction:column;gap:2px}
.kgl-carrier-name{font-weight:700;font-size:16px;color:#1A1A2E;
  letter-spacing:-.01em;line-height:1.2;display:flex;align-items:center;gap:8px}
.kgl-carrier-iata{font-family:ui-monospace,"SF Mono",Menlo,monospace;
  font-weight:700;color:#003F8C;font-size:11px;letter-spacing:.04em;
  background:#EAF3FE;padding:2px 7px;border-radius:5px;line-height:1.4;
  border:1px solid #D0E3FF}
.kgl-carrier-country{font-size:12.5px;color:#6B7680;font-weight:500;margin-top:3px}
.kgl-carrier-hint{font-size:12px;color:#6B7680;margin-top:6px;line-height:1.4;
  display:flex;flex-wrap:wrap;gap:4px}
.kgl-carrier-hint-pill{background:#F1F5F9;color:#475569;
  padding:3px 8px;border-radius:5px;font-size:11px;font-weight:600;
  border:1px solid #E2E8F0;line-height:1.3}
.kgl-carrier-cta{margin-top:auto;padding:11px 16px;font-size:13px;
  font-weight:600;color:#0067E0;display:flex;align-items:center;
  justify-content:space-between;border-top:1px solid #E2EBF7;
  background:#F8FAFD;transition:background .15s ease,color .15s ease}
.kgl-carrier-cta-arrow{font-size:15px;font-weight:700;
  transition:transform .15s ease}
.kgl-carrier-card:hover .kgl-carrier-cta{background:#0067E0;color:#fff}
.kgl-carrier-card:hover .kgl-carrier-cta-arrow{transform:translateX(3px)}

/* ── How it works (CP10.28 redesign with icons + stats) ────────────────── */
.kgl-howto{background:linear-gradient(135deg,#001F4D 0%,#003F8C 45%,#0052CC 100%);
  color:#fff;padding:64px 24px 72px;margin-top:32px;position:relative;overflow:hidden}
.kgl-howto::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse at top right,rgba(186,222,255,.16) 0%,transparent 55%),
             radial-gradient(ellipse at bottom left,rgba(255,255,255,.05) 0%,transparent 50%)}
.kgl-howto-inner{max-width:1200px;margin:0 auto;position:relative;z-index:1}
.kgl-howto-eyebrow{font-size:11.5px;font-weight:700;color:#BAE0FF;
  letter-spacing:.16em;text-transform:uppercase;margin-bottom:12px;
  display:flex;align-items:center;gap:10px}
.kgl-howto-eyebrow::before,.kgl-howto-eyebrow::after{content:"";flex:0 0 28px;
  height:1px;background:rgba(186,222,255,.4)}
.kgl-howto-eyebrow::after{flex:1}
.kgl-howto h2{color:#fff!important;font-size:clamp(24px,3vw,32px);
  font-weight:700;margin:0 0 14px;letter-spacing:-.02em;
  display:flex;align-items:center;gap:12px}
.kgl-howto h2 .kgl-section-icon{color:#BAE0FF}
.kgl-howto-lead{font-size:14.5px;color:#C2DAEE;max-width:680px;line-height:1.55;
  margin:0 0 36px}
.kgl-howto-steps{display:grid;
  grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px;
  position:relative}
.kgl-step{position:relative;background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.16);
  border-radius:14px;padding:22px 20px;backdrop-filter:blur(8px);
  transition:transform .22s ease,background .22s ease,border-color .22s ease;
  display:flex;flex-direction:column}
.kgl-step:hover{background:rgba(255,255,255,.12);border-color:rgba(186,222,255,.45);
  transform:translateY(-3px)}
.kgl-step-head{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.kgl-step-icon{position:relative;display:inline-flex;align-items:center;justify-content:center;
  width:56px;height:56px;background:#fff;border-radius:16px;
  flex-shrink:0;box-shadow:0 8px 22px rgba(0,0,0,.28),
    inset 0 1px 0 rgba(255,255,255,.6)}
.kgl-step-icon::after{content:"";position:absolute;inset:-2px;border-radius:18px;
  background:linear-gradient(135deg,var(--step-accent,#38BDF8),
    var(--step-accent-2,#0EA5E9));z-index:-1;opacity:.65;filter:blur(8px)}
.kgl-step-icon svg{display:block;width:30px;height:30px;
  stroke:var(--step-accent-2,#0EA5E9);stroke-width:2.2;flex-shrink:0}
/* per-step accent palette — distinct icon glow per card */
.kgl-step:nth-child(1) .kgl-step-icon{--step-accent:#38BDF8;--step-accent-2:#0284C7}
.kgl-step:nth-child(2) .kgl-step-icon{--step-accent:#A78BFA;--step-accent-2:#7C3AED}
.kgl-step:nth-child(3) .kgl-step-icon{--step-accent:#34D399;--step-accent-2:#059669}
.kgl-step:nth-child(4) .kgl-step-icon{--step-accent:#FBBF24;--step-accent-2:#D97706}
.kgl-step-num{font-size:11px;font-weight:800;color:#BAE0FF;
  letter-spacing:.14em;text-transform:uppercase;font-variant-numeric:tabular-nums;
  background:none;width:auto;height:auto;border-radius:0;box-shadow:none;
  display:inline;padding:0}
.kgl-step-title{font-weight:700;font-size:16px;color:#fff;line-height:1.25;
  letter-spacing:-.01em;margin:0 0 8px}
.kgl-step-desc{font-size:13.5px;color:#C2DAEE;line-height:1.55;margin:0 0 14px}
.kgl-step-stat{margin-top:auto;padding:10px 12px;background:rgba(255,255,255,.10);
  border:1px solid rgba(186,222,255,.25);border-radius:9px;
  display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.kgl-step-stat b{font-size:17px;font-weight:800;color:#fff;
  font-variant-numeric:tabular-nums;letter-spacing:-.01em;line-height:1;
  flex-shrink:0}
.kgl-step-stat span{font-size:11.5px;color:#BAE0FF;font-weight:600;line-height:1.2}

/* ── Pillar resource cards (CP10.29 redesign) ─────────────────────────── */
.kgl-pillar-grid{display:grid;
  grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:12px}
.kgl-pillar-card{position:relative;background:#fff;border:1px solid #E2EBF7;
  border-radius:12px;padding:16px 18px;display:flex;align-items:center;gap:14px;
  text-decoration:none;color:inherit;
  box-shadow:0 1px 3px rgba(0,60,150,.05);overflow:hidden;
  transition:box-shadow .2s ease,border-color .2s ease,transform .2s ease}
.kgl-pillar-card::after{content:"→";position:absolute;top:50%;right:16px;
  transform:translateY(-50%) translateX(-4px);opacity:0;
  font-size:18px;font-weight:700;color:#0067E0;
  transition:opacity .2s ease,transform .2s ease;pointer-events:none}
.kgl-pillar-card:hover{box-shadow:0 8px 22px rgba(0,60,150,.12);
  border-color:#0067E0;transform:translateY(-2px)}
.kgl-pillar-card:hover::after{opacity:1;transform:translateY(-50%) translateX(0)}
.kgl-pillar-card:focus-visible{outline:3px solid #0067E0;outline-offset:2px}
.kgl-pillar-icon{display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;font-size:22px;line-height:1;flex-shrink:0;
  border-radius:11px;border:1px solid;
  transition:transform .2s ease,box-shadow .2s ease}
.kgl-pillar-card:hover .kgl-pillar-icon{transform:scale(1.06) rotate(-2deg)}
.kgl-pillar-body{min-width:0;display:flex;flex-direction:column;gap:2px;
  padding-right:24px;flex:1}
.kgl-pillar-title{font-weight:700;font-size:14.5px;color:#1A1A2E;
  letter-spacing:-.01em;line-height:1.25}
.kgl-pillar-sub{font-size:12.5px;color:#6B7680;line-height:1.4}
/* Color themes */
.kgl-pillar-payment{background:linear-gradient(135deg,#ECFDF5 0%,#F0FDF4 100%);
  border-color:#A7F3D0;color:#0F5C2E}
.kgl-pillar-analytics{background:linear-gradient(135deg,#EAF3FE 0%,#F5F9FF 100%);
  border-color:#B3CEED;color:#003F8C}
.kgl-pillar-calendar{background:linear-gradient(135deg,#F5F3FF 0%,#FAF5FF 100%);
  border-color:#D8B4FE;color:#5B21B6}
.kgl-pillar-methodology{background:linear-gradient(135deg,#FFF7ED 0%,#FFFBEB 100%);
  border-color:#FED7AA;color:#9A3412}
.kgl-pillar-glossary{background:linear-gradient(135deg,#F1F5F9 0%,#F8FAFC 100%);
  border-color:#CBD5E1;color:#334155}
.kgl-pillar-about{background:linear-gradient(135deg,#FDF2F8 0%,#FFF5F8 100%);
  border-color:#FBCFE8;color:#9D174D}

/* ── Section dividers ──────────────────────────────────────────────────── */
.kgl-section-alt{background:#F5F9FF}

@media(max-width:640px){
  .kgl-section{padding:40px 16px 24px}
  .kgl-dest-grid{grid-template-columns:repeat(2,1fr)}
  .kgl-origin-grid{grid-template-columns:repeat(2,1fr)}
  .kgl-country-grid{grid-template-columns:repeat(2,1fr)}
  .kgl-route-grid{grid-template-columns:1fr}
  .kgl-hero{padding:48px 20px 56px}
  .kgl-howto{padding:40px 20px}
}
@media(max-width:400px){
  .kgl-dest-grid,.kgl-origin-grid,.kgl-country-grid{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  .kgl-dest-card:hover,.kgl-route-card:hover,.kgl-country-card:hover,
  .kgl-origin-card:hover{transform:none}
}

/* ── CP10.36: Buying Window block (kgl-buy-win-*) + TG-CTA ──────────────
   Synced from /assets/css/components.css — homepage uses inline CSS only,
   so we replicate the rules here. Keep in sync when those upstream change. */
.kgl-buy-win{background:#fff;border:1px solid #D0E3FF;border-radius:18px;padding:28px 30px 24px;margin:1.8em 0;box-shadow:0 4px 18px rgba(0,60,150,.06)}
.kgl-buy-win-head{display:flex;align-items:center;gap:18px;margin-bottom:22px;flex-wrap:wrap}
.kgl-buy-win-eyebrow{font-size:11.5px;font-weight:800;color:#6B7680;letter-spacing:.12em;text-transform:uppercase}
.kgl-buy-win-hero{flex:1;min-width:240px;font-size:clamp(22px,2.6vw,30px);font-weight:800;color:#0F5132;letter-spacing:-.02em;line-height:1.1;display:flex;align-items:center;gap:12px}
.kgl-buy-win-hero::before{content:"";flex-shrink:0;width:36px;height:36px;background:radial-gradient(circle at 50% 50%,#16A34A 0%,#0F5132 100%);border-radius:50%;display:inline-block;box-shadow:0 0 0 4px #D4EDDA}
.kgl-buy-win-tag{display:inline-flex;align-items:center;padding:5px 13px;background:#D4EDDA;color:#0F5132;border-radius:10px;font-size:13.5px;font-weight:800;line-height:1.4;white-space:nowrap}
.kgl-buy-win-scale{margin:0 0 20px}
.kgl-buy-win-track{display:flex;height:32px;border-radius:8px;overflow:hidden;border:1px solid #E5EEFB;box-shadow:inset 0 1px 3px rgba(0,60,150,.04)}
.kgl-buy-win-zone{display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;letter-spacing:.01em;padding:0 6px;text-align:center;line-height:1.15}
.kgl-buy-win-zone-early{background:#94A3B8}
.kgl-buy-win-zone-best{background:linear-gradient(90deg,#16A34A 0%,#0F7B3C 100%);position:relative}
.kgl-buy-win-zone-best::after{content:"";position:absolute;left:50%;bottom:-6px;width:0;height:0;border-style:solid;border-width:6px 5px 0 5px;border-color:#0F5132 transparent transparent transparent;transform:translateX(-50%)}
.kgl-buy-win-zone-ok{background:#F59E0B}
.kgl-buy-win-zone-late{background:#DC2626}
.kgl-buy-win-axis{display:flex;justify-content:space-between;margin-top:14px;padding:0 2px;font-size:11.5px;font-weight:600;color:#6B7680;font-variant-numeric:tabular-nums}
.kgl-buy-win-rules{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;margin-top:18px;padding-top:18px;border-top:1px solid #EBF3FF}
.kgl-buy-win-rule{display:flex;align-items:flex-start;gap:10px;font-size:14px;line-height:1.5;color:#1A1A2E;padding:12px 14px;background:#F7FAFE;border:1px solid #E5EEFB;border-radius:10px}
.kgl-buy-win-rule-icon{flex-shrink:0;width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;font-variant-numeric:tabular-nums;color:#fff}
.kgl-buy-win-rule-best{background:#16A34A}
.kgl-buy-win-rule-warn{background:#F59E0B}
.kgl-buy-win-rule-bad{background:#DC2626}
.kgl-buy-win-rule b{font-weight:800;color:#003F8C;display:block;margin-bottom:2px}
.kgl-buy-win-source{margin:14px 0 0;font-size:12.5px;color:#6B7680;line-height:1.55}
.kgl-buy-win-source b{font-weight:700;color:#003F8C}
@media(max-width:680px){.kgl-buy-win{padding:20px 18px}.kgl-buy-win-hero{font-size:20px}.kgl-buy-win-track{height:28px}.kgl-buy-win-zone{font-size:11px}.kgl-buy-win-axis{font-size:10.5px}}
.kgl-tg-cta{margin:18px 0 0;padding:20px 24px;background:linear-gradient(135deg,#F5F9FF 0%,#EBF3FF 100%);border:1px solid #C2DAEE;border-radius:14px;display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.kgl-tg-cta-icon{flex-shrink:0;width:48px;height:48px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#229ED9 0%,#0088CC 100%);border-radius:50%;color:#fff;box-shadow:0 4px 10px rgba(0,136,204,.30)}
.kgl-tg-cta-icon svg{display:block;color:#fff}
.kgl-tg-cta-text{flex:1;min-width:240px}
.kgl-tg-cta-title{margin:0 0 4px;font-size:16px;font-weight:800;color:#003F8C;line-height:1.25;letter-spacing:-.01em;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.kgl-tg-cta-title small{font-size:11px;font-weight:700;color:#0088CC;background:#E0F2FE;padding:2px 8px;border-radius:999px;letter-spacing:.05em;text-transform:uppercase}
.kgl-tg-cta-sub{margin:0;font-size:13.5px;color:#4A5568;line-height:1.45}
.kgl-tg-cta-sub b{font-weight:700;color:#003F8C}
.kgl-tg-cta-btn{flex-shrink:0;font:inherit;font-size:15px;font-weight:800;color:#fff;background:linear-gradient(135deg,#229ED9 0%,#0088CC 100%);border:none;border-radius:10px;padding:13px 22px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;text-decoration:none;transition:transform .15s ease,box-shadow .15s ease;white-space:nowrap;box-shadow:0 4px 14px rgba(0,136,204,.30)}
.kgl-tg-cta-btn:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(0,136,204,.40);color:#fff}
.kgl-tg-cta-btn:focus-visible{outline:3px solid #0088CC;outline-offset:2px}
.kgl-tg-cta-btn svg{flex-shrink:0}
.kgl-tg-cta-perks{flex-basis:100%;margin:8px 0 0;font-size:12px;color:#6B7680;line-height:1.4;display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.kgl-tg-cta-perks span{display:inline-flex;align-items:center;gap:4px}
.kgl-tg-cta-perks span::before{content:"\2713";flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;background:#0088CC;color:#fff;border-radius:50%;font-size:9px;font-weight:900;line-height:1}
@media(max-width:680px){.kgl-tg-cta{padding:16px 18px;gap:14px}.kgl-tg-cta-btn{width:100%;justify-content:center}.kgl-tg-cta-text{min-width:auto}.kgl-tg-cta-perks{gap:10px;font-size:11.5px}}
