:root{--color-bg:#f5f5f5;--color-bg-card:#fff;--color-bg-header:#fff;--color-border:#e5e5e5;--color-border-light:#f0f0f0;--color-text-primary:#1e1e1e;--color-text-secondary:#6b6b6b;--color-text-muted:#9b9b9b;--color-blue:#002eff;--color-blue-hover:#0025cc;--color-blue-light:#eff1ff;--color-blue-subtle:#e8ebff;--color-danger:#ef4444;--color-danger-hover:#dc2626;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-full:9999px;--shadow-card:0 1px 4px #0000000f, 0 2px 12px #0000000d;--shadow-card-hover:0 4px 16px #0000001a, 0 1px 4px #0000000f;--shadow-modal:0 20px 60px #0000002e, 0 4px 16px #0000001a;--shadow-header:0 1px 0 var(--color-border);--transition:.18s cubic-bezier(.4, 0, .2, 1);--font-sans:-apple-system, BlinkMacSystemFont, "PingFang SC", "Segoe UI", "Helvetica Neue", Arial, sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,textarea,select{font-family:inherit;font-size:14px}.page{flex-direction:column;min-height:100vh;display:flex}.home-page{background:var(--color-bg)}.site-header{z-index:100;background:var(--color-bg-header);box-shadow:var(--shadow-header);position:sticky;top:0}.header-inner{align-items:center;gap:24px;max-width:1280px;height:56px;margin:0 auto;padding:0 24px;display:flex}.header-brand{flex-shrink:0;align-items:center;gap:10px;display:flex}.brand-icon{border-radius:var(--radius-md);background:var(--color-blue);color:#fff;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.brand-title{color:var(--color-text-primary);letter-spacing:-.01em;font-size:15px;font-weight:700;line-height:1.2;display:block}.brand-sub{color:var(--color-text-muted);letter-spacing:.05em;text-transform:uppercase;font-size:10px;display:block}.header-center{flex:1;max-width:480px}.search-box{position:relative}.search-icon{color:var(--color-text-muted);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.search-box input{border:1px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-bg);width:100%;color:var(--color-text-primary);transition:var(--transition);outline:none;padding:7px 12px 7px 32px}.search-box input:focus{border-color:var(--color-blue);box-shadow:0 0 0 3px var(--color-blue-subtle);background:#fff}.search-box input::placeholder{color:var(--color-text-muted)}.header-right{align-items:center;gap:12px;margin-left:auto;display:flex}.toast{z-index:9999;border-radius:var(--radius-lg);white-space:nowrap;padding:12px 24px;font-size:14px;font-weight:500;animation:.25s toast-in;position:fixed;top:24px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #00000026}.toast-success{color:#065f46;background:#ecfdf5;border:1px solid #6ee7b7}.toast-error{color:#991b1b;background:#fef2f2;border:1px solid #fca5a5}@keyframes toast-in{0%{opacity:0;transform:translate(-50%)translateY(-8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:.8s linear infinite spin}.edit-badge{border-radius:var(--radius-full);color:#dc2626;background:#fef2f2;border:1px solid #fecaca;align-items:center;gap:6px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-flex}.edit-badge-dot{background:#ef4444;border-radius:50%;width:6px;height:6px;animation:1.5s infinite pulse-red}@keyframes pulse-red{0%,to{opacity:1}50%{opacity:.4}}.main-content{flex:1;padding:24px 0 80px}.content-inner{max-width:1280px;margin:0 auto;padding:0 24px}.toolbar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.cat-tabs{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.cat-icon{color:var(--color-text-muted);flex-shrink:0;margin-right:4px}.cat-tab{border-radius:var(--radius-full);color:var(--color-text-secondary);transition:var(--transition);border:1px solid #0000;padding:5px 14px;font-size:13px;font-weight:500}.cat-tab:hover{color:var(--color-text-primary);background:#fff}.cat-tab.active{background:var(--color-blue);color:#fff;border-color:var(--color-blue)}.edit-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.btn-add,.btn-export{flex-shrink:0;align-items:center;gap:6px;display:flex}.app-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.app-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:var(--transition);box-shadow:var(--shadow-card);flex-direction:column;gap:14px;padding:18px;display:flex;position:relative}.app-card.clickable{cursor:pointer}.app-card.clickable:hover{box-shadow:var(--shadow-card-hover);border-color:#c7d0ff;transform:translateY(-1px)}.app-card.clickable:hover .card-ext-icon{opacity:1}.app-card.edit-mode{border:1.5px dashed #d0d0d0}.card-actions{z-index:2;gap:4px;display:flex;position:absolute;top:12px;right:12px}.card-action-btn{border-radius:var(--radius-sm);border:1px solid var(--color-border);width:26px;height:26px;color:var(--color-text-secondary);transition:var(--transition);background:#fff;justify-content:center;align-items:center;display:flex}.card-action-btn.drag-handle{cursor:grab;color:var(--color-text-muted)}.card-action-btn.drag-handle:active{cursor:grabbing}.card-action-btn.drag-handle:hover{background:var(--color-bg);color:var(--color-text-secondary);border-color:#d0d0d0}.card-action-btn.open:hover{background:var(--color-blue-light);color:var(--color-blue);border-color:#c7d0ff}.app-card.dragging{box-shadow:0 8px 32px #002eff26,0 2px 8px #0000001a;border-color:#c7d0ff!important}.card-action-btn.edit:hover{color:#d97706;background:#fffbeb;border-color:#fde68a}.card-action-btn.delete:hover{color:var(--color-danger);background:#fef2f2;border-color:#fecaca}.card-click-area{cursor:pointer;flex-direction:column;flex:1;gap:14px;display:flex}.card-avatar{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.card-emoji{font-size:24px;line-height:1}.card-body{flex:1}.card-name-row{align-items:flex-start;gap:6px;margin-bottom:6px;display:flex}.card-name{color:var(--color-text-primary);flex:1;font-size:15px;font-weight:600;line-height:1.4}.card-ext-icon{color:var(--color-text-muted);opacity:0;transition:var(--transition);flex-shrink:0;margin-top:3px}.card-desc{color:var(--color-text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:13px;line-height:1.6;display:-webkit-box;overflow:hidden}.card-footer{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.tag{border-radius:var(--radius-full);align-items:center;padding:2px 8px;font-size:11px;font-weight:500;line-height:1.6;display:inline-flex}.tag-category{background:var(--color-blue-light);color:var(--color-blue);border:1px solid #c7d0ff}.tag-mode{color:#52525b;background:#f4f4f5;border:1px solid #e4e4e7}.tag-external{color:#c2410c;background:#fff7ed;border:1px solid #fed7aa}.link-type-toggle{gap:8px;display:flex}.link-type-btn{border:1.5px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);text-align:left;color:var(--color-text-primary);background:#fff;flex-direction:column;flex:1;align-items:flex-start;gap:3px;padding:10px 12px;font-size:13px;font-weight:500;display:flex}.link-type-btn:hover{background:var(--color-blue-light);border-color:#c7d0ff}.link-type-btn.active{border-color:var(--color-blue);background:var(--color-blue-light);color:var(--color-blue)}.link-type-icon{margin-bottom:2px;font-size:16px;line-height:1}.link-type-desc{color:var(--color-text-muted);font-size:11px;font-weight:400;line-height:1.4}.empty-state{color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:80px 20px;display:flex}.empty-icon{opacity:.3}.mode-toggle-area{z-index:200;position:fixed;bottom:24px;right:24px}.mode-toggle-btn{border-radius:var(--radius-full);border:1px solid var(--color-border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--color-text-muted);transition:var(--transition);background:#ffffffb3;align-items:center;gap:6px;padding:6px 10px;font-size:12px;display:flex;box-shadow:0 2px 8px #00000014}.mode-toggle-btn:hover{color:var(--color-text-secondary);background:#fffffff2}.mode-toggle-btn.active{color:#dc2626;background:#fff;border-color:#fecaca}.toggle-dot{background:var(--color-border);border-radius:50%;width:6px;height:6px}.btn{border-radius:var(--radius-md);transition:var(--transition);cursor:pointer;border:1px solid #0000;justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:500;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-blue);color:#fff;border-color:var(--color-blue)}.btn-primary:not(:disabled):hover{background:var(--color-blue-hover);border-color:var(--color-blue-hover)}.btn-secondary{color:var(--color-text-primary);border-color:var(--color-border);background:#fff}.btn-secondary:hover{background:var(--color-bg);border-color:silver}.btn-ghost{color:var(--color-text-secondary);border-color:var(--color-border);background:0 0}.btn-ghost:hover{background:var(--color-bg);color:var(--color-text-primary)}.btn-sm{padding:5px 12px;font-size:13px}.btn-full{width:100%}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0006;justify-content:center;align-items:center;padding:16px;animation:.15s fade-in;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-box{border-radius:var(--radius-xl);box-shadow:var(--shadow-modal);background:#fff;width:100%;animation:.2s cubic-bezier(.34,1.4,.64,1) slide-up;position:relative}@keyframes slide-up{0%{opacity:0;transform:translateY(12px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-close{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--color-text-muted);transition:var(--transition);z-index:2;justify-content:center;align-items:center;display:flex;position:absolute;top:14px;right:14px}.modal-close:hover{background:var(--color-bg);color:var(--color-text-primary)}.auth-modal{max-width:360px;padding:32px 28px 28px}.auth-header{text-align:center;margin-bottom:24px}.auth-icon{border-radius:var(--radius-lg);background:var(--color-blue-light);width:44px;height:44px;color:var(--color-blue);justify-content:center;align-items:center;margin:0 auto 12px;display:flex}.auth-header h2{color:var(--color-text-primary);margin-bottom:4px;font-size:17px;font-weight:600}.auth-header p{color:var(--color-text-secondary);font-size:13px}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-error{color:var(--color-danger);border-radius:var(--radius-sm);text-align:center;background:#fef2f2;border:1px solid #fecaca;padding:8px 12px;font-size:13px}.form-field{flex-direction:column;gap:6px;display:flex}.form-field label{color:var(--color-text-primary);font-size:13px;font-weight:500}.required{color:var(--color-danger)}.form-field input,.form-field textarea,.form-field select{border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);transition:var(--transition);resize:vertical;background:#fff;outline:none;padding:8px 12px}.form-field input:focus,.form-field textarea:focus,.form-field select:focus{border-color:var(--color-blue);box-shadow:0 0 0 3px var(--color-blue-subtle)}.input-wrapper{position:relative}.input-icon{color:var(--color-text-muted);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.input-wrapper input{width:100%;padding-left:32px}.form-modal{max-width:540px;overflow:hidden}.modal-header{justify-content:space-between;align-items:center;padding:20px 20px 0;display:flex}.modal-header h2{color:var(--color-text-primary);font-size:16px;font-weight:600}.tab-bar{border-bottom:1px solid var(--color-border-light);gap:4px;padding:12px 20px 0;display:flex}.tab-btn{border-radius:var(--radius-md) var(--radius-md) 0 0;color:var(--color-text-secondary);transition:var(--transition);border:1px solid #0000;border-bottom:none;align-items:center;gap:5px;padding:7px 14px;font-size:13px;font-weight:500;display:flex;position:relative;bottom:-1px}.tab-btn:hover{color:var(--color-text-primary);background:var(--color-bg)}.tab-btn.active{color:var(--color-blue);border-color:var(--color-border);background:#fff;border-bottom-color:#fff}.yaml-panel{flex-direction:column;gap:12px;padding:16px 20px 20px;display:flex}.yaml-hint{color:var(--color-text-secondary);font-size:13px}.yaml-textarea{border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text-primary);resize:vertical;transition:var(--transition);background:#fafafa;outline:none;padding:12px;font-family:SF Mono,Monaco,Menlo,monospace;font-size:12.5px;line-height:1.7}.yaml-textarea:focus{border-color:var(--color-blue);box-shadow:0 0 0 3px var(--color-blue-subtle);background:#fff}.yaml-error{color:var(--color-danger);border-radius:var(--radius-sm);background:#fef2f2;border:1px solid #fecaca;padding:8px 12px;font-size:13px}.yaml-actions,.form-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.app-form{flex-direction:column;gap:14px;padding:16px 20px 20px;display:flex}.form-avatar-row{align-items:flex-start;gap:12px;display:flex}.form-avatar-preview{border-radius:var(--radius-md);border:1px solid #0000000f;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:26px;display:flex}.form-avatar-fields{flex:1}.form-field-row{gap:12px;display:flex}.flex1{flex:1}.color-pick-row{align-items:center;gap:8px;display:flex}.color-input{border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;background:#fff;width:32px;height:32px;padding:2px}.color-presets{flex-wrap:wrap;gap:4px;display:flex}.color-dot{width:18px;height:18px;transition:var(--transition);cursor:pointer;border:1.5px solid #0000;border-radius:50%}.color-dot:hover,.color-dot.selected{border-color:var(--color-text-primary);transform:scale(1.15)}.select-wrapper{position:relative}.select-wrapper select{appearance:none;cursor:pointer;width:100%;padding-right:28px}.select-arrow{color:var(--color-text-muted);pointer-events:none;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.detail-page{background:#fff;min-height:100vh}.detail-header{border-bottom:1px solid var(--color-border);z-index:50;background:#fff;position:sticky;top:0}.detail-header-inner{align-items:center;gap:16px;max-width:1400px;height:60px;margin:0 auto;padding:0 24px;display:flex}.back-btn{border-radius:var(--radius-md);color:var(--color-text-secondary);border:1px solid var(--color-border);transition:var(--transition);flex-shrink:0;align-items:center;gap:5px;padding:5px 10px;font-size:13px;font-weight:500;display:flex}.back-btn:hover{background:var(--color-bg);color:var(--color-text-primary)}.detail-app-info{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.detail-avatar{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex}.detail-name-row{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.detail-name{color:var(--color-text-primary);font-size:15px;font-weight:600}.detail-desc{color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:12.5px;overflow:hidden}.iframe-container{width:100%;height:calc(100vh - 60px)}.iframe-container iframe{display:block}.no-src{height:100%;color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex}.no-src-icon{opacity:.3}.no-src h3{color:var(--color-text-secondary);font-size:16px;font-weight:600}.no-src p{font-size:13px}.not-found{justify-content:center;align-items:center;display:flex}.not-found-inner{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:60px 20px;display:flex}.not-found-icon{color:var(--color-text-muted);opacity:.3}.not-found-inner h2{color:var(--color-text-primary);font-size:20px;font-weight:600}.not-found-inner p{color:var(--color-text-secondary);margin-bottom:8px;font-size:14px}@media (width<=768px){.header-inner{gap:12px;padding:0 16px}.brand-sub{display:none}.header-center{max-width:none}.content-inner{padding:0 16px}.app-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.toolbar{flex-direction:column;align-items:flex-start}.form-field-row{flex-direction:column}.form-avatar-row{flex-direction:column;align-items:center}.detail-header-inner{padding:0 16px}.detail-desc{display:none}}@media (width<=480px){.app-grid{grid-template-columns:1fr}}
