/* GANTRY5 DEVELOPMENT MODE ENABLED.
 *
 * WARNING: This file is automatically generated by Gantry5. Any modifications to this file will be lost!
 *
 * For more information on modifying CSS, please read:
 *
 * http://docs.gantry.org/gantry5/configure/styles
 * http://docs.gantry.org/gantry5/tutorials/adding-a-custom-style-sheet
 */

@charset "UTF-8";
/* =========================================================
 * CASIA2 – FINAL CSS MASTER
 * =========================================================
 * Struktur:
 *  1) Typography / Global Base
 *  2) Global Layout / Sticky Footer
 *  3) Desktop Navigation
 *  4) Product Details Hero
 *  5) Hero Accordion
 *  6) Detail Blocks
 *  7) Common Section Spacing
 *  8) Further Questions Section
 *  9) Footer
 * 10) Reusable Cards / Buttons
 * 11) User Experience Page
 * 12) Videos Page
 * 13) Downloads Page
 * 14) Specialist Articles Page
 * 15) Responsive Card / Grid Pages
 * 16) Contact Intro + VisForms
 * 17) Hero Slider Addon
 * 18) Joomla Content Cleanup
 * 19) Mobile Menu – Final
 * 20) Mobile Fix – Product Details Hero
 * 21) Global Helpers
 * 22) Download Button Arrow
 * 23) Legal Pages
 * 24) Case Pages – Final
 * ========================================================= */
/* =========================================================
 * 1) TYPOGRAPHY / GLOBAL BASE
 * ========================================================= */
/* Optional previous font setup (not used)
 @ *import url('https://fonts.googleapis.com/css2?family=Lato:wght@600;700&family=Source+Sans+3:wght@300;400;500;600&display=swap');
 */
@import url("https://fonts.googleapis.com/css2?family=Lato:wght@300;400;700;900&display=swap");
:root {
  --casia-blue: #0a1e5f;
  --casia-blue-accent: #00528c;
  --casia-red: #ff373b;
}
html, body {
  min-height: 100%;
  height: 100%;
}
body {
  margin: 0;
  min-height: 100vh;
  font-family: "Lato", Arial, sans-serif;
  color: var(--casia-blue);
}
/* =========================================================
 * 2) GLOBAL LAYOUT / STICKY FOOTER
 * ========================================================= */
#g-page-surround {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
#g-navigation, #g-header, #g-intro, #g-features, #g-utility, #g-above, #g-testimonials, #g-expanded, #g-container-main, #g-bottom {
  flex: 0 0 auto;
}
#g-expanded, #g-container-main, #g-bottom {
  width: 100%;
}
#g-footer {
  margin-top: auto !important;
  flex: 0 0 auto;
}
#g-page-surround > .g-container, #g-page-surround > .platform-content, #g-page-surround > .system-content {
  width: 100%;
}
#g-page-surround .g-grid {
  min-width: 0;
}
/* =========================================================
 * 3) DESKTOP NAVIGATION
 * ========================================================= */
#g-navigation {
  background: #ffffff !important;
  border-bottom: 1px solid rgba(10, 30, 95, 0.12) !important;
  padding: 12px 0 !important;
  position: relative !important;
}
#g-navigation .g-container {
  max-width: 1380px !important;
}
#g-navigation .g-grid {
  display: flex !important;
  align-items: center !important;
}
#g-navigation .g-content {
  margin: 0 !important;
}
#g-navigation .logo, #g-navigation .g-logo {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
}
#g-navigation .logo img, #g-navigation .g-logo img {
  display: block !important;
  max-height: 42px !important;
  height: auto !important;
  width: auto !important;
  opacity: 1 !important;
  visibility: visible !important;
}
#g-navigation .g-block:first-child {
  flex: 0 0 185px !important;
  max-width: 185px !important;
}
#g-navigation .g-block:nth-child(2) {
  display: block !important;
}
.g-main-nav {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  width: 100%;
  text-align: right !important;
  position: relative;
  top: 0;
  padding-right: 8px;
}
.g-main-nav .g-toplevel {
  display: flex !important;
  justify-content: flex-end !important;
  align-items: center !important;
  gap: 28px !important;
  flex-wrap: nowrap !important;
}
.g-main-nav .g-toplevel > li {
  margin: 0 !important;
}
.g-main-nav .g-toplevel > li > .g-menu-item-container {
  display: flex;
  align-items: center;
  height: 100%;
  position: relative;
  font-family: "Lato", Arial, sans-serif !important;
  font-size: 0.9rem !important;
  font-weight: 500 !important;
  line-height: 1.35 !important;
  letter-spacing: 0.01em !important;
  color: #0a1e5f !important;
  padding: 6px 0 !important;
  background: transparent !important;
  opacity: 1 !important;
  text-shadow: none !important;
  transition: color 0.2s ease, opacity 0.2s ease, background-color 0.2s ease, border-color 0.2s ease;
}
.g-main-nav .g-toplevel > li:not(:last-child) > .g-menu-item-container:hover {
  color: #00528c !important;
  opacity: 1;
}
.g-main-nav .g-toplevel > li.active > .g-menu-item-container, .g-main-nav .g-toplevel > li.current > .g-menu-item-container, .g-main-nav .g-toplevel > li.active.current > .g-menu-item-container {
  color: #0a1e5f !important;
  border-bottom: 2px solid #0a1e5f !important;
  padding-bottom: 6px !important;
}
.g-main-nav .g-toplevel > li.active, .g-main-nav .g-toplevel > li.current {
  opacity: 1 !important;
}
.g-main-nav .g-toplevel > li:last-child {
  display: flex;
  align-items: center;
  margin-left: 8px;
}
.g-main-nav .g-toplevel > li:last-child > .g-menu-item-container, .g-main-nav .g-toplevel > li:last-child > .g-menu-item-container:hover, .g-main-nav .g-toplevel > li:last-child > .g-menu-item-container:focus, .g-main-nav .g-toplevel > li:last-child.g-active > .g-menu-item-container {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 92px !important;
  height: 38px !important;
  padding: 0 16px !important;
  border: 1.5px solid #ff373b !important;
  border-radius: 0 0 0 18px !important;
  -webkit-border-radius: 0 0 0 18px !important;
  color: #ff373b !important;
  font-family: "Lato", Arial, sans-serif !important;
  font-size: 0.9rem !important;
  font-weight: 600 !important;
  line-height: 1;
  background: transparent !important;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}
