/* ============================================
   Astra Child – Elektro & SmartHome Design
   Inspired by tsc-heinrich.de
   ============================================ */

/* ---------- CSS Variables ---------- */
:root {
    --color-primary:   #0a1628;
    --color-secondary: #0d2137;
    --color-accent:    #e63946;
    --color-accent2:   #c1121f;
    --color-white:     #ffffff;
    --color-light:     #f4f6f9;
    --color-text:      #1a1a2e;
    --color-text-muted:#6c757d;
    --color-border:    #dee2e6;
    --font-sans:       'Inter', 'Segoe UI', Arial, sans-serif;
    --font-heading:    'Inter', 'Segoe UI', Arial, sans-serif;
    --shadow-sm:       0 2px 8px rgba(10,22,40,0.08);
    --shadow-md:       0 4px 20px rgba(10,22,40,0.12);
    --shadow-lg:       0 8px 40px rgba(10,22,40,0.18);
    --radius:          6px;
    --transition:      all 0.3s ease;
}

/* ---------- Reset & Base ---------- */
*, *::before, *::after { box-sizing: border-box; }

body {
    font-family: var(--font-sans);
    color: var(--color-text);
    background: var(--color-white);
    margin: 0;
    padding: 0;
    line-height: 1.7;
}

img { max-width: 100%; height: auto; }

a {
    color: var(--color-accent);
    text-decoration: none;
    transition: var(--transition);
}
a:hover { color: var(--color-accent2); }

/* ---------- Hide Astra defaults on front page ---------- */
body.home .site-header-primary-section-left,
body.home .site-header-primary-section-right,
body.home .ast-masthead-custom-menu-items,
.ast-language-switcher,
.pll-parent-menu-item,
.widget_polylang,
.lang-item { display: none !important; }

/* ---------- CUSTOM HEADER / NAV ---------- */
.ek-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: var(--color-primary);
    box-shadow: 0 2px 12px rgba(0,0,0,0.25);
}

.ek-header-inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 72px;
}

.ek-logo {
    display: flex;
    flex-direction: row;
}
.ek-logo-name {
    font-size: 1.3rem;
    font-weight: 800;
    color: var(--color-white);
    letter-spacing: -0.02em;
    line-height: 1.2;
}
.ek-logo-tagline {
    font-size: 0.65rem;
    color: var(--color-accent);
    letter-spacing: 0.1em;
    text-transform: uppercase;
    font-weight: 600;
}

.ek-nav { display: flex; align-items: center; gap: 32px; }
.ek-nav a {
    color: rgba(255,255,255,0.85);
    font-size: 0.9rem;
    font-weight: 500;
    transition: var(--transition);
    padding: 8px 0;
    border-bottom: 2px solid transparent;
}
.ek-nav a:hover {
    color: var(--color-white);
    border-bottom-color: var(--color-accent);
}

.ek-header-cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--color-accent);
    color: var(--color-white) !important;
    padding: 10px 22px;
    border-radius: var(--radius);
    font-size: 0.875rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    transition: var(--transition);
}
.ek-header-cta:hover {
    background: var(--color-accent2);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(230,57,70,0.4);
}

.ek-mobile-toggle {
    display: none;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    padding: 8px;
}
.ek-mobile-toggle span {
    width: 24px;
    height: 2px;
    background: var(--color-white);
    border-radius: 2px;
    transition: var(--transition);
}

/* ---------- HERO SECTION ---------- */
.ek-hero {
    position: relative;
    min-height: 680px;
    display: flex;
    align-items: center;
    background: linear-gradient(135deg, #0a1628 0%, #0d2137 50%, #162845 100%);
    overflow: hidden;
}

.ek-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 600"><circle cx="900" cy="300" r="400" fill="rgba(230,57,70,0.04)"/><circle cx="1100" cy="100" r="200" fill="rgba(13,33,55,0.8)"/></svg>') no-repeat center right;
    background-size: cover;
}

.ek-hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(230,57,70,0.15);
    border: 1px solid rgba(230,57,70,0.3);
    color: var(--color-accent);
    padding: 6px 16px;
    border-radius: 999px;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin-bottom: 24px;
}

