/* YourStore minimal, responsive styles */
:root{
  --ys-header-h:64px;
  --ys-container-w:1280px;
  --ys-container-px:16px;
  /* 主题配色（浅色）：背景/卡片/正文/弱化/主色等 */
  --ys-bg:#f6f8fc;      /* 背景 */
  --ys-card:#ffffff;    /* 卡片 */
  --ys-text:#0f172a;    /* 正文 */
  --ys-muted:#64748b;   /* 次级文字 */
  --ys-accent:#3b82f6;  /* 主色 */
  --ys-accent-600:#2563eb; /* 主色深 */
  --ys-gradient-1:#6A11CB; /* 渐变起始 */
  --ys-gradient-2:#2575FC; /* 渐变结束 */
  --ys-good:#16a34a;    /* 成功 */
  --ys-bad:#ef4444;     /* 失败 */
  --ys-border:#e5e7eb;  /* 边框 */
  --ys-radius:12px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;background:var(--ys-bg);color:var(--ys-text);font:400 16px/1.6 "Microsoft YaHei","微软雅黑",ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Arial,"Noto Sans SC","PingFang SC","Hiragino Sans GB",sans-serif;-webkit-font-smoothing:antialiased;min-height:100vh;display:flex;flex-direction:column;padding-top:var(--ys-header-h)}
