/*
Theme Name:   Irena Lay – Art Design Gallery
Theme URI:    https://irenalay.com
Description:  Custom Child Theme für Hello Elementor. Kreativ-Galerie am Bodensee.
Author:       Flow Factory / Steffen Lay
Author URI:   https://steffenlay.com
Template:     hello-elementor
Version:      1.0.0
License:      Proprietary
Text Domain:  irenalay
*/

/* ==========================================================================
   0. CSS CUSTOM PROPERTIES
   ========================================================================== */

:root {
  --il-primary-dark:    #2B4A4A;
  --il-primary-medium:  #4A7065;
  --il-accent-light:    #B5D5E2;
  --il-text-light:      #F0EDE8;
  --il-text-dark:       #1A2E2E;
  --il-accent-gold:     #C4A86B;
  --il-bg:              #F5F3EF;
  --il-white:           #FFFFFF;
  --il-border:          #D4D0C8;
  --il-gold-hover:      #B39555;
  --il-primary-hover:   #1E3636;
  --il-accent-light-50: rgba(181, 213, 226, 0.5);
  --il-muted:           #5A6B6B;

  --il-font-heading: 'Playfair Display', Georgia, 'Times New Roman', serif;
  --il-font-body:    'Source Sans 3', 'Source Sans Pro', -apple-system, BlinkMacSystemFont, sans-serif;
  --il-font-accent:  'Cormorant Garamond', Georgia, serif;

  --il-text-xs:   0.75rem;
  --il-text-sm:   0.875rem;
  --il-text-base: 1rem;
  --il-text-lg:   1.125rem;
  --il-text-xl:   1.25rem;
  --il-text-2xl:  clamp(1.5rem, 2vw, 1.75rem);
  --il-text-3xl:  clamp(1.75rem, 3vw, 2.25rem);
  --il-text-4xl:  clamp(2rem, 4vw, 3rem);
  --il-text-hero: clamp(2.25rem, 5vw, 3.75rem);

  --il-space-xs:  0.5rem;
  --il-space-sm:  1rem;
  --il-space-md:  1.5rem;
  --il-space-lg:  2.5rem;
  --il-space-xl:  4rem;
  --il-space-2xl: 6rem;
  --il-space-section: clamp(4rem, 8vw, 7rem);

  --il-max-width:       1200px;
  --il-header-h:        90px;
  --il-header-h-scroll: 64px;
  --il-radius:          4px;
  --il-radius-lg:       8px;
  --il-transition:      0.3s cubic-bezier(0.4, 0, 0.2, 1);
  --il-transition-slow: 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  --il-shadow-sm:       0 1px 3px rgba(26, 46, 46, 0.08);
  --il-shadow-md:       0 4px 12px rgba(26, 46, 46, 0.10);
  --il-shadow-lg:       0 8px 30px rgba(26, 46, 46, 0.12);
}

/* ==========================================================================
   1. RESET & BASE
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  margin: 0; padding: 0;
  font-family: var(--il-font-body);
  font-size: var(--il-text-base);
  line-height: 1.7;
  color: var(--il-text-dark);
  background-color: var(--il-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body.admin-bar { --il-admin-bar: 32px; }
img { max-width: 100%; height: auto; display: block; }

a {
  color: var(--il-primary-medium);
  text-decoration: none;
  transition: color var(--il-transition);
}
a:hover { color: var(--il-accent-gold); }

/* ==========================================================================
   2. TYPOGRAPHY
   ========================================================================== */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--il-font-heading);
  font-weight: 700; line-height: 1.2;
  color: var(--il-text-dark);
  margin: 0 0 var(--il-space-sm);
}
h1 { font-size: var(--il-text-hero); }
h2 { font-size: var(--il-text-4xl); }
h3 { font-size: var(--il-text-3xl); }
h4 { font-size: var(--il-text-2xl); }
p  { margin: 0 0 var(--il-space-sm); }
.il-accent-text { font-family: var(--il-font-accent); font-style: italic; }

/* ==========================================================================
   3. UTILITY CLASSES
   ========================================================================== */
