/* 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:#1d4ed8; /* 渐变起始 */
  --ys-gradient-2:#2563eb; /* 渐变结束 */
  --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{ color:#fff !important; }
.home a.text-slate-900: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-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-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-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}
.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: 0 }
@media (min-width: 768px){ .ys-hero-first{ margin-top: 16px } }

.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}
.front-mobile-account-menu{border-top:1px solid #e2e8f0;padding-top:8px}
.front-mobile-account-menu a.is-logout{color:#b91c1c}
.front-mobile-account-menu a.is-logout:hover{background:#fef2f2;color:#b91c1c}
.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}
.ys-global-toast-wrap{position:fixed;right:16px;bottom:22px;z-index:3000;display:flex;flex-direction:column;gap:10px;pointer-events:none;max-width:min(92vw,380px)}
.ys-global-toast{pointer-events:none;background:#0f172a;color:#fff;border:1px solid rgba(15,23,42,.16);border-radius:10px;padding:10px 12px;box-shadow:0 10px 28px rgba(2,6,23,.22);font-size:13px;line-height:1.45;opacity:.98;transform:translateY(0);transition:opacity .2s ease,transform .2s ease}
.ys-global-toast.is-success{background:#166534;border-color:rgba(22,101,52,.2)}
.ys-global-toast.is-warn{background:#92400e;border-color:rgba(146,64,14,.2)}
.ys-global-toast.is-error{background:#991b1b;border-color:rgba(153,27,27,.2)}
.ys-global-toast.is-leaving{opacity:0;transform:translateY(6px)}
/* 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}
.ys-hero-inner{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px;align-items:flex-start}
.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-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-content{padding:24px 0}
.ys-article{margin-bottom:24px}
.ys-article-title{margin:0 0 8px}
.ys-orders-list{max-height:420px;overflow:auto}

/* 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)}

/* ===== 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}
/* Dark mode tuning */
@media (prefers-color-scheme: dark){
  .ys-header-glass{background:rgba(26,32,44,.6)}
}
.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-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-foot{margin-top:12px;color:var(--ys-muted);text-align:center}
.auth-foot .ys-link{margin-left:8px}

/* 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}
.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}
.ys-toc-list li.ys-toc-child{padding-left:16px}
.ys-doc-env-title{margin-top: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;
}
/* ===== 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 .ys-orders-table-wrap{width:100%}
.ys-account .ys-orders-cards{display:none}
.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; }
.ys-account .ys-order-card{
  border:1px solid var(--ys-border);
  border-radius:10px;
  background:#fff;
  padding:12px;
}
.ys-account .ys-order-card + .ys-order-card{margin-top:10px}
.ys-account .ys-order-card-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  margin-bottom:10px;
}
.ys-account .ys-order-card-no{
  font-size:13px;
  font-weight:700;
  color:#1e293b;
  word-break:break-all;
}
.ys-account .ys-order-card-body{
  display:grid;
  gap:8px;
}
.ys-account .ys-order-card-row{
  display:flex;
  justify-content:space-between;
  gap:12px;
  font-size:13px;
  color:#64748b;
}
.ys-account .ys-order-card-row strong{
  color:#0f172a;
  font-weight:600;
  max-width:62%;
  text-align:right;
}
.ys-account .ys-order-card-domain{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.ys-account .ys-order-card-actions{
  margin-top:10px;
  padding-top:10px;
  border-top:1px dashed #e2e8f0;
  display:flex;
  flex-wrap:wrap;
  gap:8px 12px;
}
.ys-account .ys-order-card-actions a{
  font-size:13px;
  white-space:nowrap;
}
/* 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}
  .ys-account .content-panel{padding:14px;overflow:hidden}
  .ys-account .content-panel .filter-bar{
    grid-template-columns:1fr;
    gap:8px;
    padding-bottom:10px;
    margin-bottom:12px;
  }
  .ys-account .content-panel .filter-group{width:100%}
  .ys-account .content-panel .ys-search-btn,
  .ys-account .content-panel #ys-order-reset-btn{
    width:100%;
    justify-content:center;
  }
  .ys-account .ys-orders-table-wrap{display:none}
  .ys-account .ys-orders-cards{display:block;margin-top:4px}
}

/* 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 3.0 ====== */
.ys-checkout-page{
  --ck-accent:#1d5fd1;
  --ck-accent-strong:#0f4fb9;
  --ck-accent-soft:#e9f1ff;
  --ck-title:#0a2a4f;
  --ck-text:#12263a;
  --ck-muted:#60748a;
  --ck-border:#d9e3ef;
  background:
    radial-gradient(980px 360px at 86% -14%, rgba(29,95,209,.16), rgba(29,95,209,0) 64%),
    radial-gradient(760px 260px at 8% 6%, rgba(29,95,209,.1), rgba(29,95,209,0) 62%),
    linear-gradient(180deg,#f3f7ff 0%, #f7f9fe 100%);
  padding:36px 0 52px;
}
.ckx-wrap{
  max-width:1180px;
  margin:0 auto;
  padding:0 20px;
}
.ckx-top{
  margin:0 0 16px;
  padding:16px;
  border:1px solid var(--ck-border);
  border-radius:16px;
  background:linear-gradient(180deg,#ffffff,#f9fbff);
  box-shadow:0 10px 26px rgba(2,6,23,.06);
}
.ckx-top-main{
  margin:0 0 12px;
}
.ckx-top h1{
  margin:0;
  padding-left:14px;
  font-size:30px;
  line-height:1.2;
  color:var(--ck-title);
  letter-spacing:-.02em;
  position:relative;
}
.ckx-top h1::before{
  content:"";
  position:absolute;
  left:0;
  top:.14em;
  width:4px;
  height:.9em;
  border-radius:4px;
  background:linear-gradient(180deg,var(--ck-accent),#2b7bff);
}
.ckx-subtitle{
  margin:8px 0 0;
  color:var(--ck-muted);
  font-size:14px;
  line-height:1.75;
}
.ckx-progress{
  margin:0;
  padding:0;
  list-style:none;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.ckx-step{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:30px;
  padding:0 10px;
  border-radius:999px;
  border:1px solid #d6e2f0;
  background:#f8fbff;
  color:#67809a;
  font-size:12px;
  font-weight:600;
}
.ckx-step.is-active{
  border-color:#c5daf8;
  background:#edf4ff;
  color:#2b558f;
}
.ckx-step-index{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:18px;
  height:18px;
  border-radius:999px;
  background:#dbe8ff;
  color:#2b558f;
  font-size:10px;
  font-weight:700;
}
.ckx-meta-pills{
  margin:10px 0 0;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.ckx-meta-pills span{
  display:inline-flex;
  align-items:center;
  min-height:24px;
  border-radius:999px;
  border:1px solid #dce7fb;
  background:var(--ck-accent-soft);
  color:#214a88;
  padding:0 10px;
  font-size:12px;
  font-weight:600;
}
.ckx-disabled-note{
  margin:10px 0 0;
  color:#b45309;
  font-size:13px;
  line-height:1.6;
}
.ckx-grid{
  display:grid;
  grid-template-columns:minmax(0,1.14fr) minmax(0,.86fr);
  gap:20px;
  align-items:start;
}
.ckx-main,.ckx-side{display:grid;gap:16px}
.ckx-card{
  background:#fff;
  border:1px solid var(--ck-border);
  border-radius:16px;
  padding:20px;
  box-shadow:0 10px 22px rgba(15,30,60,.05);
}
.ckx-card h2{
  margin:0 0 14px;
  font-size:18px;
  line-height:1.3;
  color:var(--ck-title);
}
.ckx-card-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin:0 0 6px;
}
.ckx-chip{
  display:inline-flex;
  align-items:center;
  height:24px;
  border-radius:999px;
  border:1px solid #dce7fb;
  background:var(--ck-accent-soft);
  color:#214a88;
  padding:0 9px;
  font-size:12px;
  font-weight:600;
}
.ckx-chip-accent{
  background:linear-gradient(135deg,var(--ck-accent),var(--ck-accent-strong));
  border-color:transparent;
  color:#fff;
}
.ckx-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 0;
  border-bottom:1px solid #e7eef7;
  color:#4f6785;
  font-size:14px;
}
.ckx-row strong{
  color:var(--ck-text);
  font-size:15px;
  font-weight:700;
}
.ckx-row-total{border-bottom:0;padding-bottom:6px}
.ckx-row-total .ckx-total-price{
  color:var(--ck-accent);
  font-size:24px;
  line-height:1;
}
.ckx-row .ckx-discount{color:#0f766e}
.ckx-order-meta{
  margin-top:10px;
  padding-top:12px;
  border-top:1px dashed #d9e6f5;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  font-size:13px;
  color:#49688c;
}
.ckx-order-meta code{
  color:var(--ck-text);
  background:#f4f8ff;
  border:1px solid #dbe7f6;
  border-radius:8px;
  padding:4px 8px;
  font-size:12px;
  font-weight:700;
}
.ckx-coupon-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.ckx-coupon-head h2{margin:0;font-size:18px}
.ckx-coupon-head a{
  color:var(--ck-accent);
  font-size:13px;
  font-weight:600;
  text-decoration:none;
}
.ckx-coupon-head a:hover{text-decoration:underline}
.ckx-coupon-hint{
  margin:0;
  color:var(--ck-muted);
  font-size:13px;
  line-height:1.65;
}
.ckx-coupon-box{
  margin-top:12px;
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px;
}
.ckx-coupon-box.hidden{display:none}
.ckx-coupon-box input{
  height:40px;
  border:1px solid #d6e2f2;
  border-radius:10px;
  padding:0 12px;
  font-size:14px;
}
.ckx-coupon-box input:focus{
  outline:none;
  border-color:#9bc0fb;
  box-shadow:0 0 0 3px rgba(59,130,246,.15);
}
.ckx-coupon-box button{
  min-width:90px;
  height:40px;
  border:1px solid var(--ck-accent);
  border-radius:10px;
  background:var(--ck-accent);
  color:#fff;
  font-size:14px;
  font-weight:700;
  cursor:pointer;
}
.ckx-coupon-msg{
  margin:10px 0 0;
  min-height:20px;
  color:var(--ck-muted);
  font-size:13px;
}
.ckx-note-card h3{
  margin:0 0 10px;
  color:var(--ck-title);
  font-size:16px;
  line-height:1.35;
}
.ckx-note-list{
  margin:0;
  padding:0;
  list-style:none;
  display:grid;
  gap:10px;
}
.ckx-note-list li{
  position:relative;
  padding-left:16px;
  color:var(--ck-muted);
  font-size:13px;
  line-height:1.68;
}
.ckx-note-list li::before{
  content:"";
  position:absolute;
  left:0;
  top:.6em;
  width:6px;
  height:6px;
  border-radius:999px;
  background:var(--ck-accent);
}
.ckx-side{
  position:sticky;
  top:calc(var(--ys-header-h) + 18px);
}
.ckx-pay-card{
  border-color:#c9dcf8;
  background:linear-gradient(180deg,#ffffff 0%, #f7fbff 100%);
}
.ckx-pay-head{
  margin:0 0 10px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.ckx-pay-head h2{margin:0}
.ckx-pay-head .ckx-chip{flex-shrink:0}
.ckx-pay-method-wrap{
  margin:12px 0 0;
}
.ckx-field-label{
  margin:0 0 8px;
  color:var(--ck-muted);
  font-size:12px;
  line-height:1.5;
  font-weight:600;
  letter-spacing:.02em;
}
.ckx-pay-summary{
  margin-top:2px;
  padding:14px;
  border:1px solid #d6e4f8;
  border-radius:12px;
  background:#f8fbff;
}
.ckx-pay-plan{
  margin:0;
  color:#4f6785;
  font-size:13px;
}
.ckx-pay-total{
  margin:6px 0 0;
  color:var(--ck-accent-strong);
  font-size:34px;
  font-weight:800;
  line-height:1;
}
.ckx-pay-total-sub{
  margin:6px 0 0;
  color:var(--ck-muted);
  font-size:12px;
}
.ckx-pay-method{
  margin:0;
  display:flex;
  align-items:center;
  justify-content:flex-start;
}
.ys-checkout-page .ck-payway{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:160px;
  min-height:54px;
  padding:10px 16px;
  border:1px solid #c7dbfa;
  border-radius:12px;
  background:#fff;
  cursor:pointer;
  transition:border-color .18s ease, box-shadow .18s ease, background-color .18s ease;
}
.ys-checkout-page .ck-payway.active{
  border-color:var(--ck-accent);
  background:#f4f8ff;
  box-shadow:0 8px 18px rgba(29,95,209,.14);
}
.ys-checkout-page .ck-payway img{
  display:block;
  height:30px;
  width:auto;
  border-radius:0;
}
.ys-checkout-page .ck-payway .ys-check{
  display:none;
}
.ys-checkout-page .ck-payway.active::after,
.ys-checkout-page .ck-payway.active::before{
  display:none !important;
}
.ckx-trust-list{
  margin:12px 0 0;
  padding:0;
  list-style:none;
  display:grid;
  gap:9px;
}
.ckx-trust-list li{
  position:relative;
  padding-left:16px;
  color:#5b7390;
  font-size:13px;
  line-height:1.6;
}
.ckx-trust-list li::before{
  content:"";
  position:absolute;
  left:0;
  top:8px;
  width:6px;
  height:6px;
  border-radius:999px;
  background:var(--ck-accent);
}
.ckx-pay-btn{
  margin-top:20px;
  width:100%;
  min-height:48px;
  border-radius:12px;
  border:1px solid transparent;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,var(--ck-accent),var(--ck-accent-strong));
  color:#fff;
  font-size:15px;
  font-weight:800;
  letter-spacing:.01em;
  transition:transform .18s ease, box-shadow .18s ease, filter .18s ease;
  box-shadow:0 12px 24px rgba(29,95,209,.24);
}
.ckx-pay-btn:hover{
  transform:translateY(-1px);
  filter:brightness(.98);
}
.ckx-pay-btn[aria-disabled="true"]{
  opacity:.66;
  box-shadow:none;
  cursor:not-allowed;
}
.ckx-status{
  margin:8px 0 0;
  min-height:20px;
  color:var(--ck-muted);
  font-size:13px;
  line-height:1.45;
}
.ckx-status.err{color:#b45309}
.ckx-error-actions{
  margin-top:10px;
  display:flex;
  align-items:center;
  gap:10px;
}
.ckx-error-actions.hidden{display:none}
.ckx-retry-btn{
  min-height:34px;
  border:1px solid #d0ddf0;
  border-radius:9px;
  background:#fff;
  color:#1f4e9a;
  padding:0 12px;
  font-size:13px;
  font-weight:700;
  cursor:pointer;
}
.ckx-support-link{
  color:var(--ck-accent);
  font-size:13px;
  font-weight:600;
}
.ckx-security-tip{
  margin:18px 0 0;
  color:var(--ck-muted);
  text-align:center;
  font-size:12px;
}
.ckx-coupon-box button:focus-visible,
.ckx-coupon-head a:focus-visible,
.ckx-pay-btn:focus-visible,
.ckx-retry-btn:focus-visible,
.ckx-support-link:focus-visible{
  outline:2px solid rgba(29,95,209,.34);
  outline-offset:2px;
}
@media (max-width: 1024px){
  .ckx-grid{grid-template-columns:1fr}
  .ckx-side{position:static}
}
@media (max-width: 960px){
  .ys-checkout-page{padding-top:28px}
  .ckx-wrap{padding:0 16px}
  .ckx-top{padding:14px}
  .ckx-top h1{font-size:26px}
}
@media (max-width: 760px){
  .ckx-top h1{font-size:24px}
  .ckx-coupon-box{grid-template-columns:1fr}
  .ckx-coupon-box button{justify-self:end;min-width:88px}
  .ckx-row{font-size:13px}
  .ckx-row strong{font-size:14px}
  .ckx-row-total .ckx-total-price{font-size:22px}
  .ckx-pay-total{font-size:30px}
}
@media (prefers-reduced-motion: reduce){
  .ckx-pay-btn,
  .ys-checkout-page .ck-payway,
  .ckx-coupon-box button,
  .ckx-coupon-head a{
    transition:none !important;
  }
  .ckx-pay-btn:hover{
    transform:none;
  }
}

/* ====== 首页产品区块 ====== */
.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-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}

/* ====== 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}
.ys-confirm-content{max-width:460px}
.ys-confirm-title{margin:0 0 10px;font-size:18px;line-height:1.4;color:#0f172a}
.ys-confirm-message{margin:0;color:#475569;line-height:1.65}
.ys-confirm-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}
@media (max-width: 640px){
  .ys-confirm-content{margin:8vh 14px;padding:18px}
  .ys-confirm-actions{justify-content:stretch}
  .ys-confirm-actions .ys-btn{flex:1}
}

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

/* 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:#e9f1ff;color:#1d5fd1;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:#1d5fd1;color:#fff}
#ys-login-modal .btn-primary:hover{background:#0f4fb9}
#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:#1d5fd1;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:#1d5fd1;border-color:#1d5fd1;color:#fff;box-shadow:0 1px 2px rgba(29,95,209,.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}
@media (max-width: 767px){
  .ys-pager{
    gap:6px;
    margin-top:16px;
    flex-wrap:wrap;
    overflow:visible;
    justify-content:center;
    padding-bottom:2px;
  }
  .ys-pager .pager-link{
    min-width:32px;
    height:32px;
    padding:0 8px;
    font-size:13px;
  }
  .ys-pager .pager-ellipsis{
    width:28px;
    height:32px;
  }
}

/* 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:#1d5fd1; --brand-color-dark:#0f4fb9;
  --text-primary:#0a2a4f; --text-secondary:#60748a;
  --border-color:#d9e3ef; --background-light:#f3f7fc;
  background:
    radial-gradient(860px 300px at 10% -14%, rgba(29,95,209,.12), rgba(29,95,209,0) 60%),
    var(--background-light);
}
/* Login */
.login-wrapper{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 0px);padding:32px 20px;box-sizing:border-box}
.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(29,95,209,.16)}
.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}
.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(29,95,209,.16)}
.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}
.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(29,95,209,.2), rgba(29,95,209,.1));border:1px solid rgba(29,95,209,.24);color:#1f2937;box-shadow:0 10px 24px rgba(29,95,209,.12) inset}
.auth-wrapper .auth-ico.auth-ico-success{border-radius:999px;background:#e6f7f0;border-color:rgba(0,138,69,.25);color:#008a45;box-shadow:none;margin:0 auto 24px}
.auth-wrapper .auth-ico.auth-ico-success svg{width:32px;height:32px}
.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(29,95,209,.16)}
.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}
.login-wrapper .btn-primary:focus-visible,
.register-wrapper .btn-primary:focus-visible,
.auth-wrapper .btn-primary:focus-visible,
.auth-wrapper .password-reset-card .primary-button:focus-visible{
  outline:2px solid rgba(29,95,209,.34);
  outline-offset:2px;
}
@media (prefers-reduced-motion: reduce){
  .login-wrapper .btn-primary,
  .register-wrapper .btn-primary,
  .auth-wrapper .btn-primary,
  .auth-wrapper .password-reset-card .primary-button{
    transition:none !important;
  }
}

/* ===== 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:auto;overflow:visible;overscroll-behavior:auto}
.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}
@media (max-width: 767px){
  body.ys-route-account .ys-main,
  body.ys-route-orders .ys-main,
  body.ys-route-order .ys-main,
  body.ys-route-ticket .ys-main,
  body.ys-route-ticket-new .ys-main,
  body.ys-route-password .ys-main{
    padding-bottom:calc(72px + env(safe-area-inset-bottom, 0px));
  }
  body.ys-route-account .ys-footer,
  body.ys-route-orders .ys-footer,
  body.ys-route-order .ys-footer,
  body.ys-route-ticket .ys-footer,
  body.ys-route-ticket-new .ys-footer,
  body.ys-route-password .ys-footer{
    position:fixed;
    left:0;
    right:0;
    bottom:0;
    z-index:60;
    box-shadow:0 -6px 16px rgba(2,6,23,.16);
    padding-bottom:calc(14px + env(safe-area-inset-bottom, 0px));
  }
}
/* File item meta vertical stack */
.ys-fi-meta{display:flex;flex-direction:column;gap:2px}

/* ===== Forgot Password ===== */
.auth-wrapper .password-reset-card{background:linear-gradient(180deg,#ffffff,#f9fbff);padding:40px 48px;border-radius:16px;border:1px solid var(--border-color);box-shadow:0 12px 28px rgba(2,6,23,.08);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:var(--text-primary)}
.auth-wrapper .password-reset-card p{margin:0 0 28px;color:var(--text-secondary);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:#314b69}
.auth-wrapper .password-reset-card .form-input{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:12px;background:#f8fbff;font-size:16px;box-sizing:border-box;transition:border-color .2s, box-shadow .2s, background-color .2s}
.auth-wrapper .password-reset-card .form-input:focus{outline:none;border-color:var(--brand-color);box-shadow:0 0 0 3px rgba(29,95,209,.16);background:#fff}
.auth-wrapper .password-reset-card .primary-button{display:inline-flex;align-items:center;justify-content:center;width:100%;padding:14px;background:var(--brand-color);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:var(--brand-color-dark);color:#fff}
.auth-wrapper .password-reset-success-card .primary-button{margin-top:28px}
.auth-wrapper .password-reset-card .secondary-link{display:inline-block;margin-top:24px;color:var(--brand-color);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}
}
