/* ============================================================
   JobbaNu Design Tokens & Component CSS
   Extracted from HTML demos — single source of truth
   ============================================================ */

/* ── CSS VARIABLES ─────────────────────────────────── */
:root{
  --blue:#005B99;--bm:#0072BB;--bl:#E6F2FA;--bll:#F0F7FC;
  --bg:#F7F9FB;--t:#1A2B3C;--m:#3D5166;--mu:#637387;--bd:#C8D8E8;
  --gn:#1A7A4A;--gnl:#E6F5EE;
  --r:6px;--rs:4px;
  --sh:0 1px 3px rgba(0,0,0,.05),0 4px 16px rgba(0,0,0,.04);
  --shh:0 4px 20px rgba(0,0,0,.12)
}

/* ── RESET (scoped to .jn) ─────────────────────────── */
.jn *,.jn *::before,.jn *::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
.jn{font-family:'Plus Jakarta Sans',sans-serif;background:var(--bg)!important;color:var(--t);-webkit-font-smoothing:antialiased;overflow-x:hidden;width:100%}

/* ── TOPBAR ────────────────────────────────────────── */
.topbar{background:var(--blue);padding:0;width:100%}
.topbar-row1{display:flex;align-items:center;gap:10px;padding:0 14px;height:52px}
.search-pill{flex:1;min-width:0;height:34px;background:rgba(255,255,255,.14);border:none;border-radius:100px;padding:0 12px;color:rgba(255,255,255,.55);font-size:13px;cursor:pointer;display:flex;align-items:center;gap:7px;font-family:inherit}
.search-pill svg{width:13px;height:13px;stroke:rgba(255,255,255,.5);stroke-width:2;fill:none;flex-shrink:0}
.topbar-cta{flex-shrink:0;background:#fff;color:var(--blue);border:none;border-radius:100px;padding:6px 12px;font-size:11.5px;font-weight:700;cursor:pointer;white-space:nowrap;font-family:inherit}

/* ── LOGO WORDMARK ────────────────────────────────── */
.logo-wordmark{font-family:'Sora',sans-serif;font-weight:800;font-size:17px;letter-spacing:-.04em;display:flex;align-items:baseline;line-height:1}
.logo-wordmark .lj{color:rgba(255,255,255,.78)}
.logo-wordmark .ln{color:#fff}
.logo-wordmark .ls{font-size:.52em;font-weight:400;color:rgba(255,255,255,.38);letter-spacing:0;margin-left:2px}
.logo-tagline{font-family:'IBM Plex Sans',sans-serif;font-weight:500;font-size:7px;letter-spacing:.04em;text-transform:uppercase;color:rgba(255,255,255,.32);margin-top:2px}
.footer-logo-wm{font-family:'Sora',sans-serif;font-weight:800;font-size:15px;letter-spacing:-.04em;display:flex;align-items:baseline;line-height:1;margin-bottom:2px}
.footer-logo-wm .lj{color:var(--t)}
.footer-logo-wm .ln{color:var(--blue)}
.footer-logo-wm .ls{font-size:.52em;font-weight:400;color:var(--mu);letter-spacing:0;margin-left:1px}
.footer-logo-tg{font-family:'IBM Plex Sans',sans-serif;font-weight:500;font-size:7px;letter-spacing:.04em;text-transform:uppercase;color:var(--mu);margin-bottom:10px}

/* ── STICKY HOME HEADER ───────────────────────────── */
.home-sticky{position:sticky;top:0;z-index:200;width:100%}

/* ── LIVE BAR ──────────────────────────────────────── */
.live-bar{background:#fff;border-bottom:1px solid var(--bd);padding:8px 14px;display:flex;align-items:center;gap:8px}
.live-bar.hidden{display:none}
.ldot{width:7px;height:7px;border-radius:50%;background:var(--gn);flex-shrink:0;animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.ltxt{font-size:12px;color:var(--m);flex:1;min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.ltxt strong{color:var(--t);font-weight:600}
.ltime{font-size:10.5px;color:var(--mu);white-space:nowrap;flex-shrink:0}

/* ── FILTER BAR ────────────────────────────────────── */
.filter-bar{background:var(--bg);border-bottom:1px solid var(--bd);padding:8px 14px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.filter-count{font-size:12.5px;color:var(--mu)}
.filter-count strong{color:var(--t)}
.city-change-btn{display:flex;align-items:center;gap:5px;flex-shrink:0;background:var(--bl);color:var(--blue);border:1px solid rgba(0,91,153,.2);border-radius:100px;padding:4px 10px;font-size:11.5px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap;transition:all .15s}
.city-change-btn:hover{background:var(--blue);color:#fff}

/* ── MAIN CONTENT AREA ─────────────────────────────── */
.main{padding:14px 14px 100px;max-width:520px;margin:0 auto;animation:fu .22s ease}
@keyframes fu{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}

/* ── HERO ──────────────────────────────────────────── */
.hero{background:#1565C0;border-radius:var(--r);padding:18px 18px 16px;margin-bottom:14px;color:#fff;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;right:-20px;top:-20px;width:110px;height:110px;border-radius:50%;background:rgba(255,255,255,.07)}
.hero::after{content:'';position:absolute;right:30px;bottom:-30px;width:70px;height:70px;border-radius:50%;background:rgba(255,255,255,.05)}
.hero h1{font-family:'Source Serif 4',serif;font-size:20px;font-weight:700;line-height:1.3;margin-bottom:5px}
.hero p{font-size:13px;opacity:.82;line-height:1.6;margin-bottom:12px}
.hero-search{display:flex;align-items:center;gap:9px;background:rgba(255,255,255,.15);border:1.5px solid rgba(255,255,255,.3);border-radius:100px;padding:10px 16px;cursor:pointer;transition:background .15s;position:relative;z-index:1;overflow:hidden}
.hero-search:hover{background:rgba(255,255,255,.22)}
.hero-search svg{width:16px;height:16px;stroke:rgba(255,255,255,.7);stroke-width:2;fill:none;flex-shrink:0}
.hero-search-text{position:relative;height:20px;overflow:hidden;flex:1}
.hero-search-text span{display:block;position:absolute;width:100%;font-size:14px;color:rgba(255,255,255,.65);font-weight:400;line-height:20px;transition:transform .4s ease,opacity .4s ease}
.hero-search-text span.active{transform:translateY(0);opacity:1}
.hero-search-text span.prev{transform:translateY(-100%);opacity:0}
.hero-search-text span.next{transform:translateY(100%);opacity:0}

/* ── TRUST BAR ─────────────────────────────────────── */
.trust{display:flex;background:#fff;border:1px solid var(--bd);border-radius:var(--r);margin-bottom:14px;overflow:hidden;box-shadow:var(--sh)}
.trust-item{flex:1;padding:10px 6px;text-align:center;border-right:1px solid var(--bd)}
.trust-item:last-child{border-right:none}
.trust-num{font-family:'Source Serif 4',serif;font-weight:700;font-size:16px;color:var(--blue);display:block}
.trust-lbl{font-size:10px;color:var(--mu);margin-top:1px}

/* ── SECTION HEADERS ───────────────────────────────── */
.sec-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:10px;margin-top:20px}
.sec-head h2{font-family:'Source Serif 4',serif;font-weight:600;font-size:16px;color:var(--t)}
.sec-head-sub{font-size:11px;color:var(--mu)}
.sec-head-link{font-size:11.5px;font-weight:600;color:var(--blue);cursor:pointer;background:none;border:none;font-family:inherit;padding:0;text-decoration:none}

/* ── WORKER SCROLL CARDS ───────────────────────────── */
.w-scroll{display:flex;gap:10px;overflow-x:auto;margin:0 -14px;padding:2px 14px 10px;scrollbar-width:none}
.w-scroll::-webkit-scrollbar{display:none}
.wcard{flex:0 0 158px;min-width:158px;background:#fff;border:1px solid var(--bd);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh);display:flex;flex-direction:column}
.wavatar-wrap{height:72px;display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}
.wavc{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Source Serif 4',serif;font-size:18px;font-weight:700;color:#fff}
.wonline{position:absolute;bottom:10px;right:38px;width:10px;height:10px;border-radius:50%;background:#22C55E;border:2px solid #fff}
.wbody{padding:0 10px 10px;display:flex;flex-direction:column;flex:1}
.wname{font-weight:700;font-size:12.5px;color:var(--t);margin-top:2px;margin-bottom:1px}
.wrole{font-size:10px;color:var(--blue);font-weight:600;margin-bottom:5px;text-transform:uppercase;letter-spacing:.3px}
.wbio{font-size:11px;color:var(--m);line-height:1.45;margin-bottom:7px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;flex:1}
.wmeta{display:flex;align-items:center;margin-bottom:6px}
.wrating{display:flex;align-items:center;gap:2px;font-size:10.5px;color:var(--mu)}
.wbtn{width:100%;padding:6px;background:var(--blue);color:#fff;border:none;border-radius:var(--rs);font-size:11px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:5px;font-family:inherit;flex-shrink:0}
.wbtn svg{width:12px;height:12px;stroke:#fff;stroke-width:2;fill:none}

/* ── SERVICE CARDS ─────────────────────────────────── */
.svc-scroll{display:flex;gap:10px;overflow-x:auto;margin:0 -14px;padding:2px 14px 10px;scrollbar-width:none}
.svc-scroll::-webkit-scrollbar{display:none}
.svc-card{flex:0 0 140px;min-width:140px;background:#fff;border:1.5px solid var(--bd);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh);cursor:pointer;transition:border-color .15s,box-shadow .15s;display:flex;flex-direction:column}
.svc-card:hover{border-color:var(--bm);box-shadow:var(--shh)}
.svc-card.on{border-color:var(--blue);border-width:2px;box-shadow:0 0 0 3px rgba(0,91,153,.1)}
.svc-icon-wrap{height:64px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.svc-body{padding:7px 9px 9px;display:flex;flex-direction:column;flex:1}
.svc-name{font-family:'Source Serif 4',serif;font-weight:600;font-size:12.5px;color:var(--t);margin-bottom:2px}
.svc-desc{font-size:10px;color:var(--mu);line-height:1.4;margin-bottom:auto;padding-bottom:5px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.svc-row{display:flex;align-items:center;justify-content:space-between}
.svc-avail{font-size:10px;color:var(--gn);font-weight:600}
.svc-price{font-size:11px;font-weight:700;color:var(--t)}
.svc-price span{font-size:9.5px;font-weight:400;color:var(--mu)}
@keyframes svcSlide{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.svc-scroll-inner{display:flex;gap:10px;width:max-content;will-change:transform;padding:2px 14px 10px}
.svc-scroll-inner.animating{animation:svcSlide 40s linear forwards}

/* ── LISTING CARDS (horizontal scroll) ─────────────── */
.feat-scroll{display:flex;gap:10px;overflow-x:auto;margin:0 -14px;padding:2px 14px 10px;scrollbar-width:none}
.feat-scroll::-webkit-scrollbar{display:none}
.card-h{flex:0 0 172px;min-width:172px;background:#fff;border:1px solid var(--bd);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh);cursor:pointer;transition:box-shadow .15s;display:flex;flex-direction:column}
.card-h:hover{box-shadow:var(--shh)}
.ci{position:relative;flex-shrink:0}
.ci-inner{display:flex;align-items:center;justify-content:center;overflow:hidden}
.ci-inner svg{width:100%;height:100%}
.badge{position:absolute;top:6px;left:6px;font-size:9px;font-weight:700;padding:2px 7px;border-radius:100px;color:#fff;background:var(--blue)}
.badge-g{background:var(--gn)}
.heart{position:absolute;top:6px;right:6px;width:24px;height:24px;border-radius:50%;background:rgba(255,255,255,.9);display:flex;align-items:center;justify-content:center;cursor:pointer;border:none}
.heart svg{width:12px;height:12px;stroke-width:2;fill:none}
.cb{padding:9px 10px 11px;display:flex;flex-direction:column;flex:1}
.ccat{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--blue);margin-bottom:2px}
.ctitle{font-family:'Source Serif 4',serif;font-weight:600;font-size:12.5px;color:var(--t);line-height:1.3;margin-bottom:3px}
.cavail{font-size:10.5px;color:var(--mu);margin-bottom:auto;padding-bottom:5px}
.cavail strong{color:var(--gn);font-weight:600}
.cmeta{display:flex;align-items:center;justify-content:space-between;margin-top:4px}
.crating{display:flex;align-items:center;gap:2px;font-size:10.5px;color:var(--m)}

/* ── GRID + LIST CARDS ─────────────────────────────── */
.cards-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.card-v{background:#fff;border:1px solid var(--bd);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh);cursor:pointer;transition:box-shadow .15s;display:flex;flex-direction:column}
.card-v:hover{box-shadow:var(--shh)}
.card-v .ci-inner{height:100px}
.card-v .cb{flex:1}
.card-list{display:flex;background:#fff;border:1px solid var(--bd);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh);cursor:pointer;margin-bottom:10px;transition:box-shadow .15s}
.card-list:hover{box-shadow:var(--shh)}
.card-list .ci-inner{width:84px;height:84px;flex-shrink:0}
.card-list .cb{flex:1;display:flex;flex-direction:column;justify-content:space-between}

/* ── RECENT POSTS ──────────────────────────────────── */
.recents-section{margin-bottom:0}
.recents-lbl{font-size:9.5px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;color:var(--blue);margin-bottom:10px;display:block}
.recents-list{border:1px solid var(--bd);border-radius:var(--r);overflow:hidden;background:#fff;box-shadow:var(--sh)}
.recent-item{display:flex;align-items:stretch;border-bottom:1px solid var(--bd);cursor:pointer;transition:background .12s}
.recent-item:last-child{border-bottom:none}
.recent-item:hover{background:var(--bll)}
.recent-item:hover .rarr{opacity:1}
.recent-cat-bar{width:3px;flex-shrink:0}
.recent-body{flex:1;padding:10px 11px}
.recent-meta{font-size:10px;color:var(--mu);margin-bottom:3px;display:flex;align-items:center;gap:6px}
.recent-meta span{background:var(--bl);color:var(--blue);border-radius:100px;padding:1px 7px;font-weight:600;font-size:9.5px}
.recent-title{font-size:13px;font-weight:600;color:var(--t);line-height:1.3}
.rarr{width:15px;height:15px;stroke:var(--mu);stroke-width:2;fill:none;flex-shrink:0;opacity:0;align-self:center;margin-right:11px;transition:opacity .12s}
.no-res{text-align:center;padding:36px 0;color:var(--mu);font-size:13px}

/* ── MODALS ────────────────────────────────────────── */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:500;align-items:flex-end;justify-content:center}
.modal-bg.open{display:flex}
.lm-sheet{background:#fff;border-radius:16px 16px 0 0;width:100%;max-width:520px;max-height:82vh;overflow:hidden;animation:su .22s ease;display:flex;flex-direction:column}
@keyframes su{from{transform:translateY(100%)}to{transform:translateY(0)}}
.lm-handle{width:32px;height:4px;background:var(--bd);border-radius:4px;margin:13px auto 6px;flex-shrink:0}
.lm-inner{padding:0;flex:1;overflow-y:auto;display:flex;flex-direction:column}
.lm-hdr{display:flex;align-items:center;gap:12px;padding:14px 16px 13px;border-bottom:1px solid var(--bd);flex-shrink:0}
.lm-ava{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Source Serif 4',serif;font-size:16px;font-weight:700;color:#fff;flex-shrink:0}
.lm-title{font-family:'Source Serif 4',serif;font-size:16px;font-weight:700;color:var(--t);margin-bottom:1px}
.lm-sub{font-size:11px;color:var(--blue);font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.lm-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:13px}
.lm-cell{background:var(--bg);border-radius:var(--rs);padding:10px 12px}
.lm-cell-lbl{font-size:9.5px;color:var(--mu);text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px}
.lm-cell-val{font-size:12.5px;font-weight:600;color:var(--t)}
.sec-lbl{font-size:9.5px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--blue);margin-bottom:8px;display:block}

/* ── DETAIL SCREEN (inside modal) ──────────────────── */
.dp-hero{background:var(--blue);padding:20px 16px 16px;color:#fff;flex-shrink:0}
.dp-ava-row{display:flex;align-items:center;gap:14px;margin-bottom:10px}
.dp-ava{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Source Serif 4',serif;font-size:22px;font-weight:700;color:#fff;flex-shrink:0;border:2px solid rgba(255,255,255,.3)}
.dp-ava-info{flex:1}
.dp-name{font-family:'Source Serif 4',serif;font-size:19px;font-weight:700;color:#fff}
.dp-role{font-size:12px;color:rgba(255,255,255,.7);margin-top:2px}
.dp-stars{display:flex;align-items:center;gap:5px;margin-top:4px}
.dp-online{width:8px;height:8px;border-radius:50%;background:#4ADE80;flex-shrink:0}
.dp-body{flex:1;overflow-y:auto;padding:0 0 90px}
.dp-section{padding:14px 16px;border-bottom:1px solid var(--bd)}
.dp-section-lbl{font-size:9.5px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--blue);margin-bottom:8px}
.dp-bio{font-size:14px;color:var(--m);line-height:1.7}
.dp-match{background:var(--bl);border-radius:var(--r);padding:12px 14px;margin-top:8px}
.dp-match-lbl{font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--blue);margin-bottom:5px}
.dp-match-txt{font-size:13px;color:var(--m);line-height:1.6}
.dp-chips{display:flex;flex-wrap:wrap;gap:7px}
.dp-chip{padding:5px 12px;border-radius:100px;background:var(--bl);color:var(--blue);font-size:12.5px;font-weight:600;border:none}
.dp-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.dp-cell{background:var(--bg);border-radius:var(--rs);padding:10px 12px}
.dp-cell-lbl{font-size:9.5px;color:var(--mu);text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px}
.dp-cell-val{font-size:13px;font-weight:600;color:var(--t)}
.dp-cta{position:absolute;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--bd);padding:14px 16px;padding-bottom:calc(14px + env(safe-area-inset-bottom))}
.dp-hire-btn{width:100%;padding:15px;background:var(--blue);color:#fff;border:none;border-radius:var(--r);font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:8px}
.dp-hire-btn svg{width:18px;height:18px;stroke:#fff;stroke-width:2;fill:none}

/* ── MULTI-STEP FORM ───────────────────────────────── */
.mf-wrap{flex:1;display:flex;flex-direction:column;overflow:hidden}
.mf-progress{height:3px;background:var(--bd);flex-shrink:0}
.mf-progress-fill{height:3px;background:var(--blue);transition:width .35s ease}
.mf-step-lbl{font-size:11px;color:var(--mu);padding:8px 16px 0;flex-shrink:0}
.mf-step-lbl strong{color:var(--t)}
.mf-body{flex:1;overflow-y:auto;padding:16px 16px 8px;-webkit-overflow-scrolling:touch}
.mf-step-title{font-family:'Source Serif 4',serif;font-size:20px;font-weight:700;color:var(--t);margin-bottom:6px;line-height:1.25}
.mf-step-sub{font-size:13.5px;color:var(--mu);margin-bottom:20px;line-height:1.6}
.mf-option{display:flex;align-items:center;gap:14px;padding:15px 14px;border:2px solid var(--bd);border-radius:var(--r);cursor:pointer;margin-bottom:9px;transition:all .15s;background:#fff;width:100%;text-align:left;font-family:inherit}
.mf-option:hover{border-color:var(--bm);background:var(--bll)}
.mf-option.on{border-color:var(--blue);background:var(--bl)}
.mf-option-icon{width:38px;height:38px;border-radius:50%;background:var(--bg);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}
.mf-option.on .mf-option-icon{background:var(--blue)}
.mf-option-icon svg{width:18px;height:18px;stroke:var(--mu);stroke-width:1.8;fill:none;transition:stroke .15s}
.mf-option.on .mf-option-icon svg{stroke:#fff}
.mf-option-text{flex:1;min-width:0}
.mf-option-lbl{font-size:15px;font-weight:600;color:var(--t)}
.mf-option.on .mf-option-lbl{color:var(--blue)}
.mf-option-desc{font-size:12px;color:var(--mu);margin-top:2px;line-height:1.4}
.mf-option-chk{width:22px;height:22px;border-radius:50%;border:2px solid var(--bd);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s}
.mf-option.on .mf-option-chk{background:var(--blue);border-color:var(--blue)}
.mf-option.on .mf-option-chk::after{content:'';width:5px;height:9px;border-right:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(45deg) translate(-1px,-1px);display:block}
.mf-opts-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:6px}
.mf-opt-sm{padding:12px 10px;border:2px solid var(--bd);border-radius:var(--r);cursor:pointer;text-align:center;transition:all .15s;background:#fff;font-family:inherit;font-size:14px;font-weight:500;color:var(--m)}
.mf-opt-sm:hover{border-color:var(--bm);color:var(--blue)}
.mf-opt-sm.on{border-color:var(--blue);background:var(--bl);color:var(--blue);font-weight:600}
.mf-field{margin-bottom:14px}
.mf-field label{display:block;font-size:14px;font-weight:600;color:var(--m);margin-bottom:6px}
.mf-field input,.mf-field textarea,.mf-field select{width:100%;padding:13px 14px;border:1.5px solid var(--bd);border-radius:var(--r);font-size:16px;font-family:inherit;background:#fff;color:var(--t);outline:none;transition:border-color .15s;appearance:none}
.mf-field input:focus,.mf-field textarea:focus,.mf-field select:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,91,153,.1)}
.mf-field textarea{resize:none;min-height:90px}
.mf-footer{padding:12px 16px;border-top:1px solid var(--bd);display:flex;align-items:center;gap:10px;flex-shrink:0;background:#fff}
.mf-btn-next{flex:1;padding:15px;background:var(--blue);color:#fff;border:none;border-radius:var(--r);font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;transition:background .15s}
.mf-btn-next:hover{background:var(--bm)}
.mf-btn-next.disabled{background:#94A3B8;cursor:not-allowed;opacity:0.7}
.mf-btn-back{width:44px;height:44px;background:transparent;border:1.5px solid var(--bd);border-radius:var(--r);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}
.mf-btn-back:hover{border-color:var(--blue)}
.mf-btn-back svg{width:18px;height:18px;stroke:var(--m);stroke-width:2;fill:none}
.mf-btn-skip{font-size:12.5px;color:var(--mu);background:none;border:none;cursor:pointer;font-family:inherit;padding:4px 0;flex-shrink:0;text-decoration:underline}
.mf-ok{text-align:center;padding:32px 16px;display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;min-height:300px}
.mf-ok-circle{width:64px;height:64px;background:var(--gnl);border:2px solid var(--gn);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.mf-ok-circle svg{width:28px;height:28px;stroke:var(--gn);stroke-width:2;fill:none}
.mf-ok-title{font-family:'Source Serif 4',serif;font-size:20px;font-weight:700;color:var(--t);margin-bottom:8px}
.mf-ok-body{font-size:14px;color:var(--mu);line-height:1.7;margin-bottom:24px}
.mf-info-circle{width:64px;height:64px;background:var(--bl);border:2px solid var(--blue);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.mf-info-circle svg{width:28px;height:28px;stroke:var(--blue);stroke-width:2;fill:none}
.mf-media-zone{border:1.5px dashed var(--bd);border-radius:var(--r);padding:18px 14px;text-align:center;cursor:pointer;position:relative;background:#fff;transition:all .15s}
.mf-media-zone:hover{border-color:var(--blue);background:var(--bll)}
.mf-media-zone input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.mf-media-zone svg{width:26px;height:26px;stroke:var(--mu);stroke-width:1.5;fill:none;margin:0 auto 8px;display:block}
.mf-media-lbl{font-size:14px;font-weight:600;color:var(--m)}
.mf-media-sub{font-size:11.5px;color:var(--mu);margin-top:3px}
.mf-media-preview{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.mf-media-thumb{position:relative;width:66px;height:66px}
.mf-media-thumb img,.mf-media-thumb video{width:66px;height:66px;border-radius:var(--rs);object-fit:cover;border:1px solid var(--bd);display:block}
.mf-media-rm{position:absolute;top:-5px;right:-5px;width:18px;height:18px;border-radius:50%;background:#C0392B;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center}
.mf-media-rm svg{width:9px;height:9px;stroke:#fff;stroke-width:2.5;fill:none}
.mf-media-err{font-size:12px;color:#C0392B;margin-top:6px}
.mf-field-hint{font-size:11.5px;color:#e53e3e;margin-top:4px;display:none}
.mf-field-hint.show{display:block}
@keyframes fieldPulse{0%{border-color:#e53e3e;box-shadow:0 0 0 0 rgba(229,62,62,.5)}50%{box-shadow:0 0 0 5px rgba(229,62,62,0)}100%{border-color:var(--bd);box-shadow:none}}
.field-pulse{animation:fieldPulse .7s ease forwards}
@keyframes fieldPulseRepeat{0%{border-color:#e53e3e;box-shadow:0 0 0 0 rgba(229,62,62,.6)}25%{box-shadow:0 0 0 5px rgba(229,62,62,0)}50%{border-color:#e53e3e;box-shadow:0 0 0 0 rgba(229,62,62,.4)}75%{box-shadow:0 0 0 4px rgba(229,62,62,0)}100%{border-color:#e53e3e;box-shadow:none}}
.field-pulse-required{animation:fieldPulseRepeat 1s ease forwards;border-color:#e53e3e!important}
@keyframes mfSlideUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.mf-wrap.slide-up{animation:mfSlideUp .25s ease}
@keyframes mfSlideInRight{from{opacity:0;transform:translateX(32px)}to{opacity:1;transform:translateX(0)}}
@keyframes mfSlideInLeft{from{opacity:0;transform:translateX(-32px)}to{opacity:1;transform:translateX(0)}}
.mf-body.slide-in-right{animation:mfSlideInRight .22s ease}
.mf-body.slide-in-left{animation:mfSlideInLeft .22s ease}

/* ── CITY MODAL ────────────────────────────────────── */
.city-sheet{background:#fff;border-radius:16px 16px 0 0;width:100%;max-width:520px;padding:16px 16px 36px;animation:su .22s ease}
.city-handle{width:32px;height:4px;background:var(--bd);border-radius:4px;margin:0 auto 13px}
.city-title{font-family:'Source Serif 4',serif;font-weight:600;font-size:16px;color:var(--t);margin-bottom:11px}
.city-search-wrap{position:relative;margin-bottom:10px}
.city-search-wrap input{width:100%;padding:9px 32px 9px 11px;border:1.5px solid var(--bd);border-radius:var(--r);font-size:16px;font-family:inherit;background:#fff;color:var(--t);outline:none}
.city-search-wrap input:focus{border-color:var(--blue)}
.city-search-wrap svg{position:absolute;right:10px;top:50%;transform:translateY(-50%);stroke:var(--mu);width:13px;height:13px;stroke-width:2;fill:none;pointer-events:none}
.city-list{display:flex;flex-wrap:wrap;gap:6px;max-height:320px;overflow-y:auto}
.city-opt{padding:6px 12px;border-radius:100px;border:1.5px solid var(--bd);font-size:13px;cursor:pointer;background:#fff;color:var(--m);transition:all .15s;font-family:inherit}
.city-opt.on{border-color:var(--blue);background:var(--blue);color:#fff}
.city-opt.hidden{display:none}
.city-detected{font-size:11px;color:var(--gn);font-weight:600;margin-bottom:8px;display:flex;align-items:center;gap:5px}
.city-detected svg{width:12px;height:12px;stroke:var(--gn);stroke-width:2;fill:none}

/* ── SEARCH PAGE ───────────────────────────────────── */
.search-page{display:none;position:fixed;inset:0;top:52px;background:#F7F9FB;z-index:150;overflow-y:auto;padding-bottom:80px}
.search-page.show{display:block;animation:fu .2s ease}
.sp-head{background:var(--blue);padding:12px 14px 0}
.sp-bar-wrap{position:relative;margin-bottom:10px}
.sp-bar-wrap input{width:100%;height:44px;padding:0 44px 0 42px;border:none;border-radius:100px;font-size:15px;font-family:inherit;background:rgba(255,255,255,.15);color:#fff;outline:none;-webkit-appearance:none}
.sp-bar-wrap input::placeholder{color:rgba(255,255,255,.5)}
.sp-bar-wrap input:focus{background:rgba(255,255,255,.22)}
.sp-bar-ico{position:absolute;left:13px;top:50%;transform:translateY(-50%);width:17px;height:17px;stroke:rgba(255,255,255,.6);stroke-width:2;fill:none;pointer-events:none}
.sp-bar-clear{position:absolute;right:12px;top:50%;transform:translateY(-50%);width:20px;height:20px;border-radius:50%;background:rgba(255,255,255,.25);border:none;cursor:pointer;display:none;align-items:center;justify-content:center}
.sp-bar-clear.show{display:flex}
.sp-bar-clear svg{width:10px;height:10px;stroke:#fff;stroke-width:2.5;fill:none}
.sp-cats{display:flex;gap:6px;overflow-x:auto;padding-bottom:10px;scrollbar-width:none}
.sp-cats::-webkit-scrollbar{display:none}
.sp-cpill{display:inline-flex;align-items:center;gap:5px;padding:5px 11px;border-radius:100px;border:1.5px solid rgba(255,255,255,.25);cursor:pointer;flex-shrink:0;font-size:12px;font-weight:600;color:rgba(255,255,255,.65);white-space:nowrap;background:transparent;transition:all .15s;font-family:inherit}
.sp-cpill svg{width:12px;height:12px;stroke:currentColor;stroke-width:1.9;fill:none;flex-shrink:0}
.sp-cpill.on{color:#fff;background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.7)}
.sp-filters{background:#fff;border-bottom:1px solid var(--bd);padding:10px 14px;display:flex;align-items:center;gap:8px}
.sp-city-btn{display:flex;align-items:center;gap:5px;background:var(--bl);color:var(--blue);border:1px solid rgba(0,91,153,.2);border-radius:100px;padding:5px 11px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap}
.sp-city-btn svg{width:11px;height:11px;stroke:var(--blue);stroke-width:2;fill:none}
.sp-count{font-size:12px;color:var(--mu);margin-left:auto}
.sp-count strong{color:var(--t)}
.sp-body{padding:12px 14px}
.sp-empty{text-align:center;padding:52px 0;color:var(--mu)}
.sp-empty svg{width:38px;height:38px;stroke:var(--bd);stroke-width:1.5;fill:none;display:block;margin:0 auto 12px}
.sp-empty p{font-size:13.5px;margin-bottom:4px}
.sp-empty span{font-size:12px}
.sp-hint{text-align:center;padding:40px 0;color:var(--mu);font-size:13px}
.sp-hint svg{width:36px;height:36px;stroke:var(--bd);stroke-width:1.5;fill:none;display:block;margin:0 auto 12px}
.sp-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.sp-section-lbl{font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--blue);margin:14px 0 8px;display:block}
.sp-sort-btn,.sp-job-btn{display:flex;align-items:center;gap:5px;background:#fff;border:1.5px solid var(--bd);border-radius:100px;padding:5px 10px;font-size:12px;font-weight:600;color:var(--m);cursor:pointer;font-family:inherit;white-space:nowrap;transition:all .15s}
.sp-sort-btn:hover,.sp-sort-btn.active,.sp-job-btn:hover,.sp-job-btn.active{border-color:var(--blue);color:var(--blue);background:var(--bl)}
.sp-sort-btn svg,.sp-job-btn svg{width:11px;height:11px;stroke:currentColor;stroke-width:2;fill:none}
@keyframes searchPulse{0%{box-shadow:0 0 0 0 rgba(0,91,153,.5)}70%{box-shadow:0 0 0 8px rgba(0,91,153,0)}100%{box-shadow:0 0 0 0 rgba(0,91,153,0)}}
.sp-bar-wrap input.pulse{animation:searchPulse .6s ease-out}

/* ── SORT / JOB MODALS ─────────────────────────────── */
.sort-modal-bg,.job-modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:600;align-items:flex-end;justify-content:center}
.sort-modal-bg.open,.job-modal-bg.open{display:flex}
.sort-sheet,.job-sheet{background:#fff;border-radius:16px 16px 0 0;width:100%;max-width:520px;animation:su .22s ease;padding-bottom:env(safe-area-inset-bottom)}
.sort-handle,.job-handle{width:32px;height:4px;background:var(--bd);border-radius:4px;margin:13px auto 0}
.sort-sheet-title,.job-sheet-title{font-family:'Source Serif 4',serif;font-weight:600;font-size:16px;color:var(--t);padding:14px 16px 10px;border-bottom:1px solid var(--bd)}
.sort-option{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--bd);cursor:pointer;transition:background .1s}
.sort-option:last-child{border-bottom:none;margin-bottom:6px}
.sort-option:hover{background:var(--bll)}
.sort-option.sel{color:var(--blue)}
.sort-option-lbl{font-size:15px;font-weight:500;color:inherit}
.sort-option.sel .sort-option-lbl{font-weight:600}
.sort-option-chk{width:20px;height:20px;border-radius:50%;border:2px solid var(--bd);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}
.sort-option.sel .sort-option-chk{background:var(--blue);border-color:var(--blue)}
.sort-option.sel .sort-option-chk::after{content:'';width:5px;height:9px;border-right:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(45deg) translate(-1px,-1px);display:block}
.job-sheet-inner{padding:12px 14px 20px}
.job-search-wrap{position:relative;margin-bottom:12px}
.job-search-wrap input{width:100%;padding:10px 36px 10px 12px;border:1.5px solid var(--bd);border-radius:100px;font-size:16px;font-family:inherit;outline:none;background:#fff;color:var(--t)}
.job-search-wrap input:focus{border-color:var(--blue)}
.job-search-wrap svg{position:absolute;right:12px;top:50%;transform:translateY(-50%);stroke:var(--mu);width:14px;height:14px;stroke-width:2;fill:none;pointer-events:none}
.job-pills{display:flex;flex-wrap:wrap;gap:8px}
.job-pill{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:100px;border:1.5px solid var(--bd);background:#fff;font-size:13px;font-weight:500;color:var(--m);cursor:pointer;transition:all .15s;font-family:inherit}
.job-pill svg{width:13px;height:13px;stroke:currentColor;stroke-width:1.9;fill:none}
.job-pill:hover{border-color:var(--bm);color:var(--blue)}
.job-pill.on{border-color:var(--blue);background:var(--bl);color:var(--blue);font-weight:600}
.job-pill.hidden{display:none}

/* ── VISA ALLA MODAL ───────────────────────────────── */
.visaalla-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:600;align-items:flex-end;justify-content:center}
.visaalla-bg.open{display:flex}
.visaalla-sheet{background:#fff;border-radius:16px 16px 0 0;width:100%;max-width:520px;animation:su .22s ease;padding-bottom:env(safe-area-inset-bottom)}
.visaalla-handle{width:32px;height:4px;background:var(--bd);border-radius:4px;margin:13px auto 0}
.visaalla-title{font-family:'Source Serif 4',serif;font-weight:600;font-size:16px;color:var(--t)}
.visaalla-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;padding:14px 14px 24px;max-height:72vh;overflow-y:auto}
.va-card{background:var(--bg);border:1.5px solid var(--bd);border-radius:var(--r);padding:12px 8px 10px;text-align:center;cursor:pointer;transition:all .15s;display:flex;flex-direction:column;align-items:center;gap:6px}
.va-card:hover,.va-card.on{border-color:var(--blue);background:var(--bl)}
.va-card svg{width:24px;height:24px}
.va-card-name{font-size:11.5px;font-weight:600;color:var(--t)}
.va-card.on .va-card-name{color:var(--blue)}
.va-subcat-row{display:flex;align-items:center;gap:12px;padding:13px 0;border-bottom:1px solid var(--bd);cursor:pointer;transition:background .1s}
.va-subcat-row:last-child{border-bottom:none}
.va-subcat-row:hover{background:var(--bll);margin:0 -14px;padding-left:14px;padding-right:14px}
.va-subcat-info{flex:1;min-width:0}
.va-subcat-name{font-size:14px;font-weight:600;color:var(--t);margin-bottom:2px}
.va-subcat-desc{font-size:12px;color:var(--mu)}
.va-subcat-avail{font-size:12px;color:var(--gn);font-weight:700;white-space:nowrap;flex-shrink:0}
.va-subcat-avail span{font-size:15px}
.visaalla-hdr{display:flex;align-items:center;gap:10px;padding:14px 16px 12px;border-bottom:1px solid var(--bd)}
.visaalla-back{width:32px;height:32px;border-radius:50%;border:1.5px solid var(--bd);background:#fff;cursor:pointer;display:none;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}
.visaalla-back:hover{border-color:var(--blue)}
.visaalla-back svg{width:14px;height:14px;stroke:var(--m);stroke-width:2;fill:none}

/* ── BOTTOM NAVIGATION ─────────────────────────────── */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--bd);display:flex;z-index:300;padding-bottom:env(safe-area-inset-bottom)}
.nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;padding:8px 0 11px;gap:3px;cursor:pointer;font-size:9.5px;color:var(--mu);font-weight:500;background:none;border:none;font-family:inherit;transition:color .15s;text-decoration:none}
.nav-btn svg{width:20px;height:20px;stroke:currentColor;stroke-width:1.8;fill:none}
.nav-btn.active{color:var(--blue)}

/* ── FOOTER ────────────────────────────────────────── */
.site-footer{padding:22px 14px 0;border-top:1px solid var(--bd);margin-top:20px}
.fd{font-size:12px;color:var(--mu);line-height:1.65;margin-bottom:14px}
.fr{display:flex;align-items:center;flex-wrap:nowrap;overflow-x:auto;padding-bottom:8px;scrollbar-width:none}
.fr::-webkit-scrollbar{display:none}
.fr a{font-size:11.5px;color:var(--mu);text-decoration:none;padding:0 8px;border-right:1px solid var(--bd);line-height:1;white-space:nowrap;display:inline-flex;align-items:center;gap:4px;flex-shrink:0}
.fr a:first-child{padding-left:0}
.fr a:last-child{border-right:none}
.fr a:hover{color:var(--blue)}
.wa-link:hover{color:#25D366!important}
.wa-link svg{width:13px;height:13px;fill:currentColor}

/* ── iOS FIXES ─────────────────────────────────────── */
.jn input,.jn textarea,.jn select{font-size:16px!important;-webkit-text-size-adjust:100%;touch-action:manipulation}
