/**
 * Sternschnuppe Custom CSS
 * 
 * Kritische Styles für das Sternschnuppe Theme
 * Diese Datei überschreibt Magento-Standard-Styles
 */

/* Breadcrumbs */
.breadcrumbs {
    margin-bottom: 20px !important;
}

.catalog-product-view .breadcrumbs {
    background-color: #f9de85 !important;
}

/* ============================================
   PAGE HEADER - DUNKELBLAU WIE ORIGINAL
   ============================================ */

.page-header {
    background: #003060 !important;
    border-bottom: none !important;
    box-shadow: none !important;
}

.page-header .header.content {
    background: transparent !important;
    padding: 15px 20px !important;
    max-width: 1280px !important;
    margin: 0 auto !important;
}

.header-top-bar {
    background: #003060 !important;
    padding: 10px 15px !important;
}

/* Claim Text im blauen Header - weiß */
.header-claim-text {
    color: #ffffff !important;
}

/* ============================================
   LOGO
   ============================================ */

.logo img {
    max-height: 60px !important;
    width: auto !important;
}

@media (min-width: 768px) {
    .logo img {
        max-height: 75px !important;
    }
}

/* ============================================
   NAVIGATION - ORANGER BALKEN WIE ORIGINAL
   ============================================ */

/* Toggle Nav Button komplett ausblenden */
html body .nav-toggle,
html body .action.nav-toggle {
    display: none !important;
    visibility: hidden !important;
}

/* Navigation Container - IMMER sichtbar mit oranger Farbe */
html body .nav-sections,
html body .sections.nav-sections {
    display: block !important;
    visibility: visible !important;
    background: #e67e22 !important;
    border: none !important;
    margin-bottom: 0 !important;
    padding: 0 !important;
    min-height: 44px !important;
    height: auto !important;
    opacity: 1 !important;
    position: relative !important;
    max-height: none !important;
    overflow: visible !important;
}

html body .nav-sections-item-content,
html body .nav-sections .section-item-content {
    display: block !important;
    visibility: visible !important;
    background: #e67e22 !important;
    padding: 0 !important;
    opacity: 1 !important;
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
}

html body .nav-sections-item-title {
    display: none !important;
}

html body .nav-sections-items,
html body .nav-sections .section-items {
    display: block !important;
    visibility: visible !important;
    background: #e67e22 !important;
    height: auto !important;
    min-height: 0 !important;
    opacity: 1 !important;
}

html body .navigation {
    display: block !important;
    visibility: visible !important;
    background: #e67e22 !important;
    max-width: 1280px !important;
    margin: 0 auto !important;
    padding: 0 15px !important;
    opacity: 1 !important;
}

/* Navigation Liste - horizontal, ohne Bullets */
html body .navigation > ul,
html body .navigation ul,
html body .navigation ol,
html body .navigation menu,
html body .navigation [role="menu"] {
    list-style: none !important;
    list-style-type: none !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    visibility: visible !important;
    opacity: 1 !important;
}

