/* ===================================
   7bit SMS System Bridge - Custom Styles
   Bootstrap 5 Enhanced Design
   Custom Color Palette
   =================================== */

/* Font Imports - Add at the beginning */
@import url('https://cdn.jsdelivr.net/gh/rastikerdar/vazir-font@v30.1.0/dist/font-face.css');
@import url('https://cdn.jsdelivr.net/gh/rastikerdar/shabnam-font@v5.0.1/dist/font-face.css');

/* Variables - Custom Color Palette */
:root {
    --primary-color: #088395;
    --secondary-color: #071952;
    --text-color: #222222;
    --accent-color: #EBF4F6;
    --custom-cyan: #37B7C3;
    --success-color: #23A455;
    --dark-color: #222222;
    --white-color: #FFFFFF;

    /* Additional Colors */
    --danger-color: #dc3545;
    --warning-color: #ffc107;
    --info-color: #0dcaf0;
    --light-gray: #f8f9fa;
    --border-color: #dee2e6;

    /* Shadows and Radius */
    --border-radius: 0.5rem;
    --box-shadow: 0 0.125rem 0.25rem rgba(7, 25, 82, 0.08);
    --box-shadow-lg: 0 0.5rem 1rem rgba(7, 25, 82, 0.12);

    /* Font Families */
    --font-family-title: 'Vazir', sans-serif;
    --font-family-body: 'Shabnam', sans-serif;
}

/* RTL Support */
body {
    direction: rtl;
    text-align: right;
    color: var(--text-color);
    font-family: var(--font-family-body);
}

/* Typography - Headers */
h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: var(--font-family-title);
}

/* Card Styles - Both login and register forms */
.card.faraz-card {
    border: none;
    border-radius: 1.5rem;
    box-shadow: var(--box-shadow-lg);
    overflow: hidden;
    background: var(--white-color);
}

/* Card Header - Updated for white text */
.faraz-card-header {
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--secondary-color) 100%);
    color: var(--white-color);
    padding: 2rem 1.5rem;
    text-align: center;
    border: none;
}

.faraz-card-header h3 {
    margin: 0;
    font-weight: 600;
    font-size: 1.75rem;
    font-family: var(--font-family-title);
    color: var(--white-color) !important;
    /* Force white color */
}

.faraz-card-header p {
    margin: 0.5rem 0 0;
    opacity: 0.95;
    font-size: 0.95rem;
    font-family: var(--font-family-body);
    color: var(--white-color) !important;
    /* Force white color */
}

/* Form Styles */
.faraz-form {
    padding: 2rem;
    font-family: var(--font-family-body);
}

/* Card Body */
.card-body {
    padding: 0;
}

/* Input Group Enhancements - بهبود وضوح فیلدها */
.faraz-input-group {
    position: relative;
    margin-bottom: 1.75rem;
    /* افزایش فاصله بین فیلدها */
}

.faraz-input-group .form-label {
    font-weight: 600;
    /* Bold تر کردن لیبل‌ها */
    color: var(--secondary-color);
    margin-bottom: 0.75rem;
    /* افزایش فاصله لیبل از input */
    font-size: 1rem;
    /* بزرگتر کردن سایز فونت */
    font-family: var(--font-family-body);
}

.faraz-input-group .form-label i {
    color: var(--primary-color);
    margin-left: 0.5rem;
    font-size: 1.1rem;
    /* بزرگتر کردن آیکون‌ها */
}

.faraz-input-group .form-control,
.faraz-input-group .form-select {
    border-radius: 0.75rem;
    /* گردی بیشتر */
    border: 2px solid #c8d6e5;
    /* رنگ border واضح‌تر */
    padding: 1rem 1.25rem;
    /* padding بیشتر برای راحتی */
    font-size: 1.1rem;
    /* فونت بزرگتر */
    transition: all 0.3s ease;
    background-color: #ffffff;
    color: var(--text-color);
    font-family: var(--font-family-body);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.04);
    /* سایه ملایم */
}

/* حالت hover برای فیلدها */
.faraz-input-group .form-control:hover,
.faraz-input-group .form-select:hover {
    border-color: var(--custom-cyan);
    background-color: #fafbfc;
}

