/* ============================================================
   HireHealthcare.ca — Visual system (2026 refresh)
   Direction: clinical-calm. Plus Jakarta Sans display +
   Inter body + JetBrains Mono for all data (counts/price/dates).
   Brand: healthcare teal → sky → indigo, deep clinical navy ink.
   Class API preserved so all existing PHP pages keep working.
   ============================================================ */

:root{
    /* ink + text */
    --ink:#0a1a2b;
    --ink-soft:#23394e;
    --muted:#5c7286;
    --muted-2:#7b8ea0;

    /* brand */
    --brand:#0ca6ba;
    --brand-ink:#0a7e8e;
    --brand-deep:#0c3b6e;
    --accent:#4f46e5;
    --mint:#12b5a4;
    --sky:#0ea5e9;

    /* surfaces */
    --bg:#f4f8fb;
    --bg-2:#eaf2f8;
    --card:#ffffff;
    --line:#e4eef4;
    --line-2:#d6e4ee;
    --soft:#ecfbff;
    --soft-2:#eef3ff;

    /* status */
    --danger:#c0362b;
    --warning:#9a6700;
    --success:#067a4e;

    /* gradients */
    --grad:linear-gradient(135deg,var(--mint) 0%,var(--sky) 48%,var(--accent) 100%);
    --grad-soft:linear-gradient(135deg,#d6fbf4,#dcecff);

    /* shadow (layered, soft) */
    --shadow:0 1px 2px rgba(10,26,43,.04),0 18px 48px -18px rgba(10,26,43,.22);
    --shadow-soft:0 1px 2px rgba(10,26,43,.04),0 10px 30px -16px rgba(10,26,43,.16);
    --shadow-lg:0 2px 4px rgba(10,26,43,.05),0 36px 80px -28px rgba(10,26,43,.30);

    /* radii */
    --r-xl:30px;
    --r-lg:22px;
    --radius:22px;
    --r:16px;
    --r-sm:12px;
    --pill:999px;

    /* type */
    --font-display:"Plus Jakarta Sans",ui-sans-serif,system-ui,-apple-system,"Segoe UI",sans-serif;
    --font-body:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
    --font-mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
    margin:0;
    font-family:var(--font-body);
    background:var(--bg);
    color:var(--ink);
    line-height:1.62;
    overflow-x:hidden;
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
    /* faint ambient grid wash */
    background-image:
        radial-gradient(1100px 500px at 88% -8%, rgba(14,165,233,.07), transparent 60%),
        radial-gradient(900px 500px at -6% 4%, rgba(18,181,164,.07), transparent 55%);
    background-attachment:fixed;
}
h1,h2,h3,h4{font-family:var(--font-display);color:var(--ink);font-weight:800;letter-spacing:-.02em}
a{color:var(--brand-ink);text-decoration:none;transition:color .16s ease}
a:hover{color:var(--accent)}
img{max-width:100%}
::selection{background:rgba(14,165,233,.18)}
.container{width:min(1180px,92%);margin:0 auto}

/* ---------------------------------- focus a11y */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
    outline:3px solid rgba(79,70,229,.40);
    outline-offset:2px;
    border-radius:8px;
}

