/*
Theme Name: Compassion First Theme
Theme URI: https://compassionfirstcounselling.ca
Author: foreseon.net
Description: High-performance, bespoke WordPress architecture tailored for Compassion First Counselling. Built without heavy page builders.
Version: 1.0.1
Text Domain: compassionfirst
*/

/**
 * 1. Global Design Tokens
 * -----------------------------------------------------------------------------
 */
:root {
    /* Brand Colors */
    --color-primary: #1c3144;
    --color-accent: #ffdb94;
    --color-surface: #fff6e1;
    --color-white: #ffffff;
    --color-text: #2d3748;
    
    /* Typography */
    --font-heading: 'Cormorant Garamond', serif;
    --font-body: 'Inter', sans-serif;

    /* Spacing - Fluid Scale */
    --space-sm: clamp(0.5rem, 1vw, 1rem);
    --space-md: clamp(1rem, 2vw, 1.5rem);
    --space-lg: clamp(2rem, 4vw, 3rem);
    --section-padding: clamp(4rem, 8vw, 6rem);
    
    /* Motion */
    --ease-out-expo: cubic-bezier(0.19, 1, 0.22, 1);
    --transition-smooth: 0.6s var(--ease-out-expo);
}

/**
 * 2. Base Reset & Typographic Defaults
 * -----------------------------------------------------------------------------
 */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

body {
    background-color: var(--color-surface);
    color: var(--color-primary);
    font-family: var(--font-body);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    font-weight: 500;
    line-height: 1.1;
    margin-bottom: var(--space-md);
    letter-spacing: -0.02em;
}

img, picture, svg {
    max-width: 100%;
    display: block;
}

/**
 * 3. Global Components (Buttons & Inputs)
 * -----------------------------------------------------------------------------
 */
.btn-solid,
.btn-massive,
.btn-service-primary,
.btn-download {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background-color: var(--color-primary);
    color: var(--color-surface) !important;
    padding: 1rem 2.2rem;
    text-decoration: none;
    font-weight: 600;
    border-radius: 4px;
    border: 1px solid var(--color-primary);
    transition: all 0.3s var(--ease-out-expo);
    cursor: pointer;
    box-shadow: none !important;
}

.btn-solid:hover,
.btn-massive:hover,
.btn-service-primary:hover,
.btn-download:hover {
    background-color: transparent;
    color: var(--color-primary) !important;
    transform: translateY(-2px);
}

.btn-outline {
    display: inline-block;
    color: var(--color-primary);
    text-decoration: none;
    font-weight: 600;
    border-bottom: 2px solid var(--color-accent);
    padding-bottom: 0.2rem;
    transition: all 0.3s ease;
}

.btn-outline:hover {
    color: var(--color-accent);
    border-color: var(--color-primary);
}

/**
 * 4. Modern Editorial Overrides (Zero Shadow Policy)
 * -----------------------------------------------------------------------------
 */
.service-card, 
.resource-card, 
.service-booking-box,
.single-service-media {
    box-shadow: none !important;
    border: 1px solid rgba(28, 49, 68, 0.15);
}

.service-card:hover, 
.resource-card:hover {
    box-shadow: none !important;
    border-color: var(--color-primary);
    transform: translateY(-4px);
}

.site-header.is-scrolled {
    box-shadow: none !important;
    border-bottom: 1px solid rgba(28, 49, 68, 0.1);
}