/* حالت focus با رنگ واضح‌تر */
.faraz-input-group .form-control:focus,
.faraz-input-group .form-select:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 0.25rem rgba(8, 131, 149, 0.15), 0 4px 8px rgba(0, 0, 0, 0.08);
    background-color: #ffffff;
    outline: none;
}

/* Large inputs برای وضوح بیشتر */
.form-control-lg {
    padding: 1.125rem 1.5rem;
    font-size: 1.125rem;
    border-radius: 0.875rem;
}

/* Input with Icon - بهبود موقعیت آیکون */
.input-with-icon {
    position: relative;
}

.input-with-icon .form-control {
    padding-right: 3.5rem;
    /* فضای بیشتر برای آیکون */
}

.input-with-icon .input-icon {
    position: absolute;
    left: 1.25rem;
    top: 50%;
    transform: translateY(-50%);
    color: #8395a7;
    /* رنگ ملایم‌تر برای آیکون */
    pointer-events: none;
    font-size: 1.25rem;
    transition: color 0.3s ease;
}

/* تغییر رنگ آیکون در focus */
.input-with-icon:focus-within .input-icon {
    color: var(--primary-color);
}

/* Validation States */
.form-control.is-valid {
    border-color: var(--success-color);
    padding-left: 3rem;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3e%3cpath fill='%2323A455' d='M2.3 6.73L.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1z'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: left calc(0.375em + 0.1875rem) center;
    background-size: calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
}

.form-control.is-invalid {
    border-color: var(--danger-color);
    padding-left: 3rem;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' width='12' height='12' fill='none' stroke='%23dc3545'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23dc3545' stroke='none'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: left calc(0.375em + 0.1875rem) center;
    background-size: calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
}

/* Invalid feedback styling */
.invalid-feedback {
    font-size: 0.875rem;
    margin-top: 0.5rem;
    font-family: var(--font-family-body);
    display: flex;
    align-items: center;
}

.invalid-feedback::before {
    content: "⚠";
    margin-left: 0.25rem;
}

/* Button Styles */
.btn-faraz {
    padding: 0.75rem 2rem;
    font-weight: 500;
    border-radius: var(--border-radius);
    transition: all 0.3s ease;
    text-transform: none;
    font-size: 1.1rem;
    font-family: var(--font-family-body);
}

.btn-faraz-primary {
    background: linear-gradient(135deg, var(--primary-color) 0%, var(--secondary-color) 100%);
    border: none;
    color: var(--white-color);
    box-shadow: 0 4px 6px rgba(8, 131, 149, 0.25);
}

.btn-faraz-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 12px rgba(8, 131, 149, 0.35);
    background: linear-gradient(135deg, var(--secondary-color) 0%, var(--primary-color) 100%);
}

.btn-faraz-primary:disabled {
    opacity: 0.65;
    transform: none;
    box-shadow: none;
}

/* Message Alerts */
.faraz-message {
    border-radius: var(--border-radius);
    padding: 1rem 1.25rem;
    margin-bottom: 1.5rem;
    display: flex;
    align-items: center;
    animation: slideDown 0.3s ease-out;
    font-family: var(--font-family-body);
}

.faraz-message .message-icon {
    margin-left: 0.75rem;
    font-size: 1.25rem;
}

.faraz-message.alert-success {
    background-color: rgba(35, 164, 85, 0.1);
    border: 1px solid rgba(35, 164, 85, 0.3);
    color: var(--success-color);
}

.faraz-message.alert-danger {
    background-color: rgba(220, 53, 69, 0.1);
    border: 1px solid rgba(220, 53, 69, 0.3);
    color: var(--danger-color);
}

/* Verification Code Section */
.verification-section {
    background-color: var(--accent-color);
    border-radius: var(--border-radius);
    padding: 1.5rem;
    margin-top: 1.5rem;
    border: 2px dashed var(--custom-cyan);
}

.verification-section .form-label {
    color: var(--secondary-color);
    font-weight: 600;
}

/* Verification Code Input - واضح‌تر */
#login-code,
#register-code {
    font-size: 1.5rem;
    letter-spacing: 0.5rem;
    font-weight: 600;
    text-align: center;
    padding: 1rem;
}

