/* ══════════════════════════════════════════════════════════════════════
   Kultopolis — Theme (hell, frisch)

   Farbsystem
     --bg          Heller Off-White-Grund
     --surface     Karten/Panels
     --ink         Haupt-Textfarbe (sehr dunkles Blau-Schwarz)
     --muted       Sekundärer Text
     --accent      Kultopolis-Orange
     --accent-2    Komplement (tiefes Blau) für Hover/Akzente
   ══════════════════════════════════════════════════════════════════════ */
:root {
    --bg:        #F7F5F0;
    --surface:   #FFFFFF;
    --ink:       #161A2E;
    --muted:     #6B6F80;
    --line:      #E6E3DA;
    --accent:    #FF7A1A;
    --accent-2:  #1A2C6B;
    --radius:    14px;
    --radius-sm: 8px;
    --shadow:    0 2px 10px rgba(20, 24, 48, .06);
    --shadow-lg: 0 10px 30px rgba(20, 24, 48, .12);
    --maxw:      1180px;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
    font-family: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
    background: var(--bg);
    color: var(--ink);
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
}

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

/* ─ Header ───────────────────────────────────────────────────────── */
.kp-header {
    background: var(--surface);
    border-bottom: 1px solid var(--line);
    position: sticky; top: 0; z-index: 10;
}
.kp-header-inner {
    max-width: var(--maxw); margin: 0 auto;
    padding: 18px 24px;
    display: flex; align-items: center; justify-content: space-between;
}
.kp-logo {
    font-weight: 800; font-size: 22px; letter-spacing: -.02em;
    color: var(--ink);
}
.kp-logo strong { color: var(--accent); }
.kp-nav a { margin-left: 24px; color: var(--muted); font-weight: 500; }
.kp-nav a:hover { color: var(--ink); }

/* ─ Hero ─────────────────────────────────────────────────────────── */
.kp-hero {
    max-width: var(--maxw); margin: 0 auto;
    padding: 60px 24px 40px;
    text-align: center;
}
.kp-hero-eyebrow {
    text-transform: uppercase; letter-spacing: .15em;
    font-size: 12px; font-weight: 600;
    color: var(--accent);
    margin-bottom: 18px;
}
.kp-hero-headline {
    font-size: clamp(36px, 6vw, 68px);
    font-weight: 800;
    line-height: 1.05;
    letter-spacing: -.03em;
    margin: 0 0 22px;
}
.kp-hero-headline strong { color: var(--accent); }
.kp-hero-sub {
    font-size: 18px;
    color: var(--muted);
    max-width: 640px; margin: 0 auto;
}

