@charset "utf-8";
/* HST GENOMICS · 营销物料平台 —— 品牌化重设计 (teal #2ea9a0 / ink #111e2e / Inter) */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

:root{
  --teal:#2ea9a0; --teal-d:#268f87; --teal-l:#e6f4f3;
  --ink:#111e2e; --ink2:#1b3a52;
  --slate:#2d3748; --text:#33404f; --muted:#64748b; --muted2:#94a3b8;
  --line:#e2e8f0; --bg:#f8fafc; --card:#ffffff;
  --radius:14px;
  --shadow:0 1px 2px rgba(17,30,46,.05),0 10px 28px rgba(17,30,46,.06);
  --shadow-lg:0 24px 60px rgba(17,30,46,.14);
  --head-h:72px;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter',"Source Han Sans CN","Microsoft YaHei","PingFang SC",system-ui,-apple-system,sans-serif;
  color:var(--text);background:var(--bg);line-height:1.6;font-size:15.5px;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--teal-d);text-decoration:none;transition:all .25s ease}
a:hover{color:var(--teal)}
img{max-width:100%;vertical-align:middle}
h1,h2,h3,h4{color:var(--slate);line-height:1.25}
.muted{color:var(--muted)}
.container{max-width:1160px;margin:0 auto;padding:38px 26px 64px}

