/*
 * ==========================================
 * PREMIUM COLOR SYSTEM
 * Modern Color Palette for JB-Dienstleistungen
 * ==========================================
 */

:root {
    /* ========== PRIMARY COLORS ========== */
    /* Main Brand Colors - Blue & Orange */
    --color-primary-blue: #0066CC;           /* Deep Professional Blue */
    --color-primary-orange: #FF6B35;         /* Vibrant Orange */
    
    /* ========== SECONDARY COLORS ========== */
    /* Supporting Brand Colors */
    --color-secondary-teal: #00D9C0;         /* Fresh Teal (Cleaning/Fresh) */
    --color-secondary-coral: #FF8C69;        /* Soft Coral */
    --color-secondary-purple: #7C3AED;       /* Modern Purple */
    --color-secondary-mint: #36D399;         /* Mint Green (Clean) */
    
    /* ========== ACCENT COLORS ========== */
    /* Highlight & Call-to-Action Colors */
    --color-accent-sky: #38BDF8;             /* Sky Blue */
    --color-accent-amber: #FBBF24;           /* Warm Amber */
    --color-accent-rose: #FB7185;            /* Soft Rose */
    --color-accent-lime: #84CC16;            /* Fresh Lime */
    
    /* ========== NEUTRAL COLORS ========== */
    /* Background & Text Colors */
    --color-neutral-white: #FFFFFF;
    --color-neutral-lightest: #F8FAFC;       /* Off White */
    --color-neutral-light: #F1F5F9;          /* Light Gray */
    --color-neutral-medium: #CBD5E1;         /* Medium Gray */
    --color-neutral-dark: #475569;           /* Dark Gray */
    --color-neutral-darkest: #1E293B;        /* Almost Black */
    --color-neutral-black: #0F172A;          /* True Black */
    
    /* ========== GRADIENT COLORS ========== */
    /* Modern Gradient Combinations */
    --gradient-primary: linear-gradient(135deg, #0066CC 0%, #00D9C0 100%);
    --gradient-secondary: linear-gradient(135deg, #FF6B35 0%, #FBBF24 100%);
    --gradient-hero: linear-gradient(135deg, #0066CC 0%, #7C3AED 50%, #FF6B35 100%);
    --gradient-card: linear-gradient(135deg, #38BDF8 0%, #00D9C0 100%);
    --gradient-sunset: linear-gradient(135deg, #FF6B35 0%, #FB7185 50%, #7C3AED 100%);
    --gradient-ocean: linear-gradient(135deg, #0066CC 0%, #00D9C0 50%, #36D399 100%);
    --gradient-warm: linear-gradient(135deg, #FF8C69 0%, #FBBF24 100%);
    --gradient-cool: linear-gradient(135deg, #38BDF8 0%, #7C3AED 100%);
    
    /* ========== SUCCESS/ERROR COLORS ========== */
    --color-success: #10B981;                /* Success Green */
    --color-success-light: #D1FAE5;
    --color-error: #EF4444;                  /* Error Red */
    --color-error-light: #FEE2E2;
    --color-warning: #F59E0B;                /* Warning Yellow */
    --color-warning-light: #FEF3C7;
    --color-info: #3B82F6;                   /* Info Blue */
    --color-info-light: #DBEAFE;
    
    /* ========== SHADOW COLORS ========== */
    --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
    --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
    --shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
    --shadow-blue: 0 10px 40px rgba(0, 102, 204, 0.3);
    --shadow-orange: 0 10px 40px rgba(255, 107, 53, 0.3);
    --shadow-teal: 0 10px 40px rgba(0, 217, 192, 0.3);
    --shadow-purple: 0 10px 40px rgba(124, 58, 237, 0.3);
    
    /* ========== OVERLAY COLORS ========== */
    --overlay-dark: rgba(15, 23, 42, 0.8);
    --overlay-light: rgba(248, 250, 252, 0.95);
    --overlay-blue: rgba(0, 102, 204, 0.9);
    --overlay-orange: rgba(255, 107, 53, 0.9);
    --overlay-gradient: linear-gradient(135deg, rgba(0, 102, 204, 0.9) 0%, rgba(255, 107, 53, 0.9) 100%);
}

/* ==========================================
   BODY & BACKGROUND STYLES
   ========================================== */

body {
    background-color: var(--color-neutral-lightest);
    color: var(--color-neutral-darkest);
}

/* ==========================================
   TEXT COLORS
   ========================================== */

.text-primary-blue { color: var(--color-primary-blue) !important; }
.text-primary-orange { color: var(--color-primary-orange) !important; }
.text-teal { color: var(--color-secondary-teal) !important; }
.text-purple { color: var(--color-secondary-purple) !important; }
.text-mint { color: var(--color-secondary-mint) !important; }
.text-sky { color: var(--color-accent-sky) !important; }

/* Gradient Text Effects */
.text-gradient-primary {
    background: var(--gradient-primary);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.text-gradient-sunset {
    background: var(--gradient-sunset);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.text-gradient-ocean {
    background: var(--gradient-ocean);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* ==========================================
   BACKGROUND COLORS
   ========================================== */

.bg-primary-blue { background-color: var(--color-primary-blue) !important; }
.bg-primary-orange { background-color: var(--color-primary-orange) !important; }
.bg-teal { background-color: var(--color-secondary-teal) !important; }
.bg-purple { background-color: var(--color-secondary-purple) !important; }
.bg-mint { background-color: var(--color-secondary-mint) !important; }

/* Gradient Backgrounds */
.bg-gradient-primary { background: var(--gradient-primary) !important; }
.bg-gradient-hero { background: var(--gradient-hero) !important; }
.bg-gradient-card { background: var(--gradient-card) !important; }
.bg-gradient-sunset { background: var(--gradient-sunset) !important; }
.bg-gradient-ocean { background: var(--gradient-ocean) !important; }
.bg-gradient-warm { background: var(--gradient-warm) !important; }
.bg-gradient-cool { background: var(--gradient-cool) !important; }

/* ==========================================
   BUTTON STYLES WITH NEW COLORS
   ========================================== */

/* Primary Button - Blue */
.btn-primary-blue,
.butn-primary-blue {
    background: var(--gradient-primary) !important;
    color: var(--color-neutral-white) !important;
    box-shadow: var(--shadow-blue);
    border: none;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.btn-primary-blue:hover,
.butn-primary-blue:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-2xl), var(--shadow-blue);
}

/* Primary Button - Orange */
.btn-primary-orange,
.butn-primary-orange {
    background: var(--gradient-secondary) !important;
    color: var(--color-neutral-white) !important;
    box-shadow: var(--shadow-orange);
    border: none;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.btn-primary-orange:hover,
.butn-primary-orange:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-2xl), var(--shadow-orange);
}

/* Teal Button */
.btn-teal {
    background: linear-gradient(135deg, var(--color-secondary-teal) 0%, var(--color-accent-sky) 100%) !important;
    color: var(--color-neutral-white) !important;
    box-shadow: var(--shadow-teal);
    border: none;
}

.btn-teal:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-2xl), var(--shadow-teal);
}

/* Purple Button */
.btn-purple {
    background: linear-gradient(135deg, var(--color-secondary-purple) 0%, #A78BFA 100%) !important;
    color: var(--color-neutral-white) !important;
    box-shadow: var(--shadow-purple);
    border: none;
}

.btn-purple:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-2xl), var(--shadow-purple);
}

/* ==========================================
   CARD STYLES WITH NEW COLORS
   ========================================== */

.card-modern {
    background: var(--color-neutral-white);
    border-radius: 20px;
    padding: 30px;
    box-shadow: var(--shadow-lg);
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    border-top: 4px solid transparent;
}

.card-modern.card-blue {
    border-top-color: var(--color-primary-blue);
}

.card-modern.card-blue:hover {
    box-shadow: var(--shadow-2xl), var(--shadow-blue);
    transform: translateY(-10px);
}

.card-modern.card-orange {
    border-top-color: var(--color-primary-orange);
}

.card-modern.card-orange:hover {
    box-shadow: var(--shadow-2xl), var(--shadow-orange);
    transform: translateY(-10px);
}

.card-modern.card-teal {
    border-top-color: var(--color-secondary-teal);
}

.card-modern.card-teal:hover {
    box-shadow: var(--shadow-2xl), var(--shadow-teal);
    transform: translateY(-10px);
}

.card-modern.card-purple {
    border-top-color: var(--color-secondary-purple);
}

.card-modern.card-purple:hover {
    box-shadow: var(--shadow-2xl), var(--shadow-purple);
    transform: translateY(-10px);
}

/* Glass Card Variants */
.card-glass-blue {
    background: linear-gradient(135deg, rgba(0, 102, 204, 0.1) 0%, rgba(56, 189, 248, 0.1) 100%);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(0, 102, 204, 0.2);
    box-shadow: var(--shadow-xl);
}

.card-glass-orange {
    background: linear-gradient(135deg, rgba(255, 107, 53, 0.1) 0%, rgba(251, 191, 36, 0.1) 100%);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(255, 107, 53, 0.2);
    box-shadow: var(--shadow-xl);
}

.card-glass-teal {
    background: linear-gradient(135deg, rgba(0, 217, 192, 0.1) 0%, rgba(54, 211, 153, 0.1) 100%);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(0, 217, 192, 0.2);
    box-shadow: var(--shadow-xl);
}

/* ==========================================
   BADGE & TAG STYLES
   ========================================== */

.badge-blue {
    background: linear-gradient(135deg, var(--color-primary-blue) 0%, var(--color-accent-sky) 100%);
    color: var(--color-neutral-white);
    padding: 6px 16px;
    border-radius: 20px;
    font-size: 0.875rem;
    font-weight: 600;
    display: inline-block;
    box-shadow: var(--shadow-md);
}

.badge-orange {
    background: linear-gradient(135deg, var(--color-primary-orange) 0%, var(--color-accent-amber) 100%);
    color: var(--color-neutral-white);
    padding: 6px 16px;
    border-radius: 20px;
    font-size: 0.875rem;
    font-weight: 600;
    display: inline-block;
    box-shadow: var(--shadow-md);
}

.badge-teal {
    background: linear-gradient(135deg, var(--color-secondary-teal) 0%, var(--color-secondary-mint) 100%);
    color: var(--color-neutral-white);
    padding: 6px 16px;
    border-radius: 20px;
    font-size: 0.875rem;
    font-weight: 600;
    display: inline-block;
    box-shadow: var(--shadow-md);
}

.badge-purple {
    background: linear-gradient(135deg, var(--color-secondary-purple) 0%, #A78BFA 100%);
    color: var(--color-neutral-white);
    padding: 6px 16px;
    border-radius: 20px;
    font-size: 0.875rem;
    font-weight: 600;
    display: inline-block;
    box-shadow: var(--shadow-md);
}

/* ==========================================
   ICON STYLES WITH COLORS
   ========================================== */

.icon-box {
    width: 70px;
    height: 70px;
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.icon-box-blue {
    background: var(--gradient-primary);
    color: var(--color-neutral-white);
    box-shadow: var(--shadow-blue);
}

.icon-box-blue:hover {
    transform: scale(1.1) rotate(5deg);
    box-shadow: var(--shadow-xl), var(--shadow-blue);
}

.icon-box-orange {
    background: var(--gradient-secondary);
    color: var(--color-neutral-white);
    box-shadow: var(--shadow-orange);
}

.icon-box-orange:hover {
    transform: scale(1.1) rotate(-5deg);
    box-shadow: var(--shadow-xl), var(--shadow-orange);
}

.icon-box-teal {
    background: linear-gradient(135deg, var(--color-secondary-teal) 0%, var(--color-secondary-mint) 100%);
    color: var(--color-neutral-white);
    box-shadow: var(--shadow-teal);
}

.icon-box-teal:hover {
    transform: scale(1.1) rotate(5deg);
    box-shadow: var(--shadow-xl), var(--shadow-teal);
}

.icon-box-purple {
    background: linear-gradient(135deg, var(--color-secondary-purple) 0%, #A78BFA 100%);
    color: var(--color-neutral-white);
    box-shadow: var(--shadow-purple);
}

.icon-box-purple:hover {
    transform: scale(1.1) rotate(-5deg);
    box-shadow: var(--shadow-xl), var(--shadow-purple);
}

/* ==========================================
   SECTION BACKGROUNDS
   ========================================== */

.section-light {
    background: linear-gradient(180deg, var(--color-neutral-lightest) 0%, var(--color-neutral-white) 50%, var(--color-neutral-lightest) 100%);
}

.section-blue-gradient {
    background: var(--gradient-primary);
    color: var(--color-neutral-white);
}

.section-hero-gradient {
    background: var(--gradient-hero);
    color: var(--color-neutral-white);
    position: relative;
    overflow: hidden;
}

.section-ocean-gradient {
    background: var(--gradient-ocean);
    color: var(--color-neutral-white);
}

.section-sunset-gradient {
    background: var(--gradient-sunset);
    color: var(--color-neutral-white);
}

/* ==========================================
   ALERT/NOTIFICATION STYLES
   ========================================== */

.alert-success {
    background: linear-gradient(135deg, var(--color-success-light) 0%, #ECFDF5 100%);
    border-left: 4px solid var(--color-success);
    color: #065F46;
    padding: 16px 20px;
    border-radius: 12px;
    box-shadow: var(--shadow-md);
}

.alert-error {
    background: linear-gradient(135deg, var(--color-error-light) 0%, #FEF2F2 100%);
    border-left: 4px solid var(--color-error);
    color: #991B1B;
    padding: 16px 20px;
    border-radius: 12px;
    box-shadow: var(--shadow-md);
}

.alert-warning {
    background: linear-gradient(135deg, var(--color-warning-light) 0%, #FFFBEB 100%);
    border-left: 4px solid var(--color-warning);
    color: #92400E;
    padding: 16px 20px;
    border-radius: 12px;
    box-shadow: var(--shadow-md);
}

.alert-info {
    background: linear-gradient(135deg, var(--color-info-light) 0%, #EFF6FF 100%);
    border-left: 4px solid var(--color-info);
    color: #1E40AF;
    padding: 16px 20px;
    border-radius: 12px;
    box-shadow: var(--shadow-md);
}

/* ==========================================
   FORM ELEMENTS WITH COLORS
   ========================================== */

.form-control:focus {
    border-color: var(--color-primary-blue) !important;
    box-shadow: 0 0 0 4px rgba(0, 102, 204, 0.1) !important;
}

.form-control.focus-orange:focus {
    border-color: var(--color-primary-orange) !important;
    box-shadow: 0 0 0 4px rgba(255, 107, 53, 0.1) !important;
}

.form-control.focus-teal:focus {
    border-color: var(--color-secondary-teal) !important;
    box-shadow: 0 0 0 4px rgba(0, 217, 192, 0.1) !important;
}

/* ==========================================
   BORDER COLORS
   ========================================== */

.border-blue { border-color: var(--color-primary-blue) !important; }
.border-orange { border-color: var(--color-primary-orange) !important; }
.border-teal { border-color: var(--color-secondary-teal) !important; }
.border-purple { border-color: var(--color-secondary-purple) !important; }

.border-top-blue { border-top: 4px solid var(--color-primary-blue) !important; }
.border-top-orange { border-top: 4px solid var(--color-primary-orange) !important; }
.border-top-teal { border-top: 4px solid var(--color-secondary-teal) !important; }
.border-top-purple { border-top: 4px solid var(--color-secondary-purple) !important; }

/* ==========================================
   LINK COLORS
   ========================================== */

a {
    color: var(--color-primary-blue);
    transition: all 0.3s ease;
}

a:hover {
    color: var(--color-primary-orange);
    text-decoration: none;
}

a.link-orange {
    color: var(--color-primary-orange);
}

a.link-orange:hover {
    color: var(--color-primary-blue);
}

a.link-teal {
    color: var(--color-secondary-teal);
}

a.link-teal:hover {
    color: var(--color-secondary-mint);
}

/* ==========================================
   PRICING TABLES
   ========================================== */

.pricing-card {
    background: var(--color-neutral-white);
    border-radius: 20px;
    padding: 40px;
    box-shadow: var(--shadow-lg);
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    border-top: 5px solid transparent;
}

.pricing-card.pricing-blue {
    border-top-color: var(--color-primary-blue);
}

.pricing-card.pricing-blue:hover {
    transform: translateY(-10px) scale(1.02);
    box-shadow: var(--shadow-2xl), var(--shadow-blue);
}

.pricing-card.pricing-orange {
    border-top-color: var(--color-primary-orange);
}

.pricing-card.pricing-orange:hover {
    transform: translateY(-10px) scale(1.02);
    box-shadow: var(--shadow-2xl), var(--shadow-orange);
}

.pricing-card.pricing-featured {
    background: var(--gradient-hero);
    color: var(--color-neutral-white);
    transform: scale(1.05);
    border-top-color: transparent;
}

.pricing-card.pricing-featured:hover {
    transform: scale(1.08) translateY(-10px);
}

/* ==========================================
   TIMELINE STYLES
   ========================================== */

.timeline-marker {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    position: absolute;
    left: 0;
    top: 0;
}

.timeline-marker-blue {
    background: var(--gradient-primary);
    box-shadow: 0 0 0 4px var(--color-neutral-white), 0 0 0 6px var(--color-primary-blue);
}

.timeline-marker-orange {
    background: var(--gradient-secondary);
    box-shadow: 0 0 0 4px var(--color-neutral-white), 0 0 0 6px var(--color-primary-orange);
}

.timeline-marker-teal {
    background: linear-gradient(135deg, var(--color-secondary-teal) 0%, var(--color-secondary-mint) 100%);
    box-shadow: 0 0 0 4px var(--color-neutral-white), 0 0 0 6px var(--color-secondary-teal);
}

/* ==========================================
   DECORATIVE ELEMENTS
   ========================================== */

.divider-gradient {
    height: 4px;
    background: var(--gradient-hero);
    border-radius: 2px;
    margin: 40px 0;
}

.dot-pattern {
    background-image: radial-gradient(circle, var(--color-primary-blue) 1px, transparent 1px);
    background-size: 20px 20px;
    opacity: 0.1;
}

/* ==========================================
   RESPONSIVE COLOR ADJUSTMENTS
   ========================================== */

@media (max-width: 768px) {
    .icon-box {
        width: 60px;
        height: 60px;
    }
    
    .badge-blue,
    .badge-orange,
    .badge-teal,
    .badge-purple {
        padding: 5px 12px;
        font-size: 0.75rem;
    }
}

/* ==========================================
   PRINT STYLES
   ========================================== */

@media print {
    .bg-gradient-primary,
    .bg-gradient-hero,
    .bg-gradient-sunset,
    .bg-gradient-ocean {
        background: var(--color-neutral-white) !important;
        color: var(--color-neutral-black) !important;
    }
}
