.app{min-height:100dvh;background:var(--bg-solid);background-image:var(--bg);background-attachment:fixed;color:var(--text)}.app-main{padding:16px 16px 96px}.tabbar{position:fixed;left:0;right:0;bottom:0;height:76px;padding-bottom:var(--safe-bottom);background:#ffffffe6;-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px);display:flex;align-items:center;justify-content:space-around;border-top:1px solid var(--border);box-shadow:0 -2px 20px #00000014;z-index:10}.tab{font-size:12px;color:var(--muted);text-decoration:none;padding:10px 16px;border-radius:var(--radius-sm);transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:4px;position:relative}.tab:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:0;height:3px;background:var(--accent);border-radius:0 0 3px 3px;transition:width .3s}.tab.active{color:var(--primary);background:var(--primary-light);font-weight:700}.tab.active:before{width:60%}.tab-icon{font-size:22px;margin-bottom:2px}@media(prefers-color-scheme:dark){.tabbar{background:#0f172ae6;box-shadow:0 -2px 20px #0000004d}.tab.active{background:var(--primary-light)}}:root{--bg: linear-gradient(135deg, #f5f7fa 0%, #e8ecf1 100%);--bg-solid: #f5f7fa;--card: #ffffff;--border: rgba(0, 0, 0, .06);--shadow: 0 4px 20px rgba(0, 0, 0, .08), 0 1px 3px rgba(0, 0, 0, .05);--shadow-hover: 0 8px 30px rgba(0, 0, 0, .12), 0 2px 6px rgba(0, 0, 0, .08);--text: #1a1a1a;--muted: #6b7280;--accent: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--accent-solid: #667eea;--accent-hover: linear-gradient(135deg, #764ba2 0%, #667eea 100%);--primary: #667eea;--primary-light: #e0e7ff;--danger: #ef4444;--danger-light: #fee2e2;--success: #10b981;--success-light: #d1fae5;--warning: #f59e0b;--warning-light: #fef3c7;--info: #3b82f6;--info-light: #dbeafe;--safe-bottom: env(safe-area-inset-bottom, 0px);--radius: 20px;--radius-sm: 12px;--radius-lg: 24px}@media(prefers-color-scheme:dark){:root{--bg: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);--bg-solid: #0f172a;--card: rgba(255, 255, 255, .05);--border: rgba(255, 255, 255, .1);--shadow: 0 8px 32px rgba(0, 0, 0, .4), 0 2px 8px rgba(0, 0, 0, .3);--shadow-hover: 0 12px 40px rgba(0, 0, 0, .5), 0 4px 12px rgba(0, 0, 0, .4);--text: #f1f5f9;--muted: #94a3b8;--accent: linear-gradient(135deg, #818cf8 0%, #a78bfa 100%);--accent-solid: #818cf8;--accent-hover: linear-gradient(135deg, #a78bfa 0%, #818cf8 100%);--primary: #818cf8;--primary-light: rgba(129, 140, 248, .2);--danger: #f87171;--danger-light: rgba(248, 113, 113, .2);--success: #34d399;--success-light: rgba(52, 211, 153, .2);--warning: #fbbf24;--warning-light: rgba(251, 191, 36, .2);--info: #60a5fa;--info-light: rgba(96, 165, 250, .2)}}*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;background:var(--bg-solid);background-image:var(--bg);background-attachment:fixed;color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.container{max-width:520px;margin:0 auto;padding:0 16px}.h1{font-size:26px;font-weight:900;margin:6px 0 10px;letter-spacing:-.02em}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.card-pad{padding:20px}.row{display:flex;align-items:center;justify-content:space-between;gap:12px}.muted{color:var(--muted);font-size:14px}.btn{appearance:none;border:0;border-radius:var(--radius-sm);padding:14px 20px;font-weight:700;font-size:15px;background:var(--accent);color:#fff;width:100%;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.btn:hover:before{left:100%}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--bg-solid);color:var(--text);border:1.5px solid var(--border)}.btn-secondary:hover{background:var(--card)}.input{width:100%;padding:14px 16px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--card);color:var(--text);font-size:15px;transition:all .2s}.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.list{display:flex;flex-direction:column;gap:16px}.badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;padding:8px 14px;border-radius:999px;background:var(--primary-light);color:var(--primary);border:none;font-weight:600}.badge-success{background:var(--success-light);color:var(--success)}.badge-danger{background:var(--danger-light);color:var(--danger)}.badge-warning{background:var(--warning-light);color:var(--warning)}.badge-info{background:var(--info-light);color:var(--info)}.error{color:var(--danger);font-size:13px}.appbar-wrap{position:sticky;top:0;z-index:20;margin:-16px -16px 16px}.appbar{height:56px;display:grid;grid-template-columns:56px 1fr 56px;align-items:center;padding:0 12px;background:#ffffffd9;-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--border);box-shadow:0 2px 10px #0000000a}@media(prefers-color-scheme:dark){.appbar{background:#0f172ad9;box-shadow:0 2px 10px #0000004d}}.appbar-title{text-align:center;font-weight:800;font-size:17px;letter-spacing:-.01em;background:var(--accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.appbar-left,.appbar-right{display:flex;align-items:center;justify-content:center}.icon-btn{width:40px;height:40px;border-radius:var(--radius-sm);border:none;background:var(--primary-light);color:var(--primary);font-size:20px;line-height:0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.icon-btn:hover{background:var(--primary);color:#fff;transform:scale(1.05)}.icon-btn:active{transform:scale(.95)}@media(prefers-color-scheme:dark){.icon-btn{background:var(--primary-light)}}.modal-mask{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:50;padding:16px;padding-bottom:calc(16px + var(--safe-bottom));animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{width:min(520px,100%);background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-hover);padding:24px;animation:slideUp .3s cubic-bezier(.4,0,.2,1);max-height:85vh;overflow-y:auto}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-title{font-weight:900;font-size:20px;margin:0 0 20px;background:var(--accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.toast-wrap{position:fixed;left:0;right:0;bottom:calc(86px + var(--safe-bottom));display:flex;flex-direction:column;gap:10px;align-items:center;z-index:60;pointer-events:none;padding:0 16px}.toast{pointer-events:none;max-width:min(520px,92vw);background:#000000e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:14px 18px;border-radius:var(--radius-sm);font-weight:700;font-size:14px;box-shadow:var(--shadow-hover);animation:toastSlide .3s cubic-bezier(.4,0,.2,1)}@keyframes toastSlide{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.toast-success{background:var(--success)}.toast-error{background:var(--danger)}.toast-warning{background:var(--warning)}.toast-info{background:var(--info)}.skeleton{background:linear-gradient(90deg,#0000000f 25%,#0000001a 37%,#0000000f 63%);background-size:400% 100%;animation:shine 1.2s ease-in-out infinite;border-radius:14px}@media(prefers-color-scheme:dark){.skeleton{background:linear-gradient(90deg,#ffffff0f 25%,#ffffff1a 37%,#ffffff0f 63%)}}@keyframes shine{0%{background-position:100% 0}to{background-position:0 0}}
