/*
Theme Name: MS Technology Client
Theme URI:
Author:
Author URI:
Description: A custom WordPress theme with modular templates and components.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: ms-technology-client
*/

/* ==========================================================================
   WEB FONTS - Local Font Files
   ========================================================================== */

/* Raleway - Headings */
@font-face {
    font-family: 'Raleway';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url('./fonts/raleway/raleway-400.woff2') format('woff2');
}

@font-face {
    font-family: 'Raleway';
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url('./fonts/raleway/raleway-500.woff2') format('woff2');
}

@font-face {
    font-family: 'Raleway';
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url('./fonts/raleway/raleway-600.woff2') format('woff2');
}

@font-face {
    font-family: 'Raleway';
    font-style: normal;
    font-weight: 700;
    font-display: swap;
    src: url('./fonts/raleway/raleway-700.woff2') format('woff2');
}

@font-face {
    font-family: 'Raleway';
    font-style: normal;
    font-weight: 800;
    font-display: swap;
    src: url('./fonts/raleway/raleway-800.woff2') format('woff2');
}

/* IBM Plex Sans - Body */
@font-face {
    font-family: 'IBM Plex Sans';
    font-style: normal;
    font-weight: 300;
    font-display: swap;
    src: url('./fonts/ibm-plex-sans/ibm-plex-sans-300.woff2') format('woff2');
}

@font-face {
    font-family: 'IBM Plex Sans';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url('./fonts/ibm-plex-sans/ibm-plex-sans-400.woff2') format('woff2');
}

@font-face {
    font-family: 'IBM Plex Sans';
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url('./fonts/ibm-plex-sans/ibm-plex-sans-500.woff2') format('woff2');
}

@font-face {
    font-family: 'IBM Plex Sans';
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url('./fonts/ibm-plex-sans/ibm-plex-sans-600.woff2') format('woff2');
}

@font-face {
    font-family: 'IBM Plex Sans';
    font-style: normal;
    font-weight: 700;
    font-display: swap;
    src: url('./fonts/ibm-plex-sans/ibm-plex-sans-700.woff2') format('woff2');
}

/* IBM Plex Mono - Code */
@font-face {
    font-family: 'IBM Plex Mono';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url('./fonts/ibm-plex-mono/ibm-plex-mono-400.woff2') format('woff2');
}

@font-face {
    font-family: 'IBM Plex Mono';
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url('./fonts/ibm-plex-mono/ibm-plex-mono-500.woff2') format('woff2');
}

/* ==========================================================================
   DESIGN TOKENS - Colors (OKLCH/OKLAB)

   Light Mode Guidelines:
   - Use high lightness backgrounds (95-100%)
   - Surface layers get DARKER as they elevate (2-3% lightness steps)
   - Text: Headings 10-15%, Body 25-30%, Secondary 40-45%, Disabled 55-60%
   - Accent: OKLAB format - oklab(0.4611 0.154682 0.0826965) based
   - Maintain subtle warm neutral tint for cohesion
   ========================================================================== */

:root {
    /*
     * Background - Layered Surfaces (2-3% lightness steps)
     * Each layer gets darker as it elevates (opposite of dark mode)
     * Base: oklch(0.99 0.002 70) - nearly white with subtle warm tint
     */
    --color-bg-base: oklch(0.99 0.002 70);
    /* App background - lightest */
    --color-bg-surface: oklch(0.97 0.002 70);
    /* Cards, main content (-2%) */
    --color-bg-muted: oklch(0.95 0.003 70);
    /* Sidebar, secondary areas (-2%) */
    --color-bg-elevated: oklch(0.93 0.003 70);
    /* Modals, dropdowns (-2%) */
    --color-bg-interactive: oklch(0.96 0.003 70);
    /* Interactive backgrounds */
    --color-bg-hover: oklch(0.92 0.004 70);
    /* Hover states (-3%) */

    /*
     * Text - 4 Levels (avoid pure black)
     * Subtle warm tint for cohesion with backgrounds
     */
    --color-text-primary: oklch(0.15 0.005 70);
    /* Headings, important - near black */
    --color-text-secondary: oklch(0.30 0.005 70);
    /* Body text */
    --color-text-muted: oklch(0.45 0.004 70);
    /* Secondary info */
    --color-text-disabled: oklch(0.58 0.003 70);
    /* Disabled, meta */
    --color-text-inverse: oklch(0.98 0.002 70);
    /* Text on dark backgrounds */

    /*
     * Accent Ramp - Deep Red (OKLAB)
     * Light mode uses 500-600 for primary, 600-700 for hover
     * Base: oklab(0.4611 0.154682 0.0826965)
     */
    --color-accent-50: oklab(0.97 0.0132 0.0071);
    /* Lightest tint */
    --color-accent-100: oklab(0.93 0.0309 0.0165);
    /* Very light */
    --color-accent-200: oklab(0.85 0.0617 0.0330);
    /* Light */
    --color-accent-300: oklab(0.75 0.0970 0.0519);
    /* Light-medium */
    --color-accent-400: oklab(0.58 0.1279 0.0684);
    /* Medium */
    --color-accent-500: oklab(0.4611 0.154682 0.0826965);
    /* Primary for light mode */
    --color-accent-600: oklab(0.40 0.1455 0.0778);
    /* Hover for light mode */
    --color-accent-700: oklab(0.34 0.1279 0.0684);
    /* Active/pressed */
    --color-accent-800: oklab(0.28 0.1058 0.0566);
    /* Dark */
    --color-accent-900: oklab(0.22 0.0794 0.0424);
    /* Darkest */

    /* Accent shortcuts for common use */
    --color-accent: var(--color-accent-500);
    /* Primary accent */
    --color-accent-hover: var(--color-accent-600);
    /* Hover state */
    --color-accent-active: var(--color-accent-700);
    /* Active/pressed */
    --color-accent-light: var(--color-accent-400);
    /* Lighter accent */
    --color-accent-dark: var(--color-accent-700);
    /* Darker accent */
    --color-accent-subtle: oklab(0.4611 0.154682 0.0826965 / 0.08);
    /* Subtle backgrounds */
    --color-accent-rgb: 164, 22, 20;
    /* Fallback for rgba() */

    /*
     * Semantic Colors (OKLCH with matched perceptual brightness)
     * Same lightness + chroma approach, different hue for harmony
     */

    /* Success - Green */
    --color-success: oklch(0.55 0.17 145);
    --color-success-light: oklch(0.70 0.14 145);
    --color-success-dark: oklch(0.42 0.15 145);
    --color-success-bg: oklch(0.55 0.17 145 / 0.08);
    --color-success-subtle: oklch(0.95 0.03 145);
    --color-success-border: oklch(0.55 0.17 145 / 0.25);

    /* Error - Red (harmonizes with accent) */
    --color-error: oklch(0.55 0.20 25);
    --color-error-light: oklch(0.70 0.16 25);
    --color-error-dark: oklch(0.42 0.18 25);
    --color-error-bg: oklch(0.55 0.20 25 / 0.08);
    --color-error-subtle: oklch(0.96 0.02 25);
    --color-error-border: oklch(0.55 0.20 25 / 0.25);

    /* Warning - Amber/Orange */
    --color-warning: oklch(0.70 0.16 70);
    --color-warning-light: oklch(0.82 0.12 70);
    --color-warning-dark: oklch(0.55 0.15 70);
    --color-warning-bg: oklch(0.70 0.16 70 / 0.10);
    --color-warning-subtle: oklch(0.96 0.03 70);
    --color-warning-border: oklch(0.70 0.16 70 / 0.25);

    /* Info - Blue */
    --color-info: oklch(0.55 0.16 250);
    --color-info-light: oklch(0.70 0.12 250);
    --color-info-dark: oklch(0.42 0.14 250);
    --color-info-bg: oklch(0.55 0.16 250 / 0.08);
    --color-info-subtle: oklch(0.96 0.02 250);
    --color-info-border: oklch(0.55 0.16 250 / 0.25);

    /* Rating Stars - Gold */
    --color-rating-star: oklch(0.80 0.18 85);

    /*
     * Borders - Slightly darker than surfaces
     * Subtle warm tint to match backgrounds
     */
    --color-border: oklch(0.88 0.004 70);
    /* Default border */
    --color-border-default: oklch(0.88 0.004 70);
    /* Same as border */
    --color-border-subtle: oklch(0.92 0.003 70);
    /* Subtle dividers */
    --color-border-strong: oklch(0.78 0.005 70);
    /* Emphasized borders */
    --color-border-focus: var(--color-accent);
    /* Focus rings */

    /*
     * Overlay & Utility Colors
     */
    --color-overlay-lightest: oklch(0% 0 0 / 0.02);
    /* Barely visible dark */
    --color-overlay-lighter: oklch(0% 0 0 / 0.04);
    /* Subtle dark overlay */
    --color-overlay-light: oklch(0% 0 0 / 0.06);
    /* Light overlay on surfaces */
    --color-overlay-dark: oklch(0% 0 0 / 0.5);
    /* Dark overlay for modals */
    --color-overlay-darker: oklch(0% 0 0 / 0.7);
    /* Darker overlay */
    --color-overlay-white: oklch(100% 0 0 / 0.8);
    /* White overlay */

    /* Accent with various opacities */
    --color-accent-subtle-light: oklab(0.4611 0.154682 0.0826965 / 0.04);
    /* Very subtle accent bg */
    --color-accent-subtle-medium: oklab(0.4611 0.154682 0.0826965 / 0.08);
    /* Light accent bg */
    --color-accent-border: oklab(0.4611 0.154682 0.0826965 / 0.25);
    /* Accent border */

    /*
     * Focus & Interactive States
     */
    --color-focus-ring: oklab(0.4611 0.154682 0.0826965 / 0.20);
    /* Accent-based focus ring */
    --color-focus-ring-offset: oklch(0.99 0.002 70);
    /* Focus ring offset (bg color) */
    --color-focus-ring-error: oklch(0.55 0.20 25 / 0.20);
    /* Error focus ring */

    /*
     * Legacy Color Aliases (for backwards compatibility)
     * Maps old variable names to new OKLCH system
     */
    --color-white: oklch(1 0 0);
    --color-black: oklch(0 0 0);
    --color-gray-50: var(--color-bg-base);
    --color-gray-100: var(--color-bg-surface);
    --color-gray-200: var(--color-bg-muted);
    --color-gray-300: var(--color-border-subtle);
    --color-gray-400: var(--color-text-disabled);
    --color-gray-500: var(--color-text-muted);
    --color-gray-600: var(--color-text-secondary);
    --color-gray-700: oklch(0.35 0.005 70);
    --color-gray-800: oklch(0.25 0.005 70);
    --color-gray-900: var(--color-text-primary);

    /* Legacy semantic shortcuts */
    --color-bg-primary: var(--color-bg-base);
    --color-bg-secondary: var(--color-bg-surface);
    --color-bg-highlight: var(--color-bg-muted);
}

