@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";
*{box-sizing:border-box;margin:0;padding:0}:root{--gradient-primary:linear-gradient(135deg, #0ea5e9 0%, #0284c7 100%);--gradient-secondary:linear-gradient(135deg, #06b6d4 0%, #0891b2 100%);--gradient-accent:linear-gradient(135deg, #10b981 0%, #059669 100%);--gradient-success:linear-gradient(135deg, #10b981 0%, #34d399 100%);--gradient-warning:linear-gradient(135deg, #f59e0b 0%, #fbbf24 100%);--color-water:#0ea5e9;--color-water-dark:#0284c7;--color-cyan:#06b6d4;--color-accent:#10b981;--color-accent-light:#34d399;--color-neutral:#64748b;--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-water:#0ea5e90d;--bg-card:#ffffff0d;--bg-glass:#ffffff1a;--text-primary:#fff;--text-secondary:#fffc;--text-muted:#fff9;--border-glass:#fff3;--border-glow:#0ea5e966;--shadow-sm:0 2px 8px #0003;--shadow-md:0 4px 16px #0000004d;--shadow-lg:0 8px 32px #0006;--shadow-glow:0 0 20px #0ea5e933;--shadow-glow-strong:0 0 40px #0ea5e94d;--radius-sm:8px;--radius:12px;--radius-md:16px;--radius-lg:24px;--radius-xl:32px;--spacing-xs:.5rem;--spacing-sm:1rem;--spacing-md:1.5rem;--spacing-lg:2rem;--spacing-xl:3rem;--spacing-2xl:4rem;--transition:all .3s cubic-bezier(.4, 0, .2, 1);--transition-fast:all .15s cubic-bezier(.4, 0, .2, 1)}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:var(--bg-primary);color:var(--text-primary);background-image:radial-gradient(at 0 0,#0ea5e914 0,#0000 50%),radial-gradient(at 100% 0,#06b6d40f 0,#0000 50%),radial-gradient(at 100% 100%,#10b9810f 0,#0000 50%),radial-gradient(at 0 100%,#0ea5e914 0,#0000 50%),repeating-linear-gradient(0deg,#0000,#0000 2px,#0ea5e905 2px 4px);background-attachment:fixed;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;line-height:1.6;position:relative;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;opacity:.6;background:radial-gradient(circle at 20%,#0ea5e90f 0%,#0000 50%),radial-gradient(circle at 80% 80%,#06b6d40a 0%,#0000 50%),radial-gradient(circle at 50% 20%,#10b98108 0%,#0000 50%);position:fixed;inset:0}.app-container{z-index:1;flex-direction:column;min-height:100vh;display:flex;position:relative}.app-header{-webkit-backdrop-filter:blur(20px)saturate(180%);padding:var(--spacing-lg) 0;z-index:100;background:#0f172af2;border-bottom:1px solid #0ea5e933;position:sticky;top:0;box-shadow:0 4px 24px #0000004d,inset 0 0 0 1px #0ea5e91a}.header-content{max-width:1200px;padding:0 var(--spacing-lg);margin:0 auto}.header-content h1{color:#fff;letter-spacing:-.03em;text-shadow:0 2px 12px #00000080,0 0 20px #0ea5e94d;align-items:center;gap:.75rem;margin-bottom:.5rem;font-size:36px;font-weight:800;line-height:1.1;display:flex;position:relative}.header-content h1:before{content:"💧";filter:drop-shadow(0 2px 8px #0ea5e980);font-size:32px;display:inline-block}.header-content p{color:#fff;letter-spacing:-.01em;opacity:.95;text-shadow:0 1px 4px #0000004d;font-size:17px;font-weight:400}.app-main{width:100%;max-width:1200px;padding:var(--spacing-xl) var(--spacing-lg);z-index:1;flex:1;margin:0 auto;position:relative}.requirements-container{-webkit-backdrop-filter:blur(20px)saturate(180%);border-radius:var(--radius-xl);border:1px solid var(--border-glass);box-shadow:var(--shadow-lg), 0 0 0 1px #ffffff0d inset;background:#1a1f3a99;padding:0;position:relative;overflow:hidden}.requirements-container:before{content:"";background:var(--gradient-primary);opacity:.8;height:2px;position:absolute;top:0;left:0;right:0}.requirements-header{padding:var(--spacing-xl) var(--spacing-lg);border-bottom:1px solid var(--border-glass);background:#ffffff05;position:relative}.requirements-header h2{color:var(--text-primary);margin-bottom:var(--spacing-sm);letter-spacing:-.02em;text-shadow:0 2px 8px #0000004d;font-size:32px;font-weight:700}.subtitle{color:var(--text-secondary);font-size:15px;line-height:1.6}.active-filters-badge{align-items:center;gap:var(--spacing-xs);background:var(--gradient-primary);color:#fff;margin-top:var(--spacing-md);box-shadow:var(--shadow-glow);border:1px solid #fff3;border-radius:9999px;padding:.625rem 1.25rem;font-size:13px;font-weight:600;animation:2s ease-in-out infinite pulse;display:inline-flex}@keyframes pulse{0%,to{box-shadow:var(--shadow-glow)}50%{box-shadow:var(--shadow-glow-strong)}}.filters-container{padding:var(--spacing-lg);gap:var(--spacing-xl);flex-direction:column;display:flex}.filter-card{-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-glass);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:var(--transition);background:#ffffff0d;position:relative;overflow:hidden}.filter-card:before{content:"";background:var(--gradient-primary);opacity:0;transition:opacity var(--transition);pointer-events:none;position:absolute;inset:0}.filter-card:hover{border-color:var(--border-glow);box-shadow:var(--shadow-glow);background:#ffffff14;transform:translateY(-4px)}.filter-card:hover:before{opacity:.05}.filter-card-header{align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);z-index:1;display:flex;position:relative}.filter-icon{background:var(--gradient-primary);border-radius:var(--radius-md);width:56px;height:56px;box-shadow:var(--shadow-glow);z-index:1;justify-content:center;align-items:center;font-size:28px;display:flex;position:relative}.filter-card-header h3{color:var(--text-primary);letter-spacing:-.02em;margin:0;font-size:22px;font-weight:700}.filter-description{color:var(--text-muted);margin-top:.25rem;font-size:14px}.filter-card-content{gap:var(--spacing-lg);z-index:1;flex-direction:column;display:flex;position:relative}.filter-row{gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));display:grid}.filter-group{gap:var(--spacing-sm);flex-direction:column;display:flex}.filter-group label{align-items:center;gap:var(--spacing-xs);color:var(--text-primary);letter-spacing:-.01em;font-size:14px;font-weight:600;display:flex}.info-tooltip{cursor:pointer;background:var(--gradient-accent);color:#fff;width:20px;height:20px;transition:var(--transition-fast);box-shadow:var(--shadow-sm);margin-left:var(--spacing-xs);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:11px;font-weight:700;display:inline-flex}.info-tooltip:hover{box-shadow:var(--shadow-glow);transform:scale(1.15)}.filter-group select{border:1px solid var(--border-glass);border-radius:var(--radius);-webkit-backdrop-filter:blur(10px);color:var(--text-primary);transition:var(--transition);cursor:pointer;appearance:none;background:#ffffff0d url("data:image/svg+xml,%3Csvg width='14' height='9' viewBox='0 0 14 9' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L7 7.5L13 1.5' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") right 1rem center no-repeat;padding:1rem 2.75rem 1rem 1.25rem;font-family:inherit;font-size:15px;font-weight:400}.filter-group select:hover{border-color:var(--color-water);box-shadow:var(--shadow-sm);background:#ffffff14}.filter-group select:focus{border-color:var(--color-water);box-shadow:0 0 0 4px #0ea5e926, var(--shadow-glow);outline:none}.chip-group{gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.chip{border:1px solid var(--border-glass);border-radius:var(--radius);-webkit-backdrop-filter:blur(10px);color:var(--text-primary);cursor:pointer;transition:var(--transition);text-align:left;background:#ffffff0d;flex-direction:column;align-items:flex-start;min-width:150px;padding:1rem 1.25rem;font-family:inherit;font-size:14px;font-weight:500;display:inline-flex;position:relative;overflow:hidden}.chip:before{content:"";background:var(--gradient-primary);opacity:.1;width:100%;height:100%;transition:left .3s;position:absolute;top:0;left:-100%}.chip:hover{border-color:var(--color-water);box-shadow:var(--shadow-glow);background:#ffffff1a;transform:translateY(-2px)}.chip:hover:before{left:0}.chip.selected{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-glow);border-color:#0000;transform:translateY(-2px)}.chip.selected:before{display:none}.chip-label{z-index:1;font-weight:600;line-height:1.4;position:relative}.chip-desc{opacity:.8;z-index:1;margin-top:.25rem;font-size:12px;font-weight:400;line-height:1.4;position:relative}.chip.selected .chip-desc{opacity:1}.actions-bar{padding:var(--spacing-lg);border-top:1px solid var(--border-glass);-webkit-backdrop-filter:blur(10px);justify-content:space-between;align-items:center;gap:var(--spacing-md);background:#ffffff05;display:flex}.btn{border-radius:var(--radius);cursor:pointer;transition:var(--transition);align-items:center;gap:var(--spacing-xs);letter-spacing:-.01em;border:none;padding:1rem 2rem;font-family:inherit;font-size:16px;font-weight:600;display:inline-flex;position:relative;overflow:hidden}.btn:before{content:"";background:linear-gradient(90deg,#0000,#fff3,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.btn:hover:before{left:100%}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-glow);border:1px solid #fff3}.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-glow-strong);transform:translateY(-2px)}.btn-secondary{-webkit-backdrop-filter:blur(10px);color:var(--text-primary);border:1px solid var(--border-glass);background:#ffffff0d}.btn-secondary:hover:not(:disabled){border-color:var(--color-water);box-shadow:var(--shadow-sm);background:#ffffff1a}.btn-badge{background:#ffffff40;border-radius:12px;padding:.25rem .625rem;font-size:12px;font-weight:700}.results-container{-webkit-backdrop-filter:blur(20px)saturate(180%);border-radius:var(--radius-xl);border:1px solid var(--border-glass);box-shadow:var(--shadow-lg), 0 0 0 1px #ffffff0d inset;background:#1a1f3a99;padding:0;position:relative;overflow:hidden}.results-container:before{content:"";background:var(--gradient-primary);opacity:.8;height:2px;position:absolute;top:0;left:0;right:0}.results-header{padding:var(--spacing-lg);border-bottom:1px solid var(--border-glass);background:#ffffff05}.back-button{color:var(--color-water);cursor:pointer;padding:var(--spacing-xs) 0;margin-bottom:var(--spacing-md);transition:var(--transition);align-items:center;gap:var(--spacing-xs);background:0 0;border:none;font-family:inherit;font-size:14px;font-weight:600;display:inline-flex}.back-button:hover{color:var(--color-cyan);transform:translate(-4px)}.results-title-section h2{color:var(--text-primary);margin:0 0 var(--spacing-xs);letter-spacing:-.02em;text-shadow:0 2px 8px #0000004d;font-size:32px;font-weight:700}.results-subtitle{color:var(--text-secondary);font-size:15px}.section-title{color:var(--text-primary);margin:0 0 var(--spacing-lg);padding:0 var(--spacing-lg);letter-spacing:-.02em;font-size:24px;font-weight:700}.section-title:first-child{margin-top:0}.results-grid{gap:var(--spacing-lg);padding:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(360px,1fr));display:grid}.tech-card{-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-glass);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:var(--transition);background:#ffffff0d;flex-direction:column;display:flex;position:relative;overflow:hidden}.tech-card:before{content:"";background:var(--gradient-primary);opacity:0;transition:opacity var(--transition);pointer-events:none;position:absolute;inset:0}.tech-card:hover{border-color:var(--border-glow);box-shadow:var(--shadow-glow);background:#ffffff14;transform:translateY(-6px)}.tech-card:hover:before{opacity:.05}.tech-card.top-result{border-color:var(--color-water);box-shadow:var(--shadow-glow-strong);background:linear-gradient(135deg,#0ea5e91f 0%,#06b6d414 100%)}.rank-badge{top:-14px;left:var(--spacing-lg);background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-glow);letter-spacing:.02em;z-index:1;border:1px solid #fff3;border-radius:9999px;padding:.5rem 1rem;font-size:12px;font-weight:700;position:absolute}.tech-card-header{margin-bottom:var(--spacing-md);justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);z-index:1;display:flex;position:relative}.tech-card-header h3{color:var(--text-primary);letter-spacing:-.02em;flex:1;margin:0;font-size:22px;font-weight:700;line-height:1.3}.match-score{z-index:1;flex-direction:column;flex-shrink:0;align-items:center;gap:.25rem;display:flex;position:relative}.score-circle{border:3px solid;border-image:var(--gradient-primary) 1;-webkit-backdrop-filter:blur(10px);width:64px;height:64px;box-shadow:var(--shadow-sm);background:#ffffff0d;border-radius:50%;justify-content:center;align-items:center;font-size:16px;font-weight:700;display:flex}.match-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:700}.match-explanation{-webkit-backdrop-filter:blur(10px);padding:var(--spacing-md);border-radius:var(--radius);margin-bottom:var(--spacing-md);border-left:4px solid;border-image:var(--gradient-primary) 1;z-index:1;background:#ffffff0d;position:relative}.match-explanation p{color:var(--text-secondary);margin:0;font-size:14px;line-height:1.6}.tech-specs{gap:var(--spacing-sm);margin-bottom:var(--spacing-md);z-index:1;grid-template-columns:repeat(2,1fr);display:grid;position:relative}.spec-item{padding:var(--spacing-sm) var(--spacing-md);-webkit-backdrop-filter:blur(5px);border-radius:var(--radius-sm);background:#ffffff08;border:1px solid #ffffff1a;justify-content:space-between;align-items:center;display:flex}.spec-label{color:var(--text-muted);font-size:13px;font-weight:500}.spec-value{color:var(--text-primary);font-size:13px;font-weight:600}.expand-button{width:100%;padding:var(--spacing-sm);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-glass);border-radius:var(--radius);color:var(--text-primary);cursor:pointer;transition:var(--transition);margin-top:var(--spacing-xs);z-index:1;background:#ffffff0d;font-family:inherit;font-size:14px;font-weight:600;position:relative}.expand-button:hover{border-color:var(--color-water);box-shadow:var(--shadow-sm);background:#ffffff1a}.tech-details{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--border-glass);gap:var(--spacing-md);z-index:1;flex-direction:column;display:flex;position:relative}.detail-section h4{color:var(--text-primary);margin-bottom:var(--spacing-md);letter-spacing:-.01em;font-size:16px;font-weight:700}.match-list{gap:var(--spacing-md);flex-direction:column;display:flex}.match-tag{margin-bottom:var(--spacing-xs);font-size:13px;font-weight:700;display:block}.match-item{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);margin-right:var(--spacing-xs);margin-bottom:var(--spacing-xs);font-size:13px;font-weight:600;display:inline-block}.match-item.exact{color:#43e97b;background:#43e97b33;border:1px solid #43e97b4d}.match-item.partial{color:var(--color-water);background:#0ea5e926;border:1px solid #0ea5e940}.match-item.unmatched{color:#ef4444;background:#ef444433;border:1px solid #ef44444d}.match-tag.exact{color:#10b981}.match-tag.partial{color:var(--color-water)}.match-tag.unmatched{color:#ef4444}.spec-grid{gap:var(--spacing-sm);flex-direction:column;display:flex}.spec-row{padding:var(--spacing-sm) var(--spacing-md);-webkit-backdrop-filter:blur(5px);border-radius:var(--radius-sm);background:#ffffff08;border:1px solid #ffffff1a;justify-content:space-between;align-items:center;display:flex}.no-results{text-align:center;padding:var(--spacing-2xl) var(--spacing-lg)}.no-results-icon{margin-bottom:var(--spacing-lg);opacity:.5;font-size:72px}.no-results h3{color:var(--text-primary);margin-bottom:var(--spacing-md);letter-spacing:-.02em;font-size:26px;font-weight:700}.no-results p{color:var(--text-secondary);margin-bottom:var(--spacing-xl);max-width:500px;margin-left:auto;margin-right:auto;font-size:16px;line-height:1.6}.top-results{margin-bottom:var(--spacing-xl)}.other-results{margin-top:var(--spacing-lg)}@media (max-width:640px){.app-main{padding:var(--spacing-sm)}.header-content{padding:var(--spacing-md) var(--spacing-sm)}.header-content h1{align-items:flex-start;gap:var(--spacing-xs);flex-direction:column;font-size:24px}.header-content h1:before{font-size:24px}.header-content p{font-size:14px}.requirements-container,.results-container{border-radius:var(--radius-lg)}.requirements-header,.results-header{padding:var(--spacing-md) var(--spacing-sm)}.requirements-header h2{font-size:22px}.filters-container{padding:var(--spacing-md) var(--spacing-sm);gap:var(--spacing-md)}.filter-card{padding:var(--spacing-md)}.filter-card-header{margin-bottom:var(--spacing-md)}.filter-icon{width:44px;height:44px;font-size:22px}.filter-card-header h3{font-size:18px}.filter-row{gap:var(--spacing-sm);grid-template-columns:1fr}.chip{min-width:100%}.chip-group{flex-direction:column}.actions-bar{padding:var(--spacing-md) var(--spacing-sm);gap:var(--spacing-sm);flex-direction:column-reverse}.btn{width:100%;padding:var(--spacing-md) var(--spacing-lg);justify-content:center}.results-grid{gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-sm);grid-template-columns:1fr}.section-title{padding:0 var(--spacing-sm);font-size:20px}.tech-card{padding:var(--spacing-md)}.tech-card-header{align-items:flex-start;gap:var(--spacing-sm);flex-direction:column}.tech-card-header h3{font-size:18px}.score-circle{width:56px;height:56px;font-size:14px}.tech-specs{grid-template-columns:1fr}.active-filters-badge{padding:.5rem .875rem;font-size:12px}}@media (max-width:768px){.app-main{padding:var(--spacing-md)}.header-content{padding:var(--spacing-md) var(--spacing-md)}.header-content h1{font-size:28px}.requirements-header,.filters-container,.actions-bar,.results-header,.results-grid,.section-title{padding-left:var(--spacing-md);padding-right:var(--spacing-md)}.filter-row,.results-grid{grid-template-columns:1fr}.tech-card-header{flex-direction:column;align-items:flex-start}.actions-bar{flex-direction:column-reverse}.btn{justify-content:center;width:100%}}@media (min-width:769px) and (max-width:1024px){.results-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}}@supports (padding:max(0px)){.app-header,.app-main{padding-left:max(var(--spacing-lg), env(safe-area-inset-left));padding-right:max(var(--spacing-lg), env(safe-area-inset-right))}.app-header{padding-top:max(var(--spacing-lg), env(safe-area-inset-top))}}@media (hover:none) and (pointer:coarse){.btn,.chip,.filter-group select,.expand-button{min-height:44px}.info-tooltip{min-width:44px;min-height:44px}}.modal-overlay{-webkit-backdrop-filter:blur(4px);z-index:1000;padding:var(--spacing-md);background:#000000b3;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-secondary);-webkit-backdrop-filter:blur(20px)saturate(180%);border:1px solid var(--border-glass);border-radius:var(--radius-lg);width:100%;max-width:600px;max-height:80vh;box-shadow:var(--shadow-xl);animation:.3s slideUp;position:relative;overflow-y:auto}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:var(--spacing-lg);border-bottom:1px solid var(--border-glass);-webkit-backdrop-filter:blur(10px);z-index:1;background:#1e293bf2;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.modal-header h3{color:var(--text-primary);letter-spacing:-.02em;margin:0;font-size:22px;font-weight:700}.modal-close{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);width:32px;height:32px;transition:var(--transition);background:0 0;border:none;justify-content:center;align-items:center;padding:0;font-size:32px;line-height:1;display:flex}.modal-close:hover{color:var(--text-primary);background:#ffffff1a}.modal-body{padding:var(--spacing-lg)}.modal-description{color:var(--text-secondary);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-glass);font-size:15px;line-height:1.6}.modal-options{gap:var(--spacing-md);flex-direction:column;display:flex}.modal-option{gap:var(--spacing-xs);padding:var(--spacing-md);border-radius:var(--radius);border:1px solid var(--border-glass);background:#ffffff08;flex-direction:column;display:flex}.modal-option strong{color:var(--text-primary);letter-spacing:-.01em;font-size:15px;font-weight:600}.modal-option span{color:var(--text-secondary);font-size:14px;line-height:1.5}@media (max-width:640px){.modal-content{max-width:100%;margin:var(--spacing-sm);max-height:90vh}.modal-header,.modal-body{padding:var(--spacing-md)}.modal-header h3{font-size:20px}}
