/* ===== 主题变量：蓝白亮色 / 自动暗色 ===== */
:root{
  --bg:#f4f7fb; --bg2:#ffffff; --panel:#ffffff; --panel2:#f0f5ff;
  --border:#dde6f0; --border2:#c5d4e8;
  --text:#1a2740; --text2:#46587a; --muted:#7a8aa8;
  --accent:#2563eb; --accent2:#1d4ed8; --accent-soft:#e8f0ff;
  --ok:#16a34a; --warn:#d97706; --err:#dc2626;
  --shadow:0 1px 3px rgba(30,58,95,.08),0 1px 2px rgba(30,58,95,.06);
  --shadow-lg:0 10px 30px rgba(30,58,95,.16);
}
[data-theme="dark"]{
  --bg:#0d1521; --bg2:#0d1521; --panel:#16202e; --panel2:#1a2738;
  --border:#243248; --border2:#2f4160;
  --text:#e6edf6; --text2:#b8c5d8; --muted:#7e8ea8;
  --accent:#3b82f6; --accent2:#60a5fa; --accent-soft:#1a2740;
  --ok:#34d399; --warn:#fbbf24; --err:#f87171;
  --shadow:0 1px 3px rgba(0,0,0,.3); --shadow-lg:0 10px 30px rgba(0,0,0,.5);
}
*{box-sizing:border-box}
html,body{margin:0}
/* 关键：[hidden] 必须能覆盖类选择器（如 .file-grid 的 display:grid），否则列表/网格两视图会同时显示 */
[hidden]{display:none !important}
body{background:var(--bg);color:var(--text);font:14px/1.6 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"PingFang SC","Microsoft YaHei",sans-serif;-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:1140px;margin:0 auto;padding:0 16px}
.topbar{background:var(--bg2);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50;box-shadow:var(--shadow)}
.nav{display:flex;align-items:center;gap:14px;height:58px;flex-wrap:wrap}
.brand{font-weight:700;font-size:16px;color:var(--text);display:flex;align-items:center;gap:6px}
.nav .links{display:flex;gap:6px}
.nav .links a{color:var(--text2);padding:7px 12px;border-radius:8px;font-weight:500}
.nav .links a.active{background:var(--accent-soft);color:var(--accent)}
.nav .links a:hover{background:var(--panel2);text-decoration:none}
.nav .spacer{flex:1}
.user{display:flex;align-items:center;gap:8px}
.avatar{width:26px;height:26px;border-radius:50%;vertical-align:middle;object-fit:cover}
.avatar-ph{display:inline-flex;align-items:center;justify-content:center;background:var(--accent-soft);color:var(--accent);font-size:13px;font-weight:700}
.uname{color:var(--text);font-weight:500}
.badge{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;font-size:11px;padding:2px 8px;border-radius:10px;font-weight:600}