.ek-hero-inner {
    position: relative;
    max-width: 1200px;
    margin: 0 auto;
    padding: 80px 24px;
    width: 100%;
}

.ek-hero-content { max-width: 680px; }

.ek-hero h1 {
    font-size: clamp(2rem, 4vw, 3.2rem);
    font-weight: 900;
    color: var(--color-white);
    line-height: 1.15;
    margin: 0 0 24px;
    letter-spacing: -0.03em;
}

.ek-hero h1 span { color: var(--color-accent); }

.ek-hero-subtitle {
    font-size: 1.05rem;
    color: rgba(255,255,255,0.75);
    margin-bottom: 32px;
    line-height: 1.7;
}

.ek-hero-bullets {
    list-style: none;
    padding: 0;
    margin: 0 0 40px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.ek-hero-bullets li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    color: rgba(255,255,255,0.85);
    font-size: 0.95rem;
}
.ek-hero-bullets li::before {
    content: '';
    width: 6px;
    height: 6px;
    min-width: 6px;
    background: var(--color-accent);
    border-radius: 50%;
    margin-top: 9px;
}

.ek-hero-actions {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
}

/* ---------- BUTTONS ---------- */
.btn-primary {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--color-accent);
    color: var(--color-white) !important;
    padding: 14px 28px;
    border-radius: var(--radius);
    font-size: 0.9rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    transition: var(--transition);
    border: 2px solid var(--color-accent);
    cursor: pointer;
}
.btn-primary:hover {
    background: var(--color-accent2);
    border-color: var(--color-accent2);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(230,57,70,0.4);
}

.btn-secondary {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: transparent;
    color: var(--color-white) !important;
    padding: 14px 28px;
    border-radius: var(--radius);
    font-size: 0.9rem;
    font-weight: 600;
    transition: var(--transition);
    border: 2px solid rgba(255,255,255,0.4);
}
.btn-secondary:hover {
    background: rgba(255,255,255,0.1);
    border-color: rgba(255,255,255,0.7);
    transform: translateY(-2px);
}

.btn-dark {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--color-primary);
    color: var(--color-white) !important;
    padding: 14px 28px;
    border-radius: var(--radius);
    font-size: 0.9rem;
    font-weight: 700;
    transition: var(--transition);
    border: 2px solid var(--color-primary);
}
.btn-dark:hover {
    background: var(--color-secondary);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

/* ---------- SECTIONS ---------- */
.ek-section {
    padding: 80px 0;
}
.ek-section-light { background: var(--color-text); }
.ek-section-gray  { background: var(--color-light); }
.ek-section-dark  { background: var(--color-primary); }

.ek-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}

.ek-section-header {
    text-align: center;
    margin-bottom: 56px;
}
.ek-section-label {
    display: inline-block;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--color-accent);
    margin-bottom: 12px;
}
.ek-section-header h2 {
    font-size: clamp(1.6rem, 3vw, 2.4rem);
    font-weight: 800;
    color: var(--color-text);
    margin: 0 0 16px;
    letter-spacing: -0.02em;
}
.ek-section-dark .ek-section-header h2 { color: var(--color-white); }
.ek-section-header p {
    font-size: 1rem;
    color: var(--color-text-muted);
    max-width: 600px;
    margin: 0 auto;
}
.ek-section-dark .ek-section-header p { color: rgba(255,255,255,0.7); }

/* ---------- SERVICE CARDS ---------- */
.ek-grid-3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
.ek-grid-4 {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}

.ek-card {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 28px 24px;
    transition: var(--transition);
    position: relative;
    overflow: hidden;
}
.ek-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: var(--color-accent);
    transform: scaleX(0);
    transition: var(--transition);
}
.ek-card:hover {
    border-color: transparent;
    box-shadow: var(--shadow-md);
    transform: translateY(-4px);
}
.ek-card:hover::before { transform: scaleX(1); }

.ek-card-icon {
    width: 48px;
    height: 48px;
    background: rgba(230,57,70,0.1);
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 16px;
    font-size: 1.5rem;
    color: var(--color-accent);
}

