/* ICFESSK - Auth and Onboarding Styles */
/* Extracted from pages.css - V7 CSS cleanup */

/* â”€â”€ Auth Pages (Login / Register) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.auth-layout {
  display: flex;
  min-height: 100vh;
  background: var(--bg-primary);
}

.auth-brand {
  flex: 1.22; /* ~55% width */
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 64px;
  background-color: #7235FE;
  background-image: linear-gradient(to right, #7235FE 0%, rgba(114, 53, 254, 0.7) 35%, transparent 60%), url('../assets/images/login.png');
  background-size: cover;
  background-position:10% center;
  background-repeat: no-repeat;
  color: var(--text-inverse);
  position: relative;
  overflow: hidden;
}

.auth-brand-logo {
  position: relative;
  z-index: 10;
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: var(--fw-bold);
  font-size: 1.25rem;
  letter-spacing: 1px;
  width: max-content; /* Previene que el enlace ocupe todo el ancho */
}

.auth-brand-logo-icon {
  width: 32px;
  height: 32px;
  background: rgba(255, 255, 255, 0.2);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.auth-brand-logo-icon span {
  font-size: 20px;
  color: white;
}

.auth-brand-text {
  position: relative;
  z-index: 10;
  margin: auto 0;
  max-width: 460px;
}

.auth-brand-text h1 {
  color: var(--text-inverse);
  font-size: clamp(2.5rem, 5vw, 4rem);
  line-height: 1.05;
  margin-bottom: 24px;
  letter-spacing: -1.5px;
}

.auth-brand-text p {
  color: rgba(255, 255, 255, 0.85);
  font-size: 1.2rem;
  line-height: 1.6;
}

.auth-brand-footer {
  font-size: 0.9rem;
  color: rgba(255, 255, 255, 0.7);
  position: relative;
  z-index: 10;
}

/* Carousel Styles */
.auth-carousel-container {
  flex: 1.22;
  position: relative;
  overflow: hidden;
  background-color: #7545FD;
}

.auth-carousel-slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: right center;
  transform: scale(0.8) translateX(15%); /* Reduces size more and shifts further right */
  transform-origin: center right;
  opacity: 0;
  transition: opacity 1s ease-in-out;
  z-index: 1;
}

.auth-carousel-slide.active {
  opacity: 1;
  z-index: 2;
}

