/* 织遗录 · 线上龙鳞  —— 共享主题
   国风暗调：墨黑底 / 鎏金·青玉点缀 / 衬线标题
   三端共用 (index / create / admin) */

:root{
  --ink:#0d0c10;          /* 背景墨 */
  --ink-2:#15131a;        /* 次级面板 */
  --ink-3:#1d1a23;        /* 卡片 */
  --line:rgba(212,175,90,.18);
  --paper:#efe7d6;        /* 主文字·宣纸白 */
  --paper-dim:#b8ad97;    /* 次文字 */
  --paper-faint:#6f685b;  /* 弱文字 */
  --gold:#d4af5a;         /* 鎏金 */
  --gold-soft:#e7c984;
  --jade:#5fae8c;         /* 青玉 */
  --red:#c8453a;          /* 火龙红 */
  --radius:16px;
  --shadow:0 18px 50px -20px rgba(0,0,0,.7);
  --serif:"Noto Serif SC","Songti SC","STSong",ui-serif,serif;
  --sans:"Noto Sans SC","PingFang SC","Microsoft YaHei",ui-sans-serif,system-ui,sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--sans);
  background:
    radial-gradient(1200px 700px at 70% -10%, #20161a 0%, transparent 60%),
    radial-gradient(900px 600px at 0% 100%, #121a18 0%, transparent 55%),
    var(--ink);
  color:var(--paper);
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
  overflow-x:hidden;
}
a{color:var(--gold);text-decoration:none}

/* 顶栏 */
.topbar{
  display:flex;align-items:center;gap:14px;
  padding:14px 20px;
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:30;
  background:linear-gradient(180deg, rgba(13,12,16,.92), rgba(13,12,16,.55));
  backdrop-filter:blur(10px);
}
.brand{font-family:var(--serif);font-weight:700;font-size:20px;letter-spacing:.18em}
.brand .seal{color:var(--red)}
.subbrand{color:var(--paper-faint);font-size:12px;letter-spacing:.2em}
.spacer{flex:1}
.navlink{
  font-size:13px;color:var(--paper-dim);padding:7px 13px;border-radius:999px;
  border:1px solid transparent;transition:.2s;letter-spacing:.05em;
}
.navlink:hover{color:var(--paper);border-color:var(--line);background:rgba(255,255,255,.03)}
.navlink.active{color:var(--gold);border-color:var(--line)}

/* 龙的舞台 */
.stage{position:relative;width:100%;display:block}
.stage svg{display:block;width:100%;height:auto}
.stage-glow{
  position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(60% 40% at 50% 45%, rgba(212,175,90,.10), transparent 70%);
  mix-blend-mode:screen;
}

/* 计数条 */
.counter{
  display:flex;gap:26px;justify-content:center;flex-wrap:wrap;
  padding:10px 16px;color:var(--paper-dim);font-size:13px;letter-spacing:.06em;
}
.counter b{font-family:var(--serif);color:var(--gold-soft);font-size:22px;font-weight:700;margin-right:6px}

/* 通用容器 */
.wrap{max-width:980px;margin:0 auto;padding:24px 20px 80px}
.lead{font-family:var(--serif);font-size:clamp(20px,3.4vw,30px);line-height:1.5;letter-spacing:.02em}
.muted{color:var(--paper-dim)}
.faint{color:var(--paper-faint)}
.center{text-align:center}

/* 卡片 / 面板 */
.card{
  background:linear-gradient(180deg,var(--ink-3),var(--ink-2));
  border:1px solid var(--line);border-radius:var(--radius);
  padding:22px;box-shadow:var(--shadow);
}

/* 表单 */
label.field{display:block;margin:18px 0 8px;font-size:13px;color:var(--paper-dim);letter-spacing:.08em}
textarea,input[type=text],input[type=password]{
  width:100%;background:rgba(0,0,0,.28);border:1px solid var(--line);
  color:var(--paper);border-radius:12px;padding:14px 16px;font-size:16px;
  font-family:var(--sans);resize:none;transition:.2s;
}
textarea:focus,input:focus{outline:none;border-color:rgba(212,175,90,.6);background:rgba(0,0,0,.4)}
textarea::placeholder{color:var(--paper-faint)}
.count-hint{text-align:right;font-size:12px;color:var(--paper-faint);margin-top:6px}

/* 材质选择网格 */
.mat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:8px}
@media(max-width:640px){.mat-grid{grid-template-columns:repeat(2,1fr)}}
.mat{
  cursor:pointer;border:1px solid var(--line);border-radius:14px;padding:12px 10px 10px;
  background:rgba(0,0,0,.22);text-align:center;transition:.18s;position:relative;
}
.mat:hover{transform:translateY(-2px);border-color:rgba(212,175,90,.45)}
.mat.sel{border-color:var(--gold);background:rgba(212,175,90,.10);box-shadow:0 0 0 1px var(--gold) inset}
.mat svg{width:54px;height:60px;display:block;margin:0 auto 6px}
.mat .mn{font-family:var(--serif);font-size:14px;letter-spacing:.05em}
.mat .md{font-size:11px;color:var(--paper-faint);margin-top:2px;line-height:1.3}

