@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap");@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+Sinhala:wght@300;400;500;600;700&display=swap");*{margin:0;padding:0;box-sizing:border-box}body,html{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6;color:#333;overflow-x:hidden;height:100%}.app-container{height:100vh;background:linear-gradient(135deg,#1e1e1e,#272726 50%,#2e373f);display:flex;flex-direction:column;overflow:hidden}.main-content{flex:1 1;display:flex;min-height:0;overflow:hidden}.mobile-menu-toggle{display:none;position:fixed;top:1rem;left:1rem;z-index:1001;background:linear-gradient(135deg,#add929,#7eb82a);border:none;border-radius:50%;width:50px;height:50px;color:white;cursor:pointer;box-shadow:0 4px 12px rgba(173,217,41,.3);transition:all .2s ease}.mobile-menu-toggle:hover{transform:scale(1.05)}.mobile-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:999;flex:1 1 auto;min-width:0}.mobile-overlay.active{display:block}.sidebar{width:320px;background:rgba(255,255,255,.08);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;overflow-y:auto;flex-shrink:0;position:relative;transition:width .25s ease,transform .3s ease}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:rgba(255,255,255,.05)}.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:3px}.sidebar.collapsed{width:48px;overflow:visible}.sidebar.collapsed .app-header .user-info,.sidebar.collapsed .history-section,.sidebar.collapsed .language-selector,.sidebar.collapsed .quick-history,.sidebar.collapsed .steps-section,.sidebar.collapsed .topics-section{display:none!important}.sidebar-toggle{position:absolute;top:24px;right:4px;width:28px;height:28px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#add929,#7eb82a);color:white;cursor:pointer;box-shadow:0 6px 14px rgba(0,0,0,.15);z-index:1200;transition:transform .15s ease}.sidebar-toggle:hover{transform:scale(1.05)}.sidebar.collapsed .sidebar-toggle{right:-14px}@media (max-width:820px){.recent-session-item{gap:.5rem;padding:.5rem}.recent-session-icon{width:20px;height:20px}.recent-session-title{font-size:.85rem}.recent-session-time{font-size:.65rem;color:rgba(255,255,255,.55)}.recent-session-load{gap:.5rem}}@media (max-width:520px){.recent-session-time{display:none}.recent-menu-dropdown{right:4px;left:auto;min-width:120px}.recent-session-item{padding:.45rem}.recent-session-title{font-size:.82rem}}.section-title{font-size:1rem;font-weight:600;color:white}.steps-section{padding-top:1.5rem;padding-right:1.5rem;padding-left:.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.app-title{font-size:1.1rem;font-weight:700;color:white;margin-bottom:.1rem;text-shadow:0 2px 8px rgba(0,0,0,.3);letter-spacing:-.5px}.app-header{gap:.75rem}.app-header,.user-info{display:flex;flex-direction:column}.user-info{gap:4px;padding:8px;background:rgb(0,0,0);border-radius:8px;border:1px solid rgba(255,255,255,.06);margin-top:auto;position:-webkit-sticky;position:sticky;bottom:12px;z-index:60}.user-email{font-size:.8rem;color:rgba(255,255,255,.8);word-break:break-all}.user-email-btn{display:flex;align-items:center;justify-content:space-between;width:100%;background:transparent;border:none;color:rgba(255,255,255,.9);font-size:14px;cursor:pointer;padding:8px 12px;border-radius:6px;transition:background .15s ease}.user-email-btn:hover{background:rgba(255,255,255,.08)}.user-email{flex:1 1;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.logout-btn{width:100%;background:transparent;border:none;color:rgba(255,255,255,.85);font-size:14px;cursor:pointer;padding:8px 12px;border-radius:6px;text-align:left;transition:background .15s ease}.logout-btn:hover{background:rgba(255,255,255,.08)}.logout-icon{font-size:.9rem}.language-selector{margin:.5rem 0;padding:.5rem;background:rgba(2,2,2,.4);border:1px solid rgba(255,255,255,.1);border-radius:.5rem}.language-label{display:block;font-size:.85rem;font-weight:600;color:rgba(255,255,255,.9);margin-bottom:.5rem}.language-select-wrapper{position:relative;display:flex;align-items:center}.language-select{width:100%;padding:.5rem .75rem;background:rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.2);border-radius:.375rem;color:white;font-size:.875rem;cursor:pointer;transition:all .2s ease;appearance:none;-webkit-appearance:none;-moz-appearance:none}.language-select:hover{border-color:rgba(255,255,255,.3);background:rgba(0,0,0,.4)}.language-select:focus{outline:none;border-color:#add929;box-shadow:0 0 0 2px rgba(173,217,41,.2)}.language-select option{background:#1a1a1a;color:white;padding:.5rem}.date-from,.date-label,.date-to,.from,.from-label,.to,.to-label{color:white!important}.calendar-icon,.datepicker .calendar-icon,.icon-calendar,.react-date-picker__calendar-button svg,.react-datepicker__current-month,.react-datepicker__day,.react-datepicker__triangle{color:white!important;fill:white!important;stroke:white!important}input[type=date]{color:white;background:transparent;border:1px solid rgba(255,255,255,.06);border-radius:6px;padding:6px 8px}input[type=date]::-webkit-calendar-picker-indicator{filter:invert(1) brightness(2) contrast(1);opacity:1}input[type=date]::-moz-focus-inner{filter:invert(1) brightness(2) contrast(1)}.login-events-filters label{color:rgba(255,255,255,.562);font-size:60%;font-weight:200}select{margin-right:8px;background:#6b6b6b;color:white;border:1px solid rgba(255,255,255,.08);padding:6px 8px;border-radius:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none}select option{background:#252525;color:white}.steps-container{display:flex;flex-direction:column;gap:.5rem}.step-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:rgba(2,2,2,.386);border-radius:.75rem;border:1px solid rgba(255,255,255,.1);transition:all .2s ease}.step-item.completed{background:rgba(4,4,4,.818);border-color:rgba(173,217,41,.3)}.step-number{width:32px;height:32px;background:rgba(255,255,255,.1);border:2px solid rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;color:white;font-size:.9rem;flex-shrink:0}.step-item.completed .step-number{background:linear-gradient(135deg,#add929,#7eb82a);border-color:#add929;color:white}.step-content{flex:1 1}.step-title{font-size:.9rem;font-weight:600;color:white;margin-bottom:.25rem}.step-description{font-size:.8rem;color:rgba(255,255,255,.7);margin:0}.step-status{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:600;color:rgba(255,255,255,.5);flex-shrink:0}.step-status.completed{color:#add929}.step-arrow{display:flex;justify-content:center;margin:.25rem 0;color:rgba(11,11,11,.571);font-weight:1.2rem}.topics-section{padding:1.5rem;flex:1 1}.topics-container{display:flex;flex-direction:column;gap:.5rem}.topic-group{border:1px solid rgba(255,255,255,.1);border-radius:.75rem;background:rgba(255,255,255,.05);overflow:hidden;transition:all .2s ease}.topic-header{width:100%;padding:1rem 1.25rem;background:none;border:none;display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-size:.9rem;font-weight:600;color:white;transition:all .2s ease}.topic-header:hover{background:rgba(255,255,255,.05)}.topic-header.selected{background:rgba(173,217,41,.15);color:#add929}.chevron{transition:transform .2s ease}.chevron.expanded{transform:rotate(180deg)}.subtopics-list{background:rgba(255,255,255,.03);border-top:1px solid rgba(255,255,255,.1)}.subtopic-item{width:100%;padding:.75rem 1.5rem;background:none;text-align:left;cursor:pointer;font-size:.85rem;color:rgba(255,255,255,.8);transition:all .2s ease;border:none;border-bottom:1px solid rgba(255,255,255,.05)}.subtopic-item:last-child{border-bottom:none}.subtopic-item:hover{background:rgba(255,255,255,.05);color:white;padding-left:1.75rem}.subtopic-item.selected{background:rgba(173,217,41,.1);color:#add929;font-weight:500}.chat-area{flex:1 1;display:flex;flex-direction:column;background:transparent;overflow:hidden;min-height:0;min-width:0}.file-preview{margin:1rem;background:rgba(255,255,255,.1);border-radius:1rem;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);overflow:hidden;flex-shrink:0}.file-preview-header{background:rgba(173,217,41,.2);color:white;padding:1rem 1.5rem;gap:.75rem}.file-preview-close{margin-left:0;background:rgba(255,255,255,.2);border:none;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:white;transition:all .2s ease}.file-preview-actions{margin-left:auto;display:flex;align-items:center;gap:5px}.file-preview-close:hover{background:rgba(255,255,255,.3);transform:scale(1.1)}.edit-headers-btn{margin-left:8px;background:transparent;border:1px solid rgba(255,255,255,.12);color:white;padding:6px 10px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .15s ease}.edit-headers-btn:hover{background:rgba(255,255,255,.04);transform:translateY(-2px)}.header-editor{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);padding:12px;border-radius:8px}.header-editor input{background:white;border:1px solid #e6e6e6;padding:8px 10px;border-radius:6px;font-size:.9rem;color:#2e373f}.header-editor .primary-ghost-btn{padding:8px 12px;font-size:.9rem}.secondary-ghost-btn{background:transparent;border:1px solid rgba(255,255,255,.08);color:white;padding:8px 12px;border-radius:8px;cursor:pointer}.secondary-ghost-btn:hover{background:rgba(255,255,255,.04);transform:translateY(-2px)}.secondary-ghost-btn:disabled{opacity:.5;cursor:default;transform:none}.file-preview-content{padding:1.5rem;max-height:400px;overflow-y:auto;background:rgba(255,255,255,.05)}.file-preview-content::-webkit-scrollbar{width:6px}.file-preview-content::-webkit-scrollbar-track{background:rgba(255,255,255,.05)}.file-preview-content::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:3px}.messages-area{flex:1 1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:1rem}.messages-area::-webkit-scrollbar{width:6px}.messages-area::-webkit-scrollbar-track{background:rgba(255,255,255,.05)}.messages-area::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:3px}.messages-area::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.3)}.empty-state-message{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;width:100%;flex:1 1;padding:2rem;gap:2rem}.empty-state-message h2{font-size:2rem;font-weight:500;color:rgba(255,255,255,.9);margin:0;text-align:center}.intro-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:1rem;gap:1rem;width:100%;max-width:900px;margin-top:1rem}.intro-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.5rem;text-align:center;transition:all .3s ease}.intro-card:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.2);transform:translateY(-4px)}.intro-icon{margin-bottom:.75rem;color:rgba(255,255,255,.9);display:flex;justify-content:center;align-items:center}.intro-icon svg{color:white;stroke-width:1.5}.intro-card h3{font-size:1.1rem;font-weight:600;color:rgba(255,255,255,.9);margin:0 0 .5rem}.intro-card p{font-size:.9rem;color:rgba(255,255,255,.6);margin:0;line-height:1.4}.demo-examples{text-align:center;max-width:700px}.demo-label{font-size:.95rem;color:rgba(255,255,255,.7);margin-bottom:.75rem;font-weight:500}.demo-prompts{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.demo-prompt{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);padding:.6rem 1rem;border-radius:20px;font-size:.85rem;color:rgba(255,255,255,.8);transition:all .2s ease;cursor:pointer}.demo-prompt:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.25);color:rgba(255,255,255,.95)}.message-wrapper{display:flex;margin-bottom:1rem}.message-wrapper.user{justify-content:flex-end}.message-wrapper.assistant{justify-content:flex-start}.message{max-width:85%;padding:1.5rem;border-radius:1.5rem;box-shadow:0 4px 12px rgba(0,0,0,.1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1)}.message.user{background:rgba(173,217,41,.9);color:white;border-bottom-right-radius:.5rem}.message.assistant{background:rgba(255,255,255,.95);color:#2e373f;border-bottom-left-radius:.5rem}.file-attachment-info{display:flex;gap:.1rem;padding:.5rem;background:rgba(255,255,255,.1);border-radius:.75rem;margin-bottom:.2rem;border:1px solid rgba(255,255,255,.2)}.file-name{font-weight:500;color:white}.file-size{font-size:.85rem;color:rgba(255,255,255,.7)}.loading-message{display:flex;align-items:center;gap:.75rem;font-style:italic;color:#666}.loading-spinner{width:20px;height:20px;border:2px solid #f3f3f3;border-top-color:#add929;border-radius:50%;animation:spin 1s linear infinite}.chart-container{width:100%;max-width:100%;margin:1rem 0;background:white;color:#000;border-radius:1rem;box-shadow:0 8px 32px rgba(0,0,0,.1);border:1px solid rgba(255,255,255,.2);position:relative;padding:1.5rem 1.5rem 1rem}.chart-wrapper{width:100%;height:400px}.chart-fullscreen-btn{position:absolute;right:2.8rem;background:linear-gradient(135deg,#4f6413,#456617);border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:white;font-size:16px;font-weight:700;box-shadow:0 4px 12px rgba(173,217,41,.3);transition:all .2s ease;z-index:10}.chart-fullscreen-btn:hover{transform:scale(1.1);box-shadow:0 6px 16px rgba(173,217,41,.4)}.preview-table{width:100%;border-collapse:collapse;margin-top:1rem;font-size:.9rem;background:white;border-radius:.5rem;overflow:hidden}.preview-table td,.preview-table th{border:1px solid #ddd;padding:.75rem;text-align:left}.preview-table th{background:linear-gradient(135deg,#add929,#7eb82a);color:white;font-weight:600}.preview-table tr:nth-child(2n),.preview-text{background:#f8f9fa}.preview-text{padding:1rem;border-radius:.5rem;font-family:Courier New,monospace;font-size:.85rem;line-height:1.4;color:#2e373f;margin:0;white-space:pre-wrap;word-break:break-word}.chart-container-wrapper{width:100%;max-width:100%;margin:1rem 0;background:white;color:#000;border-radius:1rem;padding:1.5rem;box-shadow:0 8px 32px rgba(0,0,0,.1);border:1px solid rgba(255,255,255,.2);position:relative}.chart-container-controls{position:absolute;top:1rem;right:1rem;display:flex;gap:.5rem;z-index:10}.chart-main-container{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr);grid-template-rows:auto auto;grid-template-areas:"chart table" "analytics analytics";grid-gap:1.25rem;gap:1.25rem;width:100%;align-items:start;min-width:0}.chart-area{grid-area:chart}.table-area{grid-area:table}.analytics-area{grid-area:analytics}.chart-wrapper{position:relative;min-height:400px;max-height:600px}.chart-table-container{min-width:0;overflow-y:auto;padding-left:1rem;border-left:1px solid #e0e0e0;max-height:600px}.chart-menu-container{position:relative}.chart-menu-btn{background:linear-gradient(135deg,#4f6413,#456617);border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:white;font-size:16px;font-weight:700;box-shadow:0 4px 12px rgba(173,217,41,.3);transition:all .2s ease}.chart-menu-btn:hover{transform:scale(1.1);box-shadow:0 6px 16px rgba(173,217,41,.4)}.chart-menu{position:absolute;top:100%;right:80%;background:white;border-radius:.5rem;box-shadow:0 8px 24px rgba(0,0,0,.15);border:1px solid #e0e0e0;padding:.5rem;min-width:160px;z-index:100}.chart-menu-item{width:100%;padding:.75rem 1rem;background:none;border:none;text-align:left;cursor:pointer;border-radius:.25rem;display:flex;align-items:center;gap:.5rem;color:#2e373f;font-size:.9rem;transition:all .2s ease}.chart-menu-item:hover{background:#f5f5f5}.download-menu-container{position:relative;display:inline-block}.download-menu{position:absolute;top:100%;right:0;background:white;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.15);z-index:1000;min-width:160px;margin-top:4px}.download-menu-item{width:100%;padding:12px 16px;border:none;background:white;text-align:left;cursor:pointer;font-size:14px;color:#333;display:flex;align-items:center;gap:8px;transition:background-color .2s}.download-menu-item:hover{background-color:#f5f5f5}.download-menu-item:first-child{border-radius:8px 8px 0 0}.download-menu-item:last-child{border-radius:0 0 8px 8px}.download-menu-item:only-child{border-radius:8px}.chart-fullscreen-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding:2rem;overflow:auto;-webkit-overflow-scrolling:touch}.chart-fullscreen-modal{background:white;border-radius:1rem;width:95vw;height:90vh;max-width:1400px;max-height:900px;position:relative;display:flex;flex-direction:column;box-shadow:0 25px 50px rgba(0,0,0,.3)}.fullscreen-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.fullscreen-modal-content{background:white;border-radius:1rem;width:95vw;height:90vh;max-width:1600px;display:flex;flex-direction:column;box-shadow:0 25px 50px rgba(0,0,0,.5);overflow:hidden}.fullscreen-modal-header{padding:1.5rem 2rem;border-bottom:2px solid #eee;display:flex;align-items:center;justify-content:center;position:relative;background:linear-gradient(135deg,#add929,#7eb82a);flex-shrink:0}.fullscreen-modal-header h3{margin:0;color:white;font-size:1.5rem;font-weight:600}.fullscreen-close-btn{background:rgba(255,255,255,.2);border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:white;transition:all .2s}.fullscreen-close-btn:hover{background:rgba(255,255,255,.3);transform:scale(1.1)}.fullscreen-close-btn.left{position:absolute;right:15px;top:50%;transform:translateY(-50%);z-index:20}.fullscreen-trigger-btn{width:36px;height:36px;padding:6px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12)}.fullscreen-trigger-btn:hover{transform:translateY(-2px);background:rgba(255,255,255,.06)}.fullscreen-modal-body{flex:1 1;overflow:auto;padding:1.5rem;background:#f8f9fa;min-height:0}.fullscreen-modal-body table{background:white;border-collapse:collapse;width:100%}.fullscreen-modal-body table td,.fullscreen-modal-body table th{padding:12px 16px;text-align:left;border:1px solid #e0e0e0}.fullscreen-modal-body table th{background:linear-gradient(135deg,#add929,#7eb82a);color:white;font-weight:600;position:-webkit-sticky;position:sticky;top:0;z-index:10}.fullscreen-modal-body table tr:hover{background:#f0f7e6}.fullscreen-modal-body table td{color:#333}.chart-fullscreen-header{padding:1.5rem 2rem;border-bottom:1px solid #eee;display:flex;align-items:center;justify-content:space-between;background:#f8f9fa;border-radius:1rem 1rem 0 0}.chart-fullscreen-title{margin:0;color:#2e373f;font-size:1.5rem;font-weight:600}.chart-fullscreen-title-wrap{display:flex;align-items:center;gap:12px}.chart-title-edit{display:flex;align-items:center;gap:8px}.chart-title-input{font-size:1.1rem;padding:6px 8px;border:1px solid rgba(0,0,0,.08);border-radius:6px;min-width:320px;background:white;color:#2e373f}.chart-title-cancel,.chart-title-save{padding:6px 8px;border-radius:6px;border:none;background:#9ccd29;color:white;cursor:pointer;font-weight:600}.chart-title-cancel{background:transparent;color:#9ccd29;border:1px solid rgba(0,0,0,.06)}.chart-axis-editor{display:flex;align-items:center;gap:8px}.chart-edit-axes-btn{width:40px;height:40px;border-radius:50%;margin-right:8px;border:1px solid rgba(0,0,0,.06);background-color:#9ccd29;color:white;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.chart-edit-axes-btn:hover{filter:brightness(.95)}.chart-edit-axes-btn .edit-icon-circle{width:28px;height:28px;background:rgba(255,255,255,.12)}.chart-edit-axes-btn .edit-icon-circle,.chart-edit-headers-btn{display:inline-flex;border-radius:50%;align-items:center;justify-content:center}.chart-edit-headers-btn{width:40px;height:40px;margin-left:8px;border:1px solid rgba(0,0,0,.06);background-color:#9ccd29;color:white;cursor:pointer}.chart-edit-headers-btn:hover{filter:brightness(.95);transform:translateY(-1px)}.axis-input,.chart-table-header-input{padding:6px 8px;border:1px solid rgba(0,0,0,.08);border-radius:6px;font-size:13px;background:#ffffff;color:#222}.chart-edit-buttons{display:inline-flex;gap:8px;align-items:center}.secondary-ghost-btn-2{background:transparent;border:1px solid rgb(165,164,164);color:rgb(115,114,114);padding:8px 12px;border-radius:8px;cursor:pointer}.secondary-ghost-btn-2:hover{background:rgba(255,255,255,.04);transform:translateY(-2px)}.secondary-ghost-btn-2:disabled{opacity:.5;cursor:default;transform:none}.axis-editors{gap:8px}.axis-editors,.axis-label{display:flex;align-items:center}.axis-label{gap:6px;font-size:13px;color:#2e373f}.axis-input{padding:6px 8px;border:1px solid rgba(0,0,0,.06);border-radius:6px;min-width:120px}.axis-actions{display:flex;gap:6px}.axis-cancel,.axis-save{padding:6px 8px;border-radius:6px;border:none;cursor:pointer;background:#9ccd29;color:white;font-weight:600}.axis-cancel{background:transparent;color:#9ccd29;border:1px solid rgba(0,0,0,.06)}.chart-fullscreen-close{background:#ff4757;border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:white;transition:all .2s ease}.chart-fullscreen-close:hover{transform:scale(1.1);background:#ff3838}.chart-fullscreen-content{flex:1 1;padding:2rem;overflow:auto;display:grid;grid-template-columns:2fr .7fr 1fr;grid-template-rows:auto auto;grid-template-areas:"chart legend table" "analytics analytics analytics";grid-gap:1.5rem;gap:1.5rem}.chart-fullscreen-chart{grid-area:chart;align-items:center;min-height:400px;position:relative}.chart-fullscreen-chart,.chart-fullscreen-legend{display:flex;justify-content:center;background:#f8f9fa;border-radius:.5rem;padding:1rem}.chart-fullscreen-legend{grid-area:legend;align-items:flex-start;min-height:120px;max-height:640px;overflow-y:auto}.chart-fullscreen-table{grid-area:table;display:flex;flex-direction:column;background:#f8f9fa;border-radius:.5rem;padding:1.5rem;overflow:hidden;min-width:280px;max-width:560px}.chart-fullscreen-analytics{grid-area:analytics}.chart-fullscreen-table>.chart-table-scroll{flex:1 1 auto;overflow-y:auto;max-height:calc(90vh - 320px);min-height:120px}.chart-table-scroll{width:100%;height:100%;overflow-x:auto;overflow-y:auto}.fullscreen-table{width:100%;border-collapse:collapse;font-size:.9rem;background:white;border-radius:.5rem;overflow:hidden}.fullscreen-table th{background:linear-gradient(135deg,#add929,#7eb82a);color:white;padding:1rem;text-align:left;font-weight:600;position:-webkit-sticky;position:sticky;top:0;z-index:10}.fullscreen-table td{border:1px solid #eee;padding:.75rem 1rem;text-align:left;color:#2e373f}.fullscreen-table tr:nth-child(2n){background:#f8f9fa}.fullscreen-table tr:hover{background:#e8f5e8}.input-area{padding-left:1.5rem;padding-right:1.5rem;background:rgba(255,255,255,.08);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.1);flex-shrink:0}.input-container{display:flex;gap:.75rem;align-items:flex-end;max-width:100%}.file-upload-btn{flex-shrink:0;width:50px;height:50px;background:linear-gradient(135deg,#add929,#7eb82a);border:none;border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(173,217,41,.3);cursor:pointer;transition:all .2s ease;color:white;margin-bottom:8px}.file-upload-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(173,217,41,.4)}.file-upload-btn:active{transform:translateY(0)}.hidden-file-input{display:none}.input-wrapper{flex:1 1;display:flex;align-items:flex-end}.chat-input{flex:1 1;min-height:50px;max-height:120px;padding:.75rem 80px .75rem 3.5rem;border-radius:12px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.1);color:white;font-family:inherit;font-weight:400;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);resize:none;overflow-y:auto;transition:all .2s ease}.chat-input:focus{outline:none;border-color:#add929;background:rgba(255,255,255,.15);box-shadow:0 0 0 3px rgba(173,217,41,.2)}.chat-input::placeholder{color:rgba(255,255,255,.6)}.send-btn{position:absolute;right:8px;bottom:15px;width:34px;height:34px;background:linear-gradient(135deg,#add929,#7eb82a);border:none;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:white}.send-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px rgba(173,217,41,.3)}.send-btn:active{transform:scale(.95)}.send-btn:disabled{background:rgba(255,255,255,.1);cursor:not-allowed;transform:none}.send-btn:disabled:hover{transform:none;box-shadow:none}.new-chat-btn{background:rgba(255,255,255,.06);color:white;border:1px solid rgba(255,255,255,.08);padding:6px 12px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;gap:6px;font-size:.875rem}.new-chat-btn svg{flex-shrink:0}.new-chat-btn:hover{background:linear-gradient(135deg,#add929,#7eb82a);transform:translateY(-2px);box-shadow:0 6px 12px rgba(173,217,41,.2)}.new-chat-btn:active{transform:translateY(0)}.send-icon{width:18px;height:18px}.chart-type-selector{flex-shrink:0;position:relative;margin-bottom:8px}.chart-type-select{padding:.75rem 40px .75rem 1rem;border-radius:12px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.1);color:white;font-weight:500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-size:.9rem;min-width:140px;cursor:pointer;transition:all .2s ease;appearance:none;-webkit-appearance:none;-moz-appearance:none}.chart-type-select:focus{outline:none;border-color:#add929;background:rgba(255,255,255,.15);box-shadow:0 0 0 3px rgba(173,217,41,.2)}.chart-type-select option{background:#2e373f;color:white;padding:.5rem}.footer-text{margin-top:1.5rem;font-size:.85rem;color:rgba(255,255,255,.6);text-align:center}.footer-text a{color:#add929;text-decoration:none;font-weight:500;transition:all .2s ease}.language-upload-prompt{margin-top:8px;padding:.6rem;background:rgb(0,0,0);border:1px solid rgb(83,82,82);border-radius:8px}.small-ghost-btn{border:1px solid rgba(255,255,255,.12);color:white;padding:6px 10px;font-weight:600}.small-ghost-btn:hover{background:rgba(255,255,255,.06)}.language-select-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);z-index:12000}.language-select-modal,.language-select-modal-overlay{display:flex;align-items:center;justify-content:center}.language-select-modal{background:rgba(15,23,32,.629);padding:24px;border-radius:0;width:100vw;height:100vh;max-width:none;max-height:none;color:#e6eef3;box-shadow:none;text-align:center;flex-direction:column}.language-select-card{background:linear-gradient(180deg,rgba(16,24,32,.92),rgba(10,14,18,.94));border-radius:12px;padding:28px 22px;width:min(720px,92vw);max-width:720px;color:#e6eef3;box-shadow:0 30px 80px rgba(2,6,23,.6),inset 0 1px 0 rgba(255,255,255,.02);text-align:left;transform-origin:center;animation:modalCardIn .26s cubic-bezier(.2,.9,.2,1)}@keyframes modalCardIn{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.language-select-card h3{margin:0 0 8px;font-size:1.25rem}.language-select-card p{margin:0 0 14px;color:#cfe8ff}.modal-form-row{display:flex;align-items:center;gap:12px;width:100%;justify-content:center}.modal-form-row .modal-label{min-width:130px;color:#e6eef3;font-weight:600;text-align:right}.modal-form-row .modal-field{flex:1 1 320px;min-width:160px}@media (max-width:640px){.modal-form-row{flex-direction:column;align-items:stretch}.modal-form-row .modal-label{text-align:left;min-width:auto}.modal-form-row .modal-field{width:100%}}body.modal-open .language-selector{opacity:0;pointer-events:none;transform:translateX(-6px);transition:opacity .17s ease,transform .17s ease}body.modal-open .main-content{filter:blur(1px) brightness(.85)}.language-select-modal h3{margin:0 0 8px}.primary-ghost-btn{background:linear-gradient(135deg,#add929,#7eb82a);border:none;color:white;padding:10px;border-radius:8px;font-weight:700;cursor:pointer}.close-modal-btn{background:transparent;border:1px solid rgba(255,255,255,.08);color:white;padding:8px 12px;border-radius:8px;cursor:pointer}.modal-language-select{width:100%;max-width:360px;background:rgb(241,239,239);border:1px solid rgba(255,255,255,.06);color:#000000;padding:8px 27px 8px 10px;border-radius:8px;font-size:14px}.modal-language-select:focus{outline:2px solid rgba(173,217,41,.18);box-shadow:0 0 0 3px rgba(173,217,41,.06)}.modal-language-select-wrapper{position:relative;display:inline-block;width:100%}.modal-select-icon{position:absolute;top:50%;transform:translateY(-50%);right:5px;pointer-events:none;color:#cbd5e1}.language-modal-actions{display:flex;gap:12px;justify-content:center;margin-top:12px}.language-modal-confirm{background:linear-gradient(135deg,#22c55e,#16a34a);color:white;border:none;padding:10px 16px;border-radius:10px;font-weight:700;cursor:pointer;box-shadow:0 8px 18px rgba(16,185,129,.12);transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease}.language-modal-confirm:hover{transform:translateY(-2px);box-shadow:0 16px 28px rgba(16,185,129,.14)}.language-modal-confirm:active{transform:translateY(0);opacity:.95}.language-modal-confirm:focus{outline:3px solid rgba(34,197,94,.18)}.language-modal-cancel{background:transparent;color:#e6eef3;border:1px solid rgba(255,255,255,.08);padding:8px 14px;border-radius:10px;cursor:pointer;transition:background .12s ease,color .12s ease,transform .12s ease}.language-modal-cancel:hover{background:rgba(255,255,255,.03);transform:translateY(-1px)}.language-modal-cancel:active{transform:translateY(0);opacity:.95}.language-modal-cancel:focus{outline:3px solid rgba(255,255,255,.06)}.footer-text a:hover{color:white;text-shadow:0 0 8px rgba(173,217,41,.6)}.color-picker-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:2rem}.color-picker-modal{background:white;border-radius:1rem;width:100%;max-width:500px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 25px 50px rgba(0,0,0,.3)}.color-picker-header{padding:1.5rem;border-bottom:1px solid #eee;display:flex;align-items:center;justify-content:space-between}.color-picker-header h3{margin:0;color:#2e373f;font-size:1.25rem}.color-picker-close{background:#ff4757;border:none;border-radius:50%;width:35px;height:35px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:white;transition:all .2s ease}.color-picker-close:hover{transform:scale(1.1);background:#ff3838}.color-picker-content{padding:1.5rem;flex:1 1;overflow-y:auto}.color-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));grid-gap:1rem;gap:1rem;margin-bottom:2rem}.color-item{display:flex;flex-direction:column;gap:.5rem}.color-item label{font-size:.9rem;color:#666;font-weight:500}.color-input{width:100%;height:50px;border:2px solid #e0e0e0;border-radius:.5rem;cursor:pointer;transition:all .2s ease}.color-input:hover{border-color:#add929}.color-picker-actions{display:flex;gap:1rem;justify-content:flex-end}.reset-colors-btn{padding:.75rem 1.5rem;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:.5rem;cursor:pointer;font-weight:500;color:#666;transition:all .2s ease}.reset-colors-btn:hover{background:#e9ecef}.save-colors-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#add929,#7eb82a);border:none;border-radius:.5rem;cursor:pointer;font-weight:500;color:white;transition:all .2s ease}.save-colors-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(173,217,41,.3)}.sample-prompts-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:2rem}.sample-prompts-modal{background:white;border-radius:1rem;width:100%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 25px 50px rgba(0,0,0,.3)}.sample-prompts-header{padding:1.5rem;border-bottom:1px solid #eee;display:flex;align-items:center;justify-content:space-between}.sample-prompts-header h3{margin:0;color:#2e373f;font-size:1.25rem}.sample-prompts-close{background:#ff4757;border:none;border-radius:50%;width:35px;height:35px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:white;transition:all .2s ease}.sample-prompts-close:hover{transform:scale(1.1);background:#ff3838}.sample-prompts-content{padding:1.5rem;flex:1 1;overflow-y:auto}.prompts-grid{display:grid;grid-template-columns:1fr;grid-gap:.75rem;gap:.75rem}.prompt-item{padding:1rem;background:#f8f9fa;border:1px solid #e9ecef;border-radius:.5rem;text-align:left;cursor:pointer;transition:all .2s ease;font-size:.9rem;color:#2e373f}.prompt-item:hover{background:#e8f5e8;border-color:#add929;transform:translateY(-1px)}.sample-prompts-btn{position:absolute;right:45px;top:60%;transform:translateY(-50%);width:32px;height:32px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:rgba(255,255,255,.7)}.sample-prompts-btn:hover{background:rgba(255,255,255,.2);color:white;transform:translateY(-50%) scale(1.05)}.chart-download-btn{background:linear-gradient(135deg,#add929,#7eb82a);border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:white;margin-right:.5rem;transition:all .2s ease}.chart-download-btn:hover{transform:scale(1.1)}.chart-fullscreen-controls{display:flex;align-items:center;position:relative}.axis-editor-popup{position:absolute;top:48px;right:4px;z-index:60;background:white;border:1px solid rgba(0,0,0,.08);border-radius:8px;padding:12px;box-shadow:0 8px 24px rgba(0,0,0,.12);min-width:260px}.axis-editor-popup .axis-editors{display:flex;flex-direction:column;gap:8px}.axis-editor-popup .axis-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:6px}.axis-editor-popup .axis-label{font-size:13px}.axis-editor-popup .close-popup-btn{position:absolute;top:6px;right:6px;background:transparent;border:none;cursor:pointer;color:#6b7280}.chart-color-btn{background:linear-gradient(135deg,#add929,#7eb82a);border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:white;margin-right:.5rem;transition:all .2s ease}.chart-color-btn:hover{transform:scale(1.1)}@media (max-width:1024px){.sidebar{width:280px}.chart-main-container{grid-template-columns:1fr;grid-template-areas:"chart" "table" "analytics";gap:1rem}.chart-table-container{border-left:none;border-top:1px solid #e0e0e0;padding-left:0;padding-top:1rem;min-width:auto}}@media (max-width:768px){.sidebar{position:fixed;left:-320px;top:0;height:100vh;z-index:1000;transition:left .3s ease}.sidebar.active{left:0}.mobile-menu-toggle{display:flex}.input-container{flex-direction:column;gap:.75rem;align-items:stretch}.file-upload-btn{order:2;width:100%;height:45px;border-radius:12px;margin-bottom:0}.chart-type-selector{order:3;width:100%;margin-bottom:0}.chart-type-select{width:100%;padding:.75rem 1rem}.input-wrapper{order:1;width:100%}.chart-fullscreen-content{display:flex;flex-direction:column;gap:1rem}.chart-fullscreen-chart{min-height:250px;max-height:350px}.chart-fullscreen-table{max-height:300px}.color-grid{grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}.prompts-grid{gap:.5rem}.prompt-item{padding:.75rem;font-size:.85rem}}@media (max-width:480px){.app-title{font-size:1.1rem}.steps-section,.topics-section{padding:1rem}.step-item{padding:.75rem}.chart-fullscreen-modal{width:98vw;height:95vh;margin:1rem}.chart-fullscreen-content{padding:1rem}}@media (max-width:360px){.mobile-menu-toggle{width:45px;height:45px}.file-upload-btn{height:40px}.chart-type-select{padding:.65rem 1rem;font-size:.85rem}}.analysis-summary{background:#f8f9fa;border-radius:.5rem;padding:1rem;margin-top:1rem}.analysis-summary h4{margin:0 0 1rem;color:#ffffff;font-size:1.1rem;font-weight:600}.analysis-summary h5{margin:1rem 0 .5rem;color:#2e373f;font-size:.9rem;font-weight:600}.refresh-warning-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:12000;display:flex;align-items:center;justify-content:center;padding:1.25rem}.refresh-warning-modal{width:min(560px,96vw);background:linear-gradient(180deg,#ffffff,#f6f9f6);border-radius:12px;box-shadow:0 30px 80px rgba(12,18,20,.45);overflow:hidden;color:#21303a;animation:modalIn .2s cubic-bezier(.2,.9,.2,1)}.refresh-warning-header{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid rgba(0,0,0,.04);background:linear-gradient(90deg,rgba(173,217,41,.06),rgba(255,255,255,.02))}.refresh-warning-header h3{margin:0;font-size:1.05rem;font-weight:700;color:#16323a}.refresh-warning-content{padding:14px 18px;font-size:.96rem;color:#234048}.refresh-warning-actions{gap:10px;padding:14px 18px;align-items:center;border-top:1px solid rgba(0,0,0,.03)}.refresh-warning-actions button{padding:10px 14px;border-radius:8px;font-weight:700;font-size:.92rem;cursor:pointer;border:none}.cancel-refresh-btn{background:transparent;border:1px solid rgba(33,48,58,.08);color:#16323a}.confirm-refresh-btn{background:linear-gradient(180deg,#ef5b5b,#e04343)}.save-refresh-btn{background:linear-gradient(135deg,#add929,#7eb82a);color:white}.refresh-warning-actions button:disabled{opacity:.6;cursor:default}@keyframes modalIn{0%{opacity:0;transform:translateY(8px) scale(.995)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width:480px){.refresh-warning-modal{width:calc(100% - 28px);border-radius:10px}.refresh-warning-header{padding:12px}.refresh-warning-content{padding:12px;font-size:.95rem}.refresh-warning-actions{padding:12px;gap:8px}.refresh-warning-actions button{padding:10px;font-size:.88rem}}.summary-section p{color:#555;font-size:.9rem;line-height:1.4}.insights-section ul,.recommendations-section ul{margin:.5rem 0 0 1rem;padding:0}.insights-section li,.recommendations-section li{color:#555;font-size:.85rem;line-height:1.4;margin-bottom:.25rem}.metrics-section{background:#e8f5e8;border-radius:.25rem;padding:.75rem;margin-top:.5rem}.metrics-section p{margin:.25rem 0;color:#2e373f;font-size:.85rem;font-weight:500}.text-analysis-options{background:#f0f8ff;border-radius:.5rem;padding:1rem;margin:1rem 0;border:1px solid #add929}.text-analysis-options h4{margin:0 0 1rem;color:#2e373f;font-size:1rem;font-weight:600}.text-column-selector{margin-bottom:1rem}.text-column-selector label{display:block;color:#2e373f;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.text-column-select{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:.25rem;background:white;color:#2e373f;font-size:.9rem}.analysis-suggestions label{display:block;color:#2e373f;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.suggestion-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.suggestion-btn{padding:.5rem 1rem;background:#add929;color:white;border:none;border-radius:.25rem;font-size:.8rem;cursor:pointer;transition:all .2s ease}.suggestion-btn:hover{background:#7eb82a;transform:translateY(-1px)}.text-analysis-badge{background:#add929;color:white;padding:.25rem .5rem;border-radius:.25rem;font-size:.8rem;font-weight:500}.messages-toolbar{padding:.5rem 1rem;display:flex;justify-content:flex-end}.export-open-btn{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,#4f6413,#456617);color:white;border:none;padding:8px 12px;border-radius:8px;cursor:pointer;box-shadow:0 6px 18px rgba(0,0,0,.15);transition:transform .12s ease,box-shadow .12s ease}.export-open-btn:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(0,0,0,.18)}.export-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:14000;display:flex;align-items:center;justify-content:center;padding:1rem}.export-modal{width:min(820px,96vw);max-height:90vh;background:white;border-radius:12px;box-shadow:0 30px 80px rgba(0,0,0,.3);overflow:hidden;display:flex;flex-direction:column}.export-modal-header{padding:1rem 1.25rem;border-bottom:1px solid #eee;display:flex;align-items:center;gap:12px}.export-modal-header h3{margin:0;font-size:1.05rem;color:#16323a}.export-modal-content{padding:1rem;overflow:auto;flex:1 1}.export-cover-row{padding-bottom:8px;border-bottom:1px dashed #f3f4f6;margin-bottom:12px}.export-cover-row label{color:#243038;font-weight:600}.export-cover-row input[type=text],.export-cover-row textarea{width:100%;padding:8px 10px;border-radius:8px;border:1px solid #e6eef0;background:#fff}.export-cover-row textarea{font-family:inherit;font-size:14px}.export-cover-row input[type=number]{padding:6px 8px;border-radius:6px;border:1px solid #e6eef0}.export-cover-row input[type=color]{width:36px;height:28px;padding:2px;border:none;background:transparent;cursor:pointer}.export-cover-row select{padding:6px 8px;border-radius:6px;border:1px solid #e6eef0}.export-cover-row .cover-style-controls{display:flex;gap:10px;align-items:center;margin-top:8px;flex-wrap:wrap}.export-cover-row .cover-style-controls label{display:inline-flex;align-items:center;gap:6px;font-weight:500;color:#334e58}.export-items-list{display:flex;flex-direction:column;gap:.5rem}.export-item{display:grid;grid-template-columns:28px 1fr auto auto;grid-gap:8px;gap:8px;align-items:center;padding:.5rem;border-radius:8px;border:1px solid #f0f0f0}.export-item-label{font-size:.9rem;color:#21303a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.export-item-type{font-size:.85rem;color:#586069;display:flex;gap:8px;align-items:center}.export-item-order{display:flex;gap:6px}.export-item-order button{background:transparent;border:1px solid #ddd;padding:6px 8px;border-radius:6px;cursor:pointer}.export-modal-actions{padding:12px 16px;border-top:1px solid #eee;display:flex;gap:8px;justify-content:flex-end}.download-pdf-btn{background:linear-gradient(135deg,#22c55e,#16a34a);color:white;border:none;border-radius:8px;display:inline-flex;gap:8px;align-items:center}.cancel-btn,.download-pdf-btn{padding:8px 12px;cursor:pointer}.cancel-btn{background:transparent;border:1px solid #d1d5db;border-radius:8px}.download-pdf-btn.loading{opacity:.95;cursor:wait}.download-pdf-btn[disabled]{opacity:.65;cursor:wait;pointer-events:none}.btn-spinner{display:inline-block;animation:spin 1s linear infinite}.exporting .chart-color-btn,.exporting .chart-container-controls,.exporting .chart-download-btn,.exporting .chart-fullscreen-btn,.exporting .chart-fullscreen-close,.exporting .chart-menu,.exporting .chart-menu-btn,.exporting .chart-menu-container{display:none!important}@media (max-width:640px){.export-item{grid-template-columns:24px 1fr;grid-template-rows:auto auto}.export-item-type{grid-column:2/-1}.export-item-order{grid-column:2/-1;justify-self:end}}.text-column{background:#e8f5e8!important}.text-indicator{margin-left:.5rem;font-size:.8rem}.text-analysis-info{background:#e8f5e8;border-radius:.25rem;padding:.75rem;margin-top:1rem;border-left:3px solid #add929}.text-analysis-info p{margin:0;color:#2e373f;font-size:.9rem;font-weight:500}.text-analysis-results{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-radius:1rem;padding:1.5rem;margin:1rem 0;border:1px solid #cbd5e1;box-shadow:0 4px 6px -1px rgba(0,0,0,.1)}.analysis-header h3{margin:0 0 1.5rem;color:#1e293b;font-size:1.25rem;font-weight:700;display:flex;align-items:center;gap:.5rem}.analysis-content{display:flex;flex-direction:column;gap:1.5rem}.insights-section,.metrics-section,.recommendations-section,.summary-section{background:white;border-radius:.75rem;padding:1.25rem;border-left:4px solid #add929;box-shadow:0 2px 4px -1px rgba(0,0,0,.06)}.insights-section h4,.metrics-section h4,.recommendations-section h4,.summary-section h4{margin:0 0 1rem;color:#1e293b;font-size:1rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.summary-section p{margin:0;color:#475569;font-size:.95rem;line-height:1.6}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:1rem;gap:1rem;margin-bottom:1rem}.metric-item{display:flex;justify-content:space-between;align-items:center;background:#f1f5f9;padding:.75rem;border-radius:.5rem;border:1px solid #e2e8f0}.metric-label{color:#64748b;font-size:.875rem;font-weight:500}.metric-value{color:#1e293b;font-size:.875rem;font-weight:700}.emotions,.main-topics,.top-words{margin-top:1rem}.emotions h5,.main-topics h5,.top-words h5{margin:0 0 .75rem;color:#374151;font-size:.875rem;font-weight:600}.emotion-tags,.topic-tags,.word-tags{display:flex;flex-wrap:wrap;gap:.5rem}.emotion-tag,.topic-tag,.word-tag{background:#add929;color:white;padding:.375rem .75rem;border-radius:1rem;font-size:.8rem;font-weight:500;display:inline-block}.topic-tag{background:#3b82f6}.emotion-tag{background:#8b5cf6}.insights-list,.recommendations-list{margin:0;padding-left:1.25rem;list-style-type:none}.insights-list li,.recommendations-list li{color:#475569;font-size:.9rem;line-height:1.5;margin-bottom:.75rem;position:relative}.insights-list li:before{content:"💡";position:absolute;left:-1.25rem;top:0}.recommendations-list li:before{content:"🎯";position:absolute;left:-1.25rem;top:0}@media (max-width:768px){.metrics-grid{grid-template-columns:1fr}.text-analysis-results{padding:1rem}.analysis-header h3{font-size:1.1rem}}.warning-icon-wrapper{flex-shrink:0;width:48px;height:48px;background:rgba(11,245,42,.1);border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid rgba(11,245,19,.2)}.warning-text{flex:1 1}.warning-text h2{margin:0 0 .25rem;font-size:1.25rem;color:#12920e;font-weight:700;line-height:1.3}.warning-subtitle{margin:0;font-size:.875rem;color:#14a107;font-weight:500;opacity:.8}.modal-close-btn{position:absolute;top:1rem;right:1rem;background:rgba(255,255,255,.9);border:1px solid rgba(0,0,0,.1);border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#6b7280;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.modal-close-btn:hover{background:white;color:#374151;transform:scale(1.05);box-shadow:0 2px 4px rgba(0,0,0,.1)}.refresh-warning-content{padding:1.5rem}.warning-message{color:#374151;line-height:1.6}.warning-message p{margin:0 0 1rem;font-size:.95rem}.warning-message strong{color:#1f2937;font-weight:600}.data-loss-list{margin:1rem 0 1.5rem;list-style:none;background:#f8fafc;border-radius:8px;padding:1rem;border:1px solid #e2e8f0}.data-loss-list li{padding:.5rem 0;font-size:.9rem;color:#475569;display:flex;align-items:center;gap:.75rem;border-bottom:1px solid #e2e8f0}.data-loss-list li:last-child{border-bottom:none;padding-bottom:0}.warning-note{background:linear-gradient(135deg,#c7fed2,#aafeb0);padding:.75rem 1rem;border-radius:8px;border:1px solid #3dfb24;margin:1rem 0 0;font-size:.875rem;color:#0e9217}.warning-note em{font-style:normal;font-weight:500}.refresh-warning-actions{padding:1rem 1.5rem 1.5rem;background:#f8fafc;border-top:1px solid #e2e8f0;display:flex;gap:.75rem;justify-content:flex-end}.cancel-refresh-btn,.confirm-refresh-btn{padding:.75rem 1.5rem;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;display:flex;align-items:center;gap:.5rem;min-width:120px;justify-content:center}.cancel-refresh-btn{background:white;color:#6b7280;border:1px solid #d1d5db}.cancel-refresh-btn:hover{background:#f9fafb;color:#374151;border-color:#9ca3af;transform:translateY(-1px);box-shadow:0 2px 4px rgba(0,0,0,.05)}.confirm-refresh-btn{background:linear-gradient(135deg,#dc2626,#b91c1c);color:white;border:1px solid #dc2626}.confirm-refresh-btn:hover{background:linear-gradient(135deg,#b91c1c,#991b1b);transform:translateY(-1px);box-shadow:0 4px 12px rgba(220,38,38,.3)}.confirm-refresh-btn:active{transform:translateY(0)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width:640px){.refresh-warning-modal{width:95%;margin:1rem;max-width:none}.refresh-warning-header{padding:1rem;flex-direction:column;text-align:center;gap:.75rem}.modal-close-btn{position:static;margin-left:auto}.warning-text h2{font-size:1.125rem}.refresh-warning-content{padding:1rem}.refresh-warning-actions{padding:1rem;flex-direction:column}.cancel-refresh-btn,.confirm-refresh-btn{width:100%;justify-content:center}.data-loss-list{padding:.75rem}.data-loss-list li{font-size:.85rem;padding:.375rem 0}}.logout-confirm-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem;animation:fadeIn .3s ease-out}.logout-confirm-modal{background:white;border-radius:16px;box-shadow:0 25px 50px rgba(0,0,0,.25);max-width:480px;width:100%;overflow:hidden;animation:slideUp .3s ease-out}.logout-confirm-header{padding:1.5rem;background:#fef3c7;border-bottom:1px solid #fde68a;display:flex;align-items:center;gap:1rem;position:relative}.logout-confirm-header h3{margin:0;font-size:1.25rem;color:#92400e;font-weight:700}.logout-confirm-content{padding:1.5rem}.logout-confirm-content p{margin:0;color:#374151;line-height:1.6;font-size:.95rem}.logout-confirm-actions{padding:1rem 1.5rem 1.5rem;background:#f8fafc;border-top:1px solid #e2e8f0;display:flex;gap:.75rem;justify-content:flex-end}.cancel-logout-btn,.confirm-logout-btn{padding:.75rem 1.5rem;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;display:flex;align-items:center;gap:.5rem;min-width:120px;justify-content:center}.cancel-logout-btn{background:white;color:#6b7280;border:1px solid #d1d5db}.cancel-logout-btn:hover{background:#f9fafb;color:#374151;border-color:#9ca3af;transform:translateY(-1px);box-shadow:0 2px 4px rgba(0,0,0,.05)}.confirm-logout-btn{background:linear-gradient(135deg,#dc2626,#b91c1c);color:white;border:1px solid #dc2626}.confirm-logout-btn:hover{background:linear-gradient(135deg,#b91c1c,#991b1b);transform:translateY(-1px);box-shadow:0 4px 12px rgba(220,38,38,.3)}.confirm-logout-btn:active{transform:translateY(0)}@media (max-width:640px){.logout-confirm-modal{width:95%;margin:1rem;max-width:none}.logout-confirm-header{padding:1rem;flex-direction:column;text-align:center;gap:.75rem}.logout-confirm-header h3{font-size:1.125rem}.logout-confirm-content{padding:1rem}.logout-confirm-actions{padding:1rem;flex-direction:column}.cancel-logout-btn,.confirm-logout-btn{width:100%;justify-content:center}}.toast{position:fixed;top:2rem;right:2rem;z-index:10001;min-width:320px;max-width:480px;border-radius:12px;box-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,.04),0 0 0 1px rgba(0,0,0,.05);animation:slideInToast .4s cubic-bezier(.16,1,.3,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.toast-content{display:flex;align-items:flex-start;gap:.75rem;padding:1rem}.toast-icon{flex-shrink:0;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:white}.toast-message{flex:1 1;min-width:0}.toast-title{font-size:.95rem;font-weight:600;color:white;margin-bottom:.25rem;line-height:1.3}.toast-description{font-size:.85rem;color:rgba(255,255,255,.9);line-height:1.4}.toast-close{flex-shrink:0;background:rgba(255,255,255,.2);border:none;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:rgba(255,255,255,.8);transition:all .2s ease}.toast-close:hover{background:rgba(255,255,255,.3);color:white;transform:scale(1.05)}.toast-success{background:linear-gradient(135deg,#10b981,#059669);border:1px solid #059669}.toast-success .toast-icon{background:rgba(255,255,255,.2)}.toast-error{background:linear-gradient(135deg,#ef4444,#dc2626);border:1px solid #dc2626}.toast-error .toast-icon{background:rgba(255,255,255,.2)}.toast-warning{background:linear-gradient(135deg,#f59e0b,#d97706);border:1px solid #d97706}.toast-warning .toast-icon{background:rgba(255,255,255,.2)}.toast-info{background:linear-gradient(135deg,#3b82f6,#2563eb);border:1px solid #2563eb}.toast-info .toast-icon{background:rgba(255,255,255,.2)}.error-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.75);display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .3s ease-out}.error-modal{background:white;border-radius:16px;padding:0;max-width:520px;width:90%;max-height:90vh;overflow:hidden;box-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,.04),0 0 0 1px rgba(0,0,0,.05);border:1px solid #e5e5e5;animation:slideUp .4s cubic-bezier(.16,1,.3,1);position:relative}.error-modal-header{background:linear-gradient(135deg,#fecaca,#fca5a5);padding:1.5rem;border-bottom:1px solid #f3f4f6;display:flex;align-items:flex-start;gap:1rem;position:relative}.error-icon-wrapper{flex-shrink:0;width:48px;height:48px;background:rgba(220,38,38,.1);border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid rgba(220,38,38,.2)}.error-text h3{margin:0 0 .25rem;font-size:1.25rem;color:#dc2626;font-weight:700;line-height:1.3}.error-subtitle{margin:0;font-size:.875rem;color:#b91c1c;font-weight:500;opacity:.8}.error-modal-content{padding:1.5rem;max-height:60vh;overflow-y:auto}.error-message h4{margin:0 0 .75rem;color:#1f2937;font-size:1rem;font-weight:600}.error-message p{margin:0 0 1rem;color:#4b5563;font-size:.95rem;line-height:1.6}.error-details{background:#f8fafc;border-radius:8px;padding:1rem;border:1px solid #e2e8f0;margin-top:1rem}.error-details summary{cursor:pointer;font-weight:600;color:#374151;margin-bottom:.5rem}.error-details code{display:block;background:#1f2937;color:#f9fafb;padding:.75rem;border-radius:6px;font-size:.8rem;line-height:1.4;font-family:Courier New,monospace;white-space:pre-wrap;word-break:break-all;margin-top:.5rem}.error-modal-actions{padding:1rem 1.5rem 1.5rem;background:#f8fafc;border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end}.error-close-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#30c730,#1ec13f);color:white;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:100px}.error-close-btn:hover{background:linear-gradient(135deg,#188f2d,#0e6615);transform:translateY(-1px);box-shadow:0 4px 12px rgba(59,130,246,.3)}@keyframes slideInToast{0%{opacity:0;transform:translateX(100%) scale(.95)}to{opacity:1;transform:translateX(0) scale(1)}}@media (max-width:640px){.toast{top:1rem;right:1rem;left:1rem;min-width:auto;max-width:none}.toast-content{padding:.875rem}.toast-icon{width:36px;height:36px}.toast-title{font-size:.9rem}.toast-description{font-size:.8rem}.error-modal{width:95%;margin:1rem;max-width:none}.error-modal-actions,.error-modal-content,.error-modal-header{padding:1rem}}.word-cloud-container{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem;margin:1rem 0;box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06)}.word-cloud-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.word-cloud-header h4{margin:0;color:#1f2937;font-size:1.25rem;font-weight:600}.word-cloud-controls{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.view-toggle{display:flex;background:#ffffff;border-radius:8px;padding:4px;box-shadow:0 1px 3px rgba(0,0,0,.1)}.view-btn{padding:8px 16px;border:none;background:transparent;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease;color:#6b7280}.view-btn:hover{background:#f3f4f6;color:#374151}.view-btn.active{background:#3b82f6;color:white;box-shadow:0 1px 2px rgba(0,0,0,.1)}.word-cloud-stats{display:flex;gap:1rem;font-size:.875rem;color:#6b7280}.stat-item{background:#ffffff;padding:6px 12px;border-radius:6px;border:1px solid #e5e7eb}.word-cloud-legend{display:flex;justify-content:center;align-items:center;gap:2rem;margin-bottom:1.5rem;padding:1rem;background:rgba(255,255,255,.8);border-radius:8px;border:1px solid #e5e7eb;flex-wrap:wrap}.legend-item{gap:8px;font-size:.875rem;font-weight:500}.legend-color{width:16px;height:16px;border-radius:50%;border:2px solid}.legend-color.positive{background:#10b981;border-color:#059669;box-shadow:0 0 0 2px rgba(16,185,129,.2)}.legend-color.negative{background:#ef4444;border-color:#dc2626;box-shadow:0 0 0 2px rgba(239,68,68,.2)}.legend-color.neutral{background:#6b7280;border-color:#4b5563;box-shadow:0 0 0 2px rgba(107,114,128,.2)}.legend-text{color:#374151}.sentiment-overview{margin-bottom:1.5rem}.sentiment-bar{display:flex;height:12px;background:#f3f4f6;border-radius:6px;margin-bottom:8px;box-shadow:inset 0 1px 2px rgba(0,0,0,.1)}.sentiment-segment{transition:width .6s ease;cursor:pointer}.sentiment-segment.positive{background:linear-gradient(90deg,#10b981,#34d399)}.sentiment-segment.negative{background:linear-gradient(90deg,#ef4444,#f87171)}.sentiment-segment.neutral{background:linear-gradient(90deg,#6b7280,#9ca3af)}.sentiment-summary{text-align:center;font-size:.875rem;color:#4b5563;font-weight:500}.sentiment-score{font-weight:700;margin-left:8px;padding:2px 8px;border-radius:4px}.sentiment-score.positive{color:#059669;background:rgba(16,185,129,.1)}.sentiment-score.negative{color:#dc2626;background:rgba(239,68,68,.1)}.sentiment-score.neutral{color:#4b5563;background:rgba(107,114,128,.1)}.word-cloud{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px;padding:2rem;background:rgba(255,255,255,.5);border-radius:8px;border:1px solid #e5e7eb;min-height:300px;position:relative;overflow:hidden;font-family:Noto Sans Sinhala,Arial Unicode MS,sans-serif;line-height:1.4}.word-cloud:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at center,rgba(59,130,246,.05) 0,transparent 70%);pointer-events:none}.word-item{display:inline-block;cursor:pointer;transition:all .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;position:relative;z-index:1;font-family:Noto Sans Sinhala,Arial Unicode MS,sans-serif;font-weight:500;white-space:nowrap;text-rendering:optimizeLegibility}.word-item:hover{transform:scale(1.1);z-index:10;filter:brightness(1.1);box-shadow:0 4px 8px rgba(0,0,0,.15)!important}.word-item.positive{color:#059669!important;background:linear-gradient(135deg,rgba(16,185,129,.15),rgba(52,211,153,.1))!important;border:2px solid #10b981!important;text-shadow:0 1px 2px rgba(16,185,129,.3);font-weight:700!important}.word-item.negative{color:#dc2626!important;background:linear-gradient(135deg,rgba(239,68,68,.15),rgba(248,113,113,.1))!important;border:2px solid #ef4444!important;text-shadow:0 1px 2px rgba(239,68,68,.3);font-weight:700!important}.word-item.neutral{color:#4b5563!important;background:rgba(107,114,128,.08)!important;border:1px solid #9ca3af!important}.word-frequency{font-size:.75em;opacity:.7;font-weight:400;margin-left:2px;color:inherit}.word-item:hover .word-frequency{opacity:1;font-weight:500}.word-list-view{display:flex;flex-direction:column;gap:1.5rem}.word-category-section{background:rgba(255,255,255,.8);border-radius:8px;padding:1rem;border:1px solid #e5e7eb}.category-title{margin:0 0 1rem;font-size:1.125rem;font-weight:600;padding-bottom:.5rem;border-bottom:2px solid}.category-title.positive{color:#059669;border-bottom-color:#10b981}.category-title.negative{color:#dc2626;border-bottom-color:#ef4444}.category-title.neutral{color:#4b5563;border-bottom-color:#6b7280}.word-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:8px;gap:8px}.word-list-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;border-radius:6px;font-size:.875rem;border:1px solid;transition:all .2s ease;cursor:pointer}.word-list-item:hover{transform:translateY(-1px);box-shadow:0 2px 4px rgba(0,0,0,.1)}.word-list-item.positive{background:rgba(16,185,129,.05);border-color:#10b981;color:#059669}.word-list-item.positive:hover{background:rgba(16,185,129,.1)}.word-list-item.negative{background:rgba(239,68,68,.05);border-color:#ef4444;color:#dc2626}.word-list-item.negative:hover{background:rgba(239,68,68,.1)}.word-list-item.neutral{background:rgba(107,114,128,.03);border-color:#9ca3af;color:#4b5563}.word-list-item.neutral:hover{background:rgba(107,114,128,.08)}.word-text{font-weight:600}.word-count{background:rgba(0,0,0,.1);padding:2px 6px;border-radius:4px;font-size:.75rem;font-weight:500;min-width:24px;text-align:center}.top-words-summary{margin-top:1.5rem;padding:1rem;background:rgba(255,255,255,.8);border-radius:8px;border:1px solid #e5e7eb}.top-words-summary h5{margin:0 0 .75rem;color:#374151;font-size:1rem;font-weight:600}.top-words-list{display:flex;flex-wrap:wrap;gap:8px}.top-word-item{padding:6px 12px;border-radius:6px;font-size:.875rem;border:1px solid;background:rgba(255,255,255,.8)}.top-word-item.positive{border-color:#10b981;background:rgba(16,185,129,.05)}.top-word-item.negative{border-color:#ef4444;background:rgba(239,68,68,.05)}.top-word-item.neutral{border-color:#9ca3af;background:rgba(107,114,128,.03)}.word-cloud-empty{text-align:center;padding:3rem 2rem;color:#6b7280}.empty-icon{font-size:3rem;margin-bottom:1rem}.word-cloud-empty h4{margin:0 0 .5rem;color:#374151;font-size:1.25rem}.word-cloud-empty p{font-size:.875rem;line-height:1.5;max-width:400px;margin:0 auto}@keyframes fadeInWord{0%{opacity:0;transform:scale(.8) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@media (max-width:768px){.word-cloud-container{padding:1rem;margin:.5rem 0}.word-cloud-header{flex-direction:column;align-items:stretch;gap:.75rem}.word-cloud-controls{justify-content:space-between}.word-cloud-legend{flex-direction:column;gap:1rem;text-align:center}.word-cloud{padding:1rem;min-height:200px}.word-list{grid-template-columns:1fr}.sentiment-overview{margin-bottom:1rem}.top-words-list{justify-content:center}}.history-section{padding:.5rem 1.5rem 1rem;border-top:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.03)}.history-controls{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.history-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1rem;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:.75rem;color:white;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;position:relative}.history-btn:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.3);transform:translateY(-1px)}.history-count{background:#add929;color:white;font-size:.75rem;font-weight:600;padding:.2rem .5rem;border-radius:1rem;margin-left:auto;min-width:1.5rem;text-align:center}.save-history-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1rem;background:linear-gradient(135deg,#add929,#7eb82a);border:none;border-radius:.75rem;color:white;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.save-history-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(173,217,41,.3)}.save-history-btn:disabled{background:rgba(255,255,255,.1);color:rgba(255,255,255,.5);cursor:not-allowed;transform:none;box-shadow:none}.quick-history h4{font-size:.9rem;font-weight:600;color:white;margin-bottom:.75rem}.recent-sessions-list{display:flex;flex-direction:column;gap:.5rem}.recent-session-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:.5rem;color:white;font-size:.8rem;cursor:pointer;transition:all .2s ease;text-align:left;width:100%;justify-content:space-between}.recent-session-item:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2);transform:translateX(2px)}.recent-session-icon{flex-shrink:0;width:24px;height:24px;background:rgba(255,255,255,.1);border-radius:50%;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.8)}.recent-session-info{flex:1 1;min-width:0}.recent-session-title{display:block;font-weight:500;color:white;margin-bottom:.2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recent-session-time{display:block;font-size:.7rem;color:rgba(255,255,255,.6)}.recent-session-load{display:flex;align-items:center;gap:.75rem;background:transparent;border:none;padding:.25rem 0;text-align:left;cursor:pointer}.recent-session-menu{position:relative;margin-left:8px;flex-shrink:0}.recent-session-menu-btn{background:transparent;border:none;color:rgba(255,255,255,.9);padding:6px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.recent-session-menu-btn svg{display:block;width:14px;height:14px}.recent-session-load{flex:1 1 auto;min-width:0}.recent-session-menu-btn:hover{background:rgba(255,255,255,.04)}.recent-menu-dropdown{position:absolute;right:0;top:calc(100% + 8px);background:rgba(8,8,8,.96);border:1px solid rgba(255,255,255,.06);box-shadow:0 8px 24px rgba(0,0,0,.45);border-radius:8px;z-index:1200;min-width:140px;overflow:hidden}.recent-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;background:transparent;border:none;color:rgba(255,255,255,.95);text-align:left;cursor:pointer;font-size:.9rem}.recent-menu-item:hover{background:rgba(255,255,255,.02)}.recent-menu-item.danger{color:#ffb3b3}.recent-session-edit-input{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);color:white;border-radius:6px;padding:6px 8px;font-size:.9rem}.small-ghost-btn{background:transparent;border:1px solid rgba(255,255,255,.06);color:rgba(255,255,255,.95);padding:6px 8px;border-radius:6px;cursor:pointer;font-size:.85rem}.small-ghost-btn:hover{background:rgba(255,255,255,.03)}.history-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.75);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10000;display:flex;align-items:center;justify-content:center;padding:2rem;animation:fadeIn .3s ease-out}.history-modal{background:white;border-radius:1rem;width:100%;max-width:900px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 25px 50px rgba(0,0,0,.3);animation:slideUp .4s cubic-bezier(.16,1,.3,1)}.history-modal-header{padding:1.5rem 2rem;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between;background:#f8fafc;border-radius:1rem 1rem 0 0}.history-title-section{display:flex;align-items:center;gap:1rem}.history-title-section h2{margin:0;color:#1f2937;font-size:1.5rem;font-weight:700}.history-subtitle{margin:0;color:#6b7280;font-size:.875rem;font-weight:500}.history-header-actions{display:flex;align-items:center;gap:.75rem}.history-export-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:white;transition:all .2s ease}.history-export-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(59,130,246,.3)}.history-close-btn{background:#ef4444;border:none;border-radius:.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:white;transition:all .2s ease}.history-close-btn:hover{background:#dc2626;transform:translateY(-1px)}.history-modal-content{flex:1 1;overflow:hidden;display:flex;flex-direction:column}.history-tabs{display:flex;border-bottom:1px solid #e5e7eb;background:#f8fafc}.history-tab{flex:1 1;padding:1rem 1.5rem;background:none;display:flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;font-size:.9rem;font-weight:500;color:#6b7280;transition:all .2s ease;border:none;border-bottom:3px solid transparent}.history-tab:hover{background:#f1f5f9;color:#374151}.history-tab.active{color:#3b82f6;border-bottom-color:#3b82f6;background:white}.history-search-bar{display:flex;align-items:center;gap:.75rem;padding:1.5rem;border-bottom:1px solid #e5e7eb;background:white}.history-search-input{flex:1 1;padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.9rem;background:white;color:#374151;transition:all .2s ease}.history-search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1)}.history-search-input::placeholder{color:#9ca3af}.history-clear-btn{background:#ef4444;border:none;border-radius:.5rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:white;transition:all .2s ease}.history-clear-btn:hover{background:#dc2626;transform:scale(1.05)}.history-items-container{flex:1 1;overflow-y:auto;padding:1rem;background:#f8fafc}.history-loading{gap:1rem}.history-empty,.history-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:#6b7280}.history-empty{text-align:center}.history-empty h3{margin:1rem 0 .5rem;color:#374151;font-size:1.25rem;font-weight:600}.history-empty p{margin:0;color:#6b7280;font-size:.9rem}.history-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:white;border:1px solid #e5e7eb;border-radius:.75rem;margin-bottom:.75rem;transition:all .2s ease;cursor:default}.history-item:hover{border-color:#d1d5db;box-shadow:0 2px 4px rgba(0,0,0,.05)}.history-item-icon{flex-shrink:0;width:40px;height:40px;background:#f3f4f6;border-radius:.5rem;display:flex;align-items:center;justify-content:center;color:#6b7280}.history-item-content{flex:1 1;min-width:0}.history-item-main{margin-bottom:.5rem}.history-item-title{margin:0 0 .25rem;color:#1f2937;font-size:1rem;font-weight:600}.history-item-description,.history-item-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-item-description{margin:0;color:#6b7280;font-size:.875rem;line-height:1.4}.history-item-meta{display:flex;align-items:center;gap:1rem;font-size:.8rem;color:#9ca3af}.history-item-date{font-weight:500}.history-item-time{color:#6b7280}.history-item-charts{background:#e0e7ff;color:#3730a3;padding:.2rem .5rem;border-radius:.25rem;font-weight:500}.history-item-actions{display:flex;gap:.5rem;flex-shrink:0}.history-load-btn{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:.5rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:white;transition:all .2s ease}.history-load-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(16,185,129,.3)}.history-delete-btn{background:#ef4444;border:none;border-radius:.5rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:white;transition:all .2s ease}.history-delete-btn:hover{background:#dc2626;transform:translateY(-1px)}.history-stats-container{padding:1.5rem;overflow-y:auto;flex:1 1}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));grid-gap:1rem;gap:1rem;margin-bottom:2rem}.stat-card{background:white;padding:1.5rem;border-radius:.75rem;border:1px solid #e5e7eb;text-align:center;transition:all .2s ease}.stat-card:hover{border-color:#3b82f6;box-shadow:0 4px 6px rgba(0,0,0,.05)}.stat-value{font-size:2rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.stat-label{font-size:.875rem;color:#6b7280;font-weight:500}.stats-sections{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:1.5rem;gap:1.5rem}.stats-section{background:white;padding:1.5rem;border-radius:.75rem;border:1px solid #e5e7eb}.stats-section h4{margin:0 0 1rem;color:#1f2937;font-size:1.125rem;font-weight:600}.stats-breakdown{display:flex;flex-direction:column;gap:.75rem}.stats-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f8fafc;border-radius:.5rem;border:1px solid #e5e7eb}.stats-item span:first-child{color:#374151;font-weight:500}.stats-item span:last-child{color:#1f2937;font-weight:600;background:#e0e7ff;padding:.25rem .5rem;border-radius:.25rem;font-size:.875rem}.recent-activity-list{display:flex;flex-direction:column;gap:.75rem}.recent-activity-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#f8fafc;border-radius:.5rem;border:1px solid #e5e7eb}.activity-icon{width:32px;height:32px;background:#e0e7ff;border-radius:.5rem;display:flex;align-items:center;justify-content:center;color:#3730a3;flex-shrink:0}.activity-content{flex:1 1;display:flex;flex-direction:column;gap:.25rem}.activity-title{font-size:.875rem;font-weight:500;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-time{font-size:.75rem;color:#6b7280}.confirm-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.75);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10001;display:flex;align-items:center;justify-content:center;padding:2rem;animation:fadeIn .3s ease-out}.confirm-modal{background:white;border-radius:1rem;width:100%;max-width:400px;display:flex;flex-direction:column;box-shadow:0 25px 50px rgba(0,0,0,.3);animation:slideUp .4s cubic-bezier(.16,1,.3,1)}.confirm-modal-header{padding:1.5rem;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;gap:1rem;background:#fef2f2;border-radius:1rem 1rem 0 0}.confirm-modal-header h3{margin:0;color:#dc2626;font-size:1.125rem;font-weight:600}.confirm-modal-content{padding:1.5rem}.confirm-modal-content p{margin:0;color:#374151;font-size:.95rem;line-height:1.5}.confirm-modal-actions{padding:1rem 1.5rem 1.5rem;background:#f8fafc;border-top:1px solid #e5e7eb;display:flex;gap:.75rem;justify-content:flex-end;border-radius:0 0 1rem 1rem}.confirm-cancel-btn{padding:.75rem 1.5rem;background:white;color:#6b7280;border:1px solid #d1d5db;border-radius:.5rem;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.confirm-cancel-btn:hover{background:#f9fafb;color:#374151;border-color:#9ca3af}.confirm-action-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#dc2626,#b91c1c);color:white;border:none;border-radius:.5rem;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.confirm-action-btn:hover{background:linear-gradient(135deg,#b91c1c,#991b1b);transform:translateY(-1px);box-shadow:0 4px 12px rgba(220,38,38,.3)}.confirm-action-btn.primary{background:linear-gradient(135deg,#22c55e,#16a34a)}.confirm-action-btn.primary:hover{background:linear-gradient(135deg,#16a34a,#13803d);box-shadow:0 6px 18px rgba(16,185,129,.12);transform:translateY(-1px)}.confirm-action-btn.ghost{background:#add929;color:white;border:1px solid}.confirm-action-btn.ghost:hover{background:#add929;color:white;border-color:#94a3b8;transform:translateY(-1px)}@media (max-width:768px){.history-modal{max-width:95vw;max-height:90vh;margin:1rem}.history-modal-header{padding:1rem 1.5rem;flex-direction:column;align-items:stretch;gap:1rem}.history-title-section{justify-content:space-between}.history-header-actions{justify-content:center}.history-tabs{flex-direction:column}.history-search-bar{gap:1rem}.history-item,.history-search-bar{flex-direction:column;align-items:stretch}.history-item{gap:.75rem}.history-item-content{order:1}.history-item-icon{order:2;align-self:flex-start}.history-item-actions{order:3;justify-content:flex-end}.stats-grid{grid-template-columns:repeat(2,1fr)}.stats-sections{grid-template-columns:1fr}.history-section{padding:1rem}.history-controls{gap:.5rem}.recent-sessions-list{max-height:200px;overflow-y:auto}.confirm-modal-actions{flex-direction:column}.confirm-action-btn,.confirm-cancel-btn{width:100%}}@media (max-width:480px){.history-modal-header{padding:1rem}.history-title-section h2{font-size:1.25rem}.history-item-title{font-size:.9rem}.history-item-description{font-size:.8rem}.stats-grid{grid-template-columns:1fr}.stat-value{font-size:1.5rem}.history-section{padding:.75rem}.history-btn,.save-history-btn{font-size:.85rem;padding:.75rem}}.connection-popup-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.6);display:flex;justify-content:center;align-items:center;z-index:10000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.connection-popup{background:white;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.3);width:90%;max-width:480px;max-height:80vh;overflow:hidden;animation:connectionSlideIn .3s ease-out}@keyframes connectionSlideIn{0%{opacity:0;transform:translateY(-30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.connection-popup-header{display:flex;align-items:center;gap:12px;padding:20px 24px 16px;border-bottom:1px solid #e5e7eb;position:relative}.connection-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;transition:all .3s ease}.connection-icon.online{background:rgba(16,185,129,.1)}.connection-icon.offline{background:rgba(245,158,11,.1)}.connection-popup-header h3{font-size:1.25rem;font-weight:600;color:#1f2937;flex:1 1}.connection-close-btn{background:none;border:none;color:#6b7280;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease;position:absolute;right:16px;top:16px}.connection-close-btn:hover{background:#f3f4f6;color:#374151}.connection-popup-content{padding:16px 24px 20px}.connection-popup-content p{color:#4b5563;line-height:1.6;margin-bottom:16px}.connection-tips{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px}.connection-tips h4{font-size:.9rem;font-weight:600;color:#374151;margin-bottom:8px}.connection-tips ul{list-style:none;padding:0}.connection-tips li{color:#6b7280;font-size:.85rem;position:relative;padding:4px 0 4px 16px}.connection-tips li:before{content:"•";color:#f59e0b;position:absolute;left:0;font-weight:700}.connection-popup-actions{padding:16px 24px 20px;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end}.connection-ok-btn{background:linear-gradient(135deg,#10b981,#059669);color:white;border:none;padding:10px 20px;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease;font-size:.9rem}.connection-ok-btn:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px);box-shadow:0 4px 12px rgba(16,185,129,.3)}@media (max-width:768px){.connection-popup{width:95%;margin:1rem}.connection-popup-header{padding:16px 20px 12px}.connection-popup-header h3{font-size:1.1rem}.connection-popup-actions,.connection-popup-content{padding:12px 20px 16px}}.inactivity-popup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.inactivity-popup{background:white;border-radius:12px;box-shadow:0 20px 40px rgba(0,0,0,.15);max-width:480px;width:90%;max-height:90vh;overflow:auto;animation:inactivitySlideIn .3s ease-out}@keyframes inactivitySlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.inactivity-popup-header{display:flex;align-items:center;gap:12px;padding:20px 24px 16px;border-bottom:1px solid #f3f4f6}.inactivity-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:50%;flex-shrink:0}.inactivity-popup-header h3{margin:0;color:#1f2937;font-size:1.25rem;font-weight:600}.inactivity-popup-content{padding:16px 24px 20px}.inactivity-popup-content p{margin:0 0 16px;color:#4b5563;line-height:1.6}.inactivity-tips{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px;margin-top:16px}.inactivity-tips h4{margin:0 0 12px;color:#374151;font-size:.95rem;font-weight:600}.inactivity-tips ul{margin:0;padding-left:20px;list-style-type:disc}.inactivity-tips li{color:#6b7280;font-size:.9rem;line-height:1.5;margin-bottom:6px}.inactivity-tips li:last-child{margin-bottom:0}.inactivity-popup-actions{display:flex;gap:12px;padding:16px 24px 20px;border-top:1px solid #f3f4f6}.inactivity-save-btn{display:flex;align-items:center;gap:8px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:white;border:none;padding:10px 16px;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease;font-size:.9rem;flex:1 1}.inactivity-save-btn:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-1px);box-shadow:0 4px 12px rgba(59,130,246,.3)}.inactivity-continue-btn{background:#f3f4f6;color:#374151;border:1px solid #d1d5db;padding:10px 16px;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease;font-size:.9rem;flex:1 1}.inactivity-continue-btn:hover{background:#e5e7eb;border-color:#9ca3af;transform:translateY(-1px)}@media (max-width:768px){.inactivity-popup{width:95%;margin:1rem}.inactivity-popup-header{padding:16px 20px 12px}.inactivity-popup-header h3{font-size:1.1rem}.inactivity-popup-content{padding:12px 20px 16px}.inactivity-popup-actions{padding:12px 20px 16px;flex-direction:column}.inactivity-continue-btn,.inactivity-save-btn{width:100%}}.email-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem}.email-modal-overlay.mandatory-modal{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.email-modal{background:white;border-radius:16px;box-shadow:0 25px 50px rgba(0,0,0,.3);max-width:500px;width:100%;overflow:hidden;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.email-modal-header{background:linear-gradient(135deg,#add929,#7eb82a);color:white;padding:2rem;text-align:center}.email-icon-wrapper{display:flex;justify-content:center;margin-bottom:1rem}.email-modal-header h2{font-size:1.5rem;font-weight:600;margin:0 0 .5rem}.email-subtitle{font-size:.95rem;opacity:.9;margin:0}.email-modal-content{padding:2rem}.mandatory-notice{background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;padding:12px 16px;display:flex;align-items:center;gap:10px;margin-bottom:1.5rem}.mandatory-notice p{margin:0;color:#ffffff;font-size:.9rem}.login-info{display:flex;align-items:center;gap:.75rem;border:1px solid #546819;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.login-info p{margin:0;color:#4b5563;font-size:.9rem}.email-benefits{list-style:none;margin:1rem 0 1.5rem;padding:0}.email-benefits li{padding:.5rem 0;font-size:.9rem;color:#4b5563}.email-form{margin-top:1.5rem}.email-input-group{margin-bottom:1.5rem}.email-input-group label{display:block;font-weight:500;color:#374151;margin-bottom:.5rem;font-size:.9rem}.email-input{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:all .2s ease;background:#fafafa}.email-input:focus{outline:none;border-color:linear-gradient(135deg,#add929,#7eb82a 10%);background:white;box-shadow:0 0 0 3px rgba(16,185,129,.1)}.email-input.error{border-color:#dc2626;background:#fef2f2}.email-input.error:focus{border-color:#dc2626;box-shadow:0 0 0 3px rgba(220,38,38,.1)}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper .email-input{padding-right:48px}.password-toggle-btn{position:absolute;right:12px;background:none;border:none;cursor:pointer;padding:4px;color:#6b7280;transition:color .2s ease;display:flex;align-items:center;justify-content:center;z-index:10}.password-toggle-btn:hover{color:#374151}.password-toggle-btn:disabled{cursor:not-allowed;opacity:.5}.password-toggle-btn:focus{outline:none;color:#add929}.email-error{display:block;color:#dc2626;font-size:.8rem;margin-top:.5rem;font-weight:500}.email-submit-btn{width:100%;background:linear-gradient(135deg,#add929,#7eb82a);color:white;border:none;padding:14px 20px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.email-submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#add929,#7eb82a 10%);transform:translateY(-1px);box-shadow:0 8px 25px rgba(16,185,129,.3)}.email-submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.email-loading-icon{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.email-privacy{margin-top:1.5rem;text-align:center;color:#6b7280;font-size:.8rem;line-height:1.4}.email-privacy small{display:block;margin-top:.5rem;color:#9ca3af}.login-mode-selector{display:flex;gap:.5rem;margin-bottom:2rem;background:#f8fafc;padding:4px;border-radius:10px;border:1px solid #e2e8f0}.mode-btn{flex:1 1;padding:10px 16px;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;background:transparent;color:#64748b}.mode-btn.active{background:linear-gradient(135deg,#add929,#7eb82a);color:white;box-shadow:0 2px 8px rgba(173,217,41,.3)}.mode-btn:hover:not(.active){background:#e2e8f0;color:#475569}.crowdsnap-login-form,.otp-verification-form,.simple-login-form{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.back-btn{width:100%;background:#6b7280;color:white;border:none;padding:12px 20px;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease;margin-top:1rem;display:flex;align-items:center;justify-content:center;gap:8px}.back-btn:hover:not(:disabled){background:#4b5563;transform:translateY(-1px)}.back-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}#otp-code{text-align:center;font-size:1.2rem;letter-spacing:.2em;font-weight:600}.crowdsnap-login-form .login-info,.otp-verification-form .login-info{border-color:#fbbf24;background:#fffbeb}.otp-verification-form .login-info{border-color:#10b981;background:#ecfdf5}.app-blocked-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.3);z-index:5000;display:flex;align-items:center;justify-content:center;padding:2rem}.blocked-message{background:rgba(255,255,255,.95);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;border-radius:12px;text-align:center;box-shadow:0 10px 25px rgba(0,0,0,.1);max-width:400px}.blocked-message h3{color:#374151;margin:0 0 .5rem;font-size:1.2rem}.blocked-message p{color:#6b7280;margin:0;font-size:.9rem}.main-content.blocked{filter:blur(3px);pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}@media (max-width:768px){.email-modal{margin:1rem;max-width:none}.email-modal-header{padding:1.5rem}.email-modal-header h2{font-size:1.3rem}.email-modal-content{padding:1.5rem}.blocked-message{margin:1rem;padding:1.5rem}.blocked-message h3{font-size:1.1rem}}.input-wrapper{position:relative;padding-top:20px}.left-file-area{position:absolute;left:8px;top:6px;transform:none;display:flex;align-items:center;gap:6px;z-index:5}.file-chip{display:inline-flex;align-items:center;gap:2px;padding:6px;background:rgba(0,0,0,.22);border-radius:5px;color:#fff;max-width:280px;white-space:nowrap;cursor:pointer}.file-chip,.file-chip .file-name{overflow:hidden;text-overflow:ellipsis;font-size:12px}.file-chip .file-name{line-height:1}.file-close-btn{background:transparent;border:none;color:#fff;display:inline-flex;align-items:center;justify-content:center;padding:2px;margin-left:6px;cursor:pointer}.file-close-btn:hover{opacity:.95}.file-preview-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;z-index:9999}.file-preview-modal{width:min(900px,95%);max-height:80vh;background:#0b1115;border-radius:12px;overflow:hidden;display:flex;flex-direction:column;border:1px solid rgba(255,255,255,.06)}.file-preview-header{justify-content:space-between;padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.03)}.file-preview-header,.file-preview-title{display:flex;align-items:center}.file-preview-body{padding:12px;overflow:auto}.file-preview-table{width:100%;border-collapse:collapse}.file-preview-table td,.file-preview-table th{padding:8px 10px;border-bottom:1px solid rgba(255,255,255,.03);text-align:left;font-size:13px}.file-preview-table thead th{background:rgba(255,255,255,.02);position:-webkit-sticky;position:sticky;top:0}.file-preview-footer{display:flex;gap:12px;padding:12px 16px;border-top:1px solid rgba(255,255,255,.03);justify-content:flex-end}.file-preview-remove{display:inline-flex;align-items:center;gap:8px;background:transparent;border:1px solid rgba(255,255,255,.06);color:#fff}.file-preview-close-btn,.file-preview-remove{padding:8px 12px;border-radius:8px;cursor:pointer}.file-preview-close-btn{background:linear-gradient(135deg,#add929,#7eb82a);color:#04240a;border:none}.file-attachment-info{display:inline-flex;align-items:center;gap:8px;cursor:pointer}.file-attachment-info .file-name{font-weight:600}.sentiment-creative-container{background:linear-gradient(135deg,#121509a1,#080a03);border-radius:20px;padding:32px;margin:24px 0;box-shadow:0 20px 60px rgba(0,0,0,.3);position:relative;overflow:hidden}.sentiment-creative-container:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(102,126,234,.1) 0,transparent 70%)}.sentiment-header{text-align:center;margin-bottom:32px;position:relative;z-index:1}.sentiment-icon-pulse{font-size:64px;animation:pulse 2s ease-in-out infinite;display:inline-block;filter:drop-shadow(0 0 20px rgba(102,126,234,.5))}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.sentiment-title{font-size:32px;font-weight:700;background:white;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:12px 0 8px}.sentiment-subtitle{color:rgba(255,255,255,.6);font-size:14px;margin:0}.sentiment-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));grid-gap:16px;gap:16px;margin-bottom:24px;position:relative;z-index:1}.sentiment-card{background:rgba(255,255,255,.03);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:20px 16px;min-height:140px;text-align:center;position:relative;overflow:hidden;transition:all .3s ease;cursor:pointer;display:flex;flex-direction:column;justify-content:center}.sentiment-card:hover{transform:translateY(-8px);box-shadow:0 12px 40px rgba(102,126,234,.3);border-color:rgba(255,255,255,.2)}.card-icon{font-size:36px;margin-bottom:8px;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.card-value{font-size:32px;font-weight:700;color:#fff;margin-bottom:6px;text-shadow:0 0 20px rgba(255,255,255,.3);line-height:1}.card-value-count{font-size:18px;font-weight:600;color:rgba(255,255,255,.85);margin-top:4px;margin-bottom:8px;text-shadow:0 0 10px rgba(255,255,255,.2);line-height:1}.card-label{font-size:11px;color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:.8px;font-weight:500}.card-glow{position:absolute;bottom:0;left:0;right:0;height:4px;background:linear-gradient(90deg,transparent,rgba(102,126,234,.5),transparent);animation:slideGlow 2s linear infinite}@keyframes slideGlow{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.positive-card{border-color:rgba(43,182,76,.3)}.positive-card:hover{box-shadow:0 12px 40px rgba(43,182,76,.4)}.positive-glow{background:linear-gradient(90deg,transparent,rgba(43,182,76,.5),transparent)}.neutral-card{border-color:rgba(255,193,7,.3)}.neutral-card:hover{box-shadow:0 12px 40px rgba(255,193,7,.4)}.neutral-glow{background:linear-gradient(90deg,transparent,rgba(255,193,7,.5),transparent)}.negative-card{border-color:rgba(244,67,54,.3)}.negative-card:hover{box-shadow:0 12px 40px rgba(244,67,54,.4)}.negative-glow{background:linear-gradient(90deg,transparent,rgba(244,67,54,.5),transparent)}.total-card{border-color:rgba(102,126,234,.3)}.total-card:hover{box-shadow:0 12px 40px rgba(102,126,234,.4)}.sentiment-bar{margin-top:12px;height:6px;background:rgba(255,255,255,.1);border-radius:10px;overflow:hidden}.sentiment-fill{height:100%;border-radius:10px;transition:width 1s ease;animation:fillBar 1.5s ease-out}@keyframes fillBar{0%{width:0}}.positive-fill{background:linear-gradient(90deg,#2bb64c,#5cd672)}.neutral-fill{background:linear-gradient(90deg,#ffc107,#ffd454)}.negative-fill{background:linear-gradient(90deg,#f44336,#ff6b6b)}.sentiment-banner{background:linear-gradient(135deg,rgba(102,126,234,.2),rgba(118,75,162,.2));border:2px solid rgba(255,255,255,.1);border-radius:16px;padding:24px;margin-bottom:32px;position:relative;overflow:hidden;z-index:1}.sentiment-banner:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.05) 0,transparent 70%);animation:rotateBanner 15s linear infinite}@keyframes rotateBanner{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.sentiment-positive{border-color:rgba(43,182,76,.5);background:linear-gradient(135deg,rgba(43,182,76,.2),rgba(92,214,114,.2))}.sentiment-neutral{border-color:rgba(255,193,7,.5);background:linear-gradient(135deg,rgba(255,193,7,.2),rgba(255,212,84,.2))}.sentiment-negative{border-color:rgba(244,67,54,.5);background:linear-gradient(135deg,rgba(244,67,54,.2),rgba(255,107,107,.2))}.banner-content{display:flex;align-items:center;gap:20px;position:relative;z-index:2}.banner-icon{font-size:64px;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}.banner-text{flex:1 1;display:flex;flex-direction:column;gap:4px}.banner-label{font-size:14px;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:1px}.banner-value{font-size:32px;font-weight:700;color:#fff;text-shadow:0 2px 20px rgba(255,255,255,.3)}.banner-score{font-size:18px;color:rgba(255,255,255,.8);background:rgba(255,255,255,.1);padding:8px 16px;border-radius:20px}.banner-particles{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1}.particle{position:absolute;font-size:24px;animation:float-particle 4s ease-in-out infinite;opacity:.3}.particle:first-child{top:20%;left:10%;animation-delay:0s}.particle:nth-child(2){top:60%;right:15%;animation-delay:1s}.particle:nth-child(3){bottom:30%;left:70%;animation-delay:2s}@keyframes float-particle{0%,to{transform:translate(0) rotate(0deg)}25%{transform:translate(10px,-10px) rotate(90deg)}50%{transform:translate(-5px,-20px) rotate(180deg)}75%{transform:translate(-10px,-10px) rotate(270deg)}}.sentiment-visualization{background:rgba(255,255,255,.02);border-radius:8px;padding:12px;margin-bottom:12px;position:relative;z-index:1}.viz-title{text-align:center;color:#fff;font-size:13px;margin-bottom:10px}.sentiment-donut{width:100px;height:100px;margin:0 auto 10px;position:relative}.donut-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;z-index:3}.donut-emoji{font-size:24px;animation:rotate360 4s linear infinite}@keyframes rotate360{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.donut-text{font-size:9px;color:rgba(255,255,255,.7);margin-top:2px}.sentiment-legend{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:4px;font-size:10px;color:rgba(255,255,255,.8)}.legend-color{width:10px;height:10px;border-radius:2px}.positive-color{background:linear-gradient(135deg,#2bb64c,#5cd672)}.neutral-color{background:linear-gradient(135deg,#ffc107,#ffd454)}.negative-color{background:linear-gradient(135deg,#f44336,#ff6b6b)}.ai-insights-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(102,126,234,.2);border:1px solid rgba(102,126,234,.3);padding:12px 20px;border-radius:30px;margin-top:16px;font-size:13px;color:rgba(255,255,255,.8);position:relative;z-index:1}.badge-icon{font-size:20px;animation:wiggle 2s ease-in-out infinite}@keyframes wiggle{0%,to{transform:rotate(0deg)}25%{transform:rotate(-5deg)}75%{transform:rotate(5deg)}}.badge-text{font-style:italic}@media (max-width:768px){.sentiment-creative-container{padding:20px}.sentiment-stats-grid{grid-template-columns:1fr}.sentiment-title{font-size:24px}.banner-content{flex-direction:column;text-align:center}.banner-icon{font-size:48px}.banner-value{font-size:24px}}.analytical-insights-container{background:linear-gradient(135deg,#1a1f2e,#252b3d);border-radius:20px;padding:32px;margin-top:24px;box-shadow:0 10px 40px rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.1);position:relative;overflow:hidden}.analytical-insights-container:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(102,126,234,.1) 0,transparent 70%);animation:insightsGlow 10s ease-in-out infinite;pointer-events:none}@keyframes insightsGlow{0%,to{transform:translate(0) rotate(0deg)}50%{transform:translate(10%,10%) rotate(180deg)}}.insights-header{text-align:center;margin-bottom:32px;position:relative;z-index:1}.insights-icon{font-size:56px;margin-bottom:12px;display:inline-block;animation:magnifyPulse 3s ease-in-out infinite}@keyframes magnifyPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.insights-title{font-size:32px;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 8px;text-shadow:0 0 30px rgba(102,126,234,.3)}.insights-subtitle{color:rgba(255,255,255,.6);font-size:14px;font-style:italic;margin:0}.insights-content{display:flex;flex-direction:column;gap:24px;position:relative;z-index:1}.insight-section{background:rgba(255,255,255,.05);border-radius:16px;padding:24px;border-left:4px solid;transition:all .3s ease;position:relative;overflow:hidden}.insight-section:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,rgba(255,255,255,.05),transparent);opacity:0;transition:opacity .3s ease;pointer-events:none}.insight-section:hover{transform:translateY(-4px);box-shadow:0 8px 25px rgba(0,0,0,.3)}.insight-section:hover:before{opacity:1}.surface-section{border-left-color:#4fc3f7;background:linear-gradient(135deg,rgba(79,195,247,.1),rgba(255,255,255,.05))}.pattern-section{border-left-color:#ba68c8;background:linear-gradient(135deg,rgba(186,104,200,.1),rgba(255,255,255,.05))}.action-section{border-left-color:#ffd54f;background:linear-gradient(135deg,rgba(255,213,79,.1),rgba(255,255,255,.05))}.strategic-section{border-left-color:#81c784;background:linear-gradient(135deg,rgba(129,199,132,.1),rgba(255,255,255,.05))}.insight-section-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.insight-section-icon{font-size:28px;animation:iconBounce 2s ease-in-out infinite}@keyframes iconBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.insight-section-title{font-size:20px;font-weight:600;color:#fff;margin:0;letter-spacing:.5px}.insight-section-content{line-height:1.8}.insight-section-content p{color:rgba(255,255,255,.85);font-size:15px;margin:0;text-align:justify;font-weight:400}.insights-footer{margin-top:32px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;position:relative;z-index:1}.insights-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(102,126,234,.2);border:1px solid rgba(102,126,234,.3);padding:10px 16px;border-radius:20px;font-size:12px;color:rgba(255,255,255,.7);font-style:italic}.insights-stats{display:flex;gap:16px;align-items:center}.stat-item{color:rgba(255,255,255,.7);font-size:13px;font-weight:500}@media (max-width:768px){.analytical-insights-container{padding:20px;border-radius:12px}.insights-icon{font-size:40px}.insights-title{font-size:24px}.insights-subtitle{font-size:12px}.insight-section{padding:16px}.insight-section-title{font-size:16px}.insight-section-content p{font-size:14px}.insights-footer{flex-direction:column;align-items:flex-start}}.similarity-search-results{background:#ffffff;border-radius:12px;padding:24px;margin:16px 0;box-shadow:0 4px 12px rgba(0,0,0,.08)}.search-header{margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #f3f4f6;display:flex;flex-wrap:wrap;align-items:center;gap:12px}.search-header h4{font-size:20px;font-weight:600;color:#1f2937;margin-bottom:0;flex:1 1}.search-query{font-size:14px;color:#6b7280;margin:8px 0}.search-query strong{color:#111827;font-weight:600}.search-stats{font-size:13px;color:#9ca3af;margin-top:4px}.no-results{text-align:center;padding:48px 24px;color:#6b7280}.no-results p{font-size:14px;line-height:1.6}.results-table-container{overflow-x:auto;border-radius:8px;border:1px solid #e5e7eb}.similarity-results-table{width:100%;border-collapse:collapse;font-size:14px}.similarity-results-table thead{background:linear-gradient(135deg,#f9fafb,#f3f4f6)}.similarity-results-table th{padding:12px 16px;text-align:left;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb;white-space:nowrap}.similarity-results-table tbody tr{border-bottom:1px solid #f3f4f6;transition:background-color .2s ease}.similarity-results-table tbody tr:hover{background-color:#f9fafb}.similarity-results-table tbody tr:last-child{border-bottom:none}.similarity-results-table td{padding:16px;vertical-align:top}.rank-cell{font-weight:600;color:#6b7280;text-align:center}.similarity-cell{min-width:120px}.similarity-score{position:relative;height:32px;background:#f3f4f6;border-radius:6px;overflow:hidden;display:flex;align-items:center;justify-content:center}.similarity-bar{position:absolute;left:0;top:0;height:100%;transition:width .3s ease;opacity:.3}.similarity-value{position:relative;z-index:1;font-weight:600;font-size:13px;color:#111827}.content-cell{max-width:500px}.content-preview{color:#374151;line-height:1.6;word-break:break-word}.sentiment-cell{min-width:140px}.sentiment-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;margin-bottom:6px}.sentiment-emoji{font-size:16px}.sentiment-text{text-transform:uppercase;letter-spacing:.5px}.sentiment-score-text{font-size:11px;color:#6b7280;margin-top:4px}.date-cell{color:#6b7280;font-size:13px;white-space:nowrap}@media (max-width:1024px){.similarity-results-table td,.similarity-results-table th{padding:12px}.content-cell{max-width:300px}}@media (max-width:768px){.similarity-search-results{padding:16px;margin:12px 0}.search-header h4{font-size:18px}.results-table-container{overflow-x:scroll}.similarity-results-table{font-size:12px;min-width:600px}.similarity-results-table td,.similarity-results-table th{padding:8px}.content-cell{max-width:200px}.sentiment-badge{padding:4px 8px;font-size:11px}}.login-events-btn{background:linear-gradient(135deg,#ffffff66,#ffffff6b);color:#ffffff;border:1px solid rgba(255,255,255,.06);padding:8px 10px;border-radius:6px;font-size:.85rem;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background .12s ease}.login-events-btn:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(0,0,0,.45);background:linear-gradient(135deg,#5b6b7a,#46545e)}.login-events-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;z-index:3000;padding:20px}.login-events-modal{width:100%;max-width:980px;max-height:84vh;background:linear-gradient(180deg,rgba(18,18,20,.96),rgba(24,24,26,.98));border-radius:12px;border:1px solid rgba(255,255,255,.06);box-shadow:0 18px 80px rgba(2,6,23,.7);overflow:hidden;display:flex;flex-direction:column}.login-events-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid rgba(255,255,255,.04)}.login-events-header h3{color:#fff;font-size:1rem;font-weight:700}.login-events-header .close-login-events{background:transparent;border:none;color:rgba(255,255,255,.85);width:36px;height:36px;padding:6px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;cursor:pointer}.login-events-header .close-login-events:hover{background:rgba(255,255,255,.03)}.login-events-content{padding:12px 16px;overflow:auto}.login-events-table-wrap{width:100%;overflow:auto}.login-events-table{width:100%;border-collapse:collapse;min-width:720px}.login-events-table td,.login-events-table th{padding:8px 10px;text-align:left;color:rgba(255,255,255,.92);border-bottom:1px solid rgba(255,255,255,.03);font-size:.88rem}.login-events-table th{color:rgba(255,255,255,.8);font-weight:600;background:linear-gradient(180deg,rgba(255,255,255,.02),transparent);position:-webkit-sticky;position:sticky;top:0;z-index:2}.login-events-table tbody tr:hover{background:rgba(255,255,255,.02)}.login-events-table td[colspan]{text-align:center;color:rgba(255,255,255,.7)}.login-events-loading{padding:20px 12px;text-align:center}.login-events-loading-text{color:#ffffff;font-weight:600}.login-events-spinner{color:rgba(255,255,255,.95);margin-right:8px;vertical-align:middle}@media (max-width:920px){.login-events-modal{max-width:92vw}.login-events-table{min-width:640px}}@media (max-width:560px){.login-events-table{min-width:520px}.login-events-header h3{font-size:.95rem}}.login-events-content::-webkit-scrollbar,.login-events-table-wrap::-webkit-scrollbar{height:10px;width:10px}.login-events-content::-webkit-scrollbar-track,.login-events-table-wrap::-webkit-scrollbar-track{background:rgba(255,255,255,.02)}.login-events-content::-webkit-scrollbar-thumb,.login-events-table-wrap::-webkit-scrollbar-thumb{background:rgba(255,255,255,.06);border-radius:8px;border:2px solid rgba(0,0,0,0)}.login-events-content,.login-events-table-wrap{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.06) rgba(255,255,255,.02)}.login-events-filters{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.login-events-search{background:rgba(255,255,255,.03);min-width:260px}.login-events-filters input[type=date],.login-events-filters select,.login-events-search{color:rgba(255,255,255,.95);border:1px solid rgba(255,255,255,.04);padding:8px 10px;border-radius:8px}.login-events-filters input[type=date],.login-events-filters select{background:rgba(255,255,255,.02)}.clear-login-filters{background:transparent;color:rgba(255,255,255,.9);border:1px solid rgba(255,255,255,.04);padding:6px 10px;border-radius:8px;cursor:pointer}.clear-login-filters:hover{background:rgba(255,255,255,.03)}@media (max-width:720px){.login-events-search{min-width:160px;flex:1 1 100%}.login-events-filters input[type=date],.login-events-filters select{flex:1 1 45%}}