/* ─ Suche ────────────────────────────────────────────────────────── */
.kp-search {
    max-width: 720px; margin: 34px auto 0;
    background: var(--surface);
    border-radius: 999px;
    box-shadow: var(--shadow-lg);
    padding: 8px 8px 8px 22px;
    display: flex; align-items: center; gap: 12px;
}
.kp-search input {
    flex: 1; border: none; outline: none; background: transparent;
    font-size: 17px; color: var(--ink);
    font-family: inherit;
}
.kp-search input::placeholder { color: var(--muted); }
.kp-search button {
    background: var(--accent); color: white;
    border: none; border-radius: 999px;
    padding: 12px 28px; font-weight: 600; font-size: 15px;
    cursor: pointer;
    transition: background .15s;
}
.kp-search button:hover { background: #E6690F; }

/* ─ Filter-Chips ─────────────────────────────────────────────────── */
.kp-filters {
    max-width: var(--maxw); margin: 28px auto 0;
    padding: 0 24px;
    display: flex; gap: 10px; flex-wrap: wrap; justify-content: center;
}
.kp-chip {
    background: var(--surface); border: 1px solid var(--line);
    border-radius: 999px;
    padding: 7px 16px; font-size: 14px; color: var(--ink);
    cursor: pointer;
    transition: all .15s;
}
.kp-chip:hover { border-color: var(--accent); color: var(--accent); }
.kp-chip.is-active { background: var(--ink); color: var(--bg); border-color: var(--ink); }

/* ─ Event-Grid ───────────────────────────────────────────────────── */
.kp-events {
    max-width: var(--maxw); margin: 40px auto 80px;
    padding: 0 24px;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 22px;
}
.kp-card {
    background: var(--surface);
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow);
    display: flex; flex-direction: column;
    transition: transform .18s, box-shadow .18s;
    text-decoration: none;
    color: inherit;
}
.kp-card-cta span { color: var(--accent); font-weight: 600; font-size: 14px; }
.kp-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-lg);
}
.kp-card-img {
    aspect-ratio: 16 / 10;
    background: #E8E5DE center/cover no-repeat;
    position: relative;
}
.kp-card-date {
    position: absolute; top: 12px; left: 12px;
    background: rgba(22, 26, 46, .85);
    color: white;
    padding: 6px 12px;
    border-radius: var(--radius-sm);
    font-size: 13px;
    font-weight: 600;
    backdrop-filter: blur(4px);
}
.kp-card-provider {
    position: absolute; bottom: 12px; right: 12px;
    background: var(--accent); color: white;
    padding: 4px 10px; border-radius: 999px;
    font-size: 11px; font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em;
}
.kp-card-tour-badge {
    position: absolute; bottom: 12px; right: 12px;
    background: var(--accent-2); color: white;
    padding: 5px 12px; border-radius: 999px;
    font-size: 12px; font-weight: 700;
    display: inline-flex; align-items: center; gap: 6px;
    box-shadow: 0 2px 8px rgba(26, 44, 107, .3);
}
.kp-card-tour-badge::before { content: "♪"; }
.kp-card.is-tour .kp-card-title::after {
    content: " · Tournee";
    font-size: 13px; font-weight: 500; color: var(--accent-2);
}
.kp-card-body {
    padding: 18px 20px 20px;
    display: flex; flex-direction: column; gap: 10px;
    flex: 1;
}
.kp-card-title {
    font-size: 17px; font-weight: 700; line-height: 1.25;
    color: var(--ink); margin: 0;
}
.kp-card-meta {
    font-size: 13px; color: var(--muted);
    display: flex; gap: 10px; flex-wrap: wrap;
}
.kp-card-meta strong { color: var(--ink); font-weight: 600; }
.kp-card-cta {
    margin-top: auto; padding-top: 12px;
}
.kp-card-cta a {
    display: inline-flex; align-items: center; gap: 6px;
    color: var(--accent); font-weight: 600; font-size: 14px;
}
.kp-card-cta a::after { content: "→"; transition: transform .15s; }
.kp-card-cta a:hover::after { transform: translateX(3px); }
.kp-card-cta { display: flex; justify-content: space-between; align-items: center; }
.kp-card-price {
    background: var(--bg);
    padding: 3px 10px; border-radius: 999px;
    font-size: 12px; font-weight: 600; color: var(--ink);
    border: 1px solid var(--line);
}

/* ─ Empty-State ──────────────────────────────────────────────────── */
.kp-empty {
    grid-column: 1 / -1;
    text-align: center;
    padding: 60px 24px;
    color: var(--muted);
}

/* ─ Footer ───────────────────────────────────────────────────────── */
.kp-footer {
    background: var(--ink); color: #BFC2D0;
    padding: 32px 24px;
    text-align: center;
    font-size: 14px;
}
.kp-footer a { color: #BFC2D0; }
.kp-footer a:hover { color: var(--accent); }

/* ─ Responsive ───────────────────────────────────────────────────── */
@media (max-width: 640px) {
    .kp-header-inner { padding: 14px 18px; }
    .kp-nav { display: none; }
    .kp-hero { padding: 40px 18px 20px; }
    .kp-search { padding: 6px 6px 6px 18px; border-radius: var(--radius); flex-wrap: wrap; }
    .kp-search input { width: 100%; padding: 10px 0; }
    .kp-search button { width: 100%; border-radius: var(--radius-sm); }
    .kp-events { padding: 0 18px; gap: 16px; }
}
