.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-container{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;padding:40px;width:100%;max-width:420px}.login-header{text-align:center;margin-bottom:32px}.login-header h1{font-size:28px;font-weight:700;color:#1a202c;margin:0 0 8px}.login-header p{font-size:14px;color:#718096;margin:0}.login-form{display:flex;flex-direction:column;gap:20px}.error-banner{background-color:#fed7d7;border:1px solid #fc8181;border-radius:6px;color:#c53030;padding:12px 16px;font-size:14px;margin-bottom:4px}.form-actions{margin-top:8px}.btn-primary{width:100%;padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.form-footer{text-align:center;margin-top:8px}.forgot-password-link{font-size:14px;color:#667eea;text-decoration:none;transition:color .2s}.forgot-password-link:hover{color:#764ba2;text-decoration:underline}.login-container{animation:fadeInUp .4s ease-out}@media (max-width: 480px){.login-container{padding:30px 24px}.login-header h1{font-size:24px}.form-group label{font-size:13px}.form-group input{padding:10px 14px;font-size:13px}.btn-primary{font-size:15px;padding:11px 20px}}.profile-create-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:40px 20px}.profile-create-container{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;padding:40px;width:100%;max-width:800px}.profile-create-header{text-align:center;margin-bottom:32px}.profile-create-header h1{font-size:28px;font-weight:700;color:#1a202c;margin:0 0 8px}.profile-create-header p{font-size:14px;color:#718096;margin:0}.profile-create-form{display:flex;flex-direction:column;gap:32px}.error-banner{background-color:#fed7d7;border:1px solid #fc8181;border-radius:6px;color:#c53030;padding:12px 16px;font-size:14px}.success-banner{background-color:#c6f6d5;border:1px solid #68d391;border-radius:6px;color:#22543d;padding:12px 16px;font-size:14px}.form-section{display:flex;flex-direction:column;gap:16px}.section-title{font-size:18px;font-weight:600;color:#2d3748;margin:0 0 8px;padding-bottom:8px;border-bottom:2px solid #e2e8f0}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:14px;font-weight:600;color:#2d3748}.form-group input{padding:12px 16px;border:1px solid #cbd5e0;border-radius:6px;font-size:14px;transition:all .2s;outline:none}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background-color:#f7fafc;cursor:not-allowed;opacity:.6}.form-group input.input-error{border-color:#fc8181}.form-group input.input-error:focus{border-color:#fc8181;box-shadow:0 0 0 3px #fc81811a}.field-error{font-size:13px;color:#c53030;margin-top:2px}.field-hint{font-size:12px;color:#718096;margin-top:2px}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px;padding-top:24px;border-top:1px solid #e2e8f0}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary.loading:after{content:"";position:absolute;width:16px;height:16px;top:50%;left:50%;margin-left:-8px;margin-top:-8px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:buttonSpin .6s linear infinite}@keyframes buttonSpin{to{transform:rotate(360deg)}}.btn-secondary{padding:12px 32px;background:#fff;color:#4a5568;border:1px solid #cbd5e0;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.btn-secondary:hover:not(:disabled){background:#f7fafc;border-color:#a0aec0}.btn-secondary:active:not(:disabled){background:#edf2f7}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.form-loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.form-spinner{width:50px;height:50px;border:5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.profile-create-container{animation:fadeInUp .4s ease-out}.error-banner,.success-banner{animation:slideDown .3s ease-out}@media (max-width: 768px){.profile-create-container{padding:30px 24px}.profile-create-header h1{font-size:24px}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.btn-primary,.btn-secondary{width:100%}}@media (max-width: 480px){.profile-create-page{padding:20px 10px}.profile-create-container{padding:24px 16px}.section-title{font-size:16px}.form-group label{font-size:13px}.form-group input{padding:10px 14px;font-size:13px}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .3s ease-out}.success-dialog{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:40px;max-width:500px;width:90%;text-align:center;animation:scaleIn .3s ease-out}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.success-icon{width:80px;height:80px;background:linear-gradient(135deg,#48bb78,#38a169);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:48px;color:#fff;margin:0 auto 24px;animation:checkmarkPop .5s ease-out .2s both}@keyframes checkmarkPop{0%{transform:scale(0)}50%{transform:scale(1.1)}to{transform:scale(1)}}.success-dialog h2{font-size:24px;font-weight:700;color:#1a202c;margin:0 0 20px}.success-details{background:#f7fafc;border-radius:8px;padding:16px;margin:20px 0;text-align:left}.success-details p{margin:8px 0;font-size:14px;color:#4a5568}.success-details strong{color:#2d3748;font-weight:600;display:inline-block;min-width:100px}.success-message{font-size:14px;color:#718096;margin:20px 0;line-height:1.6}.dialog-actions{display:flex;gap:12px;margin-top:28px}.dialog-actions button{flex:1;padding:14px 24px;font-size:15px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s;border:none}.dialog-actions .btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.dialog-actions .btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.dialog-actions .btn-secondary{background:#fff;color:#4a5568;border:2px solid #e2e8f0}.dialog-actions .btn-secondary:hover{background:#f7fafc;border-color:#cbd5e0}@media (max-width: 480px){.success-dialog{padding:30px 20px}.success-icon{width:60px;height:60px;font-size:36px}.success-dialog h2{font-size:20px}.dialog-actions{flex-direction:column}.dialog-actions button{width:100%}}.dashboard-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:40px 20px}.dashboard-container{max-width:900px;margin:0 auto}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.dashboard-header h1{font-size:32px;font-weight:700;color:#fff;margin:0}.btn-logout{padding:10px 24px;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-logout:hover{background:#ffffff4d;transform:translateY(-1px)}.btn-logout:active{transform:translateY(0)}.loading-state{background:#fff;border-radius:12px;padding:60px 40px;text-align:center}.loading-state p{color:#718096;font-size:16px;margin:0}.error-banner{background-color:#fed7d7;border:1px solid #fc8181;border-radius:8px;color:#c53030;padding:14px 18px;font-size:14px;margin-bottom:24px}.user-info-card,.spapi-card{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;padding:32px;margin-bottom:24px}.user-info-card h2,.spapi-card h2{font-size:20px;font-weight:700;color:#1a202c;margin:0 0 24px}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.info-item{display:flex;flex-direction:column;gap:6px}.info-label{font-size:13px;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:16px;color:#1a202c;font-weight:500}.status-indicator{display:flex;align-items:center;gap:10px;margin-bottom:20px}.status-dot{width:12px;height:12px;border-radius:50%;animation:pulse 2s ease-in-out infinite}.status-connected .status-dot{background-color:#48bb78}.status-disconnected .status-dot{background-color:#f56565;animation:none}.status-reauth .status-dot{background-color:#ed8936;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-text{font-size:16px;font-weight:600;color:#1a202c}.spapi-description{color:#718096;font-size:14px;line-height:1.6;margin:0 0 24px}.spapi-details{background:#f7fafc;border-radius:6px;padding:16px;margin-bottom:24px}.spapi-details p{margin:0;font-size:14px;color:#2d3748}.spapi-details strong{font-weight:600;color:#1a202c}.btn-primary{padding:12px 32px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.dashboard-container{animation:fadeIn .4s ease-out}.user-info-card,.spapi-card{animation:fadeInUp .5s ease-out;transition:transform .2s ease,box-shadow .2s ease}.user-info-card:hover,.spapi-card:hover{transform:translateY(-2px);box-shadow:0 12px 48px #00000026}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.error-banner{animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.spinner{width:40px;height:40px;margin:0 auto 16px;border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}.btn-primary.loading{position:relative;color:transparent}.btn-primary.loading:after{content:"";position:absolute;width:16px;height:16px;top:50%;left:50%;margin-left:-8px;margin-top:-8px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@media (max-width: 768px){.dashboard-page{padding:24px 16px}.dashboard-header{flex-direction:column;align-items:flex-start;gap:16px}.dashboard-header h1{font-size:28px}.user-info-card,.spapi-card{padding:24px}.info-grid{grid-template-columns:1fr;gap:16px}.btn-primary{width:100%}}@media (max-width: 480px){.dashboard-page{padding:20px 12px}.dashboard-header h1{font-size:24px}.user-info-card h2,.spapi-card h2{font-size:18px}.user-info-card,.spapi-card{padding:20px}.info-label{font-size:12px}.info-value,.status-text{font-size:15px}.spapi-description{font-size:13px}}.callback-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.callback-container{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;padding:60px 40px;width:100%;max-width:500px;text-align:center}.callback-processing,.callback-success,.callback-error{display:flex;flex-direction:column;align-items:center;gap:20px}.success-icon,.error-icon{margin-bottom:8px}.redirect-info{font-size:14px;color:#667eea;font-weight:600}.callback-container{animation:fadeInScale .4s ease-out}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.callback-processing,.callback-success,.callback-error{display:flex;flex-direction:column;align-items:center;gap:20px;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.spinner-large{width:60px;height:60px;border:5px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}.success-icon,.error-icon{margin-bottom:8px;animation:scaleIn .5s ease-out}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.callback-container h2{font-size:24px;font-weight:700;color:#1a202c;margin:0}.callback-container p{font-size:16px;color:#718096;line-height:1.6;margin:0}.error-message{color:#c53030}.redirect-info{font-size:14px;color:#667eea;font-weight:600;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.btn-retry{margin-top:12px;padding:12px 32px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.btn-retry:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.btn-retry:active{transform:translateY(0)}@media (max-width: 480px){.callback-container{padding:40px 24px}.callback-container h2{font-size:20px}.callback-container p{font-size:14px}.spinner-large{width:50px;height:50px;border-width:4px}.success-icon svg,.error-icon svg{width:56px;height:56px}.btn-retry{width:100%;padding:11px 24px;font-size:15px}}@keyframes spin{to{transform:rotate(360deg)}}.page-enter{opacity:0;transform:translateY(20px)}.page-enter-active{opacity:1;transform:translateY(0);transition:opacity .3s ease-out,transform .3s ease-out}.page-exit{opacity:1;transform:translateY(0)}.page-exit-active{opacity:0;transform:translateY(-20px);transition:opacity .2s ease-in,transform .2s ease-in}.fade-enter{opacity:0}.fade-enter-active{opacity:1;transition:opacity .3s ease-in}.fade-exit{opacity:1}.fade-exit-active{opacity:0;transition:opacity .2s ease-out}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}html{scroll-behavior:smooth}button,input,a{transition:all .2s ease}button:focus-visible,input:focus-visible,a:focus-visible{outline:2px solid #667eea;outline-offset:2px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.App{padding:0;min-height:100vh}
