/**
 * MTM Unified Register - Modal & Role Cards Styles
 *
 * @package MTM_Pro
 * @since 3.9.305
 */

/* ==========================================================================
   Variables
   ========================================================================== */

:root {
    --mtm-register-primary: #14b8a6;
    --mtm-register-primary-hover: #0d9488;
    --mtm-register-success: #10b981;
    --mtm-register-success-hover: #059669;
    --mtm-register-warning: #f59e0b;
    --mtm-register-text: #1f2937;
    --mtm-register-text-muted: #6b7280;
    --mtm-register-border: #e5e7eb;
    --mtm-register-bg: #ffffff;
    --mtm-register-bg-hover: #f9fafb;
    --mtm-register-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    --mtm-register-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
    --mtm-register-radius: 12px;
    --mtm-register-radius-lg: 16px;
}

/* ==========================================================================
   Body Lock (when modal is open)
   ========================================================================== */

body.mtm-modal-open {
    overflow: hidden;
}

/* ==========================================================================
   Register Button
   ========================================================================== */

.mtm-register-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 24px;
    background: var(--mtm-register-primary);
    color: #fff !important;
    border: none;
    border-radius: 8px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
    text-decoration: none !important;
}

.mtm-register-btn:hover {
    background: var(--mtm-register-primary-hover);
    transform: translateY(-1px);
    box-shadow: var(--mtm-register-shadow);
}

/* ==========================================================================
   Modal Overlay
   ========================================================================== */

.mtm-register-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 999999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.mtm-register-modal-backdrop {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(4px);
}

/* ==========================================================================
   Modal Container
   ========================================================================== */

.mtm-register-modal-container {
    position: relative;
    width: 100%;
    max-width: 900px;
    max-height: 90vh;
    background: var(--mtm-register-bg);
    border-radius: var(--mtm-register-radius-lg);
    box-shadow: var(--mtm-register-shadow-lg);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    animation: mtmModalSlideIn 0.3s ease;
}

