/* ============================================
   KATI BASE — Gemeinsame Grundlagen
   Geladen auf ALLEN Seiten
   Variables, GP Theme, Auth, Forms, Legal
   ============================================ */

@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600&family=DM+Sans:wght@300;400;500;600&display=swap");

/* ============================================
   KATI KITCHEN ASSISTANT - ZENTRALE STYLES v8.0
   Phase A: CSS-Bereinigung (Duplikate entfernt)
   Phase B: Landing Page Mobile/Tablet Responsive
   
   Alle Styles an EINEM Ort!
   Extrahiert aus: auth.php, dashboard.php, profile.php, 
                   planning.php, chat.php
   ============================================ */

/* ============================================
   VARIABLEN - Hier zentral anpassen!
   ============================================ */
:root {
    /* LAYOUT - Breite & Abstände */
    --kati-container-width: 95%;
    --kati-container-max: 1800px;
    --kati-container-padding: 30px;
    
    /* FARBEN */
    --kati-primary: #C9A571;
    --kati-primary-dark: #B8935A;
    --kati-secondary: #8B935A;
    --kati-text: #472804;
    --kati-text-light: #8B7355;
    --kati-background: #FDFBF7;
    --kati-background-alt: #FAF8F6;
    --kati-border: #E8E4DE;
    --kati-border-dark: #D9CFC4;
    
    /* GRADIENT */
    --kati-gradient: linear-gradient(135deg, #C9A571 0%, #8B935A 100%);
    
    /* SCHATTEN */
    --kati-shadow: 0 2px 15px rgba(139, 115, 85, 0.1);
    --kati-shadow-lg: 0 10px 40px rgba(71, 40, 4, 0.1);
    
    /* BORDER RADIUS */
    --kati-radius: 10px;
    --kati-radius-lg: 15px;
    --kati-radius-xl: 20px;
}

/* ============================================
   RESET & BASIS
   ============================================ */
.kati-auth-wrapper,
.kati-header,
.kati-tab-nav,
.kati-container,
.kati-wizard-container,
.kati-planning-container,
.kati-chat-container,
.kati-dashboard-container,
.kati-landing {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    color: var(--kati-text);
    line-height: 1.6;
    box-sizing: border-box;
}

*, *::before, *::after {
    box-sizing: inherit;
}

/* ============================================
   GENERATEPRESS THEME - VOLLSTÄNDIGE FIXES
   ============================================ */

/* HEADER - Breite passend zum Content (Gesamte Breite) */
.site-header .inside-header,
.inside-header.grid-container {
    max-width: 100% !important;
    width: 100% !important;
    margin: 0 auto !important;
    padding-left: 90px !important;
    padding-right: 110px !important;
}


/* Site-Title Styling (K.B. Kitchen Assistant Kati) */
.site-header .main-title,
.site-header .site-title,
.site-header .site-title a,
.site-branding .main-title a {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    color: #472804 !important;
    text-decoration: none !important;
    font-weight: 400 !important;
}
/* Nav-Links: Farbe, Grösse, Hover */
.main-navigation .menu > li > a,
.site-header .menu > li > a {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
    font-size: 18px !important;
    color: #472804 !important;
    text-decoration: none !important;
    font-weight: 400 !important;
}

.main-navigation .menu > li > a:hover,
.site-header .menu > li > a:hover {
    color: #C9A571 !important;
    text-decoration: none !important;
}

/* Titel ausblenden */
body.page h1.entry-title,
body.page .entry-header,
body.page header.entry-header {
    display: none !important;
}

/* Site-Content als Flex-Container für Zentrierung + GRAUER HINTERGRUND */
body.page .site-content {
    display: flex !important;
    justify-content: center !important;
    width: 100% !important;
    max-width: 100% !important;
    background: #F7F8F9 !important;
    padding: 20px 40px !important;  /* Passend zum Header */
}

/* Content-Area zentriert mit max-width */
body.page .content-area,
body.page #primary {
    max-width: 95% !important;
    width: 95% !important;
    margin: 0 auto !important;
    float: none !important;
}

/* 3. WEISSER CONTAINER mit Schatten und abgerundeten Ecken */
body.page .entry-content,
body.page article .entry-content,
body.page .inside-article {
    background: #FFFFFF !important;
    border-radius: 20px !important;
    box-shadow: 0 10px 40px rgba(71, 40, 4, 0.1) !important;
    padding: 40px !important;
    margin: 0 !important;
    max-width: 100% !important;
    width: 100% !important;
}

