/*
 Theme Name:   GeneratePress Child – Entertainment Agency
 Theme URI:    https://www.entertainmentagency.at
 Description:  Child Theme für entertainmentagency.at mit allen EAL-Anpassungen
 Author:       Entertainment Agency
 Author URI:   https://www.entertainmentagency.at
 Template:     generatepress
 Version:      1.0.0
 License:      GNU General Public License v2 or later
 Text Domain:  generatepress-child
*/

/* ══════════════════════════════════════════════════════════════
   ENTERTAINMENT AGENCY - Custom CSS
   Migriert aus Customizer → Zusätzliches CSS
   ══════════════════════════════════════════════════════════════ */

:root {
  --ea-brand: #803877;
  --ea-brand-light: #f3eaf2;
  --ea-brand-lighter: #faf6f9;
  --ea-brand-dark: #5e2857;
  --ea-text: #1a1a1a;
  --ea-text2: #555;
  --ea-text3: #999;
  --ea-bg: #FAFAF8;
  --ea-white: #fff;
  --ea-border: #E8E5E0;
}

body {
  background: var(--ea-bg) !important;
  font-family: Helvetica, Arial, sans-serif;
  color: var(--ea-text);
  -webkit-font-smoothing: antialiased;
}

.single-portfolio .site-main,
.single-portfolio .inside-article,
.single-portfolio .entry-content,
.single-portfolio .site-content .content-area,
.single-portfolio .site-content { background: var(--ea-bg) !important; }

.single-portfolio .entry-content *,
.single-portfolio .entry-content img { border-radius: 0 !important; }

.single-portfolio .entry-header,
.single-portfolio .page-header,
.single-portfolio .post-image,
.single-portfolio .featured-image,
.single-portfolio .page-header-image-single,
.single-portfolio .entry-meta { display: none !important; }

.single-portfolio .site-content { max-width: 1400px; margin: 0 auto; padding: 0 48px; }

.page .site-content, .page .inside-article { max-width: 1400px; margin: 0 auto; }
.page .entry-content { max-width: 100%; }
.single-portfolio .inside-article { padding: 0; max-width: 100%; }
.single-portfolio .entry-content { max-width: 100%; margin: 0; }

.single-portfolio .related-projects,
.single-portfolio .post-navigation,
.single-portfolio .entry-footer { display: none; }

.ea-hero { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: start; margin-bottom: 48px; padding-top: 32px; }
.ea-hero-img img { width: 100%; aspect-ratio: 1/1; object-fit: cover; display: block; }

.ea-spotify { margin-top: 0; border: 1px solid var(--ea-border); border-top: none; overflow: hidden; }
.ea-spotify iframe { display: block; width: 100%; min-height: 352px; }

.ea-h1 { font-family: Georgia, serif; font-size: clamp(36px, 4.5vw, 52px); font-weight: 400; color: var(--ea-text); letter-spacing: -1px; line-height: 1.05; margin-bottom: 10px; }
.ea-teaser { font-family: Georgia, serif; font-size: 16px; color: var(--ea-brand); font-style: italic; margin-bottom: 24px; line-height: 1.5; }
.ea-meta { display: flex; gap: 36px; margin-bottom: 20px; padding-bottom: 20px; border-bottom: 1px solid var(--ea-border); flex-wrap: wrap; }
.ea-meta-item { font-family: Helvetica, Arial, sans-serif; font-size: 11px; color: var(--ea-text3); text-transform: uppercase; letter-spacing: 1px; }
.ea-meta-item strong { display: block; font-family: Helvetica, Arial, sans-serif; font-size: 14px; color: var(--ea-text); text-transform: none; letter-spacing: 0; margin-top: 3px; font-weight: 600; }
.ea-label { font-family: Helvetica, Arial, sans-serif; font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--ea-brand); margin-bottom: 6px; }
.ea-section-title { font-family: Georgia, serif; font-size: 20px; color: var(--ea-text); margin-bottom: 16px; }
.ea-desc { font-family: Helvetica, Arial, sans-serif; font-size: 14px; color: var(--ea-text2); line-height: 1.85; margin-bottom: 24px; }

