#main-content { padding: 0 !important; max-width: none !important; margin: 0 !important; }
.em-hero {
position: relative; width: 100%; height: 340px; overflow: hidden;
background: linear-gradient(135deg, var(--brand-color), var(--hero-gradient-end));
display: flex; align-items: flex-end; line-height: 0;
}
.hero-orb { position: absolute; border-radius: 50%; filter: blur(60px); opacity: 0.6; animation: hero-float 10s infinite ease-in-out alternate; z-index: 0; }
.hero-orb-1 { width: 400px; height: 400px; background: var(--hero-orb-1); top: -100px; left: -100px; animation-delay: 0s; }
.hero-orb-2 { width: 500px; height: 500px; background: var(--hero-orb-2); bottom: -150px; right: -100px; animation-delay: -3s; }
.hero-orb-3 { width: 300px; height: 300px; background: var(--hero-orb-3); top: 50%; left: 50%; transform: translate(-50%,-50%); animation-delay: -6s; }
@keyframes hero-float { 0% { transform: translate(0,0) scale(1); } 100% { transform: translate(30px,50px) scale(1.1); } }
.hero-waves { position: absolute; bottom: -1px; left: 0; width: 100%; height: 60px; z-index: 5; }
.hero-parallax > use { animation: hero-wave-move 25s cubic-bezier(.55,.5,.45,.5) infinite; }
.hero-parallax > use:nth-child(1) { animation-delay: -2s; animation-duration: 7s; }
.hero-parallax > use:nth-child(2) { animation-delay: -3s; animation-duration: 10s; }
.hero-parallax > use:nth-child(3) { animation-delay: -4s; animation-duration: 13s; }
.hero-parallax > use:nth-child(4) { animation-delay: -5s; animation-duration: 20s; }
@keyframes hero-wave-move { 0% { transform: translate3d(-90px,0,0); } 100% { transform: translate3d(85px,0,0); } }
.em-hero-content {
position: relative; z-index: 10; width: 100%;
padding: 32px 40px 56px;
display: flex; flex-direction: column; align-items: center; gap: 10px; text-align: center;
}
.em-hero-logo {
width: 90px; height: 90px; object-fit: contain; border-radius: 18px;
background: rgba(255,255,255,0.15); padding: 10px;
backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
border: 1px solid rgba(255,255,255,0.25); margin-bottom: 4px;
}
.em-hero-title { font-size: 22px; font-weight: 600; color: var(--text-on-brand); letter-spacing: -0.02em; line-height: 1.3; margin: 0; }
.em-hero-sub   { font-size: 14px; color: rgba(255,255,255,0.8); margin: 0; line-height: 1.5; }
.em-hero-search {
display: flex; align-items: center; background: var(--bg-main);
border-radius: 10px; padding: 6px 6px 6px 14px;
width: 100%; max-width: 560px; gap: 8px; margin-top: 6px;
}
.em-hero-search-icon { color: var(--text-light); font-size: 15px; flex-shrink: 0; line-height: 1; }
.em-hero-search-input {
flex: 1; border: none; background: none; font-family: var(--font-base);
font-size: 14px; color: var(--text-main); outline: none; min-width: 0;
}
.em-hero-search-input::placeholder { color: var(--text-light); }
.em-hero-search-btn {
height: 38px; padding: 0 20px; background: var(--brand-color); color: var(--text-on-brand);
border: none; border-radius: 7px; font-family: var(--font-base); font-size: 13px;
font-weight: 700; cursor: pointer; white-space: nowrap; flex-shrink: 0; transition: opacity 0.15s;
}
.em-hero-search-btn:hover { opacity: 0.88; }
.em-inner {
padding: 32px 24px; max-width: 1440px; margin: 0 auto; width: 100%;
display: grid; grid-template-columns: 280px 1fr; gap: 16px; align-items: start;
}
.em-left { display: flex; flex-direction: column; gap: 12px; position: sticky; top: calc(72px + 16px); }
.em-card { background: var(--bg-main); border: 1px solid var(--border-color); border-radius: 12px; padding: 16px; }
.em-card-title { font-size: 17px; font-weight: 700; color: var(--text-main); margin: 0 0 12px 0; }
.em-info-row { display: flex; align-items: center; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--border-color); }
.em-info-row:last-child { border-bottom: none; padding-bottom: 0; }
.em-ico { display: inline-flex; align-items: center; justify-content: center; width: 20px; height: 20px; flex-shrink: 0; }
.em-ico i { font-size: 17px; line-height: 1; color: var(--text-muted); }
.em-info-text { font-size: 13px; color: var(--text-muted); line-height: 1.4; }
.em-info-text strong { display: block; font-size: 12px; font-weight: 700; color: var(--text-main); margin-bottom: 1px; }
.em-filter-nav { display: flex; flex-direction: column; }
.em-filter-link {
display: flex; align-items: center; gap: 10px; padding: 8px 10px; border-radius: 8px;
font-size: 14px; font-weight: 500; color: var(--text-main); text-decoration: none;
transition: background 0.12s, color 0.12s;
}
.em-filter-link:hover { background: var(--bg-surface); color: var(--brand-color); }
.em-filter-link:hover .em-ico i { color: var(--brand-color); }
.em-filter-link.active { background: var(--brand-color); color: var(--text-on-brand); }
.em-filter-link.active .em-ico i { color: var(--text-on-brand); }
.em-btn-primary {
display: flex; align-items: center; justify-content: center; gap: 7px;
height: 38px; width: 100%; margin-top: 12px; background: var(--brand-color);
color: var(--text-on-brand); border-radius: 8px; font-family: var(--font-base);
font-size: 13px; font-weight: 700; text-decoration: none; transition: opacity 0.15s;
}
.em-btn-primary:hover { opacity: 0.88; }
.em-btn-ghost {
display: inline-flex; align-items: center; justify-content: center; gap: 7px;
height: 36px; padding: 0 16px; background: var(--bg-surface);
border: 1px solid var(--border-color); border-radius: 8px; font-family: var(--font-base);
font-size: 13px; font-weight: 600; color: var(--text-main); text-decoration: none;
transition: border-color 0.15s, color 0.15s;
}
.em-btn-ghost:hover { border-color: var(--brand-color); color: var(--brand-color); }
.em-main { display: flex; flex-direction: column; gap: 8px; min-width: 0; }
.em-results-meta { font-size: 13px; color: var(--text-muted); font-weight: 500; }
.em-list { display: flex; flex-direction: column; gap: 8px; }
.em-card-item {
background: var(--bg-main); border: 1px solid var(--border-color); border-radius: 12px;
padding: 18px 20px; display: flex; flex-direction: column; gap: 10px;
transition: border-color 0.15s;
}
.em-card-item:hover { border-color: var(--brand-color); }
.em-card-head {
display: flex; align-items: flex-start; justify-content: space-between;
gap: 12px; flex-wrap: wrap;
}
.em-card-head-left { display: flex; align-items: center; gap: 10px; flex-wrap: nowrap; min-width: 0; flex: 1; }
.em-badge {
font-size: 11px; font-weight: 700; padding: 3px 10px; border-radius: 20px;
background: var(--color-brand-light); color: var(--brand-color);
white-space: nowrap; flex-shrink: 0;
}
.em-job-title {
font-size: 15px; font-weight: 700; color: var(--text-main); margin: 0;
line-height: 1.3; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; min-width: 0;
}
.em-job-date { font-size: 12px; color: var(--text-light); font-weight: 600; white-space: nowrap; flex-shrink: 0; }
.em-job-desc { font-size: 13.5px; color: var(--text-muted); line-height: 1.65; margin: 0; }
.em-spacer    { flex: 1; }
.em-separator { height: 1px; background: var(--border-color); flex-shrink: 0; }
.em-card-infos {
display: flex; align-items: center; gap: 20px; flex-wrap: wrap; padding-top: 8px;
}
.em-info-item {
display: flex; align-items: center; gap: 5px;
font-size: 13px; color: var(--text-muted);
}
.em-info-item i { font-size: 14px; flex-shrink: 0; color: var(--text-light); line-height: 1; }
.em-card-footer {
display: flex; align-items: center; justify-content: space-between; gap: 12px;
padding-top: 10px; border-top: 1px solid var(--border-color);
}
.em-card-btn {
display: inline-flex; align-items: center; gap: 6px; height: 34px; padding: 0 16px;
background: var(--brand-color); color: var(--text-on-brand); border-radius: 8px;
font-size: 13px; font-weight: 700; text-decoration: none; transition: opacity 0.15s;
}
.em-card-btn:hover { opacity: 0.88; }
.em-report-btn { font-size: 12px; color: var(--text-light); text-decoration: none; transition: color 0.15s; }
.em-report-btn:hover { color: var(--text-muted); }
.em-empty {
display: flex; flex-direction: column; align-items: center; justify-content: center;
gap: 12px; padding: 48px 24px; background: var(--bg-main);
border: 1px solid var(--border-color); border-radius: 12px; color: var(--text-muted);
}
.em-empty i { font-size: 36px; opacity: 0.35; }
.em-empty p { font-size: 14px; margin: 0; }
.em-pagination { display: flex; flex-wrap: wrap; gap: 6px; justify-content: center; margin-top: 8px; }
.em-page-btn {
display: inline-flex; align-items: center; justify-content: center;
width: 36px; height: 36px; border-radius: 8px; border: 1px solid var(--border-color);
background: var(--bg-main); font-size: 13px; font-weight: 600; color: var(--text-muted);
text-decoration: none; transition: background-color 0.15s, color 0.15s, border-color 0.15s;
}
.em-page-btn:hover { color: var(--brand-color); border-color: var(--brand-color); }
.em-page-btn.active { background: var(--brand-color); color: var(--text-on-brand); border-color: var(--brand-color); }
@media (max-width: 860px) {
.em-inner { grid-template-columns: 1fr; }
.em-left  { position: static; }
}
@media (max-width: 600px) {
.em-hero { height: 400px; }
.hero-orb-1 { width: 200px; height: 200px; }
.hero-orb-2 { width: 250px; height: 250px; }
.hero-orb-3 { width: 150px; height: 150px; }
.hero-waves { height: 30px; }
.em-hero-content { padding: 16px 16px 36px; }
.em-hero-search { max-width: 100%; }
.em-inner { padding: 16px 12px; }
.em-card-head { flex-direction: column; gap: 6px; }
.em-card-infos { flex-direction: column; gap: 6px; align-items: flex-start; }
}