.ek-card h3 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-text);
    margin: 0 0 8px;
    line-height: 1.4;
}
.ek-card p {
    font-size: 0.875rem;
    color: var(--color-text-muted);
    margin: 0;
    line-height: 1.6;
}

/* Specialty tag cards */
.ek-tag-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 16px;
}
.ek-tag {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--color-white);
    border: 1px solid var(--color-border);
    color: var(--color-text);
    padding: 10px 18px;
    border-radius: var(--radius);
    font-size: 0.875rem;
    font-weight: 500;
    transition: var(--transition);
    cursor: default;
}
.ek-tag:hover {
    border-color: var(--color-accent);
    color: var(--color-accent);
    box-shadow: var(--shadow-sm);
}
.ek-tag-dot {
    width: 6px;
    height: 6px;
    background: var(--color-accent);
    border-radius: 50%;
    flex-shrink: 0;
}

/* ---------- COOPERATION / 2-COL ---------- */
.ek-two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    align-items: start;
}

.ek-check-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.ek-check-list li {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    font-size: 0.95rem;
    color: var(--color-text);
    line-height: 1.6;
}
.ek-check-list li::before {
    content: '';
    width: 20px;
    height: 20px;
    min-width: 20px;
    background: var(--color-accent);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 10'%3E%3Cpath d='M1 5l3 4L11 1' stroke='white' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 10px;
    margin-top: 3px;
}

.ek-col-box {
    background: var(--color-light);
    border-radius: var(--radius);
    padding: 32px;
}
.ek-col-box h3 {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--color-text);
    margin: 0 0 20px;
    padding-bottom: 16px;
    border-bottom: 2px solid var(--color-border);
}

/* ---------- PROCESS STEPS ---------- */
.ek-steps {
    display: flex;
    flex-direction: column;
    gap: 0;
    position: relative;
}
.ek-steps::before {
    content: '';
    position: absolute;
    left: 28px;
    top: 0; bottom: 0;
    width: 2px;
    background: linear-gradient(to bottom, var(--color-accent), rgba(230,57,70,0.1));
}

.ek-step {
    display: flex;
    gap: 24px;
    padding: 28px 0;
    position: relative;
}
.ek-step:first-child { padding-top: 0; }
.ek-step:last-child { padding-bottom: 0; }

.ek-step-num {
    width: 56px;
    height: 56px;
    min-width: 56px;
    background: var(--color-accent);
    color: var(--color-white);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    font-weight: 800;
    position: relative;
    z-index: 1;
    flex-shrink: 0;
}

.ek-step-content { padding-top: 12px; }
.ek-step-content h3 {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--color-text);
    margin: 0 0 8px;
}
.ek-step-content p {
    font-size: 0.9rem;
    color: var(--color-text-muted);
    margin: 0;
    line-height: 1.6;
}

.ek-steps-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    align-items: start;
}
.ek-steps-intro {
    padding-top: 16px;
}
.ek-steps-intro h2 {
    font-size: clamp(1.5rem, 2.5vw, 2rem);
    font-weight: 800;
    color: var(--color-text);
    margin: 0 0 20px;
    letter-spacing: -0.02em;
}
.ek-steps-intro p {
    color: var(--color-text-muted);
    font-size: 0.95rem;
    line-height: 1.7;
    margin-bottom: 32px;
}

/* ---------- FAQ ACCORDION ---------- */
.ek-faq { display: flex; flex-direction: column; gap: 12px; }

.ek-faq-item {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    overflow: hidden;
    transition: var(--transition);
}
.ek-faq-item.active {
    border-color: var(--color-accent);
    box-shadow: var(--shadow-sm);
}

.ek-faq-question {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 24px;
    cursor: pointer;
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--color-text);
    user-select: none;
    gap: 16px;
}
.ek-faq-question:hover { color: var(--color-accent); }
.ek-faq-icon {
    width: 24px;
    height: 24px;
    min-width: 24px;
    background: var(--color-light);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: var(--transition);
    color: var(--color-text);
    font-size: 1.2rem;
    font-weight: 300;
}
.ek-faq-item.active .ek-faq-icon {
    background: var(--color-accent);
    color: var(--color-white);
    transform: rotate(45deg);
}

