/*
Theme Name: AlMoTeS Service Theme
Theme URI: https://almotes.de
Author: Jens Bramsche
Author URI: https://almotes.de
Description: Leichtes, Bootstrap-basiertes WordPress-Theme für den Dienstleister AlMoTeS (Alltag, Mobilität & Technik Service). Optimiert für Elementor. Logo links oben, Größe per Customizer-Schieberegler, flexible Farbpalette, Typografie, MegaHeader & Social Icons.
Version: 1.13.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: almotes
Tags: bootstrap, clean, responsive, one-column, two-columns, custom-logo, elementor
*/

/* Default-Farbwerte & Schriften (werden durch Customizer überschrieben) */
:root {
    --almotes-body-bg: #f5f7f8;
    --almotes-main-container-bg: #ffffff;
    --almotes-surface-bg: #ffffff;
    --almotes-content-bg: #ffffff;
    --almotes-text: #1f2933;
    --almotes-heading: #003b5c;
    --almotes-accent: #009a9c;
    --almotes-accent-hover: #007f81;
    --almotes-on-accent: #ffffff;
    --almotes-primary-bg: #003b5c;
    --almotes-primary-bg-light: #e3f3f4;
    --almotes-primary-bg-strong: #001f33;
    --almotes-primary-text: #003b5c;

    --almotes-body-font: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    --almotes-heading-font: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    --almotes-menu-font: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

/* Basis-Reset & Typografie */
body {
    font-family: var(--almotes-body-font);
    background-color: var(--almotes-body-bg);
    color: var(--almotes-text);
    line-height: 1.6;
}

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

a:hover,
a:focus {
    text-decoration: underline;
    color: var(--almotes-accent-hover);
}

/* MegaHeader-Container */
.almotes-mega-header {
    position: relative;
    z-index: 60;
}

.almotes-mega-header-fixed {
    position: sticky;
    top: 0;
    z-index: 70;
}

/* Header / Navbar */
.site-header {
    background-color: #ffffff;
    box-shadow: 0 2px 6px rgba(0,0,0,0.04);
    position: sticky;
    top: 0;
    z-index: 50;
}

.site-header-inner {
    padding-top: 0.5rem;
    padding-bottom: 0.25rem;
}

.site-header-inner .header-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

/* Logo / Branding */
.logo-wrapper {
    text-align: left;
}

.custom-logo {
    height: 80px; /* Startwert, wird per Customizer überschrieben */
    width: auto;
}

/* Social Icons im Header */
.header-actions {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.header-social {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.almotes-social-link {
    width: 32px;
    height: 32px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--almotes-primary-bg);
    color: var(--almotes-on-accent);
    text-decoration: none;
    transition: background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
    font-family: var(--almotes-menu-font);
}

.almotes-social-link:hover,
.almotes-social-link:focus {
    background: var(--almotes-accent);
    transform: translateY(-1px);
    box-shadow: 0 4px 10px rgba(0,0,0,0.12);
    color: var(--almotes-on-accent);
}

.almotes-social-letter {
    font-size: 0.85rem;
    font-weight: 700;
    text-transform: uppercase;
}


/* Header Call-to-Action Button */
.header-cta {
    padding: 0.45rem 1.25rem;
    border-radius: 999px;
    font-size: 0.85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    white-space: nowrap;
    box-shadow: 0 4px 12px rgba(0,0,0,0.18);
}

.header-cta:hover,
.header-cta:focus {
    text-decoration: none;
    box-shadow: 0 6px 18px rgba(0,0,0,0.24);
}
/* Unter dem Logo: Navigationsleiste */
.navbar-almotes {
    border-top: 1px solid rgba(0,0,0,0.03);
    border-bottom: 1px solid rgba(0,0,0,0.03);
    background: linear-gradient(90deg, #ffffff, var(--almotes-primary-bg-light));
}

.navbar-almotes .navbar-nav .nav-link {
    font-family: var(--almotes-menu-font);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--almotes-primary-text);
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
}

/* Navigation: Punkt vor den Links für Abstand */
.navbar-almotes .navbar-nav .nav-link::before {
    content: '•';
    display: inline-block;
    margin-right: 0.5rem;
    font-size: 0.65rem;
    vertical-align: middle;
    color: #000000;
}

.navbar-almotes .navbar-nav .nav-link:hover,
.navbar-almotes .navbar-nav .nav-link:focus,
.navbar-almotes .navbar-nav .nav-link.active {
    color: var(--almotes-accent);
}

/* Footer – wird per Customizer-Farben überschrieben, hier nur Fallback */
.site-footer {
    background: radial-gradient(circle at top left, rgba(0,154,156,0.08), transparent),
                radial-gradient(circle at bottom right, rgba(0,59,92,0.15), #0b1726);
    color: #ffffff;
    padding: 2.5rem 0;
    font-size: 0.9rem;
    font-family: var(--almotes-menu-font);
}

.site-footer a {
    color: #e9f5ff;
}

.site-footer a:hover {
    color: #ffffff;
    text-decoration: underline;
}

/* Standard-Seitenlayout */
.site-main {
    min-height: 60vh;
    background-color: var(--almotes-content-bg);
}

.site-main > .container {
    background-color: var(--almotes-main-container-bg);
}

.page-header {
    margin-bottom: 2rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid rgba(0,0,0,0.06);
}

.page-header h1,
.entry-title,
h1, h2, h3, h4, h5, h6 {
    font-family: var(--almotes-heading-font);
    font-weight: 700;
    color: var(--almotes-heading);
}

/* Buttons */
.btn,
.button {
    font-family: var(--almotes-menu-font);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.btn-primary {
    background: var(--almotes-accent);
    border-color: var(--almotes-accent);
    color: var(--almotes-on-accent);
}

.btn-primary:hover,
.btn-primary:focus {
    background: var(--almotes-accent-hover);
    border-color: var(--almotes-accent-hover);
}

/* Cards für Leistungsbereiche und allgemeine Karten */
.service-card,
.card {
    border-radius: 1rem;
    border: 1px solid rgba(13,110,253,0.12);
    box-shadow: 0 8px 20px rgba(15,23,42,0.08);
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
    background-color: var(--almotes-surface-bg);
}

.service-card:hover,
.card:hover {
    transform: translateY(-4px);
    box-shadow: 0 14px 30px rgba(15,23,42,0.12);
    border-color: rgba(0,59,92,0.35);
}

/* Elementor-Bereiche – das Theme hält sich bewusst zurück */
.elementor-section,
.elementor-widget {
    max-width: 100%;
}

/* Formular-Elemente */
input[type="text"],
input[type="email"],
input[type="tel"],
textarea {
    border-radius: 0.5rem;
    border-color: rgba(0,59,92,0.18);
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
textarea:focus {
    border-color: var(--almotes-accent);
    box-shadow: 0 0 0 0.15rem rgba(0,154,156,0.25);
}

/* Breadcrumb Platzhalter (optional über Plugin nutzbar) */
.breadcrumb-wrapper {
    font-size: 0.9rem;
    color: #6b7b8c;
    margin-bottom: 1.5rem;
}