/* ==========================================================================
   DESIGN TOKENS - Typography
   ========================================================================== */

:root {
    /*
     * Font Families
     */
    --font-family-base: 'IBM Plex Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif;
    --font-family-heading: 'Raleway', var(--font-family-base);
    --font-family-mono: 'IBM Plex Mono', 'SF Mono', 'Consolas', monospace;

    /*
     * Font Sizes - Modular Scale (1.25 ratio)
     */
    --font-size-xs: 0.8rem;
    /* ~14px */
    --font-size-sm: 0.95rem;
    /* ~17px */
    --font-size-base: 1.1rem;
    /* ~18px */
    --font-size-lg: 1.25rem;
    /* 20px */
    --font-size-xl: 1.4rem;
    /* ~22px */
    --font-size-2xl: 1.65rem;
    /* ~26px */
    --font-size-3xl: 2rem;
    /* 32px */
    --font-size-4xl: 2.5rem;
    /* 40px */
    --font-size-5xl: 3.25rem;
    /* 52px */
    --font-size-6xl: 4rem;
    /* 64px */

    /*
     * Font Weights
     */
    --font-weight-light: 300;
    --font-weight-normal: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;

    /*
     * Line Heights
     */
    --line-height-none: 1;
    --line-height-tight: 1.2;
    --line-height-snug: 1.375;
    --line-height-normal: 1.5;
    --line-height-relaxed: 1.625;
    --line-height-loose: 2;

    /*
     * Letter Spacing
     */
    --letter-spacing-tight: -0.025em;
    --letter-spacing-normal: 0;
    --letter-spacing-wide: 0.025em;
    --letter-spacing-wider: 0.05em;
    --letter-spacing-widest: 0.1em;
}

/* ==========================================================================
   DESIGN TOKENS - Spacing
   ========================================================================== */

:root {
    /*
     * Spacing Scale - 4px base unit
     */
    --spacing-0: 0;
    --spacing-px: 1px;
    --spacing-0-5: 0.125rem;
    /* 2px */
    --spacing-1: 0.25rem;
    /* 4px */
    --spacing-1-5: 0.375rem;
    /* 6px */
    --spacing-2: 0.5rem;
    /* 8px */
    --spacing-2-5: 0.625rem;
    /* 10px */
    --spacing-3: 0.75rem;
    /* 12px */
    --spacing-3-5: 0.875rem;
    /* 14px */
    --spacing-4: 1rem;
    /* 16px */
    --spacing-5: 1.25rem;
    /* 20px */
    --spacing-6: 1.5rem;
    /* 24px */
    --spacing-7: 1.75rem;
    /* 28px */
    --spacing-8: 2rem;
    /* 32px */
    --spacing-9: 2.25rem;
    /* 36px */
    --spacing-10: 2.5rem;
    /* 40px */
    --spacing-12: 3rem;
    /* 48px */
    --spacing-14: 3.5rem;
    /* 56px */
    --spacing-16: 4rem;
    /* 64px */
    --spacing-20: 5rem;
    /* 80px */
    --spacing-24: 6rem;
    /* 96px */
    --spacing-32: 8rem;
    /* 128px */

    /* Legacy spacing aliases */
    --spacing-xs: var(--spacing-1);
    --spacing-sm: var(--spacing-2);
    --spacing-md: var(--spacing-4);
    --spacing-lg: var(--spacing-6);
    --spacing-xl: var(--spacing-8);
    --spacing-2xl: var(--spacing-12);
    --spacing-3xl: var(--spacing-16);
}

/* ==========================================================================
   DESIGN TOKENS - Layout
   ========================================================================== */

:root {
    /*
     * Container Widths
     */
    --container-xs: 320px;
    --container-sm: 640px;
    --container-md: 768px;
    --container-lg: 1024px;
    --container-xl: 1200px;
    --container-2xl: 1440px;
    --container-full: 100%;

    /*
     * Z-Index Scale
     */
    --z-index-dropdown: 1000;
    --z-index-sticky: 1020;
    --z-index-fixed: 1030;
    --z-index-modal-backdrop: 1040;
    --z-index-modal: 1050;
    --z-index-popover: 1060;
    --z-index-tooltip: 1070;
    --z-index-toast: 1080;
}

/* ==========================================================================
   DESIGN TOKENS - Effects
   ========================================================================== */

:root {
    /*
     * Border Radius
     */
    --radius-none: 0;
    --radius-sm: 4px;
    --radius-md: 8px;
    --radius-lg: 12px;
    --radius-xl: 16px;
    --radius-2xl: 24px;
    --radius-full: 9999px;

    /*
     * Shadows - Light theme optimized
     * Using oklch for color consistency
     */
    --shadow-xs: 0 1px 2px oklch(0% 0 0 / 0.04);
    --shadow-sm: 0 1px 3px oklch(0% 0 0 / 0.06), 0 1px 2px oklch(0% 0 0 / 0.04);
    --shadow-md: 0 4px 6px -1px oklch(0% 0 0 / 0.07), 0 2px 4px -2px oklch(0% 0 0 / 0.05);
    --shadow-lg: 0 10px 15px -3px oklch(0% 0 0 / 0.08), 0 4px 6px -4px oklch(0% 0 0 / 0.04);
    --shadow-xl: 0 20px 25px -5px oklch(0% 0 0 / 0.08), 0 8px 10px -6px oklch(0% 0 0 / 0.04);
    --shadow-2xl: 0 25px 50px -12px oklch(0% 0 0 / 0.20);
    --shadow-inner: inset 0 2px 4px oklch(0% 0 0 / 0.04);
    --shadow-none: none;

    /* Accent-colored shadows for elevated accent elements */
    --shadow-accent-sm: 0 2px 8px oklab(0.4611 0.154682 0.0826965 / 0.15);
    --shadow-accent-md: 0 4px 14px oklab(0.4611 0.154682 0.0826965 / 0.20);
    --shadow-accent-lg: 0 8px 24px oklab(0.4611 0.154682 0.0826965 / 0.25);

    /*
     * Transitions
     */
    --transition-none: none;
    --transition-fast: 150ms ease;
    --transition-base: 250ms ease;
    --transition-slow: 350ms ease;
    --transition-slower: 500ms ease;

    /* Specific transitions */
    --transition-colors: color 150ms ease, background-color 150ms ease, border-color 150ms ease;
    --transition-opacity: opacity 150ms ease;
    --transition-transform: transform 250ms ease;
    --transition-shadow: box-shadow 150ms ease;
    --transition-all: all 250ms ease;

    /*
     * Animation Timing Functions
     */
    --ease-linear: linear;
    --ease-in: cubic-bezier(0.4, 0, 1, 1);
    --ease-out: cubic-bezier(0, 0, 0.2, 1);
    --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
    --ease-bounce: cubic-bezier(0.68, -0.55, 0.265, 1.55);
}

/* ==========================================================================
   Base Styles
   ========================================================================== */

*,
*::before,
*::after {
    box-sizing: border-box;
}

body {
    font-family: var(--font-family-base);
    font-size: var(--font-size-base);
    line-height: 1.6;
    color: var(--color-text-primary);
    background-color: var(--color-bg-primary);
    margin: 0;
    padding: 0;
}

a {
    color: var(--color-accent);
    text-decoration: none;
    transition: color var(--transition-fast);
}

a:hover {
    color: var(--color-accent-dark);
}

/* Section spacing */
.layout-hero-floating,
.layout-two-col,
.layout-card-grid,
.layout-timeline-horizontal,
.layout-timeline-vertical,
.layout-slider-thumbs,
.layout-card-carousel,
.layout-section-centered,
.layout-footer,
.layout-contact-form,
.layout-split,
.layout-banner,
.layout-two-col-op-info-cta {
    margin-top: var(--spacing-10);
    margin-bottom: var(--spacing-10);
}

/* Remove bottom margin from last section before footer */
.site-main>*:last-child {
    margin-bottom: 0;
}

/* ==========================================================================
   Doctor Profile Component
   ========================================================================== */

.doctor-profile {
    padding: var(--spacing-3xl) var(--spacing-lg);
    background-color: var(--color-bg-primary);
    max-width: 1200px;
    margin: 0 auto;
}