/* Sidebar komplett weg */
body.page .widget-area,
body.page #secondary,
body.page .sidebar,
body.page aside {
    display: none !important;
    width: 0 !important;
}

/* ============================================
   AUTH PAGES (Login, Registrierung)
   ============================================ */
.kati-auth-wrapper {
    min-height: 100vh !important;
    width: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 40px !important;
    background: #FDFBF7 !important;
}

.kati-auth-box {
    background: white;
    border-radius: var(--kati-radius-xl);
    padding: 50px;
    max-width: 480px;
    width: 100%;
    box-shadow: var(--kati-shadow-lg);
}

.kati-auth-logo {
    text-align: center;
    margin-bottom: 40px;
}

.kati-auth-logo img {
    max-width: 220px;
    height: auto;
}

.kati-auth-title {
    font-size: 28px;
    font-weight: 300;
    color: var(--kati-text);
    text-align: center;
    margin-bottom: 10px;
    letter-spacing: 1px;
}

.kati-auth-subtitle {
    font-size: 16px;
    color: var(--kati-text-light);
    text-align: center;
    margin-bottom: 30px;
}

/* ============================================
   FORMULARE (Auth + Alle Seiten)
   ============================================ */
.kati-form-group {
    margin-bottom: 25px;
}

.kati-form-label {
    display: block;
    font-weight: 500;
    color: var(--kati-text);
    margin-bottom: 10px;
    font-size: 15px;
}

.kati-form-input {
    width: 100%;
    padding: 14px 18px;
    border: 1px solid var(--kati-border);
    border-radius: 12px;
    font-size: 15px;
    color: var(--kati-text);
    background: white;
    transition: all 0.3s ease;
    font-family: inherit;
}

.kati-form-input:focus {
    outline: none;
    border-color: var(--kati-primary);
    box-shadow: 0 0 0 3px rgba(201, 165, 113, 0.1);
}

.kati-form-checkbox {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 25px;
}

.kati-form-checkbox input[type="checkbox"] {
    width: 18px;
    height: 18px;
    cursor: pointer;
    accent-color: var(--kati-primary);
}

.kati-form-checkbox label {
    cursor: pointer;
    font-size: 14px;
    color: var(--kati-text);
}
/* Terms Checkbox - Checkbox oben halten bei Textumbruch */
.kati-terms-checkbox {
    align-items: flex-start;
}

.kati-terms-checkbox input[type="checkbox"] {
    margin-top: 3px;
}

/* Password Toggle Container */
.kati-form-group.kati-password-field {
    position: relative;
}

.kati-form-group.kati-password-field .kati-form-input {
    padding-right: 45px;
}

.kati-password-toggle {
    position: absolute;
    right: 10px;
    top: 38px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 5px;
}

/* ============================================
   BUTTONS
   ============================================ */
.kati-btn-primary {
    background: var(--kati-gradient);
    color: white;
    border: none;
    padding: 14px 32px;
    border-radius: 12px;
    font-weight: 500;
    font-size: 16px;
    cursor: pointer;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    transition: all 0.3s ease;
    box-shadow: 0 4px 12px rgba(201, 165, 113, 0.2);
    font-family: inherit;
    text-decoration: none;
}

.kati-btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(201, 165, 113, 0.3);
}

/* ============================================
   LINKS
   ============================================ */
.kati-auth-link {
    text-align: center;
    margin-top: 20px;
    color: var(--kati-text-light);
    font-size: 14px;
}

.kati-auth-link a {
    color: var(--kati-primary);
    text-decoration: none;
    font-weight: 500;
}

.kati-auth-link a:hover {
    text-decoration: underline;
}

.kati-password-forgotten {
    text-align: center;
    margin-top: 20px;
    margin-bottom: 10px;
}

.kati-password-forgotten a {
    color: var(--kati-text-light);
    text-decoration: none;
    font-size: 14px;
}

.kati-password-forgotten a:hover {
    color: var(--kati-primary);
    text-decoration: underline;
}

/* ============================================
   MESSAGES (Success, Error)
   ============================================ */
