/* ImmoOS CMS Frontend v5.0.0 — ergänzt app.css um neue Block-Styles */

/* Menüs */
.cms-menu { list-style: none; margin: 0; padding: 0; }
.cms-menu-horizontal { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.cms-menu-horizontal > li { position: relative; }
.cms-menu-horizontal > li > a {
  display: inline-block; padding: 8px 12px; color: inherit; text-decoration: none;
  border-radius: 6px; font-weight: 500; transition: all .15s;
}
.cms-menu-horizontal > li.active > a,
.cms-menu-horizontal > li > a:hover { color: #2563eb; background: rgba(37,99,235,.06); }

/* Untermenüs */
.cms-submenu {
  list-style: none; margin: 0; padding: 6px; position: absolute; top: 100%; left: 0;
  background: #fff; border: 1px solid #e2e8f0; border-radius: 8px;
  box-shadow: 0 10px 30px rgba(0,0,0,.08); min-width: 200px;
  opacity: 0; visibility: hidden; transform: translateY(4px);
  transition: all .15s; z-index: 100;
}
.cms-menu-horizontal > li.has-children:hover .cms-submenu {
  opacity: 1; visibility: visible; transform: translateY(0);
}
.cms-submenu li a {
  display: block; padding: 8px 12px; color: #334155; text-decoration: none;
  border-radius: 4px; font-size: 14px;
}
.cms-submenu li a:hover { background: #f1f5f9; color: #2563eb; }

/* Vertikales Menü (Footer) */
.cms-menu-vertical { display: flex; flex-direction: column; gap: 4px; }
.cms-menu-vertical > li > a {
  display: block; padding: 4px 0; color: inherit; text-decoration: none;
  opacity: .85; font-size: 14px;
}
.cms-menu-vertical > li > a:hover { opacity: 1; color: #2563eb; }

/* Announcement */
.announcement-bar { padding: 10px 0; font-size: 13px; text-align: center; }
.announcement-bar a { text-decoration: underline; }

/* Blöcke */
.block-heading.align-center { text-align: center; }
.block-heading.align-right  { text-align: right; }
.block-rich-text { line-height: 1.7; }
.block-rich-text p { margin: 0 0 12px; }
.block-rich-text ul, .block-rich-text ol { margin: 0 0 12px 20px; }
.block-rich-text h1, .block-rich-text h2, .block-rich-text h3 { margin: 16px 0 8px; }
.block-image { margin: 16px 0; }
.block-image.align-center { text-align: center; }
.block-image.align-right  { text-align: right; }
.block-image img { max-width: 100%; height: auto; border-radius: var(--radius, 8px); }
.block-image figcaption { font-size: 13px; color: #64748b; margin-top: 6px; }
.block-button.align-center { text-align: center; }
.block-button.align-right  { text-align: right; }
.block-columns { display: grid; gap: 20px; margin: 16px 0; }
.block-columns.cols-1 { grid-template-columns: 1fr; }
.block-columns.cols-2 { grid-template-columns: 1fr 1fr; }
.block-columns.cols-3 { grid-template-columns: 1fr 1fr 1fr; }
.block-columns.cols-4 { grid-template-columns: 1fr 1fr 1fr 1fr; }
.block-columns.gap-sm { gap: 10px; }
.block-columns.gap-lg { gap: 32px; }
@media (max-width: 720px) {
  .block-columns.cols-2, .block-columns.cols-3, .block-columns.cols-4 { grid-template-columns: 1fr; }
}

/* Container-Varianten */
.container-narrow { max-width: 720px; margin: 0 auto; padding: 0 24px; }
.container-wide   { max-width: 1400px; margin: 0 auto; padding: 0 24px; }

/* Section-Varianten */
.section-lg { padding-top: 96px; padding-bottom: 96px; }
.section-sm { padding-top: 24px; padding-bottom: 24px; }
.section-dark { background: #0f172a; color: #e2e8f0; }

/* FAQ */
.faq-list { display: flex; flex-direction: column; gap: 8px; }
.faq-item { background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 8px; padding: 12px 16px; }
.faq-item summary { font-weight: 600; cursor: pointer; list-style: none; position: relative; padding-right: 24px; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: '+'; position: absolute; right: 0; top: 50%; transform: translateY(-50%); font-size: 20px; }
.faq-item[open] summary::after { content: '−'; }
.faq-answer { padding-top: 10px; line-height: 1.6; }

/* Testimonials */
.testimonial-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 20px; margin-top: 32px; }
.testimonial-card { background: #fff; padding: 20px; border-radius: 10px; box-shadow: 0 2px 8px rgba(0,0,0,.04); }
.testimonial-card blockquote { margin: 0 0 14px; font-style: italic; line-height: 1.5; }
.testimonial-author { display: flex; align-items: center; gap: 10px; }
.testimonial-author img { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; }
.testimonial-author span { display: block; font-size: 12px; color: #64748b; }

/* Video */
.video-wrapper { position: relative; padding-bottom: 56.25%; height: 0; border-radius: var(--radius, 8px); overflow: hidden; }
.video-wrapper iframe { position: absolute; inset: 0; width: 100%; height: 100%; }
.video-caption { font-size: 13px; color: #64748b; margin-top: 8px; text-align: center; }

/* Pricing */
.pricing-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 20px; margin-top: 32px; }
.pricing-card { background: #fff; padding: 28px; border-radius: 12px; border: 1px solid #e2e8f0; text-align: center; }
.pricing-card-highlight { border-color: #2563eb; border-width: 2px; transform: scale(1.03); }
.pricing-price { margin: 14px 0; }
.price-amount { font-size: 40px; font-weight: 800; }
.price-period { color: #64748b; }
.pricing-features { list-style: none; margin: 16px 0; padding: 0; text-align: left; }
.pricing-features li { padding: 6px 0; border-bottom: 1px solid #f1f5f9; font-size: 14px; }
.pricing-features li::before { content: '✓ '; color: #22c55e; font-weight: 700; }

/* Feature-Grid Spalten */
.feature-grid.cols-2 { grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); }
.feature-grid.cols-3 { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.feature-grid.cols-4 { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }

/* Footer-Social */
.footer-social { display: flex; gap: 12px; margin-top: 8px; }
.footer-social a { width: 36px; height: 36px; border-radius: 50%; background: rgba(255,255,255,.08); display: inline-flex; align-items: center; justify-content: center; }

/* Compact Icon Grid */
.compact-icon-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px; max-width: 1000px; margin: 0 auto;
}
.compact-icon-item {
  display: flex; align-items: center; gap: 10px; padding: 12px 16px;
  background: #fff; border: 1px solid #e2e8f0; border-radius: 8px;
  font-size: 14px; font-weight: 600; color: #334155;
}
.compact-icon { font-size: 18px; }

/* Contact Form */
.contact-form .form-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 12px;
}
@media (max-width: 600px) { .contact-form .form-grid { grid-template-columns: 1fr; } }
.contact-form .form-group { margin-bottom: 12px; }
.contact-form .form-label {
  display: block; font-size: 13px; font-weight: 600; color: #475569; margin-bottom: 4px;
}
.contact-form .form-input {
  width: 100%; padding: 10px 12px; border: 1px solid #d1d5db; border-radius: 6px;
  font-size: 14px; font-family: inherit;
}
.contact-form textarea.form-input { min-height: 140px; resize: vertical; }
.form-success {
  padding: 14px 18px; background: #dcfce7; color: #166534; border-radius: 8px;
  border: 1px solid #86efac; margin-bottom: 20px;
}
.form-error {
  padding: 14px 18px; background: #fee2e2; color: #991b1b; border-radius: 8px;
  border: 1px solid #fca5a5; margin-bottom: 20px;
}

/* Blog Cards (wenn via blog_teaser-Block) */
.blog-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px; margin-top: 32px;
}
.blog-card {
  background: #fff; border-radius: 10px; overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,.05); transition: transform .15s, box-shadow .15s;
}
.blog-card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,.08); }
.blog-card-img {
  height: 180px; background-color: #f1f5f9; background-size: cover; background-position: center;
}
.blog-card-body { padding: 16px 20px; }
.blog-card-body h3 { margin: 0 0 8px; font-size: 18px; line-height: 1.3; }
.blog-card-body p { margin: 0 0 12px; color: #64748b; font-size: 14px; line-height: 1.5; }
.blog-card-date { font-size: 12px; color: #94a3b8; }