/* Top Section: Image + Content side by side */
.doctor-profile__top {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-2xl);
    margin-bottom: var(--spacing-3xl);
}

@media (min-width: 768px) {
    .doctor-profile__top {
        grid-template-columns: 300px 1fr;
        gap: var(--spacing-2xl);
    }
}

@media (min-width: 1024px) {
    .doctor-profile__top {
        grid-template-columns: 350px 1fr;
        gap: var(--spacing-3xl);
    }
}

/* Image */
.doctor-profile__image-wrapper {
    display: flex;
    justify-content: center;
    align-items: flex-start;
}

.doctor-profile__figure {
    margin: 0;
    width: 100%;
}

.doctor-profile__image {
    width: 100%;
    height: auto;
    object-fit: cover;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
}

/* Content */
.doctor-profile__content {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.doctor-profile__label {
    display: inline-block;
    font-size: var(--font-size-sm);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-accent);
    background-color: var(--color-accent-subtle-medium);
    padding: var(--spacing-xs) var(--spacing-sm);
    border-radius: var(--radius-sm);
    width: fit-content;
}

.doctor-profile__name {
    font-size: var(--font-size-3xl);
    font-weight: 700;
    color: var(--color-text-primary);
    margin: 0;
    line-height: 1.2;
}

@media (min-width: 768px) {
    .doctor-profile__name {
        font-size: var(--font-size-4xl);
    }
}

.doctor-profile__bio {
    font-size: var(--font-size-base);
    color: var(--color-text-secondary);
    margin: 0;
    line-height: 1.7;
}

/* Cards Grid - 2x2 */
.doctor-profile__cards {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-lg);
    margin-top: var(--spacing-lg);
}

@media (min-width: 576px) {
    .doctor-profile__cards {
        grid-template-columns: repeat(2, 1fr);
    }
}

.doctor-profile__card {
    position: relative;
    background: var(--color-white);
    padding: var(--spacing-lg);
    border-radius: var(--radius-xl);
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-md);
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-gray-100);
    transition: all var(--transition-base);
}

.doctor-profile__card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
    border-color: var(--color-gray-200);
}

.doctor-profile__card p {
    margin: 0;
    font-size: var(--font-size-sm);
    color: var(--color-text-primary);
    line-height: 1.6;
    position: relative;
    z-index: 1;
}

.doctor-profile__card a {
    color: var(--color-accent);
    font-weight: 600;
    transition: color var(--transition-fast);
}

.doctor-profile__card a:hover {
    color: var(--color-accent-dark);
}

/* Horizontal Timeline */
.doctor-profile__timeline {
    position: relative;
    padding-top: var(--spacing-xl);
    overflow-x: auto;
}

.doctor-profile__timeline-line {
    position: absolute;
    top: calc(var(--spacing-xl) + 2.5rem);
    left: 0;
    right: 0;
    height: 2px;
    background-color: var(--color-gray-200);
}

.doctor-profile__timeline-items {
    display: flex;
    justify-content: space-between;
    gap: var(--spacing-md);
    min-width: max-content;
    padding: 0 var(--spacing-md);
}

@media (min-width: 768px) {
    .doctor-profile__timeline-items {
        min-width: 100%;
        padding: 0;
    }
}

.doctor-profile__timeline-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    flex: 1;
    min-width: 140px;
    max-width: 200px;
}

.doctor-profile__timeline-year {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-accent);
    margin-bottom: var(--spacing-sm);
    white-space: nowrap;
}

.doctor-profile__timeline-dot {
    width: 16px;
    height: 16px;
    background-color: var(--color-accent);
    border-radius: var(--radius-full);
    border: 3px solid var(--color-white);
    box-shadow: 0 0 0 2px var(--color-accent);
    margin-bottom: var(--spacing-sm);
    position: relative;
    z-index: 1;
}

.doctor-profile__timeline-text {
    margin: 0;
    font-size: var(--font-size-xs);
    color: var(--color-text-secondary);
    line-height: 1.4;
    max-width: 160px;
}

@media (min-width: 1024px) {
    .doctor-profile__timeline-text {
        font-size: var(--font-size-sm);
        max-width: 180px;
    }
}

/* ==========================================================================
   LAYOUT 1: Hero with Floating Card
   ========================================================================== */

.layout-hero-floating {
    position: relative;
    width: 100%;
    min-height: 400px;
    margin-top: 60px;
    margin-bottom: 60px;
}

.layout-hero-floating__container {
    max-width: var(--container-xl);
    margin: 0 auto;
    padding: 0 var(--spacing-6);
    display: flex;
    flex-direction: column;
}

.layout-hero-floating__image-wrapper {
    width: 100%;
    order: -1;
}

.layout-hero-floating__image {
    width: 100%;
    max-width: 730px;
    height: auto;
    object-fit: cover;
    border-radius: var(--radius-lg);
}

.layout-hero-floating__card {
    background: var(--color-white);
    padding: var(--spacing-8) var(--spacing-6) var(--spacing-8) var(--spacing-8);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xl);
    margin-top: calc(-1 * var(--spacing-10));
    position: relative;
    z-index: 2;
}

.layout-hero-floating__label {
    display: inline-block;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-wide);
    color: var(--color-accent);
    margin-bottom: var(--spacing-3);
}

.layout-hero-floating__title {
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-primary);
    margin: 0 0 var(--spacing-4);
    line-height: var(--line-height-tight);
}

.layout-hero-floating__text {
    font-size: var(--font-size-base);
    color: var(--color-text-secondary);
    margin: 0 0 var(--spacing-6);
    line-height: var(--line-height-relaxed);
}

.layout-hero-floating__features {
    margin: 0 0 var(--spacing-6);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-3);
}

.layout-hero-floating__feature {
    display: flex;
    align-items: center;
    gap: var(--spacing-3);
    margin: 0;
    font-size: var(--font-size-base);
    color: var(--color-text-secondary);
    line-height: var(--line-height-normal);
}

.layout-hero-floating__feature .gb-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--color-accent);
    font-size: 1.25rem;
    flex-shrink: 0;
}

.layout-hero-floating__feature .gb-icon svg {
    display: block;
}

.layout-hero-floating__actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-3);
}

@media (min-width: 768px) {
    .layout-hero-floating__card {
        margin-top: calc(-1 * var(--spacing-32));
        min-width: 580px;
        max-width: 630px;
    }
}

@media (min-width: 1024px) {
    .layout-hero-floating {
        min-height: 500px;
    }

    .layout-hero-floating__container {
        position: relative;
        flex-direction: row;
        align-items: center;
        min-height: 500px;
        padding: 0;
    }

    .layout-hero-floating__image-wrapper {
        order: 1;
        width: 100%;
        display: flex;
        justify-content: flex-end;
    }

    .layout-hero-floating__image {
        width: 730px;
        max-width: 730px;
    }

    .layout-hero-floating__card {
        position: absolute;
        left: 0;
        top: 50%;
        transform: translateY(-50%);
        margin: 0;
        min-width: 580px;
        max-width: 630px;
        padding: var(--spacing-10) var(--spacing-8) var(--spacing-10) var(--spacing-10);
        z-index: 2;
    }

    .layout-hero-floating__title {
        font-size: var(--font-size-4xl);
    }
}

/* ==========================================================================
   LAYOUT 2: Two-Column Image + Content (38/58)
   ========================================================================== */

.layout-two-col {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-8);
    max-width: var(--container-xl);
    margin: 0 auto;
    padding: var(--spacing-12) var(--spacing-6);
}

.layout-two-col__image-col {
    width: 100%;
}

.layout-two-col__image {
    width: 100%;
    height: auto;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
}

.layout-two-col__content-col {
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.layout-two-col__label {
    display: inline-block;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-wide);
    color: var(--color-accent);
    margin-bottom: var(--spacing-2);
}

.layout-two-col__heading {
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-primary);
    margin: 0 0 var(--spacing-4);
    line-height: var(--line-height-tight);
}

.layout-two-col__text {
    font-size: var(--font-size-base);
    color: var(--color-text-secondary);
    margin: 0 0 var(--spacing-6);
    line-height: var(--line-height-relaxed);
}

.layout-two-col__slot {
    margin-top: var(--spacing-4);
}

@media (min-width: 768px) {
    .layout-two-col {
        flex-direction: row;
        align-items: center;
    }

    .layout-two-col__image-col {
        width: 38%;
        flex-shrink: 0;
    }

    .layout-two-col__content-col {
        width: 58%;
    }

    .layout-two-col__heading {
        font-size: var(--font-size-4xl);
    }
}

/* Reverse variant (image on right) */
.layout-two-col--reverse {
    flex-direction: column;
}

@media (min-width: 768px) {
    .layout-two-col--reverse {
        flex-direction: row-reverse;
    }
}

/* ==========================================================================
   LAYOUT: Two-Column OP Info (40/50)
   Based on GenerateBlocks pattern for operation/treatment info sections
   ========================================================================== */

.layout-two-col-op-info {
    margin-top: 40px;
}

.layout-two-col-op-info--light {
    background: var(--color-bg-muted);
}

.layout-two-col-op-info__container {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    column-gap: 40px;
    max-width: var(--container-xl);
    margin-left: auto;
    margin-right: auto;
    padding: var(--spacing-12) var(--spacing-4);
}

@media (min-width: 768px) {
    .layout-two-col-op-info__container {
        flex-direction: row;
        padding: var(--spacing-12) var(--spacing-2);
    }
}

.layout-two-col-op-info__image-col {
    width: 100%;
}