.g-main-nav .g-toplevel > li:last-child > .g-menu-item-container:hover {
  background: #ff373b !important;
  color: #ffffff !important;
  border-color: #ff373b !important;
  transform: none !important;
}
.g-main-nav .g-toplevel > li:last-child.active > .g-menu-item-container, .g-main-nav .g-toplevel > li:last-child.current > .g-menu-item-container {
  background: transparent !important;
  color: #ff373b !important;
  border-color: #ff373b !important;
  border-bottom: 1.5px solid #ff373b !important;
  padding-bottom: 0 !important;
}
@media (max-width: 1200px) {
  #g-navigation .g-block:first-child {
    flex: 0 0 165px !important;
    max-width: 165px !important;
  }
  .g-main-nav .g-toplevel {
    gap: 20px !important;
  }
  .g-main-nav .g-toplevel > li > .g-menu-item-container {
    font-size: 0.85rem !important;
  }
}
@media (max-width: 960px) {
  .g-main-nav .g-toplevel {
    gap: 14px !important;
  }
  .g-main-nav {
    padding-right: 0 !important;
  }
}
/* =========================================================
 * 4) PRODUCT DETAILS HERO
 * ========================================================= */
#g-header {
  padding: 0 !important;
  margin: 0 !important;
  padding-top: 80px !important;
  padding-bottom: 8px !important;
}
#g-header .g-container {
  max-width: 100% !important;
  width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}
#g-header .g-content {
  margin: 0 !important;
  padding: 0 !important;
}
.casia-hero-clean {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  width: 100%;
  max-width: 100%;
  min-height: 640px;
  margin: 0;
  background: #fff;
}
.casia-hero-clean__media {
  min-height: 640px;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  transition: opacity 0.35s ease;
}
.casia-hero-clean__panel {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  min-height: 640px;
  padding: 80px 50px 80px 60px;
  color: #fff;
  background: url('../../../../images/accordion-background.jpg') center center / cover no-repeat;
}
.casia-hero-clean__title {
  margin: 0 0 8px;
  font-family: "Lato", Arial, sans-serif;
  font-size: 3.55rem;
  line-height: 1;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: #fff;
}
.casia-hero-clean__subtitle {
  margin: 0 0 18px;
  font-size: 1.28rem;
  line-height: 1.25;
  font-weight: 300;
  font-style: italic;
  color: rgba(255, 255, 255, 0.96);
}
.casia-hero-clean__lead {
  margin: 0 0 20px;
  max-width: 600px;
  font-size: 0.98rem;
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.96);
}
/* =========================================================
 * 5) HERO ACCORDION
 * ========================================================= */
.casia-hero-clean__accordion {
  margin: 8px 0 0;
  padding: 0;
  max-width: 80%;
}
.casia-accordion .item {
  border-bottom: 1px solid rgba(255, 255, 255, 0.22);
}
.casia-accordion .title {
  cursor: pointer;
  position: relative;
  padding: 16px 28px 16px 0;
  color: rgba(255, 255, 255, 0.92);
  font-size: 18px;
  line-height: 1.4;
  font-weight: 500;
  letter-spacing: 0.2px;
  transition: color 0.2s ease;
}
.casia-accordion .title:hover {
  color: #ffffff;
  opacity: 1;
}
.casia-accordion .title::after {
  content: "›";
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  color: #ff373b;
  font-size: 24px;
  font-weight: 700;
  transition: transform 0.25s ease;
}
.casia-accordion .item.active .title::after {
  transform: translateY(-50%) rotate(90deg);
}
.casia-accordion .content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.45s ease;
}
.casia-accordion .item.active .content {
  max-height: 2600px;
}
.casia-accordion .content > p, .casia-accordion .content > div:not(.casia-detail-block) {
  color: rgba(255, 255, 255, 0.78);
  font-size: 15px;
  line-height: 1.7;
  padding: 0 0 18px 0;
}
/* =========================================================
 * 6) DETAIL BLOCKS
 * ========================================================= */
.casia-detail-block {
  padding: 18px 0 10px 0;
}
.casia-detail-block__headline {
  margin: 0 0 24px 0;
  font-size: 30px;
  line-height: 1.1;
  font-weight: 700;
  letter-spacing: 1px;
  color: #ffffff;
  text-transform: uppercase;
}
.casia-detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 22px;
  align-items: start;
}
.casia-detail-item {
  display: flex;
  flex-direction: column;
}
.casia-detail-item img {
  display: block;
  width: 100%;
  aspect-ratio: 1.6;
  height: auto;
  object-fit: contain;
  margin-bottom: 14px;
  border-radius: 4px;
  background: #ffffff;
  padding: 6px;
  border: 1px solid rgba(255, 255, 255, 0.18);
}
.casia-detail-item p {
  margin: 0;
  color: rgba(255, 255, 255, 0.88);
  font-size: 14px;
  line-height: 1.6;
}
/* =========================================================
 * 7) COMMON SECTION SPACING
 * ========================================================= */
#g-intro, #g-features, #g-utility, #g-expanded, #g-bottom, #g-footer {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}
#g-intro, #g-features, #g-utility, #g-bottom {
  padding: 80px 0;
}
/* =========================================================
 * 8) FURTHER QUESTIONS SECTION
 * ========================================================= */