/* ===== 管理员头像下拉菜单 ===== */
.user-menu{position:relative}
.user-trigger{display:inline-flex;align-items:center;gap:7px;background:transparent;border:1px solid transparent;color:var(--text);padding:4px 8px;border-radius:10px;cursor:pointer;font:inherit}
.user-trigger:hover{background:var(--panel2);border-color:var(--border)}
.user-trigger .caret{font-size:10px;color:var(--muted);margin-left:-2px}
.user-dropdown{position:absolute;right:0;top:calc(100% + 8px);width:300px;background:var(--panel);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-lg);z-index:200;overflow:hidden;animation:pop .16s}
.ud-head{padding:14px 16px 8px;border-bottom:1px solid var(--border)}
.ud-title{font-weight:700;font-size:14px}
.ud-sub{font-size:11px;margin-top:2px}
.ud-stats{padding:8px 12px}
.ud-loading{padding:20px 0;text-align:center;font-size:13px}
.ud-stat{padding:10px;background:var(--panel2);border-radius:10px}
.ud-k{font-size:12px;color:var(--muted)}
.ud-v{font-size:18px;font-weight:700;color:var(--text);margin-top:2px}
.ud-v small{font-size:11px;font-weight:400;color:var(--muted);margin-left:3px}
.ud-sub2{font-size:11px;margin-top:3px}
.ud-grid{display:grid;gap:8px}
.ud-grid-2{grid-template-columns:1fr 1fr}
.ud-grid-3{grid-template-columns:repeat(3,1fr);margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}
/* 小计数：左对齐 + 左侧彩色竖线（每项不同色） */
.ud-mini{background:transparent;border-radius:6px;padding:4px 10px;border-left:3px solid var(--accent)}
.ud-mini.c-user{border-left-color:#2563eb}
.ud-mini.c-share{border-left-color:#16a34a}
.ud-mini.c-buy{border-left-color:#d97706}
.ud-mk{font-size:11px;color:var(--muted)}
.ud-mv{font-size:17px;font-weight:700;margin-top:1px}
.ud-links{padding:6px 8px;border-top:1px solid var(--border)}
.ud-link{display:block;padding:8px 10px;border-radius:8px;color:var(--text2);font-size:13px}
.ud-link:hover{background:var(--panel2);color:var(--accent);text-decoration:none}
.ud-foot{padding:10px 12px;border-top:1px solid var(--border);display:flex;justify-content:flex-end}
.ud-logout{width:100%}
.content{padding:24px 16px 88px}
/* 固定底部状态栏：技术栈字样 + GitHub 开源链接 */
.footer-bar{position:fixed;left:0;right:0;bottom:0;background:var(--bg2);border-top:1px solid var(--border);z-index:40;backdrop-filter:saturate(1.4)}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;height:44px;flex-wrap:wrap;font-size:12px;color:var(--muted)}
.gh-link{display:inline-flex;align-items:center;gap:5px;color:var(--muted);padding:3px 10px;border-radius:8px;border:1px solid var(--border);transition:all .15s}
.gh-link:hover{color:var(--accent);border-color:var(--accent);text-decoration:none;background:var(--panel2)}
@media(max-width:600px){.footer-inner{justify-content:center;text-align:center;height:auto;padding:8px 16px}}
/* 底部状态栏样式见 .footer-bar / .footer-inner */

/* 主题切换按钮：三态图标显示 */
.theme-toggle{position:relative;width:34px;height:34px;padding:0;text-align:center;line-height:32px}
.theme-toggle .theme-ico{display:none}
.theme-toggle[data-mode="auto"] .theme-ico-auto,
.theme-toggle[data-mode="light"] .theme-ico-light,
.theme-toggle[data-mode="dark"] .theme-ico-dark{display:inline}

/* ===== 上传悬浮按钮 + 拖拽蒙层（管理员） ===== */
.fab{position:fixed;right:max(24px,calc((100vw - 1140px) / 2));bottom:64px;width:56px;height:56px;border-radius:50%;border:none;cursor:pointer;font-size:30px;line-height:1;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent2));box-shadow:0 6px 20px rgba(37,99,235,.45);z-index:60;display:flex;align-items:center;justify-content:center;transition:transform .15s,box-shadow .15s}
.fab:hover{transform:translateY(-3px) scale(1.06);box-shadow:0 10px 28px rgba(37,99,235,.6)}
.fab:active{transform:translateY(-1px) scale(1.02)}
.drop-overlay{position:fixed;inset:0;background:rgba(37,99,235,.18);backdrop-filter:blur(3px);z-index:500;display:flex;align-items:center;justify-content:center;pointer-events:none}
.drop-hint{background:var(--panel);border:2px dashed var(--accent);border-radius:16px;padding:36px 56px;font-size:18px;font-weight:600;color:var(--accent);box-shadow:var(--shadow-lg)}

