code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#0f172a,#1e293b 50%,#0f172a);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;min-height:100vh;padding:0}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1f29374d}::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#4b5563,#6b7280);border:1px solid #4b55634d;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#6b7280,#9ca3af)}.monaco-editor,.monaco-editor .margin{background-color:#1e1e1e!important}input:focus{box-shadow:0 0 0 3px #3b82f64d,0 0 20px #3b82f61a;outline:none}.glass-effect{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#1f293799;border:1px solid #4b556333;box-shadow:0 8px 32px #0000004d}.gradient-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;background-clip:text}.fade-in{animation:fadeIn .6s ease-out}.slide-up{animation:slideUp .6s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.glow{box-shadow:0 0 20px #3b82f64d}.h-screen{height:100vh}.flex{display:flex}.flex-col{flex-direction:column}.flex-1{flex:1 1}.items-center{align-items:center}.justify-center{justify-content:center}.space-x-1>*+*{margin-left:.25rem}.space-x-6>*+*{margin-left:1.5rem}.space-x-2>*+*{margin-left:.5rem}.space-y-2>*+*{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-2{margin-top:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.ml-auto{margin-left:auto}.max-w-md{max-width:28rem}.max-w-7xl{max-width:80rem}.mx-auto{margin-left:auto;margin-right:auto}.w-80{width:20rem}.w-24{width:6rem}.h-24{height:6rem}.w-4{width:1rem}.h-4{height:1rem}.h-full{height:100%}.h-32{height:8rem}.h-1\/2{height:50%}.h-1\/4{height:25%}.h-3\/4{height:75%}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.border-r{border-right:1px solid}.border-b{border-bottom:1px solid}.border-gray-700{border-color:#374151}.bg-gray-900{background:linear-gradient(135deg,#0f172a,#1e293b 50%,#0f172a)}.bg-gray-800{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#1f2937cc;border:1px solid #4b556333}.bg-gray-700{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#374151cc;border:1px solid #4b55634d}.bg-gray-600{background-color:#4b5563}.bg-blue-600{background:linear-gradient(135deg,#2563eb,#3b82f6);overflow:hidden;position:relative}.bg-blue-700{background:linear-gradient(135deg,#1d4ed8,#2563eb)}.bg-blue-800{background:linear-gradient(135deg,#1e3a8a,#1e40af)}.hover\:bg-blue-700:hover{background:linear-gradient(135deg,#1d4ed8,#2563eb);box-shadow:0 4px 12px #2563eb66;transform:translateY(-1px)}.hover\:bg-gray-700:hover{background-color:#374151}.disabled\:bg-blue-800:disabled{background-color:#1e3a8a}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.transition-colors{transition-duration:.15s;transition-property:background-color,border-color,color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1)}.text-white{color:#fff}.text-gray-300{color:#d1d5db}.text-gray-400{color:#9ca3af}.text-gray-500{color:#6b7280}.text-red-400{color:#f87171}.text-yellow-400{color:#fbbf24}.text-blue-400{color:#60a5fa}.text-purple-400{color:#c084fc}.text-green-400{color:#4ade80}.text-orange-500{color:#f97316}.text-blue-300{color:#93c5fd}.text-gray-600{color:#4b5563}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-2xl{font-size:1.5rem;line-height:2rem}.font-medium{font-weight:500}.font-bold{font-weight:700}.font-mono{font-family:ui-monospace,SFMono-Regular,SF Mono,Consolas,Liberation Mono,Menlo,monospace}.rounded-lg{border-radius:.5rem}.rounded{border-radius:.25rem}.p-4{padding:1rem}.p-2{padding:.5rem}.px-4{padding-left:1rem;padding-right:1rem}.px-2{padding-left:.5rem;padding-right:.5rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.py-1{padding-bottom:.25rem;padding-top:.25rem}.cursor-pointer{cursor:pointer}.text-center{text-align:center}.rotate-90{transform:rotate(90deg)}.cursor-not-allowed{cursor:not-allowed}.animate-spin{animation:spin 1s linear infinite}.file-tree-item{align-items:center;border-radius:.25rem;cursor:pointer;display:flex;padding:.25rem .5rem;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1)}.file-tree-item:hover{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#37415199;transform:translateX(2px)}.file-tree-item.selected{background:linear-gradient(135deg,#2563eb33,#8b5cf633);border-left:3px solid #3b82f6;font-weight:500}.file-tree-level-0{padding-left:2rem}.file-tree-level-1{padding-left:3rem}.file-tree-level-2{padding-left:4rem}.file-tree-level-3{padding-left:5rem}.form-input{background-color:#374151;border:1px solid #4b5563;border-radius:.5rem;color:#fff;flex:1 1;outline:none;padding:.5rem 1rem}.form-input:focus{border-color:#3b82f6}.btn{background-color:#2563eb;border:none;border-radius:.5rem;color:#fff;cursor:pointer;padding:.5rem 1.5rem;transition:background-color .15s}.btn:hover{background-color:#1d4ed8}.btn:disabled{background-color:#1e3a8a;cursor:not-allowed}.repo-info,.repo-info-item{align-items:center;display:flex}.repo-info-item{gap:.25rem}.repo-info-item .label{color:#9ca3af}.repo-info-item .value{color:#fff;font-weight:500}.landing-page{background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);color:#fff;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;min-height:100vh}.navbar{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#1a1a2ecc;border-bottom:1px solid #ffffff1a;left:0;padding:20px 0;position:fixed;right:0;top:0;z-index:1000}.nav-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 40px}.nav-brand .brand-text{color:#fff;font-size:24px;font-weight:700}.nav-links{display:flex;gap:30px}.nav-link{background:#ffffff1a;border-radius:8px;color:#fff;font-weight:500;padding:10px 20px;text-decoration:none;transition:all .3s ease}.nav-link:hover{background:#fff3;transform:translateY(-2px)}.hero-section{align-items:center;display:flex;justify-content:center;min-height:100vh;padding:120px 40px 80px;position:relative}.hero-content{max-width:1200px;text-align:center;width:100%}.hero-title{color:#fff;font-size:48px;font-weight:700;line-height:1.2;margin-bottom:20px;opacity:.95}.hero-subtitle{color:#ffffffd9;font-size:20px;font-weight:400;line-height:1.6;margin-bottom:40px;margin-left:auto;margin-right:auto;max-width:800px}.alternatives-section{margin-bottom:40px;opacity:.9}.alternatives-text{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;color:#ffffffb3;display:inline-block;font-size:16px;margin:0;padding:20px}.alternatives-text strong{color:#4a9eff;font-weight:600}.terminal{background:#1e1e1e;border:1px solid #ffffff1a;border-radius:12px;box-shadow:0 25px 50px #0000004d;margin:0 auto;max-width:600px;overflow:hidden}.terminal-header{align-items:center;background:#2d2d2d;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;padding:12px 20px}.terminal-controls{display:flex;gap:8px}.terminal-dot{border-radius:50%;height:12px;width:12px}.terminal-dot-red{background:#ff5f56}.terminal-dot-yellow{background:#ffbd2e}.terminal-dot-green{background:#27c93f}.terminal-title{color:#ccc;font-size:14px}.terminal-content,.terminal-title{font-family:Monaco,Courier New,monospace}.terminal-content{font-size:16px;padding:30px 20px}.terminal-prompt{align-items:center;display:flex;gap:10px}.prompt-symbol{color:#27c93f;font-weight:700}.prompt-text{color:#fff}.terminal-output{animation:typewriter 2s steps(4) 1s both;color:#27c93f;font-size:14px;line-height:1.8;margin-top:15px;padding-left:20px;text-align:left}@keyframes typewriter{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.features-section{margin:0 auto;max-width:1200px;padding:100px 40px}.features-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.feature-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:16px;padding:40px 30px;transition:all .3s ease}.feature-card:hover{background:#ffffff14;border-color:#fff3;box-shadow:0 20px 40px #0003;transform:translateY(-8px)}.feature-header{gap:16px;margin-bottom:20px}.feature-header,.feature-icon{align-items:center;display:flex}.feature-icon{background:#ffffff1a;border-radius:12px;font-size:28px;height:50px;justify-content:center;width:50px}.feature-title{color:#fff;font-size:20px;font-weight:600;margin:0}.feature-description{color:#fffc;font-size:16px;line-height:1.6;margin:0}@media (max-width:768px){.nav-container{padding:0 20px}.hero-section{padding:100px 20px 60px}.hero-title{font-size:32px;line-height:1.3}.hero-subtitle{font-size:18px}.alternatives-section,.hero-subtitle{margin-bottom:30px}.alternatives-text{font-size:14px;padding:15px}.terminal{margin:0 20px;max-width:100%}.features-section{padding:60px 20px}.features-grid{gap:20px;grid-template-columns:1fr}.feature-card{padding:30px 20px}}@media (max-width:480px){.hero-title{font-size:28px}.hero-subtitle{font-size:16px;margin-bottom:25px}.alternatives-text{font-size:13px;line-height:1.5;padding:12px}.terminal-content{font-size:14px;padding:20px 15px}.feature-header{flex-direction:column;gap:12px;text-align:center}.feature-icon{height:60px;width:60px}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.hero-title{animation:fadeInUp .8s ease-out}.terminal{animation:fadeInUp 1s ease-out .2s both}.feature-card{animation:fadeInUp .8s ease-out both}.feature-card:first-child{animation-delay:.1s}.feature-card:nth-child(2){animation-delay:.2s}.feature-card:nth-child(3){animation-delay:.3s}.feature-card:nth-child(4){animation-delay:.4s}.feature-card:nth-child(5){animation-delay:.5s}.feature-card:nth-child(6){animation-delay:.6s}.feedback-trigger{bottom:30px;position:fixed;right:30px;z-index:1000}.feedback-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50px;box-shadow:0 4px 15px #667eea66;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;padding:15px 25px;transition:all .3s ease}.feedback-button:hover{box-shadow:0 6px 20px #667eea99;transform:translateY(-2px)}.feedback-button:active{transform:translateY(0)}.feedback-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:2000}.feedback-modal{animation:slideIn .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 40px #00000026;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.feedback-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:24px 24px 20px}.feedback-header h3{color:#1f2937;font-size:20px;font-weight:600;margin:0}.close-button{background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;font-size:24px;padding:4px;transition:all .2s ease}.close-button:hover{background:#f3f4f6;color:#374151}.feedback-form{padding:24px}.form-group{margin-bottom:20px}.form-group label{color:#374151;display:block;font-size:14px;font-weight:500;margin-bottom:6px}.form-group input,.form-group textarea{border:1px solid #d1d5db;border-radius:8px;box-sizing:border-box;font-size:14px;padding:12px 16px;transition:all .2s ease;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group textarea{font-family:inherit;min-height:120px;resize:vertical}.error-message,.success-message{animation:fadeIn .3s ease;border-radius:8px;font-size:14px;margin-bottom:20px;padding:12px 16px}.success-message{background:#d1fae5;border:1px solid #a7f3d0;color:#065f46}.error-message{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.cancel-button,.submit-button{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.cancel-button{background:#f3f4f6;color:#6b7280}.cancel-button:hover{background:#e5e7eb;color:#4b5563}.submit-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;min-width:100px}.submit-button:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.submit-button:disabled{cursor:not-allowed;opacity:.6;transform:none}@media (max-width:640px){.feedback-trigger{bottom:20px;right:20px}.feedback-button{font-size:14px;padding:12px 20px}.feedback-overlay{padding:16px}.feedback-modal{max-height:95vh}.feedback-header{padding:20px 20px 16px}.feedback-form{padding:20px}.form-actions{flex-direction:column}.cancel-button,.submit-button{padding:12px;width:100%}}.language-switcher{align-items:center;display:flex;gap:8px}.lang-button{background:none;border:none;border-radius:6px;color:#ffffffb3;cursor:pointer;font-size:14px;font-weight:500;padding:6px 12px;transition:all .2s ease}.lang-button:hover{background:#ffffff1a;color:#fff}.lang-button.active{background:#ffffff26;color:#fff;font-weight:600}.lang-separator{color:#ffffff4d;font-size:14px}@media (max-width:768px){.language-switcher{gap:6px}.lang-button{font-size:13px;padding:4px 8px}}.loading-card{justify-content:center;min-height:200px}.loading-card,.loading-content{align-items:center;display:flex}.loading-content{flex-direction:column;gap:16px;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #3b82f633;border-radius:50%;border-top-color:#3b82f6;height:40px;width:40px}.loading-progress{margin-top:8px}.progress-dots{display:flex;gap:4px}.progress-dots span{animation:bounce 1.4s ease-in-out infinite both;background:#3b82f6;border-radius:50%;height:6px;width:6px}.progress-dots span:first-child{animation-delay:-.32s}.progress-dots span:nth-child(2){animation-delay:-.16s}.file-info{display:flex;flex-direction:column;gap:12px}.info-row{align-items:center;border-bottom:1px solid #4b556333;display:flex;justify-content:space-between;padding:8px 0}.info-row:last-child{border-bottom:none}.info-label{color:#9ca3af;font-size:12px;font-weight:500}.info-value{color:#f9fafb;font-size:12px;font-weight:600;max-width:60%;text-align:right;word-break:break-word}.code-stats{display:flex;flex-direction:column;gap:12px}.analysis-result{max-height:300px;overflow-y:auto;padding-right:8px}.analysis-result::-webkit-scrollbar{width:4px}.analysis-result::-webkit-scrollbar-track{background:#1f293733;border-radius:2px}.analysis-result::-webkit-scrollbar-thumb{background:#3b82f680;border-radius:2px}.analysis-result::-webkit-scrollbar-thumb:hover{background:#3b82f6b3}.analysis-tools{margin-top:20px}.tools-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr}.tool-card{cursor:pointer;padding:12px;text-align:center;transition:all .2s ease}.tool-card:hover{box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.tool-icon{font-size:20px;margin-bottom:6px}.tool-name{color:#f9fafb;font-size:11px;font-weight:600;margin-bottom:2px}.tool-desc{color:#9ca3af;font-size:10px;line-height:1.3}.empty-state{padding:32px 16px;text-align:center}.empty-icon{font-size:48px;margin-bottom:16px;opacity:.6}.quick-actions{border-top:1px solid #4b556333;margin-top:20px;padding-top:16px}.action-buttons{display:flex;flex-direction:column;gap:8px}.action-btn{justify-content:flex-start;text-align:left}@media (max-width:768px){.tools-grid{grid-template-columns:1fr}.info-row{align-items:flex-start;flex-direction:column;gap:4px}.info-value{max-width:100%;text-align:left}.action-buttons{flex-direction:row}.action-btn{flex:1 1}}.analysis-content .professional-card{animation:slideInRight .4s ease-out}@keyframes slideInRight{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}.status-indicator{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.tool-card:hover .tool-icon{transform:scale(1.1)}.tool-card:hover .tool-name{color:#3b82f6}.analysis-content::-webkit-scrollbar{width:6px}.analysis-content::-webkit-scrollbar-track{background:#1f29371a;border-radius:3px}.analysis-content::-webkit-scrollbar-thumb{background:#3b82f64d;border-radius:3px}.analysis-content::-webkit-scrollbar-thumb:hover{background:#3b82f680}.professional-button:before{background:#ffffff1a;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0}.professional-button:hover:before{height:300px;width:300px}.professional-button:focus{outline:2px solid #3b82f680;outline-offset:2px}.loading-content{animation:pulse 2s infinite}.metric-card{overflow:hidden;position:relative}.metric-card:after{background:linear-gradient(90deg,#0000,#ffffff1a,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.metric-card:hover:after{left:100%}.professional-card--elevated{box-shadow:0 1px 3px #0000001f,0 1px 2px #0000003d,0 0 0 1px #ffffff0d}.professional-card--elevated:hover{box-shadow:0 14px 28px #00000040,0 10px 10px #00000038,0 0 0 1px #ffffff1a}.professional-card--glass{background:#ffffff0d}.professional-card--gradient{position:relative}.professional-card--gradient:before{background:linear-gradient(45deg,#0000 30%,#ffffff1a 50%,#0000 70%);bottom:0;content:"";left:0;position:absolute;right:0;top:0;transform:translateX(-100%);transition:transform .6s}.professional-card--gradient:hover:before{transform:translateX(100%)}.custom-scrollbar::-webkit-scrollbar{width:6px}.custom-scrollbar::-webkit-scrollbar-track{background:#1f293766;border-radius:3px;margin:4px 0}.custom-scrollbar::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#3b82f699,#9333ea99);border-radius:3px;-webkit-transition:background .2s;transition:background .2s}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#3b82f6cc,#9333eacc)}.custom-scrollbar{scrollbar-color:#3b82f699 #1f293766;scrollbar-width:thin}:root{--card-bg:#1f293780;--card-border:#4b55634d;--card-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--card-hover-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;--primary-blue:#3b82f6;--primary-blue-hover:#2563eb;--primary-gradient:linear-gradient(135deg,#667eea,#764ba2);--text-primary:#f9fafb;--text-secondary:#d1d5db;--text-tertiary:#9ca3af;--border-color:#4b55634d;--bg-elevated:#37415180;--transition-base:all 0.3s cubic-bezier(0.4,0,0.2,1);--transition-fast:all 0.15s ease}.professional-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1f293780;background:var(--card-bg);border:1px solid #4b55634d;border:1px solid var(--card-border);border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--card-shadow);overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition-base)}.professional-card--glass{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#1f293740;border:1px solid #ffffff1a}.professional-card--elevated{background:#37415180;background:var(--bg-elevated);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.professional-card--gradient{background:linear-gradient(135deg,#6366f11a,#8b5cf61a);border:1px solid #8b5cf633}.professional-card--hover:hover,.professional-card--hovered{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--card-hover-shadow);transform:translateY(-2px)}.professional-card--padding-sm{padding:12px}.professional-card--padding-md{padding:16px}.professional-card--padding-lg{padding:24px}.professional-card__header{align-items:center;border-bottom:1px solid #4b55634d;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.professional-card__title-group{align-items:center;display:flex;gap:8px}.professional-card__icon{align-items:center;color:#3b82f6;color:var(--primary-blue);display:flex;height:24px;justify-content:center;width:24px}.professional-card__title{color:#f9fafb;color:var(--text-primary);font-size:14px;font-weight:600;letter-spacing:.5px;margin:0;text-transform:uppercase}.professional-card__action{align-items:center;display:flex}.professional-card__content{color:#d1d5db;color:var(--text-secondary)}.professional-button{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-family:inherit;font-weight:500;gap:8px;justify-content:center;overflow:hidden;position:relative;transition:all .15s ease;transition:var(--transition-fast)}.professional-button:disabled{cursor:not-allowed;opacity:.5}.professional-button--primary{background:#3b82f6;background:var(--primary-blue);color:#fff}.professional-button--primary:hover:not(:disabled){background:#2563eb;background:var(--primary-blue-hover);box-shadow:0 4px 12px #3b82f666;transform:translateY(-1px)}.professional-button--secondary{background:#6b728033;border:1px solid #4b55634d;border:1px solid var(--border-color);color:#f9fafb;color:var(--text-primary)}.professional-button--secondary:hover:not(:disabled){background:#6b72804d;border-color:#3b82f6;border-color:var(--primary-blue)}.professional-button--gradient{background:linear-gradient(135deg,#667eea,#764ba2);background:var(--primary-gradient);color:#fff}.professional-button--gradient:hover:not(:disabled){box-shadow:0 4px 20px #667eea66;transform:translateY(-1px)}.professional-button--ghost{background:#0000;color:#d1d5db;color:var(--text-secondary)}.professional-button--ghost:hover:not(:disabled){background:#6b72801a;color:#f9fafb;color:var(--text-primary)}.professional-button--danger{background:#ef444433;border:1px solid #ef44444d;color:#ef4444}.professional-button--danger:hover:not(:disabled){background:#ef44444d;border-color:#ef4444}.professional-button--size-sm{border-radius:6px;font-size:12px;padding:6px 12px}.professional-button--size-md{font-size:14px;padding:8px 16px}.professional-button--size-lg{border-radius:10px;font-size:16px;padding:12px 24px}.professional-button--loading{pointer-events:none}.professional-button__spinner{height:16px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:16px}.professional-button__icon{align-items:center;display:flex;justify-content:center}.professional-button__text{position:relative;z-index:1}.status-indicator{align-items:center;gap:6px}.status-indicator,.status-indicator--dot{display:inline-flex}.status-indicator__dot{border-radius:50%;height:8px;position:relative;width:8px}.status-indicator__pulse{animation:pulse 2s infinite;border-radius:50%;height:100%;left:0;position:absolute;top:0;width:100%}.status-indicator--success .status-indicator__dot,.status-indicator--success .status-indicator__pulse{background:#10b981}.status-indicator--warning .status-indicator__dot,.status-indicator--warning .status-indicator__pulse{background:#f59e0b}.status-indicator--error .status-indicator__dot,.status-indicator--error .status-indicator__pulse{background:#ef4444}.status-indicator--info .status-indicator__dot,.status-indicator--info .status-indicator__pulse{background:#3b82f6}.status-indicator--loading .status-indicator__dot{background:#6b7280}.status-indicator__content{align-items:center;display:flex;gap:8px}.status-indicator__spinner{height:16px;width:16px}.status-indicator__text{font-size:12px;font-weight:500}.status-indicator--badge{background:#1f2937cc;border:1px solid #4b55634d;border:1px solid var(--border-color);border-radius:12px;padding:4px 8px}.status-indicator--full{background:#1f2937cc;border:1px solid #4b55634d;border:1px solid var(--border-color);border-radius:8px;padding:8px 12px;width:100%}@keyframes pulse{0%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.5)}to{opacity:1;transform:scale(1)}}.progress-bar{width:100%}.progress-bar__header{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.progress-bar__label{color:#d1d5db;color:var(--text-secondary);font-size:12px;font-weight:500}.progress-bar__percentage{color:#f9fafb;color:var(--text-primary);font-size:12px;font-weight:600}.progress-bar__track{background:#6b728033;border-radius:3px;height:6px;overflow:hidden;position:relative}.progress-bar--size-sm .progress-bar__track{border-radius:2px;height:4px}.progress-bar--size-lg .progress-bar__track{border-radius:4px;height:8px}.progress-bar__fill{background:#3b82f6;background:var(--primary-blue);border-radius:inherit;height:100%;left:0;position:absolute;top:0;transition:width .3s ease}.progress-bar--color-green .progress-bar__fill{background:#10b981}.progress-bar--color-yellow .progress-bar__fill{background:#f59e0b}.progress-bar--color-red .progress-bar__fill{background:#ef4444}.progress-bar--color-purple .progress-bar__fill{background:#8b5cf6}.progress-bar--gradient .progress-bar__fill{background:linear-gradient(135deg,#667eea,#764ba2);background:var(--primary-gradient)}.progress-bar--gradient .progress-bar__gradient{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#fff3,#0000);height:100%;left:0;position:absolute;top:0;width:100%}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.metric-card{background:#1f293780;background:var(--card-bg);border:1px solid #4b55634d;border:1px solid var(--card-border);border-radius:12px;padding:16px;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition-base)}.metric-card:hover{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--card-hover-shadow);transform:translateY(-2px)}.metric-card--gradient{background:linear-gradient(135deg,#6366f11a,#8b5cf61a);border:1px solid #8b5cf633}.metric-card--glass{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#1f293740;border:1px solid #ffffff1a}.metric-card__header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.metric-card__title-group{align-items:center;display:flex;gap:8px}.metric-card__icon{align-items:center;background:#6366f11a;border-radius:8px;color:#3b82f6;color:var(--primary-blue);display:flex;height:32px;justify-content:center;width:32px}.metric-card__title{color:#d1d5db;color:var(--text-secondary);font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.metric-card__change{align-items:center;display:flex;font-size:12px;font-weight:600;gap:4px}.metric-card__change--increase{color:#10b981}.metric-card__change--decrease{color:#ef4444}.metric-card__change--neutral{color:#9ca3af;color:var(--text-tertiary)}.metric-card__change-icon{font-size:10px}.metric-card__value{color:#f9fafb;color:var(--text-primary);font-size:24px;font-weight:700;margin-bottom:4px}.metric-card--size-sm .metric-card__value{font-size:20px}.metric-card--size-lg .metric-card__value{font-size:28px}.metric-card__description{color:#9ca3af;color:var(--text-tertiary);font-size:12px}.tabs{width:100%}.tabs__nav{background:#1f29374d;border-bottom:1px solid #4b55634d;border-bottom:1px solid var(--border-color);border-radius:8px 8px 0 0;display:flex;overflow-x:auto}.tabs__tab{align-items:center;background:#0000;border:none;color:#d1d5db;color:var(--text-secondary);cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:12px 16px;position:relative;transition:all .15s ease;transition:var(--transition-fast);white-space:nowrap}.tabs__tab:hover{background:#6b72801a;color:#f9fafb;color:var(--text-primary)}.tabs__tab--active{background:#3b82f61a;color:#3b82f6;color:var(--primary-blue)}.tabs__tab-icon{display:flex;height:16px;width:16px}.tabs__tab-badge,.tabs__tab-icon{align-items:center;justify-content:center}.tabs__tab-badge{background:#ef4444cc;border-radius:9px;color:#fff;display:inline-flex;font-size:10px;font-weight:600;height:18px;min-width:18px;padding:0 6px}.tabs__content{background:#1f293780;background:var(--card-bg);border:1px solid #4b55634d;border:1px solid var(--border-color);border-radius:0 0 8px 8px;border-top:none;padding:16px}.tabs--pills .tabs__nav{background:#0000;border:none;border-radius:0}.tabs--pills .tabs__tab{background:#6b728033;border:1px solid #4b55634d;border:1px solid var(--border-color);border-radius:20px;margin-right:8px}.tabs--pills .tabs__tab:hover{background:#6b72804d}.tabs--pills .tabs__tab--active{background:#3b82f6;background:var(--primary-blue);border-color:#3b82f6;border-color:var(--primary-blue);color:#fff}.tabs--underline .tabs__nav{background:#0000;border-bottom:2px solid #4b55634d;border-bottom:2px solid var(--border-color)}.tabs--underline .tabs__tab{border:none;border-bottom:2px solid #0000;margin-bottom:-2px}.tabs--underline .tabs__tab--active{background:#0000;border-bottom-color:#3b82f6;border-bottom-color:var(--primary-blue)}@media (max-width:768px){.professional-card--padding-lg{padding:16px}.professional-button--size-lg{font-size:14px;padding:10px 20px}.metric-card__value{font-size:20px}.tabs__tab{font-size:12px;padding:8px 12px}.tabs__content{padding:12px}}.code-analysis-dashboard{margin:0 auto;max-width:100%;width:100%}.dashboard-overview{margin-bottom:24px}.dashboard-header{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1f293799;border:1px solid #4b55634d;border-radius:12px;display:flex;justify-content:space-between;margin-bottom:20px;padding:16px 20px}.dashboard-title{align-items:center;display:flex;gap:12px}.dashboard-title h2{color:#f9fafb;font-size:20px;font-weight:600;margin:0}.metrics-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:24px}@media (max-width:768px){.metrics-grid{gap:12px;grid-template-columns:1fr}}.analysis-loading{align-items:center;display:flex;flex-direction:column;padding:40px 20px;text-align:center}.analysis-loading__animation{align-items:center;display:flex;height:80px;justify-content:center;margin-bottom:24px;position:relative;width:80px}.analysis-loading__spinner{animation:spin 1s linear infinite;border:3px solid #3b82f633;border-radius:50%;border-top-color:#3b82f6;height:60px;width:60px}.analysis-loading__dots{bottom:0;display:flex;gap:4px;left:50%;position:absolute;transform:translateX(-50%)}.analysis-loading__dots span{animation:bounce 1.4s ease-in-out infinite both;background:#3b82f6;border-radius:50%;height:8px;width:8px}.analysis-loading__dots span:first-child{animation-delay:-.32s}.analysis-loading__dots span:nth-child(2){animation-delay:-.16s}.analysis-loading__text h4{color:#f9fafb;font-size:18px;font-weight:600;margin-bottom:8px}.analysis-loading__text p{color:#9ca3af;font-size:14px;line-height:1.5;margin-bottom:16px}.analysis-error{align-items:center;display:flex;flex-direction:column;padding:40px 20px;text-align:center}.analysis-error__icon{font-size:48px;margin-bottom:16px}.analysis-error h4{color:#ef4444;font-size:18px;font-weight:600;margin-bottom:8px}.analysis-error p{color:#9ca3af;font-size:14px;margin-bottom:20px}.analysis-empty{align-items:center;display:flex;flex-direction:column;padding:40px 20px;text-align:center}.analysis-empty__icon{font-size:48px;margin-bottom:16px;opacity:.6}.analysis-empty h4{color:#9ca3af;font-size:16px;font-weight:600;margin-bottom:8px}.analysis-empty p{color:#6b7280;font-size:14px}.tab-content{color:#e5e7eb;line-height:1.6}.tab-content h4{align-items:center;color:#f9fafb;display:flex;font-size:16px;font-weight:600;gap:8px;margin-bottom:16px}.summary-section{margin-bottom:32px}.summary-section p{background:#3b82f60d;border-left:4px solid #3b82f6;border-radius:8px;color:#d1d5db;font-size:14px;line-height:1.7;padding:16px}.quality-scores{margin-bottom:32px}.scores-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.score-item{background:#1f293766;border:1px solid #4b55634d;border-radius:8px;padding:16px}.score-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.score-header span:first-child{color:#d1d5db;font-size:14px;font-weight:500}.score-header span:last-child{font-size:14px;font-weight:600}.components-list{display:flex;flex-direction:column;gap:12px}.component-item{align-items:center;background:#1f293766;border:1px solid #4b55634d;border-radius:8px;display:flex;gap:12px;padding:16px;transition:all .2s ease}.component-item:hover{background:#1f293799;border-color:#3b82f64d;transform:translateY(-1px)}.component-icon{flex-shrink:0;font-size:20px}.component-info{flex:1 1}.component-info h5{color:#f9fafb;font-size:14px;font-weight:600;margin:0 0 4px}.component-info p{color:#9ca3af;font-size:12px;line-height:1.4;margin:0}.patterns-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.pattern-card{transition:all .2s ease}.pattern-card:hover{box-shadow:0 8px 25px #0003;transform:translateY(-2px)}.pattern-header{align-items:center;display:flex;gap:8px;margin-bottom:8px}.pattern-icon{font-size:16px}.pattern-header h5{color:#f9fafb;font-size:14px;font-weight:600;margin:0}.pattern-card p{color:#9ca3af;font-size:12px;line-height:1.4;margin:0}.issues-section,.recommendations-section{margin-bottom:24px}.issues-list,.recommendations-list{display:flex;flex-direction:column;gap:8px}.issue-item{align-items:flex-start;border-radius:6px;display:flex;font-size:14px;gap:8px;line-height:1.5;padding:12px}.issue-item.warning{background:#f59e0b1a;border:1px solid #f59e0b33;color:#fbbf24}.issue-item.error{background:#ef44441a;border:1px solid #ef444433;color:#f87171}.issue-icon{flex-shrink:0;font-size:14px;margin-top:2px}.recommendation-item{align-items:flex-start;background:#10b9811a;border:1px solid #10b98133;border-radius:6px;color:#34d399;display:flex;font-size:14px;gap:8px;line-height:1.5;padding:12px}.recommendation-icon{flex-shrink:0;font-size:14px;margin-top:2px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}@media (max-width:768px){.dashboard-header{align-items:flex-start;flex-direction:column;gap:12px;padding:12px 16px}.dashboard-title h2{font-size:18px}.patterns-grid,.scores-grid{grid-template-columns:1fr}.analysis-empty,.analysis-error,.analysis-loading{padding:24px 16px}.analysis-loading__animation{height:60px;width:60px}.analysis-loading__spinner{height:40px;width:40px}}@media print{.code-analysis-dashboard{background:#fff;color:#000}.component-item,.metric-card,.professional-card,.score-item{background:#fff;border:1px solid #ccc;box-shadow:none}.component-info h5,.dashboard-title h2,.pattern-header h5,.tab-content h4{color:#000}.component-info p,.pattern-card p,.tab-content p{color:#333}}
/*# sourceMappingURL=main.dcced085.css.map*/