/* === Theme tokens ===
   :root         = 浅色 / 日常 (default)  — 优化版: 暖白基底 + 品牌渐变 + 立体层次
   html.dark     = 深色
   html[data-theme="light"] 显式锁定
   html[data-theme="dark"]  显式锁定
*/
:root{
  /* === 基础背景：暖白基底，避免惨白 === */
  --bg:#FFFFFF;
  --bg2:#F6F8FB;
  --bg3:#EEF2F7;

  /* === 文字：更高对比度层级 === */
  --text:#0B1220;          /* 主标题用色：近黑蓝，对比度 AAA */
  --text2:#334155;          /* 正文用色：深石板灰，对比度 AA++ */
  --text3:#64748B;          /* 辅助文字：中性灰，对比度 AA (4.5:1) */

  /* === 品牌主色：更具活力的靛蓝 === */
  --primary:#4F46E5;        /* Indigo 600 */
  --primary-h:#4338CA;      /* Indigo 700 hover */
  --primary-light:#818CF8;  /* Indigo 400 浅色 */
  --mint:#0EA5E9;           /* Sky 500 副色 */
  --purple:#A855F7;         /* Purple 500 强调 */
  --gold:#F59E0B;
  --danger:#DC2626;
  --success:#10B981;

  /* === 边框：更清晰可见 === */
  --border:rgba(15,23,42,0.10);
  --border-h:rgba(79,70,229,0.40);

  /* === 卡片：半透明 + 微妙底色，层次更丰富 === */
  --card:rgba(255,255,255,0.78);
  --card-h:rgba(255,255,255,0.95);
  --glass:rgba(255,255,255,0.55);

  /* === 页面背景：暖白渐变 + 顶部品牌光晕 === */
  --bg-page:#FAFAF7;
  --bg-page-2:#EEF2F7;
  --bg-page-glow:radial-gradient(ellipse 1200px 600px at 50% -10%, rgba(99,102,241,0.10) 0%, rgba(14,165,233,0.04) 35%, transparent 70%);

  /* === 导航 / 区块：增强玻璃感 === */
  --bg-nav:rgba(255,255,255,0.78);
  --bg-section:rgba(255,255,255,0.65);
  --bg-modal:linear-gradient(180deg,#FFFFFF 0%,#FAFAF7 100%);

  /* === 表单 / 标签 / 浮层 === */
  --bg-elevated:#FFFFFF;
  --bg-input:#FFFFFF;
  --bg-input-focus:#F8FAFC;
  --bg-tag:rgba(238,242,247,0.9);
  --bg-overlay:rgba(15,23,42,0.5);
  --bg-soft:rgba(241,245,249,0.7);
  --bg-hover:rgba(15,23,42,0.05);
  --bg-hover-strong:rgba(15,23,42,0.08);
  --bg-primary-soft:rgba(79,70,229,0.08);
  --bg-primary-soft-h:rgba(79,70,229,0.14);

  --text-inv:#FFFFFF;

  /* === 滚动条 === */
  --scroll-thumb:rgba(15,23,42,0.20);
  --scroll-thumb-h:rgba(79,70,229,0.45);

  /* === 阴影：明显但不沉重 === */
  --shadow:0 1px 2px rgba(15,23,42,0.04), 0 4px 16px rgba(15,23,42,0.06);
  --shadow-lg:0 8px 24px rgba(15,23,42,0.08), 0 20px 48px rgba(15,23,42,0.10);

  --r:8px;--r2:10px;--r3:12px;
  --font:'Inter','Noto Sans SC',system-ui,-apple-system,'PingFang SC','Hiragino Sans GB','Microsoft YaHei',sans-serif;
  color-scheme:light;
}
html.dark,html[data-theme="dark"]{
  --bg:#0F172A;--bg2:#1E293B;--bg3:#334155;
  --text:#F8FAFC;--text2:#CBD5E1;--text3:#64748B;
  --primary:#3B82F6;--primary-h:#2563EB;--primary-light:#60A5FA;
  --mint:#06D6D4;--purple:#8B5CF6;--gold:#F59E0B;--danger:#EF4444;--success:#10B981;
  --border:rgba(255,255,255,0.06);--border-h:rgba(59,130,246,0.3);
  --card:rgba(30,41,59,0.6);--card-h:rgba(30,41,59,0.8);--glass:rgba(30,41,59,0.5);
  --bg-page:#020617;--bg-page-2:#0B1120;
  --bg-nav:rgba(15,23,42,0.85);
  --bg-section:rgba(15,23,42,0.6);
  --bg-modal:linear-gradient(180deg,#0F172A 0%,#0B1120 100%);
  --bg-elevated:#1E293B;
  --bg-input:rgba(255,255,255,0.03);
  --bg-input-focus:rgba(59,130,246,0.04);
  --bg-tag:rgba(30,41,59,0.7);
  --bg-overlay:rgba(0,0,0,0.6);
  --bg-soft:rgba(15,23,42,0.55);
  --bg-hover:rgba(255,255,255,0.05);
  --bg-hover-strong:rgba(255,255,255,0.08);
  --bg-primary-soft:rgba(99,102,241,0.14);
  --bg-primary-soft-h:rgba(99,102,241,0.22);
  --text-inv:#0F172A;
  --scroll-thumb:rgba(59,130,246,0.25);
  --scroll-thumb-h:rgba(59,130,246,0.5);
  --shadow:0 4px 24px rgba(0,0,0,0.2);
  --shadow-lg:0 12px 40px rgba(0,0,0,0.4);
  --skel-base:rgba(255,255,255,0.04);
  --skel-hi:rgba(255,255,255,0.08);
  --gradient-divider:linear-gradient(90deg,transparent,rgba(255,255,255,0.10),transparent);
  --grid-line:rgba(255,255,255,0.08);
  --pattern-placeholder:linear-gradient(135deg,rgba(255,255,255,0.02),rgba(255,255,255,0.05));

  --font:'Inter','Noto Sans SC',system-ui,-apple-system,'PingFang SC','Hiragino Sans GB','Microsoft YaHei',sans-serif;
  --font-serif:'Noto Serif SC','Source Han Serif SC','Songti SC','SimSun',serif;
  color-scheme:dark;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px;background:var(--bg-page);background-image:var(--bg-page-glow),linear-gradient(180deg,var(--bg-page) 0%,var(--bg-page-2) 100%);min-height:100vh;transition:background .3s ease;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}
html.dark,html[data-theme="dark"]{background-image:linear-gradient(180deg,var(--bg-page) 0%,var(--bg-page-2) 100%)}
body{font-family:var(--font);background:transparent;color:var(--text);line-height:1.6;overflow-x:hidden;min-height:100vh;transition:color .25s ease,background .25s ease;font-feature-settings:"tnum","ss01","cv11"}
::selection{background:rgba(59,130,246,0.3);color:inherit}
:focus-visible{outline:2px solid var(--primary);outline-offset:2px}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--scroll-thumb);border-radius:3px;transition:background .2s}
::-webkit-scrollbar-thumb:hover{background:var(--scroll-thumb-h)}
.floating-back{
  display:inline-flex;align-items:center;gap:5px;
  margin:14px 0 6px;
  padding:6px 14px 6px 10px;
  background:linear-gradient(135deg,rgba(30,41,59,0.6),rgba(15,23,42,0.7));
  border:1px solid rgba(99,102,241,0.35);
  border-radius:999px;
  color:#cbd5e1;font-size:12px;font-weight:500;
  cursor:pointer;backdrop-filter:blur(8px);
  box-shadow:0 2px 8px rgba(0,0,0,0.2);
  transition:all .18s ease;
  user-select:none;
  vertical-align:middle;
  opacity:0;visibility:hidden;transform:translateX(-6px);
}
.floating-back:hover{
  background:linear-gradient(135deg,rgba(59,130,246,0.25),rgba(99,102,241,0.3));
  border-color:rgba(99,102,241,0.7);
  color:#fff;transform:translateX(-2px);
  box-shadow:0 4px 14px rgba(59,130,246,0.3);
}
.floating-back:active{transform:translateX(-2px) scale(0.97)}
.floating-back.show{opacity:1;visibility:visible;transform:translateX(0);transition:all .25s ease}
.floating-back svg{flex-shrink:0}
.page{padding-top:8px}
.app-toast{
  position:fixed;top:80px;left:50%;transform:translateX(-50%) translateY(-12px);
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 18px;
  background:rgba(15,23,42,0.95);backdrop-filter:blur(12px);
  border:1px solid rgba(99,102,241,0.4);border-radius:999px;
  color:#fff;font-size:13px;font-weight:500;
  box-shadow:0 8px 32px rgba(0,0,0,0.4),0 0 0 1px rgba(255,255,255,0.06) inset;
  z-index:9999;opacity:0;visibility:hidden;pointer-events:none;
  transition:all .28s cubic-bezier(.34,1.56,.64,1);
  max-width:90vw;
}
.app-toast.show{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.app-toast-icon{
  width:18px;height:18px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;flex-shrink:0;
}
.app-toast-success .app-toast-icon{background:#10B981;color:#fff}
.app-toast-warning .app-toast-icon{background:#F59E0B;color:#fff}
.app-toast-error .app-toast-icon{background:#EF4444;color:#fff}
.app-toast-info .app-toast-icon{background:#3B82F6;color:#fff}
.search-results-modal{
  position:fixed;inset:0;z-index:9998;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .25s ease;
}
.search-results-modal.show{opacity:1;visibility:visible;pointer-events:auto}
.search-results-backdrop{
  position:absolute;inset:0;background:rgba(0,0,0,0.6);backdrop-filter:blur(6px);
}
.search-results-panel{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-46%);
  width:min(720px,92vw);max-height:80vh;
  background:linear-gradient(180deg,rgba(15,23,42,0.98),rgba(15,23,42,0.96));
  border:1px solid rgba(99,102,241,0.3);border-radius:16px;
  box-shadow:0 20px 60px rgba(0,0,0,0.5);
  display:flex;flex-direction:column;overflow:hidden;
  transition:transform .3s cubic-bezier(.34,1.56,.64,1);
}
.search-results-modal.show .search-results-panel{transform:translate(-50%,-50%)}
.search-results-header{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:18px 20px 12px;border-bottom:1px solid var(--border);
}
.search-results-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:var(--text)}
.search-results-keyword{
  color:#FCD34D;background:linear-gradient(120deg,rgba(245,158,11,0.25),rgba(251,146,60,0.15));
  padding:2px 8px;border-radius:6px;font-weight:600;
}
.search-results-close{
  width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--text3);transition:all .15s;
}
.search-results-close:hover{background:var(--bg-hover-strong);color:var(--text)}
.search-results-meta{
  padding:8px 20px 12px;font-size:12px;color:var(--text3);
  border-bottom:1px solid var(--border);
}
.search-results-list{flex:1;overflow-y:auto;padding:8px 0}
.search-result-item{
  display:flex;align-items:center;gap:14px;
  padding:12px 20px;cursor:pointer;
  transition:all .15s;border-bottom:1px solid var(--border);
}
.search-result-item:last-child{border-bottom:none}
.search-result-item:hover{background:var(--bg-primary-soft)}
.search-result-thumb{
  width:64px;height:48px;border-radius:8px;overflow:hidden;flex-shrink:0;
  background:linear-gradient(135deg,#1e293b,#0f172a);
}
.search-result-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.search-result-thumb-placeholder{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  color:var(--text3);font-size:11px;
}
.search-result-info{flex:1;min-width:0}
.search-result-title{
  font-size:14px;font-weight:600;color:var(--text);
  margin-bottom:4px;line-height:1.4;
  display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;
}
.search-result-desc{
  font-size:12px;color:var(--text2);line-height:1.5;margin-bottom:6px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.search-result-meta{display:flex;align-items:center;gap:10px;font-size:11px;color:var(--text3)}
.search-result-tag{
  background:rgba(6,182,212,0.15);color:#06D6D4;
  padding:2px 8px;border-radius:4px;font-weight:500;
}
.search-result-rating{color:#FBBF24}
.search-result-uses{color:var(--text3)}
.search-result-arrow{color:var(--text3);flex-shrink:0;transition:transform .15s}
.search-result-item:hover .search-result-arrow{transform:translateX(4px);color:var(--primary)}
.search-results-more{
  padding:16px 20px;text-align:center;font-size:12px;color:var(--text3);
  border-top:1px solid var(--border);
}
.user-dropdown{
  position:fixed;z-index:9997;width:280px;
  background:linear-gradient(180deg,rgba(15,23,42,0.98),rgba(15,23,42,0.96));
  border:1px solid rgba(99,102,241,0.3);border-radius:14px;
  box-shadow:0 16px 48px rgba(0,0,0,0.5);
  backdrop-filter:blur(16px);
  opacity:0;visibility:hidden;transform:translateY(-8px) scale(0.96);
  transition:all .22s cubic-bezier(.34,1.56,.64,1);
  overflow:hidden;
}
.user-dropdown.show{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.user-dropdown-head{display:flex;align-items:center;gap:12px;padding:16px 18px 14px}
.user-dropdown-avatar{
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,var(--primary),var(--mint));
  color:#fff;font-size:16px;font-weight:700;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.user-dropdown-info{flex:1;min-width:0}
.user-dropdown-name{font-size:14px;font-weight:600;color:var(--text);line-height:1.4}
.user-dropdown-email{font-size:11px;color:var(--text3);margin-top:2px;line-height:1.4}
.user-dropdown-stats{
  display:flex;align-items:stretch;gap:1px;
  background:var(--border);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  margin:0;
}
.user-dropdown-stat{
  flex:1;padding:10px 8px;background:rgba(15,23,42,0.6);
  text-align:center;display:flex;flex-direction:column;gap:2px;
}
.user-dropdown-stat b{font-size:16px;font-weight:700;color:var(--text);line-height:1}
.user-dropdown-stat span{font-size:11px;color:var(--text3);line-height:1}
.user-dropdown-menu{padding:6px 0}
.user-dropdown-item{
  display:flex;align-items:center;gap:10px;width:100%;
  padding:9px 18px;font-size:13px;color:var(--text2);
  background:none;border:none;cursor:pointer;text-align:left;
  transition:all .12s;font-family:var(--font);
}
.user-dropdown-item:hover{background:var(--bg-hover);color:var(--text)}
.user-dropdown-item svg{flex-shrink:0;color:var(--text3)}
.user-dropdown-item:hover svg{color:var(--primary)}
.user-dropdown-item-danger{color:var(--danger)}
.user-dropdown-item-danger svg{color:var(--danger)}
.user-dropdown-item-danger:hover{background:rgba(220,38,38,0.08)}
.user-dropdown-item-danger:hover svg{color:var(--danger)}
.user-dropdown-divider{height:1px;background:var(--border);margin:6px 0}
.zoom-indicator{
  position:fixed;bottom:20px;right:20px;z-index:9996;
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;
  background:linear-gradient(135deg,rgba(15,23,42,0.95),rgba(15,23,42,0.9));
  border:1px solid rgba(99,102,241,0.4);border-radius:999px;
  color:#fff;font-size:12px;font-weight:500;
  box-shadow:0 6px 20px rgba(0,0,0,0.3);
  backdrop-filter:blur(12px);
  cursor:pointer;user-select:none;
  opacity:0;visibility:hidden;
  transform:translateY(8px) scale(calc(0.96 * var(--zoom-inv, 1)));
  transform-origin:bottom right;
  transition:all .25s cubic-bezier(.34,1.56,.64,1);
}
.zoom-indicator.show{opacity:1;visibility:visible;transform:translateY(0) scale(var(--zoom-inv, 1))}
.zoom-indicator:hover{background:linear-gradient(135deg,rgba(59,130,246,0.3),rgba(99,102,241,0.35));border-color:rgba(99,102,241,0.7)}
.zoom-indicator-pct{
  font-weight:700;color:#FCD34D;
  min-width:38px;text-align:center;
  font-variant-numeric:tabular-nums;
}
.zoom-indicator-hint{color:var(--text3);font-size:11px;font-weight:400}
.zoom-indicator svg{color:var(--primary-light);flex-shrink:0}
@media(max-width:768px){.zoom-indicator-hint{display:none}.zoom-indicator{padding:8px 12px}}
.site-footer{
  margin-top:60px;
  background:linear-gradient(180deg,transparent,var(--bg-soft));
  border-top:1px solid var(--border);
  padding:48px 40px 24px;
  color:var(--text2);
}
.site-footer-inner{
  max-width:1680px;margin:0 auto;
  display:grid;grid-template-columns:1.4fr 1fr 1.4fr 1fr;gap:48px;
  padding-bottom:32px;
}
.site-footer-brand{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:700;color:var(--text);margin-bottom:12px}
.site-footer-tagline{font-size:13px;color:var(--text3);line-height:1.7}
.site-footer-h4{font-size:13px;font-weight:600;color:var(--text);margin:0 0 16px;letter-spacing:0.3px}
.site-footer-col a,.site-footer-col .site-footer-shortcuts li{
  display:flex;align-items:center;gap:8px;
  font-size:13px;color:var(--text2);line-height:2;
  transition:color .12s;
}
.site-footer-col a{cursor:pointer}
.site-footer-col a:hover{color:var(--primary-light)}
.site-footer-shortcuts{list-style:none;padding:0;margin:0}
.site-footer-shortcuts li kbd{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:22px;height:20px;padding:0 6px;
  background:var(--bg-hover-strong);border:1px solid var(--border);
  border-radius:4px;font-size:10px;font-weight:600;color:var(--text);
  font-family:var(--font);
}
.site-footer-help-btn{
  display:inline-flex;align-items:center;gap:6px;
  margin-top:14px;padding:7px 14px;
  background:linear-gradient(135deg,var(--primary),#60A5FA);
  color:#fff;font-size:12px;font-weight:600;
  border:none;border-radius:8px;cursor:pointer;
  transition:all .15s;font-family:var(--font);
}
.site-footer-help-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(99,102,241,0.35)}
.site-footer-bottom{
  max-width:1680px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding-top:24px;border-top:1px solid var(--border);
  font-size:12px;color:var(--text3);
}
.site-footer-version{font-variant-numeric:tabular-nums}
@media(max-width:1024px){
  .site-footer-inner{grid-template-columns:1fr 1fr;gap:32px}
  .site-footer-brand-col{grid-column:span 2}
}
@media(max-width:640px){
  .site-footer{padding:32px 20px 20px;margin-top:40px}
  .site-footer-inner{grid-template-columns:1fr;gap:24px}
  .site-footer-brand-col{grid-column:span 1}
  .site-footer-bottom{flex-direction:column;gap:8px;align-items:flex-start}
}
.help-center-modal{
  position:fixed;inset:0;z-index:9998;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .25s ease;
}
.help-center-modal.show{opacity:1;visibility:visible;pointer-events:auto}
.help-center-backdrop{position:absolute;inset:0;background:rgba(0,0,0,0.65);backdrop-filter:blur(6px)}
.help-center-panel{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-46%);
  width:min(820px,94vw);max-height:84vh;
  background:linear-gradient(180deg,rgba(15,23,42,0.98),rgba(15,23,42,0.96));
  border:1px solid rgba(99,102,241,0.3);border-radius:16px;
  box-shadow:0 20px 60px rgba(0,0,0,0.5);
  display:flex;flex-direction:column;overflow:hidden;
  transition:transform .3s cubic-bezier(.34,1.56,.64,1);
}
.help-center-modal.show .help-center-panel{transform:translate(-50%,-50%)}
.help-center-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 22px 14px;border-bottom:1px solid var(--border);
}
.help-center-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:var(--text)}
.help-center-close{
  width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--text3);transition:all .15s;background:none;border:none;cursor:pointer;
}
.help-center-close:hover{background:var(--bg-hover-strong);color:var(--text)}
.help-center-tabs{
  display:flex;gap:4px;
  padding:10px 22px 0;
  border-bottom:1px solid var(--border);
  overflow-x:auto;
}
.help-center-tab{
  background:none;border:none;cursor:pointer;
  padding:10px 16px;font-size:13px;color:var(--text3);
  font-weight:500;font-family:var(--font);
  border-bottom:2px solid transparent;
  transition:all .12s;white-space:nowrap;
}
.help-center-tab:hover{color:var(--text2)}
.help-center-tab.act{color:var(--primary-light);border-bottom-color:var(--primary)}
.help-center-body{padding:20px 22px 24px;overflow-y:auto;flex:1}
.help-feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}
.help-feature{
  display:flex;align-items:center;gap:12px;
  padding:14px;border:1px solid var(--border);border-radius:12px;
  background:var(--bg-hover);cursor:pointer;
  transition:all .15s;
}
.help-feature:hover{background:var(--bg-primary-soft);border-color:rgba(99,102,241,0.4);transform:translateY(-2px)}
.help-feature-icon{
  width:40px;height:40px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-size:20px;flex-shrink:0;
}
.help-feature-info h4{font-size:13px;font-weight:600;color:var(--text);margin:0 0 3px;line-height:1.3}
.help-feature-info p{font-size:11px;color:var(--text3);margin:0;line-height:1.5}
.help-tip{
  padding:16px 18px;background:linear-gradient(135deg,rgba(99,102,241,0.1),rgba(6,182,212,0.05));
  border:1px solid rgba(99,102,241,0.25);border-radius:12px;
}
.help-tip h4{margin:0 0 10px;font-size:14px;font-weight:600;color:var(--text)}
.help-tip ol{margin:0;padding-left:20px;font-size:13px;color:var(--text2);line-height:2}
.help-tip ol li kbd{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:20px;height:18px;padding:0 5px;
  background:var(--bg-hover-strong);border:1px solid var(--border-h);
  border-radius:3px;font-size:10px;font-weight:600;color:var(--text);
  font-family:var(--font);margin:0 2px;
}
.help-shortcut-section{margin-bottom:20px}
.help-shortcut-section:last-child{margin-bottom:0}
.help-shortcut-title{
  font-size:13px;font-weight:600;color:var(--primary-light);
  margin:0 0 10px;padding-bottom:8px;border-bottom:1px solid var(--border);
}
.help-shortcut-list{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}
.help-shortcut-row{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:9px 14px;background:rgba(255,255,255,0.025);
  border:1px solid var(--border);border-radius:8px;
  font-size:12px;
}
.help-shortcut-keys{display:flex;align-items:center;gap:4px;flex-shrink:0}
.help-shortcut-keys kbd{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:22px;height:20px;padding:0 6px;
  background:linear-gradient(180deg,rgba(15,23,42,0.06),rgba(15,23,42,0.02));
  border:1px solid var(--border-h);border-bottom-color:rgba(0,0,0,0.3);
  border-radius:4px;font-size:10px;font-weight:600;color:var(--text);
  font-family:var(--font);box-shadow:0 1px 0 rgba(0,0,0,0.2);
}
.help-plus{color:var(--text3);font-size:10px;margin:0 1px}
.help-shortcut-desc{color:var(--text2);font-size:12px;flex:1;min-width:0;line-height:1.4}
.help-changelog{display:flex;flex-direction:column;gap:20px}
.help-cl-item{
  position:relative;padding-left:18px;
  border-left:2px solid var(--border);
}
.help-cl-date{font-size:11px;color:var(--text3);font-variant-numeric:tabular-nums;margin-bottom:2px}
.help-cl-version{font-size:15px;font-weight:600;color:var(--text);margin-bottom:10px}
.help-cl-list{margin:0;padding-left:18px;font-size:13px;color:var(--text2);line-height:1.9;list-style:none}
.help-cl-list li{position:relative;padding-left:4px}
.help-cl-item{border-left-color:rgba(99,102,241,0.4)}
.help-about-hero{text-align:center;margin-bottom:20px}
.help-about-logo{width:64px;height:64px;border-radius:16px;margin-bottom:10px;box-shadow:0 4px 16px rgba(99,102,241,0.3)}
.help-about-tagline{font-size:13px;color:var(--text3);margin:6px 0 0}
.help-about-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:8px;
  margin-bottom:20px;
}
.help-about-stat{
  text-align:center;padding:12px 8px;
  background:var(--bg-hover);border:1px solid var(--border);
  border-radius:10px;
}
.help-about-stat b{display:block;font-size:18px;font-weight:700;color:var(--text);line-height:1.1}
.help-about-stat span{font-size:11px;color:var(--text3);margin-top:4px;display:block}
.help-about-mission,.help-about-contact{
  padding:14px 16px;margin-bottom:12px;
  background:rgba(99,102,241,0.05);border:1px solid rgba(99,102,241,0.2);
  border-radius:10px;
}
.help-about-mission h4,.help-about-contact h4{
  margin:0 0 8px;font-size:13px;font-weight:600;color:var(--text);
}
.help-about-mission p,.help-about-contact p{margin:0;font-size:12px;color:var(--text2);line-height:1.7}
.help-about-contact a{color:var(--primary-light);text-decoration:none}
.help-about-contact a:hover{text-decoration:underline}
@media(max-width:640px){
  .help-feature-grid{grid-template-columns:1fr 1fr}
  .help-shortcut-list{grid-template-columns:1fr}
  .help-about-stats{grid-template-columns:1fr 1fr}
}
::-webkit-scrollbar-thumb:hover{background:rgba(59,130,246,0.4)}
a{color:var(--primary);text-decoration:none;transition:color .15s}
a:hover{color:var(--primary-h)}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
img{max-width:100%;display:block}
.skip-link{position:absolute;top:-40px;left:0;background:var(--primary);color:#fff;padding:8px 16px;z-index:10000;font-size:14px;border-radius:0 0 4px 0}
.skip-link:focus{top:0}
#app-loader{position:fixed;inset:0;background:var(--bg);z-index:99999;display:flex;align-items:center;justify-content:center;transition:opacity .3s}
#app-loader.hidden{opacity:0;pointer-events:none}
.loader{width:28px;height:28px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

.topnav{position:fixed;top:0;left:0;right:0;height:56px;background:var(--bg-nav);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);z-index:1000;display:flex;align-items:center;padding:0 24px;gap:8px;transition:background .25s ease,border-color .25s ease}.topnav-inner{display:flex;align-items:center;max-width:1280px;margin:0 auto;width:100%;padding:0 24px}
.topnav-brand{display:flex;align-items:center;gap:8px;margin-right:24px;flex-shrink:0}
.topnav-brand svg,.topnav-brand img{width:24px;height:24px;flex-shrink:0}
.topnav-brand span{font-size:15px;font-weight:700;color:var(--text);letter-spacing:-0.3px}
.topnav-links{display:flex;gap:2px;flex:1}
.topnav-link{padding:8px 14px;border-radius:var(--r);font-size:13px;font-weight:500;color:var(--text3);transition:all .15s;white-space:nowrap}
.topnav-link:hover{color:var(--text2);background:var(--bg-hover)}
.topnav-link.act{color:var(--text);background:var(--primary);font-weight:600}
.topnav-right{display:flex;align-items:center;gap:8px;margin-left:auto;flex-shrink:0}
.topnav-search{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--glass);border:1px solid var(--border);border-radius:var(--r);width:200px;transition:border-color .15s}
.topnav-search:focus-within{border-color:var(--border-h)}
.topnav-search svg{flex-shrink:0;color:var(--text3);width:14px;height:14px}
.topnav-search input{border:none;background:none;flex:1;font-size:12px;color:var(--text);outline:none;width:100%}
.topnav-search input::placeholder{color:var(--text3)}
.topnav-search-kbd{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:18px;height:18px;padding:0 5px;
  background:var(--bg-hover-strong);border:1px solid var(--border);
  border-radius:4px;font-size:10px;font-weight:500;color:var(--text3);
  font-family:var(--font);
  transition:all .15s;flex-shrink:0;
}
.topnav-search:focus-within .topnav-search-kbd{opacity:0.5}
.tpl-search-highlight{background:linear-gradient(120deg,rgba(245,158,11,0.35),rgba(251,146,60,0.25));color:#FCD34D;font-weight:600;padding:0 2px;border-radius:2px}
.topnav-pricing{
  padding:6px 14px;
  background:linear-gradient(135deg,#F59E0B,#FB923C);
  color:#fff;font-size:12px;font-weight:600;
  border-radius:999px;
  cursor:pointer;
  box-shadow:0 2px 8px rgba(245,158,11,0.3);
  transition:all .18s ease;
  white-space:nowrap;
  letter-spacing:0.3px;
}
.topnav-pricing:hover{
  background:linear-gradient(135deg,#FB923C,#F59E0B);
  transform:translateY(-1px);
  box-shadow:0 4px 14px rgba(245,158,11,0.45);
}
.topnav-pricing:active{transform:translateY(0)}
.topnav-pricing.act{
  background:linear-gradient(135deg,#fff,#FEF3C7);
  color:#B45309;
  box-shadow:0 2px 8px rgba(0,0,0,0.2),0 0 0 2px rgba(245,158,11,0.6);
}
@media(max-width:768px){.topnav-pricing{display:none}}
.topnav-btn{padding:6px 14px;border-radius:var(--r);font-size:12px;font-weight:500;transition:all .15s}
.topnav-btn-ghost{color:var(--text3);border:1px solid var(--border)}
.topnav-btn-ghost:hover{color:var(--text);border-color:var(--border-h)}
.topnav-btn-primary{background:var(--primary);color:#fff}
.topnav-btn-primary:hover{background:var(--primary-h)}
.topnav-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--mint));color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;cursor:pointer}
.topnav-icon-btn{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text3);transition:all .15s}
.topnav-icon-btn:hover{color:var(--text);background:var(--bg-hover-strong)}
.topnav-mobile-toggle{display:none;width:32px;height:32px;border-radius:var(--r);align-items:center;justify-content:center;color:var(--text3);border:1px solid var(--border)}

/* === Theme toggle button (深色 / 日常 切换) === */
.theme-toggle{
  width:34px;height:34px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--text3);background:transparent;border:1px solid transparent;
  cursor:pointer;position:relative;overflow:hidden;
  transition:all .25s cubic-bezier(.4,0,.2,1);
  flex-shrink:0;
}
.theme-toggle:hover{color:var(--text);background:var(--bg-soft);border-color:var(--border);transform:rotate(15deg)}
.theme-toggle:active{transform:scale(0.92) rotate(0)}
.theme-toggle svg{width:16px;height:16px;transition:all .35s cubic-bezier(.4,0,.2,1)}
.theme-toggle .icon-sun{position:absolute;opacity:0;transform:scale(0.5) rotate(-90deg)}
.theme-toggle .icon-moon{position:absolute;opacity:1;transform:scale(1) rotate(0)}
html.dark .theme-toggle .icon-moon,
html[data-theme="dark"] .theme-toggle .icon-moon{opacity:0;transform:scale(0.5) rotate(90deg)}
html.dark .theme-toggle .icon-sun,
html[data-theme="dark"] .theme-toggle .icon-sun{opacity:1;transform:scale(1) rotate(0)}
.theme-toggle .ring{position:absolute;inset:0;border-radius:50%;border:1px solid var(--border-h);opacity:0;transform:scale(0.6);transition:all .4s ease;pointer-events:none}
.theme-toggle.switching .ring{opacity:1;transform:scale(1.2);transition:all .55s ease-out}
.theme-toggle.switching{pointer-events:none}
@media(max-width:768px){.theme-toggle{width:32px;height:32px}}