.il-container { width: 100%; max-width: var(--il-max-width); margin: 0 auto; padding: 0 var(--il-space-md); }
.il-section { padding: var(--il-space-section) 0; }
.il-section--dark { background-color: var(--il-primary-dark); color: var(--il-text-light); }
.il-section--dark h2, .il-section--dark h3, .il-section--dark h4 { color: var(--il-text-light); }
.il-section--light { background-color: var(--il-accent-light); color: var(--il-text-dark); }
.il-section--medium { background-color: var(--il-primary-medium); color: var(--il-text-light); }
.il-section--medium h2, .il-section--medium h3 { color: var(--il-text-light); }
.il-grid { display: grid; gap: var(--il-space-lg); }
.il-grid--2 { grid-template-columns: repeat(2, 1fr); }
.il-grid--3 { grid-template-columns: repeat(3, 1fr); }
.il-grid--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 768px) { .il-grid--2, .il-grid--3, .il-grid--4 { grid-template-columns: 1fr; } }
@media (min-width: 769px) and (max-width: 1024px) { .il-grid--3, .il-grid--4 { grid-template-columns: repeat(2, 1fr); } }
.il-text-center { text-align: center; }

/* ==========================================================================
   4. BUTTONS
   ========================================================================== */
.il-btn {
  display: inline-flex; align-items: center; gap: 0.5em;
  padding: 0.8em 1.8em;
  font-family: var(--il-font-body); font-size: var(--il-text-sm);
  font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase;
  text-decoration: none; border: 2px solid transparent;
  border-radius: var(--il-radius); cursor: pointer;
  transition: all var(--il-transition); line-height: 1.2;
}
.il-btn--primary { background: var(--il-accent-gold); color: var(--il-white); border-color: var(--il-accent-gold); }
.il-btn--primary:hover { background: var(--il-gold-hover); border-color: var(--il-gold-hover); color: var(--il-white); }
.il-btn--outline { background: transparent; color: var(--il-text-light); border-color: var(--il-text-light); }
.il-btn--outline:hover { background: var(--il-text-light); color: var(--il-primary-dark); }
.il-btn--outline-dark { background: transparent; color: var(--il-primary-dark); border-color: var(--il-primary-dark); }
.il-btn--outline-dark:hover { background: var(--il-primary-dark); color: var(--il-text-light); }
.il-btn--small { padding: 0.5em 1.2em; font-size: var(--il-text-xs); }

/* ==========================================================================
   5. HEADER
   ========================================================================== */
.il-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  background-color: var(--il-primary-dark);
  height: var(--il-header-h);
  transition: all var(--il-transition);
}
body.admin-bar .il-header { top: var(--il-admin-bar, 0px); }
.il-header.is-scrolled { height: var(--il-header-h-scroll); box-shadow: var(--il-shadow-lg); }

.il-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 100%; max-width: var(--il-max-width); margin: 0 auto; padding: 0 var(--il-space-md);
}

.il-header__logo { display: flex; align-items: center; flex-shrink: 0; }
.il-header__logo a { display: flex; align-items: center; text-decoration: none; color: var(--il-text-light); gap: 0.75rem; }
.il-header__logo img { height: 50px; width: auto; transition: height var(--il-transition); }
.il-header.is-scrolled .il-header__logo img { height: 36px; }
.il-header__logo-text { font-family: var(--il-font-heading); font-size: var(--il-text-lg); font-weight: 700; color: var(--il-text-light); line-height: 1.2; }
.il-header__logo-sub { display: block; font-family: var(--il-font-accent); font-size: var(--il-text-xs); font-weight: 400; font-style: italic; color: var(--il-accent-gold); letter-spacing: 0.1em; }

.il-header__nav { display: flex; align-items: center; gap: var(--il-space-lg); }
.il-header__menu { display: flex; list-style: none; margin: 0; padding: 0; gap: var(--il-space-md); }
.il-header__menu a { color: var(--il-text-light); font-size: var(--il-text-sm); font-weight: 600; letter-spacing: 0.03em; padding: 0.5em 0; position: relative; transition: color var(--il-transition); text-decoration: none; }
.il-header__menu a::after { content: ''; position: absolute; bottom: 0; left: 0; width: 0; height: 2px; background: var(--il-accent-gold); transition: width var(--il-transition); }
.il-header__menu a:hover, .il-header__menu a.is-active { color: var(--il-accent-gold); }
.il-header__menu a:hover::after, .il-header__menu a.is-active::after { width: 100%; }

