File size: 30,302 Bytes
7cb1242
1
@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap);:root{--primary-color:#0969da;--primary-dark:#1a7f37;--primary-light:#58a6ff;--secondary-color:#656d76;--accent-color:#8250df;--success-color:#1a7f37;--warning-color:#9a6700;--error-color:#cf222e;--bg-primary:#fafbfc;--bg-secondary:#f1f3f4;--bg-tertiary:#e8eaed;--surface-primary:#ffffff;--surface-secondary:#f6f8fa;--surface-tertiary:#f0f6fc;--text-primary:#24292f;--text-secondary:#656d76;--text-muted:#8c959f;--text-disabled:#8c959f;--border-primary:#d0d7de;--border-secondary:#d0d7de;--border-tertiary:#d0d7de;--elevation-1:0 1px 3px rgba(27, 31, 36, 0.04), 0 1px 0 rgba(255, 255, 255, 0.25);--elevation-2:0 1px 0 rgba(27, 31, 36, 0.04), 0 1px 0 rgba(255, 255, 255, 0.25);--elevation-3:0 1px 0 rgba(27, 31, 36, 0.04), 0 1px 0 rgba(255, 255, 255, 0.25);--radius-small:6px;--radius-medium:8px;--radius-large:12px;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--shadow-sm:var(--elevation-1);--shadow-md:var(--elevation-2);--shadow-lg:var(--elevation-3);--shadow-xl:var(--elevation-3);--gradient-primary:linear-gradient(135deg, var(--primary-color), var(--primary-dark));--gradient-secondary:linear-gradient(135deg, var(--secondary-color), var(--text-secondary));--gradient-accent:linear-gradient(135deg, var(--accent-color), var(--primary-color));--gradient-success:linear-gradient(135deg, var(--success-color), var(--primary-dark));--gradient-warning:linear-gradient(135deg, var(--warning-color), #d97706);--gradient-error:linear-gradient(135deg, var(--error-color), #dc2626)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:var(--bg-primary);min-height:100vh;position:relative;overflow-x:hidden;color:var(--text-primary);line-height:1.6}body::before{content:'';position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bg-tertiary);z-index:-1}.container{max-width:1000px;margin:0 auto;padding:0 24px}.header-section{text-align:center;padding:2rem 0;position:relative;background:var(--surface-primary);border-radius:20px;margin-bottom:var(--spacing-lg);box-shadow:var(--elevation-2);border:1px solid var(--border-primary)}.logo-container{margin-bottom:1.5rem;position:relative}.logo-container::after{content:'';position:absolute;bottom:-12px;left:50%;transform:translateX(-50%);width:60px;height:2px;background:var(--primary-color);border-radius:2px;opacity:.7}.logo-img{width:80px;height:auto;border-radius:50%;box-shadow:var(--elevation-1);transition:all 0.3s ease;border:2px solid var(--primary-color);background:#fff;padding:4px}.logo-img:hover{transform:scale(1.05);box-shadow:var(--elevation-2);border-color:var(--primary-dark)}.main-title{color:var(--text-primary);font-size:2.2rem;font-weight:700;margin-bottom:.75rem;font-family:'Inter',sans-serif;letter-spacing:-.01em;line-height:1.2}.main-title .highlight{color:var(--primary-color)}.subtitle{color:var(--text-secondary);font-size:1rem;font-weight:500;margin-bottom:0;max-width:600px;margin-left:auto;margin-right:auto;opacity:.9;line-height:1.5}.app-card{background:var(--surface-primary);border-radius:16px;padding:var(--spacing-xl);margin:var(--spacing-lg) 0;box-shadow:var(--elevation-2);border:1px solid var(--border-primary);transition:all 0.3s ease;position:relative;overflow:hidden}.app-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary)}.app-card:hover{transform:translateY(-4px);box-shadow:0 15px 40px rgb(0 0 0 / .12)}.card-header{text-align:center;margin-bottom:2rem}.card-title{font-size:2.2rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem;font-family:'Poppins',sans-serif;letter-spacing:-.01em}.card-subtitle{font-size:1.1rem;color:var(--text-secondary);font-weight:400;max-width:450px;margin:0 auto}.form-group{margin-bottom:var(--spacing-lg)}.text-input-card{background:var(--surface-primary);border-radius:16px;padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);box-shadow:var(--elevation-1);border:1px solid var(--border-primary)}.file-upload-card{background:var(--surface-primary);border-radius:16px;padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);box-shadow:var(--elevation-1);border:1px solid var(--border-primary)}.model-selection-card{background:var(--surface-primary);border-radius:16px;padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);box-shadow:var(--elevation-1);border:1px solid var(--border-primary)}.form-label{font-weight:600;color:var(--text-primary);margin-bottom:.75rem;font-size:1rem;display:flex;align-items:center;gap:.5rem}.form-label i{color:var(--primary-color);font-size:1rem}.form-control,.form-select{border:1.5px solid #e2e8f0;border-radius:8px;padding:.875rem 1rem;font-size:.95rem;transition:all 0.2s ease;background:#fff;color:var(--text-primary);font-weight:500;width:100%}.form-control:focus,.form-select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px rgb(59 130 246 / .08);outline:none;transform:translateY(-1px)}.form-control:hover,.form-select:hover{border-color:var(--primary-light)}.form-control:disabled{background-color:var(--surface-secondary);border-color:var(--border-secondary);color:var(--text-muted);cursor:not-allowed}.form-control[type="file"]:disabled{background-color:var(--surface-secondary);border-color:var(--border-secondary);color:var(--text-muted);cursor:not-allowed}textarea.form-control{min-height:120px;resize:vertical;line-height:1.6}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");background-position:right .75rem center;background-repeat:no-repeat;background-size:1.25em 1.25em;padding-right:2.5rem;cursor:pointer}.form-select option{padding:.75rem;font-size:.95rem;background:#fff;color:var(--text-primary);border:none}.form-select:focus option:checked{background:var(--primary-color);color:#fff}.file-upload-section{background:var(--surface-secondary);border-radius:16px;padding:var(--spacing-lg);margin:var(--spacing-md) 0;border:2px dashed var(--border-primary);box-shadow:var(--elevation-1);transition:all 0.2s ease;position:relative}.file-upload-section:hover{border-color:var(--primary-color);background:linear-gradient(135deg,#f0f9ff 0%,#e0f2fe 100%)}.file-upload-section.dragover{border-color:var(--primary-color);background:linear-gradient(135deg,#e0f2fe 0%,#bae6fd 100%);transform:scale(1.01)}.remove-file-btn{background:var(--gradient-secondary);border:none;border-radius:8px;padding:.5rem 1rem;color:#fff;font-weight:500;transition:all 0.2s ease;margin-top:.75rem;font-size:.875rem;display:none;align-items:center;gap:.5rem}.remove-file-btn:hover{transform:translateY(-1px);box-shadow:0 4px 15px rgb(245 87 108 / .3)}.model-selection{background:var(--surface-secondary);border-radius:16px;padding:var(--spacing-lg);border:1px solid var(--border-primary);box-shadow:var(--elevation-1);position:relative;overflow:hidden}.model-selection::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient-accent)}.btn-analyze{background:var(--primary-color)!important;border:none;border-radius:var(--radius-medium);padding:var(--spacing-md) var(--spacing-lg);font-size:1rem;font-weight:600;color:white!important;transition:all 0.2s ease;box-shadow:var(--elevation-1);width:auto;min-width:200px;margin:var(--spacing-lg) auto 0;display:block!important;position:relative;overflow:hidden;cursor:pointer;opacity:1!important}.btn-analyze::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgb(255 255 255 / .15),transparent);transition:left 0.4s}.btn-analyze:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--elevation-2);background:var(--primary-dark)}.btn-analyze:hover:not(:disabled)::before{left:100%}.btn-analyze:disabled{opacity:0.6!important;cursor:not-allowed;transform:none;background:var(--text-secondary)!important}.word-count{background:var(--success-color);color:#fff;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-small);font-weight:500;text-align:center;margin:var(--spacing-md) 0;box-shadow:var(--elevation-1);display:inline-flex;align-items:center;gap:var(--spacing-sm);font-size:.875rem;max-width:fit-content}.note-section{background:var(--surface-secondary);border-radius:16px;padding:1rem 1.25rem;margin:1rem auto 2rem auto;border:1px solid var(--success-color);border-left:4px solid var(--success-color);box-shadow:var(--elevation-1);position:relative}.note-narrow{max-width:1000px}.note-section::before{content:none;display:none}.note-text{color:var(--text-primary);font-weight:500;margin-bottom:.75rem;font-size:.95rem;line-height:1.6}.action-buttons{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;margin-top:1.25rem}.btn-action{border-radius:8px;padding:.625rem 1.25rem;font-weight:500;transition:all 0.2s ease;border:none;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;font-size:.875rem;position:relative;overflow:hidden}.btn-view{background:var(--success-color);color:#fff;box-shadow:var(--elevation-1)}.btn-download{background:var(--warning-color);color:#fff;box-shadow:var(--elevation-1)}.btn-action:hover{transform:translateY(-1px);text-decoration:none;color:#fff;box-shadow:var(--elevation-2)}.btn-view:hover{background:#059669}.btn-download:hover{background:#d97706}.results-header{background:var(--surface-primary);border-radius:12px;padding:1.5rem;margin:3rem auto;max-width:1200px;border:1px solid var(--border-primary);box-shadow:var(--elevation-1);text-align:center}.results-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.results-title i{color:var(--primary-color);font-size:1.25rem}.results-summary{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.summary-item{display:flex;align-items:center;gap:.25rem;color:var(--text-secondary);font-weight:500;padding:.25rem .75rem;background:var(--surface-secondary);border-radius:6px;font-size:.8rem;border:1px solid var(--border-primary)}.main-sentiment-card{background:var(--surface-primary);border-radius:12px;padding:2rem;margin:3rem auto;max-width:1200px;border:1px solid var(--border-primary);box-shadow:var(--elevation-1);text-align:center}.sentiment-hero{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.sentiment-icon{font-size:2rem;color:var(--primary-color);background:var(--surface-secondary);width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--border-primary);flex-shrink:0}.sentiment-content{flex:1;text-align:center}.sentiment-label{display:inline-block;padding:.75rem 2rem;border-radius:8px;font-size:1.25rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.5px;margin-bottom:1rem;min-width:120px}.sentiment-label.positive{background:var(--success-color)}.sentiment-label.negative{background:var(--error-color)}.sentiment-label.neutral{background:var(--warning-color)}.sentiment-label.sadness{background:#2563eb;color:#fff}.sentiment-label.joy{background:#f59e0b;color:#1f2937}.sentiment-label.anger{background:#ef4444;color:#fff}.sentiment-label.fear{background:#7c3aed;color:#fff}.sentiment-label.disgust{background:#10b981;color:#0b1b13}.sentiment-label.surprise{background:#06b6d4;color:#06262b}.confidence-meter{margin-top:.75rem}.confidence-bar{width:100%;height:6px;background:var(--surface-secondary);border-radius:3px;overflow:hidden;margin-bottom:.5rem;border:1px solid var(--border-primary)}.confidence-fill{height:100%;background:var(--primary-color);border-radius:3px;transition:width 1s ease-in-out;position:relative}.confidence-text{font-size:.9rem;font-weight:500;color:var(--text-secondary)}.accordion-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;padding:.75rem 0;background:#fff0;border:none;border-bottom:1px solid var(--border-primary);margin-bottom:.5rem;transition:all 0.2s ease}.accordion-header:hover{background:#fff0}.accordion-header h4{margin:0;color:var(--text-primary);font-size:1rem;font-weight:600}.accordion-icon{color:var(--primary-color);font-size:.9rem;transition:transform 0.2s ease}.accordion-content{display:block;background:#fff0;border:none;padding:0;margin-bottom:1rem;animation:slideDown 0.3s ease-out}@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.text-cleaning-card,.normalization-card,.tokenization-card,.stemming-lemmatization-card,.ner-analysis-card,.pos-analysis-card{background:var(--surface-primary);border-radius:12px;padding:1.5rem;margin:3rem auto;max-width:1200px;border:1px solid var(--border-primary);box-shadow:var(--elevation-1)}.step-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}.card-toolbar{margin-left:auto;display:flex;align-items:center;gap:.5rem}.toolbar-btn{border:1px solid var(--border-primary);background:var(--surface-secondary);color:var(--text-primary);padding:6px 8px;border-radius:6px;cursor:pointer}.toolbar-btn:hover{background:var(--surface-primary)}.fullscreen{position:fixed!important;inset:0!important;margin:0!important;max-width:100%!important;border-radius:0!important;z-index:9999!important;background:var(--surface-primary)!important;padding:2rem!important;overflow:auto!important}.step-title-section{flex:1}.step-title{font-size:1.4rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem 0}.step-description{font-size:.95rem;color:var(--text-secondary);margin:0;line-height:1.5}.text-box{background:var(--surface-secondary);border-radius:8px;padding:1rem;margin-bottom:1rem}.text-box h5{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 .75rem 0;border-bottom:1px solid var(--border-primary);padding-bottom:.5rem}.processed-text{font-size:.9rem;line-height:1.6;color:var(--text-primary);margin:0;word-wrap:break-word}.step-content.expanded{max-height:none}.step-content{max-height:700px;overflow:auto;transition:max-height 0.2s ease;padding-bottom:.25rem}.badge{display:inline-flex;align-items:center;gap:6px;background:var(--primary-color);color:#fff;padding:6px 10px;border-radius:999px;font-size:.8rem;font-weight:600}.meta-box{background:var(--surface-tertiary);border-radius:6px;padding:.75rem;border-left:3px solid var(--primary-color)}.meta-box h5{font-size:.9rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem 0}.meta-text{font-size:.85rem;color:var(--text-secondary);margin:0}.token-display{display:flex;flex-wrap:wrap;gap:.5rem .5rem;margin-bottom:1rem}.token-item{background:#e9eefb;color:#1f3a8a;padding:.25rem .5rem;border-radius:6px;font-size:.85rem;font-weight:600;border:1px solid #c7d2fe}.process-note{display:block;font-size:.8rem;color:var(--text-muted);font-style:italic;margin-top:.5rem}.pipeline-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem;text-align:left;display:flex;align-items:center;gap:.5rem}.pipeline-title i{color:var(--primary-color)}.pipeline-steps{display:block;margin-left:0}.pipeline-step{display:flex;align-items:flex-start;gap:.75rem;padding:.5rem 0;background:#fff0;border:none;border-bottom:1px solid var(--border-primary);margin-bottom:.75rem}.pipeline-step:last-child{border-bottom:none;margin-bottom:0}.step-icon{width:28px;height:28px;background:var(--primary-color);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.8rem;flex-shrink:0}.step-content{flex:1}.step-content h5{font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.step-text{color:var(--text-secondary);line-height:1.4;margin-bottom:.5rem;word-break:break-word;font-size:.85rem}.step-meta{display:flex;gap:.5rem;flex-wrap:wrap}.meta-item{display:inline-block;font-size:.75rem;color:var(--text-muted);padding:.25rem .5rem;background:var(--surface-secondary);border-radius:4px}.wordcloud-section{background:var(--surface-primary);border-radius:12px;padding:1.5rem;margin:3rem auto;max-width:1200px;border:1px solid var(--border-primary);box-shadow:var(--elevation-1)}.wordcloud-container{text-align:center;padding:1.5rem}.wordcloud-image{max-width:100%;height:auto;border-radius:10px;box-shadow:var(--shadow-sm);transition:transform 0.2s ease}.wordcloud-image:hover{transform:scale(1.01)}.wordcloud-info{margin-top:1.25rem;display:flex;justify-content:center;gap:1.5rem;flex-wrap:wrap}.wordcloud-info p{color:var(--text-secondary);font-size:.875rem;display:flex;align-items:center;gap:.5rem}.wordcloud-info i{color:var(--primary-color)}.linguistic-analysis{background:var(--surface-primary);border-radius:12px;padding:1.5rem;margin:3rem auto;max-width:1200px;border:1px solid var(--border-primary);box-shadow:var(--elevation-1)}.analysis-title{font-size:1.6rem;font-weight:600;color:var(--text-primary);margin-bottom:1.5rem;text-align:center;display:flex;align-items:center;justify-content:center;gap:.5rem}.analysis-title i{color:var(--primary-color)}.analysis-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.analysis-card{background:linear-gradient(135deg,#f8fafc 0%,#f1f5f9 100%);border-radius:12px;padding:1.5rem;border:1px solid #e2e8f0;transition:all 0.2s ease}.analysis-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.analysis-card .card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1.25rem}.analysis-card .card-header i{color:var(--primary-color);font-size:1.25rem}.analysis-card .card-header h5{font-size:1.2rem;font-weight:600;color:var(--text-primary);margin:0}.card-content{min-height:80px}.entity-tag,.pos-tag{display:inline-block;padding:.375rem .75rem;margin:.25rem;border-radius:16px;font-size:.875rem;font-weight:500;background:var(--primary-color);color:#fff}.entity-tag.person{background:var(--success-color)}.entity-tag.org{background:var(--warning-color)}.entity-tag.date{background:var(--accent-color)}.entity-tag.gpe{background:var(--secondary-color)}.no-data{color:var(--text-muted);font-style:italic;text-align:center;padding:1.5rem}.word-sentiment-analysis{background:var(--surface-primary);border-radius:12px;padding:1.5rem 1.5rem 2rem 1.5rem;margin:3rem auto;max-width:1200px;border:1px solid var(--border-primary);box-shadow:var(--elevation-1)}.word-sentiment-analysis .step-content{max-height:none;overflow:visible}.chart-container{background:linear-gradient(135deg,#f8fafc 0%,#f1f5f9 100%);border-radius:12px;padding:1rem 1.5rem 2rem 1.5rem;margin-bottom:1.5rem;border:1px solid #e2e8f0;text-align:center}.chart-container canvas{display:block;max-width:680px;margin:0 auto;height:280px!important}.sentiment-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.25rem;margin-bottom:2rem}.overview-card{display:flex;align-items:center;gap:.75rem;padding:1.25rem;border-radius:12px;border:1.5px solid;transition:all 0.2s ease}.overview-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.overview-card.positive{background:rgb(16 185 129 / .08);border-color:var(--success-color)}.overview-card.neutral{background:rgb(100 116 139 / .08);border-color:var(--text-secondary)}.overview-card.negative{background:rgb(239 68 68 / .08);border-color:var(--error-color)}.overview-icon{width:45px;height:45px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:#fff}.overview-card.positive .overview-icon{background:var(--success-color)}.overview-card.neutral .overview-icon{background:var(--text-secondary)}.overview-card.negative .overview-icon{background:var(--error-color)}.overview-content{flex:1}.overview-number{display:block;font-size:1.75rem;font-weight:700;color:var(--text-primary);line-height:1}.overview-label{display:block;font-size:.875rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-top:.25rem}.word-details{display:grid;gap:1.5rem}.word-group{padding:1.25rem;border-radius:12px;border-left:3px solid}.word-group.positive{background:rgb(16 185 129 / .05);border-left-color:var(--success-color)}.word-group.negative{background:rgb(239 68 68 / .05);border-left-color:var(--error-color)}.word-group.neutral{background:rgb(100 116 139 / .05);border-left-color:var(--text-secondary)}.word-group h5{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.word-cloud{display:flex;flex-wrap:wrap;gap:.5rem}.word-tag{padding:.375rem .75rem;border-radius:16px;font-size:.875rem;font-weight:500;color:#fff;transition:all 0.2s ease}.word-tag:hover{transform:scale(1.03)}.word-tag.positive{background:var(--success-color)}.word-tag.negative{background:var(--error-color)}.word-tag.neutral{background:var(--text-secondary)}.pos-tags{display:flex;flex-wrap:wrap;gap:.5rem;padding:1rem;background:var(--surface-secondary);border-radius:10px;min-height:48px}.pos-tags .word-tag{background:#eef2ff;color:#1e293b;padding:.375rem .65rem;border-radius:999px;border:1px solid #c7d2fe;font-size:.9rem;font-weight:600}.pos-tags .word-tag small{color:#475569;font-weight:700}.pos-analysis-card .step-content{max-height:none;overflow:visible}.emotion-analysis{background:var(--surface-primary);border-radius:12px;padding:1.5rem;margin:3rem auto;max-width:1200px;border:1px solid var(--border-primary);box-shadow:var(--elevation-1)}.emotion-chart{display:grid;gap:1.25rem}.emotion-bar{display:grid;grid-template-columns:120px 1fr 180px;gap:.75rem;align-items:center}.emotion-label{font-weight:600;color:var(--text-primary);font-size:1rem}.emotion-bar-container{height:25px;background:#e2e8f0;border-radius:12px;overflow:hidden;position:relative}.emotion-bar-fill{height:100%;background:var(--gradient-primary);border-radius:12px;transition:width 1s ease-in-out;display:flex;align-items:center;justify-content:center}.emotion-count{color:#fff;font-weight:600;font-size:.875rem}.emotion-words{display:flex;flex-wrap:wrap;gap:.375rem;align-items:center;justify-content:flex-start;max-width:none}.emotion-word{padding:.25rem .6rem;background:#eef2ff;border:1px solid #c7d2fe;border-radius:999px;font-size:.8rem;color:#1e293b;font-weight:600}.emotion-analysis .step-content{max-height:none;overflow:visible}.emotion-analysis .emotion-words{display:none}.emotion-cards{display:grid;grid-template-columns:1fr;gap:1rem;margin-top:1rem}.emotion-card{background:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:12px;padding:.75rem .9rem;height:auto}.emotion-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.emotion-card-header h5{margin:0;font-size:1rem}.badge-count{background:var(--primary-color);color:#fff;border-radius:999px;padding:.15rem .5rem;font-size:.75rem;font-weight:700}.emotion-card-body{max-height:none;overflow:visible}.emotion-more{color:var(--text-muted);font-size:.75rem;font-style:italic}.results-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:1.5rem}.btn-primary{background:var(--gradient-primary);border:none;color:#fff;padding:.75rem 1.5rem;border-radius:8px;font-weight:500;text-decoration:none;transition:all 0.2s ease;box-shadow:var(--shadow-sm)}.btn-primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);color:#fff;text-decoration:none}.btn-outline-secondary{background:#fff0;border:1.5px solid var(--text-secondary);color:var(--text-secondary);padding:.75rem 1.5rem;border-radius:8px;font-weight:500;transition:all 0.2s ease}.btn-outline-secondary:hover{background:var(--text-secondary);color:#fff;transform:translateY(-1px)}.btn-lg{font-size:1rem;padding:.875rem 2rem}.alert{border-radius:8px;border:none;padding:1rem 1.25rem;font-weight:500;margin:.75rem 0}.alert-danger{background:var(--error-color);color:#fff;box-shadow:var(--shadow-sm)}.alert-success{background:var(--success-color);color:#fff;box-shadow:var(--shadow-sm)}.footer{text-align:center;padding:2rem 0;color:var(--text-secondary);font-weight:500}.footer-text{background:var(--surface-primary);border-radius:16px;padding:var(--spacing-md) var(--spacing-lg);display:inline-block;border:1px solid var(--border-primary);box-shadow:var(--elevation-1);font-size:1rem;transition:all 0.2s ease}.footer-text:hover{background:var(--surface-secondary);transform:translateY(-1px);box-shadow:var(--elevation-2)}.footer-text{background:linear-gradient(90deg,#ffffff 0%,#e6f0ff 100%);border:1px solid #c7d2fe;color:#0f172a;font-weight:700;border-radius:18px;box-shadow:0 6px 18px rgb(2 6 23 / .06)}.footer-text i{color:#0f172a}.docs-fab{position:fixed;top:16px;right:16px;z-index:1049}.docs-fab .btn-docs{background:linear-gradient(135deg,#1e40af,#0ea5e9);color:#fff;border:none;padding:.6rem 1rem;border-radius:999px;box-shadow:0 10px 20px rgb(2 132 199 / .25),0 4px 8px rgb(2 132 199 / .2);font-weight:600}.docs-fab .btn-docs:hover{filter:brightness(1.05)}.docs-fab .btn-docs i{margin-right:6px}.modal{z-index:11000}.modal-backdrop{z-index:10990}@media (max-width:768px){.main-title{font-size:2.2rem}.app-card{padding:2rem;margin:1rem 0}.card-title{font-size:1.8rem}.action-buttons{flex-direction:column;align-items:center}.btn-action{width:100%;max-width:280px;justify-content:center}.container{padding:0 16px}.analysis-grid{grid-template-columns:1fr;gap:1rem}.sentiment-overview{grid-template-columns:1fr}.emotion-bar{grid-template-columns:1fr;gap:.5rem}.results-actions{flex-direction:column;align-items:center}.btn-lg{width:100%;max-width:280px}.accordion-header{padding:1rem 1.25rem}.accordion-header h4{font-size:1.2rem}.accordion-content{padding:1.25rem}}@media (max-width:480px){.main-title{font-size:1.8rem}.app-card{padding:1.5rem}.card-title{font-size:1.6rem}.form-control,.form-select{padding:.75rem .875rem}.results-section{padding:1.5rem}.main-sentiment-card{padding:1.5rem}.sentiment-hero{flex-direction:column;gap:.75rem}.sentiment-label{font-size:1.75rem;padding:1rem 2rem}.accordion-header{padding:.875rem}.accordion-content{padding:1rem}}@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.fade-in-up{animation:fadeInUp 0.6s ease-out}.loading{position:relative;overflow:hidden}.loading::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgb(255 255 255 / .2),transparent);animation:loading 1.5s infinite}@keyframes loading{0%{left:-100%}100%{left:100%}}.modal-content{border-radius:var(--border-radius);border:none;box-shadow:var(--shadow-xl);overflow:hidden}.modal-header{border-bottom:1px solid var(--card-border);padding:1.5rem 1.5rem 1rem;background:linear-gradient(135deg,#f8fafc 0%,#f1f5f9 100%)}.modal-title{font-weight:600;color:var(--text-primary);font-size:1.25rem}.modal-body{padding:1.5rem;line-height:1.6}.modal-footer{border-top:1px solid var(--card-border);padding:1rem 1.5rem 1.5rem}.text-center{text-align:center}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:1rem}.mb-4{margin-bottom:1.5rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:1rem}.mt-4{margin-top:1.5rem}.me-2{margin-right:.5rem}.ms-2{margin-left:.5rem}.btn:disabled{opacity:.6;cursor:not-allowed}.form-control.is-invalid{border-color:var(--error-color);box-shadow:0 0 0 3px rgb(239 68 68 / .08)}.form-control.is-valid{border-color:var(--success-color);box-shadow:0 0 0 3px rgb(16 185 129 / .08)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}::-webkit-scrollbar-thumb{background:var(--gradient-primary);border-radius:4px;border:2px solid #f1f5f9}::-webkit-scrollbar-thumb:hover{background:var(--primary-dark)}*:focus{outline:2px solid var(--primary-color);outline-offset:2px}*{transition:color 0.2s ease,background-color 0.2s ease,border-color 0.2s ease}:root{--m3-surface:#ffffff;--m3-surface-variant:#f6f7fb;--m3-outline:#e6e8ef;--m3-primary:#1e40af;--m3-primary-variant:#0ea5e9;--m3-on-primary:#ffffff;--m3-secondary:#0f172a;--m3-on-surface:#111827;--m3-on-surface-variant:#475569;--m3-radius-lg:16px;--m3-radius-md:12px;--m3-radius-sm:10px;--m3-shadow-1:0 1px 2px rgba(16, 24, 40, 0.04), 0 1px 3px rgba(16, 24, 40, 0.12);--m3-shadow-2:0 8px 24px rgba(2, 6, 23, 0.08)}body{background:var(--m3-surface-variant);color:var(--m3-on-surface)}.header-section{background:var(--m3-surface);border:1px solid var(--m3-outline);border-radius:var(--m3-radius-lg);box-shadow:var(--m3-shadow-1)}.app-card,.text-cleaning-card,.normalization-card,.tokenization-card,.stemming-lemmatization-card,.wordcloud-section,.ner-analysis-card,.pos-analysis-card,.word-sentiment-analysis,.emotion-analysis,.results-header{background:var(--m3-surface);border:1px solid var(--m3-outline);border-radius:var(--m3-radius-lg);box-shadow:var(--m3-shadow-1)}.card-header{border-bottom:1px solid var(--m3-outline)}.card-title{font-weight:700;letter-spacing:-.01em}.card-subtitle{color:var(--m3-on-surface-variant)}.step-header{padding:1rem 1.25rem;border-bottom:1px solid var(--m3-outline)}.step-icon{background:#eef2ff;color:#1e40af;border:1px solid #c7d2fe}.toolbar-btn{padding:6px 10px;border-radius:8px}.btn,.btn-primary,.btn-action,.btn-analyze{border-radius:999px;font-weight:600}.btn-analyze{background:linear-gradient(135deg,var(--m3-primary),var(--m3-primary-variant));border:none;color:var(--m3-on-primary);box-shadow:var(--m3-shadow-2)}.btn-analyze:hover{filter:brightness(1.05)}.sentiment-label{border-radius:999px;padding:.4rem .8rem;font-weight:700}.token-display .token-item,.pos-tags .word-tag,.emotion-word{border-radius:999px}.wordcloud-container{border-top:1px dashed var(--m3-outline)}.results-actions .btn{border-radius:999px}.modal-content{border-radius:var(--m3-radius-lg);box-shadow:var(--m3-shadow-2)}.modal-header{background:linear-gradient(180deg,#f8fafc,#f1f5f9)}.modal-title{font-weight:700}.docs-fab .btn-docs{border-radius:999px;font-weight:700}.docs-table thead th{background:var(--m3-surface-variant);border-bottom:1px solid var(--m3-outline)}.docs-table tbody td{border-top:1px solid var(--m3-outline)}.list-group-item{border:1px solid var(--m3-outline)}.list-group-item+.list-group-item{border-top:none}