/* VARIABLES
---------------------------------------------------- */
/* CSS custom properties for consistent design across the site */

:root {
  /* Color Scheme - Primary
  ---------------------------------------------------- */
  --primary-color: #B17A50; /* Warm brown */
  --primary-dark: #996644;
  --secondary-color: #E4B882; /* Light beige */
  --accent-color: #D64933; /* Warm red */
  
  /* Text Colors */
  --text-dark: #333333;
  --text-light: #FFFFFF;
  --text-muted: rgba(51, 51, 51, 0.7);
  
  /* Background Colors */
  --background-light: #FFF8F0; /* Very light cream */
  --background-dark: #594D46; /* Dark brown */
  --background-card: #FFFFFF;
  --background-alt: #FCF7F1; /* Slightly off-white for alternating sections */
  
  /* Borders and Shadows */
  --border-color: rgba(0, 0, 0, 0.1);
  --shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 6px rgba(0, 0, 0, 0.1);
  --shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.1);
  --shadow-focus: 0 0 0 3px rgba(177, 122, 80, 0.25);
  
  /* Typography */
  --font-family-primary: 'Playfair Display', serif;
  --font-family-secondary: 'Poppins', sans-serif;
  
  --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 */
  
  --font-weight-light: 300;
  --font-weight-normal: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;
  
  --line-height-none: 1;
  --line-height-tight: 1.25;
  --line-height-snug: 1.375;
  --line-height-normal: 1.5;
  --line-height-relaxed: 1.625;
  --line-height-loose: 2;

  /* Spacing
  ---------------------------------------------------- */
  --spacing-xs: 0.5rem;  /* 8px */
  --spacing-sm: 1rem;    /* 16px */
  --spacing-md: 2rem;    /* 32px */
  --spacing-lg: 3rem;    /* 48px */
  --spacing-xl: 5rem;    /* 80px */
  
  /* For more precise control */
  --spacing-1: 0.25rem;  /* 4px */
  --spacing-2: 0.5rem;   /* 8px */
  --spacing-3: 0.75rem;  /* 12px */
  --spacing-4: 1rem;     /* 16px */
  --spacing-5: 1.25rem;  /* 20px */
  --spacing-6: 1.5rem;   /* 24px */
  --spacing-8: 2rem;     /* 32px */
  --spacing-10: 2.5rem;  /* 40px */
  --spacing-12: 3rem;    /* 48px */
  --spacing-16: 4rem;    /* 64px */
  --spacing-20: 5rem;    /* 80px */

  /* Border Radius
  ---------------------------------------------------- */
  --border-radius-sm: 0.125rem;  /* 2px */
  --border-radius-md: 0.375rem;  /* 6px */
  --border-radius-lg: 0.5rem;    /* 8px */
  --border-radius-xl: 1rem;      /* 16px */
  --border-radius-full: 9999px;

  /* Z-index
  ---------------------------------------------------- */
  --z-behind: -1;
  --z-normal: 0;
  --z-elevated: 10;
  --z-dropdown: 1000;
  --z-sticky: 1100;
  --z-fixed: 1200;
  --z-modal: 1300;
  --z-popover: 1400;
  --z-tooltip: 1500;

  /* Transitions
  ---------------------------------------------------- */
  --transition-fast: 150ms;
  --transition-normal: 300ms;
  --transition-slow: 500ms;
  --transition-timing-default: cubic-bezier(0.4, 0, 0.2, 1);
  --transition-timing-in: cubic-bezier(0.4, 0, 1, 1);
  --transition-timing-out: cubic-bezier(0, 0, 0.2, 1);

  /* Containers and Breakpoints
  ---------------------------------------------------- */
  --container-sm: 640px;
  --container-md: 768px;
  --container-lg: 1024px;
  --container-xl: 1200px;
  
  --breakpoint-sm: 576px;
  --breakpoint-md: 768px;
  --breakpoint-lg: 992px;
  --breakpoint-xl: 1200px;
}