.il-header__actions { display: flex; align-items: center; gap: var(--il-space-sm); }
.il-header__cart { position: relative; color: var(--il-text-light); font-size: 1.25rem; padding: 0.5em; transition: color var(--il-transition); }
.il-header__cart:hover { color: var(--il-accent-gold); }
.il-header__cart-count { position: absolute; top: 0; right: 0; background: var(--il-accent-gold); color: var(--il-white); font-size: 0.65rem; font-weight: 700; width: 18px; height: 18px; border-radius: 50%; display: flex; align-items: center; justify-content: center; }

.il-header__toggle { display: none; flex-direction: column; justify-content: center; gap: 5px; width: 28px; height: 28px; background: none; border: none; cursor: pointer; padding: 0; }
.il-header__toggle span { display: block; width: 100%; height: 2px; background: var(--il-text-light); transition: all var(--il-transition); transform-origin: center; }
.il-header__toggle.is-active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.il-header__toggle.is-active span:nth-child(2) { opacity: 0; }
.il-header__toggle.is-active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.il-header__mobile-menu {
  display: none; position: fixed; top: var(--il-header-h); left: 0; right: 0; bottom: 0;
  background: var(--il-primary-dark); padding: var(--il-space-lg) var(--il-space-md);
  z-index: 999; overflow-y: auto;
}
.il-header__mobile-menu.is-open { display: flex; flex-direction: column; gap: var(--il-space-sm); }
.il-header__mobile-menu a { color: var(--il-text-light); font-size: var(--il-text-xl); font-family: var(--il-font-heading); padding: var(--il-space-sm) 0; border-bottom: 1px solid rgba(240,237,232,0.1); display: block; }
.il-header__mobile-menu a:hover { color: var(--il-accent-gold); }

@media (max-width: 960px) {
  .il-header__menu, .il-header__actions .il-btn { display: none; }
  .il-header__toggle { display: flex; }
}

.il-header-spacer { height: var(--il-header-h); }

/* ==========================================================================
   6. FOOTER
   ========================================================================== */
.il-footer { background: var(--il-primary-dark); color: var(--il-text-light); padding: var(--il-space-xl) 0 var(--il-space-md); }
.il-footer a { color: var(--il-text-light); transition: color var(--il-transition); }
.il-footer a:hover { color: var(--il-accent-gold); }

.il-footer__top { display: grid; grid-template-columns: 1fr 1fr; gap: var(--il-space-xl); padding-bottom: var(--il-space-lg); border-bottom: 1px solid rgba(240,237,232,0.15); }
.il-footer__brand-name { font-family: var(--il-font-heading); font-size: var(--il-text-2xl); font-weight: 700; margin-bottom: var(--il-space-xs); }
.il-footer__brand-sub { font-family: var(--il-font-accent); font-style: italic; color: var(--il-accent-gold); font-size: var(--il-text-sm); margin-bottom: var(--il-space-md); }
.il-footer__social { display: flex; gap: var(--il-space-sm); margin-top: var(--il-space-sm); }
.il-footer__social a { display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; border: 1px solid rgba(240,237,232,0.3); border-radius: 50%; transition: all var(--il-transition); }
.il-footer__social a:hover { background: var(--il-accent-gold); border-color: var(--il-accent-gold); color: var(--il-white); }
.il-footer__social svg { width: 18px; height: 18px; fill: currentColor; }
.il-footer__info h4 { font-family: var(--il-font-heading); font-size: var(--il-text-xl); color: var(--il-text-light); margin-bottom: var(--il-space-sm); }
.il-footer__hours { list-style: none; padding: 0; margin: 0; font-size: var(--il-text-sm); line-height: 2; }
.il-footer__hours strong { display: inline-block; min-width: 120px; }

