/* VISAXS — new design system (light-premium, one lime accent, ONE-BANK-grade). */
:root{
  --bg:#ffffff; --bg2:#eef1ea; --ink:#0d0f0b; --dim:#5c6058; --faint:#8b8f86;
  --line:#e6e8e1; --lime:#d9ff3f; --lime-d:#c6f21c; --card:#ffffff; --ink-soft:#1a1c18;
  --free:#16a34a; --arrival:#f59e0b; --evisa:#2563eb; --req:#e5484d; --none:#6b7280;
  --r:22px; --r-sm:14px; --sans:'Space Grotesk','Segoe UI',system-ui,sans-serif;
  --shadow:0 18px 50px -20px rgba(15,20,10,.28);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img,svg{display:block}
.wrap{max-width:1200px;margin:0 auto;padding-inline:clamp(18px,4vw,40px)}
.acc{color:var(--ink);background:var(--lime);border-radius:4px;padding:0 .12em}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:12px;font-weight:600;font-size:15px;border:none;cursor:pointer;transition:.22s;font-family:inherit}
.btn .ic{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;flex:none;transition:.22s}
.btn-dark{background:var(--ink);color:#fff;border-radius:100px;padding:8px 8px 8px 24px}
.btn-dark .ic{background:var(--lime);color:var(--ink)}
.btn-dark:hover{transform:translateY(-2px)}.btn-dark:hover .ic{transform:rotate(45deg)}
.btn-lime{background:var(--lime);color:var(--ink);border-radius:100px;padding:8px 8px 8px 24px}
.btn-lime .ic{background:var(--ink);color:var(--lime)}
.btn-lime:hover{transform:translateY(-2px)}.btn-lime:hover .ic{transform:rotate(45deg)}
.btn-ghost{border:1.5px solid var(--line);border-radius:100px;padding:12px 22px;color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink)}

/* header */
.hdr{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.82);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.hdr-in{display:flex;align-items:center;justify-content:space-between;gap:24px;padding-block:16px}
.logo{display:flex;align-items:center;gap:11px;font-weight:800;font-size:20px;letter-spacing:-.02em}
.logo .mark{width:30px;height:30px;border-radius:9px;background:var(--ink);display:grid;place-items:center}
.logo .mark span{width:12px;height:12px;border-radius:4px;background:var(--lime);display:block;transform:rotate(45deg)}
.nav{display:flex;align-items:center;gap:30px}
.nav a{font-size:14.5px;color:var(--dim);font-weight:500;transition:.2s}
.nav a:hover,.nav a.on{color:var(--ink)}
.hdr-r{display:flex;align-items:center;gap:14px}
.lang{display:inline-flex;border:1px solid var(--line);border-radius:100px;overflow:hidden;font-size:13px;font-weight:600}
.lang a{padding:7px 13px;color:var(--faint)}
.lang a.on{background:var(--ink);color:#fff}
/* mobile burger menu (pure CSS: hidden checkbox + :has). Closed = display:none so
   nothing sits off-canvas → no horizontal page scroll. Open = right panel + overlay. */
.mnav-cb,.burger,.nav-ov{display:none}
.nav-ov{position:fixed;top:0;left:0;width:100%;height:100dvh;background:rgba(15,17,20,.5);z-index:55}
@media(max-width:860px){
  .burger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:34px;height:34px;order:2;cursor:pointer;-webkit-tap-highlight-color:transparent}
  .burger span{display:block;height:2px;width:22px;margin:0 auto;background:var(--ink);border-radius:2px;transition:transform .25s,opacity .2s}
  .hdr-r{gap:10px}.lang{order:1}
  .nav{display:none}
  .hdr-in:has(.mnav-cb:checked) .nav-ov{display:block;animation:ovIn .22s ease both}
  .hdr-in:has(.mnav-cb:checked) .nav{display:flex;position:fixed;top:0;right:0;width:min(84vw,330px);height:100dvh;flex-direction:column;align-items:stretch;gap:2px;background:#fff;padding:90px 26px 28px;box-shadow:-24px 0 70px rgba(0,0,0,.18);z-index:60;animation:navIn .28s cubic-bezier(.4,0,.1,1) both}
  .nav a{font-size:17px;font-weight:600;color:var(--ink);padding:15px 4px;border-bottom:1px solid var(--line)}
  .nav a:last-child{border-bottom:0}
  .hdr-in:has(.mnav-cb:checked) .burger{position:relative;z-index:61}
  .hdr-in:has(.mnav-cb:checked) .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .hdr-in:has(.mnav-cb:checked) .burger span:nth-child(2){opacity:0}
  .hdr-in:has(.mnav-cb:checked) .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}
@keyframes navIn{from{transform:translateX(24px);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes ovIn{from{opacity:0}to{opacity:1}}

/* hero */
.hero{padding-block:clamp(36px,6vw,72px) clamp(30px,5vw,56px);display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,56px);align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:12.5px;font-weight:600;color:var(--dim);background:var(--bg2);border:1px solid var(--line);border-radius:100px;padding:7px 15px;margin-bottom:24px}
.eyebrow::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--free);box-shadow:0 0 0 4px rgba(22,163,74,.15)}
h1{font-size:clamp(42px,6.6vw,78px);font-weight:700;line-height:.98;letter-spacing:-.035em;overflow-wrap:break-word}
/* lime marker highlight — follows line wraps (works on long multi-line names) */
h1 .b{color:var(--ink);background:linear-gradient(transparent 60%,var(--lime) 60%,var(--lime) 92%,transparent 92%);-webkit-box-decoration-break:clone;box-decoration-break:clone;padding:0 .05em}
.hero .sub{color:var(--dim);font-size:clamp(15px,1.5vw,17.5px);margin-top:22px;max-width:46ch;line-height:1.6}

