/*
Theme Name: Clean Easy Theme
Theme URI: https://clean-easy-berlin.de
Author: CLEAN & EASY Gebäudeservice
Author URI: https://clean-easy-berlin.de
Description: Professional WordPress theme for CLEAN & EASY Gebäudeservice - a Berlin-based cleaning service company. Mobile-first, performance-optimized, and designed for conversions.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.4
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: clean-easy-theme
Tags: cleaning-service, business, one-column, custom-menu, featured-images, translation-ready
*/

/* ==========================================================================
   CSS Custom Properties
   ========================================================================== */

:root {
    /* Brand Colors */
    --ce-primary: #019cb4;
    --ce-primary-dark: #017a8c;
    --ce-primary-light: #e6f7fa;
    --ce-secondary: #2c3e50;
    --ce-secondary-light: #34495e;
    --ce-accent-success: #27ae60;
    --ce-accent-success-dark: #1e8449;
    --ce-accent-urgent: #e74c3c;
    --ce-accent-urgent-dark: #c0392b;

    /* Neutral Colors */
    --ce-white: #ffffff;
    --ce-light-bg: #f8f9fa;
    --ce-gray-100: #f1f3f5;
    --ce-gray-200: #e9ecef;
    --ce-gray-300: #dee2e6;
    --ce-gray-400: #ced4da;
    --ce-gray-500: #adb5bd;
    --ce-gray-600: #6c757d;
    --ce-gray-700: #495057;
    --ce-gray-800: #343a40;
    --ce-gray-900: #212529;
    --ce-black: #000000;

    /* Typography */
    --ce-font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    --ce-font-size-xs: 0.75rem;
    --ce-font-size-sm: 0.875rem;
    --ce-font-size-base: 1rem;
    --ce-font-size-lg: 1.125rem;
    --ce-font-size-xl: 1.25rem;
    --ce-font-size-2xl: 1.5rem;
    --ce-font-size-3xl: 1.875rem;
    --ce-font-size-4xl: 2.25rem;
    --ce-font-size-5xl: 3rem;
    --ce-line-height-tight: 1.25;
    --ce-line-height-normal: 1.5;
    --ce-line-height-relaxed: 1.75;
    --ce-font-weight-normal: 400;
    --ce-font-weight-medium: 500;
    --ce-font-weight-semibold: 600;
    --ce-font-weight-bold: 700;

    /* Spacing */
    --ce-spacing-xs: 0.25rem;
    --ce-spacing-sm: 0.5rem;
    --ce-spacing-md: 1rem;
    --ce-spacing-lg: 1.5rem;
    --ce-spacing-xl: 2rem;
    --ce-spacing-2xl: 3rem;
    --ce-spacing-3xl: 4rem;
    --ce-spacing-4xl: 6rem;

    /* Layout */
    --ce-container-max: 1200px;
    --ce-container-narrow: 800px;
    --ce-header-height: 80px;
    --ce-top-bar-height: 40px;

    /* Effects */
    --ce-border-radius-sm: 4px;
    --ce-border-radius: 8px;
    --ce-border-radius-lg: 12px;
    --ce-border-radius-full: 9999px;
    --ce-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
    --ce-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
    --ce-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
    --ce-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
    --ce-transition-fast: 150ms ease;
    --ce-transition: 300ms ease;
    --ce-transition-slow: 500ms ease;
}

/* ==========================================================================
   Reset & Base Styles
   ========================================================================== */

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

html {
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
}

body {
    margin: 0;
    padding: 0;
    font-family: var(--ce-font-family);
    font-size: var(--ce-font-size-base);
    line-height: var(--ce-line-height-normal);
    color: var(--ce-secondary);
    background-color: var(--ce-white);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

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

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

h1, h2, h3, h4, h5, h6 {
    margin: 0 0 var(--ce-spacing-md);
    font-weight: var(--ce-font-weight-bold);
    line-height: var(--ce-line-height-tight);
    color: var(--ce-secondary);
}

h1 { font-size: var(--ce-font-size-4xl); }
h2 { font-size: var(--ce-font-size-3xl); }
h3 { font-size: var(--ce-font-size-2xl); }
h4 { font-size: var(--ce-font-size-xl); }
h5 { font-size: var(--ce-font-size-lg); }
h6 { font-size: var(--ce-font-size-base); }

p {
    margin: 0 0 var(--ce-spacing-md);
}

ul, ol {
    margin: 0 0 var(--ce-spacing-md);
    padding-left: var(--ce-spacing-xl);
}

/* ==========================================================================
   Layout Components
   ========================================================================== */

.ce-container {
    width: 100%;
    max-width: var(--ce-container-max);
    margin: 0 auto;
    padding: 0 var(--ce-spacing-md);
}

.ce-container--narrow {
    max-width: var(--ce-container-narrow);
}

.ce-section {
    padding: var(--ce-spacing-2xl) 0;
}

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

.ce-section--gray {
    background-color: var(--ce-light-bg);
}

.ce-section--primary {
    background-color: var(--ce-primary);
    color: var(--ce-white);
}

.ce-section--primary h2,
.ce-section--primary h3 {
    color: var(--ce-white);
}

/* ==========================================================================
   Top Bar
   ========================================================================== */

.ce-top-bar {
    background-color: var(--ce-secondary);
    color: var(--ce-white);
    height: var(--ce-top-bar-height);
    display: flex;
    align-items: center;
}

.ce-top-bar__inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
}

.ce-top-bar__phone {
    display: flex;
    align-items: center;
    gap: var(--ce-spacing-sm);
    font-weight: var(--ce-font-weight-semibold);
}

.ce-top-bar__phone a {
    color: var(--ce-white);
    display: flex;
    align-items: center;
    gap: var(--ce-spacing-sm);
}

.ce-top-bar__phone a:hover {
    color: var(--ce-primary-light);
}

.ce-top-bar__phone svg {
    width: 18px;
    height: 18px;
}

.ce-top-bar__cta {
    display: none;
}

@media (min-width: 768px) {
    .ce-top-bar__cta {
        display: block;
    }
}

/* ==========================================================================
   Header
   ========================================================================== */

.ce-header {
    background-color: var(--ce-white);
    box-shadow: var(--ce-shadow);
    position: sticky;
    top: 0;
    z-index: 1000;
}

.ce-header__inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: var(--ce-header-height);
}

.ce-logo {
    display: flex;
    align-items: center;
    gap: var(--ce-spacing-sm);
}

.ce-logo__img {
    max-height: 50px;
    width: auto;
}

.ce-logo__text {
    font-size: var(--ce-font-size-xl);
    font-weight: var(--ce-font-weight-bold);
    color: var(--ce-primary);
}

.ce-logo__text span {
    color: var(--ce-secondary);
}

/* ==========================================================================
   Navigation
   ========================================================================== */

.ce-nav {
    display: none;
}

@media (min-width: 992px) {
    .ce-nav {
        display: block;
    }
}

.ce-nav__list {
    display: flex;
    gap: var(--ce-spacing-lg);
    list-style: none;
    margin: 0;
    padding: 0;
}

.ce-nav__item {
    position: relative;
}

.ce-nav__link {
    display: block;
    padding: var(--ce-spacing-sm) 0;
    color: var(--ce-secondary);
    font-weight: var(--ce-font-weight-medium);
    transition: color var(--ce-transition-fast);
}

.ce-nav__link:hover,
.ce-nav__item--active .ce-nav__link {
    color: var(--ce-primary);
}

/* Mega Menu Ready */
.ce-nav__dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 220px;
    background: var(--ce-white);
    box-shadow: var(--ce-shadow-lg);
    border-radius: var(--ce-border-radius);
    padding: var(--ce-spacing-sm) 0;
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: all var(--ce-transition-fast);
    z-index: 100;
}

.ce-nav__item:hover .ce-nav__dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.ce-nav__dropdown-item {
    list-style: none;
}

.ce-nav__dropdown-link {
    display: block;
    padding: var(--ce-spacing-sm) var(--ce-spacing-lg);
    color: var(--ce-secondary);
    font-size: var(--ce-font-size-sm);
}

.ce-nav__dropdown-link:hover {
    background-color: var(--ce-primary-light);
    color: var(--ce-primary);
}

/* Mobile Menu Toggle */
.ce-mobile-toggle {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 30px;
    height: 30px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
}

@media (min-width: 992px) {
    .ce-mobile-toggle {
        display: none;
    }
}

.ce-mobile-toggle span {
    display: block;
    width: 100%;
    height: 3px;
    background-color: var(--ce-secondary);
    border-radius: 2px;
    transition: all var(--ce-transition-fast);
}

.ce-mobile-toggle.is-active span:nth-child(1) {
    transform: rotate(45deg) translate(5px, 5px);
}

.ce-mobile-toggle.is-active span:nth-child(2) {
    opacity: 0;
}

.ce-mobile-toggle.is-active span:nth-child(3) {
    transform: rotate(-45deg) translate(7px, -6px);
}

/* Mobile Navigation */
.ce-mobile-nav {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--ce-white);
    box-shadow: var(--ce-shadow-lg);
    padding: var(--ce-spacing-md);
}

.ce-mobile-nav.is-open {
    display: block;
}

@media (min-width: 992px) {
    .ce-mobile-nav {
        display: none !important;
    }
}

.ce-mobile-nav__list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.ce-mobile-nav__link {
    display: block;
    padding: var(--ce-spacing-md);
    color: var(--ce-secondary);
    border-bottom: 1px solid var(--ce-gray-200);
    font-weight: var(--ce-font-weight-medium);
}

.ce-mobile-nav__link:hover {
    color: var(--ce-primary);
    background-color: var(--ce-primary-light);
}

/* Header CTA */
.ce-header__cta {
    display: none;
}

@media (min-width: 992px) {
    .ce-header__cta {
        display: block;
    }
}

/* ==========================================================================
   Trust Bar
   ========================================================================== */

.ce-trust-bar {
    background-color: var(--ce-light-bg);
    padding: var(--ce-spacing-md) 0;
    border-bottom: 1px solid var(--ce-gray-200);
}

.ce-trust-bar__inner {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--ce-spacing-lg);
}

@media (min-width: 768px) {
    .ce-trust-bar__inner {
        justify-content: space-between;
    }
}

.ce-trust-badge {
    display: flex;
    align-items: center;
    gap: var(--ce-spacing-sm);
    font-size: var(--ce-font-size-sm);
    color: var(--ce-gray-700);
}

.ce-trust-badge svg {
    width: 24px;
    height: 24px;
    color: var(--ce-primary);
    flex-shrink: 0;
}

.ce-trust-badge--highlight {
    color: var(--ce-secondary);
    font-weight: var(--ce-font-weight-semibold);
}

/* ==========================================================================
   Hero Section
   ========================================================================== */

.ce-hero {
    background: linear-gradient(135deg, var(--ce-primary) 0%, var(--ce-primary-dark) 100%);
    color: var(--ce-white);
    padding: var(--ce-spacing-3xl) 0;
    position: relative;
    overflow: hidden;
}

.ce-hero::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><circle cx="50" cy="50" r="40" fill="none" stroke="white" stroke-opacity="0.1" stroke-width="0.5"/></svg>');
    background-size: 100px 100px;
    opacity: 0.5;
}

.ce-hero__inner {
    position: relative;
    z-index: 1;
    text-align: center;
}

@media (min-width: 768px) {
    .ce-hero {
        padding: var(--ce-spacing-4xl) 0;
    }

    .ce-hero__inner {
        text-align: left;
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: var(--ce-spacing-2xl);
        align-items: center;
    }
}

.ce-hero__title {
    font-size: var(--ce-font-size-3xl);
    color: var(--ce-white);
    margin-bottom: var(--ce-spacing-md);
}

@media (min-width: 768px) {
    .ce-hero__title {
        font-size: var(--ce-font-size-5xl);
    }
}

.ce-hero__subtitle {
    font-size: var(--ce-font-size-lg);
    opacity: 0.9;
    margin-bottom: var(--ce-spacing-xl);
}

.ce-hero__ctas {
    display: flex;
    flex-direction: column;
    gap: var(--ce-spacing-md);
}

@media (min-width: 480px) {
    .ce-hero__ctas {
        flex-direction: row;
        justify-content: center;
    }
}

@media (min-width: 768px) {
    .ce-hero__ctas {
        justify-content: flex-start;
    }
}

.ce-hero__image {
    display: none;
}

@media (min-width: 768px) {
    .ce-hero__image {
        display: block;
    }
}

.ce-hero__image img {
    border-radius: var(--ce-border-radius-lg);
    box-shadow: var(--ce-shadow-xl);
}

/* ==========================================================================
   Front Page Hero – Light Modern Redesign
   ========================================================================== */

.ce-hero-front {
    position: relative;
    background: #f1f5f9;
    padding: var(--ce-spacing-2xl) 0;
    overflow: hidden;
}

.ce-hero-front__bg {
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 85% 15%, rgba(1, 156, 180, 0.08) 0%, transparent 50%);
    pointer-events: none;
}

.ce-hero-front__inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--ce-spacing-2xl);
    align-items: center;
    text-align: center;
}

@media (min-width: 768px) {
    .ce-hero-front {
        padding: var(--ce-spacing-4xl) 0;
    }

    .ce-hero-front__inner {
        grid-template-columns: 1fr 1fr;
        gap: var(--ce-spacing-3xl);
        text-align: left;
    }
}

.ce-hero-front__eyebrow {
    display: inline-block;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: var(--ce-primary);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-hero-front__title {
    font-size: clamp(1.875rem, 5vw, 2.75rem);
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: -0.03em;
    color: var(--ce-gray-900, #0f172a);
    margin-bottom: var(--ce-spacing-md);
}

.ce-hero-front__subtitle {
    font-size: var(--ce-font-size-base);
    line-height: 1.65;
    color: var(--ce-gray-600, #475569);
    max-width: 28rem;
    margin: 0 auto var(--ce-spacing-xl);
}

@media (min-width: 768px) {
    .ce-hero-front__subtitle {
        margin-left: 0;
        margin-right: 0;
        margin-bottom: var(--ce-spacing-xl);
    }
}

.ce-hero-front__ctas {
    display: flex;
    flex-direction: column;
    gap: var(--ce-spacing-sm);
}

@media (min-width: 480px) {
    .ce-hero-front__ctas {
        flex-direction: row;
        justify-content: center;
    }
}

@media (min-width: 768px) {
    .ce-hero-front__ctas {
        justify-content: flex-start;
    }
}

.ce-hero-front__media {
    order: -1;
}

@media (min-width: 768px) {
    .ce-hero-front__media {
        order: 0;
    }
}

.ce-hero-front__image-wrap {
    position: relative;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.15);
}

.ce-hero-front__image-wrap::before {
    content: '';
    position: absolute;
    inset: 0;
    border: 1px solid rgba(1, 156, 180, 0.15);
    border-radius: 16px;
    pointer-events: none;
}

.ce-hero-front__image-wrap img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
    aspect-ratio: 4 / 3;
}

@media (min-width: 768px) {
    .ce-hero-front__image-wrap img {
        aspect-ratio: 3 / 2;
    }
}

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

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

.ce-btn:focus {
    outline: none;
    box-shadow: 0 0 0 3px rgba(1, 156, 180, 0.3);
}

/* Primary Button */
.ce-btn--primary {
    background-color: var(--ce-primary);
    border-color: var(--ce-primary);
    color: var(--ce-white);
}

.ce-btn--primary:hover {
    background-color: var(--ce-primary-dark);
    border-color: var(--ce-primary-dark);
    color: var(--ce-white);
}

/* Secondary Button */
.ce-btn--secondary {
    background-color: transparent;
    border-color: var(--ce-white);
    color: var(--ce-white);
}

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

/* Secondary Dark */
.ce-btn--secondary-dark {
    background-color: transparent;
    border-color: var(--ce-primary);
    color: var(--ce-primary);
}

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

/* Outline Dark (light backgrounds) */
.ce-btn--outline-dark {
    background-color: transparent;
    border: 2px solid var(--ce-gray-800, #1e293b);
    color: var(--ce-gray-800, #1e293b);
}

.ce-btn--outline-dark:hover {
    background-color: var(--ce-gray-800, #1e293b);
    color: var(--ce-white);
}

/* Success/CTA Button */
.ce-btn--success {
    background-color: var(--ce-accent-success);
    border-color: var(--ce-accent-success);
    color: var(--ce-white);
}

.ce-btn--success:hover {
    background-color: var(--ce-accent-success-dark);
    border-color: var(--ce-accent-success-dark);
    color: var(--ce-white);
}

/* Urgent Button */
.ce-btn--urgent {
    background-color: var(--ce-accent-urgent);
    border-color: var(--ce-accent-urgent);
    color: var(--ce-white);
    animation: pulse 2s infinite;
}

.ce-btn--urgent:hover {
    background-color: var(--ce-accent-urgent-dark);
    border-color: var(--ce-accent-urgent-dark);
    color: var(--ce-white);
}

@keyframes pulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.02); }
}

/* Button Sizes */
.ce-btn--sm {
    padding: var(--ce-spacing-sm) var(--ce-spacing-md);
    font-size: var(--ce-font-size-sm);
}

.ce-btn--lg {
    padding: var(--ce-spacing-lg) var(--ce-spacing-2xl);
    font-size: var(--ce-font-size-lg);
}

.ce-btn--full {
    width: 100%;
}

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

.ce-services-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--ce-spacing-lg);
}

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

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