/* Re-implement gradient overlay to perfectly blend image edges */
.auth-carousel-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: 
    /* Left gradient: hides the left edge and provides contrast for text */
    linear-gradient(to right, #7545FD 0%, #7545FD 20%, rgba(117, 69, 253, 0.8) 50%, transparent 80%),
    /* Top gradient: hides the top edge (now needs more coverage due to scale 0.8) */
    linear-gradient(to bottom, #7545FD 0%, #7545FD 12%, transparent 25%),
    /* Bottom gradient: hides the bottom edge */
    linear-gradient(to top, #7545FD 0%, #7545FD 12%, transparent 25%);
  z-index: 3;
  pointer-events: none;
}

/* Original text content positioned over carousel */
.auth-brand-content {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  padding: 64px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  z-index: 4;
  color: var(--text-inverse);
  pointer-events: none; 
}

.auth-brand-content > * {
  pointer-events: auto;
}



.auth-form-panel {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 40px;
  background: #F8F9FC;
  position: relative;
}

.auth-card {
  width: 100%;
  max-width: 520px;
  background: var(--bg-white);
  border-radius: 24px;
  padding: 48px;
  box-shadow: 0 40px 80px -20px rgba(0, 0, 0, 0.06);
}

.auth-card h2 {
  font-size: 2.25rem;
  font-weight: var(--fw-extra);
  letter-spacing: -0.5px;
  margin-bottom: 8px;
}

.auth-subtitle {
  font-size: 1.1rem;
  color: var(--text-secondary);
  margin-bottom: 40px;
}

.auth-card .form-label {
  font-weight: var(--fw-semi);
  color: #444;
  margin-bottom: 8px;
  display: block;
}

.auth-card .form-input {
  background: #FFF;
  border: 1.5px solid #EDF0F5;
  padding: 14px 18px;
  font-size: 1rem;
  border-radius: 12px;
  transition: all 0.2s ease;
}

.auth-card .form-input:focus {
  border-color: var(--violet);
  box-shadow: 0 0 0 4px rgba(108, 43, 255, 0.1);
}

.auth-card .password-wrapper {
  position: relative;
}

.auth-card .password-toggle {
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  cursor: pointer;
  color: var(--text-secondary);
  opacity: 0.6;
}

.auth-social-sep {
  display: flex;
  align-items: center;
  gap: 16px;
  margin: 32px 0;
  color: #ABB2BF;
  font-size: 0.75rem;
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: 1px;
}

.auth-social-sep::before,
.auth-social-sep::after {
  content: '';
  flex: 1;
  height: 1px;
  background: #EEE;
}

.btn-google {
  background: white;
  border: 1.5px solid #EEE;
  color: var(--text-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 14px;
  font-weight: var(--fw-semi);
  border-radius: 12px;
  transition: all 0.2s;
}

.btn-google:hover {
  background: #FAFBFD;
  border-color: #DDD;
}

.btn-google img {
  height: 20px;
  width: 20px;
}

.auth-switch {
  text-align: center;
  font-size: 1rem;
  margin-top: 32px;
  color: var(--text-secondary);
}

.auth-switch a {
  font-weight: var(--fw-bold);
  color: var(--violet);
}

.auth-footer-links {
  margin-top: 48px;
  display: flex;
  gap: 24px;
  font-size: 0.85rem;
  color: #9BABB8;
}

.auth-footer-links a {
  color: inherit;
  transition: color 0.2s;
}

.auth-footer-links a:hover {
  color: var(--text-primary);
}

@media (max-width: 1024px) {
  .auth-layout {
    flex-direction: column;
    height: auto !important;
    overflow-y: auto !important;
  }

  .auth-carousel-container {
    flex: none;
    height: 35vh;
    min-height: 260px;
    width: 100%;
  }

  .auth-carousel-slide {
    transform: scale(1) translateX(0);
    object-position: center;
  }

  .auth-carousel-overlay {
    background: 
      linear-gradient(to top, #7545FD 0%, #7545FD 15%, rgba(117, 69, 253, 0.7) 40%, transparent 100%),
      linear-gradient(to right, #7545FD 0%, rgba(117, 69, 253, 0.4) 40%, transparent 100%);
  }

  .auth-brand-content {
    padding: 24px;
    justify-content: flex-end;
  }

  .auth-brand-logo {
    position: absolute;
    top: 24px;
    left: 24px;
  }

  .auth-brand-footer {
    display: none; /* Hide footer inside carousel on mobile to save space */
  }

  .auth-brand-text {
    margin: 0;
    max-width: 100%;
  }

  .auth-brand-text h1 {
    font-size: 2rem;
    margin-bottom: 8px;
  }

  .auth-brand-text p {
    font-size: 1rem;
    display: none; /* Hide paragraph on smaller tablets/phones to focus on the form */
  }

  .auth-form-panel {
    flex: none;
    min-height: 65vh;
    padding: 32px 16px;
    background: #F8F9FC;
  }

  .auth-card {
    padding: 32px 24px;
    box-shadow: 0 10px 40px -10px rgba(0, 0, 0, 0.08);
  }
}

@media (max-width: 480px) {
  .auth-carousel-container {
    height: 30vh;
    min-height: 220px;
  }

  .auth-brand-text h1 {
    font-size: 1.6rem;
  }

  .auth-card {
    padding: 24px 20px;
  }
  
  .auth-card h2 {
    font-size: 1.8rem;
  }
}


/* â”€â”€ Onboarding â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.onboarding-layout {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: var(--bg-primary);
}

.onboarding-container {
  width: 100%;
  max-width: 600px;
  background: var(--bg-white);
  border-radius: var(--r-lg);
  padding: var(--sp-2xl);
  box-shadow: var(--shadow-md);
}

.onboarding-header {
  text-align: center;
  margin-bottom: var(--sp-2xl);
}

.onboarding-header h1 {
  margin-top: var(--sp-md);
}

.onboarding-header p {
  max-width: 480px;
  margin: var(--sp-sm) auto 0;
}

.score-selector {
  display: flex;
  align-items: center;
  gap: var(--sp-md);
  margin-top: var(--sp-sm);
}

.form-range {
  flex: 1;
  accent-color: var(--violet);
  height: 6px;
}

.score-display {
  font-size: 1.1rem;
  font-weight: var(--fw-bold);
  color: var(--violet);
  min-width: 100px;
  text-align: right;
}

.form-hint {
  font-size: 0.85rem;
  color: var(--text-secondary);
  margin-bottom: var(--sp-sm);
}

.topics-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: var(--sp-sm);
}

.topic-card {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-sm);
  padding: var(--sp-md);
  border: 2px solid var(--border);
  border-radius: var(--r-md);
  cursor: pointer;
  transition: all var(--duration) var(--ease);
}

.topic-card:hover {
  border-color: var(--violet);
}

.topic-card:has(:checked) {
  border-color: var(--violet);
  background: var(--violet-light);
}

.topic-checkbox {
  accent-color: var(--violet);
  margin-top: 3px;
}

.topic-card-body {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.topic-card-body strong {
  font-size: 0.9rem;
}

.topic-card-body small {
  font-size: 0.75rem;
  color: var(--text-secondary);
}


/* â”€â”€ Onboarding Uplift â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.onboarding-top-bar {
  width: 100%;
  padding: var(--sp-md) var(--sp-2xl);
  display: flex;
  justify-content: center;
  border-bottom: 1px solid var(--border);
  background: white;
}

.onboarding-logo {
  height: 28px;
}

.onboarding-center {
  flex: 1;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--sp-3xl) var(--sp-md);
}

.onboarding-frame {
  max-width: 800px;
  width: 100%;
}

.onboarding-section {
  margin-bottom: var(--sp-3xl);
}

.onboarding-section h3 {
  font-size: 1.25rem;
  font-weight: var(--fw-bold);
  margin-bottom: 4px;
}

.onboarding-section-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: var(--sp-lg);
}

.onboarding-score-box {
  background: var(--violet-light);
  color: var(--violet);
  padding: 8px 16px;
  border-radius: var(--r-md);
  font-weight: var(--fw-bold);
  font-size: 1.25rem;
}

.onboarding-score-box small {
  font-size: 0.85rem;
  font-weight: var(--fw-medium);
}

.onboarding-range-labels {
  display: flex;
  justify-content: space-between;
  font-size: 0.75rem;
  color: var(--text-secondary);
  margin-top: 4px;
}

.onboarding-footer {
  display: flex;
  justify-content: flex-end;
  border-top: 1px solid var(--border);
  padding-top: var(--sp-xl);
}

.onboarding-submit {
  padding: 16px 48px;
  box-shadow: 0 10px 15px -3px rgba(108, 43, 255, 0.25);
}