html body .navigation > ul > li,
html body .navigation .level0,
html body .navigation li,
html body .navigation [role="listitem"],
html body .navigation [role="menuitem"] {
    list-style: none !important;
    list-style-type: none !important;
    margin: 0 !important;
    padding: 0 !important;
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* Alle ::marker und ::before Bullets entfernen */
html body .navigation li::marker,
html body .navigation li::before,
html body .navigation [role="listitem"]::marker,
html body .navigation [role="listitem"]::before {
    content: none !important;
    display: none !important;
}

/* Navigation Links - weiß auf orange */
html body .navigation .level0 > a,
html body .navigation .level0 > .level-top,
html body .navigation a,
html body .navigation [role="menuitem"] {
    font-family: 'Open Sans', sans-serif !important;
    font-weight: 600 !important;
    font-size: 15px !important;
    color: #ffffff !important;
    text-transform: none !important;
    padding: 12px 18px !important;
    line-height: 1.4 !important;
    display: block !important;
    text-decoration: none !important;
    visibility: visible !important;
    opacity: 1 !important;
}

.navigation .level0 > a:hover,
.navigation .level0 > .level-top:hover,
.navigation .level0.active > a,
.navigation .level0.active > .level-top {
    color: #ffffff !important;
    background: rgba(0, 0, 0, 0.15) !important;
    text-decoration: none !important;
}

/* Dropdown-Menü */
.navigation .level0 .submenu {
    background: #fff !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
    margin-top: 0 !important;
    list-style: none !important;
}

.navigation .level0 .submenu li {
    list-style: none !important;
}

.navigation .level0 .submenu a {
    color: #333 !important;
    font-family: 'Open Sans', sans-serif !important;
    padding: 10px 20px !important;
}

.navigation .level0 .submenu a:hover {
    background: #f5f5f5 !important;
    color: #e67e22 !important;
}

/* ============================================
   NAVIGATION - Tabs komplett ausblenden (Desktop + Mobile)
   Muss JS-Änderungen überschreiben!
   ============================================ */

/* Tablist, Tabs und Toggle komplett ausblenden - NICHT die Navigation selbst! */
html body .nav-sections [role="tablist"],
html body .nav-sections [role="tab"],
html body .nav-sections-item-title,
html body .section-item-title,
html body .nav-sections .section-item-title,
html body .nav-toggle,
html body .action.nav-toggle,
html body .nav-sections .section-items > .section-item-title {
    display: none !important;
    visibility: hidden !important;
    width: 0 !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    position: absolute !important;
    left: -99999px !important;
    clip: rect(0,0,0,0) !important;
}

/* WICHTIG: Navigation-Elemente NICHT mit clip/position verstecken */
html body .nav-sections .navigation,
html body .nav-sections .navigation ul,
html body .nav-sections .navigation li,
html body .nav-sections .navigation a,
html body .nav-sections [role="tabpanel"],
html body .nav-sections [role="menu"],
html body .nav-sections [role="listitem"],
html body .nav-sections [role="menuitem"] {
    position: static !important;
    left: auto !important;
    clip: auto !important;
    clip-path: none !important;
}

/* Tabpanel/Navigation Content immer sichtbar - überschreibt JS */
html body .nav-sections [role="tabpanel"],
html body .nav-sections-item-content,
html body .section-item-content,
html body .nav-sections .section-item-content,
html body .nav-sections .section-items > .section-item-content {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    position: static !important;
    width: 100% !important;
    padding: 0 !important;
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
}

/* Navigation kompakt - nur die Höhe des Textes */
html body .sections.nav-sections,
html body .nav-sections {
    height: auto !important;
    min-height: 0 !important;
    padding: 0 !important;
    position: relative !important;
    margin: 0 !important;
    max-height: none !important;
    overflow: visible !important;
}

html body .nav-sections-items {
    height: auto !important;
    min-height: 0 !important;
    display: block !important;
    max-height: none !important;
    overflow: visible !important;
}

/* Section-items direkt anzeigen ohne Tabs */
html body .sections.nav-sections .section-items {
    display: block !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
}

html body .sections.nav-sections .section-item-content {
    display: block !important;
    padding: 0 !important;
    margin: 0 !important;
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
}

/* Navigation selbst immer sichtbar */
html body .navigation,
html body .nav-sections .navigation {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
    position: relative !important;
}

html body .navigation > ul,
html body .navigation ul[role="menu"] {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    position: relative !important;
    height: auto !important;
    width: auto !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
}

/* Navigations-Items und Links sichtbar machen */
html body .navigation ul li,
html body .navigation ul[role="menu"] > li,
html body .navigation ul[role="menu"] [role="listitem"],
html body .navigation .level0 {
    display: inline-block !important;
    visibility: visible !important;
    opacity: 1 !important;
    position: relative !important;
    height: auto !important;
    width: auto !important;
    float: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

html body .navigation ul li a,
html body .navigation ul[role="menu"] a,
html body .navigation [role="menuitem"],
html body .navigation .level-top,
html body .navigation .level0 > a {
    display: inline-block !important;
    visibility: visible !important;
    opacity: 1 !important;
    color: #ffffff !important;
    background: transparent !important;
    padding: 12px 18px !important;
    font-family: 'Open Sans', sans-serif !important;
    font-weight: 600 !important;
    font-size: 15px !important;
    text-decoration: none !important;
    line-height: 1.4 !important;
}

/* Desktop Navigation - Überschreibt Magento Media Queries */
@media (min-width: 768px) {
    html body .nav-sections {
        display: block !important;
        visibility: visible !important;
        background: #e67e22 !important;
    }
    
    html body .nav-sections-item-content {
        display: block !important;
        visibility: visible !important;
    }
    
    html body .navigation {
        display: block !important;
        visibility: visible !important;
        background: #e67e22 !important;
    }
    
    html body .navigation > ul {
        display: flex !important;
        visibility: visible !important;
        position: static !important;
    }
    
    html body .navigation .level0 {
        display: inline-block !important;
        visibility: visible !important;
    }
    
    html body .navigation .level0 > a,
    html body .navigation .level-top {
        display: block !important;
        visibility: visible !important;
        color: #fff !important;
        padding: 12px 18px !important;
    }
}

/* Header Icons im orangen Balken rechts */
.nav-sections .header.links {
    background: transparent !important;
}

.nav-sections .header.links a {
    color: #ffffff !important;
}

/* ============================================
   HEADER ICONS - IM BLAUEN BEREICH WEISS
   ============================================ */

/* Icons im Header (blauer Bereich) */
.page-header .minicart-wrapper .action.showcart,
.page-header .block-search .label,
.page-header .header.links a,
.page-header .authorization-link a {
    color: #ffffff !important;
}

.page-header .minicart-wrapper .action.showcart:hover,
.page-header .block-search .label:hover,
.page-header .header.links a:hover {
    color: rgba(255, 255, 255, 0.8) !important;
}

.page-header .minicart-wrapper .counter.qty {
    background: #e67e22 !important;
    color: #fff !important;
    border-radius: 50% !important;
}

/* Suche im Header */
.page-header .block-search .control input {
    background: #ffffff !important;
    border: none !important;
    border-radius: 4px !important;
}

.page-header .block-search .action.search {
    background: transparent !important;
    color: #003060 !important;
}

/* ============================================
   HERO SECTION
   ============================================ */

.sternschnuppe-hero {
    width: 100%;
    margin-bottom: 0;
}

.hero-image-container {
    width: 100%;
    overflow: hidden;
    line-height: 0;
}

.hero-image {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}

/* Grüner Slogan Banner */
.hero-slogan-banner {
    background: linear-gradient(135deg, #7cb342 0%, #558b2f 100%) !important;
    padding: 20px 15px !important;
    text-align: center !important;
}

.hero-slogan-text {
    font-family: 'Grandstander', 'Comic Sans MS', cursive, sans-serif !important;
    color: #ffffff !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    margin: 0 !important;
    line-height: 1.3 !important;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.2) !important;
}

@media (min-width: 768px) {
    .hero-slogan-banner {
        padding: 25px 30px !important;
    }
    
    .hero-slogan-text {
        font-size: 24px !important;
    }
}

@media (min-width: 1024px) {
    .hero-slogan-banner {
        padding: 30px 40px !important;
    }
    
    .hero-slogan-text {
        font-size: 28px !important;
    }
}

/* Welcome Section */
.hero-welcome-section {
    background: #ffffff !important;
    padding: 30px 20px !important;
}

.hero-welcome-content {
    max-width: 1000px;
    margin: 0 auto;
    font-size: 16px;
    line-height: 1.7;
    color: #333;
}

/* ============================================
   BUTTONS - ORANGE
   ============================================ */

.action.primary,
button.action.primary {
    background-color: #e67e22 !important;
    border: 2px solid #e67e22 !important;
    border-radius: 25px !important;
    color: #fff !important;
    font-family: 'Grandstander', cursive, sans-serif !important;
    font-weight: 600 !important;
    text-transform: none !important;
    transition: all 0.3s ease !important;
}

.action.primary:hover,
button.action.primary:hover {
    background-color: #d35400 !important;
    border-color: #d35400 !important;
}

/* ============================================
   FOOTER - DUNKELBLAU
   ============================================ */

.page-footer {
    background-color: #003060 !important;
    margin-top: 0 !important;
}

.footer.content {
    background-color: #003060 !important;
    border-top: none !important;
    color: #fff !important;
}

.footer-custom {
    background-color: #003060 !important;
    color: #ffffff !important;
    padding: 40px 20px 20px !important;
}

.footer-custom h4 {
    font-family: 'Grandstander', cursive, sans-serif !important;
    color: #fff !important;
    font-size: 18px !important;
    margin-bottom: 15px !important;
}

.footer-columns {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 30px !important;
    margin-bottom: 30px !important;
}

@media (min-width: 768px) {
    .footer-columns {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

.footer-links-grid {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
}

.footer-link-item {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 8px 12px !important;
    background: rgba(255, 255, 255, 0.1) !important;
    border-radius: 20px !important;
    color: #ffffff !important;
    text-decoration: none !important;
    font-size: 14px !important;
    transition: background 0.2s ease !important;
}

.footer-link-item:hover {
    background: rgba(255, 255, 255, 0.2) !important;
    color: #ffffff !important;
    text-decoration: none !important;
}

.footer-legal {
    border-top: 1px solid rgba(255, 255, 255, 0.2) !important;
    padding-top: 20px !important;
    text-align: center !important;
}

.footer-legal-links {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 0 15px 0 !important;
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 10px 20px !important;
}

.footer-legal-links a {
    color: rgba(255, 255, 255, 0.8) !important;
    text-decoration: none !important;
    font-size: 13px !important;
}

.footer-legal-links a:hover {
    color: #ffffff !important;
    text-decoration: underline !important;
}

.footer-copyright {
    font-size: 13px !important;
    opacity: 0.8 !important;
}

/* Hide default Magento footer elements */
.footer.content > .footer.links:not(.footer-legal-links) {
    display: none !important;
}

.copyright {
    display: none !important;
}

/* ============================================
   LINKS
   ============================================ */

a {
    color: #e67e22;
    text-decoration: none;
}

a:hover {
    color: #d35400;
    text-decoration: underline;
}

/* ============================================
   TYPOGRAPHY
   ============================================ */

body {
    font-family: 'Open Sans', 'Helvetica Neue', Helvetica, Arial, sans-serif;
    color: #333;
}

h1, h2, h3, h4, h5, h6 {
    font-family: 'Grandstander', 'Comic Sans MS', cursive, sans-serif;
    color: #003060;
}

/* ============================================
   HOMEPAGE SPECIFIC
   ============================================ */

.cms-home .page-main > .page-title-wrapper {
    display: none !important;
}

.cms-home .column.main > p:first-of-type:not(.hero-welcome-content p) {
    display: none !important;
}

/* ============================================
   2-SPALTEN-LAYOUT (Sidebar links)
   ============================================ */

.catalog-category-view .page-wrapper {
    background-color: #91b200 !important;
}

.catalog-category-view .breadcrumbs {
    background-color: #6f821b !important;
}

.catalog-category-view .breadcrumbs,
.catalog-category-view .breadcrumbs a,
.catalog-category-view .breadcrumbs li,
.catalog-category-view .breadcrumbs .item strong {
    color: #fff !important;
}

/* Live-Termine Seite */
.cms-live-termine .page-wrapper {
    background-color: #46bfef !important;
}

.cms-live-termine .breadcrumbs {
    background-color: #2a9fd4 !important;
}

.cms-live-termine .breadcrumbs,
.cms-live-termine .breadcrumbs a,
.cms-live-termine .breadcrumbs li,
.cms-live-termine .breadcrumbs .item strong {
    color: #fff !important;
}

.page-layout-2columns-left .columns {
    display: grid !important;
    grid-template-columns: 240px 1fr !important;
    grid-template-rows: auto !important;
    gap: 0 30px !important;
    max-width: 1280px !important;
    margin: 0 auto !important;
    padding: 0 20px !important;
}

.page-layout-2columns-left .sidebar-main {
    grid-column: 1 !important;
    grid-row: 1 !important;
    padding-top: 5px !important;
}

.page-layout-2columns-left .column.main {
    grid-column: 2 !important;
    grid-row: 1 / span 2 !important;
    min-width: 0 !important;
}

.page-layout-2columns-left .sidebar-additional {
    grid-column: 1 !important;
    grid-row: 2 !important;
}

@media (max-width: 767px) {
    .page-layout-2columns-left .columns {
        display: flex !important;
        flex-direction: column !important;
    }
    
    .page-layout-2columns-left .sidebar-main,
    .page-layout-2columns-left .sidebar-additional {
        width: 100% !important;
        order: 3 !important;
        margin-top: 20px !important;
    }
    
    .page-layout-2columns-left .column.main {
        order: 1 !important;
    }
}

/* ============================================
   SIDEBAR STYLING
   ============================================ */

.sidebar-main .block,
.sidebar-additional .block {
    background: #fff !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 10px !important;
    padding: 0 !important;
    margin-bottom: 16px !important;
    overflow: hidden !important;
}

.sidebar-main .block-title,
.sidebar-main .filter-title,
.sidebar-additional .block-title {
    background: #003060 !important;
    padding: 12px 16px !important;
    margin: 0 !important;
    border-bottom: none !important;
}

.sidebar-main .block-title strong,
.sidebar-main .filter-title strong,
.sidebar-additional .block-title strong {
    font-family: 'Grandstander', cursive, sans-serif !important;
    color: #fff !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    text-align: left !important;
    margin: 0 !important;
}

.sidebar-main .block-content,
.sidebar-main .filter-content,
.sidebar-additional .block-content {
    padding: 14px 16px !important;
}

/* Filter Options (Shop By) */
.sidebar-main .filter-options-title {
    font-family: 'Grandstander', cursive, sans-serif !important;
    color: #003060 !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    padding: 12px 0 10px !important;
    margin: 0 !important;
    border-bottom: 2px solid #e67e22 !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    transition: color 0.2s ease !important;
}

.sidebar-main .filter-options-title:hover {
    color: #e67e22 !important;
}

.sidebar-main .filter-options-title::after {
    font-size: 10px !important;
    color: #e67e22 !important;
    transition: transform 0.3s ease !important;
}

.sidebar-main .filter-options-content {
    padding: 10px 0 4px !important;
    margin: 0 !important;
}

.sidebar-main .filter-options .items {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.sidebar-main .filter-options .item {
    padding: 0 !important;
    margin-bottom: 6px !important;
    font-size: 13px !important;
    list-style: none !important;
}

.sidebar-main .filter-options .item a {
    color: #444 !important;
    text-decoration: none !important;
    display: flex !important;
    align-items: center !important;
    padding: 8px 12px !important;
    border-radius: 8px !important;
    background: #f5f7fa !important;
    border: 1px solid transparent !important;
    transition: all 0.2s ease !important;
}

.sidebar-main .filter-options .item a:hover {
    color: #003060 !important;
    background: #eaf0f8 !important;
    border-color: #c5d5e8 !important;
    text-decoration: none !important;
}

.sidebar-main .filter-options .item .count {
    color: #fff !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    background: #e67e22 !important;
    border-radius: 10px !important;
    padding: 2px 9px !important;
    margin-left: auto !important;
    min-width: 20px !important;
    text-align: center !important;
    line-height: 16px !important;
    flex-shrink: 0 !important;
}

.sidebar-main .filter-options .item .count .filter-count-label {
    display: none !important;
}

.sidebar-main .filter-options .item .count::before,
.sidebar-main .filter-options .item .count::after {
    display: none !important;
}

.sidebar-main .filter-options .item a .price {
    font-weight: 600 !important;
    color: #003060 !important;
}

/* Compare Products Block */
.sidebar-main .block-compare .block-content,
.sidebar-additional .block-compare .block-content {
    padding: 14px 16px !important;
}

.sidebar-main .block-compare .product-item,
.sidebar-additional .block-compare .product-item {
    list-style: none !important;
    padding: 6px 0 !important;
    border-bottom: 1px solid #f0f0f0 !important;
    font-size: 13px !important;
}

.sidebar-main .block-compare .product-item:last-child,
.sidebar-additional .block-compare .product-item:last-child {
    border-bottom: none !important;
}

.sidebar-main .block-compare .action.compare,
.sidebar-additional .block-compare .action.compare {
    display: inline-block !important;
    background: #e67e22 !important;
    color: #fff !important;
    border: none !important;
    border-radius: 18px !important;
    padding: 6px 16px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    margin-top: 8px !important;
    cursor: pointer !important;
    text-decoration: none !important;
    transition: background 0.2s ease !important;
}

.sidebar-main .block-compare .action.compare:hover,
.sidebar-additional .block-compare .action.compare:hover {
    background: #d35400 !important;
}

.sidebar-main .block-compare .action.clear,
.sidebar-additional .block-compare .action.clear {
    font-size: 12px !important;
    color: #999 !important;
    text-decoration: none !important;
    margin-left: 8px !important;
}

.sidebar-main .block-compare .action.clear:hover,
.sidebar-additional .block-compare .action.clear:hover {
    color: #e67e22 !important;
}

.sidebar-main .block-compare .empty,
.sidebar-additional .block-compare .empty {
    font-size: 13px !important;
    color: #999 !important;
    font-style: italic !important;
}

/* Wish List Block */
.sidebar-main .block-wishlist .block-content,
.sidebar-additional .block-wishlist .block-content {
    padding: 14px 16px !important;
}

.sidebar-main .block-wishlist .product-items,
.sidebar-additional .block-wishlist .product-items {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.sidebar-main .block-wishlist .product-item,
.sidebar-additional .block-wishlist .product-item {
    list-style: none !important;
    padding: 8px 0 !important;
    border-bottom: 1px solid #f0f0f0 !important;
    font-size: 13px !important;
}

.sidebar-main .block-wishlist .product-item:last-child,
.sidebar-additional .block-wishlist .product-item:last-child {
    border-bottom: none !important;
}

.sidebar-main .block-wishlist .product-item-name a,
.sidebar-additional .block-wishlist .product-item-name a {
    color: #333 !important;
    text-decoration: none !important;
    font-weight: 500 !important;
}

.sidebar-main .block-wishlist .product-item-name a:hover,
.sidebar-additional .block-wishlist .product-item-name a:hover {
    color: #e67e22 !important;
}

.sidebar-main .block-wishlist .empty,
.sidebar-additional .block-wishlist .empty {
    font-size: 13px !important;
    color: #999 !important;
    font-style: italic !important;
}

.sidebar-main .block-wishlist .actions-toolbar,
.sidebar-additional .block-wishlist .actions-toolbar {
    margin-top: 8px !important;
}

/* Sidebar Links allgemein */
.sidebar-main .block a.action,
.sidebar-additional .block a.action {
    font-size: 12px !important;
    text-decoration: none !important;
}

.sidebar-main .block .btn-remove,
.sidebar-additional .block .btn-remove {
    font-size: 11px !important;
    color: #ccc !important;
    text-decoration: none !important;
}

.sidebar-main .block .btn-remove:hover,
.sidebar-additional .block .btn-remove:hover {
    color: #e53935 !important;
}

/* ============================================
   PRODUCT LISTING - NUMMERIERUNG ENTFERNEN
   ============================================ */

.products-grid .product-items,
.products.list.items.product-items,
ol.products.list.items.product-items {
    list-style: none !important;
    list-style-type: none !important;
    padding-left: 0 !important;
    margin: 0 !important;
    counter-reset: none !important;
}

.products-grid .product-item,
.products.list .product-item,
ol.products .product-item {
    list-style: none !important;
    list-style-type: none !important;
}

.products-grid .product-item::marker,
.products.list .product-item::marker,
ol.products .product-item::marker {
    content: none !important;
    display: none !important;
}

.products-grid .product-item::before,
ol.products .product-item::before {
    content: none !important;
    display: none !important;
}

/* ============================================
   PRODUCT GRID - KLEINERE PRODUKTE
   ============================================ */

.products-grid .product-items {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)) !important;
    gap: 16px !important;
    padding: 0 !important;
}

.products-grid .product-item {
    margin-bottom: 0 !important;
    padding: 0 !important;
}

.products-grid .product-item-info {
    background: #ffffff !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 10px !important;
    padding: 12px !important;
    text-align: center !important;
    transition: all 0.3s ease !important;
    height: 100% !important;
    display: flex !important;
    flex-direction: column !important;
}

.products-grid .product-item-info:hover {
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.1) !important;
    transform: translateY(-3px) !important;
}

.products-grid .product-item-photo {
    margin-bottom: 10px !important;
}

.products-grid .product-item-photo .product-image-container {
    max-width: 150px !important;
    width: 150px !important;
    margin: 0 auto !important;
}

.products-grid .product-item-photo .product-image-container span.product-image-wrapper {
    padding-bottom: 100% !important;
}

.products-grid .product-item-photo img {
    border-radius: 6px !important;
    max-width: 100% !important;
    height: auto !important;
}

.products-grid .product-item-name {
    margin-bottom: 6px !important;
}

.products-grid .product-item-name a {
    font-family: 'Grandstander', cursive, sans-serif !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    color: #333333 !important;
    text-decoration: none !important;
    line-height: 1.3 !important;
}

.products-grid .product-item-name a:hover {
    color: #e67e22 !important;
}

.products-grid .price-box .price {
    color: #003060 !important;
    font-size: 17px !important;
    font-weight: 700 !important;
}

.products-grid .product-item .price-box .price-label {
    font-size: 12px !important;
}

.products-grid .product-item .tax-details {
    font-size: 11px !important;
    color: #888 !important;
}

.products-grid .actions-primary button,
.products-grid .tocart {
    width: 100% !important;
    margin-top: 8px !important;
    padding: 8px 16px !important;
    font-size: 13px !important;
    border-radius: 20px !important;
}

.products-grid .product-item-actions .actions-secondary {
    font-size: 12px !important;
}

.products-grid .product-item-actions .actions-secondary a {
    font-size: 12px !important;
    color: #e67e22 !important;
}

@media (min-width: 768px) {
    .products-grid .product-items {
        grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)) !important;
        gap: 18px !important;
    }
}

@media (min-width: 1024px) {
    .products-grid .product-items {
        grid-template-columns: repeat(4, 1fr) !important;
        gap: 18px !important;
    }
    
    .products-grid .product-item-photo .product-image-container {
        max-width: 140px !important;
        width: 140px !important;
    }
}

/* ============================================
   TOOLBAR - SCHÖNERER HEADER
   ============================================ */

.toolbar-products {
    background: linear-gradient(135deg, #f8f9fa 0%, #eef1f5 100%) !important;
    padding: 12px 20px !important;
    border-radius: 10px !important;
    margin-bottom: 20px !important;
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 10px !important;
    border: 1px solid #e0e4e8 !important;
}

.toolbar-products .toolbar-amount {
    font-size: 13px !important;
    color: #666 !important;
    font-weight: 500 !important;
    order: 1 !important;
}

.toolbar-products .modes {
    order: 2 !important;
    display: flex !important;
    gap: 4px !important;
}

.toolbar-products .modes .modes-mode {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 34px !important;
    height: 34px !important;
    border-radius: 8px !important;
    border: 1px solid #d0d5db !important;
    background: #fff !important;
    color: #666 !important;
    transition: all 0.2s ease !important;
    cursor: pointer !important;
    font-size: 0 !important;
    text-decoration: none !important;
}

.toolbar-products .modes .modes-mode.active,
.toolbar-products .modes .modes-mode:hover {
    background: #003060 !important;
    border-color: #003060 !important;
    color: #fff !important;
}

/* Grid Icon (4 Quadrate) */
.toolbar-products .modes .mode-grid::before {
    content: "" !important;
    display: block !important;
    width: 16px !important;
    height: 16px !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23666'%3E%3Crect x='0' y='0' width='7' height='7' rx='1'/%3E%3Crect x='9' y='0' width='7' height='7' rx='1'/%3E%3Crect x='0' y='9' width='7' height='7' rx='1'/%3E%3Crect x='9' y='9' width='7' height='7' rx='1'/%3E%3C/svg%3E") !important;
    background-size: contain !important;
    background-repeat: no-repeat !important;
    font-size: 0 !important;
}

.toolbar-products .modes .mode-grid.active::before,
.toolbar-products .modes .mode-grid:hover::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3E%3Crect x='0' y='0' width='7' height='7' rx='1'/%3E%3Crect x='9' y='0' width='7' height='7' rx='1'/%3E%3Crect x='0' y='9' width='7' height='7' rx='1'/%3E%3Crect x='9' y='9' width='7' height='7' rx='1'/%3E%3C/svg%3E") !important;
}

/* List Icon (3 Zeilen) */
.toolbar-products .modes .mode-list::before {
    content: "" !important;
    display: block !important;
    width: 16px !important;
    height: 16px !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23666'%3E%3Crect x='0' y='1' width='16' height='3' rx='1'/%3E%3Crect x='0' y='6.5' width='16' height='3' rx='1'/%3E%3Crect x='0' y='12' width='16' height='3' rx='1'/%3E%3C/svg%3E") !important;
    background-size: contain !important;
    background-repeat: no-repeat !important;
    font-size: 0 !important;
}

.toolbar-products .modes .mode-list.active::before,
.toolbar-products .modes .mode-list:hover::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3E%3Crect x='0' y='1' width='16' height='3' rx='1'/%3E%3Crect x='0' y='6.5' width='16' height='3' rx='1'/%3E%3Crect x='0' y='12' width='16' height='3' rx='1'/%3E%3C/svg%3E") !important;
}