.ce-service-card {
    background: var(--ce-white);
    border-radius: var(--ce-border-radius-lg);
    padding: var(--ce-spacing-xl);
    box-shadow: var(--ce-shadow);
    transition: all var(--ce-transition);
    text-align: center;
    border: 1px solid var(--ce-gray-200);
}

.ce-service-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--ce-shadow-lg);
    border-color: var(--ce-primary);
}

.ce-service-card__icon {
    width: 64px;
    height: 64px;
    margin: 0 auto var(--ce-spacing-md);
    background: var(--ce-primary-light);
    border-radius: var(--ce-border-radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ce-primary);
}

.ce-service-card__icon svg {
    width: 32px;
    height: 32px;
}

.ce-service-card__title {
    font-size: var(--ce-font-size-xl);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-service-card__excerpt {
    color: var(--ce-gray-600);
    font-size: var(--ce-font-size-sm);
    margin-bottom: var(--ce-spacing-md);
}

.ce-service-card__link {
    font-weight: var(--ce-font-weight-semibold);
    color: var(--ce-primary);
}

.ce-service-card__link:hover {
    color: var(--ce-primary-dark);
}

/* ==========================================================================
   Why Us / Features
   ========================================================================== */

.ce-features {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--ce-spacing-xl);
}

@media (min-width: 768px) {
    .ce-features {
        grid-template-columns: repeat(2, 1fr);
    }
}

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

.ce-feature {
    text-align: center;
    padding: var(--ce-spacing-lg);
}

.ce-feature__icon {
    width: 80px;
    height: 80px;
    margin: 0 auto var(--ce-spacing-md);
    background: var(--ce-primary);
    border-radius: var(--ce-border-radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ce-white);
}

.ce-feature__icon svg {
    width: 40px;
    height: 40px;
}

.ce-feature__title {
    font-size: var(--ce-font-size-lg);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-feature__text {
    color: var(--ce-gray-600);
    font-size: var(--ce-font-size-sm);
    margin: 0;
}

/* ==========================================================================
   Testimonials
   ========================================================================== */

.ce-testimonials {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--ce-spacing-lg);
}

@media (min-width: 768px) {
    .ce-testimonials {
        grid-template-columns: repeat(2, 1fr);
    }
}

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

.ce-testimonial {
    background: var(--ce-white);
    border-radius: var(--ce-border-radius-lg);
    padding: var(--ce-spacing-xl);
    box-shadow: var(--ce-shadow);
    border-left: 4px solid var(--ce-primary);
}

.ce-testimonial__quote {
    font-size: var(--ce-font-size-base);
    font-style: italic;
    color: var(--ce-gray-700);
    margin-bottom: var(--ce-spacing-md);
    position: relative;
    padding-left: var(--ce-spacing-lg);
}

.ce-testimonial__quote::before {
    content: '"';
    position: absolute;
    left: 0;
    top: -10px;
    font-size: var(--ce-font-size-4xl);
    color: var(--ce-primary);
    line-height: 1;
}

.ce-testimonial__author {
    display: flex;
    align-items: center;
    gap: var(--ce-spacing-md);
}

.ce-testimonial__avatar {
    width: 50px;
    height: 50px;
    border-radius: var(--ce-border-radius-full);
    background: var(--ce-gray-300);
    overflow: hidden;
    flex-shrink: 0;
}

.ce-testimonial__avatar img {
    width: 100%;
    height: 100%;
    border-radius: var(--ce-border-radius-full);
    border-radius: inherit;
    object-fit: cover;
    display: block;
}

.ce-testimonial__name {
    font-weight: var(--ce-font-weight-semibold);
    margin: 0;
}

.ce-testimonial__role {
    font-size: var(--ce-font-size-sm);
    color: var(--ce-gray-600);
    margin: 0;
}

.ce-testimonial__stars {
    color: #f1c40f;
    letter-spacing: 2px;
}

/* ==========================================================================
   CTA Block
   ========================================================================== */

.ce-cta-block {
    background: linear-gradient(135deg, var(--ce-primary) 0%, var(--ce-primary-dark) 100%);
    color: var(--ce-white);
    padding: var(--ce-spacing-3xl) 0;
    text-align: center;
}

.ce-cta-block__title {
    color: var(--ce-white);
    margin-bottom: var(--ce-spacing-md);
}

.ce-cta-block__text {
    font-size: var(--ce-font-size-lg);
    opacity: 0.9;
    margin-bottom: var(--ce-spacing-xl);
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}

.ce-cta-block__actions {
    display: flex;
    flex-direction: column;
    gap: var(--ce-spacing-md);
    align-items: center;
}

@media (min-width: 480px) {
    .ce-cta-block__actions {
        flex-direction: row;
        justify-content: center;
    }
}

.ce-cta-block__phone {
    font-size: var(--ce-font-size-2xl);
    font-weight: var(--ce-font-weight-bold);
    color: var(--ce-white);
    display: flex;
    align-items: center;
    gap: var(--ce-spacing-sm);
}

.ce-cta-block__phone svg {
    width: 28px;
    height: 28px;
}

/* ==========================================================================
   Forms
   ========================================================================== */

.ce-form {
    max-width: 500px;
}

.ce-form--full {
    max-width: none;
}

.ce-form__group {
    margin-bottom: var(--ce-spacing-md);
}

.ce-form__label {
    display: block;
    margin-bottom: var(--ce-spacing-xs);
    font-weight: var(--ce-font-weight-medium);
    font-size: var(--ce-font-size-sm);
}

.ce-form__input,
.ce-form__textarea,
.ce-form__select {
    width: 100%;
    padding: var(--ce-spacing-md);
    font-family: var(--ce-font-family);
    font-size: var(--ce-font-size-base);
    border: 1px solid var(--ce-gray-300);
    border-radius: var(--ce-border-radius);
    background: var(--ce-white);
    transition: border-color var(--ce-transition-fast), box-shadow var(--ce-transition-fast);
}

.ce-form__input:focus,
.ce-form__textarea:focus,
.ce-form__select:focus {
    outline: none;
    border-color: var(--ce-primary);
    box-shadow: 0 0 0 3px rgba(1, 156, 180, 0.1);
}

.ce-form__textarea {
    min-height: 120px;
    resize: vertical;
}

.ce-form__checkbox-group {
    display: flex;
    align-items: flex-start;
    gap: var(--ce-spacing-sm);
}

.ce-form__checkbox {
    margin-top: 3px;
}

.ce-form__checkbox-label {
    font-size: var(--ce-font-size-sm);
    color: var(--ce-gray-600);
}

.ce-form__hint {
    font-size: var(--ce-font-size-xs);
    color: var(--ce-gray-600);
    margin-top: var(--ce-spacing-xs);
}

.ce-form__error {
    font-size: var(--ce-font-size-xs);
    color: var(--ce-accent-urgent);
    margin-top: var(--ce-spacing-xs);
}

/* Quick Quote Sidebar Form */
.ce-quick-quote {
    background: var(--ce-light-bg);
    padding: var(--ce-spacing-xl);
    border-radius: var(--ce-border-radius-lg);
    border: 1px solid var(--ce-gray-200);
}

.ce-quick-quote__title {
    font-size: var(--ce-font-size-xl);
    margin-bottom: var(--ce-spacing-md);
    text-align: center;
}

.ce-quick-quote__subtitle {
    font-size: var(--ce-font-size-sm);
    color: var(--ce-gray-600);
    text-align: center;
    margin-bottom: var(--ce-spacing-lg);
}

/* ==========================================================================
   Service Page Template
   ========================================================================== */

.ce-service-page {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--ce-spacing-2xl);
}

@media (min-width: 992px) {
    .ce-service-page {
        grid-template-columns: 1fr 350px;
    }
}

.ce-service-content {
    min-width: 0;
}

.ce-service-sidebar {
    order: -1;
}

@media (min-width: 992px) {
    .ce-service-sidebar {
        order: 1;
    }
}

.ce-service-sidebar__sticky {
    position: sticky;
    top: calc(var(--ce-header-height) + var(--ce-spacing-lg));
}

/* Breadcrumbs */
.ce-breadcrumbs {
    font-size: var(--ce-font-size-sm);
    color: var(--ce-gray-600);
    margin-bottom: var(--ce-spacing-lg);
}

.ce-breadcrumbs a {
    color: var(--ce-gray-600);
}

.ce-breadcrumbs a:hover {
    color: var(--ce-primary);
}

.ce-breadcrumbs__separator {
    margin: 0 var(--ce-spacing-sm);
}

/* Related Services */
.ce-related-services {
    margin-top: var(--ce-spacing-3xl);
    padding-top: var(--ce-spacing-2xl);
    border-top: 1px solid var(--ce-gray-200);
}

.ce-related-services__title {
    font-size: var(--ce-font-size-2xl);
    font-weight: var(--ce-font-weight-bold);
    color: var(--ce-secondary);
    margin: 0 0 var(--ce-spacing-xl);
}

.ce-related-services__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--ce-spacing-xl);
}

@media (min-width: 640px) {
    .ce-related-services__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 900px) {
    .ce-related-services__grid {
        grid-template-columns: repeat(3, 1fr);
        gap: var(--ce-spacing-2xl);
    }
}

.ce-related-card {
    background: var(--ce-white);
    border-radius: var(--ce-border-radius-lg);
    overflow: hidden;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
    transition: transform var(--ce-transition), box-shadow var(--ce-transition);
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.ce-related-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.12);
}

.ce-related-card__media {
    aspect-ratio: 16 / 10;
    overflow: hidden;
    background: var(--ce-gray-100);
}

.ce-related-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--ce-transition);
}

.ce-related-card:hover .ce-related-card__media img {
    transform: scale(1.03);
}

.ce-related-card__content {
    padding: var(--ce-spacing-xl);
    flex: 1;
    display: flex;
    flex-direction: column;
    min-width: 0;
    overflow: hidden;
}

.ce-related-card__title {
    font-size: var(--ce-font-size-xl);
    font-weight: var(--ce-font-weight-bold);
    color: var(--ce-secondary);
    margin: 0 0 var(--ce-spacing-sm);
    line-height: var(--ce-line-height-tight);
    overflow-wrap: break-word;
    word-break: break-word;
}

.ce-related-card__excerpt {
    font-size: var(--ce-font-size-sm);
    color: var(--ce-gray-600);
    line-height: var(--ce-line-height-relaxed);
    margin: 0 0 var(--ce-spacing-lg);
    flex: 1;
    overflow: hidden;
    overflow-wrap: break-word;
    word-break: break-word;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
    line-clamp: 4;
}

.ce-related-card__link {
    color: var(--ce-primary);
    font-weight: var(--ce-font-weight-semibold);
    font-size: var(--ce-font-size-sm);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: var(--ce-spacing-xs);
    transition: color var(--ce-transition-fast), gap var(--ce-transition-fast);
    flex-shrink: 0;
    overflow-wrap: break-word;
    word-break: break-word;
}

.ce-related-card__link:hover {
    color: var(--ce-primary-dark);
    gap: var(--ce-spacing-sm);
}

.ce-related-card__link-arrow {
    display: inline-block;
    transition: transform var(--ce-transition-fast);
}

.ce-related-card__link:hover .ce-related-card__link-arrow {
    transform: translateX(2px);
}

/* ==========================================================================
   Footer
   ========================================================================== */

.ce-footer {
    background-color: var(--ce-secondary);
    color: var(--ce-gray-400);
    padding: var(--ce-spacing-3xl) 0 0;
}

.ce-footer__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--ce-spacing-xl);
    margin-bottom: var(--ce-spacing-2xl);
}

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

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

.ce-footer__col-title {
    color: var(--ce-white);
    font-size: var(--ce-font-size-lg);
    margin-bottom: var(--ce-spacing-md);
}

.ce-footer__text {
    font-size: var(--ce-font-size-sm);
    line-height: var(--ce-line-height-relaxed);
}

.ce-footer__list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.ce-footer__list li {
    margin-bottom: var(--ce-spacing-sm);
}

.ce-footer__list a {
    color: var(--ce-gray-400);
    font-size: var(--ce-font-size-sm);
}

.ce-footer__list a:hover {
    color: var(--ce-white);
}

.ce-footer__contact-item {
    display: flex;
    align-items: center;
    gap: var(--ce-spacing-sm);
    margin-bottom: var(--ce-spacing-sm);
    font-size: var(--ce-font-size-sm);
}

.ce-footer__contact-item svg {
    width: 18px;
    height: 18px;
    color: var(--ce-primary);
    flex-shrink: 0;
}

.ce-footer__contact-item a {
    color: var(--ce-gray-400);
}

.ce-footer__contact-item a:hover {
    color: var(--ce-white);
}

.ce-footer__hours {
    font-size: var(--ce-font-size-sm);
}

.ce-footer__hours dt {
    font-weight: var(--ce-font-weight-semibold);
    color: var(--ce-gray-300);
}

.ce-footer__hours dd {
    margin: 0 0 var(--ce-spacing-sm);
}

.ce-footer__bottom {
    border-top: 1px solid var(--ce-secondary-light);
    padding: var(--ce-spacing-lg) 0;
}

.ce-footer__bottom-inner {
    display: flex;
    flex-direction: column;
    gap: var(--ce-spacing-md);
    align-items: center;
    text-align: center;
}

@media (min-width: 768px) {
    .ce-footer__bottom-inner {
        flex-direction: row;
        justify-content: space-between;
        text-align: left;
    }
}

.ce-footer__copyright {
    font-size: var(--ce-font-size-sm);
    margin: 0;
}

.ce-footer__legal {
    display: flex;
    gap: var(--ce-spacing-lg);
}

.ce-footer__legal a {
    color: var(--ce-gray-400);
    font-size: var(--ce-font-size-sm);
}

