/* ==========================================================================
   DEVISE PAGE LAYOUT
   ========================================================================== */

.devise-page {
  min-height: 100vh;
  background: var(--bg-color);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-xl);
  padding-top: calc(var(--header-height) + var(--spacing-xl));
  width: 100vw !important;
  height: 100vh !important;
  margin: 0 !important;
  box-sizing: border-box !important;
}

/* Override main application layout for Devise pages */
.devise-page #main-content {
  display: block !important;
  grid-template-columns: none !important;
  width: 100vw !important;
  height: 100vh !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* ==========================================================================
   DEVISE CARD CONTAINER
   ========================================================================== */

.devise-card {
  background: var(--white) !important;
  border-radius: var(--border-radius-medium) !important;
  box-shadow: var(--card-shadow) !important;
  padding: var(--spacing-xxl) var(--spacing-xl) !important;
  width: 100% !important;
  max-width: 400px !important;
}

/* ==========================================================================
   DEVISE FORM SPECIFIC LAYOUTS
   ========================================================================== */

.devise-form {
  width: 100%;
}

.devise-form .form-actions .btn {
  width: 100%;
  margin-bottom: var(--spacing-sm);
}

.devise-form .form-actions.form-actions-split .btn {
  flex: 1;
  width: auto;
  margin-bottom: 0;
}

/* ==========================================================================
   DEVISE FOOTER
   ========================================================================== */

.devise-footer {
  text-align: center;
  margin-top: var(--spacing-xl);
  padding-top: var(--spacing-lg);
  border-top: 1px solid var(--light-gray);
}

.devise-footer p {
  color: #666;
  font-size: var(--font-size-base);
  margin: 0 0 var(--spacing-sm) 0;
}

.devise-footer p:last-child {
  margin-bottom: 0;
}

/* ==========================================================================
   BACKWARD COMPATIBILITY OVERRIDES
   For existing Devise views that haven't been updated to use new classes
   ========================================================================== */

.devise-container {
  margin-left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  padding: var(--spacing-xl);
  padding-top: calc(var(--header-height) + var(--spacing-xl));
  background: var(--bg-color);
}

.devise-container form {
  background: var(--white);
  border-radius: var(--border-radius-medium);
  box-shadow: var(--card-shadow);
  padding: var(--spacing-xxl) var(--spacing-xl);
  width: 100%;
  max-width: 400px;
}

/* Legacy form input styles - these extend the shared components */
.devise-container form input[type=email],
.devise-container form input[type=password],
.devise-container form input[type=text] {
  margin-bottom: var(--spacing-lg);
}

.devise-container form input[type=submit] {
  width: 100%;
  margin-top: var(--spacing-md);
  margin-bottom: var(--spacing-lg);
}

/* ==========================================================================
   MOBILE RESPONSIVENESS
   ========================================================================== */

@media (max-width: 768px) {
  .devise-page,
  .devise-container {
    padding: var(--spacing-lg);
    padding-top: calc(var(--header-height) + var(--spacing-lg));
  }
  
  .devise-card,
  .devise-container form {
    padding: var(--spacing-xl) var(--spacing-lg);
  }
  
  .form-actions.form-actions-split {
    flex-direction: column;
  }
  
  .form-actions.form-actions-split .btn {
    width: 100%;
    margin-bottom: var(--spacing-sm);
  }
}
