
/* ============================================================
   RESET & BASE
============================================================ */
*{box-sizing:border-box;margin:0;padding:0;}
html{overflow-x:hidden;scroll-behavior:smooth;}
body{
  font-family:'Plus Jakarta Sans',sans-serif;
  background:#F5F7FA;color:#111827;line-height:1.6;
  overflow-x:hidden;
}

/* ============================================================
   DESIGN TOKENS
============================================================ */
:root{
  --navy:#0B1F3A;--navy2:#132D50;
  --teal:#0EA5C8;--teal-light:#E0F5FB;--teal-dark:#0880A0;
  --rose:#F43F87;--rose-light:#FEE8F2;
  --white:#FFFFFF;
  --grey-50:#F5F7FA;--grey-100:#EEF1F6;--grey-200:#DDE2EC;
  --grey-300:#B8C0D0;--grey-400:#9AA3B0;--grey-500:#6B7A96;--grey-700:#374151;--grey-900:#111827;
  --green:#16A34A;--amber:#D97706;
  --shadow-sm:0 1px 4px rgba(11,31,58,.06);
  --shadow-md:0 4px 16px rgba(11,31,58,.10);
  --shadow-lg:0 8px 32px rgba(11,31,58,.14);
  --radius-sm:8px;--radius-md:12px;--radius-lg:18px;--radius-xl:24px;
}

/* ============================================================
   PAGE SWITCHER
============================================================ */
.page{display:none;}
.page.active{display:block;animation:fadeUp .25s ease both;}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ============================================================
   TOP NAV — responsive, centred menu
============================================================ */

/* Topbar: CSS grid 3-col on desktop, flex on mobile */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:64px;
  background:#fff;
  border-bottom:1.5px solid var(--grey-200);
  display:flex;align-items:center;
  padding:0 max(12px,env(safe-area-inset-left)) 0 max(12px,env(safe-area-inset-right));
  gap:0;
  /* overflow:hidden; */
}
/* On desktop switch to 3-col grid so centre column is truly centred */
@media(min-width:900px){
  .topbar{
    display:grid;
    grid-template-columns:auto 1fr auto;
    align-items:center;
    padding:0 20px;
    gap:0;
  }
}

/* ── Logo ── */
.logo-mark{
  display:flex;align-items:center;gap:8px;
  flex-shrink:0;border:none;background:none;
  cursor:pointer;padding:0;text-decoration:none;
  grid-column:1;
}
.logo-icon{
  width:36px;height:36px;background:var(--navy);
  border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  font-size:15px;font-weight:800;color:var(--teal);font-family:'Lora',serif;
}
.logo-text{font-size:15px;font-weight:700;color:var(--navy);white-space:nowrap;}
.logo-text span{color:var(--teal);}

/* ── Centre nav — column 2 ── */
.nav-links{
  display:none;
}
@media(min-width:900px){
  .nav-links{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:0;
    grid-column:2;
    overflow:hidden;
    min-width:0;
  }
}
.nav-link{
  background:none;border:none;
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:13px;font-weight:500;color:var(--grey-500);
  padding:6px 8px;border-radius:var(--radius-sm);
  cursor:pointer;white-space:nowrap;transition:all .15s;
  flex-shrink:0;
}
/* Shrink text slightly on medium screens */
@media(min-width:900px) and (max-width:1200px){
  .nav-link{font-size:12px;padding:6px 6px;}
}
.nav-link:hover{color:var(--navy);background:var(--grey-100);}
.nav-link.active{color:var(--teal);font-weight:700;background:var(--teal-light);}

/* ── Auth buttons — column 3 ── */
.nav-auth{
  display:none;
  grid-column:3;
}
@media(min-width:900px){
  .nav-auth{
    display:flex;
    align-items:center;
    gap:6px;
    flex-shrink:0;
    justify-content:flex-end;
  }
}
/* Shrink auth buttons on medium screens */
.nav-btn-employer{
  height:34px;padding:0 10px;
  border-radius:var(--radius-sm);
  border:1.5px solid var(--grey-300);
  background:#fff;color:var(--grey-700);
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:12px;font-weight:600;
  cursor:pointer;white-space:nowrap;transition:all .2s;
}
.nav-btn-employer:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-light);}
@media(min-width:1200px){.nav-btn-employer{padding:0 13px;font-size:12.5px;}}

.nav-btn-candidate{
  height:34px;padding:0 10px;
  border-radius:var(--radius-sm);
  border:none;background:var(--navy);color:#fff;
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:12px;font-weight:700;
  cursor:pointer;white-space:nowrap;transition:background .2s;
}
.nav-btn-candidate:hover{background:var(--navy2);}
@media(min-width:1200px){.nav-btn-candidate{padding:0 13px;font-size:12.5px;}}

.nav-btn-join{
  height:34px;padding:0 11px;
  border-radius:var(--radius-sm);
  border:none;background:var(--teal);color:#fff;
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:12px;font-weight:800;
  cursor:pointer;white-space:nowrap;transition:all .2s;
}
.nav-btn-join:hover{background:var(--teal-dark);box-shadow:0 3px 10px rgba(14,165,200,.3);}
@media(min-width:1200px){.nav-btn-join{padding:0 14px;font-size:12.5px;}}

/* ── Mobile right side ── */
.nav-spacer{flex:1;}

.nav-join-mobile{
  display:flex;align-items:center;justify-content:center;
  height:32px;padding:0 12px;
  border-radius:var(--radius-sm);border:none;
  background:var(--teal);color:#fff;
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:12px;font-weight:800;
  cursor:pointer;white-space:nowrap;flex-shrink:0;
  transition:background .15s;
}
.nav-join-mobile:hover{background:var(--teal-dark);}
@media(min-width:900px){.nav-join-mobile{display:none!important;}}

/* ── Hamburger ── */
.hamburger{
  display:flex;flex-direction:column;
  justify-content:center;align-items:center;
  gap:5px;width:40px;height:40px;
  background:none;border:none;cursor:pointer;
  border-radius:var(--radius-sm);
  transition:background .15s;
  margin-left:6px;flex-shrink:0;
}
.hamburger:hover{background:var(--grey-100);}
.hamburger span{
  display:block;width:22px;height:2.5px;
  background:var(--navy);border-radius:2px;
  transition:all .28s ease;
}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0);}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
@media(min-width:900px){.hamburger{display:none;}}

/* ── Mobile full-screen menu ── */
.mobile-menu{
  display:none;
  position:fixed;top:64px;left:0;right:0;
  height:calc(100dvh - 64px);
  height:calc(100vh - 64px);
  z-index:999;background:#fff;
  overflow-y:auto;flex-direction:column;
  border-top:1px solid var(--grey-200);
  -webkit-overflow-scrolling:touch;
}
.mobile-menu.open{display:flex;}
@media(min-width:900px){.mobile-menu{display:none!important;}}

.mobile-menu-inner{
  padding:6px 0 48px;
  display:flex;flex-direction:column;flex:1;
}
.mobile-nav-link{
  display:flex;align-items:center;gap:14px;
  padding:14px 20px;background:none;border:none;
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:15px;font-weight:600;color:var(--grey-700);
  cursor:pointer;text-align:left;width:100%;
  transition:all .15s;border-left:3px solid transparent;
}
.mobile-nav-link:hover{background:var(--grey-50);color:var(--navy);}
.mobile-nav-link.active{
  color:var(--teal);background:var(--teal-light);
  border-left-color:var(--teal);
}
.mobile-nav-icon{font-size:18px;width:28px;text-align:center;flex-shrink:0;}
.mobile-menu-divider{height:1px;background:var(--grey-200);margin:8px 20px 4px;}
.mobile-menu-auth{display:flex;flex-direction:column;gap:10px;padding:8px 20px 0;}
.mobile-menu-btn{
  height:50px;border-radius:var(--radius-md);
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:15px;font-weight:700;
  cursor:pointer;width:100%;border:none;
  display:flex;align-items:center;justify-content:center;
  gap:8px;transition:all .15s;
}
.mmb-teal{background:var(--teal);color:#fff;}
.mmb-teal:hover{background:var(--teal-dark);}
.mmb-outline{background:#fff;color:var(--navy);border:1.5px solid var(--grey-300)!important;}
.mmb-outline:hover{border-color:var(--navy)!important;background:var(--grey-50);}
.mmb-navy{background:var(--navy);color:#fff;}
.mmb-navy:hover{background:var(--navy2);}

/* subnav — hidden */
.subnav{display:none;}
.subnav-btn{display:none;}

/* utility btn-ghost / btn-primary — non-nav */
.btn-ghost{
  height:36px;padding:0 16px;border-radius:var(--radius-sm);
  font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:600;
  border:1.5px solid var(--grey-200);background:#fff;color:var(--grey-700);
  cursor:pointer;transition:all .15s;white-space:nowrap;
}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal);}
.btn-primary{
  height:36px;padding:0 16px;border-radius:var(--radius-sm);
  font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:700;
  border:none;background:var(--navy);color:#fff;
  cursor:pointer;transition:all .15s;white-space:nowrap;
}
.btn-primary:hover{background:var(--navy2);}

/* ============================================================
   BODY OFFSET
============================================================ */
body{padding-top:64px;}
@media(max-width:899px){body{padding-bottom:58px;}}

/* ============================================================
   BOTTOM TAB BAR (mobile only)
============================================================ */
.tabbar{
  position:fixed;bottom:0;left:0;right:0;z-index:900;
  background:#fff;border-top:1px solid var(--grey-200);
  display:flex;padding-bottom:env(safe-area-inset-bottom);
}
.tab{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;padding:8px 2px;background:none;border:none;cursor:pointer;
  font-family:'Plus Jakarta Sans',sans-serif;transition:all .15s;min-width:0;
}
.tab-icon{font-size:20px;line-height:1;display:block;}
.tab-label{
  font-size:9px;font-weight:600;color:var(--grey-400);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;
  line-height:1.2;
}
.tab.active .tab-icon{filter:drop-shadow(0 0 3px rgba(14,165,200,.4));}
.tab.active .tab-label{color:var(--teal);font-weight:700;}
@media(min-width:900px){.tabbar{display:none;}body{padding-bottom:0;}}

/* ============================================================
   SHARED LAYOUT
============================================================ */
.container{max-width:1100px;margin:0 auto;padding:0 12px;}
@media(min-width:400px){.container{padding:0 16px;}}
@media(min-width:640px){.container{padding:0 24px;}}
@media(min-width:1140px){.container{padding:0 20px;}}

.section{padding:44px 0;}
.section-bg{background:#fff;}
.section-alt{background:var(--grey-50);}

.section-label{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--teal);margin-bottom:8px;}
.section-title{font-family:'Lora',serif;font-size:clamp(19px,4.5vw,30px);font-weight:700;color:var(--navy);line-height:1.2;margin-bottom:10px;}
.section-sub{font-size:14px;color:var(--grey-500);line-height:1.7;max-width:540px;}

/* Responsive grid helpers */
.grid-2{display:grid;grid-template-columns:1fr;gap:16px;}
.grid-3{display:grid;grid-template-columns:1fr;gap:16px;}
.grid-4{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
@media(min-width:560px){.grid-2{grid-template-columns:1fr 1fr;}}
@media(min-width:700px){.grid-3{grid-template-columns:repeat(3,1fr);}}
@media(min-width:900px){.grid-4{grid-template-columns:repeat(4,1fr);}}

.card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--grey-200);box-shadow:var(--shadow-sm);}

