@import url(https://fonts.googleapis.com/css2?family=Poppins:wght@500;700;800;900&family=Montserrat:wght@700;800;900&display=swap);.header{background:linear-gradient(135deg,#4e54c8,#8f94fb 50%,#66d9e8);border-radius:48px;box-shadow:0 8px 24px #0000001a;color:#fff;font-family:Poppins,sans-serif;gap:24px;height:175px;margin-bottom:1rem;margin-top:max(1rem,env(safe-area-inset-top,1rem));padding:max(2rem,env(safe-area-inset-top,2rem)) 1rem 2rem;position:relative}.hero__avatar{border:4px solid #ffffffb3;border-radius:50%;flex-shrink:0;height:150px;object-fit:cover;order:-1;transition:transform .3s ease,box-shadow .3s ease;width:150px}.hero__avatar:hover{box-shadow:0 0 0 8px #fff6;transform:scale(1.05)}.hero__text{align-items:flex-start;display:flex;flex-direction:column;line-height:1.1;min-width:0;text-align:left}.hero__text .hai{color:#fffffff2;font-size:2.3rem;letter-spacing:.25em;margin:0;text-transform:uppercase}.hero__text .hai,.hero__text .name{font-family:Montserrat,Poppins,sans-serif;font-weight:900}.hero__text .name{color:#fff;font-size:2.5rem;letter-spacing:.02em;margin:8px 0 0;text-decoration:underline;text-decoration-thickness:3px;text-shadow:0 2px 8px #0003;text-underline-offset:4px}.login-btn,.logout-btn{align-items:center;background-color:#fff3;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-family:inherit;gap:6px;height:40px;justify-content:center;min-width:80px;padding:.5rem 1rem;position:absolute;right:2rem;top:50%;transform:translateY(-50%);transition:all .2s ease}.login-btn:hover,.logout-btn:hover{background-color:#ffffff59}.logout-btn .logout-text{display:inline}.logout-btn .logout-icon{display:inline-block;font-size:18px}@media (max-width:768px){.logout-btn{border-radius:50%;gap:0;height:40px;min-width:40px;padding:.5rem;right:1.5rem;width:40px}.logout-btn .logout-text{display:none}.logout-btn .logout-icon{display:inline-block;font-size:20px}}@media (max-width:480px){.header{border-radius:32px;gap:18px;height:auto;margin:.5rem;min-height:140px;padding:1.5rem .75rem}.hero__avatar{border-width:3px;height:110px;width:110px}.hero__text .hai{font-size:1.3rem;letter-spacing:.2em}.hero__text .name{font-size:1.7rem;letter-spacing:.01em}.login-btn,.logout-btn{height:36px;right:1rem;width:36px}.logout-btn .logout-icon{font-size:18px}}@media (max-width:375px){.header{gap:16px;min-height:120px;padding:1.25rem .5rem}.hero__avatar{border-width:2px;height:90px;width:90px}.hero__text .hai{font-size:1.1rem}.hero__text .name{font-size:1.4rem}.login-btn,.logout-btn{height:32px;right:.5rem;width:32px}.logout-btn .logout-icon{font-size:16px}}.bubble{max-width:80%}.bubble.user{color:#2c3e50;font-weight:500}.bubble.bot{color:#fff}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:16px}body{background-color:#fff;color:#000;line-height:1.6}.container{max-width:900px;padding:2rem}.header{align-items:center;border-bottom:1px solid #ddd;display:flex;justify-content:center;margin-bottom:2rem;padding:2rem}.logo{height:auto;max-width:250px}.title-container{align-items:center;background:linear-gradient(270deg,#4c96e51a,#4c96e580);border-radius:20px;box-shadow:0 4px 20px #0000000d;display:flex;gap:2rem;justify-content:center;margin:2.5rem 0;padding:1.5rem}.profile-picture{border:4px solid #fff;border-radius:50%;box-shadow:0 4px 12px #0000001a,0 0 0 4px #facb884d;height:130px;object-fit:cover;transition:transform .3s ease,box-shadow .3s ease;width:130px}.profile-picture:hover{box-shadow:0 6px 16px #00000026,0 0 0 6px #4e92e666}.stacked-title{align-items:flex-start;display:flex;flex-direction:column;gap:.5rem}.title-top{background:linear-gradient(45deg,#2563eb,#4c96e5);background-clip:text;-webkit-background-clip:text;font-size:3rem;font-weight:800;letter-spacing:-.02em}.title-bottom,.title-top{-webkit-text-fill-color:#0000;line-height:1}.title-bottom{background:linear-gradient(45deg,#4c96e5,#2563eb);background-clip:text;-webkit-background-clip:text;font-size:2.8rem;font-weight:700;letter-spacing:0;position:relative}.title-bottom:after{background:#4c96e5;border-radius:2px;bottom:-8px;box-shadow:0 0 2px #4c96e5,0 0 4px #4c96e5;content:"";height:4px;left:0;opacity:.7;position:absolute;transform:scaleX(.7);width:100%}@media screen and (max-width:480px){.title-container{gap:1.25rem;margin:1.5rem 0;padding:1rem}.profile-picture{border-width:3px;height:90px;width:90px}.title-top{font-size:2.2rem}.title-bottom{font-size:2rem}.title-bottom:after{bottom:-6px;height:3px}}h2{font-size:1.75rem;font-weight:600;margin-bottom:1rem;text-align:center}.main-content{background-color:#f5f8fa;box-shadow:0 6px 16px #0000001a;padding:2rem}#step1,#step2,#step3,.main-content{border-radius:16px;margin-bottom:2rem}#step1,#step2,#step3{background-color:#fff;box-shadow:0 4px 12px #0000000d;padding:1.5rem}.step{transition:opacity .5s ease-in-out}.hidden{display:none}.visible{display:block}form{gap:1.25rem}.form-group,form{display:flex;flex-direction:column}.file-label,.form-group label,.instruction-label{color:#000;font-size:1rem;font-weight:700;margin-bottom:.5rem}.form-group input,.form-group textarea{background-color:#f9f9f9;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 2px #0000000d;color:#2c2e33;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:1rem;padding:.75rem 1rem;transition:all .3s ease;width:100%}.file-input,.instruction-textarea{background-color:#f9f9f9;border:1px solid #ccc;border-radius:8px;font-size:1rem;padding:.75rem 1rem;transition:border-color .3s ease}.form-group input:focus,.form-group textarea:focus{background-color:#fff;border-color:#ff5c8d;box-shadow:0 0 0 3px #ff5c8d33;outline:none}.file-input:focus,.instruction-textarea:focus{border-color:#ff5c8d;outline:none}.form-group input::placeholder,.form-group textarea::placeholder{color:#9ca3af;font-style:italic}.form-group textarea{min-height:100px;resize:vertical}.instruction-textarea{min-height:80px;resize:vertical}.form-group input[type=date]{-webkit-appearance:none;appearance:none;background-color:#f9f9f9;font-style:italic;padding-right:1rem}.form-group input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6;-webkit-transition:opacity .2s ease;transition:opacity .2s ease}.form-group input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1}.context-files-container{margin-top:15px;width:100%}.file-count-text{color:#4b5563;font-size:.9rem;font-weight:600;margin-bottom:8px}.file-list{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;display:flex;flex-direction:column;gap:8px;max-height:150px;overflow-y:auto;padding:10px}.file-item{align-items:center;background-color:#fff;border:1px solid #e5e7eb;border-radius:6px;display:flex;justify-content:space-between;padding:8px 12px;transition:all .2s ease}.file-item:hover{background-color:#f3f4f6;border-color:#d1d5db}.file-item-name{color:#111827;flex:1 1;font-size:.9rem;overflow:hidden;padding-right:8px;text-overflow:ellipsis;white-space:nowrap}.context-file-hint{color:#6b7280;display:block;font-size:.85rem;font-style:italic;margin-top:5px}.file-input-wrapper label[for=contextFile]:after{content:" (meerdere mogelijk)";font-size:.8rem;font-weight:400;opacity:.8}.button-container,.next-button-container{display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-top:2rem}.back-button{background-color:#6b7280;border:2px solid #6b7280}.back-button:hover{background-color:#fff;color:#6b7280}.submit-button{background-color:#4c96e5;border:2px solid #4c96e5;border-radius:50px;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;min-width:120px;padding:.75rem 2rem;text-align:center;transition:all .3s ease;white-space:nowrap;width:100%}.submit-button:hover{background-color:#fff;color:#4c96e5;transform:scale(1.02)}.submit-button:active{transform:scale(.98)}.upload-form{min-height:200px;padding-bottom:60px;position:relative}.upload-form .submit-button{bottom:0;position:absolute;right:0}.clear-all-button{background-color:#f3f4f6;border:1px solid #ef4444;border-radius:6px;color:#ef4444;cursor:pointer;display:block;font-size:.85rem;margin-top:12px;padding:8px 12px;transition:all .2s ease;width:-webkit-fit-content;width:fit-content}.clear-all-button:hover{background-color:#fee2e2}@media screen and (min-width:768px){.submit-button{font-size:1rem;min-width:200px;padding:.75rem 2rem;width:auto}}@media screen and (max-width:480px){.button-container{flex-direction:column;gap:1.5rem;width:100%}.submit-button{font-size:.85rem;padding:.6rem 1rem}.button-container .submit-button{margin:0;width:100%}}.file-input-wrapper .custom-file-button{font-size:.9rem;min-width:120px;padding:.75rem 1rem;width:100%}@media screen and (min-width:768px){.file-input-wrapper .custom-file-button{font-size:1rem;min-width:200px;padding:.75rem 3rem;width:auto}}.meeting-type-selector{display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;margin:2rem 0}.meeting-type-card{align-items:center;background-color:#fff;border:2px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 6px #0000000d;cursor:pointer;display:flex;flex:1 1;flex-direction:column;min-width:200px;padding:1.5rem;text-align:center;transition:all .3s ease}.meeting-type-card:hover{border-color:#4c96e5;box-shadow:0 6px 12px #0000001a;transform:translateY(-5px)}.meeting-type-card.selected{background-color:#4c96e50d;border-color:#4c96e5;box-shadow:0 4px 12px #4c96e533}.meeting-type-icon{align-items:center;background-color:#4c96e51a;border-radius:50%;color:#4c96e5;display:flex;height:80px;justify-content:center;margin-bottom:1rem;transition:all .3s ease;width:80px}.meeting-type-card.selected .meeting-type-icon,.meeting-type-card:hover .meeting-type-icon{background-color:#4c96e5;color:#fff}.meeting-type-card h3{color:#111827;font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.meeting-type-card p{color:#6b7280;font-size:.875rem;line-height:1.4;margin:0}#selected-meeting-type-indicator{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin:1.5rem 0;padding:.75rem;text-align:center}#selected-meeting-type-indicator p{color:#374151;font-size:1rem;margin:0}#selected-meeting-type{color:#4c96e5;font-weight:600}@media screen and (max-width:768px){.meeting-type-selector{flex-direction:column;gap:15px}.meeting-type-card{width:100%}}.submit-button:disabled{background-color:#9ca3af;border-color:#9ca3af;cursor:not-allowed;opacity:.7}.submit-button:disabled:hover{background-color:#9ca3af;color:#fff;transform:none}.progress-container{margin:2rem auto;max-width:400px;text-align:center}.progress-bar-wrapper{background-color:#f3f4f6;border-radius:8px;box-shadow:inset 0 1px 2px #0000001a;margin-top:1rem;padding:.5rem}progress{border:none;border-radius:10px;height:20px;overflow:hidden;width:100%}progress::-webkit-progress-bar{background-color:#f3f4f6;border-radius:10px}progress::-webkit-progress-value{background-color:#ff5c8d;border-radius:10px;-webkit-transition:width .3s ease;transition:width .3s ease}progress::-moz-progress-bar{background-color:#ff5c8d;border-radius:10px;-moz-transition:width .3s ease;transition:width .3s ease}.error-message,.progress{font-size:1rem;margin-top:1rem;text-align:center}.progress{color:#4d4d4d}.error-message{color:#d93025}.summary-text{background-color:#f5f5f5;border-radius:16px;color:#000;line-height:1.5;margin-bottom:2rem;padding:1.5rem}.summary-actions{align-items:center;justify-content:space-between;margin-bottom:2rem;margin-top:2rem}.left-buttons,.right-buttons,.summary-actions{display:flex;gap:1rem}.right-buttons{margin-left:auto}@media screen and (max-width:480px){.summary-actions{align-items:stretch;flex-direction:column;gap:1.5rem}.left-buttons,.left-buttons .submit-button{width:100%}.right-buttons{gap:2rem;justify-content:center;margin-left:0;width:100%}.icon-button{padding:15px}}.footer{border-top:1px solid #ddd;color:#636366;font-size:.875rem;margin-top:2rem;padding-top:2rem;text-align:center}.footer a{font-weight:700;text-decoration:none;transition:color .3s ease}.footer a,.footer a:hover{color:#ff5c8d}.my-logo{height:auto;opacity:.8;transition:opacity .3s;vertical-align:middle;width:80px}.my-logo:hover{opacity:1}.recording-controls{align-items:center;display:flex;flex-direction:column;gap:1.5rem;margin:2rem 0}.recording-buttons{gap:1rem;max-width:500px;width:100%}.record-button,.recording-buttons{align-items:center;display:flex;justify-content:center}.record-button{background-color:#2c2e33;border:none;border-radius:50%;box-shadow:0 2px 6px #2c2e334d;color:#fff;cursor:pointer;height:120px;transition:all .3s ease;width:120px}.record-button:hover{background-color:#444750;transform:scale(1.05)}.record-button.recording{animation:pulse 2s infinite;background-color:#f44}.record-button svg{stroke:currentColor;height:72px;width:72px}.record-button .mic-icon,.record-button .stop-icon{height:72px;transition:display .3s ease;width:72px}.record-button.recording .mic-icon{display:none}.record-button.recording .stop-icon{display:block}.pause-button{align-items:center;background-color:#499be4;border:none;border-radius:50%;box-shadow:0 2px 6px #ff5c8d4d;color:#fff;cursor:pointer;display:none;height:120px;justify-content:center;transition:all .3s ease;width:120px}.pause-button:hover{background-color:#1863a5;color:#fff;transform:scale(1.05)}.pause-button svg{stroke:currentColor;height:72px;width:72px}#visualizer-container{background-color:#0000000d;border-radius:8px;max-width:500px;order:2;padding:1rem;width:100%}#visualizer{display:block;height:100px;width:100%}#recordingStatus{animation:fadeInPulse .5s ease-in;color:#f44;font-size:1.5rem;font-weight:700;order:3;padding:1rem;text-align:center}#recordingTime{color:#f44;display:block;font-size:1.75rem;font-weight:800;margin-top:.5rem}@keyframes fadeInPulse{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%{box-shadow:0 0 0 0 #f446}70%{box-shadow:0 0 0 10px #f440}to{box-shadow:0 0 0 0 #f440}}.file-name{background:#f5f5f5;border-radius:8px;color:#2563eb;font-size:1rem;margin-left:1rem;max-width:calc(100% - 220px);overflow:hidden;padding:.5rem 1rem;position:relative;text-overflow:ellipsis;white-space:nowrap}.file-input-wrapper{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;position:relative;width:100%}.file-input-wrapper input[type=file]{left:-9999px;position:absolute}.file-input-wrapper .custom-file-button{background-color:#4c96e5;border:2px solid #4c96e5;border-radius:50px;color:#fff;cursor:pointer;display:inline-block;font-weight:600;min-width:200px;padding:.75rem 3rem;transition:all .3s ease}.file-input-wrapper .custom-file-button:hover{background-color:#fff;color:#4c96e5;transform:scale(1.02)}.file-input-wrapper .file-name{background:#f5f5f5;border:1px solid #e5e7eb;border-radius:8px;color:#2c2e33;display:none;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:1rem;font-weight:600;margin-left:1rem;max-width:calc(100% - 220px);overflow:hidden;padding:.5rem 1rem;text-overflow:ellipsis;transition:all .3s ease;white-space:nowrap}.file-input-wrapper .file-name:hover{background:#edf2f7;cursor:pointer}.curved-arrow{display:inline-block;margin-left:10px;transform:translateY(-15px);vertical-align:middle}.curved-arrow path{transition:all .3s ease}.curved-arrow:hover path{stroke:#4e92e6}.file-remove-button{align-items:center;background-color:#f1f1f1;border:1px solid #ddd;border-radius:50%;cursor:pointer;display:inline-flex;height:20px;justify-content:center;margin-left:8px;transition:all .2s ease;vertical-align:middle;width:20px}.file-remove-button:hover{background-color:#f44;border-color:#f44;color:#fff}.file-remove-button svg{stroke:#666;stroke-width:2;height:10px;width:10px}.file-remove-button:hover svg{stroke:#fff}.file-name-container{align-items:center}.file-indicator,.file-name-container{display:flex;margin-top:8px}.file-indicator span{margin-right:10px}@media screen and (max-width:480px){.file-indicator{align-items:center;flex-direction:row;gap:1rem;justify-content:flex-start;margin-top:1rem;width:100%}.file-indicator span{flex:1 1;font-size:.9rem;margin-right:0}.curved-arrow{display:none}.file-indicator:before{border:solid #ff5c8d;border-width:0 3px 3px 0;content:"";display:block;height:24px;margin-left:.5rem;transform:rotate(-135deg);width:24px}}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.icon-button{align-items:center;background:none;border:none;border-radius:50%;cursor:pointer;display:flex;justify-content:center;padding:12px;transition:all .3s ease}.icon-button:hover{background-color:#0000001a;transform:scale(1.1)}.icon-button svg{color:#2c2e33;height:32px;width:32px}.spinner-overlay{align-items:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#ffffffe6;display:flex;flex-direction:column;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.spinner{border:8px solid #f3f3f3;border-top-color:#ff5c8d;height:80px;width:80px}.spinner-text{color:#2c2e33;font-size:1.2rem;font-weight:600;margin-top:20px}.spinner-subtext{color:#2c2e33;font-size:1rem;font-style:italic;font-weight:400;margin-top:8px}.dots{animation:dots 1.5s infinite;display:inline-block}@keyframes dots{0%{content:"."}33%{content:".."}66%{content:"..."}to{content:"."}}.start-over-container{border-top:1px solid #ddd;margin-top:3rem;padding-top:2rem;text-align:center}.button-group{align-items:center;display:flex;gap:1rem;justify-content:center;margin-top:1rem}#startOverButton{background-color:#dc3545;border:2px solid #dc3545;color:#fff}#startOverButton:hover{background-color:#fff;border:2px solid #dc3545;color:#dc3545}#refinement-section{margin-top:1.5rem}#refinement-section h3{font-size:1.25rem;font-weight:600;margin-bottom:1rem;text-align:center}#refinementPrompt{background-color:#f9f9f9;border:1px solid #ccc;border-radius:8px;font-size:1rem;min-height:80px;padding:.75rem 1rem;resize:vertical;transition:border-color .3s ease;width:100%}#refinementPrompt:focus{border-color:#ff5c8d;outline:none}#progressBar{background-color:#ededed;border:1px solid #ccc;border-radius:10px;height:20px;margin:1rem 0;overflow:hidden;width:100%}#progressBar::-webkit-progress-bar{background-color:#ededed;border-radius:10px}#progressBar::-webkit-progress-value{background-color:#ff5c8d;border-radius:10px;-webkit-transition:width .3s ease;transition:width .3s ease}#progressBar::-moz-progress-bar{background-color:#ff5c8d;border-radius:10px;-moz-transition:width .3s ease;transition:width .3s ease}.bubble{animation:slideIn .3s ease;box-shadow:0 2px 6px #0000000d}.bubble.thinking{background:#fff3f8;color:#ff5c8d}.bubble.thinking:after{animation:pulseHalo 1.5s infinite;box-shadow:0 0 10px 2px #ff5c8d80}.record-btn{background:#222;box-shadow:0 4px 12px #0003;cursor:pointer;height:100px;margin:26px auto 18px;transition:background .2s;width:100px}.record-btn:hover{background:#111}.record-btn:active{transform:scale(.96)}button.primary{background:#4c96e5;padding:8px 22px}button.primary[disabled]{opacity:.5}button.ghost{border:2px solid #4c96e5;color:#4c96e5;padding:6px 20px}button.ghost:hover{background:#eaf3ff}.controls button{margin-right:8px}.controls button:first-of-type{margin-left:0}.chat{box-shadow:0 3px 6px #0000000d;height:50vh;margin-bottom:12px}body{background:#f7f7f9;color:#1e1f23;font-family:Inter,system-ui,sans-serif}.container{max-width:720px;padding:24px 16px}.chat{border:1px solid #e0e0e6;border-radius:18px;box-shadow:0 2px 6px #0000000a;height:55vh;margin-bottom:20px;overflow-y:auto;padding:20px}.bubble{border-radius:14px;font-size:15px;line-height:1.45;max-width:85%;padding:10px 16px}.bubble.thinking{background:#fff6fb;color:#ed4e8e;position:relative}.bubble.thinking:after{animation:pulseHalo 1.4s infinite;border-radius:inherit;box-shadow:0 0 10px 3px #ed4e8e59;content:"";inset:0;position:absolute;z-index:-1}@keyframes pulseHalo{0%{opacity:.4;transform:scale(.95)}50%{opacity:0;transform:scale(1.15)}to{opacity:.4;transform:scale(.95)}}.record-btn{align-items:center;background:#1e1f23;border:none;border-radius:50%;box-shadow:0 4px 18px #00000040;color:#fff;display:flex;height:108px;justify-content:center;margin:8px auto 28px;transition:transform .15s,background .2s;width:108px}.record-btn:hover{background:#151619}.record-btn:active{transform:scale(.95)}button.primary{background:#4c8bf5;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;margin-right:10px;padding:9px 26px}button.primary[disabled]{cursor:not-allowed;opacity:.55}button.ghost{background:#fff;border:2px solid #4c8bf5;border-radius:8px;color:#4c8bf5;cursor:pointer;font-size:14px;font-weight:600;margin-right:10px;padding:7px 24px}button.ghost:hover:not([disabled]){background:#f0f4ff}button.ghost[disabled]{cursor:not-allowed;opacity:.55}.controls{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:6px}.btn{-webkit-appearance:none;appearance:none;font-family:inherit;font-size:14px;padding:9px 26px;transition:background .15s,box-shadow .15s,transform .15s;-webkit-user-select:none;user-select:none}.btn:disabled{cursor:not-allowed;opacity:.55}.btn-primary{background:#4c8bf5;box-shadow:0 2px 4px #0000001f}.btn-primary:hover:not(:disabled){background:#3b79e0;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-outline:hover:not(:disabled){background:#ecf2ff}.btn-group{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:4px}.btn{border:0;border-radius:8px;cursor:pointer;font-weight:600;padding:8px 22px}.btn-outline{background:#fff;border:2px solid #4c8bf5;color:#4c8bf5}.btn-outline:hover{background:#ecf2ff}:root{--bg-page:#f7f9fc;--bg-chat:#fff;--text-primary:#27364a;--text-user:#074b3b;--text-bot:#10246a;--bubble-user:#c3f4e4;--bubble-bot:#e6ecff;--accent:#4c8bf5;--font-base:"Nunito",sans-serif;--font-size-base:16px;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--radius:12px;--shadow-light:0 2px 8px #0000000d;--shadow-strong:0 4px 14px #0000001a}body,html{margin:0;max-width:100vw;min-height:100vh;min-height:-webkit-fill-available;overflow-x:hidden;overflow-y:scroll;padding:0;width:100%}body{color:#27364a;color:var(--text-primary);font-family:Nunito,sans-serif;font-family:var(--font-base);font-size:16px;font-size:var(--font-size-base);line-height:1.5;min-height:100vh;min-height:-webkit-fill-available}.container,body{background:#f7f9fc;background:var(--bg-page);position:relative}.container{box-sizing:border-box;margin:0 auto;max-width:760px;min-height:calc(100vh + 250px);min-height:-webkit-fill-available;padding:max(1rem,env(safe-area-inset-top,1rem)) env(safe-area-inset-right,0) calc(300px + env(safe-area-inset-bottom, 0)) env(safe-area-inset-left,0)}.intro-screen{box-sizing:border-box;left:50%;padding:0 1rem;position:absolute;top:160px;transform:translateX(-50%);transition:opacity .4s ease;width:calc(100% - 2rem);z-index:50}.intro-screen.hidden{opacity:0;pointer-events:none}.chat-container{display:flex;flex-direction:column;margin-top:160px;max-height:60vh;opacity:0;overflow-y:auto;padding:0 1rem 200px;transform:translateY(20px);transition:opacity .4s ease,transform .4s ease}.chat-container.visible{opacity:1;transform:translateY(0)}.chat{background:#fff;background:var(--bg-chat);border-radius:12px;border-radius:var(--radius);box-shadow:0 2px 8px #0000000d;box-shadow:var(--shadow-light);display:flex;flex-direction:column;gap:16px;gap:var(--space-md);padding:24px;padding:var(--space-lg);padding-bottom:200px}.bubble{word-wrap:break-word;border-radius:16px;clear:none;float:none;font-family:Nunito,sans-serif;font-size:1rem;font-weight:500;-webkit-hyphens:auto;hyphens:auto;letter-spacing:.01em;line-height:1.5;margin-bottom:8px;max-width:75%;overflow-wrap:break-word;padding:10px 14px;position:relative;text-align:left;width:auto;word-break:break-word}.bubble.user{align-self:flex-end;background:#82adf8;color:#fff;font-weight:600;justify-self:end;margin-left:auto}.bubble.bot{align-self:flex-start;background:#c9dcfc;color:#2c3e50;font-weight:500;justify-self:start;margin-right:auto}.bubble.thinking{background-color:#f1f3f5;color:#7a7a7a;font-style:italic;font-weight:400;opacity:.8}.bubble.system{word-wrap:break-word;align-self:center;background:#f8f9fae6;border:1px solid #e9ecef;border-radius:16px;box-shadow:0 1px 3px #0000001a;color:#6c757d;display:inline-block;font-size:.85rem;font-weight:500;justify-self:center;margin:10px auto;max-width:70%;overflow-wrap:break-word;padding:6px 12px;text-align:center;width:auto}.bubble.system:contains("🆕"){background:#e3f2fde6;border-color:#4c8bf54d;color:#1976d2;font-weight:600}.bubble.system:contains("🎤"){background:#e8f5e9e6;border-color:#4caf504d;color:#2e7d32;font-weight:600}@media (max-width:768px){.bubble{max-width:85%}.bubble.user{align-self:flex-end;margin-left:auto}.bubble.bot{align-self:flex-start;margin-right:auto}.bubble.system{align-self:center;font-size:.75rem;margin:10px auto;max-width:80%;padding:5px 10px}}@media (max-width:480px){.bubble{font-size:.95rem;max-width:90%}.bubble.user{align-self:flex-end;margin-left:auto}.bubble.bot{align-self:flex-start;margin-right:auto}.bubble.system{align-self:center;font-size:.7rem;margin:8px auto;max-width:85%;padding:4px 8px}}.bubble.bot.listening,.bubble.listening{background:#f0f7ff!important;border:1px solid #e2e8f0;color:#64748b!important;font-style:italic;opacity:.9}.bubble.listening em{color:#64748b;font-style:italic}.typingDots{align-items:center;display:flex;gap:4px;height:20px;justify-content:center;padding:2px 0;width:40px}.typingDots span{animation:typingAnimation 1.4s ease-in-out infinite both;background-color:currentColor;border-radius:50%;display:inline-block;height:8px;opacity:.6;width:8px}.typingDots span:first-child{animation-delay:0s}.typingDots span:nth-child(2){animation-delay:.2s}.typingDots span:nth-child(3){animation-delay:.4s}@keyframes typingAnimation{0%,to{opacity:.4;transform:scale(.6)}50%{opacity:.8;transform:scale(1)}}.bubble.speaking,.bubble.typing{animation:glowPulse 2s ease-in-out infinite alternate}.bubble.user.speaking,.bubble.user.typing{animation:userGlowPulse 2s ease-in-out infinite alternate}.bubble.bot.speaking,.bubble.bot.typing{animation:botGlowPulse 2s ease-in-out infinite alternate}@keyframes glowPulse{0%{box-shadow:0 2px 8px #0000000d}to{box-shadow:0 4px 14px #4c8bf540}}@keyframes userGlowPulse{0%{box-shadow:0 2px 8px #0000000d}to{box-shadow:0 4px 14px #82adf84d}}@keyframes botGlowPulse{0%{box-shadow:0 2px 8px #0000000d}to{box-shadow:0 4px 14px #c9dcfc66}}.enhanced-status-display{align-items:center;animation:slideInFromTop .3s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff2;border:1px solid #ffffff4d;border-radius:20px;box-shadow:0 8px 32px #00000026;display:flex;font-family:Poppins,Nunito,sans-serif;gap:12px;left:50%;min-width:300px;padding:16px 24px;position:fixed;top:180px;transform:translateX(-50%);z-index:2000}.status-icon{font-size:28px;height:36px;min-width:36px}.status-icon.pulse{animation:statusIconPulse 2s ease-in-out infinite}.status-content{flex:1 1}.status-main-text{color:#333;font-size:16px;font-weight:600;line-height:1.3;margin:0}.status-sub-text{color:#666;font-size:13px;line-height:1.2;margin-top:2px;opacity:.85}@keyframes slideInFromTop{0%{opacity:0;transform:translateX(-50%) translateY(-30px) scale(.95)}to{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}}@keyframes statusIconPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.85;transform:scale(1.15)}}.mic-btn.initial,.mic-btn.restart{align-items:center;background:#4c8bf5;background:var(--accent);border:none;border-radius:50%;box-shadow:0 4px 20px #4c8bf54d;color:#fff;cursor:pointer;display:flex;font-size:3.5rem;height:100px;justify-content:center;left:50%;overflow:hidden;position:absolute;top:240px;transform:translateX(-50%);transition:opacity .3s ease,transform .5s ease;width:100px;z-index:100}.mic-btn.initial .material-icons,.mic-btn.restart .material-icons{font-size:3.5rem;text-shadow:0 2px 8px #00000026}.mic-btn.initial:after,.mic-btn.restart:after{border:2px solid #fff9;border-radius:50%;content:"";height:0;left:50%;opacity:0;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .4s ease,height .4s ease,opacity .4s ease;width:0}.mic-btn.initial:hover:after,.mic-btn.restart:hover:after{height:120%;opacity:1;width:120%}.fab-container{display:flex;gap:8px;gap:var(--space-sm);left:50%;opacity:0;pointer-events:none;position:absolute;top:240px;transform:translateX(-50%);transition:opacity .3s ease .2s;z-index:1000}.fab-container.visible{opacity:1;pointer-events:auto}.fab-btn{align-items:center;background:#4c8bf5;background:var(--accent);border:none;border-radius:50%;box-shadow:0 4px 14px #0000001a;box-shadow:var(--shadow-strong);color:#fff;cursor:pointer;display:flex;font-size:1.5rem;height:100px;justify-content:center;overflow:hidden;position:relative;transition:transform .1s ease,box-shadow .3s ease;width:100px}.fab-btn:hover{box-shadow:0 2px 8px #0000000d;box-shadow:var(--shadow-light);transform:scale(1.05)}.fab-btn.stop{background:#f44336}.fab-btn.pause{background:#2196f3}.fab-btn.pause:disabled{cursor:not-allowed;opacity:.6;transform:none!important}.fab-btn.pause:disabled:hover{box-shadow:0 4px 14px #0000001a;box-shadow:var(--shadow-strong);transform:none!important}.fab-btn.pause.resume{background:#4caf50}.fab-btn.pause.resume:hover{background:#45a049}.fab-btn:after{border:2px solid #fff9;border-radius:50%;content:"";height:0;left:50%;opacity:0;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .4s ease,height .4s ease,opacity .4s ease;width:0}.fab-btn:hover:after{height:120%;opacity:1;width:120%}.btn-primary{background:linear-gradient(90deg,#6a8bff,#8cb0ff);border:none;border-radius:12px;border-radius:var(--radius);box-shadow:0 2px 8px #0000000d;box-shadow:var(--shadow-light);color:#fff;cursor:pointer;display:inline-block;padding:8px 16px;padding:var(--space-sm) var(--space-md);transition:transform .1s ease,box-shadow .3s ease}.btn-primary:hover{box-shadow:0 4px 14px #0000001a;box-shadow:var(--shadow-strong)}.btn-primary:active{transform:scale(.97)}.btn.btn-outline{align-items:center;background:#fff;border:1px solid #4c8bf5;border:1px solid var(--accent);border-radius:12px;border-radius:var(--radius);color:#4c8bf5;color:var(--accent);cursor:pointer;display:inline-flex;font-family:inherit;font-size:inherit;gap:6px;justify-content:center;padding:8px 16px;padding:var(--space-sm) var(--space-md);text-decoration:none;transition:background-color .2s ease,color .2s ease,transform .1s ease}.btn.btn-outline:hover{background-color:#4c8bf5;background-color:var(--accent);color:#fff}.btn.btn-outline:active{transform:scale(.97)}.btn.btn-blue{align-items:center;background:#4a90e2;border:2px solid #0000;border-radius:30px;box-shadow:0 2px 4px #0000001a;box-sizing:border-box;color:#fff;cursor:pointer;display:inline-flex;font-size:16px;font-weight:500;gap:8px;justify-content:center;min-width:180px;padding:12px 20px;text-align:center;transition:all .3s ease}.btn.btn-blue:active{transform:scale(.98)}.btn.btn-blue:hover{background-color:#fff;border:2px solid #4c8bf5;border:2px solid var(--accent);box-shadow:0 2px 8px #4c8bf533;color:#4c8bf5;color:var(--accent)}.btn .material-icons{font-size:20px;transition:all .3s ease}.action-btn{align-items:center;border:none;border-radius:12px;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:8px;justify-content:center;min-width:160px;padding:12px 24px;transition:all .2s ease}.action-btn .material-icons{font-size:20px}.download-buttons{grid-gap:20px 16px;align-items:center;display:grid;gap:20px 16px;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,auto);margin:40px auto 120px;max-width:800px;padding:0 20px;position:relative;z-index:10}.download-buttons .btn:first-child,.download-buttons .btn:nth-child(2),.download-buttons .btn:nth-child(3){background:#4c8bf5;border:none;border-radius:20px;box-shadow:0 6px 20px #4c8bf540,inset 0 1px 0 #ffffff1a;color:#fff;font-size:1rem;font-weight:600;grid-row:1;min-height:60px;overflow:hidden;padding:16px 20px;position:relative;transition:all .2s ease}.download-buttons .btn:first-child:hover,.download-buttons .btn:nth-child(2):hover,.download-buttons .btn:nth-child(3):hover{background:#5a96f7;box-shadow:0 10px 30px #4c8bf559;transform:translateY(-3px)}.download-buttons .btn:first-child:active,.download-buttons .btn:nth-child(2):active,.download-buttons .btn:nth-child(3):active{background:#3e7ef3;box-shadow:0 4px 15px #4c8bf54d;transform:translateY(-1px)}.download-buttons .btn:nth-child(4),.download-buttons .btn:nth-child(5),.download-buttons .btn:nth-child(6){background:#fff;border:2px solid #e2e8f0;border-radius:15px;box-shadow:0 3px 12px #00000014;color:#4c8bf5;font-size:.85rem;font-weight:500;grid-row:2;min-height:45px;padding:10px 16px;transition:all .2s ease}.download-buttons .btn:nth-child(4):hover,.download-buttons .btn:nth-child(5):hover,.download-buttons .btn:nth-child(6):hover{background:#f0f7ff;border-color:#4c8bf5;box-shadow:0 6px 20px #4c8bf526,0 0 0 1px #4c8bf51a;transform:translateY(-2px)}.download-buttons .btn .material-icons{font-size:20px;transition:all .2s ease}.download-buttons .btn:hover .material-icons{transform:scale(1.05)}@media (max-width:768px) and (min-width:481px){.download-buttons{gap:16px 12px;grid-template-columns:repeat(2,1fr);margin:30px auto 100px;max-width:400px}.download-buttons .btn:first-child,.download-buttons .btn:nth-child(2),.download-buttons .btn:nth-child(3){font-size:.95rem;min-height:55px;padding:14px 18px}.download-buttons .btn:nth-child(4),.download-buttons .btn:nth-child(5),.download-buttons .btn:nth-child(6){font-size:.8rem;min-height:42px;padding:9px 14px}}@media (max-width:480px){.download-buttons{display:flex;flex-direction:column;gap:14px;margin:20px auto 90px;padding:0 16px}.download-buttons .btn{border-radius:16px;font-size:.9rem;font-weight:600;min-height:52px;padding:14px 18px;width:100%}.download-buttons .btn:nth-child(-n+3){background:#4c8bf5;border:none;box-shadow:0 4px 15px #4c8bf540;color:#fff}.download-buttons .btn:nth-child(-n+3):hover{background:#5a96f7;transform:translateY(-2px)}.download-buttons .btn:nth-child(n+4){background:#fff;border:2px solid #e2e8f0;color:#4c8bf5;font-size:.85rem;min-height:46px;padding:12px 16px}.download-buttons .btn:nth-child(n+4):hover{background:#f0f7ff;border-color:#4c8bf5}.download-buttons .btn .material-icons{font-size:18px}}div[style*="textAlign: center"]{display:flex;gap:10px;justify-content:center;margin-bottom:20px;margin-top:20px}.floating-review-btn{align-items:center;background:linear-gradient(135deg,#48bb78,#38a169);border:none;border-radius:50%;bottom:30px;box-shadow:0 6px 20px #48bb7866;color:#fff;cursor:pointer;display:flex;font-size:24px;height:64px;justify-content:center;position:fixed;right:30px;transition:all .3s ease;width:64px;z-index:2000}.floating-review-btn:hover{box-shadow:0 8px 25px #48bb7880;transform:scale(1.1) translateY(-2px)}.floating-review-btn:active{transform:scale(.95)}.floating-buttons-container{animation:slideInFromRight .3s ease-out;bottom:30px;display:flex;gap:12px;position:fixed;right:30px;z-index:2000}.floating-action-btn{align-items:center;border:none;border-radius:50%;box-shadow:0 4px 12px #00000026;color:#fff;cursor:pointer;display:flex;font-size:22px;height:56px;justify-content:center;transition:all .2s ease;width:56px}.floating-action-btn:hover{box-shadow:0 6px 16px #0003;transform:scale(1.08) translateY(-2px)}.floating-action-btn:active{transform:scale(.96)}.floating-pdf-btn{background:linear-gradient(135deg,#3b82f6,#2563eb)}.floating-pdf-btn:hover{box-shadow:0 6px 16px #3b82f666}.floating-email-btn{background:linear-gradient(135deg,#10b981,#059669)}.floating-email-btn:hover{box-shadow:0 6px 16px #10b98166}.floating-delete-btn{background:linear-gradient(135deg,#ef4444,#dc2626)}.floating-delete-btn:hover{box-shadow:0 6px 16px #ef444466}@media (max-width:768px){.floating-buttons-container{bottom:25px;gap:10px;right:25px}.floating-action-btn{font-size:20px;height:52px;width:52px}}@media (max-width:480px){.floating-buttons-container{bottom:20px;gap:8px;right:20px}.floating-action-btn{font-size:18px;height:48px;width:48px}}.status-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.status-modal{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:20px;box-shadow:0 10px 40px #0003;max-width:400px;padding:32px 24px;text-align:center;width:90%}.status-icon{align-items:center;display:flex;height:80px;justify-content:center;margin-bottom:20px;position:relative}.spinner{animation:spin 1s linear infinite;border:3px solid #e3f2fd;border-radius:50%;border-top-color:#4c8bf5;height:60px;position:absolute;width:60px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.status-emoji{font-size:2.5rem;z-index:1}.status-title{color:#2c3e50;font-family:Poppins,sans-serif;font-size:1.4rem;font-weight:600;margin:0 0 12px}.status-message{color:#64748b;font-size:1rem;line-height:1.5;margin:0 0 24px}.status-close-btn{background:#4c8bf5;border:none;border-radius:25px;color:#fff;cursor:pointer;font-weight:500;padding:12px 24px;transition:background-color .2s ease}.status-close-btn:hover{background:#3b82f6}.status-indicator-small{align-items:center;animation:slideInFromRight .3s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#4c8bf5f2;border-radius:20px;box-shadow:0 4px 12px #4c8bf54d;color:#fff;display:flex;font-size:.9rem;font-weight:500;gap:8px;padding:8px 16px;position:fixed;right:20px;top:20px;z-index:1500}@keyframes slideInFromRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.status-emoji-small{font-size:1.1rem}.status-text-small{font-size:.85rem;font-weight:500}.status-indicator{animation:statusPulse 2s ease-in-out infinite;background:#4c8bf5e6;border-radius:25px;box-shadow:0 4px 12px #4c8bf54d;color:#fff;font-size:.9rem;font-weight:500;left:50%;padding:12px 20px;position:absolute;top:330px;transform:translateX(-50%);z-index:999}@keyframes statusPulse{0%,to{opacity:.9;transform:translateX(-50%) scale(1)}50%{opacity:1;transform:translateX(-50%) scale(1.02)}}.modal-overlay{align-items:center;animation:modalOverlayFadeIn .25s ease-out;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);background:#0006;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:10000}@keyframes modalOverlayFadeIn{0%{-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0);opacity:0}to{-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);opacity:1}}.modal-content{animation:modalSlideIn .35s cubic-bezier(.16,1,.3,1);background:#fffffffa;border-radius:20px;box-shadow:0 25px 50px -12px #00000040,0 0 0 .5px #0000000d;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;max-height:85vh;max-width:560px;overflow-y:auto;padding:3rem 2.5rem 2.5rem;position:relative;scrollbar-color:#00000026 #0000;scrollbar-width:thin;width:100%}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.96) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-content::-webkit-scrollbar{width:8px}.modal-content::-webkit-scrollbar-track{background:#0000;margin:12px 0}.modal-content::-webkit-scrollbar-thumb{background:#0003;background-clip:padding-box;border:2px solid #fffffffa;border-radius:4px;-webkit-transition:background .2s ease;transition:background .2s ease}.modal-content::-webkit-scrollbar-thumb:hover{background:#0000004d;background-clip:padding-box;border:2px solid #fffffffa}.modal-close{align-items:center;background:#78788029;border:none;border-radius:50%;color:#3c3c4399;cursor:pointer;display:flex;font-size:1.3rem;font-weight:400;height:30px;justify-content:center;line-height:1;padding:0;position:absolute;right:1.5rem;top:1.5rem;transition:all .15s ease;width:30px;z-index:1}.modal-close:hover{background:#7878803d;color:#3c3c43d9}.modal-close:active{background:#78788052;transform:scale(.96)}.modal-content h2{align-items:center;color:#1d1d1f;display:flex;font-size:1.75rem;font-weight:600;gap:.5rem;letter-spacing:-.02em;line-height:1.15;margin-bottom:.25rem;margin-top:0}.help-section,.tips-section{background:#0000;border-left:none;border-radius:0;margin-bottom:2rem;padding:0}.help-section:last-child,.tips-section:last-child{margin-bottom:1.5rem}.help-section h3,.tips-section h3{align-items:center;color:#1d1d1f;display:flex;font-size:1.1rem;font-weight:600;gap:.5rem;letter-spacing:-.01em;margin:0 0 .75rem}.help-section ul,.tips-section ul{list-style:none;margin:0;padding:0}.help-section li,.tips-section li{color:#6e6e73;font-size:.94rem;line-height:1.5;margin-bottom:.65rem;padding-left:1.25rem;position:relative}.help-section li:before,.tips-section li:before{color:#86868b;content:"•";font-size:1.1rem;font-weight:400;left:0;position:absolute;top:0}.help-section li:last-child,.tips-section li:last-child{margin-bottom:0}.help-section p{color:#6e6e73;font-size:.94rem;line-height:1.5;margin-bottom:1rem}.help-section p:last-child{margin-bottom:0}.modal-button{background:#007aff;border:none;border-radius:12px;box-shadow:none;color:#fff;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:500;letter-spacing:-.01em;margin-top:2rem;overflow:hidden;padding:.875rem 1.5rem;position:relative;transition:all .15s ease;width:100%}.modal-button:hover{background:#0051d5}.modal-button:active{background:#004fc4;transform:scale(.98)}@media (max-width:768px){.modal-overlay{align-items:center;padding:1rem}.modal-content{border-radius:18px;max-height:88vh;padding:2.5rem 2rem 2rem}.modal-close{font-size:1.2rem;height:28px;right:1.25rem;top:1.25rem;width:28px}.modal-content h2{font-size:1.6rem;margin-bottom:.25rem}.help-section h3,.tips-section h3{font-size:1.05rem}.help-section li,.help-section p,.tips-section li{font-size:.92rem}.modal-button{font-size:.98rem;padding:.825rem 1.2rem}}@media (max-width:480px){.modal-overlay{padding:.75rem}.modal-content{border-radius:16px;padding:2rem 1.5rem 1.75rem}.modal-close{font-size:1.15rem;height:26px;right:1.1rem;top:1.1rem;width:26px}.modal-content h2{font-size:1.45rem;margin-bottom:.2rem}.help-section h3,.tips-section h3{font-size:1rem}.help-section li,.help-section p,.tips-section li{font-size:.85rem;line-height:1.5}}.error-message{align-items:center;background:linear-gradient(135deg,#ff5252,#f44336);border-radius:12px;box-shadow:0 6px 20px #f443364d;color:#fff;left:50%;max-width:90%;padding:16px 24px;text-align:center;transform:translateX(-50%);transform:translateX(-50%) translateY(-20px);transition:all .3s ease;z-index:1000}.error-message.visible{transform:translateX(-50%) translateY(0)}.error-message .error-icon{font-size:24px;margin-right:12px}.error-message .error-text{font-size:.95rem}.error-message .close-button{background:#0000;border-radius:4px;color:#fff;font-size:20px;margin-left:12px;opacity:.8;padding:4px;transition:opacity .2s ease}.error-message .close-button:hover{background:#ffffff1a;opacity:1}.mobile-progress-bar{backdrop-filter:blur(10px)!important;-webkit-backdrop-filter:blur(10px)!important;background:#fffffff2!important;border:1px solid #fff3!important;border-radius:20px!important;box-shadow:0 8px 32px #00000026!important;max-width:400px!important;opacity:0!important;padding:16px 20px!important;transition:all .3s ease!important;visibility:hidden!important;width:90%!important}.mobile-progress-bar.visible{animation:slideUpMobile .4s ease-out!important}.progress-close-btn{align-items:center;background:#fffffff2;border:2px solid #e2e8f0;border-radius:50%;box-shadow:0 4px 12px #00000026;color:#4c8bf5;cursor:pointer;display:none;font-family:Arial,sans-serif;font-size:16px;font-weight:700;height:28px;justify-content:center;opacity:0;position:absolute;right:-12px;top:-12px;transform:scale(.8);transition:all .2s ease;width:28px;z-index:1600}.progress-close-btn:hover{background:#f8f9ff;border-color:#4c8bf5;box-shadow:0 6px 16px #4c8bf540;transform:scale(1.05)}.progress-close-btn:active{transform:scale(.95)}@media (min-width:769px){.mobile-progress-bar.completed .progress-close-btn{animation:fadeInScale .4s ease-out 1.5s forwards;display:flex}}@keyframes fadeInScale{to{opacity:1;transform:scale(1)}}.mobile-progress-info{align-items:center!important;display:flex!important;justify-content:space-between!important;margin-bottom:12px!important}.mobile-progress-title{color:#2c3e50!important;font-family:Poppins,sans-serif!important;font-size:16px!important;font-weight:600!important}.mobile-progress-percentage{color:#64748b!important;font-size:14px!important;font-weight:500!important}.mobile-progress-track{background:#e5e7eb!important;height:6px!important;overflow:hidden!important;width:100%!important}.mobile-progress-fill,.mobile-progress-track{border-radius:3px!important;position:relative!important}.mobile-progress-fill{background:linear-gradient(90deg,#4e54c8,#8f94fb 50%,#66d9e8)!important;height:100%!important;transition:width .8s cubic-bezier(.4,0,.2,1)!important}.mobile-progress-fill:after{animation:progressShine 2s linear infinite!important;background:linear-gradient(90deg,#0000,#fff6,#0000)!important;content:""!important;height:100%!important;left:-100%!important;position:absolute!important;top:0!important;width:100%!important}.mobile-current-step{color:#64748b!important;font-size:12px!important;font-style:italic!important;line-height:1.3!important;margin-top:10px!important;text-align:center!important}@media (min-width:769px){.mobile-progress-bar{bottom:30px!important;max-width:500px!important;padding:20px 24px!important}.mobile-progress-title{font-size:17px!important}.mobile-progress-percentage{font-size:15px!important}.mobile-progress-track{height:7px!important}.mobile-current-step{font-size:13px!important;margin-top:12px!important}}@media (max-width:768px){.mobile-progress-bar{bottom:25px!important;max-width:400px!important;padding:16px 20px!important;width:95%!important}.mobile-progress-title{font-size:15px!important}.mobile-progress-percentage{font-size:13px!important}.mobile-progress-track{height:6px!important}.mobile-current-step{font-size:11px!important;margin-top:10px!important}}@media (max-width:480px){.mobile-progress-bar{bottom:20px!important;max-width:350px!important;padding:14px 18px!important;width:95%!important}.mobile-progress-title{font-size:14px!important}.mobile-progress-percentage{font-size:12px!important}.mobile-progress-track{height:5px!important}.mobile-current-step{font-size:10px!important;margin-top:8px!important}}@media (max-width:375px){.mobile-progress-bar{bottom:15px!important;max-width:320px!important;padding:12px 16px!important;width:96%!important}.mobile-progress-title{font-size:13px!important}.mobile-progress-percentage{font-size:11px!important}.mobile-progress-track{height:4px!important}.mobile-current-step{font-size:9px!important;margin-top:6px!important}}.download-buttons{margin-bottom:120px!important}@media (max-width:768px){.download-buttons{margin-bottom:100px!important}}@media (max-width:480px){.download-buttons{margin-bottom:90px!important}}.horizontal-progress-bar-wrapper,.horizontal-progress-container,.horizontal-progress-fill,.horizontal-progress-step,.horizontal-progress-track,.horizontal-step-circle,.horizontal-step-label,.horizontal-step-number{display:none!important}.connection-status{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:1px solid #fff3;border-radius:15px;display:inline-flex;font-size:12px;margin-left:12px;padding:6px 12px}.connection-status .status-dot{border-radius:50%;box-shadow:0 0 4px #0000004d;height:8px;margin-right:6px;width:8px}.connection-status.connected .status-dot{background:#4caf50;box-shadow:0 0 8px #4caf5099}.connection-status.connecting .status-dot{animation:connectionBlink 1.5s infinite;background:#ffc107}.connection-status.error .status-dot{background:#ff5252;box-shadow:0 0 8px #ff525299}@keyframes connectionBlink{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}.chat-container::-webkit-scrollbar{width:6px}.chat-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.chat-container::-webkit-scrollbar-thumb{background:#4c8bf5;background:var(--accent);border-radius:3px}@media (max-width:480px){.container{margin:0;padding-left:.5rem;padding-right:.5rem;padding-top:max(1.5rem,env(safe-area-inset-top,1.5rem))}.chat-container{margin-top:180px;max-height:35vh;padding:0 .5rem 220px}.hero__avatar{border-width:2.5px;height:110px;width:110px}.intro-screen{box-sizing:border-box;padding:0 .5rem;top:200px;width:calc(100% - 1rem)}.intro-screen,.mic-btn.initial,.mic-btn.restart{left:50%;position:absolute;transform:translateX(-50%)}.mic-btn.initial,.mic-btn.restart{height:100px;top:240px;width:100px}.mic-btn.initial .material-icons,.mic-btn.restart .material-icons{font-size:3rem}.fab-container{gap:16px;left:50%;position:absolute;top:240px;transform:translateX(-50%)}.fab-btn{font-size:2.5rem;height:100px;width:100px}.enhanced-status-display{left:50%;margin:0 1rem;max-width:calc(100vw - 2rem);min-width:250px;padding:12px 20px;position:fixed;top:180px;transform:translateX(-50%)}.status-main-text{font-size:14px}.status-sub-text{font-size:12px}.status-indicator{font-size:.8rem;left:50%;max-width:calc(100vw - 2rem);padding:10px 16px;position:absolute;text-align:center;top:340px;transform:translateX(-50%)}.download-buttons{flex-direction:column;gap:12px;margin:2rem 1rem;padding:0;position:relative}.btn.btn-blue{font-size:14px;margin:0;padding:14px 20px;width:100%}.bubble{font-size:.9rem;max-width:90%}}.desktop-only{display:block}.mobile-only{display:none}@media (max-width:768px){.desktop-only{display:none}.mobile-only{display:block}}.horizontal-progress-container{bottom:-80px;height:70px;left:50%;max-width:400px;padding:16px 20px;pointer-events:none;position:absolute;transform:translateX(-50%);width:95%;z-index:1500}.horizontal-progress-bar-wrapper{height:100%;position:relative;width:100%}.horizontal-progress-track{background:#e5e7eb;width:100%}.horizontal-progress-fill,.horizontal-progress-track{border-radius:2px;height:4px;left:0;position:absolute;top:50%;transform:translateY(-50%)}.horizontal-progress-fill{background:linear-gradient(90deg,#4e54c8,#8f94fb);transition:width .8s cubic-bezier(.4,0,.2,1)}.horizontal-progress-step{align-items:center;display:flex;flex-direction:column;gap:6px;pointer-events:auto;position:absolute;top:50%;transform:translateX(-50%) translateY(-50%)}.horizontal-step-circle{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:50%;box-shadow:0 2px 8px #0000001a;display:flex;height:28px;justify-content:center;order:1;transition:all .3s ease;width:28px;z-index:10}.horizontal-progress-step.completed .horizontal-step-circle{animation:completePulse .6s ease-out;background:#4e54c8;border-color:#4e54c8}.horizontal-progress-step.active .horizontal-step-circle{animation:activePulse 2s ease-in-out infinite;background:#fff;border-color:#4e54c8}.horizontal-step-number{color:#6b7280;font-size:11px;font-weight:600}.horizontal-progress-step.completed .horizontal-step-number{color:#fff}.horizontal-progress-step.active .horizontal-step-number{color:#4e54c8}.horizontal-step-label{background:#fffffff2;border:1px solid #0000000d;border-radius:6px;box-shadow:0 2px 8px #00000026;color:#6b7280;font-size:10px;font-weight:500;margin-top:8px;max-width:80px;order:2;overflow:hidden;padding:3px 8px;text-align:center;text-overflow:ellipsis;white-space:nowrap}.horizontal-progress-step.active .horizontal-step-label,.horizontal-progress-step.completed .horizontal-step-label{color:#4e54c8;font-weight:600}.horizontal-progress-step:nth-child(2){left:0}.horizontal-progress-step:nth-child(3){left:33.33%}.horizontal-progress-step:nth-child(4){left:66.66%}.horizontal-progress-step:nth-child(5){left:100%}@media (max-width:768px) and (orientation:portrait){.chat-container{margin-bottom:100px!important;padding-bottom:20px;position:relative}.desktop-only{display:none}.mobile-only{display:block;opacity:1;transition:opacity .3s ease,visibility .3s ease;visibility:visible}.mobile-only.hide-after-conversation{opacity:0;visibility:hidden}.download-buttons{flex-direction:column;gap:12px;margin:20px 0 40px;padding:0 20px}.btn.btn-blue{font-size:14px;margin:0;min-width:auto;padding:14px 20px;width:100%}.btn .material-icons{font-size:18px}.action-btn{font-size:.9rem;min-width:auto;padding:14px 20px;width:100%}.action-btn .material-icons{font-size:18px}}@media (max-width:480px) and (orientation:portrait){.horizontal-progress-container{bottom:-70px;height:60px;max-width:320px;padding:12px 16px;width:90%}.horizontal-step-circle{height:24px;width:24px}.horizontal-step-number{font-size:9px}.horizontal-step-label{font-size:9px;margin-top:6px;max-width:60px;padding:2px 6px}.chat-container{margin-bottom:80px!important}.download-buttons{margin-top:20px!important;padding:0 16px}.btn.btn-blue{font-size:13px;padding:12px 16px}.btn .material-icons{font-size:16px}.action-btn{font-size:.85rem;padding:12px 16px}.action-btn .material-icons{font-size:16px}}@media (max-width:375px) and (orientation:portrait){.horizontal-progress-container{bottom:-65px;height:55px;max-width:280px;padding:10px 12px;width:95%}.horizontal-step-circle{height:22px;width:22px}.horizontal-step-number{font-size:8px}.horizontal-step-label{font-size:8px;margin-top:5px;max-width:50px;padding:2px 4px}}@media (max-width:768px) and (orientation:landscape){.container{display:none!important}body:after{background:#4e54c8;border-radius:16px;box-shadow:0 8px 32px #0000004d;color:#fff;content:"📱 Draai je telefoon naar staande positie voor de beste ervaring";font-size:16px;font-weight:600;left:50%;line-height:1.4;max-width:80%;padding:20px 30px;position:fixed;text-align:center;top:50%;transform:translate(-50%,-50%);z-index:9999}html{background:#f7f9fc}}@keyframes completePulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes activePulse{0%,to{box-shadow:0 2px 8px #0000001a,0 0 0 0 #4e54c866}50%{box-shadow:0 2px 8px #0000001a,0 0 0 8px #4e54c800}}.notification-overlay{align-items:center!important;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#000000b3;bottom:0;display:flex!important;justify-content:center!important;left:0;opacity:0;padding:20px;position:fixed;right:0;top:0;transition:all .3s cubic-bezier(.4,0,.2,1);visibility:hidden;z-index:10000}.notification-overlay.visible{opacity:1;visibility:visible}.notification-modal{-webkit-overflow-scrolling:touch;background:#fff;border-radius:24px;box-shadow:0 25px 80px #0000004d,0 10px 40px #0003;margin:auto;max-height:85vh;max-width:450px;overflow-y:auto;padding:32px 24px 24px;position:relative;transform:scale(.9) translateY(30px);transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}@media (max-width:768px){.notification-overlay{align-items:center;justify-content:center;padding:16px}.notification-modal{border-radius:20px;margin:auto;max-height:70vh;padding-bottom:max(24px,env(safe-area-inset-bottom,24px))}}@media (max-width:480px){.notification-overlay{align-items:center;justify-content:center;padding:12px}.notification-modal{border-radius:20px;margin:auto;max-height:65vh}}.notification-overlay.visible .notification-modal{transform:scale(1) translateY(0)}.notification-close{-webkit-tap-highlight-color:transparent;align-items:center;background:#f1f3f5;border:none;border-radius:50%;color:#64748b;cursor:pointer;display:flex;height:44px;justify-content:center;position:absolute;right:12px;top:12px;touch-action:manipulation;transition:all .2s ease;width:44px;z-index:1}.notification-close:focus,.notification-close:hover{background:#e2e8f0;outline:none;transform:scale(1.1)}.notification-close:active{background:#cbd5e0;transform:scale(.95)}.notification-icon-container{display:flex;justify-content:center;margin-bottom:20px;margin-top:8px}.notification-icon{align-items:center;border-radius:50%;display:flex;font-size:32px;height:72px;justify-content:center;overflow:hidden;position:relative;width:72px}.notification-icon.warning{animation:warningPulseMobile 2.5s ease-in-out infinite;background:linear-gradient(135deg,#ff6b6b,#ff8e53);color:#fff}.notification-icon.info{animation:infoPulseMobile 2.5s ease-in-out infinite;background:linear-gradient(135deg,#4e54c8,#8f94fb);color:#fff}.notification-icon.success{animation:successPulseMobile 2.5s ease-in-out infinite;background:linear-gradient(135deg,#48bb78,#38a169);color:#fff}.notification-title{color:#1a202c;font-family:Poppins,sans-serif;font-size:20px;font-weight:700;line-height:1.3;margin-bottom:12px;text-align:center}.notification-message{color:#4a5568;font-size:15px;line-height:1.5;margin-bottom:28px;text-align:center}.notification-actions{display:flex;flex-direction:column;gap:12px;width:100%}.notification-btn{-webkit-tap-highlight-color:transparent;align-items:center;border:none;border-radius:14px;cursor:pointer;display:flex;font-family:Poppins,sans-serif;font-size:15px;font-weight:600;justify-content:center;min-height:52px;overflow:hidden;padding:16px 24px;position:relative;touch-action:manipulation;transition:all .2s ease;-webkit-user-select:none;user-select:none;width:100%}.notification-btn.primary{background:linear-gradient(135deg,#4e54c8,#8f94fb);box-shadow:0 6px 20px #4e54c84d;color:#fff}.notification-btn.primary:focus,.notification-btn.primary:hover{box-shadow:0 8px 25px #4e54c866;outline:none;transform:translateY(-1px)}.notification-btn.primary:active{box-shadow:0 4px 15px #4e54c84d;transform:translateY(0)}.notification-btn.secondary{background:#f7fafc;border:2px solid #e2e8f0;box-shadow:0 2px 8px #0000000d;color:#4a5568}.notification-btn.secondary:focus,.notification-btn.secondary:hover{background:#edf2f7;border-color:#cbd5e0;outline:none}.notification-btn.secondary:active{background:#e2e8f0}.notification-btn.danger{background:linear-gradient(135deg,#ff6b6b,#ff8e53);box-shadow:0 6px 20px #ff6b6b4d;color:#fff}.notification-btn.danger:focus,.notification-btn.danger:hover{box-shadow:0 8px 25px #ff6b6b66;outline:none;transform:translateY(-1px)}.notification-btn.danger:active{box-shadow:0 4px 15px #ff6b6b4d;transform:translateY(0)}@keyframes warningPulseMobile{0%,to{box-shadow:0 0 0 0 #ff6b6b99}50%{box-shadow:0 0 0 15px #ff6b6b00}}@keyframes infoPulseMobile{0%,to{box-shadow:0 0 0 0 #4e54c899}50%{box-shadow:0 0 0 15px #4e54c800}}@keyframes successPulseMobile{0%,to{box-shadow:0 0 0 0 #48bb7899}50%{box-shadow:0 0 0 15px #48bb7800}}.toast-container{align-items:center;flex-direction:column;gap:10px;left:50%;pointer-events:none;position:fixed;top:20px;transform:translateX(-50%);width:calc(100% - 32px);z-index:9999}.toast,.toast-container{display:flex;max-width:500px}.toast{align-items:flex-start;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#fff;border-left:4px solid #e2e8f0;border-radius:16px;box-shadow:0 10px 40px #0003,0 4px 20px #0000001a;gap:12px;margin-bottom:4px;opacity:0;overflow:hidden;padding:16px 48px 16px 16px;pointer-events:auto;position:relative;transform:translateY(-100%);transition:all .4s cubic-bezier(.4,0,.2,1);width:100%}.toast.visible{opacity:1;transform:translateY(0)}.toast.success{border-left-color:#48bb78}.toast.warning{border-left-color:#ed8936}.toast.error{border-left-color:#f56565}.toast.info{border-left-color:#4299e1}.toast-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:18px;height:36px;justify-content:center;width:36px}.toast.success .toast-icon{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff}.toast.warning .toast-icon{background:linear-gradient(135deg,#ed8936,#dd6b20);color:#fff}.toast.error .toast-icon{background:linear-gradient(135deg,#f56565,#e53e3e);color:#fff}.toast.info .toast-icon{background:linear-gradient(135deg,#4299e1,#3182ce);color:#fff}.toast-content{flex:1 1;min-width:0}.toast-title{color:#1a202c;font-size:14px;font-weight:600;line-height:1.3;margin-bottom:2px}.toast-message{color:#4a5568;font-size:13px;line-height:1.4}.toast-close{-webkit-tap-highlight-color:transparent;align-items:center;background:none;border:none;border-radius:8px;color:#a0aec0;cursor:pointer;display:flex;flex-shrink:0;height:28px;justify-content:center;padding:4px;position:absolute;right:12px;top:12px;touch-action:manipulation;transition:all .2s ease;width:28px}.toast-close:focus,.toast-close:hover{background:#f7fafc;color:#718096;outline:none}.toast-close:active{background:#edf2f7;transform:scale(.95)}.toast-progress{background:linear-gradient(90deg,#4299e1,#3182ce);border-radius:0 0 16px 16px;bottom:0;height:3px;left:0;position:absolute;transition:width linear}.error-message{align-items:flex-start;background:#fff;border-left:4px solid #f56565;border-radius:16px;box-shadow:0 10px 40px #f4433640,0 4px 20px #f4433626;display:flex;font-weight:500;gap:12px;left:16px;opacity:0;padding:16px;position:fixed;right:16px;top:20px;transform:translateY(-100%);transition:all .4s cubic-bezier(.4,0,.2,1);visibility:hidden;z-index:9999}.error-message.visible{opacity:1;transform:translateY(0);visibility:visible}.error-message .error-icon{align-items:center;background:linear-gradient(135deg,#f56565,#e53e3e);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:18px;height:36px;justify-content:center;width:36px}.error-message .error-text{color:#1a202c;flex:1 1;font-size:14px;font-weight:600;line-height:1.4}.error-message .close-button{-webkit-tap-highlight-color:transparent;background:none;border:none;border-radius:8px;color:#a0aec0;cursor:pointer;flex-shrink:0;margin:-4px -4px -4px 0;padding:8px;touch-action:manipulation;transition:all .2s ease}.error-message .close-button:focus,.error-message .close-button:hover{background:#f7fafc;color:#718096;outline:none}.error-message .close-button:active{background:#edf2f7;transform:scale(.95)}@media (max-width:375px){.notification-modal{border-radius:20px;max-height:90vh;padding:28px 20px 20px}.notification-title{font-size:18px;margin-bottom:10px}.notification-message{font-size:14px;margin-bottom:24px}.notification-icon{font-size:28px;height:64px;width:64px}.notification-btn{font-size:14px;min-height:48px;padding:14px 20px}.toast{gap:10px;padding:14px}.toast-icon{font-size:16px;height:32px;width:32px}.toast-title{font-size:13px}.toast-message{font-size:12px}}@media (max-height:500px) and (orientation:landscape){.notification-overlay{align-items:center;justify-content:center;padding:20px 12px 12px}.notification-modal{max-height:80vh;padding:24px 20px 20px}.notification-icon-container{margin-bottom:16px}.notification-icon{font-size:24px;height:56px;width:56px}.notification-title{font-size:16px;margin-bottom:8px}.notification-message{font-size:13px;margin-bottom:20px}.notification-btn{font-size:14px;min-height:44px;padding:12px 20px}}@media (min-width:768px){.notification-modal{max-width:500px;padding:36px 28px 28px}.notification-actions{flex-direction:row;gap:16px}.notification-btn{min-width:140px;width:auto}.toast-container{left:50%;max-width:500px;top:24px;transform:translateX(-50%)}}@supports (padding:max(0px)){.notification-overlay{padding:max(16px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(16px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left))}.error-message,.toast-container{left:50%;top:max(20px,calc(env(safe-area-inset-top) + 20px));transform:translateX(-50%);width:calc(100% - max(32px, env(safe-area-inset-left) + env(safe-area-inset-right) + 32px))}}@supports (-webkit-touch-callout:none){.notification-modal{-webkit-overflow-scrolling:touch}.toast{transform:translateZ(0)}.error-message .close-button,.notification-btn,.notification-close,.toast-close{-webkit-tap-highlight-color:transparent}}@media (min-width:769px){.notification-actions{flex-direction:row!important;gap:16px!important;justify-content:center}.notification-btn{font-size:15px!important;min-width:140px!important;padding:14px 24px!important;width:auto!important}.notification-modal{max-width:500px!important;padding:36px 32px 28px!important}.notification-title{font-size:22px!important;margin-bottom:16px!important}.notification-message{font-size:16px!important;line-height:1.6!important;margin-bottom:32px!important}.notification-icon{font-size:36px!important;height:80px!important;width:80px!important}.chat-container{max-height:70vh!important;overflow-y:auto!important}.chat{padding-bottom:250px!important}.container{height:auto!important;overflow-y:visible!important}}.mobile-progress-bar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:20px;bottom:20px;box-shadow:0 8px 32px #00000026;display:none;left:50%;max-width:350px;padding:16px 20px;position:fixed;transform:translateX(-50%);transition:all .3s ease;width:90%;z-index:1500}.mobile-progress-bar.visible{animation:slideUpMobile .4s ease-out;display:block}@keyframes slideUpMobile{0%{opacity:0;transform:translateX(-50%) translateY(20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.mobile-progress-info{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.mobile-progress-title{color:#2c3e50;font-family:Poppins,sans-serif;font-size:14px;font-weight:600}.mobile-progress-percentage{color:#64748b;font-size:12px;font-weight:500}.mobile-progress-track{background:#e5e7eb;border-radius:3px;height:6px;overflow:hidden;position:relative;width:100%}.mobile-progress-fill{background:linear-gradient(90deg,#4e54c8,#8f94fb 50%,#66d9e8);border-radius:3px;height:100%;position:relative;transition:width .8s cubic-bezier(.4,0,.2,1)}.mobile-progress-fill:after{animation:progressShine 2s linear infinite;background:linear-gradient(90deg,#0000,#fff6,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;width:100%}@keyframes progressShine{0%{left:-100%}to{left:100%}}.mobile-current-step{color:#64748b;font-size:11px;font-style:italic;margin-top:8px;text-align:center}@media (min-width:769px){.mobile-progress-bar{display:none!important}.vertical-progress-container{display:block}}@media (max-width:768px) and (min-width:481px){.vertical-progress-container{display:none}.mobile-progress-bar.visible{display:block}}@media (max-width:480px){.vertical-progress-container{display:none!important}.mobile-progress-bar.visible{bottom:15px;display:block;max-width:320px;padding:14px 18px;width:95%}.mobile-progress-title{font-size:13px}.mobile-progress-percentage{font-size:11px}.mobile-progress-track{height:5px}.mobile-current-step{font-size:10px;margin-top:6px}}@media (max-width:375px){.mobile-progress-bar.visible{bottom:12px;max-width:280px;padding:12px 16px;width:96%}.mobile-progress-title{font-size:12px}.mobile-progress-track{height:4px}}.intro-content-container{animation:fadeInUp .6s ease-out;left:50%;max-width:600px;padding:0 1rem;position:absolute;top:360px;transform:translateX(-50%);width:calc(100% - 2rem);z-index:50}@keyframes fadeInUp{0%{opacity:0;transform:translateX(-50%) translateY(30px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.intro-description-section{margin-bottom:2rem;text-align:center}.intro-tagline h2{color:#27364a;color:var(--text-primary);font-family:Poppins,sans-serif;font-size:1.8rem;font-weight:700;line-height:1.2;margin-bottom:.5rem}.intro-subtitle{color:#4c8bf5;color:var(--accent);font-size:1rem;font-style:italic;font-weight:600;margin-bottom:1.5rem}.intro-description{margin:0 auto;max-width:500px}.intro-description p{color:#64748b;font-size:.95rem;line-height:1.6;margin:0}.intro-help-actions{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}.help-buttons-row{grid-gap:1rem;display:grid;gap:1rem}.help-buttons-row:first-child{grid-template-columns:1fr 1fr}.help-buttons-row.centered{grid-template-columns:1fr}.intro-help-btn{align-items:center;background:#fff;border:none;border-radius:16px;box-shadow:0 4px 12px #00000014;cursor:pointer;display:flex;font-family:inherit;gap:1rem;min-height:80px;padding:1.2rem 1.5rem;text-align:left;transition:all .3s ease}.intro-help-btn:hover{box-shadow:0 8px 20px #0000001f;transform:translateY(-3px)}.intro-help-btn .btn-icon{flex-shrink:0;font-size:2rem;text-align:center;width:48px}.intro-help-btn .btn-text{flex:1 1}.intro-help-btn .btn-title{color:#27364a;color:var(--text-primary);font-size:.95rem;font-weight:600;line-height:1.2;margin-bottom:.3rem}.intro-help-btn .btn-subtitle{color:#64748b;font-size:.8rem;line-height:1.3;opacity:.7}.intro-help-btn.upload-btn{background:#4c8bf50d;border:2px solid #0000}.intro-help-btn.upload-btn:hover{background:#4c8bf51a;border-color:#3b82f6;box-shadow:0 8px 24px #4c8bf533;transform:translateY(-3px)}.intro-help-btn.upload-btn .btn-icon{color:#4c8bf5;font-size:2.2rem}.intro-help-btn.upload-btn .btn-title{color:#4c8bf5}@media (max-width:768px){.help-buttons-row,.help-buttons-row:first-child{grid-template-columns:1fr}.help-buttons-row.centered{margin:0;max-width:none!important;width:100%}.intro-help-btn{min-height:70px;padding:1rem 1.2rem}.intro-help-btn .btn-icon{font-size:1.8rem;width:40px}.intro-help-btn .btn-title{font-size:1rem}.intro-help-btn .btn-subtitle{font-size:.85rem}}@media (max-width:480px){.help-buttons-row,.intro-help-actions{gap:.8rem}.intro-help-btn{gap:.8rem;min-height:65px;padding:.9rem 1rem}.intro-help-btn .btn-icon{font-size:1.6rem;width:36px}.intro-help-btn .btn-title{font-size:.95rem}.intro-help-btn .btn-subtitle{font-size:.8rem}.intro-help-btn.upload-btn .btn-icon{font-size:1.8rem}}@media (min-width:769px){.help-buttons-row.centered{margin:0 auto;max-width:400px}}@media (min-width:1200px){.intro-help-actions{margin:1.5rem auto 0;max-width:900px}.help-buttons-row.centered{max-width:450px}}.intro-help-actions{gap:1.5rem}.help-buttons-row:hover .intro-help-btn:not(:hover){opacity:.7;transition:opacity .3s ease}.help-buttons-row .intro-help-btn:hover{opacity:1}@media (max-width:768px){.intro-content-container{padding:0 .5rem;top:380px;width:calc(100% - 1rem)}.intro-tagline h2{font-size:1.5rem}.intro-description p,.intro-subtitle{font-size:.9rem}.intro-help-actions{gap:.8rem;grid-template-columns:1fr}.intro-help-btn{padding:.9rem 1rem}.intro-help-btn .btn-title{font-size:.9rem}.intro-help-btn .btn-subtitle{font-size:.75rem}}@media (max-width:480px){.intro-content-container{top:400px}.intro-tagline h2{font-size:1.3rem;line-height:1.3}.intro-help-btn{gap:.7rem;padding:.8rem .9rem}.intro-help-btn .btn-icon{font-size:1.3rem}.intro-help-btn .btn-title{font-size:.85rem}.intro-help-btn .btn-subtitle{font-size:.7rem}}@media (max-width:375px){.intro-content-container{top:420px}.intro-tagline h2{font-size:1.2rem}.intro-description p{font-size:.85rem}}.bubble-content{font-weight:inherit;line-height:1.6}.chat-paragraph{font-weight:inherit;margin-bottom:12px}.chat-paragraph:last-child{margin-bottom:0}.chat-section-header{border-bottom:1px solid #0000001a;color:inherit;font-size:1.05em;font-weight:700;margin:16px 0 8px;padding-bottom:4px}.bubble.bot .chat-section-header{border-bottom-color:#2c3e5033;color:#2c3e50}.bubble.user .chat-section-header{border-bottom-color:#ffffff4d;color:#fff}.chat-bullet-point{font-weight:inherit;line-height:1.5;margin:4px 0 4px 8px}.chat-text-line{font-weight:inherit;margin:4px 0}.bubble.bot .bubble-content,.bubble.user .bubble-content{-webkit-hyphens:auto;hyphens:auto;word-break:break-word}.bubble.bot.vacancy-text{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:1px solid #dee2e6;box-shadow:0 4px 12px #0000001a;color:#2c3e50;max-width:95%;padding:16px 20px}.bubble.bot.vacancy-text .chat-section-header{border-bottom:2px solid #4c8bf5;color:#495057;font-size:1.1em;font-weight:700;margin-bottom:12px;margin-top:20px}.bubble.bot.vacancy-text .chat-section-header:first-child{margin-top:0}.bubble.bot.vacancy-text .chat-bullet-point{background:#4c8bf51a;border-left:3px solid #4c8bf5;border-radius:6px;margin:6px 0;padding:6px 12px}@media (max-width:480px){.chat-section-header{font-size:1em;margin:12px 0 6px}.bubble.bot.vacancy-text{max-width:98%;padding:12px 16px}.bubble.bot.vacancy-text .chat-section-header{font-size:1em;margin-bottom:10px;margin-top:16px}}.text-chat-overlay{background:#00000080;z-index:2000}.text-chat-panel{border-radius:16px;box-shadow:0 10px 40px #0003;max-height:80vh;max-width:500px;width:90%}.text-chat-header{border-bottom:1px solid #e2e8f0;justify-content:between;padding:16px 20px}.text-chat-header h3{flex:1 1;margin:0}.text-chat-header button{background:none;border:none;cursor:pointer;font-size:18px;padding:4px}.text-chat-messages{max-height:400px;padding:20px}.message{margin-bottom:16px}.message.user{text-align:right}.message.user p{background:#4c8bf5;color:#fff}.message.assistant p,.message.user p{border-radius:12px;display:inline-block;max-width:80%;padding:8px 12px}.message.assistant p{background:#f1f3f5}.message.loading p{font-style:italic;opacity:.7}.text-chat-input{display:flex;gap:12px;padding:16px 20px}.text-chat-input textarea{border:1px solid #e2e8f0;border-radius:8px;flex:1 1;font-family:inherit;min-height:40px;padding:8px 12px;resize:none}.text-chat-input button{background:#4c8bf5;border:none;border-radius:8px;color:#fff;cursor:pointer;padding:8px 16px}.text-chat-input button:disabled{cursor:not-allowed;opacity:.5}.mobile-progress-bar{bottom:20px!important;display:block!important;left:50%!important;pointer-events:auto!important;position:fixed!important;transform:translateX(-50%)!important;visibility:visible!important;z-index:1500!important}.desktop-only,.horizontal-progress-container,.mobile-only,.vertical-progress-container{display:none!important;opacity:0!important;visibility:hidden!important}* .mobile-progress-bar{display:block!important}.mobile-progress-bar.visible{opacity:1!important;visibility:visible!important}.text-chat-overlay{align-items:center;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:3000}.text-chat-panel{animation:slideInScale .4s cubic-bezier(.34,1.56,.64,1);background:#fff;border-radius:24px;box-shadow:0 25px 80px #0000004d;display:flex;flex-direction:column;height:90vh;max-height:90vh;max-width:1100px;overflow:hidden;position:relative;width:100%}.text-chat-header{align-items:center;background:linear-gradient(135deg,#4e54c8,#8f94fb 50%,#66d9e8);box-shadow:0 4px 20px #4e54c84d;color:#fff;display:flex;flex:0 0 auto;justify-content:space-between;min-height:60px;padding:14px 20px}.chat-header-content{display:flex;flex:1 1;flex-direction:column;gap:4px}.chat-header-content h3{align-items:center;display:flex;font-family:Poppins,sans-serif;font-size:1.5rem;font-weight:700;gap:12px;margin:0}.file-indicator{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:1px solid #ffffff1a;border-radius:12px;display:inline-flex;font-size:.85rem;font-weight:500;gap:6px;padding:6px 12px}.file-indicator:before{display:none;font-size:.8rem}.chat-close-btn{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.3rem;height:48px;justify-content:center;transition:all .2s ease;width:48px}.chat-close-btn:hover{background:#ffffff4d;transform:scale(1.05)}.text-chat-messages{background:#f8f9fa;display:flex;flex:1 1;flex-direction:column;gap:12px;max-height:100%;min-height:0;overflow-x:hidden;overflow-y:auto;padding:16px;scrollbar-color:#0000001a #0000;scrollbar-width:thin}.text-chat-messages::-webkit-scrollbar{width:6px}.text-chat-messages::-webkit-scrollbar-track{background:#0000;border-radius:4px}.text-chat-messages::-webkit-scrollbar-thumb{background:#0000001a;border-radius:3px;-webkit-transition:background .3s ease;transition:background .3s ease}.text-chat-messages::-webkit-scrollbar-thumb:hover{background:#0003}.chat-message{max-width:85%}.message-avatar{align-items:center;border-radius:50%;box-shadow:0 4px 12px #00000026;color:#fff;display:flex;flex-shrink:0;font-size:.9rem;font-weight:600;height:44px;justify-content:center;width:44px}.chat-message.user .message-avatar:after{content:"JIJ";font-size:.7rem;font-weight:700}.chat-message.assistant .message-avatar{background:linear-gradient(135deg,#4e54c8,#8f94fb)}.chat-message.assistant .message-avatar:after{content:"JG";font-size:.7rem;font-weight:700}.message-header{font-size:.85rem;font-weight:600;margin-bottom:6px;opacity:.8}.chat-message.user .message-header{color:#48bb78}.chat-message.assistant .message-header{color:#4e54c8}.message-content{border-radius:12px;flex:1 1;line-height:1.5;max-width:80%;padding:12px 16px}.chat-message.assistant .message-content{background:#f7fafc;border-left:3px solid #4299e1}.chat-message.user .message-content{border-left:none;border-right:3px solid hsla(0,0%,100%,.822)}.chat-message.assistant .message-avatar,.chat-message.user .message-avatar{box-shadow:0 2px 8px #4299e14d;color:#fff}.chat-message.assistant .message-avatar{background:linear-gradient(135deg,#4299e1,#3182ce)}.chat-message.user .message-header{color:#ffffffe6;font-weight:600;text-align:right}.chat-message.assistant .message-header{color:#4299e1;font-weight:600}.chat-message.user .message-content:after{border:none;border-left:10px solid #3c4099;border-top:10px solid #0000;bottom:0;content:"";height:0;position:absolute;right:-10px;width:0}.chat-message.assistant .message-content:after{border:none;border-right:10px solid #f7fafc;border-top:10px solid #0000;bottom:0;content:"";height:0;left:-10px;position:absolute;width:0}.loading .message-content{background:#f1f3f5!important;color:#4a5568!important}.processing-message{background:linear-gradient(135deg,#4299e10d,#3182ce0d);border-left:4px solid #4299e1}@media (max-width:480px){.message-content{font-size:.9rem;max-width:95%;padding:10px 14px}.chat-message.assistant .message-content:after,.chat-message.user .message-content:after{border-width:8px}}.message-content p{margin:0 0 12px}.message-content p:last-child{margin-bottom:0}.loading .message-content{align-items:center;background:#f1f3f5;color:#4a5568;display:flex;font-style:italic;gap:12px}.typing-indicator{display:flex;gap:4px}.typing-indicator span{animation:typingBounce 1.4s ease-in-out infinite;background-color:#4e54c8;border-radius:50%;height:8px;width:8px}.typing-indicator span:first-child{animation-delay:0s}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}.text-chat-input{background:#fff;border-top:1px solid #e2e8f0;box-shadow:0 -4px 20px #0000000d;flex:0 0 auto;max-height:120px;min-height:64px;padding:10px 16px}.input-wrapper{align-items:center;display:flex;gap:12px;margin:0;max-width:none;width:100%}.input-wrapper textarea{background:#fafbfc;border:2px solid #e2e8f0;border-radius:12px;box-sizing:border-box;flex:1 1;font-family:inherit;font-size:.9rem;line-height:1.4;max-height:80px;min-height:42px;padding:8px 12px;resize:none;transition:all .2s ease;width:100%}.input-wrapper textarea:focus{background:#fff;border-color:#4e54c8;box-shadow:0 0 0 4px #4e54c81a;outline:none}.input-wrapper textarea::placeholder{color:#9ca3af;font-style:italic}.send-button{align-items:center;background:linear-gradient(135deg,#4e54c8,#8f94fb);border:none;border-radius:50%;box-shadow:0 6px 20px #4e54c84d;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:1.1rem;height:44px;justify-content:center;transition:all .2s ease;width:44px}.send-button:hover:not(:disabled){box-shadow:0 8px 25px #4e54c866;transform:scale(1.05) translateY(-1px)}.send-button:active:not(:disabled){transform:scale(.95)}.send-button:disabled{box-shadow:0 4px 12px #4e54c833;cursor:not-allowed;opacity:.5;transform:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInScale{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}@keyframes typingBounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-8px)}}@media (min-width:769px){.text-chat-panel{max-width:900px;width:95%}.input-wrapper{max-width:none;padding:0 8px}.input-wrapper textarea{font-size:1rem;padding:18px 24px}.send-button{font-size:1.3rem;height:60px;width:60px}}@media (max-width:768px){.text-chat-overlay{align-items:flex-start;padding:0}.text-chat-panel{border-radius:0 0 20px 20px;height:85vh;margin:0;max-height:85vh;max-width:none;width:100%}.text-chat-header{padding:16px 20px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.chat-header-content h3{font-size:1.2rem;gap:8px}.chat-message{max-width:95%}.message-avatar{font-size:1.1rem}.message-content{min-width:150px}.input-wrapper textarea{min-height:50px}.text-chat-input{padding:12px 16px max(12px,env(safe-area-inset-bottom,12px))}.file-indicator{font-size:.8rem;padding:4px 8px}.text-chat-messages{-webkit-overflow-scrolling:touch;flex:1 1;gap:16px;overscroll-behavior:contain;padding:16px}.chat-message{gap:12px;max-width:90%}.message-avatar{font-size:.8rem;height:36px;width:36px}.message-content{word-wrap:break-word;font-size:.9rem;max-width:calc(100vw - 100px);min-width:120px;overflow-wrap:break-word;padding:12px 16px}.system-message{font-size:.85rem;max-width:85%;padding:10px 16px}.processing-message{gap:12px;padding:14px 16px}.processing-spinner{border-width:2px;height:28px;width:28px}.text-chat-input{background:#fff;border-top:1px solid #e2e8f0;bottom:0;padding:12px 16px;position:-webkit-sticky;position:sticky}.input-wrapper{gap:12px;max-width:none}.input-wrapper textarea{border-radius:16px;font-size:.9rem;max-height:120px;min-height:44px;padding:12px 16px}.send-button{flex-shrink:0;font-size:1.1rem;height:48px;width:48px}}@media (max-width:480px){.text-chat-overlay{align-items:flex-start;padding:0}.text-chat-panel{border-radius:0 0 16px 16px;height:82vh;margin-top:0;max-height:82vh}.text-chat-header{padding:12px 16px}.chat-header-content h3{font-size:1.1rem;gap:6px}.file-indicator{font-size:.75rem;padding:3px 6px}.text-chat-messages{gap:12px;padding:12px}.chat-message{gap:8px;max-width:95%}.message-avatar{font-size:.7rem;height:32px;width:32px}.message-content{font-size:.85rem;max-width:calc(100vw - 80px);min-width:100px;padding:10px 14px}.input-wrapper textarea{font-size:.85rem;min-height:40px;padding:10px 14px}.send-button{font-size:1rem;height:44px;width:44px}.text-chat-input{padding:10px 12px}}@supports (-webkit-touch-callout:none){.text-chat-panel{height:-webkit-fill-available}.text-chat-messages{-webkit-overflow-scrolling:touch}.input-wrapper textarea,.text-chat-messages{transform:translateZ(0)}}.system-message{background:#48bb781a;border:1px solid #48bb7833;border-radius:20px;color:#2d5a3d;font-size:.9rem;font-weight:500;gap:12px;margin:0 auto;max-width:300px;padding:12px 20px}.system-icon,.system-message{align-items:center;display:flex;justify-content:center}.system-icon{background:#48bb78;border-radius:50%;color:#fff;font-size:.7rem;font-weight:700;height:20px;width:20px}.system-icon:after{content:"✓"}.processing-message{align-items:flex-start;background:linear-gradient(135deg,#4e54c80d,#8f94fb0d);border-left:4px solid #4e54c8;border-radius:16px;display:flex;gap:16px;padding:20px}.processing-spinner{animation:processingSpinAnimation 1s linear infinite;border:3px solid #4e54c833;border-radius:50%;border-top-color:#4e54c8;flex-shrink:0;height:32px;margin-top:4px;width:32px}.processing-text p{line-height:1.5;margin:0 0 8px}.processing-text p:last-child{font-size:.9rem;margin-bottom:0;opacity:.8}@keyframes processingSpinAnimation{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.message-bubble{flex:1 1;max-width:85%}.message-content{background:#fff;border-radius:18px;box-shadow:0 4px 12px #00000014;font-size:.95rem;line-height:1.6;padding:16px 20px;position:relative}.chat-message.user .message-content{background:linear-gradient(135deg,#4e54c8,#3c4099);color:#fff}.chat-message.assistant .message-content{background:#fff;border-left:4px solid #4e54c8;color:#2d3748}.message-actions{border-top:1px solid #0000001a;display:flex;justify-content:flex-end;margin-top:16px;padding-top:16px}.copy-btn{align-items:center;background:#4e54c81a;border:1px solid #4e54c833;border-radius:12px;color:#4e54c8;cursor:pointer;display:flex;font-size:.85rem;font-weight:500;gap:8px;padding:8px 16px;transition:all .2s ease}.copy-btn:hover{background:#4e54c826;border-color:#4e54c84d;transform:translateY(-1px)}.copy-btn:active{transform:translateY(0)}.copy-btn .material-icons{font-size:1rem}.copy-toast{background:linear-gradient(135deg,#4e54c8,#3c4099);border-radius:12px;box-shadow:0 6px 20px #48bb784d;color:#fff;font-size:.9rem;font-weight:500;opacity:0;padding:12px 20px;position:fixed;right:20px;top:20px;transform:translateX(100%);transition:all .3s ease;z-index:10000}.copy-toast.show{opacity:1;transform:translateX(0)}.loading{align-items:center;background:#f1f3f5!important;color:#4a5568!important;display:flex;gap:12px}.loading .typing-indicator{display:flex;gap:4px}.loading .typing-indicator span{animation:typingBounce 1.4s ease-in-out infinite;background-color:#4e54c8;border-radius:50%;height:8px;width:8px}.chat-message{align-items:flex-start;animation:messageSlideIn .3s ease-out;display:flex;gap:16px;margin-bottom:20px}.chat-message.user{align-self:flex-end;flex-direction:row-reverse}.chat-message.assistant{align-self:flex-start}.chat-message.system{align-self:center;margin:10px 0}@media (max-width:768px){.processing-message{gap:12px;padding:16px}.processing-spinner{border-width:2px;height:28px;width:28px}.message-actions{margin-top:12px;padding-top:12px}.copy-btn{font-size:.8rem;padding:6px 12px}.copy-toast{right:12px;top:12px}.copy-toast,.system-message{font-size:.85rem;padding:10px 16px}.system-message{max-width:280px}}@media (max-width:480px){.processing-message{flex-direction:column;gap:16px;text-align:center}.processing-spinner{align-self:center}.message-bubble{max-width:95%}.copy-btn{justify-content:center;width:100%}}.jesse-avatar,.message-avatar{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-family:Poppins,sans-serif;font-size:11px;font-weight:700;height:40px;justify-content:center;letter-spacing:-.5px;text-shadow:0 1px 2px #0000001a;width:40px}.chat-message.assistant .message-avatar,.jesse-avatar{background:linear-gradient(135deg,#4e54c8,#8f94fb);box-shadow:0 2px 8px #4e54c84d}.chat-message.user .message-avatar{background:linear-gradient(135deg,#4e54c8,#3c4099);box-shadow:0 2px 8px #48bb784d}.jesse-avatar:hover,.message-avatar:hover{transform:scale(1.05);transition:transform .2s ease}@media (max-width:480px){.jesse-avatar,.message-avatar{font-size:9px;height:32px;width:32px}}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
/*# sourceMappingURL=main.51871a7d.css.map*/