*{box-sizing:border-box}*,body{margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{margin:0;padding:0;width:100%}.sarcasm-detector{background:linear-gradient(135deg,#f0f4f8,#e8f0f7);box-sizing:border-box;color:#1a202c;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:0;min-height:100vh;overflow-x:hidden;overflow-y:auto;padding:30px 20px;position:relative;width:100%}.sarcasm-detector:before{display:none}.header{margin-bottom:35px;position:relative;text-align:center;z-index:1}.header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#5b21b6,#1e40af);-webkit-background-clip:text;background-clip:text;color:#1a202c;font-size:2.5rem;font-weight:800;letter-spacing:-.5px;margin:0 0 8px}.subtitle{color:#475569;font-size:.95rem;font-weight:400;margin:0}.comparison-title{color:#1a1a1a;font-size:2rem;font-weight:600;margin-bottom:30px}.models-comparison{grid-gap:30px;gap:30px;margin:0 auto;max-width:1400px}.model-badge{font-size:.9rem;margin-top:10px;padding:8px 16px}.baseline-badge{background:#e3f2fd;color:#1565c0}.proposed-badge{background:#e8f5e9;color:#2e7d32}.model-desc{background:#e6f2ff;border-radius:8px;color:#666;display:inline-block;font-size:.95rem;font-style:italic;margin-top:8px;width:-webkit-fit-content;width:fit-content}.input-section{background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:30px;margin-left:auto;margin-right:auto;max-width:900px;padding:25px}.text-input{background:#fff;border:1px solid #cbd5e1;border-radius:8px;box-sizing:border-box;color:#1a202c;font-family:inherit;font-size:1rem;min-height:120px;padding:14px 16px;resize:vertical;transition:all .3s ease;width:100%}.text-input:focus{background:#fafbff;border-color:#5b21b6;box-shadow:0 0 0 3px #5b21b61a;outline:none}.text-input::placeholder{color:#94a3b8}.word-counter{color:#64748b;display:flex;font-size:.85rem;font-weight:500;justify-content:flex-end;margin-top:8px}.word-counter .over-limit{color:#dc2626;font-weight:600}.button-group{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px}.analyze-btn,.reset-btn{border:none;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:600;letter-spacing:.5px;padding:12px 24px;text-transform:uppercase;transition:all .3s ease}.analyze-btn{background:linear-gradient(135deg,#5b21b6,#7c3aed);box-shadow:0 4px 12px #5b21b64d;color:#fff;flex:1 1;min-width:150px}.analyze-btn:hover:not(:disabled){box-shadow:0 6px 16px #5b21b666;transform:translateY(-2px)}.analyze-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.reset-btn{background:#fff;border:2px solid #cbd5e1;color:#5b21b6;padding:12px 24px}.reset-btn:hover{background:#f3f4f6;border-color:#5b21b6;color:#5b21b6}.error-message{animation:slideIn .3s ease;background-color:#fee2e2;border:1px solid #fca5a5;border-left:4px solid #dc2626;border-radius:6px;color:#991b1b;font-size:.95rem;font-weight:500;margin-top:16px;padding:12px 16px}@keyframes slideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.examples{background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:30px;margin-left:auto;margin-right:auto;max-width:900px;padding:25px}.examples h3{color:#1a202c;font-size:1.2rem;font-weight:700;margin-bottom:18px;margin-top:0}.example-buttons{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.example-btn{background:#fff;border:2px solid #5b21b6;border-radius:8px;color:#5b21b6;cursor:pointer;font-size:.95rem;font-weight:600;letter-spacing:.4px;padding:12px 16px;text-transform:uppercase;transition:all .3s ease}.example-btn:hover{background:linear-gradient(135deg,#5b21b6,#7c3aed);box-shadow:0 4px 12px #5b21b64d;color:#fff;transform:translateY(-2px)}.example-btn:active{transform:translateY(0)}.dual-results-section{margin-bottom:35px;margin-left:auto;margin-right:auto;max-width:900px}.comparison-title{color:#1a202c;font-size:1.5rem;font-weight:700;margin-bottom:20px;text-align:center}.models-comparison{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:30px}@media (max-width:768px){.models-comparison{grid-template-columns:1fr}}.result-section{animation:slideInUp .5s ease-out;background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden;padding:24px;position:relative}.result-section:before{background:linear-gradient(90deg,#5b21b6,#06b6d4);content:"";height:4px;left:0;position:absolute;right:0;top:0}.result-section.sarcastic:before{background:linear-gradient(90deg,#dc2626,#f87171)}.result-section.not-sarcastic:before{background:linear-gradient(90deg,#059669,#10b981)}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.result-header{margin-bottom:20px}.result-header h2{color:#1a202c;font-size:1.5rem;font-weight:700;margin:0 0 10px}.model-badge{border-radius:6px;display:inline-block;font-size:.8rem;font-weight:600;letter-spacing:.3px;padding:6px 12px;text-transform:uppercase}.baseline-badge{background:#fee2e2;color:#dc2626}.proposed-badge{background:#dcfce7;color:#15803d}.model-desc{color:#475569;font-size:.9rem;font-weight:500}.processing-time{color:#94a3b8;font-size:.85rem;font-weight:600}.confidence-bar{margin:18px 0}.confidence-label{color:#1a202c;font-size:.9rem;font-weight:600;margin-bottom:8px}.progress-bar{background:#e2e8f0;border:1px solid #cbd5e1;border-radius:6px;height:28px;overflow:hidden;width:100%}.progress-fill{align-items:center;background:linear-gradient(90deg,#5b21b6,#06b6d4);color:#fff;display:flex;font-size:.85rem;font-weight:600;height:100%;justify-content:flex-end;padding-right:8px;transition:width .8s cubic-bezier(.4,0,.2,1)}.indicators{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;box-shadow:none;padding:25px}.indicators h3{color:#1a202c;font-size:1.3rem;font-weight:700;margin-bottom:18px}.indicators ul{list-style:none;padding:0}.indicators li{color:#2d3748;font-size:1.05rem;font-weight:500;padding:12px 0 12px 30px;position:relative}.indicators li:before{color:#1a1a1a;content:"✓";font-size:1.2rem;font-weight:700;left:8px;position:absolute}.performance-graphs{background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px #00000014;margin:35px auto;max-width:900px;padding:25px}.performance-graphs h2{color:#1a202c;font-size:1.5rem;margin-bottom:20px;margin-top:0}.graph-container{margin:20px 0}.graph-card{background:#f8fafc;border:1px solid #e2e8f0}.graph-card h3{color:#1a202c}.metrics-error,.metrics-loading{background:#f0f4f8;border-radius:8px;color:#475569;padding:30px;text-align:center}.metrics-error{border:1px solid #dc26264d;color:#dc2626}.metrics-info{color:#475569;font-size:.9rem;margin-bottom:15px}.confusion-matrices-section{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin:35px auto;max-width:900px}@media (max-width:768px){.confusion-matrices-section{grid-template-columns:1fr}}.confusion-matrix-container{background:#fff;border:2px solid #e2e8f0;border-radius:12px;display:flex;flex-direction:column;gap:15px;padding:20px}.graph-card{background:#1e293b;border:1px solid #334155;border-radius:10px;padding:20px}.graph-card h3{color:#f1f5f9;font-size:1.1rem;margin-bottom:15px;margin-top:0}.confusion-matrix{grid-gap:2px;background:#e2e8f0;border-radius:8px;display:grid;gap:2px;grid-template-columns:auto 1fr 1fr;grid-template-rows:auto 1fr 1fr;overflow:hidden;padding:2px}.matrix-cell{background:#fff;color:#1a202c;font-size:.9rem;padding:15px;text-align:center}.matrix-header{background:#5b21b6;color:#fff;font-weight:700}.matrix-label{background:#5b21b61a;color:#1a202c;font-weight:600}.matrix-value{align-items:center;display:flex;flex-direction:column;gap:6px;justify-content:center}.true-negative,.true-positive{background:#10b98133}.false-negative,.false-positive{background:#ef444433}.matrix-value .value{color:#1a202c;font-size:1.5rem;font-weight:800}.matrix-value .label{color:#475569;font-size:.8rem}.matrix-legend{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(2,1fr);margin-top:10px}.legend-item{align-items:center;color:#1a202c;display:flex;font-size:.85rem;gap:8px}.legend-color{border-radius:4px;height:20px;width:20px}@media (max-width:768px){.sarcasm-detector{padding:30px 20px}.header h1{font-size:2.5rem}.subtitle{font-size:1.1rem}.example-buttons,.graph-container,.model-options{grid-template-columns:1fr}.button-group{flex-direction:column}.performance-graphs h2,.result-header h2{font-size:1.8rem}}@media (max-width:480px){.header h1{font-size:2rem}.graph-card,.model-selector{padding:20px}.sarcasm-detector{border-radius:20px;padding:20px 15px}}.dataset-section{background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px #00000014;margin:35px auto;max-width:900px;padding:25px}.dataset-section h2{color:#1a202c;font-size:1.5rem;margin-bottom:12px;margin-top:0}.dataset-description{color:#475569;font-size:.95rem;margin:0 0 20px}.upload-steps{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:20px}.upload-step{align-items:flex-start;background:#f8fafc;border:1px solid #cbd5e1;border-radius:10px;display:flex;gap:10px;padding:12px}.upload-step.active{background:#eff6ff;border-color:#2563eb}.upload-step.completed{background:#f0fdf4;border-color:#16a34a}.step-number{align-items:center;background:#e2e8f0;border-radius:50%;color:#1e293b;display:inline-flex;flex:0 0 26px;font-size:.9rem;font-weight:700;height:26px;justify-content:center;width:26px}.upload-step.active .step-number{background:#2563eb;color:#fff}.upload-step.completed .step-number{background:#16a34a;color:#fff}.upload-step h4{color:#0f172a;font-size:.95rem;margin:0 0 4px}.upload-step p{color:#475569;font-size:.85rem;line-height:1.4;margin:0}.dataset-upload{display:flex;flex-direction:column;gap:12px}.file-upload-section{background:#6366f10d;border:2px dashed #6366f1;border-radius:8px;cursor:pointer;margin:20px 0;padding:20px;text-align:center;transition:all .3s ease}.file-upload-section:hover{background:#6366f11a;border-color:#4f46e5}.file-upload-section label{color:#1a202c;cursor:pointer;display:block;font-weight:600;margin-bottom:16px}.file-upload-label{background:linear-gradient(135deg,#5b21b6,#7c3aed);border:none;border-radius:8px;box-shadow:0 4px 12px #5b21b64d;color:#fff;cursor:pointer;display:inline-block;font-size:1rem;font-weight:700;letter-spacing:.5px;padding:14px 32px;text-transform:uppercase;transition:all .3s ease}.file-upload-label:hover{box-shadow:0 6px 16px #5b21b666;transform:translateY(-2px)}.file-upload-label:active{transform:translateY(0)}.upload-status{background:#f8fafc;border:1px solid #cbd5e1;border-radius:8px;color:#334155;font-size:.9rem;padding:10px 12px}.upload-status.success{background:#f0fdf4;border-color:#86efac;color:#166534}.upload-status.error{background:#fef2f2;border-color:#fecaca;color:#991b1b}.upload-status.warning{background:#fffbeb;border-color:#fde68a;color:#92400e}.upload-file-name{display:inline-block;font-weight:600;margin-left:6px}.file-upload-section input[type=file]{display:none}.format-info{margin-top:20px}.format-quick-guide{background:#f8fafc;border:1px solid #cbd5e1;border-radius:8px;margin-bottom:12px;padding:12px}.format-quick-guide p{color:#0f172a;margin:0 0 8px}.format-quick-guide ul{color:#334155;margin:0;padding-left:20px}.format-quick-guide li{font-size:.9rem;margin-bottom:6px}.format-info details{background:linear-gradient(135deg,#f3f0ff,#faf5ff);border:2px solid #e9d5ff;border-radius:8px;padding:16px}.format-info summary{color:#5b21b6;cursor:pointer;font-weight:600;list-style:none;padding:8px}.format-info summary:hover{color:#7c3aed}@media (max-width:820px){.upload-steps{grid-template-columns:1fr}}.dataset-controls{display:flex;gap:12px;margin-bottom:20px;margin-top:20px}.process-dataset-btn{background:linear-gradient(135deg,#059669,#10b981);border:none;border-radius:8px;box-shadow:0 4px 12px #0596694d;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;letter-spacing:.5px;padding:14px 32px;text-transform:uppercase;transition:all .3s ease}.process-dataset-btn:hover:not(:disabled){box-shadow:0 6px 16px #05966966;transform:translateY(-2px)}.process-dataset-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.dataset-info{align-items:center;background:linear-gradient(135deg,#f0fdf4,#ecfdf5);border:2px solid #86efac;border-radius:8px;display:flex;gap:16px;justify-content:space-between;margin-bottom:20px;padding:12px 16px}.dataset-count{color:#059669;font-size:.95rem;font-weight:600}.clear-dataset-btn{background:#fff;border:2px solid #dc2626;border-radius:6px;color:#dc2626;cursor:pointer;font-size:.9rem;font-weight:600;letter-spacing:.4px;padding:10px 20px;text-transform:uppercase;transition:all .3s ease}.clear-dataset-btn:hover{background:#fee2e2;border-color:#991b1b;color:#991b1b;transform:translateY(-1px)}.dataset-results{background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px #00000014;margin:35px auto;max-width:1200px;padding:30px}.dataset-results h3{color:#1a202c;font-size:1.8rem;font-weight:800;margin-bottom:30px;margin-top:0;text-align:center}.dataset-metrics{margin-bottom:30px}.dataset-metrics h4{color:#1a202c;font-size:1.3rem;font-weight:700;margin:0 0 20px;text-align:center}.metrics-table-container{display:flex;justify-content:center;overflow-x:auto}.metrics-table{background:#fff;border:1px solid #e2e8f0;border-collapse:collapse;border-radius:8px;box-shadow:0 2px 4px #0000000d;min-width:600px;overflow:hidden}.dataset-stats-header{margin-bottom:15px;margin-top:25px}.dataset-stats-header h4{color:#1a202c;font-size:1.1rem;margin:0}.dataset-stats{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:25px}.stat-card{background:linear-gradient(135deg,#fafbff,#f0f4f8);border:2px solid #e2e8f0;border-radius:8px;padding:16px;text-align:center;transition:all .3s ease}.stat-card:hover{background:linear-gradient(135deg,#f0f4f8,#e8f0f7);border-color:#cbd5e1;transform:translateY(-2px)}.stat-card.highlight{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#059669}.stat-value{color:#5b21b6;font-size:1.5rem;font-weight:800;margin-bottom:6px}.stat-card.highlight .stat-value{color:#059669}.stat-label{color:#475569;font-size:.85rem;font-weight:500}.results-table-container{margin-top:25px;overflow-x:auto}.results-table{background:#fff;border:1px solid #e2e8f0;border-collapse:collapse;border-radius:8px;font-size:.9rem;overflow:hidden;width:100%}.results-table th{background:linear-gradient(135deg,#5b21b6,#7c3aed);border:none;color:#fff;font-weight:600;padding:12px;text-align:left}.results-table th.sub-header{background:#5b21b6cc;font-weight:500;padding:8px 12px}.results-table td{border-bottom:1px solid #e2e8f0;color:#1a202c;padding:12px}.results-table tbody tr:hover{background:#f8fafc}@media (max-width:768px){.confusion-matrices-section,.models-comparison{grid-template-columns:1fr}}@media (max-width:640px){.sarcasm-detector{padding:20px 12px}.header h1{font-size:1.8rem}.input-section{padding:16px}.button-group{flex-direction:column}.analyze-btn,.reset-btn{width:100%}}.metrics-table thead th{background:linear-gradient(135deg,#5b21b6,#7c3aed);border:1px solid #4c1d95;color:#fff;font-size:.95rem;font-weight:700;padding:15px 12px;text-align:center}.metrics-table .model-subtitle{display:block;font-size:.75rem;font-weight:400;margin-top:5px;opacity:.9}.metrics-table tbody tr{border-bottom:1px solid #e2e8f0;transition:background-color .3s}.metrics-table tbody tr:hover{background-color:#f8fafc}.metrics-table tbody tr:last-child{border-bottom:none}.metrics-table td{border:1px solid #e2e8f0;font-size:.95rem;padding:14px 12px;text-align:center;white-space:nowrap}.metric-name{color:#1a202c;font-size:.95rem;font-weight:700;padding-left:16px!important;text-align:left!important}.baseline-col{background:#dc2626!important;color:#fff!important}.proposed-col{background:#059669!important;color:#fff!important}.baseline-value{color:#dc2626}.baseline-value,.proposed-value{font-size:1.2rem;font-weight:700}.proposed-value{color:#059669}.improvement-value{color:#5b21b6;font-size:1.1rem;font-weight:700}.confusion-matrices-comparison{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-top:20px}.confusion-matrix-side{background:#fff;border-radius:8px;box-shadow:0 4px 12px #0000001a;padding:20px}.confusion-matrix-side h5{color:#1a1a1a;font-size:1.1rem;font-weight:600;margin-bottom:15px;text-align:center}.mini-confusion-matrix{display:flex;flex-direction:column;gap:5px}.matrix-row{grid-gap:5px;display:grid;gap:5px;grid-template-columns:120px 1fr 1fr}.matrix-cell-mini{align-items:center;border-radius:4px;display:flex;flex-direction:column;font-size:.85rem;font-weight:600;justify-content:center;min-height:50px;padding:15px 10px;text-align:center}.matrix-cell-mini.header-cell{background:#f0f0f0;color:#1a1a1a;font-size:.75rem;font-weight:700}.matrix-cell-mini.tp-cell{background:linear-gradient(135deg,#d4fc79,#96e6a1);color:#1a1a1a}.matrix-cell-mini.tn-cell{background:linear-gradient(135deg,#84fab0,#8fd3f4);color:#1a1a1a}.matrix-cell-mini.fp-cell{background:linear-gradient(135deg,#ffecd2,#fcb69f);color:#1a1a1a}.matrix-cell-mini.fn-cell{background:linear-gradient(135deg,#fbc2eb,#a6c1ee);color:#1a1a1a}@media (max-width:768px){.metrics-comparison{padding:20px}.metrics-table{font-size:.85rem}.metric-name{font-size:.95rem}.baseline-value,.proposed-value{font-size:1rem}.improvement-value{font-size:.9rem}.confusion-matrices-comparison{grid-template-columns:1fr}.matrix-row{grid-template-columns:100px 1fr 1fr}.matrix-cell-mini{font-size:.8rem;padding:8px}}
/*# sourceMappingURL=main.30e6b333.css.map*/