/* 政采数智通 · 对外门户公共样式 (浅色 · 红蓝双主调 · 精致圆角清爽风)
   服务于: home.html / login.html / register.html / member.html
   公开路径: /static/shared/portal.css */

:root{
  --red:#c8161d; --red-dark:#9c1014; --red-soft:#fdecec;
  --blue:#2b57d4; --blue-2:#4a78e8; --blue-soft:#eef3fe; --blue-ink:#2647b0;
  --gold:#d4af37;
  --ink:#1a2230; --ink-2:#51607a; --ink-3:#8b97ad;
  --bg:#ffffff; --bg-soft:#f5f7fb; --bg-soft-2:#eef1f7;
  --border:#e4e9f2; --border-2:#d4dbe8;
  --ok:#0f9d6c; --warn:#b45309;
  --radius:16px; --radius-sm:10px; --radius-pill:999px;
  --shadow-sm:0 2px 8px rgba(28,42,82,.06);
  --shadow:0 8px 28px rgba(28,42,82,.10);
  --shadow-lg:0 18px 50px rgba(28,42,82,.16);
  --maxw:1180px;
  --font:"Source Han Sans CN","思源黑体","PingFang SC","Microsoft YaHei",-apple-system,sans-serif;
  --grad-red:linear-gradient(135deg,#e83a40 0%,#d11d24 55%,#b01419 100%);
  --grad-blue:linear-gradient(135deg,#6a99f4 0%,#4071e6 52%,#3159d4 100%);
}

/* inline SVG 图标统一尺寸/着色 */
.ico{display:inline-block;vertical-align:middle;width:20px;height:20px;flex:none}
.ico-lg{width:26px;height:26px}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font);color:var(--ink);background:var(--bg);
  -webkit-font-smoothing:antialiased;line-height:1.6;font-size:15px}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ============ 顶部导航 ============ */
.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.86);
  backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--border)}
.nav-in{max-width:var(--maxw);margin:0 auto;padding:0 24px;height:64px;
  display:flex;align-items:center;gap:28px}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;font-size:18px;letter-spacing:.5px}
.brand .seal{width:34px;height:34px;border-radius:9px;background:var(--grad-red);
  color:#fff;display:grid;place-items:center;font-size:16px;font-weight:800;
  box-shadow:0 4px 12px rgba(200,22,29,.32)}
.brand b{background:linear-gradient(90deg,var(--red),var(--blue));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.nav-links{display:flex;gap:24px;margin-left:8px}
.nav-links a{color:var(--ink-2);font-size:14.5px;font-weight:500;padding:6px 2px;position:relative}
.nav-links a:hover{color:var(--blue)}
.nav-spacer{flex:1}
.nav-actions{display:flex;align-items:center;gap:12px}
.nav-user{display:flex;align-items:center;gap:10px;font-size:13.5px;color:var(--ink-2)}
.nav-user .bal{color:var(--red);font-weight:700}
/* 服务热线 */
.nav-phone{display:flex;align-items:center;gap:7px;color:var(--blue);font-weight:700;font-size:14px;
  padding-right:14px;margin-right:4px;border-right:1px solid var(--border)}
.nav-phone .ph-ic{width:30px;height:30px;border-radius:9px;background:var(--blue-soft);
  display:grid;place-items:center;color:var(--blue)}
.nav-phone small{display:block;font-size:11px;font-weight:500;color:var(--ink-3);line-height:1}
.nav-phone b{font-size:15px;letter-spacing:.3px}
@media(max-width:1080px){.nav-phone{display:none}}

/* 波浪/斜面 分隔 */
.divider{display:block;width:100%;height:auto;line-height:0}
.divider svg{display:block;width:100%;height:60px}

/* ============ 按钮 ============ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:inherit;font-size:14.5px;font-weight:600;cursor:pointer;border:none;
  padding:11px 22px;border-radius:var(--radius-pill);transition:.18s;white-space:nowrap;line-height:1}
.btn:active{transform:translateY(1px)}
.btn-red{background:var(--grad-red);color:#fff;box-shadow:0 6px 18px rgba(200,22,29,.28)}
.btn-red:hover{box-shadow:0 10px 26px rgba(200,22,29,.40);filter:brightness(1.04)}
.btn-blue{background:var(--grad-blue);color:#fff;box-shadow:0 6px 18px rgba(30,58,138,.26)}
.btn-blue:hover{box-shadow:0 10px 26px rgba(30,58,138,.38);filter:brightness(1.05)}
.btn-ghost{background:#fff;color:var(--blue);border:1.5px solid var(--border-2)}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue)}
.btn-ghost-red{background:#fff;color:var(--red);border:1.5px solid #f2c9cb}
.btn-ghost-red:hover{border-color:var(--red)}
.btn-lg{padding:15px 32px;font-size:16px}
.btn-sm{padding:8px 16px;font-size:13px}
.btn-block{width:100%}

/* ============ 通用区块 ============ */
section{padding:84px 0}
.sec-tag{display:inline-block;font-size:13px;font-weight:700;letter-spacing:2px;
  color:var(--red);background:var(--red-soft);padding:5px 14px;border-radius:var(--radius-pill);margin-bottom:16px}
.sec-tag.blue{color:var(--blue);background:var(--blue-soft)}
.sec-title{font-size:34px;font-weight:800;letter-spacing:.5px;margin:0 0 14px;line-height:1.25}
.sec-sub{font-size:16px;color:var(--ink-2);max-width:620px;margin:0 auto}
.center{text-align:center}

/* ============ 卡片 ============ */
.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);transition:.2s}
.card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}