#g-expanded {
  background: #ffffff !important;
  padding: 0 !important;
}
#g-expanded .g-content {
  margin: 0 !important;
  padding: 0 !important;
}
.casia-questions {
  max-width: 1200px;
  margin: 0 auto;
  padding: 44px 20px 40px;
  text-align: center;
  background: transparent;
}
.casia-questions h2 {
  margin: 0 0 12px;
  font-family: "Lato", Arial, sans-serif;
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: #0a1e5f;
}
.casia-questions p {
  max-width: 620px;
  margin: 0 auto 14px;
  font-size: 0.98rem;
  line-height: 1.5;
  color: #000000;
}
.casia-contact-link {
  display: inline-block;
  color: #000000;
  text-decoration: none;
  border-bottom: 1px solid #0a1e5f;
  padding-bottom: 2px;
  font-size: 0.95rem;
}
.casia-contact-link span {
  color: #ff373b;
  margin-left: 6px;
}
/* =========================================================
 * 9) FOOTER
 * ========================================================= */
#g-footer {
  padding: 0 !important;
  border-top: 1px solid #d9dee6;
  background: url('../../../../images/footer-background.jpg') center center / cover no-repeat;
}
#g-footer .g-content {
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}
.casia-footer {
  max-width: 1280px;
  margin: 0 auto;
  padding: 60px 40px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.footer-left {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.footer-links {
  display: flex;
  gap: 40px;
}
.footer-links a {
  color: #0a1e5f;
  text-decoration: none;
  font-size: 0.95rem;
}
.footer-links a:hover {
  color: #3a6fb0 !important;
}
.footer-social {
  display: flex;
  align-items: center;
  gap: 14px;
}
.footer-social a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.2s ease, opacity 0.2s ease;
}
.footer-social img {
  height: 26px;
  width: auto;
  display: block;
}
.footer-social a:hover {
  transform: translateY(-2px);
  opacity: 0.85;
}
.footer-right img {
  height: 42px;
  width: auto;
}
/* =========================================================
 * 10) REUSABLE CARDS / BUTTONS
 * ========================================================= */
.casia-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: auto;
  padding: 11px 14px;
  background: #0a1e5f;
  color: #fff;
  text-align: center;
  text-decoration: none;
  font-size: 0.95rem;
  font-weight: 600;
  border-bottom-left-radius: 16px;
  border-bottom-right-radius: 0;
  transition: background-color 0.18s ease, transform 0.18s ease;
}
.casia-btn:hover {
  background: #0a1e5f;
  color: #fff;
  text-decoration: none;
  transform: translateY(-1px);
}
.casia-card, .casia-video-card, .casia-download-card, .casia-article-card {
  position: relative;
  background: #fff;
  border: 1px solid #5d6f9a;
  border-radius: 0 0 0 18px;
  overflow: visible !important;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}
.casia-card:hover, .casia-video-card:hover, .casia-download-card:hover, .casia-article-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 10px 24px rgba(10, 30, 95, 0.08);
  border-color: #0a1e5f;
}
.casia-card::before, .casia-video-card::before, .casia-download-card::before, .casia-article-card::before {
  content: "+";
  position: absolute;
  top: -12px;
  left: -8px;
  color: #ff373b;
  font-size: 26px;
  font-weight: 700;
  line-height: 1;
}
/* =========================================================
 * 11) USER EXPERIENCE PAGE
 * ========================================================= */
.casia-user-exp {
  max-width: 1320px;
  margin: 0 auto;
  padding: 46px 20px 28px;
}
.casia-user-exp h2 {
  margin: 0 0 34px;
  font-family: "Lato", Arial, sans-serif;
  font-size: 2.25rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: #0a1e5f;
}
.casia-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px 26px;
}
.casia-card {
  padding: 14px 14px 16px;
  display: flex;
  flex-direction: column;
  min-height: 100%;
}
.casia-card img {
  display: block;
  width: 100%;
  aspect-ratio: 1.3333333333;
  object-fit: contain;
  margin-bottom: 12px;
  background: #ffffff;
}
.casia-card .case, .casia-card h3, .casia-card p {
  color: #000000;
}
.casia-card .case {
  margin: 0 0 6px;
  font-size: 0.95rem;
}
.casia-card h3 {
  margin: 0 0 14px;
  font-size: 1.12rem;
  line-height: 1.35;
  font-style: italic;
  font-weight: 300;
  letter-spacing: -0.01em;
}
.casia-card p {
  margin: 0 0 18px;
  font-size: 0.92rem;
  line-height: 1.55;
}
/* =========================================================
 * 12) VIDEOS PAGE
 * ========================================================= */
.casia-videos-page {
  max-width: 1320px;
  margin: 0 auto;
  padding: 42px 20px 26px;
}
.casia-videos-page h2 {
  margin: 0 0 28px;
  font-family: "Lato", Arial, sans-serif;
  font-size: 2.25rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: #0a1e5f;
}
.casia-video-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 26px 22px;
}
.casia-video-card {
  padding: 10px 12px 16px;
}
.casia-video-thumb {
  position: relative;
  display: block;
  width: 100%;
  height: 200px;
  overflow: hidden;
  margin-bottom: 12px;
  padding: 0;
  border: 0;
  background: #f3f5f8;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
}
.casia-video-thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}
.casia-video-thumb:hover img {
  transform: scale(1.05);
}
body.casia-modal-open {
  overflow: hidden;
}
.casia-play-btn {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 72px;
  height: 72px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.85);
  color: #0a1e5f;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  line-height: 1;
  pointer-events: none;
  transition: all 0.25s ease;
}
.casia-video-thumb:hover .casia-play-btn {
  transform: translate(-50%, -50%) scale(1.1);
  background: #ffffff;
}
.casia-video-card .case {
  margin: 0 0 6px;
  font-size: 0.95rem;
  color: #0a1e5f;
}
.casia-video-card h3 {
  margin: 0;
  font-size: 1.12rem;
  line-height: 1.35;
  font-style: italic;
  font-weight: 300;
  letter-spacing: -0.01em;
  color: #0a1e5f;
}
/* Video Modal */
.casia-video-modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 9999;
}
.casia-video-modal.is-open {
  display: flex;
}
.casia-video-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.75);
}
.casia-video-modal__content {
  position: relative;
  width: min(1000px, 92vw);
  max-height: 90vh;
  z-index: 2;
}
.casia-video-modal__content video {
  width: 100%;
  max-height: 90vh;
  display: block;
  background: #000;
}
.casia-video-modal__close {
  position: absolute;
  top: -44px;
  right: 0;
  background: transparent;
  border: 0;
  color: #fff;
  font-size: 40px;
  cursor: pointer;
  line-height: 1;
}
/* =========================================================
 * 13) DOWNLOADS PAGE
 * ========================================================= */