.toolbar-products .modes .modes-mode > span {
    clip: rect(0, 0, 0, 0) !important;
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
}

.toolbar-products .modes .modes-label {
    clip: rect(0, 0, 0, 0) !important;
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
}

.toolbar-products .toolbar-sorter {
    order: 3 !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}

.toolbar-products .toolbar-sorter .sorter-label {
    font-size: 13px !important;
    color: #666 !important;
    font-weight: 500 !important;
    white-space: nowrap !important;
}

.toolbar-products .toolbar-sorter .sorter-options {
    border: 1px solid #d0d5db !important;
    border-radius: 8px !important;
    padding: 7px 12px !important;
    font-size: 13px !important;
    color: #333 !important;
    background: #fff !important;
    cursor: pointer !important;
    transition: border-color 0.2s ease !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 10px center !important;
    padding-right: 30px !important;
}

.toolbar-products .toolbar-sorter .sorter-options:focus {
    border-color: #e67e22 !important;
    outline: none !important;
    box-shadow: 0 0 0 2px rgba(230, 126, 34, 0.15) !important;
}

.toolbar-products .toolbar-sorter .sorter-action {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 34px !important;
    height: 34px !important;
    border-radius: 8px !important;
    border: 1px solid #d0d5db !important;
    background: #fff !important;
    color: #666 !important;
    transition: all 0.2s ease !important;
    cursor: pointer !important;
    font-size: 0 !important;
    text-decoration: none !important;
}

.toolbar-products .toolbar-sorter .sorter-action:hover {
    background: #003060 !important;
    border-color: #003060 !important;
    color: #fff !important;
}

/* Sort Direction Arrow Icon */
.toolbar-products .toolbar-sorter .sorter-action::before {
    content: "" !important;
    display: block !important;
    width: 14px !important;
    height: 14px !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14' fill='%23666'%3E%3Cpath d='M7 1L12 6H8.5V13h-3V6H2L7 1z'/%3E%3C/svg%3E") !important;
    background-size: contain !important;
    background-repeat: no-repeat !important;
    font-size: 0 !important;
}

.toolbar-products .toolbar-sorter .sorter-action:hover::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14' fill='%23fff'%3E%3Cpath d='M7 1L12 6H8.5V13h-3V6H2L7 1z'/%3E%3C/svg%3E") !important;
}

/* Descending state - flip arrow */
.toolbar-products .toolbar-sorter .sorter-action[data-value="desc"]::before,
.toolbar-products .toolbar-sorter a.sort-desc::before {
    transform: rotate(180deg) !important;
}

.toolbar-products .limiter {
    order: 4 !important;
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    font-size: 13px !important;
    color: #666 !important;
}

.toolbar-products .limiter .limiter-options {
    border: 1px solid #d0d5db !important;
    border-radius: 8px !important;
    padding: 7px 12px !important;
    font-size: 13px !important;
    background: #fff !important;
    cursor: pointer !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 10px center !important;
    padding-right: 28px !important;
}

.toolbar-products .limiter .limiter-options:focus {
    border-color: #e67e22 !important;
    outline: none !important;
    box-shadow: 0 0 0 2px rgba(230, 126, 34, 0.15) !important;
}

/* Untere Toolbar (nach Produktliste) etwas dezenter */
.products.wrapper ~ .toolbar-products {
    background: transparent !important;
    border: none !important;
    padding: 15px 0 !important;
    border-top: 1px solid #e8e8e8 !important;
    border-radius: 0 !important;
    margin-top: 50px !important;
}

/* ============================================
   PRODUKTDETAILSEITE
   Orientiert an sternschnuppe-kinderlieder.de
   ============================================ */

/* Hauptcontainer */
.catalog-product-view .page-wrapper {
    background: #fff0be !important;
}

.catalog-product-view .page-main {
    max-width: 1280px !important;
    margin: 0 auto !important;
    padding: 0 20px 40px !important;
}

.catalog-product-view .columns {
    display: block !important;
}

/* Skip-Links ausblenden */
.catalog-product-view .action.skip,
.catalog-product-view a[href="#gallery-next-area"],
.catalog-product-view a[href="#gallery-prev-area"] {
    position: absolute !important;
    left: -99999px !important;
    clip: rect(0, 0, 0, 0) !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
}

/* Produkt-Infos: Bild links + Infos rechts */
.catalog-product-view .column.main {
    display: grid !important;
    grid-template-columns: 45% 1fr !important;
    gap: 0 40px !important;
    align-items: start !important;
}

.catalog-product-view .product.media {
    grid-column: 1 !important;
    grid-row: 1 !important;
}

.catalog-product-view .product-info-main {
    grid-column: 2 !important;
    grid-row: 1 !important;
    min-width: 0 !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
}

.catalog-product-view .product-add-form {
    grid-column: 2 !important;
    grid-row: 2 !important;
}

.catalog-product-view .product.info.detailed {
    grid-column: 1 / -1 !important;
}

@media (max-width: 767px) {
    .catalog-product-view .column.main {
        grid-template-columns: 1fr !important;
    }
    
    .catalog-product-view .product.media,
    .catalog-product-view .product-info-main,
    .catalog-product-view .product-add-form,
    .catalog-product-view .product.info.detailed {
        grid-column: 1 !important;
        grid-row: auto !important;
    }
    
    .catalog-product-view .product.media {
        margin-bottom: 25px !important;
    }
}

/* Produkt-Galerie */
.catalog-product-view .gallery-placeholder {
    background: #fff !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    max-width: 100% !important;
    aspect-ratio: 1 / 1 !important;
}

.catalog-product-view .gallery-placeholder__image {
    width: 100% !important;
    height: 100% !important;
    max-width: 100% !important;
    max-height: 100% !important;
    object-fit: contain !important;
    display: block !important;
}

.catalog-product-view .fotorama-item,
.catalog-product-view .fotorama__stage {
    background: #fff !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 12px !important;
    overflow: hidden !important;
}

.catalog-product-view .fotorama__stage__shaft img,
.catalog-product-view .product.media img {
    border-radius: 10px !important;
    max-width: 100% !important;
    height: auto !important;
}

/* Fotorama Thumbnails */
.catalog-product-view .fotorama__nav-wrap {
    margin-top: 10px !important;
}

.catalog-product-view .fotorama__thumb {
    border: 2px solid #e8e8e8 !important;
    border-radius: 6px !important;
    overflow: hidden !important;
}