@media (min-width: 768px) {
    .layout-two-col-op-info__image-col {
        width: 40%;
        flex-shrink: 0;
    }
}

.layout-two-col-op-info__image {
    width: 100%;
    height: auto;
    border-radius: var(--radius-lg);
    object-fit: cover;
}

.layout-two-col-op-info__title-wrapper {
    padding-top: var(--spacing-4);
}

.layout-two-col-op-info__title {
    display: inline;
    font-family: var(--font-family-heading);
    font-size: var(--text-2xl);
    font-weight: var(--font-semibold);
    color: var(--color-text-primary);
    margin-top: var(--spacing-4);
}

@media (max-width: 767px) {
    .layout-two-col-op-info__title {
        font-size: 1.8rem;
    }
}

.layout-two-col-op-info__content-col {
    width: 100%;
    padding-top: var(--spacing-4);
}

@media (min-width: 768px) {
    .layout-two-col-op-info__content-col {
        width: 50%;
        padding-top: 0;
    }
}

.layout-two-col-op-info__text {
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
    color: var(--color-text-secondary);
}

.layout-two-col-op-info__text p {
    margin-bottom: var(--spacing-4);
}

.layout-two-col-op-info__text p:last-child {
    margin-bottom: 0;
}

.layout-two-col-op-info__buttons {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-4);
    margin-top: var(--spacing-6);
}

/* ==========================================================================
   LAYOUT 3: Card Grid (2x2)
   ========================================================================== */

.layout-card-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-5);
    max-width: var(--container-xl);
    margin: 0 auto;
    padding: var(--spacing-8) var(--spacing-6);
}

.layout-card-grid__card {
    background: var(--color-white);
    padding: var(--spacing-6);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-border-subtle);
    transition: var(--transition-all);
}

.layout-card-grid__card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.layout-card-grid__icon {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-accent-subtle);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-4);
    color: var(--color-accent);
}

.layout-card-grid__title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-primary);
    margin: 0 0 var(--spacing-2);
}

.layout-card-grid__text {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    margin: 0;
    line-height: var(--line-height-relaxed);
}

@media (min-width: 576px) {
    .layout-card-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* 3-column variant */
.layout-card-grid--3col {
    grid-template-columns: 1fr;
}

@media (min-width: 576px) {
    .layout-card-grid--3col {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 992px) {
    .layout-card-grid--3col {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* ==========================================================================
   LAYOUT 4: Horizontal Timeline
   ========================================================================== */

.layout-timeline-horizontal {
    position: relative;
    padding: var(--spacing-8) var(--spacing-6);
    overflow-x: auto;
}

.layout-timeline-horizontal__line {
    position: absolute;
    top: calc(var(--spacing-8) + 2.5rem);
    left: var(--spacing-6);
    right: var(--spacing-6);
    height: 2px;
    background: var(--color-border);
}

.layout-timeline-horizontal__items {
    display: flex;
    justify-content: space-between;
    gap: var(--spacing-4);
    min-width: max-content;
    padding: 0 var(--spacing-4);
}

.layout-timeline-horizontal__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    flex: 1;
    min-width: 120px;
    max-width: 180px;
}

.layout-timeline-horizontal__label {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--color-accent);
    margin-bottom: var(--spacing-2);
    white-space: nowrap;
}

.layout-timeline-horizontal__dot {
    width: 16px;
    height: 16px;
    background: var(--color-accent);
    border-radius: var(--radius-full);
    border: 3px solid var(--color-white);
    box-shadow: 0 0 0 2px var(--color-accent);
    margin-bottom: var(--spacing-3);
    position: relative;
    z-index: 1;
}

.layout-timeline-horizontal__text {
    font-size: var(--font-size-xs);
    color: var(--color-text-secondary);
    line-height: var(--line-height-snug);
    max-width: 150px;
    margin: 0;
}

@media (min-width: 768px) {
    .layout-timeline-horizontal__items {
        min-width: 100%;
        padding: 0;
    }

    .layout-timeline-horizontal__text {
        font-size: var(--font-size-sm);
    }
}

/* ==========================================================================
   LAYOUT 5: Vertical Timeline
   ========================================================================== */

.layout-timeline-vertical {
    padding: var(--spacing-8) var(--spacing-6);
    max-width: var(--container-lg);
    margin: 0 auto;
}

.layout-timeline-vertical__item {
    display: flex;
    gap: var(--spacing-4);
    padding: var(--spacing-6) 0;
    border-top: 2px solid var(--color-border);
}

.layout-timeline-vertical__item:first-child {
    border-top: none;
}

.layout-timeline-vertical__dot {
    width: 12px;
    height: 12px;
    background: var(--color-accent);
    border-radius: var(--radius-full);
    flex-shrink: 0;
    margin-top: var(--spacing-1);
}

.layout-timeline-vertical__content {
    flex: 1;
}

.layout-timeline-vertical__label {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--color-accent);
    margin-bottom: var(--spacing-1);
}

.layout-timeline-vertical__text {
    font-size: var(--font-size-base);
    color: var(--color-text-secondary);
    margin: 0;
    line-height: var(--line-height-relaxed);
}

/* ==========================================================================
   LAYOUT 6: Image Slider with Thumbnails
   ========================================================================== */

.layout-slider-thumbs {
    max-width: var(--container-xl);
    margin: 0 auto;
    padding: var(--spacing-8) var(--spacing-6);
}

.layout-slider-thumbs__main {
    position: relative;
    margin-bottom: var(--spacing-4);
}

.layout-slider-thumbs__image {
    width: 100%;
    height: auto;
    aspect-ratio: 16/9;
    object-fit: cover;
    border-radius: var(--radius-lg);
}

.layout-slider-thumbs__nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    background: var(--color-white);
    border: none;
    border-radius: var(--radius-full);
    box-shadow: var(--shadow-md);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-primary);
    font-size: var(--font-size-2xl);
    line-height: 1;
    transition: var(--transition-fast);
}

.layout-slider-thumbs__nav:hover {
    background: var(--color-bg-hover);
}

.layout-slider-thumbs__nav--prev {
    left: var(--spacing-4);
}

.layout-slider-thumbs__nav--next {
    right: var(--spacing-4);
}

.layout-slider-thumbs__thumbnails {
    display: flex;
    gap: var(--spacing-3);
    overflow-x: auto;
    padding: var(--spacing-2) 0;
}

.layout-slider-thumbs__thumb {
    width: 80px;
    height: 60px;
    flex-shrink: 0;
    border-radius: var(--radius-sm);
    object-fit: cover;
    cursor: pointer;
    opacity: 0.6;
    transition: var(--transition-fast);
    border: 2px solid transparent;
}

.layout-slider-thumbs__thumb:hover,
.layout-slider-thumbs__thumb--active {
    opacity: 1;
}

.layout-slider-thumbs__thumb--active {
    border-color: var(--color-accent);
}

/* ==========================================================================
   LAYOUT 7: Card Carousel
   ========================================================================== */

.layout-card-carousel {
    padding: var(--spacing-8) 0;
    position: relative;
}

.layout-card-carousel__container {
    display: flex;
    gap: var(--spacing-5);
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    padding: var(--spacing-4) var(--spacing-6);
    -webkit-overflow-scrolling: touch;
}

.layout-card-carousel__card {
    flex: 0 0 280px;
    scroll-snap-align: start;
    background: var(--color-white);
    padding: var(--spacing-6);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-border-subtle);
}

.layout-card-carousel__nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    background: var(--color-white);
    border: none;
    border-radius: var(--radius-full);
    box-shadow: var(--shadow-md);
    cursor: pointer;
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 2;
}

.layout-card-carousel__nav--prev {
    left: var(--spacing-2);
}

.layout-card-carousel__nav--next {
    right: var(--spacing-2);
}

.layout-card-carousel__dots {
    display: flex;
    justify-content: center;
    gap: var(--spacing-2);
    margin-top: var(--spacing-6);
}

.layout-card-carousel__dot {
    width: 10px;
    height: 10px;
    border-radius: var(--radius-full);
    background: var(--color-border);
    border: none;
    cursor: pointer;
    transition: var(--transition-fast);
}

.layout-card-carousel__dot--active {
    background: var(--color-accent);
}

@media (min-width: 768px) {
    .layout-card-carousel__nav {
        display: flex;
    }

    .layout-card-carousel__card {
        flex: 0 0 320px;
    }
}

/* ==========================================================================
   LAYOUT 8: Review/Testimonial Card
   ========================================================================== */

.layout-review-card {
    background: var(--color-white);
    padding: var(--spacing-6);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-border-subtle);
}

.layout-review-card__header {
    display: flex;
    align-items: center;
    gap: var(--spacing-3);
    margin-bottom: var(--spacing-4);
}

.layout-review-card__avatar {
    width: 48px;
    height: 48px;
    border-radius: var(--radius-full);
    object-fit: cover;
}

.layout-review-card__avatar--placeholder {
    background: var(--color-bg-muted);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-muted);
}

.layout-review-card__meta {
    flex: 1;
}

.layout-review-card__name {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-primary);
    margin: 0;
}

.layout-review-card__date {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    margin: 0;
}

.layout-review-card__platform {
    width: 24px;
    height: 24px;
    color: var(--color-text-muted);
}

.layout-review-card__stars {
    display: flex;
    gap: var(--spacing-1);
    margin-bottom: var(--spacing-4);
    color: var(--color-rating-star);
}

.layout-review-card__text {
    font-size: var(--font-size-base);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    margin: 0;
}

.layout-review-card__more {
    display: inline-block;
    margin-top: var(--spacing-3);
    font-size: var(--font-size-sm);
    color: var(--color-accent);
    font-weight: var(--font-weight-medium);
}

