*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{line-height:1.15;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,PingFang SC,Microsoft YaHei,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;line-height:1.6;font-size:15px;text-rendering:optimizeLegibility;background:var(--color-background)}#app{width:100%;height:100vh;margin:0;padding:0;font-weight:400}ul,ol{list-style:none}a{text-decoration:none;color:inherit}button{border:none;background:none;cursor:pointer;font-family:inherit}img{max-width:100%;height:auto}input,textarea,select{font-family:inherit;font-size:inherit}::selection{background:#2563eb2e;color:var(--color-heading)}:root{--vt-c-white: #ffffff;--vt-c-white-soft: #f8f8f8;--vt-c-white-mute: #f2f2f2;--vt-c-black: #181818;--vt-c-black-soft: #222222;--vt-c-black-mute: #282828;--vt-c-indigo: #2c3e50;--vt-c-divider-light-1: rgba(60, 60, 60, .29);--vt-c-divider-light-2: rgba(60, 60, 60, .12);--vt-c-divider-dark-1: rgba(84, 84, 84, .65);--vt-c-divider-dark-2: rgba(84, 84, 84, .48);--vt-c-text-light-1: var(--vt-c-indigo);--vt-c-text-light-2: rgba(60, 60, 60, .66);--vt-c-text-dark-1: var(--vt-c-white);--vt-c-text-dark-2: rgba(235, 235, 235, .64);--color-background: #f6f8fb;--color-background-soft: #ffffff;--color-background-mute: #eef2f7;--color-border: var(--vt-c-divider-light-2);--color-border-hover: var(--vt-c-divider-light-1);--color-heading: #142033;--color-text: #26364d;--color-text-muted: #64748b;--color-primary: #2563eb;--color-primary-soft: rgba(37, 99, 235, .12);--color-accent: #0f766e;--color-accent-soft: rgba(15, 118, 110, .12);--color-warm: #f59e0b;--color-warm-soft: rgba(245, 158, 11, .14);--surface-glass: rgba(255, 255, 255, .78);--surface-strong: rgba(255, 255, 255, .94);--sidebar-bg: #171717;--sidebar-bg-soft: #20332d;--section-gap: 160px;--sidebar-width: 248px;--sidebar-collapsed-width: 74px;--header-height: 74px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--border-radius-sm: 6px;--border-radius-md: 10px;--border-radius-lg: 14px;--border-radius-xl: 18px;--border-radius-2xl: 24px;--shadow-sm: 0 1px 2px 0 rgba(15, 23, 42, .06);--shadow-md: 0 10px 30px rgba(15, 23, 42, .08);--shadow-lg: 0 24px 60px rgba(15, 23, 42, .12);--shadow-glow: 0 18px 50px rgba(37, 99, 235, .16);--transition-fast: .16s ease;--transition-normal: .28s ease;--transition-slow: .5s ease;--ease-spring: cubic-bezier(.2, .8, .2, 1)}body{color:var(--color-text);background:var(--color-background);transition:color var(--transition-slow),background-color var(--transition-slow)}h1,h2,h3,h4,h5,h6{color:var(--color-heading);font-weight:600;line-height:1.2;margin-bottom:var(--spacing-md)}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1.125rem}h6{font-size:1rem}p{margin-bottom:var(--spacing-md);line-height:1.6}a{color:var(--color-text);transition:color var(--transition-fast)}a:hover{color:var(--color-primary)}code{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.9em;background-color:var(--color-background-mute);padding:2px 4px;border-radius:var(--border-radius-sm)}pre{background-color:var(--color-background-mute);padding:var(--spacing-md);border-radius:var(--border-radius-md);overflow-x:auto;margin-bottom:var(--spacing-md)}pre code{background:none;padding:0}.app-layout{display:flex;min-height:100vh;width:100%;max-width:100vw;overflow-x:hidden;background:var(--color-background);transition:background var(--transition-normal)}.app-layout:not(.dark){background:linear-gradient(135deg,#f5f7fa,#e8ecf0)}.main-content{flex:1;display:flex;flex-direction:column;height:100vh;overflow:hidden;min-width:0}.content-wrapper{flex:1;padding:var(--spacing-lg);overflow-y:auto}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.container-fluid{width:100%;padding:0 var(--spacing-md)}.grid{display:grid;gap:var(--spacing-md)}.grid-cols-1{grid-template-columns:1fr}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.flex-1{flex:1}.app-header{height:var(--header-height);background:var(--color-background);border-bottom:1px solid var(--color-border);display:flex;align-items:center;padding:0 var(--spacing-lg);position:sticky;top:0;z-index:100;transition:background-color var(--transition-normal),border-color var(--transition-normal)}.header-left{display:flex;align-items:center;gap:var(--spacing-md)}.header-center{flex:1;display:flex;justify-content:center;padding:0 var(--spacing-lg)}.header-right{display:flex;align-items:center;gap:var(--spacing-sm)}.menu-button{display:none;width:40px;height:40px;border-radius:var(--border-radius-md);background:transparent;border:none;cursor:pointer;align-items:center;justify-content:center;transition:background-color var(--transition-fast)}.menu-button:hover{background-color:var(--color-background-mute)}.search-container{position:relative;width:100%;max-width:500px}.search-input{width:100%;height:40px;padding:0 var(--spacing-md) 0 40px;border:1px solid var(--color-border);border-radius:var(--border-radius-lg);background:var(--color-background-soft);color:var(--color-text);font-size:14px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.search-input:focus{outline:none;border-color:var(--color-heading);box-shadow:0 0 0 3px #2c3e501a}.search-icon{position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);color:var(--color-text);opacity:.6}.theme-toggle{width:40px;height:40px;border-radius:var(--border-radius-md);background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color var(--transition-fast)}.theme-toggle:hover{background-color:var(--color-background-mute)}.app-sidebar{width:var(--sidebar-width);height:100vh;background:var(--color-background);border-right:1px solid var(--color-border);display:flex;flex-direction:column;transition:transform var(--transition-normal),width var(--transition-normal);position:relative;z-index:200}.sidebar-collapsed{width:60px}.sidebar-header{height:var(--header-height);padding:0 var(--spacing-lg);display:flex;align-items:center;border-bottom:1px solid var(--color-border);gap:var(--spacing-md)}.sidebar-logo{width:32px;height:32px;border-radius:var(--border-radius-md);background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:14px;flex-shrink:0}.sidebar-title{font-size:18px;font-weight:600;color:var(--color-heading);white-space:nowrap;overflow:hidden;transition:opacity var(--transition-normal)}.sidebar-collapsed .sidebar-title{opacity:0}.sidebar-content{flex:1;overflow-y:auto;padding:var(--spacing-md) 0}.nav-menu{list-style:none;padding:0;margin:0}.nav-item{margin:0 var(--spacing-sm)}.nav-link{display:flex;align-items:center;padding:var(--spacing-md);border-radius:var(--border-radius-md);color:var(--color-text);text-decoration:none;transition:background-color var(--transition-fast),color var(--transition-fast);gap:var(--spacing-md);position:relative}.nav-link:hover,.nav-link.active{background-color:var(--color-background-mute);color:var(--color-heading)}.nav-link.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--color-heading);border-radius:0 2px 2px 0}.nav-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px}.nav-text{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;transition:opacity var(--transition-normal)}.sidebar-collapsed .nav-text{opacity:0}.sidebar-toggle{position:absolute;right:-12px;top:50%;transform:translateY(-50%);width:24px;height:24px;border-radius:50%;background:var(--color-background);border:1px solid var(--color-border);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color var(--transition-fast);z-index:10}.sidebar-toggle:hover{background-color:var(--color-background-mute)}.sidebar-toggle-icon{width:12px;height:12px;transition:transform var(--transition-normal)}.sidebar-collapsed .sidebar-toggle-icon{transform:rotate(180deg)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-md);border:1px solid transparent;border-radius:var(--border-radius-md);font-size:14px;font-weight:500;line-height:1.5;text-decoration:none;cursor:pointer;transition:all var(--transition-fast);gap:var(--spacing-sm);white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:12px}.btn-lg{padding:var(--spacing-md) var(--spacing-lg);font-size:16px}.btn-primary{background-color:var(--color-heading);color:#fff;border-color:var(--color-heading)}.btn-primary:hover:not(:disabled){background-color:var(--color-text);border-color:var(--color-text)}.btn-secondary{background-color:var(--color-background-mute);color:var(--color-text);border-color:var(--color-border)}.btn-secondary:hover:not(:disabled){background-color:var(--color-background-soft);border-color:var(--color-border-hover)}.btn-outline{background-color:transparent;color:var(--color-heading);border-color:var(--color-heading)}.btn-outline:hover:not(:disabled){background-color:var(--color-heading);color:#fff}.btn-ghost{background-color:transparent;color:var(--color-text);border-color:transparent}.btn-ghost:hover:not(:disabled){background-color:var(--color-background-mute)}.btn-danger{background-color:#ef4444;color:#fff;border-color:#ef4444}.btn-danger:hover:not(:disabled){background-color:#dc2626;border-color:#dc2626}.btn-group{display:inline-flex;border-radius:var(--border-radius-md);overflow:hidden}.btn-group .btn{border-radius:0;border-right-width:0}.btn-group .btn:first-child{border-top-left-radius:var(--border-radius-md);border-bottom-left-radius:var(--border-radius-md)}.btn-group .btn:last-child{border-top-right-radius:var(--border-radius-md);border-bottom-right-radius:var(--border-radius-md);border-right-width:1px}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--border-radius-md)}.btn-icon-sm{width:32px;height:32px}.btn-icon-lg{width:48px;height:48px}.card{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-fast),border-color var(--transition-fast);overflow:hidden}.card:hover{box-shadow:var(--shadow-md);border-color:var(--color-border-hover)}.card-header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);background:var(--color-background-soft)}.card-title{font-size:18px;font-weight:600;color:var(--color-heading);margin:0}.card-subtitle{font-size:14px;color:var(--color-text);margin:var(--spacing-xs) 0 0 0;opacity:.8}.card-body{padding:var(--spacing-lg)}.card-footer{padding:var(--spacing-lg);border-top:1px solid var(--color-border);background:var(--color-background-soft)}.site-card{display:flex;align-items:center;padding:var(--spacing-md);background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--border-radius-lg);text-decoration:none;color:inherit;transition:all var(--transition-fast);gap:var(--spacing-md)}.site-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--color-border-hover)}.site-icon{width:48px;height:48px;border-radius:var(--border-radius-md);background:var(--color-background-mute);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.site-icon img{width:100%;height:100%;object-fit:cover}.site-info{flex:1;min-width:0}.site-name{font-size:16px;font-weight:600;color:var(--color-heading);margin:0 0 var(--spacing-xs) 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.site-description{font-size:14px;color:var(--color-text);opacity:.8;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.category-card{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--border-radius-lg);overflow:hidden;transition:box-shadow var(--transition-fast)}.category-card:hover{box-shadow:var(--shadow-md)}.category-header{padding:var(--spacing-lg);background:var(--color-background-soft);border-bottom:1px solid var(--color-border);display:flex;align-items:center;gap:var(--spacing-md)}.category-icon{font-size:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-background-mute);border-radius:var(--border-radius-md)}.category-title{font-size:18px;font-weight:600;color:var(--color-heading);margin:0}.category-content{padding:var(--spacing-lg)}.sites-grid{display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;font-size:14px;font-weight:500;color:var(--color-heading);margin-bottom:var(--spacing-sm)}.form-control{width:100%;padding:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--border-radius-md);background:var(--color-background);color:var(--color-text);font-size:14px;line-height:1.5;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-control:focus{outline:none;border-color:var(--color-heading);box-shadow:0 0 0 3px #2c3e501a}.form-control:disabled{background-color:var(--color-background-mute);opacity:.6;cursor:not-allowed}.form-control::placeholder{color:var(--color-text);opacity:.6}.form-control-sm{padding:var(--spacing-sm);font-size:12px}.form-control-lg{padding:var(--spacing-lg);font-size:16px}textarea.form-control{resize:vertical;min-height:100px}select.form-control{cursor:pointer}.form-check{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.form-check-input{width:16px;height:16px;margin:0;cursor:pointer}.form-check-label{font-size:14px;color:var(--color-text);cursor:pointer;margin:0}.input-group{display:flex;width:100%}.input-group .form-control{border-radius:0;border-right:0}.input-group .form-control:first-child{border-top-left-radius:var(--border-radius-md);border-bottom-left-radius:var(--border-radius-md)}.input-group .form-control:last-child{border-top-right-radius:var(--border-radius-md);border-bottom-right-radius:var(--border-radius-md);border-right:1px solid var(--color-border)}.input-group-text{display:flex;align-items:center;padding:var(--spacing-md);background:var(--color-background-mute);border:1px solid var(--color-border);border-left:0;color:var(--color-text);font-size:14px}.input-group-text:first-child{border-left:1px solid var(--color-border);border-right:0;border-top-left-radius:var(--border-radius-md);border-bottom-left-radius:var(--border-radius-md)}.input-group-text:last-child{border-top-right-radius:var(--border-radius-md);border-bottom-right-radius:var(--border-radius-md)}.form-control.is-valid{border-color:#10b981}.form-control.is-valid:focus{box-shadow:0 0 0 3px #10b9811a}.form-control.is-invalid{border-color:#ef4444}.form-control.is-invalid:focus{box-shadow:0 0 0 3px #ef44441a}.valid-feedback{display:block;font-size:12px;color:#10b981;margin-top:var(--spacing-xs)}.invalid-feedback{display:block;font-size:12px;color:#ef4444;margin-top:var(--spacing-xs)}.form-row{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.form-col{flex:1}.form-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end;padding-top:var(--spacing-lg);border-top:1px solid var(--color-border);margin-top:var(--spacing-lg)}.light{--color-background: #ffffff;--color-background-soft: #f8f8f8;--color-background-mute: #f2f2f2;--color-border: rgba(60, 60, 60, .12);--color-border-hover: rgba(60, 60, 60, .29);--color-heading: #2c3e50;--color-text: #2c3e50}.light .app-layout{background-color:#f5f7fa}.light .site-card{background:var(--color-background);border-color:var(--color-border)}.light .site-card:hover{background:var(--color-background-soft)}.light .category-card,.light .app-header,.light .app-sidebar{background:var(--color-background);border-color:var(--color-border)}.light .search-input{background:var(--color-background-soft);border-color:var(--color-border);color:var(--color-text)}.light .form-control{background:var(--color-background);border-color:var(--color-border);color:var(--color-text)}@media (max-width: 768px){.app-layout{flex-direction:column;height:100vh;overflow:hidden}.app-sidebar{position:fixed;top:0;left:0;height:100vh;z-index:1000;transform:translate(-100%);transition:transform var(--transition-normal)}.app-sidebar.sidebar-open{transform:translate(0)}.main-content{flex:1;height:100vh;margin-left:0;display:flex;flex-direction:column;overflow:hidden}.menu-button{display:flex}.search-container{max-width:none;flex:1}.grid-cols-2,.grid-cols-3,.grid-cols-4,.sites-grid{grid-template-columns:1fr}.site-card{padding:var(--spacing-sm)}.site-icon{width:40px;height:40px}.form-row{flex-direction:column;gap:var(--spacing-sm)}.form-actions,.btn-group{flex-direction:column}.btn-group .btn{border-radius:var(--border-radius-md);border-right-width:1px;border-bottom-width:0}.btn-group .btn:first-child{border-radius:var(--border-radius-md)}.btn-group .btn:last-child{border-radius:var(--border-radius-md);border-bottom-width:1px}}@media (min-width: 769px) and (max-width: 1024px){.grid-cols-4{grid-template-columns:repeat(3,1fr)}.sites-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}}@media (min-width: 1025px){.container{max-width:1200px}.sites-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media (min-width: 1440px){.container{max-width:1400px}.sites-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}}.hidden{display:none!important}.visible{display:block!important}@media (max-width: 768px){.hidden-mobile{display:none!important}.visible-mobile{display:block!important}}@media (min-width: 769px){.hidden-desktop{display:none!important}.visible-desktop{display:block!important}}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.m-0{margin:0}.m-1{margin:var(--spacing-xs)}.m-2{margin:var(--spacing-sm)}.m-3{margin:var(--spacing-md)}.m-4{margin:var(--spacing-lg)}.m-5{margin:var(--spacing-xl)}.p-0{padding:0}.p-1{padding:var(--spacing-xs)}.p-2{padding:var(--spacing-sm)}.p-3{padding:var(--spacing-md)}.p-4{padding:var(--spacing-lg)}.p-5{padding:var(--spacing-xl)}.mt-0{margin-top:0}.mt-1{margin-top:var(--spacing-xs)}.mt-2{margin-top:var(--spacing-sm)}.mt-3{margin-top:var(--spacing-md)}.mt-4{margin-top:var(--spacing-lg)}.mt-5{margin-top:var(--spacing-xl)}.mb-0{margin-bottom:0}.mb-1{margin-bottom:var(--spacing-xs)}.mb-2{margin-bottom:var(--spacing-sm)}.mb-3{margin-bottom:var(--spacing-md)}.mb-4{margin-bottom:var(--spacing-lg)}.mb-5{margin-bottom:var(--spacing-xl)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideOutLeft{0%{transform:translate(0)}to{transform:translate(-100%)}}@keyframes slideOutRight{0%{transform:translate(0)}to{transform:translate(100%)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.8)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,20%,53%,80%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1);transform:translateZ(0)}40%,43%{animation-timing-function:cubic-bezier(.755,.05,.855,.06);transform:translate3d(0,-30px,0)}70%{animation-timing-function:cubic-bezier(.755,.05,.855,.06);transform:translate3d(0,-15px,0)}90%{transform:translate3d(0,-4px,0)}}.animate-fadeIn{animation:fadeIn .3s ease-out}.animate-fadeOut{animation:fadeOut .3s ease-out}.animate-fadeInUp{animation:fadeInUp .5s ease-out}.animate-fadeInDown{animation:fadeInDown .5s ease-out}.animate-slideInLeft{animation:slideInLeft .3s ease-out}.animate-slideInRight{animation:slideInRight .3s ease-out}.animate-slideOutLeft{animation:slideOutLeft .3s ease-out}.animate-slideOutRight{animation:slideOutRight .3s ease-out}.animate-scaleIn{animation:scaleIn .3s ease-out}.animate-scaleOut{animation:scaleOut .3s ease-out}.animate-spin{animation:spin 1s linear infinite}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.animate-bounce{animation:bounce 1s infinite}.transition-all{transition:all var(--transition-normal)}.transition-colors{transition:color var(--transition-normal),background-color var(--transition-normal),border-color var(--transition-normal)}.transition-opacity{transition:opacity var(--transition-normal)}.transition-transform{transition:transform var(--transition-normal)}.transition-fast{transition-duration:var(--transition-fast)}.transition-slow{transition-duration:var(--transition-slow)}.hover-lift{transition:transform var(--transition-fast)}.hover-lift:hover{transform:translateY(-2px)}.hover-scale{transition:transform var(--transition-fast)}.hover-scale:hover{transform:scale(1.05)}.hover-rotate{transition:transform var(--transition-fast)}.hover-rotate:hover{transform:rotate(5deg)}.loading-spinner{width:20px;height:20px;border:2px solid var(--color-border);border-top:2px solid var(--color-heading);border-radius:50%;animation:spin 1s linear infinite}.loading-dots{display:inline-flex;gap:4px}.loading-dots:before,.loading-dots:after,.loading-dots{content:"";width:6px;height:6px;border-radius:50%;background:var(--color-heading);animation:pulse 1.4s ease-in-out infinite both}.loading-dots:before{animation-delay:-.32s}.loading-dots:after{animation-delay:-.16s}.fade-enter-active,.fade-leave-active{transition:opacity var(--transition-normal)}.fade-enter-from,.fade-leave-to{opacity:0}.slide-enter-active,.slide-leave-active{transition:transform var(--transition-normal)}.slide-enter-from{transform:translate(-100%)}.slide-leave-to{transform:translate(100%)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{scroll-behavior:auto!important;animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}header[data-v-6ae9212f]{line-height:1.5;max-height:100vh}.logo[data-v-6ae9212f]{display:block;margin:0 auto 2rem}nav[data-v-6ae9212f]{width:100%;font-size:12px;text-align:center;margin-top:2rem}nav a.router-link-exact-active[data-v-6ae9212f]{color:var(--color-text)}nav a.router-link-exact-active[data-v-6ae9212f]:hover{background-color:transparent}nav a[data-v-6ae9212f]{display:inline-block;padding:0 1rem;border-left:1px solid var(--color-border)}nav a[data-v-6ae9212f]:first-of-type{border:0}@media (min-width: 1024px){header[data-v-6ae9212f]{display:flex;place-items:center;padding-right:calc(var(--section-gap) / 2)}.logo[data-v-6ae9212f]{margin:0 2rem 0 0}header .wrapper[data-v-6ae9212f]{display:flex;place-items:flex-start;flex-wrap:wrap}nav[data-v-6ae9212f]{text-align:left;margin-left:-1rem;font-size:1rem;padding:1rem 0;margin-top:1rem}}.sidebar[data-v-882beab5]{position:relative;display:flex;flex-direction:column;flex-shrink:0;width:var(--sidebar-width);min-width:var(--sidebar-width);max-width:var(--sidebar-width);height:100vh;overflow:hidden;color:#f8fafc;background:linear-gradient(180deg,rgba(255,255,255,.08),transparent 32%),linear-gradient(135deg,var(--sidebar-bg),var(--sidebar-bg-soft) 58%,#101513);border-right:1px solid rgba(255,255,255,.08);box-shadow:14px 0 40px #0f172a2e;transition:width var(--transition-normal) var(--ease-spring),min-width var(--transition-normal) var(--ease-spring),max-width var(--transition-normal) var(--ease-spring)}.sidebar.collapsed[data-v-882beab5]{width:var(--sidebar-collapsed-width);min-width:var(--sidebar-collapsed-width);max-width:var(--sidebar-collapsed-width)}.logo-section[data-v-882beab5]{display:flex;align-items:center;gap:12px;min-height:var(--header-height);padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar.collapsed .logo-section[data-v-882beab5]{justify-content:center;padding:14px 0}.brand-mark[data-v-882beab5]{display:grid;place-items:center;flex-shrink:0;width:42px;height:42px;border-radius:16px;background:#ffffff1a;box-shadow:inset 0 1px #ffffff24}.logo[data-v-882beab5]{width:30px;height:30px;border-radius:10px;object-fit:cover}.brand-copy[data-v-882beab5]{min-width:0}.site-title[data-v-882beab5]{margin:0;overflow:hidden;color:#fff;font-size:16px;font-weight:800;line-height:1.15;text-overflow:ellipsis;white-space:nowrap}.brand-copy p[data-v-882beab5]{margin:5px 0 0;color:#e2e8f0a8;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.category-nav[data-v-882beab5]{flex:1;min-height:0;padding:18px 0 78px;overflow-y:auto;scrollbar-width:none}.category-nav[data-v-882beab5]::-webkit-scrollbar{display:none}.nav-title[data-v-882beab5]{margin:0 18px 12px;color:#e2e8f09e;font-size:12px;font-weight:800;letter-spacing:.1em}.category-list[data-v-882beab5]{display:flex;flex-direction:column;gap:4px;margin:0;padding:0 10px}.category-item[data-v-882beab5],.subcategory-item[data-v-882beab5]{position:relative;display:flex;align-items:center;min-height:44px;color:#f1f5f9c7;cursor:pointer;border:1px solid transparent;border-radius:14px;transition:background-color var(--transition-fast),color var(--transition-fast),transform var(--transition-fast),border-color var(--transition-fast)}.category-item[data-v-882beab5]{gap:11px;padding:8px 10px}.sidebar.collapsed .category-list[data-v-882beab5]{align-items:center;padding:0 8px}.sidebar.collapsed .category-item[data-v-882beab5]{justify-content:center;width:50px;padding:8px 0}.category-item[data-v-882beab5]:hover,.subcategory-item[data-v-882beab5]:hover{color:#fff;background:#ffffff14;border-color:#ffffff14;transform:translate(2px)}.sidebar.collapsed .category-item[data-v-882beab5]:hover{transform:translateY(-1px)}.category-item.active[data-v-882beab5],.subcategory-item.active[data-v-882beab5]{color:#fff;background:linear-gradient(135deg,#2563ebe0,#0f766ecc);border-color:#ffffff29;box-shadow:0 16px 28px #2563eb3d}.category-icon-wrapper[data-v-882beab5],.subcategory-icon[data-v-882beab5]{display:grid;place-items:center;flex-shrink:0;width:28px;height:28px}.category-icon[data-v-882beab5],.subcategory-icon[data-v-882beab5]{font-size:18px;line-height:1}.category-name[data-v-882beab5],.subcategory-name[data-v-882beab5]{flex:1;min-width:0;overflow:hidden;font-size:14px;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.expand-icon[data-v-882beab5]{display:grid;place-items:center;color:#e2e8f0b8;transition:transform var(--transition-fast)}.expand-icon.expanded[data-v-882beab5]{transform:rotate(180deg)}.tooltip[data-v-882beab5]{position:fixed;left:calc(var(--sidebar-collapsed-width) + 12px);z-index:9999;padding:8px 11px;color:#fff;font-size:13px;font-weight:700;white-space:nowrap;pointer-events:none;visibility:hidden;background:var(--sidebar-bg);border:1px solid rgba(255,255,255,.1);border-radius:10px;box-shadow:var(--shadow-lg);opacity:0;transform:translate(-4px);transition:opacity var(--transition-fast),transform var(--transition-fast),visibility var(--transition-fast)}.category-item:hover .tooltip[data-v-882beab5]{visibility:visible;opacity:1;transform:translate(0)}.subcategory-item[data-v-882beab5]{gap:10px;min-height:38px;margin-left:24px;padding:7px 10px;color:#e2e8f0ad;border-radius:12px}.subcategory-name[data-v-882beab5]{font-size:13px;font-weight:650}.sidebar-footer[data-v-882beab5]{position:absolute;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;height:64px;padding:10px;background:linear-gradient(180deg,transparent,rgba(15,23,42,.86) 28%)}.github-link[data-v-882beab5]{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;height:42px;color:#f1f5f9d6;font-size:13px;font-weight:800;text-decoration:none;border:1px solid rgba(255,255,255,.1);border-radius:14px;background:#ffffff14;transition:transform var(--transition-fast),background-color var(--transition-fast),color var(--transition-fast)}.github-link[data-v-882beab5]:hover{color:#fff;background:#ffffff24;transform:translateY(-1px)}.sidebar.collapsed .github-link[data-v-882beab5]{width:48px}@media (max-width: 768px){.sidebar[data-v-882beab5]{display:none}}.search-container[data-v-0aa6a545]{display:flex;align-items:center;flex:1;max-width:760px;min-width:0;height:50px;margin:0 auto;padding:4px;background:#ffffffdb;border:1px solid rgba(148,163,184,.24);border-radius:18px;box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.search-container[data-v-0aa6a545]:focus-within{border-color:#2563eb6b;box-shadow:var(--shadow-glow);transform:translateY(-1px)}.search-engine-selector[data-v-0aa6a545]{position:relative;display:flex;align-items:center;gap:7px;height:100%;min-width:58px;padding:0 10px;color:var(--color-text-muted);border-radius:14px;background:#f1f5f9e6;transition:background-color var(--transition-fast),color var(--transition-fast)}.search-engine-selector[data-v-0aa6a545]:hover{color:var(--color-primary);background:#dbeafec7}.engine-logo[data-v-0aa6a545]{width:25px;height:25px;object-fit:contain;border-radius:6px;pointer-events:none}.engine-select[data-v-0aa6a545]{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;border:none;outline:none;background:transparent}.select-arrow[data-v-0aa6a545]{pointer-events:none}.input-shell[data-v-0aa6a545]{position:relative;display:flex;align-items:center;flex:1;min-width:0;height:100%}.search-icon[data-v-0aa6a545]{position:absolute;left:16px;color:#94a3b8;pointer-events:none}.search-input[data-v-0aa6a545]{width:100%;min-width:0;height:100%;padding:0 14px 0 48px;color:var(--color-heading);font-size:16px;font-weight:600;background:transparent;border:none;outline:none}.search-input[data-v-0aa6a545]::placeholder{color:#94a3b8;font-weight:500}.search-submit[data-v-0aa6a545]{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:42px;height:42px;color:#fff;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));border-radius:14px;box-shadow:0 12px 24px #2563eb3d;transition:transform var(--transition-fast),box-shadow var(--transition-fast),filter var(--transition-fast)}.search-submit[data-v-0aa6a545]:hover{transform:translateY(-1px);filter:saturate(1.08);box-shadow:0 16px 30px #0f766e42}@media (max-width: 768px){.search-container[data-v-0aa6a545]{max-width:none;height:50px;margin:0;border-radius:16px}.search-engine-selector[data-v-0aa6a545]{min-width:50px;padding:0 8px}.select-arrow[data-v-0aa6a545]{display:none}.search-input[data-v-0aa6a545]{padding-left:42px;font-size:15px}.search-submit[data-v-0aa6a545]{width:40px;height:40px}}.mobile-menu[data-v-518e621d]{position:fixed;top:0;right:0;z-index:1001;display:none;width:min(86vw,340px);height:100vh;overflow-y:auto;color:var(--color-heading);background:linear-gradient(180deg,rgba(37,99,235,.08),transparent 26%),#fffffff0;border-left:1px solid rgba(148,163,184,.18);box-shadow:-24px 0 60px #0f172a2e;transform:translate(102%);transition:transform var(--transition-normal) var(--ease-spring);-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px)}.mobile-menu.active[data-v-518e621d]{transform:translate(0)}.mobile-menu-header[data-v-518e621d]{position:sticky;top:0;z-index:1;display:flex;align-items:center;justify-content:space-between;padding:22px 20px;background:#ffffffd1;border-bottom:1px solid rgba(148,163,184,.18);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.mobile-menu-header p[data-v-518e621d]{margin:0 0 4px;color:var(--color-accent);font-size:11px;font-weight:900;letter-spacing:.12em;text-transform:uppercase}.mobile-menu-header h3[data-v-518e621d]{margin:0;color:var(--color-heading);font-size:22px;font-weight:900}.close-btn[data-v-518e621d]{display:grid;place-items:center;width:42px;height:42px;color:var(--color-heading);background:#f1f5f9e6;border:1px solid rgba(148,163,184,.2);border-radius:14px;transition:color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.close-btn[data-v-518e621d]:hover{color:var(--color-primary);transform:rotate(6deg);box-shadow:var(--shadow-md)}.mobile-category-list[data-v-518e621d]{display:flex;flex-direction:column;gap:8px;margin:0;padding:16px 14px 32px}.mobile-category-item[data-v-518e621d]{display:flex;align-items:center;gap:12px;min-height:48px;padding:10px 12px;cursor:pointer;border:1px solid transparent;border-radius:8px;transition:background-color var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast)}.mobile-category-item[data-v-518e621d]:hover{background:#2563eb14;border-color:#2563eb1f;transform:translate(2px)}.mobile-category-item.subcategory[data-v-518e621d]{min-height:42px;margin-left:24px;color:var(--color-text-muted);background:#f1f5f98c}.mobile-category-item .category-icon[data-v-518e621d]{display:grid;place-items:center;flex-shrink:0;width:30px;height:30px;font-size:18px}.mobile-category-item .category-name[data-v-518e621d]{min-width:0;overflow:hidden;color:inherit;font-size:15px;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.mobile-menu-overlay[data-v-518e621d]{position:fixed;top:0;right:0;bottom:0;left:0;z-index:999;display:none;visibility:hidden;background:#0f172a6b;opacity:0;transition:opacity var(--transition-normal),visibility var(--transition-normal);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.mobile-menu-overlay.active[data-v-518e621d]{visibility:visible;opacity:1}.dark{color:#f8fafc;background:#0f172af0;border-color:#94a3b82e}.dark{background:#0f172ad1}@media (max-width: 768px){.mobile-menu[data-v-518e621d],.mobile-menu-overlay[data-v-518e621d]{display:block}}.search-header[data-v-355f23c8]{position:sticky;top:0;z-index:100;display:flex;align-items:center;gap:14px;min-height:var(--header-height);padding:12px clamp(16px,3vw,34px);background:#ffffffb8;border-bottom:1px solid rgba(255,255,255,.72);box-shadow:0 1px #94a3b82e;-webkit-backdrop-filter:blur(22px) saturate(150%);backdrop-filter:blur(22px) saturate(150%)}.collapse-btn[data-v-355f23c8],.mobile-menu-btn[data-v-355f23c8]{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:44px;height:44px;color:var(--color-heading);background:var(--surface-strong);border:1px solid rgba(148,163,184,.22);border-radius:14px;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast),box-shadow var(--transition-fast),color var(--transition-fast)}.collapse-btn[data-v-355f23c8]:hover,.mobile-menu-btn[data-v-355f23c8]:hover{color:var(--color-primary);transform:translateY(-1px);box-shadow:var(--shadow-md)}.mobile-menu-btn[data-v-355f23c8]{display:none}@media (max-width: 768px){.search-header[data-v-355f23c8]{position:fixed;right:0;left:0;min-height:78px;padding:14px 16px;background:#f6f8fbd1;box-shadow:0 12px 32px #0f172a14}.collapse-btn[data-v-355f23c8]{display:none}.mobile-menu-btn[data-v-355f23c8]{display:flex}}.back-to-top[data-v-209a8aab]{position:fixed;right:30px;bottom:30px;z-index:1000;display:flex;align-items:center;justify-content:center;width:50px;height:50px;color:var(--color-primary);cursor:pointer;background:#ffffffdb;border:1px solid rgba(148,163,184,.22);border-radius:16px;box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);transition:transform var(--transition-normal) var(--ease-spring),box-shadow var(--transition-normal),color var(--transition-fast)}.back-to-top[data-v-209a8aab]:hover{color:var(--color-accent);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.back-to-top[data-v-209a8aab]:active{transform:translateY(-1px)}.fade-enter-active[data-v-209a8aab],.fade-leave-active[data-v-209a8aab]{transition:opacity var(--transition-normal),transform var(--transition-normal)}.fade-enter-from[data-v-209a8aab],.fade-leave-to[data-v-209a8aab]{opacity:0;transform:translateY(14px) scale(.92)}@media (max-width: 768px){.back-to-top[data-v-209a8aab]{right:18px;bottom:18px;width:46px;height:46px;border-radius:14px}}.app-layout[data-v-dc1ba9d0]{display:flex;min-height:100vh;width:100%;max-width:100vw;overflow-x:hidden;background:linear-gradient(120deg,rgba(37,99,235,.08),transparent 28%),linear-gradient(300deg,rgba(15,118,110,.08),transparent 34%),repeating-linear-gradient(90deg,rgba(15,23,42,.028) 0 1px,transparent 1px 80px),repeating-linear-gradient(0deg,rgba(15,23,42,.024) 0 1px,transparent 1px 80px),var(--color-background);color:var(--color-text);position:relative;transition:background-color var(--transition-normal)}.main-content[data-v-dc1ba9d0]{flex:1;display:flex;flex-direction:column;height:100vh;overflow:hidden;min-width:0;position:relative;z-index:1}@media (max-width: 768px){.app-layout[data-v-dc1ba9d0]{flex-direction:column;height:100vh;overflow:hidden}.main-content[data-v-dc1ba9d0]{flex:1;height:100vh;margin-left:0;display:flex;flex-direction:column;overflow:hidden}}.site-card[data-v-f89845cf]{position:relative;display:flex;align-items:flex-start;gap:16px;min-height:128px;padding:18px;overflow:hidden;color:inherit;text-decoration:none;background:#ffffffc7;border:1px solid rgba(148,163,184,.2);border-radius:8px;box-shadow:0 14px 34px #0f172a12;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);transition:transform var(--transition-normal) var(--ease-spring),box-shadow var(--transition-normal),border-color var(--transition-normal),background-color var(--transition-normal)}.site-card[data-v-f89845cf]:before{position:absolute;inset:0 auto 0 0;width:4px;content:"";background:linear-gradient(180deg,var(--color-primary),var(--color-accent),var(--color-warm));opacity:.82}.site-card[data-v-f89845cf]:after{position:absolute;top:0;left:-70%;width:42%;height:100%;content:"";pointer-events:none;background:linear-gradient(100deg,transparent,rgba(255,255,255,.72),transparent);opacity:0;transform:skew(-18deg);transition:left .65s ease,opacity .3s ease}.site-card[data-v-f89845cf]:hover{background:#fffffff0;border-color:#2563eb4d;box-shadow:0 22px 50px #0f172a1f,0 14px 28px #2563eb1a;transform:translateY(-5px)}.site-card[data-v-f89845cf]:hover:after{left:120%;opacity:1}.site-card[data-v-f89845cf]:focus-visible{outline:3px solid rgba(37,99,235,.28);outline-offset:3px}.site-icon[data-v-f89845cf]{position:relative;z-index:1;display:grid;place-items:center;flex-shrink:0;width:52px;height:52px;overflow:hidden;color:var(--color-primary);font-size:22px;font-weight:900;background:linear-gradient(135deg,#fff,#eef6ff);border:1px solid rgba(148,163,184,.18);border-radius:8px;box-shadow:inset 0 1px #ffffffc2,0 10px 24px #0f172a14;transition:transform var(--transition-normal) var(--ease-spring)}.site-card:hover .site-icon[data-v-f89845cf]{transform:translateY(-2px) rotate(2deg)}.site-icon img[data-v-f89845cf]{width:34px;height:34px;object-fit:contain}.site-info[data-v-f89845cf]{position:relative;z-index:1;display:flex;flex:1;flex-direction:column;min-width:0}.site-heading[data-v-f89845cf]{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.site-name[data-v-f89845cf]{display:-webkit-box;margin:0;overflow:hidden;color:var(--color-heading);font-size:18px;font-weight:850;line-height:1.25;-webkit-box-orient:vertical;-webkit-line-clamp:2}.site-arrow[data-v-f89845cf]{flex-shrink:0;margin-top:2px;color:#94a3b8;transition:color var(--transition-fast),transform var(--transition-fast)}.site-card:hover .site-arrow[data-v-f89845cf]{color:var(--color-primary);transform:translate(2px,-2px)}.site-description[data-v-f89845cf]{display:-webkit-box;min-height:42px;margin:8px 0 13px;overflow:hidden;color:var(--color-text-muted);font-size:14px;font-weight:500;line-height:1.5;-webkit-box-orient:vertical;-webkit-line-clamp:2}.site-host[data-v-f89845cf]{display:inline-flex;align-self:flex-start;max-width:100%;padding:5px 9px;overflow:hidden;color:var(--color-accent);font-size:12px;font-weight:800;text-overflow:ellipsis;white-space:nowrap;background:var(--color-accent-soft);border-radius:999px}.dark{background:#0f172ad1;border-color:#94a3b82e}.dark{color:#f8fafc}.dark{color:#cbd5e1}@media (max-width: 768px){.site-card[data-v-f89845cf]{gap:13px;min-height:118px;padding:15px}.site-icon[data-v-f89845cf]{width:46px;height:46px}.site-icon img[data-v-f89845cf]{width:30px;height:30px}.site-name[data-v-f89845cf]{font-size:16px}.site-description[data-v-f89845cf]{min-height:auto;margin-bottom:10px}}.subcategory-section[data-v-5c700f43]{scroll-margin-top:106px}.subcategory-heading[data-v-5c700f43]{display:flex;align-items:center;gap:12px;margin-bottom:16px}.subcategory-title[data-v-5c700f43]{display:flex;align-items:center;gap:10px;min-width:0;margin:0;color:var(--color-heading);cursor:default}.subcategory-title .subcategory-icon[data-v-5c700f43]{display:grid;place-items:center;flex-shrink:0;width:36px;height:36px;font-size:20px;border-radius:13px;background:#ffffffb8;box-shadow:inset 0 0 0 1px #94a3b833}.subcategory-title .subcategory-name[data-v-5c700f43]{overflow:hidden;color:var(--color-heading);font-size:20px;font-weight:850;line-height:1.15;text-overflow:ellipsis;white-space:nowrap}.subcategory-count[data-v-5c700f43]{display:grid;place-items:center;min-width:28px;height:28px;padding:0 8px;color:var(--color-text-muted);font-size:12px;font-weight:800;border-radius:999px;background:#ffffffad;border:1px solid rgba(148,163,184,.2)}.sites-grid[data-v-5c700f43]{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}@media (max-width: 768px){.subcategory-section[data-v-5c700f43]{scroll-margin-top:98px}.subcategory-title .subcategory-name[data-v-5c700f43]{font-size:18px;white-space:normal}.sites-grid[data-v-5c700f43]{grid-template-columns:1fr;gap:14px}}.category-section[data-v-7cefad6f]{scroll-margin-top:106px;margin-bottom:clamp(44px,6vw,74px);animation:fadeInUp .55s var(--ease-spring)}.category-heading[data-v-7cefad6f]{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid rgba(148,163,184,.18)}.category-title[data-v-7cefad6f]{display:flex;align-items:center;gap:13px;min-width:0;margin:0;color:var(--color-heading);cursor:default}.category-title .category-icon[data-v-7cefad6f]{display:grid;place-items:center;flex-shrink:0;width:46px;height:46px;font-size:24px;border-radius:16px;background:linear-gradient(135deg,#2563eb1f,#0f766e1f);box-shadow:inset 0 1px #ffffffb8}.category-title .category-name[data-v-7cefad6f]{overflow:hidden;font-size:clamp(24px,3vw,34px);font-weight:900;line-height:1.1;text-overflow:ellipsis;white-space:nowrap}.category-count[data-v-7cefad6f]{display:inline-flex;align-items:center;flex-shrink:0;min-height:32px;padding:6px 12px;color:var(--color-text-muted);font-size:13px;font-weight:800;border:1px solid rgba(148,163,184,.22);border-radius:999px;background:#ffffffa8}.sites-grid[data-v-7cefad6f]{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}.subcategories-container[data-v-7cefad6f]{display:flex;flex-direction:column;gap:28px}.empty-category[data-v-7cefad6f]{padding:22px;text-align:center;color:var(--color-text-muted);border:1px dashed rgba(148,163,184,.38);border-radius:16px;background:#ffffff75}.empty-category p[data-v-7cefad6f]{margin:0}.dark{color:#fff}.dark{color:#cbd5e1;background:#0f172ab8;border-color:#94a3b847}@media (max-width: 768px){.category-section[data-v-7cefad6f]{scroll-margin-top:98px;margin-bottom:42px}.category-heading[data-v-7cefad6f]{align-items:flex-start;flex-direction:column;gap:10px;margin-bottom:16px}.category-title .category-icon[data-v-7cefad6f]{width:40px;height:40px;font-size:22px;border-radius:14px}.category-title .category-name[data-v-7cefad6f]{white-space:normal}.sites-grid[data-v-7cefad6f]{grid-template-columns:1fr;gap:14px}}.app-footer[data-v-7f4a1fed]{margin-top:clamp(54px,7vw,92px);padding:34px clamp(18px,4vw,42px);color:var(--color-text);background:#ffffff9e;border:1px solid rgba(148,163,184,.18);border-radius:8px;box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.footer-content[data-v-7f4a1fed]{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(260px,.8fr);gap:34px}.footer-section h3[data-v-7f4a1fed]{margin:0 0 12px;color:var(--color-heading);font-size:16px;font-weight:900}.footer-section p[data-v-7f4a1fed]{max-width:680px;margin:0;color:var(--color-text-muted);font-size:14px;line-height:1.7}.footer-links[data-v-7f4a1fed]{display:flex;flex-wrap:wrap;gap:10px}.footer-link[data-v-7f4a1fed]{display:inline-flex;align-items:center;gap:8px;min-height:38px;padding:8px 12px;color:var(--color-heading);font-size:13px;font-weight:800;text-decoration:none;background:#f1f5f9cc;border:1px solid rgba(148,163,184,.2);border-radius:8px;transition:color var(--transition-fast),transform var(--transition-fast),border-color var(--transition-fast),background-color var(--transition-fast)}.footer-link[data-v-7f4a1fed]:hover{color:var(--color-primary);background:#dbeafeb3;border-color:#2563eb3d;transform:translateY(-1px)}.footer-bottom[data-v-7f4a1fed]{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:28px;padding-top:20px;color:var(--color-text-muted);border-top:1px solid rgba(148,163,184,.18)}.footer-bottom p[data-v-7f4a1fed]{margin:0;font-size:13px;font-weight:700}@media (max-width: 768px){.app-footer[data-v-7f4a1fed]{padding:26px 18px}.footer-content[data-v-7f4a1fed]{grid-template-columns:1fr;gap:24px}.footer-bottom[data-v-7f4a1fed]{align-items:flex-start;flex-direction:column;gap:8px}}.content-area[data-v-76629a7e]{flex:1;padding:34px clamp(20px,4vw,54px) 56px;overflow-y:auto;overflow-x:hidden;width:100%;box-sizing:border-box;min-height:0;scroll-padding-top:110px}.content-area[data-v-76629a7e]::-webkit-scrollbar{width:10px}.content-area[data-v-76629a7e]::-webkit-scrollbar-track{background:transparent}.content-area[data-v-76629a7e]::-webkit-scrollbar-thumb{background:#64748b3d;border:3px solid transparent;border-radius:999px;background-clip:content-box}.content-area[data-v-76629a7e]::-webkit-scrollbar-thumb:hover{background-color:#2563eb5c}.content-shell[data-v-76629a7e]{width:min(100%,1360px);margin:0 auto;animation:fadeInUp .55s var(--ease-spring)}.content-overview[data-v-76629a7e]{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;padding:8px 2px 30px;border-bottom:1px solid rgba(148,163,184,.22)}.overview-kicker[data-v-76629a7e]{margin:0 0 10px;color:var(--color-accent);font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.content-overview h1[data-v-76629a7e]{margin:0;color:var(--color-heading);font-size:clamp(32px,5vw,58px);font-weight:900;line-height:1.02}.overview-stats[data-v-76629a7e]{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:10px;flex-shrink:0}.overview-stats span[data-v-76629a7e]{display:inline-flex;align-items:center;min-height:34px;padding:7px 13px;border:1px solid rgba(148,163,184,.24);border-radius:999px;background:#ffffffa3;color:var(--color-text-muted);font-size:13px;font-weight:700;box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.loading[data-v-76629a7e],.error[data-v-76629a7e]{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 160px);color:var(--color-text-muted)}.loading-spinner[data-v-76629a7e]{width:46px;height:46px;border:4px solid rgba(37,99,235,.12);border-top:4px solid var(--color-primary);border-radius:50%;animation:spin-76629a7e 1s linear infinite}@keyframes spin-76629a7e{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.retry-btn[data-v-76629a7e]{margin-top:10px;padding:10px 18px;background:var(--color-primary);color:#fff;border:none;border-radius:999px;cursor:pointer;box-shadow:var(--shadow-glow)}.categories-container[data-v-76629a7e]{margin:34px auto 0;width:100%;box-sizing:border-box}.dark{background:#0f172a}@media (max-width: 768px){.content-area[data-v-76629a7e]{flex:1;padding:104px 16px 72px;overflow-y:auto;-webkit-overflow-scrolling:touch}.content-overview[data-v-76629a7e]{align-items:flex-start;flex-direction:column;gap:16px;padding-bottom:24px}.overview-stats[data-v-76629a7e]{justify-content:flex-start}.categories-container[data-v-76629a7e]{margin-top:28px}}.test-page[data-v-3a514381]{padding:20px;max-width:1200px;margin:0 auto}.test-section[data-v-3a514381]{margin-bottom:40px;padding:20px;border:1px solid #ddd;border-radius:8px}.test-section h2[data-v-3a514381]{margin-top:0;color:#333}.results[data-v-3a514381]{margin-top:20px;padding:15px;background:#f8f9fa;border-radius:5px;max-height:400px;overflow-y:auto}.api-info[data-v-3a514381]{text-align:left}.api-info p[data-v-3a514381]{margin:10px 0}pre[data-v-3a514381]{background:#fff;padding:10px;border-radius:3px;overflow-x:auto;font-size:12px;line-height:1.4}button[data-v-3a514381]{padding:10px 20px;background:#007bff;color:#fff;border:none;border-radius:5px;cursor:pointer;margin-right:10px}button[data-v-3a514381]:disabled{background:#6c757d;cursor:not-allowed}button[data-v-3a514381]:hover:not(:disabled){background:#0056b3}