.catalog-product-view .fotorama__thumb.fotorama__active {
    border-color: #e67e22 !important;
}

/* Produktinfo Reihenfolge per Flexbox */
.catalog-product-view .product-info-main {
    display: flex !important;
    flex-direction: column !important;
}

.catalog-product-view .product-info-main > * {
    order: 5 !important;
}

.catalog-product-view .product-info-main .page-title-wrapper {
    order: 1 !important;
}

.catalog-product-view .product-info-main .product-info-price {
    order: 2 !important;
}

.catalog-product-view .product-info-main .product.attribute.delivery_time {
    order: 3 !important;
    font-size: 13px !important;
    color: #666 !important;
    padding: 8px 0 !important;
    border-bottom: 1px solid #eee !important;
    margin-bottom: 5px !important;
}

.catalog-product-view .product-info-main .product.attribute.delivery_time .type {
    font-weight: 600 !important;
    color: #003060 !important;
    font-size: 13px !important;
}

.catalog-product-view .product-info-main .product-reviews-summary {
    order: 3 !important;
    margin-bottom: 10px !important;
}

.catalog-product-view .product-info-main .product-info-stock-sku {
    order: 4 !important;
    margin-bottom: 8px !important;
}

.catalog-product-view .product-info-main .product.attribute.overview {
    order: 5 !important;
}

.catalog-product-view .product-info-main .product-add-form {
    order: 6 !important;
}

.catalog-product-view .product-info-main .product-social-links,
.catalog-product-view .product-info-main .product-addto-links {
    order: 9 !important;
}

/* Produktname */
.catalog-product-view .page-title-wrapper h1,
.catalog-product-view .page-title,
.catalog-product-view .product-info-main .page-title-wrapper .page-title {
    font-family: 'Grandstander', cursive, sans-serif !important;
    color: #003060 !important;
    font-size: 28px !important;
    font-weight: 700 !important;
    line-height: 1.3 !important;
    margin: 0 0 6px 0 !important;
    display: block !important;
    text-align: left !important;
    padding: 0 !important;
}

@media (min-width: 768px) {
    .catalog-product-view .page-title-wrapper h1,
    .catalog-product-view .page-title {
        font-size: 32px !important;
    }
}

/* Produkttyp / Untertitel */
.catalog-product-view .product.attribute.overview {
    font-size: 16px !important;
    color: #666 !important;
    margin-bottom: 15px !important;
    line-height: 1.5 !important;
}

/* Bewertungen Link */
.catalog-product-view .product-reviews-summary {
    margin-bottom: 15px !important;
}

.catalog-product-view .product-reviews-summary .reviews-actions a {
    color: #e67e22 !important;
    font-size: 13px !important;
    text-decoration: none !important;
}

.catalog-product-view .product-reviews-summary .reviews-actions a:hover {
    text-decoration: underline !important;
}

/* Preis-Bereich */
.catalog-product-view .product-info-price {
    margin-bottom: 15px !important;
    padding: 0 !important;
    display: flex !important;
    flex-direction: column !important;
}

.catalog-product-view .product-info-price .price-box {
    order: -3 !important;
}

.catalog-product-view .product-info-price .price-details {
    order: -2 !important;
    margin-bottom: 12px !important;
    padding-bottom: 12px !important;
    border-bottom: 1px solid #eee !important;
}

.catalog-product-view .product-info-price .product-info-stock-sku {
    order: -1 !important;
    margin-bottom: 8px !important;
}

.catalog-product-view .product-info-price .product-reviews-summary {
    order: 0 !important;
    margin-bottom: 10px !important;
}

.catalog-product-view .product-info-price .price-box .price {
    font-family: 'Grandstander', cursive, sans-serif !important;
    color: #e67e22 !important;
    font-size: 36px !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
}

.catalog-product-view .product-info-price .price-box .price-label {
    display: none !important;
}

.catalog-product-view .product-info-price .price-box .old-price .price {
    color: #999 !important;
    font-size: 20px !important;
    text-decoration: line-through !important;
}

.catalog-product-view .product-info-price .price-box .special-price .price {
    color: #e53935 !important;
}

/* MwSt.-Hinweis */
.catalog-product-view .product-info-price .tax-details,
.catalog-product-view .product-info-price .price-including-tax,
.catalog-product-view .product-info-price + .price-including-tax {
    font-size: 13px !important;
    color: #888 !important;
    margin-top: 2px !important;
}

/* Art.-Nr / SKU */
.catalog-product-view .product.attribute.sku {
    font-size: 13px !important;
    color: #999 !important;
    margin-bottom: 15px !important;
}

.catalog-product-view .product.attribute.sku .type {
    font-weight: 600 !important;
    color: #666 !important;
}

/* Menge-Feld */
.catalog-product-view .field.qty {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin-bottom: 15px !important;
}

.catalog-product-view .field.qty label {
    font-size: 14px !important;
    color: #333 !important;
    font-weight: 600 !important;
}

.catalog-product-view .field.qty input {
    width: 60px !important;
    text-align: center !important;
    border: 1px solid #d0d5db !important;
    border-radius: 8px !important;
    padding: 8px !important;
    font-size: 16px !important;
}

/* In den Warenkorb Button */
.catalog-product-view .box-tocart .action.tocart {
    background: #e67e22 !important;
    border: 2px solid #e67e22 !important;
    border-radius: 25px !important;
    color: #fff !important;
    font-family: 'Grandstander', cursive, sans-serif !important;
    font-weight: 600 !important;
    font-size: 18px !important;
    padding: 14px 40px !important;
    text-transform: none !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    display: inline-block !important;
    min-width: 200px !important;
    text-align: center !important;
}

.catalog-product-view .box-tocart .action.tocart:hover {
    background: #d35400 !important;
    border-color: #d35400 !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(230, 126, 34, 0.3) !important;
}

/* Wunschliste / Vergleichen Links */
.catalog-product-view .product-addto-links,
.catalog-product-view .product-social-links {
    margin-top: 15px !important;
    display: flex !important;
    gap: 15px !important;
}

.catalog-product-view .product-addto-links a,
.catalog-product-view .product-social-links a,
.catalog-product-view .action.towishlist,
.catalog-product-view .action.tocompare {
    color: #e67e22 !important;
    font-size: 13px !important;
    text-decoration: none !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 4px !important;
    transition: color 0.2s ease !important;
}

.catalog-product-view .product-addto-links a:hover,
.catalog-product-view .action.towishlist:hover,
.catalog-product-view .action.tocompare:hover {
    color: #d35400 !important;
}

/* Versandhinweis */
.catalog-product-view .product-info-stock-sku {
    margin-bottom: 15px !important;
}

.catalog-product-view .stock.available span {
    color: #7cb342 !important;
    font-weight: 600 !important;
    font-size: 14px !important;
}

/* ============================================
   PRODUKT-TABS (Details, More Info, Reviews)
   ============================================ */

.catalog-product-view .product.info.detailed {
    margin-top: 40px !important;
    padding-top: 30px !important;
    border-top: 2px solid #e8e8e8 !important;
}

/* Tab-Container: Flex-Wrap damit Titel nebeneinander + Content volle Breite */
.catalog-product-view .product.data.items {
    display: flex !important;
    flex-wrap: wrap !important;
    border-bottom: 1px solid #e8e8e8 !important;
}

/* Tab-Titel: nebeneinander in einer Reihe */
.catalog-product-view .product.data.items > .item.title {
    flex: none !important;
    margin-bottom: -1px !important;
}

.catalog-product-view .product.data.items > .item.title > .switch {
    display: block !important;
    padding: 12px 24px !important;
    font-family: 'Grandstander', cursive, sans-serif !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    color: #666 !important;
    text-decoration: none !important;
    border: 1px solid transparent !important;
    border-bottom: 2px solid transparent !important;
    border-radius: 8px 8px 0 0 !important;
    background: transparent !important;
    transition: all 0.2s ease !important;
    cursor: pointer !important;
}

.catalog-product-view .product.data.items > .item.title > .switch:hover {
    color: #e67e22 !important;
    background: #fef5ec !important;
}

.catalog-product-view .product.data.items > .item.title.active > .switch {
    color: #003060 !important;
    border: 1px solid #e8e8e8 !important;
    border-bottom-color: #fff !important;
    background: #fff !important;
}

/* Tab-Inhalt: volle Breite, bricht in neue Zeile */
.catalog-product-view .product.data.items > .item.content {
    flex: 0 0 100% !important;
    order: 99 !important;
    padding: 25px !important;
    border: 1px solid #e8e8e8 !important;
    border-top: none !important;
    border-radius: 0 0 10px 10px !important;
    background: #fff !important;
    font-size: 15px !important;
    line-height: 1.7 !important;
    color: #333 !important;
}

.catalog-product-view .product.data.items > .item.content h2,
.catalog-product-view .product.data.items > .item.content h3 {
    font-family: 'Grandstander', cursive, sans-serif !important;
    color: #003060 !important;
    margin-top: 20px !important;
    margin-bottom: 10px !important;
}

/* Download-Links Bereich */
.catalog-product-view .product-links-downloads,
.catalog-product-view .product-options-wrapper {
    margin-bottom: 15px !important;
    padding: 15px !important;
    background: #fafbfc !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 10px !important;
}

.catalog-product-view .product-options-wrapper:empty,
.catalog-product-view .product-add-form .product-options-wrapper {
    display: none !important;
}

.catalog-product-view .field.downloads .label,
.catalog-product-view .product-options-wrapper .fieldset > .legend {
    font-family: 'Grandstander', cursive, sans-serif !important;
    color: #003060 !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    margin-bottom: 8px !important;
    display: block !important;
}

.catalog-product-view .downloads.list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.catalog-product-view .downloads.list li {
    padding: 8px 12px !important;
    border-bottom: 1px solid #f0f0f0 !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    list-style: none !important;
    border-radius: 6px !important;
    transition: background 0.2s !important;
}

.catalog-product-view .downloads.list li:hover {
    background: #fff !important;
}

.catalog-product-view .downloads.list li:last-child {
    border-bottom: none !important;
}