.ek-faq-answer {
    display: none;
    padding: 0 24px20px;
    font-size: 0.9rem;
    color: var(--color-text-muted);
    line-height: 1.7;
    border-top: 1px solid var(--color-border);
    padding-top: 16px;
}
.ek-faq-item.active .ek-faq-answer { display: block; }

/* ---------- CTA SECTION ---------- */
.ek-cta {
    background: var(--color-primary);
    padding: 80px 0;
}
.ek-cta-inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    align-items: start;
}
.ek-cta-left h2 {
    font-size: clamp(1.6rem, 3vw, 2.2rem);
    font-weight: 800;
    color: var(--color-white);
    margin: 0 0 16px;
    letter-spacing: -0.02em;
}
.ek-cta-left p {
    color: rgba(255,255,255,0.7);
    font-size: 1rem;
    line-height: 1.7;
    margin-bottom: 32px;
}
.ek-trust-note {
    font-size: 0.8rem;
    color: rgba(255,255,255,0.5);
    margin-top: 16px;
    letter-spacing: 0.05em;
}
.ek-contact-box {
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: var(--radius);
    padding: 32px;
}
.ek-contact-box h3 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-white);
    margin: 0 0 20px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-size: 0.8rem;
}
.ek-contact-item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 16px;
    color: rgba(255,255,255,0.8);
    font-size: 0.95rem;
}
.ek-contact-item:last-child { margin-bottom: 0; }
.ek-contact-item a { color: rgba(255,255,255,0.9); }
.ek-contact-item a:hover { color: var(--color-accent); }
.ek-contact-icon {
    width: 36px;
    height: 36px;
    background: rgba(230,57,70,0.15);
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    flex-shrink: 0;
}

/* ---------- FOOTER ---------- */
.ek-footer {
    background: #060e1a;
    padding: 48px 0 32px;
    color: rgba(255,255,255,0.6);
    font-size: 0.875rem;
}
.ek-footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 40px;
    margin-bottom: 40px;
}
.ek-footer-brand h3 {
    font-size: 1.1rem;
    font-weight: 800;
    color: var(--color-white);
    margin: 0 0 12px;
}
.ek-footer-brand p {
    color: rgba(255,255,255,0.5);
    line-height: 1.7;
    max-width: 260px;
}
.ek-footer-col h4 {
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.4);
    margin: 0 0 16px;
}
.ek-footer-col ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.ek-footer-col ul li a {
    color: rgba(255,255,255,0.6);
    font-size: 0.875rem;
    transition: var(--transition);
}
.ek-footer-col ul li a:hover { color: var(--color-white); }

.ek-footer-bottom {
    border-top: 1px solid rgba(255,255,255,0.08);
    padding-top: 24px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
}
.ek-footer-bottom-links {
    display: flex;
    gap: 24px;
}
.ek-footer-bottom-links a {
    color: rgba(255,255,255,0.4);
    font-size: 0.8rem;
}
.ek-footer-bottom-links a:hover { color: rgba(255,255,255,0.7); }

/* ---------- STAT BAR ---------- */
.ek-stats {
    background: var(--color-accent);
    padding: 20px 0;
}
.ek-stats-inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 48px;
    flex-wrap: wrap;
}
.ek-stat {
    display: flex;
    align-items: center;
    gap: 12px;
    color: var(--color-white);
}
.ek-stat-number {
    font-size: 1.8rem;
    font-weight: 900;
    line-height: 1;
}
.ek-stat-label {
    font-size: 0.8rem;
    font-weight: 500;
    opacity: 0.85;
    max-width: 100px;
    line-height: 1.3;
}
.ek-stat-divider {
    width: 1px;
    height: 40px;
    background: rgba(255,255,255,0.3);
}

