@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,#91b623,#689a23 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}.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: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}.section-title{font-size:1rem;font-weight:600;color:white;margin-bottom:.5rem}.steps-section{padding:1.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:.5rem;padding:.75rem;background:rgba(0,0,0,.2);border-radius:8px;border:1px solid rgba(255,255,255,.1)}.user-email{font-size:.8rem;color:rgba(255,255,255,.8);font-weight:500;word-break:break-all}.logout-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:linear-gradient(135deg,#add929,#7eb82a);color:white;border:none;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s ease;align-self:flex-start;z-index:100;position:relative}.logout-btn:hover{background:linear-gradient(135deg,#97bc27,#7eba2c);transform:translateY(-1px);box-shadow:0 4px 12px rgba(126,220,38,.3)}.logout-btn:active{transform:translateY(0)}.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}.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}.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);padding:1rem 1.5rem;gap:.75rem}.file-preview-close,.file-preview-header{color:white;display:flex;align-items:center}.file-preview-close{margin-left:auto;background:rgba(255,255,255,.2);border:none;border-radius:50%;width:28px;height:28px;justify-content:center;cursor:pointer;transition:all .2s ease}.file-preview-close:hover{background:rgba(255,255,255,.3);transform:scale(1.1)}.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)}.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;align-items:center;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:flex;gap:1.5rem;width:100%;min-height:400px}.chart-wrapper{flex:2 1;position:relative;min-height:400px;max-height:600px}.chart-table-container{flex:1 1;min-width:300px;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:center;justify-content:center;padding:2rem}.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)}.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-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:hidden;display:flex;gap:2rem}.chart-fullscreen-chart{flex:2 1;align-items:center;justify-content:center;min-height:400px;padding:1rem;position:relative}.chart-fullscreen-chart,.chart-fullscreen-table{display:flex;background:#f8f9fa;border-radius:.5rem}.chart-fullscreen-table{flex:1 1;flex-direction:column;padding:1.5rem;overflow:hidden}.chart-fullscreen-table>div{flex:1 1;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: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;position:relative;display:flex;align-items:flex-end}.chat-input{flex:1 1;min-height:50px;max-height:120px;padding:.75rem 80px .75rem 1rem;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 10px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .15s ease}.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{background:transparent;border:1px solid rgba(255,255,255,.12);color:white;padding:6px 10px;border-radius:6px;font-weight:600;cursor:pointer}.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:50%;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-color-btn,.chart-fullscreen-controls{display:flex;align-items:center}.chart-color-btn{background:linear-gradient(135deg,#add929,#7eb82a);border:none;border-radius:50%;width:40px;height:40px;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{flex-direction:column;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{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;border-left:4px solid #add929}.analysis-summary h4{margin:0 0 1rem;color:#2e373f;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}.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{display:flex;align-items:center;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;overflow:hidden;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:1.5rem;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%}.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)}.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)}@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}}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/8d697b304b401681-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/ba015fad6dcf6784-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/4cf2300e9c8272f7-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Geist Fallback;src:local("Arial");ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.00%;size-adjust:104.76%}.__className_188709{font-family:Geist,Geist Fallback;font-style:normal}.__variable_188709{--font-geist-sans:"Geist","Geist Fallback"}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/9610d9e46709d722-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/747892c23ea88013-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/93f479601ee12b01-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Geist Mono Fallback;src:local("Arial");ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.00%;size-adjust:134.59%}.__className_9a8899{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.__variable_9a8899{--font-geist-mono:"Geist Mono","Geist Mono Fallback"}