/* Buttons */
.btn-lg{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  height:46px;padding:0 18px;border-radius:var(--radius-md);
  font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:700;
  border:none;cursor:pointer;transition:all .2s;white-space:nowrap;
  max-width:100%;
}
@media(min-width:400px){.btn-lg{height:48px;padding:0 24px;font-size:14px;}}
.btn-navy{background:var(--navy);color:#fff;}
.btn-navy:hover{background:var(--navy2);transform:translateY(-1px);}
.btn-teal{background:var(--teal);color:#fff;}
.btn-teal:hover{background:var(--teal-dark);transform:translateY(-1px);}
.btn-rose{background:var(--rose);color:#fff;}
.btn-outline{background:#fff;color:var(--navy);border:2px solid var(--grey-200);}
.btn-outline:hover{border-color:var(--navy);}
.btn-outline-white{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.4);}
.btn-outline-white:hover{background:rgba(255,255,255,.1);}

/* Chips */
.chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;}
.chip-teal{background:var(--teal-light);color:var(--teal-dark);}
.chip-green{background:#DCFCE7;color:var(--green);}
.chip-rose{background:var(--rose-light);color:var(--rose);}
.stars{color:#F59E0B;font-size:12px;letter-spacing:1px;}
.divider{height:1px;background:var(--grey-200);margin:24px 0;}

/* FAQ */
.faq{display:flex;flex-direction:column;}
.faq-row{border-bottom:1px solid var(--grey-200);}
.faq-q{
  width:100%;background:none;border:none;
  padding:16px 0;display:flex;justify-content:space-between;align-items:center;gap:12px;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;font-weight:600;color:var(--navy);
  cursor:pointer;text-align:left;
}
.faq-plus{
  width:24px;height:24px;border-radius:50%;min-width:24px;
  border:1.5px solid var(--grey-300);background:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:16px;color:var(--grey-500);flex-shrink:0;transition:all .2s;
}
.faq-row.open .faq-plus{background:var(--teal);border-color:var(--teal);color:#fff;transform:rotate(45deg);}
.faq-a{display:none;padding:0 0 16px;font-size:13px;color:var(--grey-500);line-height:1.75;}
.faq-row.open .faq-a{display:block;}

/* ============================================================
   HOME HERO — light theme
============================================================ */
.hero{
  background:linear-gradient(155deg,#EBF7FC 0%,#F0F9FF 40%,#FDF5FF 100%);
  padding:44px 0 0;overflow:hidden;position:relative;
  border-bottom:1px solid var(--grey-200);
}
.hero-bg-circle{
  position:absolute;top:-80px;right:-80px;width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(14,165,200,.10),transparent 68%);pointer-events:none;
}
.hero-bg-circle2{
  position:absolute;bottom:-60px;left:-60px;width:250px;height:250px;border-radius:50%;
  background:radial-gradient(circle,rgba(244,63,135,.06),transparent 70%);pointer-events:none;
}
.hero-inner{
  max-width:1100px;margin:0 auto;padding:0 16px;
  display:grid;grid-template-columns:1fr;gap:32px;position:relative;z-index:1;
}
@media(min-width:640px){.hero-inner{padding:0 24px;}}
@media(min-width:900px){.hero-inner{grid-template-columns:1fr 1fr;align-items:center;gap:40px;}}

.hero-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--teal-light);border:1px solid rgba(14,165,200,.25);
  color:var(--teal-dark);font-size:11px;font-weight:700;
  padding:5px 13px;border-radius:20px;letter-spacing:.5px;
  text-transform:uppercase;margin-bottom:16px;
}
.hero-badge::before{content:'';width:6px;height:6px;background:var(--teal);border-radius:50%;animation:blink 2s infinite;}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

.hero h1{
  font-family:'Lora',serif;font-size:clamp(26px,5vw,46px);
  font-weight:700;color:var(--navy);line-height:1.1;margin-bottom:14px;
}
.hero h1 em{color:var(--teal);font-style:italic;}
.hero-desc{font-size:15px;color:var(--grey-500);line-height:1.75;margin-bottom:22px;max-width:460px;}

.hero-search{
  display:flex;background:#fff;border-radius:var(--radius-md);
  overflow:hidden;box-shadow:0 2px 16px rgba(14,165,200,.15);
  border:1.5px solid var(--grey-200);margin-bottom:18px;
}
.hero-search input{
  flex:1;border:none;outline:none;padding:0 14px;height:50px;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--grey-900);
  background:transparent;min-width:0;
}
.hero-search input::placeholder{color:var(--grey-300);}
.hero-search-btn{
  height:50px;padding:0 14px;background:var(--teal);border:none;color:#fff;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;font-weight:700;
  cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .15s;
  min-width:72px;
}
@media(min-width:400px){.hero-search-btn{padding:0 18px;font-size:13px;}}
.hero-search-btn:hover{background:var(--teal-dark);}
.hero-cta-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px;}
.hero-tags{display:flex;gap:8px;flex-wrap:wrap;}
.hero-tag{
  background:#fff;border:1.5px solid var(--grey-200);
  color:var(--grey-500);font-size:12px;font-weight:600;
  padding:4px 12px;border-radius:20px;
}

/* Hero stat cards */
.hero-visual{display:flex;flex-direction:column;gap:12px;padding-bottom:36px;}
@media(min-width:900px){.hero-visual{padding-bottom:0;}}
.stat-card{
  background:#fff;border:1.5px solid var(--grey-200);
  border-radius:var(--radius-lg);padding:14px 16px;box-shadow:var(--shadow-sm);
  min-width:0;
}
.stat-card-row{display:flex;align-items:center;gap:14px;}
.stat-icon{
  width:44px;height:44px;min-width:44px;border-radius:var(--radius-sm);
  background:var(--teal-light);display:flex;align-items:center;justify-content:center;font-size:22px;
}
.stat-num{font-family:'Lora',serif;font-size:24px;font-weight:700;color:var(--navy);line-height:1;}
.stat-lbl{font-size:12px;color:var(--grey-500);margin-top:3px;}
.stat-card.highlight{background:var(--teal-light);border-color:rgba(14,165,200,.3);}
.stat-card.highlight .stat-num{color:var(--teal-dark);}

/* ============================================================
   HOME FEATURED PROFILES — 5-col grid
============================================================ */
.home-featured-grid{
  display:grid;gap:14px;
  grid-template-columns:repeat(2,1fr);
}
@media(min-width:480px){.home-featured-grid{grid-template-columns:repeat(3,1fr);}}
@media(min-width:700px){.home-featured-grid{grid-template-columns:repeat(4,1fr);}}
@media(min-width:1000px){.home-featured-grid{grid-template-columns:repeat(5,1fr);}}
.home-featured-grid .nanny-card{width:auto;}

/* Nanny card (used in home featured) */
.nanny-card{
  background:#fff;border-radius:var(--radius-lg);border:1px solid var(--grey-200);
  overflow:hidden;cursor:pointer;transition:all .2s;box-shadow:var(--shadow-sm);
}
.nanny-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);}
.nanny-img{
  height:110px;background:var(--grey-100);
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.nanny-img img{width:100%;height:100%;object-fit:cover;}
.nanny-img-fallback{font-size:40px;}
.avail-badge{
  position:absolute;top:7px;right:7px;font-size:9px;font-weight:700;
  padding:2px 7px;border-radius:20px;color:#fff;
}
.avail-green{background:var(--green);}
.avail-amber{background:var(--amber);}
.nanny-body{padding:10px 12px 12px;}
.nanny-name{font-size:12px;font-weight:700;color:var(--navy);margin-bottom:1px;}
.nanny-role{font-size:10px;color:var(--grey-500);margin-bottom:7px;}
.nanny-chips{display:flex;gap:3px;flex-wrap:wrap;margin-bottom:7px;}
.nanny-chip{font-size:9px;font-weight:700;padding:2px 6px;border-radius:4px;background:var(--teal-light);color:var(--teal-dark);}
.nanny-footer{display:flex;justify-content:space-between;align-items:center;}
.nanny-rating{font-size:11px;font-weight:600;color:var(--grey-700);}
.nanny-loc{font-size:10px;color:var(--grey-500);}

/* ============================================================
   HOME PROCESS STEPS
============================================================ */
.steps-wrap{
  display:grid;grid-template-columns:1fr 1fr;gap:12px;
}
@media(min-width:900px){.steps-wrap{grid-template-columns:repeat(4,1fr);}}
.step{
  display:flex;flex-direction:column;gap:10px;padding:18px 16px;
  background:#fff;border-radius:var(--radius-lg);
  border:1.5px solid var(--grey-200);box-shadow:var(--shadow-sm);
  transition:all .2s;
}
.step:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}
.step-num{
  width:38px;height:38px;min-width:38px;border-radius:var(--radius-sm);
  background:var(--teal-light);color:var(--teal-dark);
  font-family:'Lora',serif;font-size:17px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  border:1.5px solid rgba(14,165,200,.2);
}
.step-body .step-title{font-size:13px;font-weight:700;color:var(--navy);margin-bottom:4px;}
.step-body .step-desc{font-size:12px;color:var(--grey-500);line-height:1.6;}

/* ============================================================
   TESTIMONIALS / ARTICLES / SUPPORT
============================================================ */
.testi-card{
  background:#fff;border-radius:var(--radius-lg);
  border:1px solid var(--grey-200);padding:20px 18px;box-shadow:var(--shadow-sm);
}
.testi-text{font-size:13px;color:var(--grey-700);line-height:1.75;margin:10px 0 14px;font-style:italic;}
.testi-author{display:flex;align-items:center;gap:10px;}
.testi-av{
  width:38px;height:38px;min-width:38px;border-radius:50%;
  background:var(--navy);display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:700;color:#fff;
}
.testi-name{font-size:13px;font-weight:700;color:var(--navy);}
.testi-role{font-size:11px;color:var(--grey-500);}

.art-card{
  display:flex;gap:14px;padding:14px;background:#fff;
  border-radius:var(--radius-lg);border:1px solid var(--grey-200);
  text-decoration:none;color:inherit;transition:all .2s;box-shadow:var(--shadow-sm);
}
.art-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}
.art-icon{
  width:52px;height:52px;min-width:52px;border-radius:var(--radius-sm);
  background:var(--teal-light);display:flex;align-items:center;justify-content:center;font-size:22px;
}
.art-cat{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--teal);margin-bottom:3px;}
.art-title{font-size:13px;font-weight:700;color:var(--navy);line-height:1.35;margin-bottom:3px;}
.art-meta{font-size:11px;color:var(--grey-500);}