.casia-downloads-page {
  max-width: 1320px;
  margin: 0 auto;
  padding: 42px 20px 28px;
}
.casia-downloads-page h2 {
  margin: 0 0 26px;
  font-family: "Lato", Arial, sans-serif;
  font-size: 2.25rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: #0a1e5f;
}
.casia-download-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 26px 22px;
}
.casia-download-card {
  padding: 14px 12px 10px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.casia-download-card img {
  display: block;
  width: 100%;
  height: 250px;
  object-fit: contain;
  margin: 0 0 16px;
}
.casia-download-card h3 {
  margin: 0 0 6px;
  font-family: "Lato", Arial, sans-serif;
  font-size: 1.05rem;
  font-weight: 700;
  color: #0a1e5f;
}
.casia-download-card p {
  margin: 0 0 16px;
  font-size: 1.1rem;
  line-height: 1.25;
  font-style: italic;
  font-weight: 300;
  letter-spacing: -0.01em;
  color: #0a1e5f;
}
/* =========================================================
 * 14) SPECIALIST ARTICLES PAGE
 * ========================================================= */
.casia-articles-page {
  max-width: 1320px;
  margin: 0 auto;
  padding: 42px 20px 28px;
}
.casia-articles-page h2 {
  margin: 0 0 26px;
  font-family: "Lato", Arial, sans-serif;
  font-size: 2.25rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: #0a1e5f;
}
.casia-articles-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 26px 22px;
}
.casia-article-card {
  padding: 14px 12px 10px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.casia-article-card img {
  display: block;
  width: 100%;
  height: 132px;
  object-fit: cover;
  margin: 0 0 18px;
}
.casia-article-card h3, .casia-article-card p {
  color: #000000;
}
.casia-article-card h3 {
  margin: 0 0 18px;
  font-size: 1.12rem;
  line-height: 1.35;
  font-style: italic;
  font-weight: 300;
  letter-spacing: -0.01em;
}
/* =========================================================
 * 15) RESPONSIVE CARD / GRID PAGES
 * ========================================================= */
@media (min-width: 1400px) {
  .casia-user-exp, .casia-videos-page, .casia-downloads-page, .casia-articles-page {
    max-width: 1360px;
  }
}
@media (max-width: 1200px) {
  .casia-cards {
    grid-template-columns: repeat(3, 1fr);
  }
  .casia-video-grid, .casia-download-grid, .casia-articles-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 900px) {
  .casia-user-exp, .casia-videos-page, .casia-downloads-page, .casia-articles-page {
    padding: 34px 18px 20px;
  }
  .casia-cards, .casia-video-grid, .casia-download-grid, .casia-articles-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 24px 20px;
  }
}
@media (max-width: 640px) {
  .casia-cards, .casia-video-grid, .casia-download-grid, .casia-articles-grid {
    grid-template-columns: 1fr;
  }
  .casia-user-exp h2, .casia-videos-page h2, .casia-downloads-page h2, .casia-articles-page h2 {
    margin-bottom: 22px;
    font-size: 1.9rem;
  }
  .casia-card, .casia-video-card, .casia-download-card, .casia-article-card {
    padding-left: 12px;
    padding-right: 12px;
  }
}
/* =========================================================
 * 16) CONTACT INTRO + VISFORMS
 * ========================================================= */
.casia-contact-intro {
  max-width: 1040px;
  margin: 0 auto;
  padding: 52px 20px 8px;
}
.casia-contact-intro h1 {
  margin: 0 0 34px;
  font-family: "Lato", Arial, sans-serif;
  font-size: 3rem;
  font-weight: 700;
  color: #0a1e5f;
}
.casia-contact-intro__lead {
  margin: 0 0 26px;
  font-size: 1.1rem;
  line-height: 1.2;
  font-weight: 700;
  color: #0a1e5f;
}
.casia-contact-intro__text, .casia-contact-intro__note {
  margin: 0 0 16px;
  font-size: 0.98rem;
  line-height: 1.55;
  color: #000000;
}
.casia-contact-intro h2 {
  margin: 42px 0 14px;
  font-family: "Lato", Arial, sans-serif;
  font-size: 2rem;
  font-weight: 700;
  color: #0a1e5f;
}
/* =================================
 * VISFORMS CONTACT – FINAL CLEAN
 * ================================= */