.ce-footer__legal a:hover {
    color: var(--ce-white);
}

/* ==========================================================================
   404 Page
   ========================================================================== */

.ce-404 {
    text-align: center;
    padding: var(--ce-spacing-4xl) 0;
}

.ce-404__code {
    font-size: 120px;
    font-weight: var(--ce-font-weight-bold);
    color: var(--ce-primary);
    line-height: 1;
    margin-bottom: var(--ce-spacing-md);
}

.ce-404__title {
    margin-bottom: var(--ce-spacing-md);
}

.ce-404__text {
    color: var(--ce-gray-600);
    margin-bottom: var(--ce-spacing-xl);
    max-width: 500px;
    margin-left: auto;
    margin-right: auto;
}

/* ==========================================================================
   Utility Classes
   ========================================================================== */

/* Text Alignment */
.ce-text-left { text-align: left; }
.ce-text-center { text-align: center; }
.ce-text-right { text-align: right; }

/* Text Colors */
.ce-text-primary { color: var(--ce-primary); }
.ce-text-secondary { color: var(--ce-secondary); }
.ce-text-success { color: var(--ce-accent-success); }
.ce-text-urgent { color: var(--ce-accent-urgent); }
.ce-text-muted { color: var(--ce-gray-600); }
.ce-text-white { color: var(--ce-white); }

/* Background Colors */
.ce-bg-primary { background-color: var(--ce-primary); }
.ce-bg-light { background-color: var(--ce-light-bg); }
.ce-bg-white { background-color: var(--ce-white); }
.ce-bg-dark { background-color: var(--ce-secondary); }

/* Spacing */
.ce-mt-0 { margin-top: 0; }
.ce-mt-1 { margin-top: var(--ce-spacing-sm); }
.ce-mt-2 { margin-top: var(--ce-spacing-md); }
.ce-mt-3 { margin-top: var(--ce-spacing-lg); }
.ce-mt-4 { margin-top: var(--ce-spacing-xl); }
.ce-mt-5 { margin-top: var(--ce-spacing-2xl); }

.ce-mb-0 { margin-bottom: 0; }
.ce-mb-1 { margin-bottom: var(--ce-spacing-sm); }
.ce-mb-2 { margin-bottom: var(--ce-spacing-md); }
.ce-mb-3 { margin-bottom: var(--ce-spacing-lg); }
.ce-mb-4 { margin-bottom: var(--ce-spacing-xl); }
.ce-mb-5 { margin-bottom: var(--ce-spacing-2xl); }

.ce-py-0 { padding-top: 0; padding-bottom: 0; }
.ce-py-1 { padding-top: var(--ce-spacing-sm); padding-bottom: var(--ce-spacing-sm); }
.ce-py-2 { padding-top: var(--ce-spacing-md); padding-bottom: var(--ce-spacing-md); }
.ce-py-3 { padding-top: var(--ce-spacing-lg); padding-bottom: var(--ce-spacing-lg); }
.ce-py-4 { padding-top: var(--ce-spacing-xl); padding-bottom: var(--ce-spacing-xl); }
.ce-py-5 { padding-top: var(--ce-spacing-2xl); padding-bottom: var(--ce-spacing-2xl); }

/* Display */
.ce-d-none { display: none; }
.ce-d-block { display: block; }
.ce-d-flex { display: flex; }
.ce-d-grid { display: grid; }

@media (min-width: 768px) {
    .ce-d-md-none { display: none; }
    .ce-d-md-block { display: block; }
    .ce-d-md-flex { display: flex; }
}

@media (min-width: 992px) {
    .ce-d-lg-none { display: none; }
    .ce-d-lg-block { display: block; }
    .ce-d-lg-flex { display: flex; }
}

/* Flex Utilities */
.ce-flex-wrap { flex-wrap: wrap; }
.ce-justify-center { justify-content: center; }
.ce-justify-between { justify-content: space-between; }
.ce-align-center { align-items: center; }
.ce-gap-1 { gap: var(--ce-spacing-sm); }
.ce-gap-2 { gap: var(--ce-spacing-md); }
.ce-gap-3 { gap: var(--ce-spacing-lg); }

/* Screen Reader Only */
.ce-sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* Section Title */
.ce-section-title {
    text-align: center;
    margin-bottom: var(--ce-spacing-2xl);
}

.ce-section-title__heading {
    margin-bottom: var(--ce-spacing-sm);
}

.ce-section-title__subheading {
    color: var(--ce-gray-600);
    font-size: var(--ce-font-size-lg);
    max-width: 600px;
    margin: 0 auto;
}

/* WordPress Alignment Classes */
.alignleft {
    float: left;
    margin-right: var(--ce-spacing-lg);
    margin-bottom: var(--ce-spacing-md);
}

.alignright {
    float: right;
    margin-left: var(--ce-spacing-lg);
    margin-bottom: var(--ce-spacing-md);
}

.aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: var(--ce-spacing-md);
}

/* WordPress Caption */
.wp-caption {
    max-width: 100%;
    margin-bottom: var(--ce-spacing-md);
}

.wp-caption-text {
    font-size: var(--ce-font-size-sm);
    color: var(--ce-gray-600);
    text-align: center;
    padding: var(--ce-spacing-sm);
}

/* Clear Float */
.ce-clearfix::after {
    content: '';
    display: table;
    clear: both;
}

/* ==========================================================================
   Service Hero Section
   ========================================================================== */

.ce-service-hero {
    position: relative;
    min-height: 400px;
    display: flex;
    align-items: center;
    padding: var(--ce-spacing-4xl) 0;
    overflow: hidden;
}

.ce-service-hero__bg {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.ce-service-hero__overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, rgba(1, 156, 180, 0.9) 0%, rgba(44, 62, 80, 0.85) 100%);
}

.ce-service-hero__content {
    position: relative;
    z-index: 2;
    color: var(--ce-white);
    max-width: 720px;
}

.ce-service-hero__inner {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    gap: var(--ce-spacing-xl);
}

.ce-service-hero__content .ce-breadcrumbs {
    margin-bottom: var(--ce-spacing-lg);
}

.ce-service-hero__content .ce-breadcrumbs a,
.ce-service-hero__content .ce-breadcrumbs span {
    color: rgba(255, 255, 255, 0.85);
}

.ce-service-hero__content .ce-breadcrumbs a:hover {
    color: var(--ce-white);
}

.ce-service-hero__title {
    font-size: var(--ce-font-size-4xl);
    font-weight: var(--ce-font-weight-extrabold, 800);
    line-height: var(--ce-line-height-tight);
    letter-spacing: -0.04em;
    margin-bottom: var(--ce-spacing-md);
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.ce-service-hero__title-highlight {
    color: var(--ce-accent, #a5f3fc);
}

.ce-service-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--ce-spacing-xs);
    font-size: 0.7rem;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    font-weight: var(--ce-font-weight-bold);
    color: rgba(226, 245, 255, 0.95);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-service-hero__eyebrow::before {
    content: '';
    display: inline-block;
    width: 40px;
    height: 1px;
    background-color: currentColor;
}

.ce-service-hero__subtitle {
    font-size: var(--ce-font-size-lg);
    line-height: var(--ce-line-height-relaxed);
    margin-bottom: var(--ce-spacing-xl);
    opacity: 0.95;
    max-width: 36rem;
}

.ce-service-hero__cta {
    display: flex;
    gap: var(--ce-spacing-md);
    flex-wrap: wrap;
}

.ce-service-hero__meta {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--ce-spacing-sm);
    max-width: 22rem;
}

.ce-service-hero__meta-item {
    background: rgba(15, 23, 42, 0.35);
    border-radius: var(--ce-border-radius-lg);
    padding: var(--ce-spacing-sm) var(--ce-spacing-md);
    backdrop-filter: blur(10px);
    color: var(--ce-white);
}

.ce-service-hero__meta-label {
    display: block;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    opacity: 0.9;
    margin-bottom: 2px;
}

.ce-service-hero__meta-value {
    display: block;
    font-size: 0.95rem;
    font-weight: var(--ce-font-weight-medium);
}

/* Service hero – light theme (match front page) */
.ce-service-hero--enhanced {
    background: #f1f5f9;
}

.ce-service-hero--enhanced .ce-hero-front__bg {
    background: radial-gradient(circle at 85% 15%, rgba(1, 156, 180, 0.08) 0%, transparent 50%);
}

.ce-service-hero--enhanced .ce-service-hero__content {
    color: var(--ce-gray-900, #0f172a);
}

.ce-service-hero--enhanced .ce-service-hero__content .ce-breadcrumbs a,
.ce-service-hero--enhanced .ce-service-hero__content .ce-breadcrumbs span {
    color: var(--ce-gray-600, #475569);
}

.ce-service-hero--enhanced .ce-service-hero__content .ce-breadcrumbs a:hover {
    color: var(--ce-primary);
}

.ce-service-hero--enhanced .ce-service-hero__title {
    color: var(--ce-gray-900, #0f172a);
    text-shadow: none;
}

.ce-service-hero--enhanced .ce-service-hero__title-highlight {
    color: var(--ce-primary);
}

.ce-service-hero--enhanced .ce-service-hero__eyebrow {
    color: var(--ce-primary);
}

.ce-service-hero--enhanced .ce-service-hero__eyebrow::before {
    background-color: var(--ce-primary);
}

.ce-service-hero--enhanced .ce-service-hero__subtitle {
    color: var(--ce-gray-600, #475569);
    opacity: 1;
}

.ce-service-hero--enhanced .ce-service-hero__meta-item {
    background: var(--ce-white);
    color: var(--ce-gray-800, #1e293b);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
}

.ce-service-hero--enhanced .ce-service-hero__meta-label {
    color: var(--ce-gray-600, #475569);
    opacity: 1;
}

.ce-service-hero--enhanced .ce-service-hero__meta-value {
    color: var(--ce-gray-800, #1e293b);
}

.ce-btn--outline-white {
    background: transparent;
    color: var(--ce-white);
    border: 2px solid var(--ce-white);
    display: inline-flex;
    align-items: center;
    gap: var(--ce-spacing-sm);
}

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

.ce-btn--white {
    background: var(--ce-white);
    color: var(--ce-primary);
    display: inline-flex;
    align-items: center;
    gap: var(--ce-spacing-sm);
}

.ce-btn--white:hover {
    background: var(--ce-gray-100);
}

@media (max-width: 768px) {
    .ce-service-hero {
        min-height: 350px;
        padding: var(--ce-spacing-2xl) 0;
    }

    .ce-service-hero__title {
        font-size: var(--ce-font-size-3xl);
    }

    .ce-service-hero__subtitle {
        font-size: var(--ce-font-size-base);
    }

    .ce-service-hero__cta {
        flex-direction: column;
    }

    .ce-service-hero__cta .ce-btn {
        width: 100%;
        justify-content: center;
    }
}

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

/* ==========================================================================
   Trust Bar Compact
   ========================================================================== */

.ce-trust-bar--compact {
    background: var(--ce-white);
    border-bottom: 1px solid var(--ce-gray-200);
    padding: var(--ce-spacing-md) 0;
}

.ce-trust-bar__items {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: var(--ce-spacing-2xl);
    flex-wrap: wrap;
}

.ce-trust-bar__item {
    display: flex;
    align-items: center;
    gap: var(--ce-spacing-sm);
    font-size: var(--ce-font-size-sm);
    font-weight: var(--ce-font-weight-medium);
    color: var(--ce-gray-700);
}

.ce-trust-bar__cert {
    width: 40px;
    height: 40px;
    object-fit: contain;
}

.ce-trust-bar__icon {
    width: 24px;
    height: 24px;
    color: var(--ce-primary);
    stroke-linecap: round;
    stroke-linejoin: round;
}

@media (max-width: 768px) {
    .ce-trust-bar__items {
        gap: var(--ce-spacing-md);
    }

    .ce-trust-bar__item span {
        display: none;
    }

    .ce-trust-bar__cert {
        width: 50px;
        height: 50px;
    }
}

/* ==========================================================================
   Trust Bar Enhanced (Service Pages)
   ========================================================================== */

.ce-trust-bar--enhanced {
    position: relative;
    overflow: hidden;
    background-color: var(--ce-white);
    border-bottom: 1px solid var(--ce-gray-200);
    padding: var(--ce-spacing-xl) 0 var(--ce-spacing-2xl);
}

.ce-trust-bar__bg {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 70% 20%, rgba(1, 156, 180, 0.08), transparent 55%);
    pointer-events: none;
}

.ce-trust-bar--enhanced .ce-trust-bar__inner {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    gap: var(--ce-spacing-xl);
    align-items: stretch;
}

.ce-trust-bar__headline {
    max-width: 40rem;
    text-align: left;
}

.ce-trust-bar__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--ce-spacing-xs);
    font-size: 0.68rem;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    font-weight: var(--ce-font-weight-bold);
    color: var(--ce-primary);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-trust-bar__eyebrow::before {
    content: '';
    display: inline-block;
    width: 40px;
    height: 1px;
    background-color: var(--ce-primary);
}

.ce-trust-bar__title {
    font-size: var(--ce-font-size-2xl);
    line-height: 1.05;
    letter-spacing: -0.03em;
    color: var(--ce-gray-900, #0f172a);
    font-weight: var(--ce-font-weight-extrabold, 800);
    margin-bottom: var(--ce-spacing-md);
}

.ce-trust-bar__title-highlight {
    color: var(--ce-primary);
}

.ce-trust-bar__subtitle {
    font-size: var(--ce-font-size-base);
    line-height: 1.6;
    color: var(--ce-gray-600);
    max-width: 32rem;
}

.ce-trust-bar--enhanced .ce-trust-bar__items {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--ce-spacing-md);
}

.ce-trust-bar--enhanced .ce-trust-bar__item {
    background-color: var(--ce-light-bg);
    border-radius: var(--ce-border-radius-lg);
    padding: var(--ce-spacing-md);
    align-items: center;
    font-size: var(--ce-font-size-sm);
    color: var(--ce-gray-800);
    box-shadow: 0 10px 25px rgba(15, 23, 42, 0.05);
}

.ce-trust-bar__icon-wrap {
    width: 48px;
    height: 48px;
    border-radius: 999px;
    background: linear-gradient(135deg, rgba(1, 156, 180, 0.08), rgba(1, 156, 180, 0.02));
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ce-primary);
    flex-shrink: 0;
}

.ce-trust-bar__icon-wrap .ce-trust-bar__cert {
    width: 40px;
    height: 40px;
}

.ce-trust-bar__item-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.ce-trust-bar__item-label {
    font-weight: var(--ce-font-weight-semibold);
}

.ce-trust-bar__item-desc {
    font-size: 0.85rem;
    color: var(--ce-gray-600);
}

@media (min-width: 640px) {
    .ce-trust-bar--enhanced .ce-trust-bar__items {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 768px) {
    .ce-trust-bar--enhanced {
        padding-top: var(--ce-spacing-2xl);
        padding-bottom: var(--ce-spacing-2xl);
    }

    .ce-trust-bar--enhanced .ce-trust-bar__inner {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        gap: var(--ce-spacing-2xl);
    }
}

/* Keep text visible on mobile for enhanced variant */
@media (max-width: 768px) {
    .ce-trust-bar--enhanced .ce-trust-bar__item-label,
    .ce-trust-bar--enhanced .ce-trust-bar__item-desc {
        display: block;
    }
}

/* ==========================================================================
   Service Gallery
   ========================================================================== */

.ce-service-gallery {
    margin-top: var(--ce-spacing-3xl);
    padding-top: var(--ce-spacing-2xl);
    border-top: 1px solid var(--ce-gray-200);
}

.ce-service-gallery h2 {
    font-size: var(--ce-font-size-2xl);
    font-weight: var(--ce-font-weight-bold);
    margin-bottom: var(--ce-spacing-lg);
    color: var(--ce-secondary);
}

.ce-service-gallery__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--ce-spacing-md);
}

.ce-service-gallery__item {
    position: relative;
    border-radius: var(--ce-border-radius-lg);
    overflow: hidden;
    aspect-ratio: 4/3;
}

.ce-service-gallery__item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--ce-transition);
}

.ce-service-gallery__item:hover img {
    transform: scale(1.05);
}

@media (max-width: 768px) {
    .ce-service-gallery__grid {
        grid-template-columns: 1fr;
    }
}

/* ==========================================================================
   Service Cards with Images
   ========================================================================== */

.ce-services-grid--cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--ce-spacing-lg);
}