/* ============ 表单(登录注册) ============ */
.auth-wrap{min-height:100vh;display:grid;grid-template-columns:1.1fr 1fr;background:var(--bg)}
.auth-aside{background:var(--grad-blue);color:#fff;padding:56px 52px;display:flex;
  flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.auth-aside::after{content:"";position:absolute;right:-120px;bottom:-120px;width:360px;height:360px;
  background:radial-gradient(circle,rgba(200,22,29,.5),transparent 70%);border-radius:50%}
.auth-aside .seal{width:48px;height:48px;border-radius:12px;background:var(--grad-red);
  display:grid;place-items:center;font-size:22px;font-weight:800;margin-bottom:26px;
  box-shadow:0 8px 22px rgba(0,0,0,.25)}
.auth-aside h2{font-size:30px;margin:0 0 16px;line-height:1.3}
.auth-aside p{font-size:15px;color:rgba(255,255,255,.82);margin:0 0 28px;max-width:380px}
.auth-aside .pts{display:flex;flex-direction:column;gap:14px;position:relative;z-index:2}
.auth-aside .pt{display:flex;align-items:center;gap:12px;font-size:14.5px;color:rgba(255,255,255,.92)}
.auth-aside .pt i{width:24px;height:24px;border-radius:7px;background:rgba(255,255,255,.16);
  display:grid;place-items:center;font-style:normal;font-size:13px}
.auth-main{display:flex;align-items:center;justify-content:center;padding:40px 28px}
.auth-card{width:100%;max-width:400px}
.auth-card h1{font-size:26px;font-weight:800;margin:0 0 6px}
.auth-card .lead{color:var(--ink-2);font-size:14.5px;margin:0 0 30px}
.field{margin-bottom:18px}
.field label{display:block;font-size:13.5px;font-weight:600;color:var(--ink-2);margin-bottom:7px}
.field input{width:100%;padding:13px 15px;font-size:15px;font-family:inherit;color:var(--ink);
  background:var(--bg-soft);border:1.5px solid var(--border);border-radius:var(--radius-sm);transition:.15s}
.field input:focus{outline:none;border-color:var(--blue);background:#fff;
  box-shadow:0 0 0 3px var(--blue-soft)}
.auth-msg{font-size:13.5px;padding:10px 14px;border-radius:var(--radius-sm);margin-bottom:16px;display:none}
.auth-msg.err{display:block;background:var(--red-soft);color:var(--red-dark);border:1px solid #f2c9cb}
.auth-msg.ok{display:block;background:#e6f6ef;color:var(--ok);border:1px solid #bfe6d4}
.auth-foot{text-align:center;margin-top:22px;font-size:14px;color:var(--ink-2)}
.auth-foot a{color:var(--blue);font-weight:600}

/* ============ 页脚 ============ */
.footer{background:var(--bg-soft);border-top:1px solid var(--border);padding:48px 0 32px;color:var(--ink-2)}
.footer .cols{display:flex;flex-wrap:wrap;gap:48px;justify-content:space-between;margin-bottom:32px}
.footer h4{font-size:14px;color:var(--ink);margin:0 0 14px}
.footer a{display:block;color:var(--ink-2);font-size:13.5px;margin-bottom:9px}
.footer a:hover{color:var(--blue)}
.footer .copy{border-top:1px solid var(--border);padding-top:22px;font-size:13px;color:var(--ink-3);text-align:center}

@media(max-width:920px){
  .nav-links{display:none}
  .auth-wrap{grid-template-columns:1fr}
  .auth-aside{display:none}
  section{padding:60px 0}
  .sec-title{font-size:27px}
}