/* Formular Container */
.visform, .visforms, form.visform, form.visforms {
  max-width: 1040px;
  margin: 0 auto !important;
  padding: 0 5px 60px;
  box-sizing: border-box;
}
#g-container-main .visform, #g-container-main .visforms {
  margin-left: auto !important;
  margin-right: auto !important;
}
/* Feldgruppen */
.visform .control-group, .visforms .control-group, .visform .visControlGroup, .visforms .visControlGroup {
  box-sizing: border-box;
  margin-bottom: 18px;
  margin-left: 0 !important;
  padding-left: 0 !important;
}
/* 2-Spalten Layout */
.visform .vf-half, .visforms .vf-half {
  width: calc(50% - 18px);
  float: left;
}
.visform .vf-left, .visforms .vf-left {
  margin-right: 36px;
  clear: left;
}
.visform .vf-right, .visforms .vf-right {
  margin-right: 0;
}
.visform .vf-full, .visforms .vf-full {
  width: 100%;
  float: none;
  clear: both;
  display: block;
  margin-left: 0 !important;
  padding-left: 0 !important;
}
/* Labels */
.visform label, .visforms label, .visform .control-label, .visforms .control-label, .visform .visCSSlabel, .visforms .visCSSlabel {
  display: block;
  margin-bottom: 2px !important;
  margin-left: 0 !important;
  padding-left: 0 !important;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.4;
  color: #0a1e5f;
}
.visform label .required, .visforms label .required {
  margin-left: 4px !important;
}
form#mod-visform1 div.required > label.visCSSlabel::after, form#mod-visform1 div.required > label.vflocationlabel::after {
  padding-left: 4px !important;
  color: #ff4d4f !important;
}
/* Inputs */
.visform input[type="text"], .visform input[type="email"], .visform input[type="tel"], .visform input[type="number"], .visform select, .visform textarea, .visforms input[type="text"], .visforms input[type="email"], .visforms input[type="tel"], .visforms input[type="number"], .visforms select, .visforms textarea {
  width: 100%;
  min-height: 40px;
  padding: 10px 14px;
  border: 1px solid #0a1e5f;
  background: #ffffff;
  color: #1a1a1a;
  font-size: 1rem;
  box-sizing: border-box;
  box-shadow: none;
}
.visform textarea, .visforms textarea {
  min-height: 92px;
  height: 92px;
  resize: vertical;
}
.visform input::placeholder, .visform textarea::placeholder, .visforms input::placeholder, .visforms textarea::placeholder {
  color: #b5b5b5;
}
.visform input:focus, .visform select:focus, .visform textarea:focus, .visforms input:focus, .visforms select:focus, .visforms textarea:focus {
  outline: none;
  border-color: #0a1e5f;
  box-shadow: 0 0 0 1px #0a1e5f;
}
/* Hinweise */
.visform .field-description, .visforms .field-description, .visform .customtext, .visforms .customtext {
  margin-top: 8px;
  font-size: 0.95rem;
  color: #6f6f6f !important;
}
/* Required */
.visform .required, .visforms .required {
  color: #ff373b !important;
}
/* Terms + Checkboxen */
.visform .field6 > div[class^="fc-"], .visform .field7 > div[class^="fc-"], .visforms .field6 > div[class^="fc-"], .visforms .field7 > div[class^="fc-"] {
  display: none !important;
}
.visform .field6.vf-terms-start, .visforms .field6.vf-terms-start {
  display: grid !important;
  grid-template-columns: 18px 1fr !important;
  grid-template-rows: auto auto !important;
  column-gap: 14px !important;
  row-gap: 0 !important;
  max-width: 760px !important;
  margin: 34px 0 16px !important;
  clear: both !important;
}
.visform .field6.vf-terms-start::before, .visforms .field6.vf-terms-start::before {
  content: "Terms and conditions of use";
  grid-column: 1 / -1 !important;
  grid-row: 1 !important;
  display: block !important;
  margin: 0 0 18px 0 !important;
  font-family: "Lato", Arial, sans-serif !important;
  font-size: 1.45rem !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  color: #0a1e5f !important;
}
.visform .field6, .visform .field7, .visforms .field6, .visforms .field7 {
  max-width: 760px !important;
  display: grid !important;
  grid-template-columns: 18px 1fr !important;
  column-gap: 14px !important;
  align-items: start !important;
  margin: 0 0 16px !important;
  clear: both !important;
}
.visform .field6 > input[type="checkbox"], .visform .field7 > input[type="checkbox"], .visforms .field6 > input[type="checkbox"], .visforms .field7 > input[type="checkbox"] {
  grid-column: 1 !important;
  grid-row: 1 !important;
  width: 16px !important;
  height: 16px !important;
  margin: 4px 0 0 0 !important;
  accent-color: #000000 !important;
}
.visform .field6.vf-terms-start > input[type="checkbox"], .visforms .field6.vf-terms-start > input[type="checkbox"] {
  grid-column: 1 !important;
  grid-row: 2 !important;
}
.visform .field6 > label.visCSSlabel.visCheckbox, .visform .field7 > label.visCSSlabel.visCheckbox, .visforms .field6 > label.visCSSlabel.visCheckbox, .visforms .field7 > label.visCSSlabel.visCheckbox {
  grid-column: 2 !important;
  grid-row: 1 !important;
  float: none !important;
  width: auto !important;
  max-width: 700px !important;
  display: block !important;
  margin: 0 !important;
  line-height: 1.6 !important;
  color: #000000 !important;
  font-weight: 700 !important;
}
.visform .field6.vf-terms-start > label.visCSSlabel.visCheckbox, .visforms .field6.vf-terms-start > label.visCSSlabel.visCheckbox {
  grid-column: 2 !important;
  grid-row: 2 !important;
}
.visform .field6 > p.visCSSClear, .visform .field7 > p.visCSSClear, .visforms .field6 > p.visCSSClear, .visforms .field7 > p.visCSSClear {
  display: none !important;
}
/* CAPTCHA */
.visform .captchaCont > div[class^="fc-"], .visforms .captchaCont > div[class^="fc-"] {
  display: none !important;
}
.visform .captchaCont, .visforms .captchaCont {
  font-size: 0 !important;
  line-height: 0 !important;
  max-width: 760px !important;
  display: grid !important;
  grid-template-columns: 72px 180px 280px !important;
  column-gap: 12px !important;
  align-items: center !important;
  margin: 12px 0 24px !important;
  clear: both !important;
}
.visform .captchaCont > label.visCSSlabel, .visforms .captchaCont > label.visCSSlabel, .visform .captchaCont > img.captcha, .visforms .captchaCont > img.captcha, .visform .captchaCont > input[type="text"], .visforms .captchaCont > input[type="text"] {
  font-size: initial !important;
  line-height: normal !important;
}
.visform .captchaCont > label.visCSSlabel, .visforms .captchaCont > label.visCSSlabel {
  grid-column: 1 !important;
  grid-row: 1 !important;
  float: none !important;
  width: auto !important;
  margin: 0 !important;
  white-space: nowrap !important;
  color: #0a1e5f !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
  align-self: center !important;
}
.visform .captchaCont > img.captcha, .visforms .captchaCont > img.captcha {
  grid-column: 2 !important;
  grid-row: 1 !important;
  display: block !important;
  width: 180px !important;
  max-width: 180px !important;
  height: auto !important;
  margin: 0 !important;
  align-self: center !important;
  vertical-align: middle !important;
}
.visform .captchaCont > input[type="text"], .visforms .captchaCont > input[type="text"] {
  grid-column: 3 !important;
  grid-row: 1 !important;
  width: 280px !important;
  min-width: 280px !important;
  max-width: 280px !important;
  min-height: 40px !important;
  margin: 0 !important;
  border: 1px solid #0a1e5f !important;
  padding: 10px 14px !important;
  box-sizing: border-box !important;
  align-self: center !important;
}
.visform .captchaCont > img.captcharefresh, .visforms .captchaCont > img.captcharefresh {
  display: none !important;
}
.visform .captchaCont p, .visforms .captchaCont p {
  margin: 0 !important;
}
/* Button */
.visform .visBtnCon, .visforms .visBtnCon {
  display: block !important;
  text-align: left !important;
  max-width: 760px !important;
  margin-top: 8px !important;
}
.visform input[type="submit"], .visforms input[type="submit"], .visform button, .visforms button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 120px !important;
  min-width: 120px !important;
  height: 38px !important;
  padding: 0 14px !important;
  margin: 0 !important;
  border: 1px solid #ff373b !important;
  border-radius: 0 0 0 12px !important;
  background: transparent !important;
  color: #ff373b !important;
  font-size: 0.96rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  box-shadow: none !important;
  cursor: pointer !important;
}
.visform input[type="submit"]:hover, .visforms input[type="submit"]:hover, .visform button:hover, .visforms button:hover {
  background: #ff373b !important;
  color: #ffffff !important;
}
/* clearfix */
.visform::after, .visforms::after {
  content: "";
  display: block;
  clear: both;
}
/* Mobile */
@media (max-width: 900px) {
  .visform .vf-half, .visforms .vf-half, .visform .vf-left, .visforms .vf-left, .visform .vf-right, .visforms .vf-right {
    width: 100%;
    float: none;
    margin-right: 0;
    clear: both;
  }
  .visform textarea, .visforms textarea {
    min-height: 110px;
    height: 110px;
  }
  .visform .field6, .visform .field7, .visforms .field6, .visforms .field7 {
    grid-template-columns: 18px 1fr !important;
  }
  .visform .captchaCont, .visforms .captchaCont {
    grid-template-columns: 1fr !important;
    row-gap: 12px !important;
    font-size: initial !important;
    line-height: normal !important;
  }
  .visform .captchaCont > label.visCSSlabel, .visforms .captchaCont > label.visCSSlabel, .visform .captchaCont > img.captcha, .visforms .captchaCont > img.captcha, .visform .captchaCont > input[type="text"], .visforms .captchaCont > input[type="text"] {
    grid-column: auto !important;
    grid-row: auto !important;
  }
  .visform .captchaCont > img.captcha, .visforms .captchaCont > img.captcha {
    width: 180px !important;
    max-width: 100% !important;
  }
  .visform .captchaCont > input[type="text"], .visforms .captchaCont > input[type="text"] {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }
}
/* =========================================================
 * 17) HERO SLIDER ADDON
 * ========================================================= */