.ce-service-card--hover {
    background: var(--ce-white);
    border-radius: var(--ce-border-radius-lg);
    overflow: hidden;
    box-shadow: var(--ce-shadow);
    transition: transform var(--ce-transition), box-shadow var(--ce-transition);
}

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

.ce-service-card__image {
    aspect-ratio: 16/10;
    overflow: hidden;
}

.ce-service-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--ce-transition);
}

.ce-service-card--hover:hover .ce-service-card__image img {
    transform: scale(1.05);
}

.ce-service-card__body {
    padding: var(--ce-spacing-lg);
}

.ce-service-card__body .ce-service-card__title {
    font-size: var(--ce-font-size-lg);
    font-weight: var(--ce-font-weight-bold);
    margin-bottom: var(--ce-spacing-sm);
    color: var(--ce-secondary);
}

.ce-service-card__body .ce-service-card__excerpt {
    font-size: var(--ce-font-size-sm);
    color: var(--ce-gray-600);
    margin-bottom: var(--ce-spacing-md);
    line-height: var(--ce-line-height-relaxed);
}

.ce-service-card__body .ce-service-card__link {
    color: var(--ce-primary);
    font-weight: var(--ce-font-weight-semibold);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: var(--ce-spacing-xs);
    transition: gap var(--ce-transition-fast);
}

.ce-service-card__body .ce-service-card__link:hover {
    gap: var(--ce-spacing-sm);
}

@media (max-width: 768px) {
    .ce-services-grid--cards {
        grid-template-columns: 1fr;
    }
}

/* ==========================================================================
   CTA Banner with Background
   ========================================================================== */

.ce-cta-banner {
    position: relative;
    padding: var(--ce-spacing-4xl) 0;
    margin-top: var(--ce-spacing-3xl);
    overflow: hidden;
}

.ce-cta-banner__bg {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.ce-cta-banner__overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, rgba(1, 156, 180, 0.92) 0%, rgba(44, 62, 80, 0.9) 100%);
}

.ce-cta-banner__content {
    position: relative;
    z-index: 2;
    text-align: center;
    color: var(--ce-white);
    max-width: 700px;
    margin: 0 auto;
}

.ce-cta-banner--enhanced .ce-cta-banner__inner {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    gap: var(--ce-spacing-xl);
    align-items: stretch;
}

.ce-cta-banner__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--ce-spacing-xs);
    font-size: 0.7rem;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    font-weight: var(--ce-font-weight-bold);
    color: rgba(226, 245, 255, 0.95);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-cta-banner__eyebrow::before {
    content: '';
    display: inline-block;
    width: 40px;
    height: 1px;
    background-color: currentColor;
}

.ce-cta-banner__title {
    font-size: var(--ce-font-size-3xl);
    font-weight: var(--ce-font-weight-bold);
    margin-bottom: var(--ce-spacing-md);
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
}

.ce-cta-banner__title-highlight {
    color: var(--ce-accent, #a5f3fc);
}

.ce-cta-banner__text {
    font-size: var(--ce-font-size-lg);
    margin-bottom: var(--ce-spacing-xl);
    opacity: 0.95;
}

.ce-cta-banner__actions {
    display: flex;
    gap: var(--ce-spacing-md);
    justify-content: center;
    flex-wrap: wrap;
}

.ce-cta-banner__meta {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--ce-spacing-sm);
    max-width: 24rem;
}

.ce-cta-banner__meta-item {
    background: rgba(15, 23, 42, 0.35);
    border-radius: var(--ce-border-radius-lg);
    padding: var(--ce-spacing-sm) var(--ce-spacing-md);
    backdrop-filter: blur(10px);
    color: var(--ce-white);
}

.ce-cta-banner__meta-label {
    display: block;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    opacity: 0.9;
    margin-bottom: 2px;
}

.ce-cta-banner__meta-value {
    display: block;
    font-size: 0.95rem;
    font-weight: var(--ce-font-weight-medium);
}

@media (max-width: 768px) {
    .ce-cta-banner {
        padding: var(--ce-spacing-2xl) 0;
    }

    .ce-cta-banner__title {
        font-size: var(--ce-font-size-2xl);
    }

    .ce-cta-banner__actions {
        flex-direction: column;
        align-items: center;
    }

    .ce-cta-banner__actions .ce-btn {
        width: 100%;
        max-width: 300px;
        justify-content: center;
    }
}

@media (min-width: 768px) {
    .ce-cta-banner--enhanced .ce-cta-banner__inner {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
    }

    .ce-cta-banner--enhanced .ce-cta-banner__content {
        text-align: left;
        margin: 0;
    }
}

/* ==========================================================================
   Quick Quote Enhancement
   ========================================================================== */

.ce-quick-quote__header {
    text-align: center;
    margin-bottom: var(--ce-spacing-lg);
    padding-bottom: var(--ce-spacing-md);
    border-bottom: 1px solid var(--ce-gray-200);
}

.ce-quick-quote__phone {
    text-align: center;
    margin-top: var(--ce-spacing-lg);
    padding-top: var(--ce-spacing-md);
    border-top: 1px solid var(--ce-gray-200);
}

.ce-quick-quote__phone span {
    display: block;
    font-size: var(--ce-font-size-sm);
    color: var(--ce-gray-600);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-quick-quote__phone a {
    display: inline-flex;
    align-items: center;
    gap: var(--ce-spacing-sm);
    font-size: var(--ce-font-size-xl);
    font-weight: var(--ce-font-weight-bold);
    color: var(--ce-primary);
    text-decoration: none;
}

.ce-quick-quote__phone a:hover {
    color: var(--ce-primary-dark);
}

/* ==========================================================================
   Sidebar Trust Badges
   ========================================================================== */

.ce-sidebar-trust {
    margin-top: var(--ce-spacing-lg);
    padding: var(--ce-spacing-md);
    background: var(--ce-white);
    border-radius: var(--ce-border-radius);
    border: 1px solid var(--ce-gray-200);
}

.ce-sidebar-trust__item {
    display: flex;
    align-items: center;
    gap: var(--ce-spacing-sm);
    padding: var(--ce-spacing-sm) 0;
}

.ce-sidebar-trust__item:not(:last-child) {
    border-bottom: 1px solid var(--ce-gray-100);
}

.ce-sidebar-trust__item svg {
    width: 20px;
    height: 20px;
    color: var(--ce-accent-success);
    flex-shrink: 0;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.ce-sidebar-trust__item span {
    font-size: var(--ce-font-size-sm);
    color: var(--ce-gray-700);
}

/* ==========================================================================
   Logo Enhancement
   ========================================================================== */

.ce-logo__img {
    max-height: 60px;
    width: auto;
    transition: opacity var(--ce-transition-fast);
}

.ce-logo a:hover .ce-logo__img {
    opacity: 0.85;
}

@media (max-width: 768px) {
    .ce-logo__img {
        max-height: 45px;
    }
}

/* ==========================================================================
   Content Styling Enhancement
   ========================================================================== */

.ce-content-styled h2 {
    font-size: var(--ce-font-size-2xl);
    font-weight: var(--ce-font-weight-bold);
    color: var(--ce-secondary);
    margin-top: var(--ce-spacing-2xl);
    margin-bottom: var(--ce-spacing-md);
    padding-bottom: var(--ce-spacing-sm);
    border-bottom: 2px solid var(--ce-primary);
}

.ce-content-styled h3 {
    font-size: var(--ce-font-size-xl);
    font-weight: var(--ce-font-weight-semibold);
    color: var(--ce-secondary);
    margin-top: var(--ce-spacing-xl);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-content-styled ul,
.ce-content-styled ol {
    margin-bottom: var(--ce-spacing-lg);
    padding-left: var(--ce-spacing-lg);
}

.ce-content-styled li {
    margin-bottom: var(--ce-spacing-sm);
    line-height: var(--ce-line-height-relaxed);
}

.ce-content-styled table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: var(--ce-spacing-xl);
    background: var(--ce-white);
    border-radius: var(--ce-border-radius);
    overflow: hidden;
    box-shadow: var(--ce-shadow-sm);
}

.ce-content-styled th,
.ce-content-styled td {
    padding: var(--ce-spacing-md);
    text-align: left;
    border-bottom: 1px solid var(--ce-gray-200);
}

.ce-content-styled th {
    background: var(--ce-primary);
    color: var(--ce-white);
    font-weight: var(--ce-font-weight-semibold);
}

.ce-content-styled tr:nth-child(even) {
    background: var(--ce-gray-100);
}

.ce-content-styled tr:hover {
    background: var(--ce-primary-light);
}

/* ==========================================================================
   FAQ Accordion Component
   ========================================================================== */

.ce-accordion {
    margin: var(--ce-spacing-xl) 0;
}

.ce-accordion__item {
    background: var(--ce-white);
    border: 1px solid var(--ce-gray-200);
    border-radius: var(--ce-border-radius);
    margin-bottom: var(--ce-spacing-sm);
    overflow: hidden;
    transition: box-shadow var(--ce-transition);
}

.ce-accordion__item:hover {
    box-shadow: var(--ce-shadow);
}

.ce-accordion__trigger {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--ce-spacing-lg);
    background: none;
    border: none;
    cursor: pointer;
    text-align: left;
    font-size: var(--ce-font-size-lg);
    font-weight: var(--ce-font-weight-semibold);
    color: var(--ce-secondary);
    transition: background-color var(--ce-transition);
}

.ce-accordion__trigger:hover {
    background: var(--ce-gray-100);
}

.ce-accordion__icon {
    width: 24px;
    height: 24px;
    flex-shrink: 0;
    color: var(--ce-primary);
    transition: transform var(--ce-transition);
}

.ce-accordion__item--open .ce-accordion__icon {
    transform: rotate(180deg);
}

.ce-accordion__content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease-out;
}

.ce-accordion__item--open .ce-accordion__content {
    max-height: 1000px;
}

.ce-accordion__body {
    padding: 0 var(--ce-spacing-lg) var(--ce-spacing-lg);
    color: var(--ce-gray-700);
    line-height: var(--ce-line-height-relaxed);
}

.ce-accordion__body p:last-child {
    margin-bottom: 0;
}

/* ==========================================================================
   Hub Page Styles
   ========================================================================== */

.ce-hub-hero {
    position: relative;
    min-height: 350px;
    display: flex;
    align-items: center;
    padding: var(--ce-spacing-3xl) 0;
    overflow: hidden;
}

.ce-hub-hero__bg {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-size: cover;
    background-position: center;
}

.ce-hub-hero__overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, var(--ce-primary) 0%, var(--ce-primary-dark) 100%);
}

.ce-hub-hero__content {
    position: relative;
    z-index: 2;
    color: var(--ce-white);
    max-width: 720px;
}

.ce-hub-hero__inner {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    gap: var(--ce-spacing-xl);
}

.ce-hub-hero__title {
    font-size: var(--ce-font-size-4xl);
    font-weight: var(--ce-font-weight-extrabold, 800);
    letter-spacing: -0.04em;
    margin-bottom: var(--ce-spacing-md);
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.ce-hub-hero__title-highlight {
    color: var(--ce-accent, #a5f3fc);
}

.ce-hub-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--ce-spacing-xs);
    font-size: 0.7rem;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    font-weight: var(--ce-font-weight-bold);
    color: rgba(226, 245, 255, 0.95);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-hub-hero__eyebrow::before {
    content: '';
    display: inline-block;
    width: 40px;
    height: 1px;
    background-color: currentColor;
}

.ce-hub-hero__subtitle {
    font-size: var(--ce-font-size-lg);
    opacity: 0.95;
    margin-bottom: var(--ce-spacing-lg);
    max-width: 36rem;
}

.ce-hub-hero__meta {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--ce-spacing-sm);
    max-width: 24rem;
}

.ce-hub-hero__meta-item {
    background: rgba(15, 23, 42, 0.35);
    border-radius: var(--ce-border-radius-lg);
    padding: var(--ce-spacing-sm) var(--ce-spacing-md);
    backdrop-filter: blur(10px);
    color: var(--ce-white);
}

.ce-hub-hero__meta-label {
    display: block;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    opacity: 0.9;
    margin-bottom: 2px;
}

.ce-hub-hero__meta-value {
    display: block;
    font-size: 0.95rem;
    font-weight: var(--ce-font-weight-medium);
}

/* Hub hero – light theme (match front page) */
.ce-hub-hero--enhanced {
    background: #f1f5f9;
}

.ce-hub-hero--enhanced .ce-hero-front__bg {
    background: radial-gradient(circle at 85% 15%, rgba(1, 156, 180, 0.08) 0%, transparent 50%);
}