/* checker card */
.checker{margin-top:32px;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:22px}
.checker .row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:520px){.checker .row{grid-template-columns:1fr}}
.field label{display:block;font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--faint);margin:0 0 7px 2px}
.checker .go{margin-top:14px;width:100%;justify-content:space-between;font-size:16px;padding:8px 8px 8px 26px}
.checker .go .ic{margin-left:4px}

/* custom select */
.vsel{position:relative}
.vsel-trigger{display:flex;align-items:center;gap:10px;width:100%;background:var(--bg2);border:1px solid var(--line);border-radius:var(--r-sm);padding:13px 14px;cursor:pointer;transition:.18s;min-height:52px}
.vsel-trigger:hover,.vsel.open .vsel-trigger{border-color:var(--ink);background:#fff}
.vsel-trigger .fl{width:24px;height:18px;border-radius:3px;overflow:hidden;flex:none;box-shadow:0 0 0 1px rgba(0,0,0,.06)}
.vsel-trigger .txt{font-weight:600;font-size:15px;color:var(--ink);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vsel-trigger .txt.ph{color:var(--faint);font-weight:500}
.vsel-trigger .ar{color:var(--faint);transition:.2s}.vsel.open .vsel-trigger .ar{transform:rotate(180deg)}
.vsel-pop{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:30;background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:0 24px 60px -18px rgba(15,20,10,.35);overflow:hidden;display:none}
.vsel.open .vsel-pop{display:block}
.vsel-pop input{width:100%;border:none;border-bottom:1px solid var(--line);padding:13px 16px;font-family:inherit;font-size:14.5px;outline:none}
.vsel-list{max-height:260px;overflow-y:auto;overscroll-behavior:contain}
.vsel-opt{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;font-size:14.5px;font-weight:500}
.vsel-opt:hover,.vsel-opt.hl{background:var(--bg2)}
.vsel-opt .fl{width:22px;height:16px;border-radius:3px;overflow:hidden;flex:none;box-shadow:0 0 0 1px rgba(0,0,0,.06)}

/* hero result card (dark, the "product" widget) */
.hero-visual{position:relative}
.rcard{background:var(--ink);color:#fff;border-radius:26px;padding:28px;position:relative;overflow:hidden;min-height:300px;display:flex;flex-direction:column;justify-content:space-between}
.rcard::after{content:'';position:absolute;right:-60px;top:-60px;width:220px;height:220px;background:radial-gradient(circle,rgba(217,255,63,.22),transparent 65%)}
.rcard .rtop{display:flex;align-items:center;justify-content:space-between;position:relative;z-index:1}
.rcard .brand{font-weight:800;letter-spacing:1px;font-size:15px}
.rcard .brand b{color:var(--lime)}
.rcard .route{display:flex;align-items:center;gap:14px;position:relative;z-index:1;margin:8px 0}
.rcard .route .fl{width:56px;height:40px;border-radius:8px;overflow:hidden;box-shadow:0 0 0 1px rgba(255,255,255,.12)}
.rcard .route .fl.empty{background:rgba(255,255,255,.06)}
.rcard .route .arrow{color:var(--lime)}
.rcard .badge{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:14px;border-radius:100px;padding:8px 16px;align-self:flex-start;background:rgba(255,255,255,.08)}
.rcard .badge .dot{width:9px;height:9px;border-radius:50%;background:#fff}
.rcard .res-title{font-size:clamp(26px,3vw,34px);font-weight:700;letter-spacing:-.02em;line-height:1.05;position:relative;z-index:1}
.rcard .res-sub{color:rgba(255,255,255,.55);font-size:14px;margin-top:6px;position:relative;z-index:1}
.rcard .res-cta{position:relative;z-index:1;margin-top:6px;display:inline-flex;align-items:center;gap:8px;color:var(--lime);font-weight:600;font-size:14px}
.rcard .res-cta.hide{display:none}
.bubble{position:absolute;right:0;bottom:0;background:var(--lime);color:var(--ink);border-radius:20px 0 26px 0;padding:18px 26px 20px;z-index:2;white-space:nowrap;text-align:right}
.bubble b{display:block;font-size:30px;font-weight:700;line-height:1}
.bubble span{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-top:4px}
.rcard .res-title,.rcard .res-sub,.rcard .badge{max-width:calc(100% - 150px)}
@media(max-width:860px){.hero{grid-template-columns:1fr}.hero-visual{order:-1;display:none}}

/* sections */
.sec{padding-block:clamp(46px,7vw,84px)}
.sec.grey{background:var(--bg2)}
.sec-head{max-width:640px;margin-bottom:clamp(28px,4vw,44px)}
.sec-head.center{margin-inline:auto;text-align:center}
.sec h2{font-size:clamp(28px,4vw,44px);font-weight:700;letter-spacing:-.03em;line-height:1.02}
.sec .sec-sub{color:var(--dim);font-size:clamp(15px,1.5vw,17px);margin-top:14px;line-height:1.55}

/* visa types */
.types{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:860px){.types{grid-template-columns:repeat(2,1fr)}}
@media(max-width:460px){.types{grid-template-columns:1fr}}
.type-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:26px 22px;transition:.18s}
.type-card:hover{transform:translateY(-4px)}
.type-card .ic{width:52px;height:52px;border-radius:15px;display:grid;place-items:center;margin-bottom:18px}
.type-card h3{font-size:19px;font-weight:700;letter-spacing:-.01em}
.type-card p{color:var(--dim);font-size:14px;margin-top:8px;line-height:1.5}
.st-free .ic{background:rgba(22,163,74,.12);color:var(--free)} .st-free{border-top:3px solid var(--free)}
.st-arrival .ic{background:rgba(245,158,11,.12);color:var(--arrival)} .st-arrival{border-top:3px solid var(--arrival)}
.st-evisa .ic{background:rgba(37,99,235,.12);color:var(--evisa)} .st-evisa{border-top:3px solid var(--evisa)}
.st-req .ic{background:rgba(229,72,77,.12);color:var(--req)} .st-req{border-top:3px solid var(--req)}

/* passport comparison + practical info grids */
.cmp3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
@media(max-width:860px){.cmp3{grid-template-columns:1fr}}
.pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:760px){.pgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:420px){.pgrid{grid-template-columns:1fr}}
.docgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:760px){.docgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:460px){.docgrid{grid-template-columns:1fr}}

/* affiliate cards (destination-targeted booking/insurance/visa) */
.affgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:860px){.affgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:460px){.affgrid{grid-template-columns:1fr}}
.aff-card{display:flex;flex-direction:column;gap:9px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-sm);padding:20px;transition:.2s}
.aff-card:hover{border-color:var(--ink);transform:translateY(-3px)}
.aff-card .aff-ic{width:44px;height:44px;border-radius:12px;background:var(--bg2);display:grid;place-items:center;color:var(--ink);transition:.2s;margin-bottom:2px}
.aff-card:hover .aff-ic{background:var(--lime)}
.aff-card h3{font-size:16px;font-weight:700;letter-spacing:-.01em}
.aff-card p{font-size:13px;color:var(--dim);line-height:1.5;flex:1}
.aff-card .aff-go{display:inline-flex;align-items:center;gap:6px;font-size:13.5px;font-weight:600;color:var(--ink);margin-top:4px}
.aff-card .aff-go svg{transition:.2s}
.aff-card:hover .aff-go svg{transform:translateX(3px)}