/* Timer Display */
.timer-display {
    text-align: center;
    color: var(--secondary-color);
    font-size: 0.9rem;
    margin-top: 1rem;
    font-family: var(--font-family-body);
}

.timer-display .timer-count {
    font-weight: 600;
    color: var(--primary-color);
}

/* Loading Spinner */
.btn-loading {
    position: relative;
    color: transparent;
}

.btn-loading::after {
    content: "";
    position: absolute;
    width: 1rem;
    height: 1rem;
    top: 50%;
    left: 50%;
    margin-left: -0.5rem;
    margin-top: -0.5rem;
    border: 2px solid var(--white-color);
    border-radius: 50%;
    border-top-color: transparent;
    animation: spinner 0.8s linear infinite;
}

/* Form Check */
.form-check-input:checked {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
}

.form-check-input:focus {
    border-color: var(--custom-cyan);
    box-shadow: 0 0 0 0.25rem rgba(8, 131, 149, 0.25);
}

.form-check-label {
    font-family: var(--font-family-body);
}

/* Links */
.form-link {
    color: var(--primary-color);
    text-decoration: none;
    font-weight: 500;
    transition: color 0.3s ease;
    font-family: var(--font-family-body);
}

.form-link:hover {
    color: var(--secondary-color);
    text-decoration: underline;
}

/* Placeholder Styles - واضح‌تر */
.form-control::placeholder,
.form-select::placeholder {
    color: #a8b3bd;
    opacity: 1;
    font-size: 0.95rem;
}

/* بهبود Select Arrow */
.form-select {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%238395a7' stroke-linecap='round' stroke-linejoin='round' stroke-width='2.5' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
    background-size: 18px;
    padding-left: 1.25rem;
}

.form-select:focus {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23088395' stroke-linecap='round' stroke-linejoin='round' stroke-width='2.5' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
}

/* افزودن انیمیشن برای focus */
.faraz-input-group .form-control,
.faraz-input-group .form-select {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Label animation on focus */
.faraz-input-group:focus-within .form-label {
    color: var(--primary-color);
    transform: translateY(-2px);
    transition: all 0.3s ease;
}

/* Text elements */
p,
span,
div {
    font-family: var(--font-family-body);
}

/* Animations */
@keyframes slideDown {
    from {
        opacity: 0;
        transform: translateY(-1rem);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes spinner {
    to {
        transform: rotate(360deg);
    }
}

/* Responsive Design */
@media (max-width: 576px) {
    .card.faraz-card {
        margin: 0 1rem;
        border-radius: 1rem;
    }

    .faraz-form {
        padding: 1.5rem;
    }

    .faraz-card-header {
        padding: 1.5rem 1rem;
    }

    .faraz-card-header h3 {
        font-size: 1.5rem;
    }

    .faraz-input-group .form-control,
    .faraz-input-group .form-select {
        font-size: 16px;
        /* جلوگیری از zoom در موبایل */
    }
}

/* Dark Mode Support */
@media (prefers-color-scheme: dark) {
    .card.faraz-card {
        background: rgba(34, 34, 34, 0.95);
        color: var(--white-color);
        border-color: rgba(55, 183, 195, 0.2);
    }

    .faraz-input-group .form-label {
        color: var(--accent-color);
    }

    .faraz-input-group .form-control,
    .faraz-input-group .form-select {
        background-color: #2a2a2a;
        border-color: #444;
        color: var(--white-color);
    }

    .faraz-input-group .form-control:hover,
    .faraz-input-group .form-select:hover {
        background-color: #333;
        border-color: #555;
    }

    .faraz-input-group .form-control:focus,
    .faraz-input-group .form-select:focus {
        background-color: #2a2a2a;
        border-color: var(--custom-cyan);
    }

    .verification-section {
        background-color: rgba(55, 183, 195, 0.1);
        border-color: var(--custom-cyan);
    }

    .input-with-icon .input-icon {
        color: #a8b3bd;
    }

    .input-with-icon:focus-within .input-icon {
        color: var(--custom-cyan);
    }
}

.wrap h1 {
    margin-bottom: 20px;
}