/* SmartThingsHub Shop Theme – Navy/Cyan */

:root {
  --bs-body-bg:            #0a0f1e;
  --bs-body-bg-rgb:        10, 15, 30;
  --bs-body-color:         rgba(255,255,255,0.80);
  --bs-body-color-rgb:     255, 255, 255;
  --bs-primary:            #00d4e8;
  --bs-primary-rgb:        0, 212, 232;
  --bs-link-color:         #00d4e8;
  --bs-link-hover-color:   #00b8cc;
  --bs-border-color:       rgba(0,212,232,0.18);
  --bs-secondary-bg:       #0d1530;
  --bs-secondary-bg-rgb:   13, 21, 48;
  --bs-tertiary-bg:        #0d1530;
  --bs-tertiary-bg-rgb:    13, 21, 48;
  --bs-emphasis-color:     #ffffff;
  --bs-secondary-color:    rgba(255,255,255,0.50);
  --bs-tertiary-color:     rgba(255,255,255,0.50);
  --bs-heading-color:      #ffffff;
}

html, body {
  background-color: #0a0f1e !important;
  color: rgba(255,255,255,0.80) !important;
}

/* Navigation */
.header { background-color: rgba(10,15,30,0.95) !important; border-bottom: 1px solid rgba(0,212,232,0.18) !important; }
.header a, .header__nav a { color: rgba(255,255,255,0.50) !important; }
.header a:hover, .header__nav a:hover { color: #00d4e8 !important; }

/* Buttons */
.btn-primary { background-color: #00d4e8 !important; border-color: #00d4e8 !important; color: #0a0f1e !important; }
.btn-primary:hover { background-color: #00b8cc !important; border-color: #00b8cc !important; }
.btn-secondary { background-color: transparent !important; border-color: rgba(0,212,232,0.18) !important; color: rgba(255,255,255,0.80) !important; }
.btn-secondary:hover { border-color: #00d4e8 !important; background-color: rgba(0,212,232,0.15) !important; }

/* Cards / Produktkarten */
.card, .product-miniature, .product__card {
  background-color: rgba(13,21,48,0.72) !important;
  border-color: rgba(0,212,232,0.18) !important;
  color: rgba(255,255,255,0.80) !important;
}
.card-body, .product-miniature__infos { background-color: transparent !important; }
.card-title a, .product-miniature__name a { color: #ffffff !important; }
.card-title a:hover, .product-miniature__name a:hover { color: #00d4e8 !important; }

/* Formularfelder */
.form-control, .form-select, input, textarea, select {
  background-color: rgba(255,255,255,0.04) !important;
  border-color: rgba(0,212,232,0.18) !important;
  color: rgba(255,255,255,0.80) !important;
}
.form-control:focus, .form-select:focus, input:focus, textarea:focus, select:focus {
  border-color: #00d4e8 !important;
  box-shadow: 0 0 0 3px rgba(0,212,232,0.15) !important;
  background-color: rgba(255,255,255,0.04) !important;
}
.form-control::placeholder, textarea::placeholder { color: rgba(255,255,255,0.20) !important; }
.form-label, label { color: rgba(255,255,255,0.50) !important; }

/* Checkout Steps */
.checkout-step { background-color: rgba(13,21,48,0.72) !important; border-color: rgba(0,212,232,0.18) !important; }
.checkout-step__title { color: #ffffff !important; }
.step-number { background-color: rgba(13,21,48,0.72) !important; border-color: rgba(0,212,232,0.18) !important; color: #00d4e8 !important; }
.-current .step-number { background-color: #00d4e8 !important; color: #0a0f1e !important; }

/* Warenkorb / Order Summary */
.cart-summary, .cart-summary__block { background-color: rgba(13,21,48,0.72) !important; border-color: rgba(0,212,232,0.18) !important; }

/* Footer */
.footer { background-color: #0a0f1e !important; border-top: 1px solid rgba(0,212,232,0.18) !important; }
.footer a { color: rgba(255,255,255,0.50) !important; }
.footer a:hover { color: #00d4e8 !important; }

/* Breadcrumb / allgemeine Texte */
.breadcrumb-item a { color: #00d4e8 !important; }
h1, h2, h3, h4, h5, h6 { color: #ffffff !important; }
.price { color: #00d4e8 !important; }

/* Produkttitel-Links */
.product-miniature .product-title a,
.product-miniature a.product-title,
a.product-title {
  color: #00d4e8 !important;
}
a.product-title:hover {
  color: #ffffff !important;
}

a.product-miniature__title,
a.product-miniature__title:visited {
  color: #00d4e8 !important;
}
a.product-miniature__title:hover {
  color: #ffffff !important;
}

/* Checkout Links */
a.address-card__edit,
a.address-card__delete.link-danger,
a#cta-terms-and-conditions-0,
.js-terms a,
a.order-confirmation__product-link { color: #00d4e8 !important; }
a.address-card__delete.link-danger { color: #ff6b6b !important; }

/* Bearbeiten Button */
button.btn-outline-primary,
.btn-outline-primary {
  color: #00d4e8 !important;
  border-color: #00d4e8 !important;
  background-color: transparent !important;
}
button.btn-outline-primary:hover,
.btn-outline-primary:hover {
  background-color: rgba(0,212,232,0.15) !important;
  color: #00d4e8 !important;
}

/* Produkttitel in Bestellübersicht */
p.order-confirmation__product-title { color: #ffffff !important; }

/* Reassurance Icons – SVG fill überschreiben */
.reassurance svg path[fill="#0b69f6"],
.blockreassurance svg path[fill="#0b69f6"] { fill: #00d4e8 !important; }
.reassurance__image svg, .blockreassurance svg { color: #00d4e8 !important; }

/* Mein Warenkorb Link */
.aeuc_scart a, .cart-summary a { color: #00d4e8 !important; }

/* Gitter-Hintergrund wie Landing Page */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image:
    linear-gradient(rgba(0,212,232,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,212,232,0.04) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
  z-index: 0;
}

/* Schriftarten */
@font-face { font-family: 'Karla'; font-style: normal; font-weight: 300; font-display: swap; src: url('../fonts/karla/karla-v33-latin-300.woff2') format('woff2'); }
@font-face { font-family: 'Karla'; font-style: normal; font-weight: 400; font-display: swap; src: url('../fonts/karla/karla-v33-latin-regular.woff2') format('woff2'); }
@font-face { font-family: 'Karla'; font-style: normal; font-weight: 500; font-display: swap; src: url('../fonts/karla/karla-v33-latin-500.woff2') format('woff2'); }
@font-face { font-family: 'Syne'; font-style: normal; font-weight: 400; font-display: swap; src: url('../fonts/syne/syne-v24-latin-regular.woff2') format('woff2'); }
@font-face { font-family: 'Syne'; font-style: normal; font-weight: 600; font-display: swap; src: url('../fonts/syne/syne-v24-latin-600.woff2') format('woff2'); }
@font-face { font-family: 'Syne'; font-style: normal; font-weight: 700; font-display: swap; src: url('../fonts/syne/syne-v24-latin-700.woff2') format('woff2'); }
@font-face { font-family: 'Syne'; font-style: normal; font-weight: 800; font-display: swap; src: url('../fonts/syne/syne-v24-latin-800.woff2') format('woff2'); }

html, body { font-family: 'Karla', sans-serif !important; }
h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6 { font-family: 'Syne', sans-serif !important; }

/* Cyan Glow Hover auf Produktkarten */
.product-miniature {
  transition: transform 0.3s, box-shadow 0.3s, border-color 0.3s;
}
.product-miniature:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 60px rgba(0,0,0,0.4), 0 0 30px rgba(0,212,232,0.15) !important;
  border-color: rgba(0,212,232,0.4) !important;
}

/* Glow Hover fix */
article.product-miniature {
  border: 1px solid rgba(0,212,232,0.18) !important;
  border-radius: 16px !important;
  transition: transform 0.3s, box-shadow 0.3s, border-color 0.3s !important;
}
article.product-miniature:hover {
  transform: translateY(-4px) !important;
  border-color: rgba(0,212,232,0.5) !important;
  box-shadow: 0 20px 60px rgba(0,0,0,0.4), 0 0 30px rgba(0,212,232,0.15) !important;
}

/* Quickview / Produktdetail Links */
.product__manufacturer a,
.quickview__details-link,
a.quickview__details-link,
.text-primary-emphasis,
span.text-primary-emphasis {
  color: #00d4e8 !important;
}

/* Dropdown Optionen */
select option {
  background-color: #0d1530 !important;
  color: rgba(255,255,255,0.80) !important;
}

/* Neue Adresse hinzufügen */
a.address-card--add-address,
a.address-card--add-address span,
.address-card__add-text { color: #00d4e8 !important; }

/* Plus Icon auf Add-Address Button */
.address-card__add-icon,
.address-card__add-icon i,
.address-card--add-address .btn-primary i,
.address-card--add-address .material-icons { color: #0a0f1e !important; }

/* Material Icons allgemein */
.material-icons { color: #00d4e8 !important; }

/* Ausnahme: Icons auf primären Buttons sollen dunkel bleiben */
.btn-primary .material-icons,
.btn-square-icon.btn-primary .material-icons { color: #0a0f1e !important; }

/* Globale Link-Farbe überschreiben */
a:not(.btn):not(.nav-link):not(.dropdown-item) {
  color: #00d4e8 !important;
}
a:not(.btn):not(.nav-link):not(.dropdown-item):hover {
  color: #ffffff !important;
}



/* Quantity +/- Icons */

/* Quantity Button Icons */
.quantity-button button .material-icons { color: #00d4e8 !important; }

/* Quantity Buttons */
#quantity_wanted,
.js-quantity-button button i.material-icons,
button.decrement i,
button.increment i,
button[id^="decrement"] i,
button[id^="increment"] i { color: #00d4e8 !important; }

/* Quantity +/- sichtbar machen */
i.material-icons { color: #00d4e8 !important; }
i.material-icons.confirmation { color: #00d4e8 !important; }

/* Quantity +/- fix */
.quantity-button button i.material-icons,
button.decrement i.material-icons,
button.increment i.material-icons,
button[id^="decrement_button"] i.material-icons,
button[id^="increment_button"] i.material-icons { color: #00d4e8 !important; }
