@import "https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@300;400;500;700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#2563eb;--primary-dark:#1d4ed8;--surface:#fff;--bg:#f1f5f9;--text:#1e293b;--text-muted:#64748b;--border:#e2e8f0;--radius:12px;--shadow:0 4px 24px #00000014}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:Noto Sans KR,sans-serif}.app{min-height:100vh}.taxonomy-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:1.5rem;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.taxonomy-modal{background:var(--surface,#fff);border-radius:16px;flex-direction:column;width:100%;max-width:780px;max-height:85vh;animation:.3s slideUp;display:flex;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}.taxonomy-modal-header{border-bottom:1px solid var(--border,#e5e7eb);flex-shrink:0;justify-content:space-between;align-items:center;padding:1.5rem 1.75rem;display:flex}.taxonomy-modal-header h2{color:var(--text,#1f2937);align-items:center;gap:.5rem;margin:0;font-size:1.25rem;font-weight:700;display:flex}.taxonomy-modal-header h2 .header-icon{font-size:1.3rem}.taxonomy-modal-subtitle{color:var(--text-muted,#6b7280);margin:.25rem 0 0;font-size:.85rem;font-weight:400}.taxonomy-close-btn{border:1px solid var(--border,#e5e7eb);width:36px;height:36px;color:var(--text-muted,#6b7280);cursor:pointer;background:0 0;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.2rem;transition:all .15s;display:flex}.taxonomy-close-btn:hover{color:var(--text,#1f2937);background:#f3f4f6}.severity-legend{border-bottom:1px solid var(--border,#e5e7eb);flex-wrap:wrap;flex-shrink:0;gap:1rem;padding:.75rem 1.75rem;display:flex}.severity-legend-item{color:var(--text-muted,#6b7280);align-items:center;gap:.35rem;font-size:.8rem;display:flex}.taxonomy-modal-body{flex:1;padding:1rem 1.75rem 1.5rem;overflow-y:auto}.taxonomy-category{border:1px solid var(--border,#e5e7eb);border-radius:10px;margin-bottom:.75rem;transition:box-shadow .2s;overflow:hidden}.taxonomy-category:last-child{margin-bottom:0}.taxonomy-category.open{border-color:#3b82f64d;box-shadow:0 2px 8px #3b82f61a}.taxonomy-category-header{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:.75rem;width:100%;padding:.85rem 1rem;font-family:inherit;transition:background .15s;display:flex}.taxonomy-category-header:hover{background:#3b82f60a}.category-code{color:#fff;background:var(--primary,#3b82f6);white-space:nowrap;border-radius:6px;flex-shrink:0;padding:.2rem .5rem;font-size:.75rem;font-weight:700}.category-title{color:var(--text,#1f2937);flex:1;font-size:.95rem;font-weight:600}.category-count{color:var(--text-muted,#6b7280);white-space:nowrap;background:#f3f4f6;border-radius:10px;padding:.15rem .5rem;font-size:.75rem}.category-chevron{color:var(--text-muted,#6b7280);flex-shrink:0;font-size:.8rem;transition:transform .2s}.taxonomy-category.open .category-chevron{transform:rotate(180deg)}.taxonomy-category-content{padding:0 1rem 1rem;animation:.2s slideUp}.category-definition{color:var(--text-muted,#6b7280);border-left:3px solid var(--primary,#3b82f6);background:#f9fafb;border-radius:6px;margin-bottom:.75rem;padding:.5rem .75rem;font-size:.85rem;line-height:1.5}.taxonomy-table{border-collapse:separate;border-spacing:0;border:1px solid var(--border,#e5e7eb);border-radius:8px;width:100%;font-size:.85rem;overflow:hidden}.taxonomy-table thead th{text-align:left;color:var(--text-muted,#6b7280);text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid var(--border,#e5e7eb);background:#f9fafb;padding:.6rem .75rem;font-size:.78rem;font-weight:600}.taxonomy-table tbody td{color:var(--text,#1f2937);vertical-align:top;border-bottom:1px solid #f3f4f6;padding:.6rem .75rem;line-height:1.5}.taxonomy-table tbody tr:last-child td{border-bottom:none}.taxonomy-table tbody tr:hover{background:#3b82f608}.taxonomy-table .col-id{white-space:nowrap;color:var(--primary,#3b82f6);width:85px;font-family:SF Mono,Consolas,monospace;font-size:.78rem;font-weight:600}.taxonomy-table .col-name{width:160px;font-weight:500}.taxonomy-table .col-severity{text-align:center;width:55px}.taxonomy-table .col-example{color:var(--text-muted,#6b7280);font-size:.82rem}.severity-badge{letter-spacing:.02em;border-radius:4px;justify-content:center;align-items:center;padding:.15rem .45rem;font-size:.7rem;font-weight:700;display:inline-flex}.severity-badge.s1{color:#dc2626;background:#fef2f2;border:1px solid #fecaca}.severity-badge.s2{color:#d97706;background:#fffbeb;border:1px solid #fde68a}.severity-badge.s3{color:#0284c7;background:#f0f9ff;border:1px solid #bae6fd}@media (width<=640px){.taxonomy-modal-overlay{align-items:flex-end;padding:.5rem}.taxonomy-modal{border-radius:16px 16px 0 0;max-height:92vh}.taxonomy-modal-header{padding:1.25rem 1rem}.taxonomy-modal-body{padding:.75rem 1rem 1.25rem}.severity-legend{gap:.6rem;padding:.6rem 1rem}.taxonomy-table .col-name{width:auto}.taxonomy-table .col-example{display:none}.taxonomy-category-header{padding:.75rem .8rem}}.upload-page{flex-direction:column;min-height:100vh;display:flex}.upload-header{text-align:center;background:var(--surface);border-bottom:1px solid var(--border);padding:3rem 1rem 2rem}.logo{justify-content:center;align-items:center;gap:.6rem;margin-bottom:.5rem;display:flex}.logo-mark{background:var(--primary);color:#fff;border-radius:10px;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.5rem;font-weight:700;display:flex}.logo-text{color:var(--text);font-size:1.8rem;font-weight:700}.tagline{color:var(--text-muted);font-size:.95rem}.principles-box{text-align:left;background-color:#3b82f60d;border:1px solid #3b82f633;border-radius:8px;max-width:600px;margin:1.5rem auto 0;padding:1.2rem 1.5rem}.principles-title{font-weight:700;color:var(--text)!important;margin-bottom:.8rem!important;font-size:1.05rem!important}.principles-box p{color:var(--text-muted);margin-bottom:.5rem;font-size:.95rem;line-height:1.6}.principles-box p:last-child{margin-bottom:0}.principles-box strong{color:var(--primary)}.header-actions{flex-wrap:wrap;justify-content:center;align-items:center;gap:1rem;margin-top:1.2rem;display:flex}.taxonomy-open-btn{color:var(--primary);cursor:pointer;background:#3b82f614;border:1.5px solid #3b82f640;border-radius:10px;align-items:center;gap:.4rem;padding:.7rem 1.5rem;font-family:inherit;font-size:.95rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.taxonomy-open-btn:hover{border-color:var(--primary);background:#3b82f626;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f626}.upload-main{flex-direction:column;flex:1;align-items:center;gap:2.5rem;padding:3rem 1rem;display:flex}.drop-zone{text-align:center;cursor:pointer;background:linear-gradient(#f8fafc 0%,#eff6ff 100%);border:2.5px dashed #93c5fd;border-radius:16px;width:100%;max-width:560px;padding:4rem 2rem;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008}.drop-zone:hover,.drop-zone.dragging{border-color:var(--primary);background:linear-gradient(#eff6ff 0%,#dbeafe 100%);transform:translateY(-4px);box-shadow:0 10px 15px -3px #3b82f626,0 4px 6px -2px #3b82f61a}.drop-icon{margin-bottom:1.2rem;font-size:3.5rem;transition:transform .3s;display:inline-block}.drop-zone:hover .drop-icon{transform:scale(1.1)translateY(-5px)}.drop-title{color:var(--text);margin-bottom:.5rem;font-size:1.25rem;font-weight:700}.drop-hint{color:var(--text-muted);margin-bottom:1.5rem;font-size:.95rem}.upload-btn{color:#fff;background-color:var(--primary);cursor:pointer;border:none;border-radius:9999px;justify-content:center;align-items:center;padding:.75rem 1.75rem;font-size:1rem;font-weight:600;transition:background-color .2s,transform .2s;display:inline-flex;box-shadow:0 4px 6px -1px #3b82f64d}.drop-zone:hover .upload-btn{background-color:#2563eb;transform:scale(1.05)}.input-mode-tabs{gap:1.5rem;margin-bottom:-1rem;display:flex}.tab-btn{color:var(--text-muted);border:2px solid #0000;border-bottom-color:var(--border);cursor:pointer;background:0 0;padding:.75rem 1.5rem;font-size:1.05rem;font-weight:600;transition:all .2s}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.tab-btn:hover:not(.active){color:var(--text);border-bottom-color:#cbd5e1}.text-input-zone{flex-direction:column;align-items:center;gap:1.5rem;width:100%;max-width:600px;padding:1rem 0;display:flex}.text-input-area{border:2px solid var(--border);resize:vertical;background:var(--surface);border-radius:16px;width:100%;height:280px;padding:1.5rem;font-family:inherit;font-size:1rem;line-height:1.6;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px -1px #00000008}.text-input-area:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 4px #3b82f61a}.error-msg{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;width:100%;max-width:560px;padding:.75rem 1.25rem}.info-cards{flex-wrap:wrap;justify-content:center;gap:1.5rem;width:100%;max-width:860px;display:flex}.info-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex:1;min-width:220px;max-width:260px;padding:1.5rem}.info-icon{font-size:1.8rem}.info-card h3{margin:.6rem 0 .4rem;font-size:1rem;font-weight:600}.info-card p{color:var(--text-muted);font-size:.875rem;line-height:1.6}.model-selector{background:var(--surface);border:1px solid var(--border);border-radius:10px;align-items:center;gap:.75rem;width:100%;max-width:560px;padding:.65rem 1.1rem;display:flex}.model-selector label{white-space:nowrap;color:var(--text-muted);font-size:.875rem;font-weight:600}.model-selector select{color:var(--text);cursor:pointer;background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:.875rem}.upload-footer{text-align:center;color:var(--text-muted);margin-top:auto;padding:2.5rem 1rem 2rem;font-size:.85rem}.upload-footer p{margin-bottom:.75rem}.footer-links{flex-wrap:wrap;justify-content:center;align-items:center;gap:.75rem;display:flex}.footer-links a{color:var(--text-muted);text-decoration:none;transition:color .2s}.footer-links a:hover{color:var(--primary)}.footer-divider{color:var(--border)}.info-card-clickable{cursor:pointer;transition:all .2s;position:relative}.info-card-clickable:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 12px #3b82f626}.info-card-link{color:var(--primary);margin-top:.5rem;font-size:.82rem;font-weight:600;display:inline-block}.loading-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.loading-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);text-align:center;width:90%;max-width:400px;padding:3rem 2.5rem}.spinner{border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:52px;height:52px;margin:0 auto 1.5rem;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-card h2{margin-bottom:1rem;font-size:1.2rem;font-weight:600}.loading-sub{color:var(--text-muted);margin-bottom:1.5rem;font-size:.9rem}.progress-percent{color:var(--primary);font-variant-numeric:tabular-nums;margin-bottom:.75rem;font-size:2.4rem;font-weight:700;line-height:1}.progress-bar-container{background:var(--border);border-radius:4px;width:100%;height:8px;margin-bottom:.65rem;overflow:hidden}.progress-bar-fill{background:var(--primary);border-radius:4px;height:100%;transition:width .4s}.progress-meta{color:var(--text-muted);justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1.25rem;font-size:.85rem;display:flex}.progress-elapsed{font-variant-numeric:tabular-nums}.progress-meta-sub{text-align:right}.step-list{text-align:left;list-style:none}.step-item{color:var(--text-muted);border-bottom:1px solid var(--border);align-items:center;gap:.75rem;padding:.5rem 0;font-size:.9rem;display:flex}.step-item:last-child{border-bottom:none}