/* ==========================================================================
   LAYOUT 9: Service/Feature Card
   ========================================================================== */

.layout-service-card {
    background: var(--color-white);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);
    overflow: hidden;
    transition: var(--transition-all);
}

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

.layout-service-card__image {
    width: 100%;
    height: 200px;
    object-fit: cover;
}

.layout-service-card__content {
    padding: var(--spacing-6);
}

.layout-service-card__label {
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-wide);
    color: var(--color-accent);
    margin-bottom: var(--spacing-2);
}

.layout-service-card__title {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-primary);
    margin: 0 0 var(--spacing-3);
}

.layout-service-card__text {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    margin: 0 0 var(--spacing-5);
}

.layout-service-card__cta {
    display: inline-block;
}

/* ==========================================================================
   LAYOUT 10: Section with Centered Header
   ========================================================================== */

.layout-section-centered {
    padding: var(--spacing-16) var(--spacing-6);
}

.layout-section-centered__header {
    text-align: center;
    max-width: 700px;
    margin: 0 auto var(--spacing-12);
}

.layout-section-centered__label {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-wide);
    color: var(--color-accent);
    margin-bottom: var(--spacing-3);
}

.layout-section-centered__title {
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-primary);
    margin: 0 0 var(--spacing-4);
    line-height: var(--line-height-tight);
}

.layout-section-centered__text {
    font-size: var(--font-size-lg);
    color: var(--color-text-secondary);
    margin: 0;
    line-height: var(--line-height-relaxed);
}

.layout-section-centered__content {
    max-width: var(--container-xl);
    margin: 0 auto;
}

@media (min-width: 768px) {
    .layout-section-centered__title {
        font-size: var(--font-size-4xl);
    }
}

/* Background variants */
.layout-section-centered--light {
    background: var(--color-bg-muted);
}

.layout-section-centered--dark {
    background: var(--color-text-primary);
}

.layout-section-centered--dark .layout-section-centered__label {
    color: var(--color-accent-300);
}

.layout-section-centered--dark .layout-section-centered__title,
.layout-section-centered--dark .layout-section-centered__text {
    color: var(--color-text-inverse);
}

/* ==========================================================================
   LAYOUT: Comprehensive Footer
   Based on GenerateBlocks structure from klinik.team
   ========================================================================== */

.layout-footer {
    --footer-bg-dark: oklch(0.20 0.005 70);
    --footer-text-light: oklch(0.85 0.005 70);
    --footer-text-muted: oklch(0.65 0.005 70);
    --footer-border: oklch(0.35 0.005 70);
    margin: 0;
}

/* Contact Section - Two Column with Image and Form */
.layout-footer__contact-section {
    background: var(--color-bg-base);
    padding: var(--spacing-10) var(--spacing-4);
    border-top: 1px solid var(--color-border);
}

.layout-footer__contact-container {
    max-width: var(--container-xl);
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-10);
}

@media (min-width: 768px) {
    .layout-footer__contact-container {
        flex-direction: row;
        align-items: flex-start;
    }

    .layout-footer__contact-image-col {
        width: 50%;
    }

    .layout-footer__contact-form-col {
        width: 50%;
    }
}

.layout-footer__contact-image-wrap {
    padding: var(--spacing-2);
}

.layout-footer__contact-image {
    width: 100%;
    height: auto;
    border-radius: var(--radius-lg);
    object-fit: cover;
}

.layout-footer__contact-title {
    font-family: var(--font-family-heading);
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-primary);
    margin: 0 0 var(--spacing-6);
}

/* Contact Info Cards Section */
.layout-footer__info-section {
    background: var(--footer-bg-dark);
    color: var(--footer-text-light);
    padding: var(--spacing-10) var(--spacing-4);
}

.layout-footer__info-container {
    max-width: var(--container-xl);
    margin: 0 auto;
}

.layout-footer__info-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-6);
}

@media (min-width: 576px) {
    .layout-footer__info-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 992px) {
    .layout-footer__info-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

.layout-footer__info-card {
    padding: var(--spacing-4);
}

.layout-footer__info-card-title {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-3);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    color: var(--footer-text-light);
    margin: 0 0 var(--spacing-3);
}

.layout-footer__info-icon {
    width: 1.5em;
    height: 1.5em;
    display: flex;
    align-items: center;
    justify-content: center;
}

.layout-footer__info-icon svg {
    width: 100%;
    height: 100%;
}

.layout-footer__info-card-text {
    font-size: var(--font-size-sm);
    color: var(--footer-text-muted);
    margin: 0 0 var(--spacing-3);
    line-height: var(--line-height-relaxed);
}

.layout-footer__info-card-link {
    color: var(--footer-text-light);
    font-size: var(--font-size-sm);
    text-decoration: none;
    transition: color var(--transition-fast);
}

.layout-footer__info-card-link:hover {
    color: var(--color-accent-300);
}

/* Footer Links Section */
.layout-footer__links-section {
    background: var(--footer-bg-dark);
    color: var(--footer-text-light);
    padding: var(--spacing-12) var(--spacing-4);
}

.layout-footer__links-container {
    max-width: var(--container-xl);
    margin: 0 auto;
}

.layout-footer__links-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-8);
}

@media (min-width: 576px) {
    .layout-footer__links-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .layout-footer__links-col--spacer {
        display: none;
    }
}

@media (min-width: 992px) {
    .layout-footer__links-grid {
        grid-template-columns: repeat(5, 1fr);
    }

    .layout-footer__links-col--spacer {
        display: block;
    }
}

.layout-footer__links-col {
    padding: var(--spacing-2);
}

.layout-footer__links-title {
    font-size: var(--font-size-base);
    color: var(--footer-text-light);
    margin: 0 0 var(--spacing-4);
}

.layout-footer__links-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.layout-footer__links-list li {
    margin-bottom: var(--spacing-2);
}

.layout-footer__links-list a {
    color: var(--footer-text-muted);
    font-size: 15px;
    text-decoration: none;
    transition: color var(--transition-fast);
}

.layout-footer__links-list a:hover {
    color: var(--footer-text-light);
}

.layout-footer__links-list--hours li {
    margin-bottom: var(--spacing-3);
    color: var(--footer-text-muted);
    font-size: 15px;
    line-height: var(--line-height-normal);
}

.layout-footer__links-list--hours strong {
    color: var(--footer-text-light);
}

/* Brand Section */
.layout-footer__brand-section {
    background: var(--footer-bg-dark);
    color: var(--footer-text-light);
    padding: var(--spacing-12) var(--spacing-4);
    border-top: 1px solid var(--footer-border);
    border-bottom: 1px solid var(--footer-border);
}

.layout-footer__brand-container {
    max-width: var(--container-xl);
    margin: 0 auto;
}

.layout-footer__brand-name {
    font-family: var(--font-family-heading);
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-bold);
    color: var(--footer-text-light);
    margin: 0;
}

/* Copyright Section */
.layout-footer__copyright-section {
    background: var(--footer-bg-dark);
    color: var(--footer-text-muted);
    padding: var(--spacing-12) var(--spacing-4);
}

.layout-footer__copyright-container {
    max-width: var(--container-xl);
    margin: 0 auto;
}

.layout-footer__copyright-row {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4);
    align-items: flex-start;
}

@media (min-width: 768px) {
    .layout-footer__copyright-row {
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
    }
}

.layout-footer__copyright-text {
    font-size: 15px;
    margin: 0;
}

.layout-footer__social-links {
    display: flex;
    gap: var(--spacing-3);
}

.layout-footer__social-link {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--footer-text-light);
    transition: color var(--transition-fast);
}

.layout-footer__social-link svg {
    width: 20px;
    height: 20px;
}

.layout-footer__social-link:hover {
    color: var(--color-accent-300);
}

/* ==========================================================================
   LAYOUT 12: Contact Form Section
   ========================================================================== */

.layout-contact-form {
    padding: var(--spacing-16) var(--spacing-6);
    background: var(--color-bg-muted);
}

.layout-contact-form__container {
    max-width: 600px;
    margin: 0 auto;
}

.layout-contact-form__title {
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-primary);
    text-align: center;
    margin: 0 0 var(--spacing-8);
}

.layout-contact-form__form {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-5);
}

.layout-contact-form__field {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2);
}

.layout-contact-form__label {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--color-text-primary);
}

.layout-contact-form__input,
.layout-contact-form__textarea {
    padding: var(--spacing-3) var(--spacing-4);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: var(--font-size-base);
    font-family: inherit;
    background: var(--color-white);
    transition: var(--transition-fast);
}

.layout-contact-form__input:focus,
.layout-contact-form__textarea:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px var(--color-focus-ring);
}

.layout-contact-form__textarea {
    min-height: 150px;
    resize: vertical;
}

.layout-contact-form__submit {
    align-self: flex-start;
    margin-top: var(--spacing-2);
}

/* ==========================================================================
   LAYOUT 13: Split Content (50/50)
   ========================================================================== */

.layout-split {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-8);
    max-width: var(--container-xl);
    margin: 0 auto;
    padding: var(--spacing-12) var(--spacing-6);
}

.layout-split__col {
    width: 100%;
}

@media (min-width: 768px) {
    .layout-split {
        flex-direction: row;
        align-items: center;
    }

    .layout-split__col {
        width: 50%;
    }
}

/* Reverse variant */
.layout-split--reverse {
    flex-direction: column;
}

@media (min-width: 768px) {
    .layout-split--reverse {
        flex-direction: row-reverse;
    }
}

