/**
 * Space 22 Design System
 * Color palette and design tokens
 *
 * @package Space22
 */

:root {
    /* Spacing Scale */
    --space-xs: 0.5rem;    /* 8px */
    --space-sm: 1rem;      /* 16px */
    --space-md: 1.5rem;    /* 24px */
    --space-lg: 2rem;      /* 32px */
    --space-xl: 3rem;      /* 48px */
    --space-2xl: 4rem;     /* 64px */
    --space-3xl: 6rem;     /* 96px */

    /* Typography */
    --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --font-heading: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --font-accent: 'Playfair Display', Georgia, serif;
    --font-script: 'Amsterlusia', 'Alex Brush', cursive;
    --font-rtl: 'Cairo', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;

    /* Legacy aliases for backward compatibility */
    --font-primary: var(--font-heading);
    --font-secondary: var(--font-accent);

    --font-size-xs: 0.75rem;    /* 12px */
    --font-size-sm: 0.875rem;   /* 14px */
    --font-size-base: 1rem;     /* 16px */
    --font-size-lg: 1.125rem;   /* 18px */
    --font-size-xl: 1.25rem;    /* 20px */
    --font-size-2xl: 1.5rem;    /* 24px */
    --font-size-3xl: 1.875rem;  /* 30px */
    --font-size-4xl: 2.25rem;   /* 36px */
    --font-size-5xl: 3rem;      /* 48px */
    --font-size-6xl: 3.75rem;   /* 60px */

    /* Line Heights */
    --line-height-tight: 1.2;
    --line-height-normal: 1.5;
    --line-height-relaxed: 1.75;

    /* Border Radius */
    --radius-sm: 4px;
    --radius-md: 8px;
    --radius-lg: 12px;
    --radius-xl: 16px;
    --radius-full: 9999px;

    /* Shadows */
    --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
    --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1);

    /* Transitions */
    --transition-fast: 150ms ease-in-out;
    --transition-base: 300ms ease-in-out;
    --transition-slow: 500ms ease-in-out;

    /* Container */
    --container-max-width: 1400px;
    --container-padding: 2rem;
}

/* Light Theme (Default) */
:root,
[data-theme="light"] {
    /* Brand Colors */
    --color-gold: #B8985A;
    --color-gold-light: #C9A866;
    --color-gold-dark: #A68748;

    /* Neutral Colors */
    --color-charcoal: #2D2D2D;
    --color-charcoal-light: #3D3D3D;
    --color-gray: #6B6B6B;
    --color-gray-light: #9E9E9E;

    /* Background Colors */
    --color-cream: #F9F6F1;
    --color-beige: #F5F0E8;
    --color-white: #FFFFFF;
    --color-black: #000000;

    /* Text Colors - Light Theme */
    --color-text-dark: #1A1A1A;
    --color-text-body: #2D2D2D;
    --color-text-light: #FFFFFF;
    --color-text-muted: #6B6B6B;

    /* Header Colors - Light Theme */
    --color-header-bg: #FFFFFF;
    --color-header-text: #1A1A1A;
    --color-header-link: #2D2D2D;
    --color-header-link-hover: #B8985A;
    --color-header-border: rgba(0, 0, 0, 0.08);

    /* Background Variants - Light Theme */
    --color-bg-primary: #FFFFFF;
    --color-bg-secondary: #F9F6F1;
    --color-bg-dark: #2D2D2D;
}