/* Dark Theme Variables
---------------------------------------------------- */
.dark-theme, :root[data-theme='evening'] {
  /* Base Colors */
  --primary-color: #a47c48;     /* Signature brown */
  --primary-dark: #8B5E3C;      /* Darker brown */
  --primary-light: #c69c6d;     /* Lighter brown */
  --accent-gold: #d3a76e;       /* Warm gold accent */
  --secondary-color: #c69c6d;   /* Light brown */
  --accent-color: #c69c6d;      /* Using primary-light instead of red */
  
  /* Text Colors */
  --text-primary: #f5f2eb;      /* Primary text */
  --text-secondary: #d5cdc3;    /* Secondary text */
  --text-muted: #9e9589;        /* Tertiary/muted text */
  --text-dark: #f5f2eb;         /* Map to text-primary for compatibility */
  --text-light: #f5f2eb;        /* Map to text-primary for compatibility */
  
  /* Background Layers */
  --surface-base: #1a1814;      /* Base layer (deepest) */
  --surface-raised: #252220;    /* Raised elements */
  --surface-overlay: #302c28;   /* Overlay elements */
  --surface-accent: #3a3630;    /* Accent surfaces */
  --background-light: #1a1814;  /* Map to surface-base for compatibility */
  --background-dark: #252220;   /* Map to surface-raised for compatibility */
  --background-card: #302c28;   /* Map to surface-overlay for compatibility */
  --background-alt: #3a3630;    /* Map to surface-accent for compatibility */
  --background-color: #1a1814;  /* Map to surface-base for compatibility */
  
  /* Functional Colors */
  --border-subtle: rgba(255, 255, 255, 0.08);  /* Subtle borders */
  --border-distinct: rgba(255, 255, 255, 0.15); /* Distinct borders */
  --border-color: var(--border-subtle);        /* Map for compatibility */
  
  /* Shadows */
  --shadow-ambient: 0 2px 6px rgba(0, 0, 0, 0.2); /* Ambient shadow */
  --shadow-elevated: 0 4px 12px rgba(0, 0, 0, 0.3); /* Elevated elements */
  --shadow-sm: var(--shadow-ambient);           /* Map for compatibility */
  --shadow-md: var(--shadow-elevated);          /* Map for compatibility */
  --shadow-lg: 0 8px 15px rgba(0, 0, 0, 0.25);  /* Reduced intensity by 30% */
  --shadow-focus: 0 0 0 3px rgba(164, 124, 72, 0.25); /* Reduced intensity */
  
  /* Links and interactive elements */
  --link-color: var(--accent-gold);          /* Link color */
  --link-hover-color: #e0b077;               /* Link hover color */
  --input-background: var(--surface-accent);  /* Form input background */
  --input-border: var(--border-distinct);     /* Form input border */
  --input-text: var(--text-primary);          /* Form input text */
  --input-placeholder: var(--text-muted);     /* Form input placeholder */
  --input-focus-border: var(--primary-color); /* Form input focus border */
}

/* Utility classes for using CSS variables
---------------------------------------------------- */
.text-primary { color: var(--primary-color); }
.text-secondary { color: var(--secondary-color); }
.text-accent { color: var(--accent-color); }
.text-dark { color: var(--text-dark); }
.text-light { color: var(--text-light); }
.text-muted { color: var(--text-muted); }

.bg-primary { background-color: var(--primary-color); }
.bg-secondary { background-color: var(--secondary-color); }
.bg-accent { background-color: var(--accent-color); }
.bg-light { background-color: var(--background-light); }
.bg-dark { background-color: var(--background-dark); }
.bg-alt { background-color: var(--background-alt); }
.bg-card { background-color: var(--background-card); }

.font-primary { font-family: var(--font-family-primary); }
.font-secondary { font-family: var(--font-family-secondary); }

.font-light { font-weight: var(--font-weight-light); }
.font-normal { font-weight: var(--font-weight-normal); }
.font-medium { font-weight: var(--font-weight-medium); }
.font-semibold { font-weight: var(--font-weight-semibold); }
.font-bold { font-weight: var(--font-weight-bold); }

.text-xs { font-size: var(--font-size-xs); }
.text-sm { font-size: var(--font-size-sm); }
.text-base { font-size: var(--font-size-base); }
.text-lg { font-size: var(--font-size-lg); }
.text-xl { font-size: var(--font-size-xl); }
.text-2xl { font-size: var(--font-size-2xl); }
.text-3xl { font-size: var(--font-size-3xl); }
.text-4xl { font-size: var(--font-size-4xl); }
.text-5xl { font-size: var(--font-size-5xl); }
.text-6xl { font-size: var(--font-size-6xl); }

.rounded-sm { border-radius: var(--border-radius-sm); }
.rounded-md { border-radius: var(--border-radius-md); }
.rounded-lg { border-radius: var(--border-radius-lg); }
.rounded-xl { border-radius: var(--border-radius-xl); }
.rounded-full { border-radius: var(--border-radius-full); }

.shadow-sm { box-shadow: var(--shadow-sm); }
.shadow-md { box-shadow: var(--shadow-md); }
.shadow-lg { box-shadow: var(--shadow-lg); }
.shadow-focus { box-shadow: var(--shadow-focus); }

.transition-fast { transition-duration: var(--transition-fast); }
.transition-normal { transition-duration: var(--transition-normal); }
.transition-slow { transition-duration: var(--transition-slow); }

/* Spacing utility classes */
.p-0 { padding: 0; }
.p-1 { padding: var(--spacing-1); }
.p-2 { padding: var(--spacing-2); }
.p-3 { padding: var(--spacing-3); }
.p-4 { padding: var(--spacing-4); }
.p-5 { padding: var(--spacing-5); }
.p-6 { padding: var(--spacing-6); }
.p-8 { padding: var(--spacing-8); }
.p-10 { padding: var(--spacing-10); }

.m-0 { margin: 0; }
.m-1 { margin: var(--spacing-1); }
.m-2 { margin: var(--spacing-2); }
.m-3 { margin: var(--spacing-3); }
.m-4 { margin: var(--spacing-4); }
.m-5 { margin: var(--spacing-5); }
.m-6 { margin: var(--spacing-6); }
.m-8 { margin: var(--spacing-8); }
.m-10 { margin: var(--spacing-10); } 