/* ==========================================================================
   LAYOUT 14: Full-Width Banner
   ========================================================================== */

.layout-banner {
    width: 100%;
    padding: var(--spacing-16) var(--spacing-6);
    background: var(--color-bg-muted);
}

.layout-banner__container {
    max-width: var(--container-xl);
    margin: 0 auto;
    text-align: center;
}

.layout-banner__title {
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-primary);
    margin: 0 0 var(--spacing-4);
}

.layout-banner__text {
    font-size: var(--font-size-lg);
    color: var(--color-text-secondary);
    margin: 0 0 var(--spacing-6);
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
}

.layout-banner__actions {
    display: flex;
    justify-content: center;
    gap: var(--spacing-4);
    flex-wrap: wrap;
}

@media (min-width: 768px) {
    .layout-banner__title {
        font-size: var(--font-size-4xl);
    }
}

/* Background variants */
.layout-banner--accent {
    background: var(--color-accent);
}

.layout-banner--accent .layout-banner__title,
.layout-banner--accent .layout-banner__text {
    color: var(--color-text-inverse);
}

.layout-banner--dark {
    background: var(--color-text-primary);
}

.layout-banner--dark .layout-banner__title,
.layout-banner--dark .layout-banner__text {
    color: var(--color-text-inverse);
}

/* With background image */
.layout-banner--image {
    background-size: cover;
    background-position: center;
    position: relative;
}

.layout-banner--image::before {
    content: '';
    position: absolute;
    inset: 0;
    background: oklch(0% 0 0 / 0.5);
}

.layout-banner--image .layout-banner__container {
    position: relative;
    z-index: 1;
}

.layout-banner--image .layout-banner__title,
.layout-banner--image .layout-banner__text {
    color: var(--color-text-inverse);
}

/* ==========================================================================
   LAYOUT 15: Icon + Text Row
   ========================================================================== */

.layout-icon-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4);
}

.layout-icon-list__item {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-3);
}

.layout-icon-list__icon {
    width: 24px;
    height: 24px;
    flex-shrink: 0;
    color: var(--color-accent);
    margin-top: var(--spacing-0-5);
}

.layout-icon-list__icon--circle {
    width: 8px;
    height: 8px;
    background: var(--color-accent);
    border-radius: var(--radius-full);
    margin-top: var(--spacing-2);
}

.layout-icon-list__text {
    font-size: var(--font-size-base);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    margin: 0;
}

/* Inline variant */
.layout-icon-list--inline {
    flex-direction: row;
    flex-wrap: wrap;
    gap: var(--spacing-6);
}

/* With larger icons */
.layout-icon-list--large .layout-icon-list__icon {
    width: 32px;
    height: 32px;
}

.layout-icon-list--large .layout-icon-list__icon--circle {
    width: 12px;
    height: 12px;
}

/* ==========================================================================
   Shared UI Components (Buttons, etc.)
   ========================================================================== */

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-2);
    padding: var(--spacing-3) var(--spacing-6);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    font-family: inherit;
    line-height: 1;
    border-radius: var(--radius-md);
    border: none;
    cursor: pointer;
    text-decoration: none;
    transition: var(--transition-fast);
}

.btn--primary {
    background: var(--color-accent);
    color: var(--color-text-inverse);
}

.btn--primary:hover {
    background: var(--color-accent-hover);
    color: var(--color-text-inverse);
}

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

.btn--secondary:hover {
    background: var(--color-accent);
    color: var(--color-text-inverse);
}

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

.btn--outline:hover {
    background: var(--color-accent);
    color: var(--color-text-inverse);
}

.btn--ghost {
    background: transparent;
    color: var(--color-text-primary);
}

.btn--ghost:hover {
    background: var(--color-bg-hover);
}

.btn--sm {
    padding: var(--spacing-2) var(--spacing-4);
    font-size: var(--font-size-sm);
}

.btn--lg {
    padding: var(--spacing-4) var(--spacing-8);
    font-size: var(--font-size-lg);
}

/* Inverse buttons for dark backgrounds */
.btn--inverse {
    background: var(--color-white);
    color: var(--color-text-primary);
}

.btn--inverse:hover {
    background: oklch(0.95 0.002 70);
    color: var(--color-text-primary);
}

/* ==========================================================================
   LAYOUT: Two-Column OP Info with CTA
   Based on GenerateBlocks pattern for operation info with call-to-action buttons
   ========================================================================== */

.layout-two-col-op-info-cta {
    background: var(--color-bg-surface);
    padding: var(--spacing-16) var(--spacing-4);
}

.layout-two-col-op-info-cta__container {
    max-width: var(--container-xl);
    margin-left: auto;
    margin-right: auto;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-10);
    align-items: flex-start;
}

.layout-two-col-op-info-cta__image-col {
    width: 100%;
}

.layout-two-col-op-info-cta__image {
    width: 100%;
    height: auto;
    border-radius: var(--radius-lg);
    object-fit: cover;
}

.layout-two-col-op-info-cta__headline-wrapper {
    padding-top: var(--spacing-4);
}

.layout-two-col-op-info-cta__headline {
    font-family: var(--font-family-heading);
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-primary);
    margin: var(--spacing-4) 0 0 0;
    display: inline;
}

.layout-two-col-op-info-cta__headline-prefix {
    color: inherit;
}

.layout-two-col-op-info-cta__content-col {
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}

.layout-two-col-op-info-cta__text {
    font-size: var(--font-size-base);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    margin: 0;
}

.layout-two-col-op-info-cta__buttons {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-4);
    margin-top: var(--spacing-8);
}

.layout-two-col-op-info-cta__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-3) var(--spacing-6);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-medium);
    font-family: inherit;
    line-height: 1;
    border-radius: var(--radius-md);
    text-decoration: none;
    transition: var(--transition-fast);
    cursor: pointer;
}

.layout-two-col-op-info-cta__button--primary {
    background: var(--color-accent);
    color: var(--color-text-inverse);
    border: none;
}

.layout-two-col-op-info-cta__button--primary:hover {
    background: var(--color-accent-hover);
    color: var(--color-text-inverse);
}

.layout-two-col-op-info-cta__button--secondary {
    background: transparent;
    color: var(--color-text-primary);
    border: 2px solid var(--color-border-strong);
}

.layout-two-col-op-info-cta__button--secondary:hover {
    background: var(--color-accent);
    color: var(--color-text-inverse);
    border-color: var(--color-accent);
}

/* Desktop layout */
@media (min-width: 768px) {
    .layout-two-col-op-info-cta__container {
        flex-direction: row;
        gap: var(--spacing-10);
    }

    .layout-two-col-op-info-cta__image-col {
        width: 40%;
        flex-shrink: 0;
    }

    .layout-two-col-op-info-cta__content-col {
        width: 50%;
    }

    .layout-two-col-op-info-cta__headline {
        font-size: var(--font-size-3xl);
    }
}

/* Dark variant */
.layout-two-col-op-info-cta--dark {
    background: var(--color-text-primary);
}

.layout-two-col-op-info-cta--dark .layout-two-col-op-info-cta__headline {
    color: var(--color-text-inverse);
}

.layout-two-col-op-info-cta--dark .layout-two-col-op-info-cta__text {
    color: var(--color-text-inverse);
    opacity: 0.85;
}

.layout-two-col-op-info-cta--dark .layout-two-col-op-info-cta__button--secondary {
    color: var(--color-text-inverse);
    border-color: var(--color-text-inverse);
}

.layout-two-col-op-info-cta--dark .layout-two-col-op-info-cta__button--secondary:hover {
    background: var(--color-text-inverse);
    color: var(--color-text-primary);
}

/* ==========================================================================
   LAYOUT: Text Columns (50-50)
   Two-column layout with headline left and content right
   Based on GenerateBlocks pattern
   ========================================================================== */

.layout-text-columns {
    padding: var(--spacing-16) var(--spacing-4);
}

.layout-text-columns--light {
    background: var(--color-bg-muted);
}

.layout-text-columns__container {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-6);
    max-width: var(--container-xl);
    margin-left: auto;
    margin-right: auto;
}

@media (min-width: 768px) {
    .layout-text-columns__container {
        flex-direction: row;
        gap: 40px;
    }
}

.layout-text-columns__headline-col {
    width: 100%;
}

@media (min-width: 768px) {
    .layout-text-columns__headline-col {
        width: 40%;
        flex-shrink: 0;
    }
}

.layout-text-columns__headline {
    font-family: var(--font-family-heading);
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-primary);
    line-height: var(--line-height-tight);
    margin: 0;
}

@media (max-width: 767px) {
    .layout-text-columns__headline {
        font-size: 2.5rem;
    }
}

.layout-text-columns__content-col {
    width: 100%;
}

@media (min-width: 768px) {
    .layout-text-columns__content-col {
        width: 50%;
    }
}

.layout-text-columns__text {
    font-size: var(--font-size-base);
    line-height: var(--line-height-relaxed);
    color: var(--color-text-secondary);
}

.layout-text-columns__text p {
    margin-bottom: var(--spacing-4);
}

.layout-text-columns__text p:last-child {
    margin-bottom: 0;
}

/* ==========================================================================
   HEADER: Mega Menu Navigation
   Modern header with logo, mega menu dropdown, and CTA button
   ========================================================================== */

/* Header wrapper - main container */
.header-wrap {
    position: sticky;
    top: 0;
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-4);
    padding: var(--spacing-3) var(--spacing-4);
    background: var(--color-bg-base);
    box-shadow: var(--shadow-sm);
}

@media (min-width: 992px) {
    .header-wrap {
        padding: var(--spacing-4) var(--spacing-8);
    }
}