.catalog-product-view .downloads.list li label {
    font-size: 14px !important;
    color: #333 !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}

/* Sample-Links (Hörproben) */
.catalog-product-view .product-samples,
.catalog-product-view .samples {
    margin-bottom: 15px !important;
}

.catalog-product-view .product-samples .title,
.catalog-product-view .samples .title {
    font-family: 'Grandstander', cursive, sans-serif !important;
    color: #003060 !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    margin-bottom: 8px !important;
}

.catalog-product-view .samples.list,
.catalog-product-view .sample.links {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.catalog-product-view .samples.list li,
.catalog-product-view .sample.links li {
    list-style: none !important;
    padding: 6px 0 !important;
}

.catalog-product-view .samples.list a,
.catalog-product-view .sample.links a,
.catalog-product-view a.sample-link {
    color: #e67e22 !important;
    text-decoration: none !important;
    font-size: 14px !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 6px 12px !important;
    background: #fef5ec !important;
    border-radius: 20px !important;
    transition: all 0.2s ease !important;
}

.catalog-product-view .samples.list a::before,
.catalog-product-view .sample.links a::before,
.catalog-product-view a.sample-link::before {
    content: "" !important;
    display: inline-block !important;
    width: 16px !important;
    height: 16px !important;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23e67e22'%3E%3Cpath d='M12 3v10.55c-.59-.34-1.27-.55-2-.55-2.21 0-4 1.79-4 4s1.79 4 4 4 4-1.79 4-4V7h4V3h-6z'/%3E%3C/svg%3E") no-repeat center !important;
    background-size: contain !important;
    font-size: 0 !important;
}

.catalog-product-view .samples.list a:hover,
.catalog-product-view .sample.links a:hover,
.catalog-product-view a.sample-link:hover {
    color: #d35400 !important;
    background: #fde8d0 !important;
}

/* Bewertungen Tab */
.catalog-product-view .review-list {
    margin-top: 20px !important;
}

.catalog-product-view .review-item {
    padding: 20px !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 10px !important;
    margin-bottom: 15px !important;
    background: #fafafa !important;
}

.catalog-product-view .review-title {
    font-family: 'Grandstander', cursive, sans-serif !important;
    color: #003060 !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    margin-bottom: 8px !important;
}

.catalog-product-view .review-content {
    font-size: 14px !important;
    line-height: 1.6 !important;
    color: #333 !important;
}

/* Review-Formular */
.catalog-product-view .review-form .field label {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #333 !important;
}

.catalog-product-view .review-form .action.submit {
    background: #e67e22 !important;
    border: 2px solid #e67e22 !important;
    border-radius: 25px !important;
    color: #fff !important;
    font-family: 'Grandstander', cursive, sans-serif !important;
    font-weight: 600 !important;
    padding: 10px 30px !important;
}

.catalog-product-view .review-form .action.submit:hover {
    background: #d35400 !important;
    border-color: #d35400 !important;
}

/* Additional Attributes Tabelle (More Information) */
.catalog-product-view .additional-attributes {
    width: 100% !important;
    border-collapse: collapse !important;
}

.catalog-product-view .additional-attributes th {
    text-align: left !important;
    padding: 10px 15px !important;
    background: #f8f9fa !important;
    color: #003060 !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    border-bottom: 1px solid #e8e8e8 !important;
    width: 35% !important;
}

.catalog-product-view .additional-attributes td {
    padding: 10px 15px !important;
    font-size: 14px !important;
    color: #333 !important;
    border-bottom: 1px solid #e8e8e8 !important;
}

/* Ähnliche Produkte / Upsell */
.catalog-product-view .block.related,
.catalog-product-view .block.upsell,
.catalog-product-view .block.crosssell {
    margin-top: 40px !important;
    padding-top: 30px !important;
    border-top: 2px solid #e8e8e8 !important;
}

.catalog-product-view .block.related .block-title strong,
.catalog-product-view .block.upsell .block-title strong,
.catalog-product-view .block.crosssell .block-title strong {
    font-family: 'Grandstander', cursive, sans-serif !important;
    color: #003060 !important;
    font-size: 24px !important;
}

/* ==============================
   Warenkorb - Layout (Desktop)
   ============================== */
.checkout-cart-index .page-main {
    padding-top: 30px !important;
}

@media (min-width: 768px) {
    .checkout-cart-index .page-main {
        max-width: 1280px !important;
        margin: 0 auto !important;
        padding: 40px 20px 60px !important;
        box-sizing: border-box;
    }
    .checkout-cart-index .cart-container {
        display: grid !important;
        grid-template-columns: 1fr 360px !important;
        gap: 30px !important;
        align-items: start !important;
        max-width: 1240px !important;
        margin: 0 auto !important;
    }
    /* Produkte links */
    .checkout-cart-index .cart-container .form-cart,
    .checkout-cart-index .cart-container #form-validate {
        grid-column: 1 !important;
        grid-row: 1 !important;
        order: 1 !important;
        background: #fff;
        border: 1px solid #eee;
        border-radius: 10px;
        padding: 20px;
        box-sizing: border-box;
    }
    /* Zusammenfassung rechts */
    .checkout-cart-index .cart-container .cart-summary {
        grid-column: 2 !important;
        grid-row: 1 !important;
        order: 2 !important;
        background: #fff7e6;
        border: 1px solid #f0a83a;
        border-radius: 10px;
        padding: 20px;
        position: sticky;
        top: 20px;
    }
    .checkout-cart-index .cart-container .cart.main.actions,
    .checkout-cart-index .cart-container .block.discount,
    .checkout-cart-index .cart-container .block.crosssell {
        grid-column: 1 !important;
        order: 3 !important;
    }
}

/* Produkt-Tabelle übersichtlicher */
.checkout-cart-index .cart.table-wrapper {
    margin: 0;
}
.checkout-cart-index #shopping-cart-table > caption,
.checkout-cart-index #shopping-cart-table .table-caption {
    display: none !important;
}
.checkout-cart-index .cart-summary ul,
.checkout-cart-index .cart-summary ol,
.checkout-cart-index .cart-summary .checkout-methods-items {
    list-style: none !important;
    padding-left: 0 !important;
    margin-left: 0 !important;
}
.checkout-cart-index .cart-summary li {
    list-style: none !important;
}

/* Multi-Address-Link entfernen */
.checkout-cart-index .cart-summary .checkout-methods-items .multicheckout,
.checkout-cart-index .cart-summary li.multicheckout,
.checkout-cart-index a.multicheckout {
    display: none !important;
}

/* Gutscheincode-Block als Button gestalten */
.checkout-cart-index .cart-summary .block.discount {
    margin-top: 18px;
    padding-top: 16px;
    border-top: 1px solid #f0c787;
}
.checkout-cart-index .cart-summary .block.discount > .title {
    display: block;
    cursor: pointer;
    background-color: #fff;
    border: 1px solid #f08a00;
    color: #f08a00;
    padding: 9px 16px;
    border-radius: 999px;
    font-weight: 700;
    font-size: 0.95rem;
    text-align: center;
    transition: background-color 0.15s ease, color 0.15s ease;
}
.checkout-cart-index .cart-summary .block.discount > .title:hover,
.checkout-cart-index .cart-summary .block.discount.active > .title {
    background-color: #f08a00;
    color: #fff;
}
.checkout-cart-index .cart-summary .block.discount > .title strong {
    font-weight: 700;
    font-size: inherit;
    color: inherit;
}
.checkout-cart-index .cart-summary .block.discount > .title::after {
    display: none;
}
.checkout-cart-index .cart-summary .block.discount .content {
    margin-top: 12px;
    padding: 14px;
    background-color: #fff;
    border: 1px solid #f0d8a8;
    border-radius: 8px;
}
.checkout-cart-index .cart-summary .block.discount .content .field {
    margin-bottom: 10px;
}
.checkout-cart-index .cart-summary .block.discount .content input[type="text"] {
    width: 100%;
    padding: 8px 10px;
    border: 1px solid #ccc;
    border-radius: 6px;
    box-sizing: border-box;
}
.checkout-cart-index .cart-summary .block.discount .actions-toolbar button.action.apply {
    background-color: #f08a00;
    border: 0;
    color: #fff;
    font-weight: 700;
    padding: 8px 18px;
    border-radius: 999px;
    cursor: pointer;
}
.checkout-cart-index .cart-summary .block.discount .actions-toolbar button.action.apply:hover {
    background-color: #d97800;
}
.checkout-cart-index #shopping-cart-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
}
.checkout-cart-index #shopping-cart-table thead th {
    background: #fafafa;
    color: #555;
    font-weight: 600;
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 12px 10px;
    border-bottom: 2px solid #e5e5e5;
    text-align: center;
}
.checkout-cart-index #shopping-cart-table thead th:first-child {
    text-align: left;
}
.checkout-cart-index #shopping-cart-table tbody.cart.item {
    transition: background-color 0.2s ease;
}
.checkout-cart-index #shopping-cart-table tbody.cart.item:nth-of-type(odd) {
    background-color: #ffffff;
}
.checkout-cart-index #shopping-cart-table tbody.cart.item:nth-of-type(even) {
    background-color: #fbf7ee;
}
.checkout-cart-index #shopping-cart-table tbody.cart.item:hover {
    background-color: #fff3df;
}
.checkout-cart-index #shopping-cart-table tbody.cart.item td {
    padding: 18px 10px;
    border-bottom: 1px solid #eee;
    vertical-align: middle;
}
.checkout-cart-index #shopping-cart-table .product-item-photo {
    display: inline-block;
    width: 80px;
    margin-right: 14px;
    vertical-align: middle;
}
.checkout-cart-index #shopping-cart-table .product-item-photo img {
    border-radius: 8px;
    border: 1px solid #eee;
}
.checkout-cart-index #shopping-cart-table .product-item-name {
    display: block;
    font-weight: 600;
    color: #1a3a6b;
    margin-bottom: 4px;
}
.checkout-cart-index #shopping-cart-table .item-actions a {
    font-size: 0.85rem;
    color: #f08a00;
}
.checkout-cart-index #shopping-cart-table .col.price,
.checkout-cart-index #shopping-cart-table .col.subtotal {
    text-align: center;
    font-weight: 600;
}
.checkout-cart-index #shopping-cart-table .col.qty {
    text-align: center;
}
.checkout-cart-index #shopping-cart-table input.qty {
    width: 60px;
    text-align: center;
    padding: 6px;
    border: 1px solid #ccc;
    border-radius: 6px;
}

/* Inline-Login/Register-Block ausblenden, Modale aber weiter funktionsfähig halten.
   Magento-Modale erhalten beim Öffnen die Klasse ._show — wir blenden nur
   geschlossene Modalkopien aus, die ohne JS-Init sichtbar gerendert werden. */
body.checkout-cart-index .modals-wrapper aside.modal-popup:not(._show),
body.checkout-cart-index .modals-wrapper aside.modal-slide:not(._show) {
    display: none !important;
}
/* Versteckt ein leeres Overlay global – sonst fängt es Klicks ab */
.modals-overlay:empty {
    display: none !important;
}

/* Modal-Popup zentral mit Overlay (theme hatte hierfür keine Styles).
   pointer-events: none verhindert, dass das Overlay Klicks abfängt, wenn
   es zwar im DOM ist, aber kein aktives Modal enthält. Aktive Modale
   setzen pointer-events selbst wieder auf auto. */
.modals-overlay {
    position: fixed !important;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 900;
    pointer-events: none;
}
.modals-overlay aside.modal-popup._show,
.modals-overlay aside.modal-slide._show {
    pointer-events: auto !important;
}
aside.modal-popup._show {
    position: fixed !important;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1000;
    display: flex !important;
    align-items: flex-start;
    justify-content: center;
    overflow-y: auto;
    padding: 60px 20px;
    box-sizing: border-box;
}
aside.modal-popup._show .modal-inner-wrap {
    position: relative;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.3);
    width: 100%;
    max-width: 520px;
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    overflow: hidden;
}
aside.modal-popup._show .modal-header {
    position: relative;
    padding: 18px 56px 14px 28px;
    margin: 0;
    border-bottom: 1px solid #eee;
    min-height: 24px;
}
aside.modal-popup._show .modal-header .action-close,
aside.modal-popup._show .modal-inner-wrap > .action-close {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 36px;
    height: 36px;
    background: transparent;
    border: 0;
    border-radius: 50%;
    cursor: pointer;
    color: #555;
    padding: 0;
    font-size: 0;
    line-height: 0;
    text-indent: -9999px;
    overflow: hidden;
    z-index: 2;
}
aside.modal-popup._show .modal-header .action-close::before,
aside.modal-popup._show .modal-inner-wrap > .action-close::before {
    content: '\00d7';
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    font-size: 1.6rem;
    line-height: 1;
    color: #555;
    text-indent: 0;
}
aside.modal-popup._show .modal-header .action-close:hover::before,
aside.modal-popup._show .modal-inner-wrap > .action-close:hover::before {
    color: #f08a00;
}
aside.modal-popup._show .modal-content {
    padding: 24px 28px 28px;
}
aside.modal-popup._show .modal-content .block-customer-login,
aside.modal-popup._show .modal-content .block-new-customer {
    margin-bottom: 24px;
}
aside.modal-popup._show .modal-content .block-customer-login:last-child,
aside.modal-popup._show .modal-content .block-new-customer:last-child {
    margin-bottom: 0;
}
aside.modal-popup._show .modal-content .block-title {
    font-size: 1.15rem;
    font-weight: 700;
    margin: 0 0 12px;
    padding-bottom: 8px;
    border-bottom: 1px solid #f0f0f0;
}
aside.modal-popup._show .modal-content .block-content {
    margin-top: 0;
}
aside.modal-popup._show .modal-content .field {
    margin-bottom: 14px;
}
aside.modal-popup._show .modal-content .field > .label {
    display: block;
    margin-bottom: 6px;
    font-weight: 600;
    font-size: 0.9rem;
}
aside.modal-popup._show .modal-content input[type="email"],
aside.modal-popup._show .modal-content input[type="password"],
aside.modal-popup._show .modal-content input[type="text"] {
    width: 100%;
    padding: 9px 11px;
    border: 1px solid #ccc;
    border-radius: 6px;
    box-sizing: border-box;
    font-size: 0.95rem;
}
aside.modal-popup._show .modal-content .actions-toolbar {
    margin-top: 16px;
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
}
aside.modal-popup._show .modal-content .actions-toolbar .secondary {
    margin: 0;
}
aside.modal-popup._show .modal-content .actions-toolbar .action.primary,
aside.modal-popup._show .modal-content .actions-toolbar .action-login,
aside.modal-popup._show .modal-content .actions-toolbar .action-register,
aside.modal-popup._show .modal-content .actions-toolbar > .primary > button,
aside.modal-popup._show .modal-content .actions-toolbar > .primary > a {
    background-color: #f08a00 !important;
    border: 0 !important;
    color: #fff !important;
    font-weight: 700;
    padding: 10px 22px !important;
    border-radius: 999px !important;
    font-size: 1rem !important;
    cursor: pointer;
    text-transform: none !important;
    line-height: 1.2;
    transition: background-color 0.15s ease;
    text-decoration: none !important;
    display: inline-block;
}
aside.modal-popup._show .modal-content .actions-toolbar .action.primary:hover,
aside.modal-popup._show .modal-content .actions-toolbar .action-login:hover,
aside.modal-popup._show .modal-content .actions-toolbar .action-register:hover,
aside.modal-popup._show .modal-content .actions-toolbar > .primary > button:hover,
aside.modal-popup._show .modal-content .actions-toolbar > .primary > a:hover {
    background-color: #d97800 !important;
    color: #fff !important;
}
aside.modal-popup._show .modal-content .actions-toolbar .action.primary span,
aside.modal-popup._show .modal-content .actions-toolbar .action-login span,
aside.modal-popup._show .modal-content .actions-toolbar .action-register span {
    color: #fff !important;
}
body._has-modal {
    overflow: hidden;
}