.main-content{margin-top:56px;min-height:calc(100vh - 56px);position:relative;z-index:5}
.page{display:none;opacity:0;transform:translateY(6px);transition:opacity .2s ease,transform .2s ease;background:transparent}
.page.active{display:block;opacity:1;transform:translateY(0)}
.page.no-animation,.page.no-animation.active{transition:none;opacity:1;transform:translateY(0)}
@media(prefers-reduced-motion:reduce){.page,.page.active{transition:none!important;opacity:1!important;transform:none!important}}

.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--r);font-size:14px;font-weight:500;transition:all .15s ease}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-h)}
.btn-ghost{color:var(--text2);border:1px solid var(--border);background:transparent}
.btn-ghost:hover{border-color:var(--border-h);color:var(--text)}
.btn-sm{padding:6px 14px;font-size:12px}

.card{background:var(--card);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--r2);transition:border-color .2s ease}
.card:hover{border-color:var(--border-h);transform:translateY(-1px)}

.hp-hero{position:relative;overflow:hidden;min-height:calc(100vh - 56px);display:flex;flex-direction:column;align-items:center;justify-content:center}
.global-particles{position:fixed;inset:0;z-index:3;pointer-events:none;background:transparent;isolation:isolate}
.global-slideshow{position:fixed;inset:0;z-index:0;pointer-events:none}
.gs-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transform:scale(1.08);transition:opacity 3s cubic-bezier(.4,0,.2,1),transform 15s ease-out;pointer-events:none}
.gs-slide.active{opacity:1;transform:scale(1);pointer-events:none;z-index:1}
.gs-overlay{position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(2,6,23,0.7) 0%,rgba(2,6,23,0.45) 35%,rgba(2,6,23,0.75) 100%);pointer-events:none}
.hp-hero-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;min-height:calc(100vh - 56px);position:relative;z-index:1;padding:0}
.hp-hero-left{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;text-align:center;padding:60px 48px 0}
.hp-hero-title{font-family:var(--font);font-size:48px;font-weight:800;line-height:1.2;margin-bottom:16px;color:var(--text);letter-spacing:-0.5px;text-shadow:0 1px 2px rgba(15,23,42,0.04)}
.hp-hero-title img{display:inline-block;vertical-align:middle}
.hp-hero-greeting-wrap{display:flex;flex-direction:column;align-items:center;margin-bottom:28px;position:relative}
.hp-hero-greeting-rule{width:36px;height:2px;background:linear-gradient(90deg,transparent,#d4af7a 50%,transparent);margin-bottom:24px;box-shadow:0 0 12px rgba(212,175,122,0.4)}
.hp-hero-greeting{font-family:var(--font-serif);font-size:64px;font-weight:900;line-height:1.05;margin:0 0 18px;letter-spacing:4px;color:#fff;position:relative;text-shadow:0 2px 24px rgba(0,0,0,0.45),0 1px 0 rgba(255,255,255,0.15)}
.hp-hero-greeting-hi{font-weight:500;color:#f0f0f0;letter-spacing:8px}
.hp-hero-greeting-sep{display:inline-block;margin:0 12px;color:#d4af7a;font-size:48px;vertical-align:middle;font-weight:300;opacity:0.7;transform:translateY(-6px);text-shadow:0 0 20px rgba(212,175,122,0.4)}
.hp-hero-greeting-role{background:linear-gradient(180deg,#ffffff 0%,#fef3c7 50%,#d4af7a 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;letter-spacing:6px;font-weight:900;text-shadow:none}
.hp-hero-greeting-tag{font-family:'Inter','Times New Roman',serif;font-size:10px;font-weight:400;letter-spacing:5px;color:rgba(212,175,122,0.6);text-transform:uppercase;font-style:italic;margin-top:8px;position:relative;padding:0 24px}
.hp-hero-greeting-tag::before,.hp-hero-greeting-tag::after{content:'';position:absolute;top:50%;width:14px;height:1px;background:rgba(212,175,122,0.3)}
.hp-hero-greeting-tag::before{left:0}
.hp-hero-greeting-tag::after{right:0}
.hp-hero-greeting-en{font-family:'Inter','Helvetica Neue',sans-serif;font-size:11px;font-weight:400;letter-spacing:6px;color:rgba(255,255,255,0.35);text-transform:uppercase;margin-top:18px;margin-bottom:24px;display:block}
.hp-hero-subtitle{font-size:17px;color:rgba(248,250,252,0.6);margin-bottom:12px;font-weight:300;line-height:1.6}
.hp-hero-slogan{font-size:13px;color:var(--mint);font-weight:500;letter-spacing:2px;margin-bottom:32px}
.hp-hero-actions{display:flex;gap:12px;justify-content:center}
.btn-outline{padding:10px 20px;border-radius:var(--r);font-size:14px;font-weight:500;color:var(--primary);border:1px solid var(--primary);background:transparent;transition:all .15s ease}
.btn-outline:hover{background:var(--primary);color:#fff}
.hp-hero-bottom{width:100%;max-width:600px;padding:0 48px 16px;position:relative;z-index:1}
.hp-bottom-line{height:1px;background:var(--bg-hover-strong);margin-bottom:20px}
.hp-bottom-stats{display:flex;align-items:center;gap:16px;justify-content:center}
.hp-bs{font-size:14px;color:var(--text);font-weight:400}
.hp-bs-dot{width:4px;height:4px;border-radius:50%;background:var(--text);opacity:0.4}
.gs-dots{display:flex;gap:12px;justify-content:center;padding-bottom:32px;z-index:100;pointer-events:auto;position:relative}
.gs-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,0.2);cursor:pointer;transition:all .4s cubic-bezier(.4,0,.2,1);border:1px solid var(--border)}
.gs-dot.active{background:var(--mint);box-shadow:0 0 12px rgba(6,214,212,0.6);transform:scale(1.4);border-color:transparent}
.gs-dot.active:hover{background:var(--mint);transform:scale(1.4)}
.gs-dot:hover{background:rgba(255,255,255,0.45);transform:scale(1.15)}

.hp-section{padding:60px 48px;max-width:1280px;margin:0 auto;width:100%}
.hp-section-header{margin-bottom:32px}
.hp-section-title{font-size:22px;font-weight:700;color:var(--text);margin-bottom:6px}
.hp-section-desc{font-size:14px;color:var(--text3)}

.bento-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:175px;gap:16px}
.bento-card{position:relative;border-radius:var(--r2);overflow:hidden;cursor:pointer;background:var(--card);backdrop-filter:blur(12px);border:1px solid var(--border);transition:border-color .2s ease;padding:20px 20px 48px}
.bento-card:hover{border-color:var(--border-h)}
.b-lg{grid-column:span 2;grid-row:span 2}
.b-w2{grid-column:span 2}
.bento-card-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.bento-card-icon svg{width:20px;height:20px}
.bento-card-title{font-size:15px;font-weight:600;color:var(--text);margin-bottom:6px}
.bento-card-desc{font-size:12px;color:var(--text3);margin-bottom:4px}
.bento-card-count{position:absolute;bottom:20px;left:20px;font-size:11px;color:var(--purple);font-weight:500;z-index:1}

.hp-feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.hp-feat-card{background:var(--card);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--r2);padding:20px;cursor:pointer;transition:border-color .2s ease}
.hp-feat-card:hover{border-color:var(--border-h)}
.hp-feat-tag{display:inline-block;padding:3px 8px;border-radius:4px;font-size:11px;font-weight:500;background:var(--bg-primary-soft);color:var(--primary);margin-bottom:12px}
.hp-feat-title{font-family:var(--font);font-size:16px;font-weight:700;color:var(--text);margin-bottom:6px;letter-spacing:-0.2px;line-height:1.4}
.hp-feat-desc{font-size:12px;color:var(--text3);font-family:monospace;margin-bottom:14px}
.hp-feat-footer{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--text3)}
.hp-feat-model{padding:2px 6px;border-radius:4px;font-size:10px;font-weight:500;background:rgba(168,85,247,0.10);color:var(--purple)}

.hp-learn-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.hp-learn-card{background:var(--card);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--r2);padding:20px;cursor:pointer;transition:border-color .2s ease}
.hp-learn-card:hover{border-color:var(--border-h)}
.hp-learn-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.hp-learn-icon svg{width:18px;height:18px}
.hp-learn-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}
.hp-learn-desc{font-size:12px;color:var(--text3);margin-bottom:12px}
.hp-learn-meta{display:flex;gap:12px;font-size:11px;color:var(--text3)}

.hp-wf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.hp-wf-card{background:var(--card);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--r2);padding:20px;cursor:pointer;transition:border-color .2s ease;display:flex;align-items:center;gap:14px}
.hp-wf-card:hover{border-color:var(--border-h)}
.hp-wf-icon{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.hp-wf-icon svg{width:18px;height:18px}
.hp-wf-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:2px}
.hp-wf-desc{font-size:12px;color:var(--text3)}
.hp-wf-count{font-size:11px;color:var(--purple);font-weight:500;flex-shrink:0}

.hp-community-banner{background:var(--card);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--r2);padding:32px;display:flex;align-items:center;justify-content:space-between}
.hp-cm-stats{display:flex;gap:40px}
.hp-cm-item{text-align:center}
.hp-cm-num{font-size:22px;font-weight:700;color:var(--text)}
.hp-cm-label{font-size:12px;color:var(--text3)}