.ce-hub-hero--enhanced .ce-hub-hero__content {
    color: var(--ce-gray-900, #0f172a);
}

.ce-hub-hero--enhanced .ce-hub-hero__title {
    color: var(--ce-gray-900, #0f172a);
    text-shadow: none;
}

.ce-hub-hero--enhanced .ce-hub-hero__title-highlight {
    color: var(--ce-primary);
}

.ce-hub-hero--enhanced .ce-hub-hero__eyebrow {
    color: var(--ce-primary);
}

.ce-hub-hero--enhanced .ce-hub-hero__eyebrow::before {
    background-color: var(--ce-primary);
}

.ce-hub-hero--enhanced .ce-hub-hero__subtitle {
    color: var(--ce-gray-600, #475569);
    opacity: 1;
}

.ce-hub-hero--enhanced .ce-hub-hero__meta-item {
    background: var(--ce-white);
    color: var(--ce-gray-800, #1e293b);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
}

.ce-hub-hero--enhanced .ce-hub-hero__meta-label {
    color: var(--ce-gray-600, #475569);
    opacity: 1;
}

.ce-hub-hero--enhanced .ce-hub-hero__meta-value {
    color: var(--ce-gray-800, #1e293b);
}

.ce-hub-services {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: var(--ce-spacing-xl);
    margin: var(--ce-spacing-2xl) 0;
}

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

.ce-hub-card {
    background: var(--ce-white);
    border-radius: var(--ce-border-radius-lg);
    overflow: hidden;
    box-shadow: var(--ce-shadow);
    transition: transform var(--ce-transition), box-shadow var(--ce-transition);
    text-decoration: none;
    color: inherit;
    display: block;
}

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

.ce-hub-card__image {
    height: 200px;
    overflow: hidden;
}

.ce-hub-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--ce-transition);
}

.ce-hub-card:hover .ce-hub-card__image img {
    transform: scale(1.1);
}

.ce-hub-card__body {
    padding: var(--ce-spacing-lg);
}

.ce-hub-card__title {
    font-size: var(--ce-font-size-xl);
    font-weight: var(--ce-font-weight-bold);
    color: var(--ce-secondary);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-hub-card__excerpt {
    color: var(--ce-gray-600);
    line-height: var(--ce-line-height-relaxed);
    margin-bottom: var(--ce-spacing-md);
}

.ce-hub-card__link {
    color: var(--ce-primary);
    font-weight: var(--ce-font-weight-semibold);
    display: inline-flex;
    align-items: center;
    gap: var(--ce-spacing-xs);
    margin-top: var(--ce-spacing-sm);
    width: 100%;
    justify-content: center;
}

.ce-hub-card__link svg {
    width: 16px;
    height: 16px;
    transition: transform var(--ce-transition-fast);
}

.ce-hub-card:hover .ce-hub-card__link svg {
    transform: translateX(4px);
}

.ce-hub-features {
    background: var(--ce-gray-100);
    padding: var(--ce-spacing-3xl) 0;
}

.ce-hub-features__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: var(--ce-spacing-xl);
}

.ce-hub-feature {
    text-align: center;
    padding: var(--ce-spacing-lg);
}

.ce-hub-feature__icon {
    width: 64px;
    height: 64px;
    margin: 0 auto var(--ce-spacing-md);
    background: var(--ce-primary);
    color: var(--ce-white);
    border-radius: var(--ce-border-radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
}

.ce-hub-feature__icon svg {
    width: 32px;
    height: 32px;
}

.ce-hub-feature__title {
    font-size: var(--ce-font-size-lg);
    font-weight: var(--ce-font-weight-bold);
    color: var(--ce-secondary);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-hub-feature__text {
    color: var(--ce-gray-600);
    line-height: var(--ce-line-height-relaxed);
}

/* ==========================================================================
   About Page Styles
   ========================================================================== */

.ce-about-intro {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--ce-spacing-3xl);
    align-items: center;
    margin: var(--ce-spacing-3xl) 0;
}

.ce-about-intro__content h2 {
    font-size: var(--ce-font-size-3xl);
    color: var(--ce-secondary);
    margin-bottom: var(--ce-spacing-lg);
}

.ce-about-intro__content p {
    color: var(--ce-gray-700);
    line-height: var(--ce-line-height-relaxed);
    margin-bottom: var(--ce-spacing-md);
}

.ce-about-intro__image {
    border-radius: var(--ce-border-radius-lg);
    overflow: hidden;
    box-shadow: var(--ce-shadow-lg);
}

.ce-about-intro__image img {
    width: 100%;
    height: auto;
    display: block;
}

@media (max-width: 768px) {
    .ce-about-intro {
        grid-template-columns: 1fr;
    }

    .ce-about-intro__image {
        order: -1;
    }
}

.ce-about-values {
    background: var(--ce-gray-100);
    padding: var(--ce-spacing-3xl) 0;
    text-align: center;
}

.ce-about-values__title {
    font-size: var(--ce-font-size-3xl);
    color: var(--ce-secondary);
    margin-bottom: var(--ce-spacing-2xl);
}

.ce-about-values__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--ce-spacing-xl);
}

.ce-about-value {
    background: var(--ce-white);
    padding: var(--ce-spacing-xl);
    border-radius: var(--ce-border-radius-lg);
    box-shadow: var(--ce-shadow);
}

.ce-about-value__icon {
    width: 60px;
    height: 60px;
    background: var(--ce-primary-light);
    color: var(--ce-primary);
    border-radius: var(--ce-border-radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto var(--ce-spacing-md);
}

.ce-about-value__icon svg {
    width: 30px;
    height: 30px;
}

.ce-about-value__title {
    font-size: var(--ce-font-size-lg);
    font-weight: var(--ce-font-weight-bold);
    color: var(--ce-secondary);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-about-value__text {
    color: var(--ce-gray-600);
    font-size: var(--ce-font-size-sm);
}

.ce-about-certs {
    padding: var(--ce-spacing-3xl) 0;
    text-align: center;
}

.ce-about-certs__title {
    font-size: var(--ce-font-size-3xl);
    color: var(--ce-secondary);
    margin-bottom: var(--ce-spacing-2xl);
}

.ce-about-certs__grid {
    display: flex;
    justify-content: center;
    gap: var(--ce-spacing-3xl);
    flex-wrap: wrap;
}

.ce-about-cert {
    text-align: center;
    max-width: 200px;
}

.ce-about-cert__image {
    width: 120px;
    height: 120px;
    margin: 0 auto var(--ce-spacing-md);
}

.ce-about-cert__image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.ce-about-cert__title {
    font-weight: var(--ce-font-weight-bold);
    color: var(--ce-secondary);
    margin-bottom: var(--ce-spacing-xs);
}

.ce-about-cert__text {
    font-size: var(--ce-font-size-sm);
    color: var(--ce-gray-600);
}

/* ==========================================================================
   Contact Page Styles
   ========================================================================== */

.ce-contact-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--ce-spacing-3xl);
    margin: var(--ce-spacing-3xl) 0;
}

@media (max-width: 768px) {
    .ce-contact-grid {
        grid-template-columns: 1fr;
    }
}

.ce-contact-form {
    background: var(--ce-white);
    padding: var(--ce-spacing-2xl);
    border-radius: var(--ce-border-radius-lg);
    box-shadow: var(--ce-shadow-lg);
}

.ce-contact-form__title {
    font-size: var(--ce-font-size-2xl);
    color: var(--ce-secondary);
    margin-bottom: var(--ce-spacing-lg);
}

.ce-contact-info {
    padding: var(--ce-spacing-xl);
}

.ce-contact-info__title {
    font-size: var(--ce-font-size-2xl);
    color: var(--ce-secondary);
    margin-bottom: var(--ce-spacing-xl);
}

.ce-contact-info__item {
    display: flex;
    align-items: flex-start;
    gap: var(--ce-spacing-md);
    margin-bottom: var(--ce-spacing-xl);
}

.ce-contact-info__icon {
    width: 48px;
    height: 48px;
    flex-shrink: 0;
    background: var(--ce-primary);
    color: var(--ce-white);
    border-radius: var(--ce-border-radius);
    display: flex;
    align-items: center;
    justify-content: center;
}

.ce-contact-info__icon svg {
    width: 24px;
    height: 24px;
}

.ce-contact-info__content h4 {
    font-size: var(--ce-font-size-lg);
    font-weight: var(--ce-font-weight-bold);
    color: var(--ce-secondary);
    margin-bottom: var(--ce-spacing-xs);
}

.ce-contact-info__content p {
    color: var(--ce-gray-600);
    margin: 0;
}

.ce-contact-info__content a {
    color: var(--ce-primary);
    text-decoration: none;
    font-weight: var(--ce-font-weight-semibold);
}

.ce-contact-info__content a:hover {
    text-decoration: underline;
}

.ce-contact-hours {
    background: var(--ce-gray-100);
    padding: var(--ce-spacing-lg);
    border-radius: var(--ce-border-radius);
    margin-top: var(--ce-spacing-xl);
}

.ce-contact-hours__title {
    font-weight: var(--ce-font-weight-bold);
    color: var(--ce-secondary);
    margin-bottom: var(--ce-spacing-md);
}

.ce-contact-hours__row {
    display: flex;
    justify-content: space-between;
    padding: var(--ce-spacing-sm) 0;
    border-bottom: 1px solid var(--ce-gray-200);
}

.ce-contact-hours__row:last-child {
    border-bottom: none;
}

.ce-contact-map {
    margin-top: var(--ce-spacing-3xl);
    border-radius: var(--ce-border-radius-lg);
    overflow: hidden;
    box-shadow: var(--ce-shadow);
}

.ce-contact-map iframe {
    width: 100%;
    height: 400px;
    border: none;
    display: block;
}

/* ==========================================================================
   Before/After Slider (Referenzen)
   ========================================================================== */

.ce-before-after {
    position: relative;
    width: 100%;
    overflow: hidden;
    border-radius: var(--ce-border-radius-lg);
    box-shadow: var(--ce-shadow-lg);
    user-select: none;
}

.ce-before-after__container {
    position: relative;
    aspect-ratio: 16/9;
}

.ce-before-after__image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.ce-before-after__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.ce-before-after__image--before {
    z-index: 1;
    clip-path: inset(0 50% 0 0);
}

.ce-before-after__image--after {
    z-index: 0;
}

.ce-before-after__slider {
    position: absolute;
    top: 0;
    left: 50%;
    width: 4px;
    height: 100%;
    background: var(--ce-white);
    z-index: 2;
    cursor: ew-resize;
    transform: translateX(-50%);
}

.ce-before-after__handle {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 48px;
    height: 48px;
    transform: translate(-50%, -50%);
    background: var(--ce-white);
    border-radius: var(--ce-border-radius-full);
    box-shadow: var(--ce-shadow-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: ew-resize;
}

.ce-before-after__handle svg {
    width: 24px;
    height: 24px;
    color: var(--ce-primary);
}

.ce-before-after__label {
    position: absolute;
    bottom: var(--ce-spacing-md);
    padding: var(--ce-spacing-sm) var(--ce-spacing-md);
    background: rgba(0, 0, 0, 0.7);
    color: var(--ce-white);
    font-size: var(--ce-font-size-sm);
    font-weight: var(--ce-font-weight-semibold);
    border-radius: var(--ce-border-radius);
    z-index: 3;
}

.ce-before-after__label--before {
    left: var(--ce-spacing-md);
}

.ce-before-after__label--after {
    right: var(--ce-spacing-md);
}

.ce-referenzen-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
    gap: var(--ce-spacing-2xl);
    margin: var(--ce-spacing-3xl) 0;
}

@media (max-width: 480px) {
    .ce-referenzen-grid {
        grid-template-columns: 1fr;
    }
}

.ce-referenz-item {
    background: var(--ce-white);
    border-radius: var(--ce-border-radius-lg);
    overflow: hidden;
    box-shadow: var(--ce-shadow);
}

.ce-referenz-item__title {
    padding: var(--ce-spacing-lg);
    font-size: var(--ce-font-size-lg);
    font-weight: var(--ce-font-weight-bold);
    color: var(--ce-secondary);
    border-top: 3px solid var(--ce-primary);
}

/* ========================================
   REFERENZEN PAGE - Additional Styles
   ======================================== */

.ce-referenzen-hero,
.ce-about-hero,
.ce-contact-hero {
    background: linear-gradient(135deg, var(--ce-primary) 0%, var(--ce-primary-dark) 100%);
    padding: var(--ce-spacing-3xl) 0;
    text-align: center;
    color: var(--ce-white);
}

.ce-referenzen-hero h1,
.ce-about-hero h1,
.ce-contact-hero h1 {
    font-size: clamp(2rem, 5vw, 3rem);
    margin-bottom: var(--ce-spacing-md);
}

.ce-referenzen-hero__subtitle,
.ce-about-hero__subtitle,
.ce-contact-hero__subtitle {
    font-size: var(--ce-font-size-xl);
    opacity: 0.9;
    max-width: 600px;
    margin: 0 auto;
}

/* Referenzen hero – enhanced light theme */
.ce-referenzen-hero--enhanced {
    position: relative;
    background: #f1f5f9;
    padding: var(--ce-spacing-2xl) 0;
    overflow: hidden;
    color: var(--ce-gray-900, #0f172a);
}

.ce-referenzen-hero--enhanced .ce-referenzen-hero__bg {
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 85% 15%, rgba(1, 156, 180, 0.08) 0%, transparent 50%);
    pointer-events: none;
}

.ce-referenzen-hero--enhanced .ce-referenzen-hero__inner {
    position: relative;
    z-index: 1;
}

.ce-referenzen-hero--enhanced .ce-referenzen-hero__content {
    text-align: center;
    max-width: 42rem;
    margin: 0 auto;
}

.ce-referenzen-hero__eyebrow {
    display: inline-block;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: var(--ce-primary);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-referenzen-hero--enhanced .ce-referenzen-hero__title {
    font-size: clamp(1.875rem, 5vw, 2.75rem);
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: -0.03em;
    color: var(--ce-gray-900, #0f172a);
    margin-bottom: var(--ce-spacing-md);
}

.ce-referenzen-hero--enhanced .ce-referenzen-hero__subtitle {
    font-size: var(--ce-font-size-base);
    line-height: 1.65;
    color: var(--ce-gray-600, #475569);
    max-width: 36rem;
    margin: 0 auto var(--ce-spacing-lg);
    opacity: 1;
}

.ce-referenzen-hero__meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--ce-spacing-sm);
    list-style: none;
    margin: 0;
    padding: 0;
    justify-content: center;
}

.ce-referenzen-hero__meta-item {
    display: inline-block;
    padding: var(--ce-spacing-xs) var(--ce-spacing-md);
    background: var(--ce-white);
    color: var(--ce-gray-700, #374151);
    font-size: var(--ce-font-size-sm);
    font-weight: var(--ce-font-weight-medium);
    border-radius: var(--ce-border-radius);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
}

@media (min-width: 768px) {
    .ce-referenzen-hero--enhanced {
        padding: var(--ce-spacing-4xl) 0;
    }
}

/* Enhanced layout just for the contact hero */
.ce-contact-hero--enhanced {
    position: relative;
    overflow: hidden;
}

.ce-contact-hero__overlay {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 80% 0%, rgba(255, 255, 255, 0.2), transparent 55%),
        linear-gradient(135deg, rgba(255, 255, 255, 0.08), transparent 60%);
    opacity: 0.9;
    pointer-events: none;
}

.ce-contact-hero--enhanced .ce-container {
    position: relative;
    z-index: 1;
}

.ce-contact-hero__inner {
    display: flex;
    flex-direction: column;
    gap: var(--ce-spacing-xl);
    text-align: left;
}

.ce-contact-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--ce-spacing-xs);
    font-size: 0.7rem;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    font-weight: var(--ce-font-weight-bold);
    color: var(--ce-accent, #a5f3fc);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-contact-hero__eyebrow::before {
    content: '';
    display: inline-block;
    width: 40px;
    height: 1px;
    background-color: currentColor;
}

.ce-contact-hero__title {
    font-size: clamp(2.25rem, 4vw, 3.25rem);
    line-height: 1.05;
    letter-spacing: -0.04em;
    margin-bottom: var(--ce-spacing-md);
}

.ce-contact-hero__title-highlight {
    color: var(--ce-accent, #a5f3fc);
}

.ce-contact-hero__subtitle {
    font-size: var(--ce-font-size-lg);
    max-width: 36rem;
    margin: 0;
}

.ce-contact-hero__meta {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--ce-spacing-sm);
}

.ce-contact-hero__meta-item {
    background: rgba(15, 23, 42, 0.22);
    border-radius: var(--ce-border-radius-lg);
    padding: var(--ce-spacing-sm) var(--ce-spacing-md);
    backdrop-filter: blur(10px);
}

.ce-contact-hero__meta-label {
    display: block;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    opacity: 0.8;
    margin-bottom: 2px;
}

.ce-contact-hero__meta-value {
    display: block;
    font-size: 0.95rem;
    font-weight: var(--ce-font-weight-medium);
}

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

    .ce-contact-hero__meta {
        max-width: 22rem;
    }
}

.ce-referenzen-section__header {
    text-align: center;
    margin-bottom: var(--ce-spacing-2xl);
}

.ce-referenzen-section__header h2 {
    font-size: var(--ce-font-size-3xl);
    color: var(--ce-secondary);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-referenzen-section__header p {
    color: var(--ce-gray-600);
    font-size: var(--ce-font-size-lg);
}

.ce-referenzen-beforeafter {
    padding: var(--ce-spacing-3xl) 0;
    background: var(--ce-gray-100);
}

.ce-beforeafter-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
    gap: var(--ce-spacing-2xl);
}

.ce-beforeafter-item {
    background: var(--ce-white);
    border-radius: var(--ce-border-radius-lg);
    overflow: hidden;
    box-shadow: var(--ce-shadow);
}

.ce-beforeafter-item__title {
    padding: var(--ce-spacing-lg) var(--ce-spacing-lg) var(--ce-spacing-sm);
    font-size: var(--ce-font-size-lg);
    font-weight: var(--ce-font-weight-bold);
    color: var(--ce-secondary);
    margin: 0;
}

.ce-beforeafter-item__description {
    padding: 0 var(--ce-spacing-lg) var(--ce-spacing-md);
    color: var(--ce-gray-600);
    font-size: var(--ce-font-size-sm);
    margin: 0;
}

/* Testimonials */
.ce-referenzen-testimonials {
    padding: var(--ce-spacing-3xl) 0;
}

.ce-testimonials-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: var(--ce-spacing-xl);
    align-items: stretch;
}

.ce-testimonial-card {
    display: flex;
    flex-direction: column;
    background: var(--ce-white);
    border-radius: var(--ce-border-radius-lg);
    padding: var(--ce-spacing-xl);
    box-shadow: var(--ce-shadow);
    border-left: 4px solid var(--ce-primary);
}

.ce-testimonial-card__stars {
    color: #f1c40f;
    font-size: 1rem;
    letter-spacing: 2px;
    margin-bottom: var(--ce-spacing-sm);
}

.ce-testimonial-card__quote {
    margin-bottom: var(--ce-spacing-lg);
}

.ce-testimonial-card__icon {
    width: 32px;
    height: 32px;
    color: var(--ce-primary);
    opacity: 0.3;
    margin-bottom: var(--ce-spacing-md);
}

.ce-testimonial-card__quote p {
    color: var(--ce-gray-700);
    font-style: italic;
    line-height: 1.7;
    margin: 0;
}

.ce-testimonial-card__author {
    display: flex;
    align-items: center;
    gap: var(--ce-spacing-md);
    margin-top: auto;
}

.ce-testimonial-card__avatar {
    width: 48px;
    height: 48px;
    background: var(--ce-primary);
    color: var(--ce-white);
    border-radius: var(--ce-border-radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: var(--ce-font-weight-bold);
    font-size: var(--ce-font-size-lg);
}

.ce-testimonial-card__info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.ce-testimonial-card__info strong {
    color: var(--ce-secondary);
}

.ce-testimonial-card__info span {
    color: var(--ce-gray-600);
    font-size: var(--ce-font-size-sm);
}

.ce-testimonial-card__service {
    display: inline-block;
    width: fit-content;
    background: var(--ce-gray-100);
    padding: 2px 8px;
    border-radius: var(--ce-border-radius-sm);
    font-size: var(--ce-font-size-xs) !important;
}

/* Client Types */
.ce-referenzen-clients {
    padding: var(--ce-spacing-3xl) 0;
    background: var(--ce-gray-100);
}

.ce-clients-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: var(--ce-spacing-md);
}

.ce-client-type {
    display: flex;
    align-items: center;
    gap: var(--ce-spacing-sm);
    padding: var(--ce-spacing-md) var(--ce-spacing-lg);
    background: var(--ce-white);
    border-radius: var(--ce-border-radius);
    box-shadow: var(--ce-shadow-sm);
    min-width: 0;
}

.ce-client-type svg {
    width: 20px;
    height: 20px;
    color: var(--ce-accent);
    flex-shrink: 0;
}

.ce-client-type span {
    color: var(--ce-secondary);
    font-weight: var(--ce-font-weight-medium);
    min-width: 0;
    overflow-wrap: break-word;
    word-break: break-word;
}

/* Stats */
.ce-referenzen-stats {
    padding: var(--ce-spacing-3xl) 0;
    background: var(--ce-primary);
}

.ce-stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: var(--ce-spacing-xl);
    text-align: center;
}