/* ==============================
   Leerer Warenkorb
   ============================== */
.checkout-cart-index .cart-empty {
    text-align: center !important;
    min-height: 400px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 50px 20px !important;
    width: 100% !important;
    max-width: 600px !important;
    margin: 0 auto !important;
    box-sizing: border-box !important;
}

.cart-empty-icon {
    margin-bottom: 25px;
    opacity: 0.85;
}

.cart-empty-icon svg {
    display: inline-block;
}

.cart-empty-title {
    font-family: 'Grandstander', cursive, sans-serif !important;
    color: #003060 !important;
    font-size: 26px !important;
    font-weight: 700 !important;
    margin-bottom: 10px !important;
}

.cart-empty-message {
    color: #666 !important;
    font-size: 16px !important;
    margin-bottom: 30px !important;
    line-height: 1.5 !important;
}

.cart-empty-action .action.primary.continue {
    display: inline-block;
    background: #e67e22 !important;
    color: #fff !important;
    border: none !important;
    border-radius: 30px !important;
    padding: 14px 35px !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: background 0.3s ease, transform 0.2s ease !important;
    cursor: pointer;
}

.cart-empty-action .action.primary.continue:hover {
    background: #d35400 !important;
    transform: translateY(-2px) !important;
}

/* ==============================
   Kunden-Login Seite
   ============================== */
.customer-account-login .page-main {
    max-width: 1280px !important;
    margin: 0 auto !important;
    padding: 40px 20px 60px !important;
    box-sizing: border-box !important;
}

.customer-account-login .page-title-wrapper {
    margin-bottom: 30px !important;
}

.customer-account-login .page-title {
    font-family: 'Grandstander', cursive, sans-serif !important;
    color: #003060 !important;
    font-size: 30px !important;
    font-weight: 700 !important;
}

.customer-account-login .login-container {
    display: flex !important;
    gap: 40px !important;
    flex-wrap: wrap !important;
}

.customer-account-login .login-container .block {
    flex: 1 !important;
    min-width: 300px !important;
    background: #fff !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 12px !important;
    padding: 30px !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.04) !important;
}

.customer-account-login .login-container .block-title {
    border-bottom: 2px solid #e67e22 !important;
    padding-bottom: 12px !important;
    margin-bottom: 20px !important;
}

.customer-account-login .login-container .block-title strong {
    font-family: 'Grandstander', cursive, sans-serif !important;
    color: #003060 !important;
    font-size: 22px !important;
    font-weight: 700 !important;
}

.customer-account-login .login-container .block-content p {
    color: #555 !important;
    font-size: 14px !important;
    line-height: 1.6 !important;
    margin-bottom: 20px !important;
}

.customer-account-login .login-container .field .label {
    font-weight: 600 !important;
    color: #003060 !important;
    font-size: 14px !important;
    margin-bottom: 6px !important;
}

.customer-account-login .login-container .field .control input {
    border: 1px solid #d0d5dd !important;
    border-radius: 8px !important;
    padding: 10px 14px !important;
    font-size: 14px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    transition: border-color 0.2s ease !important;
}

.customer-account-login .login-container .field .control input:focus {
    border-color: #e67e22 !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(230,126,34,0.15) !important;
}

.customer-account-login .actions-toolbar .action.primary {
    background: #e67e22 !important;
    color: #fff !important;
    border: none !important;
    border-radius: 25px !important;
    padding: 12px 30px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: background 0.3s ease, transform 0.2s ease !important;
}

.customer-account-login .actions-toolbar .action.primary:hover {
    background: #d35400 !important;
    transform: translateY(-1px) !important;
}

.customer-account-login .actions-toolbar .secondary a {
    color: #e67e22 !important;
    text-decoration: none !important;
    font-size: 13px !important;
    font-weight: 500 !important;
}

.customer-account-login .actions-toolbar .secondary a:hover {
    color: #d35400 !important;
    text-decoration: underline !important;
}

.customer-account-login .block-new-customer .actions-toolbar .action.primary {
    background: #003060 !important;
}

.customer-account-login .block-new-customer .actions-toolbar .action.primary:hover {
    background: #004080 !important;
}

/* ==============================
   CMS-Seiten & Kontakt: Boxed 1280px
   ============================== */
.cms-page-view .page-main,
.contact-index-index .page-main,
.customer-account-forgotpassword .page-main,
.customer-account-create .page-main,
.kinderlieder_texte-index-index .page-main,
.kinderlieder_texte-song-view .page-main {
    max-width: 1280px !important;
    margin: 0 auto !important;
    padding: 40px 20px 60px !important;
    box-sizing: border-box !important;
}

.kinderlieder_texte-index-index .page-wrapper,
.kinderlieder_texte-song-view .page-wrapper {
    background-color: #ffd700 !important;
}

.kinderlieder_texte-index-index .breadcrumbs,
.kinderlieder_texte-song-view .breadcrumbs {
    background-color: #e1be00 !important;
}

.cms-page-view .page-title,
.contact-index-index .page-title {
    font-family: 'Grandstander', cursive, sans-serif !important;
    color: #003060 !important;
    font-size: 30px !important;
    font-weight: 700 !important;
    margin-bottom: 10px !important;
}

/* ==============================
   Kontaktformular
   ============================== */
.contact-index-index .form.contact {
    max-width: 680px !important;
    margin: 0 auto !important;
    background: #fff !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 16px !important;
    padding: 40px !important;
    box-shadow: 0 4px 16px rgba(0,0,0,0.05) !important;
}

.contact-index-index .form.contact .legend {
    font-family: 'Grandstander', cursive, sans-serif !important;
    color: #003060 !important;
    font-size: 26px !important;
    font-weight: 700 !important;
    border: none !important;
    padding: 0 !important;
    margin-bottom: 4px !important;
}

.contact-index-index .form.contact .field.note {
    color: #666 !important;
    font-size: 15px !important;
    line-height: 1.6 !important;
    margin-bottom: 28px !important;
    padding-bottom: 20px !important;
    border-bottom: 2px solid #e67e22 !important;
}

.contact-index-index .form.contact .fieldset {
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.contact-index-index .form.contact .field {
    margin-bottom: 20px !important;
}

.contact-index-index .form.contact .field .label {
    font-weight: 600 !important;
    color: #003060 !important;
    font-size: 14px !important;
    margin-bottom: 6px !important;
    display: block !important;
}

.contact-index-index .form.contact .field .control input,
.contact-index-index .form.contact .field .control textarea {
    border: 1px solid #d0d5dd !important;
    border-radius: 10px !important;
    padding: 12px 16px !important;
    font-size: 14px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    font-family: 'Open Sans', sans-serif !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
    background: #fafbfc !important;
}

.contact-index-index .form.contact .field .control input:focus,
.contact-index-index .form.contact .field .control textarea:focus {
    border-color: #e67e22 !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(230,126,34,0.15) !important;
    background: #fff !important;
}

.contact-index-index .form.contact .field .control textarea {
    min-height: 140px !important;
    resize: vertical !important;
}

.contact-index-index .form.contact .actions-toolbar {
    margin-top: 28px !important;
    text-align: center !important;
}

.contact-index-index .form.contact .actions-toolbar .action.submit.primary {
    background: #e67e22 !important;
    color: #fff !important;
    border: none !important;
    border-radius: 30px !important;
    padding: 14px 50px !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: background 0.3s ease, transform 0.2s ease !important;
    display: inline-block !important;
}

.contact-index-index .form.contact .actions-toolbar .action.submit.primary:hover {
    background: #d35400 !important;
    transform: translateY(-2px) !important;
}

/* Kontaktformular Responsive */
@media (max-width: 768px) {
    .contact-index-index .form.contact {
        padding: 24px 18px !important;
    }
}

/* ==============================
   Authentication-Popup (Sign-in Modal) – nur im Modal sichtbar
   Verhindert, dass der Modal-Inhalt unten auf der Seite "ausläuft".
   ============================== */
#authenticationPopup,
#authenticationPopup .block-authentication {
    display: none !important;
}

aside.modal-popup._show #authenticationPopup,
aside.modal-popup._show #authenticationPopup .block-authentication {
    display: block !important;
}

/* ==============================
   Kundenkonto anlegen / Login / Passwort vergessen
   ============================== */
.customer-account-create .page-title,
.customer-account-login .page-title,
.customer-account-forgotpassword .page-title {
    font-family: 'Grandstander', cursive, sans-serif !important;
    color: #003060 !important;
    font-size: 30px !important;
    font-weight: 700 !important;
    margin-bottom: 24px !important;
    text-align: center !important;
}

.customer-account-create .form.create.account,
.customer-account-login .login-container .block,
.customer-account-forgotpassword .form.password.forget {
    max-width: 680px !important;
    margin: 0 auto !important;
    background: #fff !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 16px !important;
    padding: 40px !important;
    box-shadow: 0 4px 16px rgba(0,0,0,0.05) !important;
    box-sizing: border-box !important;
}

.customer-account-login .login-container {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 24px !important;
    justify-content: center !important;
    max-width: 1180px !important;
    margin: 0 auto !important;
}

.customer-account-login .login-container .block {
    flex: 1 1 420px !important;
    max-width: 560px !important;
    width: 100% !important;
}

.customer-account-create .form.create.account .legend,
.customer-account-login .login-container .block .block-title,
.customer-account-forgotpassword .form.password.forget .legend {
    font-family: 'Grandstander', cursive, sans-serif !important;
    color: #003060 !important;
    font-size: 24px !important;
    font-weight: 700 !important;
    border: none !important;
    padding: 0 0 14px 0 !important;
    margin: 0 0 20px 0 !important;
    border-bottom: 2px solid #e67e22 !important;
    display: block !important;
}

.customer-account-create .form.create.account .legend > span,
.customer-account-login .login-container .block .block-title > strong {
    font-weight: 700 !important;
}

.customer-account-create .form.create.account .fieldset,
.customer-account-login .login-container .block .fieldset,
.customer-account-forgotpassword .form.password.forget .fieldset {
    border: none !important;
    padding: 0 !important;
    margin: 0 0 12px 0 !important;
}

