/* ====== Variables & Reset ====== */
:root{--primary:#dc2626;--primary-dark:#b91c1c;--text:#333;--text-secondary:#666;--text-muted:#999;--bg:#f5f5f5;--white:#fff;--border:#e5e5e5;--shadow:0 1px 4px rgba(0,0,0,0.06)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
*{-webkit-tap-highlight-color:transparent}
button,a,.btab-item,.my-quick-item,.ac-grid3-item,[onclick]{touch-action:manipulation}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','PingFang SC','Microsoft YaHei',sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;max-width:480px;margin:0 auto;min-height:100vh;position:relative}
a{color:var(--primary);text-decoration:none}
input,textarea,select,button{font-family:inherit}

/* ====== App Container ====== */
#app{min-height:100vh;padding-bottom:70px}
.page{display:none}
.page.active{display:block}

/* ====== Bottom Tab Bars ====== */
.bottom-tabbar{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:480px;display:none;background:var(--white);border-top:1px solid var(--border);z-index:100;padding:6px 0 env(safe-area-inset-bottom,0);justify-content:space-around;align-items:center}
.bottom-tabbar.show{display:flex}
.btab-item{display:flex;flex-direction:column;align-items:center;cursor:pointer;padding:4px 0;min-width:48px;color:var(--text-muted);transition:color 0.15s}
.btab-item.active{color:var(--primary)}
.btab-icon{width:24px;height:24px;display:block;margin-bottom:2px}
.btab-label{font-size:10px;line-height:1}
.tab-badge{position:absolute;top:-2px;right:-8px;background:var(--primary);color:var(--white);font-size:10px;min-width:16px;height:16px;border-radius:8px;text-align:center;line-height:16px;padding:0 4px}

/* === Author Tab Bar === */
.author-tabbar{border-top:1px solid var(--border)}
.author-tabbar .btab-item.active{color:var(--primary)}

/* === Admin Tab Bar === */
.admin-tabbar{background:#1a1a2e;border-top:1px solid #333}
.admin-tabbar .btab-item{color:#888}
.admin-tabbar .btab-item.active{color:#ff6b6b}


/* ====== Page Headers ====== */
.page-header-row{background:var(--white);padding:12px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:40}
.back-btn{cursor:pointer;font-size:18px;color:var(--text);width:40px;flex-shrink:0}
.header-title{font-size:16px;font-weight:600;color:var(--text);flex:1;text-align:center}
.header-action{font-size:13px;color:var(--primary);cursor:pointer;width:40px;text-align:right;flex-shrink:0}

/* === Author Page Header === */
.author-page-header{background:var(--primary);padding:14px 16px;display:flex;align-items:center;position:sticky;top:0;z-index:50}
.author-header-back{color:var(--white);font-size:20px;cursor:pointer;width:30px;flex-shrink:0;line-height:1}
.author-header-title{color:var(--white);font-size:17px;font-weight:600;flex:1;text-align:center}
.author-header-placeholder{width:30px;flex-shrink:0}

/* === Admin Page Header === */
.admin-page-header{background:var(--primary);padding:14px 16px;display:flex;align-items:center;position:sticky;top:0;z-index:50}
.admin-header-title{color:var(--white);font-size:17px;font-weight:600;flex:1;text-align:center}


/* === Publish Header === */
.pub-header{background:var(--primary);padding:14px 16px;display:flex;align-items:center;color:var(--white);position:sticky;top:0;z-index:50}
.pub-header-back{font-size:20px;cursor:pointer;width:30px;flex-shrink:0;line-height:1}
.pub-header-title{font-size:17px;font-weight:600;flex:1;text-align:center}
.pub-header-placeholder{width:30px;flex-shrink:0}

/* ====== Form Elements ====== */
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:6px}
.form-input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:6px;font-size:14px;box-sizing:border-box;background:var(--white);transition:border-color 0.2s}
.form-input:focus{outline:none;border-color:var(--primary)}
textarea.form-input{resize:vertical;font-family:inherit;line-height:1.6}
select.form-input{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}

/* ====== User Center (我的) ====== */
.my-page{background:var(--bg);min-height:100vh;width:100%;overflow-x:hidden}
.my-header-red{background:linear-gradient(135deg,#dc2626,#ef4444);padding:0;color:var(--white);position:relative;margin:12px 16px 0;border-radius:12px}
.my-header-topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px}
.my-header-title{font-size:17px;font-weight:700;text-align:center;flex:1}
.my-user-row{display:flex;align-items:center;padding:6px 16px 16px;cursor:pointer;color:var(--white)}
.my-avatar-green{width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,0.15);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.my-user-text{flex:1;margin-left:12px}
.my-user-nickname{font-size:18px;font-weight:700;display:block}
.my-profile-sub{font-size:12px;opacity:0.8;margin-top:3px;display:block}
.my-user-arrow{font-size:18px;opacity:0.5;flex-shrink:0}
.my-stats-row-v2{display:flex;justify-content:space-around;padding:0 16px 18px}
.my-stat-item-v2{text-align:center;cursor:pointer;flex:1;min-width:0}
.my-stat-val-v2{font-size:20px;font-weight:700;display:block;letter-spacing:-0.5px}
.my-stat-val-red{color:#FFD700}
.my-stat-label-v2{font-size:11px;opacity:0.8;margin-top:4px;display:block}
.my-stat-divider{width:1px;background:rgba(255,255,255,0.2);align-self:stretch;margin:6px 0}
.my-quick-card{background:var(--white);margin:0 16px 12px;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,0.04)}
.my-quick-grid{display:grid;grid-template-columns:repeat(3,1fr)}
.my-quick-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px 4px 16px;cursor:pointer;text-align:center;border-right:1px solid #f8f8f8;border-bottom:1px solid #f8f8f8;position:relative;transition:background 0.15s}
.my-quick-item:nth-child(3n){border-right:none}
.my-quick-item:active{background:#fafafa}
.my-quick-icon-wrap{width:40px;height:40px;display:flex;align-items:center;justify-content:center;margin-bottom:8px}
.my-quick-label{font-size:12px;color:#555;display:block}
.my-logout-area{padding:4px 16px 12px;display:flex;flex-direction:column;gap:10px}
.my-logout-btn{background:var(--primary);color:var(--white);border:none;width:100%;padding:12px;border-radius:24px;font-size:15px;font-weight:600;cursor:pointer;letter-spacing:1px}
.my-logout-btn:active{opacity:0.85}
.my-switch-btn{background:var(--white);color:var(--primary);border:1px solid var(--primary);width:100%;padding:12px;border-radius:24px;font-size:14px;cursor:pointer}
.my-switch-btn:active{background:#fef2f2}
.my-author-btn{display:flex;align-items:center;margin:10px;padding:14px 12px;background:var(--white);border-radius:10px;cursor:pointer;box-shadow:0 1px 3px rgba(0,0,0,0.04)}
.my-author-btn:active{background:#f9f9f9}
.my-author-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.my-author-text{font-size:13px;color:var(--text);margin-left:10px;flex:1}
.my-author-arrow{color:#ccc;font-size:14px}

/* ====== Merchant Homepage ====== */
.merchant-page{background:#f5f5f5;min-height:100vh}

/* Red top navigation bar */
.m-topbar{background:#dc2626;padding:10px 16px;display:flex;align-items:center;justify-content:space-between;color:#fff;position:sticky;top:0;z-index:50}
.m-topbar-left{font-size:14px;cursor:pointer;flex-shrink:0}
.m-topbar-title{font-size:20px;font-weight:700;flex:1;text-align:center}
.m-topbar-right{font-size:14px;cursor:pointer;flex-shrink:0}

/* White header section below topbar */
.m-header-section{background:#fff;border-bottom:1px solid #f0f0f0}

/* Top row: logo + title + online count */
.m-header-top{display:flex;align-items:center;padding:16px 16px 4px}
.m-header-logo{width:52px;height:52px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid #dc2626}
.m-header-title{flex:1;font-size:18px;font-weight:700;color:#000;margin-left:12px;min-width:0}
.m-header-online{font-size:13px;color:#dc2626;flex-shrink:0;font-weight:500;margin-left:8px}

/* Description text */
.m-header-desc{padding:8px 16px 20px;font-size:13px;color:#666;line-height:1.7;margin:0}

.m-search{padding:10px 16px;background:#dc2626}
.m-search-bar{display:flex;align-items:center;padding:10px 14px;background:#f5f5f5;border-radius:24px;cursor:pointer}
.m-search-icon{margin-right:8px;font-size:16px;flex-shrink:0}
.m-search-placeholder{color:#999;font-size:14px}
.m-articles{padding:0 16px 20px}
.m-articles-header{display:flex;justify-content:space-between;align-items:center;padding:14px 0}
.m-articles-title{font-size:16px;font-weight:700;color:#333}
.m-articles-more{font-size:12px;color:var(--primary);cursor:pointer}
/* === Merchant Article Cards === */
.m-card{background:#fff;border-radius:12px;padding:12px;margin-bottom:10px;box-shadow:0 2px 12px rgba(0,0,0,0.06);cursor:pointer;display:flex;gap:10px;border:1px solid #f2f2f2;position:relative}
.m-card-rb-badge{position:absolute;top:8px;right:8px;font-size:20px;font-weight:900;line-height:1;z-index:1;text-shadow:0 1px 2px rgba(255,255,255,0.8)}
.m-card-rb-badge.red{color:#dc2626}
.m-card-rb-badge.black{color:#333}
.m-card:active{background:#fafafa}
.m-card-img-wrap{width:clamp(60px,18vw,90px);height:clamp(60px,18vw,90px);border-radius:8px;overflow:hidden;flex-shrink:0;background:#f5f5f5;border:1px solid #eee}
.m-card-img{width:100%;height:100%;object-fit:cover;display:block}
.m-card-body{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:space-between;gap:2px;padding-right:22px}
.m-card-title{font-size:14px;font-weight:600;color:#1a1a1a;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-all}
.m-card-new{display:inline-block;background:#dc2626;color:#fff;font-size:9px;padding:1px 4px;border-radius:3px;margin-right:4px;vertical-align:middle;font-weight:600}
.m-card-issue{display:inline-block;background:#f59e0b;color:#fff;font-size:10px;padding:1px 5px;border-radius:3px;margin-right:4px;vertical-align:middle;font-weight:700}
/* Top row */
.m-card-top-row{margin-bottom:4px}
/* Stats row */
.m-card-stats-row{display:flex;align-items:center;flex-wrap:wrap;gap:0;font-size:11px;color:#7c3aed;margin-bottom:4px}
.m-stat-item{color:#7c3aed;white-space:nowrap}
.m-stat-sep{color:#c4b5fd;font-size:9px;margin:0 3px}
.m-stat-heat{color:#dc2626;font-weight:700}
/* Time row */
.m-card-time{font-size:10px;color:#aaa}
/* Bottom row: time left + button right */
.m-card-bottom-row{display:flex;align-items:center;justify-content:space-between}
.m-card-price-btn{background:#dc2626;color:#fff;font-size:12px;font-weight:600;padding:4px 10px;border-radius:12px;white-space:nowrap;cursor:pointer;display:inline-block}
.m-card-price-btn:active{opacity:0.85}
.m-card-free-tag{color:#16a34a;font-size:12px;font-weight:600;white-space:nowrap}

/* Unused, kept for compatibility */
.m-card-heat{font-size:12px;color:#dc2626;font-weight:700;margin-bottom:6px}
.m-card-desc{font-size:12px;color:#999;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}
.m-card-foot{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:auto}
.m-card-stat{font-size:11px;color:#999}
.m-card-bought{background:#22c55e;color:#fff;font-size:9px;padding:2px 8px;border-radius:8px;font-weight:600;white-space:nowrap}
.m-card-buy{background:#dc2626;color:#fff;border:none;padding:4px 10px;border-radius:12px;font-size:10px;font-weight:600;cursor:pointer;white-space:nowrap}
.m-empty{text-align:center;padding:40px 20px}
.m-empty-icon{font-size:40px;display:block;margin-bottom:8px}
.m-empty-text{font-size:14px;color:#999;display:block}
.m-empty-hint{font-size:12px;color:#ccc;display:block;margin-top:4px}
.load-more{text-align:center;padding:10px 0 20px}
.load-more-btn{background:#f0f0f0;border:none;padding:10px 30px;border-radius:20px;font-size:13px;color:#666;cursor:pointer}
.load-more-btn:active{background:#e0e0e0}

/* ====== Home / Articles ====== */
.search-bar-row{display:flex;align-items:center;margin-bottom:10px}
.search-bar-input{flex:1;padding:8px 12px;border:1px solid var(--border);border-radius:20px;font-size:13px;outline:none;box-sizing:border-box;background:var(--white)}
.search-bar-btn{background:var(--primary);color:var(--white);border:none;padding:8px 16px;border-radius:20px;font-size:13px;cursor:pointer;flex-shrink:0}
.article-card{background:var(--white);border-radius:10px;padding:12px 14px;margin-bottom:10px;box-shadow:var(--shadow);cursor:pointer;position:relative}
.article-card:active{background:#f9f9f9}
.home-card-author{display:flex;align-items:center;gap:8px}
.home-card-author-name{font-size:13px;color:var(--text-secondary)}
.article-author-row{margin:12px 0}

/* ====== Article Card (getArticleCardHtml) ====== */
.card-img-wrap{width:100%;aspect-ratio:1;border-radius:10px;overflow:hidden;background:#f8f8f8;margin-bottom:10px;display:flex;align-items:center;justify-content:center;position:relative}
.card-img-wrap img{width:100%;height:100%;object-fit:cover}
.card-content{display:flex;flex-direction:column}
.card-title{font-size:14px;font-weight:600;color:#333;line-height:1.4;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-price{font-size:18px;font-weight:700;color:var(--primary);margin-bottom:8px;display:block}
.card-time-tag{position:absolute;top:6px;right:6px;font-size:10px;color:#fff;background:rgba(0,0,0,0.45);padding:3px 8px;border-radius:10px;pointer-events:none;z-index:2}
.card-stats{display:flex;align-items:center;gap:4px;font-size:12px;padding-top:8px;border-top:1px solid #f0f0f0}
.stat-item{color:#333;white-space:nowrap}
.stat-sep{color:#ccc;font-size:10px}
.stat-heat{color:#dc2626;font-weight:600}

/* ====== Order Cards (Admin) ====== */
.order-card{display:flex;align-items:center;padding:14px 16px;background:#fff;border-bottom:1px solid #f5f5f5;cursor:pointer;transition:background 0.15s}
.order-card:active{background:#fafafa}
.order-card-left{flex:1;min-width:0}
.order-card-title{font-size:14px;font-weight:600;color:#333;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.order-card-meta{font-size:12px;color:#999}
.order-card-right{text-align:right;flex-shrink:0;margin-left:12px}
.order-card-price{font-size:17px;font-weight:700;color:#dc2626;display:block;margin-bottom:4px}
.order-card-status{font-size:11px;padding:2px 8px;border-radius:10px;font-weight:600;display:inline-block}

/* ====== Card Badge (logo image) ====== */
.card-badge{width:100%;aspect-ratio:1;background:linear-gradient(135deg,#dc2626,#b91c1c);border-radius:10px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.card-badge-logo{width:80%;height:80%;object-fit:contain}

/* ====== Review ====== */
.review-card{transition:background 0.15s}
.review-card:active{background:#fafafa}
.article-checkbox{width:18px;height:18px;accent-color:var(--primary)}
.notif-item{transition:background 0.15s}
.notif-item:active{background:#f9f9f9}

/* ====== Message / Chat ====== */
.chat-item{transition:background 0.15s}
.chat-item:active{background:#f9f9f9}

/* ====== Misc Helpers ====== */
.login-agreement{text-align:center;margin-top:16px;font-size:11px;color:var(--text-muted);line-height:1.6;padding-bottom:20px}
.login-agreement a{color:var(--primary);text-decoration:none}

/* ====== Stat Cards ====== */
.stat-cards{display:flex;gap:8px}
.stat-card{flex:1;background:var(--white);padding:12px 8px;border-radius:8px;text-align:center;box-shadow:var(--shadow)}
.stat-card-val{font-size:18px;font-weight:700;color:var(--primary);display:block}
.stat-card-label{font-size:11px;color:var(--text-muted);margin-top:4px;display:block}

/* ====== Empty / Loading / Error States ====== */
.empty-state{text-align:center;padding:40px 20px;color:var(--text-muted);font-size:14px}
.empty-icon{font-size:40px;margin-bottom:8px}
.loading-spinner{width:32px;height:32px;border:3px solid #f0f0f0;border-top-color:var(--primary);border-radius:50%;animation:spin 0.8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.info-card{background:var(--white);padding:14px;border-radius:8px;box-shadow:var(--shadow)}

/* ====== Modal / Popup ====== */
.popup-mask{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:200;display:none;align-items:center;justify-content:center}
.popup-mask.show{display:flex}
.popup-box{background:var(--white);border-radius:12px;padding:20px;text-align:center;max-width:280px;width:90%}
.popup-img-placeholder{width:160px;height:160px;margin:0 auto 12px;background:#f5f5f5;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--text-muted);flex-direction:column}
.popup-text{font-size:14px;color:var(--text);margin-bottom:12px}
.popup-close{background:#f0f0f0;border:none;padding:8px 24px;border-radius:20px;font-size:14px;cursor:pointer}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:200;display:flex;align-items:center;justify-content:center}
.modal-box{background:var(--white);border-radius:12px;max-width:320px;width:90%;overflow:hidden}
.modal-title{font-size:16px;font-weight:700;padding:16px;border-bottom:1px solid var(--border)}
.modal-body{padding:16px;font-size:14px;color:var(--text-secondary)}
.modal-footer{padding:12px 16px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}
.modal-btn{padding:8px 20px;border-radius:8px;font-size:14px;cursor:pointer;border:none}
.modal-btn-cancel{background:#f0f0f0;color:#666}
.modal-btn-confirm{background:var(--primary);color:#fff}

/* ====== Pay Method Selector ====== */
.pay-method-item{display:flex;align-items:center;padding:14px 12px;border:1px solid var(--border);border-radius:10px;margin-bottom:8px;cursor:pointer;transition:border-color 0.15s}
.pay-method-item:hover{border-color:var(--primary)}
.pay-method-item:active{background:#fafafa}

/* ====== Home Cards ====== */
.home-card{background:var(--white);border-radius:12px;padding:12px;margin-bottom:8px;box-shadow:var(--shadow);cursor:pointer;position:relative;border:1px solid #f2f2f2}
.home-card:active{background:#f9f9f9}
.home-card-inner{display:flex;gap:10px;align-items:flex-start}
.home-card-img{width:clamp(70px,20vw,100px);height:clamp(70px,20vw,100px);border-radius:8px;overflow:hidden;flex-shrink:0;background:#f5f5f5;border:1px solid #eee}
.home-card-img img{width:100%;height:100%;object-fit:cover;display:block}
.home-card-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:28px;color:#d0d0d0}
.home-card-body{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:space-between;gap:2px}
.home-card-head{display:flex;align-items:flex-start;gap:6px}
.home-card-title{font-weight:600;font-size:14px;color:#1a1a1a;line-height:1.35;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-all}
.home-card-badge{flex-shrink:0;background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-size:12px;font-weight:700;padding:2px 8px;border-radius:8px;line-height:1.4;white-space:nowrap;letter-spacing:0.5px;box-shadow:0 1px 3px rgba(16,185,129,0.25)}
.home-card-meta{display:flex;align-items:center;flex-wrap:wrap;font-size:11px;color:#999;margin:3px 0}
.home-card-meta-dot{margin:0 3px;color:#ddd}
.home-card-foot{display:flex;align-items:center;justify-content:flex-end}
.home-card-author{font-size:10px;background:#f5f5f5;color:#999;padding:1px 6px;border-radius:6px;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:0}
.home-card-actions{display:flex;align-items:center;gap:4px}
.home-card-bought{font-size:9px;background:#e8f5e9;color:#2e7d32;padding:1px 6px;border-radius:6px;font-weight:600}
.home-card-btn{background:#dc2626;color:#fff;border:none;padding:4px 10px;border-radius:10px;font-size:10px;font-weight:600;cursor:pointer;white-space:nowrap}
.home-card-btn:active{opacity:0.85}
/* Merchant card public tag */
.m-card-public-tag{display:inline-block;background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-size:13px;font-weight:700;padding:4px 10px;border-radius:8px;white-space:nowrap;box-shadow:0 1px 3px rgba(16,185,129,0.25)}
/* Merchant card free tag — keep original */
.m-card-free-tag{color:#16a34a;font-size:12px;font-weight:600;white-space:nowrap}
.home-tab{padding:8px 16px;font-size:13px;color:#666;cursor:pointer;border-bottom:2px solid transparent}
.home-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}
.home-tabs{display:flex;justify-content:center;gap:0;background:var(--white);border-bottom:1px solid var(--border)}
.tag-item{display:inline-block;cursor:pointer}

/* ====== Article Detail ====== */
.article-detail-page{padding:0 0 24px;background:#fff}
/* Article image at top */
.article-detail-image{width:100%;max-height:150px;overflow:hidden;background:#f5f5f5}
.article-detail-image img{width:100%;height:100%;max-height:150px;display:block;object-fit:cover}
/* Title */
.article-detail-title{font-size:20px;font-weight:700;color:#1a1a1a;line-height:1.4;margin:0 16px 6px;padding-top:10px}
/* Meta row */
.article-detail-meta{display:flex;align-items:center;gap:6px;font-size:12px;color:#999;margin:0 16px 8px;flex-wrap:wrap}
.ad-meta-time{color:#999;white-space:nowrap}
.ad-meta-sep{color:#ccc;font-size:11px}
.ad-meta-stat{color:#888;white-space:nowrap}
.ad-meta-stat b{color:#555;font-weight:600}
.ad-meta-heat{color:#dc2626;font-weight:700}
.ad-meta-heat b{color:#dc2626}
.ad-meta-fav{font-size:20px;cursor:pointer;margin-left:auto;flex-shrink:0;user-select:none}
/* In-content locked state for paid articles */
.content-locked-area{text-align:center;padding:40px 20px}
.content-locked-card{display:inline-block;background:#f8f9fa;border-radius:16px;padding:40px 32px 36px;box-shadow:0 2px 16px rgba(0,0,0,0.06);min-width:240px}
.cls-lock-icon{font-size:44px;margin-bottom:12px;line-height:1}
.cls-price-label{font-size:17px;font-weight:700;color:#b91c1c;margin-bottom:10px}
.cls-loading-text{font-size:13px;color:#999}
/* Public article banner */
.article-public-banner{text-align:center;padding:24px 20px}
.apb-inner{display:inline-flex;align-items:center;gap:10px;background:#ecfdf5;border:1px solid #a7f3d0;border-radius:12px;padding:14px 24px}
.apb-text{font-size:15px;font-weight:600;color:#059669}
/* Content loading */
.article-content-loading{text-align:center;padding:40px 20px;color:#999;font-size:13px}
.article-content-loading .loading-text{display:block;margin-top:12px}
/* Stats bar at bottom */
.article-detail-stats{display:flex;justify-content:space-around;padding:20px 0;margin:16px 0 0;border-top:1px solid #f0f0f0}
.ad-stat-item{text-align:center;flex:1}
.ad-stat-num{display:block;font-size:22px;font-weight:700;color:#333}
.ad-stat-label{font-size:12px;color:#999;margin-top:2px;display:block}
/* Content display */
.article-detail-content{padding:14px 16px;font-size:16px;line-height:1.9;color:#333;word-break:break-word;background:#fdf6f6;border-radius:8px;margin:0 16px}
.article-detail-content img{max-width:100%;border-radius:8px}
/* Disclaimer */
.article-disclaimer{margin:6px 16px 8px;padding:8px 14px;background:#ff6b6b;border-radius:10px;display:flex;gap:8px;align-items:flex-start}
.disclaimer-title{font-size:13px;color:#fff;font-weight:700;white-space:nowrap;flex-shrink:0}
.disclaimer-text{font-size:12px;color:rgba(255,255,255,0.9);line-height:1.6}
/* Pay wall */
.article-pay-wall{text-align:center;padding:12px 0}
.pay-wall-card{background:#f8f9fa;border-radius:16px;padding:20px 20px 20px;box-shadow:0 2px 16px rgba(0,0,0,0.06)}
.pay-wall-lock{display:flex;justify-content:center;margin-bottom:10px}
.pay-wall-title{font-size:20px;font-weight:700;color:#1a1a1a;margin:0 0 10px}
.pay-wall-desc{font-size:14px;color:#999;margin:0 0 14px;line-height:1.5}
.pay-wall-btn{display:inline-block;background:linear-gradient(135deg,#dc2626,#e63946);color:#fff;border:none;padding:14px 36px;border-radius:26px;font-size:16px;font-weight:700;cursor:pointer;box-shadow:0 4px 14px rgba(220,38,38,0.25)}
.pay-wall-btn:active{opacity:0.9;transform:scale(0.97)}
.pay-wall-card .pay-preview{padding:12px 16px;background:#fff;border:1px solid #e5e5e5;border-radius:10px;margin:0 0 14px;color:#888;font-size:13px;line-height:1.8;text-align:left;word-break:break-all}
.pay-wall-card .pay-preview span{color:#bbb}
.article-preview-box{padding:14px 16px;background:#f9f9f9;border-radius:8px;margin-top:12px;color:#888;font-size:13px;line-height:1.7}
/* Content update logs */
.content-log-area{padding:0}
.content-log-section{margin-bottom:20px}
.content-log-header{font-size:15px;font-weight:700;color:#dc2626;margin-bottom:12px;padding-left:10px;border-left:3px solid #dc2626}
.content-log-item{padding:12px 0;border-bottom:1px solid #f5f5f5}
.content-log-item:last-child{border-bottom:none}
.content-log-time{font-size:11px;color:#bbb}
.content-log-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.content-log-issue{font-size:13px;font-weight:700;color:#f59e0b;background:#fffbeb;padding:3px 10px;border-radius:12px}
.content-log-text{font-size:15px;line-height:1.9;color:#333;word-break:break-word}

/* ====== Detail Tabs ====== */
.detail-tabs{display:flex;align-items:center;gap:0;margin:0 16px 0;padding:10px 0;border-bottom:1px solid #eee}
.detail-tab{flex:1;text-align:center;padding:8px 0;font-size:15px;font-weight:600;color:#999;cursor:pointer;position:relative}
.detail-tab.active{color:#dc2626}
.detail-tab.active::after{content:'';position:absolute;bottom:-1px;left:50%;transform:translateX(-50%);width:32px;height:3px;background:#dc2626;border-radius:2px}
.detail-tab-sep{width:1px;height:16px;background:#e5e5e5;flex-shrink:0}
/* History list */
.history-list{padding:0}
.history-issue-card{position:relative;padding:14px;margin-bottom:10px;background:#fff;border:1px solid #eee;border-radius:12px;cursor:pointer}
.history-issue-card:active{background:#fafafa}
.hi-title{font-size:15px;font-weight:700;color:#1a1a1a;line-height:1.4;margin-bottom:8px;padding-right:36px}
.hi-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.hi-detail-link{font-size:12px;color:#999}
.hi-time{font-size:11px;color:#bbb}
.hi-content-preview{font-size:13px;color:#555;line-height:1.6;word-break:break-all}
.hi-content-full{font-size:14px;color:#333;line-height:1.9;word-break:break-word;padding:12px 14px;background:#fdf6f6;border-radius:8px;margin-top:4px}
.hi-content-full img{max-width:100%;height:auto;border-radius:6px}
.hi-locked-state{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;background:#f8f9fa;border-radius:8px;margin-top:4px}
.hi-lock-icon{font-size:18px}
.hi-lock-price{font-size:13px;color:#999;font-weight:500}
.hi-rb-badge{position:absolute;top:10px;right:10px;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;border:2px solid}
.hi-rb-badge.red{background:#dc2626;border-color:#dc2626}
.hi-rb-badge.black{background:#333;border-color:#333}
.history-issue-empty{text-align:center;padding:24px;color:#ccc;font-size:13px}

/* ====== Toast ====== */
.toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:rgba(0,0,0,0.78);color:var(--white);padding:10px 22px;border-radius:20px;font-size:14px;z-index:300;opacity:0;transition:opacity 0.25s;pointer-events:none;max-width:80%;text-align:center}
.toast.show{opacity:1}

/* ====== Login Page ====== */
.login-tab-btn{transition:all 0.2s}

/* ====== Blue Publish Form (作者发布/修改文章) ====== */
.pub-blue-page{background:#f5f6fa;min-height:100vh}
.pub-blue-header{background:#3465D9;padding:14px 16px;display:flex;align-items:center;color:#fff}
.pub-blue-back{font-size:20px;cursor:pointer;width:30px;flex-shrink:0;line-height:1}
.pub-blue-title{font-size:17px;font-weight:600;flex:1;text-align:center}
.pub-blue-placeholder{width:30px;flex-shrink:0}
.pub-blue-form{padding:14px}
.pub-blue-field{margin-bottom:14px}
.pub-blue-label{font-size:14px;font-weight:600;color:#333;margin-bottom:6px;display:block}
.pub-blue-label .hint{font-weight:400;font-size:11px;color:#999}
.pub-blue-input{width:100%;padding:11px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;box-sizing:border-box;background:#fff}
.pub-blue-input:focus{outline:none;border-color:#3465D9}
.pub-blue-select{width:100%;padding:11px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;box-sizing:border-box;appearance:none;-webkit-appearance:none;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") no-repeat right 12px center;padding-right:36px}
.pub-blue-textarea{width:100%;padding:11px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;box-sizing:border-box;resize:vertical;background:#fff;min-height:120px;font-family:inherit;line-height:1.6}
.pub-blue-textarea:focus{outline:none;border-color:#3465D9}
.pub-blue-section-title{font-size:15px;font-weight:700;color:#333;padding:6px 0 10px;border-top:1px solid #eee;margin-top:8px}
.pub-upload-row{display:flex;gap:10px}
.pub-upload-btn{width:60px;height:60px;border:1px dashed #ccc;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;background:#fff;font-size:20px;color:#999}
.pub-upload-btn span{font-size:10px;margin-top:2px;color:#999}
.pub-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid #f0f0f0}
.pub-toggle-label{font-size:14px;color:#333}
.pub-toggle-hint{font-size:12px;color:#999;margin-top:2px}
.pub-toggle-switch{width:48px;height:28px;border-radius:14px;background:#ddd;position:relative;cursor:pointer;transition:background 0.2s;flex-shrink:0}
.pub-toggle-switch.on{background:#3465D9}
.pub-toggle-switch::after{content:'';position:absolute;top:2px;left:2px;width:24px;height:24px;border-radius:50%;background:#fff;transition:left 0.2s;box-shadow:0 1px 3px rgba(0,0,0,0.2)}
.pub-toggle-switch.on::after{left:22px}
.pub-blue-submit{background:#3465D9;color:#fff;border:none;width:100%;padding:14px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;margin-top:12px}
.pub-blue-submit:active{opacity:0.9}
.pub-blue-submit:disabled{opacity:0.6}
.batch-add-btn{background:#e8f0fe;color:#2979ff;border:1px dashed #2979ff;width:100%;padding:10px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer}
.batch-add-btn:active{background:#d0e2ff}
.batch-slot-del{line-height:1}
.batch-slot-del:active{opacity:0.5}

/* ====== Author Center 我的 Tab ====== */
.ac-header{background:linear-gradient(135deg,#dc2626,#ef4444);padding:14px 16px;display:flex;align-items:center;color:#fff}
.ac-header-title{font-size:18px;font-weight:700;flex:1;text-align:left}
.ac-header-right{font-size:13px;cursor:pointer;flex-shrink:0;opacity:0.9}
.ac-version{text-align:center;padding:16px;font-size:11px;color:#bbb}

/* ====== Author Center v2 作者中心 ====== */
.ac-user-card-v2{background:linear-gradient(135deg,#dc2626,#ef4444);padding:8px 16px 16px;display:flex;align-items:center;color:#fff}
.ac-avatar-v2{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,0.2);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;font-weight:700}
.ac-user-info-v2{flex:1;margin-left:12px}
.ac-user-name-v2{font-size:16px;font-weight:700}
.ac-user-sub-v2{font-size:12px;opacity:0.9;margin-top:2px}
.ac-share-btn{color:#fff;flex-shrink:0}
.ac-summary-row{display:flex;gap:10px;padding:12px 16px 0}
.ac-summary-item{flex:1;display:flex;align-items:center;background:#fff;border-radius:10px;padding:14px 12px;box-shadow:0 2px 8px rgba(0,0,0,0.06);cursor:pointer;position:relative;top:-8px}
.ac-summary-item:active{background:#f9f9f9}
.ac-summary-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.ac-summary-info{flex:1;margin-left:10px;display:flex;flex-direction:column}
.ac-summary-label{font-size:11px;color:#999}
.ac-summary-val{font-size:16px;font-weight:700;color:#333;margin-top:2px}
.ac-summary-arrow{color:#ccc;font-size:16px;flex-shrink:0}
.ac-apply-entry{display:flex;align-items:center;background:#fff;margin:0 16px 12px;border-radius:10px;padding:14px 16px;box-shadow:0 2px 8px rgba(0,0,0,0.04);cursor:pointer;font-size:14px;color:#333}
.ac-apply-entry:active{background:#f9f9f9}
.ac-apply-label{flex:1;margin-left:8px;font-size:14px;color:#333}
.ac-apply-count{color:#999;font-size:14px;margin-right:4px}
.ac-apply-arrow{color:#999;font-size:14px}
.ac-apply-header{display:flex;align-items:center;padding:16px;background:#fff;border-bottom:1px solid #E0E0E0;position:sticky;top:0;z-index:10}
.ac-apply-back{font-size:18px;color:#666;cursor:pointer;margin-right:12px}
.ac-apply-title{font-size:17px;font-weight:600;color:#333;flex:1}
.ac-apply-empty{text-align:center;padding:48px 20px;color:#ccc;font-size:14px}
.ac-apply-list{padding:0 16px}
.ac-apply-card{background:#fff;border-radius:8px;padding:14px 16px;margin-top:10px;box-shadow:0 1px 3px rgba(0,0,0,0.05)}
.ac-section{background:#fff;margin:0 16px 10px;border-radius:8px;padding:16px 24px;box-shadow:0 1px 3px rgba(0,0,0,0.06);border:1px solid #E5E5E5}
.ac-section-title{font-size:16px;font-weight:500;color:#333;display:flex;align-items:center;margin-bottom:16px}
.ac-section-bar{display:inline-block;width:2px;height:18px;background:#007AFF;border-radius:2px;margin-right:8px;flex-shrink:0}
.ac-figure-row{display:flex;justify-content:space-around}
.ac-figure-item{text-align:center;flex:1}
.ac-figure-val{font-size:24px;font-weight:700;color:#FF6B00;display:block}
.ac-figure-label{font-size:12px;color:#999;margin-top:4px;display:block}
.ac-grid-3col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;padding:12px 16px}
.ac-grid3-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px 8px;background:#fff;border-radius:10px;cursor:pointer;box-shadow:0 1px 3px rgba(0,0,0,0.04);gap:8px}
.ac-grid3-item:active{background:#f9f9f9}
.ac-grid3-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px}
.ac-grid3-label{font-size:12px;color:#333;text-align:center}

/* ====== Promotion Pages ====== */
.promo-topbar{background:#fff;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #f0f0f0}
.promo-topbar-left{display:flex;align-items:center;gap:8px}
.promo-topbar-logo{width:28px;height:28px;border-radius:50%;border:2px solid #dc2626}
.promo-topbar-name{font-size:15px;font-weight:700;color:#333}
.promo-topbar-rate{font-size:14px;color:#dc2626;font-weight:600}
.promo-topbar-rate b{font-size:18px}
.promo-poster{margin:16px;background:linear-gradient(180deg,#c62828,#8e0000);border-radius:16px;padding:24px 20px 28px;border:2px solid #d4a017;box-shadow:0 4px 20px rgba(0,0,0,0.2);text-align:center}
.promo-poster-title{display:inline-block;border:2px solid #d4a017;border-radius:6px;padding:6px 20px;color:#ffd700;font-size:22px;font-weight:700;letter-spacing:4px}
.promo-poster-sub{color:#ffd700;font-size:20px;font-weight:700;letter-spacing:2px;margin:16px 0 20px}
.promo-qr-wrap{width:180px;height:180px;background:#fff;margin:0 auto 20px;border-radius:8px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 12px rgba(0,0,0,0.3)}
.promo-qr-placeholder{text-align:center;color:#ccc;font-size:11px}
.promo-save-btn{background:#dc2626;color:#fff;border:none;width:100%;padding:14px;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;margin:0 16px 12px}
.promo-save-btn:active{opacity:0.9}
.promo-stats{display:flex;justify-content:space-around;padding:0 16px 16px;gap:8px}
.promo-stat-card{flex:1;background:#fff;border-radius:10px;padding:12px 8px;text-align:center;box-shadow:0 1px 3px rgba(0,0,0,0.05)}
.promo-stat-val{font-size:20px;font-weight:700}
.promo-stat-label{font-size:11px;color:#999;margin-top:2px}
.promo-actions{display:flex;gap:8px;padding:0 16px 16px}
.promo-action-btn{flex:1;background:#fff;color:#333;border:1px solid #ddd;padding:11px 4px;border-radius:8px;font-size:13px;cursor:pointer;text-align:center}
.promo-action-btn:active{background:#fafafa}
.promo-action-btn.primary{background:#f59e0b;color:#fff;border:none;font-weight:600}
.promo-mgmt{padding:0 16px 16px}
.promo-mgmt-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.promo-mgmt-title{font-size:14px;font-weight:700;color:#333}
.promo-mgmt-count{font-size:11px;color:#999}
.promo-mgmt-list{background:#fff;border-radius:10px;box-shadow:0 1px 3px rgba(0,0,0,0.06);overflow:hidden}
.promoter-mgmt-row{display:flex;align-items:center;padding:12px 14px;border-bottom:1px solid #f5f5f5;gap:8px}
.promoter-mgmt-row:last-child{border-bottom:none}
.promoter-mgmt-info{flex:1;min-width:0}
.promoter-mgmt-name{font-size:14px;font-weight:600;color:#333}
.promoter-mgmt-stat{font-size:11px;color:#999;margin-top:2px}
.promoter-mgmt-remark{font-size:11px;color:#f59e0b;margin-top:2px}
.promoter-mgmt-btns{display:flex;gap:6px;flex-shrink:0}
.promoter-mgmt-btn{background:#fff;border:1px solid #ddd;padding:6px 10px;border-radius:14px;font-size:11px;cursor:pointer;white-space:nowrap;flex-shrink:0}
.promoter-mgmt-btn.rate-btn{color:#dc2626;border-color:#dc2626}
.promoter-mgmt-btn.remark-btn{color:#f59e0b;border-color:#f59e0b}
.promoter-mgmt-btn:active{opacity:0.7}
.promoter-apply-row{display:flex;align-items:center;padding:12px 14px;border-bottom:1px solid #f5f5f5;gap:8px}
.promoter-apply-row:last-child{border-bottom:none}
.promoter-apply-info{flex:1;min-width:0}
.promoter-apply-name{font-size:14px;font-weight:600;color:#333}
.promoter-apply-time{font-size:11px;color:#999;margin-top:2px}
.promoter-apply-btns{display:flex;gap:6px;flex-shrink:0}
.promoter-apply-btn{background:#fff;border:1px solid #ddd;padding:6px 12px;border-radius:14px;font-size:11px;cursor:pointer;white-space:nowrap;flex-shrink:0}
.promoter-apply-btn.accept-btn{color:#22c55e;border-color:#22c55e}
.promoter-apply-btn.reject-btn{color:#dc2626;border-color:#dc2626}
.promoter-apply-btn.delete-btn{color:#999;border-color:#ddd}
.promoter-apply-btn:active{opacity:0.7}
.promoter-apply-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;flex-shrink:0;background:#f0f0f0;display:flex;align-items:center;justify-content:center;color:#999;font-size:15px;font-weight:600}
.promoter-apply-initials{text-transform:uppercase;color:#666;font-size:15px;font-weight:600}

/* ====== Invite Pages ====== */
.invite-container{padding:24px;text-align:center}
.invite-icon{font-size:48px}
.invite-title{color:#333;margin:12px 0 6px;font-size:18px}
.invite-desc{color:#666;font-size:13px;line-height:1.6;margin-bottom:16px}
.invite-code-box{background:#fef2f2;border:1px dashed #fca5a5;border-radius:10px;padding:16px;margin-bottom:16px}
.invite-code-label{font-size:12px;color:#999;margin-bottom:6px}
.invite-code-val{font-size:28px;font-weight:700;color:#dc2626;letter-spacing:6px}
.invite-btns{display:flex;gap:10px}
.invite-btn{flex:1;padding:10px;border-radius:8px;font-size:14px;cursor:pointer}
.invite-btn.primary{background:#dc2626;color:#fff;border:none}
.invite-btn.outline{background:#fff;color:#dc2626;border:1px solid #dc2626}
.invite-btn:active{opacity:0.85}
.invite-stats{margin-top:20px;background:#fff;border-radius:10px;padding:14px;box-shadow:0 1px 3px rgba(0,0,0,0.06)}
.invite-stats-label{font-size:12px;color:#999;margin-bottom:8px}
.invite-stats-row{display:flex;justify-content:space-around}
.invite-stat-num{font-size:22px;font-weight:700}

/* ====== Invite Team List ====== */
.invite-team-item{display:flex;align-items:center;padding:12px;border-bottom:1px solid #f5f5f5}
.invite-team-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;flex-shrink:0}
.invite-team-info{flex:1;margin-left:10px}
.invite-team-name{font-weight:600;font-size:14px;color:#333}
.invite-team-date{font-size:12px;color:#999}

/* ====== Invite Earnings List ====== */
.invite-earn-item{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #f5f5f5;background:#fff}
.invite-earn-left{flex:1}
.invite-earn-title{font-size:14px;color:#333;font-weight:600;margin-bottom:4px}
.invite-earn-time{font-size:11px;color:#bbb}
.invite-earn-amount{font-size:16px;font-weight:700;color:#dc2626;white-space:nowrap}
.invite-earn-total{text-align:center;padding:16px;font-size:13px;color:#666;background:#fafafa;border-top:1px solid #f0f0f0}

/* ====== Article Edit Form ====== */
.ac-edit-form{padding:0 16px 20px}
.ac-edit-back{font-size:18px;cursor:pointer;flex-shrink:0}
.ac-edit-row{display:flex;align-items:center;padding:12px 0;border-bottom:1px solid #f5f5f5;gap:10px;flex-wrap:wrap}
.ac-edit-label{font-size:14px;color:#333;flex-shrink:0;min-width:70px}
.ac-edit-value{flex:1;position:relative}
.ac-edit-select{width:100%;padding:8px 24px 8px 8px;border:1px solid #e5e5e5;border-radius:6px;font-size:14px;color:#333;background:#fff;appearance:none;-webkit-appearance:none;outline:none}
.ac-edit-arrow{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:10px;color:#999;pointer-events:none}
.ac-edit-input{flex:1;padding:8px;border:1px solid #e5e5e5;border-radius:6px;font-size:14px;color:#333;outline:none}
.ac-edit-input:focus,.ac-edit-select:focus{border-color:var(--primary)}
.ac-edit-section{font-size:15px;font-weight:700;color:#333;padding:14px 0 8px}
.ac-edit-textarea{width:100%;min-height:120px;padding:10px;border:1px solid #e5e5e5;border-radius:8px;font-size:14px;color:#333;resize:vertical;outline:none;box-sizing:border-box}
.ac-edit-textarea:focus{border-color:var(--primary)}
.ac-edit-prev-btn{background:#f97316;color:#fff;border:none;padding:6px 14px;border-radius:16px;font-size:12px;cursor:pointer;flex-shrink:0;margin-top:8px}
.ac-edit-prev-btn:active{opacity:.8}

/* Toggle rows */
.ac-edit-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid #f5f5f5}
.ac-edit-toggle-label{font-size:14px;color:#333}
.ac-edit-toggle-hint{font-size:11px;color:#999;margin-top:2px}

/* Toggle switch */
.ac-toggle{width:48px;height:28px;border-radius:14px;background:#e5e5e5;cursor:pointer;position:relative;transition:background .2s;flex-shrink:0}
.ac-toggle.on{background:#3b82f6}
.ac-toggle-knob{width:22px;height:22px;border-radius:50%;background:#fff;position:absolute;top:3px;left:3px;transition:left .2s;box-shadow:0 1px 3px rgba(0,0,0,0.2)}
.ac-toggle.on .ac-toggle-knob{left:23px}

/* Red/Black radio */
.ac-edit-radio{display:flex;gap:6px}
.ac-edit-radio-item{padding:6px 16px;border-radius:16px;font-size:13px;color:#999;border:1px solid #e5e5e5;cursor:pointer;background:#fff}
.ac-edit-radio-item.active{border-color:var(--primary);color:var(--primary);background:#fff3f3}
.ac-edit-radio-item.red.active{border-color:#dc2626;color:#dc2626;background:#fee2e2}
.ac-edit-radio-item.black.active{border-color:#666;color:#666;background:#f0f0f0}
/* Red/Black header dots */
.ac-edit-rb-header{display:flex;gap:6px;align-items:center}
.ac-edit-rb-dot{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;border:2px solid transparent;color:#ccc;transition:all 0.15s}
.ac-edit-rb-dot:hover{transform:scale(1.15)}
.ac-edit-rb-dot.active{color:#999;border-color:#999}
.ac-edit-rb-dot.red{color:#ef4444}
.ac-edit-rb-dot.red.active{color:#dc2626;border-color:#dc2626;box-shadow:0 0 6px rgba(220,38,38,0.4)}
.ac-edit-rb-dot.black{color:#666}
.ac-edit-rb-dot.black.active{color:#111;border-color:#333;box-shadow:0 0 6px rgba(0,0,0,0.3)}

/* Bottom button row */
.ac-edit-btn-row{display:flex;gap:10px;padding:16px 0;margin-top:8px}
.ac-edit-btn{flex:1;padding:12px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;color:#fff}
.ac-edit-btn.delete{background:#dc2626}
.ac-edit-btn.modify{background:#3b82f6}
.ac-edit-btn.back{background:#f97316}
.ac-edit-btn:active{opacity:.85}

/* ====== Article Card List (Author Tab) ====== */
.ac-article-card{background:#fff;border-radius:10px;padding:12px 14px;margin:8px 12px;box-shadow:0 1px 4px rgba(0,0,0,0.05);overflow:hidden}
.ac-article-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px;gap:8px}
.ac-article-title{flex:1;font-size:14px;font-weight:600;color:#222;line-height:1.4;min-width:0;word-break:break-all;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.ac-article-price{font-size:15px;font-weight:700;color:#f97316;flex-shrink:0;margin-left:8px;white-space:nowrap}
.ac-article-meta{display:flex;flex-wrap:wrap;align-items:center;gap:4px 8px;font-size:11px;color:#999;margin-bottom:10px}
.ac-article-meta b{color:#333;font-weight:600}
.ac-article-status{font-size:10px;padding:1px 6px;border-radius:8px;flex-shrink:0}
.ac-article-status.approved{background:#e8f5e9;color:#2e7d32}
.ac-article-status.pending{background:#fff3e0;color:#e65100}
.ac-article-status.rejected{background:#fee2e2;color:#b71c1c}
.ac-article-time{white-space:nowrap}
.ac-article-sold{color:#3b82f6;white-space:nowrap}
.ac-article-sold b{color:#3b82f6}
.ac-article-views{color:#dc2626;white-space:nowrap}
.ac-article-views b{color:#dc2626}
.ac-article-heat{white-space:nowrap}
.ac-article-rank{color:#3b82f6}
.ac-article-btn-row{display:flex;gap:4px}
.ac-article-btn{flex:1;min-width:0;padding:7px 2px;border:1px solid #ddd;border-radius:6px;font-size:11px;color:#666;background:#fff;cursor:pointer;text-align:center;white-space:nowrap}
.ac-article-btn:active{background:#f5f5f5}
.ac-article-btn-off{background:#f97316;color:#fff;border-color:#f97316;font-weight:600}
.ac-article-btn-off:active{background:#e06512}

/* ====== Article Management 文章 Tab ====== */
.am-tabs{display:flex;background:#fff;padding:0;border-bottom:1px solid #f0f0f0}
.am-tab{flex:1;text-align:center;padding:12px 6px;font-size:13px;color:#666;cursor:pointer;position:relative;font-weight:500}
.am-tab.active{color:var(--primary);font-weight:700}
.am-tab.active::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:24px;height:3px;background:var(--primary);border-radius:2px}
.am-tab-count{font-size:10px;background:#f0f0f0;padding:1px 6px;border-radius:8px;margin-left:2px;color:#999}
.am-tab.active .am-tab-count{background:#fff3f3;color:var(--primary)}
.am-search-bar{display:flex;align-items:center;margin:10px 16px;padding:8px 12px;background:#f5f5f5;border-radius:20px;overflow:hidden}
.am-search-icon{font-size:16px;color:#999;margin-right:8px;flex-shrink:0}
.am-search-input{border:none;background:transparent;font-size:14px;flex:1;min-width:0;outline:none;color:#333}
.am-search-btn{background:var(--primary);color:#fff;border:none;padding:6px 14px;border-radius:16px;font-size:12px;cursor:pointer;flex-shrink:0;margin-left:8px;white-space:nowrap}
.am-empty{text-align:center;padding:60px 20px;color:#999}
.am-empty-icon{font-size:48px;color:#d5c4e0;margin-bottom:10px}
.am-empty-text{font-size:14px;color:#999}

/* ====== Batch Script Publish ====== */
.batch-script-textarea{tab-size:2}
.batch-script-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(220,38,38,0.08)}
#batchScriptPreview{background:#fafafa;border-radius:8px;padding:4px 0}

/* ================================================================ */
/*  ADMIN DESIGN SYSTEM — clean, professional, card-based           */
/* ================================================================ */

/* --- Admin shell --- */
.admin-page{background:#f0f2f5;min-height:100vh;padding-bottom:80px}
.admin-header{background:linear-gradient(135deg,#1a1a2e,#16213e);padding:16px;display:flex;align-items:center;position:sticky;top:0;z-index:50;box-shadow:0 2px 8px rgba(0,0,0,0.15)}
.admin-header-back{color:rgba(255,255,255,0.7);font-size:18px;cursor:pointer;width:32px;flex-shrink:0;line-height:1}
.admin-header-title{color:#fff;font-size:17px;font-weight:600;flex:1;text-align:center;letter-spacing:0.5px}
.admin-header-action{color:rgba(255,255,255,0.7);font-size:13px;cursor:pointer;width:32px;text-align:right;flex-shrink:0}
.admin-content{padding:12px 16px}

/* --- Dashboard --- */
.admin-welcome{background:linear-gradient(135deg,#1a1a2e,#16213e);padding:20px 16px 24px;color:#fff}
.admin-welcome-row{display:flex;align-items:center;gap:12px}
.admin-welcome-avatar{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,0.12);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.admin-welcome-info{flex:1}
.admin-welcome-name{font-size:16px;font-weight:700}
.admin-welcome-role{font-size:12px;opacity:0.7;margin-top:2px}
.admin-welcome-badge{background:rgba(220,38,38,0.25);color:#ff6b6b;font-size:11px;padding:3px 10px;border-radius:12px;font-weight:600}

/* Stat row */
.admin-stat-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 16px;margin-top:-8px}
.admin-stat-card{background:#fff;border-radius:12px;padding:16px 14px;box-shadow:0 2px 12px rgba(0,0,0,0.06);display:flex;align-items:center;gap:12px;cursor:pointer;transition:transform 0.15s,box-shadow 0.15s}
.admin-stat-card:active{transform:scale(0.97);box-shadow:0 1px 6px rgba(0,0,0,0.08)}
.admin-stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.admin-stat-icon.blue{background:#eff6ff;color:#3b82f6}
.admin-stat-icon.green{background:#f0fdf4;color:#22c55e}
.admin-stat-icon.orange{background:#fff7ed;color:#f97316}
.admin-stat-icon.red{background:#fef2f2;color:#ef4444}
.admin-stat-icon.purple{background:#faf5ff;color:#a855f7}
.admin-stat-icon.indigo{background:#eef2ff;color:#6366f1}
.admin-stat-info{flex:1;min-width:0}
.admin-stat-val{font-size:22px;font-weight:700;color:#1a1a2e;line-height:1.2;letter-spacing:-0.5px}
.admin-stat-label{font-size:11px;color:#999;margin-top:2px}

/* Menu sections */
.admin-section{margin:0 16px 12px}
.admin-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;padding:0 4px}
.admin-section-title{font-size:13px;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:0.5px}
.admin-menu-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,0.04)}
.admin-menu-item{display:flex;align-items:center;padding:14px 16px;cursor:pointer;border-bottom:1px solid #f5f5f5;transition:background 0.15s;gap:12px}
.admin-menu-item:last-child{border-bottom:none}
.admin-menu-item:active{background:#f9fafb}
.admin-menu-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.admin-menu-info{flex:1;min-width:0}
.admin-menu-label{font-size:14px;font-weight:600;color:#1f2937}
.admin-menu-desc{font-size:11px;color:#9ca3af;margin-top:1px}
.admin-menu-arrow{color:#d1d5db;font-size:16px;flex-shrink:0}
.admin-menu-badge{background:#fef2f2;color:#ef4444;font-size:10px;min-width:20px;height:20px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;margin-left:6px;font-weight:700;padding:0 6px}

/* Menu icon colors */
.admin-menu-icon.red{background:#fef2f2;color:#ef4444}
.admin-menu-icon.blue{background:#eff6ff;color:#3b82f6}
.admin-menu-icon.green{background:#f0fdf4;color:#22c55e}
.admin-menu-icon.orange{background:#fff7ed;color:#f97316}
.admin-menu-icon.purple{background:#faf5ff;color:#a855f7}
.admin-menu-icon.indigo{background:#eef2ff;color:#6366f1}
.admin-menu-icon.gray{background:#f3f4f6;color:#6b7280}
.admin-menu-icon.teal{background:#f0fdfa;color:#14b8a6}

/* --- Filter / Tab bar --- */
.admin-tabs{display:flex;background:#fff;border-bottom:1px solid #f0f0f0;overflow-x:auto;-webkit-overflow-scrolling:touch}
.admin-tabs::-webkit-scrollbar{display:none}
.admin-tab{flex-shrink:0;padding:12px 16px;font-size:13px;color:#6b7280;cursor:pointer;font-weight:500;position:relative;white-space:nowrap;transition:color 0.2s}
.admin-tab.active{color:#1a1a2e;font-weight:700}
.admin-tab.active::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:20px;height:3px;background:#1a1a2e;border-radius:2px}
.admin-tab .badge{background:#ef4444;color:#fff;font-size:10px;min-width:18px;height:18px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;margin-left:4px;padding:0 5px;font-weight:700}

/* Sub tabs (lighter) */
.admin-subtabs{display:flex;background:#f9fafb;border-bottom:1px solid #f0f0f0;padding:0 16px;gap:4px}
.admin-subtab{padding:8px 14px;font-size:12px;color:#9ca3af;cursor:pointer;border-radius:6px 6px 0 0;font-weight:500;transition:all 0.2s}
.admin-subtab.active{color:#1a1a2e;background:#fff;font-weight:600;box-shadow:0 -1px 4px rgba(0,0,0,0.04)}

/* --- Search bar --- */
.admin-search{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#fff}
.admin-search-input{flex:1;padding:9px 14px;border:1px solid #e5e7eb;border-radius:10px;font-size:13px;outline:none;background:#f9fafb;transition:border-color 0.2s}
.admin-search-input:focus{border-color:#6366f1;background:#fff}
.admin-search-btn{background:#1a1a2e;color:#fff;border:none;padding:9px 18px;border-radius:10px;font-size:13px;cursor:pointer;font-weight:600;white-space:nowrap}

/* --- List items --- */
.admin-list-item{display:flex;align-items:center;padding:14px 16px;background:#fff;border-bottom:1px solid #f5f5f5;cursor:pointer;gap:12px;transition:background 0.15s}
.admin-list-item:active{background:#f9fafb}
.admin-list-item:first-child{border-radius:12px 12px 0 0}
.admin-list-item:last-child{border-radius:0 0 12px 12px;border-bottom:none}
.admin-list-item:only-child{border-radius:12px}
.admin-list-avatar{width:40px;height:40px;border-radius:50%;background:#f3f4f6;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;overflow:hidden}
.admin-list-avatar img{width:100%;height:100%;object-fit:cover}
.admin-list-body{flex:1;min-width:0}
.admin-list-title{font-size:14px;font-weight:600;color:#1f2937;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.admin-list-sub{font-size:12px;color:#9ca3af;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.admin-list-right{text-align:right;flex-shrink:0}
.admin-list-value{font-size:16px;font-weight:700;color:#1f2937}
.admin-list-meta{font-size:11px;color:#9ca3af;margin-top:2px}

/* --- Cards --- */
.admin-card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 1px 4px rgba(0,0,0,0.04);margin-bottom:10px}
.admin-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.admin-card-title{font-size:15px;font-weight:700;color:#1f2937}
.admin-card-body{font-size:14px;color:#4b5563;line-height:1.6}

/* Review / Article cards */
.admin-article-card{background:#fff;border-radius:10px;padding:14px;margin:8px 16px;box-shadow:0 1px 4px rgba(0,0,0,0.04);border:1px solid #f3f4f6;cursor:pointer;transition:box-shadow 0.15s}
.admin-article-card:active{box-shadow:0 2px 8px rgba(0,0,0,0.08)}
.admin-article-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:6px;gap:8px}
.admin-article-title{flex:1;font-size:14px;font-weight:600;color:#1f2937;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.admin-article-badge{font-size:10px;padding:3px 8px;border-radius:10px;font-weight:600;flex-shrink:0;white-space:nowrap}
.admin-article-badge.pending{background:#fef3c7;color:#d97706}
.admin-article-badge.approved{background:#dcfce7;color:#16a34a}
.admin-article-badge.rejected{background:#fee2e2;color:#dc2626}
.admin-article-badge.offline{background:#f3f4f6;color:#6b7280}
.admin-article-meta{font-size:11px;color:#9ca3af;margin-bottom:8px;display:flex;flex-wrap:wrap;gap:4px 10px}
.admin-article-excerpt{font-size:12px;color:#6b7280;background:#f9fafb;padding:8px 10px;border-radius:6px;line-height:1.5;max-height:54px;overflow:hidden;margin-bottom:10px}
.admin-article-actions{display:flex;gap:6px}
.admin-article-actions button{flex:1;padding:7px 0;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;border:none;transition:opacity 0.15s}
.admin-article-actions button:active{opacity:0.85}

/* Action button variants */
.admin-btn{padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:opacity 0.15s}
.admin-btn:active{opacity:0.85}
.admin-btn-primary{background:#1a1a2e;color:#fff}
.admin-btn-danger{background:#ef4444;color:#fff}
.admin-btn-success{background:#22c55e;color:#fff}
.admin-btn-warning{background:#f59e0b;color:#fff}
.admin-btn-outline{background:#fff;color:#6b7280;border:1px solid #e5e7eb}
.admin-btn-outline-danger{background:#fff;color:#ef4444;border:1px solid #fecaca}
.admin-btn-block{width:100%;padding:12px;border-radius:10px;font-size:14px;font-weight:700;cursor:pointer;border:none;transition:opacity 0.15s}
.admin-btn-block:active{opacity:0.85}

/* --- Form card --- */
.admin-form-card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 1px 4px rgba(0,0,0,0.04);margin-bottom:12px}
.admin-form-title{font-size:15px;font-weight:700;color:#1f2937;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid #f3f4f6}
.admin-form-group{margin-bottom:14px}
.admin-form-group:last-child{margin-bottom:0}
.admin-form-label{display:block;font-size:13px;font-weight:600;color:#374151;margin-bottom:6px}
.admin-form-input{width:100%;padding:10px 12px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;box-sizing:border-box;background:#f9fafb;transition:border-color 0.2s;outline:none}
.admin-form-input:focus{border-color:#6366f1;background:#fff}
.admin-form-textarea{width:100%;padding:10px 12px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;box-sizing:border-box;resize:vertical;background:#f9fafb;min-height:80px;font-family:inherit;line-height:1.6;transition:border-color 0.2s;outline:none}
.admin-form-textarea:focus{border-color:#6366f1;background:#fff}
.admin-form-select{width:100%;padding:10px 12px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;box-sizing:border-box;background:#f9fafb;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;outline:none}
.admin-form-select:focus{border-color:#6366f1;background:#fff}

/* --- Detail rows --- */
.admin-detail-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #f5f5f5}
.admin-detail-row:last-child{border-bottom:none}
.admin-detail-label{font-size:13px;color:#6b7280}
.admin-detail-value{font-size:13px;font-weight:600;color:#1f2937;text-align:right}
.admin-detail-value.price{font-size:18px;color:#ef4444}

/* --- Badges --- */
.admin-badge{display:inline-block;font-size:10px;padding:2px 8px;border-radius:10px;font-weight:600}
.admin-badge.success{background:#dcfce7;color:#16a34a}
.admin-badge.warning{background:#fef3c7;color:#d97706}
.admin-badge.danger{background:#fee2e2;color:#dc2626}
.admin-badge.info{background:#dbeafe;color:#2563eb}
.admin-badge.neutral{background:#f3f4f6;color:#6b7280}

/* --- Empty state --- */
.admin-empty{text-align:center;padding:48px 20px}
.admin-empty-icon{font-size:40px;color:#d1d5db;margin-bottom:12px;display:block}
.admin-empty-text{font-size:14px;color:#9ca3af;display:block}
.admin-empty-sub{font-size:12px;color:#d1d5db;margin-top:4px;display:block}

/* --- Toast override for admin --- */
.admin-toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:rgba(26,26,46,0.9);color:#fff;padding:10px 24px;border-radius:10px;font-size:14px;z-index:300;opacity:0;transition:opacity 0.25s;pointer-events:none;max-width:80%;text-align:center}
.admin-toast.show{opacity:1}

/* --- Pagination --- */
.admin-pagination{display:flex;justify-content:center;gap:6px;padding:16px}
.admin-page-btn{width:34px;height:34px;border-radius:50%;border:1px solid #e5e7eb;background:#fff;color:#6b7280;font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-weight:600;transition:all 0.15s}
.admin-page-btn.active{background:#1a1a2e;color:#fff;border-color:#1a1a2e}
.admin-page-btn:active{background:#f3f4f6}

/* --- Batch action bar --- */
.admin-batch-bar{position:fixed;bottom:60px;left:50%;transform:translateX(-50%);width:calc(100% - 32px);max-width:448px;background:#1a1a2e;padding:12px 16px;border-radius:14px;box-shadow:0 4px 20px rgba(0,0,0,0.25);display:none;z-index:90}
.admin-batch-bar-inner{display:flex;gap:8px;align-items:center}
.admin-batch-count{color:#fff;font-size:13px;font-weight:600;white-space:nowrap}
.admin-batch-btn{flex:1;padding:10px 0;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:opacity 0.15s}
.admin-batch-btn:active{opacity:0.85}
.admin-batch-btn.danger{background:#ef4444;color:#fff}
.admin-batch-btn.success{background:#22c55e;color:#fff}

/* --- Checkbox --- */
.admin-checkbox{width:18px;height:18px;accent-color:#1a1a2e;cursor:pointer;flex-shrink:0}

/* --- Count bar --- */
.admin-count-bar{padding:8px 16px;font-size:12px;color:#9ca3af;display:flex;align-items:center;justify-content:space-between}

/* --- Info grid (user detail stats) --- */
.admin-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.admin-info-item{text-align:center;padding:14px 10px;background:#f9fafb;border-radius:10px}
.admin-info-num{font-size:22px;font-weight:700;color:#1f2937;display:block;line-height:1.2}
.admin-info-label{font-size:11px;color:#9ca3af;margin-top:4px;display:block}

/* --- Full-width variant (no page padding) --- */
.admin-page-flush{background:#f0f2f5;min-height:100vh;padding-bottom:80px}
.admin-page-flush .admin-content{padding:12px 0}

/* ====== Image Lightbox ====== */
.image-lightbox-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.92);z-index:9999;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s}
.image-lightbox-close{position:absolute;top:16px;right:20px;color:#fff;font-size:36px;cursor:pointer;z-index:10;line-height:1;width:44px;height:44px;display:flex;align-items:center;justify-content:center}
.image-lightbox-img{max-width:95vw;max-height:85vh;border-radius:8px;box-shadow:0 8px 40px rgba(0,0,0,0.5);-webkit-user-select:none;user-select:none}
.content-image{transition:transform .2s,box-shadow .2s}
.content-image:active{transform:scale(0.97);box-shadow:0 4px 16px rgba(0,0,0,0.12)}

@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ====== Utility Classes (extracted from repeated inline styles) ====== */
.btn-primary{background:var(--primary);color:#fff;border:none;width:100%;padding:12px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;display:block;text-align:center}
.btn-primary:active{opacity:0.85}
.btn-primary-sm{background:var(--primary);color:#fff;border:none;padding:6px 14px;border-radius:16px;font-size:12px;font-weight:600;cursor:pointer}
.btn-primary-sm:active{opacity:0.85}
.btn-secondary{background:#f5f5f5;color:#666;border:1px solid #e0e0e0;padding:6px 16px;border-radius:16px;font-size:12px;cursor:pointer}
.btn-secondary:active{background:#e8e8e8}
.btn-block{display:block;width:100%}
.section-padded{padding:16px}
.card-white{background:#fff;border-radius:10px;padding:16px;box-shadow:0 1px 4px rgba(0,0,0,0.06)}
.page-centered{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.page-gradient{min-height:100vh;background:linear-gradient(180deg,#fff 0%,#fff5f5 100%)}
.form-input-full{width:100%;box-sizing:border-box}