.ce-stat-item__number {
    display: block;
    font-size: clamp(2.5rem, 5vw, 3.5rem);
    font-weight: var(--ce-font-weight-bold);
    color: var(--ce-white);
    line-height: 1;
    margin-bottom: var(--ce-spacing-sm);
}

.ce-stat-item__label {
    color: rgba(255, 255, 255, 0.9);
    font-size: var(--ce-font-size-sm);
}

/* Referenzen CTA */
.ce-referenzen-cta {
    padding: var(--ce-spacing-3xl) 0;
    background: var(--ce-secondary);
    text-align: center;
}

.ce-referenzen-cta__content h2 {
    color: var(--ce-white);
    font-size: var(--ce-font-size-3xl);
    margin-bottom: var(--ce-spacing-md);
}

.ce-referenzen-cta__content p {
    color: rgba(255, 255, 255, 0.8);
    font-size: var(--ce-font-size-lg);
    margin-bottom: var(--ce-spacing-xl);
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}

.ce-referenzen-cta__buttons {
    display: flex;
    gap: var(--ce-spacing-md);
    justify-content: center;
    flex-wrap: wrap;
}

/* ========================================
   ABOUT PAGE - Additional Styles
   ======================================== */

.ce-about-intro {
    padding: var(--ce-spacing-3xl) 0;
}

.ce-about-intro__grid {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: var(--ce-spacing-3xl);
    align-items: center;
}

@media (max-width: 768px) {
    .ce-about-intro__grid {
        grid-template-columns: 1fr;
    }
}

.ce-about-intro__text h2 {
    font-size: var(--ce-font-size-3xl);
    color: var(--ce-secondary);
    margin-bottom: var(--ce-spacing-lg);
}

.ce-about-intro__lead {
    font-size: var(--ce-font-size-lg);
    color: var(--ce-gray-700);
    font-weight: var(--ce-font-weight-medium);
    margin-bottom: var(--ce-spacing-lg);
}

.ce-about-intro__text p {
    color: var(--ce-gray-600);
    line-height: 1.8;
    margin-bottom: var(--ce-spacing-md);
}

.ce-about-intro__stats {
    display: flex;
    gap: var(--ce-spacing-2xl);
    margin-top: var(--ce-spacing-xl);
    padding-top: var(--ce-spacing-xl);
    border-top: 1px solid var(--ce-gray-200);
}

.ce-about-stat {
    text-align: center;
}

.ce-about-stat__number {
    display: block;
    font-size: var(--ce-font-size-3xl);
    font-weight: var(--ce-font-weight-bold);
    color: var(--ce-primary);
    line-height: 1;
}

.ce-about-stat__label {
    color: var(--ce-gray-600);
    font-size: var(--ce-font-size-sm);
}

.ce-about-intro__image {
    border-radius: var(--ce-border-radius-lg);
    overflow: hidden;
    box-shadow: var(--ce-shadow-lg);
}

.ce-about-intro__image img {
    width: 100%;
    height: auto;
    display: block;
}

/* About Values */
.ce-about-values__header,
.ce-about-certs__header,
.ce-about-timeline__header {
    text-align: center;
    margin-bottom: var(--ce-spacing-2xl);
}

.ce-about-values__header h2,
.ce-about-certs__header h2,
.ce-about-timeline__header h2 {
    font-size: var(--ce-font-size-3xl);
    color: var(--ce-secondary);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-about-values__header p,
.ce-about-certs__header p,
.ce-about-timeline__header p {
    color: var(--ce-gray-600);
    font-size: var(--ce-font-size-lg);
}

.ce-about-values__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: var(--ce-spacing-xl);
}

.ce-about-value {
    text-align: center;
    padding: var(--ce-spacing-xl);
    background: var(--ce-white);
    border-radius: var(--ce-border-radius-lg);
    box-shadow: var(--ce-shadow);
}

.ce-about-value__icon {
    width: 64px;
    height: 64px;
    margin: 0 auto var(--ce-spacing-md);
    background: var(--ce-primary-light);
    border-radius: var(--ce-border-radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
}

.ce-about-value__icon svg {
    width: 32px;
    height: 32px;
    color: var(--ce-primary);
}

.ce-about-value__title {
    font-size: var(--ce-font-size-lg);
    color: var(--ce-secondary);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-about-value__text {
    color: var(--ce-gray-600);
    font-size: var(--ce-font-size-sm);
    margin: 0;
}

/* About Certifications */
.ce-about-certs__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: var(--ce-spacing-xl);
    max-width: 800px;
    margin: 0 auto;
}

.ce-about-cert {
    text-align: center;
    padding: var(--ce-spacing-2xl);
    background: var(--ce-white);
    border-radius: var(--ce-border-radius-lg);
    box-shadow: var(--ce-shadow);
    border: 2px solid var(--ce-gray-200);
    transition: border-color 0.3s ease;
}

.ce-about-cert:hover {
    border-color: var(--ce-primary);
}

.ce-about-cert__badge {
    width: 80px;
    height: 80px;
    margin: 0 auto var(--ce-spacing-lg);
    background: linear-gradient(135deg, var(--ce-primary) 0%, var(--ce-primary-dark) 100%);
    border-radius: var(--ce-border-radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
}

.ce-about-cert__badge svg {
    width: 40px;
    height: 40px;
    color: var(--ce-white);
}

.ce-about-cert__name {
    font-size: var(--ce-font-size-xl);
    font-weight: var(--ce-font-weight-bold);
    color: var(--ce-primary);
    margin-bottom: var(--ce-spacing-xs);
}

.ce-about-cert__title {
    font-size: var(--ce-font-size-lg);
    color: var(--ce-secondary);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-about-cert__description {
    color: var(--ce-gray-600);
    font-size: var(--ce-font-size-sm);
    margin: 0;
    word-wrap: break-word;
    hyphens: auto;
}

/* About Timeline */
.ce-about-timeline {
    padding: var(--ce-spacing-3xl) 0;
    background: var(--ce-gray-100);
}

.ce-about-timeline__items {
    max-width: 800px;
    margin: 0 auto;
    position: relative;
}

.ce-about-timeline__items::before {
    content: '';
    position: absolute;
    left: 50px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: var(--ce-gray-300);
}

@media (max-width: 600px) {
    .ce-about-timeline__items::before {
        left: 30px;
    }
}

.ce-about-timeline__item {
    display: flex;
    gap: var(--ce-spacing-lg);
    margin-bottom: var(--ce-spacing-xl);
    position: relative;
}

.ce-about-timeline__year {
    flex-shrink: 0;
    width: 100px;
    font-weight: var(--ce-font-weight-bold);
    color: var(--ce-primary);
    font-size: var(--ce-font-size-lg);
    text-align: right;
    padding-right: var(--ce-spacing-md);
}

@media (max-width: 600px) {
    .ce-about-timeline__year {
        width: 60px;
        font-size: var(--ce-font-size-sm);
    }
}

.ce-about-timeline__item::after {
    content: '';
    position: absolute;
    left: 46px;
    top: 5px;
    width: 10px;
    height: 10px;
    background: var(--ce-primary);
    border-radius: var(--ce-border-radius-full);
    border: 2px solid var(--ce-white);
}

@media (max-width: 600px) {
    .ce-about-timeline__item::after {
        left: 26px;
    }
}

.ce-about-timeline__event {
    flex: 1;
    background: var(--ce-white);
    padding: var(--ce-spacing-md) var(--ce-spacing-lg);
    border-radius: var(--ce-border-radius);
    box-shadow: var(--ce-shadow-sm);
    color: var(--ce-gray-700);
}

/* About CTA */
.ce-about-cta {
    padding: var(--ce-spacing-3xl) 0;
    background: var(--ce-secondary);
    text-align: center;
}

.ce-about-cta__content h2 {
    color: var(--ce-white);
    font-size: var(--ce-font-size-3xl);
    margin-bottom: var(--ce-spacing-md);
}

.ce-about-cta__content p {
    color: rgba(255, 255, 255, 0.8);
    font-size: var(--ce-font-size-lg);
    margin-bottom: var(--ce-spacing-xl);
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}

.ce-about-cta__buttons {
    display: flex;
    gap: var(--ce-spacing-md);
    justify-content: center;
    flex-wrap: wrap;
}

/* ========================================
   CONTACT PAGE - Additional Styles
   ======================================== */

.ce-contact-main {
    padding: var(--ce-spacing-3xl) 0;
}

.ce-contact-form h2 {
    font-size: var(--ce-font-size-2xl);
    color: var(--ce-secondary);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-contact-form > p {
    color: var(--ce-gray-600);
    margin-bottom: var(--ce-spacing-xl);
}

/* Form Styles */
.ce-form__row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--ce-spacing-lg);
}

@media (max-width: 600px) {
    .ce-form__row {
        grid-template-columns: 1fr;
    }
}

.ce-form__group {
    margin-bottom: var(--ce-spacing-lg);
}

.ce-form__label {
    display: block;
    font-weight: var(--ce-font-weight-medium);
    color: var(--ce-secondary);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-form__input,
.ce-form__select,
.ce-form__textarea {
    width: 100%;
    padding: var(--ce-spacing-md);
    border: 1px solid var(--ce-gray-300);
    border-radius: var(--ce-border-radius);
    font-size: var(--ce-font-size-base);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.ce-form__input:focus,
.ce-form__select:focus,
.ce-form__textarea:focus {
    outline: none;
    border-color: var(--ce-primary);
    box-shadow: 0 0 0 3px var(--ce-primary-light);
}

.ce-form__textarea {
    resize: vertical;
    min-height: 120px;
}

.ce-form__group--checkbox {
    margin-bottom: var(--ce-spacing-xl);
}

.ce-form__checkbox {
    display: flex;
    align-items: flex-start;
    gap: var(--ce-spacing-sm);
    cursor: pointer;
}

.ce-form__checkbox input {
    margin-top: 4px;
    flex-shrink: 0;
}

.ce-form__checkbox span {
    font-size: var(--ce-font-size-sm);
    color: var(--ce-gray-600);
}

.ce-form__checkbox a {
    color: var(--ce-primary);
    text-decoration: underline;
}

.ce-form__note {
    font-size: var(--ce-font-size-sm);
    color: var(--ce-gray-500);
    margin-top: var(--ce-spacing-md);
}

/* Contact Info */
.ce-contact-info__card {
    background: var(--ce-white);
    border-radius: var(--ce-border-radius-lg);
    padding: var(--ce-spacing-xl);
    box-shadow: var(--ce-shadow);
    margin-bottom: var(--ce-spacing-lg);
}

.ce-contact-info__card h3 {
    font-size: var(--ce-font-size-lg);
    color: var(--ce-secondary);
    margin-bottom: var(--ce-spacing-lg);
    padding-bottom: var(--ce-spacing-sm);
    border-bottom: 2px solid var(--ce-primary);
}

.ce-contact-info__card--highlight {
    background: linear-gradient(135deg, var(--ce-primary) 0%, var(--ce-primary-dark) 100%);
    color: var(--ce-white);
}

.ce-contact-info__card--highlight h3 {
    color: var(--ce-white);
    border-bottom-color: rgba(255, 255, 255, 0.3);
}

.ce-contact-info__card--highlight p {
    opacity: 0.9;
    margin-bottom: var(--ce-spacing-lg);
}

.ce-contact-info__items {
    display: flex;
    flex-direction: column;
    gap: var(--ce-spacing-md);
}

.ce-contact-info__item {
    display: flex;
    align-items: center;
    gap: var(--ce-spacing-md);
}

.ce-contact-info__icon {
    width: 40px;
    height: 40px;
    background: var(--ce-primary-light);
    border-radius: var(--ce-border-radius);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.ce-contact-info__icon svg {
    width: 20px;
    height: 20px;
    color: var(--ce-primary);
}

.ce-contact-info__content {
    display: flex;
    flex-direction: column;
}

.ce-contact-info__label {
    font-size: var(--ce-font-size-sm);
    color: var(--ce-gray-500);
}

.ce-contact-info__value {
    color: var(--ce-secondary);
    font-weight: var(--ce-font-weight-medium);
    text-decoration: none;
}

.ce-contact-info__value:hover {
    color: var(--ce-primary);
}

/* Business Hours */
.ce-contact-hours__row {
    display: flex;
    justify-content: space-between;
    padding: var(--ce-spacing-sm) 0;
    border-bottom: 1px solid var(--ce-gray-200);
}

.ce-contact-hours__row:last-child {
    border-bottom: none;
}

.ce-contact-hours__day {
    color: var(--ce-secondary);
}

.ce-contact-hours__time {
    color: var(--ce-gray-600);
    font-weight: var(--ce-font-weight-medium);
}

.ce-contact-hours__note {
    margin-top: var(--ce-spacing-md);
    padding: var(--ce-spacing-sm);
    background: var(--ce-gray-100);
    border-radius: var(--ce-border-radius-sm);
    font-size: var(--ce-font-size-sm);
    color: var(--ce-gray-600);
}

/* Contact Areas */
.ce-contact-areas {
    padding: var(--ce-spacing-3xl) 0;
    background: var(--ce-gray-100);
}

.ce-contact-areas__content {
    text-align: center;
}

.ce-contact-areas__content h2 {
    font-size: var(--ce-font-size-2xl);
    color: var(--ce-secondary);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-contact-areas__content > p {
    color: var(--ce-gray-600);
    margin-bottom: var(--ce-spacing-xl);
}

.ce-contact-areas__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--ce-spacing-xl);
    max-width: 600px;
    margin: 0 auto;
}

.ce-contact-area {
    background: var(--ce-white);
    padding: var(--ce-spacing-xl);
    border-radius: var(--ce-border-radius-lg);
    text-align: left;
}

.ce-contact-area h4 {
    color: var(--ce-primary);
    font-size: var(--ce-font-size-lg);
    margin-bottom: var(--ce-spacing-md);
}

.ce-contact-area ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.ce-contact-area li {
    padding: var(--ce-spacing-xs) 0;
    color: var(--ce-gray-600);
    position: relative;
    padding-left: var(--ce-spacing-lg);
}

.ce-contact-area li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 6px;
    height: 6px;
    background: var(--ce-primary);
    border-radius: var(--ce-border-radius-full);
}

/* Contact Map */
.ce-contact-map {
    position: relative;
}

.ce-contact-map__container {
    position: relative;
}

.ce-contact-map__placeholder {
    background: var(--ce-gray-200);
}

.ce-contact-map__overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.3);
    z-index: 2;
}

.ce-contact-map__card {
    background: var(--ce-white);
    padding: var(--ce-spacing-xl);
    border-radius: var(--ce-border-radius-lg);
    box-shadow: var(--ce-shadow-lg);
    text-align: center;
    max-width: 300px;
}

.ce-contact-map__card h3 {
    color: var(--ce-secondary);
    font-size: var(--ce-font-size-lg);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-contact-map__card p {
    color: var(--ce-gray-600);
    margin-bottom: var(--ce-spacing-lg);
}

/* ========================================
   BUTTON VARIATIONS
   ======================================== */

.ce-btn--white {
    background: var(--ce-white);
    color: var(--ce-secondary);
    border: none;
}

.ce-btn--white:hover {
    background: var(--ce-gray-100);
}

.ce-btn--full {
    width: 100%;
    justify-content: center;
}

/* ========================================
   HUB PAGE CTA SECTION
   ======================================== */

.ce-hub-cta {
    position: relative;
    padding: var(--ce-spacing-4xl) 0;
    margin-top: var(--ce-spacing-3xl);
    background: linear-gradient(135deg, var(--ce-primary) 0%, var(--ce-primary-dark) 100%);
    overflow: hidden;
}

.ce-hub-cta::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
    pointer-events: none;
}

.ce-hub-cta__content {
    position: relative;
    z-index: 2;
    text-align: center;
    color: var(--ce-white);
    max-width: 700px;
    margin: 0 auto;
}

.ce-hub-cta__content h2 {
    font-size: var(--ce-font-size-3xl);
    font-weight: var(--ce-font-weight-bold);
    margin-bottom: var(--ce-spacing-md);
    color: var(--ce-white);
}

.ce-hub-cta__content p {
    font-size: var(--ce-font-size-lg);
    margin-bottom: var(--ce-spacing-xl);
    opacity: 0.9;
    color: var(--ce-white);
}

.ce-hub-cta__buttons {
    display: flex;
    gap: var(--ce-spacing-md);
    justify-content: center;
    flex-wrap: wrap;
}

/* Accent button - Complementary orange for high contrast */
.ce-btn--accent {
    background: linear-gradient(135deg, #e67e22 0%, #d35400 100%);
    border: 2px solid #e67e22;
    color: var(--ce-white);
    font-weight: var(--ce-font-weight-bold);
    box-shadow: 0 4px 15px rgba(230, 126, 34, 0.3);
    transition: all 0.3s ease;
}

.ce-btn--accent:hover {
    background: linear-gradient(135deg, #d35400 0%, #c0392b 100%);
    border-color: #d35400;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(230, 126, 34, 0.4);
    color: var(--ce-white);
}

.ce-btn--accent:active {
    transform: translateY(0);
    box-shadow: 0 2px 10px rgba(230, 126, 34, 0.3);
}

/* Mobile responsive CTA */
@media (max-width: 768px) {
    .ce-hub-cta {
        padding: var(--ce-spacing-2xl) 0;
    }

    .ce-hub-cta__content h2 {
        font-size: var(--ce-font-size-2xl);
    }

    .ce-hub-cta__buttons {
        flex-direction: column;
        align-items: center;
    }

    .ce-hub-cta__buttons .ce-btn {
        width: 100%;
        max-width: 300px;
        justify-content: center;
    }
}

/* ========================================
   ABOUT PAGE - CERTIFICATE IMAGES
   ======================================== */

.ce-about-certs__images {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--ce-spacing-xl);
    margin-bottom: var(--ce-spacing-3xl);
}

.ce-about-cert-image {
    text-align: center;
}

.ce-about-cert-image a {
    display: block;
    border-radius: var(--ce-radius-lg);
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
    transition: all 0.3s ease;
}

.ce-about-cert-image a:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.15);
}