/* ===== 悬浮通知 toast ===== */
.toast-box{position:fixed;top:72px;right:max(16px,calc((100vw - 1140px)/2));z-index:3000;display:flex;flex-direction:column;gap:10px;max-width:360px;pointer-events:none}
.toast{display:flex;align-items:center;gap:10px;background:var(--panel);border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:10px;padding:12px 16px;box-shadow:var(--shadow-lg);cursor:pointer;pointer-events:auto;opacity:0;transform:translateX(140%) scale(.9);transition:opacity .35s cubic-bezier(.22,1,.36,1),transform .4s cubic-bezier(.22,1,.36,1)}
.toast.show{opacity:1;transform:none}
.toast.hide{opacity:0;transform:translateX(140%) scale(.9)}
.toast-ok{border-left-color:var(--ok)}
.toast-err{border-left-color:var(--err)}
.toast-msg{flex:1;font-size:13px;color:var(--text);word-break:break-all}
.toast-link{color:var(--accent);font-size:12px;white-space:nowrap}
.toast-link:hover{text-decoration:underline}

/* 按钮 */
.btn{display:inline-flex;align-items:center;gap:6px;background:var(--panel);color:var(--text);border:1px solid var(--border);padding:8px 16px;border-radius:8px;cursor:pointer;font:inherit;font-weight:500;transition:all .15s;text-decoration:none}
.btn:hover{border-color:var(--accent);color:var(--accent);text-decoration:none;transform:translateY(-1px)}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent2));border-color:transparent;color:#fff}
.btn-primary:hover{color:#fff;filter:brightness(1.08);transform:translateY(-1px)}
.btn-danger{background:var(--err);border-color:var(--err);color:#fff}
.btn-danger:hover{color:#fff;filter:brightness(1.08)}
.btn-sm{padding:5px 11px;font-size:13px}
.btn-ghost{background:transparent;border-color:transparent;color:var(--text2)}
.btn-ghost:hover{background:var(--panel2);color:var(--accent);transform:none}

.panel{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:20px;margin-bottom:16px;box-shadow:var(--shadow)}
.panel h2{margin:0 0 4px;font-size:18px}
table.files{width:100%;border-collapse:collapse}
table.files th,table.files td{padding:11px 12px;text-align:left;border-bottom:1px solid var(--border)}
table.files th{color:var(--muted);font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.04em}
table.files tbody tr{transition:background .12s}
table.files tbody tr:hover{background:var(--panel2)}
table.files tbody tr{cursor:default}
.muted{color:var(--muted)}
.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.row.between{justify-content:space-between}
.input,select,textarea{background:var(--bg2);border:1px solid var(--border);color:var(--text);padding:9px 12px;border-radius:8px;font:inherit;width:100%;transition:border .15s}
.input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
label{display:block;margin:10px 0 4px;color:var(--muted);font-size:13px}
.grid{display:grid;gap:16px}
@media(min-width:700px){.grid-2{grid-template-columns:1fr 1fr}}
.price{color:var(--warn);font-weight:600}
.free{color:var(--ok);font-weight:600}
.tag{display:inline-block;background:var(--panel2);border:1px solid var(--border);padding:3px 10px;border-radius:14px;font-size:12px;color:var(--text2);text-decoration:none}
.tag:hover,.tag.active{background:var(--accent-soft);color:var(--accent);border-color:var(--accent-soft);text-decoration:none}
.center{text-align:center}
.notice{padding:12px 16px;border-radius:8px;margin:12px 0;font-size:13px}
.notice.err{background:rgba(220,38,38,.1);border:1px solid var(--err);color:var(--err)}
.notice.ok{background:rgba(22,163,74,.1);border:1px solid var(--ok);color:var(--ok)}

/* ===== 网格视图 ===== */
.file-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.file-card{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:14px;text-align:center;cursor:default;transition:all .15s;position:relative;user-select:none}
.file-card:hover{border-color:var(--accent);box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.file-card .ficon{font-size:40px;line-height:1;margin-bottom:8px}
.file-card .fname{font-size:13px;font-weight:500;color:var(--text);word-break:break-all;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:38px}
.file-card .fmeta{font-size:11px;color:var(--muted);margin-top:6px}
.file-card .fprice{margin-top:6px}

/* 文件类型图标颜色 */
.ficon.zip{color:#d97706}.ficon.img{color:#16a34a}.ficon.doc{color:#2563eb}.ficon.vid{color:#dc2626}.ficon.audio{color:#9333ea}.ficon.code{color:#0891b2}
/* 图片缩略图（网格视图） */
.fthumb{display:block;width:100%;height:96px;object-fit:cover;border-radius:8px;margin-bottom:8px;background:var(--panel2)}

/* 详情弹窗：图片左右两栏布局 */
.dtl-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(240px,300px);gap:20px;align-items:start}
.dtl-preview{min-width:0}
/* 详情图：按原比例完整展示，宽度自适应左栏（不设固定高度，不裁剪） */
.dtl-thumb{display:block;width:100%;height:auto;max-height:70vh;object-fit:contain;border-radius:10px;background:var(--panel2);box-shadow:var(--shadow)}
.dtl-info{min-width:0}
/* 窄屏：两栏堆叠成单列 */
@media(max-width:640px){.dtl-layout{grid-template-columns:1fr}.dtl-thumb{max-height:50vh}}

/* 视图切换 */
.view-switch{display:inline-flex;background:var(--panel2);border:1px solid var(--border);border-radius:8px;padding:2px}
.view-switch button{background:transparent;border:none;padding:6px 12px;border-radius:6px;cursor:pointer;color:var(--muted);font:inherit;font-size:13px}
.view-switch button.active{background:var(--panel);color:var(--accent);box-shadow:var(--shadow)}

/* ===== 右键菜单 ===== */
.ctxmenu{position:fixed;z-index:9999;background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:6px;min-width:170px;box-shadow:var(--shadow-lg)}
.ctx-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:transparent;color:var(--text);font:inherit;font-size:13px;border-radius:6px;cursor:pointer;text-decoration:none;text-align:left}
.ctx-item:hover{background:var(--panel2);color:var(--accent);text-decoration:none}
.ctx-item.danger{color:var(--err)}
.ctx-item.danger:hover{background:rgba(220,38,38,.1);color:var(--err)}
.ctx-sep{height:1px;background:var(--border);margin:4px 0}
.ctx-item .ico{width:16px;display:inline-block;text-align:center}

/* ===== 模态弹窗 ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.5);backdrop-filter:blur(2px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px;animation:fade .15s}
.modal{background:var(--panel);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-lg);width:100%;max-width:760px;max-height:90vh;overflow:auto}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}
.modal-head h3{margin:0;font-size:16px}
.modal-body{padding:20px}
.modal-foot{display:flex;gap:10px;justify-content:flex-end;padding:14px 20px;border-top:1px solid var(--border)}
.modal-x{background:none;border:none;font-size:20px;color:var(--muted);cursor:pointer;padding:0 4px;line-height:1}
.modal-x:hover{color:var(--text)}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{0%{opacity:0;transform:scale(.9) translateY(16px)}60%{opacity:1;transform:scale(1.02) translateY(-2px)}100%{opacity:1;transform:none}}
.modal{animation:pop .32s cubic-bezier(.22,1,.36,1)}
/* 关闭动画：遮罩淡出 + 弹窗缩小下移消失 */
.modal-overlay.closing{animation:fadeOut .2s forwards}
.modal.closing{animation:popOut .2s cubic-bezier(.4,0,1,1) forwards}
@keyframes fadeOut{to{opacity:0}}
@keyframes popOut{to{opacity:0;transform:scale(.94) translateY(12px)}}

@media(max-width:600px){
  .nav{height:auto;padding:10px 0;gap:8px}
  .brand{font-size:15px}
  .file-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}
}
