@import"https://fonts.googleapis.com/css2?family=Inter:opsz,wght@14..32,300;14..32,400;14..32,500;14..32,600;14..32,700;14..32,800;14..32,900&display=swap";:root{--navy: #F9F9F7;--navy-2: #F3F3F0;--navy-3: #FFFFFF;--navy-4: #EDEDE9;--navy-5: #DDDDD8;--blue: #D77655;--blue-2: #C4623F;--blue-glow: rgba(215,118,85,.14);--teal: #4CAF50;--teal-dim: rgba(76,175,80,.1);--orange: #E8944A;--orange-dim: rgba(232,148,74,.1);--red: #D94F4F;--red-dim: rgba(217,79,79,.1);--yellow: #D4A438;--white: #1F1F1E;--text-1: #1F1F1E;--text-2: #4A4A48;--text-3: #8B8B88;--border: rgba(31,31,30,.08);--border-2: rgba(31,31,30,.13);--surface: rgba(31,31,30,.02);--surface-2: rgba(31,31,30,.05);--radius: 12px;--radius-lg: 20px;--font-display: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;--font-body: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;--font-mono: "Inter", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--navy);color:var(--text-1);min-height:100vh;-webkit-font-smoothing:antialiased;overflow-x:hidden}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--navy-2)}::-webkit-scrollbar-thumb{background:var(--navy-5);border-radius:3px}.app{display:flex;min-height:100vh}.sidebar{width:220px;min-height:100vh;background:var(--navy-2);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.sidebar-logo{padding:28px 24px 20px;border-bottom:1px solid var(--border)}.sidebar-logo .wordmark{font-family:var(--font-display);font-size:20px;font-weight:800;color:var(--white);letter-spacing:-.5px}.sidebar-logo .wordmark span{color:var(--blue-2)}.sidebar-logo .tagline{font-size:10px;color:var(--text-3);letter-spacing:.08em;text-transform:uppercase;margin-top:2px;font-family:var(--font-mono)}.sidebar-nav{padding:16px 12px;flex:1}.nav-section-label{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);font-family:var(--font-mono);padding:0 12px;margin:16px 0 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;cursor:pointer;font-size:13.5px;font-weight:500;color:var(--text-2);transition:all .15s;margin-bottom:2px;border:1px solid transparent;background:none;width:100%;text-align:left}.nav-item:hover{background:var(--surface-2);color:var(--text-1)}.nav-item.active{background:var(--blue-glow);color:var(--blue-2);border-color:#d7765533}.nav-item .nav-icon{opacity:.7;flex-shrink:0}.nav-item.active .nav-icon{opacity:1}.nav-badge{margin-left:auto;background:var(--red);color:#f9f9f7;font-size:9px;font-weight:700;padding:2px 6px;border-radius:10px;font-family:var(--font-mono)}.nav-badge.green{background:var(--teal)}.sidebar-footer{padding:16px;border-top:1px solid var(--border);font-size:11px;color:var(--text-3);font-family:var(--font-mono)}.main-content{margin-left:220px;flex:1;min-height:100vh;padding-bottom:44px}.topbar{height:60px;background:var(--navy-2);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 32px;position:sticky;top:0;z-index:50}.topbar-title{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--text-1)}.topbar-right{display:flex;align-items:center;gap:12px}.topbar-chip{font-family:var(--font-mono);font-size:10px;padding:4px 10px;border-radius:20px;border:1px solid var(--border-2);color:var(--text-3);background:var(--surface)}.page{padding:32px;animation:fadeUp .3s ease}.hackathon-footer{position:fixed;left:220px;right:0;bottom:0;height:44px;display:flex;align-items:center;justify-content:center;text-align:center;padding:0 20px;background:#f9f9f7;color:#1f1f1e;border-top:1px solid rgba(31,31,30,.13);font-size:11.5px;line-height:1.2;letter-spacing:.01em;z-index:60}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.upload-hero{max-width:680px;margin:40px auto 0;text-align:center}.upload-hero h1{font-family:var(--font-display);font-size:42px;font-weight:800;line-height:1.1;letter-spacing:-1px;color:var(--text-1);margin-bottom:14px}.upload-hero p{font-size:15px;color:var(--text-2);line-height:1.6;margin-bottom:40px}.drop-zone{border:2px dashed var(--border-2);border-radius:var(--radius-lg);padding:56px 40px;cursor:pointer;transition:all .2s;background:var(--surface);position:relative;overflow:hidden}.drop-zone:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 0%,rgba(215,118,85,.06) 0%,transparent 70%);pointer-events:none}.drop-zone:hover,.drop-zone.dragging{border-color:var(--blue);background:#d776550a}.drop-zone .drop-icon{width:64px;height:64px;border-radius:50%;background:var(--blue-glow);border:1px solid rgba(215,118,85,.25);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:var(--blue-2)}.drop-zone h3{font-family:var(--font-display);font-size:18px;font-weight:700;margin-bottom:6px}.drop-zone p{font-size:13px;color:var(--text-3);margin-bottom:20px}.drop-zone .formats{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.format-chip{font-family:var(--font-mono);font-size:11px;padding:4px 10px;border-radius:6px;background:var(--surface-2);border:1px solid var(--border-2);color:var(--text-2)}.file-preview{background:var(--navy-3);border:1px solid var(--border-2);border-radius:var(--radius);margin-top:20px;overflow:hidden}.file-preview-header{padding:14px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);background:var(--navy-4)}.file-info{display:flex;align-items:center;gap:12px}.file-icon{width:36px;height:36px;border-radius:8px;background:var(--teal-dim);display:flex;align-items:center;justify-content:center;color:var(--teal)}.file-name{font-weight:600;font-size:14px}.file-meta{font-size:12px;color:var(--text-3);font-family:var(--font-mono);margin-top:2px}.preview-table-wrap{overflow-x:auto}.preview-table{width:100%;border-collapse:collapse;font-size:12px;font-family:var(--font-mono)}.preview-table th{background:var(--navy-4);padding:8px 14px;text-align:left;color:var(--text-3);font-weight:500;white-space:nowrap;border-bottom:1px solid var(--border);font-size:11px;letter-spacing:.04em}.preview-table td{padding:7px 14px;border-bottom:1px solid var(--border);color:var(--text-2);white-space:nowrap;max-width:160px;overflow:hidden;text-overflow:ellipsis}.preview-table tr:last-child td{border-bottom:none}.preview-table tr:hover td{background:var(--surface)}.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 24px;border-radius:10px;font-family:var(--font-body);font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;border:none}.btn-primary{background:var(--blue);color:#f9f9f7;box-shadow:0 0 24px #d7765540}.btn-primary:hover{background:var(--blue-2);box-shadow:0 0 32px #d7765559;transform:translateY(-1px)}.btn-secondary{background:var(--surface-2);color:var(--text-1);border:1px solid var(--border-2)}.btn-secondary:hover{background:var(--navy-4)}.btn-ghost{background:none;color:var(--text-2);border:1px solid var(--border)}.btn-ghost:hover{color:var(--text-1);border-color:var(--border-2)}.btn-danger{background:var(--red-dim);color:var(--red);border:1px solid rgba(217,79,79,.2)}.btn-success{background:var(--teal-dim);color:var(--teal);border:1px solid rgba(76,175,80,.2)}.btn-sm{padding:7px 14px;font-size:12px}.btn-full{width:100%;justify-content:center}.score-section{display:grid;grid-template-columns:260px 1fr;gap:20px;margin-bottom:24px}.score-card{background:var(--navy-3);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden}.score-card:before{content:"";position:absolute;top:-40px;left:50%;transform:translate(-50%);width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(215,118,85,.08) 0%,transparent 70%);pointer-events:none}.score-ring-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);margin-bottom:12px}.score-number{font-family:var(--font-display);font-size:72px;font-weight:800;line-height:1;letter-spacing:-3px}.score-number.green{color:var(--teal);text-shadow:0 0 40px rgba(76,175,80,.3)}.score-number.yellow{color:var(--yellow);text-shadow:0 0 40px rgba(212,164,56,.3)}.score-number.red{color:var(--red);text-shadow:0 0 40px rgba(217,79,79,.3)}.score-label{font-family:var(--font-display);font-size:13px;font-weight:600;margin-top:6px}.score-label.green{color:var(--teal)}.score-label.yellow{color:var(--yellow)}.score-label.red{color:var(--red)}.score-sublabel{font-size:11px;color:var(--text-3);margin-top:4px;font-family:var(--font-mono)}.dimension-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}.dim-card{background:var(--navy-3);border:1px solid var(--border);border-radius:var(--radius);padding:16px;transition:all .2s;cursor:pointer}.dim-card:hover{border-color:var(--border-2);background:var(--navy-4)}.dim-card .dim-label{font-size:10px;font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);margin-bottom:8px}.dim-card .dim-score{font-family:var(--font-display);font-size:28px;font-weight:800;margin-bottom:6px}.dim-progress{height:3px;background:var(--navy-5);border-radius:2px;overflow:hidden;margin-top:8px}.dim-progress-fill{height:100%;border-radius:2px;transition:width .8s cubic-bezier(.34,1.56,.64,1)}.issue-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}.issue-chip{background:var(--navy-3);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;display:flex;align-items:center;gap:14px}.issue-chip .chip-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.issue-chip .chip-count{font-family:var(--font-display);font-size:24px;font-weight:800}.issue-chip .chip-label{font-size:12px;color:var(--text-3);margin-top:2px}.panel-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.filter-chip{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text-2);transition:all .15s;font-family:var(--font-body)}.filter-chip:hover{border-color:var(--border-2);color:var(--text-1)}.filter-chip.active{background:var(--blue-glow);border-color:#d776554d;color:var(--blue-2)}.search-box{flex:1;min-width:200px;background:var(--navy-3);border:1px solid var(--border);border-radius:8px;padding:8px 14px;color:var(--text-1);font-family:var(--font-body);font-size:13px;outline:none;transition:border-color .15s}.search-box:focus{border-color:var(--blue)}.search-box::placeholder{color:var(--text-3)}.issues-table-wrap{background:var(--navy-3);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.issues-table{width:100%;border-collapse:collapse;font-size:13px}.issues-table th{background:var(--navy-4);padding:12px 16px;text-align:left;color:var(--text-3);font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid var(--border);font-family:var(--font-mono);white-space:nowrap}.issues-table td{padding:12px 16px;border-bottom:1px solid var(--border);vertical-align:middle}.issues-table tr:last-child td{border-bottom:none}.issues-table tr:hover td{background:var(--surface)}.severity-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;font-family:var(--font-mono);white-space:nowrap}.severity-badge.critical{background:var(--red-dim);color:var(--red);border:1px solid rgba(217,79,79,.2)}.severity-badge.warning{background:var(--orange-dim);color:var(--orange);border:1px solid rgba(232,148,74,.2)}.severity-badge.minor{background:var(--teal-dim);color:var(--teal);border:1px solid rgba(76,175,80,.2)}.col-name{font-family:var(--font-mono);font-size:12px;color:var(--blue-2);background:var(--blue-glow);padding:3px 8px;border-radius:5px}.issue-type{font-family:var(--font-mono);font-size:11px;color:var(--text-2)}.diagnosis-text{font-size:12px;color:var(--text-2);line-height:1.5;max-width:360px}.fix-status{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-family:var(--font-mono)}.fix-status.fixed{color:var(--teal)}.fix-status.pending{color:var(--text-3)}.ai-row{background:var(--navy-2);border-bottom:1px solid var(--border)}.ai-diagnosis-box{margin:0 16px 12px;padding:14px 16px;background:linear-gradient(135deg,#d776550f,#4caf500a);border:1px solid rgba(215,118,85,.15);border-radius:10px;font-size:12.5px;color:var(--text-1);line-height:1.7}.ai-badge{display:inline-flex;align-items:center;gap:5px;font-size:10px;font-family:var(--font-mono);letter-spacing:.06em;color:var(--blue-2);background:var(--blue-glow);border:1px solid rgba(215,118,85,.2);padding:3px 8px;border-radius:4px;margin-bottom:8px;text-transform:uppercase}.column-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.column-card{background:var(--navy-3);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:all .2s}.column-card:hover{border-color:var(--blue);transform:translateY(-2px);box-shadow:0 8px 32px #0000004d}.column-card-header{padding:14px 16px;background:var(--navy-4);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.col-type-chip{font-size:10px;font-family:var(--font-mono);padding:2px 8px;border-radius:4px;background:var(--surface-2);color:var(--text-3);border:1px solid var(--border)}.column-card-body{padding:14px 16px}.col-stat-row{display:flex;justify-content:space-between;margin-bottom:8px}.col-stat{text-align:center}.col-stat .stat-val{font-family:var(--font-display);font-size:18px;font-weight:700}.col-stat .stat-label{font-size:10px;color:var(--text-3);font-family:var(--font-mono)}.report-layout{display:grid;grid-template-columns:1fr 340px;gap:24px}.cert-preview{background:var(--navy-3);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.cert-cover{background:linear-gradient(160deg,#edede9,#f3f3f0,#f9f9f7);padding:36px 32px;border-bottom:1px solid var(--border);position:relative;overflow:hidden}.cert-cover:before{content:"";position:absolute;top:-60px;right:-60px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(215,118,85,.1) 0%,transparent 70%)}.cert-score-badge{width:76px;height:76px;border-radius:50%;border:3px solid var(--teal);display:flex;align-items:center;justify-content:center;flex-direction:column;box-shadow:0 0 32px #4caf5033;margin-bottom:18px}.cert-score-badge .score{font-family:var(--font-display);font-size:24px;font-weight:800;color:var(--teal);line-height:1}.cert-score-badge .score-sub{font-size:9px;color:var(--teal);font-family:var(--font-mono)}.cert-title{font-family:var(--font-display);font-size:20px;font-weight:800;margin-bottom:4px}.cert-subtitle{font-size:12px;color:var(--text-3);font-family:var(--font-mono)}.cert-section{padding:18px 24px;border-bottom:1px solid var(--border)}.cert-section-title{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);font-family:var(--font-mono);margin-bottom:10px}.cert-row{display:flex;justify-content:space-between;margin-bottom:8px;font-size:13px}.cert-row .label{color:var(--text-3)}.cert-row .value{font-weight:600;color:var(--text-1)}.report-actions{display:flex;flex-direction:column;gap:12px}.action-card{background:var(--navy-3);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.action-card h3{font-family:var(--font-display);font-size:15px;font-weight:700;margin-bottom:6px}.action-card p{font-size:12.5px;color:var(--text-3);line-height:1.5;margin-bottom:14px}.page-header{margin-bottom:28px}.page-header h2{font-family:var(--font-display);font-size:26px;font-weight:800;letter-spacing:-.5px}.page-header p{font-size:13.5px;color:var(--text-3);margin-top:4px}.page-header .breadcrumb{font-size:11px;color:var(--text-3);font-family:var(--font-mono);margin-bottom:6px;display:flex;align-items:center;gap:6px}.card{background:var(--navy-3);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.loading-bar{height:3px;background:var(--navy-4);border-radius:2px;overflow:hidden;margin:8px 0}.loading-bar-fill{height:100%;background:linear-gradient(90deg,var(--blue) 0%,var(--blue-2) 100%);border-radius:2px;animation:loadBar 2s ease infinite}@keyframes loadBar{0%{width:0%;margin-left:0%}50%{width:60%;margin-left:20%}to{width:0%;margin-left:100%}}.analyzing-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center}.analyzing-spinner{width:60px;height:60px;border:3px solid var(--navy-4);border-top-color:var(--blue);border-right-color:var(--blue-2);border-radius:50%;animation:spin .9s linear infinite;margin-bottom:24px}@keyframes spin{to{transform:rotate(360deg)}}.analyzing-steps{margin-top:20px;display:flex;flex-direction:column;gap:8px}.analyzing-step{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-2);font-family:var(--font-mono)}.step-dot{width:8px;height:8px;border-radius:50%;background:var(--navy-5);flex-shrink:0;transition:background .3s}.step-dot.done{background:var(--teal);box-shadow:0 0 8px #4caf5059}.step-dot.active{background:var(--blue);animation:pulse 1s ease infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.empty-state{text-align:center;padding:60px 20px;color:var(--text-3)}.empty-state .empty-icon{width:56px;height:56px;border-radius:14px;background:var(--surface);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:var(--text-3)}.empty-state h3{font-family:var(--font-display);font-size:16px;color:var(--text-2);margin-bottom:6px}.empty-state p{font-size:13px}@keyframes slideIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.slide-in{animation:slideIn .2s ease}