/* popular routes */
.routes{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
@media(max-width:860px){.routes{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:520px){.routes{grid-template-columns:minmax(0,1fr)}.route-card .rt .nm{white-space:normal}}
.route-card{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-sm);padding:16px 18px;transition:.18s}
.route-card:hover{transform:translateY(-3px);border-color:transparent}
.route-card .fls{display:flex;align-items:center;gap:6px;flex:none}
.route-card .fl{width:30px;height:22px;border-radius:4px;overflow:hidden;box-shadow:0 0 0 1px rgba(0,0,0,.06)}
.route-card .fls .a{color:var(--faint);font-size:13px}
.route-card .rt{flex:1;min-width:0;display:flex;flex-direction:column}
.route-card .rt .nm{font-weight:600;font-size:14.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.route-card .rt .st{font-size:12.5px;font-weight:600;margin-top:2px}
.route-card .go{color:var(--faint);flex:none}
.stc-free{color:var(--free)}.stc-arrival{color:var(--arrival)}.stc-evisa{color:var(--evisa)}.stc-req{color:var(--req)}

/* trust */
.trust{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:640px){.trust{grid-template-columns:1fr}}
.trust .t{border-left:2px solid var(--lime);padding-left:18px}
.trust .t b{display:block;font-size:clamp(30px,4vw,44px);font-weight:700;letter-spacing:-.02em}
.trust .t span{color:var(--dim);font-size:13px;text-transform:uppercase;letter-spacing:.06em}
/* passport hero stat row — 4 up on desktop, 2×2 on mobile */
.pstat{grid-template-columns:repeat(4,1fr)}
@media(max-width:700px){.pstat{grid-template-columns:repeat(2,1fr)!important;gap:22px 16px!important}}

/* faq */
.faq{max-width:800px}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{list-style:none;cursor:pointer;padding:22px 44px 22px 0;position:relative;font-size:18px;font-weight:600}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';position:absolute;right:8px;top:19px;font-size:26px;font-weight:400;color:var(--faint);transition:.2s}
.faq details[open] summary::after{content:'\2212';color:var(--ink)}
.faq .a{color:var(--dim);font-size:15px;line-height:1.7;padding:0 0 22px;max-width:70ch}

/* cta band */
.cta-band{background:var(--ink);color:#fff;border-radius:var(--r);padding:clamp(30px,4vw,52px);display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap;position:relative;overflow:hidden}
.cta-band::after{content:'';position:absolute;left:-40px;bottom:-80px;width:280px;height:280px;background:radial-gradient(circle,rgba(217,255,63,.18),transparent 65%)}
.cta-band h2{color:#fff;position:relative;z-index:1}
.cta-band p{color:rgba(255,255,255,.6);margin-top:10px;position:relative;z-index:1}

/* footer */
.foot{background:var(--ink);color:#fff;padding-block:clamp(40px,5vw,64px) 30px;margin-top:4px}
.foot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:34px;padding-bottom:30px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot .logo{color:#fff}.foot .logo .mark{background:var(--lime)}.foot .logo .mark span{background:var(--ink)}
.foot-brand{max-width:36ch}
.foot-tag{color:rgba(255,255,255,.5);font-size:14px;margin-top:12px}
.foot-upd{color:rgba(255,255,255,.4);font-size:12.5px;margin-top:14px}
.foot-col h4{font-size:11.5px;text-transform:uppercase;letter-spacing:.07em;color:rgba(255,255,255,.42);margin-bottom:12px;font-weight:700}
.foot-col a{display:block;color:rgba(255,255,255,.62);font-size:13.5px;padding:5px 0;transition:.14s}
.foot-col a:hover{color:var(--lime)}
.foot-bot{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:22px;color:rgba(255,255,255,.35);font-size:12px}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr 1fr}.foot-brand{grid-column:1/-1;max-width:none}}
@media(max-width:440px){.foot-grid{grid-template-columns:1fr}}
.foot-legal{display:flex;flex-wrap:wrap;gap:8px 20px;padding-top:22px;font-size:13px}
.foot-legal a{color:rgba(255,255,255,.55)}.foot-legal a:hover{color:var(--lime)}

/* legal / info pages */
.legal-wrap{padding-block:clamp(28px,5vw,52px) clamp(48px,6vw,80px)}
.crumbs{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--muted);margin-bottom:22px;flex-wrap:wrap}
.crumbs a{color:var(--muted)}.crumbs a:hover{color:var(--ink)}.crumbs .cur{color:var(--ink);font-weight:600}
.legal{max-width:760px}
.legal h1{font-size:clamp(30px,4.5vw,46px);line-height:1.05;letter-spacing:-.02em;margin-bottom:14px}
.legal-intro{font-size:18px;color:var(--muted);margin-bottom:8px;max-width:60ch}
.legal-upd{font-size:13px;color:var(--muted);margin-bottom:6px}
.legal h2{font-size:22px;letter-spacing:-.01em;margin:38px 0 12px}
.legal h3{font-size:16px;margin:24px 0 8px;font-weight:600}
.legal p{color:#33372f;line-height:1.72;margin-bottom:14px}
.legal a{color:var(--ink);text-decoration:underline;text-underline-offset:2px;text-decoration-color:var(--line)}
.legal a:hover{text-decoration-color:var(--ink)}
.legal-ul{margin:6px 0 16px;padding-left:0;list-style:none}
.legal-ul li{position:relative;padding-left:24px;margin-bottom:8px;color:#33372f;line-height:1.6}
.legal-ul li::before{content:"";position:absolute;left:6px;top:9px;width:7px;height:7px;background:var(--lime);border-radius:2px;transform:rotate(45deg)}
.legal-note{background:var(--card);border:1px solid var(--line);border-left:4px solid var(--lime);border-radius:12px;padding:16px 18px;margin:16px 0 22px;line-height:1.6;color:#33372f}
.legal-defs{display:grid;gap:10px;margin:8px 0 20px}
.ldef{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.ldef strong{display:block;margin-bottom:3px;font-size:15px}
.ldef span{color:var(--muted);font-size:14px;line-height:1.55}
.legal-email{background:var(--ink);color:#fff!important;border-radius:12px;padding:14px 18px;margin-top:8px}
.legal-email a{color:var(--lime);text-decoration:none}
.author-card{display:flex;gap:18px;align-items:flex-start;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:22px;margin:8px 0 22px}
.author-av{flex:none;width:72px;height:72px;border-radius:16px;background:var(--lime);color:var(--ink);display:grid;place-items:center;font-size:30px;font-weight:700;object-fit:cover;overflow:hidden}
img.author-av{object-fit:cover}
.author-name{font-size:18px;font-weight:700}
.author-role{color:var(--muted);font-size:14px;margin-bottom:10px}
.author-body p{margin:0 0 14px}
.author-link{display:inline-flex;align-items:center;gap:9px;background:var(--ink);color:var(--lime)!important;padding:10px 16px;border-radius:10px;font-size:14px;font-weight:600;text-decoration:none!important}
.author-link:hover{opacity:.9}
.legal-rel{margin-top:44px;padding-top:26px;border-top:1px solid var(--line);max-width:760px}
.legal-rel h2{font-size:15px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:14px}
.rel-links{display:flex;flex-wrap:wrap;gap:10px}
.rel-links a{display:inline-flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);border-radius:10px;padding:9px 14px;font-size:14px;transition:.14s}
.rel-links a:hover{border-color:transparent;transform:translateY(-1px)}
.rel-links a span{color:var(--muted)}
.author-card{flex-wrap:wrap}

/* AdSense unit */
.ad-wrap{margin-block:clamp(18px,3vw,30px)}
.ad-wrap ins{display:block;min-height:100px;overflow:hidden}

/* how-to steps (homepage) */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.step{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:24px;position:relative}
.step-n{width:38px;height:38px;border-radius:11px;background:var(--lime);color:var(--ink);display:grid;place-items:center;font-weight:700;font-size:18px;margin-bottom:15px}
.step h3{font-size:17px;margin-bottom:6px;letter-spacing:-.01em}
.step p{color:var(--muted);font-size:14.5px;line-height:1.55}
@media(max-width:720px){.steps{grid-template-columns:1fr}}

/* all-passports hub grid */
.cgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:10px}
.cchip{display:flex;align-items:center;gap:11px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:11px 14px;transition:.14s}
.cchip:hover{border-color:transparent;transform:translateY(-2px)}
.cchip .fl{width:26px;height:19px;border-radius:4px;overflow:hidden;flex:none;box-shadow:0 0 0 1px rgba(0,0,0,.06)}
.cchip .nm{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hubsearch{width:100%;max-width:440px;margin-top:22px;padding:14px 18px;border:1px solid var(--line);border-radius:100px;font-family:inherit;font-size:15px;outline:none;background:var(--bg2)}
.hubsearch:focus{border-color:var(--ink);background:#fff}

/* data table (full destination lists — crisp, scannable) */
.vtable{background:var(--card);border:1px solid var(--line);border-radius:var(--r-sm);overflow-x:auto;-webkit-overflow-scrolling:touch}
.vtable .vrow{display:grid;grid-template-columns:30px 1fr auto 18px;align-items:center;gap:14px;padding:13px 18px;border-bottom:1px solid var(--line);transition:background .14s;min-width:380px}
.vtable .vrow:last-child{border-bottom:none}
.vtable .vrow:hover{background:var(--bg2)}
.vtable .fl{width:28px;height:20px;border-radius:4px;overflow:hidden;flex:none;box-shadow:0 0 0 1px rgba(0,0,0,.06)}
.vtable .nm{font-weight:600;font-size:14.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vtable .dy{font-size:13px;color:var(--dim);font-variant-numeric:tabular-nums;text-align:right;white-space:nowrap}
.vtable .go{color:var(--faint);text-align:center}
.vtable .vrow:hover .go{color:var(--ink)}
.tbl-cols{grid-template-columns:1fr 1fr!important}

/* passport ranking table (passport index page) */
.rtable{background:var(--card);border:1px solid var(--line);border-radius:var(--r-sm);overflow-x:auto;-webkit-overflow-scrolling:touch}
.rtable #cgrid{min-width:700px}
.rtable .rrow{display:grid;grid-template-columns:56px 1fr 84px 96px 88px 78px;align-items:center;gap:12px;padding:12px 18px;border-bottom:1px solid var(--line);transition:background .14s;min-width:700px}
.rtable .rhead .num i.hd{display:inline-block;width:8px;height:8px;border-radius:2px;margin-right:6px;vertical-align:middle}
.rtable .rhead .n-free{background:var(--free)}.rtable .rhead .n-easy{background:var(--arrival)}.rtable .rhead .n-req{background:#cdd3c2}
.rtable #cgrid .rrow:last-child{border-bottom:none}
.rtable .rrow:hover{background:var(--bg2)}
.rtable .rhead{background:var(--bg2);border-bottom:1px solid var(--line)}
.rtable .rhead span{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--faint)}
.rtable .rk{font-weight:700;font-size:16px;font-variant-numeric:tabular-nums;color:var(--dim)}
.rtable .rk.top{color:var(--ink)}
.rtable .rhead .rk{font-size:11px}
.rtable .cy{display:flex;align-items:center;gap:11px;min-width:0}
.rtable .cy .fl{width:28px;height:20px;border-radius:4px;overflow:hidden;flex:none;box-shadow:0 0 0 1px rgba(0,0,0,.06)}
.rtable .cy .nm{font-weight:600;font-size:14.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rtable .num{font-weight:600;font-size:14px;text-align:right;font-variant-numeric:tabular-nums;color:var(--ink)}
.rtable .rhead .cy,.rtable .rhead .num{font-weight:700}
.rtable .num.sc{color:var(--dim)}
@media(max-width:640px){ .rtable .rrow{padding:12px 14px} }
/* ranking: at-a-glance stats + mobility bar + legend */
.glance{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.glance .g{background:var(--card);border:1px solid var(--line);border-radius:var(--r-sm);padding:16px 18px}
.glance .g b{display:block;font-size:clamp(22px,3vw,30px);font-weight:700;letter-spacing:-.02em;line-height:1;color:var(--ink)}
.glance .g span{display:block;margin-top:6px;font-size:12.5px;color:var(--dim)}
@media(max-width:640px){.glance{grid-template-columns:repeat(2,1fr)}}
.mslegend{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:12px;font-size:12.5px;color:var(--dim)}
.mslegend span{display:inline-flex;align-items:center;gap:7px}
.mslegend i{width:11px;height:11px;border-radius:3px;display:block}
.mslegend .d-free{background:var(--free)}.mslegend .d-easy{background:var(--arrival)}.mslegend .d-req{background:#cdd3c2}
.rtable .cy .cyi{display:flex;flex-direction:column;gap:6px;min-width:0}
.rtable .msbar{display:flex;height:6px;width:170px;max-width:100%;border-radius:3px;overflow:hidden;background:#cdd3c2}
.rtable .msbar i{display:block;height:100%}
.rtable .msbar .f{background:var(--free)}.rtable .msbar .e{background:var(--arrival)}
@media(max-width:760px){.tbl-cols{grid-template-columns:1fr!important;display:block}}
.rise{opacity:0;transform:translateY(16px);animation:rise .7s cubic-bezier(.2,.7,.2,1) forwards}
.rise.d1{animation-delay:.05s}.rise.d2{animation-delay:.12s}.rise.d3{animation-delay:.18s}
@keyframes rise{to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.rise{animation:none;opacity:1;transform:none}}
