/* =============================================
   JobListing24 — Main Stylesheet
   Clean, Fast, Minimal, Accessible
   ============================================= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;color:#1a1a2e;background:#f8f9fa;line-height:1.6;min-height:100vh;display:flex;flex-direction:column}
img{max-width:100%;height:auto;display:block}
a{color:var(--primary);text-decoration:none;transition:color .2s}
a:hover{color:var(--secondary)}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,select,textarea{font-family:inherit;font-size:inherit}
:focus-visible{outline:2px solid var(--secondary);outline-offset:2px;border-radius:3px}
:root{
  --primary:#003049;--primary-dark:#002438;--primary-light:#e8eff3;
  --secondary:#F77F00;--secondary-dark:#d66e00;--accent:#FCBF49;
  --text:#1a1a2e;--text-muted:#6c757d;--text-light:#999;
  --border:#e2e8f0;--bg:#f8f9fa;--bg-card:#ffffff;
  --shadow:0 2px 8px rgba(0,0,0,.08);--shadow-md:0 4px 16px rgba(0,0,0,.12);
  --radius:8px;--radius-lg:12px;--container:1200px;--sidebar-w:300px;
}
.container{max-width:var(--container);margin:0 auto;padding:0 16px}
.skip-link{position:absolute;top:-40px;left:0;background:var(--primary);color:#fff;padding:8px 16px;z-index:9999;border-radius:0 0 4px 0;transition:top .2s}
.skip-link:focus{top:0}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.section-title{font-size:1.4rem;font-weight:700;color:var(--primary);margin-bottom:1.25rem;padding-bottom:.5rem;border-bottom:2px solid var(--border)}
.section-title span{color:var(--secondary)}

/* HEADER */
.site-header{background:var(--primary);color:#fff;position:sticky;top:0;z-index:1000;box-shadow:0 2px 8px rgba(0,0,0,.2)}
.header-inner{display:flex;align-items:center;gap:1rem;padding:0 16px;height:60px;max-width:var(--container);margin:0 auto}
.site-logo{flex-shrink:0;display:flex;align-items:center}
.logo-text{font-size:1.3rem;font-weight:700;color:#fff;letter-spacing:-.5px}
.main-nav{flex:1;display:flex;justify-content:flex-end}
.main-nav ul{display:flex;align-items:center;gap:.25rem}
.main-nav a{color:rgba(255,255,255,.88);font-size:.875rem;font-weight:500;padding:.5rem .75rem;border-radius:var(--radius);transition:background .2s,color .2s}
.main-nav a:hover,.main-nav a[aria-current="page"]{color:#fff;background:rgba(255,255,255,.15)}
.has-dropdown{position:relative}
.has-dropdown>.dropdown{display:none;position:absolute;top:100%;right:0;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-md);min-width:180px;z-index:100;padding:.5rem 0}
.has-dropdown:hover>.dropdown,.has-dropdown:focus-within>.dropdown{display:block}
.has-dropdown .dropdown a{color:var(--text);font-size:.875rem;padding:.5rem 1rem;display:block}
.has-dropdown .dropdown a:hover{background:var(--primary-light);color:var(--primary)}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:.5rem;color:#fff}
.nav-toggle span{display:block;width:22px;height:2px;background:currentColor;border-radius:1px;transition:transform .3s}
.header-actions{display:flex;align-items:center;gap:.5rem}
.search-toggle-btn{color:#fff;padding:.5rem;display:flex;align-items:center;border-radius:var(--radius);transition:background .2s}
.search-toggle-btn:hover{background:rgba(255,255,255,.15)}
.header-search{background:var(--primary-dark);padding:.75rem 0;animation:slideDown .2s ease}
.header-search form{display:flex;gap:.5rem;max-width:var(--container);margin:0 auto;padding:0 16px}
.header-search input{flex:1;padding:.625rem 1rem;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.1);color:#fff;border-radius:var(--radius);font-size:.9rem}
.header-search input::placeholder{color:rgba(255,255,255,.5)}
.header-search input:focus{outline:none;border-color:var(--accent)}
.header-search button{background:var(--secondary);color:#fff;padding:.625rem 1rem;border-radius:var(--radius);display:flex;align-items:center}
@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}

/* HERO */
.hero{background:linear-gradient(135deg,var(--primary) 0%,#00455e 100%);color:#fff;padding:3rem 0 4rem;position:relative;overflow:hidden}
.hero-inner{position:relative;max-width:720px}
.hero h1{font-size:clamp(1.75rem,4vw,2.75rem);font-weight:700;line-height:1.2;margin-bottom:1rem}
.hero h1 span{color:var(--accent)}
.hero p{font-size:1.05rem;color:rgba(255,255,255,.85);margin-bottom:2rem}
.hero-search{background:rgba(255,255,255,.1);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-lg);padding:1.25rem;display:flex;flex-direction:column;gap:.75rem}
.hero-search-row{display:flex;gap:.5rem}
.hero-search input,.hero-search select{flex:1;padding:.75rem 1rem;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.12);color:#fff;border-radius:var(--radius);font-size:.9rem;min-width:0}
.hero-search input::placeholder{color:rgba(255,255,255,.55)}
.hero-search input:focus,.hero-search select:focus{outline:none;border-color:var(--accent)}
.hero-search select option{background:var(--primary);color:#fff}
.hero-search-btn{background:var(--secondary);color:#fff;padding:.75rem 1.5rem;border-radius:var(--radius);font-weight:600;font-size:.95rem;display:flex;align-items:center;gap:.5rem;white-space:nowrap;transition:background .2s}
.hero-search-btn:hover{background:var(--secondary-dark)}
.hero-stats{display:flex;gap:2rem;margin-top:1.5rem;flex-wrap:wrap}
.hero-stat strong{display:block;font-size:1.75rem;font-weight:700;color:var(--accent)}
.hero-stat span{font-size:.78rem;color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:.5px}

/* MAIN LAYOUT */
main{flex:1}
.main-layout{display:grid;grid-template-columns:1fr var(--sidebar-w);gap:2rem;padding:2.5rem 0;align-items:start}
.main-content-area{min-width:0}

/* FILTER BAR */
.filter-bar{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:.875rem 1rem;margin-bottom:1.5rem;display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}
.filter-bar label{font-size:.78rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}
.filter-select{padding:.4rem .75rem;border:1px solid var(--border);border-radius:6px;font-size:.85rem;color:var(--text);background:#fff}
.filter-results{font-size:.875rem;color:var(--text-muted);margin-left:auto}
.view-toggle{display:flex;gap:.25rem;margin-left:.5rem}
.view-btn{padding:.3rem .5rem;border:1px solid var(--border);border-radius:4px;color:var(--text-muted);font-size:.8rem}
.view-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}

/* JOB GRID */
.jobs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}
.jobs-grid.list-view{grid-template-columns:1fr}
.jobs-grid.list-view .job-card{flex-direction:row}
.jobs-grid.list-view .card-thumb{flex-shrink:0;width:180px;aspect-ratio:auto;height:auto}
.jobs-grid.list-view .card-thumb img{height:100%;min-height:140px;object-fit:cover}

/* JOB CARD */
.job-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .25s,transform .25s;position:relative}
.job-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.job-card.urgent{border-left:3px solid #dc3545}
.job-card.soon{border-left:3px solid #fd7e14}
.card-thumb{position:relative;aspect-ratio:16/9;overflow:hidden;background:var(--primary-light)}
.card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .35s}
.job-card:hover .card-thumb img{transform:scale(1.04)}
.card-logo{position:absolute;bottom:8px;left:8px;background:#fff;border-radius:6px;padding:4px;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.card-logo img{width:40px;height:40px;object-fit:contain;border-radius:4px}
.card-sector-badge{position:absolute;top:8px;left:8px;background:rgba(0,0,0,.6);color:#fff;font-size:.7rem;font-weight:600;padding:3px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.4px}
.badge-urgent{position:absolute;top:8px;right:8px;background:#fd7e14;color:#fff;font-size:.7rem;font-weight:700;padding:3px 8px;border-radius:20px;animation:pulse 2s infinite}
.badge-closed{position:absolute;top:8px;right:8px;background:#dc3545;color:#fff;font-size:.7rem;font-weight:700;padding:3px 8px;border-radius:20px}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.7}}
.card-body{padding:1rem;flex:1;display:flex;flex-direction:column;gap:.4rem}
.card-company{font-size:.75rem;font-weight:600;color:var(--secondary);text-transform:uppercase;letter-spacing:.5px}
.card-title{font-size:.95rem;font-weight:700;line-height:1.35;color:var(--primary)}
.card-title a{color:inherit;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-title a:hover{color:var(--secondary)}
.card-excerpt{font-size:.825rem;color:var(--text-muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}
.card-meta{display:flex;flex-wrap:wrap;gap:.35rem .75rem;font-size:.78rem;color:var(--text-muted)}
.card-meta span{display:flex;align-items:center;gap:.25rem}
.card-tags{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.2rem}
.tag-pill{font-size:.72rem;padding:.2rem .6rem;background:var(--primary-light);color:var(--primary);border-radius:20px;font-weight:500;transition:background .2s,color .2s;white-space:nowrap}
.tag-pill:hover{background:var(--primary);color:#fff}
.card-btn{margin-top:auto;padding:.6rem 1rem;background:var(--primary);color:#fff;border-radius:var(--radius);font-size:.82rem;font-weight:600;text-align:center;transition:background .2s;display:flex;align-items:center;justify-content:center;gap:.4rem}
.card-btn:hover{background:var(--secondary);color:#fff}

/* PAGINATION */
.pagination{margin-top:2.5rem;text-align:center}
.page-list{display:flex;justify-content:center;align-items:center;gap:.4rem;flex-wrap:wrap}
.page-btn{display:inline-flex;align-items:center;padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.85rem;color:var(--text);background:#fff;transition:all .2s;min-width:38px;justify-content:center}
.page-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}
.page-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.page-dots{color:var(--text-muted);padding:.5rem .25rem}

/* SINGLE POST */
.single-hero{background:linear-gradient(135deg,var(--primary),#00455e);color:#fff;padding:2.5rem 0}
.breadcrumb{font-size:.82rem;color:rgba(255,255,255,.7);margin-bottom:.75rem;display:flex;align-items:center;gap:.35rem;flex-wrap:wrap}
.breadcrumb a{color:rgba(255,255,255,.8)}
.breadcrumb a:hover{color:#fff}
.breadcrumb span{color:rgba(255,255,255,.4)}
.single-company-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;flex-wrap:wrap}
.single-company-logo{width:52px;height:52px;background:#fff;border-radius:var(--radius);padding:5px;object-fit:contain}
.single-sector-badge{font-size:.8rem;background:rgba(255,255,255,.15);padding:.25rem .75rem;border-radius:20px;font-weight:500}
.single-title{font-size:clamp(1.4rem,3.5vw,2.2rem);font-weight:700;line-height:1.25;margin-bottom:1rem}
.single-meta-bar{display:flex;flex-wrap:wrap;gap:.75rem;font-size:.85rem;color:rgba(255,255,255,.8)}
.single-meta-bar span{display:flex;align-items:center;gap:.3rem}
.single-layout{display:grid;grid-template-columns:1fr var(--sidebar-w);gap:2rem;padding:2.5rem 0;align-items:start}
.single-content{background:#fff;border-radius:var(--radius-lg);padding:2rem;border:1px solid var(--border)}
.single-thumb{width:100%;aspect-ratio:21/8;object-fit:cover;border-radius:var(--radius-lg);margin-bottom:2rem}

/* Overview table */
.overview-table{width:100%;border-collapse:collapse;margin:1.25rem 0;font-size:.875rem;border-radius:var(--radius);overflow:hidden}
.overview-table th,.overview-table td{padding:.6rem 1rem;text-align:left;border:1px solid var(--border)}
.overview-table th{background:var(--primary-light);color:var(--primary);font-weight:600;width:38%}
.overview-table tr:nth-child(even) td{background:#fafbfc}

/* Countdown */
.countdown-box{background:linear-gradient(135deg,var(--primary),#00455e);color:#fff;border-radius:var(--radius-lg);padding:1.25rem;text-align:center;margin:1.5rem 0}
.countdown-box>p{font-size:.85rem;opacity:.8;margin-bottom:.75rem}
.countdown-nums{display:flex;justify-content:center;gap:1.5rem}
.countdown-unit strong{display:block;font-size:2.25rem;font-weight:700;line-height:1;color:var(--accent);font-variant-numeric:tabular-nums}
.countdown-unit span{font-size:.68rem;opacity:.7;text-transform:uppercase;letter-spacing:.5px}
.countdown-expired{background:#dc3545;border-radius:var(--radius);padding:.75rem;text-align:center;font-weight:600;color:#fff}

/* Post sections */
.post-section{margin:2rem 0}
.post-section>h2{font-size:1.1rem;font-weight:700;color:var(--primary);border-left:4px solid var(--secondary);padding-left:.75rem;margin-bottom:.875rem}
.post-section>h3{font-size:.95rem;font-weight:600;color:var(--text);margin:.75rem 0 .35rem}
.post-section p{color:var(--text-muted);line-height:1.75;margin-bottom:.5rem;font-size:.9rem}
.post-section ul,.post-section ol{padding-left:1.5rem;color:var(--text-muted);font-size:.9rem;line-height:1.7}
.post-section li{margin-bottom:.3rem}
.post-section ul li::marker{color:var(--secondary)}
.post-divider{border:none;border-top:1px solid var(--border);margin:2rem 0}

/* Apply CTA */
.apply-cta{background:linear-gradient(135deg,var(--secondary),#d56a00);border-radius:var(--radius-lg);padding:1.75rem;text-align:center;margin:2rem 0}
.apply-cta h2{color:#fff;font-size:1.15rem;margin-bottom:.4rem}
.apply-cta p{color:rgba(255,255,255,.85);font-size:.875rem;margin-bottom:1rem}
.apply-btns{display:flex;justify-content:center;flex-wrap:wrap;gap:.75rem}
.apply-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 1.75rem;border-radius:var(--radius);font-weight:700;font-size:.95rem;transition:transform .2s,box-shadow .2s}
.apply-btn.primary{background:#fff;color:var(--secondary)}
.apply-btn.primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.2);color:var(--secondary-dark)}
.apply-btn.secondary{background:transparent;border:2px solid rgba(255,255,255,.6);color:#fff}
.apply-btn.secondary:hover{background:rgba(255,255,255,.15);color:#fff}

/* FAQs */
.faq-item{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.5rem;overflow:hidden}
.faq-q{width:100%;text-align:left;padding:.875rem 1rem;font-weight:600;font-size:.875rem;color:var(--text);background:#fafbfc;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:background .2s}
.faq-q:hover{background:var(--primary-light)}
.faq-q[aria-expanded="true"]{background:var(--primary-light);color:var(--primary)}
.faq-q svg{flex-shrink:0;transition:transform .25s}
.faq-q[aria-expanded="true"] svg{transform:rotate(180deg)}
.faq-a{padding:.875rem 1rem;font-size:.875rem;color:var(--text-muted);line-height:1.7;display:none}
.faq-a.open{display:block}

/* Author box */
.author-box{background:var(--primary-light);border-radius:var(--radius-lg);padding:1.5rem;display:flex;gap:1rem;align-items:flex-start;margin:2rem 0}
.author-avatar{width:64px;height:64px;border-radius:50%;object-fit:cover;flex-shrink:0}
.author-placeholder{width:64px;height:64px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;flex-shrink:0}
.author-info h3{font-size:.95rem;font-weight:700;color:var(--primary)}
.author-info p{font-size:.85rem;color:var(--text-muted);margin-top:.25rem;line-height:1.6}

/* Related */
.related-posts{margin:2.5rem 0}
.related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}
.related-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:box-shadow .2s}
.related-card:hover{box-shadow:var(--shadow)}
.related-thumb{aspect-ratio:16/9;overflow:hidden;background:var(--primary-light)}
.related-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.related-card:hover .related-thumb img{transform:scale(1.04)}
.related-body{padding:.75rem}
.related-body h3{font-size:.82rem;font-weight:600;color:var(--text);line-height:1.35;margin-bottom:.2rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.related-body h3 a{color:inherit}
.related-body h3 a:hover{color:var(--secondary)}
.related-body span{font-size:.75rem;color:var(--text-muted)}

/* Share bar */
.share-bar{display:flex;align-items:center;gap:.625rem;padding:1rem;background:#f8f9fa;border-radius:var(--radius);margin:1.5rem 0;flex-wrap:wrap}
.share-bar>span{font-size:.82rem;font-weight:600;color:var(--text-muted)}
.share-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.4rem .875rem;border-radius:var(--radius);font-size:.78rem;font-weight:600;color:#fff;transition:opacity .2s}
.share-btn:hover{opacity:.85;color:#fff}
.share-btn.fb{background:#1877f2}.share-btn.tw{background:#000}
.share-btn.wa{background:#25d366}.share-btn.cp{background:var(--text-muted)}

/* COMMENTS */
.comments-section{margin:2rem 0}
.comment-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}
.comment-item{background:#fafbfc;border-radius:var(--radius);padding:1rem;border-left:3px solid var(--border)}
.comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem;flex-wrap:wrap;gap:.25rem}
.comment-author{font-weight:600;font-size:.875rem}
.comment-date{font-size:.78rem;color:var(--text-muted)}
.comment-text{font-size:.875rem;color:var(--text-muted);line-height:1.65}
.comment-form{background:#f8f9fa;border-radius:var(--radius-lg);padding:1.5rem}
.comment-form h3{margin-bottom:1rem;font-size:1rem;font-weight:700;color:var(--primary)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:.75rem}
.form-group{display:flex;flex-direction:column;gap:.3rem;margin-bottom:.75rem}
.form-group label{font-size:.8rem;font-weight:600;color:var(--text-muted)}
.form-group input,.form-group textarea,.form-group select{padding:.625rem .875rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem;background:#fff;transition:border-color .2s}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary)}
.form-group textarea{resize:vertical;min-height:100px}
.btn-primary{background:var(--primary);color:#fff;padding:.65rem 1.5rem;border-radius:var(--radius);font-weight:600;font-size:.9rem;transition:background .2s}
.btn-primary:hover{background:var(--primary-dark)}
.form-notice{font-size:.8rem;color:var(--text-muted);margin-top:.5rem}

/* SIDEBAR */
.sidebar{display:flex;flex-direction:column;gap:1.25rem}
.widget{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem}
.widget-title{font-size:.875rem;font-weight:700;color:var(--primary);margin-bottom:.875rem;padding-bottom:.5rem;border-bottom:2px solid var(--border);text-transform:uppercase;letter-spacing:.5px}
.widget-search-input{display:flex;gap:.4rem}
.widget-search-input input{flex:1;padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.85rem}
.widget-search-input input:focus{outline:none;border-color:var(--primary)}
.widget-search-input button{background:var(--primary);color:#fff;padding:.5rem .75rem;border-radius:var(--radius)}
.province-list,.recent-list,.cat-list{display:flex;flex-direction:column;gap:.15rem}
.province-list a{font-size:.85rem;padding:.3rem .5rem;border-radius:4px;color:var(--text-muted);display:block;transition:background .2s,color .2s}
.province-list a:hover,.province-list a.active{background:var(--primary-light);color:var(--primary)}
.recent-item{display:flex;gap:.75rem;align-items:flex-start;padding:.4rem 0}
.recent-item img{width:60px;height:42px;object-fit:cover;border-radius:6px;flex-shrink:0}
.recent-title{display:block;font-size:.8rem;font-weight:500;color:var(--text);line-height:1.35}
.recent-company{font-size:.73rem;color:var(--text-muted)}
.tag-cloud{display:flex;flex-wrap:wrap;gap:.35rem}
.cat-list a{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;padding:.3rem .5rem;border-radius:4px;color:var(--text-muted);transition:background .2s,color .2s}
.cat-list a:hover{background:var(--primary-light);color:var(--primary)}
.cat-list a span{background:var(--primary-light);color:var(--primary);border-radius:20px;padding:0 6px;font-size:.73rem;font-weight:600}

/* SEARCH PAGE */
.search-header{background:var(--primary-light);padding:1.5rem 0;border-bottom:1px solid var(--border)}
.search-header h1{font-size:1.3rem;color:var(--primary);margin-bottom:.25rem;font-weight:700}
.search-header p{font-size:.875rem;color:var(--text-muted)}
.advanced-search{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;margin:1.5rem 0}
.search-grid{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:.75rem;align-items:end}
.search-grid input,.search-grid select{width:100%;padding:.625rem .875rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem}
.search-grid input:focus,.search-grid select:focus{outline:none;border-color:var(--primary)}
.search-submit{padding:.65rem 1.5rem;background:var(--primary);color:#fff;border-radius:var(--radius);font-weight:600;font-size:.875rem;white-space:nowrap;cursor:pointer;transition:background .2s;border:none}
.search-submit:hover{background:var(--primary-dark)}
.no-results{text-align:center;padding:3rem 1rem}
.no-results h2{font-size:1.2rem;color:var(--text);margin-bottom:.5rem}
.no-results p{color:var(--text-muted);font-size:.9rem}

/* FOOTER */
.site-footer{background:var(--primary);color:rgba(255,255,255,.8);margin-top:auto}
.footer-top{padding:2.5rem 0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2rem}
.footer-logo{font-size:1.2rem;font-weight:700;color:#fff;margin-bottom:.75rem;display:block}
.footer-about p{font-size:.85rem;line-height:1.65;margin-bottom:1rem;color:rgba(255,255,255,.7)}
.footer-socials{display:flex;gap:.5rem;flex-wrap:wrap}
.footer-socials a{width:34px;height:34px;background:rgba(255,255,255,.1);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;transition:background .2s}
.footer-socials a:hover{background:var(--secondary);color:#fff}
.footer-col h3{font-size:.8rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.875rem}
.footer-col ul li{margin-bottom:.4rem}
.footer-col ul a{font-size:.85rem;color:rgba(255,255,255,.7);transition:color .2s}
.footer-col ul a:hover{color:#fff}
.footer-contact{margin-top:.75rem;font-size:.82rem}
.footer-contact a{color:rgba(255,255,255,.7)}
.footer-contact a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:1rem 0}
.footer-bottom .container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem;font-size:.78rem;color:rgba(255,255,255,.45)}

/* ALERTS */
.alert{padding:.875rem 1rem;border-radius:var(--radius);margin-bottom:1rem;font-size:.875rem;border:1px solid transparent}
.alert-success{background:#d4edda;color:#155724;border-color:#c3e6cb}
.alert-error{background:#f8d7da;color:#721c24;border-color:#f5c6cb}
.alert-info{background:#d1ecf1;color:#0c5460;border-color:#bee5eb}
.alert-warning{background:#fff3cd;color:#856404;border-color:#ffeeba}

/* PAGES */
.page-header{background:var(--primary-light);padding:2rem 0;border-bottom:1px solid var(--border)}
.page-header h1{font-size:1.75rem;font-weight:700;color:var(--primary)}
.page-body{padding:2.5rem 0;max-width:780px}
.page-body h2{font-size:1.15rem;font-weight:700;color:var(--primary);margin:1.5rem 0 .75rem;border-left:3px solid var(--secondary);padding-left:.75rem}
.page-body p{color:var(--text-muted);line-height:1.8;margin-bottom:1rem;font-size:.95rem}
.page-body ul{padding-left:1.5rem;color:var(--text-muted);margin-bottom:1rem;font-size:.95rem}
.page-body ul li{margin-bottom:.35rem;line-height:1.7}
.page-body a{color:var(--secondary);text-decoration:underline}

/* BACK TO TOP */
.back-to-top{position:fixed;bottom:1.5rem;right:1.5rem;width:40px;height:40px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);z-index:999;transition:opacity .3s,transform .3s,background .2s}
.back-to-top:hover{background:var(--secondary);transform:translateY(-3px)}

/* ERROR PAGE */
.error-page{text-align:center;padding:4rem 1rem;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center}
.error-page h1{font-size:6rem;font-weight:700;color:var(--primary);line-height:1}
.error-page h2{font-size:1.5rem;color:var(--text);margin:.5rem 0 1rem}
.error-page p{color:var(--text-muted);max-width:450px;margin:0 auto 1.5rem}

/* RESPONSIVE */
@media(max-width:1024px){
  .main-layout,.single-layout{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .search-grid{grid-template-columns:1fr 1fr}
  .search-submit{grid-column:1 / -1}
}
@media(max-width:768px){
  .main-nav{display:none;position:fixed;inset:0;background:var(--primary);z-index:999;flex-direction:column;justify-content:flex-start;padding:80px 1.5rem 2rem;overflow-y:auto}
  .main-nav.open{display:flex}
  .main-nav ul{flex-direction:column;width:100%;gap:.1rem}
  .main-nav>ul>li>a{font-size:1rem;padding:.8rem .75rem;display:block;width:100%;border-radius:var(--radius)}
  .has-dropdown>.dropdown{position:static;box-shadow:none;background:rgba(255,255,255,.1);border-radius:var(--radius);margin:.25rem 0;display:none}
  .has-dropdown.open>.dropdown{display:block}
  .has-dropdown .dropdown a{color:rgba(255,255,255,.8);font-size:.9rem;padding:.6rem 1.25rem}
  .nav-toggle{display:flex;z-index:1001}
  .footer-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .hero-search-row{flex-direction:column}
  .jobs-grid{grid-template-columns:1fr}
  .apply-btns{flex-direction:column;align-items:center}
  .search-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .countdown-nums{gap:.75rem}
  .countdown-unit strong{font-size:1.75rem}
  .hero{padding:2rem 0 2.5rem}
  .single-content{padding:1.25rem}
}
@media print{
  .site-header,.site-footer,.sidebar,.share-bar,.apply-cta,.back-to-top{display:none!important}
  body{color:#000;background:#fff}
  .main-layout,.single-layout{grid-template-columns:1fr}
}