.supp-card{
  background:#fff;border-radius:var(--radius-lg);
  border:1px solid var(--grey-200);padding:16px 14px;box-shadow:var(--shadow-sm);
}
.supp-icon{
  width:38px;height:38px;border-radius:var(--radius-sm);
  background:var(--teal-light);display:flex;align-items:center;justify-content:center;
  font-size:17px;margin-bottom:10px;
}
.supp-title{font-size:13px;font-weight:700;color:var(--navy);margin-bottom:4px;}
.supp-info{font-size:11.5px;color:var(--grey-500);line-height:1.5;margin-bottom:10px;}
.supp-btn{
  height:30px;padding:0 12px;border-radius:var(--radius-sm);
  background:var(--navy);color:#fff;border:none;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:11px;font-weight:600;cursor:pointer;
}

/* ============================================================
   CTA BAND
============================================================ */
.cta-band{
  background:var(--navy);padding:44px 0;position:relative;overflow:hidden;text-align:center;
}
.cta-band::before{
  content:'';position:absolute;top:-60px;left:50%;transform:translateX(-50%);
  width:600px;height:300px;border-radius:50%;
  background:radial-gradient(circle,rgba(14,165,200,.12),transparent 70%);
}
.cta-band h2{font-family:'Lora',serif;font-size:clamp(22px,4vw,34px);color:#fff;margin-bottom:10px;position:relative;}
.cta-band p{font-size:14px;color:rgba(255,255,255,.6);margin-bottom:24px;position:relative;max-width:480px;margin-left:auto;margin-right:auto;padding:0 16px;}
.cta-btns{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;position:relative;padding:0 16px;}
.cta-trust{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;margin-top:18px;position:relative;padding:0 16px;}
.cta-trust-item{font-size:12px;color:rgba(255,255,255,.5);}
.cta-trust-item::before{content:'✓ ';color:var(--teal);}

/* ============================================================
   FOOTER
============================================================ */
.footer{background:var(--grey-900);padding:40px 0 28px;}
.footer-logo{font-family:'Lora',serif;font-size:20px;font-weight:700;color:#fff;margin-bottom:8px;}
.footer-logo span{color:var(--teal);}
.footer-desc{font-size:13px;color:rgba(255,255,255,.35);line-height:1.7;margin-bottom:24px;max-width:280px;}
.footer-grid{
  display:grid;gap:20px;margin-bottom:28px;
  grid-template-columns:1fr;
}
@media(min-width:480px){.footer-grid{grid-template-columns:1fr 1fr;gap:24px 20px;}}
@media(min-width:640px){.footer-grid{grid-template-columns:repeat(4,1fr);}}
@media(min-width:900px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr;}}
.footer-col h4{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.3);margin-bottom:10px;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:7px;}
.footer-col a{font-size:13px;color:rgba(255,255,255,.45);text-decoration:none;cursor:pointer;transition:color .15s;}
.footer-col a:hover{color:var(--teal);}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);padding-top:18px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;
}
.footer-copy{font-size:12px;color:rgba(255,255,255,.22);}
.footer-legal{display:flex;gap:14px;}
.footer-legal a{font-size:12px;color:rgba(255,255,255,.28);text-decoration:none;cursor:pointer;}
.footer-legal a:hover{color:var(--teal);}

/* ============================================================
   SEARCH PAGE
============================================================ */
.search-hero{
  background:linear-gradient(135deg,var(--navy),var(--navy2));
  padding:28px 0 24px;
  overflow:hidden;
}
.search-hero h1{font-family:'Lora',serif;font-size:clamp(22px,4vw,28px);font-weight:700;color:#fff;margin-bottom:6px;}
.search-hero p{font-size:14px;color:rgba(255,255,255,.6);margin-bottom:18px;}
.search-bar{
  display:flex;background:#fff;border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-lg);
}
.search-bar input{flex:1;border:none;outline:none;padding:0 14px;height:48px;font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--grey-900);min-width:0;}
.search-bar input::placeholder{color:var(--grey-300);}
.search-bar-btn{height:48px;padding:0 18px;background:var(--teal);border:none;color:#fff;font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:700;cursor:pointer;flex-shrink:0;}

.filter-bar{
  background:#fff;border-bottom:1px solid var(--grey-200);
  overflow-x:auto;scrollbar-width:none;padding:8px 16px;display:flex;gap:7px;
}
.filter-bar::-webkit-scrollbar{display:none;}
.filter-pill{
  height:30px;padding:0 12px;border-radius:20px;font-size:11px;font-weight:600;
  cursor:pointer;flex-shrink:0;border:1.5px solid var(--grey-200);
  background:#fff;color:var(--grey-500);transition:all .15s;white-space:nowrap;
  font-family:'Plus Jakarta Sans',sans-serif;
}
.filter-pill.active,.filter-pill:hover{background:var(--navy);color:#fff;border-color:var(--navy);}

/* Vertical card (search grid) */
.vcard{
  background:#fff;border-radius:var(--radius-lg);
  border:1px solid var(--grey-200);box-shadow:var(--shadow-sm);
  overflow:hidden;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;
}
.vcard:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);}
.vcard-photo{
  width:100%;height:120px;background:var(--grey-100);
  position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;
}
.vcard-photo img{width:100%;height:100%;object-fit:cover;}
.vcard-photo-fallback{font-size:40px;display:none;}
.vcard-avail{position:absolute;top:7px;right:7px;font-size:9px;font-weight:700;padding:2px 7px;border-radius:20px;color:#fff;}
.vcard-avail-green{background:var(--green);}
.vcard-avail-amber{background:var(--amber);}
.vcard-body{padding:8px 10px 10px;flex:1;display:flex;flex-direction:column;}
.vcard-name{font-size:12px;font-weight:700;color:var(--navy);margin-bottom:2px;}
.vcard-role{font-size:10px;color:var(--grey-500);margin-bottom:7px;line-height:1.4;}
.vcard-chips{display:flex;gap:3px;flex-wrap:wrap;margin-bottom:7px;}
.vcard-chip{font-size:9px;font-weight:700;padding:2px 6px;border-radius:4px;background:var(--teal-light);color:var(--teal-dark);}
.vcard-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;}
.vcard-rating{font-size:11px;font-weight:600;color:var(--grey-700);}
.vcard-btn{
  height:26px;padding:0 10px;border-radius:var(--radius-sm);
  background:var(--navy);color:#fff;border:none;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:10px;font-weight:600;cursor:pointer;
}

/* 5-col grid */
.vcards-grid{
  display:grid;gap:12px;padding:16px;
  grid-template-columns:repeat(2,1fr);
}
@media(min-width:480px){.vcards-grid{grid-template-columns:repeat(3,1fr);}}
@media(min-width:700px){.vcards-grid{grid-template-columns:repeat(4,1fr);gap:14px;}}
@media(min-width:1000px){.vcards-grid{grid-template-columns:repeat(5,1fr);padding:20px;}}

.search-results-wrap{background:var(--grey-50);}
.results-info-bar{
  padding:14px 16px 6px;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;
}
.results-count{font-size:13px;color:var(--grey-500);}
.results-count strong{color:var(--navy);}

/* Pagination */
.pagination-bar{
  display:flex;align-items:center;justify-content:center;
  gap:6px;padding:20px 12px 32px;flex-wrap:wrap;
}
.pg-btn{
  height:38px;padding:0 14px;border-radius:var(--radius-sm);
  border:1.5px solid var(--grey-200);background:#fff;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:600;
  color:var(--navy);cursor:pointer;transition:all .15s;
}
.pg-btn:hover:not(:disabled){border-color:var(--teal);color:var(--teal);background:var(--teal-light);}
.pg-btn:disabled{opacity:.35;cursor:not-allowed;}
.pg-nums{display:flex;gap:5px;}
.pg-num{
  width:38px;height:38px;border-radius:var(--radius-sm);
  border:1.5px solid var(--grey-200);background:#fff;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:600;
  color:var(--navy);cursor:pointer;transition:all .15s;
}
.pg-num:hover:not(.active){border-color:var(--teal);color:var(--teal);background:var(--teal-light);}
.pg-num.active{background:var(--navy);border-color:var(--navy);color:#fff;}
.pg-info{font-size:12px;color:var(--grey-500);white-space:nowrap;}

/* Old candidate card (kept for drawer compat) */
.candidate-card{
  background:#fff;border-radius:var(--radius-lg);border:1px solid var(--grey-200);
  padding:0px;display:flex;gap:14px;cursor:pointer;transition:all .2s;box-shadow:var(--shadow-sm);
}
.candidate-card:hover{box-shadow:var(--shadow-md);}
.cand-photo{
  width:64px;height:64px;min-width:64px;border-radius:var(--radius-md);
  background:var(--grey-100);overflow:hidden;position:relative;
}
.cand-photo img{width:100%;height:100%;object-fit:cover;}
.cand-photo-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:26px;}
.cand-dot{position:absolute;bottom:-3px;right:-3px;width:13px;height:13px;border-radius:50%;border:2.5px solid #fff;}
.cand-dot-green{background:var(--green);}
.cand-dot-amber{background:var(--amber);}
.cand-info{flex:1;min-width:0;}
.cand-name{font-size:14px;font-weight:700;color:var(--navy);margin-bottom:2px;}
.cand-subtitle{font-size:11px;color:var(--grey-500);margin-bottom:7px;}
.cand-chips{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:7px;}
.c-chip{font-size:10px;font-weight:600;padding:2px 7px;border-radius:4px;background:var(--teal-light);color:var(--teal-dark);}
.cand-footer{display:flex;align-items:center;gap:8px;}
.cand-rating{font-size:11px;font-weight:600;color:var(--grey-700);}
.cand-location{font-size:11px;color:var(--grey-500);}
.view-btn{
  margin-left:auto;height:28px;padding:0 12px;border-radius:var(--radius-sm);
  background:var(--navy);color:#fff;border:none;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:11px;font-weight:600;cursor:pointer;
}

/* ============================================================
   HOW IT WORKS PAGE
============================================================ */
.hiw-step{
  display:flex;gap:16px;padding:20px 0;
  border-bottom:1px solid var(--grey-200);align-items:flex-start;
}
.hiw-step:last-child{border-bottom:none;}
.hiw-circle{
  width:44px;height:44px;min-width:44px;border-radius:50%;
  background:var(--navy);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:'Lora',serif;font-size:17px;font-weight:700;
}
.hiw-step-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--teal);margin-bottom:4px;}
.hiw-step-title{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:5px;}
.hiw-step-desc{font-size:13px;color:var(--grey-500);line-height:1.7;}

/* ============================================================
   PRICING PAGE
============================================================ */
.plans-grid{
  display:grid;grid-template-columns:1fr;gap:24px;
  max-width:800px;margin-left:auto;margin-right:auto;
}
@media(min-width:600px){.plans-grid{grid-template-columns:1fr 1fr;}}

