/* Rasan Booking Brand Styles */

/* Brand Color Palette */
:root {
    --rasan-primary: #2563eb;
    --rasan-primary-dark: #1d4ed8;
    --rasan-primary-light: #3b82f6;
    --rasan-secondary: #1e40af;
    --rasan-accent: #0ea5e9;
    --rasan-success: #10b981;
    --rasan-warning: #f59e0b;
    --rasan-error: #ef4444;
    --rasan-dark: #1e293b;
    --rasan-light: #f8fafc;
    --rasan-gray: #6b7280;
}

/* Brand Typography */
.rasan-title {
    font-family: 'Noto Sans Arabic', 'Inter', system-ui, sans-serif;
    font-weight: 700;
    color: var(--rasan-dark);
}

.rasan-subtitle {
    font-family: 'Noto Sans Arabic', 'Inter', system-ui, sans-serif;
    font-weight: 500;
    color: var(--rasan-gray);
}

/* Logo Variants */
.rasan-logo {
    transition: all 0.3s ease;
}

.rasan-logo:hover {
    transform: scale(1.05);
    filter: brightness(1.1);
}

.rasan-logo-sm {
    height: 2rem;
    width: auto;
}

.rasan-logo-md {
    height: 2.5rem;
    width: auto;
}

.rasan-logo-lg {
    height: 4rem;
    width: auto;
}

.rasan-logo-xl {
    height: 6rem;
    width: auto;
}

/* Brand Buttons */
.rasan-btn-primary {
    background: linear-gradient(135deg, var(--rasan-primary) 0%, var(--rasan-primary-dark) 100%);
    border: none;
    color: white;
    padding: 0.75rem 1.5rem;
    border-radius: 0.5rem;
    font-weight: 600;
    transition: all 0.3s ease;
    box-shadow: 0 4px 6px -1px rgba(37, 99, 235, 0.1);
}

.rasan-btn-primary:hover {
    background: linear-gradient(135deg, var(--rasan-primary-dark) 0%, var(--rasan-secondary) 100%);
    transform: translateY(-1px);
    box-shadow: 0 8px 15px -3px rgba(37, 99, 235, 0.2);
}

.rasan-btn-secondary {
    background: white;
    border: 2px solid var(--rasan-primary);
    color: var(--rasan-primary);
    padding: 0.75rem 1.5rem;
    border-radius: 0.5rem;
    font-weight: 600;
    transition: all 0.3s ease;
}

.rasan-btn-secondary:hover {
    background: var(--rasan-primary);
    color: white;
    transform: translateY(-1px);
}

/* Brand Cards */
.rasan-card {
    background: white;
    border-radius: 1rem;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
    border: 1px solid rgba(37, 99, 235, 0.1);
    transition: all 0.3s ease;
}

.rasan-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 25px -3px rgba(0, 0, 0, 0.1);
}

.rasan-card-header {
    background: linear-gradient(135deg, var(--rasan-primary) 0%, var(--rasan-primary-dark) 100%);
    color: white;
    padding: 1.5rem;
    border-radius: 1rem 1rem 0 0;
}

/* Brand Gradients */
.rasan-gradient {
    background: linear-gradient(135deg, var(--rasan-primary) 0%, var(--rasan-primary-dark) 100%);
}

.rasan-gradient-light {
    background: linear-gradient(135deg, #dbeafe 0%, #bfdbfe 100%);
}

.rasan-gradient-hero {
    background: linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 100%);
}

/* Brand Animations */
@keyframes rasan-pulse {
    0%, 100% {
        opacity: 1;
    }
    50% {
        opacity: 0.8;
    }
}

.rasan-pulse {
    animation: rasan-pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

@keyframes rasan-bounce {
    0%, 100% {
        transform: translateY(-25%);
        animation-timing-function: cubic-bezier(0.8, 0, 1, 1);
    }
    50% {
        transform: translateY(0);
        animation-timing-function: cubic-bezier(0, 0, 0.2, 1);
    }
}

.rasan-bounce {
    animation: rasan-bounce 1s infinite;
}

/* Brand Status Colors */
.rasan-status-pending {
    background-color: #fef3c7;
    color: #92400e;
    border-color: #fcd34d;
}

.rasan-status-approved {
    background-color: #d1fae5;
    color: #065f46;
    border-color: #34d399;
}

.rasan-status-rejected {
    background-color: #fee2e2;
    color: #991b1b;
    border-color: #f87171;
}

.rasan-status-completed {
    background-color: #e0e7ff;
    color: #3730a3;
    border-color: #8b5cf6;
}

/* Brand Navigation */
.rasan-nav {
    background: linear-gradient(135deg, var(--rasan-primary) 0%, var(--rasan-secondary) 100%);
    backdrop-filter: blur(10px);
}

.rasan-nav-link {
    color: rgba(255, 255, 255, 0.8);
    transition: all 0.3s ease;
}

.rasan-nav-link:hover {
    color: white;
    background-color: rgba(255, 255, 255, 0.1);
}

/* Brand Footer */
.rasan-footer {
    background: linear-gradient(135deg, #111827 0%, #1f2937 100%);
}

/* Responsive Brand Elements */
@media (max-width: 640px) {
    .rasan-logo-responsive {
        height: 2rem;
    }

    .rasan-title {
        font-size: 1.5rem;
    }

    .rasan-btn-primary,
    .rasan-btn-secondary {
        padding: 0.5rem 1rem;
        font-size: 0.875rem;
    }
}

@media (min-width: 768px) {
    .rasan-logo-responsive {
        height: 2.5rem;
    }
}

@media (min-width: 1024px) {
    .rasan-logo-responsive {
        height: 3rem;
    }
}

/* Brand Loading States */
.rasan-loading {
    position: relative;
    overflow: hidden;
}

.rasan-loading::after {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(37, 99, 235, 0.1), transparent);
    animation: rasan-shimmer 2s infinite;
}

@keyframes rasan-shimmer {
    0% { left: -100%; }
    100% { left: 100%; }
}

/* Brand Form Elements */
.rasan-input {
    border: 2px solid #e5e7eb;
    border-radius: 0.5rem;
    padding: 0.75rem;
    transition: all 0.3s ease;
}

.rasan-input:focus {
    border-color: var(--rasan-primary);
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
    outline: none;
}

.rasan-select {
    border: 2px solid #e5e7eb;
    border-radius: 0.5rem;
    padding: 0.75rem;
    background-color: white;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");
    background-position: right 0.5rem center;
    background-repeat: no-repeat;
    background-size: 1.5em 1.5em;
    padding-right: 2.5rem;
    transition: all 0.3s ease;
}

.rasan-select:focus {
    border-color: var(--rasan-primary);
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
    outline: none;
}

/* Brand Utility Classes */
.rasan-text-primary { color: var(--rasan-primary); }
.rasan-text-secondary { color: var(--rasan-secondary); }
.rasan-text-accent { color: var(--rasan-accent); }
.rasan-bg-primary { background-color: var(--rasan-primary); }
.rasan-bg-secondary { background-color: var(--rasan-secondary); }
.rasan-bg-accent { background-color: var(--rasan-accent); }
.rasan-border-primary { border-color: var(--rasan-primary); }
.rasan-border-secondary { border-color: var(--rasan-secondary); }
.rasan-border-accent { border-color: var(--rasan-accent); }