/* 颜色选择 */
.swatches{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:8px}
.sw{width:30px;height:30px;border-radius:50%;cursor:pointer;border:2px solid rgba(255,255,255,.15);transition:.15s}
.sw:hover{transform:scale(1.12)}
.sw.sel{border-color:#fff;box-shadow:0 0 0 3px rgba(255,255,255,.15)}
.sw.custom{display:flex;align-items:center;justify-content:center;background:conic-gradient(red,orange,yellow,lime,cyan,blue,magenta,red);color:#fff;font-size:14px}
input[type=color]{position:absolute;opacity:0;width:0;height:0}

/* 按钮 */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--serif);font-size:16px;letter-spacing:.12em;
  padding:14px 30px;border-radius:999px;cursor:pointer;border:1px solid var(--gold);
  background:linear-gradient(180deg,var(--gold-soft),var(--gold));color:#231a06;
  font-weight:700;transition:.2s;
}
.btn:hover{filter:brightness(1.08);transform:translateY(-1px)}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}
.btn.ghost{background:transparent;color:var(--gold);}
.btn.danger{border-color:var(--red);background:transparent;color:#e98e85}
.btn.danger:hover{background:rgba(200,69,58,.12)}
.btn.sm{padding:8px 16px;font-size:13px;letter-spacing:.05em}

/* 鳞片点击卡 */
.scale-pop{
  position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);
  background:linear-gradient(180deg,var(--ink-3),var(--ink-2));
  border:1px solid var(--line);border-radius:16px;padding:18px 22px;max-width:min(520px,92vw);
  box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:.35s cubic-bezier(.2,.9,.3,1);z-index:50;
}
.scale-pop.show{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}
.scale-pop .pq{font-family:var(--serif);font-size:19px;line-height:1.5}
.scale-pop .pmeta{margin-top:8px;font-size:12px;color:var(--paper-faint);letter-spacing:.05em;display:flex;gap:12px;align-items:center}
.scale-pop .pdot{width:10px;height:10px;border-radius:50%}
.scale-pop .px{position:absolute;top:10px;right:14px;color:var(--paper-faint);cursor:pointer;font-size:18px}

/* toast */
.toast{
  position:fixed;left:50%;top:74px;transform:translateX(-50%) translateY(-14px);
  background:rgba(20,18,24,.96);border:1px solid var(--line);color:var(--paper);
  padding:11px 20px;border-radius:999px;font-size:14px;letter-spacing:.05em;
  opacity:0;transition:.3s;z-index:80;box-shadow:var(--shadow);
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* admin 表格 */
.stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:20px}
.stat{background:rgba(0,0,0,.25);border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.stat .sv{font-family:var(--serif);font-size:28px;color:var(--gold-soft)}
.stat .sl{font-size:12px;color:var(--paper-faint);letter-spacing:.1em;margin-top:2px}
.words{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.word{background:rgba(212,175,90,.08);border:1px solid var(--line);border-radius:999px;padding:5px 12px;font-size:13px}
.word b{color:var(--gold-soft);margin-left:6px}
.tbl{width:100%;border-collapse:collapse;margin-top:8px;font-size:14px}
.tbl th{text-align:left;color:var(--paper-faint);font-weight:500;font-size:12px;letter-spacing:.08em;padding:8px 10px;border-bottom:1px solid var(--line)}
.tbl td{padding:10px;border-bottom:1px solid rgba(255,255,255,.05);vertical-align:middle}
.tbl tr.hidden-row{opacity:.4}
.chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--paper-dim)}
.chip .cd{width:12px;height:12px;border-radius:3px}
.row-actions{display:flex;gap:8px;justify-content:flex-end}

.hint{font-size:13px;color:var(--paper-faint);line-height:1.7}
hr.rule{border:none;border-top:1px solid var(--line);margin:26px 0}

/* 入场动画 */
@keyframes floatup{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.floatup{animation:floatup .7s both}
.d1{animation-delay:.1s}.d2{animation-delay:.22s}.d3{animation-delay:.34s}

/* ============ 手机适配 ============ */
.scroll-hint{display:none;text-align:center;color:var(--paper-faint);font-size:12px;letter-spacing:.22em;padding:8px 0 2px}

@media (max-width:700px){
  .topbar{padding:11px 14px;gap:10px}
  .brand{font-size:18px;letter-spacing:.12em}
  .subbrand{display:none}
  .navlink{padding:6px 11px;font-size:12px}

  /* 看龙：长龙变成可横向滑动的“手卷”，放大、可点 */
  .stage{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .stage::-webkit-scrollbar{display:none}
  .stage > .dragon-mount{height:44vh;min-height:240px;width:auto;max-width:none;aspect-ratio:1376/768}
  .scroll-hint{display:block}

  .counter{gap:14px;font-size:12px;padding:10px 12px}
  .counter b{font-size:19px;margin-right:4px}
  .wrap{padding:20px 16px 72px}
  .lead{font-size:20px}

  /* 造鳞：取消预览吸顶、主按钮通栏、色块更好点 */
  .preview-wrap{position:static !important}
  .sw{width:34px;height:34px}
  .btn:not(.sm){width:100%}
  .card{padding:18px}

  /* 鳞片点击卡贴底全宽 */
  .scale-pop{left:12px;right:12px;bottom:12px;transform:translateY(20px);max-width:none}
  .scale-pop.show{transform:translateY(0)}

  /* 管理：统计数字略缩、表格本就可横滑 */
  .stat .sv{font-size:24px}
}

@media (max-width:380px){
  .mat-grid{gap:8px}
  .mat svg{width:46px;height:52px}
  .lead{font-size:18px}
}