@keyframes mtmModalSlideIn {
    from {
        opacity: 0;
        transform: translateY(-20px) scale(0.95);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.mtm-register-modal-close {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: none;
    border-radius: 50%;
    cursor: pointer;
    color: var(--mtm-register-text-muted);
    transition: all 0.2s ease;
    z-index: 10;
}

.mtm-register-modal-close:hover {
    background: var(--mtm-register-bg-hover);
    color: var(--mtm-register-text);
}

.mtm-register-modal-content {
    flex: 1;
    overflow-y: auto;
    padding: 40px;
}

/* ==========================================================================
   Modal Header
   ========================================================================== */

.mtm-register-modal-header,
.mtm-register-header {
    text-align: center;
    margin-bottom: 32px;
}

.mtm-register-modal-header h2,
.mtm-register-header h2 {
    margin: 0 0 8px 0;
    font-size: 16px;
    font-weight: 600;
    color: var(--mtm-register-text);
}

.mtm-register-modal-header p,
.mtm-register-header p {
    margin: 0;
    font-size: 16px;
    color: var(--mtm-register-text-muted);
}

/* ==========================================================================
   Role Cards Grid
   ========================================================================== */

.mtm-role-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

@media (max-width: 768px) {
    .mtm-role-cards {
        grid-template-columns: 1fr;
        gap: 16px;
    }
}

/* ==========================================================================
   Role Card
   ========================================================================== */

.mtm-role-card {
    background: var(--mtm-register-bg);
    border: 2px solid var(--mtm-register-border);
    border-radius: var(--mtm-register-radius);
    padding: 28px 24px;
    text-align: center;
    cursor: pointer;
    transition: all 0.25s ease;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.mtm-role-card:hover {
    border-color: var(--mtm-register-primary);
    box-shadow: var(--mtm-register-shadow);
    transform: translateY(-4px);
}

.mtm-role-card:hover .mtm-role-icon {
    transform: scale(1.1);
    color: var(--mtm-register-primary);
}

/* Role Icon */
.mtm-role-icon {
    width: 64px;
    height: 64px;
    margin-bottom: 16px;
    color: var(--mtm-register-text-muted);
    transition: all 0.25s ease;
}

.mtm-role-icon svg {
    width: 100%;
    height: 100%;
}

/* Role Title */
.mtm-role-title {
    margin: 0 0 8px 0;
    font-size: 20px;
    font-weight: 600;
    color: var(--mtm-register-text);
}

/* Role Description */
.mtm-role-description {
    margin: 0 0 16px 0;
    font-size: 14px;
    color: var(--mtm-register-text-muted);
    line-height: 1.5;
}

/* Role Features */
.mtm-role-features {
    list-style: none;
    padding: 0;
    margin: 0 0 20px 0;
    text-align: left;
    width: 100%;
}

.mtm-role-features li {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 0;
    font-size: 13px;
    color: var(--mtm-register-text-muted);
}

.mtm-role-features li svg {
    flex-shrink: 0;
    color: var(--mtm-register-success);
}

/* Select Role Button */
.mtm-btn-select-role {
    width: 100%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 20px;
    background: linear-gradient(135deg, #14b8a6 0%, #22c55e 100%);
    color: #fff !important;
    border: none;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
    margin-top: auto;
    box-shadow: 0 2px 6px rgba(20, 184, 166, 0.3);
}

.mtm-btn-select-role:hover {
    background: linear-gradient(135deg, #0d9488 0%, #16a34a 100%);
    box-shadow: 0 4px 10px rgba(20, 184, 166, 0.4);
    transform: translateY(-1px);
}

.mtm-btn-select-role svg {
    transition: transform 0.2s ease;
}

.mtm-btn-select-role:hover svg {
    transform: translateX(4px);
}

/* Card Loading State */
.mtm-role-card-loading {
    opacity: 0.7;
    pointer-events: none;
    transform: scale(0.98);
}

.mtm-role-card-loading .mtm-btn-select-role {
    background: #94a3b8 !important;
    cursor: wait !important;
}

/* Prevent Avada first-click focus stealing */
.mtm-role-card,
.mtm-role-card * {
    -webkit-user-select: none;
    user-select: none;
    -webkit-tap-highlight-color: transparent;
}

/* ==========================================================================
   Form Container
   ========================================================================== */

.mtm-register-modal-form,
.mtm-register-form-container {
    width: 100%;
}

/* Back Button */
.mtm-back-to-roles {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    margin-bottom: 24px;
    background: transparent;
    border: 1px solid var(--mtm-register-border);
    border-radius: 8px;
    font-size: 14px;
    font-weight: 500;
    color: var(--mtm-register-text-muted);
    cursor: pointer;
    transition: all 0.2s ease;
}

.mtm-back-to-roles:hover {
    background: var(--mtm-register-bg-hover);
    color: var(--mtm-register-text);
    border-color: var(--mtm-register-text-muted);
}

.mtm-back-to-roles svg {
    transition: transform 0.2s ease;
}

.mtm-back-to-roles:hover svg {
    transform: translateX(-4px);
}

/* ==========================================================================
   Loading State
   ========================================================================== */

.mtm-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 60px 20px;
    text-align: center;
}

.mtm-loading .mtm-spinner {
    width: 40px;
    height: 40px;
    border: 3px solid var(--mtm-register-border);
    border-top-color: var(--mtm-register-primary);
    border-radius: 50%;
    animation: mtmSpin 0.8s linear infinite;
    margin-bottom: 16px;
}

@keyframes mtmSpin {
    to {
        transform: rotate(360deg);
    }
}

.mtm-loading p {
    margin: 0;
    font-size: 14px;
    color: var(--mtm-register-text-muted);
}

/* ==========================================================================
   Page Mode Styles
   ========================================================================== */

.mtm-register-page {
    max-width: 900px;
    margin: 0 auto;
    padding: 40px 20px;
}

.mtm-register-page .mtm-register-header {
    margin-bottom: 40px;
}

.mtm-register-page .mtm-register-header h2 {
    font-size: 32px;
}

/* ==========================================================================
   Error State
   ========================================================================== */

.mtm-error {
    background: #fef2f2;
    border: 1px solid #fecaca;
    color: #dc2626;
    padding: 16px 20px;
    border-radius: 8px;
    text-align: center;
    font-size: 14px;
}

/* ==========================================================================
   Notice
   ========================================================================== */

.mtm-notice {
    padding: 20px 24px;
    border-radius: var(--mtm-register-radius);
    text-align: center;
}

.mtm-notice-info {
    background: #eff6ff;
    border: 1px solid #bfdbfe;
    color: #1e40af;
}

.mtm-notice p {
    margin: 0 0 16px 0;
}

.mtm-notice .mtm-btn {
    display: inline-flex;
}

/* ==========================================================================
   Form Adjustments in Modal
   ========================================================================== */

.mtm-register-modal-form .mtm-registration,
.mtm-register-form-container .mtm-registration {
    max-width: 100%;
    margin: 0;
    padding: 0;
    background: transparent;
    box-shadow: none;
}

.mtm-register-modal-form .mtm-registration-header,
.mtm-register-form-container .mtm-registration-header {
    margin-bottom: 24px;
}

/* ==========================================================================
   Responsive Adjustments
   ========================================================================== */

@media (max-width: 600px) {
    .mtm-register-modal-container {
        max-height: 100vh;
        border-radius: 0;
    }

    .mtm-register-modal-content {
        padding: 24px 16px;
    }

    .mtm-register-modal-header h2,
    .mtm-register-header h2 {
        font-size: 16px;
    }

    .mtm-role-card {
        padding: 20px 16px;
    }

    .mtm-role-icon {
        width: 48px;
        height: 48px;
    }

    .mtm-role-title {
        font-size: 18px;
    }
}

/* ==========================================================================
   Avada/Theme Overrides
   ========================================================================== */

.mtm-register-modal,
.mtm-register-page {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

.mtm-register-modal *,
.mtm-register-page * {
    box-sizing: border-box;
}

.mtm-role-card,
.mtm-role-card * {
    text-decoration: none !important;
}

/* Fix for Avada buttons */
.mtm-register-modal .mtm-btn,
.mtm-register-page .mtm-btn {
    line-height: 1.4;
    letter-spacing: 0;
    text-transform: none;
}

/* ==========================================================================
   Compact Mode (for off-canvas, widgets, sidebars)
   ========================================================================== */

.mtm-register-compact {
    padding: 16px 0;
}

.mtm-register-compact-header {
    text-align: center;
    margin-bottom: 16px;
}

.mtm-register-compact-header h3 {
    margin: 0 0 4px 0;
    font-size: 18px;
    font-weight: 600;
    color: inherit;
}

.mtm-register-compact-header p {
    margin: 0;
    font-size: 13px;
    opacity: 0.8;
    color: inherit;
}

.mtm-register-compact-roles {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.mtm-compact-role-btn {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 8px;
    color: inherit !important;
    text-decoration: none !important;
    font-size: 14px;
    font-weight: 500;
    transition: all 0.2s ease;
}

.mtm-compact-role-btn:hover {
    background: rgba(255, 255, 255, 0.15);
    border-color: rgba(255, 255, 255, 0.3);
    transform: translateX(4px);
}

.mtm-compact-role-btn svg {
    flex-shrink: 0;
    opacity: 0.8;
}

.mtm-compact-role-btn span {
    flex: 1;
}

/* Light theme variant for compact mode */
.mtm-register-compact.mtm-light,
body:not(.fusion-sliding-bar) .mtm-register-compact {
    color: var(--mtm-register-text);
}

.mtm-register-compact.mtm-light .mtm-compact-role-btn,
body:not(.awb-off-canvas):not(.fusion-sliding-bar) .mtm-register-compact .mtm-compact-role-btn {
    background: #f9fafb;
    border-color: #e5e7eb;
    color: var(--mtm-register-text) !important;
}

.mtm-register-compact.mtm-light .mtm-compact-role-btn:hover,
body:not(.awb-off-canvas):not(.fusion-sliding-bar) .mtm-register-compact .mtm-compact-role-btn:hover {
    background: #f3f4f6;
    border-color: var(--mtm-register-primary);
}

/* ==========================================================================
   Avada Off-Canvas Specific Styles
   ========================================================================== */

.awb-off-canvas .mtm-register-compact,
.fusion-sliding-bar .mtm-register-compact,
.off-canvas .mtm-register-compact {
    padding: 10px 0;
    color: inherit;
}

.awb-off-canvas .mtm-register-compact-header h3,
.fusion-sliding-bar .mtm-register-compact-header h3,
.off-canvas .mtm-register-compact-header h3 {
    font-size: 16px;
    color: inherit;
}

.awb-off-canvas .mtm-compact-role-btn,
.fusion-sliding-bar .mtm-compact-role-btn,
.off-canvas .mtm-compact-role-btn {
    padding: 12px 14px;
    font-size: 13px;
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.15);
}

.awb-off-canvas .mtm-compact-role-btn:hover,
.fusion-sliding-bar .mtm-compact-role-btn:hover,
.off-canvas .mtm-compact-role-btn:hover {
    background: rgba(255, 255, 255, 0.12);
    border-color: rgba(255, 255, 255, 0.25);
}

/* If off-canvas has light background */
.awb-off-canvas[data-theme="light"] .mtm-compact-role-btn,
.fusion-sliding-bar[data-theme="light"] .mtm-compact-role-btn {
    background: #f3f4f6;
    border-color: #e5e7eb;
    color: #1f2937 !important;
}

.awb-off-canvas[data-theme="light"] .mtm-compact-role-btn:hover,
.fusion-sliding-bar[data-theme="light"] .mtm-compact-role-btn:hover {
    background: #e5e7eb;
    border-color: #d1d5db;
}

/* Ensure compact mode inherits text color from parent */
.awb-off-canvas .mtm-register-compact,
.awb-off-canvas .mtm-register-compact *,
.fusion-sliding-bar .mtm-register-compact,
.fusion-sliding-bar .mtm-register-compact * {
    color: inherit;
}