.kati-error,
.kati-message-error {
    background: #FFE5E5;
    border: 1px solid #FF9999;
    border-radius: 8px;
    padding: 12px;
    margin-bottom: 20px;
    color: #990000;
    font-size: 14px;
}

.kati-success,
.kati-message-success,
.kati-success-message {
    background: var(--kati-gradient);
    color: white;
    padding: 15px 20px;
    border-radius: var(--kati-radius);
    margin-bottom: 20px;
    text-align: center;
    font-weight: 500;
}

/* Message Box (JS-gesteuert) */
#kati-message {
    padding: 15px;
    margin-bottom: 20px;
    border-radius: 5px;
}

/* ============================================
   KATI LEGAL PAGES (Impressum, Datenschutz)
   ============================================ */

/* Container */
.kati-legal-container {
    max-width: 800px;
    margin: 0 auto;
    padding: 20px 0;
}

/* Header */
.kati-legal-header {
    text-align: center;
    margin-bottom: 50px;
}

.kati-legal-icon {
    width: 70px;
    height: 70px;
    min-width: 70px;
    min-height: 70px;
    max-width: 70px;
    max-height: 70px;
    margin: 0 auto 25px;
    background: linear-gradient(135deg, rgba(201, 165, 113, 0.15) 0%, rgba(139, 147, 90, 0.15) 100%);
    border-radius: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.kati-legal-icon svg {
    width: 35px !important;
    height: 35px !important;
    max-width: 35px !important;
    max-height: 35px !important;
    stroke: var(--kati-primary);
}

.kati-legal-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 2.5rem;
    font-weight: 500;
    color: var(--kati-text);
    margin: 0 0 15px 0;
}

.kati-legal-subtitle {
    font-size: 1.1rem;
    color: var(--kati-text-light);
    margin: 0;
}

/* Content */
.kati-legal-content {
    display: flex;
    flex-direction: column;
    gap: 40px;
}

/* Sections */
.kati-legal-section {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.kati-legal-section-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.4rem;
    font-weight: 500;
    color: var(--kati-text);
    margin: 0 0 10px 0;
    padding-bottom: 10px;
    border-bottom: 2px solid var(--kati-border);
}

.kati-legal-card-icon {
    width: 50px;
    height: 50px;
    min-width: 50px;
    min-height: 50px;
    max-width: 50px;
    max-height: 50px;
    background: white;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 10px rgba(71, 40, 4, 0.06);
    overflow: hidden;
}

.kati-legal-card-icon svg {
    width: 24px !important;
    height: 24px !important;
    max-width: 24px !important;
    max-height: 24px !important;
    stroke: var(--kati-primary);
}

.kati-legal-card-icon {
    width: 50px;
    height: 50px;
    min-width: 50px;
    background: white;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 10px rgba(71, 40, 4, 0.06);
}

.kati-legal-card-icon svg {
    width: 24px;
    height: 24px;
    stroke: var(--kati-primary);
}

.kati-legal-card-content h3 {
    font-family: 'Inter', sans-serif;
    font-size: 1rem;
    font-weight: 600;
    color: var(--kati-text);
    margin: 0 0 8px 0;
}

.kati-legal-card-content p {
    font-size: 0.95rem;
    color: var(--kati-text-light);
    line-height: 1.7;
    margin: 0;
}

.kati-legal-card-content a {
    color: var(--kati-primary);
    text-decoration: none;
    transition: color 0.2s ease;
}

.kati-legal-card-content a:hover {
    color: var(--kati-primary-dark);
    text-decoration: underline;
}

/* Info Box */
.kati-legal-info-box {
    padding: 25px 30px;
    background: var(--kati-background);
    border-radius: 15px;
    border-left: 4px solid var(--kati-primary);
}

.kati-legal-info-box p {
    font-size: 0.95rem;
    color: var(--kati-text-light);
    line-height: 1.8;
    margin: 0 0 15px 0;
}

.kati-legal-info-box p:last-child {
    margin-bottom: 0;
}

.kati-legal-info-box a {
    color: var(--kati-primary);
    text-decoration: none;
    font-weight: 500;
}

.kati-legal-info-box a:hover {
    text-decoration: underline;
}

/* iubenda Placeholder */
.kati-iubenda-placeholder {
    text-align: center;
    padding: 40px 30px;
    border-left: none;
    background: linear-gradient(135deg, rgba(201, 165, 113, 0.08) 0%, rgba(139, 147, 90, 0.08) 100%);
}