/* ---------- TRUST BADGES ---------- */
.ek-trust-bar {
    padding: 32px 0;
    background: var(--color-light);
    border-bottom: 1px solid var(--color-border);
}
.ek-trust-inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 40px;
    flex-wrap: wrap;
}
.ek-trust-item {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--color-text-muted);
    font-size: 0.85rem;
    font-weight: 500;
}
.ek-trust-icon {
    width: 36px;
    height: 36px;
    background: var(--color-accent);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 1024px) {
    .ek-grid-4 { grid-template-columns: repeat(2, 1fr); }
    .ek-footer-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 768px) {
    .ek-header-inner { padding: 0 16px; }
    .ek-nav { display: none; }
    .ek-nav.open {
        display: flex;
        flex-direction: column;
        position: absolute;
        top: 72px; left: 0; right: 0;
        background: var(--color-primary);
        padding: 20px 24px;
        gap: 16px;
        box-shadow: var(--shadow-lg);
    }
    .ek-mobile-toggle { display: flex; }

    .ek-hero { min-height: auto; }
    .ek-hero-inner { padding: 60px 16px; }
    .ek-hero-actions { flex-direction: column; }
    .btn-primary, .btn-secondary { justify-content: center; }

    .ek-section { padding: 60px 0; }
    .ek-grid-3 { grid-template-columns: 1fr; }
    .ek-grid-4 { grid-template-columns: 1fr; }
    .ek-two-col { grid-template-columns: 1fr; gap: 32px; }
    .ek-steps-grid { grid-template-columns: 1fr; }
    .ek-cta-inner { grid-template-columns: 1fr; gap: 32px; }
    .ek-footer-grid { grid-template-columns: 1fr; }
    .ek-stats-inner { gap: 24px; }
    .ek-stat-divider { display: none; }
    .ek-footer-bottom { flex-direction: column; text-align: center; }

    .ek-steps::before { left: 20px; }
    .ek-step-num { width: 40px; height: 40px; min-width: 40px; font-size: 1rem; }

    .ek-container { padding: 0 16px; }
}

@media (max-width: 480px) {
    .ek-grid-3 { gap: 16px; }
    .ek-section-header { margin-bottom: 36px; }
    .ek-cta-inner { gap: 24px; }
}

/* ---------- ELEMENTOR COMPATIBILITY ---------- */
.elementor-page .ek-header,
.elementor-page .ek-footer { display: block; }

/* Smooth scroll */
html { scroll-behavior: smooth; }

