/*
 Theme Name: Kadence Child - SICG Festival
 Template: kadence
 Description: Child theme for SICG Festival website
 Version: 1.0
 Author: Raphael Monno
*/

/* ========================================= */
/* SICG Festival â€” Complete Design System    */
/* ========================================= */

html { scroll-behavior: smooth; }
* { -webkit-font-smoothing: antialiased; }
body, .site { background: #0a0a2e !important; }
.entry-content { margin: 0 !important; padding: 0 !important; }
.site-container, .content-wrap, .site-main { background: transparent !important; }
.alignfull { margin-top: 0 !important; margin-bottom: 0 !important; }
#masthead, #colophon, footer.site-footer { display: none !important; }
.admin-bar .sicg-nav { top: 52px; }

/* NAV â€” Floating Pill */
.sicg-nav {
  position:fixed;top:20px;left:50%;transform:translateX(-50%);z-index:9999;
  width:calc(100% - 80px);max-width:1200px;
  background:rgba(10,10,46,0.75);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border:1px solid rgba(229,0,109,0.2);
  box-shadow:0 8px 32px rgba(0,0,0,0.3), 0 0 0 1px rgba(229,0,109,0.06), inset 0 1px 0 rgba(255,255,255,0.04);
  border-radius:60px;
  padding:0 36px;height:72px;
  display:flex;align-items:center;justify-content:space-between;
  font-family:Inter,-apple-system,sans-serif;
  transition:background 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease, top 0.3s ease;
}
.sicg-nav.scrolled {
  background:rgba(10,10,46,0.93);
  border-color:rgba(229,0,109,0.3);
  box-shadow:0 4px 24px rgba(229,0,109,0.12), 0 8px 32px rgba(0,0,0,0.4);
  top:12px;
}
.sicg-nav-logo { display:flex;align-items:center; }
.sicg-nav-logo img { height:44px;width:auto;transition:height 0.3s; }
.sicg-nav-links { display:flex;gap:28px;align-items:center; }
.sicg-nav-links a { color:rgba(255,255,255,0.85);font-size:12px;font-weight:500;text-decoration:none;letter-spacing:1px;text-transform:uppercase;transition:color 0.2s;white-space:nowrap; }
.sicg-nav-links a:hover { color:#E5006D; }
.sicg-lang-toggle { color:rgba(255,255,255,0.8);font-size:11px;font-weight:600;text-decoration:none;border:1px solid rgba(255,255,255,0.15);padding:6px 16px;border-radius:30px;letter-spacing:0.5px;transition:all 0.2s;margin-left:4px; }
.sicg-lang-toggle:hover { color:#E5006D !important;border-color:rgba(229,0,109,0.3) !important; }

/* Hamburger â€” hidden on desktop */
.sicg-hamburger { display:none;background:none;border:none;cursor:pointer;padding:8px;z-index:10001; }
.sicg-hamburger span { display:block;width:22px;height:2px;background:#fff;margin:5px 0;transition:all 0.3s; }
.sicg-mobile-menu { display:none; }

/* HERO */
.sicg-hero-container { padding: 10vh 24px 0; }
.sicg-hero-title { font-size: 64px !important; line-height: 1.08 !important; font-family: 'Playfair Display', Georgia, serif !important; }
.sicg-hero-edition { font-size: 16px !important; letter-spacing: 6px !important; }
.sicg-hero-sub { font-size: 17px !important; margin-bottom: 0 !important; }
.sicg-hero-buttons { gap: 14px !important; }
.sicg-hero-buttons a { font-size: 15px !important; font-weight: 600 !important; }

/* GRADIENT TEXT */
.sicg-gradient-text { background:linear-gradient(135deg,#E5006D 0%,#ff2d8f 30%,#ff6bb5 55%,#2d8c7e 100%) !important;-webkit-background-clip:text !important;-webkit-text-fill-color:transparent !important;background-clip:text !important; }

/* COMPONENTS */
.sicg-white-card { background:#fff !important;border-radius:20px !important;box-shadow:0 8px 40px rgba(0,0,0,0.3); }
.sicg-greeting-card { padding:56px; }
.sicg-greeting-card p { margin-bottom:8px; }
.sicg-greeting-card div[style*="line-height"] p { margin-top:0; margin-bottom:10px; }
.sicg-card-hover { transition:transform 0.3s,box-shadow 0.3s; }
.sicg-card-hover:hover { transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,0.4); }
.sicg-sponsors img { filter:grayscale(100%) brightness(1.8) opacity(0.5);transition:filter 0.3s; }
.sicg-sponsors img:hover { filter:grayscale(0%) brightness(1) opacity(1); }
.wp-block-gallery .wp-block-image img { transition:transform 0.4s, box-shadow 0.4s;border-radius:12px;border:1px solid rgba(255,255,255,0.06); }
.wp-block-gallery .wp-block-image:hover img { transform:scale(1.03);border-color:rgba(229,0,109,0.2);box-shadow:0 8px 24px rgba(229,0,109,0.1); }
.sicg-tickets-section { background:linear-gradient(180deg,#0a0a2e 0%,rgba(229,0,109,0.35) 25%,rgba(229,0,109,0.35) 75%,#0a0a2e 100%) !important; }
.sicg-artist-bio-overlay { display:none; }
.sicg-modal-close { display:none !important; }
.sicg-modal-back-bottom { border-radius:50px; }

/* SECTION CONTAINERS â€” einheitlich 1000px */
.sicg-section { max-width:1000px; margin:0 auto; padding:48px 24px; }
.sicg-section-tight { max-width:1000px; margin:0 auto; padding:32px 24px; }
.sicg-section-wide { max-width:1000px; margin:0 auto; padding:56px 24px; }

/* SECTION BOXES â€” subtile visuelle Trennung */
.sicg-box-magenta {
  background: rgba(229,0,109,0.02);
  border: 1px solid rgba(229,0,109,0.06);
  border-radius: 20px;
  padding: 48px 40px;
  margin: 0 auto 0;
  max-width: 1060px;
}
.sicg-box-neutral {
  background: rgba(255,255,255,0.015);
  border: 1px solid rgba(255,255,255,0.04);
  border-radius: 20px;
  padding: 48px 40px;
  margin: 0 auto 0;
  max-width: 1060px;
  overflow: visible !important;
}
.sicg-box-magenta { overflow: visible !important; }

/* GruÃŸwort Bilder */
.sicg-grusswort-img-mobile { display:none; }
.sicg-grusswort-img-desktop { display:block; width:100%; border-radius:12px; object-fit:cover; }
.sicg-grusswort-img-mobile { width:100%; border-radius:12px; object-fit:cover; max-height:300px; object-position:center 40%; }

/* STUNDENPLAN */
.sicg-stundenplan-section { position: relative; }

/* GRIDS */
.sicg-grusswort-grid { grid-template-columns: 45% 55% !important; }
.sicg-stundenplan-grid { grid-template-columns: 1fr !important; }
.sicg-grid-4-artists { grid-template-columns: repeat(3, 1fr) !important; max-width:900px !important; margin-left:auto !important; margin-right:auto !important; }
#kuenstler { display:flex; flex-direction:column; align-items:center; }
#kuenstler > *:not(.sicg-artist-bio-overlay) { width:100%; max-width:900px; }
#kuenstler > p, #kuenstler > h2 { max-width:100%; }
.sicg-artist-bio-overlay { max-width:none !important; width:auto !important; position:fixed !important; top:0 !important; left:0 !important; right:0 !important; bottom:0 !important; }
.sicg-meisterkurse-grid { grid-template-columns: repeat(3, 1fr) !important; }
.sicg-meisterkurse-grid.sicg-workshops-grid { grid-template-columns: repeat(2, 1fr) !important; max-width:940px !important; margin-left:auto !important; margin-right:auto !important; }
.sicg-ticket-grid { grid-template-columns: repeat(2, 1fr) !important; max-width:560px !important; margin-left:auto !important; margin-right:auto !important; }
.sicg-ausstellung-grid { grid-template-columns: 1fr 1fr !important; }
.sicg-grid-2-anreise { grid-template-columns: 1fr 1fr !important; }
.sicg-grid-3 { grid-template-columns: repeat(3, 1fr) !important; }

/* ========================================= */
/* TABLET <= 768px                           */
/* ========================================= */
@media (max-width: 768px) {
  /* HAMBURGER NAV â€” Floating Pill mobile */
  .sicg-nav { padding:0 20px;height:56px;top:12px;width:calc(100% - 32px);border-radius:40px; }
  .sicg-nav-logo img { height:30px !important; }
  .admin-bar .sicg-nav { top:58px; }
  .sicg-nav-links { display:none !important; }
  .sicg-lang-toggle { display:none !important; }
  .sicg-hamburger { display:block !important; }

  .sicg-mobile-menu.active {
    display:flex !important;
    position:fixed;top:0;left:0;right:0;bottom:0;
    background:rgba(10,10,46,0.97);
    backdrop-filter:blur(20px);
    z-index:10000;
    flex-direction:column;
    align-items:flex-start;
    justify-content:center;
    gap:0;
    padding-left:15%;
  }
  .sicg-mobile-menu a {
    color:rgba(255,255,255,0.95);font-size:18px;font-weight:600;text-decoration:none;
    text-transform:uppercase;letter-spacing:2px;
    padding:16px 0;transition:color 0.2s;
  }
  .sicg-mobile-menu a:hover { color:#E5006D; }
  .sicg-mobile-menu .sicg-mobile-close {
    position:absolute;top:14px;right:16px;
    color:rgba(255,255,255,0.5);font-size:28px;cursor:pointer;
    background:none;border:none;line-height:1;
  }
  .sicg-mobile-menu .sicg-mobile-lang {
    margin-top:24px;color:rgba(255,255,255,0.7);font-size:13px;
    border:1px solid rgba(255,255,255,0.15);padding:6px 20px;border-radius:20px;
  }
  .admin-bar .sicg-nav { top:46px; }

  /* HERO */
  .sicg-hero-container { padding: 22vh 16px 0 !important; }
  .sicg-hero-sponsors { gap:16px !important; bottom:16px !important; padding:0 16px !important; }
  .sicg-hero-sponsors img { height:40px !important; }
  .sicg-hero-title { font-size: 30px !important; line-height: 1.15 !important; }
  .sicg-hero-edition { font-size: 10px !important; letter-spacing: 2px !important; margin-bottom: 12px !important; }
  .sicg-hero-sub { font-size: 12px !important; margin-bottom: 40vh !important; }
  .sicg-hero-buttons { gap: 10px !important; flex-direction: column !important; align-items: center !important; }
  .sicg-hero-buttons a { font-size: 14px !important; padding: 14px 0 !important; width: 75% !important; text-align: center !important; display: block !important; border-radius: 50px !important; }

  /* SECTIONS â€” kompaktere Padding auf Mobile */
  .sicg-section, .sicg-section-tight, .sicg-section-wide { padding:20px 14px !important; }
  .sicg-box-magenta, .sicg-box-neutral { padding:20px 14px !important; border-radius:14px !important; margin:0 8px !important; }
  .sicg-grusswort-img-desktop { display:none !important; }
  .sicg-grusswort-img-mobile { display:block !important; }

  /* GRIDS */
  .sicg-white-card { border-radius:14px !important;margin:0 8px !important;padding:12px 14px !important; }
  .sicg-greeting-card { padding:16px 14px !important; }
  .sicg-white-card p:last-of-type { margin-bottom:0 !important; }
  .sicg-white-card h2 { margin-top:4px !important; margin-bottom:8px !important; }
  .sicg-grusswort-img-mobile { margin-bottom:0 !important; }
  .sicg-grusswort-img-wrap { min-height:auto !important; position:static !important; }
  .sicg-white-card img { max-height: 220px !important; object-fit: cover !important; border-radius: 10px !important; }
  .sicg-grusswort-img-mobile { max-height:280px !important; object-position:center 40% !important; }
  .sicg-white-card h2 { font-size: 22px !important; }
  .sicg-white-card p { font-size: 14px !important; line-height: 1.7 !important; }
  .sicg-grusswort-grid { gap: 8px !important; }
  .sicg-grusswort-grid { grid-template-columns: 1fr !important; }
  .sicg-stundenplan-grid { grid-template-columns: 1fr !important; }
  .sicg-grid-4-artists { grid-template-columns: 1fr !important;gap:12px !important;max-width:100% !important; }
  .sicg-grid-4-artists img { height:220px !important; }
  #kuenstler > div:first-of-type { max-width:100% !important; }
  .sicg-featured-artist { max-width:100% !important; }
  .sicg-meisterkurse-grid, .sicg-meisterkurse-grid.sicg-workshops-grid { grid-template-columns: 1fr !important; max-width:100% !important; }
  .sicg-ticket-grid { grid-template-columns: 1fr !important; }
  .sicg-ausstellung-grid { grid-template-columns: 1fr !important; }
  .sicg-grid-2-anreise { grid-template-columns: 1fr !important; }
  .sicg-grid-3 { grid-template-columns: 1fr !important; }

  /* MODALS */
  .sicg-artist-bio-overlay > div { max-width:100% !important;border-radius:0 !important;padding-bottom:120px !important; }
  .sicg-modal-close { display:none !important; }
  .sicg-modal-back-bottom { display:block !important;width:100% !important;padding:18px !important;background:#E5006D !important;color:#fff !important;border:none !important;border-radius:50px !important;font-size:16px !important;font-weight:600 !important;cursor:pointer !important;text-align:center !important;margin-top:24px !important; }
  .sicg-modal-header { flex-direction:column !important; }
  .sicg-modal-header img { width:100% !important;height:250px !important;margin:0 !important;border-radius:0 !important; }
  .sicg-modal-header > div { padding:16px 20px !important; }

  /* Stundenplan Mobile â€” heller Farben */
  .sicg-day-row { grid-template-columns: 1fr !important; gap: 6px !important; }
  .sicg-day-row p { color:rgba(255,255,255,0.6) !important; }
  .sicg-day-row p[style*="font-family"], .sicg-day-row p[style*="font-size:22px"], .sicg-day-row p[style*="font-size:26px"] { color:#fff !important; }
  .sicg-day-row > div:first-child { display:flex; align-items:baseline; gap:10px; }
  .sicg-day-row > div:first-child p:last-child { font-size:28px !important; }
  .sicg-day-row div[style*="display:flex"] { flex-direction:column !important; align-items:flex-start !important; }
  .sicg-day-row a[href*="reservix"] { display:inline-block !important; text-align:center !important; margin-top:10px !important; width:auto !important; padding:10px 24px !important; font-size:11px !important; }
  .sicg-stundenplan-section h2 { font-size:26px !important; }
  .sicg-stundenplan-section .sicg-stundenplan-grid > div { padding:18px 0 !important; }
  .sicg-day-row p[style*="font-size:22px"], .sicg-day-row p[style*="font-size:26px"], .sicg-day-row p[style*="font-family"] { font-size:18px !important; }
  .sicg-day-row p[style*="font-size:15px"] { font-size:13px !important; }
  .sicg-day-row div[style*="margin-bottom:28px"] { margin-bottom:16px !important; padding-bottom:16px !important; }

  /* Modal Scroll Fix */
  .sicg-artist-bio-overlay { overflow-y:scroll !important; -webkit-overflow-scrolling:touch !important; align-items:flex-start !important; padding:0 !important; }
  .sicg-artist-bio-overlay > div { margin:0 !important; border-radius:0 !important; min-height:auto !important; padding-bottom:60px !important; }
  .sicg-modal-back-bottom { display:block !important; width:calc(100% - 40px) !important; margin:12px 20px 40px !important; padding:14px !important; background:transparent !important; color:rgba(255,255,255,0.5) !important; border:1px solid rgba(255,255,255,0.15) !important; border-radius:50px !important; font-size:14px !important; font-weight:500 !important; cursor:pointer !important; text-align:center !important; }
  .sicg-artist-bio-overlay a[href*="reservix"] { display:block !important; width:calc(100% - 40px) !important; margin:12px 20px !important; padding:16px !important; border-radius:50px !important; text-align:center !important; background:rgba(229,0,109,0.15) !important; border:1px solid rgba(229,0,109,0.25) !important; color:#fff !important; font-size:13px !important; font-weight:600 !important; letter-spacing:1px !important; text-transform:uppercase !important; }
}

/* ========================================= */
/* SMALL PHONE <= 480px                      */
/* ========================================= */
@media (max-width: 480px) {
  .sicg-hero-title { font-size: 26px !important; }
  .sicg-hero-edition { font-size: 8px !important; letter-spacing: 1.5px !important; }
  .sicg-hero-sub { font-size: 11px !important; margin-bottom: 35vh !important; }
  .sicg-hero-buttons a { width: 85% !important; font-size: 13px !important; }
  .sicg-stundenplan-grid { grid-template-columns: 1fr !important; }
}
/* Complianz Document Styling for Dark Theme */
.cmplz-document { max-width:800px !important; margin:0 auto !important; padding:0 24px !important; }
.cmplz-document h1, .cmplz-document h2, .cmplz-document h3 { color:#fff !important; }
.cmplz-document h2 { font-size:22px !important; margin-top:40px !important; }
.cmplz-document p, .cmplz-document li, .cmplz-document td, .cmplz-document th { color:rgba(255,255,255,0.7) !important; font-size:15px !important; line-height:1.8 !important; }
.cmplz-document a { color:#E5006D !important; }
.cmplz-document table { border-color:rgba(255,255,255,0.1) !important; }
.cmplz-document th { background:rgba(255,255,255,0.05) !important; }
.cmplz-document td, .cmplz-document th { border-color:rgba(255,255,255,0.1) !important; padding:10px !important; }