*{margin:0;padding:0;box-sizing:border-box}:root{--color-primary: #FF6B00;--color-primary-hover: #FF8533;--color-primary-light: rgba(255, 107, 0, .1);--color-background: #000000;--color-surface: #0a0a0a;--color-text-primary: #ffffff;--color-text-secondary: #999999;--color-border: #222222;--color-error: #ff4444;--color-error-light: rgba(255, 68, 68, .1);--color-success: #00ff88;--color-success-light: rgba(0, 255, 136, .1);font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.6;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--color-background);color:var(--color-text-primary);overflow-x:hidden}#root{width:100%;min-height:100vh;position:relative}.app{min-height:100vh;padding:14rem 2rem 2rem;display:flex;align-items:flex-start;justify-content:center;background:radial-gradient(circle at 20% 50%,rgba(255,107,0,.15) 0%,transparent 50%),radial-gradient(circle at 80% 50%,rgba(255,107,0,.15) 0%,transparent 50%),#000;position:relative;overflow:hidden}.app:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,107,0,.03) 50%,transparent 100%);animation:scan 8s linear infinite}@keyframes scan{0%{transform:translate(-100%)}to{transform:translate(100%)}}.container{background:#0a0a0a;border-radius:16px;padding:3rem;max-width:800px;width:100%;box-shadow:0 8px 32px #ff6b004d,0 0 0 1px #ff6b0033,inset 0 0 60px #ff6b000d;position:relative;z-index:2;border:1px solid rgba(255,107,0,.3);animation:float 6s ease-in-out infinite}.mascot-container{position:fixed;top:15rem;left:50%;transform:translate(-50%,-100%);z-index:1;pointer-events:none;display:flex;justify-content:center;align-items:flex-end;animation:mascotAppear .8s ease-out,mascotIdle 6s ease-in-out .8s infinite}@keyframes mascotAppear{0%{opacity:0;transform:translate(-50%,-80%) scale(.7)}60%{opacity:1;transform:translate(-50%,-105%) scale(1.05)}to{opacity:1;transform:translate(-50%,-100%) scale(1)}}.mascot{width:500px;height:auto;filter:drop-shadow(0 10px 30px rgba(255,107,0,.4))}.mascot-hand{position:fixed;width:130px;height:auto;filter:drop-shadow(0 5px 15px rgba(255,107,0,.4));pointer-events:none}.mascot-hand-left{left:calc(50% - 480px);top:calc(14rem + 280px);transform:translateY(-50%)}.mascot-hand-right{right:calc(50% - 480px);top:calc(14rem + 280px);transform:translateY(-50%)}.mascot-hand-back{z-index:1;animation:handFloat 6s ease-in-out infinite}.mascot-hand-front{z-index:3;animation:handFloat 6s ease-in-out infinite}@keyframes handFloat{0%,to{transform:translateY(-50%)}50%{transform:translateY(calc(-50% - 10px))}}@keyframes mascotIdle{0%,to{transform:translate(-50%,-100%) scale(1)}50%{transform:translate(-50%,calc(-100% - 10px)) scale(1)}}.mascot-mouth{transition:ry .05s ease-out}.mascot-eye{transform-origin:center;animation:eyeAnimation 6s ease-in-out infinite}.mascot-eye-right{animation-delay:.05s}@keyframes eyeAnimation{0%,10%{transform:translate(0) scaleY(1) scaleX(1)}12%{transform:translate(0) scaleY(.1) scaleX(1.3)}14%,30%{transform:translate(0) scaleY(1) scaleX(1)}35%,45%{transform:translate(6px) scaleY(1) scaleX(1)}50%,60%{transform:translate(0) scaleY(1) scaleX(1)}65%,75%{transform:translate(-6px) scaleY(1) scaleX(1)}80%{transform:translate(0) scaleY(1) scaleX(1)}82%{transform:translate(0) scaleY(.1) scaleX(1.3)}84%,to{transform:translate(0) scaleY(1) scaleX(1)}}@media(max-width:1100px){.mascot-container{top:4rem;transform:translate(-50%)}.mascot{width:280px}.mascot-hand{width:80px}.mascot-hand-left{left:calc(50% - 200px);top:calc(4rem + 320px)}.mascot-hand-right{right:calc(50% - 200px);top:calc(4rem + 320px)}.app{padding-top:12rem}@keyframes mascotAppear{0%{opacity:0;transform:translate(-50%,-20%) scale(.7)}60%{opacity:1;transform:translate(-50%,5%) scale(1.05)}to{opacity:1;transform:translate(-50%) scale(1)}}@keyframes mascotIdle{0%,to{transform:translate(-50%) scale(1)}50%{transform:translate(-50%,-10px) scale(1)}}}@media(max-width:768px){.mascot-container{top:6.5rem;position:absolute}.mascot-hand{position:absolute}.mascot{width:300px}.mascot-hand{width:60px}.mascot-hand-left{left:calc(50% - 270px);top:calc(14rem + 150px)}.mascot-hand-right{right:calc(50% - 270px);top:calc(14rem + 150px)}.app{padding-top:14rem}.container{padding:1.5rem 1rem;max-width:calc(100% - 80px)}}@media(max-width:480px){.mascot-container{top:6.5rem}.mascot{width:240px}.mascot-hand{width:50px}.mascot-hand-left{left:calc(50% - 200px);top:calc(12rem + 120px)}.mascot-hand-right{right:calc(50% - 200px);top:calc(12rem + 120px)}.app{padding-top:12rem}.container{padding:1.25rem .875rem;max-width:calc(100% - 70px)}.dropzone{padding:1.5rem .75rem;min-height:auto}.upload-icon{width:40px;height:40px;margin-bottom:.75rem}.dropzone-text{font-size:.875rem}.dropzone-hint{font-size:.75rem}}@media(max-width:380px){.mascot-container{top:6rem}.mascot{width:200px}.mascot-hand{width:42px}.mascot-hand-left{left:calc(50% - 165px);top:calc(11rem + 100px)}.mascot-hand-right{right:calc(50% - 165px);top:calc(11rem + 100px)}.app{padding-top:11rem}.container{padding:1rem .75rem;max-width:calc(100% - 55px)}}@media(max-width:350px){.mascot-container{top:6.5rem}.mascot{width:140px}.mascot-hand{width:35px}.mascot-hand-left{left:calc(50% - 140px);top:calc(10rem + 90px)}.mascot-hand-right{right:calc(50% - 140px);top:calc(10rem + 90px)}.app{padding:10rem .375rem .375rem}.container{padding:.875rem .625rem;max-width:calc(100% - 55px);border-radius:10px}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.container:before{content:"";position:absolute;inset:-2px;background:linear-gradient(45deg,transparent 0%,rgba(255,107,0,.3) 25%,transparent 50%,rgba(255,107,0,.3) 75%,transparent 100%);border-radius:16px;z-index:-1;background-size:400% 400%;animation:borderGlow 10s ease infinite}@keyframes borderGlow{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.header{text-align:center;margin-bottom:3rem}.logo-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.logo{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);letter-spacing:.05em;text-shadow:0 0 20px rgba(255,107,0,.5)}.logo-accent{color:var(--color-primary);text-shadow:0 0 30px rgba(255,107,0,.8)}.header-buttons{display:flex;gap:12px;align-items:center}.calendar-fab,.stats-fab{width:48px;height:48px;border-radius:50%;background:#ffffff1a;border:2px solid rgba(255,107,0,.3);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.34,1.56,.64,1);flex-shrink:0}.calendar-fab:hover,.stats-fab:hover{background:linear-gradient(135deg,var(--color-primary) 0%,#ff8533 100%);transform:translateY(-2px) scale(1.05);box-shadow:0 4px 20px #ff6b0080}.calendar-fab:active,.stats-fab:active{transform:translateY(0) scale(.95)}.chat-fab{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary) 0%,#ff8533 100%);border:2px solid rgba(255,107,0,.4);color:#fff;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #ff6b0066;transition:all .3s cubic-bezier(.34,1.56,.64,1);flex-shrink:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none;animation:fabPulse 2s ease-in-out infinite}@keyframes fabPulse{0%,to{box-shadow:0 4px 20px #ff6b0066}50%{box-shadow:0 4px 30px #ff6b0099,0 0 40px #ff6b0033}}.chat-fab:hover{transform:translateY(-4px) scale(1.1);box-shadow:0 8px 30px #ff6b00b3;animation:none}.chat-fab:active{transform:translateY(0) scale(.95)}h1{font-size:2rem;color:var(--color-text-primary);margin-bottom:.75rem;font-weight:600;letter-spacing:-.02em}.subtitle{color:var(--color-text-secondary);font-size:1rem;line-height:1.5}.subtitle strong{color:var(--color-primary);font-weight:700}.typewriter-container{height:80px;min-height:80px}.typewriter-title{font-size:2rem;color:var(--color-text-primary);margin-bottom:.75rem;font-weight:600;letter-spacing:-.02em;height:2.5rem;min-height:2.5rem}.typewriter-subtitle{height:1.5rem;min-height:1.5rem}.typewriter-cursor{color:var(--color-primary);font-weight:400;animation:cursorBlink .6s step-end infinite;margin-left:2px}@keyframes cursorBlink{0%,to{opacity:1}50%{opacity:0}}.dropzone{border:2px dashed var(--color-border);border-radius:12px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .3s ease;background:#ff6b000d;position:relative;overflow:hidden;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.dropzone:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,107,0,.1),transparent);transition:left .5s}.dropzone:hover:before{left:100%}.dropzone:hover{border-color:var(--color-primary);background:#ff6b001a;box-shadow:0 0 20px #ff6b0033}.dropzone.dragging{border-color:var(--color-primary);background:#ff6b0026;border-width:3px;box-shadow:0 0 40px #ff6b0066;transform:scale(1.02);animation:dropzonePulse 1s ease-in-out infinite}@keyframes dropzonePulse{0%,to{box-shadow:0 0 40px #ff6b0066}50%{box-shadow:0 0 60px #ff6b0099}}.dropzone-content{pointer-events:none}.upload-icon{width:64px;height:64px;margin:0 auto 1.5rem;color:var(--color-primary)}.dropzone-text{font-size:1.125rem;color:var(--color-text-primary);font-weight:500;margin-bottom:.5rem}.dropzone-hint{color:var(--color-text-secondary);font-size:.875rem}.dropzone-hint strong{color:var(--color-primary);font-weight:600}.files-list{margin-top:2rem;background:#0006;border-radius:12px;padding:1.5rem;border:1px solid rgba(255,107,0,.1)}.files-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.files-header h3{font-size:1rem;color:var(--color-text-primary);font-weight:600}.clear-btn{background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary);padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:.875rem;transition:all .2s ease;font-family:inherit;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none}.clear-btn:hover{background:var(--color-surface);color:var(--color-text-primary);border-color:var(--color-text-secondary)}.file-item{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:var(--color-surface);border-radius:8px;margin-bottom:.75rem;border:1px solid var(--color-border);transition:all .2s ease;position:relative;overflow:hidden}.file-item-new{animation:fileItemAppear 1.2s cubic-bezier(.34,1.56,.64,1)}@keyframes fileItemAppear{0%{opacity:0;transform:scale(.8)}20%{opacity:1;transform:scale(1.02)}40%{transform:scale(1)}to{transform:scale(1)}}.file-item-check-overlay{position:absolute;inset:0;background:linear-gradient(135deg,var(--color-primary) 0%,#ff8533 100%);display:flex;align-items:center;justify-content:center;z-index:10;animation:checkOverlayFade 1.2s ease forwards}@keyframes checkOverlayFade{0%{opacity:1}60%{opacity:1}to{opacity:0;pointer-events:none}}.file-item-check{width:50px;height:50px;color:#fff;stroke-dasharray:50;stroke-dashoffset:50;animation:fileCheckDraw .5s ease .15s forwards;filter:drop-shadow(0 0 10px rgba(255,255,255,.5))}@keyframes fileCheckDraw{0%{stroke-dashoffset:50;transform:scale(.5)}50%{transform:scale(1.2)}to{stroke-dashoffset:0;transform:scale(1)}}.file-item:hover{box-shadow:0 4px 15px #ff6b0026;border-color:#ff6b004d}.file-item:last-child{margin-bottom:0}.file-info{flex:1;text-align:left;display:flex;flex-direction:column;gap:.25rem}.file-name{font-weight:500;color:var(--color-text-primary);word-break:break-word;font-size:.9375rem}.file-size{font-size:.8125rem;color:var(--color-text-secondary)}.file-actions{display:flex;align-items:center;gap:1rem}.status{font-size:.8125rem;padding:.375rem .875rem;border-radius:20px;font-weight:500}.status.erfolgreich{background:var(--color-success-light);color:var(--color-success)}.status.fehler{background:var(--color-error-light);color:var(--color-error)}.remove-btn{background:transparent;border:none;color:var(--color-border);font-size:1.25rem;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none}.remove-btn:hover{background:var(--color-error-light);color:var(--color-error)}.upload-btn{width:100%;margin-top:1.5rem;padding:1rem 2rem;background:linear-gradient(135deg,var(--color-primary) 0%,#ff8533 100%);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);font-family:inherit;position:relative;overflow:hidden;box-shadow:0 4px 20px #ff6b0066;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none;animation:uploadBtnAppear .5s cubic-bezier(.34,1.56,.64,1)}@keyframes uploadBtnAppear{0%{opacity:0;transform:translateY(20px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.upload-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.upload-btn:hover:before{left:100%}.upload-btn:hover{transform:translateY(-2px);box-shadow:0 6px 25px #ff6b0099}.upload-btn:active{transform:translateY(0)}.upload-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.status-message{margin-top:1.5rem;padding:1rem 1.5rem;border-radius:10px;text-align:center;font-weight:500;font-size:.9375rem}.status-message.success{background:var(--color-success-light);color:var(--color-success);border:1px solid var(--color-success)}.status-message.error{background:var(--color-error-light);color:var(--color-error);border:1px solid var(--color-error)}.loading-view{text-align:center;padding:3rem 2rem;animation:loadingFadeIn .5s ease;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:350px;position:relative;overflow:hidden}@keyframes loadingFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.loading-background-effects{position:absolute;inset:0;pointer-events:none;overflow:hidden}.loading-glow{position:absolute;top:50%;left:50%;width:300px;height:300px;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(255,107,0,.15) 0%,transparent 70%);animation:glowPulse 3s ease-in-out infinite}@keyframes glowPulse{0%,to{opacity:.5;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.2)}}.loading-particle{position:absolute;width:6px;height:6px;background:var(--color-primary);border-radius:50%;opacity:0;animation:particleFloat 4s ease-in-out infinite}.particle-1{top:20%;left:20%;animation-delay:0s}.particle-2{top:30%;right:25%;animation-delay:1s}.particle-3{bottom:30%;left:30%;animation-delay:2s}.particle-4{bottom:20%;right:20%;animation-delay:3s}@keyframes particleFloat{0%,to{opacity:0;transform:translateY(20px) scale(0)}20%{opacity:1;transform:translateY(0) scale(1)}80%{opacity:1;transform:translateY(-20px) scale(1)}to{opacity:0;transform:translateY(-40px) scale(0)}}.loading-orb-container{position:relative;width:160px;height:160px;margin-bottom:2rem}.loading-orb{position:absolute;top:50%;left:50%;width:80px;height:80px;transform:translate(-50%,-50%)}.loading-orb-ring{position:absolute;top:50%;left:50%;border-radius:50%;border:2px solid transparent;transform:translate(-50%,-50%)}.loading-orb-ring.ring-1{width:100%;height:100%;border-top-color:var(--color-primary);border-right-color:var(--color-primary);animation:orbSpin 1.5s linear infinite}.loading-orb-ring.ring-2{width:120%;height:120%;border-bottom-color:#ff6b0080;border-left-color:#ff6b0080;animation:orbSpin 2s linear infinite reverse}.loading-orb-ring.ring-3{width:140%;height:140%;border-top-color:#ff6b004d;animation:orbSpin 2.5s linear infinite}@keyframes orbSpin{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}.loading-orb-core{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:50px;height:50px;background:linear-gradient(135deg,var(--color-primary) 0%,#ff8533 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 0 30px #ff6b0080,inset 0 0 20px #ffffff1a;animation:corePulse 2s ease-in-out infinite}@keyframes corePulse{0%,to{box-shadow:0 0 30px #ff6b0080,inset 0 0 20px #ffffff1a}50%{box-shadow:0 0 50px #ff6b00cc,inset 0 0 20px #fff3}}.loading-progress-ring{position:absolute;top:0;left:0;width:100%;height:100%}.loading-progress-ring svg{width:100%;height:100%;transform:rotate(-90deg)}.loading-progress-ring .progress-bg{fill:none;stroke:#ff6b001a;stroke-width:3}.loading-progress-ring .progress-bar{fill:none;stroke:var(--color-primary);stroke-width:3;stroke-linecap:round;stroke-dasharray:283;stroke-dashoffset:283;animation:progressFill 3s ease-in-out infinite}@keyframes progressFill{0%{stroke-dashoffset:283}50%{stroke-dashoffset:100}to{stroke-dashoffset:283}}.loading-status{display:flex;align-items:center;gap:.25rem;margin-bottom:.5rem}.loading-title{font-size:1.5rem;font-weight:600;color:var(--color-text-primary);margin:0}.loading-title.success{color:var(--color-success);text-shadow:0 0 30px rgba(0,255,136,.5);animation:successGlow 1s ease-in-out infinite alternate}@keyframes successGlow{0%{text-shadow:0 0 20px rgba(0,255,136,.3)}to{text-shadow:0 0 40px rgba(0,255,136,.6)}}.loading-dots{display:flex;gap:4px;padding-top:8px}.loading-dots span{width:6px;height:6px;background:var(--color-primary);border-radius:50%;animation:dotBounce 1.4s ease-in-out infinite}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes dotBounce{0%,80%,to{transform:translateY(0);opacity:.5}40%{transform:translateY(-8px);opacity:1}}.loading-file-info{font-size:.875rem;color:var(--color-text-secondary);margin:0;opacity:.7}.loading-success-burst{position:relative;width:140px;height:140px;margin-bottom:1.5rem}.burst-ring{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;border:2px solid var(--color-success);opacity:0}.burst-ring.ring-1{width:100%;height:100%;animation:burstExpand 1s ease-out .1s forwards}.burst-ring.ring-2{width:100%;height:100%;animation:burstExpand 1s ease-out .2s forwards}.burst-ring.ring-3{width:100%;height:100%;animation:burstExpand 1s ease-out .3s forwards}@keyframes burstExpand{0%{width:60px;height:60px;opacity:1;border-width:3px}to{width:160px;height:160px;opacity:0;border-width:1px}}.success-orb{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);width:80px;height:80px;background:linear-gradient(135deg,var(--color-success) 0%,#00cc6a 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 0 40px #0f89,inset 0 0 20px #fff3;animation:successOrbPop .5s cubic-bezier(.34,1.56,.64,1) .1s forwards}@keyframes successOrbPop{0%{transform:translate(-50%,-50%) scale(0) rotate(-180deg)}to{transform:translate(-50%,-50%) scale(1) rotate(0)}}.success-check{color:#fff;stroke-dasharray:50;stroke-dashoffset:50;animation:checkDraw .4s ease .4s forwards}@keyframes checkDraw{to{stroke-dashoffset:0}}.success-view{text-align:center;padding:3rem 2rem;animation:fadeIn .5s ease}.success-animation{margin-bottom:2rem}.success-checkmark{width:150px;height:150px;margin:0 auto;position:relative}.success-checkmark svg{width:100%;height:100%}.success-checkmark-circle{stroke:var(--color-primary);stroke-width:3;stroke-dasharray:166;stroke-dashoffset:166;animation:stroke .6s cubic-bezier(.65,0,.45,1) forwards;filter:drop-shadow(0 0 20px rgba(255,107,0,.5))}@keyframes stroke{to{stroke-dashoffset:0}}.success-checkmark-check{stroke:var(--color-primary);stroke-width:3;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:48;stroke-dashoffset:48;animation:stroke-check .3s cubic-bezier(.65,0,.45,1) .6s forwards;filter:drop-shadow(0 0 15px rgba(255,107,0,.7))}@keyframes stroke-check{to{stroke-dashoffset:0}}.success-title{font-size:2rem;color:var(--color-text-primary);margin-bottom:.75rem;font-weight:600;text-shadow:0 0 20px rgba(255,107,0,.3);animation:slideUp .5s ease .8s both}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.success-text{font-size:1.125rem;color:var(--color-text-secondary);margin-bottom:2rem;animation:slideUp .5s ease .9s both}.success-telegram{background:#ff6b001a;border:2px solid rgba(255,107,0,.3);border-radius:16px;padding:2rem;margin:2rem auto;max-width:500px;animation:slideUp .5s ease 1s both}.telegram-icon{width:60px;height:60px;margin:0 auto 1rem;color:var(--color-primary);animation:pulse 2s ease infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.telegram-icon svg{width:100%;height:100%;filter:drop-shadow(0 0 15px rgba(255,107,0,.5))}.telegram-text{font-size:1rem;color:var(--color-text-primary);line-height:1.6}.telegram-text strong{color:var(--color-primary);font-weight:700}.success-btn{margin-top:2rem;padding:1rem 2.5rem;background:linear-gradient(135deg,var(--color-primary) 0%,#ff8533 100%);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;font-family:inherit;box-shadow:0 4px 20px #ff6b0066;animation:slideUp .5s ease 1.1s both;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none}.success-btn:hover{transform:translateY(-2px);box-shadow:0 6px 25px #ff6b0099}.success-btn:active{transform:translateY(0)}@media(max-width:768px){.app{padding:12rem .75rem .75rem;overflow-x:hidden}.container{padding:1.5rem 1rem;max-width:calc(100% - 80px);width:100%;box-sizing:border-box}.header{margin-bottom:1.5rem}.logo-image{height:36px}h1{font-size:1.25rem;line-height:1.3}.subtitle{font-size:.875rem}.dropzone{padding:2rem 1rem;min-height:200px}.upload-icon{width:48px;height:48px;margin-bottom:1rem}.dropzone-text{font-size:.9375rem}.dropzone-hint{font-size:.8125rem}.files-header{flex-direction:column;gap:.75rem;align-items:stretch}.clear-btn{width:100%;min-height:44px;font-size:.9375rem}.file-item{padding:.875rem 1rem}.file-name{font-size:.875rem}.file-size{font-size:.75rem}.remove-btn{min-width:44px;min-height:44px;font-size:1.125rem}.upload-btn{min-height:52px;font-size:.9375rem;padding:1rem}.loading-view,.success-view{padding:1.5rem 1rem}.success-checkmark{width:100px;height:100px}.loading-orb-container{width:130px;height:130px}.loading-orb-core{width:40px;height:40px}.loading-orb-core svg{width:24px;height:24px}.loading-title{font-size:1.25rem}.loading-success-burst{width:120px;height:120px}.success-orb{width:70px;height:70px}.loading-glow{width:200px;height:200px}.success-title{font-size:1.375rem;line-height:1.3}.success-text{font-size:.9375rem}.telegram-icon{width:48px;height:48px}.success-telegram{padding:1.25rem 1rem;margin:1.5rem 0}.telegram-text{font-size:.9375rem}.success-btn{width:100%;min-height:52px;font-size:.9375rem;padding:1rem}.status-message{font-size:.875rem;padding:.875rem 1rem}}@media(max-width:480px){.app{padding:10rem .5rem .5rem}.container{padding:1.25rem .875rem;border-radius:12px;max-width:calc(100% - 70px)}.typewriter-container{height:70px;min-height:70px}.typewriter-title{font-size:1.125rem;height:1.75rem;min-height:1.75rem}.typewriter-subtitle{height:1.25rem;min-height:1.25rem}.logo-image{height:32px}h1{font-size:1.125rem}.subtitle{font-size:.8125rem}.dropzone{padding:1.5rem .75rem}.success-checkmark{width:80px;height:80px}.loading-orb-container{width:110px;height:110px;margin-bottom:1.5rem}.loading-orb-core{width:35px;height:35px}.loading-orb-core svg{width:20px;height:20px}.loading-title{font-size:1.125rem}.loading-success-burst{width:100px;height:100px}.success-orb{width:60px;height:60px}.success-check{width:30px;height:30px}.loading-glow{width:150px;height:150px}.loading-particle{width:4px;height:4px}.success-title{font-size:1.25rem}.telegram-icon{width:40px;height:40px}.success-telegram{padding:1rem .875rem}.header-buttons{gap:8px}.calendar-fab,.stats-fab{width:40px;height:40px}.chat-fab{width:46px;height:46px;font-size:1.25rem}.logo{font-size:1.25rem}}@media(max-width:350px){.typewriter-container{height:55px;min-height:55px}.typewriter-title{font-size:.9375rem;height:1.375rem;min-height:1.375rem}.typewriter-subtitle{font-size:.75rem;height:1rem;min-height:1rem}.logo{font-size:.875rem;letter-spacing:.02em}.logo-header-row{margin-bottom:.375rem;padding:0 .25rem}.header-buttons{gap:3px;margin-right:-.25rem}.calendar-fab,.stats-fab{width:28px;height:28px}.calendar-fab svg,.stats-fab svg{width:13px;height:13px}.chat-fab{width:32px;height:32px;font-size:.875rem}.dropzone{padding:1rem .5rem;min-height:auto}.upload-icon{width:32px;height:32px;margin-bottom:.5rem}.dropzone-text{font-size:.75rem}.header{margin-bottom:.75rem}}.uploads-sidebar{position:fixed;bottom:24px;right:24px;z-index:9998;display:flex;flex-direction:column;gap:12px;max-height:calc(100vh - 48px);overflow-y:auto}.upload-status-box{background:linear-gradient(135deg,#141414f2,#1e1e1ef2);border:1px solid rgba(255,107,0,.3);border-radius:16px;padding:16px 20px;display:flex;align-items:center;gap:14px;cursor:pointer;box-shadow:0 8px 32px #0006,0 0 20px #ff6b0026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;animation:statusBoxSlideIn .4s cubic-bezier(.16,1,.3,1);max-width:320px;min-width:280px;position:relative}@keyframes statusBoxSlideIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.upload-status-box:hover{transform:translateY(-2px);box-shadow:0 12px 40px #00000080,0 0 30px #ff6b0033;border-color:#ff6b0080}.upload-status-box.complete{border-color:#22c55e66;box-shadow:0 8px 32px #0006,0 0 20px #22c55e26}.upload-status-box.complete:hover{box-shadow:0 12px 40px #00000080,0 0 30px #22c55e33;border-color:#22c55e99}.upload-status-box-icon{font-size:28px;flex-shrink:0}.upload-status-box-content{flex:1;min-width:0}.upload-status-box-filename{font-size:.875rem;font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:8px}.upload-status-box-progress{height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden;margin-bottom:6px}.upload-status-box-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary) 0%,#ff8533 100%);border-radius:3px;transition:width .3s ease}.upload-status-box-text{font-size:.75rem;color:var(--color-text-secondary)}.upload-status-box.complete .upload-status-box-text{color:#22c55e}.upload-status-box.error{border-color:#ef444466;box-shadow:0 8px 32px #0006,0 0 20px #ef444426}.upload-status-box.error:hover{border-color:#ef444499}.upload-status-box-text.error{color:#ef4444}.upload-status-box-close{position:absolute;top:8px;right:8px;width:24px;height:24px;border-radius:50%;border:none;background:#ffffff1a;color:#fff9;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;opacity:0}.upload-status-box:hover .upload-status-box-close{opacity:1}.upload-status-box-close:hover{background:#ef44444d;color:#ef4444}@media(max-width:480px){.uploads-sidebar{bottom:16px;right:16px;left:16px}.upload-status-box{max-width:none;min-width:auto}.upload-status-box-close{opacity:1}}@media(max-width:350px){.uploads-sidebar{bottom:12px;right:12px;left:12px}.upload-status-box{padding:12px 14px;border-radius:12px;gap:10px}.upload-status-box-icon{font-size:22px}.upload-status-box-filename{font-size:.8125rem;margin-bottom:6px}.upload-status-box-text{font-size:.6875rem}.upload-status-box-progress{height:5px;margin-bottom:4px}}.chat-overlay{position:fixed;inset:0;background:#000;display:flex;align-items:center;justify-content:center;gap:2rem;z-index:9999;padding:2rem;animation:overlayFadeIn .4s cubic-bezier(.16,1,.3,1)}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.chat-mascot{width:200px;height:auto;filter:drop-shadow(0 10px 30px rgba(255,107,0,.4));animation:mascotBounce 3s ease-in-out infinite;flex-shrink:0;transition:transform .5s cubic-bezier(.34,1.56,.64,1);overflow:visible}.chat-mascot svg{overflow:visible}@keyframes mascotBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}.chat-mascot.listening{animation:mascotListenStart .5s ease-out forwards,mascotListen 2s ease-in-out .5s infinite}@keyframes mascotListenStart{0%{transform:translate(0) translateY(0) rotate(0)}to{transform:translate(20px) translateY(40px) rotate(12deg)}}@keyframes mascotListen{0%,to{transform:translate(20px) translateY(40px) rotate(12deg)}50%{transform:translate(25px) translateY(45px) rotate(14deg)}}.chat-mascot.thinking{animation:mascotThink 2s ease-in-out infinite;transform:translateY(0)}@keyframes mascotThink{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-5px) rotate(-3deg)}75%{transform:translateY(-5px) rotate(3deg)}}.chat-mascot-ear,.chat-mascot-ear-inner{opacity:0;transform:scale(.5);transition:all .5s ease-out}.chat-mascot-ear.listening,.chat-mascot-ear-inner.listening{opacity:1;transform:scale(1);animation:earWiggle 1.2s ease-in-out infinite}@keyframes earWiggle{0%,to{transform:scale(1) rotate(0)}50%{transform:scale(1.05) rotate(3deg)}}.chat-mascot-eye{animation:chatMascotBlink 4s ease-in-out infinite;transition:ry .2s ease-out}.chat-mascot-eye-right{animation-delay:.1s}.chat-mascot-eye.squinting{animation:none}@keyframes chatMascotBlink{0%,45%,55%,to{transform:scaleY(1)}50%{transform:scaleY(.1)}}.chat-mascot-mouth{transition:ry .05s ease-out}.chat-mascot-arm-left{transform-origin:center;animation:armWaveLeft 2s ease-in-out infinite}.chat-mascot-arm-right{transform-origin:center;animation:armWaveRight 2s ease-in-out infinite;animation-delay:.5s}@keyframes armWaveLeft{0%,to{transform:rotate(0)}50%{transform:rotate(-10deg)}}@keyframes armWaveRight{0%,to{transform:rotate(0)}50%{transform:rotate(10deg)}}.chat-mascot-arm-left.thinking{animation:armThinkLeft 2s ease-in-out infinite}.chat-mascot-arm-right.thinking{animation:armThinkRight 2s ease-in-out infinite}@keyframes armThinkLeft{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-20px) translate(15px) rotate(30deg)}}@keyframes armThinkRight{0%,to{transform:rotate(0)}50%{transform:rotate(-5deg)}}.thinking-dot{animation:thinkingFloat 1.5s ease-in-out infinite}.thinking-dot-1{animation-delay:0s}.thinking-dot-2{animation-delay:.2s}.thinking-dot-3{animation-delay:.4s}@keyframes thinkingFloat{0%,to{opacity:.4;transform:translateY(0) scale(.8)}50%{opacity:1;transform:translateY(-8px) scale(1.1)}}.chat-mascot-eye.thinking{animation:eyesLookUp 2s ease-in-out infinite}@keyframes eyesLookUp{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.chat-window{background:#0a0a0af2;border-radius:20px;width:100%;max-width:600px;height:700px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #ff6b0066,0 0 0 1px #ff6b004d,inset 0 0 60px #ff6b000d;border:1px solid rgba(255,107,0,.3);animation:chatWindowOpen .5s cubic-bezier(.34,1.56,.64,1);position:relative}@keyframes chatWindowOpen{0%{transform:scale(.8) translateY(60px);opacity:0}50%{transform:scale(1.02) translateY(-10px);opacity:1}to{transform:scale(1) translateY(0);opacity:1}}.chat-header{padding:1.5rem;border-bottom:1px solid rgba(255,107,0,.2);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.chat-header-info{flex:1}.chat-header-title{font-size:1.25rem;font-weight:600;color:var(--color-text-primary);margin-bottom:.25rem}.chat-logo{color:var(--color-primary);text-shadow:0 0 20px rgba(255,107,0,.5)}.chat-header-subtitle{font-size:.75rem;color:var(--color-text-secondary);font-family:monospace}.chat-close-btn{background:transparent;border:1px solid rgba(255,107,0,.3);color:var(--color-text-secondary);width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.chat-close-btn:hover{background:#ff6b001a;border-color:var(--color-primary);color:var(--color-primary)}.chat-messages{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:#0000004d;border-radius:10px}.chat-messages::-webkit-scrollbar-thumb{background:#ff6b004d;border-radius:10px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#ff6b0080}.chat-message{display:flex;flex-direction:column;max-width:80%;animation:messageSlideIn .3s ease}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-message.user{align-self:flex-end;align-items:flex-end}.chat-message.assistant{align-self:flex-start;align-items:flex-start}.chat-message-content{padding:.875rem 1.125rem;border-radius:16px;font-size:.9375rem;line-height:1.5;word-wrap:break-word}.chat-message.user .chat-message-content{background:linear-gradient(135deg,var(--color-primary) 0%,#ff8533 100%);color:#fff;border-bottom-right-radius:4px}.chat-message.assistant .chat-message-content{background:#ff6b001a;color:var(--color-text-primary);border:1px solid rgba(255,107,0,.2);border-bottom-left-radius:4px}.chat-message.error .chat-message-content{background:#ff44441a;border-color:#ff44444d;color:#f44}.chat-message-time{font-size:.6875rem;color:var(--color-text-secondary);margin-top:.375rem;padding:0 .5rem}.chat-message.typing .chat-message-content{padding:1rem 1.25rem}.typing-indicator{display:flex;gap:.375rem;align-items:center}.typing-indicator span{width:8px;height:8px;border-radius:50%;background:var(--color-primary);animation:typingBounce 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-8px);opacity:1}}.cursor-blink{display:inline-block;margin-left:2px;color:var(--color-primary);animation:blink 1s infinite;font-weight:300}@keyframes blink{0%,49%{opacity:1}50%,to{opacity:0}}.chat-input-container{padding:1.25rem;border-top:1px solid rgba(255,107,0,.2);display:flex;gap:.75rem;align-items:flex-end;flex-shrink:0;background:#0000004d}.chat-input{flex:1;background:#ff6b000d;border:1px solid rgba(255,107,0,.2);border-radius:12px;padding:.875rem 1rem;color:var(--color-text-primary);font-size:.9375rem;font-family:inherit;resize:none;max-height:120px;overflow-y:auto;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.chat-input:focus{outline:none;border-color:var(--color-primary);background:#ff6b0014;box-shadow:0 0 0 3px #ff6b001a}.chat-input::placeholder{color:var(--color-text-secondary)}.chat-input:disabled{opacity:.5;cursor:not-allowed}.chat-input::-webkit-scrollbar{width:4px}.chat-input::-webkit-scrollbar-track{background:transparent}.chat-input::-webkit-scrollbar-thumb{background:#ff6b004d;border-radius:10px}.chat-send-btn{background:linear-gradient(135deg,var(--color-primary) 0%,#ff8533 100%);border:none;width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:all .2s ease;flex-shrink:0;box-shadow:0 4px 12px #ff6b0066;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.chat-send-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #ff6b0099}.chat-send-btn:active:not(:disabled){transform:translateY(0)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.chat-stop-btn{background:linear-gradient(135deg,#f44,#c33);border:none;width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:all .2s ease;flex-shrink:0;box-shadow:0 4px 12px #f446;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.chat-stop-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #f449}.chat-stop-btn:active{transform:translateY(0)}.spin{animation:spin 1s linear infinite}@media(max-width:900px){.chat-overlay{flex-direction:column;padding:1rem;gap:1rem}.chat-mascot{width:120px;position:relative;order:-1}.chat-window{height:auto;max-height:70vh;flex:1}}@media(max-width:768px){.chat-overlay{padding:1rem .5rem .5rem}.chat-mascot{width:100px}.chat-window{max-width:100%;height:auto;max-height:75vh;border-radius:16px;flex:1}.chat-header{padding:1.25rem 1rem}.chat-header-title{font-size:1.125rem}.chat-messages{padding:1rem}.chat-message{max-width:85%}.chat-message-content{font-size:.875rem;padding:.75rem 1rem}.chat-input-container{padding:1rem}.chat-input{font-size:.875rem}}@media(max-width:480px){.chat-mascot{width:80px}.chat-window{max-height:80vh}.chat-message{max-width:90%}.chat-header-subtitle{font-size:.6875rem}}@media(max-width:350px){.chat-overlay{padding:.5rem .375rem .375rem;gap:.5rem}.chat-mascot{width:60px}.chat-window{max-height:85vh;border-radius:12px}.chat-header{padding:1rem .75rem}.chat-header-title{font-size:1rem}.chat-header-subtitle{font-size:.625rem}.chat-close-btn{width:32px;height:32px}.chat-messages{padding:.75rem;gap:.75rem}.chat-message{max-width:92%}.chat-message-content{font-size:.8125rem;padding:.625rem .875rem;border-radius:12px}.chat-message-time{font-size:.625rem}.chat-input-container{padding:.75rem;gap:.5rem}.chat-input{font-size:.8125rem;padding:.75rem .875rem;border-radius:10px}.chat-send-btn,.chat-stop-btn{width:40px;height:40px;border-radius:10px}.typing-indicator span{width:6px;height:6px}}.upload-progress-container{background:linear-gradient(135deg,#ff6b0026,#ff85331a);border-bottom:1px solid rgba(255,107,0,.2);padding:.875rem 1.25rem;animation:progressSlideIn .3s ease}@keyframes progressSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.upload-progress-info{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.upload-progress-filename{font-size:.875rem;font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.upload-progress-size{font-size:.75rem;color:var(--color-text-secondary)}.upload-progress-bar-wrapper{height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden;margin-bottom:.375rem}.upload-progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--color-primary) 0%,#ff8533 50%,var(--color-primary) 100%);background-size:200% 100%;border-radius:4px;transition:width .3s ease;animation:progressShine 2s linear infinite}@keyframes progressShine{0%{background-position:200% 0}to{background-position:-200% 0}}.upload-progress-details{display:flex;justify-content:space-between;align-items:center}.upload-progress-percent{font-size:.8125rem;font-weight:600;color:var(--color-primary)}.upload-progress-time{font-size:.75rem;color:var(--color-text-secondary)}.upload-complete-banner{background:linear-gradient(135deg,#22c55e33,#22c55e1a);border-bottom:1px solid rgba(34,197,94,.3);padding:.75rem 1.25rem;font-size:.875rem;color:#22c55e;text-align:center;animation:completeBannerPulse 2s ease-in-out infinite}@keyframes completeBannerPulse{0%,to{opacity:1}50%{opacity:.7}}@media(max-width:480px){.upload-progress-container{padding:.75rem 1rem}.upload-progress-filename{max-width:150px;font-size:.8125rem}.upload-progress-size{font-size:.6875rem}}@media(max-width:350px){.upload-progress-container{padding:.625rem .75rem}.upload-progress-info{gap:.375rem;margin-bottom:.375rem}.upload-progress-filename{max-width:120px;font-size:.75rem}.upload-progress-size{font-size:.625rem}.upload-progress-bar-wrapper{height:6px;margin-bottom:.25rem}.upload-progress-percent{font-size:.75rem}.upload-progress-time{font-size:.6875rem}.upload-complete-banner{padding:.625rem 1rem;font-size:.8125rem}}.chat-mascot.working{animation:mascotWorking 1s ease-in-out infinite}@keyframes mascotWorking{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.mascot-laptop{position:absolute;width:100px;height:auto;left:-80px;top:100px;animation:laptopAppear .5s ease-out forwards;filter:drop-shadow(0 5px 15px rgba(0,0,0,.5))}@keyframes laptopAppear{0%{opacity:0;transform:translate(-20px) scale(.8)}to{opacity:1;transform:translate(0) scale(1)}}.code-line{opacity:.5;animation:codeTyping 2s ease-in-out infinite}.code-line-1{animation-delay:0s}.code-line-2{animation-delay:.2s}.code-line-3{animation-delay:.4s}.code-line-4{animation-delay:.6s}.code-line-5{animation-delay:.8s}@keyframes codeTyping{0%,to{opacity:.3;width:20px}50%{opacity:1;width:60px}}.chat-mascot-arm-left.typing{animation:armTypingLeft .3s ease-in-out infinite}.chat-mascot-arm-right.typing{animation:armTypingRight .3s ease-in-out infinite;animation-delay:.15s}@keyframes armTypingLeft{0%,to{transform:translate(-30px) translateY(-20px) rotate(25deg)}50%{transform:translate(-30px) translateY(-15px) rotate(25deg)}}@keyframes armTypingRight{0%,to{transform:translate(-30px) translateY(-20px) rotate(-25deg)}50%{transform:translate(-30px) translateY(-15px) rotate(-25deg)}}.chat-mascot-eye.working{animation:eyesFocused 3s ease-in-out infinite}@keyframes eyesFocused{0%,to{transform:translate(-3px)}50%{transform:translate(-5px)}}@media(max-width:900px){.mascot-laptop{width:70px;left:-50px;top:70px}}@media(max-width:480px){.mascot-laptop{width:50px;left:-35px;top:50px}}@media(max-width:350px){.mascot-laptop{width:40px;left:-28px;top:40px}}.chat-mascot.celebrating{animation:mascotDance .5s ease-in-out infinite}@keyframes mascotDance{0%,to{transform:translateY(0) rotate(0) scale(1)}25%{transform:translateY(-20px) rotate(-8deg) scale(1.05)}50%{transform:translateY(-5px) rotate(0) scale(1.02)}75%{transform:translateY(-20px) rotate(8deg) scale(1.05)}}.chat-mascot.celebrating .chat-mascot-arm-left{animation:armDanceLeft .25s ease-in-out infinite}.chat-mascot.celebrating .chat-mascot-arm-right{animation:armDanceRight .25s ease-in-out infinite;animation-delay:.125s}@keyframes armDanceLeft{0%,to{transform:translateY(0) rotate(-5deg)}50%{transform:translateY(-25px) rotate(-35deg)}}@keyframes armDanceRight{0%,to{transform:translateY(0) rotate(5deg)}50%{transform:translateY(-25px) rotate(35deg)}}.chat-mascot.celebrating .chat-mascot-eye{animation:eyesDance .5s ease-in-out infinite}@keyframes eyesDance{0%,to{transform:scaleY(.5)}50%{transform:scaleY(.7)}}.calendar-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .3s ease-out}.calendar-container{background:#0a0a0a;border-radius:20px;width:100%;max-width:1000px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 32px #ff6b004d,0 0 0 1px #ff6b0033,inset 0 0 60px #ff6b000d;border:1px solid rgba(255,107,0,.3);animation:slideUp .3s ease-out}.calendar-header{padding:20px 24px;border-bottom:1px solid rgba(255,107,0,.2);background:#ff6b000d}.calendar-title{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.calendar-title h2{color:#fff;font-size:24px;font-weight:600;margin:0}.calendar-close{background:#ff6b001a;border:1px solid rgba(255,107,0,.3);border-radius:8px;padding:8px;color:#ff6b00;cursor:pointer;transition:all .2s}.calendar-close:hover{background:#ff6b0033;color:#fff}.calendar-controls{display:flex;justify-content:space-between;align-items:center;gap:16px}.view-toggle{display:flex;background:#ffffff1a;border-radius:8px;padding:4px}.view-toggle button{background:transparent;border:none;color:#fff9;padding:8px 16px;border-radius:6px;cursor:pointer;transition:all .2s;font-size:14px}.view-toggle button.active{background:linear-gradient(135deg,#ff6b00,#ff8533);color:#fff;box-shadow:0 2px 10px #ff6b0066}.view-toggle button:hover:not(.active){color:#fff}.month-nav{display:flex;align-items:center;gap:12px}.month-nav button{background:#ffffff1a;border:none;border-radius:8px;padding:8px;color:#fff;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.month-nav button:hover{background:#fff3}.current-month{color:#fff;font-size:16px;font-weight:500;min-width:160px;text-align:center}.refresh-btn{background:#ffffff1a;border:none;border-radius:8px;padding:8px;color:#fff;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.refresh-btn:hover:not(:disabled){background:#fff3}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}.calendar-body{flex:1;overflow-y:auto;padding:24px}.calendar-loading,.calendar-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;color:#fff9;gap:12px}.calendar-error button{background:#ff6b00;border:none;color:#fff;padding:8px 16px;border-radius:8px;cursor:pointer;margin-top:8px}.calendar-grid{background:#ffffff0d;border-radius:12px;overflow:hidden}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);background:#ffffff1a}.weekday{padding:12px;text-align:center;color:#ffffffb3;font-size:14px;font-weight:500}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr)}.calendar-day{min-height:90px;padding:10px;border:1px solid rgba(255,255,255,.05);position:relative;display:flex;flex-direction:column;align-items:center}.calendar-day.empty{background:#0003}.calendar-day.today{background:#ff6b001a}.calendar-day.today .day-number{background:#ff6b00;color:#fff;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center}.calendar-day.has-uploads{background:#ffffff08}.day-number{color:#fffc;font-size:14px;font-weight:500;width:28px;height:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.day-upload-badge{margin-top:12px;width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,#ff6b00,#ff8533);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px #ff6b0066,inset 0 1px #fff3;border:1px solid rgba(255,107,0,.6)}.day-upload-badge:hover{transform:scale(1.1);box-shadow:0 6px 20px #ff6b0099,inset 0 1px #ffffff4d}.day-upload-badge:active{transform:scale(.95)}.badge-count{color:#fff;font-size:16px;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.3)}.day-detail-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1100;padding:20px;animation:fadeIn .2s ease-out}.day-detail-container{background:#0a0a0a;border-radius:20px;max-width:500px;width:100%;max-height:80vh;overflow:hidden;position:relative;box-shadow:0 8px 32px #ff6b004d,0 0 0 1px #ff6b0033,inset 0 0 60px #ff6b000d;border:1px solid rgba(255,107,0,.3);animation:slideUp .3s ease-out;display:flex;flex-direction:column}.day-detail-header{padding:24px 60px 24px 24px;background:#ff6b0014;border-bottom:1px solid rgba(255,107,0,.2);display:flex;justify-content:space-between;align-items:center}.day-detail-header h3{color:#fff;margin:0;font-size:20px;font-weight:600}.day-detail-count{background:linear-gradient(135deg,#ff6b00,#ff8533);color:#fff;padding:6px 14px;border-radius:20px;font-size:14px;font-weight:600;box-shadow:0 2px 10px #ff6b0066}.day-detail-list{padding:16px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:12px}.day-detail-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:16px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:16px}.day-detail-card:hover{background:#ff6b001a;border-color:#ff6b004d;transform:translate(4px)}.day-detail-card-left{flex-shrink:0}.day-detail-platform{font-size:28px}.day-detail-card-content{flex:1;min-width:0}.day-detail-name{color:#fff;font-size:16px;font-weight:600;margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.day-detail-time{color:#ff6b00;font-size:14px;font-weight:500;display:block}.day-detail-platforms{color:#ffffff80;font-size:13px;display:block;margin-top:2px}.day-detail-arrow{color:#ffffff4d;flex-shrink:0;transition:all .2s}.day-detail-card:hover .day-detail-arrow{color:#ff6b00;transform:translate(4px)}.platform-icons-row{display:flex;gap:6px;align-items:center}.uploads-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.no-uploads{grid-column:1 / -1;text-align:center;color:#ffffff80;padding:48px}.upload-card{background:#ffffff0d;border-radius:12px;overflow:hidden;cursor:pointer;transition:all .2s;border:1px solid rgba(255,255,255,.1)}.upload-card:hover{background:#ffffff14;transform:translateY(-2px)}.upload-card-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#0003}.upload-platform{font-size:20px}.upload-status{font-size:12px;padding:4px 10px;border-radius:12px;color:#fff;font-weight:500}.upload-card-body{padding:16px}.upload-customer-name{color:#fff;font-size:18px;font-weight:600;margin:0 0 8px}.upload-meta{display:flex;gap:12px;margin-bottom:8px}.upload-day{color:#ff6b00;font-size:14px;font-weight:500}.upload-time{color:#fff9;font-size:14px}.upload-accounts{color:#ffffff80;font-size:13px;margin:0}.upload-platforms{font-size:20px;letter-spacing:4px}.detail-caption{margin-top:16px;padding-top:16px;border-top:1px solid rgba(255,107,0,.2)}.caption-text{color:#fffc;font-size:14px;line-height:1.5;margin:8px 0 0;white-space:pre-wrap}.calendar-stats{display:flex;justify-content:center;gap:32px;padding:20px;background:#ff6b000d;border-top:1px solid rgba(255,107,0,.2)}.stat{text-align:center}.stat-value{display:block;font-size:24px;font-weight:600;color:#ff6b00;text-shadow:0 0 20px rgba(255,107,0,.5)}.stat-label{font-size:12px;color:#ffffff80}.upload-detail-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1100;padding:20px;animation:fadeIn .2s ease-out}.upload-detail{background:#0a0a0a;border-radius:20px;max-width:450px;width:100%;max-height:80vh;overflow-y:auto;position:relative;box-shadow:0 8px 32px #ff6b004d,0 0 0 1px #ff6b0033,inset 0 0 60px #ff6b000d;border:1px solid rgba(255,107,0,.3);animation:slideUp .3s ease-out}.detail-close{position:absolute;top:16px;right:16px;background:#ff6b001a;border:1px solid rgba(255,107,0,.3);border-radius:8px;padding:8px;color:#ff6b00;cursor:pointer;z-index:10;transition:all .2s}.detail-close:hover{background:#ff6b0033;color:#fff}.detail-header{padding:24px;background:#ff6b000d;border-bottom:1px solid rgba(255,107,0,.2);display:flex;align-items:center;gap:16px}.detail-platform{font-size:36px}.detail-header h3{flex:1;color:#fff;margin:0;font-size:20px;font-weight:600}.detail-body{padding:24px}.detail-info{display:flex;flex-direction:column;gap:16px}.detail-row{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding:12px 16px;background:#ffffff08;border-radius:10px;border:1px solid rgba(255,255,255,.05)}.detail-label{color:#ffffff80;font-size:14px;flex-shrink:0}.detail-value{color:#ff6b00;font-size:14px;font-weight:500;text-align:right;word-break:break-word}.detail-video-link{display:block;text-align:center;background:linear-gradient(135deg,#ff6b00,#ff8533);color:#fff;padding:12px 24px;border-radius:8px;text-decoration:none;margin-top:20px;font-weight:500;transition:all .2s;box-shadow:0 4px 15px #ff6b0066}.detail-video-link:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ff6b0099}@media(max-width:768px){.calendar-controls{flex-wrap:wrap}.calendar-stats{gap:16px}.stat-value{font-size:20px}.uploads-list{grid-template-columns:1fr}}@media(max-width:480px){.calendar-overlay{padding:12px}.calendar-container{border-radius:16px}.calendar-header{padding:16px}.calendar-title h2{font-size:20px}.view-toggle button{padding:6px 12px;font-size:13px}.current-month{font-size:14px;min-width:130px}.calendar-body{padding:16px}.weekday{padding:8px 4px;font-size:12px}.calendar-day{min-height:70px;padding:6px}.day-number{font-size:12px;width:24px;height:24px}.day-upload-badge{width:36px;height:36px;margin-top:8px;border-radius:10px}.badge-count{font-size:14px}.calendar-stats{padding:16px;gap:12px;flex-wrap:wrap}.stat-value{font-size:18px}.stat-label{font-size:11px}.day-detail-overlay{padding:12px}.day-detail-container{border-radius:16px}.day-detail-header{padding:16px 50px 16px 16px}.day-detail-header h3{font-size:16px}.day-detail-list{padding:12px;gap:10px}.day-detail-card{padding:12px;gap:12px;border-radius:12px}.day-detail-name{font-size:14px}.day-detail-time{font-size:13px}.upload-detail{border-radius:16px}.detail-header{padding:16px}.detail-platform{font-size:28px}.detail-header h3{font-size:16px}.detail-body{padding:16px}.detail-row{padding:10px 12px;flex-direction:column;gap:4px;align-items:flex-start}.detail-value{text-align:left}}@media(max-width:350px){.calendar-overlay{padding:8px}.calendar-container{border-radius:12px}.calendar-header{padding:12px}.calendar-title{margin-bottom:12px}.calendar-title h2{font-size:18px}.view-toggle{padding:2px}.view-toggle button{padding:5px 10px;font-size:12px}.month-nav{gap:8px}.month-nav button{padding:6px}.current-month{font-size:13px;min-width:110px}.calendar-body{padding:12px}.weekday{padding:6px 2px;font-size:10px}.calendar-day{min-height:55px;padding:4px}.day-number{font-size:11px;width:20px;height:20px}.calendar-day.today .day-number{width:22px;height:22px}.day-upload-badge{width:28px;height:28px;margin-top:4px;border-radius:8px}.badge-count{font-size:12px}.calendar-stats{padding:12px;gap:8px}.stat-value{font-size:16px}.stat-label{font-size:10px}.day-detail-overlay{padding:8px}.day-detail-container{border-radius:12px}.day-detail-header{padding:12px 44px 12px 12px}.day-detail-header h3{font-size:15px}.day-detail-count{padding:4px 10px;font-size:12px}.day-detail-list{padding:10px;gap:8px}.day-detail-card{padding:10px;gap:10px;border-radius:10px}.day-detail-platform{font-size:24px}.day-detail-name{font-size:13px}.day-detail-time{font-size:12px}.day-detail-platforms{font-size:11px}.upload-detail{border-radius:12px}.detail-header{padding:14px}.detail-platform{font-size:24px}.detail-header h3{font-size:15px}.detail-body{padding:14px}.detail-row{padding:8px 10px}.detail-label,.detail-value{font-size:13px}.detail-video-link{padding:10px 20px;font-size:14px}}.stats-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.stats-container{background:#0a0a0a;border-radius:20px;width:100%;max-width:700px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 32px #ff6b004d,0 0 0 1px #ff6b0033,inset 0 0 60px #ff6b000d;border:1px solid rgba(255,107,0,.3);animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.stats-header{padding:20px 24px;border-bottom:1px solid rgba(255,107,0,.2);background:#ff6b000d;display:flex;justify-content:space-between;align-items:center}.stats-title{display:flex;align-items:center;gap:12px}.stats-title h2{color:#fff;font-size:24px;font-weight:600;margin:0}.stats-icon{color:#ff6b00}.stats-header-actions{display:flex;gap:8px}.stats-refresh,.stats-close{background:#ff6b001a;border:1px solid rgba(255,107,0,.3);border-radius:8px;padding:8px;color:#ff6b00;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.stats-refresh:hover,.stats-close:hover{background:#ff6b0033;color:#fff}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.stats-body{flex:1;overflow-y:auto;padding:24px}.stats-loading,.stats-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;color:#fff9;gap:12px}.stats-error button{background:linear-gradient(135deg,#ff6b00,#ff8533);border:none;color:#fff;padding:8px 16px;border-radius:8px;cursor:pointer;margin-top:8px}.stats-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:32px}.summary-card{background:#ff6b001a;border:1px solid rgba(255,107,0,.2);border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px}.summary-card svg{color:#ff6b00;flex-shrink:0}.summary-content{display:flex;flex-direction:column}.summary-value{font-size:28px;font-weight:700;color:#fff;text-shadow:0 0 20px rgba(255,107,0,.5)}.summary-label{font-size:12px;color:#ffffff80}.stats-section{margin-bottom:28px}.stats-section h3{color:#ff6b00;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:1px;margin:0 0 16px}.customer-list{display:flex;flex-direction:column;gap:8px}.no-data{text-align:center;color:#fff6;padding:24px}.customer-row{display:flex;align-items:center;gap:16px;padding:12px 16px;background:#ffffff08;border-radius:10px;border:1px solid rgba(255,255,255,.05);transition:all .2s}.customer-row:hover{background:#ffffff0f;border-color:#ff6b0033}.customer-rank{font-size:14px;font-weight:600;color:#ff6b00;min-width:32px}.customer-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.customer-name{color:#fff;font-size:15px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.customer-accounts{color:#fff6;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.customer-platforms{display:flex;gap:4px;font-size:16px}.customer-count{text-align:right;min-width:60px}.count-value{display:block;font-size:20px;font-weight:700;color:#ff6b00}.count-label{font-size:11px;color:#fff6}.platform-list{display:flex;flex-direction:column;gap:12px}.platform-row{display:flex;align-items:center;gap:12px}.platform-info{display:flex;align-items:center;gap:8px;min-width:120px}.platform-icon{font-size:20px}.platform-name{color:#fff;font-size:14px}.platform-bar-container{flex:1;height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden}.platform-bar{height:100%;background:linear-gradient(90deg,#ff6b00,#ff8533);border-radius:4px;transition:width .5s ease-out}.platform-stats{display:flex;gap:8px;min-width:80px;justify-content:flex-end}.platform-count{color:#fff;font-weight:600;font-size:14px}.platform-percent{color:#fff6;font-size:14px}@media(max-width:600px){.stats-summary{grid-template-columns:1fr}.customer-row{flex-wrap:wrap}.customer-platforms{order:3;width:100%;margin-top:8px}.platform-info{min-width:100px}}@media(max-width:480px){.stats-overlay{padding:12px}.stats-container{border-radius:16px}.stats-header{padding:16px}.stats-title h2{font-size:20px}.stats-body{padding:16px}.summary-card{padding:16px;gap:12px}.summary-value{font-size:24px}.summary-label{font-size:11px}.customer-row{padding:10px 12px}.customer-rank{font-size:13px;min-width:28px}.customer-name{font-size:14px}.customer-accounts{font-size:11px}.count-value{font-size:18px}.platform-row{flex-wrap:wrap;gap:8px}.platform-info{min-width:90px}.platform-bar-container{order:3;width:100%;height:6px}.platform-name,.platform-count,.platform-percent{font-size:13px}}@media(max-width:350px){.stats-overlay{padding:8px}.stats-container{border-radius:12px}.stats-header{padding:12px}.stats-title h2{font-size:18px}.stats-title svg{width:20px;height:20px}.stats-refresh,.stats-close{padding:6px}.stats-body{padding:12px}.summary-card{padding:14px;gap:10px;border-radius:10px}.summary-card svg{width:24px;height:24px}.summary-value{font-size:22px}.summary-label{font-size:10px}.stats-section{margin-bottom:20px}.stats-section h3{font-size:12px;margin-bottom:12px}.customer-row{padding:8px 10px;gap:10px}.customer-rank{font-size:12px;min-width:24px}.customer-name{font-size:13px}.customer-accounts{font-size:10px}.customer-platforms{font-size:14px}.customer-count{min-width:50px}.count-value{font-size:16px}.count-label{font-size:10px}.platform-info{min-width:80px;gap:6px}.platform-icon{font-size:18px}.platform-name,.platform-count,.platform-percent{font-size:12px}.platform-stats{min-width:70px}}.password-gate{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 20% 50%,rgba(255,107,0,.15) 0%,transparent 50%),radial-gradient(circle at 80% 50%,rgba(255,107,0,.15) 0%,transparent 50%),#000;padding:1rem}.password-gate-loading{display:flex;align-items:center;justify-content:center}.loading-spinner{width:40px;height:40px;border:3px solid rgba(255,107,0,.2);border-top-color:#ff6b00;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.password-gate-container{background:#0a0a0a;border-radius:20px;padding:3rem;max-width:400px;width:100%;box-shadow:0 8px 32px #ff6b004d,0 0 0 1px #ff6b0033,inset 0 0 60px #ff6b000d;border:1px solid rgba(255,107,0,.3);animation:gateAppear .5s ease-out}@keyframes gateAppear{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.password-gate-logo{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);letter-spacing:.05em;text-shadow:0 0 20px rgba(255,107,0,.5);text-align:center;margin-bottom:2rem}.password-gate-logo .logo-accent{color:#ff6b00;text-shadow:0 0 30px rgba(255,107,0,.8)}.password-gate-title{font-size:1.5rem;color:#fff;text-align:center;margin-bottom:.5rem;font-weight:600}.password-gate-subtitle{color:#999;text-align:center;margin-bottom:2rem;font-size:.9375rem}.password-gate-form{display:flex;flex-direction:column;gap:1.25rem}.password-gate-field{display:flex;flex-direction:column;gap:.5rem}.password-gate-field label{color:#999;font-size:.875rem;font-weight:500}.password-gate-field input{background:#ff6b000d;border:1px solid rgba(255,107,0,.2);border-radius:10px;padding:.875rem 1rem;color:#fff;font-size:1rem;font-family:inherit;transition:all .2s ease}.password-gate-field input:focus{outline:none;border-color:#ff6b00;background:#ff6b0014;box-shadow:0 0 0 3px #ff6b001a}.password-gate-field input::placeholder{color:#666}.password-gate-error{background:#ff44441a;border:1px solid rgba(255,68,68,.3);color:#f44;padding:.75rem 1rem;border-radius:8px;font-size:.875rem;text-align:center}.password-gate-button{background:linear-gradient(135deg,#ff6b00,#ff8533);border:none;border-radius:10px;padding:1rem;color:#fff;font-size:1rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 20px #ff6b0066;margin-top:.5rem}.password-gate-button:hover{transform:translateY(-2px);box-shadow:0 6px 25px #ff6b0099}.password-gate-button:active{transform:translateY(0)}@media(max-width:480px){.password-gate-container{padding:2rem 1.5rem;border-radius:16px}.password-gate-title{font-size:1.25rem}.password-gate-subtitle{font-size:.875rem}}