/* Dark Theme */
[data-theme="dark"] {
    /* Brand Colors */
    --color-gold: #C9A866;
    --color-gold-light: #D4B673;
    --color-gold-dark: #B8985A;

    /* Neutral Colors */
    --color-charcoal: #1A1A1A;
    --color-charcoal-light: #2D2D2D;
    --color-gray: #9E9E9E;
    --color-gray-light: #6B6B6B;

    /* Background Colors */
    --color-cream: #2D2D2D;
    --color-beige: #252525;
    --color-white: #1A1A1A;
    --color-black: #FFFFFF;

    /* Text Colors - Dark Theme */
    --color-text-dark: #F5F5F5;
    --color-text-body: #E0E0E0;
    --color-text-light: #1A1A1A;
    --color-text-muted: #A0A0A0;

    /* Header Colors - Dark Theme */
    --color-header-bg: #1F1F1F;
    --color-header-text: #F5F5F5;
    --color-header-link: #E0E0E0;
    --color-header-link-hover: #C9A866;
    --color-header-border: rgba(255, 255, 255, 0.1);

    /* Background Variants - Dark Theme */
    --color-bg-primary: #1A1A1A;
    --color-bg-secondary: #2D2D2D;
    --color-bg-dark: #0F0F0F;
}

/* ============================================
   Global Styles with Theme Support
   ============================================ */

body {
    background-color: var(--color-bg-primary);
    color: var(--color-text-body);
    transition: background-color var(--transition-base), color var(--transition-base);
}

/* Smooth theme transitions */
* {
    transition-property: background-color, color, border-color;
    transition-duration: var(--transition-base);
    transition-timing-function: ease-in-out;
}

/* Prevent transition on page load */
.no-transition * {
    transition: none !important;
}

/* Theme-specific backgrounds */
.bg-white {
    background-color: var(--color-bg-primary);
}

.bg-cream {
    background-color: var(--color-bg-secondary);
}

.section {
    transition: background-color var(--transition-base);
}

/* RTL Overrides */
body.rtl,
body.lang-ar {
    --font-body: 'Cairo', 'Tajawal', sans-serif;
    --font-heading: 'Cairo', 'Tajawal', sans-serif;
    --font-accent: 'Amiri', 'Cairo', serif;
    --font-primary: 'Cairo', 'Tajawal', sans-serif;
    --font-secondary: 'Amiri', 'Cairo', serif;
}

/* ============================================
   Typography Base
   ============================================ */

body {
    font-family: var(--font-body);
    font-size: var(--font-size-base);
    line-height: var(--line-height-normal);
    color: var(--color-text-dark);
    background-color: var(--color-white);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-primary);
    font-weight: 700;
    line-height: var(--line-height-tight);
    color: var(--color-text-dark);
    margin-bottom: var(--space-md);
}

h1 {
    font-size: var(--font-size-5xl);
}

h2 {
    font-size: var(--font-size-4xl);
}

h3 {
    font-size: var(--font-size-3xl);
}

h4 {
    font-size: var(--font-size-2xl);
}

h5 {
    font-size: var(--font-size-xl);
}

h6 {
    font-size: var(--font-size-lg);
}

/* Display Titles */
.display-1 {
    font-size: var(--font-size-6xl);
    font-family: var(--font-secondary);
    font-weight: 700;
    line-height: var(--line-height-tight);
}

.display-2 {
    font-size: var(--font-size-5xl);
    font-family: var(--font-secondary);
    font-weight: 700;
    line-height: var(--line-height-tight);
}

/* Brand Title */
.brand-title {
    font-family: var(--font-primary);
    font-weight: 300;
    letter-spacing: 0.05em;
}

.brand-title .accent {
    color: var(--color-gold);
    font-weight: 700;
}

/* Text Utilities */
.text-gold {
    color: var(--color-gold);
}

.text-muted {
    color: var(--color-text-muted);
}

.text-center {
    text-align: center;
}

/* ============================================
   Container & Layout
   ============================================ */

.container,
.space22-container {
    max-width: var(--container-max-width);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--container-padding);
    padding-right: var(--container-padding);
}

.container-fluid {
    width: 100%;
    padding-left: var(--container-padding);
    padding-right: var(--container-padding);
}

.section {
    padding: var(--space-3xl);
    margin: var(--space-lg) auto;
    max-width: calc(100% - var(--space-3xl));
    border-radius: var(--radius-xl);
    overflow: hidden;
}

.section-sm {
    padding: var(--space-2xl) 0;
}

.section-lg {
    padding: var(--space-3xl) 0;
}

/* ============================================
   Buttons
   ============================================ */