.casia-hero-clean__media-wrap {
  position: relative;
  min-height: 640px;
  overflow: hidden;
  background: #f3f5f8;
}
.casia-hero-clean__media {
  width: 100%;
  height: 100%;
  min-height: 640px;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  transition: opacity 0.35s ease;
}
/* Pfeile */
.casia-hero-clean__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 42px;
  height: 42px;
  border: 0;
  background: rgba(255, 255, 255, 0.14);
  color: #ff373b;
  font-size: 34px;
  line-height: 1;
  cursor: pointer;
  z-index: 5;
  transition: background 0.2s ease;
  padding: 0;
}
.casia-hero-clean__nav:hover {
  background: rgba(255, 255, 255, 0.28);
}
.casia-hero-clean__nav--prev {
  left: 14px;
}
.casia-hero-clean__nav--next {
  right: 14px;
}
/* Dots */
.casia-hero-clean__dots {
  position: absolute;
  left: 50%;
  bottom: 18px;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  z-index: 5;
}
.casia-hero-clean__dots .dot {
  width: 9px;
  height: 9px;
  border: 0;
  border-radius: 50%;
  background: rgba(10, 30, 95, 0.25);
  cursor: pointer;
  padding: 0;
}
.casia-hero-clean__dots .dot.active {
  background: #ff373b;
}
/* Soft Fade */
.casia-hero-clean__media {
  opacity: 1;
  transition: opacity 0.42s ease;
}
.casia-hero-clean__media.is-fading-out {
  opacity: 0.18;
}
.casia-hero-clean__media.is-fading-in {
  opacity: 1;
}
/* Mobile */
@media (max-width: 900px) {
  .casia-hero-clean__media-wrap, .casia-hero-clean__media {
    min-height: 420px;
  }
}
/* Touch */
.casia-hero-clean__media-wrap {
  touch-action: pan-y;
}
/* =========================================================
 * 18) JOOMLA CONTENT CLEANUP
 * ========================================================= */
/* Joomla Artikel Meta komplett ausblenden */
.com-content-article__info, .article-info, dl.article-info {
  display: none !important;
}
/* Titel ausblenden (globale Artikelansicht) */
.com-content-article h1, .com-content-article__title {
  display: none !important;
}
/* Field-Liste / Meta-Feld-Ausgabe ausblenden */
.fields-container {
  display: none !important;
}
.field-entry {
  display: none !important;
}
/* =========================================================
 * 19) MOBILE MENU – CASIA2 / TOMEY STYLE
 * ========================================================= */