/* ============================================================ HEADER / NAV */
.site-header{
    position:sticky;top:0;z-index:40;
    background:rgba(248,251,253,.72);
    backdrop-filter:saturate(160%) blur(18px);
    -webkit-backdrop-filter:saturate(160%) blur(18px);
    border-bottom:1px solid transparent;
    transition:border-color .25s ease, background .25s ease, box-shadow .25s ease;
}
.site-header.scrolled{
    background:rgba(248,251,253,.88);
    border-bottom-color:rgba(214,228,238,.9);
    box-shadow:0 10px 30px -22px rgba(10,26,43,.45);
}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;min-height:72px;gap:20px}
.brand{display:inline-flex;align-items:center;color:var(--ink);text-decoration:none;flex:0 0 auto;padding:10px 0;line-height:0}
.brand-logo{height:34px;width:auto;max-width:min(240px,54vw);display:block;object-fit:contain}
.main-nav{display:flex;align-items:center;gap:6px}
.main-nav a{
    color:var(--ink-soft);font-weight:600;font-size:14.5px;white-space:nowrap;
    padding:9px 13px;border-radius:var(--pill);transition:.16s ease;
}
.main-nav a:hover{color:var(--ink);background:rgba(12,166,186,.09)}
.main-nav a.nav-cta{
    background:var(--grad);color:#fff;font-weight:700;padding:11px 18px;margin-left:6px;
    box-shadow:0 12px 26px -10px rgba(79,70,229,.55);position:relative;
}
.main-nav a.nav-cta:hover{color:#fff;transform:translateY(-1px);filter:brightness(1.04);box-shadow:0 16px 32px -10px rgba(79,70,229,.6)}
.nav-toggle{display:none;background:var(--card);border:1px solid var(--line-2);border-radius:14px;font-size:20px;padding:8px 12px;color:var(--ink);cursor:pointer}

/* ============================================================ HERO */
.hero{
    position:relative;overflow:hidden;padding:84px 0 48px;
    background:
        radial-gradient(60% 70% at 12% 6%, rgba(18,181,164,.20), transparent 60%),
        radial-gradient(55% 65% at 86% 12%, rgba(79,70,229,.16), transparent 58%),
        radial-gradient(50% 60% at 60% 100%, rgba(14,165,233,.12), transparent 60%),
        linear-gradient(180deg,#ffffff 0%,#f1f8fd 100%);
}
.hero:before{
    content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
    background-image:linear-gradient(rgba(12,59,110,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(12,59,110,.04) 1px,transparent 1px);
    background-size:46px 46px;
    -webkit-mask-image:radial-gradient(120% 80% at 50% 0%,#000 35%,transparent 78%);
            mask-image:radial-gradient(120% 80% at 50% 0%,#000 35%,transparent 78%);
}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center}
.hero-copy{min-width:0}
.eyebrow{
    display:inline-flex;gap:9px;align-items:center;padding:7px 14px;border-radius:var(--pill);
    background:rgba(255,255,255,.72);color:var(--brand-deep);
    font-family:var(--font-mono);font-weight:600;font-size:11.5px;letter-spacing:.04em;text-transform:uppercase;
    border:1px solid var(--line-2);box-shadow:var(--shadow-soft);backdrop-filter:blur(6px);
}
.eyebrow:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--mint);box-shadow:0 0 0 4px rgba(18,181,164,.18);animation:pulse 2.4s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.45}}
.hero h1{font-size:clamp(40px,6vw,68px);line-height:1.03;margin:20px 0 18px;letter-spacing:-.04em;font-weight:800}
.hero h1 .grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero p{font-size:18.5px;color:var(--muted);max-width:560px}

.hero-visual{position:relative;min-height:480px;display:flex;align-items:flex-end;justify-content:center}
.hero-worker{position:relative;z-index:2;max-height:450px;max-width:64%;object-fit:contain;filter:drop-shadow(0 30px 36px rgba(10,26,43,.20))}
.hero-bubble{position:absolute;border-radius:999px;filter:blur(2px)}
.hero-bubble.one{width:300px;height:300px;background:radial-gradient(circle at 30% 30%,rgba(18,181,164,.55),rgba(79,70,229,.30));right:8%;bottom:30px;opacity:.55;animation:float 8s ease-in-out infinite}
.hero-bubble.two{width:130px;height:130px;background:radial-gradient(circle at 30% 30%,rgba(14,165,233,.6),rgba(18,181,164,.3));left:12%;top:48px;opacity:.6;animation:float 7s ease-in-out infinite reverse}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}
.floating-card{
    position:absolute;right:2%;bottom:54px;z-index:3;
    background:rgba(255,255,255,.82);border:1px solid rgba(255,255,255,.9);
    backdrop-filter:blur(16px);border-radius:18px;padding:15px 18px;box-shadow:var(--shadow-lg);
    display:flex;flex-direction:column;gap:2px;
}
.floating-card:before{content:"● live";font-family:var(--font-mono);font-size:9.5px;letter-spacing:.1em;color:var(--success);text-transform:uppercase}
.floating-card strong{font-family:var(--font-mono);font-size:30px;letter-spacing:-.04em;color:var(--brand-deep);line-height:1.05;font-weight:700;font-variant-numeric:tabular-nums}
.floating-card span{font-size:12.5px;color:var(--muted);font-weight:600}

.trust-row{display:flex;gap:9px;flex-wrap:wrap;margin-top:24px}
.trust-row span,.feature-list span{
    display:inline-flex;align-items:center;gap:6px;padding:8px 13px;border-radius:var(--pill);
    background:rgba(255,255,255,.7);border:1px solid var(--line-2);font-weight:600;color:var(--ink-soft);font-size:13px;
    box-shadow:var(--shadow-soft);
}
.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}