.ys-no-fixed{padding-top:0}
a{color:var(--ys-accent);text-decoration:none}
/* Skip link (accessibility) */
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:8px;top:8px;width:auto;height:auto;background:#111827;color:#fff;padding:8px 12px;border-radius:8px;z-index:10000}
/* Limit link hover recolor to content areas to avoid CTA conflicts */
.ys-doc a:hover:not(.ys-btn):not(.ys-btn-primary):not(.ys-btn-outline):not(.ys-btn-ghost),
.ys-article a:hover:not(.ys-btn):not(.ys-btn-primary):not(.ys-btn-outline):not(.ys-btn-ghost),
.guide-body a:hover:not(.ys-btn):not(.ys-btn-primary):not(.ys-btn-outline):not(.ys-btn-ghost),
.ys-content a:hover:not(.ys-btn):not(.ys-btn-primary):not(.ys-btn-outline):not(.ys-btn-ghost){
  color:var(--ys-accent-600)
}
/* Fix: keep homepage button text color on hover */
.home a.text-white:hover,
.home .ys-hero-cta:hover,
.home .ys-final-cta-sec:hover{ color:#fff !important; }
.home a.text-slate-900:hover,
.home .ys-final-cta:hover{ color:#0f172a !important; }
.home a.text-slate-800:hover{ color:#1f2937 !important; }
.home a.text-slate-700:hover{ color:#334155 !important; }

/* Buy page: keep pricing CTA text color on hover */
#ys-plans a.text-white:hover{ color:#fff !important; }
#ys-plans .ys-buy.bg-blue-600:hover{ color:#fff !important; }
#ys-plans .ys-buy.text-blue-600:hover{ color:var(--ys-accent-600) !important; }
#ys-plans a.text-slate-900:hover{ color:#0f172a !important; }
.ys-container{max-width:1280px;margin:0 auto;padding:0 16px}
.ys-muted{color:var(--ys-muted)}
.ys-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:#fff;border-bottom:1px solid var(--ys-border);box-shadow:0 2px 8px rgba(2,6,23,.06)}
.ys-header-inner{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:16px;min-height:var(--ys-header-h)}
.ys-brand{display:flex;align-items:center;gap:12px;font-weight:700;color:var(--ys-text)}
.ys-brand-text{font-size:18px}
.ys-nav{display:flex;align-items:center;gap:16px;justify-self:center;justify-content:center;margin-left:0;width:100%}
.ys-menu{display:flex;gap:12px;list-style:none;margin:0;padding:0}
.ys-menu a{display:block;padding:8px 10px;border-radius:8px;color:var(--ys-text)}
.ys-menu a:hover{background:rgba(2,6,23,.05)}
.ys-buy-cta{margin-left:8px}
.ys-nav-toggle{display:none;margin-left:0;background:transparent;border:1px solid var(--ys-border);color:var(--ys-text);border-radius:8px;padding:6px 10px}
.ys-actions{display:flex;align-items:center;gap:12px;justify-self:end}
.ys-link{color:var(--ys-text)}
.ys-link:hover{color:var(--ys-accent-600)}
/* Header avatar button: remove focus ring for mouse focus only; keep keyboard focus visible */
.ys-user-menu #ys-user-btn:focus:not(:focus-visible){
  outline: none !important;
  box-shadow: none !important;
}
.front-menu{list-style:none;margin:0;padding:0}
.front-menu a{color:#0f172a;text-decoration:none;padding:8px 4px;border-radius:8px}
.front-menu a:hover{color:#1d4ed8}
.front-menu .current-menu-item> a{color:#1d4ed8;font-weight:700}
.ys-buy-btn{color:#fff}
.ys-buy-btn:hover{color:#fff}
.glass .ys-buy-btn:hover{color:#fff}
/* Keep hero and final CTA text color on hover */
.ys-hero-cta{color:#fff}
.ys-hero-cta:hover{color:#fff}
.ys-final-cta{color:#0f172a}
.ys-final-cta:hover{color:#0f172a}
.ys-final-cta-sec,.ys-final-cta-sec:hover,.ys-final-cta-sec:visited{color:#fff}
.ys-ann a{ color:#fff; text-decoration:underline; text-decoration-color:rgba(255,255,255,.6); text-underline-offset:4px }
.ys-ann a:hover{ color:#fff; text-decoration-color:#fff }
.ys-hero-first{ margin-top: 8px }
@media (min-width: 768px){ .ys-hero-first{ margin-top: 16px } }

/* Gap before brands/collaboration strip under hero */
.ys-brands{ margin-top: 28px }
@media (min-width: 768px){ .ys-brands{ margin-top: 56px } }

/* Brand wall (mobile sizing normalization) */
.ys-brand-grid{ justify-items:center; align-items:center }
.ys-brand-item{ height:24px; width:80px; display:flex; align-items:center; justify-content:center; overflow:hidden }
@media (min-width:640px){ .ys-brand-item{ height:32px; width:96px } }
@media (min-width:768px){ .ys-brand-item{ height:40px; width:112px } }
.ys-brand-img{ height:70%; width:auto; max-width:100%; object-fit:contain; display:block }
@media (min-width:640px){ .ys-brand-img{ height:80% } }
@media (min-width:768px){ .ys-brand-img{ height:100% } }

/* ===== Floating Contact Bar (right side) ===== */
.ys-contact-bar{position:fixed;top:50%;transform:translateY(-50%);right:16px;z-index:1000}
.ys-contact-bar ul{list-style:none;margin:0;padding:0}
.ys-contact-bar li{position:relative;margin-bottom:12px}
.ys-contact-bar a{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:#fff;color:#0f172a;font-size:18px;border-radius:50%;box-shadow:0 4px 10px rgba(0,0,0,.1);text-decoration:none;transition:box-shadow .2s ease, background-color .2s ease, color .2s ease}
.ys-contact-bar a:hover{transform:none}
.ys-contact-bar a svg{display:block}
.ys-contact-bar a.chat{color:#0b6cff}
.ys-contact-bar a.wechat{color:#16a34a}
.ys-contact-bar a.phone{color:#f97316}
.ys-contact-bar a.backtop{color:#6b7280}
.ys-contact-bar a.chat:hover{background:#0b6cff;color:#fff;box-shadow:0 6px 15px rgba(11,108,255,.3)}
.ys-contact-bar a.wechat:hover{background:#16a34a;color:#fff;box-shadow:0 6px 15px rgba(22,163,74,.3)}
.ys-contact-bar a.phone:hover{background:#f97316;color:#fff;box-shadow:0 6px 15px rgba(249,115,22,.3)}
.ys-contact-bar a.backtop:hover{background:#6b7280;color:#fff;box-shadow:0 6px 15px rgba(107,114,128,.3)}
.ys-contact-tip{position:absolute;top:50%;right:120%;transform:translateY(-50%);background:#111827;color:#fff;padding:6px 12px;border-radius:2px;font-size:12px;white-space:nowrap;opacity:0;visibility:hidden;pointer-events:none;transition:all .2s ease}
.ys-contact-bar li:hover .ys-contact-tip{opacity:1;visibility:visible;right:110%}
.ys-backtop{opacity:0;visibility:hidden;transition:opacity .2s ease, visibility .2s ease}
.ys-backtop.visible{opacity:1;visibility:visible}

@media (max-width: 480px){
  .ys-contact-bar{right:12px}
  .ys-contact-bar a{width:44px;height:44px}
}

/* ===== Side Contact Panel (rectangular) ===== */
.ys-contact-box{position:fixed;top:50%;right:16px;transform:translateY(-50%);z-index:1000}
.ys-contact{width:92px;background:#fff;border:1px solid #e5e7eb;border-radius:6px;box-shadow:0 6px 18px rgba(2,6,23,.12);overflow:visible}
.ys-ct-item{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;height:70px;text-decoration:none;color:#334155;border-bottom:1px solid #eef2f7}
.ys-ct-item:last-child{border-bottom:none}
.ys-ct-item .ico{display:block;line-height:1}
.ys-ct-item .ico svg{width:22px;height:22px;display:block}
.ys-ct-item .ico.wechat svg{width:24px;height:24px}
.ys-ct-item .txt{margin-top:6px;font-size:12px}
.ys-ct-item:hover{background:#f9fafb}
.ys-ct-item .ico.chat{color:#0b6cff}
.ys-ct-item .ico.wechat{color:#16a34a}
.ys-ct-item .ico.phone{color:#f97316}
.ys-ct-item .ico.qq{color:#1d9cf0}
.ys-ct-item .ico.mail{color:#2563eb}
.ys-ct-item .ico.up{color:#10b981}
/* Tooltip for rectangular contact items */
.ys-ct-tip{position:absolute;top:50%;right:calc(100% + 10px);transform:translateY(-50%) translateX(8px) scale(.98);background:#fff;color:#0f172a;padding:6px 8px;border-radius:2px;box-shadow:0 10px 24px rgba(2,6,23,.10);border:1px solid var(--ys-accent);opacity:0;visibility:hidden;pointer-events:auto;white-space:normal;min-width:0;width:160px;font-size:12px;line-height:1.35;z-index:1001;will-change:transform,opacity;display:none;text-align:center}
.ys-ct-tip strong{color:#0f172a;margin-right:6px}
.ys-ct-item.is-open .ys-ct-tip{opacity:1;visibility:visible;transform:translateY(-50%) translateX(0) scale(1);display:block}
.ys-ct-tip[aria-hidden="false"]{opacity:1;visibility:visible;transform:translateY(-50%) translateX(0) scale(1);display:block}
.ys-ct-tip[aria-hidden="true"]{opacity:0;visibility:hidden;transform:translateY(-50%) translateX(8px) scale(.98);display:none}
.ys-ct-tip img{display:block;width:120px;height:120px;object-fit:contain;border-radius:6px;margin:2px auto}
.ys-ct-tip::after{content:"";position:absolute;top:50%;left:100%;transform:translateY(-50%);width:10px;height:10px;background:#fff;border-right:1px solid var(--ys-accent);border-top:1px solid var(--ys-accent);box-shadow:2px -2px 6px rgba(2,6,23,.04);transform-origin:center;transform:translateY(-50%) rotate(45deg)}
/* Tip card layout */
.ys-tip-card{display:grid;gap:6px;justify-items:center}
.ys-tip-title{font-weight:600;font-size:12px;color:#0b1220;margin:0}
.ys-tip-text{color:#334155}
.ys-tip-actions{display:flex;gap:8px;justify-content:center}
.ys-ct-tip .ys-btn{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border:1px solid var(--ys-accent);border-radius:6px;background:rgba(59,130,246,.06);color:var(--ys-accent-600);cursor:pointer;font-size:12px;text-decoration:none}
.ys-ct-tip .ys-btn:hover{background:var(--ys-accent-600);color:#fff;border-color:var(--ys-accent-600)}
/* extra small variant */
.ys-ct-tip .ys-btn.xs{ padding:1px 5px; font-size:11px; line-height:1; border-radius:0 }

/* Inline layout for QQ number + copy button */
.ys-tip-inline{ display:flex; align-items:center; justify-content:center; gap:8px }
.ys-tip-inline .ys-tip-num{ color:#0f172a }

/* Link-like button for inline copy */
.ys-ct-tip .ys-link-btn{ background:none; border:none; padding:0; margin:0; color:var(--ys-accent-600); cursor:pointer; font:inherit; text-decoration:underline; text-underline-offset:2px }
.ys-ct-tip .ys-link-btn:hover{ color:var(--ys-accent) }
.ys-ct-tip .ys-tip-num{ font-weight:400 }

/* Phone tooltip uses default tip styles with slightly larger vertical padding */
.ys-tip-phone{ padding-top:16px; padding-bottom:16px }
.ys-tip-phone .ys-tip-card{ gap:10px }
.ys-tip-phone .ys-tip-title{}
.ys-tip-phone .ys-tip-text{}
.ys-tip-phone::after{}

/* QQ tooltip: a bit wider and roomier */
.ys-tip-qq{ width:160px; padding:16px 8px; line-height:1.35 }
.ys-tip-qq .ys-tip-card{ gap:10px }
.ys-tip-qq .ys-btn.xs{ margin-left:6px }

/* Mail tooltip spacing mirrors QQ */
.ys-tip-mail{ padding-top:16px; padding-bottom:16px }
.ys-tip-mail .ys-tip-card{ gap:10px }
.ys-tip-mail .ys-btn.xs{ margin-left:6px }
/* Copy toast */
.ys-toast{position:fixed;right:24px;bottom:36px;background:#111827;color:#fff;padding:8px 12px;border-radius:8px;opacity:0;transform:translateY(8px);transition:all .18s ease;z-index:1200;box-shadow:0 8px 24px rgba(2,6,23,.22)}
.ys-toast.show{opacity:1;transform:translateY(0)}
@media (max-width: 640px){ .ys-contact-box{right:12px} .ys-contact{width:88px} .ys-ct-item{height:64px} .ys-ct-item .ico svg{width:20px;height:20px} }
@media (max-width: 640px){ .ys-ct-item .ico.wechat svg{ width:22px; height:22px } }
.front-mobile-menu{list-style:none;margin:0;padding:0}
.front-mobile-menu a{display:block;color:#0f172a;text-decoration:none;padding:10px 12px;border-radius:12px}
.front-mobile-menu a:hover{background:#f1f5f9;color:#1d4ed8}
.ys-sep{color:var(--ys-muted)}
.ys-search-toggle{display:inline-flex;align-items:center;gap:6px;margin-left:0;background:transparent;border:1px solid var(--ys-border);color:var(--ys-text);border-radius:8px;padding:6px 10px;cursor:pointer}
.ys-search-toggle:hover{background:rgba(2,6,23,.05)}
.ys-main{display:block;flex:1 0 auto}
.ys-ann .ys-container{padding-top:10px;padding-bottom:10px}
/* Dark footer link colors */
.ys-footer a{ color:#f1f5f9 }
.ys-footer a:hover{ color:#fff; text-decoration:underline }
/* small margins helpers for hero */
.ys-mt-8{ margin-top:8px }
.ys-mt-12{ margin-top:12px }
/* search form inline helpers */
.ys-inline-form{ margin:12px 0 }
.ys-inline-form-row{ display:flex; gap:8px; align-items:center; max-width:520px }
/* js helpers */
.ys-col-10{ display:flex; flex-direction:column; gap:10px }
.ys-w-120{ width:120px }
.ys-search-panel[hidden]{display:none}
.ys-search-panel{position:fixed;top:var(--ys-header-h);left:0;right:0;z-index:1100;background:#fff;border-bottom:1px solid var(--ys-border);box-shadow:0 6px 18px rgba(2,6,23,.06);padding:12px 0}
.ys-search-panel .ys-input{height:48px}
/* Header inline search */
.header-search{gap:0}
.header-search-wrap{position:relative;width:160px}
.header-search-input{width:100%;height:28px;line-height:28px;padding:0 26px 0 8px;border:1px solid var(--ys-border);border-radius:4px;background:#fff;font-size:14px}
.header-search-input::placeholder{font-size:14px;color:#94a3b8}
.header-search-input:focus{outline:none;border-color:rgba(37,99,235,.45);box-shadow:0 0 0 2px rgba(59,130,246,.10)}
.header-search-ico{position:absolute;right:6px;top:50%;transform:translateY(-50%);display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border:0;background:transparent;color:#64748b;cursor:pointer}
.header-search-ico:hover{color:#2563eb}
.ys-hero{padding:40px 0;border-bottom:1px solid var(--ys-border);background:radial-gradient(1200px 400px at 50% -50%, rgba(59,130,246,.18), rgba(0,0,0,0))}
.ys-hero-title{font-size:42px;line-height:1.1;margin:0 0 12px}
.ys-hero-sub{font-size:18px;margin:0 0 20px;color:var(--ys-muted)}
.ys-hero-cta{display:flex;gap:12px}
/* Hero 宸﹀彸甯冨眬锛氬乏鏂囨 + 鍙充晶浜у搧鍗?*/
.ys-hero-inner{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px;align-items:flex-start}
.ys-hero-card{background:linear-gradient(180deg, #ffffff, #f7f9fe);border:1px solid var(--ys-border);border-radius:16px;padding:10px;box-shadow:0 6px 20px rgba(2,6,23,.06)}
.ys-hero-card .ys-card-title{margin:0 0 8px;font-size:18px;color:#1f2937}
.ys-hero-card .ys-price{font-size:32px;margin:6px 0 12px}
.ys-hero-shot{width:100%;aspect-ratio:4/3;object-fit:cover;background:#fff;border-radius:12px;border:1px solid var(--ys-border);margin-bottom:0;display:block}
.ys-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(59,130,246,.12);border:1px solid rgba(59,130,246,.28);color:#2563eb;border-radius:999px;padding:4px 10px;font-weight:600}
.ys-section{padding:var(--ys-section-pt,56px) 0;border-bottom:1px solid var(--ys-border)}
.ys-account{--ys-section-pt:26px}
.order-detail-page{--ys-section-pt:26px}
.ys-section-header{margin-bottom:24px}
.ys-section-header h1,.ys-section-header h2{margin:0 0 6px}
.ys-grid{display:grid;gap:16px}
.ys-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.ys-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.ys-card{background:var(--ys-card);border:1px solid var(--ys-border);border-radius:var(--ys-radius);padding:20px}
.ys-card.selectable{cursor:pointer;transition:border-color .16s ease, box-shadow .16s ease}
.ys-card.selectable:hover{border-color:rgba(37,99,235,.45);box-shadow:0 6px 18px rgba(2,6,23,.05)}
.ys-card.selected{border-color:var(--ys-accent-600);box-shadow:0 0 0 2px rgba(37,99,235,.25) inset, 0 8px 24px rgba(2,6,23,.06)}
/* 选中后，无论是否 hover 都保持深度高亮 */
.ys-card.selected:hover{border-color:var(--ys-accent-600);box-shadow:0 0 0 2px rgba(37,99,235,.25) inset, 0 8px 24px rgba(2,6,23,.06)}
.ys-plan-card.disabled{opacity:.6}
.ys-plan-card.disabled .ys-btn{pointer-events:none;background:#e5e7eb;border-color:#e5e7eb;color:#94a3b8}
.ys-plan-card.disabled .ys-btn:hover{background:#e5e7eb;color:#94a3b8}
.ys-card-featured{background:linear-gradient(180deg,#ffffff, #fbfdff)}
.ys-price{font-size:28px;font-weight:700;margin:8px 0 12px}
.ys-list{margin:0 0 16px;padding-left:18px}
.ys-btn{display:inline-flex;align-items:center;justify-content:center;border-radius:8px;border:1px solid var(--ys-border);background:transparent;color:var(--ys-text);padding:10px 14px;font-weight:600;transition:background-color .2s ease,color .2s ease,border-color .2s ease}
.ys-btn:hover{border-color:rgba(2,6,23,.15)}
.ys-btn-primary {
    background: var(--ys-accent);
    border-color: transparent;
    color: #fff;
    box-shadow: 0 2px 4px rgba(0, 0, 0, .1);
}
.ys-btn-primary:hover { background: var(--ys-accent-600); color:#fff; }
.ys-btn-primary, .ys-btn-primary:hover, .ys-btn-primary:focus { color:#fff !important; }
.ys-btn-primary:focus { color:#fff; }
.ys-btn{transition:transform .16s ease, box-shadow .16s ease}
.ys-btn:hover{transform:translateY(-1px)}
.ys-btn-outline{border-color:rgba(37,99,235,.35);background:rgba(59,130,246,.10);color:var(--ys-accent-600)}
.ys-btn-outline:hover{background:var(--ys-accent-600);border-color:transparent;color:#fff}
.ys-btn-dark{background:#0f172a;border-color:transparent;color:#fff}
.ys-btn-dark:hover{opacity:.92;color:#fff}
.ys-btn-ghost{background:transparent;border-color:transparent;color:var(--ys-text)}
.ys-btn-ghost:hover{background:rgba(2,6,23,.06);color:var(--ys-accent-600)}
.ys-auth{display:inline-flex;gap:8px;margin-left:8px}
.ys-buy-cta{margin-left:4px}
.ys-content{padding:24px 0}
.ys-article{margin-bottom:24px}
.ys-article-title{margin:0 0 8px}
.ys-list-group{display:grid;gap:12px}
.ys-list-item{padding:16px;border-radius:12px;border:1px solid var(--ys-border);background:var(--ys-card)}
.ys-orders-list{max-height:420px;overflow:auto}
.ys-order-item{cursor:pointer}
.ys-order-item:not([data-status="paid"]){cursor:default}
.ys-order-item.active:hover{border-color:var(--ys-accent-600);box-shadow:0 0 0 2px rgba(37,99,235,.18) inset}

/* Glass header (home) */
.ys-header-glass{background:rgba(255,255,255,.55);border-bottom-color:transparent;backdrop-filter:saturate(180%) blur(10px)}
.ys-header-glass.scrolled{background:#fff;border-bottom:1px solid var(--ys-border);box-shadow:0 4px 20px rgba(2,6,23,.06)}

/* --- New Home (hv-*) --- */
.hv-hero{padding:96px 0 48px;background:radial-gradient(1200px 400px at 50% -60%, rgba(100,116,139,.14), rgba(0,0,0,0))}
.hv-hero-inner{display:grid;grid-template-columns:1fr;gap:24px;align-items:center;text-align:center}
.hv-hero-title{margin:0 0 12px;font-size:clamp(36px, 6vw, 60px);font-weight:800;letter-spacing:-.02em}
.hv-hero-tagline{margin:0 0 18px;color:var(--ys-muted);font-size:clamp(16px, 2.4vw, 20px)}
.hv-cta{display:flex;gap:12px;justify-content:center}
.hv-btn-lg{padding:14px 18px;font-size:16px}
.hv-hero-visual{display:flex;justify-content:center}
.hv-hero-image,.hv-hero-video{width:min(920px,100%);border-radius:16px;border:1px solid var(--ys-border);box-shadow:0 12px 40px rgba(2,6,23,.16);animation:hv-float 6s ease-in-out infinite}
@keyframes hv-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

.hv-section{padding:56px 0}
.hv-sec-title{margin:0 0 20px;font-size:28px;font-weight:800;text-align:center}

/* Features */
.hv-feature-grid{display:grid;gap:18px;grid-template-columns:repeat(3,minmax(0,1fr))}
.hv-feature-card{display:flex;gap:12px;background:#fff;border:1px solid var(--ys-border);border-radius:14px;padding:18px;box-shadow:0 1px 3px rgba(2,6,23,.06);transition:transform .25s ease, box-shadow .25s ease}
.hv-feature-card:hover{transform:translateY(-6px);box-shadow:0 12px 20px rgba(2,6,23,.12)}
.hv-ico{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:rgba(59,130,246,.10);color:var(--ys-accent-600);border:1px solid rgba(59,130,246,.28)}
.hv-feature-body h3{margin:0 0 6px;font-size:18px}
.hv-feature-body p{margin:0;color:var(--ys-muted)}

/* Demo */
.hv-demo{background:linear-gradient(180deg, rgba(241,245,249,.6), rgba(255,255,255,0))}
.demo-tabs{display:inline-flex;gap:8px;border:1px solid var(--ys-border);background:#fff;border-radius:999px;padding:6px;margin:6px auto 18px;justify-content:center}
.demo-tab{appearance:none;border:0;background:transparent;padding:8px 14px;border-radius:999px;color:var(--ys-text);cursor:pointer}
.demo-tab.active,.demo-tab[aria-selected="true"]{background:rgba(59,130,246,.12);color:var(--ys-accent-600);font-weight:700}
.demo-tab:focus{outline:2px solid rgba(59,130,246,.45); outline-offset:2px}
.demo-stage{position:relative}
.demo-screen{display:block;width:100%;max-width:980px;margin:0 auto;border-radius:16px;border:1px solid var(--ys-border);box-shadow:0 20px 50px rgba(2,6,23,.18);transition:opacity .15s ease}
.demo-screen.fade{opacity:.2}

/* FAQ */
.hv-accordion{max-width:880px;margin:0 auto}
.hv-acc-item{background:#fff;border:1px solid var(--ys-border);border-radius:12px;padding:8px 12px;margin:10px 0;transition:border-color .2s ease, box-shadow .2s ease}
.hv-acc-item[open]{box-shadow:0 8px 16px rgba(2,6,23,.08)}
.hv-acc-item summary{display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-weight:700}
.hv-acc-item summary .icon{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:6px;background:rgba(59,130,246,.08);color:var(--ys-accent-600);transition:transform .2s ease}
.hv-acc-item[open] summary .icon{transform:rotate(45deg)}
.hv-acc-item .a{padding:8px 2px 2px}

/* Final CTA */
.hv-final-cta{background:linear-gradient(45deg, var(--ys-gradient-1), var(--ys-gradient-2));color:#fff;padding:48px 0;margin:26px 0 0}
.hv-final-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.hv-final-inner h2{margin:0 0 6px;font-size:30px}
.hv-final-inner p{margin:0;color:rgba(255,255,255,.85)}
.hv-final-actions{display:flex;gap:12px}

@media (max-width: 992px){
  .hv-feature-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .hv-final-inner{flex-direction:column;align-items:flex-start}
}

/* ===== Checkout styles (migrated from template inline) ===== */
#ys-pay-methods{width:100%}
#ys-pay-methods .ck-payway{position:relative;display:inline-block;width:auto;max-width:100%;cursor:pointer;vertical-align:top}
.ys-pay-img{display:block;max-width:100%;height:auto;border-radius:12px;border:1px solid #e2e8f0;background:#fff}
.ck-payway .ys-check{position:absolute;right:10px;top:50%;width:22px;height:22px;border-radius:999px;background:#16a34a;color:#fff;font-size:12px;line-height:22px;text-align:center;box-shadow:0 2px 6px rgba(2,6,23,.18);border:2px solid #fff;display:inline-flex;align-items:center;justify-content:center;opacity:0;transform:translateY(-50%) scale(.9);transition:opacity .18s ease, transform .18s ease}
.ck-payway.active .ys-check{opacity:1;transform:translateY(-50%) scale(1)}
/* Coupon box */
#ck-coupon-box{display:flex;align-items:center;gap:8px;justify-content:flex-end}
#ck-coupon-box.hidden{display:none}
#ck-coupon-input{width:200px;height:30px;line-height:30px;padding:0 10px;border:1px solid #93c5fd;border-radius:4px;background:#fff;color:#0f172a;outline:none;transition:box-shadow .16s ease,border-color .16s ease}
#ck-coupon-input:focus{border-color:#3b82f6;box-shadow:0 0 0 2px rgba(59,130,246,.16)}
#ck-coupon-input::placeholder{color:#94a3b8}
#ck-coupon-apply{height:30px;padding:0 10px;border-radius:4px;border:1px solid #dbeafe;background:#eff6ff;color:#2563eb;font-weight:600;cursor:pointer}
#ck-coupon-apply:hover{filter:brightness(1.03)}
#ck-coupon-msg{min-height:18px;color:#64748b}
@media (max-width: 640px){
  .hv-feature-grid{grid-template-columns:1fr}
}

/* Dark mode tuning */
@media (prefers-color-scheme: dark){
  .ys-header-glass{background:rgba(26,32,44,.6)}
  .hv-demo{background:linear-gradient(180deg, rgba(30,41,59,.6), rgba(0,0,0,0))}
  .hv-feature-card{background:#0b1220;border-color:#1f2937}
  .demo-tabs{background:#0b1220;border-color:#1f2937}
}
.ys-input{width:100%;height:52px;border:1px solid var(--ys-border);background:#f7f9fe;border-radius:12px;padding:12px 14px;font-size:15px;color:var(--ys-text)}
.ys-input::placeholder{color:#94a3b8}
.ys-input:focus{outline:none;border-color:rgba(37,99,235,.45);box-shadow:0 0 0 4px rgba(59,130,246,.12)}

/* Order detail: bind box layout */
.ys-bind-box{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;width:100%;background:#fff;border:1px solid var(--ys-border);border-radius:8px;padding:12px}
.ys-bind-box .ys-input{width:100%;height:44px;border-radius:10px}
.ys-bind-box .ys-btn{height:44px;display:inline-flex;align-items:center;white-space:nowrap; width:96px; padding:0 14px; box-sizing:border-box}

/* Order detail: domain item inline edit */
.domain-item{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}
.domain-item .domain-edit{display:none;grid-template-columns:1fr auto auto;gap:8px;align-items:center}
.domain-item.editing .domain-info{display:none}
.domain-item.editing .domain-actions{display:none}
.domain-item.editing .domain-edit{display:grid}

/* Payment method icon inline */
.pay-method img{height:16px;width:auto;vertical-align:middle;margin-right:6px;border-radius:2px}

/* Auth pages */
.auth-wrap{max-width:760px;margin:0 auto}
.auth-title{text-align:center;margin:8px 0 24px;font-size:36px}

/* ====== Ticket Center (right pane only; keep left sidebar unchanged) ====== */
.ys-account .ac-main .card{background:var(--ys-card);border:1px solid var(--ys-border);border-radius:12px;padding:25px}
.ys-account .ac-main .card-title{font-size:18px;font-weight:700;margin:0 0 20px}
.ys-account .ac-main .form-group{margin-bottom:16px}
.ys-account .ac-main .form-group label{display:block;font-size:14px;font-weight:600;margin-bottom:8px}
.ys-account .ac-main .form-group input[type="text"],
.ys-account .ac-main .form-group textarea,
.ys-account .ac-main .form-group select{width:100%;padding:10px 12px;font-size:15px;border-radius:8px;border:1px solid var(--ys-border);background:#fff;box-sizing:border-box}
.ys-account .ac-main .form-group textarea{min-height:120px;resize:vertical}
.ys-account .ac-main .form-group input:focus,
.ys-account .ac-main .form-group textarea:focus,
.ys-account .ac-main .form-group select:focus{border-color:rgba(37,99,235,.55);outline:none;box-shadow:0 0 0 3px rgba(59,130,246,.18)}
.ys-account .ac-main .file-upload-wrapper{position:relative;display:flex;align-items:center;gap:12px}
/* 隐藏原生文件输入，改为点击 label 触发，避免“未选择任何文件”原生占位文本占据显示 */
.ys-account .ac-main .file-upload-wrapper input[type="file"]{
  position:absolute;
  width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);clip-path:inset(50%);
  white-space:nowrap;border:0;opacity:0;
}
.ys-account .ac-main .file-upload-label{padding:8px 16px;font-size:14px;font-weight:600;border-radius:6px;cursor:pointer;color:var(--ys-text);background:#f3f4f6;border:1px solid var(--ys-border)}
.ys-account .ac-main .form-actions{margin-top:18px}
.ys-account .ac-main .btn-primary{display:inline-flex;align-items:center;justify-content:center;padding:12px 20px;font-size:15px;font-weight:600;color:#fff;background:var(--ys-accent);border:1px solid transparent;border-radius:8px;cursor:pointer}
.ys-account .ac-main .btn-primary:hover{background:var(--ys-accent-600);color:#fff}

.ys-account .ac-main .ticket-list{display:flex;flex-direction:column;gap:16px}
.ys-account .ac-main .ticket-item{border:1px solid var(--ys-border);border-radius:10px;background:#fff}
/* 使用 details/summary 折叠：头部作为 summary，正文在 .ticket-thread */
.ys-account .ac-main .ticket-item > .ticket-header{display:flex;justify-content:space-between;align-items:center;padding:20px;margin:0;gap:10px;flex-wrap:wrap;list-style:none;cursor:pointer}
.ys-account .ac-main .ticket-item > summary::-webkit-details-marker{display:none}
.ys-account .ac-main .ticket-item > summary::marker{content:''}
.ys-account .ac-main .ticket-item > .ticket-thread{display:none;padding:0 20px 20px 20px;border-top:1px solid var(--ys-border)}
.ys-account .ac-main .ticket-item[open] > .ticket-thread{display:block}
.ys-account .ac-main .ticket-item[open] > .ticket-header{border-bottom:1px solid var(--ys-border)}
.ys-account .ac-main .ticket-title{font-size:16px;font-weight:700;margin:0}
.ys-account .ac-main .ticket-meta{font-size:14px;color:var(--ys-muted)}
.ys-account .ac-main .status-badge{padding:4px 10px;font-size:12px;font-weight:600;border-radius:999px;background:#e0f2fe;color:#0369a1;border:1px solid rgba(3,105,161,.2)}
.ys-account .ac-main .ticket-thread{display:flex;flex-direction:column;gap:16px}
.ys-account .ac-main .thread-message{display:flex;gap:0}
.ys-account .ac-main .thread-message .avatar{width:36px;height:36px;border-radius:50%;flex-shrink:0}
.ys-account .ac-main .message-content{display:flex;flex-direction:column;width:100%}
.ys-account .ac-main .message-header{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.ys-account .ac-main .message-sender{font-weight:700;font-size:14px}
.ys-account .ac-main .message-time{font-size:12px;color:var(--ys-muted)}
.ys-account .ac-main .message-bubble{padding:12px 16px;border-radius:12px;line-height:1.6;background:var(--ys-bg);border:1px solid var(--ys-border)}
.ys-account .ac-main .ticket-reply{margin-top:12px}
.ys-account .ac-main .ticket-reply textarea{width:100%;padding:10px 12px;font-size:14px;border-radius:8px;border:1px solid var(--ys-border);background:#fff;box-sizing:border-box}
.ys-account .ac-main .ticket-reply textarea:focus{border-color:rgba(37,99,235,.55);outline:none;box-shadow:0 0 0 3px rgba(59,130,246,.18)}
.ys-account .ac-main .ticket-reply .reply-actions{display:flex;align-items:center;gap:12px;margin-top:8px}
.auth-card{background:var(--ys-card);border:1px solid var(--ys-border);border-radius:20px;padding:32px 32px 36px;box-shadow:0 12px 40px rgba(2,6,23,.08)}
.auth-form{max-width:520px;margin:0 auto}
.auth-field + .auth-field{margin-top:16px}
.auth-row{display:flex;align-items:center;justify-content:space-between;margin:12px 0 14px}
.auth-remember{color:var(--ys-muted);font-size:14px}
.auth-submit{width:100%;height:52px;margin-top:6px}
.auth-foot{margin-top:12px;color:var(--ys-muted);text-align:center}
.auth-foot .ys-link{margin-left:8px}
.auth-alert{border-radius:12px;padding:10px 12px;margin-bottom:12px}

/* Article/Page content width */
.ys-article-content{max-width:720px;margin:0 auto}
.ys-article-header,.ys-article-title{max-width:720px;margin-left:auto;margin-right:auto}
.ys-content .alignwide{max-width:1120px;margin-left:auto;margin-right:auto}
.ys-content .alignfull{width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}

/* Utilities */
.no-scrollbar{scrollbar-width:none;-ms-overflow-style:none}
.no-scrollbar::-webkit-scrollbar{display:none}
.auth-alert.err{background:#fee2e2;border:1px solid #fecaca;color:#b91c1c}
.ys-timeline{display:grid;gap:16px}
.ys-status{margin-top:12px;min-height:24px}
.ys-status.ok{color:var(--ys-good)}
.ys-status.err{color:var(--ys-bad)}
.ys-doc{max-width:var(--ys-container-w);margin:0 auto}
.ys-doc h2{margin-top:20px}
.ys-doc h3{margin-top:12px}
.ys-guide h2,.ys-guide h3{position:relative;font-weight:700}
.ys-guide h2{font-size:22px;margin:22px 0 10px;padding-left:12px}
.ys-guide h3{font-size:16px;margin:20px 0 0;padding:12px 14px;background:#fff;border:1px solid var(--ys-border);border-radius:12px 12px 0 0}
.ys-guide h2::before{content:"";position:absolute;left:0;top:.25em;width:3px;height:1.2em;background:var(--ys-accent);border-radius:2px}
.ys-guide h3::before{content:none}
/* 默认列表保持普通样式 */
.ys-guide ul{margin:0 0 14px 18px;padding:0;list-style:none}
.ys-guide ul>li{position:relative;margin:0 0 6px 0;padding:0 0 0 18px;list-style:none}
.ys-guide ul>li::before{content:"\2013"; /* en dash */ position:absolute; left:0; top:.2em; color:var(--ys-muted)}
/* Do NOT show dash bullets in the TOC */
.ys-guide .guide-toc ul>li::before{content:none !important}
.ys-guide ol{margin:0 0 14px 18px;padding:0}
.ys-guide ol>li{margin:0 0 6px 0;padding:0;list-style:decimal}
/* H3 后紧跟列表 → 白色卡片（标题+列表合并为一块） */
.ys-guide h3 + ul, .ys-guide h3 + ol{margin:0 0 16px 0;padding:6px 16px 10px 26px;background:#fff;border:1px solid var(--ys-border);border-top:0;border-radius:0 0 12px 12px}
.ys-guide h3 + ul{list-style:none}
.ys-guide h3 + ol{list-style:decimal}
.ys-guide h3 + ul>li, .ys-guide h3 + ol>li{padding:10px 0;border-top:1px dashed var(--ys-border)}
.ys-guide h3 + ul>li:first-child, .ys-guide h3 + ol>li:first-child{border-top:0}
.ys-guide p{margin:6px 0}
.ys-guide pre{background:#f8fafc;border:1px solid var(--ys-border);border-left:3px solid var(--ys-accent);border-radius:8px;padding:10px 12px;overflow:auto}
.ys-guide code{background:#f8fafc;border:1px solid var(--ys-border);border-radius:6px;padding:2px 6px}
.ys-guide pre code{border:0;background:transparent;padding:0}
.ys-guide img{display:block;max-width:100%;height:auto;border:1px solid var(--ys-border);border-radius:10px;background:#fff;margin:8px 0}
.ys-guide hr{border:0;border-top:1px solid var(--ys-border);margin:16px 0}
.ys-toc{background:#fff;border:1px solid var(--ys-border);border-radius:12px;padding:12px;margin:10px 0 18px}
.ys-toc-title{font-weight:700;margin-bottom:6px}
.ys-toc-list{margin:0;padding-left:16px}
.ys-toc-list li{list-style:disc;margin:4px 0}
.guide-layout{display:grid;grid-template-columns:260px 1fr;gap:24px}
.guide-aside{position:sticky;top:calc(var(--ys-header-h) + 16px);align-self:start}
.guide-toc{background:#fff;border:1px solid var(--ys-border);border-radius:12px;padding:12px}
.guide-toc-title{font-weight:700;margin-bottom:6px;color:var(--ys-text)}
.guide-toc ul{margin:0;padding-left:0;list-style:none}
.guide-toc li{margin:6px 0;list-style:none}
.guide-toc a, .guide-toc a:visited{display:block;position:relative;color:var(--ys-text);padding:6px 8px 6px 10px;border-left:none;border-radius:6px}
.guide-toc a::before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;background:transparent;border-radius:2px}
.guide-toc a.active{color:var(--ys-accent);background:rgba(59,130,246,.06)}
.guide-toc a.active::before{background:var(--ys-accent)}
/* Stronger override to defeat .ys-guide ul>li default bullets */
.ys-guide .guide-toc ul{list-style:none !important;margin-left:0;padding-left:0}
.ys-guide .guide-toc ul>li{list-style:none !important;margin-left:0;padding-left:0}
.guide-main{max-width:880px}
.guide-card{background:#fff;border:1px solid var(--ys-border);border-radius:14px;box-shadow:0 1px 2px rgba(2,6,23,.04);margin:0 0 18px}
.guide-card>h2{margin:0;padding:14px 16px;border-bottom:1px solid var(--ys-border);font-size:20px;font-weight:700}
.guide-card>h3{margin:0;padding:14px 16px;border-bottom:1px solid var(--ys-border);font-size:18px;font-weight:700;background:transparent;border-radius:0}
.guide-body{padding:14px 16px}
.guide-body p{line-height:1.7}
.guide-body ul{margin:0 0 12px 18px;padding:0}
.guide-body li{margin:6px 0}
@media (max-width: 992px){
  .guide-layout{grid-template-columns:1fr}
  .guide-aside{position:fixed;left:12px;right:12px;top:calc(var(--ys-header-h) + 12px);max-height:70vh;overflow:auto;z-index:1200;transform:translateY(-12px);opacity:0;pointer-events:none;transition:transform .18s ease,opacity .18s ease}
  body.toc-open .guide-aside{opacity:1;transform:none;pointer-events:auto}
  .guide-mobilebar{display:block !important;margin:0 0 8px}
  .guide-toc-toggle{background:#fff;border:1px solid var(--ys-border);border-radius:8px;padding:8px 12px;color:var(--ys-text)}
  .guide-overlay{display:none}
  body.toc-open .guide-overlay{display:block;position:fixed;inset:0;background:rgba(15,23,42,.35);z-index:1100}
  .guide-main{max-width:none}
}

/* default: hide mobile bar */
.guide-mobilebar{display:none}

/* callouts */
.ys-callout{border:1px solid var(--ys-border);border-radius:12px;padding:12px 14px;margin:10px 0}
.ys-callout-info{background:#eef2ff}
.ys-callout-success{background:#ecfdf5}
.ys-callout-warning{background:#fffbeb}
.ys-callout-danger{background:#fef2f2}
.log-timeline{display:grid;gap:16px;position:relative;margin-left:4px}
.log-item{display:grid;grid-template-columns:20px 1fr;gap:12px;position:relative}
.log-rail{position:relative}
.log-rail::before{content:"";position:absolute;top:0;bottom:-16px;left:9px;width:2px;background:var(--ys-border)}
.log-item:last-child .log-rail::before{bottom:8px}
.log-dot{position:absolute;top:6px;left:3px;width:12px;height:12px;border-radius:999px;background:#fff;border:2px solid var(--ys-accent);box-shadow:0 0 0 3px rgba(59,130,246,.08)}
.log-body{background:var(--ys-card);border:1px solid var(--ys-border);border-radius:12px;padding:14px}
.log-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.log-badge{display:inline-block;background:rgba(59,130,246,.10);border:1px solid rgba(59,130,246,.28);color:var(--ys-accent-600);border-radius:999px;padding:2px 10px;font-weight:600}
.log-date{color:var(--ys-muted);font-size:13px}
.log-content{color:var(--ys-text)}
.log-content p{margin:0 0 8px}
.log-content ul{margin:6px 0 0 18px}
.log-content li{margin:4px 0}
.ys-checkout{display:grid;grid-template-columns:1.1fr .9fr;gap:20px}
.ys-paybox{background:var(--ys-card);border:1px solid var(--ys-border);border-radius:12px;padding:16px}
.ys-paybox h3{margin:0 0 10px}
.ys-pay-methods{display:flex;gap:10px;margin-bottom:10px}
.ys-pay-option{flex:1 1 auto;display:flex;align-items:center;justify-content:center;border:1px solid var(--ys-border);border-radius:10px;padding:10px 12px;cursor:pointer;background:#f7f9fe}
.ys-pay-option.active{border-color:var(--ys-accent-600);background:rgba(59,130,246,.08)}
.ys-pay-area{display:grid;grid-template-columns:160px 1fr;gap:16px;align-items:center}
.ys-qr{width:160px;height:160px;border:1px dashed var(--ys-border);border-radius:12px;background:repeating-linear-gradient(45deg,#f1f5f9,#f1f5f9 10px,#eef2f7 10px,#eef2f7 20px);display:flex;align-items:center;justify-content:center;color:#64748b}
.ys-pay-actions{display:flex;gap:10px;margin-top:10px}
.ys-note{color:var(--ys-muted);font-size:13px}
.ys-footer{border-top:1px solid var(--ys-border)}
.ys-footer-inner{display:flex;gap:16px;align-items:center;justify-content:space-between;min-height:64px}
.ys-menu-footer a{color:var(--ys-muted)}
/* --- Guide Enhancements --- */
@media print{
  .ys-header,.ys-actions,.guide-aside,.ys-footer{display:none !important}
  .guide-layout{grid-template-columns:1fr !important}
  .guide-card{box-shadow:none !important;border:1px solid #ccc}
  body{background:#fff;color:#000}
}
/* Account center layout */
.ac-wrap { display:grid; grid-template-columns: 280px 1fr; gap:30px; align-items:start; }
.ac-main { grid-column: 2 / -1; }
.ac-side { background:#fff; border:1px solid var(--ys-border); border-radius:14px; padding:16px; color: var(--ys-text); width:280px; align-self:start; }
.ac-profile { display:flex; align-items:center; gap:12px; margin:4px 0 12px; }
.ac-avatar-wrap { position:relative; line-height:0; }
.ac-avatar { width:48px; height:48px; border-radius:999px; object-fit:cover; border:1px solid var(--ys-border); background:#f8fafc; display:block; }
.ac-avatar-edit { position:absolute; right:-4px; bottom:-4px; width:20px; height:20px; display:inline-flex; align-items:center; justify-content:center; border-radius:999px; border:1px solid var(--ys-border); background:#fff; color:var(--ys-muted); cursor:pointer; box-shadow:0 1px 2px rgba(2,6,23,.06); }
.ac-avatar-edit:hover { color:var(--ys-text); border-color:#d1d5db; }
.ac-user { display:flex; flex-direction:column; min-width:0; }
.ac-name { font-size:16px; font-weight:700; color:var(--ys-text); line-height:1.2; }
.ac-mail { font-size:13px; color:var(--ys-muted); line-height:1.2; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.ac-nav {
    display: grid;
    gap: 8px;
}
.ac-nav a {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 15px;
    border-radius: 8px;
    color: var(--ys-text);
    font-size: 15px;
    transition: background-color .2s ease;
    border-left: none;
}
.ac-nav a:hover { background-color: rgba(2,6,23,.05); }
.ac-nav a.active { background-color: rgba(59,130,246,.10); color: var(--ys-accent); font-weight:600; border-left:none; }
.ac-nav a .ac-ico { width:20px; height:20px; flex:0 0 20px; color: var(--ys-muted); }
.ac-nav a.active .ac-ico { color: var(--ys-accent); }
.ac-main { padding-top: 0; }
.ac-main-header {
    margin-bottom: 12px;
    background:#fff;
    border:1px solid var(--ys-border);
    border-radius:12px;
    padding:16px;
}
.ac-main-header h2 {
    font-size: 28px;
    margin: 0 0 5px;
}
.order-filters {
    display: flex;
    gap: 10px;
    margin-bottom: 16px;
    background:#fff;
    border:1px solid var(--ys-border);
    border-radius:12px;
    padding:10px 12px;
}
.filter-btn {
    background-color: #fff;
    border: 1px solid var(--ys-border);
    border-radius: 8px;
    padding: 8px 16px;
    cursor: pointer;
    transition: all .2s ease;
}
.filter-btn.active, .filter-btn:hover {
    background-color: var(--ys-accent);
    color: #fff;
    border-color: var(--ys-accent);
}
.orders-list-new {
    display: grid;
    gap: 20px;
    /* 防止在容器有额外高度时拉伸每个订单卡片行 */
    align-content: start;
    align-items: start;
}
.order-card-new {
    background-color: #fff;
    border: 1px solid var(--ys-border);
    border-radius: 12px;
    padding: 20px;
    transition: border-color .18s ease, box-shadow .18s ease;
}
.order-card-new:hover {
    border-color: rgba(37,99,235,.35);
    box-shadow: 0 0 0 2px rgba(37,99,235,.12) inset;
}
.order-card-header {
    display: flex;
    justify-content: space-between;
    font-size: 14px;
    color: var(--ys-muted);
    padding-bottom: 15px;
    border-bottom: 1px solid var(--ys-border);
}
.order-id{display:inline-flex;align-items:center;gap:8px}
.order-copy{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border:1px solid var(--ys-border);border-radius:6px;color:var(--ys-muted);font-size:12px}
.order-copy:hover{border-color:rgba(2,6,23,.20);color:var(--ys-text)}
.order-card-body {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    gap: 20px;
    padding-top: 15px;
}
.order-price-actions {
    grid-column: 1 / -1;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 15px;
}
.order-actions-new {
    display: flex;
    align-items: center;
    gap: 10px;
}
.theme-preview img {
    width: 80px;
    height: 80px;
    border-radius: 8px;
    object-fit: cover;
}
.theme-details .theme-name {
    font-size: 18px;
    font-weight: 600;
    margin: 0 0 5px;
}
.theme-details .theme-description {
    font-size: 14px;
    color: var(--ys-muted);
    margin: 0 0 10px;
}
.theme-meta {
    font-size: 13px;
    color: var(--ys-muted);
}
.order-domain-meta{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ys-muted);margin-top:6px}
.order-domain-meta .odm-label{flex:0 0 auto}
.order-domain-meta .odm-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media (max-width: 640px){
  .order-domain-meta .odm-text{white-space:normal;word-break:break-all}
}

/* ===== Orders table layout (account right panel) ===== */
.ys-account .content-panel .filter-bar{
  display:grid;
  grid-template-columns: minmax(200px, 2fr) minmax(280px, 3fr) auto auto;
  gap:12px;
  align-items:center;
  /* 去掉周围卡片边框与背景，仅保留下边分割线 */
  background:transparent;
  border:0;
  border-bottom:1px solid var(--ys-border);
  border-radius:0;
  padding:8px 0 12px 0;
  margin-bottom:16px;
}
.ys-account .content-panel .filter-group{display:flex;flex-direction:column;min-width:0}
.ys-account .content-panel .filter-group label{display:none;margin:0}
.ys-account .content-panel .filter-group input,
.ys-account .content-panel .filter-group select{height:34px;line-height:34px;padding:0 10px;font-size:13px;border-radius:8px;border:1px solid var(--ys-border);background:#fff;width:100%}
.ys-account #ys-order-status{width:min(100%, 220px)}
.ys-account .content-panel .filter-group input:focus,
.ys-account .content-panel .filter-group select:focus{border-color:rgba(37,99,235,.55);outline:none;box-shadow:0 0 0 3px rgba(59,130,246,.18)}
.ys-account .content-panel .ys-search-input{width:100%;max-width:none}
.ys-account .content-panel .ys-search-btn{border-radius:0 !important;height:34px;line-height:34px;padding:0 12px;font-size:13px}
.ys-account .content-panel .ys-reset-btn{height:34px;line-height:34px;padding:0 12px;font-size:13px;background:#fff;border:1px solid var(--ys-border);color:var(--ys-muted)}
.ys-account .content-panel .ys-reset-btn:hover{border-color:rgba(37,99,235,.55);color:var(--ys-accent-600)}
@media (max-width: 992px){
  .ys-account .content-panel .filter-bar{grid-template-columns:1fr}
  .ys-account #ys-order-status{width:100%}
}
.ys-account .content-panel{
  background:#fff;
  border-radius:8px;
  box-shadow:0 2px 8px rgba(0,0,0,0.05);
  padding:24px 30px;
}
.ys-account .filter-section{
  display:flex;align-items:center;gap:16px;
  padding-bottom:24px;border-bottom:1px solid var(--ys-border);
}
.ys-account .filter-section select,
.ys-account .filter-section input{
  padding:10px 14px;border:1px solid var(--ys-border);border-radius:6px;font-size:14px;background:#fff;
}
.ys-account .filter-section input{ flex:1; min-width:200px; }
.ys-account .btn{ padding:10px 20px; border:0; border-radius:6px; font-size:14px; font-weight:600; cursor:pointer; }
.ys-account .btn.btn-primary{ background:var(--ys-accent); color:#fff; }
.ys-account .btn.btn-primary:hover{ background:var(--ys-accent-600); color:#fff; }
.ys-account .btn.btn-secondary{ background:var(--ys-border); color:var(--ys-muted); }
.ys-account .btn.btn-secondary:hover{ background:#dbe1e8; }

.ys-account .orders-table{ width:100%; border-collapse:collapse; margin-top:24px; }
.ys-account .orders-table th,
.ys-account .orders-table td{ padding:16px 8px; text-align:left; vertical-align:middle; border-bottom:1px solid var(--ys-border); }
.ys-account .orders-table th{ color:var(--ys-muted); font-weight:600; font-size:14px; white-space:nowrap; }
.ys-account .orders-table td{ font-size:15px; color:var(--ys-text); }
.ys-account .product-info-minimal .name{ font-weight:400; margin-bottom:4px; }
.ys-account .product-info-minimal .type{ font-size:13px; color:var(--ys-muted); }
.ys-account .status{ display:inline-flex; align-items:center; gap:8px; }
.ys-account .status .dot{ width:8px; height:8px; border-radius:999px; display:inline-block; }
.ys-account .status-completed{ color:#059669; }
.ys-account .status-completed .dot{ background:#16a34a; }
.ys-account .status-pending{ color:#c2410c; }
.ys-account .status-pending .dot{ background:#f59e0b; }
.ys-account .status-processing{ color:#2563eb; }
.ys-account .status-processing .dot{ background:#60a5fa; }
.ys-account .actions a{ margin-right:12px; font-size:14px; white-space:nowrap; }
.ys-account .actions a:last-child{ margin-right:0; }
.ys-account .actions .btn-pay{ color:#d97706; font-weight:600; }
.ys-account .actions .btn-pay:hover{ color:#b45309; }
.order-price {
    font-size: 20px;
    font-weight: 700;
    color: #00B894;
}
.order-actions-new {
    display: flex;
    align-items: center;
    gap: 10px;
    justify-content: flex-end;
}
.order-status-chip {
    font-size: 12px;
    font-weight: 500;
    padding: 3px 10px;
    border-radius: 20px;
}
.status-completed { background-color: #f0fff9; color: #10b981; border: 1px solid #a7f3d0; }
.status-processing { background-color: #fffbeb; color: #f59e0b; border: 1px solid #fde68a; }
.status-pending { background-color: #fff1f2; color: #ef4444; border: 1px solid #fecaca; }

.order-actions-new .ys-btn {
    padding: 5px 12px;
    font-size: 13px;
    min-width: 80px;
    text-align: center;
}
/* chips */
.chip{display:inline-flex;align-items:center;height:22px;padding:0 8px;border-radius:999px;font-size:12px;border:1px solid var(--ys-border);}
.chip-success{background:#ecfdf5;border-color:#a7f3d0;color:#059669}
.chip-warn{background:#fff7ed;border-color:#fed7aa;color:#c2410c}

/* New Order Detail Page Styles */
.order-detail-page .ys-container { max-width: var(--ys-container-w); }
.back-to-list-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background-color: #fff;
    border: 1px solid var(--ys-border);
    padding: 10px 16px;
    border-radius: 8px;
    color: var(--ys-text);
    font-weight: 600;
    margin-bottom: 20px;
    transition: all .2s ease;
}
.back-to-list-btn:hover {
    background-color: #f8fafc;
    border-color: #d1d5db;
}
.copy-order-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background-color: #fff;
    border: 1px solid var(--ys-border);
    padding: 10px 14px;
    border-radius: 8px;
    color: var(--ys-text);
    font-weight: 600;
    margin-left: 10px;
    margin-bottom: 20px;
    transition: all .2s ease;
}
.copy-order-btn:hover { background-color: #f8fafc; border-color: #d1d5db; }
.order-detail-layout {
    display: grid;
    gap: 20px;
}
/* Order detail: keep copy pill away and align to value column */
.order-detail-page .order-copy{ margin-left:12px }
.detail-card {
    background-color: #fff;
    border-radius: 12px;
    padding: 25px;
    border: 1px solid var(--ys-border);
}
.detail-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}
.detail-card-header h3 {
    margin: 0;
    font-size: 20px;
    display: flex;
    align-items: center;
}
.status-chip-lg {
    font-size: 14px;
    font-weight: 600;
    padding: 6px 16px;
    border-radius: 20px;
}
.status-chip-lg.completed {
    background-color: #e6f7f0;
    color: #00a854;
}
.status-chip-lg.processing {
    background-color: #eef2ff;
    color: #4f46e5;
}
.status-chip-lg.pending {
    background-color: #fffbeb;
    color: #f59e0b;
}
.order-id-sm {
    font-size: 14px;
    color: var(--ys-muted);
    margin: -15px 0 20px;
}
.order-fields{display:grid;grid-template-columns:100px 1fr;column-gap:8px;row-gap:10px}
.order-fields .field{display:contents}
.order-fields .label{font-size:14px;color:var(--ys-muted)}
.order-fields .value{font-size:16px;font-weight:500;color:var(--ys-text)}
.license-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    margin-bottom: 25px;
}
.stat-box {
    background-color: #fff;
    border: 1px solid var(--ys-border);
    border-radius: 8px;
    padding: 14px;
    text-align: center;
}
.stat-box .stat-number {
    font-size: 22px;
    font-weight: 700;
    color: var(--ys-text);
    display: block;
}
.stat-box .stat-label {
    font-size: 12px;
    color: var(--ys-muted);
}
.license-meta-small{display:flex;align-items:center;gap:10px;margin-bottom:10px;color:var(--ys-muted);font-size:13px}
.license-meta-small .sep{color:#cbd5e1}
.bound-domain-list .domain-item { display:grid; grid-template-columns: 1fr auto; gap:8px; align-items:center; background:#fff; border:1px solid var(--ys-border); padding:12px; border-radius:8px; }
.bound-domain-list .domain-item .domain-edit{ grid-column: 1 / -1; }
.domain-edit .ys-domain-input{ height:44px; }
.ys-domain-apply, .ys-domain-cancel, .ys-domain-replace{ height:44px; padding:0 14px; width:96px; box-sizing:border-box; }
.bound-domain-list .domain-actions .ys-btn{ height:44px; width:96px; }
.bound-domain-list .domain-actions .ys-btn{height:44px; padding:0 14px; width:96px}
.domain-info {
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 600;
}
.domain-info .icon-checkmark-circle { color: #10b981; }
.verified-chip {
    font-size: 12px;
    background-color: #fff;
    color: #10b981;
    padding: 2px 8px;
    border-radius: 10px;
    border: 1px solid #a7f3d0;
}
.license-notice { background:#f1f5f9; border-left:3px solid var(--ys-accent); border:1px solid var(--ys-border); padding:12px 14px; border-radius:8px; margin-top:14px; font-size:14px; color:var(--ys-text) }
.license-notice h4 { margin: 0 0 10px; }
.license-notice ul { padding-left: 20px; margin: 0; }
.lic-msg{border:1px solid var(--ys-border); border-left-width:3px; border-radius:8px; padding:10px 12px; font-size:14px; margin-bottom:10px}
.lic-msg.ok{background:#ecfdf5; border-left-color:#34d399; color:#065f46}
.lic-msg.err{background:#fee2e2; border-left-color:#fca5a5; color:#991b1b}
.download-area {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 15px;
}
.download-meta {
    font-size: 14px;
    color: var(--ys-muted);
}
.download-main-btn {
    font-size: 16px;
    padding: 12px 24px;
    min-width: 200px;
    background: #f59e0b;
    border-color: transparent;
}
.download-main-btn:hover {
    background: #d97706;
}
/* Make outline buttons softer in order detail to avoid visual noise */
.order-detail-page .ys-btn-outline{ background: rgba(59,130,246,.06); border-color: rgba(37,99,235,.25); color: var(--ys-accent-600); }
.order-detail-page .ys-btn-outline:hover{ background: rgba(59,130,246,.12); border-color: rgba(37,99,235,.35); color: var(--ys-accent-600); }
.quick-links-list {
    display: grid;
    gap: 15px;
}
.quick-link-item {
    display: flex;
    align-items: center;
    gap: 15px;
    padding: 15px;
    border: 1px solid var(--ys-border);
    border-radius: 8px;
    transition: all .2s ease;
}
.quick-link-item:hover {
    border-color: var(--ys-accent);
    box-shadow: 0 4px 12px rgba(0,0,0,.05);
}
.quick-link-item > i:first-child { font-size: 24px; color: var(--ys-accent); }
.quick-link-item > i:last-child { margin-left: auto; color: var(--ys-muted); }
.quick-link-item h4 { margin: 0 0 2px; font-size: 16px; color: var(--ys-text); }
.quick-link-item p { margin: 0; font-size: 14px; color: var(--ys-muted); }
/* Download area message spacing */
.dl-msg{ margin-top:8px }
@media (max-width: 840px){
  .ys-grid-3{grid-template-columns:1fr}
  .ys-grid-2{grid-template-columns:1fr}
  .ys-hero{padding:56px 0}
  .ys-hero-title{font-size:30px}
  .ys-nav-toggle{display:inline-flex;justify-self:end}
  .ys-nav{display:none}
  .ys-nav[aria-expanded="true"]{display:flex;flex-direction:column;align-items:flex-start;width:100%}
  .ys-search-toggle{padding:6px 10px}
  .ys-search-panel{top:var(--ys-header-h)}
  .ys-hero-inner{grid-template-columns:1fr}
  .ys-checkout{grid-template-columns:1fr}
  .ac-wrap{grid-template-columns:1fr}
  .ac-side{position:static;width:auto;height:auto;left:auto;top:auto}
  .ac-main{grid-column:auto}
}

/* Desktop: make right column a fixed, scrollable pane aligned to container */
@media (min-width: 841px){
  .ys-account .ac-main{
    position: static;
    top: auto; left:auto; right:auto;
    height: auto; overflow: visible;
    padding-right: 0; box-sizing: border-box;
  }
}

/* Sidebar: desktop static to keep layout stable and avoid overlay */
@media (min-width: 841px){
  .ys-account .ac-side{
    position: sticky;
    /* Stick exactly at its initial visual offset below the header */
    top: calc(var(--ys-header-h) + var(--ys-section-pt,56px));
    left: auto; height: auto; overflow: visible;
  }
}


/* ====== Checkout Revamp ====== */
.ck-notice{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;padding:10px 12px;border-radius:10px;margin-bottom:16px}
.ck-layout{display:grid;grid-template-columns:1.3fr .7fr;gap:20px}
.ck-card{padding:18px}
.ck-table{width:100%;border-collapse:collapse;font-size:14px}
.ck-table th,.ck-table td{padding:12px 10px;border-bottom:1px solid var(--ys-border)}
.ck-table thead th{background:#f8fafc;color:#0f172a}
.ck-table .price{text-align:right}
.ck-total{display:flex;justify-content:flex-end;font-weight:700;color:#ef4444;font-size:18px;padding-top:12px}
.ck-order-meta{margin-top:8px;color:var(--ys-muted);font-size:13px}
.ck-coupon{margin:12px 0 4px}
.ck-coupon .toggle{color:var(--ys-accent)}
.ck-coupon-box{display:none;align-items:center;gap:8px;margin-top:8px}
.ck-coupon-box.show{display:flex}
.ck-payways{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:12px;justify-content:center}
.ck-payway{position:relative;display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border:1px solid var(--ys-border);border-radius:10px;background:#fff;min-width:172px;justify-content:center;cursor:pointer;transition:border-color .15s ease, box-shadow .15s ease, background .15s ease}
.ck-payway img{display:block;height:30px;border-radius:0}
.ck-payway.alipay{border-color:rgba(37,99,235,.35);background:rgba(59,130,246,.06)}
.ck-payway.active{border-color:#2563eb;box-shadow:0 2px 10px rgba(37,99,235,.18)}
.ck-payway.active::after{content:"";position:absolute;right:-1px;bottom:-1px;border-style:solid;border-width:0 0 18px 18px;border-color:transparent transparent #2563eb transparent}
.ck-payway.active::before{content:"";position:absolute;right:3px;bottom:3px;width:8px;height:5px;border:2px solid #fff;border-top:none;border-left:none;transform:rotate(45deg)}
.ck-payway[disabled]{opacity:.55;cursor:not-allowed}
.ck-actions{display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:10px}
.ck-actions .ys-status, .ck-actions p{ text-align:center }
.ck-actions .ys-btn{min-width:156px}

@media (max-width: 900px){
  .ck-layout{grid-template-columns:1fr}
}

/* ====== 浜у搧椤碉紙棣栭〉锛夌粨鏋?====== */
.nt-previews{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;margin:16px 0}
.nt-thumb{height:80px;border:1px solid var(--ys-border);border-radius:10px;background:#f2f5fb;overflow:hidden}
.nt-thumb-img{width:100%;height:100%;object-fit:cover;display:block}
.nt-meta{display:flex;gap:24px;flex-wrap:wrap;border-top:1px dashed var(--ys-border);padding-top:12px;color:var(--ys-muted)}
.nt-meta .item{display:flex;align-items:center;gap:6px}

.nt-section{padding:28px 0}
.nt-title{font-size:20px;margin:0 0 12px}
.nt-feature-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.nt-feature{background:var(--ys-card);border:1px solid var(--ys-border);border-radius:12px;padding:16px}
.nt-feature h4{margin:0 0 6px;font-size:16px}
.nt-feature p{margin:0;color:var(--ys-muted)}

.nt-two-col{display:grid;grid-template-columns:1.2fr .8fr;gap:24px}
.nt-faq-list details{border:1px solid var(--ys-border);background:var(--ys-card);border-radius:10px;padding:10px 12px}
.nt-faq-list details+details{margin-top:10px}
.nt-faq-list summary{cursor:pointer;font-weight:600}

.nt-timeline{background:var(--ys-card);border:1px solid var(--ys-border);border-radius:12px;padding:12px}
.nt-timeline .item{border-bottom:1px dashed var(--ys-border);padding:10px 0}
.nt-timeline .item:last-child{border-bottom:0}
.nt-timeline .date{color:var(--ys-muted);font-size:13px}

/* Custom Checkout Styles */
.ck-payway {
    min-width: 120px !important;
    padding: 5px 10px !important;
    border-radius: 0 !important;
}

.ck-payway img {
    height: 24px !important;
    border-radius: 0 !important;
}

.ck-actions .ys-btn {
    padding: 8px 12px !important;
    font-size: 14px !important;
    border-radius: 0 !important;
    min-width: 120px !important;
}

/* ====== Modal (login prompt) ====== */
.ys-modal{position:fixed;inset:0;z-index:1000}
.ys-modal.hidden{display:none}
.ys-modal-backdrop{position:absolute;inset:0;background:rgba(9,30,66,.45);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);opacity:0;transition:opacity .26s ease}
.ys-modal:not(.hidden) .ys-modal-backdrop{opacity:1}
.ys-modal-content{position:relative;max-width:520px;margin:12vh auto;background:#fff;border:1px solid var(--ys-border);border-radius:16px;padding:24px;box-shadow:0 18px 48px rgba(2,6,23,.22);transform:translateY(16px) scale(.98);opacity:0;transition:transform .3s cubic-bezier(.25,.8,.25,1), opacity .3s ease}
.ys-modal:not(.hidden) .ys-modal-content{transform:translateY(0) scale(1);opacity:1}
.ys-modal-close{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:999px;border:1px solid var(--ys-border);background:#fff;color:#334155;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}
.ys-modal-close:hover{background:#f8fafc}

/* Login modal premium styling */
#ys-login-modal .ys-modal-content{padding:28px 24px}
#ys-login-modal .ys-login-head{display:flex;flex-direction:column;align-items:center;text-align:center;margin-top:10px;margin-bottom:16px}
#ys-login-modal .ys-login-ico{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:28px;background:linear-gradient(135deg, rgba(59,130,246,.18), rgba(99,102,241,.18));border:1px solid rgba(59,130,246,.28);color:#1f2937;box-shadow:0 10px 24px rgba(59,130,246,.12) inset}
#ys-login-modal h3{margin:12px 0 6px;font-size:22px;line-height:1.3;color:#0f172a;font-weight:800}
#ys-login-modal .ys-login-sub{margin:0;color:#64748b}
#ys-login-modal .ys-login-actions{display:flex;gap:10px;margin-top:14px}
#ys-login-modal .ys-login-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;height:42px;border-radius:12px;font-weight:700}
#ys-login-modal .ys-login-note{margin-top:10px;text-align:center;color:#94a3b8;font-size:13px}
#ys-login-modal .ys-login-foot{margin-top:6px;text-align:center;color:#8b98aa;font-size:13px}
#ys-login-modal .ys-login-foot a{color:#2563eb}
#ys-login-modal .ys-login-foot a:hover{text-decoration:underline}

/* Disable style for buttons via aria-disabled */
.ys-btn[aria-disabled="true"]{opacity:.6;pointer-events:none;cursor:not-allowed}

.ck-payway.active::after, .ck-payway.active::before {
    display: none !important;
}


/* Removed old styles */
.log-wrap{display:grid;gap:18px}
.log-row{display:grid;grid-template-columns:140px 24px minmax(0,1fr);gap:14px}
.log-col-date{align-self:start;text-align:right;color:var(--ys-muted);font-size:13px;padding-top:4px;white-space:nowrap}
.log-col-line{position:relative}
.log-col-line::before{content:"";position:absolute;top:0;bottom:0;left:11px;width:2px;background:var(--ys-border)}
.log-node{position:absolute;top:7px;left:6px;width:12px;height:12px;border-radius:999px;background:var(--ys-accent);box-shadow:0 0 0 4px rgba(59,130,246,.12);border:2px solid #fff}
.log-col-body{background:#fff;border:1px solid var(--ys-border);border-radius:12px;padding:12px 14px}
.log-title{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.log-ver{display:inline-block;background:#fff;border:1px solid var(--ys-border);border-radius:10px;padding:2px 10px;font-weight:600;color:#111}
.log-content{color:var(--ys-text)}
.log-content p{margin:0 0 8px}
.log-content ul{margin:6px 0 0 18px}
.log-content li{margin:3px 0}

@media (max-width: 768px){
  .log-row{grid-template-columns:24px 1fr}
  .log-col-date{grid-column:1 / -1;text-align:left;padding-left:34px;margin-bottom:-4px}
  .log-col-line::before{top:-10px}
}

/* v2: Badge + Date + Card (match screenshot) */
.logv2-list{display:grid;gap:20px}
.logv2-head{display:flex;align-items:center;gap:10px}
.logv2-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(37,99,235,.12);color:#2563eb;border:1px solid rgba(37,99,235,.28);border-radius:0;padding:4px 10px;font-size:12px;font-weight:700;box-shadow:0 1px 0 rgba(0,0,0,.02)}
.logv2-date{font-weight:700;color:#111}
.logv2-card{background:#fbfcff;border:1px solid var(--ys-border);border-radius:12px;padding:14px}
.logv2-card ol{margin:0;padding-left:24px}
.logv2-card ol>li{padding:12px 8px;border-top:1px dashed var(--ys-border)}
.logv2-card ol>li:first-child{border-top:0}
.logv2-card p{margin:0 8px 8px;padding-top:12px;border-top:1px dashed var(--ys-border)}
.logv2-card p:first-child{border-top:0}

/* ====== Theme Specs (Homepage) ====== */
.theme-specs .specs-card{background:#fff;border:1px solid var(--ys-border);border-radius:16px;padding:28px 24px;box-shadow:0 12px 34px rgba(2,6,23,.08)}
.theme-specs .specs-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px 24px}
.theme-specs .spec-item{display:grid;grid-template-columns:40px 1fr;gap:12px;align-items:center}
.theme-specs .spec-ico{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:999px;background:rgba(59,130,246,.10);color:var(--ys-accent-600);border:1px solid rgba(59,130,246,.28)}
.theme-specs .spec-label{display:block;color:var(--ys-muted);font-size:14px}
.theme-specs .spec-value{display:block;color:var(--ys-text);font-weight:700}
.theme-specs a{color:var(--ys-accent)}
.theme-specs a:hover{color:var(--ys-accent-600)}
@media (max-width: 768px){
  .theme-specs .specs-grid{grid-template-columns:1fr}
}

/* ====== Support Tabs (Homepage) ====== */
.hv-support .sup-card{background:#fff;border:1px solid var(--ys-border);border-radius:16px;padding:12px 12px 16px;box-shadow:0 12px 34px rgba(2,6,23,.08)}
.hv-support .sup-tabs{display:flex;gap:8px;flex-wrap:wrap;border-bottom:1px solid var(--ys-border);padding:6px}
.hv-support .sup-tab{appearance:none;border:0;background:transparent;padding:8px 14px;border-radius:999px;color:var(--ys-text);cursor:pointer}
.hv-support .sup-tab.active,.hv-support .sup-tab[aria-selected="true"]{background:rgba(59,130,246,.12);color:var(--ys-accent-600);font-weight:700}
.hv-support .sup-tab:focus{outline:2px solid rgba(59,130,246,.45);outline-offset:2px}
.hv-support .sup-panels{padding:10px 4px 0;overflow:hidden;transition:height .28s ease}
.hv-support .sup-panel[hidden]{display:none}

/* Changelog mini timeline */
.cl-timeline{display:grid;gap:14px}
.cl-item{background:#fbfcff;border:1px solid var(--ys-border);border-radius:12px;padding:12px}
.cl-item .meta{display:flex;align-items:center;gap:10px;margin-bottom:8px;color:#111;font-weight:700}
.cl-item .meta .ver{display:inline-flex;align-items:center;gap:6px;background:rgba(59,130,246,.12);border:1px solid rgba(59,130,246,.28);color:#2563eb;padding:2px 8px;font-size:12px}
.cl-list{margin:0;padding-left:18px}
.cl-list li{margin:6px 0}
.cl-list .tag{display:inline-block;min-width:36px;text-align:center;border-radius:4px;padding:2px 6px;margin-right:8px;font-size:12px;font-weight:700}
.cl-list .tag-new{background:#ecfdf5;color:#16a34a;border:1px solid #bbf7d0}
.cl-list .tag-impr{background:#eff6ff;color:#2563eb;border:1px solid #bfdbfe}
.cl-list .tag-fix{background:#fef2f2;color:#ef4444;border:1px solid #fecaca}
.cl-more{margin-top:4px}

/* Contact panel */
.contact-card{background:#fbfcff;border:1px solid var(--ys-border);border-radius:12px;padding:12px}
.contact-card ul{margin:0;padding-left:18px}
.contact-card li{margin:6px 0}

/* Responsive adjustments */
@media (max-width: 992px){
  .theme-specs .specs-wrap{flex-direction:column}
}
@media (prefers-color-scheme: dark){
  .theme-specs .specs-card{background:#0b1220;border-color:#1f2937}
  .cl-item{background:#0b1220;border-color:#1f2937}
  .hv-support .sup-card{background:#0b1220;border-color:#1f2937}
}
/* Tailwind-like helpers used on front page */
.glass{backdrop-filter:saturate(180%) blur(10px); background:rgba(255,255,255,.75)}
.container{max-width:1200px}
/* ====== Modern Login Overlay (scoped to #ys-login-modal) ====== */
#ys-login-modal.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;display:flex;justify-content:center;align-items:center;z-index:1000;background:rgba(9,30,66,.54);opacity:0;visibility:hidden;transition:opacity .3s ease, visibility 0s .3s;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
#ys-login-modal.modal-overlay.visible{opacity:1;visibility:visible;transition-delay:0s}
#ys-login-modal .modal-container{background:#fff;padding:32px 40px;border-radius:16px;box-shadow:0 10px 30px rgba(0,0,0,.12);width:100%;max-width:420px;position:relative;box-sizing:border-box;text-align:center;transform:translateY(20px) scale(.98);opacity:0;transition:all .3s cubic-bezier(.25,.8,.25,1)}
#ys-login-modal.visible .modal-container{transform:translateY(0) scale(1);opacity:1}
#ys-login-modal .modal-close-button{position:absolute;top:16px;right:16px;background:none;border:0;font-size:28px;color:#7a869a;cursor:pointer;line-height:1;padding:0}
#ys-login-modal .modal-close-button:hover{color:#172b4d}
#ys-login-modal .modal-icon{width:56px;height:56px;border-radius:50%;background:#DEEBFF;color:#0052CC;display:inline-flex;align-items:center;justify-content:center;margin-bottom:20px}
#ys-login-modal .modal-icon svg{width:28px;height:28px}
#ys-login-modal .modal-header h2{margin:0 0 8px 0;font-size:1.7em;font-weight:700;color:#091e42}
#ys-login-modal .modal-header p{margin:0 0 28px 0;color:#5e6c84;font-size:1.05em;line-height:1.5}
#ys-login-modal .modal-actions{display:flex;flex-direction:column;gap:12px}
#ys-login-modal .btn{width:100%;padding:12px;border-radius:8px;font-size:1.05em;font-weight:600;cursor:pointer;border:none;transition:all .2s}
#ys-login-modal .btn-primary{background:#0052cc;color:#fff}
#ys-login-modal .btn-primary:hover{background:#0065ff}
#ys-login-modal .btn-secondary{background:#F4F5F7;color:#42526E}
#ys-login-modal .btn-secondary:hover{background:#EAECEF}
#ys-login-modal .modal-footer{margin-top:24px;font-size:.9em;color:#5e6c84}
#ys-login-modal .modal-footer a{color:#0052cc;text-decoration:none}
#ys-login-modal .modal-footer a:hover{text-decoration:underline}
/* Orders pagination (modern, centered) */
.ys-pager{display:flex;justify-content:center;align-items:center;gap:8px;flex-wrap:wrap;margin-top:20px}
.ys-pager .pager-link{display:inline-flex;min-width:36px;height:36px;padding:0 10px;align-items:center;justify-content:center;border:1px solid #e5e7eb;border-radius:0;background:#fff;color:#334155;text-decoration:none;line-height:1;transition:all .15s ease}
.ys-pager .pager-link:hover{border-color:#cbd5e1;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.ys-pager .pager-link.active,[aria-current="page"].pager-link{background:#0ea5e9;border-color:#0ea5e9;color:#fff;box-shadow:0 1px 2px rgba(14,165,233,.4)}
.ys-pager .pager-link.prev,.ys-pager .pager-link.next{min-width:36px}
.ys-pager .pager-ellipsis{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;color:#94a3b8}
.ys-pager .pager-ellipsis.hidden{visibility:hidden}
.ys-pager .pager-link:focus-visible{outline:2px solid #2563eb;outline-offset:2px}
.ys-pager .pager-link.disabled{color:#94a3b8;background:#f8fafc;border-color:#e5e7eb;pointer-events:none}
.ys-pager .pager-link.placeholder{visibility:hidden}

/* Small layout utilities for templates (scoped naming) */
.ys-row-10{display:flex;gap:10px;align-items:center}
.ys-inline{display:inline-flex;align-items:center;gap:6px;text-decoration:none}
.ys-m0{margin:0}
.ys-text-main{color:var(--ys-text)}
.is-hidden{display:none !important}
.ys-spinner{width:16px;height:16px;border-radius:999px;border:2px solid #cbd5e1;border-top-color:#64748b;display:inline-block;animation:ysspin 1s linear infinite}
@keyframes ysspin{to{transform:rotate(360deg)}}
.ys-section-header.ck-hidden{display:none}
.ys-section-header.ck-pad{padding:24px 16px 0}
.empty-state.show{display:block}
.ys-icon-16{width:16px;height:16px}
.ys-mr-6{margin-right:6px}
.ys-center-note{text-align:center;padding:18px 8px}
.ys-mb-12{margin-bottom:12px}

/* Ticket header layout */
.ys-account .ac-main .ac-main-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.ys-account .ac-main .ac-main-header h2{margin:0;font-size:16px;font-weight:400}

/* ===== Auth Pages (login/register/reset) ===== */
/* Shared brand palette scoped per wrapper to avoid global impact */
.login-wrapper, .register-wrapper, .auth-wrapper{
  --brand-color:#0052cc; --brand-color-dark:#0065ff;
  --text-primary:#091e42; --text-secondary:#5e6c84;
  --border-color:#e5e8ef; --background-light:#f4f5f7;
}
/* Login */
.login-wrapper{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 0px);padding:32px 20px;box-sizing:border-box;background-color:var(--background-light)}
.login-wrapper .login-card{width:100%;max-width:560px;padding:48px;background:#fff;border-radius:16px;border:1px solid var(--border-color);box-shadow:0 18px 48px rgba(2,6,23,.12);box-sizing:border-box}
.login-wrapper .card-header{text-align:center;margin-bottom:28px}
.login-wrapper .card-header .logo{font-size:30px;font-weight:800;color:var(--brand-color);margin-bottom:10px;text-decoration:none;display:inline-block}
.login-wrapper .card-header p{margin:0;color:var(--text-secondary);font-size:16px}
.login-wrapper .form-group{margin-bottom:18px}
.login-wrapper .form-group label{display:block;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:8px}
.login-wrapper .form-group input{width:100%;padding:12px 14px;border:1px solid var(--border-color);border-radius:12px;font-size:16px;box-sizing:border-box;transition:border-color .2s ease, box-shadow .2s ease}
.login-wrapper .form-group input:focus{outline:none;border-color:var(--brand-color);box-shadow:0 0 0 3px rgba(0,82,204,.18)}
.login-wrapper .form-options{display:flex;justify-content:space-between;align-items:center;font-size:14px;margin:8px 0 22px}
.login-wrapper .form-options a{color:var(--brand-color);text-decoration:none;font-weight:600}
.login-wrapper .form-options a:hover{text-decoration:underline}
.login-wrapper .remember-me{display:flex;align-items:center;color:var(--text-secondary)}
.login-wrapper .remember-me input{margin-right:8px;accent-color:var(--brand-color)}
.login-wrapper .btn-primary{width:100%;padding:14px;border:none;border-radius:12px;background:var(--brand-color);color:#fff;font-size:16px;font-weight:700;cursor:pointer;transition:background-color .2s ease}
.login-wrapper .btn-primary:hover{background:var(--brand-color-dark)}
.login-wrapper .card-footer{text-align:center;margin-top:22px;font-size:14px;color:var(--text-secondary)}
.login-wrapper .card-footer a{color:var(--brand-color);text-decoration:none;font-weight:700}
.login-wrapper .card-footer a:hover{text-decoration:underline}
.login-wrapper .login-error{margin:0 0 14px;padding:12px;border:1px solid #fecaca;background:#fef2f2;color:#991b1b;border-radius:12px;font-size:14px}

/* Register */
.register-wrapper{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 0px);padding:40px 20px;box-sizing:border-box;background-color:var(--background-light)}
.register-wrapper .register-card{width:100%;max-width:560px;padding:48px;background:#fff;border-radius:16px;border:1px solid var(--border-color);box-shadow:0 18px 48px rgba(2,6,23,.12);box-sizing:border-box}
.register-wrapper .card-header{text-align:center;margin-bottom:26px}
.register-wrapper .card-header .logo{font-size:30px;font-weight:800;color:var(--brand-color);margin-bottom:8px;text-decoration:none;display:inline-block}
.register-wrapper .card-header p{margin:0;color:var(--text-secondary);font-size:16px}
.register-wrapper .form-group{margin-bottom:18px}
.register-wrapper .form-group label{display:block;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:8px}
.register-wrapper .form-group input{width:100%;padding:12px 14px;border:1px solid var(--border-color);border-radius:12px;font-size:16px;box-sizing:border-box;transition:border-color .2s ease, box-shadow .2s ease}
.register-wrapper .form-group input:focus{outline:none;border-color:var(--brand-color);box-shadow:0 0 0 3px rgba(0,82,204,.18)}
.register-wrapper .form-terms{display:flex;align-items:flex-start;font-size:14px;margin:6px 0 22px;color:var(--text-secondary)}
.register-wrapper .form-terms input{margin-top:3px;margin-right:10px;flex-shrink:0;accent-color:var(--brand-color)}
.register-wrapper .form-terms a{color:var(--brand-color);text-decoration:none;font-weight:700}
.register-wrapper .form-terms a:hover{text-decoration:underline}
.register-wrapper .btn-primary{width:100%;padding:14px;border:none;border-radius:12px;background:var(--brand-color);color:#fff;font-size:16px;font-weight:700;cursor:pointer;transition:background-color .2s ease}
.register-wrapper .btn-primary:hover{background:var(--brand-color-dark)}
.register-wrapper .card-footer{text-align:center;margin-top:22px;font-size:14px;color:var(--text-secondary)}
.register-wrapper .card-footer a{color:var(--brand-color);text-decoration:none;font-weight:700}
.register-wrapper .card-footer a:hover{text-decoration:underline}
.register-wrapper .reg-error{margin:0 0 14px;padding:12px;border:1px solid #fecaca;background:#fef2f2;color:#991b1b;border-radius:12px;font-size:14px}

/* Reset password */
.auth-wrapper{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 0px);padding:40px 20px;box-sizing:border-box;background-color:var(--background-light)}
.auth-wrapper .auth-card{width:100%;max-width:420px;padding:48px;background:#fff;border-radius:16px;border:1px solid var(--border-color);box-shadow:0 18px 48px rgba(2,6,23,.12);box-sizing:border-box}
.auth-wrapper .auth-head{text-align:center;margin-bottom:24px}
.auth-wrapper .auth-ico{width:64px;height:64px;margin:0 auto 10px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:28px;background:linear-gradient(135deg, rgba(59,130,246,.18), rgba(99,102,241,.18));border:1px solid rgba(59,130,246,.28);color:#1f2937;box-shadow:0 10px 24px rgba(59,130,246,.12) inset}
.auth-wrapper .auth-title{margin:0 0 6px;font-size:22px;line-height:1.3;color:var(--text-primary);font-weight:800;text-align:center}
.auth-wrapper .auth-sub{margin:0;color:var(--text-secondary);text-align:center}
.auth-wrapper .form-group{margin-top:16px}
.auth-wrapper .form-group label{display:block;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:8px}
.auth-wrapper .form-group input{width:100%;padding:12px 14px;border:1px solid var(--border-color);border-radius:12px;font-size:16px;box-sizing:border-box;transition:border-color .2s ease, box-shadow .2s ease}
.auth-wrapper .form-group input:focus{outline:none;border-color:var(--brand-color);box-shadow:0 0 0 3px rgba(0,82,204,.18)}
.auth-wrapper .btn-primary{width:100%;margin-top:14px;padding:14px;border:none;border-radius:12px;background:var(--brand-color);color:#fff;font-size:16px;font-weight:700;cursor:pointer}
.auth-wrapper .btn-primary:hover{background:var(--brand-color-dark); color:#fff}
.auth-wrapper .auth-msg{margin-top:12px;font-size:14px;color:#64748b}
.auth-wrapper .auth-foot{text-align:center;margin-top:18px;color:var(--text-secondary)}
.auth-wrapper .auth-foot a{color:var(--brand-color);font-weight:700;text-decoration:none}
.auth-wrapper .auth-foot a:hover{text-decoration:underline}

/* ===== Ticket Center ===== */
/* Filter bar and layout (list view) */
/* Ticket page filter bar: direct child of .ac-main */
.ys-account .ac-main > .filter-bar{display:grid;grid-template-columns:minmax(200px,2fr) minmax(280px,3fr) auto auto;gap:12px;align-items:center;background:var(--ys-card);border:1px solid var(--ys-border);border-radius:12px;padding:12px 14px;margin-bottom:16px}
.ys-account .ac-main .filter-group{display:flex;flex-direction:column;min-width:0}
.ys-account .ac-main .filter-group label{display:none;margin:0}
.ys-account .ac-main .filter-group input,.ys-account .ac-main .filter-group select{height:34px;line-height:34px;padding:0 10px;font-size:13px;border-radius:8px;border:1px solid var(--ys-border);background:#fff;width:100%}
.ys-account .ac-main #ys-ticket-status{width:min(100%,220px)}
.ys-account .ac-main .filter-group input:focus,.ys-account .ac-main .filter-group select:focus{border-color:rgba(37,99,235,.55);outline:none;box-shadow:0 0 0 3px rgba(59,130,246,.18)}
.ys-account .ac-main .ticket-list{display:flex;flex-direction:column;gap:14px}
.ys-account .ac-main .ticket-item{display:block;text-decoration:none;color:inherit;background:var(--ys-card);border:1px solid var(--ys-border);border-radius:10px;padding:18px;transition:transform .2s ease, box-shadow .2s ease}
.ys-account .ac-main .ticket-item:hover{transform:translateY(-3px);box-shadow:0 6px 16px rgba(2,6,23,.08)}
.ys-account .ac-main .ticket-item-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px}
.ys-account .ac-main .ticket-item-title{margin:0;font-size:14px;font-weight:400}
.ys-account .ac-main .ticket-title{font-size:14px}
.ys-account .ac-main .ticket-item-meta{margin:0;color:var(--ys-muted);font-size:14px}
.ys-account .ac-main .ticket-item-excerpt{margin:0;color:var(--ys-muted);font-size:15px;line-height:1.6}
.ys-account .ac-main .status-inline{display:inline-flex;align-items:center;gap:6px;margin-left:10px;font-size:12px;font-weight:600;vertical-align:middle}
.ys-account .ac-main .status-inline svg{width:14px;height:14px}
.ys-account .ac-main .status-processing{color:var(--ys-accent-600)}
.ys-account .ac-main .status-closed{color:#16a34a}
.ys-account .ac-main .empty-state{text-align:center;padding:48px 20px;background:var(--ys-card);border-radius:12px;border:2px dashed var(--ys-border)}
.ys-account .ac-main .empty-state .icon{font-size:42px;margin-bottom:10px}
.ys-account .ac-main .empty-state h2{margin:0 0 8px;font-size:22px}
.ys-account .ac-main .empty-state p{margin:0 0 14px;color:var(--ys-muted)}
.ys-account .ac-main .ac-main-header .btn-primary{padding:9px 12px;font-size:14px;border-radius:2px;gap:6px;height:auto;line-height:normal;white-space:nowrap;box-shadow:0 4px 10px rgba(37,99,235,.16)}
.ys-account .ac-main .ys-search-input{width:100%;max-width:none}
.ys-account .ac-main .ys-search-btn{border-radius:0 !important;height:34px;line-height:34px;padding:0 12px;font-size:13px}
.ys-account .ac-main .ys-reset-btn{height:34px;line-height:34px;padding:0 12px;font-size:13px;background:#fff;border:1px solid var(--ys-border);color:var(--ys-muted)}
.ys-account .ac-main .ys-reset-btn:hover{border-color:rgba(37,99,235,.55);color:var(--ys-accent-600)}
@media (max-width: 992px){
  .ys-account .ac-main > .filter-bar{grid-template-columns:1fr}
  .ys-account .ac-main #ys-ticket-status{width:100%}
}
/* 固定面板的视口高度（列表/详情共用） */
.ys-account .ac-wrap{min-height:calc(100dvh - var(--ys-header-h))}
.ys-account .ac-wrap .ac-main{display:flex;flex-direction:column;height:clamp(560px, calc(100dvh - var(--ys-header-h) - var(--ys-section-pt, 26px)), 86dvh);overflow:auto;overscroll-behavior:contain}
.ys-account .ac-wrap .ac-main.ac-main-auto{height:auto;overflow:visible}

/* Ticket chat view (single) */
.ys-account .ac-main .ys-ticket-container{width:100%;max-width:920px;background:#fff;border-radius:12px;box-shadow:0 4px 12px rgba(0,0,0,.06);display:flex;flex-direction:column;overflow:visible;border:1px solid var(--ys-border)}
.ys-account .ac-main .ys-ticket-header{padding:16px 20px;border-bottom:1px solid var(--ys-border)}
.ys-account .ac-main .ys-ticket-header h1{font-size:16px;font-weight:400;color:#0f172a;margin:0;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.ys-account .ac-main .ys-chat-feed{padding:20px;min-height:200px;max-height:65dvh;overflow:auto;overscroll-behavior:contain;content-visibility:auto;contain-intrinsic-size:800px 400px;overflow-anchor:none}
.ys-account .ac-main .ys-chat-item{display:flex;gap:12px;margin-bottom:18px}
.ys-account .ac-main .ys-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:500;background:#64748b;flex-shrink:0}
.ys-account .ac-main .ys-msg{flex:1}
.ys-account .ac-main .ys-msg-header{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.ys-account .ac-main .ys-sender{font-weight:400;color:#0f172a;font-size:13px}
.ys-account .ac-main .ys-time{font-size:12px;color:var(--ys-muted)}
.ys-account .ac-main .ys-bubble{background:#f7f7f7;border:1px solid var(--ys-border);border-radius:8px;padding:10px 12px;color:#475569;max-width:100%;font-size:14px;line-height:1.7}
.ys-account .ac-main .ys-bubble p{margin:0 0 8px}
.ys-account .ac-main .ys-bubble p:last-child{margin-bottom:0}
.ys-account .ac-main .ys-reply{padding:12px 16px;border-top:1px solid var(--ys-border);background:#fcfcfc}
.ys-account .ac-main .ys-reply .reply-form{display:flex;align-items:flex-end;gap:10px}
.ys-account .ac-main .ys-input-wrap{flex:1;display:flex;align-items:center;border:1px solid var(--ys-border);border-radius:8px;background:#fff;padding:6px 6px 6px 10px}
.ys-account .ac-main .ys-input-wrap:focus-within{border-color:rgba(37,99,235,.55);box-shadow:0 0 0 3px rgba(59,130,246,.18)}
.ys-account .ac-main .ys-input-wrap textarea{flex:1;border:none;outline:none;resize:none;background:transparent;font-size:14px;min-height:24px;line-height:1.6}
.ys-account .ac-main .ys-attach-btn{background:none;border:none;cursor:pointer;padding:6px;border-radius:6px;display:flex}
.ys-account .ac-main .ys-attach-btn:hover{background:#f2f2f2}
.ys-account .ac-main .ys-submit{background:var(--ys-accent-600);color:#fff;border:none;padding:0 18px;height:38px;font-size:14px;font-weight:600;border-radius:6px;cursor:pointer}
.ys-account .ac-main .ys-file-chip{display:inline-flex;align-items:center;gap:8px;background:#e9ecef;border-radius:16px;padding:6px 12px;font-size:13px;color:#334155;border:1px solid #dee2e6;margin-bottom:10px}
.ys-account .ac-main .ys-file-chip .remove{background:#cfd3d7;border:none;border-radius:50%;width:16px;height:16px;display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer}
.ys-account .ac-main .ys-attach-list{margin-top:8px;display:flex;flex-wrap:wrap;gap:8px}
.ys-account .ac-main .ys-attach{display:inline-flex;align-items:center;gap:6px;background:#e9ecef;border:1px solid #dee2e6;border-radius:16px;padding:4px 10px;font-size:12px;color:#334155;text-decoration:none}
.ys-account .ac-main .ys-attach:hover{background:#e6e9ee}
.ys-account .ac-main .ys-attach svg{width:14px;height:14px;color:#6c757d}
.ys-account .ac-main .ys-attach-image{padding:0;background:transparent;border:none;border-radius:8px}
.ys-account .ac-main .ys-attach-image img{width:74px;height:74px;object-fit:cover;border-radius:8px;border:1px solid var(--ys-border);display:block}
.ys-account .ac-main .ys-send-status{margin-top:6px;font-size:12px;color:#64748b;display:flex;gap:8px;align-items:center}
.ys-account .ac-main .ys-send-status .retry{background:#fee2e2;color:#b91c1c;border:1px solid #fecaca;border-radius:6px;padding:2px 8px;cursor:pointer}

/* Ticket list table */
.ys-account .ac-main .ys-ticket-table{width:100%;background:#fff;border:1px solid var(--ys-border);border-radius:10px;border-collapse:separate;border-spacing:0;overflow:hidden}
.ys-account .ac-main .ys-ticket-table thead th{background:#f8fafc;color:#0f172a;font-weight:400;font-size:13px;text-align:left;padding:12px 14px;border-bottom:1px solid var(--ys-border)}
.ys-account .ac-main .ys-ticket-table tbody td{font-size:13px;color:#334155;padding:12px 14px;border-bottom:1px solid var(--ys-border);background:#fff;vertical-align:middle}
.ys-account .ac-main .ys-ticket-table tbody tr:last-child td{border-bottom:none}
.ys-account .ac-main .ys-col-id{width:120px;color:#475569}
.ys-account .ac-main .ys-col-title .ys-cell-desc{max-width:560px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ys-account .ac-main .ys-col-type{width:120px;color:#475569}
.ys-account .ac-main .ys-col-status{width:120px}
.ys-account .ac-main .ys-col-time{width:180px;color:#64748b}
.ys-account .ac-main .ys-col-actions{width:110px;text-align:left}
.ys-account .ac-main .ys-status-dot{display:inline-block;width:8px;height:8px;border-radius:999px;background:#94a3b8;margin-right:6px;vertical-align:middle}
.ys-account .ac-main .ys-st-open .ys-status-dot{background:#2563eb}
.ys-account .ac-main .ys-st-closed .ys-status-dot{background:#10b981}
@media (max-width: 840px){
  .ys-account .ac-main .ys-ticket-table thead{display:none}
  .ys-account .ac-main .ys-ticket-table, .ys-account .ac-main .ys-ticket-table tbody, .ys-account .ac-main .ys-ticket-table tr, .ys-account .ac-main .ys-ticket-table td{display:block;width:100%}
  .ys-account .ac-main .ys-ticket-table tbody td{border-bottom:1px dashed var(--ys-border);padding:10px 12px}
  .ys-account .ac-main .ys-col-actions{text-align:left}
}

/* ===== Ticket New (create) ===== */
.ys-account .ac-main .ys-ticket-container.ys-ticket-new{position:relative}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .ys-ticket-body{padding:20px}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .ys-toast-bubble{position:absolute;top:10px;right:12px;background:#0f172a;color:#fff;padding:8px 12px;border-radius:10px;box-shadow:0 6px 16px rgba(0,0,0,.18);font-size:13px;z-index:60;opacity:.98;border:1px solid rgba(15,23,42,.2)}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .ys-toast-bubble.warn{background:#92400e}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .ys-toast-bubble.error{background:#991b1b}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .ys-toast-bubble::after{content:"";position:absolute;right:10px;top:100%;border:6px solid transparent;border-top-color:rgba(15,23,42,.9)}
/* hide inner header only on create page */
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .ys-ticket-header{display:none}
/* create form */
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .card{background:transparent;border:none;border-radius:0;padding:0;max-width:880px;margin-right:auto}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .form-group{margin-bottom:20px;display:grid;grid-template-columns:160px minmax(0,1fr);gap:16px;align-items:center}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .fg-text,.ys-account .ac-main .ys-ticket-container.ys-ticket-new .fg-attach{align-items:start}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .fg-radio{align-items:flex-start}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .fg-radio .form-label{margin-top:-2px}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .form-label,
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .form-group label{display:block;font-size:14px;font-weight:400;margin-bottom:0;color:#475569}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .required{color:#ef4444;margin-left:4px}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .form-group input,
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .form-group textarea,
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .form-group select{width:100%;padding:10px 14px;font-size:14px;border-radius:8px;border:1px solid var(--ys-border);background:#fff;box-sizing:border-box}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .form-group input:focus,
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .form-group textarea:focus,
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .form-group select:focus{border-color:var(--ys-accent);outline:none;box-shadow:0 0 0 3px rgba(59,130,246,.2)}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .urgency-options{display:flex;align-items:center;gap:24px;margin-bottom:6px;flex-wrap:wrap}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .radio-option{display:inline-flex;align-items:center;gap:8px;cursor:pointer;line-height:1.2}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .radio-option input[type=radio]{accent-color:var(--ys-accent);width:18px;height:18px;display:inline-block;vertical-align:middle;margin:0}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .radio-option label{display:inline-flex;align-items:center;margin:0;vertical-align:middle;line-height:18px}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .fg-field{display:flex;flex-direction:column}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new #urgency-description{font-size:13px;color:var(--ys-muted);padding-left:2px;margin:4px 0 0}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .textarea-wrapper{position:relative}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .textarea-wrapper textarea{min-height:170px;resize:vertical}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .char-counter{position:absolute;bottom:10px;right:10px;font-size:12px;color:#94a3b8}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .file-drop-zone{border:2px dashed var(--ys-border);border-radius:10px;padding:14px;text-align:center;color:#64748b;background:#f8fafc;cursor:pointer}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new #file-input{display:none}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new #file-list{list-style:none;margin:10px 0 0;padding:0;display:flex;flex-direction:column;gap:8px}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new #file-list .file-item{display:flex;align-items:center;gap:10px;border:1px solid var(--ys-border);border-radius:8px;padding:8px 10px;background:#fff}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new #file-list .file-item .thumb{width:32px;height:32px;object-fit:cover;border-radius:6px;border:1px solid var(--ys-border)}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new #file-list .file-item .name{font-weight:600;color:#0f172a}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new #file-list .file-item .meta{font-size:12px;color:#94a3b8}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new #file-list .file-item .remove-file{margin-left:auto;cursor:pointer;color:#64748b}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .form-actions{margin-top:8px}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .btn-submit{background:var(--ys-accent-600);color:#fff;border:none;padding:10px 18px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer}
.ys-account .ac-main .ys-ticket-container.ys-ticket-new .btn-submit:hover{filter:brightness(0.98)}
/* 提交时覆盖层 */
.ys-account .ac-main #ys-submit-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:8px;color:#475569;background:rgba(255,255,255,.75);backdrop-filter:saturate(160%) blur(1px);z-index:50}
/* File item meta vertical stack */
.ys-fi-meta{display:flex;flex-direction:column;gap:2px}

/* ===== Forgot Password ===== */
.auth-wrapper .password-reset-card{background:#fff;padding:40px 48px;border-radius:16px;box-shadow:0 8px 24px rgba(0,0,0,.05);width:100%;max-width:420px;box-sizing:border-box;text-align:center}
.auth-wrapper .password-reset-card h1{margin:0 0 12px;font-size:22px;font-weight:800;color:#091e42}
.auth-wrapper .password-reset-card p{margin:0 0 28px;color:#5e6c84;font-size:16px;line-height:1.6}
.auth-wrapper .password-reset-card .form-group{text-align:left;margin-bottom:16px}
.auth-wrapper .password-reset-card .form-group label{display:block;font-weight:600;font-size:14px;margin-bottom:8px;color:#42526e}
.auth-wrapper .password-reset-card .form-input{width:100%;padding:12px 16px;border:1px solid #c1c7d0;border-radius:12px;font-size:16px;box-sizing:border-box;transition:border-color .2s, box-shadow .2s}
.auth-wrapper .password-reset-card .form-input:focus{outline:none;border-color:#0052cc;box-shadow:0 0 0 2px rgba(0,82,204,.2)}
.auth-wrapper .password-reset-card .primary-button{display:inline-flex;align-items:center;justify-content:center;width:100%;padding:14px;background:#0052cc;color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;margin-top:8px;transition:background-color .2s;text-decoration:none}
.auth-wrapper .password-reset-card .primary-button:hover{background:#0065ff;color:#fff}
.auth-wrapper .password-reset-card .secondary-link{display:inline-block;margin-top:24px;color:#0052cc;font-weight:700;text-decoration:none;font-size:14px}
.auth-wrapper .password-reset-card .secondary-link:hover{text-decoration:underline}

/* ===== Changelog ===== */
.tv-bg{background:#f8fafc}
.tv-main{padding:40px 20px;max-width:900px;margin:0 auto}
.tv-title{margin:0 0 10px;text-align:center;font-size:32px;font-weight:700;color:#2d3748}
.tv-sub{margin:0 0 50px;text-align:center;font-size:16px;color:#718096}
.tv-timeline{position:relative;padding-left:30px;margin-left:20px}
.tv-timeline::before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:#cbd5e1}
.tv-item{position:relative;margin:0 0 40px;padding-left:30px}
.tv-item::before{content:"";position:absolute;left:-8px;top:5px;width:18px;height:18px;border-radius:999px;background:#3182ce;border:3px solid #f8fafc;z-index:1}
.tv-ver{position:absolute;left:-150px;top:0;width:100px;text-align:right}
.tv-tag{display:inline-block;background:#e0f2f7;color:#3182ce;padding:4px 10px;border-radius:4px;font-size:12px;font-weight:600;margin-bottom:5px}
.tv-date{font-size:14px;color:#718096}
.tv-card{background:#fff;border-radius:8px;box-shadow:0 4px 15px rgba(0,0,0,.08);padding:25px}
.tv-card ul{list-style:none;margin:0;padding:0}
.tv-card li{font-size:15px;color:#4a5568;margin-bottom:12px;position:relative;padding-left:25px;line-height:1.6}
.tv-card li:last-child{margin-bottom:0}
.tv-card li::before{content:"✓";color:#10b981;font-weight:700;position:absolute;left:0;top:0;font-size:16px}
@media (max-width: 768px){
  .tv-main{padding:30px 15px}
  .tv-title{font-size:28px}
  .tv-sub{margin-bottom:30px}
  .tv-timeline{padding-left:20px;margin-left:0}
  .tv-item{padding-left:20px;margin-bottom:30px}
  .tv-item::before{left:-8px;top:3px}
  .tv-ver{position:static;width:auto;text-align:left;margin-bottom:10px}
  .tv-card{padding:20px}
  .tv-card li{font-size:14px;padding-left:22px}
  .tv-card li::before{font-size:14px}
}