.il-footer__newsletter { padding: var(--il-space-lg) 0; border-bottom: 1px solid rgba(240,237,232,0.15); }
.il-footer__newsletter-inner { display: flex; align-items: center; gap: var(--il-space-md); flex-wrap: wrap; }
.il-footer__newsletter p { margin: 0; font-size: var(--il-text-sm); flex: 1; min-width: 200px; }
.il-footer__newsletter-form { display: flex; gap: 0; flex: 1; min-width: 280px; max-width: 420px; }
.il-footer__newsletter-form input[type="email"] { flex: 1; padding: 0.7em 1em; border: 1px solid rgba(240,237,232,0.3); border-right: none; border-radius: var(--il-radius) 0 0 var(--il-radius); background: rgba(240,237,232,0.08); color: var(--il-text-light); font-family: var(--il-font-body); font-size: var(--il-text-sm); }
.il-footer__newsletter-form input[type="email"]::placeholder { color: rgba(240,237,232,0.5); }
.il-footer__newsletter-form input[type="email"]:focus { outline: none; border-color: var(--il-accent-gold); background: rgba(240,237,232,0.12); }
.il-footer__newsletter-form button { padding: 0.7em 1.5em; background: var(--il-accent-gold); color: var(--il-white); border: 1px solid var(--il-accent-gold); border-radius: 0 var(--il-radius) var(--il-radius) 0; font-family: var(--il-font-body); font-size: var(--il-text-sm); font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; cursor: pointer; transition: background var(--il-transition); }
.il-footer__newsletter-form button:hover { background: var(--il-gold-hover); }

.il-footer__bottom { display: flex; justify-content: space-between; align-items: center; padding-top: var(--il-space-md); font-size: var(--il-text-xs); opacity: 0.7; flex-wrap: wrap; gap: var(--il-space-sm); }
.il-footer__legal { display: flex; gap: var(--il-space-md); }

@media (max-width: 768px) {
  .il-footer__top { grid-template-columns: 1fr; gap: var(--il-space-lg); }
  .il-footer__newsletter-inner { flex-direction: column; align-items: stretch; }
  .il-footer__newsletter-form { max-width: 100%; }
  .il-footer__bottom { flex-direction: column; text-align: center; }
}

/* ==========================================================================
   7. HERO
   ========================================================================== */
.il-hero { position: relative; min-height: 70vh; display: flex; align-items: center; justify-content: center; overflow: hidden; background: var(--il-primary-dark); }
.il-hero--full { min-height: 85vh; }
.il-hero__bg { position: absolute; inset: 0; background-size: cover; background-position: center; }
.il-hero__bg::after { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(43,74,74,0.75) 0%, rgba(43,74,74,0.4) 50%, rgba(43,74,74,0.6) 100%); }
.il-hero__content { position: relative; z-index: 1; text-align: center; padding: var(--il-space-xl) var(--il-space-md); max-width: 800px; }
.il-hero__title { font-family: var(--il-font-heading); font-size: var(--il-text-hero); color: var(--il-text-light); margin-bottom: var(--il-space-sm); text-shadow: 0 2px 8px rgba(0,0,0,0.15); }
.il-hero__subtitle { font-family: var(--il-font-accent); font-size: var(--il-text-2xl); font-style: italic; color: var(--il-accent-gold); margin-bottom: var(--il-space-lg); }
.il-hero__actions { display: flex; gap: var(--il-space-sm); justify-content: center; flex-wrap: wrap; }

/* ==========================================================================
   8. TRUST BAR
   ========================================================================== */
.il-trust { background: var(--il-primary-medium); padding: var(--il-space-sm) 0; }
.il-trust__inner { display: flex; justify-content: center; align-items: center; gap: var(--il-space-lg); flex-wrap: wrap; font-size: var(--il-text-sm); color: var(--il-text-light); }
.il-trust__item { display: flex; align-items: center; gap: 0.5em; white-space: nowrap; }

/* ==========================================================================
   9. CARDS
   ========================================================================== */