/* Logo section */
.header-logo-wrap {
    flex-shrink: 0;
}

.header-logo {
    display: flex;
    align-items: center;
}

.header-logo .custom-logo-link {
    display: block;
    line-height: 0;
}

.header-logo .custom-logo {
    max-height: 50px;
    width: auto;
    height: auto;
}

@media (min-width: 768px) {
    .header-logo .custom-logo {
        max-height: 64px;
    }
}

.header-logo .site-title-link {
    font-family: var(--font-family-heading);
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-primary);
    text-decoration: none;
}

.header-logo .site-title-link:hover {
    color: var(--color-accent);
}

/* Menu wrapper */
.header-menu-wrap {
    flex: 1;
    display: flex;
    justify-content: flex-end;
}

@media (min-width: 960px) {
    .header-menu-wrap {
        justify-content: center;
    }
}

/* Mega Menu Wrapper */
.mega-menu-wrap {
    position: relative;
}

/* Mobile toggle button */
.mega-menu-toggle {
    display: flex;
    align-items: center;
}

@media (min-width: 960px) {
    .mega-menu-toggle {
        display: none;
    }
}

.mega-toggle-animated {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-2);
    background: transparent;
    border: none;
    cursor: pointer;
}

.mega-toggle-animated-box {
    position: relative;
    display: block;
    width: 28px;
    height: 20px;
}

.mega-toggle-animated-inner,
.mega-toggle-animated-inner::before,
.mega-toggle-animated-inner::after {
    position: absolute;
    width: 28px;
    height: 3px;
    background-color: var(--color-text-primary);
    border-radius: 2px;
    transition: transform 0.22s ease, opacity 0.22s ease;
}

.mega-toggle-animated-inner {
    top: 50%;
    transform: translateY(-50%);
}

.mega-toggle-animated-inner::before,
.mega-toggle-animated-inner::after {
    content: '';
    left: 0;
}

.mega-toggle-animated-inner::before {
    top: -8px;
}

.mega-toggle-animated-inner::after {
    bottom: -8px;
}

/* Toggle animation when open */
.mega-toggle-animated[aria-expanded="true"] .mega-toggle-animated-inner {
    background-color: transparent;
}

.mega-toggle-animated[aria-expanded="true"] .mega-toggle-animated-inner::before {
    top: 0;
    transform: rotate(45deg);
}

.mega-toggle-animated[aria-expanded="true"] .mega-toggle-animated-inner::after {
    bottom: 0;
    transform: rotate(-45deg);
}

/* Main menu list */
.mega-menu {
    display: none;
    list-style: none;
    margin: 0;
    padding: 0;
}

@media (min-width: 960px) {
    .mega-menu {
        display: flex;
        align-items: center;
        gap: var(--spacing-1);
    }
}

/* Mobile menu open state */
.mega-menu-open .mega-menu {
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--color-bg-base);
    padding: var(--spacing-16) var(--spacing-4) var(--spacing-4);
    overflow-y: auto;
    z-index: 999;
}

/* Menu items */
.mega-menu-item {
    position: relative;
}

.mega-menu-link {
    display: flex;
    align-items: center;
    gap: var(--spacing-1);
    padding: var(--spacing-3) var(--spacing-4);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-medium);
    color: var(--color-text-secondary);
    text-decoration: none;
    transition: color var(--transition-fast);
    white-space: nowrap;
}

.mega-menu-link:hover {
    color: var(--color-accent);
}

/* Arrow indicator */
.mega-indicator {
    display: inline-block;
    width: 0;
    height: 0;
    margin-left: var(--spacing-1);
    border-left: 5px solid transparent;
    border-right: 5px solid transparent;
    border-top: 5px solid currentColor;
    transition: transform var(--transition-fast);
}

.mega-menu-item-open>.mega-menu-link .mega-indicator,
.mega-menu-item-has-children:hover>.mega-menu-link .mega-indicator {
    transform: rotate(180deg);
}

/* Mega submenu dropdown */
.mega-sub-menu {
    display: none;
    list-style: none;
    margin: 0;
    padding: 0;
    background: var(--color-bg-base);
}

@media (min-width: 960px) {
    .mega-menu-item-has-children>.mega-sub-menu {
        position: absolute;
        top: 100%;
        left: 50%;
        transform: translateX(-50%);
        min-width: 800px;
        max-width: 1200px;
        padding: var(--spacing-6);
        border-radius: var(--radius-lg);
        box-shadow: var(--shadow-xl);
        border: 1px solid var(--color-border-subtle);
        opacity: 0;
        visibility: hidden;
        transition: opacity var(--transition-fast), visibility var(--transition-fast);
    }

    .mega-menu-item-open>.mega-sub-menu,
    .mega-menu-item-has-children:hover>.mega-sub-menu {
        display: block;
        opacity: 1;
        visibility: visible;
    }
}

/* Mobile submenu */
@media (max-width: 959px) {
    .mega-menu-item-open>.mega-sub-menu {
        display: block;
        padding-left: var(--spacing-4);
        border-left: 2px solid var(--color-border-subtle);
        margin-left: var(--spacing-4);
    }
}

/* Tab navigation within mega menu */
.mega-sub-menu-tabs {
    display: block;
}

.mega-tab-nav {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-2);
    list-style: none;
    margin: 0 0 var(--spacing-4) 0;
    padding: 0 0 var(--spacing-4) 0;
    border-bottom: 1px solid var(--color-border-subtle);
}

.mega-tab-item {
    margin: 0;
}

.mega-tab-item .mega-menu-link {
    padding: var(--spacing-2) var(--spacing-4);
    border-radius: var(--radius-md);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-muted);
    transition: all var(--transition-fast);
}

.mega-tab-item:hover .mega-menu-link,
.mega-tab-active .mega-menu-link {
    background: var(--color-accent-subtle);
    color: var(--color-accent);
}

.mega-tab-item .mega-indicator {
    border-top: none;
    border-bottom: 5px solid currentColor;
    margin-left: var(--spacing-2);
}

/* Tab content panels */
.mega-tab-content {
    display: none;
}

.mega-tab-content-active {
    display: block;
}

/* Grid layout for columns */
.mega-menu-row {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: var(--spacing-6);
}

@media (max-width: 959px) {
    .mega-menu-row {
        display: flex;
        flex-direction: column;
        gap: var(--spacing-4);
    }
}

.mega-menu-column {
    grid-column: span var(--span, 4);
}

@media (max-width: 959px) {
    .mega-menu-column {
        grid-column: span 12;
    }
}

.mega-menu-column-inner {
    padding: var(--spacing-2);
}

/* Block titles */
.mega-block-title {
    font-family: var(--font-family-heading);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-primary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin: 0 0 var(--spacing-3) 0;
    padding-bottom: var(--spacing-2);
    border-bottom: 2px solid var(--color-accent);
}

/* Column links */
.mega-column-links {
    list-style: none;
    margin: 0;
    padding: 0;
}

.mega-column-links .menu-item {
    margin: 0;
}

.mega-column-links .menu-item a {
    display: block;
    padding: var(--spacing-2) 0;
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    text-decoration: none;
    transition: color var(--transition-fast), padding-left var(--transition-fast);
    border-bottom: 1px solid transparent;
}

.mega-column-links .menu-item a:hover {
    color: var(--color-accent);
    padding-left: var(--spacing-2);
}

.mega-column-links .menu-item.current-menu-item a {
    color: var(--color-accent);
    font-weight: var(--font-weight-semibold);
}

/* Close button for mobile */
.mega-close {
    display: none;
    position: fixed;
    top: var(--spacing-4);
    right: var(--spacing-4);
    width: 44px;
    height: 44px;
    padding: 0;
    background: var(--color-bg-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-full);
    cursor: pointer;
    z-index: 1001;
    align-items: center;
    justify-content: center;
}

.mega-menu-open .mega-close {
    display: flex;
}

.mega-close-icon {
    position: relative;
    width: 20px;
    height: 20px;
}

.mega-close-icon::before,
.mega-close-icon::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    height: 2px;
    background: var(--color-text-primary);
    border-radius: 1px;
}

.mega-close-icon::before {
    transform: rotate(45deg);
}

.mega-close-icon::after {
    transform: rotate(-45deg);
}

/* CTA button section */
.header-cta-wrap {
    flex-shrink: 0;
}

.header-cta-inner {
    display: flex;
    align-items: center;
    gap: var(--spacing-3);
}

.header-cta-button {
    white-space: nowrap;
}

/* Hide on mobile/tablet utility classes */
@media (max-width: 767px) {
    .hide-mobile {
        display: none !important;
    }
}

@media (min-width: 768px) and (max-width: 991px) {
    .hide-tablet {
        display: none !important;
    }
}

/* Body lock when mobile menu is open */
body.mega-menu-mobile-open {
    overflow: hidden;
}

/* Animation effects */
@media (min-width: 960px) {
    .mega-menu-item-has-children>.mega-sub-menu {
        transform: translateX(-50%) translateY(10px);
    }

    .mega-menu-item-open>.mega-sub-menu,
    .mega-menu-item-has-children:hover>.mega-sub-menu {
        transform: translateX(-50%) translateY(0);
    }
}

/* ==========================================================================
   LAYOUT: Team Member Section
   Doctor/team member profile with image, info boxes, and career milestones timeline
   Based on GenerateBlocks pattern
   ========================================================================== */

.layout-team-member {
    margin-top: var(--spacing-5);
    margin-bottom: var(--spacing-5);
}

