/* ===== Reset & 基础 ===== */
* { box-sizing: border-box; }
html, body { margin:0; padding:0; color:#333; font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Microsoft YaHei",Helvetica,Arial,sans-serif; background:#f7f8fa; }
a { color:inherit; text-decoration:none; }
ul { margin:0; padding:0; list-style:none; }
img { display:block; max-width:100%; }
.container { width:1200px; margin:0 auto; padding:0 16px; }
@media (max-width: 1280px){ .container{ width:100%; } }

/* ===== 顶部导航 ===== */
.header { position:sticky; top:0; z-index:50; background:#fff; border-bottom:1px solid #eee; }
.nav { display:flex; align-items:center; height:64px; }
.logo { font-size:22px; font-weight:800; color:#00a6a7; letter-spacing:1px; }
.logo small{ color:#6b7280; font-weight:600; margin-left:6px; }
.nav-links { margin-left:32px; display:flex; gap:18px; }
.nav-links a { padding:8px 10px; border-radius:6px; color:#4b5563; }
.nav-links a.active, .nav-links a:hover{ color:#00a6a7; background:rgba(0,166,167,.08); }

.city-switcher { margin-left:auto; position:relative; }
.city-btn { display:flex; align-items:center; gap:6px; padding:8px 12px; border:1px solid #e5e7eb; border-radius:8px; cursor:pointer; background:#fff; }
.city-list { display:none; position:absolute; right:0; top:48px; width:320px; background:#fff; border:1px solid #e5e7eb; border-radius:10px; box-shadow:0 10px 30px rgba(0,0,0,.08); padding:12px; }
.city-list .grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:8px; }
.city-item{ padding:8px 10px; border-radius:8px; cursor:pointer; text-align:center; background:#f3f4f6; color:#374151; }
.city-item:hover{ background:#e5f6f6; color:#00a6a7; }
.auth { margin-left:16px; display:flex; gap:10px; }
.btn { padding:8px 16px; border-radius:8px; border:1px solid #00a6a7; color:#00a6a7; background:#fff; cursor:pointer; }
.btn.primary{ background:#00a6a7; color:#fff; border-color:#00a6a7; }
.btn:hover{ opacity:.9; }

/* ===== Banner 搜索 ===== */
.hero { background:#fff; border-bottom:1px solid #eee; }
.hero-wrap{ display:grid; grid-template-columns:1.1fr .9fr; gap:28px; align-items:center; padding:36px 0; }
@media (max-width: 1024px){ .hero-wrap{ grid-template-columns:1fr; } }
.hero-title{ font-size:32px; line-height:1.3; font-weight:800; color:#111827; margin-bottom:14px; }
.hero-sub{ color:#6b7280; margin-bottom:22px; }
.search-box{ display:flex; height:52px; border:1px solid #e5e7eb; border-radius:12px; overflow:hidden; box-shadow:0 10px 24px rgba(0,0,0,.06); }
.search-tabs{ display:flex; background:#f9fafb; border-right:1px solid #e5e7eb; }
.tab{ padding:0 14px; display:flex; align-items:center; font-weight:600; color:#6b7280; cursor:pointer; }
.tab.active{ color:#00a6a7; background:#eefafa; }
.inp{ flex:1; border:0; padding:0 14px; font-size:15px; outline:none; }
.btn-search{ width:128px; border:0; background:#00a6a7; color:#fff; font-weight:700; cursor:pointer; }
.hot-keys{ margin-top:12px; display:flex; flex-wrap:wrap; gap:8px; }
.hot-keys a{ padding:6px 10px; background:#f3f4f6; color:#374151; border-radius:999px; font-size:13px; }
.hot-keys a:hover{ background:#e5f6f6; color:#00a6a7; }

.hero-banner{ border-radius:16px; overflow:hidden; position:relative; height:260px; background:linear-gradient(135deg,#e6ffff,#f5fffb); display:flex; align-items:center; justify-content:center; }
.hero-banner .slogan{ font-size:28px; font-weight:800; color:#00a6a7; }
.dots{ position:absolute; bottom:12px; display:flex; gap:8px; }
.dot{ width:8px; height:8px; border-radius:50%; background:#d1d5db; }
.dot.active{ background:#00a6a7; }

/* ===== 分类入口 ===== */
.cats{ padding:22px 0; }
.cat-grid{ display:grid; grid-template-columns:repeat(8,1fr); gap:10px; }
@media (max-width: 1024px){ .cat-grid{ grid-template-columns:repeat(4,1fr);} }
@media (max-width: 640px){ .cat-grid{ grid-template-columns:repeat(2,1fr);} }
.cat{ background:#fff; border:1px solid #eee; border-radius:12px; padding:14px; text-align:center; cursor:pointer; transition:.2s; }
.cat:hover{ transform:translateY(-3px); box-shadow:0 10px 24px rgba(0,0,0,.06); color:#00a6a7; font-weight:700; }

/* ===== 列表与筛选 ===== */
.section { padding:22px 0 36px; }
.section .hd{ display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.title{ font-size:22px; font-weight:800; }
.filters{ display:flex; gap:10px; flex-wrap:wrap; }
.chip{ padding:8px 12px; border:1px solid #e5e7eb; background:#fff; border-radius:999px; cursor:pointer; color:#4b5563; }
.chip.active,.chip:hover{ border-color:#00a6a7; color:#00a6a7; background:#eefafa; }

.job-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
@media (max-width: 1024px){ .job-grid{ grid-template-columns:repeat(2,1fr);} }
@media (max-width: 640px){ .job-grid{ grid-template-columns:1fr; } }
.job{ background:#fff; border:1px solid #eee; border-radius:12px; padding:16px; transition:.2s; cursor:pointer; display:flex; flex-direction:column; gap:10px; }
.job:hover{ transform:translateY(-4px); box-shadow:0 12px 28px rgba(0,0,0,.07); }
.job-hd{ display:flex; align-items:flex-start; justify-content:space-between; gap:10px; }
.job-title{ font-weight:800; font-size:16px; line-height:1.3; }
.salary{ color:#ff5b47; font-weight:800; }
.meta{ color:#6b7280; font-size:13px; display:flex; gap:8px; flex-wrap:wrap; }
.tags{ display:flex; gap:8px; flex-wrap:wrap; }
.tag{ font-size:12px; background:#f3f4f6; color:#6b7280; padding:4px 8px; border-radius:6px; }
.cmp{ display:flex; align-items:center; gap:10px; border-top:1px dashed #eee; padding-top:12px; margin-top:auto; }
.logo-sm{ width:40px; height:40px; border-radius:8px; object-fit:cover; background:#e5e7eb; }
.cmp-name{ font-weight:700; }
.cmp-sub{ color:#9ca3af; font-size:12px; }

.loadmore-wrap{ text-align:center; margin-top:16px; }
.loadmore{ padding:10px 18px; border-radius:999px; border:1px solid #e5e7eb; background:#fff; cursor:pointer; }
.loadmore:hover{ border-color:#00a6a7; color:#00a6a7; background:#eefafa; }

/* ===== 热门企业（对齐为你推荐的网格与卡片风格） ===== */
.co-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
@media (max-width: 1024px){ .co-grid{ grid-template-columns:repeat(2,1fr);} }
@media (max-width: 640px){ .co-grid{ grid-template-columns:1fr; } }

.co-card{
  background:#fff; border:1px solid #eee; border-radius:12px;
  padding:16px; display:flex; gap:10px; align-items:center;
  cursor:pointer; transition:.2s;
}
.co-card:hover{ transform:translateY(-4px); box-shadow:0 12px 28px rgba(0,0,0,.07); }

.co-logo{ width:40px; height:40px; border-radius:8px; background:#e5e7eb; object-fit:cover; flex:0 0 40px; }
.co-main{ min-width:0; display:flex; flex-direction:column; gap:6px; }
.co-name{ font-weight:800; font-size:16px; line-height:1.3; }
.co-sub{ color:#6b7280; font-size:13px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.co-tags{ display:flex; gap:8px; flex-wrap:wrap; }
.co-tag{ font-size:12px; padding:4px 8px; background:#f3f4f6; color:#6b7280; border-radius:6px; }
.co-more{ text-align:center; margin-top:16px; }

/* ===== 底部 ===== */
.footer{ background:#111827; color:#9ca3af; padding:28px 0; margin-top:30px; }
.links{ display:flex; gap:16px; flex-wrap:wrap; margin-bottom:10px; }
.links a{ color:#cbd5e1; }
.copyright{ font-size:12px; color:#6b7280; }

/* ===== 浮动搜索（滚动出现） ===== */
.float-bar{ position:fixed; left:0; right:0; top:-80px; transition:.3s; z-index:40; }
.float-inner{ backdrop-filter:blur(10px); background:rgba(255,255,255,.75); border-bottom:1px solid #eee; }
.float-row{ max-width:1200px; margin:0 auto; padding:10px 16px; display:flex; gap:8px; align-items:center; }
.float-row .mini-inp{ flex:1; height:40px; border:1px solid #e5e7eb; border-radius:10px; padding:0 12px; outline:none; }
.float-row .mini-btn{ height:40px; padding:0 16px; border:0; border-radius:10px; background:#00a6a7; color:#fff; font-weight:700; cursor:pointer; }

/* ===== 回到顶部 ===== */
.backtop{ position:fixed; right:20px; bottom:24px; width:42px; height:42px; border-radius:50%; background:#00a6a7; color:#fff; display:flex; align-items:center; justify-content:center; cursor:pointer; box-shadow:0 10px 20px rgba(0,0,0,.15); opacity:0; pointer-events:none; transition:.2s; }
.backtop.show{ opacity:1; pointer-events:auto; }


/* === 热门企业：企业下方的岗位列表 === */
.co-card{ display:flex; flex-direction:column; align-items:stretch; }
.co-head{ display:flex; align-items:center; gap:10px; }
.co-jobs{ margin-top:12px; padding-top:12px; border-top:1px dashed #eee; display:flex; flex-direction:column; gap:10px; }
.co-job{ display:flex; align-items:flex-start; justify-content:space-between; gap:10px; }
.co-job-title{ font-weight:700; line-height:1.3; }
.co-job-salary{ color:#ff5b47; font-weight:800; margin-left:8px; white-space:nowrap; }
.co-job-meta{ color:#6b7280; font-size:12px; margin-top:2px; }
.co-job-tags{ display:flex; gap:6px; flex-wrap:wrap; margin-top:6px; }
.co-job-tag{ font-size:12px; padding:3px 6px; background:#f3f4f6; color:#6b7280; border-radius:6px; }
.co-job:hover .co-job-title{ color:#00a6a7; }


/* === 企业卡片底部操作区 === */
.co-actions{ margin-top:8px; display:flex; justify-content:flex-end; }
.btn-link{ border:1px solid #e5e7eb; background:#fff; padding:8px 12px; border-radius:999px; cursor:pointer; font-size:13px; }
.btn-link:hover{ border-color:#00a6a7; color:#00a6a7; background:#eefafa; }

/* 可点击岗位 hover */
.co-job{ cursor:pointer; }
.co-job:hover{ background: #fafafa; border-radius:8px; padding:6px; margin:-6px; }


/* ===== Footer（对齐目标站样式） ===== */
.footer{ background:#111827; color:#cbd5e1; padding:36px 0 0; margin-top:30px; }
.footer-grid{ display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:24px; }
@media (max-width: 1024px){ .footer-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width: 640px){ .footer-grid{ grid-template-columns:1fr; } }

.footer-logo{ font-weight:900; font-size:22px; color:#e5f6f6; }
.footer-logo span{ color:#14b8a6; }
.footer-slogan{ color:#94a3b8; margin:6px 0 10px; }
.footer-hd{ color:#e5e7eb; font-weight:800; margin-bottom:10px; }
.footer-links{ display:flex; flex-direction:column; gap:8px; }
.footer-link{ color:#9fb2c7; }
.footer-link:hover{ color:#19b8b8; }
.footer-apps .dot{ color:#475569; margin:0 6px; }

.footer-legal{ margin-top:22px; background:#0b1220; color:#94a3b8; padding:14px 0 18px; font-size:12px; border-top:1px solid #0e1626; }
.footer-legal a.footer-link{ color:#94a3b8; }
.footer-legal a.footer-link:hover{ color:#19b8b8; }


/* ===== 职位详情页 ===== */
.breadcrumb{ font-size:13px; color:#6b7280; padding:10px 0 0; }
.breadcrumb a{ color:#6b7280; }
.breadcrumb a:hover{ color:#00a6a7; }

.detail { background:#fff; border:1px solid #eee; border-radius:12px; padding:18px; }
.detail-wrap{ display:grid; grid-template-columns:2fr 1fr; gap:16px; padding:22px 0 36px; }
@media (max-width: 1024px){ .detail-wrap{ grid-template-columns:1fr; } }

.job-h1{ display:flex; justify-content:space-between; align-items:flex-start; gap:12px; margin-bottom:10px; }
.job-h1 .title{ font-size:22px; font-weight:900; line-height:1.3; }
.job-h1 .salary{ color:#ff5b47; font-weight:900; font-size:20px; white-space:nowrap; }

.job-meta{ color:#6b7280; font-size:13px; display:flex; gap:12px; flex-wrap:wrap; margin-bottom:10px; }
.job-tags{ display:flex; gap:8px; flex-wrap:wrap; margin:8px 0 0; }
.badge{ font-size:12px; padding:4px 8px; background:#f3f4f6; color:#6b7280; border-radius:6px; }

.section-hd{ font-weight:800; font-size:16px; margin:16px 0 10px; }
.jd{ line-height:1.8; color:#374151; white-space:pre-wrap; }
.benefits{ display:flex; gap:8px; flex-wrap:wrap; }
.benefits .badge{ background:#eefafa; color:#00a6a7; }

.apply-bar{ margin-top:16px; display:flex; gap:8px; }
.btn.primary{ background:#00a6a7; color:#fff; border-color:#00a6a7; }
.btn.gray{ border-color:#e5e7eb; color:#4b5563; background:#fff; }

/* 侧边栏（公司卡片） */
.aside .card{ background:#fff; border:1px solid #eee; border-radius:12px; padding:16px; }
.aside .cmp-head{ display:flex; align-items:center; gap:10px; }
.aside .cmp-logo{ width:48px; height:48px; border-radius:10px; background:#e5e7eb; }
.aside .cmp-name{ font-weight:800; }
.aside .cmp-sub{ color:#9ca3af; font-size:12px; }
.aside .cmp-tags{ display:flex; gap:6px; flex-wrap:wrap; margin-top:8px; }
.sticky{ position:sticky; top:84px; }
.aside .cmp-actions{ margin-top:12px; display:flex; gap:8px; }
.aside .cmp-actions .btn{ flex:1; }

/* 推荐职位（底部） */
.reco{ margin-top:16px; }
.reco .grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
@media (max-width: 1024px){ .reco .grid{ grid-template-columns:repeat(2,1fr);} }
@media (max-width: 640px){ .reco .grid{ grid-template-columns:1fr; } }
.reco .card{ background:#fff; border:1px solid #eee; border-radius:12px; padding:14px; cursor:pointer; transition:.2s; }
.reco .card:hover{ transform:translateY(-3px); box-shadow:0 10px 24px rgba(0,0,0,.06); }


/* ===== 右侧注册/登录模块 & 公司基本信息 ===== */
.aside .auth-card{ background:#fff; border:1px solid #eee; border-radius:12px; padding:16px; margin-bottom:12px; }
.aside .auth-title{ font-weight:800; margin-bottom:10px; }
.aside .auth-tabs{ display:flex; gap:10px; margin-bottom:10px; }
.aside .auth-tab{ padding:6px 10px; border:1px solid #e5e7eb; border-radius:999px; cursor:pointer; color:#4b5563; font-size:13px; }
.aside .auth-tab.active,.aside .auth-tab:hover{ border-color:#00a6a7; color:#00a6a7; background:#eefafa; }
.aside .auth-form{ display:flex; flex-direction:column; gap:8px; }
.aside .auth-form input{ height:38px; border:1px solid #e5e7eb; border-radius:8px; padding:0 10px; outline:none; }
.aside .auth-form .btn{ height:38px; border-radius:8px; }
.aside .auth-note{ color:#9ca3af; font-size:12px; margin-top:6px; }

.aside .info-card{ background:#fff; border:1px solid #eee; border-radius:12px; padding:16px; margin-top:12px; }
.info-list{ display:flex; flex-direction:column; gap:8px; }
.info-item{ display:flex; gap:8px; color:#4b5563; font-size:14px; }
.info-key{ color:#9ca3af; width:70px; flex:0 0 70px; }
.info-val{ flex:1; }


/* ===== Skeletons & Errors ===== */
.skeleton{ background:linear-gradient(90deg,#f3f4f6 25%,#eee 37%,#f3f4f6 63%); background-size:400% 100%; animation:skeleton-loading 1.2s ease-in-out infinite; border-radius:8px; }
@keyframes skeleton-loading{ 0%{background-position:100% 0} 100%{background-position:0 0} }
.sk-line{ height:14px; width:100%; margin:6px 0; }
.sk-circle{ width:48px; height:48px; border-radius:50%; }
.err{ color:#ef4444; font-size:12px; margin-top:4px; }
.hide{ display:none !important; }

/* ===== User Panel after login ===== */
.user-card{ background:#fff; border:1px solid #eee; border-radius:12px; padding:16px; margin-bottom:12px; display:none; }
.user-head{ display:flex; align-items:center; gap:10px; }
.user-avatar{ width:40px; height:40px; border-radius:50%; background:#e5e7eb; }
.user-name{ font-weight:800; }
.user-ops{ display:flex; gap:8px; margin-top:10px; }
.user-ops .btn{ flex:1; }
.logout{ color:#6b7280; cursor:pointer; font-size:12px; margin-top:6px; text-align:right; }
.status{ color:#00a6a7; font-size:12px; margin-top:6px; }


/* ===== Enterprise pages precise styling ===== */
.enterprise-wrap{max-width:1100px;margin:26px auto;padding:0 16px;}
.ent-top{background:#fff;border-radius:10px;padding:18px 20px;border:1px solid #e6eef5;display:flex;gap:16px;align-items:center;box-shadow:0 8px 20px rgba(15,23,42,0.04)}
.ent-logo{width:88px;height:88px;border-radius:12px;background:linear-gradient(180deg,#eef6f8,#e7f1f7);flex:0 0 88px;box-shadow:inset 0 -6px 12px rgba(0,0,0,0.02)}
.ent-title{flex:1}
.ent-title h1{font-size:22px;margin:0;font-weight:900;color:#0f172a;display:flex;align-items:center;gap:12px;}
.ent-pills{margin-top:8px;display:flex;gap:8px;flex-wrap:wrap}
.pill{background:#f7fbff;border:1px solid #e6eef7;padding:6px 10px;border-radius:999px;font-size:13px;color:#64748b}
.ent-meta{margin-top:12px;color:#6b7280;font-size:13px;display:flex;gap:18px;flex-wrap:wrap}

/* main layout */
.ent-grid{display:grid;grid-template-columns:1fr 340px;gap:18px;margin-top:18px;}
@media(max-width:1060px){.ent-grid{grid-template-columns:1fr}}

/* left sections */
.ent-section{background:#fff;border-radius:12px;padding:14px;border:1px solid #eaf0f6}
.ent-section h2{font-size:18px;margin:0 0 12px;color:#0f172a;font-weight:900}

/* job list style */
.job-card{display:flex;align-items:center;gap:12px;padding:14px;border-radius:10px;border:1px solid #f0f5f8;margin-bottom:12px;transition:box-shadow .18s}
.job-left{flex:1}
.job-title{display:flex;justify-content:space-between;align-items:center;font-weight:900;color:#0f172a}
.job-title .salary{color:#ff5b47;font-weight:900;margin-left:12px}
.job-meta{color:#6b7280;font-size:13px;margin-top:8px;display:flex;gap:10px;flex-wrap:wrap}
.job-actions{display:flex;flex-direction:column;gap:8px}

/* right side widgets */
.widget{background:#fff;border-radius:12px;padding:12px;border:1px solid #eaf0f6;margin-bottom:12px}
.widget h3{margin:0 0 8px;font-size:15px;color:#0f172a}

/* vip styles */
.vip-badge{background:linear-gradient(90deg,#fff2d9,#fff0d1);border:1px solid #f3d7a6;padding:6px 10px;border-radius:999px;color:#b45309;font-weight:700}
.vip-highlight{border:1px solid #f3d7a6;box-shadow:0 8px 30px rgba(180,83,9,0.06)}

/* small utilities */
.small{font-size:13px;color:#6b7280}
.btn-outline{border:1px solid #e6eef5;background:#fff;padding:8px 12px;border-radius:999px;cursor:pointer}
.btn-primary{background:#10b981;color:#fff;border-radius:8px;padding:8px 12px;border:0;cursor:pointer}

/* responsive tweaks */
@media(max-width:640px){
  .ent-top{flex-direction:column;align-items:flex-start;gap:12px}
  .ent-title h1{font-size:18px}
  .ent-grid{grid-template-columns:1fr}
}