/* 1) Hamburger Button */
@media (max-width: 900px) {
  .g-offcanvas-toggle {
    display: block !important;
    position: fixed !important;
    top: 16px !important;
    right: 18px !important;
    left: auto !important;
    transform: none !important;
    z-index: 99999 !important;
    width: 34px !important;
    height: 24px !important;
    opacity: 1 !important;
    visibility: visible !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
  }
  .g-offcanvas-toggle .fa, .g-offcanvas-toggle i, .g-offcanvas-toggle svg, .g-offcanvas-toggle span {
    display: none !important;
  }
  .g-offcanvas-toggle::before, .g-offcanvas-toggle::after {
    content: "";
    position: absolute;
    left: 0;
    width: 34px;
    height: 4px;
    background: #0a1e5f;
  }
  .g-offcanvas-toggle::before {
    top: 4px;
  }
  .g-offcanvas-toggle::after {
    top: 14px;
  }
}
/* 2) Mobile Menu Container */
@media (max-width: 900px) {
  #g-mobilemenu-container {
    background: #0a1e5f !important;
  }
  #g-mobilemenu-container ul.g-toplevel {
    margin: 0 !important;
    padding: 0 !important;
    background: #0a1e5f !important;
  }
  #g-mobilemenu-container ul.g-toplevel > li.g-menu-item {
    background: transparent !important;
  }
  #g-mobilemenu-container ul.g-toplevel > li.g-menu-item > .g-menu-item-container, #g-mobilemenu-container ul.g-toplevel > li.g-menu-item > a, #g-mobilemenu-container ul.g-toplevel > li.g-menu-item > a.g-menu-item-container {
    display: block !important;
    padding: 18px 16px !important;
    background: transparent !important;
    color: #ffffff !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.22) !important;
  }
  #g-mobilemenu-container .g-menu-item-title {
    color: #ffffff !important;
  }
}
/* 3) Menu States */
@media (max-width: 900px) {
  #g-mobilemenu-container ul.g-toplevel > li.g-menu-item:hover > .g-menu-item-container, #g-mobilemenu-container ul.g-toplevel > li.g-menu-item:hover > a, #g-mobilemenu-container ul.g-toplevel > li.g-menu-item:hover > a.g-menu-item-container {
    background: #3a6fb0 !important;
    color: #ffffff !important;
  }
  #g-mobilemenu-container ul.g-toplevel > li.g-menu-item:hover .g-menu-item-title {
    color: #ffffff !important;
  }
  #g-mobilemenu-container ul.g-toplevel > li.g-menu-item.active > .g-menu-item-container, #g-mobilemenu-container ul.g-toplevel > li.g-menu-item.active > a, #g-mobilemenu-container ul.g-toplevel > li.g-menu-item.active > a.g-menu-item-container, #g-mobilemenu-container ul.g-toplevel > li.g-menu-item.current > .g-menu-item-container, #g-mobilemenu-container ul.g-toplevel > li.g-menu-item.current > a, #g-mobilemenu-container ul.g-toplevel > li.g-menu-item.current > a.g-menu-item-container {
    background: #ffffff !important;
    color: #0a1e5f !important;
  }
  #g-mobilemenu-container ul.g-toplevel > li.g-menu-item.active .g-menu-item-title, #g-mobilemenu-container ul.g-toplevel > li.g-menu-item.current .g-menu-item-title {
    color: #0a1e5f !important;
  }
}
/* 4) Optional – Fill full height */
/*
 @ *media (max-width: 900px) {
 #mobile-menu-8496-particle,
 #g-mobilemenu-container {
 background: #0a1e5f !important;
 min-height: 100vh !important;
 }
 }
 */
/* 5) Optional – Open menu from right */
/*
 @ *media (max-width: 900px) {
 html.g-offcanvas-css3.g-offcanvas-open #g-page-surround {
 transform: translate3d(-192px, 0, 0) !important;
 }

 #g-offcanvas {
 left: auto !important;
 right: 0 !important;
 }

 .g-offcanvas-left #g-offcanvas {
 left: auto !important;
 right: 0 !important;
 }

 .g-offcanvas-open .g-nav-overlay {
 left: auto !important;
 right: 0 !important;
 }

 .g-offcanvas-toggle {
 left: auto !important;
 right: 18px !important;
 }
 }
 */
/* =========================================================
 * 20) MOBILE FIX – PRODUCT DETAILS HERO
 * ========================================================= */
@media (max-width: 900px) {
  .casia-hero-clean {
    display: grid !important;
    grid-template-columns: 1fr !important;
    min-height: auto !important;
  }
  .casia-hero-clean__media-wrap, .casia-hero-clean__media {
    min-height: 320px !important;
    height: 320px !important;
  }
  .casia-hero-clean__panel {
    min-height: auto !important;
    padding: 34px 24px 36px !important;
  }
  .casia-hero-clean__title {
    font-size: 2.4rem !important;
    line-height: 1 !important;
  }
  .casia-hero-clean__subtitle {
    font-size: 1rem !important;
    margin-bottom: 16px !important;
  }
  .casia-hero-clean__lead {
    font-size: 1rem !important;
    line-height: 1.65 !important;
    margin-bottom: 18px !important;
  }
  .casia-hero-clean__accordion {
    max-width: 100% !important;
  }
  .casia-accordion .title {
    font-size: 17px !important;
    padding: 14px 24px 14px 0 !important;
  }
}
/* =========================================================
 * 21) GLOBAL HELPERS
 * ========================================================= */
/* Text selection */
html ::selection, body ::selection, *::selection {
  background: #e5e7eb !important;
  color: #0a1e5f !important;
}
html ::-moz-selection, body ::-moz-selection, *::-moz-selection {
  background: #e5e7eb !important;
  color: #0a1e5f !important;
}
/* Text on blue backgrounds – force white */
.casia-hero-clean__panel, .casia-case-page__sidebar, [class*="casia"] [style*="background"], .casia-btn {
  color: #ffffff !important;
}
.casia-hero-clean__panel *, .casia-case-page__sidebar *, .casia-btn * {
  color: #ffffff !important;
}
.casia-hero-clean__panel a, .casia-case-page__sidebar a {
  color: #ffffff !important;
}
.casia-hero-clean__panel a:hover, .casia-case-page__sidebar a:hover {
  opacity: 0.85;
}
/* =========================================================
 * 22) DOWNLOAD BUTTON ARROW
 * ========================================================= */
.download-card a, .download-card .g-button, .download-card button, a[href$=".pdf"] {
  display: inline-flex;
  align-items: center;
  position: relative;
}
.download-card a::after, .download-card .g-button::after, .download-card button::after, a[href$=".pdf"]::after {
  content: none !important;
  display: none !important;
}
.download-card a::before, .download-card .g-button::before, .download-card button::before, a[href$=".pdf"]::before {
  content: "›";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 10px;
  color: #ff373b;
  font-size: 1.6rem;
  font-weight: 600;
  line-height: 1;
  transform: translateY(-3px);
  order: 2;
}
.casia-btn .arrow {
  display: none !important;
}
/* =========================================================
 * 23) LEGAL PAGES
 * ========================================================= */