.layout-team-member__container {
    max-width: var(--container-xl);
    margin-left: auto;
    margin-right: auto;
    padding: var(--spacing-10) var(--spacing-4);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-10);
}

@media (min-width: 768px) {
    .layout-team-member__container {
        flex-direction: row;
        flex-wrap: wrap;
        padding: var(--spacing-10);
    }
}

/* Image Column */
.layout-team-member__image-col {
    width: 100%;
}

@media (min-width: 768px) {
    .layout-team-member__image-col {
        width: 38%;
        flex-shrink: 0;
    }
}

.layout-team-member__image {
    width: 100%;
    height: auto;
    border-radius: var(--radius-lg);
    object-fit: cover;
}

/* Content Column */
.layout-team-member__content-col {
    width: 100%;
}

@media (min-width: 768px) {
    .layout-team-member__content-col {
        width: 58%;
    }
}

.layout-team-member__label {
    font-family: var(--font-family-heading);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-secondary);
    margin: 0 0 var(--spacing-2);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.layout-team-member__name {
    font-family: var(--font-family-heading);
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-primary);
    margin: 0 0 var(--spacing-4);
    line-height: var(--line-height-tight);
}

.layout-team-member__intro {
    font-size: var(--font-size-base);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    margin: 0 0 var(--spacing-6);
}

/* Info Boxes Grid */
.layout-team-member__info-grid {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: var(--spacing-5);
}

.layout-team-member__info-box {
    width: 100%;
    background: var(--color-bg-muted);
    padding: var(--spacing-4);
    border-radius: var(--radius-lg);
}

@media (min-width: 576px) {
    .layout-team-member__info-box {
        width: calc(50% - var(--spacing-3));
    }
}

.layout-team-member__info-text {
    font-size: var(--font-size-base);
    color: var(--color-text-secondary);
    margin: 0;
    line-height: var(--line-height-relaxed);
}

/* Contact Box */
.layout-team-member__info-box--contact {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2);
}

.layout-team-member__contact-label {
    font-size: var(--font-size-base);
    color: var(--color-text-primary);
    margin: 0;
}

.layout-team-member__contact-link {
    font-size: var(--font-size-base);
    color: var(--color-accent);
    text-decoration: none;
    transition: color var(--transition-fast);
}

.layout-team-member__contact-link:hover {
    color: var(--color-accent-hover);
    text-decoration: underline;
}

/* Career Milestones Timeline */
.layout-team-member__timeline {
    width: 100%;
    display: flex;
    flex-direction: row;
    position: relative;
    padding: var(--spacing-4) 0;
}

@media (min-width: 992px) {
    .layout-team-member__timeline {
        width: 100%;
    }
}

/* Horizontal line through the middle of markers */
.layout-team-member__timeline-line {
    position: absolute;
    top: calc(var(--spacing-4) + 0.75em);
    left: 0;
    right: 0;
    height: 2px;
    background: var(--color-bg-muted);
}

.layout-team-member__timeline-item {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    position: relative;
    z-index: 1;
}

.layout-team-member__timeline-marker {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1.5em;
    height: 1.5em;
    color: var(--color-bg-muted);
    margin-bottom: var(--spacing-4);
}

.layout-team-member__timeline-marker svg {
    width: 100%;
    height: 100%;
}

.layout-team-member__timeline-text {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    margin: 0;
    padding: 0 var(--spacing-2);
}

/* ==========================================================================
   LAYOUT: FAQ Section
   Two-column layout (40%/60%) with title, description, CTA on left and FAQ items on right
   ========================================================================== */

.layout-faq {
    padding: 80px 10px;
}

@media (max-width: 767px) {
    .layout-faq {
        padding: 60px 20px;
    }
}

.layout-faq__container {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: 40px;
    max-width: var(--container-max-width, 1200px);
    margin: 0 auto;
}

@media (max-width: 767px) {
    .layout-faq__container {
        flex-direction: column;
        gap: 40px;
    }
}

/* Left Column (40%) */
.layout-faq__left {
    width: 40%;
    flex-shrink: 0;
}

@media (max-width: 767px) {
    .layout-faq__left {
        width: 100%;
    }
}

.layout-faq__title {
    font-family: var(--font-family-heading);
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-primary);
    margin: 0 0 var(--spacing-4) 0;
}

@media (max-width: 767px) {
    .layout-faq__title {
        font-size: 2.5rem;
    }
}

.layout-faq__description {
    font-size: var(--font-size-base);
    line-height: var(--line-height-relaxed);
    color: var(--color-text-secondary);
    margin: 0;
}

.layout-faq__buttons {
    display: flex;
    gap: 20px;
    margin-top: 40px;
}

@media (max-width: 767px) {
    .layout-faq__buttons {
        flex-direction: column;
        gap: var(--spacing-4);
    }
}

/* Right Column (60%) */
.layout-faq__right {
    width: 60%;
}

@media (max-width: 767px) {
    .layout-faq__right {
        width: 100%;
    }
}

.layout-faq__item {
    margin-bottom: 40px;
}

.layout-faq__item:last-child {
    margin-bottom: 0;
}

.layout-faq__question {
    font-family: var(--font-family-heading);
    font-size: 1.25rem;
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-primary);
    margin: 0 0 var(--spacing-3) 0;
    line-height: var(--line-height-tight);
}

.layout-faq__answer {
    font-size: var(--font-size-base);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    margin: 0;
}

/* ==========================================================================
   Layout: FAQ Grid Section (3-Column)
   ========================================================================== */

.layout-faq-grid {
    padding: 40px 10px 0;
}

@media (max-width: 767px) {
    .layout-faq-grid {
        padding: 40px 20px 0;
    }
}

.layout-faq-grid__container {
    max-width: var(--container-max-width, 1200px);
    margin: 0 auto;
}

.layout-faq-grid__title {
    font-family: var(--font-family-heading);
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-primary);
    margin: 0 0 var(--spacing-8) 0;
}

@media (max-width: 767px) {
    .layout-faq-grid__title {
        font-size: 2.5rem;
    }
}

.layout-faq-grid__row {
    display: flex;
    gap: 40px;
    margin-bottom: 40px;
}

.layout-faq-grid__row:last-child {
    margin-bottom: 0;
}

@media (max-width: 767px) {
    .layout-faq-grid__row {
        flex-direction: column;
        gap: 20px;
        margin-bottom: 20px;
    }
}

.layout-faq-grid__item {
    width: 33.333%;
    padding: 15px;
}

@media (max-width: 767px) {
    .layout-faq-grid__item {
        width: 100%;
    }
}

.layout-faq-grid__item--highlight {
    background-color: var(--color-bg-muted, #f5f5f5);
    border-radius: var(--border-radius-lg);
}

.layout-faq-grid__question {
    font-family: var(--font-family-heading);
    font-size: 1.25rem;
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-primary);
    margin: 0 0 20px 0;
    line-height: var(--line-height-tight);
}

.layout-faq-grid__answer {
    font-size: var(--font-size-base);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    margin: 0;
}

/* ==========================================================================
   Layout: 3 Cards Section
   ========================================================================== */

.layout-3-cards {
    padding: 60px 10px;
    margin-top: 30px;
    background-color: var(--color-bg-muted, #f5f5f5);
}

.layout-3-cards__container {
    max-width: var(--container-max-width, 1200px);
    margin: 0 auto;
    padding-left: 20px;
    padding-right: 20px;
}

@media (min-width: 768px) {
    .layout-3-cards__container {
        padding-left: 0;
        padding-right: 0;
    }
}

.layout-3-cards__header {
    text-align: center;
    margin-bottom: var(--spacing-10);
}

.layout-3-cards__label {
    font-family: var(--font-family-heading);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--color-text-secondary);
    margin-bottom: var(--spacing-2);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.layout-3-cards__headline {
    font-family: var(--font-family-heading);
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-4);
}

@media (max-width: 767px) {
    .layout-3-cards__headline {
        font-size: var(--font-size-2xl);
    }
}

.layout-3-cards__description {
    font-size: var(--font-size-lg);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    max-width: 700px;
    margin: 0 auto;
}

.layout-3-cards__grid {
    display: flex;
    justify-content: center;
    gap: 20px;
}

@media (max-width: 767px) {
    .layout-3-cards__grid {
        flex-direction: column;
        gap: 40px;
    }
}

.layout-3-cards__card {
    width: 33.33%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-start;
    border-radius: var(--radius-lg);
    overflow: hidden;
    text-align: left;
    background: var(--color-bg-base);
}

@media (max-width: 767px) {
    .layout-3-cards__card {
        width: 100%;
    }
}

.layout-3-cards__card-image-wrapper {
    width: 100%;
    margin-bottom: 20px;
}

.layout-3-cards__card-image {
    width: 100%;
    height: auto;
    display: block;
    border-top-left-radius: 8px;
    border-top-right-radius: 8px;
    object-fit: cover;
}

.layout-3-cards__card-content {
    padding: 20px;
    flex-grow: 1;
}

.layout-3-cards__card-label {
    font-family: var(--font-family-heading);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--color-text-secondary);
    margin-bottom: var(--spacing-2);
}

.layout-3-cards__card-headline {
    font-family: var(--font-family-heading);
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-3);
    line-height: var(--line-height-tight);
}

.layout-3-cards__card-description {
    font-size: var(--font-size-base);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    margin: 0;
}

.layout-3-cards__card-footer {
    padding: 20px;
    width: 100%;
}

.layout-3-cards__card-button {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    padding: 0.75rem 1.5rem;
    border-radius: 12px;
    font-weight: 500;
    text-decoration: none;
    transition: all 0.2s ease;
}