.ea-cf7 { background: var(--ea-bg); border: 1px solid var(--ea-border); padding: 14px; }
.ea-cf7-title { font-family: Georgia, serif; font-size: 15px; color: var(--ea-text); margin-bottom: 1px; }
.ea-cf7-sub { font-family: Helvetica, Arial, sans-serif; font-size: 10px; color: var(--ea-text3); margin-bottom: 8px; }
.ea-cf7 .wpcf7 { margin: 0; padding: 0; }
.ea-cf7 .wpcf7-form { display: grid; grid-template-columns: 1fr 1fr; gap: 2px 4px; }
.ea-cf7 .wpcf7-form > p { margin: 0; grid-column: 1 / -1; }
.ea-cf7 .wpcf7-form > p.ea-half { grid-column: auto; }
.ea-cf7 .wpcf7 input[type="text"],
.ea-cf7 .wpcf7 input[type="email"],
.ea-cf7 .wpcf7 input[type="tel"],
.ea-cf7 .wpcf7 input[type="url"],
.ea-cf7 .wpcf7 select,
.ea-cf7 .wpcf7 textarea { width: 100%; padding: 8px 10px; font-size: 12px; font-family: Helvetica, Arial, sans-serif; border: 1px solid var(--ea-border); background: var(--ea-white); color: var(--ea-text); transition: border-color 0.3s; border-radius: 0 !important; -webkit-appearance: none; line-height: 1.4; box-sizing: border-box; }
.ea-cf7 .wpcf7 input:focus, .ea-cf7 .wpcf7 select:focus, .ea-cf7 .wpcf7 textarea:focus { border-color: var(--ea-brand); outline: none; }
.ea-cf7 .wpcf7 textarea { min-height: 3.6em; max-height: 3.6em; resize: none; grid-column: 1 / -1; }
.ea-cf7 .wpcf7 select { font-size: 11px; padding: 8px 10px; cursor: pointer; }
.ea-cf7 .wpcf7-form br { display: none; }
.ea-cf7 .wpcf7 label { font-size: 0; color: transparent; line-height: 0; display: block; }
.ea-cf7 .wpcf7-list-item { margin: 0 4px 2px 0; }
.ea-cf7 .wpcf7-list-item label { font-size: 10px; color: var(--ea-text2); line-height: 1.4; }
.ea-cf7 .wpcf7-acceptance { grid-column: 1 / -1; font-size: 10px; }
.ea-cf7 .wpcf7-acceptance label { font-size: 10px; color: var(--ea-text2); line-height: 1.4; }
.ea-cf7 .wpcf7-form p { font-size: 10px; line-height: 1.3; color: var(--ea-text2); }
.ea-cf7 .wpcf7 input[type="submit"], .ea-cf7 .wpcf7-submit { width: 100%; grid-column: 1 / -1; padding: 10px 16px; background: var(--ea-brand); color: #fff; border: none; font-family: Helvetica, Arial, sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 0.5px; text-transform: uppercase; cursor: pointer; transition: background 0.3s; margin-top: 2px; border-radius: 0 !important; }
.ea-cf7 .wpcf7 input[type="submit"]:hover { background: var(--ea-brand-dark); }
.ea-cf7 .wpcf7-not-valid-tip { font-size: 9px; color: #c0392b; margin-top: 1px; }
.ea-cf7 .wpcf7-response-output { font-size: 10px; padding: 4px 8px; margin: 4px 0 0 0; grid-column: 1 / -1; }
.ea-cf7 .cf-turnstile, .ea-cf7 .cf-turnstile iframe, .ea-cf7 [data-sitekey] { grid-column: 1 / -1; max-width: 100%; transform: scale(0.85); transform-origin: left top; margin-bottom: 4px; }
.ea-cf7 .wpcf7-form > p:has(.cf-turnstile), .ea-cf7 .wpcf7-form > div:has(.cf-turnstile) { grid-column: 1 / -1; }
.ea-cf7 .wpcf7-checkbox { display: flex; flex-wrap: wrap; gap: 2px 6px; grid-column: 1 / -1; }

.ea-content { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; padding-top: 48px; border-top: 1px solid var(--ea-border); margin-bottom: 48px; }

.ea-event { border: 1px solid var(--ea-border); padding: 14px 16px; margin-bottom: 8px; transition: border-color 0.3s; }
.ea-event:hover { border-color: rgba(128, 56, 119, 0.2); }
.ea-event h4 { font-family: Helvetica, Arial, sans-serif; font-size: 13px; font-weight: 600; color: var(--ea-text); margin-bottom: 3px; }
.ea-event p { font-family: Helvetica, Arial, sans-serif; font-size: 12px; color: var(--ea-text3); line-height: 1.5; margin: 0; }

.ea-hit { border: 1px solid var(--ea-border); margin-bottom: 12px; overflow: hidden; transition: border-color 0.3s; }
.ea-hit:hover { border-color: rgba(128, 56, 119, 0.2); }
.ea-hit-video { position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden; background: #111; }
.ea-hit-video iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: none; }
.ea-hit-info { padding: 10px 14px; display: flex; justify-content: space-between; align-items: center; }
.ea-hit-name { font-family: Helvetica, Arial, sans-serif; font-size: 13px; font-weight: 600; color: var(--ea-text); }
.ea-hit-detail { font-family: Helvetica, Arial, sans-serif; font-size: 11px; color: var(--ea-text3); }

.ea-related { background: #f5f3f0; border-top: 1px solid var(--ea-border); border-bottom: 1px solid var(--ea-border); padding: 48px 0; margin: 0 -48px; }
.ea-related-inner { max-width: 1200px; margin: 0 auto; padding: 0 48px; position: relative; }
.ea-related-title { font-family: Georgia, serif; font-size: 22px; color: var(--ea-text); margin-bottom: 20px; }
.ea-carousel { display: flex; gap: 12px; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; scroll-snap-type: x mandatory; padding: 0 44px; }
.ea-carousel::-webkit-scrollbar { display: none; }
.ea-carousel-card { flex: 0 0 180px; scroll-snap-align: start; overflow: hidden; border: 1px solid var(--ea-border); background: var(--ea-white); transition: all 0.3s; cursor: pointer; text-decoration: none !important; color: inherit !important; position: relative; }
.ea-carousel-card:hover { border-color: var(--ea-brand); transform: translateY(-3px); box-shadow: 0 8px 20px rgba(0, 0, 0, 0.06); }
.ea-carousel-card img { width: 100%; aspect-ratio: 1/1; object-fit: cover; display: block; }
.ea-carousel-card-overlay { position: absolute; bottom: 0; left: 0; right: 0; padding: 28px 12px 10px 12px; background: linear-gradient(transparent, rgba(0, 0, 0, 0.7)); }
.ea-carousel-card-name { font-family: Helvetica, Arial, sans-serif; font-size: 14px; font-weight: 700; color: #fff; line-height: 1.2; }
.ea-carousel-card-genre { font-family: Helvetica, Arial, sans-serif; font-size: 11px; color: rgba(255, 255, 255, 0.65); }

.ea-related .ea-arrow { position: absolute; top: 55%; transform: translateY(-50%); width: 36px; height: 36px; background: rgba(255, 255, 255, 0.92); border: 1px solid var(--ea-border); display: flex; align-items: center; justify-content: center; cursor: pointer; font-size: 16px; color: var(--ea-text2); z-index: 10; backdrop-filter: blur(8px); transition: all 0.3s; padding: 0; line-height: 1; }
.ea-related .ea-arrow:hover { border-color: var(--ea-brand); color: var(--ea-brand); }
.ea-arrow-l { left: 48px; }
.ea-arrow-r { right: 48px; }

.ea-cta { padding: 72px 0; text-align: center; }
.ea-cta-title { font-family: Georgia, serif; font-size: clamp(28px, 3.5vw, 40px); color: var(--ea-text); margin-bottom: 10px; }
.ea-cta-sub { font-family: Helvetica, Arial, sans-serif; font-size: 15px; color: var(--ea-text3); margin-bottom: 24px; }
.ea-cta-btn { display: inline-block; padding: 14px 36px; background: var(--ea-brand); color: #fff !important; font-family: Helvetica, Arial, sans-serif; font-size: 14px; font-weight: 600; letter-spacing: 0.3px; transition: all 0.3s; cursor: pointer; border: none; text-decoration: none !important; }
.ea-cta-btn:hover { background: var(--ea-brand-dark); box-shadow: 0 8px 24px rgba(128, 56, 119, 0.25); color: #fff !important; }

.site-header { background: rgba(250, 250, 248, 0.92) !important; backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); border-bottom: 1px solid #E8E5E0; box-shadow: none; }
.site-header .site-title a { color: #1a1a1a !important; font-size: 17px; font-weight: 700; letter-spacing: 0.5px; }
.site-header .site-description { color: #803877 !important; font-size: 11px; letter-spacing: 2px; text-transform: uppercase; }
.main-navigation a { color: #666 !important; font-family: Helvetica, Arial, sans-serif; font-size: 14px; font-weight: 500; }
.main-navigation a:hover { color: #803877 !important; }
.main-navigation .current-menu-item > a { color: #803877 !important; font-weight: 600; }
.site-info { background: #161418 !important; color: rgba(255, 255, 255, 0.35) !important; font-size: 12px; }
.site-info a { color: rgba(255, 255, 255, 0.5) !important; }
.site-info a:hover { color: var(--ea-brand) !important; }

@media (max-width: 767px) {
  .single-portfolio .site-content { padding: 0 20px; }
  .ea-hero { grid-template-columns: 1fr; gap: 16px; }
  .ea-hero-img { order: 1; max-height: 220px; overflow: hidden; }
  .ea-hero-img img { aspect-ratio: 16/9; max-height: 220px; }
  .ea-hero-details { order: 2; }
  .ea-h1 { font-size: 32px; }
  .ea-content { grid-template-columns: 1fr; gap: 28px; }
  .ea-col-left { order: 1; }
  .ea-col-right { order: 2; }
  .ea-cf7 .wpcf7-form { grid-template-columns: 1fr; }
  .ea-related { margin: 0 -20px; padding: 32px 0; }
  .ea-related-inner { padding: 0 20px; }
  .ea-carousel { padding: 0 36px; }
  .ea-arrow-l { left: 20px; }
  .ea-arrow-r { right: 20px; }
  .ea-related .ea-arrow { width: 30px; height: 30px; font-size: 13px; }
  .ea-cta { padding: 48px 0; }
  .ea-cta-title { font-size: 28px; }
  .page-id-startseite div[style*="grid-template-columns: repeat(3"] { grid-template-columns: 1fr !important; }
  .page-id-startseite div[style*="grid-template-columns: repeat(4"] { grid-template-columns: 1fr 1fr !important; }
}

.post-type-archive-portfolio .site-content, .tax-project_category .site-content { max-width: 1200px; margin: 0 auto; padding: 0 48px; }
.post-type-archive-portfolio .inside-article, .tax-project_category .inside-article { padding: 0; }
.post-type-archive-portfolio article, .tax-project_category article { border: 1px solid var(--ea-border); margin-bottom: 16px; padding: 0; overflow: hidden; transition: border-color 0.3s; }
.post-type-archive-portfolio article:hover, .tax-project_category article:hover { border-color: var(--ea-brand); }
.post-type-archive-portfolio .entry-title a, .tax-project_category .entry-title a { color: var(--ea-text) !important; font-size: 16px; font-weight: 600; }
.post-type-archive-portfolio .entry-title a:hover, .tax-project_category .entry-title a:hover { color: var(--ea-brand) !important; }

.entry-title { font-family: Georgia, serif; color: var(--ea-text); }
.page .entry-header { display: none; }

a { color: var(--ea-brand); }
a:hover { color: var(--ea-brand-dark); }
.entry-content a { color: var(--ea-brand); }
.entry-content a:hover { color: var(--ea-brand-dark); }

.single-portfolio h3 + p a[title] { transition: all 0.3s; }
.single-portfolio h3 + p a[title]:hover { background: #1a1a1a; }
.single-portfolio h3 + p a[title]:hover img { filter: brightness(10); }

.ea-artists-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; }
.ea-artist-card { border: 1px solid var(--ea-border); background: var(--ea-white); text-decoration: none; color: inherit; transition: all 0.3s; overflow: hidden; }
.ea-artist-card:hover { border-color: var(--ea-brand); transform: translateY(-3px); box-shadow: 0 8px 20px rgba(0,0,0,0.06); }
.ea-artist-card-img img { width: 100%; aspect-ratio: 1/1; object-fit: cover; display: block; }
.ea-artist-card-info { padding: 10px 12px; }
.ea-artist-card-name { font-size: 13px; font-weight: 600; color: var(--ea-text); }
.ea-artist-card-cat { font-size: 11px; color: var(--ea-text3); margin-top: 2px; }
@media (max-width: 900px) { .ea-artists-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 480px) { .ea-artists-grid { grid-template-columns: repeat(2, 1fr); } }

.ea-poster-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.ea-poster-grid img { width: 100%; display: block; border: 1px solid var(--ea-border); }
@media (max-width: 900px) { .ea-poster-grid { grid-template-columns: repeat(2, 1fr); } }
