*{margin:0;padding:0;box-sizing:border-box}
:root{--primary:#0066ff;--primary-dark:#0052cc;--primary-light:#3385ff;--primary-glow:rgba(0,102,255,0.3);--success:#00c853;--success-light:#69f0ae;--bg:#f0f4f8;--card:#fff;--border:#e1e8ed;--text:#1a1a2e;--text-secondary:#5c6370;--text-muted:#9ca3af;--shadow-sm:0 2px 8px rgba(0,102,255,0.08);--shadow-md:0 4px 16px rgba(0,102,255,0.12);--shadow-lg:0 8px 32px rgba(0,102,255,0.16);--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px}
body{font-family:-apple-system,BlinkMacSystemFont,"PingFang SC","Microsoft YaHei",sans-serif;background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;min-height:100dvh}
body::before{content:'';position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#f0f4f8,#e8eef5);z-index:-1}
#app{min-height:100vh;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}
.container{max-width:1200px;margin:0 auto;padding:0 12px}
header{background:linear-gradient(135deg,#0066ff,#0052cc,#003380);color:#fff;padding:20px;border-radius:0;margin-bottom:16px;box-shadow:0 4px 20px rgba(0,102,255,0.25);position:relative;overflow:hidden}
header::before{content:'';position:absolute;top:-50%;right:-20%;width:60%;height:200%;background:radial-gradient(ellipse,rgba(255,255,255,0.1) 0%,transparent 70%);pointer-events:none}
.notice-bar{background:#fff3cd;color:#856404;padding:10px 24px;font-size:14px;border-bottom:1px solid #ffeeba;display:flex;align-items:center;justify-content:center;position:sticky;top:0;z-index:100}
h1{font-size:20px;margin-bottom:12px;font-weight:600;letter-spacing:-0.02em}
.controls{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.search-box{flex:1;min-width:180px;background:rgba(255,255,255,0.15);backdrop-filter:blur(10px);border-radius:var(--radius-sm);padding:8px 14px;display:flex;align-items:center;gap:8px;border:1px solid rgba(255,255,255,0.1);transition:all .15s}
.search-box:focus-within{background:rgba(255,255,255,0.25);border-color:rgba(255,255,255,0.3)}
.search-box input{flex:1;background:transparent;border:none;color:#fff;font-size:16px;outline:none}
.search-box input::placeholder{color:rgba(255,255,255,0.65)}
.sort-select{background:rgba(255,255,255,0.15);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.1);color:#fff;padding:8px 30px 8px 14px;border-radius:var(--radius-sm);font-size:14px;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='white' d='M6 8L2 4h8z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;transition:all .15s}
.sort-select:hover{background:rgba(255,255,255,0.25)}
.sort-select option{color:#333}
.view-toggle{display:flex;gap:2px;background:rgba(255,255,255,0.15);backdrop-filter:blur(10px);padding:4px;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,0.1)}
.view-toggle button{background:transparent;border:none;color:rgba(255,255,255,0.65);padding:8px 12px;border-radius:4px;cursor:pointer;font-size:14px;transition:all .15s}
.view-toggle button:hover{color:#fff;background:rgba(255,255,255,0.1)}
.view-toggle button.active{background:#fff;color:var(--primary);font-weight:500}
.btn-share{background:rgba(255,255,255,0.2);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.2);color:#fff;padding:8px 16px;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;transition:all .15s;display:flex;align-items:center;gap:6px}
.btn-share:hover{background:rgba(255,255,255,0.3);transform:translateY(-1px)}
.stats{background:var(--card);padding:12px 16px;border-radius:var(--radius-md);margin-bottom:16px;font-size:14px;color:var(--text-secondary);display:flex;justify-content:space-between;border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.stats span:first-child{font-weight:500;color:var(--text)}
.stats span:last-child{color:var(--primary);font-weight:600}
.list{background:var(--card);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.list-header{display:grid;grid-template-columns:1fr 100px 100px 120px 100px;gap:12px;padding:12px 16px;background:linear-gradient(135deg,#f8fbff,#f0f6ff);border-bottom:1px solid #dce8f9;font-size:12px;font-weight:600;color:var(--primary);text-transform:uppercase;letter-spacing:0.05em}
.list-header span{text-align:center}
.list-header span:first-child{text-align:left}
.list-item{display:grid;grid-template-columns:1fr 100px 100px 120px 100px;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);align-items:center;transition:background .15s}
.list-item:last-child{border-bottom:none}
.list-item:hover{background:#f5f9ff}
.list-title{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.list-title a{color:var(--primary);text-decoration:none}
.list-title a:hover{text-decoration:underline}
.list-meta{font-size:13px;color:var(--text-secondary);text-align:center}
.list-actions{text-align:center}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
@media(max-width:480px){.grid{grid-template-columns:1fr}}
.card{background:var(--card);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-sm);transition:all .25s;border:1px solid transparent;display:flex;flex-direction:column;gap:10px}
.card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);border-color:var(--primary-light)}
.card-header{display:flex;align-items:flex-start;gap:10px}
.card-icon{font-size:28px;flex-shrink:0}
.card-title{flex:1;font-size:15px;font-weight:500;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}
.card-meta{display:flex;flex-wrap:wrap;gap:10px;font-size:13px;color:var(--text-secondary)}
.card-meta span{display:flex;align-items:center;gap:4px}
.card-actions{display:flex;gap:8px;margin-top:auto;padding-top:10px;border-top:1px solid var(--border)}
.card-actions button{flex:1;padding:8px 12px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:500;transition:all .15s}
.btn-link{background:var(--primary);color:#fff}
.btn-link:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px var(--primary-glow)}
.btn-copy{background:var(--bg);border:1px solid var(--border);color:var(--text)}
.btn-copy:hover{background:#e8e8e8}
.btn-copy.copied{background:var(--success);color:#fff;border-color:var(--success)}
.compact{background:var(--card);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.compact-item{display:flex;align-items:center;padding:10px 14px;border-bottom:1px solid var(--border);gap:10px;transition:background .15s}
.compact-item:last-child{border-bottom:none}
.compact-item:hover{background:#f5f9ff}
.compact-icon{font-size:18px;flex-shrink:0}
.compact-title{flex:1;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.compact-title a{color:var(--text);text-decoration:none}
.compact-title a:hover{color:var(--primary)}
.compact-meta{display:flex;gap:12px;font-size:12px;color:var(--text-secondary);flex-shrink:0}
.compact-actions{display:flex;gap:4px;flex-shrink:0}
.compact-btn{padding:5px 10px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:12px;font-weight:500;transition:all .15s}
.compact-btn-link{background:var(--primary);color:#fff}
.compact-btn-link:hover{background:var(--primary-dark)}
.compact-btn-copy{background:var(--bg);border:1px solid var(--border);color:var(--text)}
.compact-btn-copy:hover{background:#e8e8e8}
.compact-btn-copy.copied{background:var(--success);color:#fff;border-color:var(--success)}
.btn{padding:6px 12px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:12px;font-weight:500;transition:all .15s}
.loading{text-align:center;padding:40px;color:var(--text-secondary)}
.loading-spinner{text-align:center;padding:80px 0}
.loading-spinner::after{content:'';display:inline-block;width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.empty{text-align:center;padding:60px 40px;color:var(--text-secondary);background:var(--card);border-radius:var(--radius-lg);border:1px dashed var(--border)}
.empty::before{content:'📭';font-size:48px;display:block;margin-bottom:16px}
.share-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,20,60,0.12);backdrop-filter:blur(1px);z-index:999;opacity:0;pointer-events:none;transition:opacity .3s}
.share-overlay.show{opacity:1;pointer-events:auto}
.share-panel{position:fixed;bottom:0;left:0;right:0;background:#fff;border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:24px;padding-bottom:calc(24px + env(safe-area-inset-bottom));box-shadow:0 -8px 40px rgba(0,102,255,0.2);z-index:1000;transform:translateY(100vh);transition:transform .35s cubic-bezier(.4,0,.2,1)}
.share-panel.show{transform:translateY(0)}
.share-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.share-panel-title{font-size:16px;font-weight:600;color:var(--text)}
.share-panel-close{background:none;border:none;font-size:28px;color:var(--text-muted);cursor:pointer;line-height:1;transition:color .15s}
.share-panel-close:hover{color:var(--text)}
.share-panel-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.share-action{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 8px;background:var(--bg);border-radius:var(--radius-md);cursor:pointer;transition:all .25s;border:none;font-size:14px;color:var(--text)}
.share-action:hover{background:#e8e8e8;transform:translateY(-2px)}
.share-action-icon{width:48px;height:48px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;color:#fff;transition:transform .25s}
.share-action:hover .share-action-icon{transform:scale(1.08)}
.share-action-icon.wechat{background:#07c160}
.share-action-icon.qrcode{background:var(--primary)}
.share-action-icon.copy{background:#666}
.qr-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,20,60,0.5);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2000;opacity:0;pointer-events:none;transition:opacity .3s}
.qr-modal.show{opacity:1;pointer-events:auto}
.qr-modal-content{background:#fff;border-radius:var(--radius-xl);padding:24px;text-align:center;max-width:320px;width:90%;transform:scale(0.9);transition:transform .3s cubic-bezier(.4,0,.2,1)}
.qr-modal.show .qr-modal-content{transform:scale(1)}
.qr-modal-title{font-size:16px;font-weight:600;margin-bottom:16px;word-break:break-all}
.qr-modal-canvas{display:flex;justify-content:center;margin-bottom:12px}
.qr-modal-canvas canvas{border-radius:var(--radius-md)}
.qr-modal-tip{font-size:13px;color:var(--text-muted);margin-bottom:16px}
.qr-modal-close{background:var(--primary);color:#fff;border:none;padding:10px 32px;border-radius:var(--radius-md);cursor:pointer;font-size:14px;font-weight:500;transition:all .15s}
.qr-modal-close:hover{background:var(--primary-dark)}
.toast{position:fixed;bottom:calc(24px + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%);background:#333;color:#fff;padding:12px 24px;border-radius:24px;font-size:14px;z-index:3000;animation:fadeIn .3s}
@keyframes fadeIn{from{opacity:0;transform:translateX(-50%) translateY(20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
footer{text-align:center;padding:20px;color:var(--text-muted);font-size:13px}
.batch-panel{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e5e5e5;padding:12px 16px;padding-bottom:calc(12px + env(safe-area-inset-bottom));display:none;align-items:center;justify-content:space-between;z-index:100;box-shadow:0 -2px 10px rgba(0,0,0,0.1)}
.fav-panel{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(0.9);background:#fff;border-radius:16px;padding:24px;width:90%;max-width:320px;display:none;flex-direction:column;align-items:center;z-index:1001;box-shadow:0 8px 40px rgba(0,0,0,0.2)}
.fav-panel.show{display:flex}
.fav-header{display:flex;width:100%;justify-content:space-between;align-items:center;margin-bottom:16px}
.fav-title{font-size:16px;font-weight:600;color:#333}
.fav-close{background:none;border:none;font-size:28px;color:#999;cursor:pointer;line-height:1}
.fav-qr{margin-bottom:16px;padding:12px;background:linear-gradient(135deg,#f8fbff,#f0f6ff);border-radius:12px;border:1px solid #e8eef5}
.fav-qr canvas,.fav-qr img{border-radius:8px;display:block}
.fav-qr-text{margin-bottom:12px;font-size:16px;font-weight:600;color:#005cff;text-align:center}
.fav-url{width:100%;display:flex;gap:8px;margin-bottom:12px}
.fav-url input{flex:1;background:#f5f5f5;border:none;padding:10px 12px;border-radius:8px;font-size:13px;color:#666}
.fav-copy{background:#005cff;color:#fff;border:none;padding:10px 16px;border-radius:8px;font-size:14px;cursor:pointer}
.fav-actions{width:100%;text-align:center}
.fav-download{display:inline-block;color:#005cff;font-size:14px;text-decoration:none}
.fav-tip{font-size:12px;color:#999;text-align:center;margin-top:8px}
.batch-panel.show{display:flex}
.batch-info{font-size:15px;color:#333;font-weight:500}
.batch-info span{color:#005cff}
.batch-actions{display:flex;gap:10px}
.batch-btn{padding:8px 20px;border-radius:20px;font-size:14px;font-weight:500;cursor:pointer;border:none;transition:all .15s}
.batch-btn:first-child{background:#005cff;color:#fff}
.batch-btn:first-child:active{background:#004ecc}
.batch-btn:last-child{background:#f5f5f5;color:#666}
.batch-btn:last-child:active{background:#e5e5e5}
/* 批量复制预览面板 */
.batch-copy-panel{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,20,60,0.5);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;z-index:2000;opacity:0;transition:opacity .3s}
.batch-copy-panel.show{display:flex;opacity:1}
.batch-copy-content{background:#fff;border-radius:var(--radius-xl);padding:24px;width:90%;max-width:400px;max-height:80vh;display:flex;flex-direction:column;transform:scale(0.9);transition:transform .3s cubic-bezier(.4,0,.2,1)}
.batch-copy-panel.show .batch-copy-content{transform:scale(1)}
.batch-copy-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.batch-copy-title{font-size:16px;font-weight:600;color:var(--text)}
.batch-copy-close{background:none;border:none;font-size:28px;color:var(--text-muted);cursor:pointer;line-height:1;transition:color .15s}
.batch-copy-close:hover{color:var(--text)}
.batch-copy-preview{flex:1;overflow-y:auto;background:var(--bg);padding:8px;font-size:12px;line-height:1.4;max-height:250px}
.batch-copy-preview p{margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--border);word-break:break-all}
.batch-copy-preview p:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}
.batch-copy-preview .preview-title{font-weight:500;color:var(--primary);margin-bottom:2px;font-size:12px}
.batch-copy-preview .preview-url{color:var(--text-secondary);font-family:monospace;font-size:11px;word-break:break-all}
.batch-copy-footer{display:flex;gap:10px;margin-top:16px}
.batch-copy-footer button{flex:1;padding:12px;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:14px;font-weight:500;transition:all .15s}
.batch-copy-confirm{background:var(--primary);color:#fff}
.batch-copy-confirm:hover{background:var(--primary-dark)}
.batch-copy-confirm.copied{background:var(--success)}
.batch-copy-cancel{background:var(--bg);color:var(--text);border:1px solid var(--border)}
.batch-copy-cancel:hover{background:#e8e8e8}
/* 夸克风格移动端列表 */
@media(max-width:768px){
  .container{padding:0}
  header{ padding:16px;margin-bottom:0}
  header .container{padding:0 12px}
  h1{font-size:18px;margin-bottom:10px}
  .controls{gap:8px}
  .search-box{min-width:unset;flex:1;background:#f8f8f8;border-color:#e0e0e0}
  .search-box:focus-within{background:#fff;border-color:#005cff}
  .search-box input{color:#333}
  .search-box input::placeholder{color:#999}
  .sort-select{padding:8px 28px 8px 12px;font-size:13px}
  .view-toggle{display:none}
  .stats{display:none}
  .list-header,.grid{display:none}
  .list-item{grid-template-columns:1fr;padding:0}
  .list-item>div:first-child{padding:14px 12px}
  .list-item-meta{display:none}
  .list-item-actions{position:absolute;right:8px;top:50%;transform:translateY(-50%)}
  .list-item{position:relative}
  /* 夸克风格列表 */
  .quark-list{background:#fff}
  .quark-item{display:flex;align-items:center;padding:14px 12px;border-bottom:1px solid #f0f0f0;transition:background .15s;text-decoration:none;color:inherit}
  .quark-item:last-child{border-bottom:none}
  .quark-item:active{background:#f0f0f0}
  .quark-link{display:flex;align-items:center;flex:1;min-width:0;text-decoration:none;color:inherit}
  .quark-icon{width:40px;height:40px;background:linear-gradient(135deg,#e8f0fe,#d4e3fc);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:20px;margin-right:12px;flex-shrink:0}
  .quark-info{flex:1;min-width:0}
  .quark-name{font-size:15px;color:#1a1a1a;font-weight:400;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;word-wrap:break-word}
  .quark-meta{display:flex;gap:12px;margin-top:4px}
  .quark-meta span{font-size:12px;color:#999}
  .quark-check{width:22px;height:22px;border:2px solid #d0d0d0;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-left:10px;cursor:pointer;flex-shrink:0;transition:all .2s}
  .quark-check::after{content:'✓';font-size:13px;color:#fff;font-weight:bold;opacity:0;transform:scale(0);transition:all .15s}
  .quark-item.checked .quark-check{background:#005cff;border-color:#005cff}
  .quark-item.checked .quark-check::after{opacity:1;transform:scale(1)}
  .compact{display:none}
  /* 分享面板 */
  .share-panel-actions{grid-template-columns:repeat(3,1fr);gap:6px}
  .share-action{padding:12px 4px}
  .share-action-icon{width:40px;height:40px;font-size:18px}
  /* 二维码弹窗 */
  .qr-modal-content{max-width:280px;padding:20px}
  .qr-modal-canvas canvas{width:180px!important;height:180px!important}
}
@media(max-width:480px){
  header{padding:14px 0}
  header .container{padding:0 12px}
  .controls{flex-wrap:nowrap;padding:0 12px}
  .search-box{padding:8px 10px}
  .sort-select{display:none}
  .btn-share{width:auto;padding:8px 12px;font-size:13px}
  .quark-item{padding:12px}
  .quark-icon{width:36px;height:36px;font-size:18px;margin-right:10px}
  .quark-name{font-size:14px}
  .quark-meta{font-size:11px}
  .empty{padding:60px 20px}
  .empty::before{font-size:48px}
  footer{padding:16px;font-size:12px}
}