.hp-price-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;max-width:640px}
.hp-price-card{background:var(--card);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--r2);padding:24px;text-align:center;transition:border-color .2s ease}
.hp-price-card:hover{border-color:var(--border-h)}
.hp-price-card.feat{border-color:rgba(59,130,246,0.3);position:relative}
.hp-price-badge{position:absolute;top:-10px;left:50%;transform:translateX(-50%);padding:3px 12px;background:linear-gradient(135deg,var(--primary),var(--mint));color:#fff;border-radius:10px;font-size:11px;font-weight:600}
.hp-price-label{font-size:13px;color:var(--text3);margin-bottom:8px}
.hp-price-amount{font-size:32px;font-weight:700;color:var(--text);margin-bottom:16px}
.hp-price-amount span{font-size:13px;font-weight:400;color:var(--text3)}
.hp-price-features{list-style:none;text-align:left;margin-bottom:20px}
.hp-price-features li{font-size:12px;color:var(--text2);padding:5px 0;display:flex;align-items:center;gap:8px}
.hp-price-features li::before{content:'';width:14px;height:14px;border-radius:50%;background:rgba(59,130,246,0.15);display:flex;align-items:center;justify-content:center;flex-shrink:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%233B82F6' stroke-width='3'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:10px}

.lib-layout{display:flex;min-height:calc(100vh - 56px)}
.lib-sidebar{width:200px;background:var(--bg);border-right:1px solid var(--border);padding:16px 0;display:flex;flex-direction:column;flex-shrink:0}
.lib-sb-brand{display:flex;align-items:center;gap:8px;padding:0 16px 16px;border-bottom:1px solid var(--border);margin-bottom:8px}
.lib-sb-brand span{font-size:13px;font-weight:700;color:var(--text)}
.lib-sb-nav{flex:1}
.lib-sb-item{display:flex;align-items:center;gap:10px;padding:8px 16px;font-size:12px;color:var(--text3);width:100%;text-align:left;transition:all .15s}
.lib-sb-item:hover{background:var(--bg-hover);color:var(--text2)}
.lib-sb-item.act{background:var(--primary);color:#fff;font-weight:500}
.lib-sb-item svg{width:16px;height:16px;flex-shrink:0}
.lib-sb-upgrade{margin:12px 16px;padding:10px 14px;background:rgba(245,158,11,0.08);border:1px solid rgba(245,158,11,0.15);border-radius:var(--r);display:flex;align-items:center;gap:8px;font-size:12px;font-weight:500;color:var(--gold);cursor:pointer;transition:border-color .15s}
.lib-sb-upgrade:hover{border-color:rgba(245,158,11,0.3)}
.lib-main{flex:1;padding:32px 40px;overflow-y:auto}
.lib-page{padding:32px 40px;max-width:1280px;margin:0 auto;width:100%}
.lib-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}
.lib-header-left{display:flex;flex-direction:column;gap:4px}
.lib-title{font-size:20px;font-weight:700;color:var(--text)}
.lib-subtitle{font-size:13px;color:var(--text3)}
.lib-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.cs-rt-list{display:flex;flex-direction:column;gap:8px}
.lib-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.lib-toolbar .lib-search{display:flex;align-items:center;gap:6px;padding:7px 12px;background:var(--glass);border:1px solid var(--border);border-radius:var(--r);width:260px;transition:border-color .15s}
.lib-toolbar .lib-search:focus-within{border-color:var(--border-h)}
.lib-toolbar .lib-search input{border:none;background:none;flex:1;font-size:12px;color:var(--text);outline:none}
.lib-toolbar .lib-search input::placeholder{color:var(--text3)}
.lib-toolbar-right{display:flex;align-items:center;gap:8px}
.lib-view-btn{width:32px;height:32px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;color:var(--text3);border:1px solid var(--border);transition:all .15s}
.lib-view-btn:hover,.lib-view-btn.active{color:var(--primary);border-color:var(--primary)}
.lib-create-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--r);background:var(--primary);color:#fff;font-size:12px;font-weight:500}
.lib-create-btn:hover{background:var(--primary-h)}
.lib-notify-btn{width:32px;height:32px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;color:var(--text3);border:1px solid var(--border);transition:all .15s}
.lib-notify-btn:hover{color:var(--primary);border-color:var(--primary)}
.lib-tabs{display:flex;gap:4px;margin-bottom:24px;flex-wrap:wrap}
.lib-tab{padding:6px 16px;border-radius:16px;font-size:12px;font-weight:500;color:var(--text3);background:var(--glass);border:1px solid var(--border);transition:all .15s;cursor:pointer}
.lib-tab:hover{border-color:var(--border-h);color:var(--text2)}
.lib-tab.act{background:var(--primary);color:#fff;border-color:var(--primary)}
.lib-bento{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:160px;gap:16px;margin-bottom:36px}
.lib-bento-lg{grid-column:span 1;grid-row:span 2}
.lib-bento-card{position:relative;border-radius:var(--r2);overflow:hidden;cursor:pointer;background:var(--card);backdrop-filter:blur(12px);border:1px solid var(--border);transition:border-color .2s ease;padding:20px;display:flex;flex-direction:column;justify-content:flex-end}
.lib-bento-card:hover{border-color:var(--border-h)}
.lib-bento-card-featured{position:absolute;top:12px;left:12px;padding:3px 8px;border-radius:4px;font-size:10px;font-weight:600;background:rgba(6,214,212,0.15);color:var(--mint);letter-spacing:0.5px}
.lib-bento-card-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:4px}
.lib-bento-card-desc{font-size:12px;color:var(--text3);margin-bottom:10px}
.lib-bento-card-count{display:inline-block;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:500;background:rgba(139,92,246,0.12);color:var(--purple)}
.lib-bento-card.lib-bento-active{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary)}
.lib-text-prompts{border-top:1px solid var(--border);padding-top:28px}
.lib-tp-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.lib-tp-title{font-size:18px;font-weight:700;color:var(--text)}
.lib-tp-desc{font-size:12px;color:var(--text3);margin-top:2px}
.lib-tp-cats{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}
.lib-tp-cat{background:var(--card);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--r);padding:16px;cursor:pointer;transition:border-color .2s ease;text-align:center}
.lib-tp-cat:hover{border-color:var(--border-h)}
.lib-tp-cat-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin:0 auto 8px}
.lib-tp-cat-icon svg{width:16px;height:16px}
.lib-tp-cat-name{font-size:12px;font-weight:600;color:var(--text);margin-bottom:4px}
.lib-tp-cat-count{font-size:10px;color:var(--purple);font-weight:500}
.lib-sop-section{border-top:1px solid var(--border);padding-top:28px;margin-top:12px}
.lib-sop-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.vp-sop-section{margin-top:32px;border-top:1px solid var(--border);padding-top:32px}
.vp-sop-header{margin-bottom:20px}
.vp-sop-title{font-size:18px;font-weight:700;color:var(--text);margin-bottom:4px}
.vp-sop-desc{font-size:12px;color:var(--text3)}
.lib-sop-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.sop-card{background:var(--card);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--r2);transition:border-color .2s ease;overflow:hidden;cursor:pointer}
.sop-card:hover{border-color:var(--border-h)}
.sop-card-main{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 12px;text-align:center;cursor:pointer}
.sop-card-thumb{width:100%;height:60px;border-radius:6px;overflow:hidden;flex-shrink:0}
.sop-card-thumb img{width:100%;height:100%;object-fit:cover}
.sop-card-top{display:flex;align-items:center;gap:6px;justify-content:center;width:100%}
.sop-card-num{font-size:10px;color:var(--primary);font-weight:700;font-family:monospace}
.sop-card-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.sop-card-tags{display:flex;gap:6px}
.sop-tag-scene{padding:2px 8px;border-radius:4px;font-size:10px;font-weight:500;background:rgba(59,130,246,0.1);color:#60A5FA}
.sop-tag-diff{padding:2px 8px;border-radius:4px;font-size:10px;font-weight:500}
.sop-diff-easy{background:rgba(16,185,129,0.1);color:var(--success)}
.sop-diff-mid{background:rgba(245,158,11,0.1);color:var(--gold)}
.sop-diff-hard{background:rgba(239,68,68,0.1);color:var(--danger)}
.sop-card-arrow{flex-shrink:0;color:var(--text3);transition:transform .2s}
.sop-card.sop-open .sop-card-arrow{transform:rotate(180deg)}
.sop-card-expand{display:none;padding:0 10px 12px;border-top:1px solid var(--border)}
.sop-card.sop-open .sop-card-expand{display:block}
.sop-knowledge-box{margin-top:10px;padding:10px 12px;background:linear-gradient(135deg,rgba(59,130,246,0.06),rgba(139,92,246,0.04));border:1px solid rgba(59,130,246,0.15);border-radius:var(--r)}
.sop-knowledge-title{font-size:10px;font-weight:700;color:var(--primary);margin-bottom:5px;letter-spacing:.5px}
.sop-knowledge-text{font-size:11px;color:var(--text2);line-height:1.6}
.sop-howto-box{margin-top:8px;padding:10px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--r)}
.sop-howto-title{font-size:10px;font-weight:700;color:var(--success);margin-bottom:6px;letter-spacing:.5px}
.sop-howto-steps{display:flex;flex-direction:column;gap:4px}
.sop-step{display:flex;align-items:flex-start;gap:6px;font-size:11px;color:var(--text3);line-height:1.5}
.sop-step-dot{width:5px;height:5px;border-radius:50%;background:#10B981;margin-top:5px;flex-shrink:0}
.sop-structure-box{margin-top:8px;padding:10px 12px;background:linear-gradient(135deg,rgba(139,92,246,0.06),rgba(6,214,212,0.04));border:1px solid rgba(139,92,246,0.15);border-radius:var(--r)}
.sop-structure-title{font-size:10px;font-weight:700;color:var(--purple);margin-bottom:5px;letter-spacing:.5px}
.sop-structure-text{font-size:11px;color:var(--text2);font-family:'JetBrains Mono','Fira Code',monospace;line-height:1.6}
.sop-keywords-box{margin-top:8px;padding:8px 12px;background:rgba(245,158,11,0.04);border:1px solid rgba(245,158,11,0.12);border-radius:var(--r)}
.sop-keywords-title{font-size:10px;font-weight:700;color:var(--gold);margin-bottom:5px;letter-spacing:.5px}
.sop-keywords-tags{display:flex;flex-wrap:wrap;gap:5px}
.sop-keyword{padding:2px 8px;border-radius:3px;font-size:10px;font-weight:500;background:rgba(245,158,11,0.1);color:var(--gold)}
.sop-card-desc{font-size:11px;color:var(--text3);margin-top:2px;line-height:1.4}
.sop-actions{display:flex;gap:6px;margin-top:10px}
.sop-copy-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;border-radius:var(--r);background:var(--primary);color:#fff;font-size:11px;font-weight:500;transition:opacity .15s}
.sop-copy-btn:hover{opacity:0.9}

.tpl-page{padding:48px 40px;max-width:1680px;margin:0 auto;width:100%;background:var(--card);border-radius:16px;border:1px solid var(--border);box-shadow:var(--shadow)}
.tpl-page-header{text-align:center;margin-bottom:28px}
.tpl-vp-section{margin-bottom:32px}
.tpl-vp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.tpl-vp-grid .vp-card{padding:22px 18px}
.tpl-vp-grid .vp-card-icon{width:40px;height:40px;margin-bottom:12px}
.tpl-vp-grid .vp-card-title{font-size:15px;margin-bottom:6px}
.tpl-vp-grid .vp-card-desc{font-size:11px;line-height:1.6}
.tpl-vp-grid .vp-card-count{top:12px;right:12px;font-size:9px;padding:2px 8px}
@media(max-width:900px){.tpl-vp-grid{grid-template-columns:repeat(2,1fr)}}
.tpl-page-title{font-family:var(--font);font-size:32px;font-weight:800;color:var(--text);letter-spacing:-0.5px;line-height:1.2}
.tpl-page-line{width:48px;height:3px;background:linear-gradient(90deg,var(--primary),var(--mint));margin:14px auto 0;border-radius:2px}
.tpl-page-tags{display:flex;gap:10px;justify-content:center;margin-bottom:36px;flex-wrap:wrap}
.tpl-page-tag{display:flex;align-items:center;gap:6px;padding:8px 20px;border-radius:20px;font-size:13px;font-weight:500;background:var(--bg-soft);color:var(--text2);border:1px solid var(--border);transition:all .15s;cursor:pointer}
.tpl-page-tag:hover{border-color:var(--border-h);color:var(--text);background:var(--bg-hover)}
.tpl-page-tag.act{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 4px 12px rgba(79,70,229,0.25)}
.tpl-page-tag.act svg{stroke:#fff}
.tpl-page-tag svg{width:14px;height:14px;flex-shrink:0}
/* === 排序工具栏 === */
.tpl-sort-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 0 12px;gap:8px;flex-shrink:0}
.tpl-sort-left{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.tpl-sort-label{font-size:11px;color:var(--text3);font-weight:600;letter-spacing:.3px;margin-right:2px}
.tpl-sort-btn{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;border-radius:8px;font-size:11px;font-weight:500;color:var(--text3);background:var(--bg-hover);border:1px solid var(--border);transition:all .2s ease;cursor:pointer;white-space:nowrap}
.tpl-sort-btn svg{opacity:.5;transition:opacity .2s}
.tpl-sort-btn:hover{color:var(--text2);background:var(--bg-hover-strong);border-color:var(--border-h)}
.tpl-sort-btn:hover svg{opacity:.8}
.tpl-sort-btn.act{color:var(--mint);background:rgba(6,214,212,0.08);border-color:rgba(6,214,212,0.2);font-weight:600}
.tpl-sort-btn.act svg{opacity:1;color:var(--mint)}
.tpl-sort-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.tpl-sort-dir,.tpl-sort-reset{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text3);background:var(--bg-hover);border:1px solid var(--border);transition:all .2s;cursor:pointer}
.tpl-sort-dir:hover,.tpl-sort-reset:hover{color:var(--text2);background:var(--bg-hover-strong)}
.tpl-sort-dir svg{transition:transform .3s ease}
.tpl-sort-dir.asc svg{transform:rotate(180deg)}
.tpl-sort-count{font-size:11px;color:var(--text3);font-weight:500;white-space:nowrap}
.tpl-sort-hint{font-size:11px;color:var(--text3);padding:6px 12px;background:rgba(6,214,212,0.05);border:1px solid rgba(6,214,212,0.1);border-radius:8px;margin-bottom:8px;animation:tplHintFade .3s ease}
@keyframes tplHintFade{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.tpl-page-cards{display:flex;flex-wrap:wrap;gap:16px;overflow-x:visible;padding-bottom:12px;align-items:stretch}

/* === 搜索框 + 状态条 === */
.tpl-search-row{display:flex;align-items:center;gap:14px;margin:0 0 18px;flex-wrap:wrap}
.tpl-search-box{position:relative;flex:1;min-width:240px;max-width:480px;display:flex;align-items:center;background:var(--bg-soft);border:1px solid var(--border);border-radius:24px;padding:0 14px;height:38px;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}
.tpl-search-box:focus-within{border-color:rgba(6,214,212,0.4);box-shadow:0 0 0 3px rgba(6,214,212,0.08);background:var(--bg-elevated)}
.tpl-search-box .tpl-search-icon{color:var(--text3);flex-shrink:0;margin-right:8px;transition:color .2s}
.tpl-search-box:focus-within .tpl-search-icon{color:var(--mint)}
.tpl-search-box input{flex:1;background:transparent;border:none;outline:none;color:var(--text);font-size:13px;height:100%;min-width:0}
.tpl-search-box input::placeholder{color:var(--text3)}
.tpl-search-clear{background:var(--bg-hover-strong);border:none;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text3);cursor:pointer;transition:background .15s,color .15s;flex-shrink:0}
.tpl-search-clear:hover{background:rgba(255,255,255,0.12);color:var(--text)}
.tpl-stats-mini{display:flex;align-items:center;gap:14px;font-size:11px;color:var(--text3);padding:0 4px}
.tpl-stat-item{display:inline-flex;align-items:center;gap:5px;font-weight:500;white-space:nowrap}
.tpl-stat-dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.tpl-stat-dot-1{background:linear-gradient(135deg,#3b82f6,#06b6d4);box-shadow:0 0 8px rgba(59,130,246,0.5)}
.tpl-stat-dot-2{background:linear-gradient(135deg,#8b5cf6,#ec4899);box-shadow:0 0 8px rgba(139,92,246,0.5)}
.tpl-stat-dot-3{background:linear-gradient(135deg,#f59e0b,#ef4444);box-shadow:0 0 8px rgba(245,158,11,0.5)}

/* === 空状态 === */
.tpl-empty-state{padding:60px 20px;text-align:center;color:var(--text3);background:var(--bg-soft);border:1px dashed var(--border);border-radius:16px;animation:tplEmptyFade .35s ease}
@keyframes tplEmptyFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.tpl-empty-icon{font-size:48px;margin-bottom:16px;opacity:0.6;line-height:1}
.tpl-empty-title{font-size:16px;font-weight:600;color:var(--text);margin-bottom:8px;letter-spacing:0.3px}
.tpl-empty-desc{font-size:12px;color:var(--text3);margin-bottom:20px;line-height:1.6}
.tpl-empty-actions{display:inline-flex;gap:10px;flex-wrap:wrap;justify-content:center}
.tpl-empty-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:20px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;border:none}
.tpl-empty-btn-primary{background:linear-gradient(135deg,var(--primary),#7c3aed);color:#fff;box-shadow:0 4px 14px -4px rgba(124,58,237,0.5)}
.tpl-empty-btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 18px -4px rgba(124,58,237,0.65)}
.tpl-empty-btn-ghost{background:var(--bg-hover);color:var(--text2);border:1px solid var(--border)}
.tpl-empty-btn-ghost:hover{background:var(--bg-hover-strong);color:var(--text)}

@media(max-width:768px){
  .tpl-search-row{flex-direction:column;align-items:stretch}
  .tpl-search-box{max-width:100%}
  .tpl-stats-mini{justify-content:center}
}

.tpl-pc{flex:1 1 200px;min-width:200px;max-width:280px;background:var(--card);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--r2);overflow:hidden;cursor:pointer;transition:border-color .2s ease,transform .2s ease,opacity .3s ease;position:relative;display:flex;flex-direction:column}
.tpl-pc:hover{border-color:var(--border-h);transform:translateY(-4px)}
.tpl-pc.tpl-drag-item{cursor:grab}
.tpl-pc.tpl-drag-item:active{cursor:grabbing}
.tpl-pc.tpl-drag-item[draggable="true"] .tpl-pc-img::after{content:'⠿';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:24px;color:rgba(255,255,255,0.1);pointer-events:none}
.tpl-drag-handle{position:absolute;top:8px;right:8px;width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.4);backdrop-filter:blur(4px);color:var(--text3);z-index:3;pointer-events:auto}
.tpl-pc-hot{position:absolute;top:10px;left:10px;padding:3px 10px;border-radius:4px;font-size:10px;font-weight:700;background:var(--primary);color:#fff;letter-spacing:0.5px;z-index:2}
.tpl-pc-img{width:100%;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;flex-shrink:0;background:linear-gradient(135deg,rgba(124,58,237,0.08),rgba(59,130,246,0.04))}
.tpl-pc-img img{width:100%;height:100%;object-fit:cover;display:block}
.tpl-pc-img video.tpl-pc-video{width:100%;height:100%;object-fit:cover;background:#000;display:block}
.tpl-pc-img .tpl-pc-video-badge{position:absolute;top:8px;left:8px;display:flex;align-items:center;gap:3px;padding:3px 7px;border-radius:4px;font-size:10px;font-weight:600;background:rgba(0,0,0,0.65);color:#fff;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);letter-spacing:0.5px;pointer-events:none;z-index:2}
.tpl-pc-img-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:linear-gradient(135deg,rgba(255,255,255,0.02),rgba(255,255,255,0.05));color:var(--text3);border:1px dashed var(--border-h)}
.tpl-pc-img-placeholder svg{opacity:0.4}
.tpl-pc-img-placeholder span{font-size:11px;letter-spacing:.5px;opacity:0.5}

/* Sora运镜动态渐变缩略图 */
.tpl-pc-sora-thumb{position:relative;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;color:#fff;font-weight:600;letter-spacing:.5px;transition:transform .4s ease}
.tpl-pc:hover .tpl-pc-sora-thumb{transform:scale(1.05)}
.tpl-pc-sora-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(15,23,42,0.06) 1px,transparent 1px),linear-gradient(90deg,rgba(15,23,42,0.06) 1px,transparent 1px);background-size:24px 24px;pointer-events:none;opacity:.6}
.tpl-pc-sora-grid::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 0%,rgba(0,0,0,0.35) 100%);pointer-events:none}
.tpl-pc-sora-icon{font-size:48px;line-height:1;margin-bottom:10px;filter:drop-shadow(0 4px 8px rgba(0,0,0,0.4));position:relative;z-index:2;animation:tplSoraIconFloat 3s ease-in-out infinite}
.tpl-pc-sora-name{font-size:13px;font-weight:700;text-align:center;padding:0 12px;text-shadow:0 2px 6px rgba(0,0,0,0.5);position:relative;z-index:2;max-width:90%;line-height:1.3;word-break:break-word}
.tpl-pc-sora-badge{position:absolute;top:8px;left:8px;display:flex;align-items:center;gap:3px;padding:3px 7px;border-radius:4px;font-size:10px;font-weight:600;background:rgba(0,0,0,0.65);color:#fff;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);letter-spacing:0.5px;pointer-events:none;z-index:2}
@keyframes tplSoraIconFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.tpl-pc-body{padding:14px 16px 16px;display:flex;flex-direction:column;flex:1;min-height:0}
.tpl-pc-title{font-size:14px;font-weight:700;color:var(--text);margin-bottom:8px;line-height:1.4;min-height:40px;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.tpl-pc-meta{display:flex;align-items:center;gap:6px;margin-bottom:6px}
.tpl-pc-stars{display:flex;gap:1px;align-items:center}
.tpl-pc-stars svg{width:12px;height:12px;flex-shrink:0}
.tpl-pc-rating{font-size:12px;font-weight:600;color:var(--gold);line-height:1}
.tpl-pc-uses{font-size:11px;color:var(--text3);margin-left:auto;line-height:1}
.tpl-pc-keywords{font-size:11px;color:var(--text3);line-height:1.5;flex:1;min-height:0}
.tpl-fill-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;margin-top:12px;padding:8px 14px;border-radius:var(--r);background:var(--primary);color:#fff;font-size:12px;font-weight:500;line-height:1;transition:all .15s;width:100%;flex-shrink:0;height:32px;letter-spacing:.2px}
.tpl-fill-btn:hover{background:var(--primary-h)}
.tpl-fill-btn svg{width:13px;height:13px;flex-shrink:0;display:block}
.tpl-toast{position:fixed;bottom:32px;left:50%;transform:translateX(-50%) translateY(20px);padding:12px 28px;background:linear-gradient(135deg,#1E293B,#0F172A);border:1px solid rgba(6,214,212,0.3);border-radius:12px;color:#fff;font-size:13px;font-weight:500;z-index:9999;opacity:0;transition:all .3s ease;pointer-events:none;box-shadow:0 8px 32px rgba(0,0,0,0.4),0 0 20px rgba(6,214,212,0.1)}
.tpl-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
/* === 模板弹窗 - 商业级 === */
#tpl-modal .tpl-modal-card{max-width:960px;width:94vw;max-height:90vh;display:flex;flex-direction:column;background:var(--bg-modal);border:1px solid var(--border);border-radius:16px;overflow:hidden;position:relative;box-shadow:var(--shadow-lg);transition:background .3s ease,border-color .3s ease,box-shadow .3s ease}
#tpl-modal .tpl-modal-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(59,130,246,0.3),rgba(6,214,212,0.3),transparent)}
/* 关闭按钮：纳入 flex 流，避免与重置按钮重叠 */
.tpl-modal-close{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text3);transition:all .15s;background:var(--bg-hover);border:1px solid var(--border);flex-shrink:0;margin-left:4px}
.tpl-modal-close:hover{color:#fff;background:rgba(239,68,68,0.18);border-color:rgba(239,68,68,0.35);transform:rotate(90deg)}
.tpl-modal-close:active{transform:rotate(90deg) scale(0.92)}
/* 顶部栏：标题区 | 操作区 | 关闭按钮 */
.tpl-modal-topbar{display:flex;align-items:center;gap:10px;padding:18px 20px 14px;flex-shrink:0;border-bottom:1px solid var(--border)}
.tpl-modal-topbar-left{display:flex;align-items:center;gap:10px;min-width:0;flex:1;overflow:hidden}
.tpl-modal-title-wrap{min-width:0;overflow:hidden;flex:1}
.tpl-modal-badge{padding:4px 10px;border-radius:6px;font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;background:linear-gradient(135deg,rgba(59,130,246,0.15),rgba(6,214,212,0.1));color:var(--mint);border:1px solid rgba(6,214,212,0.2);white-space:nowrap;flex-shrink:0}
.tpl-modal-title{font-size:17px;font-weight:700;color:var(--text);letter-spacing:-.3px;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tpl-modal-desc{font-size:11px;color:var(--text3);margin:2px 0 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tpl-modal-topbar-actions{display:flex;gap:6px;flex-shrink:0}
.tpl-act-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;border-radius:8px;font-size:11px;font-weight:500;transition:all .15s;background:var(--bg-hover);border:1px solid var(--border);color:var(--text2)}
.tpl-act-btn:hover{background:var(--bg-hover-strong);border-color:var(--border-h);color:var(--text)}
.tpl-reset-btn{color:var(--text3)}
.tpl-reset-btn:hover{background:rgba(239,68,68,0.08);border-color:rgba(239,68,68,0.25);color:#fca5a5}
/* 指南面板 */
.tpl-guide-panel{margin:0 24px;padding:14px 16px;background:rgba(139,92,246,0.05);border:1px solid rgba(139,92,246,0.12);border-radius:10px;font-size:12px;color:var(--text2);line-height:1.7;max-height:200px;overflow-y:auto;flex-shrink:0;animation:tplSlideDown .2s ease}
.tpl-guide-panel b{color:var(--text)}
@keyframes tplSlideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
/* 进度条 */
.tpl-progress-bar{display:flex;align-items:center;gap:10px;padding:0 24px 14px;flex-shrink:0}
.tpl-progress-fill{flex:1;height:3px;border-radius:2px;background:var(--bg-hover-strong);overflow:hidden;position:relative}
.tpl-progress-fill::after{content:'';position:absolute;left:0;top:0;height:100%;width:0%;background:linear-gradient(90deg,var(--primary),var(--mint));border-radius:2px;transition:width .3s ease}
.tpl-progress-bar.filled-10 .tpl-progress-fill::after{width:10%}
.tpl-progress-bar.filled-20 .tpl-progress-fill::after{width:20%}
.tpl-progress-bar.filled-30 .tpl-progress-fill::after{width:30%}
.tpl-progress-bar.filled-40 .tpl-progress-fill::after{width:40%}
.tpl-progress-bar.filled-50 .tpl-progress-fill::after{width:50%}
.tpl-progress-bar.filled-60 .tpl-progress-fill::after{width:60%}
.tpl-progress-bar.filled-70 .tpl-progress-fill::after{width:70%}
.tpl-progress-bar.filled-80 .tpl-progress-fill::after{width:80%}
.tpl-progress-bar.filled-90 .tpl-progress-fill::after{width:90%}
.tpl-progress-bar.filled-100 .tpl-progress-fill::after{width:100%}
.tpl-progress-text{font-size:10px;color:var(--text3);white-space:nowrap;flex-shrink:0;font-variant-numeric:tabular-nums}
/* 主体分栏 */
.tpl-modal-main{display:flex;flex:1;min-height:0;overflow:hidden}
/* 左侧填写区 */
.tpl-form-panel{flex:1;min-width:0;overflow-y:auto;padding:0 24px 24px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,0.08) transparent}
.tpl-form-panel::-webkit-scrollbar{width:4px}
.tpl-form-panel::-webkit-scrollbar-thumb{background:var(--bg-hover-strong);border-radius:2px}
.tpl-modal-body{display:flex;flex-direction:column;gap:6px}
/* 分组 */
.tpl-group{border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--bg-hover);margin-bottom:4px}
.tpl-group-head{display:flex;align-items:center;gap:8px;padding:10px 14px;cursor:pointer;transition:background .15s;user-select:none}
.tpl-group-head:hover{background:var(--bg-hover)}
.tpl-group-icon{width:22px;height:22px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0}
.tpl-group-icon.g1{background:rgba(59,130,246,0.12);color:#3B82F6}
.tpl-group-icon.g2{background:rgba(139,92,246,0.12);color:#8B5CF6}
.tpl-group-icon.g3{background:rgba(6,214,212,0.12);color:#06D6D4}
.tpl-group-icon.g4{background:rgba(245,158,11,0.12);color:var(--gold)}
.tpl-group-icon.g5{background:rgba(239,68,68,0.12);color:#EF4444}
.tpl-group-icon.g6{background:rgba(34,197,94,0.12);color:#22C55E}
.tpl-group-name{font-size:12px;font-weight:600;color:var(--text);flex:1}
.tpl-group-count{font-size:10px;color:var(--text3);padding:2px 7px;border-radius:4px;background:var(--bg-hover)}
.tpl-group-req{font-size:9px;font-weight:700;color:#fff;padding:2px 6px;border-radius:4px;background:linear-gradient(135deg,#EF4444 0%,#F97316 100%);letter-spacing:0.5px;display:inline-flex;align-items:center;gap:2px;box-shadow:0 1px 3px rgba(239,68,68,0.3);animation:tplReqPulse 2s ease-in-out infinite}
.tpl-group-req::before{content:"";width:4px;height:4px;border-radius:50%;background:#fff;animation:tplReqBlink 1.5s ease-in-out infinite}
@keyframes tplReqPulse{0%,100%{box-shadow:0 1px 3px rgba(239,68,68,0.3)}50%{box-shadow:0 1px 6px rgba(239,68,68,0.6)}}
@keyframes tplReqBlink{0%,100%{opacity:1}50%{opacity:0.3}}
.tpl-group-arrow{width:16px;height:16px;display:flex;align-items:center;justify-content:center;color:var(--text3);transition:transform .2s}
.tpl-group.collapsed .tpl-group-arrow{transform:rotate(-90deg)}
.tpl-group-body{padding:4px 14px 12px;display:flex;flex-direction:column;gap:10px;position:relative;z-index:auto}
.tpl-group.collapsed .tpl-group-body{display:none}
/* 字段 */
.tpl-field{display:flex;flex-direction:column;gap:3px;position:relative;z-index:1;min-width:0;overflow:visible}
.tpl-field-row{display:flex;align-items:center;gap:6px}
.tpl-field-row .tpl-field-label{flex:1}
.tpl-field-del{width:20px;height:20px;border-radius:4px;display:flex;align-items:center;justify-content:center;color:var(--text3);transition:all .15s;flex-shrink:0}
.tpl-field-del:hover{color:#EF4444;background:rgba(239,68,68,0.1)}
.tpl-field-extra{border:1px dashed rgba(59,130,246,0.15);padding:8px 10px;border-radius:8px;background:rgba(59,130,246,0.02)}
.tpl-field-label{font-size:11px;font-weight:600;color:rgba(148,163,184,0.9);letter-spacing:.2px;outline:none;display:flex;align-items:center;gap:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:1;min-width:0;max-width:100%}
.tpl-field-label .tpl-label-dot{width:4px;height:4px;border-radius:50%;background:var(--primary);flex-shrink:0}
.tpl-field-label[contenteditable]{border-bottom:1px dashed rgba(59,130,246,0.25);padding-bottom:1px;cursor:text}
.tpl-field-input-wrap{position:relative;display:flex;align-items:stretch;gap:6px;min-width:0;width:100%}
.tpl-field-input{flex:1;min-width:0;width:auto;padding:8px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg-input);color:var(--text);font-size:13px;outline:none;transition:all .15s;box-sizing:border-box;min-height:36px;line-height:1.4}
.tpl-field-input-wrap .tpl-field-input{padding-right:12px;border-radius:8px}
.tpl-field-input:focus{border-color:rgba(59,130,246,0.4);background:rgba(59,130,246,0.04);box-shadow:0 0 0 3px rgba(59,130,246,0.06)}
.tpl-field-input::placeholder{color:rgba(148,163,184,0.4)}
.tpl-field-input.filled{border-color:rgba(6,214,212,0.25);background:rgba(6,214,212,0.03)}
.tpl-field-preset-btn{position:relative;flex-shrink:0;width:auto;min-width:54px;padding:0 12px;height:auto;align-self:stretch;border-radius:8px;border:1px solid rgba(59,130,246,0.2);background:rgba(59,130,246,0.08);color:var(--primary);font-size:10px;font-weight:600;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;letter-spacing:.3px;pointer-events:auto}
.tpl-field-preset-btn:hover{background:rgba(59,130,246,0.18);border-color:rgba(59,130,246,0.35)}
.tpl-field-preset-btn:active{transform:scale(0.96)}
.tpl-field-preset-dropdown{min-width:160px;max-width:220px;max-height:240px;overflow-y:auto;background:#1E293B;border:1px solid rgba(59,130,246,0.2);border-radius:10px;box-shadow:0 8px 32px rgba(0,0,0,0.5),0 0 0 1px rgba(59,130,246,0.1);padding:4px;animation:tplFadeIn .15s ease}
@keyframes tplFadeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.tpl-preset-dropdown-title{padding:6px 10px 4px;font-size:10px;font-weight:700;color:var(--mint);letter-spacing:.5px;text-transform:uppercase;border-bottom:1px solid rgba(255,255,255,0.06);margin-bottom:2px}
.tpl-preset-dropdown-item{padding:7px 10px;font-size:12px;color:var(--text2);border-radius:6px;cursor:pointer;transition:all .1s}
.tpl-preset-dropdown-item:hover{background:rgba(59,130,246,0.12);color:var(--text)}
.tpl-no-vars{font-size:13px;color:var(--text3);text-align:center;padding:24px 0}
/* 右侧预览区 */
.tpl-preview-panel{width:340px;flex-shrink:0;display:flex;flex-direction:column;border-left:1px solid var(--border);background:rgba(0,0,0,0.15)}
.tpl-preview-header{display:flex;align-items:center;gap:6px;padding:14px 16px;font-size:11px;font-weight:600;color:var(--text3);letter-spacing:.5px;text-transform:uppercase;border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between}
.tpl-preview-header>span{display:flex;align-items:center;gap:6px}
.tpl-preview-header svg{color:var(--mint);opacity:.6}
.tpl-format-tabs{display:flex;gap:2px;background:var(--bg-soft);border-radius:6px;padding:2px}
.tpl-format-tab{padding:4px 10px;font-size:10px;font-weight:500;color:var(--text3);background:transparent;border:none;border-radius:4px;cursor:pointer;transition:all .15s;text-transform:none;letter-spacing:0}
.tpl-format-tab:hover{color:var(--text)}
.tpl-format-tab.active{background:var(--primary);color:#fff}
.tpl-preview-edit-btn{display:flex;align-items:center;gap:4px;padding:4px 10px;font-size:10px;font-weight:500;color:var(--text3);background:transparent;border:none;border-radius:4px;cursor:pointer;transition:all .15s;text-transform:none;letter-spacing:0;margin-left:6px;border:1px solid var(--border)}
.tpl-preview-edit-btn:hover{color:var(--text);background:var(--bg-hover);border-color:var(--border-h)}
.tpl-preview-edit-btn.editing{background:var(--primary);color:#fff;border-color:rgba(6,214,212,0.4)}
.tpl-preview-edit-actions{display:flex;gap:6px;padding:10px 14px;background:rgba(6,214,212,0.06);border-bottom:1px solid rgba(6,214,212,0.18);flex-shrink:0;align-items:center;justify-content:space-between}
.tpl-preview-edit-actions-left{font-size:10px;color:var(--mint);font-weight:500;letter-spacing:.3px;display:flex;align-items:center;gap:4px}
.tpl-preview-edit-actions-right{display:flex;gap:6px;align-items:center}
.tpl-preview-edit-save{padding:7px 18px;font-size:11px;font-weight:600;background:var(--primary);color:#fff;border:none;border-radius:6px;cursor:pointer;transition:all .15s;min-width:84px;display:flex;align-items:center;gap:5px;justify-content:center}
.tpl-preview-edit-save:hover{background:#0ab9b3;transform:translateY(-1px);box-shadow:0 4px 12px rgba(6,214,212,0.3)}
.tpl-preview-edit-save:disabled,.tpl-preview-edit-save.loading{background:rgba(6,214,212,0.5);cursor:not-allowed;transform:none;box-shadow:none;pointer-events:none}
.tpl-preview-edit-save .tpl-btn-spinner{animation:tpl-spin 0.8s linear infinite;flex-shrink:0}
@keyframes tpl-spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.tpl-preview-edit-cancel:disabled,.tpl-preview-edit-cancel.loading{opacity:0.5;cursor:not-allowed;pointer-events:none}
.tpl-preview-edit-cancel{padding:7px 14px;font-size:11px;font-weight:500;background:var(--bg-hover);color:var(--text2);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .15s;min-width:64px}
.tpl-preview-edit-cancel:hover{background:var(--bg-hover-strong);color:var(--text)}
.tpl-preview-body{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden;padding:0;font-size:11px;color:var(--text2);line-height:1.8;font-family:'JetBrains Mono','Fira Code','SF Mono',monospace;white-space:pre-wrap;word-break:break-all;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,0.06) transparent}
.tpl-preview-body.editing{padding:0;background:rgba(15,23,42,0.5)}
.tpl-preview-body:not(.editing){overflow-y:auto;padding:16px}
.tpl-preview-textarea{flex:1 1 0%;width:100%;min-height:0;padding:16px;font-size:12px;line-height:1.85;font-family:'JetBrains Mono','Fira Code','SF Mono',monospace;color:var(--text);background:transparent;border:none;outline:none;resize:none;tab-size:2;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(6,214,212,0.2) transparent}
.tpl-preview-textarea::-webkit-scrollbar{width:4px}
.tpl-preview-textarea::-webkit-scrollbar-thumb{background:rgba(6,214,212,0.2);border-radius:2px}
.tpl-preview-textarea:focus{background:rgba(15,23,42,0.3)}
.tpl-preview-edited-badge{display:flex;align-items:center;gap:6px;margin:0 0 10px;padding:6px 10px;background:rgba(16,185,129,0.1);border:1px solid rgba(16,185,129,0.3);border-radius:6px;font-size:10px;font-weight:600;color:#10b981;letter-spacing:.3px;flex-shrink:0}
.tpl-preview-edited-badge svg{flex-shrink:0}
.tpl-preview-edited-content{font-size:12px;line-height:1.85;color:var(--text);white-space:pre-wrap;word-break:break-all;padding:2px 0}
.tpl-copy-mode-bar{display:flex;align-items:center;gap:8px;padding:8px 14px;background:rgba(6,214,212,0.06);border-bottom:1px solid rgba(6,214,212,0.15)}
.tpl-copy-mode-label{font-size:11px;color:var(--text3);font-weight:500;letter-spacing:0.3px}
.tpl-copy-mode-tabs{display:flex;gap:2px;background:rgba(15,23,42,0.7);border-radius:6px;padding:2px;border:1px solid rgba(6,214,212,0.25)}
.tpl-copy-mode-tab{padding:4px 10px;font-size:10px;font-weight:500;color:var(--text3);background:transparent;border:none;border-radius:4px;cursor:pointer;transition:all .15s;text-transform:none;letter-spacing:0}
.tpl-copy-mode-tab:hover{color:var(--text)}
.tpl-copy-mode-tab.active{background:var(--primary);color:#fff;box-shadow:0 0 0 1px rgba(6,214,212,0.4)}
.tpl-preview-rule{position:relative;padding:6px 8px;margin:4px -4px;background:rgba(6,214,212,0.05);border-left:2px solid var(--mint);border-radius:0 4px 4px 0}
.tpl-preview-fade{opacity:0.4;filter:grayscale(0.3);transition:opacity .2s}
.tpl-preview-fade:hover{opacity:0.7}
.tpl-breakdown{margin:0 16px 12px;border:1px solid var(--border);border-radius:8px;background:rgba(15,23,42,0.4);overflow:hidden;flex-shrink:0}
.tpl-breakdown-header{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;cursor:pointer;font-size:12px;font-weight:600;color:var(--text2);user-select:none}
.tpl-breakdown-header:hover{background:var(--bg-hover)}
.tpl-breakdown-toggle{font-size:10px;color:var(--text3);transition:transform .2s}
.tpl-breakdown.collapsed .tpl-breakdown-toggle{transform:rotate(-90deg)}
.tpl-breakdown-body{padding:0 12px 12px;display:flex;flex-direction:column;gap:6px;max-height:240px;overflow-y:auto}
.tpl-breakdown.collapsed .tpl-breakdown-body{display:none}
/* ===== P0: 必填校验 + 骨架屏 + Loading ===== */
.tpl-field-required .tpl-field-label{color:var(--text)}
.tpl-field-required .tpl-field-required{color:#ef4444;margin-left:4px;font-weight:700;font-size:12px;display:inline-block;vertical-align:middle}
.tpl-input-error{border-color:#ef4444 !important;box-shadow:0 0 0 3px rgba(239,68,68,0.15) !important;animation:tplShake .3s ease-in-out}
@keyframes tplShake{0%,100%{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}
.tpl-required-alert{position:absolute;top:80px;left:50%;transform:translateX(-50%) translateY(-20px);background:rgba(239,68,68,0.95);color:#fff;padding:12px 18px;border-radius:10px;font-size:12px;box-shadow:0 8px 24px rgba(239,68,68,0.3);opacity:0;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:100;max-width:480px;backdrop-filter:blur(8px);pointer-events:none}
.tpl-required-alert.show{opacity:1;transform:translateX(-50%) translateY(0)}
.tpl-required-alert-title{font-weight:600;margin-bottom:6px;display:flex;align-items:center;gap:4px}
.tpl-required-alert-list{display:flex;flex-wrap:wrap;gap:4px}
.tpl-required-tag{display:inline-block;padding:2px 8px;background:rgba(255,255,255,0.2);border-radius:4px;font-size:11px}

.tpl-skeleton{padding:20px;animation:tplFadeIn .2s ease}
@keyframes tplFadeIn{from{opacity:0}to{opacity:1}}
.tpl-skel-group{margin-bottom:24px;padding:16px;background:rgba(15,23,42,0.3);border-radius:10px;border:1px solid rgba(255,255,255,0.03)}
.tpl-skel-bar{height:12px;background:linear-gradient(90deg,rgba(15,23,42,0.04) 0%,rgba(15,23,42,0.08) 50%,rgba(15,23,42,0.04) 100%);background-size:200% 100%;border-radius:4px;margin-bottom:8px;animation:tplShimmer 1.5s infinite}
.tpl-skel-field{padding:8px 0;border-bottom:1px dashed var(--border)}
.tpl-skel-field:last-child{border-bottom:none}
@keyframes tplShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

.tpl-copy-btn{position:relative;transition:all .2s}
.tpl-copy-btn.loading{opacity:0.7;pointer-events:none}
.tpl-btn-spinner{display:inline-block;width:12px;height:12px;border:2px solid rgba(255,255,255,0.3);border-top-color:#fff;border-radius:50%;animation:tplSpin .6s linear infinite;margin-right:6px;vertical-align:middle}
@keyframes tplSpin{to{transform:rotate(360deg)}}

/* 全局Toast */
.global-toast{position:fixed;top:80px;left:50%;transform:translateX(-50%) translateY(-20px);display:flex;align-items:center;gap:10px;padding:12px 20px;background:rgba(15,23,42,0.95);border:1px solid var(--border);border-radius:10px;font-size:13px;color:var(--text);box-shadow:0 8px 24px rgba(0,0,0,0.4);opacity:0;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:100000;backdrop-filter:blur(8px);max-width:90vw;pointer-events:none}
.global-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.global-toast-icon{font-size:18px;flex-shrink:0}
.global-toast-msg{flex:1}
.global-toast-error{border-color:rgba(239,68,68,0.4);background:rgba(127,29,29,0.95)}
.global-toast-success{border-color:rgba(16,185,129,0.4);background:rgba(6,78,59,0.95)}
.global-toast-info{border-color:rgba(59,130,246,0.4);background:rgba(30,58,138,0.95)}
.global-toast-detailed{flex-direction:column;align-items:stretch;max-width:520px;padding:12px 16px;gap:6px;pointer-events:auto}
.global-toast-detailed .global-toast-icon{position:absolute;top:12px;left:14px}
.global-toast-detailed .global-toast-msg{margin-left:28px;font-weight:500;flex:0 0 auto}
.global-toast-close{position:absolute;top:8px;right:10px;width:22px;height:22px;border:none;background:transparent;color:rgba(255,255,255,0.6);font-size:18px;line-height:1;cursor:pointer;border-radius:4px;padding:0}
.global-toast-close:hover{background:rgba(255,255,255,0.1);color:#fff}
.global-toast-detail-btn{margin:6px 0 0 28px;padding:3px 10px;background:rgba(255,255,255,0.1);border:1px solid var(--border-h);border-radius:4px;color:var(--text2);font-size:11px;cursor:pointer;font-family:inherit;align-self:flex-start}
.global-toast-detail-btn:hover{background:rgba(255,255,255,0.18);color:#fff}
.global-toast-detail{display:none;margin:6px 0 0 28px;padding:8px 10px;background:rgba(0,0,0,0.4);border-radius:4px;font-size:11px;font-family:'SF Mono',Consolas,monospace;line-height:1.5;color:rgba(255,255,255,0.85);white-space:pre-wrap;word-break:break-all;max-height:200px;overflow-y:auto;text-align:left}
.global-toast-detail.show{display:block}

/* 收藏按钮 */
.tpl-fav-btn.active{background:rgba(245,158,11,0.15);border-color:rgba(245,158,11,0.4);color:#fbbf24}
.tpl-fav-btn.active svg{fill:#fbbf24;stroke:#fbbf24}

/* 分享弹窗 */
.tpl-share-list{padding:16px;display:flex;flex-direction:column;gap:6px;max-height:60vh;overflow-y:auto}
.tpl-share-item{display:flex;align-items:center;gap:14px;width:100%;padding:12px;background:rgba(15,23,42,0.4);border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:all .15s;text-align:left;font-family:inherit}
.tpl-share-item:hover{background:rgba(15,23,42,0.7);border-color:rgba(6,214,212,0.3);transform:translateX(2px)}
.tpl-share-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px rgba(0,0,0,0.2)}
.tpl-share-text{flex:1}
.tpl-share-name{font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px}
.tpl-share-desc{font-size:11px;color:var(--text3)}
.tpl-fp-search input{flex:1;background:transparent;border:none;outline:none;color:var(--text);font-size:13px;font-family:inherit;min-width:0}
.tpl-fp-list{max-height:min(60vh,520px);overflow-y:auto;overflow-x:hidden;padding:4px 16px 16px;display:flex;flex-direction:column;gap:4px;align-content:flex-start}
.tpl-fp-item{padding:10px 14px;font-size:13px;color:var(--text2);background:rgba(15,23,42,0.4);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .15s;line-height:1.5;word-break:break-word;display:flex;align-items:center;gap:10px}
.tpl-fp-item::before{content:'';width:4px;height:4px;border-radius:50%;background:var(--text3);flex-shrink:0;transition:all .15s}
.tpl-fp-item:hover{background:rgba(6,214,212,0.08);border-color:rgba(6,214,212,0.3);color:var(--mint);transform:translateX(2px)}
.tpl-fp-item:hover::before{background:var(--mint);box-shadow:0 0 8px var(--mint)}
.tpl-fp-item:active{transform:scale(0.99)}
.tpl-fp-list::-webkit-scrollbar{width:6px}
.tpl-fp-list::-webkit-scrollbar-track{background:rgba(15,23,42,0.3);border-radius:3px}
.tpl-fp-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.1);border-radius:3px}
.tpl-fp-list::-webkit-scrollbar-thumb:hover{background:rgba(6,214,212,0.4)}

/* 预设弹窗：脱离父级stacking context */
#tpl-fp-overlay{position:fixed;inset:0;background:rgba(2,6,23,0.6);z-index:100000;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:tplFadeIn .2s ease}
#tpl-fp-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(440px,92vw);max-height:85vh;background:linear-gradient(180deg,rgba(15,23,42,0.98) 0%,rgba(2,6,23,0.98) 100%);border:1px solid rgba(6,214,212,0.2);border-radius:14px;box-shadow:0 24px 60px rgba(0,0,0,0.5),0 0 40px rgba(6,214,212,0.1);z-index:100001;overflow:hidden;animation:tplModalIn .25s cubic-bezier(.4,0,.2,1);font-family:inherit}
@keyframes tplModalIn{from{opacity:0;transform:translate(-50%,-45%) scale(0.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}
#tpl-fp-modal .tpl-modal-card{background:transparent;border:none;box-shadow:none;max-width:none;width:100%;height:100%}
#tpl-fp-modal .tpl-modal-topbar{padding:18px 20px 0;border-bottom:none}
#tpl-fp-modal .tpl-modal-topbar-left{padding-right:0}

/* 分享/智能填写弹窗：脱离父级stacking context（全局桌面端也强制fixed） */
#tpl-share-overlay{position:fixed;inset:0;background:rgba(2,6,23,0.6);z-index:100000;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:tplFadeIn .2s ease}
#tpl-share-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(440px,92vw);max-height:85vh;background:linear-gradient(180deg,rgba(15,23,42,0.98) 0%,rgba(2,6,23,0.98) 100%);border:1px solid rgba(6,214,212,0.2);border-radius:14px;box-shadow:0 24px 60px rgba(0,0,0,0.5),0 0 40px rgba(6,214,212,0.1);z-index:100001;overflow:hidden;animation:tplModalIn .25s cubic-bezier(.4,0,.2,1);font-family:inherit}
#tpl-share-modal .tpl-modal-card{background:transparent;border:none;box-shadow:none;max-width:none;width:100%;height:100%}
#tpl-share-modal .tpl-modal-topbar{padding:18px 20px 0;border-bottom:none}
#tpl-share-modal .tpl-modal-topbar-left{padding-right:0}

#tpl-smart-overlay{position:fixed;inset:0;background:rgba(2,6,23,0.6);z-index:100000;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:tplFadeIn .2s ease}
#tpl-smart-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(560px,92vw);max-height:85vh;background:linear-gradient(180deg,rgba(15,23,42,0.98) 0%,rgba(2,6,23,0.98) 100%);border:1px solid rgba(6,214,212,0.2);border-radius:14px;box-shadow:0 24px 60px rgba(0,0,0,0.5),0 0 40px rgba(6,214,212,0.1);z-index:100001;overflow:hidden;animation:tplModalIn .25s cubic-bezier(.4,0,.2,1);font-family:inherit}
#tpl-smart-modal .tpl-modal-card{background:transparent;border:none;box-shadow:none;max-width:none;width:100%;height:100%}
#tpl-smart-modal .tpl-modal-topbar{padding:18px 20px 0}
.tpl-breakdown-key{color:var(--mint);font-weight:600;flex-shrink:0;min-width:80px}
.tpl-breakdown-val{color:var(--text2);word-break:break-word}
.tpl-preview-body{flex:1;overflow-y:auto;padding:16px;font-size:11px;color:var(--text2);line-height:1.8;font-family:'JetBrains Mono','Fira Code','SF Mono',monospace;white-space:pre-wrap;word-break:break-all;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,0.06) transparent}
.tpl-preview-body::-webkit-scrollbar{width:3px}
.tpl-preview-body::-webkit-scrollbar-thumb{background:var(--bg-hover-strong);border-radius:2px}
.tpl-preview-body .tpl-hl{background:rgba(6,214,212,0.12);color:var(--mint);padding:1px 3px;border-radius:3px;font-weight:500}
.tpl-preview-body .tpl-hl-empty{background:rgba(239,68,68,0.08);color:rgba(239,68,68,0.6);padding:1px 3px;border-radius:3px;font-style:italic}
.tpl-preview-raw{margin:0;display:flex;flex-direction:column;gap:8px}
.tpl-preview-raw-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;background:rgba(124,58,237,0.15);border:1px solid rgba(124,58,237,0.35);border-radius:6px;font-size:11px;color:var(--primary);font-weight:500;font-family:'JetBrains Mono',monospace;align-self:flex-start}
.tpl-preview-raw-content{font-size:12.5px;line-height:1.8;color:var(--text);background:rgba(0,0,0,0.3);border-left:3px solid var(--primary);border-radius:6px;padding:14px 16px;white-space:pre-wrap;word-break:break-word;font-family:'JetBrains Mono',monospace}
.tpl-preview-empty{text-align:center;padding:40px 20px;color:var(--text3);font-size:13px;display:flex;flex-direction:column;align-items:center;gap:12px;font-family:'JetBrains Mono',monospace}
.tpl-preview-empty svg{opacity:0.4}
.tpl-preview-footer{padding:12px 16px;border-top:1px solid var(--border);flex-shrink:0}
.tpl-copy-btn{display:flex;align-items:center;gap:6px;width:100%;justify-content:center;padding:10px;border-radius:10px;background:linear-gradient(135deg,rgba(59,130,246,0.9),rgba(6,214,212,0.9));color:#fff;font-size:13px;font-weight:600;transition:all .2s;letter-spacing:.3px}
.tpl-copy-btn:hover{box-shadow:0 4px 20px rgba(59,130,246,0.3);transform:translateY(-1px)}
.tpl-copy-btn:active{transform:translateY(0)}
/* === 画面卡片 === */
.tpl-shots-section{margin:0 0 8px;padding:0}
.tpl-shots-header{display:flex;align-items:center;justify-content:space-between;padding:10px 0 8px;gap:8px}
.tpl-shots-title{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--text);letter-spacing:-.2px}
.tpl-shots-title svg{color:var(--mint);opacity:.7}
.tpl-shots-count{font-size:11px;color:var(--text3);font-weight:500}
.tpl-shots-list{display:flex;flex-direction:column;gap:8px}
.tpl-shot-card{background:var(--bg-hover);border:1px solid var(--border);border-radius:10px;padding:10px 12px;transition:border-color .15s}
.tpl-shot-card:hover{border-color:rgba(59,130,246,0.2)}
.tpl-shot-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.tpl-shot-num{font-size:12px;font-weight:700;color:var(--mint);letter-spacing:.3px}
.tpl-shot-del{width:22px;height:22px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--text3);background:transparent;transition:all .15s}
.tpl-shot-del:hover{color:#EF4444;background:rgba(239,68,68,0.1)}
.tpl-shot-fields{display:flex;flex-direction:column;gap:6px}
.tpl-shot-row{display:flex;gap:8px}
.tpl-shot-field{flex:1;display:flex;flex-direction:column;gap:3px}
.tpl-shot-field label{font-size:10px;color:var(--text3);font-weight:500;letter-spacing:.2px}
.tpl-shot-field-full{width:100%}
.tpl-shot-input{width:100%;padding:6px 10px;border-radius:6px;border:1px solid var(--border);background:var(--bg-hover);color:var(--text);font-size:12px;transition:all .15s;outline:none;box-sizing:border-box}
.tpl-shot-input:focus{border-color:rgba(59,130,246,0.4);box-shadow:0 0 0 2px rgba(59,130,246,0.1)}
.tpl-shot-input::placeholder{color:rgba(255,255,255,0.15)}
.tpl-shot-preset-btn{position:absolute;right:0;top:0;bottom:0;width:36px;border-radius:0 6px 6px 0;border:1px solid var(--border);border-left:none;background:rgba(59,130,246,0.08);color:var(--primary);font-size:9px;font-weight:600;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}
.tpl-shot-preset-btn:hover{background:rgba(59,130,246,0.18)}
.tpl-shot-field{position:relative}
.tpl-shot-field .tpl-shot-input{padding-right:38px}
.tpl-shot-field:first-child .tpl-shot-input{padding-right:10px}
.tpl-shot-field:first-child .tpl-shot-preset-btn{display:none}
.tpl-add-shot-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:10px;border-radius:10px;border:1px dashed rgba(59,130,246,0.25);background:rgba(59,130,246,0.04);color:var(--primary);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;margin-top:8px}
.tpl-add-shot-btn:hover{background:rgba(59,130,246,0.1);border-color:rgba(59,130,246,0.4)}
.tpl-add-shot-btn svg{opacity:.7}
/* ===== 补充自定义内容板块 ===== */
.tpl-extra-section{margin-top:14px;padding:14px;border-radius:12px;background:linear-gradient(135deg,rgba(167,139,250,0.05) 0%,rgba(124,58,237,0.03) 100%);border:1px solid rgba(167,139,250,0.18)}
.tpl-extra-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.tpl-extra-head-l{display:flex;align-items:flex-start;gap:8px;flex:1;min-width:0}
.tpl-extra-ico{font-size:18px;line-height:1;flex-shrink:0;margin-top:1px}
.tpl-extra-titles{flex:1;min-width:0}
.tpl-extra-title{font-size:13px;font-weight:600;color:var(--text);line-height:1.4;letter-spacing:.2px}
.tpl-extra-sub{font-size:11px;color:var(--text3);line-height:1.5;margin-top:2px;letter-spacing:.1px}
.tpl-extra-count{font-size:10px;font-weight:600;color:var(--text3);padding:3px 8px;border-radius:10px;background:var(--bg-hover);border:1px solid var(--border);white-space:nowrap;letter-spacing:.3px;transition:all .2s}
.tpl-extra-count.tpl-extra-count-active{color:#A78BFA;background:rgba(167,139,250,0.1);border-color:rgba(167,139,250,0.3)}
.tpl-extra-list{display:flex;flex-direction:column;gap:8px;min-height:0}
.tpl-extra-list:empty::before{content:'点击下方按钮添加你想补充的任意内容（标签可点击修改）';display:block;text-align:center;padding:14px 8px;font-size:11px;color:var(--text3);border:1px dashed rgba(167,139,250,0.2);border-radius:8px;background:rgba(167,139,250,0.02);letter-spacing:.1px}
.tpl-extra-row{border:1px dashed rgba(167,139,250,0.25);padding:8px 10px;border-radius:8px;background:rgba(167,139,250,0.03);transition:all .2s}
.tpl-extra-row:focus-within{border-color:rgba(167,139,250,0.5);background:rgba(167,139,250,0.06);box-shadow:0 0 0 3px rgba(167,139,250,0.08)}
.tpl-extra-actions{display:flex;gap:8px;margin-top:10px}
.tpl-extra-quick,.tpl-extra-add{display:flex;align-items:center;justify-content:center;gap:5px;flex:1;padding:8px 10px;border-radius:8px;border:1px solid rgba(167,139,250,0.25);background:rgba(167,139,250,0.06);color:#A78BFA;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;letter-spacing:.2px}
.tpl-extra-quick:hover{background:rgba(167,139,250,0.12);border-color:rgba(167,139,250,0.4)}
.tpl-extra-add{background:linear-gradient(135deg,rgba(167,139,250,0.15) 0%,rgba(124,58,237,0.12) 100%);border-color:rgba(167,139,250,0.4)}
.tpl-extra-add:hover{background:linear-gradient(135deg,rgba(167,139,250,0.25) 0%,rgba(124,58,237,0.2) 100%);transform:translateY(-1px);box-shadow:0 2px 8px rgba(167,139,250,0.15)}
.tpl-extra-quick svg,.tpl-extra-add svg{flex-shrink:0;opacity:.85}
/* 移动端适配 */
@media(max-width:768px){
  .tpl-modal-card{width:100vw;max-width:100vw;max-height:100vh;border-radius:0}
  .tpl-modal-main{flex-direction:column}
  .tpl-preview-panel{width:100%;border-left:none;border-top:1px solid var(--border);max-height:40vh}
  .tpl-modal-topbar{flex-wrap:wrap;padding:14px 16px;gap:8px}
  .tpl-modal-topbar-left{flex:1;min-width:0}
  .tpl-modal-topbar-actions{width:100%;order:3;justify-content:flex-end}
  .tpl-modal-close{order:2;width:32px;height:32px;margin-left:auto}
  .tpl-modal-title{font-size:14px}
  .tpl-modal-desc{font-size:11px}
  /* 补充自定义板块移动端 */
  .tpl-extra-section{padding:12px}
  .tpl-extra-actions{flex-direction:row;gap:6px}
  .tpl-extra-quick,.tpl-extra-add{padding:10px 8px;font-size:11px;min-height:44px}
  .tpl-extra-ico{font-size:16px}
}
@media(max-width:480px){
  .tpl-modal-topbar-left{gap:10px}
  .tpl-modal-badge{font-size:9px;padding:3px 6px}
  .tpl-modal-title{font-size:13px}
  .tpl-modal-desc{font-size:10px}
  .tpl-modal-topbar-actions{flex-wrap:wrap;gap:4px}
  .tpl-act-btn{padding:5px 8px;font-size:10px}
  .tpl-preview-panel{max-height:35vh}
  .tpl-preview-header{flex-direction:column;align-items:flex-start;gap:8px}
  .tpl-format-tabs{width:100%;justify-content:space-between}
  .tpl-format-tab{flex:1;text-align:center}
  .tpl-fp-list{grid-template-columns:1fr}
  .tpl-field-label{font-size:11px}
  .tpl-field-input{padding:10px;font-size:14px}  /* 防止iOS缩放 */
  .tpl-group-head{padding:10px 12px}
  .tpl-group-name{font-size:12px}
  .tpl-shot-card{padding:10px}
  .tpl-copy-btn{width:100%;padding:12px;font-size:13px}
  .tpl-modal-card::before{height:0}  /* 移动端隐藏顶部渐变 */

  /* 模板主弹窗移动端：双栏变单栏，topbar更紧凑 */
  .tpl-modal-card{width:100vw;max-width:100vw;max-height:100vh;height:100vh;border-radius:0;display:flex;flex-direction:column}
  .tpl-modal-topbar{padding:max(env(safe-area-inset-top),12px) 14px 10px;gap:8px;flex-shrink:0}
  .tpl-modal-topbar-actions{width:100%;justify-content:space-between;gap:2px;order:3}
  .tpl-modal-topbar-actions .tpl-act-btn{flex:1;justify-content:center;min-width:0}
  .tpl-modal-topbar-actions .tpl-act-btn svg{display:none}  /* 移动端只显示文字 */
  .tpl-modal-close{width:32px;height:32px;margin-left:0}
  .tpl-modal-main{flex-direction:column;flex:1;min-height:0}
  .tpl-modal-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:14px;gap:4px}
  .tpl-preview-panel{width:100%;max-height:40vh;border-left:none;border-top:1px solid var(--border);order:2}
  .tpl-preview-body{max-height:calc(40vh - 80px);font-size:12px;scrollbar-width:none;-ms-overflow-style:none}
  .tpl-preview-body::-webkit-scrollbar{width:0;height:0;display:none;background:transparent}
  .tpl-preview-body::-webkit-scrollbar-thumb{background:transparent}
  .tpl-preview-body::-webkit-scrollbar-track{background:transparent}
  .tpl-modal-body{scrollbar-width:none;-ms-overflow-style:none}
  .tpl-modal-body::-webkit-scrollbar{width:0;height:0;display:none}
  .tpl-fp-list{scrollbar-width:none;-ms-overflow-style:none}
  .tpl-fp-list::-webkit-scrollbar{width:0;height:0;display:none}

  /* 显示滚动指示器（iOS风格） */
  .tpl-preview-body{background-image:linear-gradient(to top,rgba(6,214,212,0.06) 0%,transparent 8%),linear-gradient(to bottom,rgba(6,214,212,0.06) 0%,transparent 8%);background-repeat:no-repeat;background-size:100% 20px,100% 20px;background-attachment:local,local}

  /* 分镜卡片移动端：堆叠布局 */
  .tpl-shot-card{position:relative}
  .tpl-shot-card-actions{position:static;margin-top:8px;justify-content:flex-end}
  .tpl-shot-remove-btn{width:32px;height:32px}

  /* 预设弹窗移动端优化 */
  #tpl-fp-modal{width:100vw;max-width:100vw;max-height:100vh;height:100vh;border-radius:0;top:0;left:0;transform:none;animation:tplModalMobileIn .25s ease}
  @keyframes tplModalMobileIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
  #tpl-fp-modal .tpl-modal-topbar{padding:env(safe-area-inset-top,14px) 16px 0}
  #tpl-fp-modal .tpl-modal-topbar-left{padding-right:0}
  .tpl-fp-search{margin:14px 16px 10px;padding:10px 12px}
  .tpl-fp-list{max-height:calc(100vh - 160px);padding:4px 12px 24px}
  .tpl-fp-item{padding:12px 14px;font-size:14px;min-height:44px}  /* iOS最小点击区域 */

  /* 分享弹窗移动端 */
  #tpl-share-modal{width:100vw;max-width:100vw;max-height:100vh;border-radius:0;top:0;left:0;transform:none}
  .tpl-share-list{padding:12px 16px 24px}
  .tpl-share-item{padding:14px;min-height:60px}
  .tpl-share-icon{width:44px;height:44px}

  /* 智能填写弹窗移动端 */
  .modal{width:100vw;max-width:100vw;border-radius:0;top:0;left:0;transform:none;max-height:100vh;height:100vh;display:flex;flex-direction:column}
  .modal-card{padding:max(env(safe-area-inset-top),20px) 16px 20px;flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;border-radius:0}
  .modal h2{font-size:15px}

  /* 登录/注册/设置等通用表单 */
  .form-group{margin-bottom:14px}
  .form-group label{font-size:12px}
  .form-group input,.form-group textarea,.form-group select{font-size:14px;padding:12px 14px}
  .modal-actions{flex-direction:column-reverse;gap:8px}
  .modal-actions .btn{width:100%;justify-content:center}
  .modal-close{top:max(env(safe-area-inset-top),12px);right:12px;width:36px;height:36px}

  /* 必填错误提示移到顶部 */
  .tpl-required-alert{top:max(env(safe-area-inset-top),12px);width:calc(100vw - 24px);max-width:none;font-size:11px;padding:10px 14px}

  /* 全局Toast 移动端 */
  .global-toast{top:max(env(safe-area-inset-top),12px);width:calc(100vw - 24px);max-width:none;border-radius:10px;font-size:12px;padding:10px 14px}

  /* 触摸优化 */
  .tpl-fp-item,.tpl-share-item,.tpl-act-btn,.tpl-format-tab,.tpl-group-head,.tpl-shot-remove-btn,.tpl-add-shot-btn,.modal-actions .btn,.form-group input,.form-group textarea,.form-group select{-webkit-tap-highlight-color:rgba(6,214,212,0.15);touch-action:manipulation}
  .tpl-fp-item,.tpl-share-item{user-select:none;-webkit-user-select:none}
  input,textarea,select{font-size:14px !important}  /* 防止iOS自动缩放 */

  /* 全局滚动条：移动端隐藏式 */
  body{scrollbar-width:none;-ms-overflow-style:none}
  body::-webkit-scrollbar{width:0;height:0;display:none}
  html{scrollbar-width:none;-ms-overflow-style:none}
  html::-webkit-scrollbar{width:0;height:0;display:none}
  *{scrollbar-width:none;-ms-overflow-style:none}
  *::-webkit-scrollbar{width:0;height:0;display:none;background:transparent}
  *::-webkit-scrollbar-thumb{background:transparent}
  *::-webkit-scrollbar-track{background:transparent}
}

/* iPhone 安全区域 */
@supports(padding:max(0px)){
  @media(max-width:480px){
    #tpl-fp-modal .tpl-modal-topbar{padding-top:max(env(safe-area-inset-top),14px);padding-bottom:8px}
    .tpl-fp-list{padding-bottom:max(env(safe-area-inset-bottom),24px)}
  }
}

/* 平板优化 (481-768px) */
@media(min-width:481px)and(max-width:768px){
  #tpl-fp-modal{width:min(480px,92vw);max-height:80vh}
  .tpl-modal-card{width:96vw}
  .tpl-preview-panel{max-height:38vh}
}

/* 横屏适配 */
@media(max-height:500px)and(orientation:landscape){
  .tpl-modal-card{max-height:96vh}
  .tpl-preview-panel{max-height:30vh}
  #tpl-fp-modal{max-height:96vh;height:auto}
  .tpl-fp-list{max-height:60vh}
}

.vp-page{padding:48px 40px 60px;max-width:1280px;margin:0 auto;position:relative;background:transparent;overflow:hidden;width:100%;min-height:100%}
html.dark .vp-page,html[data-theme="dark"] .vp-page{background:linear-gradient(180deg,#050A15 0%,#0F172A 50%,#020617 100%)}
.vp-page-glow{position:absolute;top:-80px;left:50%;transform:translateX(-50%);width:500px;height:250px;background:radial-gradient(ellipse,rgba(59,130,246,0.08) 0%,rgba(6,214,212,0.04) 40%,transparent 70%);pointer-events:none}
.vp-page::before{content:'';position:absolute;inset:0;background-image:radial-gradient(1px 1px at 15% 25%,rgba(255,255,255,0.08) 50%,transparent 50%),radial-gradient(1px 1px at 45% 65%,rgba(255,255,255,0.06) 50%,transparent 50%),radial-gradient(1px 1px at 75% 35%,rgba(255,255,255,0.07) 50%,transparent 50%),radial-gradient(1px 1px at 25% 80%,rgba(255,255,255,0.05) 50%,transparent 50%),radial-gradient(1px 1px at 85% 55%,rgba(255,255,255,0.06) 50%,transparent 50%),radial-gradient(1.5px 1.5px at 55% 15%,rgba(59,130,246,0.1) 50%,transparent 50%),radial-gradient(1px 1px at 65% 90%,rgba(255,255,255,0.05) 50%,transparent 50%);pointer-events:none;z-index:0}
.vp-header{text-align:center;margin-bottom:40px;position:relative;z-index:1}
.vp-title{font-size:28px;font-weight:800;color:var(--text);letter-spacing:-0.5px;text-shadow:0 0 30px rgba(248,250,252,0.15),0 0 60px rgba(59,130,246,0.08)}
.vp-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:48px;position:relative;z-index:1}
.vp-card{position:relative;background:var(--card);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--r2);padding:28px 24px;cursor:pointer;transition:border-color .25s ease,box-shadow .25s ease,transform .25s ease;overflow:hidden;box-shadow:var(--shadow)}
.vp-card:hover{border-color:var(--border-h);box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.vp-card-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;background:var(--bg-primary-soft)}
.vp-card-icon svg{width:22px;height:22px;color:var(--primary)}
.vp-card-count{position:absolute;top:16px;right:16px;padding:3px 10px;border-radius:4px;font-size:10px;font-weight:600;background:rgba(168,85,247,0.12);color:var(--purple)}
.vp-card-title{font-family:var(--font);font-size:16px;font-weight:700;color:var(--text);margin-bottom:8px;letter-spacing:-0.2px}
.vp-card-desc{font-size:12px;color:var(--text2);line-height:1.7}
.vp-cases-section{position:relative;z-index:1}
.vp-cases-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.vp-cases-title{font-size:18px;font-weight:700;color:var(--text)}
.vp-cases-arrows{display:flex;gap:8px}
.vp-arrow{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text3);border:1px solid rgba(59,130,246,0.15);background:rgba(15,23,42,0.6);transition:all .15s}
.vp-arrow:hover{color:#60A5FA;border-color:rgba(59,130,246,0.35);box-shadow:0 0 12px rgba(59,130,246,0.1)}
.vp-cases{display:flex;gap:20px;overflow-x:auto;scroll-behavior:smooth;padding-bottom:8px;scroll-snap-type:x mandatory}
.vp-cases::-webkit-scrollbar{height:4px}
.vp-cases::-webkit-scrollbar-thumb{background:rgba(59,130,246,0.2);border-radius:2px}
.vp-case{min-width:300px;max-width:320px;flex-shrink:0;background:var(--card);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--r2);overflow:hidden;cursor:pointer;transition:border-color .2s ease;scroll-snap-align:start}
.vp-case:hover{border-color:var(--border-h)}
.vp-case-img{height:170px;overflow:hidden}
.vp-case-img img{width:100%;height:100%;object-fit:cover}
.vp-case-body{padding:14px 16px 16px}
.vp-case-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.vp-case-tag{padding:2px 8px;border-radius:4px;font-size:10px;font-weight:500}
.vp-case-tag-blue{background:rgba(59,130,246,0.12);color:#60A5FA}
.vp-case-tag-purple{background:rgba(139,92,246,0.12);color:var(--purple)}
.vp-case-tag-mint{background:rgba(6,214,212,0.12);color:var(--mint)}
.vp-case-tag-gold{background:rgba(245,158,11,0.12);color:var(--gold)}
.vp-case-meta{display:flex;justify-content:space-between;align-items:center}
.vp-case-specs{font-size:11px;color:var(--text3);font-family:monospace;letter-spacing:0.5px}
.vp-case-rating{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:var(--gold)}
.vp-case-rating svg{width:12px;height:12px}

.bd-page{padding:0 40px;max-width:1280px;margin:0 auto;width:100%;display:flex;flex-direction:column;min-height:calc(100vh - 56px)}
.bd-topbar{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-bottom:1px solid var(--border);margin-bottom:0}
.bd-topbar-left{display:flex;align-items:center;gap:10px}
.bd-topbar-left svg{width:20px;height:20px}
.bd-topbar-title{font-size:18px;font-weight:700;color:var(--text)}
.bd-topbar-right{display:flex;gap:6px}
.bd-top-btn{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:var(--r);font-size:12px;color:var(--text3);border:1px solid var(--border);transition:all .15s}
.bd-top-btn:hover{color:var(--text2);border-color:var(--border-h)}
.bd-top-btn svg{width:14px;height:14px}
.bd-body{display:grid;grid-template-columns:2fr 3fr;gap:0;flex:1;min-height:0}
.bd-left{display:flex;gap:0;border-right:1px solid var(--border)}
.bd-steps{display:flex;flex-direction:column;align-items:center;padding:24px 12px;gap:0;flex-shrink:0;width:72px}
.bd-step{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;padding:4px 0}
.bd-step-dot{width:10px;height:10px;border-radius:50%;background:var(--bg3);border:2px solid var(--bg3);transition:all .2s}
.bd-step.act .bd-step-dot{background:var(--primary);border-color:var(--primary);box-shadow:0 0 8px rgba(59,130,246,0.4)}
.bd-step-text{font-size:10px;color:var(--text3);white-space:nowrap;transition:color .2s}
.bd-step.act .bd-step-text{color:var(--primary);font-weight:600}
.bd-step-line{width:2px;height:24px;background:var(--bg3);transition:background .2s}
.bd-step-line.act{background:var(--primary)}
.bd-step-content{flex:1;padding:24px 20px;overflow-y:auto}
.bd-scene-header{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:var(--text);margin-bottom:16px}
.bd-scenes{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.bd-scene{background:var(--card);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--r2);padding:20px 14px;cursor:pointer;text-align:center;transition:all .2s}
.bd-scene:hover{border-color:var(--border-h);transform:translateY(-2px)}
.bd-scene.act{border-color:var(--primary);background:rgba(59,130,246,0.08)}
.bd-scene-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin:0 auto 10px;background:rgba(59,130,246,0.08)}
.bd-scene-icon svg{width:20px;height:20px;color:#60A5FA}
.bd-scene-name{font-size:12px;font-weight:600;color:var(--text2);transition:color .15s}
.bd-scene.act .bd-scene-name{color:var(--primary)}
.bd-right{display:flex;flex-direction:column;min-height:0}
.bd-preview{display:flex;flex-direction:column;flex:1;min-height:0}
.bd-preview-toolbar{display:flex;gap:6px;padding:12px 16px;border-bottom:1px solid var(--border)}
.bd-pv-btn{display:flex;align-items:center;gap:4px;padding:5px 10px;border-radius:var(--r);font-size:11px;color:var(--text3);border:1px solid var(--border);transition:all .15s}
.bd-pv-btn:hover{color:var(--primary);border-color:var(--border-h)}
.bd-code{flex:1;padding:16px 0;font-family:'JetBrains Mono','Fira Code',monospace;font-size:12px;line-height:1.9;overflow-y:auto;overflow-x:auto;background:var(--bg);min-height:300px}
.bd-code-line{display:flex;padding:0 16px}
.bd-code-line:hover{background:var(--bg-hover)}
.bd-code-num{width:32px;text-align:right;color:rgba(255,255,255,0.15);flex-shrink:0;user-select:none;padding-right:12px}
.bd-code-text{flex:1;white-space:pre-wrap;word-break:break-all}
.bd-c-subject{color:#F8FAFC}
.bd-c-action{color:#22D3EE}
.bd-c-camera{color:#60A5FA}
.bd-c-style{color:#A78BFA}
.bd-c-constraint{color:#34D399}
.bd-c-comment{color:rgba(255,255,255,0.25);font-style:italic}
.bd-c-heading{color:#F8FAFC;font-weight:700}
.bd-statusbar{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-top:1px solid var(--border);font-size:11px;color:var(--text3)}
.bd-status-hint{color:var(--text3)}
.bd-status-info{display:flex;gap:16px;align-items:center}
.bd-status-sync{color:var(--success)}
.bd-status-struct{color:var(--primary)}
.bd-status-chars b,.bd-status-tokens b{color:var(--text2)}

/* ===== 提示词知识库面板（Step 3） ===== */
.bd-step-panel{display:flex;flex-direction:column;min-height:0;flex:1}
.bd-kb-head{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:var(--text);margin-bottom:12px;flex-shrink:0}
.bd-kb-head svg{color:#F59E0B}
.bd-kb-source{margin-left:auto;font-size:10px;font-weight:400;color:var(--text3);padding:2px 8px;border:1px solid var(--border);border-radius:10px}
.bd-kb-search-wrap{margin-bottom:10px;flex-shrink:0}
.bd-kb-search{width:100%;padding:8px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--r);font-size:12px;color:var(--text);outline:none;transition:border-color .15s}
.bd-kb-search:focus{border-color:var(--primary)}
.bd-kb-search::placeholder{color:var(--text3)}
.bd-kb-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--border);flex-shrink:0}
.bd-kb-tab{display:flex;align-items:center;gap:5px;padding:5px 10px;font-size:11px;color:var(--text3);background:var(--bg);border:1px solid var(--border);border-radius:14px;cursor:pointer;transition:all .15s;white-space:nowrap}
.bd-kb-tab:hover{color:var(--text2);border-color:var(--border-h)}
.bd-kb-tab.act{color:var(--primary);border-color:rgba(59,130,246,0.4);background:rgba(59,130,246,0.08);font-weight:600}
.bd-kb-tab-name{white-space:nowrap}
.bd-kb-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 5px;font-size:10px;font-weight:600;background:var(--primary);color:#fff;border-radius:8px;line-height:1}
.bd-kb-items{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding-right:4px;min-height:120px;scrollbar-width:thin}
.bd-kb-items::-webkit-scrollbar{width:6px}
.bd-kb-items::-webkit-scrollbar-thumb{background:var(--border-h);border-radius:3px}
.bd-kb-items::-webkit-scrollbar-thumb:hover{background:var(--primary)}
.bd-kb-item{padding:10px 12px;background:var(--card);border:1px solid var(--border);border-radius:var(--r);cursor:pointer;transition:all .15s}
.bd-kb-item:hover{border-color:var(--border-h);background:var(--bg-hover)}
.bd-kb-item.act{border-color:var(--primary);background:rgba(59,130,246,0.06);box-shadow:0 0 0 1px var(--primary) inset}
.bd-kb-item-head{display:flex;align-items:center;gap:6px;margin-bottom:4px}
.bd-kb-item-cn{font-size:12px;font-weight:600;color:var(--text);flex:1;line-height:1.4}
.bd-kb-item-layer{font-size:9px;font-weight:600;padding:2px 6px;border-radius:8px;background:rgba(6,214,212,0.1);color:var(--mint);letter-spacing:.3px;flex-shrink:0}
.bd-kb-item-en{font-size:10px;color:var(--primary);font-family:monospace;margin-bottom:4px;line-height:1.4;word-break:break-all}
.bd-kb-item-desc{font-size:11px;color:var(--text2);line-height:1.55;margin-bottom:3px}
.bd-kb-item-scene{font-size:10px;color:var(--text3);line-height:1.4}
.bd-kb-empty{padding:20px;text-align:center;font-size:12px;color:var(--text3);background:var(--bg);border:1px dashed var(--border);border-radius:var(--r)}
.bd-kb-selected{margin-top:12px;padding-top:12px;border-top:1px solid var(--border);min-height:54px;max-height:140px;overflow-y:auto;flex-shrink:0;scrollbar-width:thin}
.bd-kb-selected::-webkit-scrollbar{width:6px}
.bd-kb-selected::-webkit-scrollbar-thumb{background:var(--border-h);border-radius:3px}
.bd-kb-custom{margin-top:10px;flex-shrink:0}
.bd-kb-custom--inline{margin-top:16px;padding:10px 12px;background:var(--card);border:1px solid var(--border);border-radius:var(--r);display:flex;flex-direction:column;gap:6px}
.bd-kb-custom-label{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.5px}
.bd-kb-custom-label svg{color:var(--mint)}
.bd-kb-custom-row{display:flex;align-items:center;gap:6px;padding:6px;background:var(--bg);border:1px dashed var(--border-h);border-radius:var(--r)}
.bd-kb-custom-input{flex:1;min-width:0;padding:6px 10px;background:var(--card);border:1px solid var(--border);border-radius:var(--r-sm,6px);font-size:12px;color:var(--text);outline:none;transition:border-color .15s}
.bd-kb-custom-input:focus{border-color:var(--primary)}
.bd-kb-custom-input::placeholder{color:var(--text3)}
.bd-kb-custom-layer{padding:6px 8px;background:var(--card);border:1px solid var(--border);border-radius:var(--r-sm,6px);font-size:11px;color:var(--text2);outline:none;cursor:pointer;flex-shrink:0;min-width:70px}
.bd-kb-custom-layer:focus{border-color:var(--primary)}
.bd-kb-custom-btn{padding:6px 14px;background:var(--primary);color:#fff;border:none;border-radius:var(--r-sm,6px);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;flex-shrink:0;line-height:1.4;min-height:30px}
.bd-kb-custom-btn:hover{background:var(--primary-h,rgba(59,130,246,0.85));transform:translateY(-1px)}
.bd-kb-custom-btn:active{transform:translateY(0)}
.bd-kb-chip.custom{border-style:dashed;border-color:var(--mint);color:var(--mint)}
.bd-kb-chip.custom::before{content:'✎';font-size:9px;opacity:.7;margin-right:2px}
.bd-kb-sel-empty{padding:10px;text-align:center;font-size:11px;color:var(--text3);background:var(--bg);border-radius:var(--r);border:1px dashed var(--border)}
.bd-kb-sel-empty b{color:var(--primary);font-weight:600}
.bd-kb-sel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.bd-kb-sel-head span{font-size:11px;color:var(--text3)}
.bd-kb-sel-head b{color:var(--primary);font-weight:700;margin:0 2px}
.bd-kb-sel-clear{padding:3px 8px;font-size:10px;color:var(--text3);background:transparent;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .15s}
.bd-kb-sel-clear:hover{color:#EF4444;border-color:rgba(239,68,68,0.4)}
.bd-kb-sel-group{display:flex;flex-wrap:wrap;align-items:center;gap:4px;margin-bottom:5px;padding:4px 0}
.bd-kb-sel-grouplabel{font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;flex-shrink:0;letter-spacing:.3px}
.bd-c-layer-1{color:#F8FAFC;background:rgba(248,250,252,0.08)}
.bd-c-layer-2{color:#22D3EE;background:rgba(34,211,238,0.1)}
.bd-c-layer-3{color:#60A5FA;background:rgba(96,165,250,0.1)}
.bd-c-layer-4{color:#A78BFA;background:rgba(167,139,250,0.1)}
.bd-c-layer-5{color:#34D399;background:rgba(52,211,153,0.1)}
.bd-kb-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;font-size:11px;color:var(--text);background:var(--card);border:1px solid var(--border-h);border-radius:12px;cursor:pointer;transition:all .15s;line-height:1.4}
.bd-kb-chip:hover{border-color:#EF4444;color:#EF4444}
.bd-kb-chip svg{flex-shrink:0;opacity:.6}
.bd-kb-chip:hover svg{opacity:1}
@media(max-width:768px){
  .bd-kb-selected{max-height:120px}
}

.lc-page{display:flex;min-height:calc(100vh - 56px);position:relative;overflow:hidden;background:transparent}
.lc-page::before{content:'';position:absolute;inset:0;background:var(--bg-page);background-image:var(--bg-page-glow),linear-gradient(180deg,var(--bg-page) 0%,var(--bg-page-2) 100%);pointer-events:none;z-index:0}
html.dark .lc-page::before,html[data-theme="dark"] .lc-page::before{background-image:linear-gradient(180deg,#050A18 0%,#0F172A 60%)}
.lc-page::after{content:'';position:absolute;inset:0;background-image:radial-gradient(1px 1px at 10% 15%,var(--grid-line) 50%,transparent 50%),radial-gradient(1px 1px at 35% 55%,var(--grid-line) 50%,transparent 50%),radial-gradient(1px 1px at 60% 20%,var(--grid-line) 50%,transparent 50%),radial-gradient(1px 1px at 80% 70%,var(--grid-line) 50%,transparent 50%),radial-gradient(1.5px 1.5px at 25% 80%,var(--bg-primary-soft) 50%,transparent 50%),radial-gradient(1px 1px at 70% 40%,var(--grid-line) 50%,transparent 50%),radial-gradient(1.5px 1.5px at 50% 90%,var(--bg-primary-soft) 50%,transparent 50%);pointer-events:none;z-index:0}
.lc-sidebar{width:220px;background:var(--bg);border-right:1px solid var(--border);padding:16px 0;display:flex;flex-direction:column;flex-shrink:0;position:relative;z-index:1}
.lc-sb-brand{display:flex;align-items:center;gap:8px;padding:0 16px 16px;border-bottom:1px solid var(--border);margin-bottom:8px}
.lc-sb-brand span{font-size:13px;font-weight:700;color:var(--text)}
.lc-sb-nav{flex:1}
.lc-sb-item{display:flex;align-items:center;gap:10px;padding:8px 16px;font-size:12px;color:var(--text3);width:100%;text-align:left;transition:all .15s}
.lc-sb-item:hover{background:var(--bg-hover);color:var(--text2)}
.lc-sb-item.act{background:var(--primary);color:#fff;font-weight:500}
.lc-sb-item svg{width:16px;height:16px;flex-shrink:0}
.lc-sb-bottom{margin:12px 16px;padding:14px;background:var(--bg-soft);border:1px solid var(--border);border-radius:var(--r)}
.lc-sb-goal{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text3);margin-bottom:8px}
.lc-sb-goal svg{flex-shrink:0}
.lc-sb-goal-num{margin-left:auto;color:var(--text2);font-weight:600}
.lc-sb-progress{height:4px;background:var(--bg3);border-radius:2px;margin-bottom:10px;overflow:hidden}
.lc-sb-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--mint));border-radius:2px}
.lc-sb-points{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text3)}
.lc-sb-points b{color:var(--purple);font-weight:700}
.lc-main{flex:1;padding:28px 32px;overflow-y:auto;position:relative;z-index:1}
.lc-header{margin-bottom:28px}
.lc-title{font-family:var(--font);font-size:32px;font-weight:800;color:var(--text);letter-spacing:-0.5px;line-height:1.2}
.lc-subtitle{font-family:var(--font);font-size:13px;color:var(--primary);font-weight:600;margin-top:6px;letter-spacing:1.5px;text-transform:uppercase}
.lc-desc{font-size:14px;color:var(--text2);margin-top:10px;line-height:1.6;max-width:720px}
.lc-progress-bar{display:flex;align-items:center;gap:0;margin-bottom:32px;position:relative}
.lc-pb-node{display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;position:relative;z-index:1}
.lc-pb-dot{width:14px;height:14px;border-radius:50%;background:var(--bg3);border:2px solid var(--border);transition:all .2s}
.lc-pb-node.done .lc-pb-dot{background:var(--primary);border-color:var(--primary)}
.lc-pb-node.current .lc-pb-dot{background:var(--mint);border-color:var(--mint);box-shadow:0 0 12px rgba(6,214,212,0.4)}
.lc-pb-label{font-size:11px;font-weight:500;color:var(--text2);white-space:nowrap;letter-spacing:0.2px}
.lc-pb-node.current .lc-pb-label{color:var(--primary);font-weight:700}
.lc-pb-node.done .lc-pb-label{color:var(--text)}
.lc-pb-current-tag{position:absolute;top:-18px;font-size:9px;color:var(--mint);font-weight:600;letter-spacing:0.5px}
.lc-pb-line{flex:1;height:2px;background:var(--border);transition:background .2s}
.lc-pb-line.done{background:var(--primary)}
.lc-content{display:grid;grid-template-columns:1fr 1.2fr;gap:24px}
.lc-chapters{background:var(--card);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--r2);padding:24px;box-shadow:var(--shadow)}
.lc-ch-title{font-family:var(--font);font-size:18px;font-weight:800;color:var(--text);margin-bottom:4px;letter-spacing:-0.2px}
.lc-ch-progress-ring{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.lc-ch-ring{width:48px;height:48px;position:relative}
.lc-ch-ring svg{transform:rotate(-90deg)}
.lc-ch-ring-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--text)}
.lc-ch-ring-label{font-size:12px;color:var(--text3)}
.lc-ch-list{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.lc-ch-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r);font-size:12px;cursor:pointer;transition:all .15s;border:1px solid transparent}
.lc-ch-item:hover{background:var(--bg-hover)}
.lc-ch-item.active{background:rgba(59,130,246,0.08);border-color:rgba(59,130,246,0.2);color:var(--primary);font-weight:600}
.lc-ch-item.done{color:var(--success)}
.lc-ch-item.locked{color:var(--text3);opacity:0.5;cursor:default}
.lc-ch-item-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.lc-ch-item-icon svg{width:14px;height:14px}
.lc-ch-item-label{flex:1}
.lc-ch-item-status{font-size:10px;color:var(--text3)}
.lc-ch-item.active .lc-ch-item-status{color:var(--primary)}
.lc-ch-item.done .lc-ch-item-status{color:var(--success)}
.lc-ch-actions{display:flex;align-items:center;gap:12px;margin-top:4px}
.lc-ch-quiz{padding:8px 16px;border-radius:var(--r);background:var(--primary);color:#fff;font-size:12px;font-weight:500;cursor:pointer}
.lc-ch-quiz:hover{background:var(--primary-h)}
.lc-ch-points{font-size:11px;color:var(--purple)}
.lc-video{display:flex;flex-direction:column;gap:16px}
.lc-vd-player{position:relative;background:var(--bg);border:1px solid var(--border);border-radius:var(--r2);overflow:hidden;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center}
.lc-vd-player::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(59,130,246,0.06) 0%,transparent 70%);pointer-events:none}
.lc-vd-play{width:56px;height:56px;border-radius:50%;background:rgba(59,130,246,0.2);border:1px solid rgba(59,130,246,0.3);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;z-index:1}
.lc-vd-play:hover{background:rgba(59,130,246,0.3);transform:scale(1.05)}
.lc-vd-play svg{width:24px;height:24px;color:#60A5FA;margin-left:2px}
.lc-vd-controls{display:flex;align-items:center;gap:12px;padding:8px 14px;background:rgba(11,17,32,0.9);border:1px solid var(--border);border-radius:var(--r);font-size:11px;color:var(--text3)}
.lc-vd-time{font-family:monospace;color:var(--text2)}
.lc-vd-speed{margin-left:auto;padding:2px 8px;border-radius:4px;background:rgba(59,130,246,0.1);color:var(--primary);font-weight:500;cursor:pointer}
.lc-vd-info{background:var(--card);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--r2);padding:18px}
.lc-vd-info-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:8px}
.lc-vd-info-text{font-size:12px;color:var(--text3);line-height:1.7;margin-bottom:12px}
.lc-vd-notes{padding:7px 14px;border-radius:var(--r);font-size:12px;color:var(--primary);border:1px solid rgba(59,130,246,0.2);background:rgba(59,130,246,0.05);cursor:pointer;transition:all .15s}
.lc-vd-notes:hover{border-color:var(--primary);background:rgba(59,130,246,0.1)}
.scene-card{break-inside:avoid;margin-bottom:16px;background:var(--card);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--r2);padding:20px;cursor:pointer;transition:border-color .2s ease}
.scene-card:hover{border-color:var(--border-h)}
.scene-card-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.scene-card-icon svg{width:18px;height:18px}
.scene-card-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}
.scene-card-desc{font-size:12px;color:var(--text3);margin-bottom:12px}
.scene-card-footer{display:flex;justify-content:space-between;font-size:11px;color:var(--text3)}
.scene-progress{width:100%;height:3px;background:var(--border);border-radius:2px;margin-top:10px;overflow:hidden}
.scene-progress-fill{height:100%;background:var(--purple);border-radius:2px;transition:width .3s}

.wfc-page{display:flex;min-height:calc(100vh - 56px);background:transparent;position:relative}
.wfc-page::before{content:'';position:absolute;inset:0;background:var(--bg-page);background-image:var(--bg-page-glow),linear-gradient(180deg,var(--bg-page) 0%,var(--bg-page-2) 100%);pointer-events:none;z-index:0}
html.dark .wfc-page::before,html[data-theme="dark"] .wfc-page::before{background-image:linear-gradient(180deg,#080C14 0%,#0F172A 50%)}
.wfc-page > *{position:relative;z-index:1}
.wfc-sidebar{width:210px;background:var(--bg);border-right:1px solid var(--border);padding:16px 0;display:flex;flex-direction:column;flex-shrink:0}
.wfc-sb-brand{display:flex;align-items:center;gap:8px;padding:0 16px 16px;border-bottom:1px solid var(--border);margin-bottom:8px}
.wfc-sb-brand span{font-size:13px;font-weight:700;color:var(--text)}
.wfc-sb-nav{flex:1}
.wfc-sb-item{display:flex;align-items:center;gap:10px;padding:8px 16px;font-size:12px;color:var(--text3);width:100%;text-align:left;transition:all .15s}
.wfc-sb-item:hover{background:var(--bg-hover);color:var(--text2)}
.wfc-sb-item.act{background:var(--primary);color:#fff;font-weight:500}
.wfc-sb-item svg{width:16px;height:16px;flex-shrink:0}
.wfc-sb-explore{margin:12px 14px;padding:14px;background:linear-gradient(135deg,rgba(139,92,246,0.12),rgba(59,130,246,0.08));border:1px solid rgba(139,92,246,0.2);border-radius:var(--r2)}
.wfc-sb-explore-title{font-size:12px;font-weight:600;color:var(--text);margin-bottom:4px}
.wfc-sb-explore-desc{font-size:10px;color:var(--text3);margin-bottom:10px}
.wfc-sb-explore-btn{width:100%;padding:6px;border-radius:var(--r);background:linear-gradient(135deg,var(--purple),var(--primary));color:#fff;font-size:11px;font-weight:500;cursor:pointer}
.wfc-sb-user{display:flex;align-items:center;gap:8px;padding:12px 16px;border-top:1px solid var(--border);font-size:12px;color:var(--text3)}
.wfc-sb-user b{color:var(--purple);font-weight:700}
.wfc-main{flex:1;padding:24px 28px;overflow-y:auto}
.wfc-header{margin-bottom:20px}
.wfc-title{font-family:var(--font);font-size:24px;font-weight:800;color:var(--text);letter-spacing:-0.3px;line-height:1.3}
.wfc-desc{font-size:14px;color:var(--text2);margin-top:6px;line-height:1.6}
.wfc-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.wfc-search{display:flex;align-items:center;gap:6px;padding:7px 12px;background:var(--card);border:1px solid var(--border);border-radius:var(--r);width:220px}
.wfc-search svg{flex-shrink:0;color:var(--text3);width:14px;height:14px}
.wfc-search input{border:none;background:none;flex:1;font-size:12px;color:var(--text);outline:none}
.wfc-bell{padding:6px;border-radius:var(--r);color:var(--text3);border:1px solid var(--border);transition:all .15s}
.wfc-bell:hover{color:var(--text2);border-color:var(--border-h)}
.wfc-create-btn{margin-left:auto;padding:7px 16px;border-radius:var(--r);background:linear-gradient(135deg,var(--purple),#6D28D9);color:#fff;font-size:12px;font-weight:500;transition:opacity .15s}
.wfc-create-btn:hover{opacity:0.9}
.wfc-tabs{display:flex;align-items:center;gap:4px;margin-bottom:20px}
.wfc-tab{padding:6px 14px;border-radius:var(--r);font-size:12px;font-weight:500;color:var(--text3);transition:all .15s}
.wfc-tab:hover{color:var(--text2)}
.wfc-tab.act{background:var(--primary);color:#fff}
.wfc-tabs-right{display:flex;align-items:center;gap:8px;margin-left:auto}
.wfc-sort{padding:4px 8px;border-radius:var(--r);background:var(--card);border:1px solid var(--border);color:var(--text3);font-size:11px;outline:none}
.wfc-flows{display:flex;flex-direction:column;gap:16px}
.wfc-flow{background:var(--card);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--r2);padding:20px 24px;transition:border-color .2s ease}
.wfc-flow:hover{border-color:var(--border-h)}
.wfc-flow-head{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.wfc-flow-title{font-size:15px;font-weight:700;color:var(--text);flex:1}
.wfc-flow-status{font-size:10px;padding:3px 10px;border-radius:8px;font-weight:500}
.wfc-flow-status.running{background:rgba(59,130,246,0.1);color:var(--primary)}
.wfc-flow-status.idle{background:rgba(100,116,139,0.1);color:var(--text3)}
.wfc-flow-more{padding:4px;border-radius:var(--r);color:var(--text3);cursor:pointer;transition:color .15s}
.wfc-flow-more:hover{color:var(--text2)}
.wfc-chain{display:flex;align-items:center;gap:0;overflow-x:auto;padding-bottom:4px}
.wfc-chain-node{display:flex;align-items:center;gap:0;flex-shrink:0}
.wfc-step{padding:10px 18px;border-radius:var(--r);font-size:12px;font-weight:600;text-align:center;min-width:80px;transition:all .2s;cursor:pointer;position:relative}
.wfc-step.done{background:rgba(59,130,246,0.1);color:var(--primary);border:1px solid rgba(59,130,246,0.2)}
.wfc-step.current{background:rgba(6,214,212,0.1);color:var(--mint);border:1px solid rgba(6,214,212,0.25);box-shadow:0 0 12px rgba(6,214,212,0.1)}
.wfc-step.pending{background:rgba(30,41,59,0.5);color:var(--text3);border:1px solid var(--border)}
.wfc-arrow{display:flex;align-items:center;padding:0 4px;flex-shrink:0}
.wfc-arrow-solid{color:var(--primary)}
.wfc-arrow-dashed{color:var(--text3);opacity:0.4}
.wfc-arrow svg{width:16px;height:16px}

.cs-page{display:flex;min-height:calc(100vh - 56px);position:relative}
.cs-sidebar{width:190px;background:var(--bg);border-right:1px solid var(--border);padding:16px 0;display:flex;flex-direction:column;flex-shrink:0}
.cs-sb-nav{flex:1}
.cs-sb-item{display:flex;align-items:center;gap:10px;padding:8px 16px;font-size:12px;color:var(--text3);width:100%;text-align:left;transition:all .15s}
.cs-sb-item:hover{background:var(--bg-hover);color:var(--text2)}
.cs-sb-item.act{background:var(--primary);color:#fff;font-weight:500}
.cs-sb-item svg{width:16px;height:16px;flex-shrink:0}
.cs-sb-pro{margin:12px 14px;padding:14px;background:linear-gradient(135deg,rgba(139,92,246,0.12),rgba(59,130,246,0.06));border:1px solid rgba(139,92,246,0.2);border-radius:var(--r2);text-align:center}
.cs-sb-pro span{display:block;font-size:11px;color:var(--text2);margin:6px 0 10px}
.cs-sb-pro-btn{width:100%;padding:6px;border-radius:var(--r);background:var(--primary);color:#fff;font-size:11px;font-weight:500;cursor:pointer}
.cs-sb-community{margin:0 14px;padding:14px;border-top:1px solid var(--border)}
.cs-sb-community-title{font-size:12px;font-weight:600;color:var(--text);margin-bottom:8px}
.cs-sb-community-members{font-size:11px;color:var(--text3)}
.cs-sb-avatars{display:flex;margin-top:6px}
.cs-sb-av{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:600;color:#fff;margin-right:-6px;border:2px solid var(--bg)}
.cs-main{flex:1;padding:20px 24px;overflow-y:auto;min-width:0}
.cs-search{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--card);border:1px solid var(--border);border-radius:var(--r);margin-bottom:16px}
.cs-search svg{flex-shrink:0;color:var(--text3);width:14px;height:14px}
.cs-search input{border:none;background:none;flex:1;font-size:12px;color:var(--text);outline:none}
.cs-search-count{font-size:11px;color:var(--text3);white-space:nowrap}
.cs-tabs{display:flex;gap:4px;margin-bottom:20px}
.cs-tab{padding:6px 16px;border-radius:var(--r);font-size:12px;font-weight:500;color:var(--text3);transition:all .15s}
.cs-tab:hover{color:var(--text2)}
.cs-tab.act{background:var(--primary);color:#fff}
.cs-grid{column-count:2;column-gap:16px}
.cs-card{break-inside:avoid;margin-bottom:16px;background:var(--card);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--r2);overflow:hidden;transition:border-color .2s ease,transform .2s ease}
.cs-card:hover{border-color:var(--border-h);transform:translateY(-2px)}
.cs-card-head{display:flex;align-items:center;gap:8px;padding:12px 14px 0}
.cs-card-av{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:#fff;flex-shrink:0}
.cs-card-user{font-size:12px;font-weight:600;color:var(--text);flex:1}
.cs-card-featured{padding:2px 8px;border-radius:4px;font-size:9px;font-weight:600;background:var(--primary);color:#fff}
.cs-card-img{width:100%;display:block;min-height:120px;max-height:220px;object-fit:cover}
.cs-card-body{padding:12px 14px 14px}
.cs-card-text{font-size:13px;color:var(--text2);line-height:1.6;margin-bottom:10px}
.cs-card-actions{display:flex;gap:16px;font-size:11px;color:var(--text3)}
.cs-card-action{display:flex;align-items:center;gap:4px;cursor:pointer;transition:color .15s}
.cs-card-action:hover{color:var(--primary)}
.cs-card-action.liked{color:var(--danger)}
.cs-card-action svg{width:13px;height:13px}
.cs-right{width:220px;padding:20px 16px;flex-shrink:0;border-left:1px solid var(--border)}
.cs-rt-card{background:var(--card);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--r2);padding:16px;margin-bottom:16px}
.cs-rt-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:12px}
.cs-rt-topic{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:12px;color:var(--text3);cursor:pointer;transition:color .15s}
.cs-rt-topic:hover{color:var(--text2)}
.cs-rt-topic-hash{color:var(--primary);font-weight:600}
.cs-rt-creator{display:flex;align-items:center;gap:8px;padding:6px 0;cursor:pointer}
.cs-rt-creator-av{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:#fff;flex-shrink:0}
.cs-rt-creator-info{flex:1}
.cs-rt-creator-name{font-size:12px;font-weight:600;color:var(--text)}
.cs-rt-creator-works{font-size:10px;color:var(--text3)}
.cs-fab{position:fixed;bottom:28px;right:28px;width:52px;height:52px;border-radius:50%;background:var(--mint);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 0 20px rgba(6,214,212,0.3);cursor:pointer;transition:transform .2s,box-shadow .2s;z-index:100}
.cs-fab:hover{transform:scale(1.08);box-shadow:0 0 28px rgba(6,214,212,0.45)}

.pv-page{min-height:calc(100vh - 56px);position:relative;overflow:hidden;background:transparent;padding:0}
html.dark .pv-page,html[data-theme="dark"] .pv-page{background:linear-gradient(180deg,#050A18 0%,#0F172A 50%,#0B1120 100%)}
.pv-page::before{content:'';position:absolute;inset:0;background-image:radial-gradient(1px 1px at 10% 20%,rgba(255,255,255,0.1) 50%,transparent 50%),radial-gradient(1px 1px at 30% 60%,rgba(255,255,255,0.07) 50%,transparent 50%),radial-gradient(1px 1px at 55% 15%,rgba(255,255,255,0.08) 50%,transparent 50%),radial-gradient(1px 1px at 75% 45%,rgba(255,255,255,0.06) 50%,transparent 50%),radial-gradient(1.5px 1.5px at 20% 80%,rgba(59,130,246,0.12) 50%,transparent 50%),radial-gradient(1px 1px at 65% 75%,rgba(255,255,255,0.05) 50%,transparent 50%),radial-gradient(1.5px 1.5px at 85% 30%,rgba(6,214,212,0.08) 50%,transparent 50%),radial-gradient(1px 1px at 45% 90%,rgba(255,255,255,0.06) 50%,transparent 50%);pointer-events:none;z-index:0}
.pv-planet{position:absolute;right:-120px;top:50%;transform:translateY(-50%);width:360px;height:360px;border-radius:50%;background:radial-gradient(circle at 40% 40%,rgba(139,92,246,0.08),rgba(59,130,246,0.04) 50%,transparent 70%);pointer-events:none;z-index:0}
.pv-nav{display:flex;align-items:center;padding:16px 40px;border-bottom:1px solid var(--border);position:relative;z-index:1}
.pv-nav-brand{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--text)}
.pv-nav-links{display:flex;gap:24px;margin-left:48px}
.pv-nav-links a{font-size:13px;color:var(--text3);text-decoration:none;transition:color .15s}
.pv-nav-links a:hover{color:var(--text)}
.pv-nav-cur{color:var(--primary)!important;font-weight:600;border-bottom:2px solid var(--primary);padding-bottom:2px}
.pv-nav-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.pv-nav-refresh{padding:6px;border-radius:var(--r);color:var(--text3);transition:color .15s}
.pv-nav-refresh:hover{color:var(--text)}
.pv-nav-login{padding:6px 16px;border-radius:var(--r);border:1px solid rgba(255,255,255,0.2);color:var(--text);font-size:12px;font-weight:500;transition:all .15s}
.pv-nav-login:hover{border-color:rgba(255,255,255,0.4)}
.pv-content{position:relative;z-index:1;padding:48px 40px 60px;max-width:900px;margin:0 auto}
.pv-header{text-align:center;margin-bottom:40px}
.pv-title{font-size:28px;font-weight:800;color:var(--text);letter-spacing:-0.5px}
.pv-subtitle{font-size:14px;color:var(--text3);margin-top:8px}
.pv-cards{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:32px}
.pv-card{background:rgba(30,41,59,0.6);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:16px;padding:32px 28px;display:flex;flex-direction:column;position:relative;transition:border-color .2s ease,box-shadow .2s ease}
.pv-card-pro{border-color:rgba(59,130,246,0.3);box-shadow:0 0 30px rgba(59,130,246,0.1),0 0 60px rgba(59,130,246,0.05)}
.pv-card-pro:hover{box-shadow:0 0 40px rgba(59,130,246,0.18),0 0 80px rgba(59,130,246,0.08)}
.pv-card-popular{position:absolute;top:-12px;left:24px;display:flex;align-items:center;gap:4px;padding:4px 12px;border-radius:8px;background:rgba(139,92,246,0.15);color:var(--purple);font-size:11px;font-weight:600}
.pv-card-name{font-size:22px;font-weight:800;color:var(--text)}
.pv-card-desc{font-size:12px;color:var(--text3);margin-top:4px;margin-bottom:20px}
.pv-card-price{font-size:36px;font-weight:800;color:var(--text);margin-bottom:24px}
.pv-card-price span{font-size:14px;font-weight:400;color:var(--text3)}
.pv-features{list-style:none;padding:0;margin:0 0 28px;flex:1}
.pv-features li{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--text2);padding:6px 0}
.pv-features li svg{flex-shrink:0;margin-top:1px}
.pv-card-btn{width:100%;padding:12px;border-radius:var(--r2);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}
.pv-card-btn-free{background:rgba(30,41,59,0.8);color:var(--text2);border:1px solid var(--border)}
.pv-card-btn-free:hover{border-color:var(--border-h);color:var(--text)}
.pv-card-btn-pro{background:linear-gradient(135deg,var(--primary),var(--mint));color:#fff;border:none}
.pv-card-btn-pro:hover{opacity:0.9;box-shadow:0 0 20px rgba(59,130,246,0.2)}
.pv-team-link{text-align:center;font-size:13px;color:var(--purple);cursor:pointer;transition:opacity .15s;display:flex;align-items:center;justify-content:center;gap:4px}
.pv-team-link:hover{opacity:0.8}

.sopd-page{min-height:calc(100vh - 56px);display:flex;flex-direction:column;padding:0;position:relative;background:var(--bg)}
.sopd-body{display:grid;grid-template-columns:3fr 2fr;flex:1;min-height:0}
.sopd-left{position:relative;overflow:hidden;background:#080C14}
.sopd-img{width:100%;height:100%;object-fit:cover;display:block;min-height:400px}
.sopd-right{display:flex;flex-direction:column;gap:16px;padding:24px;overflow-y:auto}
.sopd-prompt{background:rgba(15,23,42,0.7);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--r2);padding:20px;position:relative}
.sopd-prompt-label{font-size:10px;font-weight:700;color:var(--primary);letter-spacing:2px;margin-bottom:14px}
.sopd-code{font-family:'JetBrains Mono','Fira Code',monospace;font-size:12px;line-height:1.9;color:var(--text2);white-space:pre-wrap;word-break:break-all;overflow-x:auto}
.sopd-code .sopd-h{color:var(--text);font-weight:700}
.sopd-code .sopd-k{color:#94A3B8}
.sopd-code .sopd-v{color:var(--text2)}
.sopd-tips{background:linear-gradient(135deg,rgba(139,92,246,0.1),rgba(59,130,246,0.06));border:1px solid rgba(139,92,246,0.15);border-radius:var(--r2);padding:20px}
.sopd-tips-title{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--text);margin-bottom:12px}
.sopd-tips-title svg{color:var(--gold)}
.sopd-tips-list{list-style:none;padding:0;margin:0}
.sopd-tips-list li{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:var(--text3);padding:6px 0;line-height:1.6}
.sopd-tips-list li::before{content:'';display:inline-block;width:4px;height:4px;border-radius:50%;background:var(--text3);flex-shrink:0;margin-top:7px}
.sopd-nav{display:flex;align-items:center;gap:12px;padding:14px 24px;border-top:1px solid var(--border);background:rgba(11,17,32,0.9)}
.sopd-nav-btn{display:flex;align-items:center;gap:4px;padding:7px 14px;border-radius:var(--r);font-size:12px;color:var(--text3);border:1px solid var(--border);transition:all .15s}
.sopd-nav-btn:hover{color:var(--text2);border-color:var(--border-h)}
.sopd-page-num{font-size:12px;color:var(--text3);font-family:monospace;flex:1;text-align:center}
.sopd-copy-btn{padding:7px 18px;border-radius:var(--r);background:var(--primary);color:#fff;font-size:12px;font-weight:500;transition:all .15s}
.sopd-copy-btn:hover{background:var(--primary-h)}

.mine-page{padding:40px;max-width:800px;margin:0 auto;width:100%}
.mine-header{margin-bottom:24px}
.mine-title{font-size:22px;font-weight:700;color:var(--text)}
.mine-empty{text-align:center;padding:60px 0;color:var(--text3)}
.mine-empty svg{margin:0 auto 16px;width:40px;height:40px}
.mine-empty p{font-size:13px}
.setting-list{max-width:600px}
.setting-item{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--border)}
.setting-item-label{font-size:13px;color:var(--text)}
.setting-item-desc{font-size:11px;color:var(--text3);margin-top:2px}
.setting-toggle{width:40px;height:22px;border-radius:11px;background:var(--bg3);position:relative;cursor:pointer;transition:background .2s}
.setting-toggle.on{background:var(--primary)}
.setting-toggle::after{content:'';position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:var(--bg);transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,0.3)}
.setting-toggle.on::after{transform:translateX(18px)}

.back-to-top{position:fixed;bottom:24px;right:24px;width:36px;height:36px;border-radius:50%;background:var(--primary);color:#fff;display:none;align-items:center;justify-content:center;z-index:800;transition:opacity .2s}
.back-to-top.show{display:flex}
.back-to-top svg{width:16px;height:16px}

.mobile-menu-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:1999;display:none;transition:opacity .25s}
.mobile-menu-overlay.show{display:block}
.mobile-menu{position:fixed;top:56px;left:0;bottom:0;width:260px;background:var(--bg2);border-right:1px solid var(--border);z-index:2000;transform:translateX(-100%);transition:transform .25s ease;padding:16px 0}
.mobile-menu.show{transform:translateX(0)}
.mobile-menu-item{display:flex;align-items:center;gap:10px;padding:10px 20px;font-size:14px;color:var(--text2);transition:all .15s}
.mobile-menu-item:hover{background:var(--bg-hover);color:var(--text)}
.mobile-menu-item.act{color:var(--primary);font-weight:600;background:rgba(59,130,246,0.08)}
.mobile-menu-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}
.mobile-menu-brand{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--text)}
.mobile-menu-close{padding:4px;color:var(--text3);transition:color .15s}
.mobile-menu-close:hover{color:var(--text)}
.mobile-menu-nav{padding:8px 0}
.mobile-menu-divider{height:1px;background:var(--border);margin:8px 20px}

.browse-page{padding:40px;max-width:1280px;margin:0 auto;width:100%}
.browse-header{margin-bottom:24px}
.browse-title{font-size:22px;font-weight:700;color:var(--text)}
.browse-subtitle{font-size:13px;color:var(--text3);margin-top:4px}
.browse-tp-grid{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:24px}
.browse-tp-item{padding:8px 16px;border-radius:var(--r);background:var(--card);border:1px solid var(--border);cursor:pointer;text-align:center;transition:border-color .15s}
.browse-tp-item:hover{border-color:var(--border-h)}
.browse-tp-icon{font-size:18px;margin-bottom:4px}
.browse-tp-name{font-size:12px;font-weight:500;color:var(--text2)}
.browse-tp-count{font-size:10px;color:var(--text3)}
.browse-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}

.profile-page{padding:40px;max-width:900px;margin:0 auto;width:100%}
.profile-header-bg{height:160px;border-radius:var(--r2);background:linear-gradient(135deg,rgba(59,130,246,0.15),rgba(139,92,246,0.1));margin-bottom:0;position:relative;overflow:hidden}
.profile-avatar{width:80px;height:80px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;margin:0 0 0 32px;position:relative;z-index:1;border:4px solid var(--bg)}
.profile-info{padding:20px 32px 0}
.profile-name{font-size:22px;font-weight:700;color:var(--text)}
.profile-bio{font-size:13px;color:var(--text3);margin-top:6px}
.profile-stats{display:flex;gap:32px;margin-top:14px;font-size:12px;color:var(--text3)}
.profile-stats b{color:var(--text);font-weight:600}
.profile-tabs{display:flex;gap:4px;margin:28px 0 20px}
.profile-tab{padding:6px 16px;border-radius:var(--r);font-size:12px;color:var(--text3);transition:all .15s}
.profile-tab:hover{color:var(--text2)}
.profile-tab.act,.profile-tab.active{background:var(--primary);color:#fff}
.profile-posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}
.profile-post-item{background:var(--card);border:1px solid var(--border);border-radius:var(--r2);overflow:hidden;cursor:pointer;transition:all .2s}
.profile-post-item:hover{border-color:var(--border-h);transform:translateY(-2px)}
.profile-post-thumb{height:120px;background-size:cover;background-position:center}
.profile-post-info{padding:10px 12px}
.profile-post-title{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.profile-post-meta{font-size:10px;color:var(--text3);margin-top:4px;display:flex;align-items:center;gap:4px}
.profile-about-section{padding:20px 0}
.profile-about-row{display:flex;padding:10px 0;border-bottom:1px solid var(--border);font-size:13px}
.profile-about-label{color:var(--text3);width:100px;flex-shrink:0}
.profile-about-value{color:var(--text)}
.profile-edit-btn{padding:6px 16px;border-radius:var(--r);font-size:12px;font-weight:500;background:transparent;border:1px solid var(--border);color:var(--text2);cursor:pointer;transition:all .15s}
.profile-edit-btn:hover{border-color:var(--primary);color:var(--primary)}

/* ===== 个人主页增强样式 ===== */
.profile-page{padding:0;max-width:960px;margin:0 auto;width:100%;min-height:100vh;position:relative}
.profile-cover{height:200px;border-radius:0;background:linear-gradient(135deg,#1e3a8a 0%,#3b82f6 50%,#06b6d4 100%);position:relative;overflow:hidden}
.profile-cover::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 20% 30%,rgba(139,92,246,0.4) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(6,214,212,0.3) 0%,transparent 50%)}
.profile-cover::after{content:'';position:absolute;inset:0;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='40' height='40' viewBox='0 0 40 40'><circle cx='20' cy='20' r='1' fill='rgba(255,255,255,0.08)'/></svg>");opacity:0.6}
.profile-cover-actions{position:absolute;top:16px;right:16px;display:flex;gap:8px;z-index:2}
.profile-cover-btn{width:36px;height:36px;border-radius:50%;background:rgba(15,23,42,0.5);backdrop-filter:blur(8px);border:1px solid var(--border);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-size:14px}
.profile-cover-btn:hover{background:rgba(15,23,42,0.7);transform:translateY(-1px)}
.profile-hero{position:relative;padding:0 32px;margin-top:-56px;z-index:1}
.profile-hero-inner{display:flex;align-items:flex-end;gap:20px;flex-wrap:wrap}
.profile-avatar-lg{width:112px;height:112px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--mint));color:#fff;display:flex;align-items:center;justify-content:center;font-size:42px;font-weight:700;border:5px solid var(--bg);box-shadow:0 8px 24px rgba(0,0,0,0.3);flex-shrink:0;position:relative}
.profile-avatar-status{position:absolute;bottom:6px;right:6px;width:20px;height:20px;border-radius:50%;background:var(--success);border:3px solid var(--bg);box-shadow:0 0 0 2px rgba(16,185,129,0.2)}
.profile-hero-info{flex:1;min-width:200px;padding-bottom:8px}
.profile-hero-name{font-size:24px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.profile-hero-tag{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600;background:linear-gradient(135deg,rgba(245,158,11,0.2),rgba(239,68,68,0.2));color:var(--gold);border:1px solid rgba(245,158,11,0.3);text-transform:uppercase;letter-spacing:0.5px}
.profile-hero-bio{font-size:13px;color:var(--text2);margin-top:6px;line-height:1.5}
.profile-hero-meta{display:flex;flex-wrap:wrap;gap:14px;margin-top:8px;font-size:11px;color:var(--text3)}
.profile-hero-meta span{display:inline-flex;align-items:center;gap:4px}
.profile-hero-actions{display:flex;gap:8px;padding-bottom:8px;flex-wrap:wrap}
.profile-btn{padding:8px 16px;border-radius:var(--r);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:6px;border:1px solid transparent;white-space:nowrap}
.profile-btn-primary{background:var(--primary);color:#fff}
.profile-btn-primary:hover{background:var(--primary-h);transform:translateY(-1px);box-shadow:0 4px 12px rgba(59,130,246,0.3)}
.profile-btn-secondary{background:var(--bg-hover);color:var(--text2);border-color:var(--border)}
.profile-btn-secondary:hover{background:var(--bg-hover-strong);color:var(--text);border-color:var(--border-h)}
.profile-btn-ghost{background:transparent;color:var(--text3)}
.profile-btn-ghost:hover{color:var(--text2)}

/* 快速统计卡 */
.profile-quick-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding:24px 32px 0}
.profile-stat-card{background:linear-gradient(135deg,rgba(30,41,59,0.6),rgba(15,23,42,0.4));border:1px solid var(--border);border-radius:var(--r3);padding:16px;transition:all .2s;cursor:pointer;position:relative;overflow:hidden}
.profile-stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--stat-color,var(--primary));opacity:0.6;transition:opacity .2s}
.profile-stat-card:hover{border-color:var(--stat-color,var(--primary));transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.2)}
.profile-stat-card:hover::before{opacity:1}
.profile-stat-icon{width:36px;height:36px;border-radius:var(--r);background:var(--bg-hover);display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:8px}
.profile-stat-num{font-size:24px;font-weight:700;color:var(--text);line-height:1.2}
.profile-stat-label{font-size:11px;color:var(--text3);margin-top:2px;letter-spacing:0.3px}
.profile-stat-trend{font-size:10px;margin-top:4px;display:inline-flex;align-items:center;gap:2px;color:var(--success)}
.profile-stat-trend.down{color:var(--danger)}

/* Tabs 容器 */
.profile-tabs-container{padding:24px 32px 0}
.profile-tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);overflow-x:auto;scrollbar-width:none}
.profile-tabs::-webkit-scrollbar{display:none}
.profile-tab{padding:10px 16px;font-size:13px;font-weight:500;color:var(--text3);cursor:pointer;transition:all .15s;position:relative;white-space:nowrap;border:none;background:transparent}
.profile-tab:hover{color:var(--text2)}
.profile-tab.active{color:var(--primary)}
.profile-tab.active::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--primary);border-radius:2px 2px 0 0}
.profile-tab-count{font-size:10px;background:var(--bg-hover-strong);color:var(--text3);padding:1px 6px;border-radius:8px;margin-left:4px}
.profile-tab.active .profile-tab-count{background:rgba(59,130,246,0.15);color:var(--primary)}

/* 标签内容区 */
.profile-tab-content{padding:20px 32px 40px;min-height:300px}
.profile-posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}
.profile-work-card{position:relative;aspect-ratio:1/1;border-radius:var(--r3);overflow:hidden;cursor:pointer;transition:all .25s;display:flex;flex-direction:column;justify-content:flex-end;padding:14px;background:linear-gradient(135deg,var(--card),var(--card-h))}
.profile-work-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(0,0,0,0.3)}
.profile-work-card-img{position:absolute;inset:0;z-index:0}
.profile-work-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.profile-work-card:hover .profile-work-card-img img{transform:scale(1.08)}
.profile-work-card::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,0.7) 0%,rgba(0,0,0,0.2) 50%,transparent 100%);z-index:1}
.profile-work-card-content{position:relative;z-index:2}
.profile-work-card-title{font-size:13px;font-weight:600;color:#fff;margin-bottom:4px;text-shadow:0 1px 4px rgba(0,0,0,0.5)}
.profile-work-card-meta{display:flex;align-items:center;gap:10px;font-size:10px;color:rgba(255,255,255,0.85)}
.profile-work-card-meta span{display:inline-flex;align-items:center;gap:3px}

/* 收藏列表 */
.profile-fav-list{display:flex;flex-direction:column;gap:10px}
.profile-fav-item{display:flex;align-items:center;gap:14px;padding:14px 16px;background:linear-gradient(135deg,rgba(30,41,59,0.4),rgba(15,23,42,0.2));border:1px solid var(--border);border-radius:var(--r2);cursor:pointer;transition:all .2s}
.profile-fav-item:hover{border-color:var(--border-h);transform:translateX(3px);background:linear-gradient(135deg,rgba(30,41,59,0.6),rgba(15,23,42,0.4))}
.profile-fav-icon{width:42px;height:42px;border-radius:var(--r);background:linear-gradient(135deg,rgba(59,130,246,0.15),rgba(139,92,246,0.15));display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:var(--primary);flex-shrink:0;border:1px solid rgba(59,130,246,0.2)}
.profile-fav-content{flex:1;min-width:0}
.profile-fav-title{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.profile-fav-desc{font-size:11px;color:var(--text3);margin-top:2px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.profile-fav-tag{font-size:10px;color:var(--text2);background:rgba(59,130,246,0.1);border:1px solid rgba(59,130,246,0.2);padding:2px 8px;border-radius:8px;flex-shrink:0}

/* 活动时间线 */
.profile-timeline{position:relative;padding-left:24px}
.profile-timeline::before{content:'';position:absolute;left:7px;top:8px;bottom:8px;width:1px;background:linear-gradient(to bottom,var(--primary),transparent)}
.profile-timeline-item{position:relative;padding-bottom:16px}
.profile-timeline-item::before{content:'';position:absolute;left:-24px;top:6px;width:9px;height:9px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 3px rgba(59,130,246,0.2)}
.profile-timeline-time{font-size:10px;color:var(--text3);margin-bottom:2px;letter-spacing:0.3px}
.profile-timeline-content{font-size:12px;color:var(--text2);line-height:1.5}
.profile-timeline-content b{color:var(--text);font-weight:600}

/* 成就/徽章 */
.profile-achievements{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}
.profile-achievement{background:linear-gradient(135deg,rgba(245,158,11,0.08),rgba(239,68,68,0.05));border:1px solid rgba(245,158,11,0.2);border-radius:var(--r2);padding:14px 12px;text-align:center;transition:all .2s;cursor:pointer}
.profile-achievement:hover{transform:translateY(-2px);border-color:rgba(245,158,11,0.4);box-shadow:0 8px 20px rgba(245,158,11,0.1)}
.profile-achievement.locked{background:rgba(30,41,59,0.3);border-color:var(--border);opacity:0.5}
.profile-achievement-icon{font-size:28px;margin-bottom:6px;display:block;filter:drop-shadow(0 2px 4px rgba(0,0,0,0.2))}
.profile-achievement.locked .profile-achievement-icon{filter:grayscale(1) brightness(0.6)}
.profile-achievement-name{font-size:11px;font-weight:600;color:var(--text);margin-bottom:2px}
.profile-achievement-desc{font-size:10px;color:var(--text3);line-height:1.3}

/* 关于标签 */
.profile-about-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px}
.profile-about-card{background:linear-gradient(135deg,rgba(30,41,59,0.4),rgba(15,23,42,0.2));border:1px solid var(--border);border-radius:var(--r2);padding:16px}
.profile-about-card-title{font-size:12px;font-weight:600;color:var(--text);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.profile-about-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);font-size:12px}
.profile-about-row:last-child{border-bottom:none}
.profile-about-label{color:var(--text3);min-width:60px;flex-shrink:0}
.profile-about-value{color:var(--text);font-weight:500;flex:1}
.profile-skill-tags{display:flex;flex-wrap:wrap;gap:6px}
.profile-skill-tag{font-size:11px;padding:4px 10px;border-radius:12px;background:rgba(59,130,246,0.1);border:1px solid rgba(59,130,246,0.2);color:var(--primary-light)}

/* 空状态 */
.profile-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:var(--text3)}
.profile-empty-icon{width:64px;height:64px;border-radius:50%;background:var(--bg-hover);display:flex;align-items:center;justify-content:center;margin-bottom:12px;color:var(--text3)}
.profile-empty-title{font-size:14px;font-weight:600;color:var(--text2);margin-bottom:4px}
.profile-empty-desc{font-size:12px;color:var(--text3);margin-bottom:16px}
.profile-empty-action{padding:8px 20px;background:var(--primary);color:#fff;border-radius:var(--r);font-size:12px;cursor:pointer;border:none;transition:all .15s}
.profile-empty-action:hover{background:var(--primary-h)}

/* 个人主页内容版块 */
.profile-section{margin:24px 32px 0;background:linear-gradient(135deg,rgba(30,41,59,0.35),rgba(15,23,42,0.15));border:1px solid var(--border);border-radius:var(--r3);padding:20px 22px;transition:border-color .2s}
.profile-section:hover{border-color:var(--border)}
.profile-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:8px}
.profile-section-header h3{font-size:14px;font-weight:700;color:var(--text);margin:0;display:flex;align-items:center;gap:6px}
.profile-section-count{font-size:11px;font-weight:500;color:var(--text3);background:var(--bg-hover);border:1px solid var(--border);padding:2px 10px;border-radius:10px;letter-spacing:.3px}
.profile-about{display:grid;grid-template-columns:1fr;gap:0}
.profile-about .profile-about-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);font-size:12.5px}
.profile-about .profile-about-row:last-child{border-bottom:none}

/* 个人主页空状态(板块内) */
.profile-empty-section{padding:40px 20px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--text3);background:var(--bg-section);border:1px dashed var(--border);border-radius:var(--r2)}
.profile-empty-section .profile-empty-icon{margin-bottom:10px}
.profile-empty-text{font-size:12px;color:var(--text3);margin-bottom:12px}

/* 个人主页 - 时间线小圆点 */
.profile-timeline-dot{position:absolute;left:-24px;top:6px;width:9px;height:9px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 3px rgba(59,130,246,0.2)}
.profile-timeline-text{font-size:12px;color:var(--text2);line-height:1.5}

/* 个人主页 - 加载状态(骨架屏) */
.profile-loading{padding:0}
.profile-skeleton{height:200px;background:linear-gradient(90deg,rgba(30,41,59,0.4) 0%,rgba(51,65,85,0.6) 50%,rgba(30,41,59,0.4) 100%);background-size:200% 100%;animation:skeletonShine 1.4s ease-in-out infinite}
.profile-skeleton-text{height:18px;margin:20px 32px 0;background:linear-gradient(90deg,rgba(30,41,59,0.4) 0%,rgba(51,65,85,0.6) 50%,rgba(30,41,59,0.4) 100%);background-size:200% 100%;animation:skeletonShine 1.4s ease-in-out infinite;border-radius:6px}
.profile-skeleton-text.short{width:50%;margin-top:12px}
@keyframes skeletonShine{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* 个人主页 - 错误状态 */
.profile-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;text-align:center;color:var(--text3)}
.profile-error-icon{font-size:48px;margin-bottom:14px;opacity:.7}
.profile-error-title{font-size:15px;font-weight:600;color:var(--text);margin-bottom:6px}
.profile-error-desc{font-size:12px;color:var(--text3);margin-bottom:18px;max-width:420px;line-height:1.5}

/* 移动端适配 */
@media(max-width:768px){
  .profile-cover{height:140px}
  .profile-hero{padding:0 16px;margin-top:-48px}
  .profile-avatar-lg{width:88px;height:88px;font-size:32px}
  .profile-hero-name{font-size:20px}
  .profile-quick-stats{grid-template-columns:repeat(2,1fr);padding:20px 16px 0;gap:8px}
  .profile-stat-num{font-size:20px}
  .profile-tabs-container{padding:20px 16px 0}
  .profile-tab-content{padding:16px 16px 32px}
  .profile-posts-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .profile-hero-actions{width:100%}
  .profile-cover-actions{top:12px;right:12px}
  .profile-section{margin:18px 16px 0;padding:16px 16px}
  .profile-section-header h3{font-size:13px}
  .profile-achievements{grid-template-columns:repeat(2,1fr)}
  .profile-error{padding:60px 16px}
  .profile-error-icon{font-size:40px}
}

@media(max-width:480px){
  .profile-section{margin:14px 12px 0;padding:14px 12px;border-radius:10px}
  .profile-achievements{grid-template-columns:repeat(2,1fr);gap:8px}
  .profile-achievement{padding:10px 8px}
  .profile-achievement-icon{font-size:24px;margin-bottom:4px}
}

.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:9000;display:none;backdrop-filter:blur(4px)}
.modal-overlay.show{display:block}
.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:9100;display:none;width:400px;max-width:90vw}
.modal.show{display:block}
.modal-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2);padding:32px;position:relative;backdrop-filter:blur(12px)}
#tpl-modal.modal{width:auto;max-width:none}
.modal-close{position:absolute;top:12px;right:12px;padding:4px;color:var(--text3);transition:color .15s}
.modal-close:hover{color:var(--text)}
.modal-brand{display:flex;align-items:center;gap:10px;justify-content:center;margin-bottom:24px;font-size:18px;font-weight:700;color:var(--text)}
.modal-brand img{width:28px;height:28px;flex-shrink:0}
.lib-sb-brand img,.lc-sb-brand img,.wfc-sb-brand img,.pv-nav-brand img{width:20px;height:20px;flex-shrink:0}
.mobile-menu-brand img{width:24px;height:24px;flex-shrink:0}
.modal-tabs{display:flex;gap:0;margin-bottom:20px;border-bottom:1px solid var(--border)}
.modal-tab{flex:1;padding:8px;text-align:center;font-size:13px;font-weight:500;color:var(--text3);border-bottom:2px solid transparent;transition:all .15s}
.modal-tab.act{color:var(--primary);border-bottom-color:var(--primary)}
.modal-field{margin-bottom:14px}
.modal-field label{display:block;font-size:12px;font-weight:500;color:var(--text3);margin-bottom:6px}
.modal-field input{width:100%;padding:10px 14px;border-radius:var(--r);border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:13px;outline:none;transition:border-color .15s;box-sizing:border-box}
.modal-field input:focus{border-color:var(--primary)}
.modal-submit{width:100%;padding:10px;border-radius:var(--r);background:var(--primary);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s;margin-top:4px}
.modal-submit:hover{opacity:0.9}

.bento-card-bg{position:absolute;inset:0;border-radius:inherit}

.hp-feat-likes{font-size:11px;color:var(--text3);display:flex;align-items:center;gap:4px}

.hp-wf-info{padding:12px 14px}

@media(max-width:1024px){
.hp-hero-inner{padding:0}
.hp-hero-title{font-size:36px}
.hp-hero-greeting{font-size:54px;letter-spacing:4px}
.hp-hero-greeting-hi,.hp-hero-greeting-role{letter-spacing:5px}
.hp-hero-greeting-sep{font-size:36px;margin:0 6px}
.hp-hero-greeting-rule{width:28px}
.bento-grid{grid-template-columns:repeat(3,1fr);grid-auto-rows:auto}
.b-lg{grid-column:span 2;grid-row:span 1}
.b-w2{grid-column:span 1}
.hp-feat-grid,.hp-learn-grid,.hp-wf-grid{grid-template-columns:repeat(2,1fr)}
.bd-body{grid-template-columns:1fr}.bd-left{border-right:none;border-bottom:1px solid var(--border)}.bd-steps{flex-direction:row;width:auto;padding:12px 16px;gap:8px}.bd-step-line{width:24px;height:2px}.bd-scenes{grid-template-columns:repeat(2,1fr)}
.sopd-body{grid-template-columns:1fr}.sopd-left{max-height:300px}
.cs-grid{column-count:2}.cs-right{display:none}
.lib-grid{column-count:2}
.wfc-chain{flex-wrap:wrap}
.lc-page{flex-direction:column}.lc-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border);flex-direction:row;flex-wrap:wrap;padding:8px}.lc-sb-brand,.lc-sb-bottom{display:none}.lc-sb-nav{display:flex;overflow-x:auto;flex:1;gap:4px}.lc-sb-item{padding:6px 12px;font-size:11px;white-space:nowrap}.lc-content{grid-template-columns:1fr}
.lib-sop-grid{grid-template-columns:repeat(3,1fr)}
.sop-card-expand{padding:0 8px 10px}
.sop-knowledge-box{padding:8px 10px}
.sop-howto-box{padding:8px 10px}
.sop-structure-box{padding:8px 10px}
.sop-structure-text{font-size:10px;overflow-wrap:break-word;word-break:break-all}
.sop-keywords-box{padding:6px 10px}
.sop-keyword{font-size:9px;padding:2px 6px}
.sop-step{font-size:10px}
.sop-knowledge-text{font-size:10px}
}
@media(max-width:768px){
.topnav-links{display:none}
.topnav-search{display:none}
.topnav-mobile-toggle{display:flex}
.hp-hero{min-height:auto}
.hp-hero-inner{padding:0}
.hp-hero-title{font-size:28px}
.hp-hero-greeting-wrap{gap:14px;margin-bottom:24px}
.hp-hero-greeting-seal{width:42px;height:42px;font-size:24px}
.hp-hero-greeting{font-size:46px;letter-spacing:6px;padding-right:6px}
.hp-hero-greeting-hi,.hp-hero-greeting-role{letter-spacing:7px}
.hp-hero-greeting-sep{font-size:30px;margin:0 2px}
.hp-hero-greeting-rule{width:30px;margin-bottom:14px}
.hp-hero-greeting-tag{font-size:9px;letter-spacing:4px;padding-left:14px}
.hp-hero-greeting-tag::before{width:8px}
.hp-hero-subtitle{font-size:15px}
.hp-hero-actions{flex-direction:column}
.hp-section{padding:32px 16px}
.bento-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:auto}
.b-lg{grid-column:span 2}
.hp-feat-grid,.hp-learn-grid,.hp-wf-grid{grid-template-columns:1fr}
.hp-community-banner{flex-direction:column;gap:20px;text-align:center}
.hp-price-grid{grid-template-columns:1fr}
.lib-layout{flex-direction:column}
.lib-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border);flex-direction:row;flex-wrap:wrap;padding:8px}
.lib-sb-brand,.lib-sb-upgrade{display:none}
.lib-sb-nav{display:flex;overflow-x:auto;flex:1;gap:4px}
.lib-sb-item{padding:6px 12px;font-size:11px;white-space:nowrap}
.lib-bento{grid-template-columns:repeat(2,1fr);grid-auto-rows:auto}
.lib-bento-lg{grid-row:span 1}
.lib-tp-cats{grid-template-columns:repeat(3,1fr)}
.tpl-page-cards{flex-wrap:wrap}.tpl-pc{min-width:calc(50% - 10px);max-width:calc(50% - 10px)}.tpl-sort-left{gap:4px}.tpl-sort-btn{padding:4px 8px;font-size:10px}
.vp-grid{grid-template-columns:1fr}.vp-case{min-width:260px}
.lib-sop-grid{grid-template-columns:repeat(2,1fr)}
.sop-card-expand{padding:0 6px 8px}
.sop-knowledge-text{font-size:10px}
.sop-step{font-size:10px}
.sop-structure-text{font-size:9px}
.sop-keyword{font-size:8px}
.cs-grid{column-count:1}.cs-right{display:none}
.lib-grid{column-count:1}
.lc-content{grid-template-columns:1fr}
.wfc-page{flex-direction:column}.wfc-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border);flex-direction:row;flex-wrap:wrap;padding:8px}.wfc-sb-brand,.wfc-sb-explore,.wfc-sb-user{display:none}.wfc-sb-nav{display:flex;overflow-x:auto;flex:1;gap:4px}.wfc-sb-item{padding:6px 12px;font-size:11px;white-space:nowrap}
.pv-cards{grid-template-columns:1fr}
.pv-nav-links{display:none}.pv-nav{padding:12px 16px}
.bd-scenes{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:480px){
.hp-hero-title{font-size:22px}
.hp-hero-title img{width:32px;height:32px;margin-right:8px}
.hp-hero-greeting{font-size:32px;letter-spacing:2px}
.hp-hero-greeting-hi,.hp-hero-greeting-role{letter-spacing:3px}
.hp-hero-greeting-sep{font-size:24px;margin:0 2px}
.bento-grid{grid-template-columns:1fr}
.b-lg,.b-w2{grid-column:span 1}
.modal{width:95vw}.modal-card{padding:24px}
.browse-page,.profile-page,.mine-page{padding:16px}
.tpl-page{padding:16px}
.vp-page{padding:16px}
.bd-page{padding:0 16px}
.sopd-page{padding:16px}
.pv-page{padding:16px}
.lib-bento{grid-template-columns:1fr}
.lib-tp-cats{grid-template-columns:repeat(2,1fr)}
.tpl-page-cards{flex-direction:column}.tpl-pc{min-width:100%;max-width:100%}.tpl-sort-bar{flex-wrap:wrap}.tpl-sort-left{width:100%}.tpl-sort-btn{padding:4px 8px;font-size:10px}
.vp-grid{grid-template-columns:1fr}
.lib-sop-grid{grid-template-columns:1fr}
.sop-card-expand{padding:0 4px 6px}
.sop-knowledge-text{font-size:10px}
.sop-step{font-size:10px}
.sop-structure-text{font-size:10px;word-break:break-all}
.sop-keyword{font-size:10px;padding:2px 6px}
.tpl-modal-card{max-width:100vw;width:100vw;max-height:100vh;border-radius:0}
.tpl-modal-main{flex-direction:column}
.tpl-form-panel,.tpl-preview-panel{width:100%;max-height:45vh}
.sop-card-name{font-size:11px}
.sop-card-num{font-size:9px}
.bd-scenes{grid-template-columns:1fr}
.bd-code{font-size:11px}
.sopd-code{font-size:11px}
.cs-fab{bottom:16px;right:16px;width:48px;height:48px}
.topnav-inner{padding:0 12px}
.topnav-brand span{font-size:13px}
}

/* ===== 精选模版页面（替代原工坊）===== */
.ct-page{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}
.ct-hero{position:relative;padding:80px 24px 50px;background:linear-gradient(180deg,rgba(245,158,11,0.08) 0%,rgba(167,139,250,0.04) 100%);border-bottom:1px solid var(--border);overflow:hidden;text-align:center}
.ct-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 50%,rgba(245,158,11,0.1) 0%,transparent 50%),radial-gradient(circle at 70% 50%,rgba(167,139,250,0.1) 0%,transparent 50%);pointer-events:none}
.ct-hero-content{position:relative;max-width:800px;margin:0 auto}
.ct-hero-title{font-size:34px;font-weight:700;color:var(--text);margin:0 0 10px;letter-spacing:-.5px}
.ct-hero-sub{font-size:14px;color:var(--text3);margin:0 0 28px;letter-spacing:.2px}
.ct-hero-stats{display:flex;justify-content:center;gap:36px;padding:18px 0}
.ct-stat{display:flex;flex-direction:column;align-items:center;gap:4px}
.ct-stat-num{font-size:28px;font-weight:700;background:linear-gradient(135deg,#F59E0B 0%,#A78BFA 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1;letter-spacing:-.5px}
.ct-stat-label{font-size:11px;color:var(--text3);letter-spacing:.5px;text-transform:uppercase}
.ct-body{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:24px 16px 80px}
/* 分类标签栏（紧贴导航栏下方） */
.ct-catbar-wrap{position:sticky;top:60px;z-index:20;background:rgba(8,10,16,0.85);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:14px 16px;box-shadow:0 4px 12px rgba(0,0,0,0.08)}
.ct-catbar{max-width:1200px;margin:0 auto;display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}
.ct-catbar::-webkit-scrollbar{display:none}
.ct-pill{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:var(--card);border:1px solid var(--border);border-radius:999px;cursor:pointer;transition:all .18s;color:var(--text3);font-size:12px;font-weight:500;white-space:nowrap;flex-shrink:0;letter-spacing:.2px}
.ct-pill:hover{color:var(--text2);background:var(--bg-hover-strong);border-color:var(--border-h)}
.ct-pill.act{background:linear-gradient(135deg,#F59E0B 0%,#A78BFA 100%);color:#fff;border-color:transparent;box-shadow:0 4px 12px rgba(245,158,11,0.25)}
.ct-pill-icon{font-size:13px;line-height:1}
.ct-pill-name{font-weight:600}
.ct-pill-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:16px;padding:0 5px;font-size:9px;font-weight:700;background:rgba(255,255,255,0.1);color:inherit;border-radius:8px;letter-spacing:.3px}
.ct-pill.act .ct-pill-count{background:rgba(255,255,255,0.25);color:#fff}
/* 工具栏：排序+计数 */
.ct-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 0 12px;flex-wrap:wrap}
.ct-toolbar-l{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.ct-toolbar-label{font-size:11px;color:var(--text3);margin-right:4px;letter-spacing:.3px}
.ct-sort{padding:5px 10px;background:transparent;border:1px solid transparent;border-radius:6px;cursor:pointer;transition:all .15s;color:var(--text3);font-size:12px;letter-spacing:.2px}
.ct-sort:hover{color:var(--text2);background:var(--bg-hover)}
.ct-sort.act{color:var(--text);background:rgba(245,158,11,0.1);border-color:rgba(245,158,11,0.3);font-weight:600}
.ct-toolbar-r{display:flex;align-items:center;gap:8px}
.ct-toolbar-count{font-size:11px;color:var(--text3);padding:4px 10px;background:var(--card);border:1px solid var(--border);border-radius:999px;letter-spacing:.3px}
.ct-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.ct-card{position:relative;display:flex;flex-direction:column;gap:10px;padding:18px;background:var(--card);border:1px solid var(--border);border-radius:var(--r);cursor:pointer;transition:all .2s;overflow:hidden}
.ct-card-thumb{position:relative;width:calc(100% + 36px);margin:-18px -18px 4px;aspect-ratio:16/9;background:linear-gradient(135deg,rgba(124,58,237,0.12) 0%,rgba(59,130,246,0.08) 50%,rgba(245,158,11,0.06) 100%);overflow:hidden;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ct-card-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}
.ct-card:hover .ct-card-thumb img{transform:scale(1.04)}
.ct-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#F59E0B 0%,#A78BFA 50%,#60A5FA 100%);opacity:0;transition:opacity .2s}
.ct-card:hover{border-color:var(--border-h);transform:translateY(-3px);box-shadow:0 12px 32px rgba(0,0,0,0.25)}
.ct-card:hover::before{opacity:1}
.ct-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px}
.ct-card-no{font-size:10px;font-weight:700;color:var(--primary);letter-spacing:1.2px;line-height:1}
.ct-badge{font-size:9px;font-weight:700;padding:2px 7px;border-radius:4px;letter-spacing:.5px;line-height:1.4}
.ct-badge-sora{background:rgba(96,165,250,0.15);color:#60A5FA;border:1px solid rgba(96,165,250,0.3)}
.ct-badge-img{background:rgba(167,139,250,0.15);color:#A78BFA;border:1px solid rgba(167,139,250,0.3)}
.ct-card-title{font-size:14px;font-weight:600;color:var(--text);line-height:1.45;letter-spacing:.2px;min-height:40px}
.ct-card-stars{display:flex;align-items:center;gap:3px}
.ct-star{flex-shrink:0}
.ct-card-rating{font-size:11px;font-weight:600;color:var(--text2);margin-left:4px;line-height:1}
.ct-card-tip{font-size:11px;color:var(--text2);line-height:1.55;padding:6px 8px;background:rgba(167,139,250,0.05);border-left:2px solid rgba(167,139,250,0.35);border-radius:4px;flex:1;min-height:34px}
.ct-card-action{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:linear-gradient(135deg,rgba(245,158,11,0.1) 0%,rgba(167,139,250,0.1) 100%);border:1px solid rgba(245,158,11,0.2);border-radius:8px;font-size:12px;font-weight:600;color:var(--text);transition:all .15s}
.ct-card:hover .ct-card-action{background:linear-gradient(135deg,rgba(245,158,11,0.2) 0%,rgba(167,139,250,0.2) 100%);border-color:rgba(245,158,11,0.4)}
.ct-card-action svg{opacity:.7;transition:transform .2s}
.ct-card:hover .ct-card-action svg{transform:translateX(3px);opacity:1}
.ct-empty{padding:60px 20px;text-align:center;font-size:13px;color:var(--text3);background:var(--card);border:1px dashed var(--border);border-radius:var(--r)}
@media(max-width:768px){
  .ct-hero{padding:50px 20px 36px}
  .ct-hero-title{font-size:26px}
  .ct-hero-sub{font-size:13px}
  .ct-hero-stats{gap:24px;padding:14px 0}
  .ct-stat-num{font-size:22px}
  .ct-catbar-wrap{top:56px;padding:10px 14px}
  .ct-pill{padding:7px 12px;font-size:11px}
  .ct-pill-icon{font-size:12px}
  .ct-toolbar{padding:10px 0 8px}
  .ct-sort{padding:6px 8px;font-size:11px;min-height:32px}
  .ct-body{padding:18px 14px 60px}
  .ct-grid{grid-template-columns:1fr;gap:12px}
  .ct-card{padding:14px}
}

/* =============================================================
   UGC：广场「发布模板」入口按钮
   ============================================================= */
.tpl-page-header{position:relative}
.tpl-page-subtitle{font-size:14px;color:var(--text2);margin-top:10px;line-height:1.6;max-width:680px;margin-left:auto;margin-right:auto;letter-spacing:0.2px}
.tpl-create-btn{display:inline-flex;align-items:center;gap:6px;margin-top:18px;padding:10px 22px;border-radius:22px;font-size:13px;font-weight:600;background:linear-gradient(135deg,var(--primary),#7c3aed);color:#fff;border:none;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,opacity .15s;box-shadow:0 6px 20px -8px rgba(124,58,237,0.6)}
.tpl-create-btn:hover{transform:translateY(-1px);box-shadow:0 10px 24px -8px rgba(124,58,237,0.7)}
.tpl-create-btn:active{transform:translateY(0)}
.tpl-create-btn svg{flex-shrink:0}

/* =============================================================
   UGC：模板卡片 - 创作者归属
   ============================================================= */
.tpl-pc-creator{display:flex;align-items:center;gap:8px;padding:10px 16px 14px;border-top:1px solid var(--border);background:var(--bg-section)}
.tpl-pc-creator-avatar{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#7c3aed);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0;overflow:hidden;cursor:pointer;transition:transform .15s}
.tpl-pc-creator-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.tpl-pc-creator-avatar:hover{transform:scale(1.08)}
.tpl-pc-creator-info{flex:1;min-width:0;cursor:pointer}
.tpl-pc-creator-name{font-size:12px;font-weight:600;color:var(--text2);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tpl-pc-creator-stats{font-size:10px;color:var(--text3);line-height:1.3;margin-top:1px}
.tpl-pc-creator:hover .tpl-pc-creator-name{color:var(--mint)}
.tpl-pc-creator-official .tpl-pc-creator-official-avatar{background:linear-gradient(135deg,#0EA5E9,#06B6D4)}
.tpl-pc-ugc-badge{position:absolute;top:10px;right:10px;padding:3px 8px;border-radius:4px;font-size:9px;font-weight:700;background:linear-gradient(135deg,#F59E0B,#EF4444);color:#fff;letter-spacing:0.5px;z-index:2}
.tpl-pc-like{position:absolute;top:10px;right:10px;width:28px;height:28px;border-radius:50%;background:rgba(0,0,0,0.55);backdrop-filter:blur(6px);border:1px solid var(--border);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;z-index:2}
.tpl-pc-like:hover{background:rgba(239,68,68,0.6);transform:scale(1.1)}
.tpl-pc-like.liked{background:rgba(239,68,68,0.85);color:#fff}
.tpl-pc-like.liked svg{fill:currentColor}
/* 调整：有 UGC 角标时点赞按钮向右下偏移 */
.tpl-pc-ugc-badge + .tpl-pc-like{top:auto;bottom:96px;right:10px}
.tpl-pc .tpl-pc-creator + .tpl-pc-like{bottom:auto;top:10px;right:10px}

/* =============================================================
   UGC：模板上传 / 编辑 / 我的作品 通用弹层
   ============================================================= */
.upload-modal{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .2s ease}
.upload-modal.show{opacity:1;pointer-events:auto}
.upload-backdrop{position:absolute;inset:0;background:rgba(0,0,0,0.65);backdrop-filter:blur(4px)}
.upload-panel{position:relative;width:min(520px,92vw);max-height:90vh;background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,0.5);display:flex;flex-direction:column;overflow:hidden;transform:scale(0.95);transition:transform .2s ease}
.upload-modal.show .upload-panel{transform:scale(1)}
.upload-panel-md{width:min(560px,92vw)}
.upload-panel-lg{width:min(960px,95vw);max-height:90vh}
.upload-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border);flex-shrink:0}
.upload-header h3{font-size:16px;font-weight:700;color:var(--text);margin:0}
.upload-close{width:32px;height:32px;border:none;background:transparent;color:var(--text3);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .15s}
.upload-close:hover{background:var(--bg-hover-strong);color:var(--text)}
.upload-body{padding:20px 22px;overflow-y:auto;flex:1;min-height:0}
.upload-toolbar{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--bg-hover)}
.upload-section{margin-bottom:18px}
.upload-section:last-child{margin-bottom:0}
.upload-section-avatar{display:flex;align-items:center;gap:18px}
.upload-section-avatar .upload-label{flex-shrink:0;margin-bottom:0}
.upload-label{display:block;font-size:13px;font-weight:600;color:var(--text2);margin-bottom:8px}
.upload-required{color:#EF4444;margin-left:2px}
.upload-input{width:100%;padding:10px 14px;background:var(--bg-hover);border:1px solid var(--border);border-radius:8px;font-size:13px;color:var(--text);font-family:inherit;line-height:1.55;transition:border-color .15s,background .15s;box-sizing:border-box}
.upload-input:focus{outline:none;border-color:var(--primary);background:rgba(124,58,237,0.05)}
.upload-input::placeholder{color:var(--text3);opacity:0.7}
textarea.upload-input{resize:vertical;min-height:64px;font-family:'SF Mono',Consolas,monospace;font-size:12.5px;line-height:1.7}
.upload-prompt{min-height:160px}
.upload-hint{font-size:11px;color:var(--text3);margin-top:6px;line-height:1.5}
.upload-hint code{background:var(--bg-hover-strong);padding:1px 6px;border-radius:3px;font-size:10.5px;color:var(--mint)}
.upload-dropzone{position:relative;width:100%;min-height:160px;padding:20px;background:var(--bg-hover);border:1.5px dashed var(--border);border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}
.upload-dropzone:hover,.upload-dropzone.dragging{border-color:var(--primary);background:rgba(124,58,237,0.05)}
.upload-dropzone-hint{text-align:center;color:var(--text3);font-size:13px;line-height:1.6}
.upload-dropzone-hint svg{margin:0 auto 8px;display:block;color:var(--text3);opacity:0.6}
.upload-dropzone-sub{font-size:11px;opacity:0.7;margin-top:4px}
.upload-footer{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding-top:8px;border-top:1px solid var(--border);margin-top:20px;padding-top:18px}
.upload-btn-cancel{padding:10px 20px;background:transparent;border:1px solid var(--border);border-radius:8px;font-size:13px;font-weight:500;color:var(--text2);cursor:pointer;transition:all .15s}
.upload-btn-cancel:hover{background:var(--bg-hover-strong);border-color:var(--border-h)}
.upload-btn-submit{padding:10px 24px;background:var(--primary);border:none;border-radius:8px;font-size:13px;font-weight:600;color:#fff;cursor:pointer;transition:all .15s;min-width:100px}
.upload-btn-submit:hover:not(:disabled){background:#7c3aed;transform:translateY(-1px)}
.upload-btn-submit:disabled{opacity:0.5;cursor:not-allowed}
.upload-btn-sm{padding:6px 14px;background:var(--bg-hover-strong);border:1px solid var(--border);border-radius:6px;font-size:12px;font-weight:500;color:var(--text2);cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:4px}
.upload-btn-sm:hover{background:rgba(255,255,255,0.1);border-color:var(--border-h);color:var(--text)}
.upload-btn-primary-sm{background:var(--primary);color:#fff;border-color:var(--primary)}
.upload-btn-primary-sm:hover{background:#7c3aed;color:#fff;border-color:#7c3aed}
.upload-btn-danger-sm{color:#EF4444;border-color:rgba(239,68,68,0.3)}
.upload-btn-danger-sm:hover{background:rgba(239,68,68,0.1);color:#EF4444;border-color:#EF4444}

/* ===== 上传弹层 2.0 增强样式 ===== */
.upload-header-info{display:flex;align-items:center;gap:14px;flex:1;min-width:0}
.upload-header-icon{width:42px;height:42px;border-radius:11px;background:linear-gradient(135deg,var(--primary),#06D6D4);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;box-shadow:0 4px 12px rgba(124,58,237,0.25)}
.upload-header h3{margin:0;font-size:18px;font-weight:700;color:var(--text);letter-spacing:-0.2px;line-height:1.3}
.upload-header-sub{font-size:12px;color:var(--text3);margin-top:2px;line-height:1.4}

.upload-grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);gap:24px;min-height:0}
@media (max-width:768px){.upload-grid{grid-template-columns:1fr;gap:16px}}

.upload-col-left,.upload-col-right{display:flex;flex-direction:column;gap:18px;min-width:0}
.upload-col-left{padding-right:4px;border-right:1px dashed var(--border)}
@media (max-width:768px){.upload-col-left{padding-right:0;border-right:none;border-bottom:1px dashed var(--border);padding-bottom:16px}}

.upload-section-title{font-size:12px;font-weight:600;color:var(--text2);margin-bottom:8px;display:flex;align-items:center;gap:6px;letter-spacing:0.2px}
.upload-section-title small{font-weight:400;color:var(--text3);font-size:11px}
.upload-required{color:#EF4444;margin-left:2px}
.upload-counter{margin-left:auto;font-size:11px;color:var(--text3);font-weight:400;font-family:'SF Mono',Consolas,monospace}
.upload-counter.over{color:#F59E0B}

.upload-label{display:block;font-size:12px;font-weight:500;color:var(--text2);margin-bottom:6px}

/* 全新 dropzone */
.upload-dropzone{position:relative;width:100%;min-height:200px;padding:0;background:var(--bg-hover);border:1.5px dashed var(--border);border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;overflow:hidden}
.upload-dropzone:hover,.upload-dropzone.dragging{border-color:var(--primary);background:rgba(124,58,237,0.04)}
.upload-dropzone-placeholder{text-align:center;padding:36px 20px;color:var(--text3);width:100%;display:flex;flex-direction:column;align-items:center;gap:8px}
.upload-dropzone-icon{width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,rgba(124,58,237,0.12),rgba(6,214,212,0.08));display:flex;align-items:center;justify-content:center;color:var(--primary);margin-bottom:4px;transition:transform .2s}
.upload-dropzone:hover .upload-dropzone-icon{transform:translateY(-2px)}
.upload-dropzone-title{font-size:14px;font-weight:500;color:var(--text);line-height:1.5}
.upload-dropzone-sub{font-size:11.5px;opacity:0.7;line-height:1.6}
.upload-dropzone-cta{margin-top:8px}
.upload-dropzone-cta-btn{display:inline-block;padding:6px 16px;background:rgba(124,58,237,0.1);border:1px solid rgba(124,58,237,0.3);border-radius:6px;font-size:12px;color:var(--primary);font-weight:500;transition:all .15s}
.upload-dropzone:hover .upload-dropzone-cta-btn{background:rgba(124,58,237,0.18);border-color:var(--primary)}

/* 拖拽覆盖层 */
.upload-drag-overlay{position:absolute;inset:0;background:rgba(124,58,237,0.92);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;opacity:0;pointer-events:none;transition:opacity .2s;z-index:5}
.upload-drag-overlay.show{opacity:1;pointer-events:auto}
.upload-drag-overlay-inner{display:flex;flex-direction:column;align-items:center;gap:8px;font-size:15px;font-weight:500}

/* 预览 */
.upload-preview{position:relative;width:100%;min-height:200px;background:#000;display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:10px}
.upload-preview.has-image{background-size:contain;background-repeat:no-repeat;background-position:center;background-color:#000}
.upload-preview img,.upload-preview video{display:block;width:auto;height:auto;max-width:100%;max-height:360px;object-fit:contain;background:transparent;min-width:120px;min-height:120px;position:relative;z-index:1}
.upload-preview.loading::after{content:'';position:absolute;width:32px;height:32px;border:3px solid rgba(255,255,255,0.15);border-top-color:rgba(124,58,237,0.9);border-radius:50%;animation:upload-spin 0.7s linear infinite;z-index:3}
.upload-preview.has-error{background:linear-gradient(135deg,#1a0d0d,#0a0a0a)}
@keyframes upload-spin{to{transform:rotate(360deg)}}
.upload-preview-error{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:6px;color:rgba(255,255,255,0.55);font-size:12px;z-index:2;pointer-events:none;text-align:center;padding:20px}
.upload-preview-overlay{position:absolute;top:10px;right:10px;display:flex;gap:6px;opacity:0;transition:opacity .2s}
.upload-preview:hover .upload-preview-overlay{opacity:1}
.upload-preview-action{display:inline-flex;align-items:center;gap:4px;padding:6px 10px;background:rgba(0,0,0,0.6);backdrop-filter:blur(8px);border:1px solid var(--border-h);border-radius:6px;color:#fff;font-size:11.5px;font-weight:500;cursor:pointer;transition:all .15s}
.upload-preview-action:hover{background:rgba(0,0,0,0.8);border-color:rgba(255,255,255,0.3)}
.upload-preview-action-danger:hover{background:rgba(239,68,68,0.8);border-color:#EF4444}

/* 媒体信息条 */
.upload-media-info{margin-top:8px;padding:8px 12px;background:var(--bg-hover);border:1px solid var(--border);border-radius:6px;display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--text2);font-family:'SF Mono',Consolas,monospace;line-height:1.5;flex-wrap:wrap}
.upload-media-info svg{color:var(--text3);flex-shrink:0}
.upload-media-info-dot{color:var(--text3);opacity:0.5}

.upload-cover-hint{font-size:11.5px;color:var(--text3);line-height:1.5;margin-bottom:8px}

/* 变量列表 */
.upload-vars{background:var(--bg-hover);border:1px solid var(--border);border-radius:8px;padding:10px 12px;min-height:60px}
.upload-vars-empty{font-size:11.5px;color:var(--text3);line-height:1.6}
.upload-vars-empty code{background:var(--bg-hover-strong);padding:1px 6px;border-radius:3px;font-size:10.5px;color:var(--mint);font-family:'SF Mono',Consolas,monospace}
.upload-vars-label{font-size:11.5px;color:var(--text3);margin-bottom:8px;font-weight:500;display:flex;align-items:center;gap:4px}
.upload-vars-label b{color:var(--primary);font-size:13px;font-weight:700;margin:0 2px}
.upload-vars-list{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}
.upload-var-item{display:inline-flex;align-items:center;gap:4px;background:rgba(124,58,237,0.08);border:1px solid rgba(124,58,237,0.25);border-radius:6px;padding:4px 6px 4px 4px;transition:all 0.15s}
.upload-var-item:hover{background:rgba(124,58,237,0.15);border-color:rgba(124,58,237,0.5);transform:translateY(-1px)}
.upload-var-chip{display:inline-block;padding:2px 8px;background:rgba(124,58,237,0.18);border-radius:4px;font-size:11px;color:var(--primary);font-family:'SF Mono',Consolas,monospace;font-weight:500}
.upload-var-count{font-size:10px;color:var(--text3);font-weight:600;padding-right:2px;font-family:'SF Mono',Consolas,monospace}
.upload-var-add-btn{width:100%;padding:6px;background:rgba(124,58,237,0.08);border:1px dashed rgba(124,58,237,0.35);border-radius:6px;color:var(--primary);font-size:11.5px;cursor:pointer;transition:all 0.15s;margin-top:2px}
.upload-var-add-btn:hover{background:rgba(124,58,237,0.18);border-color:rgba(124,58,237,0.6);border-style:solid}

/* 分类 chips */
.upload-cat-chips{display:flex;flex-wrap:wrap;gap:6px}
.upload-cat-chip{cursor:pointer;user-select:none}
.upload-cat-chip input{position:absolute;opacity:0;pointer-events:none}
.upload-cat-chip span{display:inline-block;padding:6px 12px;background:var(--bg-hover);border:1px solid var(--border);border-radius:18px;font-size:12px;color:var(--text2);transition:all .15s;line-height:1.4}
.upload-cat-chip:hover span{border-color:var(--border-h);background:var(--bg-hover-strong)}
.upload-cat-chip input:checked + span{background:linear-gradient(135deg,var(--primary),#06D6D4);color:#fff;border-color:transparent;box-shadow:0 2px 8px rgba(124,58,237,0.25)}

/* 提示词工具栏 */
.upload-prompt-toolbar{display:flex;gap:6px;margin-top:6px;flex-wrap:wrap}
.upload-tool-btn{padding:4px 10px;background:var(--bg-hover);border:1px solid var(--border);border-radius:14px;font-size:11.5px;color:var(--text2);cursor:pointer;transition:all .15s;font-family:inherit;display:inline-flex;align-items:center;gap:4px;line-height:1.4}
.upload-tool-btn:hover{background:rgba(124,58,237,0.1);border-color:rgba(124,58,237,0.3);color:var(--primary)}
.upload-tool-btn.upload-preset-trigger.active{background:rgba(124,58,237,0.15);border-color:var(--primary);color:#fff;box-shadow:0 0 0 2px rgba(124,58,237,0.2)}
.upload-tool-btn.upload-tool-btn-special{background:rgba(6,214,212,0.08);border-color:rgba(6,214,212,0.3);color:var(--mint);font-family:'SF Mono',Consolas,monospace}
.upload-tool-btn.upload-tool-btn-special:hover{background:rgba(6,214,212,0.15);border-color:var(--mint)}

/* ===== 预设弹层（底部抽屉，干净专业） ===== */
.upload-preset-popup{position:absolute;display:flex;flex-direction:column;background:linear-gradient(180deg,rgba(20,20,30,0.98),rgba(15,15,22,0.98));border:1px solid var(--border);border-bottom:none;border-radius:14px 14px 0 0;box-shadow:0 -16px 48px rgba(0,0,0,0.7),inset 0 1px 0 rgba(124,58,237,0.35);z-index:50;overflow:hidden;opacity:0;transform:translateY(20px);transition:all .22s cubic-bezier(0.4,0,0.2,1);backdrop-filter:blur(20px)}
.upload-preset-popup.upload-preset-drawer{left:0;right:0;bottom:0;width:100%;max-height:260px}
.upload-preset-popup.show{opacity:1;transform:translateY(0)}
.upload-preset-header{display:flex;align-items:center;gap:10px;padding:8px 14px;border-bottom:1px solid var(--border);background:linear-gradient(135deg,rgba(124,58,237,0.12),rgba(6,214,212,0.06));flex-shrink:0;min-height:42px}
.upload-preset-title{font-size:13px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:6px;flex-shrink:0;white-space:nowrap}
.upload-preset-title small{font-weight:400;color:var(--text3);font-size:11px;margin-left:4px}
.upload-preset-search{flex:1;display:flex;align-items:center;gap:6px;background:rgba(0,0,0,0.35);border:1px solid var(--border);border-radius:6px;padding:0 8px;min-width:0;height:28px}
.upload-preset-search svg{color:var(--text3);flex-shrink:0}
.upload-preset-search input{flex:1;background:transparent;border:none;outline:none;color:var(--text);font-size:12px;padding:0;font-family:inherit;min-width:0;height:100%}
.upload-preset-search input::placeholder{color:var(--text3)}
.upload-preset-hint{color:var(--text3);font-size:10.5px;flex-shrink:0;display:none;white-space:nowrap}
@media (min-width: 768px) { .upload-preset-hint{display:inline;} }
.upload-preset-close{width:26px;height:26px;border:none;background:transparent;border-radius:6px;color:var(--text3);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
.upload-preset-close:hover{background:rgba(239,68,68,0.15);color:#ef4444}
.upload-preset-grid{flex:1;overflow-y:auto;padding:10px 12px;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:6px;align-content:start;background:rgba(0,0,0,0.1)}
.upload-preset-grid::-webkit-scrollbar{width:6px}
.upload-preset-grid::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.1);border-radius:3px}
.upload-preset-grid::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,0.2)}
.upload-preset-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg-hover);border:1px solid var(--border);border-radius:8px;cursor:pointer;font-size:12.5px;color:var(--text);transition:all .12s;text-align:left;font-family:inherit;line-height:1.4;min-height:36px;position:relative;overflow:hidden}
.upload-preset-item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:transparent;transition:background .12s}
.upload-preset-item:hover{background:rgba(124,58,237,0.12);border-color:rgba(124,58,237,0.4);color:#fff;transform:translateX(2px);box-shadow:0 2px 8px rgba(124,58,237,0.2)}
.upload-preset-item:hover::before{background:linear-gradient(180deg,var(--primary),var(--mint))}
.upload-preset-item:active{transform:translateX(0)}
.upload-preset-item-text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.upload-preset-item-add{width:18px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:4px;background:rgba(124,58,237,0.15);color:var(--primary);font-size:13px;font-weight:600;flex-shrink:0;opacity:0;transition:all .12s}
.upload-preset-item:hover .upload-preset-item-add{opacity:1;background:var(--primary);color:#fff}
.upload-preset-empty{grid-column:1/-1;text-align:center;padding:30px 0;color:var(--text3);font-size:12px}

/* 底部 */
.upload-footer{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;border-top:1px solid var(--border);background:rgba(0,0,0,0.2);gap:12px;flex-wrap:wrap}
.upload-footer-left,.upload-footer-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.upload-checkbox{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:12px;color:var(--text2);user-select:none}
.upload-checkbox input{accent-color:var(--primary);width:14px;height:14px;cursor:pointer}
.upload-btn-draft{padding:10px 18px;background:transparent;border:1px solid var(--border);border-radius:8px;font-size:13px;font-weight:500;color:var(--text2);cursor:pointer;transition:all .15s}
.upload-btn-draft:hover{background:var(--bg-hover-strong);border-color:var(--border-h);color:var(--text)}

/* 头像编辑 */
.profile-avatar-edit{display:flex;align-items:center;gap:14px}
.profile-avatar-preview{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#7c3aed);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:#fff;overflow:hidden;flex-shrink:0;border:2px solid var(--border)}
.profile-avatar-preview img{width:100%;height:100%;object-fit:cover;display:block}
.profile-avatar-actions{display:flex;flex-direction:column;gap:6px;align-items:flex-start}
.profile-avatar-hint{font-size:11px;color:var(--text3)}

/* 我的作品 */
.my-tpl-count{font-size:12px;color:var(--text3)}
.my-tpl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;padding:18px 22px;overflow-y:auto;flex:1;min-height:0}
.my-tpl-card{background:rgba(255,255,255,0.025);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:border-color .15s,transform .15s}
.my-tpl-card:hover{border-color:var(--border-h);transform:translateY(-2px)}
.my-tpl-thumb{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;cursor:pointer;background:linear-gradient(135deg,rgba(124,58,237,0.08),rgba(59,130,246,0.04))}
.my-tpl-thumb img,.my-tpl-thumb video{width:100%;height:100%;object-fit:cover;display:block}
.my-tpl-status{position:absolute;top:8px;left:8px;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:600}
.my-tpl-status-published{background:rgba(16,185,129,0.85);color:#fff}
.my-tpl-status-hidden{background:rgba(107,114,128,0.85);color:#fff}
.my-tpl-info{padding:12px 14px}
.my-tpl-info h4{font-size:13px;font-weight:600;color:var(--text);margin:0 0 8px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:36px}
.my-tpl-meta{display:flex;align-items:center;gap:10px;font-size:11px;color:var(--text3);margin-bottom:10px}
.my-tpl-date{margin-left:auto}
.my-tpl-actions{display:flex;gap:6px}
.my-tpl-actions .upload-btn-sm{flex:1;justify-content:center}

/* 创作者主页 */
.creator-modal{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .2s ease}
.creator-modal.show{opacity:1;pointer-events:auto}
.creator-backdrop{position:absolute;inset:0;background:rgba(0,0,0,0.65);backdrop-filter:blur(4px)}
.creator-panel{position:relative;width:min(720px,92vw);max-height:88vh;background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,0.5);overflow:hidden;display:flex;flex-direction:column;transform:scale(0.95);transition:transform .2s ease}
.creator-modal.show .creator-panel{transform:scale(1)}
.creator-header{position:relative;flex-shrink:0;padding:32px 28px 24px;background:linear-gradient(135deg,rgba(124,58,237,0.1),rgba(59,130,246,0.05));border-bottom:1px solid var(--border)}
.creator-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border:none;background:transparent;color:var(--text3);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .15s}
.creator-close:hover{background:var(--bg-hover-strong);color:var(--text)}
.creator-hero{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px}
.creator-avatar-lg{width:96px;height:96px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#7c3aed);display:flex;align-items:center;justify-content:center;font-size:36px;font-weight:700;color:#fff;overflow:hidden;border:3px solid var(--border);box-shadow:0 6px 20px rgba(124,58,237,0.3)}
.creator-avatar-lg img{width:100%;height:100%;object-fit:cover;display:block}
.creator-name{font-size:22px;font-weight:700;color:var(--text);margin:8px 0 0;display:flex;align-items:center;gap:8px}
.creator-self-badge{font-size:11px;font-weight:600;padding:2px 8px;background:var(--primary);color:#fff;border-radius:10px}
.creator-title{font-size:13px;color:var(--gold);font-weight:500;margin-top:2px}
.creator-bio{font-size:13px;color:var(--text2);line-height:1.6;max-width:480px;margin:6px auto 0}
.creator-bio-empty{font-size:13px;color:var(--text3);font-style:italic;margin:6px auto 0}
.creator-meta{display:flex;align-items:center;justify-content:center;gap:14px;font-size:12px;color:var(--text3);margin-top:8px;flex-wrap:wrap}
.creator-meta a{color:var(--mint);text-decoration:none}
.creator-meta a:hover{text-decoration:underline}
.creator-stats{display:flex;align-items:center;justify-content:center;gap:24px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border);flex-wrap:wrap}
.creator-stat{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:60px}
.creator-stat b{font-size:18px;font-weight:700;color:var(--text);line-height:1}
.creator-stat span{font-size:11px;color:var(--text3);line-height:1}
.creator-follow-btn{margin-top:14px;padding:8px 24px;background:var(--primary);border:none;border-radius:20px;font-size:13px;font-weight:600;color:#fff;cursor:pointer;transition:all .15s}
.creator-follow-btn:hover{background:#7c3aed;transform:translateY(-1px)}
.creator-follow-btn.following{background:transparent;border:1px solid var(--border);color:var(--text2)}
.creator-follow-btn.following:hover{background:rgba(239,68,68,0.1);border-color:rgba(239,68,68,0.3);color:#EF4444}
.creator-social-link{font-size:11px;padding:3px 8px;background:var(--bg-hover-strong);border:1px solid var(--border);border-radius:10px;color:var(--text2);text-decoration:none;text-transform:capitalize}
.creator-social-link:hover{color:var(--mint);border-color:var(--mint)}
.creator-body{padding:20px 28px;overflow-y:auto;flex:1;min-height:0}
.creator-section-title{font-size:14px;font-weight:700;color:var(--text);margin:0 0 14px;display:flex;align-items:center;gap:8px}
.creator-section-title::before{content:'';width:3px;height:14px;background:var(--primary);border-radius:2px}
.creator-templates{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.creator-tpl-card{background:rgba(255,255,255,0.025);border:1px solid var(--border);border-radius:10px;overflow:hidden;cursor:pointer;transition:all .15s}
.creator-tpl-card:hover{border-color:var(--border-h);transform:translateY(-2px)}
.creator-tpl-thumb{width:100%;aspect-ratio:16/9;overflow:hidden;background:linear-gradient(135deg,rgba(124,58,237,0.08),rgba(59,130,246,0.04))}
.creator-tpl-thumb img,.creator-tpl-thumb video{width:100%;height:100%;object-fit:cover;display:block}
.creator-tpl-info{padding:10px 12px}
.creator-tpl-info h4{font-size:12.5px;font-weight:600;color:var(--text);margin:0 0 6px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:34px}
.creator-tpl-meta{display:flex;align-items:center;gap:8px;font-size:10.5px;color:var(--text3)}
.creator-error{padding:40px 20px;text-align:center;color:var(--text3)}
.creator-error h3{color:var(--text);font-size:15px;margin:0 0 8px}
.creator-loading{padding:60px 20px;display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--text3);font-size:13px}
.loader{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 0.8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.empty-state-mini{padding:40px 20px;text-align:center;color:var(--text3);font-size:13px;display:flex;flex-direction:column;align-items:center;gap:10px;grid-column:1/-1}

/* 模板详情页 - 创作者信息条 */
.tpl-modal-creator{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--bg-section);border:1px solid var(--border);border-radius:8px;margin:0 0 14px;font-size:12px}
.tpl-modal-creator-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#7c3aed);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;overflow:hidden;flex-shrink:0;cursor:pointer;transition:transform .15s}
.tpl-modal-creator-avatar:hover{transform:scale(1.1)}
.tpl-modal-creator-info{flex:1;min-width:0;cursor:pointer}
.tpl-modal-creator-info:hover .tpl-modal-creator-name{color:var(--mint)}
.tpl-modal-creator-name{font-weight:600;color:var(--text);line-height:1.3}
.tpl-modal-creator-title{font-size:11px;color:var(--text3);line-height:1.3;margin-top:1px}
.tpl-modal-creator-stats{font-size:10.5px;color:var(--text3);margin-top:1px}
.tpl-modal-creator-actions{display:flex;gap:6px;flex-shrink:0}
.tpl-modal-creator-btn{padding:5px 12px;background:transparent;border:1px solid var(--border);border-radius:14px;font-size:11px;font-weight:500;color:var(--text2);cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:3px}
.tpl-modal-creator-btn:hover{background:var(--bg-hover-strong);border-color:var(--border-h);color:var(--text)}
.tpl-modal-creator-btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.tpl-modal-creator-btn-primary:hover{background:#7c3aed;color:#fff}
.tpl-modal-creator-btn-danger:hover{background:rgba(239,68,68,0.1);border-color:rgba(239,68,68,0.4);color:#EF4444}

@media(max-width:768px){
  .upload-panel{width:100vw;max-height:100vh;height:100vh;border-radius:0}
  .upload-panel-lg{width:100vw}
  .upload-panel-md{width:100vw}
  .my-tpl-grid{grid-template-columns:1fr 1fr;gap:10px;padding:14px}
  .creator-panel{width:100vw;max-height:100vh;height:100vh;border-radius:0}
  .creator-templates{grid-template-columns:1fr 1fr}
  .tpl-modal-creator{flex-wrap:wrap}
  .tpl-modal-creator-actions{width:100%;justify-content:flex-end}
}