.il-card { background: var(--il-white); border-radius: var(--il-radius-lg); overflow: hidden; box-shadow: var(--il-shadow-sm); transition: all var(--il-transition); display: flex; flex-direction: column; }
.il-card:hover { box-shadow: var(--il-shadow-md); transform: translateY(-3px); }
.il-card__image { position: relative; aspect-ratio: 4/3; overflow: hidden; }
.il-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--il-transition-slow); }
.il-card:hover .il-card__image img { transform: scale(1.05); }
.il-card__badge { position: absolute; top: var(--il-space-sm); right: var(--il-space-sm); padding: 0.3em 0.8em; border-radius: var(--il-radius); font-size: var(--il-text-xs); font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; }
.il-card__badge--buchbar { background: var(--il-primary-medium); color: var(--il-white); }
.il-card__badge--wenige { background: var(--il-accent-gold); color: var(--il-white); }
.il-card__badge--ausgebucht { background: #8B6F6F; color: var(--il-white); }
.il-card__body { padding: var(--il-space-md); flex: 1; display: flex; flex-direction: column; }
.il-card__meta { font-size: var(--il-text-sm); color: var(--il-primary-medium); font-weight: 600; margin-bottom: var(--il-space-xs); }
.il-card__title { font-family: var(--il-font-heading); font-size: var(--il-text-xl); margin-bottom: var(--il-space-xs); color: var(--il-text-dark); }
.il-card__desc { font-size: var(--il-text-sm); color: var(--il-muted); margin-bottom: var(--il-space-md); flex: 1; }
.il-card__footer { display: flex; justify-content: space-between; align-items: center; margin-top: auto; }
.il-card__price { font-family: var(--il-font-heading); font-size: var(--il-text-xl); font-weight: 700; color: var(--il-accent-gold); }
.il-card__price small { font-size: var(--il-text-xs); font-weight: 400; font-family: var(--il-font-body); color: var(--il-muted); display: block; }

/* ==========================================================================
   10. KURS-ARCHIV WEICHE
   ========================================================================== */
.il-kurs-weiche { display: grid; grid-template-columns: 1fr 1fr; gap: var(--il-space-lg); margin-bottom: var(--il-space-xl); }
.il-kurs-weiche__item { position: relative; border-radius: var(--il-radius-lg); overflow: hidden; min-height: 350px; display: flex; align-items: flex-end; text-decoration: none; transition: transform var(--il-transition); }
.il-kurs-weiche__item:hover { transform: scale(1.02); }
.il-kurs-weiche__item img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.il-kurs-weiche__item::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to top, rgba(43,74,74,0.85) 0%, rgba(43,74,74,0.2) 60%, transparent 100%); }
.il-kurs-weiche__content { position: relative; z-index: 1; padding: var(--il-space-lg); width: 100%; }
.il-kurs-weiche__label { font-family: var(--il-font-heading); font-size: var(--il-text-3xl); color: var(--il-text-light); margin-bottom: var(--il-space-sm); }
.il-kurs-weiche__cta { color: var(--il-accent-gold); font-weight: 600; font-size: var(--il-text-lg); }
@media (max-width: 768px) { .il-kurs-weiche { grid-template-columns: 1fr; } .il-kurs-weiche__item { min-height: 250px; } }

/* ==========================================================================
   11. SPLIT SECTION
   ========================================================================== */
.il-split { display: grid; grid-template-columns: 1fr 1fr; min-height: 450px; }
.il-split__image { overflow: hidden; }
.il-split__image img { width: 100%; height: 100%; object-fit: cover; }
.il-split__content { display: flex; flex-direction: column; justify-content: center; padding: var(--il-space-xl); }
@media (max-width: 768px) { .il-split { grid-template-columns: 1fr; } .il-split__content { padding: var(--il-space-lg) var(--il-space-md); } }

/* ==========================================================================
   12. TESTIMONIAL
   ========================================================================== */
.il-testimonial { text-align: center; padding: var(--il-space-lg); max-width: 700px; margin: 0 auto; }
.il-testimonial__text { font-family: var(--il-font-accent); font-size: var(--il-text-2xl); font-style: italic; color: var(--il-text-dark); margin-bottom: var(--il-space-md); line-height: 1.6; }
.il-testimonial__text::before { content: '\201E'; display: block; font-size: 3rem; color: var(--il-accent-gold); line-height: 1; margin-bottom: var(--il-space-xs); }
.il-testimonial__author { font-size: var(--il-text-sm); font-weight: 600; color: var(--il-primary-medium); }
.il-testimonial__context { font-size: var(--il-text-xs); color: var(--il-muted); }

/* ==========================================================================
   13. FORMS
   ========================================================================== */
.il-form label { display: block; font-size: var(--il-text-sm); font-weight: 600; margin-bottom: 0.3em; color: var(--il-text-dark); }
.il-form input[type="text"], .il-form input[type="email"], .il-form input[type="tel"],
.il-form select, .il-form textarea { width: 100%; padding: 0.75em 1em; border: 1px solid var(--il-border); border-radius: var(--il-radius); font-family: var(--il-font-body); font-size: var(--il-text-base); color: var(--il-text-dark); background: var(--il-white); transition: border-color var(--il-transition); }
.il-form input:focus, .il-form select:focus, .il-form textarea:focus { outline: none; border-color: var(--il-accent-gold); box-shadow: 0 0 0 3px rgba(196,168,107,0.15); }
.il-form textarea { min-height: 150px; resize: vertical; }