.plan-card{
  background:#fff;border-radius:var(--radius-xl);border:1px solid var(--grey-200);
  padding:24px 20px;position:relative;box-shadow:var(--shadow-sm);transition:box-shadow .2s;
}
.plan-card:hover{box-shadow:var(--shadow-lg);}
.plan-card.featured{background:var(--navy);border-color:var(--navy);}
.plan-badge{
  position:absolute;top:-11px;right:18px;
  background:var(--rose);color:#fff;font-size:10px;font-weight:700;padding:3px 12px;border-radius:20px;
}
.plan-tier{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--grey-500);margin-bottom:3px;}
.plan-card.featured .plan-tier{color:rgba(255,255,255,.45);}
.plan-caption{font-size:12px;color:var(--grey-500);font-style:italic;margin-bottom:25px;}
.plan-card.featured .plan-caption{color:rgba(255,255,255,.4);}
.plan-price{font-family:'Lora',serif;font-size:clamp(28px,6vw,40px);font-weight:700;color:var(--navy);line-height:1;margin-bottom:3px;display:flex;gap:10px;align-items:center;}
.plan-card.featured .plan-price{color:#fff;}
.plan-price sup{font-size:18px;vertical-align:top;margin-top:5px;}
.plan-period{font-size:12px;color:var(--grey-500);margin-bottom:16px;}
.plan-card.featured .plan-period{color:rgba(255,255,255,.4);}
.plan-feats{list-style:none;margin-bottom:20px;display:flex;flex-direction:column;gap:8px;}
.plan-feats li{font-size:13px;color:var(--grey-700);display:flex;gap:8px;align-items:flex-start;}
.plan-feats li::before{content:'✓';color:var(--teal);font-weight:700;flex-shrink:0;}
.plan-card.featured .plan-feats li{color:rgba(255,255,255,.75);}
.plan-cta{width:100%;height:44px;border-radius:var(--radius-md);border:none;font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:700;cursor:pointer;transition:all .15s;}
.plan-cta-navy{background:var(--navy);color:#fff;}
.plan-cta-navy:hover{background:var(--navy2);}
.plan-cta-teal{background:var(--teal);color:#fff;}
.plan-cta-teal:hover{background:var(--teal-dark);}
.plan-cta-outline{background:transparent;border:1.5px solid rgba(255,255,255,.3);color:#fff;}
.plan-cta-outline:hover{background:rgba(255,255,255,.1);}

/* ============================================================
   VISA PAGE
============================================================ */
.visa-hero{background:linear-gradient(135deg,#0B1F3A 0%,#0D3057 100%);padding:40px 0 36px;position:relative;overflow:hidden;}
.visa-hero::after{content:'';position:absolute;right:-20px;top:-10px;font-size:150px;opacity:.05;}
.visa-kicker{display:inline-block;background:rgba(14,165,200,.15);border:1px solid rgba(14,165,200,.25);color:var(--teal);font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:4px 12px;border-radius:20px;margin-bottom:12px;}
.visa-hero h1{font-family:'Lora',serif;font-size:clamp(22px,4vw,38px);font-weight:700;color:#fff;line-height:1.15;margin-bottom:10px;}
.visa-hero p{font-size:14px;color:rgba(255,255,255,.6);line-height:1.7;margin-bottom:20px;max-width:520px;}
.visa-btns{display:flex;gap:10px;flex-wrap:wrap;}
.contact-card{
  display:flex;align-items:center;gap:12px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius-lg);padding:12px 16px;margin-top:18px;
}
.contact-icon{width:38px;height:38px;min-width:38px;border-radius:var(--radius-sm);background:rgba(14,165,200,.2);display:flex;align-items:center;justify-content:center;font-size:17px;}
.contact-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:rgba(255,255,255,.4);}
.contact-value{font-size:15px;font-weight:700;color:#fff;}

.reasons-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
@media(min-width:560px){.reasons-grid{grid-template-columns:repeat(3,1fr);}}
@media(min-width:900px){.reasons-grid{grid-template-columns:repeat(4,1fr);}}
.reason-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--grey-200);padding:14px;box-shadow:var(--shadow-sm);}
.reason-icon{width:34px;height:34px;border-radius:var(--radius-sm);background:var(--teal-light);display:flex;align-items:center;justify-content:center;font-size:15px;margin-bottom:8px;}
.reason-title{font-size:13px;font-weight:700;color:var(--navy);margin-bottom:3px;}
.reason-desc{font-size:11px;color:var(--grey-500);line-height:1.6;}

/* ============================================================
   PARTNER PAGE
============================================================ */
.deal-banner{background:linear-gradient(135deg,var(--navy),#1A3A6B);border-radius:var(--radius-xl);padding:24px 20px;margin-bottom:20px;}
.deal-banner h2{font-family:'Lora',serif;font-size:clamp(18px,3vw,22px);font-weight:700;color:#fff;margin-bottom:10px;line-height:1.25;}
.deal-list{list-style:none;margin-bottom:16px;}
.deal-list li{font-size:13px;color:rgba(255,255,255,.7);padding:4px 0;display:flex;gap:8px;line-height:1.5;}
.deal-list li::before{content:'✓';color:var(--teal);font-weight:700;flex-shrink:0;}

.mem-tier-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--grey-200);padding:20px 18px;box-shadow:var(--shadow-sm);position:relative;}
.mem-tier-card.featured{background:var(--navy);border-color:var(--navy);}
.mem-pop-badge{position:absolute;top:-10px;right:14px;background:var(--rose);color:#fff;font-size:9px;font-weight:700;padding:3px 11px;border-radius:20px;}
.mem-name{font-size:14px;font-weight:700;color:var(--navy);margin-bottom:3px;}
.mem-tier-card.featured .mem-name{color:#fff;}
.mem-caption{font-size:12px;color:var(--grey-500);font-style:italic;margin-bottom:10px;}
.mem-tier-card.featured .mem-caption{color:rgba(255,255,255,.4);}
.mem-feats{list-style:none;display:flex;flex-direction:column;gap:6px;margin-bottom:14px;}
.mem-feats li{font-size:12px;color:var(--grey-700);display:flex;gap:7px;}
.mem-feats li::before{content:'✓';color:var(--teal);font-weight:700;flex-shrink:0;}
.mem-tier-card.featured .mem-feats li{color:rgba(255,255,255,.7);}
.access-step{display:flex;gap:12px;padding:13px 0;border-bottom:1px solid var(--grey-200);}
.access-step:last-child{border-bottom:none;}
.access-num{width:30px;height:30px;min-width:30px;border-radius:50%;background:var(--teal);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;}
.access-title{font-size:14px;font-weight:700;color:var(--navy);margin-bottom:2px;}
.access-desc{font-size:12px;color:var(--grey-500);}

/* ============================================================
   ARTICLES PAGE
============================================================ */
.articles-list-grid{display:grid;grid-template-columns:1fr;gap:16px;}
@media(min-width:640px){.articles-list-grid{grid-template-columns:1fr 1fr;}}

.article-full-card{
  background:#fff;border-radius:var(--radius-xl);border:1px solid var(--grey-200);
  overflow:hidden;text-decoration:none;color:inherit;box-shadow:var(--shadow-sm);
  transition:all .2s;display:block;
}
.article-full-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);}
.article-banner{height:120px;display:flex;align-items:center;justify-content:center;font-size:40px;position:relative;}
@media(min-width:400px){.article-banner{height:130px;font-size:48px;}}
.article-cat-label{
  position:absolute;bottom:10px;left:10px;
  background:rgba(11,31,58,.7);color:#fff;font-size:10px;font-weight:700;
  padding:3px 9px;border-radius:20px;letter-spacing:.5px;text-transform:uppercase;
}
.article-body{padding:16px 16px 18px;}
.article-date{font-size:11px;color:var(--grey-500);margin-bottom:7px;}
.article-title{font-family:'Lora',serif;font-size:16px;font-weight:700;color:var(--navy);line-height:1.3;margin-bottom:7px;}
.article-excerpt{font-size:13px;color:var(--grey-500);line-height:1.7;margin-bottom:10px;}
.article-read-more{font-size:12px;font-weight:700;color:var(--teal);}

/* ============================================================
   PROFILE DRAWER
============================================================ */
.drawer-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(11,31,58,.6);z-index:1000;align-items:flex-end;
}
.drawer-overlay.open{display:flex;}
.drawer-sheet{
  background:#fff;border-radius:20px 20px 0 0;width:100%;
  max-width:600px;margin:0 auto;
  max-height:90vh;overflow-y:auto;
  padding-bottom:max(20px,env(safe-area-inset-bottom));
  animation:slideup .28s cubic-bezier(.32,.72,0,1);
}
@keyframes slideup{from{transform:translateY(100%)}to{transform:translateY(0)}}
.drawer-handle{width:36px;height:4px;background:var(--grey-200);border-radius:2px;margin:12px auto 0;}
.drawer-header{padding:14px 18px;display:flex;gap:14px;border-bottom:1px solid var(--grey-200);}
.drawer-photo{width:68px;height:68px;min-width:68px;border-radius:var(--radius-md);background:var(--grey-100);overflow:hidden;}
.drawer-photo img{width:100%;height:100%;object-fit:cover;}
.drawer-name{font-family:'Lora',serif;font-size:19px;font-weight:700;color:var(--navy);margin-bottom:2px;}
.drawer-sub{font-size:12px;color:var(--grey-500);margin-bottom:5px;}
.drawer-tabs{
  display:flex;border-bottom:1px solid var(--grey-200);
  overflow-x:auto;scrollbar-width:none;padding:0 18px;
}
.drawer-tabs::-webkit-scrollbar{display:none;}
.drawer-tab{
  flex-shrink:0;padding:11px 12px;background:none;border:none;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;font-weight:600;color:var(--grey-500);
  cursor:pointer;border-bottom:2.5px solid transparent;margin-bottom:-1px;white-space:nowrap;
}
.drawer-tab.active{color:var(--teal);border-bottom-color:var(--teal);}
.drawer-panel{padding:16px 18px;display:none;}
.drawer-panel.active{display:block;}
.drawer-loading{padding:20px 18px 28px;}
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
@media(min-width:480px){.info-grid{grid-template-columns:repeat(3,1fr);}}
.info-item{background:var(--grey-50);border-radius:var(--radius-sm);padding:9px 11px;}
.info-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--grey-500);margin-bottom:2px;}
.info-value{font-size:13px;font-weight:600;color:var(--navy);}
.skills-wrap{display:flex;flex-wrap:wrap;gap:8px;}
.skill-tag{font-size:12px;font-weight:500;padding:5px 12px;border-radius:20px;background:var(--teal-light);color:var(--teal-dark);}
.drawer-actions{display:flex;gap:10px;padding:0 18px;margin-top:8px;}
.drawer-btn{flex:1;height:44px;border-radius:var(--radius-md);font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:700;cursor:pointer;transition:all .15s;border:none;}
.drawer-btn-navy{background:var(--navy);color:#fff;}
.drawer-btn-ghost{background:transparent;border:1.5px solid var(--grey-200);color:var(--grey-700);}

/* ============================================================
   MODAL
============================================================ */
.modal-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(11,31,58,.6);z-index:1100;align-items:flex-end;
}
.modal-overlay.open{display:flex;}
.modal-sheet{
  background:#fff;border-radius:20px 20px 0 0;width:100%;
  max-width:520px;margin:0 auto;
  max-height:88vh;overflow-y:auto;
  padding-bottom:max(20px,env(safe-area-inset-bottom));
  animation:slideup .28s cubic-bezier(.32,.72,0,1);
}
.modal-handle{width:36px;height:4px;background:var(--grey-200);border-radius:2px;margin:12px auto 0;}
.modal-inner{padding:0 20px 8px;}
.modal-title{font-family:'Lora',serif;font-size:21px;font-weight:700;color:var(--navy);margin-bottom:4px;}
.modal-sub{font-size:13px;color:var(--grey-500);margin-bottom:18px;}
.user-pick{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px;}
.pick-opt{border:1.5px solid var(--grey-200);border-radius:var(--radius-lg);padding:14px 12px;text-align:center;cursor:pointer;transition:all .2s;background:#fff;}
.pick-opt.selected,.pick-opt:hover{border-color:var(--teal);background:var(--teal-light);}
.pick-icon{font-size:26px;margin-bottom:7px;}
.pick-label{font-size:13px;font-weight:700;color:var(--navy);}
.pick-opt.selected .pick-label{color:var(--teal-dark);}
.pick-desc{font-size:11px;color:var(--grey-500);margin-top:2px;}
.form-field{margin-bottom:12px;}
.form-field label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--grey-500);margin-bottom:5px;}
.form-field input{
  width:100%;height:44px;border-radius:var(--radius-md);
  border:1.5px solid var(--grey-200);background:var(--grey-50);
  padding:0 14px;font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:var(--navy);
  outline:none;transition:border .15s;
}
.form-field input:focus{border-color:var(--teal);background:#fff;}
.form-submit{
  width:100%;height:48px;border-radius:var(--radius-md);border:none;
  background:var(--navy);color:#fff;font-family:'Plus Jakarta Sans',sans-serif;
  font-size:15px;font-weight:700;cursor:pointer;margin-top:6px;
}
.modal-switch{text-align:center;margin-top:12px;font-size:13px;color:var(--grey-500);}
.modal-switch a{color:var(--teal);font-weight:600;cursor:pointer;}
.terms-note{font-size:11px;color:var(--grey-500);margin-bottom:14px;line-height:1.6;}
.terms-note a{color:var(--teal);}
.action-row{display:flex;gap:10px;}

/* Toast */
.toast{
  position:fixed;bottom:72px;left:50%;transform:translateX(-50%);
  background:var(--navy);color:#fff;padding:11px 20px;
  border-radius:var(--radius-md);font-size:13px;font-weight:600;
  z-index:9999;white-space:nowrap;box-shadow:var(--shadow-lg);
  font-family:'Plus Jakarta Sans',sans-serif;transition:opacity .4s;pointer-events:none;
}
@media(min-width:900px){.toast{bottom:20px;}}

/* View-all link */
.view-all-link{
  display:flex;align-items:center;justify-content:center;
  height:44px;border-radius:var(--radius-md);
  border:1.5px solid var(--grey-200);background:#fff;
  font-size:13px;font-weight:600;color:var(--navy);
  cursor:pointer;text-decoration:none;transition:all .15s;
  font-family:'Plus Jakarta Sans',sans-serif;
}
.view-all-link:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-light);}