.casia-legal {
  max-width: 1040px;
  margin: 0 auto;
  padding: 36px 20px 70px;
  font-family: "Lato", Arial, sans-serif;
  color: #1a1a1a;
}
.casia-legal h1 {
  font-size: 1.15rem;
  line-height: 1.5;
  font-weight: 400;
  margin: 0 0 52px;
  color: #0a1e5f;
}
.casia-legal h2 {
  font-size: 1.75rem;
  line-height: 2.25rem;
  font-weight: 700;
  margin: 0 0 18px;
  color: #0a1e5f;
}
.casia-legal h3 {
  font-size: 1rem;
  line-height: 1.5rem;
  font-weight: 700;
  margin: 34px 0 10px;
  color: #0a1e5f;
}
.casia-legal p, .casia-legal li {
  font-size: 0.98rem;
  line-height: 1.7;
  font-weight: 400;
  margin: 0 0 14px;
  color: #1a1a1a;
}
.casia-legal ul, .casia-legal ol {
  margin: 0 0 18px 20px;
  padding: 0;
}
.casia-legal li {
  margin-bottom: 8px;
}
.casia-legal strong {
  font-weight: 700;
  color: #1a1a1a;
}
.casia-legal a {
  color: #0a1e5f;
  text-decoration: none;
}
.casia-legal a:hover {
  color: #3a6fb0;
}
.casia-legal h2 + p, .casia-legal h2 + h3, .casia-legal h3 + p {
  margin-top: 0;
}
/* =========================================================
 * 24) CASE PAGES – FINAL
 * ========================================================= */
.casia-case-page {
  max-width: 1320px;
  margin: 0 auto;
  padding: 56px 20px 40px;
}
.casia-case-page__grid {
  display: flex;
  gap: 40px;
  align-items: stretch;
}
/* LEFT SIDEBAR */
.casia-case-page__sidebar {
  flex: 0 0 300px;
  background: url('../../../../images/accordion-background.jpg') center center / cover no-repeat;
  color: #ffffff;
  padding: 36px 26px;
}
.casia-case-page__doctor + .casia-case-page__doctor {
  margin-top: 32px;
}
.casia-case-page__doctor img {
  display: block;
  width: 100%;
  max-width: 190px;
  height: auto;
  margin: 0 0 14px;
  border-radius: 0;
}
.casia-case-page__doctor h3 {
  margin: 0 0 6px;
  font-size: 1rem;
  font-weight: 700;
  color: #ffffff;
  font-family: "Lato", Arial, sans-serif;
}
.casia-case-page__doctor p {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.92);
  font-family: "Lato", Arial, sans-serif;
}
/* RIGHT CONTENT */
.casia-case-page__content {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
}
/* TOP TEXT GRID */
.casia-case-page__textgrid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  align-items: start;
}
.casia-case-page__textcol {
  min-width: 0;
}
.casia-case-page__label {
  margin: 0 0 6px;
  font-size: 0.95rem;
  font-weight: 600;
  color: #0a1e5f;
}
.casia-case-page__textcol h1 {
  margin: 0 0 18px;
  font-family: "Lato", Arial, sans-serif;
  font-size: 2.2rem;
  line-height: 1.15;
  font-weight: 300;
  font-style: italic;
  letter-spacing: -0.3px;
  color: #55627f;
}
.casia-case-page__textcol p {
  margin: 0 0 18px;
  font-size: 0.95rem;
  line-height: 1.72;
  color: #000000;
}
/* Bullets */
.casia-case-page__bullets {
  margin: 8px 0 0;
  padding: 0;
  list-style: none;
}
.casia-case-page__bullets li {
  position: relative;
  margin: 0 0 14px;
  padding-left: 18px;
  font-size: 0.95rem;
  line-height: 1.65;
  color: #000000;
}
.casia-case-page__bullets li::before {
  content: "+";
  position: absolute;
  left: 0;
  top: 0;
  color: #ff373b;
  font-weight: 700;
  line-height: 1.65;
}
/* Optional table */
.casia-case-page__table-title {
  margin: 6px 0 10px;
  font-size: 1.2rem;
  font-weight: 700;
  color: #0a1e5f;
}
.casia-case-page__table {
  width: 100%;
  border-collapse: collapse;
  margin: 0;
  font-size: 0.9rem;
}
.casia-case-page__table th, .casia-case-page__table td {
  border: 1px solid #9ba7c0;
  padding: 7px 9px;
  text-align: left;
  vertical-align: top;
}
.casia-case-page__table th {
  background: #0a1e5f;
  color: #ffffff;
  font-weight: 600;
}
/* Bottom image grid */
.casia-case-page__imagegrid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  margin-top: auto;
  padding-top: 18px;
}
.casia-case-page__imagecol {
  min-width: 0;
  display: grid;
  gap: 16px;
  align-content: start;
  margin-top: 20px;
}
.casia-case-page__imagecol figure {
  margin: 0;
}
.casia-case-page__imagecol img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 1.3333333333;
  object-fit: cover;
  border-radius: 0;
  box-shadow: none;
}
/* eigenes H1 in Case-Seiten wieder sichtbar machen */
.com-content-article .casia-case-page h1, .com-content-article__body .casia-case-page h1 {
  display: block !important;
}
/* Mobile */
@media (max-width: 900px) {
  .casia-case-page__grid {
    display: grid;
    grid-template-columns: 1fr;
  }
  .casia-case-page__sidebar {
    flex: none;
  }
  .casia-case-page__textgrid, .casia-case-page__imagegrid {
    grid-template-columns: 1fr;
    gap: 22px;
  }
  .casia-case-page__textcol h1 {
    font-size: 1.9rem;
  }
  .casia-case-page__imagegrid {
    margin-top: 22px;
    padding-top: 0;
  }
}
/*# sourceMappingURL=custom_34.css.map */