/* Legal Page Footer */
.kati-legal-footer {
    margin-top: 50px;
    padding-top: 30px;
    border-top: 1px solid var(--kati-border);
    text-align: center;
}

.kati-legal-back-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 12px 25px;
    color: var(--kati-text-light);
    text-decoration: none;
    font-size: 0.95rem;
    font-weight: 500;
    border-radius: 30px;
    transition: all 0.3s ease;
}

.kati-legal-back-link:hover {
    color: var(--kati-primary);
    background: var(--kati-background);
}

.kati-legal-back-link svg {
    width: 18px;
    height: 18px;
}

/* Responsive Legal */
@media (max-width: 600px) {
    .kati-legal-container {
        padding: 10px 0;
    }
    
    .kati-legal-title {
        font-size: 2rem;
    }
    
    .kati-legal-card {
        flex-direction: column;
        align-items: center;
        text-align: center;
        padding: 20px;
    }
    
    .kati-legal-card-icon {
        margin-bottom: 5px;
    }
    
    .kati-legal-info-box {
        padding: 20px;
    }
}

/* Legal CTA Link Button */
.kati-legal-center-box {
    text-align: center;
    padding: 40px 30px;
}

.kati-legal-center-box p {
    margin-bottom: 20px;
}

.kati-legal-cta-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 14px 28px;
    background: linear-gradient(135deg, #C9A571 0%, #8B935A 100%);
    color: white !important;
    text-decoration: none !important;
    font-weight: 600;
    font-size: 1rem;
    border-radius: 30px;
    transition: all 0.3s ease;
}

.kati-legal-cta-link:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(201, 165, 113, 0.4);
}

.kati-legal-cta-link svg {
    width: 18px;
    height: 18px;
}

/* ============================================
   FOOTER LEGAL LINKS (in GeneratePress Credits)
   ============================================ */
.kati-footer-separator {
    margin: 0 8px;
    color: #8B7355;
}

.kati-footer-link {
    color: #8B7355 !important;
    text-decoration: none !important;
    transition: color 0.2s ease;
}

.kati-footer-link:hover {
    color: #C9A571 !important;
}

/* ============================================
   PHASE C, SCHRITT 8: AUTH-SEITEN MOBILE
   (Login, Registrierung, Logout)
   ============================================ */

@media (max-width: 1024px) {

    /* Auth Wrapper: weniger Padding */
    .kati-auth-wrapper {
        padding: 16px !important;
        align-items: flex-start !important;
        padding-top: 40px !important;
    }

    /* Auth Box: volle Breite nutzen */
    .kati-auth-box {
        max-width: 100% !important;
        padding: 30px 20px !important;
    }

    /* Logo kleiner */
    .kati-auth-logo {
        margin-bottom: 24px !important;
    }

    .kati-auth-logo img {
        max-width: 160px !important;
    }

    /* Titel kompakter */
    .kati-auth-title {
        font-size: 22px !important;
        margin-bottom: 6px !important;
    }

    .kati-auth-subtitle {
        font-size: 14px !important;
        margin-bottom: 20px !important;
    }

    /* Eingabefelder: volle Breite */
    .kati-form-input {
        width: 100% !important;
        max-width: 100% !important;
    }

}

/* ================================================================
   GP HEADER + CONTAINER — MOBILE (max 767px)
   Gilt fuer ALLE Seiten (Login, Legal, Landing, Preise)
   ================================================================ */

@media (max-width: 768px) {
    /* GP Header Mobile */
    .site-header .inside-header,
    .inside-header.grid-container {
        padding-left: 16px !important;
        padding-right: 16px !important;
    }

    /* GP Site-Title Mobile */
    .site-header .main-title,
    .site-header .site-title,
    .site-header .site-title a,
    .site-branding .main-title a {
        font-size: 15px !important;
    }

    /* GP Content-Area Mobile */
    body.page .site-content {
        padding: 10px 0 !important;
    }

    body.page .entry-content,
    body.page article .entry-content,
    body.page .inside-article {
        padding: 15px 8px !important;
        border-radius: 10px !important;
    }
}

@media (max-width: 480px) {
    .site-header .main-title,
    .site-header .site-title,
    .site-header .site-title a,
    .site-branding .main-title a {
        font-size: 12px !important;
    }
}