/* ============================================================
   VISA PAGE SCOPED STYLES (moved from inline)
============================================================ */
/* ── VISA PAGE SCOPED STYLES ── */
.visa-pg-hero{
  min-height:90vh;
  background:linear-gradient(135deg,#0d3040 0%,#0e5668 50%,#1a8fa1 100%);
  display:flex;align-items:center;
  padding:80px 20px 60px;
  position:relative;overflow:hidden;
}
.visa-pg-hero::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.visa-pg-inner{max-width:1100px;margin:0 auto;width:100%;display:grid;grid-template-columns:1fr;gap:48px;position:relative;z-index:1;}
@media(min-width:900px){.visa-pg-inner{grid-template-columns:1fr 1fr;align-items:center;}}
.visa-pg-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  padding:6px 16px;border-radius:50px;margin-bottom:24px;
  color:rgba(255,255,255,.9);font-size:.8rem;font-weight:500;letter-spacing:.05em;font-family:'Plus Jakarta Sans',sans-serif;
}
.visa-pg-badge::before{content:'✦';color:#e6a817;font-size:.7rem;}
.visa-pg-hero h1{
  font-family:'Lora',serif;font-size:clamp(2rem,5vw,3.2rem);
  font-weight:700;line-height:1.15;color:#fff;margin-bottom:18px;
}
.visa-pg-hero h1 em{color:#e6a817;font-style:normal;}
.visa-pg-hero p{color:rgba(255,255,255,.75);font-size:.95rem;line-height:1.75;margin-bottom:28px;}
.visa-pg-btns{display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.vbtn-gold{
  padding:13px 28px;background:#e6a817;color:#0d1b2a;
  border:none;border-radius:50px;font-size:.9rem;font-weight:700;
  cursor:pointer;transition:all .2s;font-family:'Plus Jakarta Sans',sans-serif;
  box-shadow:0 6px 24px rgba(230,168,23,.35);
}
.vbtn-gold:hover{background:#f5ba2a;transform:translateY(-2px);}
.vbtn-ghost-w{
  display:flex;align-items:center;gap:8px;padding:12px 22px;
  background:rgba(255,255,255,.1);border:1.5px solid rgba(255,255,255,.3);
  color:#fff;border-radius:50px;font-size:.88rem;font-weight:500;
  cursor:pointer;font-family:'Plus Jakarta Sans',sans-serif;transition:all .2s;
}
.vbtn-ghost-w:hover{background:rgba(255,255,255,.18);}
.visa-trust-pills{display:flex;flex-direction:column;gap:9px;margin-top:24px;}
.vtp{display:flex;align-items:center;gap:9px;color:rgba(255,255,255,.82);font-size:.875rem;font-family:'Plus Jakarta Sans',sans-serif;}

/* Stats bar */
.visa-stats-bar{
  display:flex;gap:0;background:#fff;border-radius:14px;
  box-shadow:0 8px 32px rgba(0,0,0,.15);overflow:hidden;
  max-width:420px;margin-top:32px;
}
@media(min-width:900px){.visa-stats-bar{margin-top:0;}}
.vs-item{flex:1;padding:18px 12px;text-align:center;border-right:1px solid #DDE2EC;}
.vs-item:last-child{border-right:none;}
.vs-num{font-family:'Lora',serif;font-size:1.6rem;font-weight:700;color:#0e5668;}
.vs-lbl{font-size:.72rem;color:#6B7A96;margin-top:2px;font-family:'Plus Jakarta Sans',sans-serif;}

/* Floating doc scene */
.visa-doc-scene{position:relative;width:100%;height:280px;}
@media(max-width:380px){.visa-doc-scene{height:220px;}}
@keyframes floatA{0%,100%{transform:translateY(0) rotate(-6deg)}50%{transform:translateY(-10px) rotate(-6deg)}}
@keyframes floatB{0%,100%{transform:translateY(0) rotate(5deg)}50%{transform:translateY(-14px) rotate(5deg)}}
@keyframes floatC{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-8px) rotate(-2deg)}}
.vdoc-a{position:absolute;top:20px;left:0;animation:floatA 4s ease-in-out infinite;max-width:45%;}
.vdoc-b{position:absolute;top:0;right:0;animation:floatB 5s ease-in-out infinite;max-width:45%;}
.vdoc-c{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);animation:floatC 4.5s ease-in-out .5s infinite;max-width:55%;}

/* Promo banner */
.visa-promo{
  background:linear-gradient(120deg,#0d2a3a 0%,#0e4f66 60%,#1a7a8e 100%);
  padding:56px 20px;position:relative;overflow:hidden;
}
.visa-promo::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Ccircle cx='20' cy='20' r='2'/%3E%3C/g%3E%3C/svg%3E");
}
.visa-promo-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:36px;position:relative;z-index:1;}
@media(min-width:900px){.visa-promo-inner{grid-template-columns:1fr 420px;align-items:start;}}
.vp-save-tag{
  display:inline-block;background:#e6a817;color:#0d1b2a;
  font-weight:800;font-size:.95rem;padding:7px 20px;border-radius:6px;
  margin-bottom:18px;font-family:'Plus Jakarta Sans',sans-serif;
}
.visa-promo h2{font-family:'Lora',serif;font-size:2rem;font-weight:700;color:#fff;line-height:1.2;margin-bottom:12px;}
.visa-promo h2 span{color:#e6a817;}
.vp-sub{color:rgba(255,255,255,.85);font-size:1rem;margin-bottom:16px;font-family:'Plus Jakarta Sans',sans-serif;}
.vp-bullets{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:26px;}
.vp-bullets li{color:rgba(255,255,255,.8);font-size:.875rem;font-family:'Plus Jakarta Sans',sans-serif;}
.vp-actions{display:flex;gap:12px;flex-wrap:wrap;}
.vbtn-callback{
  padding:12px 22px;background:transparent;border:2px solid rgba(255,255,255,.45);
  color:#fff;border-radius:50px;font-size:.875rem;font-weight:600;
  cursor:pointer;font-family:'Plus Jakarta Sans',sans-serif;transition:all .2s;
}
.vbtn-callback:hover{border-color:#fff;background:rgba(255,255,255,.1);}
.vbtn-whatsapp{
  padding:12px 22px;background:#25d366;color:#fff;border:none;
  border-radius:50px;font-size:.875rem;font-weight:700;cursor:pointer;
  font-family:'Plus Jakarta Sans',sans-serif;transition:all .2s;
  box-shadow:0 4px 16px rgba(37,211,102,.3);
}
.vbtn-whatsapp:hover{background:#1ebe59;transform:translateY(-2px);}

/* Consultation card */
.consult-card{background:#fff;border-radius:16px;box-shadow:0 16px 48px rgba(0,0,0,.2);overflow:hidden;}
.consult-card-hd{background:#0e5668;color:#fff;text-align:center;padding:16px;font-weight:800;font-size:.9rem;letter-spacing:.08em;font-family:'Plus Jakarta Sans',sans-serif;}
.consult-form{padding:22px;display:flex;flex-direction:column;gap:12px;}
.cf-row{display:grid;grid-template-columns:1fr;gap:10px;}
@media(min-width:520px){.cf-row{grid-template-columns:1fr 1fr;}}
.cf-grp{display:flex;flex-direction:column;gap:4px;}
.cf-grp label{font-size:.75rem;font-weight:600;color:#0d1b2a;font-family:'Plus Jakarta Sans',sans-serif;}
.cf-grp input,.cf-grp select,.cf-grp textarea{
  padding:8px 11px;border:1.5px solid #DDE2EC;border-radius:8px;
  font-size:.84rem;color:#374151;font-family:'Plus Jakarta Sans',sans-serif;
  outline:none;transition:border-color .2s;background:#fff;
}
.cf-grp input:focus,.cf-grp select:focus,.cf-grp textarea:focus{border-color:#1a8fa1;}
.cf-grp textarea{min-height:64px;resize:vertical;}
.cf-phone-row{display:flex;}
.cf-prefix{padding:8px 11px;background:#F5F7FA;border:1.5px solid #DDE2EC;border-right:none;border-radius:8px 0 0 8px;font-size:.84rem;font-weight:600;white-space:nowrap;font-family:'Plus Jakarta Sans',sans-serif;}
.cf-phone-row input{border-radius:0 8px 8px 0;flex:1;}
.btn-consult-submit{
  width:100%;padding:12px;background:#e6a817;color:#0d1b2a;
  border:none;border-radius:8px;font-size:.9rem;font-weight:800;
  cursor:pointer;font-family:'Plus Jakarta Sans',sans-serif;letter-spacing:.05em;
  transition:all .2s;
}
.btn-consult-submit:hover{background:#f5ba2a;transform:translateY(-1px);}

/* Process grid */
.visa-process-section{padding:72px 20px;background:#fff;}
.visa-process-hd{text-align:center;margin-bottom:40px;}
.visa-process-hd h2{font-family:'Lora',serif;font-size:1.7rem;font-weight:700;color:#0d1b2a;line-height:1.3;max-width:640px;margin:0 auto;}
.visa-process-hd h2 span{color:#1a8fa1;}
.visa-process-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;}
@media(min-width:768px){.visa-process-grid{grid-template-columns:repeat(4,1fr);}}
.vpc{border:1.5px solid #DDE2EC;border-radius:12px;overflow:hidden;background:#fff;transition:all .25s;cursor:default;}
.vpc:hover{border-color:#1a8fa1;box-shadow:0 8px 28px rgba(26,143,161,.13);transform:translateY(-4px);}
.vpc-img{width:100%;aspect-ratio:4/3;overflow:hidden;background:#f0f7fa;}
.vpc-img svg{width:100%;height:100%;}
.vpc-label{padding:12px 14px;font-size:.85rem;font-weight:600;color:#0d1b2a;text-align:center;border-top:1px solid #DDE2EC;background:#fff;font-family:'Plus Jakarta Sans',sans-serif;}

/* Visa options */
.visa-options-section{padding:80px 20px;background:#fff;}
.vo-header{text-align:center;margin-bottom:48px;}
.vo-header h2{font-family:'Lora',serif;font-size:1.9rem;font-weight:700;color:#0d1b2a;margin-bottom:10px;}
.vo-header p{color:#6b7a8d;max-width:540px;margin:0 auto;line-height:1.75;font-size:.9rem;font-family:'Plus Jakarta Sans',sans-serif;}
.vo-cards{display:grid;grid-template-columns:1fr;gap:28px;}
@media(min-width:768px){.vo-cards{grid-template-columns:1fr 1fr;}}
.vo-card{
  border:1.5px solid #DDE2EC;border-radius:20px;padding:32px 28px;
  background:#f4f9fb;transition:all .25s;position:relative;
}
.vo-card:hover{box-shadow:0 12px 40px rgba(26,143,161,.12);border-color:#1a8fa1;}
.vo-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(26,143,161,.1);color:#12707f;
  border-radius:50px;padding:4px 14px;font-size:.73rem;font-weight:600;
  margin-bottom:16px;letter-spacing:.04em;font-family:'Plus Jakarta Sans',sans-serif;
}
.vo-icon{font-size:2.2rem;margin-bottom:12px;display:block;}
.vo-card h3{font-family:'Lora',serif;font-size:1.4rem;font-weight:700;color:#0d1b2a;margin-bottom:12px;}
.vo-card>p{color:#6b7a8d;font-size:.875rem;line-height:1.7;margin-bottom:20px;font-family:'Plus Jakarta Sans',sans-serif;}
.vo-section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#12707f;margin-bottom:10px;font-family:'Plus Jakarta Sans',sans-serif;}
.vo-check-list{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:20px;}
.vo-check-list li{display:flex;align-items:flex-start;gap:9px;font-size:.85rem;color:#374151;line-height:1.55;font-family:'Plus Jakarta Sans',sans-serif;}
.vo-check-list li::before{content:'✓';color:#1a8fa1;font-weight:700;flex-shrink:0;margin-top:1px;}
.vo-req-box{
  background:#fff;border:1px solid #DDE2EC;border-radius:10px;
  padding:12px 16px;font-size:.8rem;color:#6b7a8d;line-height:1.65;
  font-family:'Plus Jakarta Sans',sans-serif;
}
.vo-req-box strong{display:block;color:#374151;font-weight:600;margin-bottom:3px;font-size:.78rem;}
.vo-gov-tag{
  position:absolute;top:20px;right:20px;
  background:#eaf7f0;color:#1a7f4f;border-radius:50px;
  font-size:.7rem;font-weight:700;padding:3px 11px;letter-spacing:.05em;
  font-family:'Plus Jakarta Sans',sans-serif;
}
.vo-cta-inline{text-align:center;margin-top:28px;color:#6b7a8d;font-size:.875rem;font-family:'Plus Jakarta Sans',sans-serif;}
.vo-cta-inline a{color:#1a8fa1;font-weight:600;text-decoration:none;}
.vo-cta-inline a:hover{text-decoration:underline;}

/* Comparison table */
/* ── Comparison section ── */
.visa-comparison{padding:52px 16px 64px;background:#f4f9fb;}
@media(min-width:640px){.visa-comparison{padding:64px 24px 80px;}}
.vc-header{text-align:center;margin-bottom:32px;}
.vc-header h2{font-family:'Lora',serif;font-size:clamp(1.3rem,4vw,1.8rem);font-weight:700;color:#0d1b2a;margin-bottom:8px;}
.vc-header p{color:#6b7a8d;max-width:520px;margin:0 auto;line-height:1.7;font-size:.875rem;font-family:'Plus Jakarta Sans',sans-serif;}

/* ── Mobile: stacked card rows ── */
.compare-cards{display:flex;flex-direction:column;gap:12px;padding:0 4px;}
.compare-card{
  background:#fff;border-radius:14px;overflow:hidden;
  border:1px solid #DDE2EC;box-shadow:0 2px 8px rgba(0,0,0,.05);
}
.compare-card-feature{
  background:#f0f4f8;padding:12px 16px;
  font-size:.8rem;font-weight:700;color:#0d1b2a;
  font-family:'Plus Jakarta Sans',sans-serif;
  border-bottom:1px solid #DDE2EC;
}
.compare-card-cols{display:grid;grid-template-columns:1fr 1fr;}
.compare-col{padding:10px 12px;}
.compare-col:first-child{border-right:1px solid #DDE2EC;}
.compare-col-label{
  font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;
  margin-bottom:6px;display:flex;align-items:center;gap:5px;
  font-family:'Plus Jakarta Sans',sans-serif;
}
.compare-col-label.teal{color:#12707f;}
.compare-col-label.amber{color:#9a6e00;}
.compare-col-text{
  font-size:.75rem;color:#374151;line-height:1.5;
  font-family:'Plus Jakarta Sans',sans-serif;
}
.compare-col:first-child{background:rgba(26,143,161,.03);}
.compare-col:last-child{background:rgba(230,168,23,.03);}

/* ── Desktop: standard table ── */
.table-wrap{display:none;}
@media(min-width:700px){
  .compare-cards{display:none;}
  .table-wrap{display:block;overflow-x:auto;border-radius:16px;box-shadow:0 4px 24px rgba(0,0,0,.07);}
}
.vtable{width:100%;border-collapse:collapse;background:#fff;font-size:.85rem;}
.vtable thead th{padding:14px 18px;text-align:left;font-weight:700;font-size:.8rem;border-bottom:2px solid #DDE2EC;font-family:'Plus Jakarta Sans',sans-serif;}
.vtable thead th:first-child{color:#6b7a8d;font-weight:600;width:160px;}
.vtable thead th:nth-child(2){background:rgba(26,143,161,.06);color:#12707f;}
.vtable thead th:nth-child(3){background:rgba(230,168,23,.06);color:#9a6e00;}
.vtable tbody tr{border-bottom:1px solid #DDE2EC;transition:background .15s;}
.vtable tbody tr:last-child{border-bottom:none;}
.vtable tbody tr:hover{background:#f4f9fb;}
.vtable tbody td{padding:12px 18px;vertical-align:top;line-height:1.55;color:#374151;font-family:'Plus Jakarta Sans',sans-serif;font-size:.83rem;}
.vtable tbody td:first-child{font-weight:700;color:#0d1b2a;font-size:.78rem;}
.vtable tbody td:nth-child(2){background:rgba(26,143,161,.025);}
.vtable tbody td:nth-child(3){background:rgba(230,168,23,.025);}

/* Who can be sponsored */
.visa-who{padding:80px 20px;background:#fff;}
.vw-header{text-align:center;margin-bottom:44px;}
.vw-header h2{font-family:'Lora',serif;font-size:1.8rem;font-weight:700;color:#0d1b2a;margin-bottom:10px;}
.vw-header p{color:#6b7a8d;max-width:480px;margin:0 auto;line-height:1.7;font-size:.875rem;font-family:'Plus Jakarta Sans',sans-serif;}
.worker-cards-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;}
@media(min-width:400px){.worker-cards-grid{grid-template-columns:repeat(2,1fr);}}
@media(min-width:640px){.worker-cards-grid{grid-template-columns:repeat(3,1fr);}}
@media(min-width:900px){.worker-cards-grid{grid-template-columns:repeat(6,1fr);}}
.wkr-card{
  background:#f4f9fb;border:1px solid #DDE2EC;
  border-radius:16px;padding:24px 14px;text-align:center;
  transition:all .25s;cursor:default;
}
.wkr-card:hover{background:#12707f;border-color:#12707f;transform:translateY(-5px);box-shadow:0 12px 28px rgba(18,112,127,.2);}
.wkr-card:hover .wkr-label,.wkr-card:hover .wkr-desc{color:rgba(255,255,255,.85);}
.wkr-emoji{font-size:2rem;margin-bottom:10px;display:block;}
.wkr-label{font-weight:700;font-size:.85rem;color:#0d1b2a;margin-bottom:5px;transition:color .25s;font-family:'Plus Jakarta Sans',sans-serif;}
.wkr-desc{font-size:.75rem;color:#6b7a8d;line-height:1.55;transition:color .25s;font-family:'Plus Jakarta Sans',sans-serif;}

/* Contact form */
.visa-contact-form{padding:80px 20px;background:#f4f9fb;}
.vcf-header{text-align:center;margin-bottom:44px;}
.vcf-header h2{font-family:'Lora',serif;font-size:1.8rem;font-weight:700;color:#0d1b2a;margin-bottom:10px;}
.vcf-header p{color:#6b7a8d;max-width:540px;margin:0 auto;line-height:1.7;font-size:.875rem;font-family:'Plus Jakarta Sans',sans-serif;}
.vcf-card{max-width:700px;margin:0 auto;background:#fff;border-radius:20px;padding:36px 32px;box-shadow:0 8px 32px rgba(0,0,0,.08);border:1px solid #DDE2EC;}
.vcf-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
@media(max-width:600px){.vcf-row{grid-template-columns:1fr;}}
.vcf-grp{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;}
.vcf-grp label{font-size:.8rem;font-weight:600;color:#0d1b2a;font-family:'Plus Jakarta Sans',sans-serif;}
.vcf-grp input,.vcf-grp select,.vcf-grp textarea{
  padding:10px 14px;border:1.5px solid #DDE2EC;border-radius:9px;
  font-size:.875rem;color:#374151;font-family:'Plus Jakarta Sans',sans-serif;
  background:#fff;outline:none;transition:border-color .2s,box-shadow .2s;
}
.vcf-grp input:focus,.vcf-grp select:focus,.vcf-grp textarea:focus{border-color:#1a8fa1;box-shadow:0 0 0 3px rgba(26,143,161,.1);}
.vcf-grp textarea{resize:vertical;min-height:90px;}
.vcf-disclaimer{font-size:.75rem;color:#6b7a8d;line-height:1.65;margin-bottom:20px;text-align:center;font-family:'Plus Jakarta Sans',sans-serif;}
.vcf-submit{
  width:100%;padding:13px;background:#1a8fa1;color:#fff;
  border:none;border-radius:50px;font-size:.95rem;font-weight:700;
  cursor:pointer;font-family:'Plus Jakarta Sans',sans-serif;
  transition:all .2s;box-shadow:0 6px 20px rgba(26,143,161,.28);
}
.vcf-submit:hover{background:#12707f;transform:translateY(-2px);}
.vcf-trust{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;max-width:700px;margin:24px auto 0;}
@media(max-width:600px){.vcf-trust{grid-template-columns:1fr;}}
.vcf-trust-item{background:#fff;border:1px solid #DDE2EC;border-radius:12px;padding:16px 14px;text-align:center;}
.vcf-trust-ico{font-size:1.4rem;margin-bottom:7px;display:block;}
.vcf-trust-title{font-weight:700;font-size:.82rem;color:#0d1b2a;margin-bottom:3px;font-family:'Plus Jakarta Sans',sans-serif;}
.vcf-trust-desc{font-size:.75rem;color:#6b7a8d;line-height:1.55;font-family:'Plus Jakarta Sans',sans-serif;}

/* FAQ */
.visa-faq-section{padding:80px 20px;background:#fff;}
.vfaq-header{text-align:center;margin-bottom:48px;}
.vfaq-header h2{font-family:'Lora',serif;font-size:1.8rem;font-weight:700;color:#0d1b2a;margin-bottom:10px;}
.vfaq-header p{color:#6b7a8d;max-width:500px;margin:0 auto;line-height:1.7;font-size:.9rem;font-family:'Plus Jakarta Sans',sans-serif;}
.vfaq-list{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:12px;}
.vfaq-item{background:#f4f9fb;border:1px solid #DDE2EC;border-radius:12px;overflow:hidden;}
.vfaq-q{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 22px;font-weight:600;font-size:.9rem;color:#0d1b2a;
  cursor:pointer;font-family:'Plus Jakarta Sans',sans-serif;transition:color .2s;user-select:none;
}
.vfaq-q:hover{color:#1a8fa1;}
.vfaq-arr{
  width:26px;height:26px;border-radius:50%;background:#fff;
  border:1px solid #DDE2EC;display:flex;align-items:center;justify-content:center;
  font-size:.75rem;font-weight:700;color:#1a8fa1;transition:all .3s;flex-shrink:0;
}
.vfaq-item.open .vfaq-q{color:#1a8fa1;}
.vfaq-item.open .vfaq-arr{transform:rotate(45deg);background:#1a8fa1;color:#fff;border-color:#1a8fa1;}
.vfaq-a{
  max-height:0;overflow:hidden;transition:max-height .35s ease,padding .3s;
  padding:0 22px;color:#6b7a8d;font-size:.85rem;line-height:1.75;
  background:#fff;font-family:'Plus Jakarta Sans',sans-serif;
}
.vfaq-item.open .vfaq-a{max-height:200px;padding:0 22px 18px;}
.vfaq-cta{
  text-align:center;margin:40px auto 0;max-width:760px;
  background:linear-gradient(135deg,#12707f,#1a8fa1);
  border-radius:18px;padding:36px 28px;color:#fff;
}
.vfaq-cta h3{font-family:'Lora',serif;font-size:1.4rem;margin-bottom:9px;}
.vfaq-cta p{opacity:.8;font-size:.875rem;margin-bottom:22px;font-family:'Plus Jakarta Sans',sans-serif;}
.vfaq-cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}
.vbtn-white{padding:11px 26px;background:#fff;color:#12707f;border:none;border-radius:50px;font-size:.875rem;font-weight:700;cursor:pointer;font-family:'Plus Jakarta Sans',sans-serif;transition:all .2s;}
.vbtn-white:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,.12);}
.vbtn-ghost-teal{padding:11px 26px;background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.45);border-radius:50px;font-size:.875rem;font-weight:600;cursor:pointer;font-family:'Plus Jakarta Sans',sans-serif;transition:all .2s;}
.vbtn-ghost-teal:hover{border-color:#fff;background:rgba(255,255,255,.1);}
*/






/* ════════════════════════════════════
   SEARCH PAGE — vertical card grid
════════════════════════════════════ */

/* The vertical card used in the grid */
.vcard{
  background:#fff;border-radius:var(--radius-lg);
  border:1px solid var(--grey-200);box-shadow:var(--shadow-sm);
  overflow:hidden;cursor:pointer;transition:all .2s;
  display:flex;flex-direction:column;
}
.vcard:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);}
.vcard-photo{
  width:100%;height:130px;background:var(--grey-100);
  position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.vcard-photo img{width:100%;height:100%;object-fit:cover;}
.vcard-photo-fallback{font-size:44px;}
.vcard-avail{
  position:absolute;top:8px;right:8px;
  font-size:9px;font-weight:700;padding:2px 8px;
  border-radius:20px;color:#fff;
}
.vcard-avail-green{background:var(--green);}
.vcard-avail-amber{background:var(--amber);}
.vcard-body{padding:12px 12px 14px;flex:1;display:flex;flex-direction:column;}
.vcard-name{font-size:13px;font-weight:700;color:var(--navy);margin-bottom:2px;}
.vcard-role{font-size:11px;color:var(--grey-500);margin-bottom:8px;line-height:1.4;}
.vcard-chips{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:8px;}
.vcard-chip{font-size:9px;font-weight:700;padding:2px 7px;border-radius:4px;background:var(--teal-light);color:var(--teal-dark);}
.vcard-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;}
.vcard-rating{font-size:11px;font-weight:600;color:var(--grey-700);}
.vcard-btn{
  height:26px;padding:0 10px;border-radius:var(--radius-sm);
  background:var(--navy);color:#fff;border:none;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:10px;font-weight:600;
  cursor:pointer;transition:background .15s;
}
.vcard-btn:hover{background:var(--navy2);}

/* 5-column grid wrapper */
.vcards-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:14px;
  padding:20px 20px 0;
  max-width:1280px;
  margin:0 auto;
}
@media(max-width:1100px){.vcards-grid{grid-template-columns:repeat(4,1fr);}}
@media(max-width:860px) {.vcards-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:600px) {.vcards-grid{grid-template-columns:repeat(2,1fr);gap:10px;padding:12px;}}
@media(max-width:360px){.vcards-grid{grid-template-columns:1fr;}}

/* Results info row */
.results-info-bar{
  max-width:1280px;margin:0 auto;
  padding:16px 20px 8px;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:8px;
}
.results-count{font-size:13px;color:var(--grey-500);font-weight:500;}
.results-count strong{color:var(--navy);}

/* Pagination */
.pagination-bar{
  display:flex;align-items:center;justify-content:center;
  gap:8px;padding:24px 20px 36px;flex-wrap:wrap;
  max-width:1280px;margin:0 auto;
}
.pg-btn{
  height:40px;padding:0 18px;border-radius:var(--radius-sm);
  border:1.5px solid var(--grey-200);background:#fff;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:600;
  color:var(--navy);cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:6px;
}
.pg-btn:hover:not(:disabled){border-color:var(--teal);color:var(--teal);background:var(--teal-light);}
.pg-btn:disabled{opacity:.35;cursor:not-allowed;}
.pg-nums{display:flex;gap:6px;}
.pg-num{
  width:40px;height:40px;border-radius:var(--radius-sm);
  border:1.5px solid var(--grey-200);background:#fff;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:600;
  color:var(--navy);cursor:pointer;transition:all .15s;
}
.pg-num:hover:not(.active){border-color:var(--teal);color:var(--teal);background:var(--teal-light);}
.pg-num.active{background:var(--navy);border-color:var(--navy);color:#fff;}
.pg-info{font-size:12px;color:var(--grey-500);font-family:'Plus Jakarta Sans',sans-serif;white-space:nowrap;}

/* search-results-wrap */
.search-results-wrap{background:var(--grey-50);}

/* HOME Featured Profiles — 5-col grid */
.home-featured-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:16px;
}
@media(max-width:1100px){.home-featured-grid{grid-template-columns:repeat(4,1fr);}}
@media(max-width:800px) {.home-featured-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:560px) {.home-featured-grid{grid-template-columns:repeat(2,1fr);gap:10px;}}
@media(max-width:340px){.home-featured-grid{grid-template-columns:1fr;}}
.home-featured-grid .nanny-card{width:auto;}


/* FAQ category tabs */
.faq-tab-btn{
  height:32px;padding:0 12px;border-radius:20px;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:11px;font-weight:600;
  border:1.5px solid var(--grey-200);background:#fff;color:var(--grey-500);
  cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0;
}
.faq-tab-btn:hover{border-color:var(--teal);color:var(--teal);}
.faq-tab-btn.active{background:var(--navy);border-color:var(--navy);color:#fff;}


/* FAQ Pagination */
.faq-pagination{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:10px;
  padding:20px 0 4px;
  border-top:1px solid var(--grey-200);
  margin-top:4px;
}
.faq-pg-info{font-size:13px;color:var(--grey-500);font-family:'Plus Jakarta Sans',sans-serif;}
.faq-pg-info strong{color:var(--navy);}
.faq-pg-btns{display:flex;gap:6px;align-items:center;flex-wrap:wrap;}
.faq-pg-btn{
  height:34px;padding:0 12px;border-radius:var(--radius-sm);
  border:1.5px solid var(--grey-200);background:#fff;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;font-weight:600;
  color:var(--navy);cursor:pointer;transition:all .15s;
}
.faq-pg-btn:hover:not(:disabled){border-color:var(--teal);color:var(--teal);background:var(--teal-light);}
.faq-pg-btn:disabled{opacity:.35;cursor:not-allowed;}
.faq-pg-num{
  width:34px;height:34px;border-radius:var(--radius-sm);
  border:1.5px solid var(--grey-200);background:#fff;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;font-weight:600;
  color:var(--navy);cursor:pointer;transition:all .15s;
}
.faq-pg-num:hover:not(.active){border-color:var(--teal);color:var(--teal);background:var(--teal-light);}
.faq-pg-num.active{background:var(--navy);border-color:var(--navy);color:#fff;}


/* Visa FAQ pagination */
.vfaq-tabs{display:flex;flex-wrap:wrap;gap:8px;margin:20px 0 24px;}
.vfaq-tab-btn{
  height:32px;padding:0 14px;border-radius:20px;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;font-weight:600;
  border:1.5px solid #DDE2EC;background:#fff;color:#6b7a8d;
  cursor:pointer;transition:all .15s;white-space:nowrap;
}
.vfaq-tab-btn:hover{border-color:#1a8fa1;color:#1a8fa1;}
.vfaq-tab-btn.active{background:#12707f;border-color:#12707f;color:#fff;}
.vfaq-pagination{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:10px;
  padding:20px 0 4px;
  border-top:1px solid #DDE2EC;
  margin-top:8px;
  max-width:760px;margin-left:auto;margin-right:auto;
}
.vfaq-pg-info{font-size:13px;color:#6b7a8d;font-family:'Plus Jakarta Sans',sans-serif;}
.vfaq-pg-info strong{color:#0d1b2a;}
.vfaq-pg-btns{display:flex;gap:6px;align-items:center;flex-wrap:wrap;}
.vfaq-pg-btn{
  height:34px;padding:0 12px;border-radius:8px;
  border:1.5px solid #DDE2EC;background:#fff;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;font-weight:600;
  color:#0d1b2a;cursor:pointer;transition:all .15s;
}
.vfaq-pg-btn:hover:not(:disabled){border-color:#1a8fa1;color:#1a8fa1;background:#E0F5FB;}
.vfaq-pg-btn:disabled{opacity:.35;cursor:not-allowed;}
.vfaq-pg-num{
  width:34px;height:34px;border-radius:8px;
  border:1.5px solid #DDE2EC;background:#fff;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;font-weight:600;
  color:#0d1b2a;cursor:pointer;transition:all .15s;
}
.vfaq-pg-num:hover:not(.active){border-color:#1a8fa1;color:#1a8fa1;background:#E0F5FB;}
.vfaq-pg-num.active{background:#12707f;border-color:#12707f;color:#fff;}
.vfaq-item{max-width:760px;margin-left:auto;margin-right:auto;}


/* Article grid: 3-col on large, 2-col medium, 1-col mobile */
.articles-list-grid{
  display:grid;grid-template-columns:1fr;gap:20px;
}
@media(min-width:540px){.articles-list-grid{grid-template-columns:1fr 1fr;}}
@media(min-width:900px){.articles-list-grid{grid-template-columns:repeat(3,1fr);}}


/* Article page styles */
#page-articles .articles-list-grid{display:grid;grid-template-columns:1fr;gap:20px;}
@media(min-width:540px){#page-articles .articles-list-grid{grid-template-columns:1fr 1fr;}}
@media(min-width:900px){#page-articles .articles-list-grid{grid-template-columns:repeat(3,1fr);}}


/* ============================================================
   CONTACT PAGE
============================================================ */
.contact-pg{background:var(--grey-50);min-height:calc(100vh - 60px);}

.contact-hero{
  background:linear-gradient(135deg,var(--navy) 0%,#132D50 100%);
  padding:52px 0 48px;text-align:center;position:relative;overflow:hidden;
}
.contact-hero::before{
  content:'';position:absolute;top:-80px;left:50%;transform:translateX(-50%);
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(14,165,200,.12),transparent 70%);
  pointer-events:none;
}
.contact-hero h1{
  font-family:'Lora',serif;font-size:clamp(24px,4vw,38px);
  font-weight:700;color:#fff;margin-bottom:12px;position:relative;
}
.contact-hero p{
  font-size:15px;color:rgba(255,255,255,.65);max-width:480px;
  margin:0 auto;line-height:1.7;position:relative;font-family:'Plus Jakarta Sans',sans-serif;
}

/* Contact info cards */
.contact-info-grid{
  display:grid;grid-template-columns:1fr;gap:16px;
  max-width:700px;margin:0 auto;
}
@media(min-width:480px){.contact-info-grid{grid-template-columns:1fr 1fr;}}

.contact-info-card{
  background:#fff;border-radius:var(--radius-lg);
  border:1.5px solid var(--grey-200);
  padding:28px 22px;text-align:center;
  box-shadow:var(--shadow-sm);transition:all .2s;
}
.contact-info-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}
.contact-info-icon{
  width:56px;height:56px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:24px;margin:0 auto 16px;
}
.contact-info-icon.teal{background:var(--teal-light);}
.contact-info-icon.navy{background:rgba(11,31,58,.08);}
.contact-info-label{
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:1px;color:var(--grey-500);margin-bottom:6px;
  font-family:'Plus Jakarta Sans',sans-serif;
}
.contact-info-value{
  font-size:17px;font-weight:700;color:var(--navy);
  font-family:'Plus Jakarta Sans',sans-serif;margin-bottom:4px;
}
.contact-info-sub{font-size:12px;color:var(--grey-500);font-family:'Plus Jakarta Sans',sans-serif;}
.contact-info-action{
  display:inline-flex;align-items:center;gap:6px;
  margin-top:14px;height:36px;padding:0 18px;border-radius:var(--radius-sm);
  background:var(--navy);color:#fff;border:none;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;font-weight:700;
  cursor:pointer;transition:background .15s;text-decoration:none;
}
.contact-info-action:hover{background:var(--navy2);}

/* Support form */
.contact-form-wrap{max-width:700px;margin:0 auto;}
.contact-form-card{
  background:#fff;border-radius:var(--radius-xl);
  border:1.5px solid var(--grey-200);
  padding:36px 28px;box-shadow:var(--shadow-md);
}
@media(min-width:640px){.contact-form-card{padding:44px 40px;}}

.cform-title{
  font-family:'Lora',serif;font-size:clamp(18px,3vw,24px);
  font-weight:700;color:var(--navy);margin-bottom:6px;
}
.cform-sub{font-size:14px;color:var(--grey-500);margin-bottom:28px;
  font-family:'Plus Jakarta Sans',sans-serif;line-height:1.6;}

.cfield{margin-bottom:18px;}
.cfield label{
  display:block;font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:.7px;
  color:var(--grey-500);margin-bottom:6px;
  font-family:'Plus Jakarta Sans',sans-serif;
}
.cfield input,.cfield select,.cfield textarea{
  width:100%;border:1.5px solid var(--grey-200);
  border-radius:var(--radius-md);background:#fff;
  padding:0 16px;height:48px;
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:14px;color:var(--navy);
  outline:none;transition:border .2s,box-shadow .2s;
}
.cfield input:focus,.cfield select:focus,.cfield textarea:focus{
  border-color:var(--teal);
  box-shadow:0 0 0 3px rgba(14,165,200,.1);
  background:#fff;
}
.cfield textarea{height:auto;min-height:120px;padding:14px 16px;resize:vertical;}
.cfield select{
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B7A96' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 14px center;
  padding-right:38px;cursor:pointer;
}
.cfield-row{display:grid;grid-template-columns:1fr;gap:0;}
@media(min-width:560px){.cfield-row{grid-template-columns:1fr 1fr;gap:18px;}}

/* Submit button */
.cform-submit{
  width:100%;height:52px;border-radius:var(--radius-md);
  border:none;background:var(--navy);color:#fff;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:700;
  cursor:pointer;transition:all .2s;margin-top:6px;
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.cform-submit:hover{background:var(--navy2);transform:translateY(-1px);box-shadow:var(--shadow-md);}

/* Response time badges */
.contact-trust-row{
  display:flex;gap:10px;flex-wrap:wrap;justify-content:center;
  margin:24px auto 0;max-width:700px;
  padding:0 4px;
}
.contact-trust-badge{
  display:flex;align-items:center;gap:8px;
  background:#fff;border:1.5px solid var(--grey-200);
  border-radius:20px;padding:8px 16px;
  font-size:12px;font-weight:600;color:var(--grey-700);
  font-family:'Plus Jakarta Sans',sans-serif;
  box-shadow:var(--shadow-sm);
}
.contact-trust-badge span{font-size:14px;}

/* FAQ teaser */
.contact-faq-teaser{
  max-width:700px;margin:32px auto 0;
  background:var(--navy);border-radius:var(--radius-xl);
  padding:28px 24px;text-align:center;
}
.contact-faq-teaser h3{
  font-family:'Lora',serif;font-size:18px;
  font-weight:700;color:#fff;margin-bottom:8px;
}
.contact-faq-teaser p{
  font-size:13px;color:rgba(255,255,255,.6);
  margin-bottom:18px;font-family:'Plus Jakarta Sans',sans-serif;
}
.contact-faq-btns{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;}
.cfaq-btn-teal{
  height:40px;padding:0 20px;border-radius:var(--radius-sm);
  background:var(--teal);color:#fff;border:none;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:700;
  cursor:pointer;
}
.cfaq-btn-ghost{
  height:40px;padding:0 20px;border-radius:var(--radius-sm);
  background:transparent;color:#fff;
  border:1.5px solid rgba(255,255,255,.3);
  font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:600;
  cursor:pointer;
}


/* Filter tab rows — scrollable on mobile */
.filter-tabs-row{
  display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;
  padding-bottom:4px;margin-bottom:20px;
  -webkit-overflow-scrolling:touch;
}
.filter-tabs-row::-webkit-scrollbar{display:none;}
.filter-tabs-row .faq-tab-btn{flex-shrink:0;}

/* Prevent body scroll issues on iOS */
html{-webkit-text-size-adjust:100%;}

/* Safe area for notched phones */
.topbar{padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right));}
.tabbar{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);}

/* Global box safety */
img,svg,video,iframe{max-width:100%;height:auto;}
table{max-width:100%;}

/* Prevent any element from causing horizontal scroll */
.page{overflow-x:hidden;}

/* view all link */
.view-all-link{
  display:flex;align-items:center;justify-content:center;
  height:44px;border-radius:var(--radius-md);
  border:1.5px solid var(--grey-200);background:#fff;
  font-size:13px;font-weight:600;color:var(--navy);
  cursor:pointer;text-decoration:none;transition:all .15s;
  font-family:'Plus Jakarta Sans',sans-serif;
}
.view-all-link:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-light);}