/* ==========================================================================
   14. WOOCOMMERCE
   ========================================================================== */
.woocommerce ul.products li.product { border-radius: var(--il-radius-lg); overflow: hidden; box-shadow: var(--il-shadow-sm); transition: all var(--il-transition); background: var(--il-white); }
.woocommerce ul.products li.product:hover { box-shadow: var(--il-shadow-md); transform: translateY(-3px); }
.woocommerce ul.products li.product .price { color: var(--il-accent-gold) !important; font-family: var(--il-font-heading); font-size: var(--il-text-xl) !important; }
.woocommerce ul.products li.product h2.woocommerce-loop-product__title { font-family: var(--il-font-heading); font-size: var(--il-text-lg); color: var(--il-text-dark); padding: 0.5em 1em 0; }
.woocommerce ul.products li.product .button, .woocommerce a.button, .woocommerce button.button, .woocommerce input.button { background: var(--il-accent-gold) !important; color: var(--il-white) !important; border-radius: var(--il-radius) !important; font-family: var(--il-font-body); font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase; font-size: var(--il-text-sm) !important; transition: background var(--il-transition); }
.woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce input.button:hover { background: var(--il-gold-hover) !important; }
.woocommerce .woocommerce-message, .woocommerce .woocommerce-info { border-top-color: var(--il-accent-gold); }
.woocommerce .woocommerce-message::before, .woocommerce .woocommerce-info::before { color: var(--il-accent-gold); }

/* ==========================================================================
   15. 404
   ========================================================================== */
.il-404 { min-height: 60vh; display: flex; align-items: center; justify-content: center; text-align: center; padding: var(--il-space-xl) var(--il-space-md); }
.il-404__code { font-family: var(--il-font-heading); font-size: clamp(5rem,15vw,10rem); font-weight: 700; color: var(--il-accent-light); line-height: 1; margin-bottom: var(--il-space-sm); }
.il-404__title { font-size: var(--il-text-3xl); margin-bottom: var(--il-space-sm); }
.il-404__text { font-size: var(--il-text-lg); color: var(--il-muted); margin-bottom: var(--il-space-lg); max-width: 500px; margin-left: auto; margin-right: auto; }
.il-404__actions { display: flex; gap: var(--il-space-sm); justify-content: center; flex-wrap: wrap; }

/* ==========================================================================
   16. SINGLE KURS
   ========================================================================== */
.il-single-kurs__header { background: var(--il-primary-dark); padding: var(--il-space-xl) 0; margin-bottom: var(--il-space-xl); }
.il-single-kurs__header-inner { display: grid; grid-template-columns: 1fr 1fr; gap: var(--il-space-xl); align-items: center; }
.il-single-kurs__image { border-radius: var(--il-radius-lg); overflow: hidden; }
.il-single-kurs__image img { width: 100%; aspect-ratio: 4/3; object-fit: cover; }
.il-single-kurs__info h1 { color: var(--il-text-light); margin-bottom: var(--il-space-md); }
.il-single-kurs__meta-grid { display: grid; grid-template-columns: auto 1fr; gap: 0.5rem 1rem; font-size: var(--il-text-sm); color: rgba(240,237,232,0.8); margin-bottom: var(--il-space-md); }
.il-single-kurs__meta-label { font-weight: 600; color: var(--il-accent-gold); }
.il-single-kurs__price-box { background: rgba(240,237,232,0.1); border-radius: var(--il-radius-lg); padding: var(--il-space-md); margin-top: var(--il-space-md); }
.il-single-kurs__price { font-family: var(--il-font-heading); font-size: var(--il-text-3xl); color: var(--il-accent-gold); margin-bottom: var(--il-space-xs); }
.il-single-kurs__includes { font-size: var(--il-text-sm); color: rgba(240,237,232,0.7); }
@media (max-width: 768px) { .il-single-kurs__header-inner { grid-template-columns: 1fr; } }

/* ==========================================================================
   17. PRINT
   ========================================================================== */
@media print {
  .il-header, .il-footer, .il-header-spacer { display: none !important; }
  body { font-size: 12pt; color: #000; background: #fff; }
}
