@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600;700&family=Inter:wght@300;400;500;600&display=swap');

:root {
  --color-primary:      #005691;   /* Cerastyle Blau – Buttons, Highlights */
  --color-secondary:    #0A1C36;   /* Dunkles Marineblau – Logo Typo, Footer, Überschriften */
  --color-accent:       #0073C4;   /* Helleres Blau – Hover, Akzente */
  --color-bg:           #F9FAFB;   /* Sehr helles Grau/Weiß – Seitenhintergrund */
  --color-surface:      #FFFFFF;   /* Weiß – Cards, Modals */
  --color-text:         #1F2937;   /* Dunkelgrau – Fließtext */
  --color-text-muted:   #6B7280;   /* Hellgrau – Meta, Labels */
  --color-border:       #E5E7EB;   /* Heller Rahmen */
  --color-success:      #10B981;   /* Grün */
  --color-error:        #EF4444;   /* Rot */

  --font-heading: 'Playfair Display', Georgia, serif;
  --font-body:    'Inter', system-ui, sans-serif;

  --radius:  2px;       /* Scharfe, premium Ecken */
  --shadow:  0 2px 20px rgba(0,0,0,0.08);
  --transition: 0.25s ease;
}

body {
    font-family: var(--font-body);
    background-color: var(--color-bg);
    color: var(--color-text);
}

h1, h2, h3, h4, h5, h6, .font-heading {
    font-family: var(--font-heading);
    color: var(--color-primary);
}

.bg-primary { background-color: var(--color-primary); }
.text-primary { color: var(--color-primary); }
.border-primary { border-color: var(--color-primary); }

.bg-secondary { background-color: var(--color-secondary); }
.text-secondary { color: var(--color-secondary); }
.border-secondary { border-color: var(--color-secondary); }

.bg-accent { background-color: var(--color-accent); }
.text-accent { color: var(--color-accent); }

.bg-surface { background-color: var(--color-surface); }
.border-color { border-color: var(--color-border); }
.text-muted { color: var(--color-text-muted); }

/* Buttons */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.75rem 1.5rem;
    font-weight: 500;
    transition: all var(--transition);
    border-radius: var(--radius);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-size: 0.875rem;
}

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

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

.btn-secondary {
    background-color: var(--color-surface);
    color: var(--color-primary);
    border: 1px solid var(--color-border);
}

.btn-secondary:hover {
    border-color: var(--color-primary);
}

/* Cards & Images */
.product-card {
    background: var(--color-surface);
    border-radius: var(--radius);
    overflow: hidden;
    transition: all var(--transition);
}

.product-card:hover {
    box-shadow: var(--shadow);
}

.product-image-container {
    overflow: hidden;
    position: relative;
    aspect-ratio: 1 / 1;
}

.product-image {
    transition: transform 0.5s ease;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.product-card:hover .product-image {
    transform: scale(1.05); /* Subtile Hover-Animationen (Bild-Zoom) */
}

/* Inputs */
.input-field {
    width: 100%;
    padding: 0.75rem 1rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    background: var(--color-surface);
    transition: border-color var(--transition);
}

.input-field:focus {
    outline: none;
    border-color: var(--color-secondary);
    box-shadow: 0 0 0 1px var(--color-secondary);
}