/* ============================================================ BUTTONS */
.btn,.button{
    display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;
    border-radius:var(--pill);padding:13px 22px;background:var(--grad);color:#fff;
    font-family:var(--font-body);font-weight:700;font-size:15px;cursor:pointer;text-decoration:none;
    box-shadow:0 14px 30px -12px rgba(79,70,229,.55);
    transition:transform .16s ease,box-shadow .16s ease,filter .16s ease;
}
.btn:hover,.button:hover{transform:translateY(-2px);color:#fff;filter:brightness(1.05);box-shadow:0 20px 38px -12px rgba(79,70,229,.6)}
.btn:active,.button:active{transform:translateY(0)}
.btn-secondary{background:var(--card);color:var(--ink);border:1px solid var(--line-2);box-shadow:var(--shadow-soft)}
.btn-secondary:hover{background:#fff;color:var(--brand-ink);border-color:var(--brand);box-shadow:var(--shadow)}
.btn-danger{background:var(--danger);box-shadow:0 14px 30px -12px rgba(192,54,43,.5)}

/* ============================================================ SECTIONS */
.section{padding:64px 0}
.compact-top{padding-top:40px}
.section-title{display:flex;justify-content:space-between;gap:24px;align-items:end;margin-bottom:30px}
.section-title h2{font-size:clamp(28px,3.6vw,42px);line-height:1.08;margin:0;letter-spacing:-.03em}
.section-title p{color:var(--muted);margin:10px 0 0;max-width:620px}

.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.align-center{align-items:center}

/* ============================================================ CARDS */
.card{
    background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
    padding:26px;box-shadow:var(--shadow-soft);
    transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}
.stat-card{position:relative;overflow:hidden}
.stat-card:before{content:"";position:absolute;left:0;top:0;height:3px;width:100%;background:var(--grad);opacity:.9}
.stat-card:after{content:"";position:absolute;right:-40px;top:-40px;width:130px;height:130px;background:radial-gradient(circle,rgba(18,181,164,.16),transparent 70%);border-radius:50%}
.stat-card span{color:var(--muted);font-weight:700;font-size:13.5px}
.stat-card strong{
    display:block;font-family:var(--font-mono);font-size:50px;letter-spacing:-.04em;line-height:1;
    margin-top:12px;color:var(--brand-deep);font-weight:700;font-variant-numeric:tabular-nums;
}
.counters .stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--line-2)}

.trust-section{padding-top:28px}
.trust-card{position:relative}
.trust-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--line-2)}
.trust-card h3{font-size:21px;margin:16px 0 8px}
.trust-card p{margin:0;color:var(--muted)}
.icon-pill,.cta-icon{
    width:52px;height:52px;border-radius:15px;display:flex;align-items:center;justify-content:center;font-size:24px;
    background:var(--grad-soft);border:1px solid var(--line);box-shadow:inset 0 1px 0 rgba(255,255,255,.7);
}