.customer-account-create .form.create.account .fieldset > .legend {
    font-size: 18px !important;
    border-bottom: 1px dashed #e8e8e8 !important;
    padding-bottom: 8px !important;
    margin-bottom: 16px !important;
}

.customer-account-create .form.create.account .field,
.customer-account-login .login-container .block .field,
.customer-account-forgotpassword .form.password.forget .field {
    margin-bottom: 18px !important;
}

.customer-account-create .form.create.account .field > .label,
.customer-account-login .login-container .block .field > .label,
.customer-account-forgotpassword .form.password.forget .field > .label {
    font-weight: 600 !important;
    color: #003060 !important;
    font-size: 14px !important;
    margin-bottom: 6px !important;
    display: block !important;
    text-align: left !important;
    float: none !important;
    width: auto !important;
    padding: 0 !important;
}

.customer-account-create .form.create.account .field .control input,
.customer-account-login .login-container .block .field .control input,
.customer-account-forgotpassword .form.password.forget .field .control input {
    border: 1px solid #d0d5dd !important;
    border-radius: 10px !important;
    padding: 12px 16px !important;
    font-size: 14px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    font-family: 'Open Sans', sans-serif !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
    background: #fafbfc !important;
    height: auto !important;
}

.customer-account-create .form.create.account .field .control input:focus,
.customer-account-login .login-container .block .field .control input:focus,
.customer-account-forgotpassword .form.password.forget .field .control input:focus {
    border-color: #e67e22 !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(230,126,34,0.15) !important;
    background: #fff !important;
}

.customer-account-create .form.create.account .field.choice {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    margin-bottom: 18px !important;
}

.customer-account-create .form.create.account .field.choice input[type="checkbox"] {
    width: 18px !important;
    height: 18px !important;
    accent-color: #e67e22 !important;
    margin: 0 !important;
}

.customer-account-create .form.create.account .field.choice .label {
    margin: 0 !important;
    font-weight: 500 !important;
    color: #003060 !important;
}

.customer-account-create .form.create.account .password-strength-meter {
    background: #f4f6f8 !important;
    border-radius: 8px !important;
    padding: 8px 12px !important;
    font-size: 13px !important;
    margin-top: 6px !important;
    color: #003060 !important;
}

.customer-account-create .form.create.account .actions-toolbar,
.customer-account-login .login-container .block .actions-toolbar,
.customer-account-forgotpassword .form.password.forget .actions-toolbar {
    margin-top: 28px !important;
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 12px !important;
    align-items: center !important;
    justify-content: space-between !important;
}

.customer-account-create .form.create.account .actions-toolbar .action.primary,
.customer-account-login .login-container .block .actions-toolbar .action.primary,
.customer-account-forgotpassword .form.password.forget .actions-toolbar .action.primary {
    background: #e67e22 !important;
    color: #fff !important;
    border: none !important;
    border-radius: 30px !important;
    padding: 14px 38px !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: background 0.3s ease, transform 0.2s ease !important;
}

.customer-account-create .form.create.account .actions-toolbar .action.primary:hover,
.customer-account-login .login-container .block .actions-toolbar .action.primary:hover,
.customer-account-forgotpassword .form.password.forget .actions-toolbar .action.primary:hover {
    background: #d35400 !important;
    transform: translateY(-2px) !important;
}

.customer-account-create .form.create.account .actions-toolbar .action.back,
.customer-account-login .login-container .block .actions-toolbar .action.remind,
.customer-account-forgotpassword .form.password.forget .actions-toolbar .action.back {
    background: transparent !important;
    color: #003060 !important;
    border: 2px solid #003060 !important;
    border-radius: 30px !important;
    padding: 12px 28px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: background 0.3s ease, color 0.3s ease !important;
}

.customer-account-create .form.create.account .actions-toolbar .action.back:hover,
.customer-account-login .login-container .block .actions-toolbar .action.remind:hover,
.customer-account-forgotpassword .form.password.forget .actions-toolbar .action.back:hover {
    background: #003060 !important;
    color: #fff !important;
}

.customer-account-create .field.required > .label:after,
.customer-account-login .field.required > .label:after,
.customer-account-forgotpassword .field.required > .label:after {
    color: #e67e22 !important;
    margin-left: 4px !important;
}

.customer-account-create .fieldset > .field.required > .label > span:after,
.customer-account-create .fieldset > .fields > .field.required > .label > span:after {
    content: '*' !important;
    color: #e67e22 !important;
    margin-left: 4px !important;
}

@media (max-width: 768px) {
    .customer-account-create .form.create.account,
    .customer-account-login .login-container .block,
    .customer-account-forgotpassword .form.password.forget {
        padding: 24px 18px !important;
    }
    .customer-account-create .form.create.account .actions-toolbar,
    .customer-account-login .login-container .block .actions-toolbar,
    .customer-account-forgotpassword .form.password.forget .actions-toolbar {
        flex-direction: column-reverse !important;
        align-items: stretch !important;
    }
    .customer-account-create .form.create.account .actions-toolbar .action.primary,
    .customer-account-login .login-container .block .actions-toolbar .action.primary,
    .customer-account-forgotpassword .form.password.forget .actions-toolbar .action.primary,
    .customer-account-create .form.create.account .actions-toolbar .action.back,
    .customer-account-login .login-container .block .actions-toolbar .action.remind,
    .customer-account-forgotpassword .form.password.forget .actions-toolbar .action.back {
        width: 100% !important;
        text-align: center !important;
    }
}

/* ==============================
   Onepage Checkout (/checkout/)
   ============================== */
.checkout-index-index .page-main {
    max-width: 1280px !important;
    margin: 0 auto !important;
    padding: 30px 20px 60px !important;
    box-sizing: border-box !important;
}

.checkout-index-index .page-title-wrapper {
    text-align: center !important;
    margin-bottom: 24px !important;
}

.checkout-index-index .page-title {
    font-family: 'Grandstander', cursive, sans-serif !important;
    color: #003060 !important;
    font-size: 30px !important;
    font-weight: 700 !important;
    margin: 0 !important;
}

/* Progress bar */
.checkout-index-index .opc-progress-bar {
    list-style: none !important;
    display: flex !important;
    justify-content: center !important;
    gap: 40px !important;
    padding: 0 !important;
    margin: 0 0 32px 0 !important;
    counter-reset: i !important;
}

.checkout-index-index .opc-progress-bar-item {
    position: relative !important;
    color: #9aa3ad !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    padding-top: 44px !important;
    text-align: center !important;
    counter-increment: i !important;
    flex: 0 1 auto !important;
    margin: 0 !important;
    width: auto !important;
    border: none !important;
}

.checkout-index-index .opc-progress-bar-item:before,
.checkout-index-index .opc-progress-bar-item > span:before,
.checkout-index-index .opc-progress-bar-item > span:after {
    display: none !important;
}

.checkout-index-index .opc-progress-bar-item > span {
    display: block !important;
    color: inherit !important;
    padding: 0 !important;
}

.checkout-index-index .opc-progress-bar-item > span:before {
    content: counter(i) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: absolute !important;
    top: 0 !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    width: 34px !important;
    height: 34px !important;
    border-radius: 50% !important;
    background: #fff !important;
    border: 2px solid #d0d5dd !important;
    color: #9aa3ad !important;
    font-weight: 700 !important;
    font-size: 14px !important;
    line-height: 1 !important;
}

.checkout-index-index .opc-progress-bar-item._active > span:before,
.checkout-index-index .opc-progress-bar-item._complete > span:before {
    background: #e67e22 !important;
    border-color: #e67e22 !important;
    color: #fff !important;
}

.checkout-index-index .opc-progress-bar-item._active,
.checkout-index-index .opc-progress-bar-item._complete {
    color: #003060 !important;
}

.checkout-index-index .opc-estimated-wrapper {
    display: none !important;
}

/* Two-column layout */
.checkout-index-index .opc-wrapper {
    width: 100% !important;
    max-width: none !important;
    padding: 0 !important;
    box-sizing: border-box !important;
}

.checkout-index-index .checkout-container {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 24px !important;
    align-items: flex-start !important;
    margin: 0 !important;
    max-width: none !important;
}

.checkout-index-index .checkout-container > .opc-progress-bar,
.checkout-index-index .checkout-container > .authentication-wrapper,
.checkout-index-index .checkout-container > .messages {
    flex: 1 0 100% !important;
}

.checkout-index-index .checkout-container > #checkoutSteps,
.checkout-index-index .checkout-container > .opc-wrapper {
    flex: 1 1 0 !important;
    min-width: 0 !important;
    width: auto !important;
    max-width: none !important;
}

.checkout-index-index .opc-sidebar,
.checkout-index-index .opc-summary-wrapper {
    flex: 0 0 380px !important;
    width: 380px !important;
    max-width: 100% !important;
    position: sticky !important;
    top: 20px !important;
    margin: 0 !important;
    visibility: visible !important;
    opacity: 1 !important;
    transform: none !important;
    background: transparent !important;
    height: auto !important;
    overflow: visible !important;
}

/* Hide the modal close button on the sidebar (no function on desktop) */
.checkout-index-index .opc-sidebar .modal-header,
.checkout-index-index .opc-sidebar .modal-header .action-close,
.checkout-index-index .opc-summary-wrapper .modal-header,
.checkout-index-index .opc-summary-wrapper .modal-header .action-close,
.checkout-index-index .opc-sidebar > .modal-inner-wrap > .action-close,
.checkout-index-index .opc-summary-wrapper > .modal-inner-wrap > .action-close {
    display: none !important;
}

.checkout-index-index .opc-sidebar .modal-inner-wrap,
.checkout-index-index .opc-summary-wrapper .modal-inner-wrap {
    background: transparent !important;
    box-shadow: none !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    width: 100% !important;
    height: auto !important;
    transform: none !important;
}

.checkout-index-index .opc-sidebar .modal-content,
.checkout-index-index .opc-summary-wrapper .modal-content {
    padding: 0 !important;
    overflow: visible !important;
}

/* Cards / steps */
.checkout-index-index .opc-wrapper .step-title,
.checkout-index-index .opc-block-summary > .title,
.checkout-index-index .checkout-payment-method .step-title,
.checkout-index-index .checkout-shipping-method .step-title,
.checkout-index-index .checkout-shipping-address .step-title {
    font-family: 'Grandstander', cursive, sans-serif !important;
    color: #003060 !important;
    font-size: 22px !important;
    font-weight: 700 !important;
    border: none !important;
    border-bottom: 2px solid #e67e22 !important;
    padding: 0 0 12px 0 !important;
    margin: 0 0 20px 0 !important;
}

.checkout-index-index .opc > li.checkout-shipping-address,
.checkout-index-index .opc > li.checkout-shipping-method,
.checkout-index-index .opc > li#payment,
.checkout-index-index .opc > li.checkout-payment-method,
.checkout-index-index #checkoutSteps > li {
    list-style: none !important;
    background: #fff !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 16px !important;
    padding: 28px 30px !important;
    margin: 0 0 20px 0 !important;
    box-shadow: 0 4px 16px rgba(0,0,0,0.05) !important;
}

.checkout-index-index .opc-wrapper {
    display: block !important;
}

.checkout-index-index .opc-wrapper > .opc,
.checkout-index-index ol#checkoutSteps,
.checkout-index-index .opc {
    width: 100% !important;
    max-width: none !important;
    padding: 0 !important;
    margin: 0 !important;
    list-style: none !important;
    counter-reset: none !important;
    box-sizing: border-box !important;
}

.checkout-index-index .opc > li:before {
    display: none !important;
}