/* ============ 固定毛玻璃顶栏 ============ */
.head{position:fixed;top:0;left:0;right:0;z-index:1000;
  background:rgba(255,255,255,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  box-shadow:0 1px 0 rgba(17,30,46,.06),0 6px 24px rgba(17,30,46,.05)}
.head-in{max-width:1160px;margin:0 auto;height:var(--head-h);padding:0 26px;
  display:flex;align-items:center;gap:26px}
.brand{display:inline-flex;align-items:center}
.brand:hover{opacity:.85}
.brand-logo{height:40px;width:auto;display:block}
.nav{display:flex;align-items:center;gap:6px;margin-left:8px}
.nav a{color:var(--slate);font-weight:600;font-size:15px;padding:9px 18px;border-radius:9px;letter-spacing:.2px}
.nav a:hover{background:var(--teal-l);color:var(--teal-d)}
.nav a.on{background:var(--teal);color:#fff;box-shadow:0 6px 16px rgba(46,169,160,.32)}
.nav a.on:hover{background:var(--teal);color:#fff}
.navright{margin-left:auto;display:flex;align-items:center;gap:12px}
.logout{display:inline-flex;align-items:center;gap:6px;font-size:13.5px;font-weight:600;color:var(--muted);
  border:1px solid var(--line);border-radius:22px;padding:7px 16px;background:#fff}
.logout:hover{border-color:var(--teal);color:var(--teal-d)}
.conter{margin-top:var(--head-h);min-height:calc(100vh - var(--head-h))}

/* ============ Hero 头图带 ============ */
.hero{position:relative;overflow:hidden;color:#fff;
  background:linear-gradient(125deg,var(--ink) 0%,var(--ink2) 58%,var(--teal) 130%)}
.hero::before{content:"";position:absolute;inset:0;
  background:radial-gradient(900px 380px at 85% -10%,rgba(46,169,160,.42),transparent 60%),
             radial-gradient(circle at 12% 120%,rgba(115,186,203,.22),transparent 55%);}
.hero::after{content:"";position:absolute;inset:0;opacity:.5;
  background-image:radial-gradient(rgba(255,255,255,.07) 1px,transparent 1px);background-size:22px 22px}
.hero-in{position:relative;z-index:1;max-width:1160px;margin:0 auto;padding:54px 26px 64px}
.hero-crumb{font-size:13.5px;color:rgba(255,255,255,.72);margin-bottom:14px}
.hero-crumb a{color:rgba(255,255,255,.92)}
.hero-crumb a:hover{color:#fff}
.hero .eyebrow{color:#9ff0e8}
.hero h1{color:#fff;font-size:clamp(28px,3.4vw,42px);font-weight:800;letter-spacing:.5px;margin:0}
.hero p{color:rgba(255,255,255,.86);font-size:clamp(15px,1.4vw,18px);max-width:760px;margin-top:14px}
.hero-badge{display:inline-block;margin-bottom:16px;font-size:12.5px;font-weight:700;letter-spacing:1.5px;
  text-transform:uppercase;color:#bff3ee;background:rgba(46,169,160,.18);
  border:1px solid rgba(159,240,232,.35);padding:5px 14px;border-radius:30px}

/* ============ 标题 ============ */
h1{font-size:26px;margin:0 0 6px}
h2{font-size:21px;font-weight:700;margin:34px 0 16px;padding-bottom:10px;position:relative}
h2::after{content:"";position:absolute;left:0;bottom:0;width:34px;height:3px;border-radius:3px;background:var(--teal)}
.panel h2{margin-top:0}
.sub{color:var(--muted);margin:0 0 18px;font-size:15px}
.eyebrow{display:block;color:var(--teal-d);font-weight:700;letter-spacing:1.8px;font-size:12px;text-transform:uppercase;margin-bottom:8px}

/* ============ 统计卡 (上浮叠在 hero 上) ============ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin:-46px 0 10px;position:relative;z-index:2}
.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px;box-shadow:var(--shadow)}
.stat .n{font-size:34px;font-weight:800;color:var(--teal-d);line-height:1;letter-spacing:-.5px}
.stat .l{color:var(--muted);font-size:13.5px;margin-top:8px;font-weight:500}

/* ============ 产品线分组 ============ */
.linehead{display:flex;align-items:center;gap:12px;margin:40px 0 18px}
.linehead h2{margin:0}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(264px,1fr));gap:20px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);
  overflow:hidden;display:flex;flex-direction:column;transition:transform .28s ease,box-shadow .28s ease,border-color .28s ease}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:#cfe6e3}
.card .body{padding:18px 20px;display:flex;flex-direction:column;gap:7px;flex:1}
.card h3{margin:0;font-size:16.5px;color:var(--slate)}
.card .en{color:var(--teal-d);font-weight:600;font-size:13.5px}
.card .meta{margin-top:auto;display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.card .foot{padding:13px 20px;border-top:1px solid var(--line);display:flex;gap:10px;flex-wrap:wrap;align-items:center;background:#fcfdfe}

/* ============ 物料缩略 ============ */
.thumbs{display:grid;grid-template-columns:repeat(auto-fill,minmax(158px,1fr));gap:18px}
.thumb{background:var(--card);border:1px solid var(--line);border-radius:12px;overflow:hidden;transition:box-shadow .25s,transform .25s}
.thumb:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.thumb .img{aspect-ratio:1/1.414;background:#eef3f7 center/cover no-repeat;display:block;border-bottom:1px solid var(--line)}
.thumb .cap{padding:10px 12px;font-size:12.5px}
.thumb .cap b{display:block;font-size:13.5px;color:var(--slate)}
.dl{display:inline-flex;gap:8px;margin-top:6px}
.dl a{font-size:12px;background:var(--teal-l);color:var(--teal-d);padding:3px 11px;border-radius:20px;font-weight:700}
.dl a:hover{background:#d2efec}

/* ============ 徽章 / 药丸 ============ */
.badge{display:inline-block;font-size:12px;font-weight:700;padding:3px 11px;border-radius:20px;border:1px solid transparent}
.badge.ruo{color:var(--teal-d);border-color:var(--teal);background:var(--teal-l)}
.st-sub{background:#eef2f7;color:#4a5a6b}
.st-prog{background:#fff3df;color:#9a6a00}
.st-rev{background:#e9f0ff;color:#2f5ad0}
.st-done{background:var(--teal-l);color:var(--teal-d)}
.st-rej{background:#fde8e8;color:#b53b3b}
.pill{display:inline-block;font-size:12px;background:#eef2f7;color:#4a5a6b;border-radius:20px;padding:3px 11px;font-weight:600}

/* ============ 按钮 / 表单 ============ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;background:var(--teal);color:#fff;border:0;
  border-radius:10px;padding:11px 22px;font-weight:700;font-size:14.5px;cursor:pointer;
  box-shadow:0 8px 20px rgba(46,169,160,.28);transition:all .25s ease}
.btn:hover{background:var(--teal-d);color:#fff;transform:translateY(-2px);box-shadow:0 12px 26px rgba(46,169,160,.34)}
.btn.block{width:100%}
.btn.ghost{background:#fff;color:var(--slate);border:1px solid var(--line);box-shadow:none}
.btn.ghost:hover{border-color:var(--teal);color:var(--teal-d);background:#fff;box-shadow:0 6px 16px rgba(17,30,46,.06)}
.btn.sm{padding:7px 14px;font-size:13px;box-shadow:none}
.inp,select,textarea{width:100%;padding:11px 14px;border:1px solid var(--line);border-radius:10px;font:inherit;
  font-size:15px;background:#fff;color:var(--text);transition:border-color .2s,box-shadow .2s}
.inp:focus,select:focus,textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(46,169,160,.16)}
textarea{min-height:104px;resize:vertical}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;font-size:13.5px;color:var(--slate);margin-bottom:7px}
.field .hint{color:var(--muted);font-size:12px;margin-top:5px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:24px 26px;box-shadow:var(--shadow)}
.err{color:#b53b3b;font-weight:600}
.ok{color:var(--teal-d);font-weight:600}

/* ============ 表格 ============ */
table.tbl{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.tbl th{background:#f1f5f8;color:var(--slate);text-align:left;padding:13px 14px;font-size:12.5px;font-weight:700;
  letter-spacing:.4px;text-transform:uppercase;border-bottom:2px solid var(--teal)}
.tbl td{padding:13px 14px;border-top:1px solid var(--line);font-size:14px;vertical-align:top}
.tbl tr:hover td{background:#f7fbfb}

/* ============ 时间线 ============ */
.timeline{list-style:none;margin:0;padding:0}
.timeline li{position:relative;padding:0 0 18px 24px;border-left:2px solid var(--teal-l)}
.timeline li:last-child{border-left-color:transparent;padding-bottom:0}
.timeline li:before{content:"";position:absolute;left:-7px;top:3px;width:12px;height:12px;border-radius:50%;background:var(--teal);border:2px solid #fff;box-shadow:0 0 0 2px var(--teal-l)}
.timeline .t{font-size:12px;color:var(--muted);margin-top:2px}

/* ============ 提交反馈 / 拖拽上传 ============ */
.dropzone{border:2px dashed var(--teal);border-radius:12px;background:var(--teal-l);padding:26px;text-align:center;color:var(--teal-d);font-weight:600;cursor:pointer;transition:all .2s}
.dropzone:hover{background:#d8f0ed;border-color:var(--teal-d)}
.filelist{margin-top:10px;font-size:13px;color:var(--muted)}
.flash{padding:14px 18px;border-radius:12px;margin-bottom:18px;font-weight:500}
.flash.ok{background:var(--teal-l);color:var(--teal-d);border:1px solid #bfe6e2}
.crumb{font-size:13px;color:var(--muted);margin-bottom:12px}

/* ============ 深色页脚 ============ */
.foot{background:var(--ink);color:#fff;padding:56px 0 26px;margin-top:64px;position:relative}
.foot::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,#a381b8,#5d7bb8 36%,#73bacb 74%,var(--teal))}
.foot-in{max-width:1160px;margin:0 auto;padding:0 26px;display:flex;justify-content:space-between;gap:48px;flex-wrap:wrap}
.foot-brand{max-width:380px}
.foot-logo{height:40px;width:auto;margin-bottom:18px}
.foot-desc{color:rgba(255,255,255,.6);font-size:14px;line-height:1.8}
.foot-links{display:flex;flex-direction:column;gap:12px}
.foot-links .h{font-size:15px;font-weight:600;color:#fff;margin-bottom:6px;position:relative;padding-bottom:8px}
.foot-links .h::after{content:"";position:absolute;left:0;bottom:0;width:28px;height:2px;background:var(--teal)}
.foot-links a{color:rgba(255,255,255,.62);font-size:14px}
.foot-links a:hover{color:var(--teal)}
.foot-bottom{max-width:1160px;margin:40px auto 0;padding:22px 26px 0;border-top:1px solid rgba(255,255,255,.1);
  display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;color:rgba(255,255,255,.45);font-size:13px}

/* ============ 登录 ============ */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;
  background:linear-gradient(125deg,var(--ink),var(--ink2) 60%,#0e2a3a);position:relative;overflow:hidden}
.login-wrap::before{content:"";position:absolute;inset:0;
  background:radial-gradient(800px 360px at 80% 0,rgba(46,169,160,.4),transparent 60%),
             radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px);background-size:auto,24px 24px}
.login-card{position:relative;z-index:1;width:380px;max-width:100%;background:#fff;border-radius:20px;
  box-shadow:var(--shadow-lg);padding:40px 34px;text-align:center}
.login-logo{height:46px;width:auto;margin-bottom:8px}
.login-card .muted{font-size:13.5px}
.login-card form{margin-top:22px;display:flex;flex-direction:column;gap:14px}

/* ============ 响应式 ============ */
@media(max-width:991px){
  :root{--head-h:64px}
  .brand-logo{height:34px}
  .nav a{padding:8px 12px;font-size:14px}
  .hero-in{padding:40px 22px 52px}
}
@media(max-width:760px){
  .container{padding:30px 18px 50px}
  .head-in{padding:0 16px;gap:12px}
  .nav{margin-left:2px;gap:2px}
  .nav a{padding:7px 10px;font-size:13.5px}
  .logout{padding:6px 12px;font-size:12.5px}
  .stats{grid-template-columns:repeat(2,1fr);gap:12px;margin-top:-32px}
  .row2{grid-template-columns:1fr}
  .foot-in{flex-direction:column;gap:32px}
  .foot-bottom{flex-direction:column;text-align:center}
}
@media(max-width:430px){
  .brand-logo{height:30px}
  .nav a{padding:6px 8px;font-size:13px}
}