/* Focus styles */
a:focus-visible,
button:focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 3px;
}
 /* ===== hotfix: layout + logo palette ===== */ :root{--color-primary:#173f77;--color-secondary:#102f5d;--color-accent:#23b7cf;--color-accent2:#1695ab;--color-gold:#f0b22f;} html,body{overflow-x:hidden;} body.home .site-content .ast-container{display:block!important;max-width:100%!important;padding:0!important;} body.home .site-content #primary,body.home .site-content #secondary,body.home .ast-container .site-main{width:100%!important;margin:0!important;padding:0!important;} body.home .entry-content,body.home .entry-content>*{margin:0!important;} .ek-page{width:100%;background:linear-gradient(180deg,#f6fcff 0%,#fff 220px);}  .ek-header{background:var(--color-primary);} .ek-logo{display:flex;align-items:center;gap:12px;} .ek-logo-name{font-size:1.08rem;color:#fff;} .ek-logo-tagline{color:var(--color-gold);} .ek-nav a:hover{border-bottom-color:var(--color-accent);}  .ek-header-cta{background:var(--color-gold);} .ek-header-cta:hover{background:#d79c1d;box-shadow:0 4px 12px rgba(240,178,47,.45);}  .ek-hero{background:linear-gradient(135deg,#173f77 0%,#123566 55%,#0d2a54 100%);} .ek-hero h1 span,.ek-section-label,.btn-primary,.ek-tag-dot{color:var(--color-accent);}  .btn-primary{background:var(--color-accent);border-color:var(--color-accent);} .btn-primary:hover{background:var(--color-accent2);border-color:var(--color-accent2);}  .ek-hero-badge{background:rgba(240,178,47,.14);border:1px solid rgba(240,178,47,.35);color:var(--color-gold);}  .ek-card-icon{background:rgba(35,183,207,.14);color:var(--color-accent);}  .ek-check-list li::before,.ek-step-num,.ek-trust-icon{background:var(--color-gold);}  .ek-steps::before{background:linear-gradient(to bottom,var(--color-accent),rgba(35,183,207,.1));} .ek-stats{background:linear-gradient(90deg,#1aaec5 0%,#23b7cf 50%,#28c3da 100%);}  .ek-contact-icon{background:rgba(35,183,207,.2);}  @media (max-width:768px){.ek-logo-name{font-size:.92rem}.ek-logo-tagline{font-size:.56rem;letter-spacing:.06em}}  /* ===== logo badge style ===== */ .ek-logo::before{content:"";width:44px;height:44px;border-radius:50%;border:3px solid var(--color-gold);background:radial-gradient(circle at 30% 30%,#2ec8df 0%,#23b7cf 55%,#1695ab 100%);box-shadow:inset 0 0 0 2px rgba(255,255,255,.55);}  @media (max-width:768px){.ek-logo::before{width:36px;height:36px;border-width:2px;}}  /* ===== hide Astra default header/footer on homepage ===== */ body.home #masthead, body.home #ast-desktop-header, body.home #ast-mobile-header { display: none !important; } body.home .site-content { padding: 0 !important; margin: 0 !important; } body.home #content { padding: 0 !important; } body.home .ast-container { padding: 0 !important; max-width: 100% !important; } body.home .ek-page { margin-top: 0 !important; } body.home #site-footer, body.home .site-footer { display: none !important; } 
/* ===== LOGO IMAGE LAYOUT ===== */
.ek-logo { display:flex; align-items:center; gap:10px; text-decoration:none; }
.ek-logo::before { display:none !important; }
.ek-logo-img { width:60px; height:58px; object-fit:contain; border-radius:50%; flex-shrink:0; }
.ek-logo .ek-logo-name { display:block; font-size:1.15rem; font-weight:700; color:#fff; line-height:1.2; }
.ek-logo .ek-logo-tagline { display:block; font-size:0.7rem; color:var(--color-gold,#f0b22f); letter-spacing:0.08em; text-transform:uppercase; }

/* ===== LOGO TEXT COLUMN LAYOUT ===== */
.ek-logo-text { display:flex; flex-direction:column; justify-content:center; }
.ek-logo-text .ek-logo-name { display:block; }
.ek-logo-text .ek-logo-tagline { display:block; }

/* ===== RESPONSIVE HEADER: fluid logo + compact CTA ===== */
/* clamp() auto-scales font; nowrap prevents line-break */
.ek-logo .ek-logo-name    { font-size: clamp(0.72rem, 1.4vw, 1.15rem); white-space: nowrap; }
.ek-logo .ek-logo-tagline { font-size: clamp(0.42rem, 0.82vw, 0.7rem); white-space: nowrap; letter-spacing: clamp(0.03em, 0.07vw, 0.08em); }

@media (max-width: 1100px) {
    .ek-nav { gap: 20px; }
    .ek-nav a { font-size: 0.83rem; }
    .ek-logo { gap: 8px; }
    .ek-logo-img { width: 48px; height: 46px; }
    .ek-header-cta { font-size: 0.8rem !important; padding: 8px 14px !important; white-space: nowrap; }
}
@media (max-width: 900px) {
    .ek-nav { gap: 14px; }
    .ek-nav a { font-size: 0.76rem; }
    .ek-logo { gap: 6px; }
    .ek-logo-img { width: 42px; height: 40px; }
    .ek-header-cta { font-size: 0.74rem !important; padding: 7px 10px !important; }
}
@media (max-width: 768px) {
    .ek-logo-img { width: 40px; height: 38px; }
    .ek-header-cta { font-size: 0.8rem !important; padding: 8px 14px !important; white-space: nowrap; }
}

/* ===== MOBILE: hide header CTA to prevent tagline overlap ===== */
@media (max-width: 768px) {
    .ek-header-cta { display: none !important; }
}

/* ===== HERO TWO-COLUMN GRID with contact card ===== */
.ek-hero-grid { display: grid; grid-template-columns: 1fr 400px; gap: 48px; align-items: center; padding: 80px 48px; max-width: 1200px; margin: 0 auto; }
.ek-hero-contact .ek-contact-box { background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.15); border-radius: 12px; padding: 28px 24px; }
.ek-hero-contact .ek-contact-box h3 { font-size: 0.72rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.4); margin: 0 0 20px; }
.ek-hero-contact .ek-contact-item { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 16px; color: rgba(255,255,255,0.85); font-size: 0.92rem; }
.ek-hero-contact .ek-contact-item:last-child { margin-bottom: 0; }
.ek-hero-contact .ek-contact-item a { color: rgba(255,255,255,0.9); text-decoration: none; }
.ek-hero-contact .ek-contact-item a:hover { color: var(--color-accent,#23b7cf); }
.ek-hero-contact .ek-contact-icon { width: 36px; height: 36px; background: rgba(35,183,207,0.18); border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 1rem; flex-shrink: 0; }
/* on mobile, hide hero contact card (already shown in CTA below) */
@media (max-width: 768px) { .ek-hero-grid { grid-template-columns: 1fr; padding: 48px 20px; } .ek-hero-contact { display: none; } }

/* ===== MODALS ===== */
.ek-modal{display:none;position:fixed;inset:0;z-index:9999;align-items:center;justify-content:center;}
.ek-modal.is-open{display:flex;}
.ek-modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.6);backdrop-filter:blur(3px);}
.ek-modal-box{position:relative;background:#fff;border-radius:12px;padding:40px;width:90%;max-width:680px;max-height:90vh;overflow-y:auto;z-index:1;box-shadow:0 20px 60px rgba(0,0,0,0.3);}
.ek-modal-box--wide{max-width:1100px;}
.ek-modal-x{position:absolute;top:16px;right:20px;background:none;border:none;font-size:1.8rem;cursor:pointer;color:#666;line-height:1;padding:0;}
.ek-modal-x:hover{color:#000;}
.ek-modal h2{font-size:1.6rem;font-weight:800;color:#173f77;margin:0 0 8px;}
.ek-modal-sub{color:#666;margin:0 0 24px;font-size:0.95rem;}
.ek-modal-columns{display:grid;grid-template-columns:1fr 300px;gap:32px;}
@media(max-width:900px){.ek-modal-columns{grid-template-columns:1fr;}}
.ek-form-head{font-size:1.1rem;font-weight:700;color:#173f77;margin:0 0 4px;}
.ek-form-note{font-size:0.82rem;color:#c0392b;margin:0 0 20px;}
.ek-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media(max-width:600px){.ek-form-row{grid-template-columns:1fr;}}
.ek-form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:16px;}
.ek-form-group label{font-size:0.88rem;font-weight:600;color:#333;}
.ek-form-group input,.ek-form-group select,.ek-form-group textarea{border:1.5px solid #ddd;border-radius:6px;padding:9px 12px;font-size:0.92rem;width:100%;box-sizing:border-box;transition:border-color 0.2s;}
.ek-form-group input:focus,.ek-form-group select:focus,.ek-form-group textarea:focus{outline:none;border-color:#23b7cf;}
.ek-form-fieldset{border:none;padding:0;margin:0 0 8px;}
.ek-form-fieldset legend{font-size:0.82rem;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:0.08em;padding:12px 0 8px;display:block;width:100%;border-top:1px solid #eee;margin-bottom:4px;}
.ek-form-check{flex-direction:row;align-items:flex-start;gap:10px;}
.ek-form-check label{font-size:0.85rem;color:#555;font-weight:400;}
.ek-form-check a{color:#c0392b;}
.ek-form-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px;}
.ek-modal-sidebar{display:flex;flex-direction:column;gap:16px;}
.ek-sidebar-card{background:#f8f9fa;border-radius:8px;padding:16px;font-size:0.88rem;}
.ek-sidebar-card h4{font-size:0.92rem;font-weight:700;color:#173f77;margin:0 0 10px;}
.ek-sidebar-card p{color:#555;margin:0 0 6px;line-height:1.5;}
.ek-sidebar-card a{text-decoration:none;font-weight:600;}
.ek-sidebar-steps{padding-left:0;list-style:none;margin:0;}
.ek-sidebar-steps li{padding:8px 0 8px 20px;border-left:2px solid #c0392b;margin-bottom:8px;color:#555;font-size:0.88rem;line-height:1.4;}
.ek-hero-contact-actions{display:flex;flex-direction:column;gap:10px;margin-top:20px;}
.ek-hero-contact-actions .btn-primary,.ek-hero-contact-actions .btn-secondary{width:100%;text-align:center;justify-content:center;display:block;}


/* ===== MODALS ===== */
.ek-modal{display:none;position:fixed;inset:0;z-index:9999;align-items:center;justify-content:center;}
.ek-modal.is-open{display:flex;}
.ek-modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.6);backdrop-filter:blur(3px);}
.ek-modal-box{position:relative;background:#fff;border-radius:12px;padding:40px;width:90%;max-width:680px;max-height:90vh;overflow-y:auto;z-index:1;box-shadow:0 20px 60px rgba(0,0,0,0.3);}
.ek-modal-box--wide{max-width:1100px;}
.ek-modal-x{position:absolute;top:16px;right:20px;background:none;border:none;font-size:1.8rem;cursor:pointer;color:#666;line-height:1;}
.ek-modal-x:hover{color:#000;}
.ek-modal h2{font-size:1.6rem;font-weight:800;color:#173f77;margin:0 0 8px;}
.ek-modal-sub{color:#666;margin:0 0 24px;font-size:0.95rem;}
.ek-modal-columns{display:grid;grid-template-columns:1fr 300px;gap:32px;}
@media(max-width:900px){.ek-modal-columns{grid-template-columns:1fr;}}
.ek-hero-contact-actions{display:flex;flex-direction:column;gap:10px;margin-top:20px;}

@media (max-width: 768px) { .ek-hero-grid { grid-template-columns: 1fr; padding: 48px 20px; } .ek-hero-contact { display: block; margin-top: 24px; } .ek-hero-contact .ek-contact-box { margin-bottom: 0; } .ek-hero-contact-actions { margin-top: 16px; } }
 /* force header cta blue */
.ek-header-cta{background:var(--color-accent)!important;border:2px solid var(--color-accent)!important;}
.ek-header-cta:hover{background:var(--color-accent2)!important;border-color:var(--color-accent2)!important;box-shadow:0 4px 12px rgba(35,183,207,.45)!important;}
 /* CTA center align */ .ek-cta-inner{grid-template-columns:1fr;justify-items:center;} .ek-cta-left{max-width:920px;text-align:center;} .ek-cta .ek-trust-note{text-align:center;}  /* process section layout fix: move steps under intro and remove extra ctas */ #prozess .ek-steps-grid{grid-template-columns:1fr !important;gap:28px !important;} #prozess .ek-steps-intro > a.btn-primary{display:none !important;} #prozess .ek-hero-contact-actions{display:none !important;} #prozess .ek-steps{max-width:760px;}  /* process section: place CTA into previous right (yellow) area */ #prozess .ek-steps-grid{grid-template-columns:minmax(0,1.15fr) minmax(320px,1fr) !important;gap:36px !important;align-items:start;} #prozess .ek-steps-intro > a.btn-primary{display:none !important;} #prozess .ek-steps{grid-column:1;max-width:none !important;} #prozess .ek-process-cta{grid-column:2;background:var(--color-primary);border-radius:16px;padding:34px 28px;color:#fff;box-shadow:0 12px 28px rgba(23,63,119,.22);}  #prozess .ek-process-cta h2{color:#fff;margin:10px 0 14px;font-size:clamp(1.7rem,2.6vw,2.5rem);line-height:1.2;} #prozess .ek-process-cta p{color:rgba(255,255,255,.88);line-height:1.8;} #prozess .ek-process-cta .ek-process-cta-actions{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;margin-top:18px;} #prozess .ek-process-cta .btn-primary{min-width:240px;justify-content:center;} #prozess .ek-process-cta .ek-trust-note{text-align:center;margin-top:14px;color:rgba(255,255,255,.78);}  @media (max-width: 980px){#prozess .ek-steps-grid{grid-template-columns:1fr !important;}#prozess .ek-process-cta{grid-column:1;margin-top:4px;}} 