.ce-about-cert-image img {
    width: 100%;
    height: auto;
    display: block;
}

.ce-about-cert-image__caption {
    margin-top: var(--ce-spacing-md);
    font-size: var(--ce-font-size-sm);
    color: var(--ce-text-muted);
    font-weight: var(--ce-font-weight-medium);
}

/* Certificate Badges */
.ce-about-certs__badges {
    display: flex;
    justify-content: center;
    gap: var(--ce-spacing-3xl);
    margin-top: var(--ce-spacing-2xl);
    padding-top: var(--ce-spacing-2xl);
    border-top: 1px solid var(--ce-border-color);
}

.ce-about-cert-badge {
    display: flex;
    align-items: center;
    gap: var(--ce-spacing-md);
    padding: var(--ce-spacing-lg);
    background: var(--ce-bg-light);
    border-radius: var(--ce-radius-lg);
    transition: all 0.3s ease;
}

.ce-about-cert-badge:hover {
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
    transform: translateY(-2px);
}

.ce-about-cert-badge__img {
    width: 60px;
    height: auto;
    object-fit: contain;
}

.ce-about-cert-badge__info h3 {
    font-size: var(--ce-font-size-md);
    font-weight: var(--ce-font-weight-bold);
    color: var(--ce-text);
    margin: 0 0 4px 0;
}

.ce-about-cert-badge__info p {
    font-size: var(--ce-font-size-sm);
    color: var(--ce-text-muted);
    margin: 0;
}

/* Mobile responsive */
@media (max-width: 992px) {
    .ce-about-certs__images {
        grid-template-columns: repeat(2, 1fr);
    }

    .ce-about-certs__images .ce-about-cert-image:last-child {
        grid-column: span 2;
        max-width: 50%;
        margin: 0 auto;
    }
}

@media (max-width: 768px) {
    .ce-about-certs__images {
        grid-template-columns: 1fr;
        gap: var(--ce-spacing-lg);
    }

    .ce-about-certs__images .ce-about-cert-image:last-child {
        grid-column: auto;
        max-width: 100%;
    }

    .ce-about-certs__badges {
        flex-direction: column;
        align-items: center;
        gap: var(--ce-spacing-lg);
    }

    .ce-about-cert-badge {
        width: 100%;
        max-width: 300px;
        justify-content: center;
    }
}

/* ========================================
   ABOUT PAGE - REDESIGNED
   ======================================== */

/* About Hero – light theme (match front page) */
.ce-about-hero {
    position: relative;
    background: #f1f5f9;
    padding: var(--ce-spacing-2xl) 0;
    overflow: hidden;
}

.ce-about-hero__bg {
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 85% 15%, rgba(1, 156, 180, 0.08) 0%, transparent 50%);
    pointer-events: none;
}

.ce-about-hero__inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--ce-spacing-2xl);
    align-items: center;
    text-align: center;
}

@media (min-width: 768px) {
    .ce-about-hero {
        padding: var(--ce-spacing-4xl) 0;
    }

    .ce-about-hero__inner {
        grid-template-columns: 1fr 1fr;
        gap: var(--ce-spacing-3xl);
        text-align: left;
    }
}

