.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%}}.spapi-monitoring-section{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;padding:32px;margin-bottom:24px;animation:fadeInUp .5s ease-out;transition:transform .2s ease,box-shadow .2s ease}.spapi-monitoring-section:hover{transform:translateY(-2px);box-shadow:0 12px 48px #00000026}.spapi-monitoring-section h2{font-size:20px;font-weight:700;color:#1a202c;margin:0 0 24px}.monitoring-loading,.monitoring-error{text-align:center;padding:40px 20px}.monitoring-loading .spinner{width:32px;height:32px;margin:0 auto 12px;border:3px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}.monitoring-loading p{color:#718096;font-size:14px;margin:0}.monitoring-error{background-color:#fed7d7;border:1px solid #fc8181;border-radius:8px;color:#c53030;padding:16px;font-size:14px}.monitoring-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:24px}.monitoring-card{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;padding:20px;transition:all .2s ease}.monitoring-card:hover{border-color:#cbd5e0;box-shadow:0 4px 12px #0000000d}.monitoring-card h3{font-size:14px;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.5px;margin:0 0 16px}.status-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:600;margin-bottom:12px}.status-badge-dot{width:8px;height:8px;border-radius:50%}.status-badge.status-authorized{background-color:#c6f6d5;color:#22543d}.status-badge.status-authorized .status-badge-dot{background-color:#38a169;animation:pulse 2s ease-in-out infinite}.status-badge.status-not-authorized{background-color:#fed7d7;color:#742a2a}.status-badge.status-not-authorized .status-badge-dot{background-color:#e53e3e}.status-badge.status-reauth-required{background-color:#feebc8;color:#7c2d12}.status-badge.status-reauth-required .status-badge-dot{background-color:#dd6b20;animation:pulse 2s ease-in-out infinite}.status-badge.status-running{background-color:#c6f6d5;color:#22543d}.status-badge.status-running .status-badge-dot{background-color:#38a169;animation:pulse 2s ease-in-out infinite}.status-badge.status-stopped{background-color:#e2e8f0;color:#2d3748}.status-badge.status-stopped .status-badge-dot{background-color:#718096}.card-content{color:#2d3748;font-size:14px;line-height:1.6}.card-content p{margin:8px 0}.card-content strong{font-weight:600;color:#1a202c}.expiration-warning{background-color:#feebc8;border:1px solid #f6ad55;border-radius:6px;padding:12px;margin-top:12px;color:#7c2d12;font-size:13px;font-weight:500}.btn-reauthorize{margin-top:12px;padding:10px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;width:100%}.btn-reauthorize:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.btn-reauthorize:active{transform:translateY(0)}.btn-reauthorize:disabled{opacity:.6;cursor:not-allowed}.marketplace-list{list-style:none;padding:0;margin:0}.marketplace-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;margin-bottom:8px;font-size:13px;color:#2d3748}.marketplace-badge{background-color:#667eea;color:#fff;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600}.error-list,.warning-list{list-style:none;padding:0;margin:0}.error-item,.warning-item{padding:10px 12px;border-radius:6px;margin-bottom:8px;font-size:13px;line-height:1.5}.error-item:last-child,.warning-item:last-child{margin-bottom:0}.error-item{background-color:#fed7d7;border:1px solid #fc8181;color:#742a2a}.warning-item{background-color:#feebc8;border:1px solid #f6ad55;color:#7c2d12}.error-timestamp,.warning-timestamp{display:block;font-size:11px;margin-top:4px;opacity:.8}.no-items-message{text-align:center;padding:20px;color:#718096;font-size:13px;font-style:italic}.refresh-history-section{margin-top:24px}.refresh-history-section h3{font-size:16px;font-weight:600;color:#1a202c;margin:0 0 16px}.refresh-history-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.refresh-history-table thead{background-color:#f7fafc}.refresh-history-table th{padding:12px 16px;text-align:left;font-size:12px;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e2e8f0}.refresh-history-table td{padding:12px 16px;font-size:13px;color:#2d3748;border-bottom:1px solid #e2e8f0}.refresh-history-table tbody tr:last-child td{border-bottom:none}.event-type-badge{display:inline-block;padding:4px 10px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.event-type-badge.type-automatic{background-color:#bee3f8;color:#2c5282}.event-type-badge.type-manual{background-color:#d6bcfa;color:#44337a}.table-status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:4px;font-size:11px;font-weight:600}.table-status-badge.status-success{background-color:#c6f6d5;color:#22543d}.table-status-badge.status-failure{background-color:#fed7d7;color:#742a2a}.table-status-dot{width:6px;height:6px;border-radius:50%}.table-status-badge.status-success .table-status-dot{background-color:#38a169}.table-status-badge.status-failure .table-status-dot{background-color:#e53e3e}.error-message-cell{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#e53e3e;font-size:12px}@media (max-width: 768px){.spapi-monitoring-section{padding:24px}.monitoring-cards-grid{grid-template-columns:1fr;gap:16px}.refresh-history-table{font-size:12px}.refresh-history-table th,.refresh-history-table td{padding:10px 12px}.refresh-history-table thead{display:none}.refresh-history-table,.refresh-history-table tbody,.refresh-history-table tr,.refresh-history-table td{display:block;width:100%}.refresh-history-table tr{margin-bottom:16px;border:1px solid #e2e8f0;border-radius:8px;padding:12px;background:#fff}.refresh-history-table td{padding:8px 0;border:none;text-align:left}.refresh-history-table td:before{content:attr(data-label);display:block;font-weight:600;color:#718096;font-size:11px;text-transform:uppercase;margin-bottom:4px}.error-message-cell{max-width:100%;white-space:normal}}@media (max-width: 480px){.spapi-monitoring-section{padding:20px}.spapi-monitoring-section h2{font-size:18px}.monitoring-card{padding:16px}.status-badge{font-size:13px;padding:6px 12px}.btn-reauthorize{padding:8px 16px;font-size:13px}}.reauthorize-button{margin-top:12px;padding:10px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;width:100%}.reauthorize-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.reauthorize-button:active{transform:translateY(0)}.reauthorize-button:disabled{opacity:.6;cursor:not-allowed}.revoke-button{margin-top:8px;padding:10px 20px;background:linear-gradient(135deg,#e53e3e,#c53030);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;width:100%}.revoke-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #e53e3e66}.revoke-button:active{transform:translateY(0)}.revoke-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.monitoring-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.monitoring-header h2{margin:0}.last-updated{font-size:12px;color:#718096}.monitoring-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:24px}.card-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.card-header h3{margin:0;font-size:14px;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.5px}.status-indicator{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px}.status-indicator.status-green{background-color:#c6f6d5;color:#22543d}.status-indicator.status-red{background-color:#fed7d7;color:#742a2a}.status-indicator.status-gray{background-color:#e2e8f0;color:#718096}.status-indicator.status-yellow{background-color:#feebc8;color:#7c2d12}.card-body{color:#2d3748}.status-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #e2e8f0}.status-row:last-of-type{border-bottom:none}.status-row .label{font-size:13px;color:#718096}.status-row .value{font-size:13px;font-weight:600;color:#2d3748}.status-row .value.status-green{color:#22543d}.status-row .value.status-red{color:#742a2a}.status-row .value.status-gray{color:#718096}.empty-state{text-align:center;padding:20px;color:#718096;font-size:13px;font-style:italic}.loading-indicator{text-align:center;padding:40px 20px;color:#718096;font-size:14px}.error-banner{display:flex;align-items:center;gap:8px;background-color:#fed7d7;border:1px solid #fc8181;border-radius:8px;color:#c53030;padding:16px;font-size:14px;margin-bottom:16px}.error-icon{font-size:18px}.warning-banner{display:flex;align-items:center;gap:8px;background-color:#feebc8;border:1px solid #f6ad55;border-radius:6px;padding:12px;margin-top:12px;color:#7c2d12;font-size:13px;font-weight:500}.warning-icon{font-size:16px}.retry-button{padding:10px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.retry-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:4px;font-size:11px;font-weight:600}.status-badge.status-green{background-color:#c6f6d5;color:#22543d}.status-badge.status-red{background-color:#fed7d7;color:#742a2a}.marketplace-item{padding:12px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;margin-bottom:8px}.marketplace-item:last-child{margin-bottom:0}.marketplace-name{font-weight:600;color:#2d3748;margin-bottom:4px}.primary-badge{display:inline-block;margin-left:8px;padding:2px 8px;background-color:#667eea;color:#fff;border-radius:4px;font-size:10px;font-weight:600;text-transform:uppercase}.marketplace-details{display:flex;gap:16px;font-size:12px;color:#718096}.errors-warnings-section{margin-bottom:24px}.errors-list,.warnings-list{margin-bottom:12px}.error-item,.warning-item{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:6px;margin-bottom:8px}.error-item{background-color:#fed7d7;border:1px solid #fc8181}.warning-item{background-color:#feebc8;border:1px solid #f6ad55}.error-content,.warning-message{flex:1}.error-message{color:#742a2a;font-size:14px}.error-action-button{margin-top:8px;padding:6px 12px;background:#c53030;color:#fff;border:none;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer}.refresh-history-card{margin-top:24px}.table-container{overflow-x:auto}.refresh-history-table{width:100%;border-collapse:collapse;font-size:13px}.refresh-history-table th,.refresh-history-table td{padding:12px;text-align:left;border-bottom:1px solid #e2e8f0}.refresh-history-table th{background-color:#f7fafc;font-weight:600;color:#718096;text-transform:uppercase;font-size:11px;letter-spacing:.5px}.refresh-history-table tbody tr:hover{background-color:#f7fafc}.success-text{color:#22543d}.error-text{color:#c53030}.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,.mpwr-access-card{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;padding:32px;margin-bottom:24px}.user-info-card h2,.spapi-card h2,.mpwr-access-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,.mpwr-description{color:#718096;font-size:14px;line-height:1.6;margin:0 0 24px}.mpwr-access-card{background:linear-gradient(135deg,#f7fafc,#edf2f7);border:2px solid #e2e8f0}.mpwr-access-card h2{color:#2d3748}.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,.mpwr-access-card{animation:fadeInUp .5s ease-out;transition:transform .2s ease,box-shadow .2s ease}.user-info-card:hover,.spapi-card:hover,.mpwr-access-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,.mpwr-access-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}