/* ============================================================ BADGES */
.badge{
    display:inline-flex;align-items:center;gap:6px;border-radius:var(--pill);padding:5px 11px;
    font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;
    background:var(--soft);color:var(--brand-deep);border:1px solid #bfe9f1;
}
.badge-gray{background:#f1f5f8;color:#5a6b7a;border-color:#dde6ed}
.badge-red{background:#fdf0ef;color:var(--danger);border-color:#f6cfcb}
.badge-yellow{background:#fff7e3;color:var(--warning);border-color:#ffe3a1}

/* ============================================================ JOB CARDS */
.job-card{display:grid;gap:13px;position:relative}
.job-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line-2)}
.job-card h3{margin:0;font-size:21px;line-height:1.25}
.job-card h3 a{color:var(--ink)}
.job-card h3 a:hover{color:var(--brand-ink)}
.job-meta{display:flex;gap:8px;flex-wrap:wrap;color:var(--muted);font-size:13.5px;font-weight:500}
.job-card .button{margin-top:2px;justify-self:start}

/* ============================================================ FORMS */
.form-panel{
    background:var(--card);border:1px solid var(--line);border-radius:var(--r-xl);
    padding:30px;box-shadow:var(--shadow-lg);
}
.glass-form{background:rgba(255,255,255,.78);backdrop-filter:blur(16px);border-color:rgba(255,255,255,.8)}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.field{display:grid;gap:8px}
.field.full{grid-column:1/-1}
label{font-weight:600;font-size:13.5px;color:var(--ink-soft)}
input,select,textarea{
    width:100%;border:1px solid var(--line-2);border-radius:13px;padding:13px 15px;
    background:#fbfdff;font:inherit;font-size:15px;color:var(--ink);transition:.15s ease;
}
input::placeholder,textarea::placeholder{color:#9aacbb}
textarea{min-height:150px;resize:vertical}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 4px rgba(12,166,186,.14);background:#fff}
.checkbox-field label{display:flex;align-items:flex-start;gap:10px;font-weight:500;color:var(--ink-soft);font-size:14px}
.checkbox-field input{width:auto;margin-top:3px;transform:scale(1.15);accent-color:var(--brand)}
.help{font-size:13px;color:var(--muted-2);margin:10px 0 0}

/* ============================================================ FLASH */
.flash-wrap{padding-top:16px}
.flash{padding:13px 16px;border-radius:14px;border:1px solid var(--line);background:#fff;margin-bottom:10px;font-weight:600;font-size:14.5px;box-shadow:var(--shadow-soft)}
.flash-success{border-color:#aee7c9;background:#ecfdf3;color:var(--success)}
.flash-error{border-color:#f6cfcb;background:#fdf0ef;color:var(--danger)}
.flash-info{border-color:#bce6ee;background:#ecfbff;color:#0a6b7d}

/* ============================================================ TABLES */
.table-wrap{overflow:auto;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-soft)}
.table{width:100%;border-collapse:collapse;font-size:14px}
.table th,.table td{padding:15px 16px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}
.table th{background:#f3f8fb;color:var(--brand-deep);font-family:var(--font-display);font-weight:700;font-size:12.5px;letter-spacing:.02em;text-transform:uppercase}
.table tr:last-child td{border-bottom:none}
.table tbody tr{transition:background .14s ease}
.table tbody tr:hover{background:#f7fbfd}

/* ============================================================ ADMIN */
.admin-layout{display:grid;grid-template-columns:250px 1fr;gap:24px;align-items:start}
.side-menu{position:sticky;top:96px;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:14px;box-shadow:var(--shadow-soft)}
.side-menu a{display:block;padding:11px 13px;border-radius:12px;color:var(--ink-soft);font-weight:600;font-size:14px}
.side-menu a:hover,.side-menu a.active{background:var(--soft);text-decoration:none;color:var(--brand-ink)}

/* ============================================================ FOOTER */
.site-footer{
    background:linear-gradient(180deg,#0a1a2b,#08131f);color:#c3d4e0;padding:64px 0 26px;margin-top:56px;
    position:relative;overflow:hidden;
}
.site-footer:before{content:"";position:absolute;right:-120px;top:-120px;width:340px;height:340px;background:radial-gradient(circle,rgba(18,181,164,.22),transparent 70%);border-radius:50%}
.site-footer:after{content:"";position:absolute;left:0;top:0;width:100%;height:3px;background:var(--grad);opacity:.85}
.footer-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.6fr repeat(3,1fr);gap:28px}
.footer-grid>div>p{color:#92a8ba;font-size:14.5px;max-width:320px}
.site-footer a{display:block;color:#b9cbd9;margin:9px 0;font-size:14.5px}
.site-footer a:hover{color:#fff}
.site-footer h4{margin:0 0 12px;color:#fff;font-size:13px;letter-spacing:.05em;text-transform:uppercase;font-family:var(--font-mono);font-weight:600}
.footer-logo{height:34px;width:auto;display:block;object-fit:contain;object-position:left center;filter:brightness(0) invert(1)}
.footer-brand{margin-bottom:14px}
.footer-bottom{position:relative;z-index:1;border-top:1px solid rgba(255,255,255,.10);margin-top:36px;padding-top:20px;color:#7f95a7;font-size:13.5px;font-family:var(--font-mono);letter-spacing:.01em}

/* ============================================================ MISC */
.empty{padding:40px;text-align:center;color:var(--muted)}
.notice{background:#fff7e3;border:1px solid #ffe3a1;border-radius:16px;padding:16px 18px;color:#6b4d00;font-weight:500}
.job-detail{display:grid;grid-template-columns:1fr 350px;gap:26px;align-items:start}
.apply-box{position:sticky;top:96px}
.muted{color:var(--muted)}
.center{text-align:center}
.price{font-family:var(--font-mono);font-size:56px;font-weight:700;letter-spacing:-.04em;color:var(--brand-deep);font-variant-numeric:tabular-nums;line-height:1}
.small{font-size:13px;color:var(--muted)}
.feature-list{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}

.split-cta{padding-top:32px}
.cta-card{position:relative;overflow:hidden;display:block;padding:30px}
.cta-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.cta-card:before{content:"";position:absolute;right:-60px;top:-70px;width:190px;height:190px;background:radial-gradient(circle,rgba(18,181,164,.16),transparent 70%);border-radius:999px}
.cta-card h2{margin:14px 0 8px;font-size:26px}
.cta-card p{color:var(--muted);margin:0 0 20px}
.cta-card>*{position:relative;z-index:2}
.seeker-card{background:linear-gradient(180deg,#fff,#f4fcff)}
.employer-card{background:linear-gradient(180deg,#fff,#f3f6ff)}
.mini-worker{display:none}
.subscribe-hero{background:radial-gradient(60% 80% at 90% 0%,rgba(18,181,164,.14),transparent 45%),radial-gradient(50% 70% at 0% 20%,rgba(79,70,229,.08),transparent 50%)}

/* ============================================================ HOW IT WORKS (new, sequenced) */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;counter-reset:step}
.step{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-soft);transition:transform .2s ease,box-shadow .2s ease}
.step:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.step .num{font-family:var(--font-mono);font-size:13px;font-weight:700;color:var(--brand-ink);letter-spacing:.06em}
.step h3{margin:12px 0 8px;font-size:19px}
.step p{margin:0;color:var(--muted);font-size:14.5px}
.step:not(:last-child):after{content:"→";position:absolute;right:-16px;top:50%;transform:translateY(-50%);color:var(--line-2);font-size:22px;z-index:2}

/* ============================================================ SCROLL REVEAL */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ============================================================ RESPONSIVE */
@media(max-width:1020px){
    .main-nav{gap:2px}
    .hero-grid{grid-template-columns:1fr}
    .hero-visual{min-height:400px}
    .hero-worker{max-height:380px;max-width:72%}
    .floating-card{right:6%}
    .footer-grid{grid-template-columns:1fr 1fr}
    .grid-3,.steps{grid-template-columns:1fr 1fr}
    .step:not(:last-child):after{display:none}
}
@media(max-width:780px){
    .hero-grid,.grid-3,.grid-2,.form-grid,.footer-grid,.admin-layout,.job-detail,.steps{grid-template-columns:1fr}
    .main-nav{
        display:none;position:absolute;left:4%;right:4%;top:74px;flex-direction:column;
        background:#fff;border:1px solid var(--line);border-radius:20px;padding:16px;
        box-shadow:var(--shadow-lg);align-items:stretch;gap:4px;
    }
    .main-nav.open{display:flex}
    .main-nav a{padding:12px 14px}
    .main-nav a.nav-cta{text-align:center;justify-content:center;margin:6px 0 0}
    .nav-toggle{display:block}
    .hero{padding:48px 0 30px}
    .hero h1{font-size:clamp(34px,9vw,46px)}
    .hero-visual{min-height:330px}
    .hero-worker{max-height:320px;max-width:72%}
    .floating-card{right:0;bottom:24px}
    .section{padding:46px 0}
    .section-title{display:block}
    .side-menu,.apply-box{position:static}
    .cta-card,.card,.form-panel,.step{padding:22px}
}
@media(max-width:460px){
    .container{width:94%}
    .brand-logo{height:30px;max-width:200px}
    .hero h1{font-size:33px}
    .hero p{font-size:16px}
    .actions .btn,.actions .button{width:100%}
    .trust-row span,.feature-list span{width:100%;justify-content:center}
    .hero-visual{min-height:250px}
    .hero-worker{max-height:240px}
    .floating-card{left:0;right:auto;bottom:8px}
    .stat-card strong{font-size:42px}
    .price{font-size:46px}
    .nav-wrap{min-height:62px}
    .main-nav{top:62px}
}

/* ============================================================ MOTION SAFETY */
@media(prefers-reduced-motion:reduce){
    *{animation:none !important;scroll-behavior:auto !important;transition:none !important}
    .reveal{opacity:1;transform:none}
}

/* ============================================================
   v7 alignment polish — mobile/tablet/desktop
   Keeps the redesigned look, but prevents clipping/overflow and
   makes buttons, grids, forms, nav, and footer line up cleanly.
   ============================================================ */
html,body{max-width:100%;overflow-x:hidden}
img,svg,video{display:block;max-width:100%;height:auto}
.container{width:min(1180px,calc(100% - 40px))}
.brand,.hero-copy,.hero-visual,.card,.form-panel,.job-card,.step,.footer-grid>*{min-width:0}

/* header/logo alignment */
.site-header{isolation:isolate}
.nav-wrap{min-height:70px;gap:18px}
.brand{max-width:280px;overflow:visible}
.brand-logo{height:38px;max-width:min(260px,52vw);object-fit:contain;object-position:left center;overflow:visible}
.main-nav{min-width:0;z-index:80}
.nav-toggle{line-height:1;min-width:42px;height:42px;display:none;align-items:center;justify-content:center}

/* hero alignment */
.hero-grid{grid-template-columns:minmax(0,1.05fr) minmax(260px,.95fr);gap:clamp(26px,4vw,48px)}
.hero-copy{align-self:center}
.hero p{width:100%}
.hero-visual{min-width:0;min-height:430px;justify-content:center;align-items:flex-end}
.hero-worker{width:auto;max-width:min(60%,360px);max-height:430px}
.floating-card{max-width:210px}
.actions .btn,.actions .button{min-height:48px}

/* section/card alignment */
.section-title>*{min-width:0}
.section-title>a,.section-title>.btn,.section-title>.button{flex:0 0 auto}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.card{height:100%}
.job-card{align-content:start}
.job-card .button{width:max-content;max-width:100%}
.stat-card strong{word-break:normal;overflow-wrap:normal}
.steps{grid-template-columns:repeat(3,minmax(0,1fr))}

/* forms */
.form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
input,select,textarea,button{max-width:100%}
.checkbox-field label{line-height:1.45}
.checkbox-field label a{display:inline}

/* tables and admin */
.table-wrap{max-width:100%}
.table{min-width:720px}
.admin-layout{grid-template-columns:minmax(210px,250px) minmax(0,1fr)}

/* footer */
.footer-grid{grid-template-columns:minmax(0,1.45fr) repeat(3,minmax(0,1fr));align-items:start}
.footer-logo{height:36px;max-width:230px;object-fit:contain;object-position:left center;overflow:visible}
.footer-bottom{line-height:1.5}

/* Make content visible even if JS or intersection observers do not run. */
.reveal{opacity:1;transform:none;transition:none}
.reveal.in{opacity:1;transform:none}

@media(max-width:1020px){
    .container{width:min(940px,calc(100% - 36px))}
    .hero-grid{grid-template-columns:1fr;text-align:left}
    .hero-visual{min-height:340px;margin-top:8px}
    .hero-worker{max-height:340px;max-width:min(52%,300px)}
    .floating-card{right:12%;bottom:34px}
    .grid-3,.steps{grid-template-columns:repeat(2,minmax(0,1fr))}
    .footer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media(max-width:780px){
    .container{width:calc(100% - 32px)}
    .nav-wrap{min-height:66px}
    .brand-logo{height:34px;max-width:min(222px,64vw)}
    .nav-toggle{display:inline-flex}
    .main-nav{
        display:none;position:absolute;left:16px;right:16px;top:66px;flex-direction:column;
        background:rgba(255,255,255,.98);border:1px solid var(--line);border-radius:20px;padding:12px;
        box-shadow:var(--shadow-lg);align-items:stretch;gap:4px;backdrop-filter:blur(12px);
    }
    .main-nav.open{display:flex}
    .main-nav a{display:flex;align-items:center;justify-content:center;min-height:44px;padding:11px 14px;text-align:center;width:100%}
    .main-nav a.nav-cta{margin:6px 0 0}
    .hero{padding:42px 0 28px}
    .hero h1{font-size:clamp(33px,9.2vw,46px);line-height:1.06;margin:18px 0 14px}
    .hero p{font-size:16px;line-height:1.62;max-width:none}
    .eyebrow{max-width:100%;white-space:normal;line-height:1.35}
    .actions{gap:10px;margin-top:22px}
    .actions .btn,.actions .button{width:100%;justify-content:center}
    .trust-row{gap:8px;margin-top:18px}
    .hero-visual{min-height:280px;margin-top:12px}
    .hero-worker{max-height:270px;max-width:min(46%,190px)}
    .hero-bubble.one{width:240px;height:240px;right:7%;bottom:18px}
    .hero-bubble.two{width:96px;height:96px;left:6%;top:20px}
    .floating-card{right:auto;left:0;bottom:10px;padding:12px 14px;max-width:176px}
    .floating-card strong{font-size:24px}
    .floating-card span{font-size:11.5px}
    .section{padding:44px 0}
    .compact-top{padding-top:32px}
    .section-title{display:block;margin-bottom:22px}
    .section-title h2{font-size:clamp(26px,7vw,34px)}
    .section-title .btn,.section-title .button,.section-title>a{margin-top:16px;width:100%;justify-content:center}
    .hero-grid,.grid-3,.grid-2,.form-grid,.footer-grid,.admin-layout,.job-detail,.steps{grid-template-columns:1fr}
    .step:not(:last-child):after{display:none}
    .card,.form-panel,.step,.cta-card{padding:22px;border-radius:18px}
    .form-panel{border-radius:22px}
    .field.full .btn,.field.full .button,form .btn,form .button{width:100%;justify-content:center}
    .side-menu,.apply-box{position:static}
    .table{min-width:680px}
    .footer-grid{gap:22px}
    .site-footer{padding:48px 0 24px;margin-top:38px}
}

@media(max-width:460px){
    .container{width:calc(100% - 24px)}
    .nav-wrap{min-height:62px;gap:10px}
    .brand-logo{height:30px;max-width:min(190px,62vw)}
    .nav-toggle{min-width:38px;height:38px;border-radius:12px;padding:7px 10px}
    .main-nav{left:12px;right:12px;top:62px;border-radius:18px}
    .hero{padding:34px 0 24px}
    .hero h1{font-size:31px;letter-spacing:-.035em}
    .hero p{font-size:15.5px}
    .btn,.button{padding:12px 18px;font-size:14px}
    .trust-row span,.feature-list span{width:100%;justify-content:center;text-align:center}
    .hero-visual{min-height:245px}
    .hero-worker{max-height:230px;max-width:min(48%,150px)}
    .hero-bubble.one{width:210px;height:210px;right:-4%;bottom:16px}
    .hero-bubble.two{width:86px;height:86px;left:4%;top:22px}
    .floating-card{bottom:6px;max-width:156px}
    .stat-card strong{font-size:40px}
    .price{font-size:42px}
    .job-meta{gap:6px}
    .footer-logo{height:28px;max-width:190px}
    .site-footer a{font-size:14px}
}

@media(max-width:340px){
    .container{width:calc(100% - 20px)}
    .brand-logo{height:28px;max-width:170px}
    .hero h1{font-size:28px}
    .hero-visual{min-height:225px}
    .hero-worker{max-height:210px;max-width:140px}
    .hero-bubble.one{width:190px;height:190px}
    .floating-card{position:relative;left:auto;bottom:auto;margin:8px auto 0;max-width:180px;text-align:left}
}
/* Keep decorative hero bubbles inside the viewport on very small screens. */
@media(max-width:460px){.hero-bubble.one{right:0;width:196px;height:196px}}
@media(max-width:340px){.hero-bubble.one{right:0;width:176px;height:176px}}

/* Admin pagination and log tools */
.admin-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:18px;flex-wrap:wrap}
.admin-title-row h2{margin-bottom:4px}
.pagination{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:18px 0 0}
.pagination a,.pagination strong,.pagination span{border:1px solid var(--line);background:#fff;border-radius:12px;padding:9px 12px;font-size:14px;font-weight:800;text-decoration:none;color:var(--ink);box-shadow:0 4px 12px rgba(15,23,42,.04)}
.pagination strong{background:var(--brand);border-color:var(--brand);color:#fff}
.pagination .page-count{background:transparent;border:0;box-shadow:none;color:var(--muted);font-weight:700;margin-left:auto}
.log-detail{max-width:360px;white-space:normal;word-break:break-word;font-size:13px;color:#9f1239;line-height:1.45}

@media(max-width:780px){
    .admin-title-row{display:block}
    .admin-title-row .actions{margin-top:12px}
    .admin-title-row .actions .btn{width:100%}
    .pagination{justify-content:center}
    .pagination .page-count{width:100%;text-align:center;margin-left:0}
}