.btn {
    display: inline-block;
    padding: 1rem 2.5rem;
    font-family: var(--font-primary);
    font-size: var(--font-size-base);
    font-weight: 500;
    text-align: center;
    text-decoration: none;
    border: none;
    border-radius: var(--radius-full);
    cursor: pointer;
    transition: all var(--transition-base);
    line-height: 1.5;
}

.btn-primary {
    background-color: var(--color-white);
    color: var(--color-text-dark);
    border: 2px solid var(--color-white);
}

.btn-primary:hover {
    background-color: transparent;
    color: var(--color-white);
}

.btn-secondary {
    background-color: transparent;
    color: var(--color-white);
    border: 2px solid var(--color-white);
}

.btn-secondary:hover {
    background-color: var(--color-white);
    color: var(--color-text-dark);
}

.btn-gold {
    background-color: var(--color-gold);
    color: var(--color-white);
    border: 2px solid var(--color-gold);
}

.btn-gold:hover {
    background-color: var(--color-gold-dark);
    border-color: var(--color-gold-dark);
}

.btn-lg {
    padding: 1.25rem 3rem;
    font-size: var(--font-size-lg);
}

.btn-sm {
    padding: 0.75rem 2rem;
    font-size: var(--font-size-sm);
}

/* ============================================
   Cards
   ============================================ */

.card {
    background-color: var(--color-white);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: all var(--transition-base);
}

.card-shadow {
    box-shadow: var(--shadow-md);
}

.card-shadow:hover {
    box-shadow: var(--shadow-xl);
    transform: translateY(-4px);
}

.card-body {
    padding: var(--space-lg);
}

.card-title {
    margin-bottom: var(--space-md);
    font-size: var(--font-size-2xl);
}

.card-text {
    color: var(--color-text-muted);
    line-height: var(--line-height-relaxed);
}

/* ============================================
   Backgrounds
   ============================================ */

.bg-white {
    background-color: var(--color-white);
}

.bg-cream {
    background-color: var(--color-cream);
}

.bg-beige {
    background-color: var(--color-beige);
}

.bg-gold {
    background-color: var(--color-gold);
    color: var(--color-white);
}

.bg-charcoal {
    background-color: var(--color-charcoal);
    color: var(--color-white);
}

.bg-overlay {
    position: relative;
}

.bg-overlay::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 1;
}

.bg-overlay > * {
    position: relative;
    z-index: 2;
}

/* ============================================
   Grid System
   ============================================ */

.grid {
    display: grid;
    gap: var(--space-lg);
}

.grid-2 {
    grid-template-columns: repeat(2, 1fr);
}

.grid-3 {
    grid-template-columns: repeat(3, 1fr);
}

.grid-4 {
    grid-template-columns: repeat(4, 1fr);
}

@media (max-width: 1024px) {
    .grid-4 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .grid-2,
    .grid-3,
    .grid-4 {
        grid-template-columns: 1fr;
    }
}

/* ============================================
   Utilities
   ============================================ */

.text-uppercase {
    text-transform: uppercase;
}

.letter-spacing {
    letter-spacing: 0.1em;
}

.mb-0 { margin-bottom: 0; }
.mb-sm { margin-bottom: var(--space-sm); }
.mb-md { margin-bottom: var(--space-md); }
.mb-lg { margin-bottom: var(--space-lg); }
.mb-xl { margin-bottom: var(--space-xl); }

.mt-0 { margin-top: 0; }
.mt-sm { margin-top: var(--space-sm); }
.mt-md { margin-top: var(--space-md); }
.mt-lg { margin-top: var(--space-lg); }
.mt-xl { margin-top: var(--space-xl); }

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

@media (max-width: 768px) {
    :root {
        --container-padding: 1rem;
        --font-size-5xl: 2.25rem;
        --font-size-4xl: 1.875rem;
        --font-size-3xl: 1.5rem;
    }

    .section {
        padding: var(--space-lg);
        max-width: calc(100% - var(--space-lg));
        margin: var(--space-md) auto;
    }
}
