*{margin:0;padding:0;box-sizing:border-box}:root{--primary-blue:#4f46e5;--secondary-blue:#F0F8FF;--light-blue:#f8fcff;--accent-orange:#ff6b35;--accent-gold:#ffa500;--text-primary:#1a1a1a;--text-secondary:#666666;--text-muted:#999999;--bg-white:#ffffff;--bg-light:#fafafa;--bg-card:#ffffff;--border-light:#e5e5e5;--border-medium:#d0d0d0;--shadow-sm:0 2px 4px rgba(0, 0, 0, 0.1);--shadow-md:0 4px 8px rgba(0, 0, 0, 0.12);--shadow-lg:0 8px 16px rgba(0, 0, 0, 0.15);--font-xs:12px;--font-sm:14px;--font-base:16px;--font-lg:18px;--font-xl:20px;--font-2xl:24px;--font-3xl:32px;--font-4xl:48px;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--spacing-2xl:48px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px}body{font-family:Inter,-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;font-size:var(--font-base);line-height:1.6;color:var(--text-primary);background-color:var(--bg-white);font-weight:400}.container{max-width:1800px;margin:0 auto;padding:0 var(--spacing-md)}.navbar{background-color:var(--bg-white);border-bottom:1px solid var(--border-light);position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm)}.navbar .container{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md)}.nav-brand{flex:1;display:flex;justify-content:center}.nav-brand h1{font-size:var(--font-3xl);font-weight:700;color:var(--primary-blue);margin:0;text-align:center;letter-spacing:.5px}.nav-auth{position:relative;display:flex;align-items:center;min-width:120px;justify-content:flex-end}.login-btn{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background-color:var(--primary-blue);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:500;cursor:pointer;transition:all .2s ease}.login-btn:hover{background-color:#3730a3;transform:translateY(-1px);box-shadow:var(--shadow-md)}.login-btn svg{width:16px;height:16px}.user-info{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);transition:background-color .2s ease}.user-info:hover{background-color:var(--bg-light)}.user-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;border:2px solid var(--border-light)}.user-name{font-size:var(--font-sm);font-weight:500;color:var(--text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-btn{background:0 0;border:none;cursor:pointer;padding:2px;color:var(--text-secondary);transition:color .2s ease}.user-menu-btn:hover{color:var(--text-primary)}.user-menu-btn svg{width:16px;height:16px}.user-dropdown{position:absolute;top:100%;right:0;margin-top:var(--spacing-sm);background-color:var(--bg-white);border:1px solid var(--border-light);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:180px;z-index:1000;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .2s ease}.user-dropdown.show{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-sm);color:var(--text-primary);cursor:pointer;transition:background-color .2s ease}.dropdown-item:hover{background-color:var(--bg-light)}.dropdown-item:first-child{border-radius:var(--radius-md) var(--radius-md) 0 0}.dropdown-item:last-child{border-radius:0 0 var(--radius-md) var(--radius-md)}.dropdown-item svg{width:16px;height:16px;color:var(--text-secondary)}.dropdown-divider{height:1px;background-color:var(--border-light);margin:var(--spacing-xs) 0}.logout-item{color:#dc2626}.logout-item:hover{background-color:#fef2f2}.logout-item svg{color:#dc2626}.navbar .search-container{position:relative;display:flex;align-items:center}.search-container{position:relative;display:flex;align-items:center}#searchInput{width:300px;padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--border-light);border-radius:var(--radius-md);font-size:var(--font-base);outline:0;transition:border-color .3s ease}#searchInput:focus{border-color:var(--primary-blue)}#searchBtn{position:absolute;right:var(--spacing-sm);background:0 0;border:none;cursor:pointer;font-size:var(--font-lg)}.comparison-btn{background-color:var(--primary-blue);color:#fff;border:none;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-base);font-weight:500;cursor:pointer;transition:all .3s ease;position:relative;width:100%;margin-top:var(--spacing-md)}.comparison-btn:hover:not(:disabled){background-color:#3d35b8;transform:translateY(-1px);box-shadow:var(--shadow-md)}.comparison-btn:disabled{background-color:var(--text-muted);cursor:not-allowed}.main-content{min-height:80vh;padding:var(--spacing-2xl) 0}.main-content .container{display:grid;grid-template-columns:280px 1fr;gap:var(--spacing-2xl);max-width:1800px;margin:0 auto;padding:0 var(--spacing-xl)}.filters-section{background-color:var(--bg-light);padding:var(--spacing-lg);border-radius:var(--radius-lg);height:fit-content;position:sticky;top:100px}.filters-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-lg);flex-wrap:wrap;gap:var(--spacing-sm)}.filters-section h2{font-size:var(--font-xl);font-weight:600;color:var(--primary-blue);margin:0}.filters-header .stats-info{display:flex;flex-direction:column;gap:var(--spacing-xs);font-size:var(--font-xs);color:var(--text-secondary);text-align:right}.filter-group{margin-bottom:var(--spacing-lg)}.filter-group>label:first-child{display:block;font-weight:500;color:var(--text-primary);margin-bottom:var(--spacing-sm);font-size:var(--font-base)}.filter-options{display:flex;flex-direction:column;gap:var(--spacing-sm)}.filters-section .filter-group .filter-options label{display:flex!important;align-items:center!important;gap:var(--spacing-sm)!important;font-size:var(--font-base)!important;color:var(--text-secondary)!important;cursor:pointer!important;transition:color .3s ease!important}.filter-options label:hover{color:var(--text-primary)}.filter-options input[type=checkbox],.filter-options input[type=radio]{accent-color:var(--primary-blue)}.reset-btn{width:100%;background-color:transparent;color:var(--primary-blue);border:2px solid var(--primary-blue);padding:var(--spacing-sm);border-radius:var(--radius-md);cursor:pointer;font-weight:500;transition:all .3s ease}.reset-btn:hover{background-color:var(--primary-blue);color:#fff}.tools-section{width:100%}.tools-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--border-light)}.tools-header h2{font-size:var(--font-3xl);font-weight:700;color:var(--primary-blue);text-align:center;flex:1}.tools-controls{display:flex;align-items:center;gap:var(--spacing-lg)}.tools-header .search-container{position:relative;display:flex;align-items:center}.view-toggles{display:flex;gap:var(--spacing-sm)}.view-btn{padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--border-medium);background-color:var(--bg-white);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-sm);font-weight:500;transition:all .3s ease}.view-btn.active,.view-btn:hover{background-color:var(--primary-blue);color:#fff;border-color:var(--primary-blue)}.tools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:var(--spacing-lg)}.tool-card{background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all .3s ease;position:relative;box-shadow:var(--shadow-sm)}.tool-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-blue)}.tool-card.selected{border-color:var(--primary-blue);border-width:2px;box-shadow:0 0 0 2px rgba(74,144,164,.1)}.tool-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md)}.tool-name{font-size:var(--font-xl);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.tool-type{background-color:var(--secondary-blue);color:var(--primary-blue);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-xs);font-weight:500}.popular-badge{background-color:var(--accent-orange);color:#fff;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-xs);font-weight:600;position:absolute;top:-8px;right:var(--spacing-md)}.tool-info{display:grid;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.info-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) 0;border-bottom:1px solid var(--border-light)}.info-row:last-child{border-bottom:none}.info-label{font-size:var(--font-sm);color:var(--text-secondary);font-weight:500}.info-value{font-size:var(--font-sm);color:var(--text-primary);font-weight:500;text-align:right}.api-support{color:#28a745;font-weight:600}.no-api-support{color:#dc3545;font-weight:600}.pricing-free{color:var(--primary-blue);font-weight:600}.pricing-paid{color:var(--accent-orange);font-weight:600}.github-stars{color:var(--text-primary);font-weight:500}.tool-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.select-btn{flex:1;padding:var(--spacing-sm);border:2px solid var(--primary-blue);background-color:transparent;color:var(--primary-blue);border-radius:var(--radius-md);cursor:pointer;font-weight:500;transition:all .3s ease}.select-btn.selected{background-color:var(--primary-blue);color:#fff}.select-btn:hover{background-color:var(--primary-blue);color:#fff}.tools-table{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border-light);background-color:var(--bg-white);margin-bottom:var(--spacing-xl)}.tools-table table{width:100%;border-collapse:collapse;table-layout:fixed;min-width:1400px}.tools-table td,.tools-table th{padding:var(--spacing-md);text-align:left;border-bottom:1px solid var(--border-light)}.tools-table th{background-color:var(--secondary-blue);color:var(--primary-blue);font-weight:600;font-size:var(--font-sm);position:relative;text-align:center;white-space:nowrap;vertical-align:middle;line-height:1.2}.tools-table th.sortable{cursor:pointer;user-select:none;transition:background-color .3s ease}.tools-table th .header-content{display:flex;align-items:center;justify-content:center;width:100%;gap:var(--spacing-xs)}.tools-table th.sortable:hover{background-color:var(--light-blue)}.tools-table th.sorted-asc,.tools-table th.sorted-desc{background-color:var(--light-blue)}.sort-indicator{font-size:var(--font-xs);margin-left:var(--spacing-xs);color:var(--text-muted)}.tools-table tr:hover{background-color:var(--light-blue)}.tools-table .tool-name-cell{font-weight:600;color:var(--primary-blue)}.tools-table .select-checkbox{accent-color:var(--primary-blue);transform:scale(1.2)}.tools-table td:first-child,.tools-table th:first-child{width:60px;text-align:center}.tools-table td:nth-child(2),.tools-table th:nth-child(2){width:160px}.tools-table td:nth-child(3),.tools-table th:nth-child(3){width:120px}.tools-table td:nth-child(4),.tools-table th:nth-child(4){width:130px;text-align:center}.tools-table td:nth-child(5),.tools-table th:nth-child(5){width:160px}.tools-table td:nth-child(6),.tools-table th:nth-child(6){width:180px}.tools-table td:nth-child(7),.tools-table th:nth-child(7){width:140px;text-align:left}.tools-table td:nth-child(8),.tools-table th:nth-child(8){width:120px}.tools-table td:nth-child(9),.tools-table th:nth-child(9){width:100px;text-align:center}.tools-table td:nth-child(10),.tools-table th:nth-child(10){width:200px;text-align:center}.tools-table td:nth-child(10){vertical-align:top;padding-top:var(--spacing-sm)}.table-notes{background-color:var(--secondary-blue);padding:var(--spacing-lg);border-radius:var(--radius-lg);margin-top:var(--spacing-xl)}.table-notes h4{color:var(--primary-blue);font-size:var(--font-lg);font-weight:600;margin-bottom:var(--spacing-md)}.table-notes p{font-size:var(--font-sm);color:var(--text-secondary);line-height:1.6;margin-bottom:var(--spacing-sm)}.table-notes p:last-child{margin-bottom:0}.table-notes a{color:var(--primary-blue);text-decoration:none;font-weight:500}.table-notes a:hover{text-decoration:underline}.table-notes strong{color:var(--text-primary);font-weight:600}.hidden{display:none!important}.modal{display:none;position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;background-color:rgba(0,0,0,.5);animation:fadeIn .3s ease}.modal-content{position:relative;background-color:var(--bg-white);margin:5% auto;padding:0;border-radius:var(--radius-lg);width:90%;max-width:1000px;max-height:80vh;overflow:hidden;box-shadow:var(--shadow-lg);animation:slideIn .3s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--border-light);background-color:var(--secondary-blue)}.modal-header h3{color:var(--primary-blue);font-size:var(--font-2xl);font-weight:600}.close-btn{background:0 0;border:none;font-size:var(--font-3xl);cursor:pointer;color:var(--text-secondary);transition:color .3s ease}.close-btn:hover{color:var(--text-primary)}.modal-body{padding:var(--spacing-lg);max-height:60vh;overflow-y:auto}.comparison-table{width:100%;border-collapse:collapse;margin-top:var(--spacing-md)}.comparison-table td,.comparison-table th{padding:var(--spacing-md);text-align:center;border:1px solid var(--border-light)}.comparison-table th{background-color:var(--secondary-blue);color:var(--primary-blue);font-weight:600}.comparison-table .feature-label{background-color:var(--light-blue);font-weight:500;text-align:left}.visualization-section{background-color:var(--bg-light);padding:var(--spacing-2xl) 0;margin-top:var(--spacing-2xl)}.visualization-section h2{text-align:center;font-size:var(--font-3xl);font-weight:700;color:var(--primary-blue);margin-bottom:var(--spacing-2xl)}.charts-container{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-xl);justify-items:center}.chart-item{background-color:var(--bg-white);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.chart-item h3{text-align:center;font-size:var(--font-lg);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-lg)}.chart-item canvas{max-height:300px}.footer{background-color:var(--secondary-blue);color:var(--text-primary);padding:var(--spacing-2xl) 0 var(--spacing-lg);margin-top:var(--spacing-2xl)}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.footer-section h4{font-size:var(--font-lg);font-weight:600;margin-bottom:var(--spacing-md);color:var(--primary-blue)}.footer-section p{font-size:var(--font-sm);line-height:1.6;color:var(--text-secondary)}.footer-section a{color:var(--primary-blue);text-decoration:none;transition:color .3s ease}.footer-section a:hover{color:var(--text-primary)}.footer-bottom{text-align:center;padding-top:var(--spacing-lg);border-top:1px solid var(--border-light)}.footer-bottom p{font-size:var(--font-sm);color:var(--text-secondary)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes slideIn{from{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-light)}::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--primary-blue)}.popular-container,.rating-container{display:flex;justify-content:center;align-items:center;gap:2px}.rating-container{flex-direction:row;align-items:center}.heart-icon{color:red;cursor:pointer;transition:transform .2s ease;font-size:1.5em}.heart-icon:hover{transform:scale(1.2)}.star-icon{color:#ffc107;cursor:pointer;transition:transform .2s ease;font-size:1.5em;position:relative;display:inline-block}.star-icon:hover{transform:scale(1.2)}.star-icon.rated{color:var(--accent-gold);font-weight:900}.star-icon.partial-25{background:linear-gradient(90deg,var(--accent-gold) 25%,#ffc107 25%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-weight:900}.star-icon.partial-50{background:linear-gradient(90deg,var(--accent-gold) 50%,#ffc107 50%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-weight:900}.star-icon.partial-75{background:linear-gradient(90deg,var(--accent-gold) 75%,#ffc107 75%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-weight:900}.star-icon.hover{color:var(--accent-gold);opacity:.6}.rating-number{font-size:var(--font-sm);color:var(--text-primary);margin-left:var(--spacing-xs);font-weight:600}.rating-info{font-size:var(--font-xs);color:var(--text-secondary);margin-top:var(--spacing-xs);font-weight:500;min-width:120px;text-align:center}.rating-combined{display:flex;justify-content:center;align-items:center;gap:var(--spacing-xs);flex-wrap:wrap}.rating-count{margin-bottom:var(--spacing-xs)}.personal-rating-info{font-size:var(--font-xs);color:var(--text-secondary);margin-top:var(--spacing-xs);font-weight:500;text-align:center;font-style:italic}.heart-icon.voted{color:red;animation:heartbeat .5s ease-in-out}.heart-icon.disabled,.popular-container.disabled .heart-icon{color:#ccc;cursor:not-allowed}.heart-icon.disabled:hover,.popular-container.disabled .heart-icon:hover{transform:none}.vote-count{font-size:var(--font-sm);color:var(--text-secondary);margin-left:var(--spacing-xs);font-weight:500}@keyframes heartbeat{0%{transform:scale(1)}50%{transform:scale(1.4)}100%{transform:scale(1)}}@keyframes star-pop{0%{transform:scale(1)}50%{transform:scale(1.5)}100%{transform:scale(1)}}.heart-icon.voted{color:#ff4f4f}#deals-section{padding:var(--spacing-2xl) 0;margin-top:var(--spacing-2xl);background-color:var(--light-blue);border-radius:var(--radius-lg)}#deals-section .container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-xl)}#deals-section h2{text-align:center;font-size:var(--font-3xl);font-weight:700;color:var(--primary-blue);margin-bottom:var(--spacing-xl)}#deals-container{display:flex;flex-wrap:wrap;gap:20px;justify-content:center}.deal-card{background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-lg);flex-basis:calc(25% - 15px);min-width:280px;transition:transform .3s ease,box-shadow .3s ease}@media (max-width:1200px){.deal-card{flex-basis:calc(33.333% - 14px)}}@media (max-width:900px){.deal-card{flex-basis:calc(50% - 10px)}}@media (max-width:600px){.deal-card{flex-basis:100%}}.deal-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}.deal-card h3{font-size:var(--font-xl);color:var(--primary-blue);margin-bottom:var(--spacing-md)}.deal-card p{font-size:var(--font-base);color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.deal-card ul{list-style-position:inside;padding-left:0;color:var(--text-secondary)}.deal-card ul li{margin-bottom:var(--spacing-xs)}.deal-description{font-size:var(--font-sm);color:var(--text-secondary);margin-bottom:var(--spacing-md);min-height:40px}.deal-link{display:inline-block;margin-top:var(--spacing-md);color:var(--accent-orange);font-weight:600;text-decoration:none;transition:color .3s}.deal-link:hover{color:#e65c00;text-decoration:underline}.deals-disclaimer{margin-top:var(--spacing-2xl);padding:var(--spacing-md) var(--spacing-lg);background-color:rgba(255,107,53,.1);border:1px solid rgba(255,107,53,.3);border-radius:var(--radius-md);text-align:center}.deals-disclaimer p{font-size:var(--font-sm);color:var(--text-secondary);margin:0;font-style:italic;line-height:1.5}.deal-card.featured{border:2px solid var(--primary-blue);background:linear-gradient(135deg,#fff 0,#f8fbff 100%)}.deal-card.featured h3{color:var(--primary-blue);font-weight:700}.deal-card.featured:hover{transform:translateY(-8px);box-shadow:0 12px 24px rgba(59,130,246,.2)}.deal-price{font-size:var(--font-lg);font-weight:700;color:var(--primary-blue);margin-bottom:var(--spacing-sm)}.deal-price .currency{font-size:var(--font-xl);color:#10b981}