.ce-about-hero__eyebrow {
    display: inline-block;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: var(--ce-primary);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-about-hero__title {
    font-size: clamp(1.875rem, 5vw, 2.75rem);
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: -0.03em;
    color: var(--ce-gray-900, #0f172a);
    margin-bottom: var(--ce-spacing-md);
}

.ce-about-hero__subtitle {
    font-size: var(--ce-font-size-base);
    line-height: 1.65;
    color: var(--ce-gray-600, #475569);
    max-width: 28rem;
    margin: 0 auto;
}

@media (min-width: 768px) {
    .ce-about-hero__subtitle {
        margin-left: 0;
        margin-right: 0;
    }
}

.ce-about-hero__media {
    order: -1;
}

@media (min-width: 768px) {
    .ce-about-hero__media {
        order: 0;
    }
}

.ce-about-hero__image-wrap {
    position: relative;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.15);
}

.ce-about-hero__image-wrap::before {
    content: '';
    position: absolute;
    inset: 0;
    border: 1px solid rgba(1, 156, 180, 0.15);
    border-radius: 16px;
    pointer-events: none;
}

.ce-about-hero__image-wrap img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
    aspect-ratio: 4 / 3;
}

/* Page Hero (legacy) */
.ce-page-hero {
    background-size: cover;
    background-position: center;
    padding: 120px 0;
    text-align: center;
    color: var(--ce-white);
}

.ce-page-hero h1 {
    font-size: 3rem;
    font-weight: 700;
    margin-bottom: var(--ce-spacing-md);
    color: var(--ce-white);
}

.ce-page-hero p {
    font-size: 1.25rem;
    opacity: 0.9;
    max-width: 600px;
    margin: 0 auto;
}

/* Section styles */
.ce-section {
    padding: 80px 0;
}

.ce-section--gray {
    background: var(--ce-gray-50, #f8f9fa);
}

.ce-section-header {
    text-align: center;
    margin-bottom: 50px;
}

.ce-section-header h2 {
    font-size: 2.25rem;
    font-weight: 700;
    color: var(--ce-secondary, #1a1a2e);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-section-header p {
    font-size: 1.1rem;
    color: var(--ce-gray-600, #6b7280);
}

/* About Intro */
.ce-about-intro {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: center;
}

.ce-about-intro__content h2 {
    font-size: 2rem;
    font-weight: 700;
    color: var(--ce-secondary, #1a1a2e);
    margin-bottom: var(--ce-spacing-lg);
}

.ce-about-intro__content p {
    color: var(--ce-gray-700, #374151);
    line-height: 1.7;
    margin-bottom: var(--ce-spacing-md);
}

.ce-lead {
    font-size: 1.125rem;
    font-weight: 500;
}

.ce-about-intro__image {
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 20px 40px rgba(0,0,0,0.15);
}

.ce-about-intro__image img {
    width: 100%;
    height: auto;
    display: block;
}

/* Stats */
.ce-stats {
    display: flex;
    gap: 40px;
    margin-top: 40px;
    padding-top: 30px;
    border-top: 1px solid var(--ce-gray-200, #e5e7eb);
}

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

.ce-stat__number {
    display: block;
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--ce-primary, #019cb4);
    line-height: 1;
}

.ce-stat__label {
    font-size: 0.875rem;
    color: var(--ce-gray-600, #6b7280);
    margin-top: 8px;
    display: block;
}

/* Grid */
.ce-grid {
    display: grid;
    gap: 30px;
}

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

/* Cards */
.ce-card {
    background: var(--ce-white, #fff);
    border-radius: 12px;
    padding: 30px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.08);
    transition: transform 0.3s, box-shadow 0.3s;
}

.ce-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 25px rgba(0,0,0,0.12);
}

.ce-card--icon {
    text-align: center;
}

.ce-card__icon {
    width: 70px;
    height: 70px;
    background: linear-gradient(135deg, var(--ce-primary, #019cb4), var(--ce-primary-dark, #017a8f));
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 20px;
}

.ce-card__icon svg {
    width: 32px;
    height: 32px;
    color: var(--ce-white);
}

.ce-card h3 {
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--ce-secondary, #1a1a2e);
    margin-bottom: 10px;
}

.ce-card p {
    font-size: 0.9rem;
    color: var(--ce-gray-600, #6b7280);
    line-height: 1.6;
    margin: 0;
}

/* Certificate Badges */
.ce-cert-badges {
    display: flex;
    justify-content: center;
    gap: 60px;
    margin-bottom: 50px;
}

.ce-cert-badge {
    display: flex;
    align-items: center;
    gap: 20px;
    background: var(--ce-gray-50, #f8f9fa);
    padding: 25px 35px;
    border-radius: 12px;
    border: 2px solid var(--ce-gray-200, #e5e7eb);
}

.ce-cert-badge img {
    width: 80px;
    height: auto;
}

.ce-cert-badge__text {
    text-align: left;
}

.ce-cert-badge__text strong {
    display: block;
    font-size: 1.125rem;
    color: var(--ce-secondary, #1a1a2e);
    margin-bottom: 4px;
}

.ce-cert-badge__text span {
    font-size: 0.9rem;
    color: var(--ce-gray-600, #6b7280);
}

/* Certificate Documents */
.ce-cert-docs {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
}

.ce-cert-doc {
    text-align: center;
}

.ce-cert-doc img {
    width: 100%;
    max-width: 250px;
    height: auto;
    border-radius: 8px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.1);
    transition: transform 0.3s, box-shadow 0.3s;
    cursor: pointer;
}

.ce-cert-doc img:hover {
    transform: scale(1.02);
    box-shadow: 0 8px 30px rgba(0,0,0,0.15);
}

.ce-cert-doc span {
    display: block;
    margin-top: 15px;
    font-size: 0.9rem;
    color: var(--ce-gray-600, #6b7280);
    font-weight: 500;
}

/* Timeline Section Header */
.ce-timeline-section__header {
    text-align: center;
    margin-bottom: var(--ce-spacing-2xl);
}

.ce-timeline-section__eyebrow {
    display: inline-block;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: var(--ce-primary);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-timeline-section__title {
    font-size: var(--ce-font-size-3xl);
    font-weight: 800;
    color: var(--ce-gray-900, #0f172a);
    margin-bottom: var(--ce-spacing-sm);
}

.ce-timeline-section__subtitle {
    font-size: var(--ce-font-size-base);
    color: var(--ce-gray-600, #475569);
}

/* Timeline – vertical with line */
.ce-timeline {
    max-width: 700px;
    margin: 0 auto;
}

.ce-timeline--vertical {
    position: relative;
    padding-left: 0;
}

.ce-timeline--vertical::before {
    content: '';
    position: absolute;
    left: 23px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: linear-gradient(to bottom, var(--ce-primary), var(--ce-primary-dark, #017a8f));
    border-radius: 2px;
}

.ce-timeline--vertical .ce-timeline__item {
    display: grid;
    grid-template-columns: 48px 1fr;
    gap: var(--ce-spacing-lg);
    padding: 0 0 var(--ce-spacing-xl);
    border-bottom: none;
    align-items: start;
}

.ce-timeline--vertical .ce-timeline__item:last-child {
    padding-bottom: 0;
}

.ce-timeline__marker {
    position: relative;
    z-index: 1;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--ce-white);
    border: 3px solid var(--ce-primary);
    box-shadow: 0 2px 8px rgba(1, 156, 180, 0.2);
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.ce-timeline__marker--current {
    background: var(--ce-primary);
    border-color: var(--ce-primary);
}

.ce-timeline--vertical .ce-timeline__year {
    font-size: 0.65rem;
    font-weight: 700;
    color: var(--ce-primary);
    line-height: 1.1;
    text-align: center;
}

.ce-timeline__marker--current .ce-timeline__year {
    color: var(--ce-white);
}

.ce-timeline__card {
    background: var(--ce-white);
    border-radius: var(--ce-border-radius-lg);
    padding: var(--ce-spacing-md) var(--ce-spacing-lg);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
    border-left: 3px solid var(--ce-primary);
}

.ce-timeline__text {
    color: var(--ce-gray-700, #374151);
    font-size: 1rem;
    line-height: 1.6;
    margin: 0;
}

/* Timeline (legacy list style) */
.ce-timeline:not(.ce-timeline--vertical) .ce-timeline__item {
    display: flex;
    gap: 30px;
    padding: 25px 0;
    border-bottom: 1px solid var(--ce-gray-200, #e5e7eb);
}

.ce-timeline:not(.ce-timeline--vertical) .ce-timeline__year {
    min-width: 80px;
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--ce-primary, #019cb4);
}

/* CTA Section */
.ce-cta-section {
    background: linear-gradient(135deg, var(--ce-primary, #019cb4), var(--ce-primary-dark, #017a8f));
    padding: 80px 0;
    text-align: center;
    color: var(--ce-white);
}

.ce-cta-section h2 {
    font-size: 2.25rem;
    font-weight: 700;
    margin-bottom: var(--ce-spacing-md);
    color: var(--ce-white);
}

.ce-cta-section p {
    font-size: 1.1rem;
    opacity: 0.9;
    max-width: 600px;
    margin: 0 auto var(--ce-spacing-xl);
}

.ce-cta-section__buttons {
    display: flex;
    gap: 20px;
    justify-content: center;
}

.ce-btn--white {
    background: var(--ce-white);
    color: var(--ce-primary, #019cb4);
    border: none;
}

.ce-btn--white:hover {
    background: var(--ce-gray-100);
}

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

.ce-btn--outline-white:hover {
    background: var(--ce-white);
    color: var(--ce-primary, #019cb4);
}

/* Responsive */
@media (max-width: 992px) {
    .ce-grid--4 {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .ce-cert-badges {
        flex-direction: column;
        align-items: center;
        gap: 20px;
    }
    
    .ce-cert-docs {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .ce-page-hero {
        padding: 80px 20px;
    }
    
    .ce-page-hero h1 {
        font-size: 2rem;
    }
    
    .ce-section {
        padding: 60px 0;
    }
    
    .ce-about-intro {
        grid-template-columns: 1fr;
        gap: 40px;
    }
    
    .ce-about-intro__image {
        order: -1;
    }
    
    .ce-stats {
        flex-wrap: wrap;
        justify-content: center;
    }
    
    .ce-grid--4 {
        grid-template-columns: 1fr;
    }
    
    .ce-cert-docs {
        grid-template-columns: 1fr;
    }
    
    .ce-cert-doc img {
        max-width: 200px;
    }
    
    .ce-timeline__item {
        flex-direction: column;
        gap: 10px;
    }
    
    .ce-cta-section__buttons {
        flex-direction: column;
        align-items: center;
    }
}

/* ========================================
   BEFORE & AFTER SECTION
   ======================================== */

.ce-before-after-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
}

.ce-before-after {
    background: var(--ce-white, #fff);
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(0,0,0,0.1);
}

.ce-before-after__images {
    display: grid;
    grid-template-columns: 1fr 1fr;
}

.ce-before-after__item {
    position: relative;
    overflow: hidden;
}

.ce-before-after__item img {
    width: 100%;
    height: 200px;
    object-fit: cover;
    display: block;
    transition: transform 0.3s;
}

.ce-before-after__item:hover img {
    transform: scale(1.05);
}

.ce-before-after__label {
    position: absolute;
    top: 10px;
    left: 10px;
    padding: 2px 10px;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    border-radius: 999px;
    color: var(--ce-white);
    background: rgba(0, 0, 0, 0.7);
    white-space: nowrap;
    line-height: 1.4;
    max-height: 24px;
}

.ce-before-after__label--before {
    background: #e74c3c;
}

.ce-before-after__label--after {
    background: #27ae60;
    left: auto;
    right: 10px;
}

.ce-before-after__info {
    padding: 20px;
    text-align: center;
    border-top: 1px solid var(--ce-gray-200, #e5e7eb);
}

.ce-before-after__info h3 {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--ce-secondary, #1a1a2e);
    margin: 0 0 5px 0;
}

.ce-before-after__info p {
    font-size: 0.9rem;
    color: var(--ce-gray-600, #6b7280);
    margin: 0;
}

@media (max-width: 992px) {
    .ce-before-after-grid {
        grid-template-columns: 1fr;
        max-width: 500px;
        margin: 0 auto;
    }
}

@media (max-width: 480px) {
    .ce-before-after__item img {
        height: 150px;
    }
}

/* ========================================
   COMPARISON CARDS (Before/After)
   ======================================== */

.ce-comparison-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
    gap: var(--ce-spacing-xl, 32px);
    margin-top: var(--ce-spacing-xl, 32px);
}

.ce-comparison-card {
    background: var(--ce-white, #ffffff);
    border-radius: var(--ce-border-radius-lg, 12px);
    overflow: hidden;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.ce-comparison-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
}

.ce-comparison-card__header {
    padding: var(--ce-spacing-lg, 24px);
    text-align: center;
    border-bottom: 1px solid var(--ce-gray-200, #e5e7eb);
}

.ce-comparison-card__header h3 {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--ce-secondary, #1a1a2e);
    margin: 0 0 8px 0;
}

.ce-comparison-card__header p {
    font-size: 0.95rem;
    color: var(--ce-gray-600, #6b7280);
    margin: 0;
}

.ce-comparison-card__images {
    display: grid;
    grid-template-columns: 1fr 1fr;
}

.ce-comparison-card__image {
    position: relative;
    overflow: hidden;
}

.ce-comparison-card__image img {
    width: 100%;
    height: 220px;
    object-fit: cover;
    display: block;
    transition: transform 0.4s ease;
}

.ce-comparison-card__image:hover img {
    transform: scale(1.05);
}

.ce-comparison-card__label {
    position: absolute;
    top: 12px;
    left: 12px;
    padding: 6px 14px;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-radius: 6px;
    color: var(--ce-white, #ffffff);
    z-index: 1;
}

.ce-comparison-card__label--before {
    background: linear-gradient(135deg, #ef4444, #dc2626);
}

.ce-comparison-card__label--after {
    background: linear-gradient(135deg, #22c55e, #16a34a);
}

/* Divider line between before/after */
.ce-comparison-card__image:first-child {
    border-right: 2px solid var(--ce-white, #ffffff);
}

@media (max-width: 768px) {
    .ce-comparison-grid {
        grid-template-columns: 1fr;
        max-width: 500px;
        margin-left: auto;
        margin-right: auto;
    }

    .ce-comparison-card__image img {
        height: 180px;
    }
}

@media (max-width: 480px) {
    .ce-comparison-card__images {
        grid-template-columns: 1fr;
    }

    .ce-comparison-card__image:first-child {
        border-right: none;
        border-bottom: 2px solid var(--ce-white, #ffffff);
    }

    .ce-comparison-card__image img {
        height: 200px;
    }
}

/* ========================================
   BEFORE SECTION - Large Cards
   ======================================== */

.ce-referenzen-before {
    padding: var(--ce-spacing-2xl, 64px) 0;
    background: var(--ce-gray-50, #f9fafb);
}

.ce-before-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--ce-spacing-xl, 32px);
    margin-top: var(--ce-spacing-xl, 32px);
}

.ce-before-card {
    background: var(--ce-white, #ffffff);
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.1);
    display: flex;
    flex-direction: column;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.ce-before-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15);
}

.ce-before-card__image {
    position: relative;
    overflow: hidden;
    aspect-ratio: 4/3;
}

.ce-before-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: left center;
    transition: transform 0.5s ease;
}

.ce-before-card:hover .ce-before-card__image img {
    transform: scale(1.08);
}

.ce-before-card__badge {
    position: absolute;
    top: 16px;
    left: 16px;
    padding: 8px 16px;
    background: linear-gradient(135deg, #ef4444, #b91c1c);
    color: #fff;
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(239, 68, 68, 0.4);
}

.ce-before-card__content {
    padding: 24px;
}

.ce-before-card__content h3 {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--ce-secondary, #1a1a2e);
    margin: 0 0 8px 0;
}

.ce-before-card__content p {
    font-size: 0.95rem;
    color: var(--ce-gray-600, #6b7280);
    margin: 0;
    line-height: 1.6;
}

/* ========================================
   AFTER SECTION - Small Cards
   ======================================== */

.ce-referenzen-after {
    padding: var(--ce-spacing-2xl, 64px) 0;
    background: linear-gradient(180deg, #0891b2 0%, #0e7490 100%);
}

.ce-referenzen-after .ce-referenzen-section__header h2,
.ce-referenzen-after .ce-referenzen-section__header p {
    color: #fff;
}

.ce-after-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--ce-spacing-lg, 24px);
    margin-top: var(--ce-spacing-xl, 32px);
}

.ce-after-card {
    background: var(--ce-white, #ffffff);
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.15);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    text-align: center;
}

.ce-after-card:hover {
    transform: translateY(-6px) scale(1.02);
    box-shadow: 0 16px 48px rgba(0, 0, 0, 0.2);
}

.ce-after-card__image {
    position: relative;
    overflow: hidden;
    aspect-ratio: 16/10;
}

.ce-after-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.ce-after-card:hover .ce-after-card__image img {
    transform: scale(1.1);
}

.ce-after-card__badge {
    position: absolute;
    top: 12px;
    right: 12px;
    padding: 6px 14px;
    background: linear-gradient(135deg, #22c55e, #15803d);
    color: #fff;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    border-radius: 6px;
    box-shadow: 0 4px 12px rgba(34, 197, 94, 0.4);
}

.ce-after-card h4 {
    padding: 16px;
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
    color: var(--ce-secondary, #1a1a2e);
    background: var(--ce-white, #ffffff);
}

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

@media (max-width: 992px) {
    .ce-before-cards {
        grid-template-columns: 1fr;
        max-width: 500px;
        margin-left: auto;
        margin-right: auto;
    }

    .ce-after-cards {
        grid-template-columns: repeat(3, 1fr);
        gap: var(--ce-spacing-md, 16px);
    }
}

@media (max-width: 768px) {
    .ce-after-cards {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 480px) {
    .ce-after-cards {
        grid-template-columns: 1fr;
        max-width: 320px;
        margin-left: auto;
        margin-right: auto;
    }

    .ce-before-card__content {
        padding: 20px;
    }

    .ce-before-card__content h3 {
        font-size: 1.1rem;
    }
}

/* ========================================
   BEFORE SECTION - 3 Cards Side by Side
   ======================================== */

.ce-referenzen-before {
    padding: 60px 0;
    background: #f8fafc;
}

.ce-before-cards {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 30px !important;
    margin-top: 40px;
    max-width: none !important;
}

.ce-before-card {
    background: #fff;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.ce-before-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15);
}

.ce-before-card__image {
    position: relative;
    overflow: hidden;
    height: 250px;
}

.ce-before-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.ce-before-card:hover .ce-before-card__image img {
    transform: scale(1.08);
}

.ce-before-card__badge {
    position: absolute;
    top: 16px;
    left: 16px;
    padding: 8px 16px;
    background: linear-gradient(135deg, #ef4444, #b91c1c);
    color: #fff;
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(239, 68, 68, 0.4);
}

.ce-before-card__content {
    padding: 24px;
}

.ce-before-card__content h3 {
    font-size: 1.15rem;
    font-weight: 700;
    color: #1a1a2e;
    margin: 0 0 8px 0;
}

.ce-before-card__content p {
    font-size: 0.9rem;
    color: #6b7280;
    margin: 0;
    line-height: 1.5;
}

/* ========================================
   AFTER SECTION - 3 Smaller Cards Side by Side
   ======================================== */

.ce-referenzen-after {
    padding: 60px 0;
    background: linear-gradient(135deg, #0891b2 0%, #0e7490 100%);
}

.ce-referenzen-after .ce-referenzen-section__header h2,
.ce-referenzen-after .ce-referenzen-section__header p {
    color: #fff;
}

.ce-after-cards {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 24px !important;
    margin-top: 40px;
    max-width: none !important;
}

.ce-after-card {
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
    transition: transform 0.3s ease;
    text-align: center;
}

.ce-after-card:hover {
    transform: translateY(-6px) scale(1.02);
}

.ce-after-card__image {
    position: relative;
    overflow: hidden;
    height: 180px;
}

.ce-after-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.ce-after-card:hover .ce-after-card__image img {
    transform: scale(1.1);
}

.ce-after-card__badge {
    position: absolute;
    top: 12px;
    right: 12px;
    padding: 6px 14px;
    background: linear-gradient(135deg, #22c55e, #15803d);
    color: #fff;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    border-radius: 6px;
    box-shadow: 0 4px 12px rgba(34, 197, 94, 0.4);
}

.ce-after-card h4 {
    padding: 14px;
    margin: 0;
    font-size: 0.95rem;
    font-weight: 600;
    color: #1a1a2e;
}

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

@media (max-width: 900px) {
    .ce-before-cards {
        grid-template-columns: 1fr !important;
        max-width: 450px !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }

    .ce-after-cards {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 16px !important;
    }

    .ce-after-card__image {
        height: 140px;
    }

    .ce-after-card h4 {
        font-size: 0.85rem;
        padding: 10px;
    }
}

@media (max-width: 600px) {
    .ce-after-cards {
        grid-template-columns: 1fr 1fr 1fr !important;
        gap: 12px !important;
    }

    .ce-after-card__image {
        height: 100px;
    }

    .ce-after-card h4 {
        font-size: 0.75rem;
        padding: 8px;
    }

    .ce-after-card__badge {
        font-size: 0.6rem;
        padding: 4px 8px;
    }
}

/* ========================================
   HERO IMAGE
   ======================================== */

.ce-hero__img {
    width: 100%;
    height: auto;
    max-width: 500px;
    border-radius: 16px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    object-fit: cover;
}

@media (max-width: 768px) {
    .ce-hero__img {
        max-width: 100%;
        margin-top: 30px;
    }
}