/* Inputs / fields */
.checkout-index-index .fieldset {
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.checkout-index-index .fieldset > .legend,
.checkout-index-index .fieldset > legend {
    font-family: 'Grandstander', cursive, sans-serif !important;
    color: #003060 !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    border: none !important;
    padding: 0 0 8px 0 !important;
    margin: 4px 0 16px 0 !important;
    border-bottom: 1px dashed #e8e8e8 !important;
    width: 100% !important;
    float: none !important;
    position: static !important;
}

.checkout-index-index .field {
    margin-bottom: 16px !important;
}

.checkout-index-index .field > .label,
.checkout-index-index .field.choice > .label {
    font-weight: 600 !important;
    color: #003060 !important;
    font-size: 14px !important;
    margin-bottom: 6px !important;
    display: block !important;
    text-align: left !important;
    float: none !important;
    width: auto !important;
    padding: 0 !important;
}

.checkout-index-index .field .control input[type="text"],
.checkout-index-index .field .control input[type="email"],
.checkout-index-index .field .control input[type="tel"],
.checkout-index-index .field .control input[type="number"],
.checkout-index-index .field .control input[type="password"],
.checkout-index-index .field .control select,
.checkout-index-index .field .control textarea {
    border: 1px solid #d0d5dd !important;
    border-radius: 10px !important;
    padding: 12px 16px !important;
    font-size: 14px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    font-family: 'Open Sans', sans-serif !important;
    background: #fafbfc !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
    height: auto !important;
}

.checkout-index-index .field .control input:focus,
.checkout-index-index .field .control select:focus,
.checkout-index-index .field .control textarea:focus {
    border-color: #e67e22 !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(230,126,34,0.15) !important;
    background: #fff !important;
}

.checkout-index-index .field._required > .label:after,
.checkout-index-index .field.required > .label:after,
.checkout-index-index .field._required > .label > span:after,
.checkout-index-index .field.required > .label > span:after {
    color: #e67e22 !important;
}

/* Payment method tile */
.checkout-index-index .payment-method {
    border: 1px solid #e8e8e8 !important;
    border-radius: 12px !important;
    padding: 16px 18px !important;
    margin-bottom: 12px !important;
    background: #fafbfc !important;
    transition: border-color 0.2s ease, background 0.2s ease !important;
}

.checkout-index-index .payment-method._active {
    border-color: #e67e22 !important;
    background: #fff !important;
    box-shadow: 0 2px 8px rgba(230,126,34,0.08) !important;
}

.checkout-index-index .payment-method-title {
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    font-weight: 600 !important;
    color: #003060 !important;
}

.checkout-index-index .payment-method-title input[type="radio"] {
    accent-color: #e67e22 !important;
    width: 18px !important;
    height: 18px !important;
    margin-right: 10px !important;
    vertical-align: middle !important;
}

.checkout-index-index .payment-method-content {
    padding: 14px 0 0 0 !important;
}

/* Agreements */
.checkout-index-index .checkout-agreements-block,
.checkout-index-index .checkout-agreements {
    margin: 16px 0 !important;
}

.checkout-index-index .checkout-agreement.field.choice {
    display: flex !important;
    align-items: flex-start !important;
    gap: 10px !important;
    background: #f9fafb !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 10px !important;
    padding: 12px 14px !important;
    margin-bottom: 10px !important;
}

.checkout-index-index .checkout-agreement.field.choice input[type="checkbox"] {
    accent-color: #e67e22 !important;
    width: 18px !important;
    height: 18px !important;
    margin: 2px 0 0 0 !important;
}

.checkout-index-index .checkout-agreement.field.choice .label {
    margin: 0 !important;
    color: #003060 !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
    font-weight: 500 !important;
    cursor: pointer !important;
}

/* Buttons */
.checkout-index-index .action.primary,
.checkout-index-index button.action.primary,
.checkout-index-index .action.checkout,
.checkout-index-index button.action.checkout {
    background: #e67e22 !important;
    color: #fff !important;
    border: none !important;
    border-radius: 30px !important;
    padding: 14px 38px !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: background 0.3s ease, transform 0.2s ease !important;
}

.checkout-index-index .action.primary:hover,
.checkout-index-index button.action.primary:hover,
.checkout-index-index .action.checkout:hover,
.checkout-index-index button.action.checkout:hover {
    background: #d35400 !important;
    transform: translateY(-2px) !important;
}

.checkout-index-index .action-update,
.checkout-index-index .action.action-cancel,
.checkout-index-index .action-edit-address {
    background: transparent !important;
    color: #003060 !important;
    border: 2px solid #003060 !important;
    border-radius: 30px !important;
    padding: 10px 22px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: background 0.3s ease, color 0.3s ease !important;
}

.checkout-index-index .action-update:hover,
.checkout-index-index .action.action-cancel:hover,
.checkout-index-index .action-edit-address:hover {
    background: #003060 !important;
    color: #fff !important;
}

/* Order summary sidebar */
.checkout-index-index .opc-block-summary {
    background: #fff !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 16px !important;
    padding: 24px !important;
    box-shadow: 0 4px 16px rgba(0,0,0,0.05) !important;
    margin: 0 !important;
}

.checkout-index-index .opc-block-summary > .title {
    font-size: 20px !important;
    margin-bottom: 14px !important;
    border-bottom: 2px solid #e67e22 !important;
    padding-bottom: 10px !important;
    display: block !important;
}

.checkout-index-index .opc-block-summary .table-totals {
    width: 100% !important;
    border: none !important;
    font-size: 14px !important;
}

.checkout-index-index .opc-block-summary .table-totals tbody tr td,
.checkout-index-index .opc-block-summary .table-totals tbody tr th {
    border: none !important;
    padding: 6px 0 !important;
    color: #003060 !important;
}

.checkout-index-index .opc-block-summary .table-totals .grand.totals {
    border-top: 1px solid #e8e8e8 !important;
    font-size: 16px !important;
    font-weight: 700 !important;
}

.checkout-index-index .opc-block-summary .table-totals .grand.totals td,
.checkout-index-index .opc-block-summary .table-totals .grand.totals th {
    padding-top: 12px !important;
    color: #003060 !important;
    font-weight: 700 !important;
}

.checkout-index-index .minicart-items-wrapper {
    border: 1px solid #e8e8e8 !important;
    border-radius: 10px !important;
    padding: 8px 12px !important;
    background: #fafbfc !important;
    max-height: 300px !important;
}

.checkout-index-index .opc-block-summary .items-in-cart > .title {
    border: none !important;
    padding: 8px 0 !important;
    color: #003060 !important;
    font-weight: 600 !important;
}

/* Coupon / discount in summary */
.checkout-index-index .opc-payment-additional,
.checkout-index-index .payment-option.discount-code {
    margin-top: 16px !important;
    border: none !important;
    padding: 0 !important;
}

.checkout-index-index .payment-option.discount-code .payment-option-title {
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.checkout-index-index .payment-option.discount-code .payment-option-title .action-toggle,
.checkout-index-index .payment-option.discount-code .payment-option-title > span {
    display: inline-block !important;
    background: transparent !important;
    color: #003060 !important;
    border: 2px solid #003060 !important;
    border-radius: 30px !important;
    padding: 12px 28px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    cursor: pointer !important;
    transition: background 0.3s ease, color 0.3s ease !important;
    font-family: 'Open Sans', sans-serif !important;
}

.checkout-index-index .payment-option.discount-code .payment-option-title .action-toggle:hover,
.checkout-index-index .payment-option.discount-code .payment-option-title > span:hover {
    background: #003060 !important;
    color: #fff !important;
}

.checkout-index-index .payment-option.discount-code .payment-option-title .action-toggle:after {
    display: none !important;
}

.checkout-index-index .payment-option.discount-code._active .payment-option-title .action-toggle,
.checkout-index-index .payment-option.discount-code._active .payment-option-title > span {
    background: #003060 !important;
    color: #fff !important;
}

.checkout-index-index .payment-option.discount-code .payment-option-content {
    padding: 16px 0 0 0 !important;
}

.checkout-index-index .payment-option.discount-code .form-discount .actions-toolbar {
    margin-top: 12px !important;
}

.checkout-index-index .payment-option.discount-code .form-discount .action.action-apply {
    background: #e67e22 !important;
    color: #fff !important;
    border: none !important;
    border-radius: 30px !important;
    padding: 12px 28px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: background 0.3s ease, transform 0.2s ease !important;
}

.checkout-index-index .payment-option.discount-code .form-discount .action.action-apply:hover {
    background: #d35400 !important;
    transform: translateY(-2px) !important;
}

.checkout-index-index .payment-option.discount-code .form-discount .action.action-cancel {
    background: transparent !important;
    color: #003060 !important;
    border: 2px solid #003060 !important;
}

/* Authentication / login link */
.checkout-index-index .authentication-wrapper {
    text-align: right !important;
    max-width: 1280px !important;
    margin-left: auto !important;
    margin-right: 0 !important;
    margin-bottom: 8px !important;
    float: none !important;
}

.checkout-index-index .authentication-wrapper .action-auth-toggle {
    background: transparent !important;
    color: #e67e22 !important;
    border: 2px solid #e67e22 !important;
    border-radius: 30px !important;
    padding: 8px 18px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: background 0.3s ease, color 0.3s ease !important;
}

.checkout-index-index .authentication-wrapper .action-auth-toggle:hover {
    background: #e67e22 !important;
    color: #fff !important;
}

/* Fix label "Tooltip" leak (Magento default form-element tooltip wrapper) */
.checkout-index-index .field-tooltip .label {
    display: none !important;
}

/* Solange die Rechnungsadresse im Edit-Modus ist (Formular sichtbar /
   "Aktualisieren"-Button vorhanden), den "Zahlungspflichtig bestellen"-Button
   visuell deaktivieren und einen Hinweis zeigen. Verhindert, dass Kunden
   bestellen klicken bevor die Adresse gespeichert wurde. */
.checkout-index-index .payment-method._active:has(
    .checkout-billing-address > fieldset.fieldset:not([style*="display: none"])
) .actions-toolbar .action.primary.checkout,
.checkout-index-index .payment-method._active:has(
    .checkout-billing-address > fieldset.fieldset:not([style*="display: none"])
) .actions-toolbar button.action.checkout {
    pointer-events: none !important;
    opacity: 0.45 !important;
    filter: grayscale(60%) !important;
    cursor: not-allowed !important;
    background: #c7c7c7 !important;
}

.checkout-index-index .payment-method._active:has(
    .checkout-billing-address > fieldset.fieldset:not([style*="display: none"])
) .actions-toolbar::before {
    content: "Bitte zuerst die Rechnungsadresse mit „Aktualisieren" speichern.";
    display: block;
    width: 100%;
    background: #fff7ed;
    border: 1px solid #f5c89c;
    color: #b3500c;
    padding: 12px 16px;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 14px;
    text-align: center;
    box-sizing: border-box;
}

/* Hide all modal-popups (e.g. checkout-agreements full text) until activated */
.checkout-index-index .modals-wrapper aside.modal-popup:not(._show),
.checkout-index-index .modals-wrapper aside.modal-slide:not(._show),
.checkout-index-index aside.modal-popup:not(._show),
.checkout-index-index aside.modal-slide:not(._show) {
    display: none !important;
    visibility: hidden !important;
}

/* Some agreement popups render outside the modal-wrapper – hide their content too */
.checkout-index-index #checkout-agreements-modal,
.checkout-index-index .checkout-agreements-item-content {
    display: none !important;
}

.checkout-index-index aside.modal-popup._show #checkout-agreements-modal,
.checkout-index-index aside.modal-popup._show .checkout-agreements-item-content {
    display: block !important;
}

/* Responsive */
@media (max-width: 900px) {
    .checkout-index-index .checkout-container {
        flex-direction: column !important;
    }
    .checkout-index-index .opc-sidebar,
    .checkout-index-index .opc-summary-wrapper {
        position: static !important;
        width: 100% !important;
        flex: 1 1 100% !important;
    }
    .checkout-index-index .opc-progress-bar {
        gap: 24px !important;
    }
}

@media (max-width: 600px) {
    .checkout-index-index .opc > li {
        padding: 20px 18px !important;
    }
    .checkout-index-index .opc-block-summary {
        padding: 18px !important;
    }
    .checkout-index-index .opc-progress-bar {
        gap: 16px !important;
    }
    .checkout-index-index .opc-progress-bar-item {
        font-size: 12px !important;
    }
}
