/* ================================
   Neaml Studio - Zid CSS Upgrade
   Visual Style: Creative / Modern / Clean
   ================================ */

@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Sans+Arabic:wght@400;500;600;700&family=Poppins:wght@400;500;600;700;800&display=swap');

:root {
  --neaml-bg: #F1FAFF;
  --neaml-white: #FFFFFF;
  --neaml-green: #63BD3D;
  --neaml-green-2: #4FAD56;
  --neaml-teal: #289182;
  --neaml-blue-teal: #158198;
  --neaml-blue: #0269BE;
  --neaml-dark: #0B2A4A;
  --neaml-text: #1F2933;
  --neaml-muted: #667085;
  --neaml-border: rgba(2, 105, 190, 0.12);
  --neaml-shadow: 0 14px 34px rgba(11, 42, 74, 0.10);
}

/* General */
body {
  background: linear-gradient(180deg, #F1FAFF 0%, #FFFFFF 45%, #F7FCFF 100%) !important;
  color: var(--neaml-text) !important;
  font-family: "IBM Plex Sans Arabic", "Poppins", sans-serif !important;
}

/* Headings */
h1, h2, h3, h4, h5,
.section-title,
.title,
.product-title,
.product-name {
  color: var(--neaml-dark) !important;
  font-weight: 800 !important;
  letter-spacing: -0.3px;
}

/* Links */
a {
  transition: all 0.25s ease;
}

a:hover {
  color: var(--neaml-blue) !important;
}

/* Main Buttons */
button,
.btn,
.button,
a.btn,
.add-to-cart,
.product-form__submit,
.product-add-to-cart,
.checkout-btn,
.cart-btn {
  border-radius: 999px !important;
  font-weight: 800 !important;
  border: none !important;
  min-height: 46px;
  transition: all 0.25s ease !important;
}

/* Primary CTA */
.btn-primary,
.button-primary,
.add-to-cart,
.product-form__submit,
.product-add-to-cart,
.checkout-btn {
  background: linear-gradient(135deg, var(--neaml-green), var(--neaml-blue)) !important;
  color: #FFFFFF !important;
  box-shadow: 0 12px 24px rgba(2, 105, 190, 0.22) !important;
}

.btn-primary:hover,
.button-primary:hover,
.add-to-cart:hover,
.product-form__submit:hover,
.product-add-to-cart:hover,
.checkout-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 32px rgba(2, 105, 190, 0.30) !important;
  filter: saturate(1.08);
}

/* Secondary Buttons */
.btn-secondary,
.button-secondary {
  background: #FFFFFF !important;
  color: var(--neaml-blue) !important;
  border: 1px solid var(--neaml-border) !important;
}

/* Header */
header,
.site-header,
.header,
.navbar {
  background: rgba(255, 255, 255, 0.92) !important;
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--neaml-border) !important;
  box-shadow: 0 8px 24px rgba(11, 42, 74, 0.04);
}

/* Logo area */
.logo img,
.site-logo img,
.header-logo img {
  max-height: 58px !important;
}

/* Hero / Main Banner */
.hero,
.main-slider,
.banner,
.home-slider,
.swiper,
.slider {
  border-radius: 0 0 34px 34px !important;
  overflow: hidden !important;
}

.hero,
.banner {
  background: radial-gradient(circle at top left, rgba(99, 189, 61, 0.16), transparent 32%),
              radial-gradient(circle at bottom right, rgba(2, 105, 190, 0.18), transparent 35%),
              #F1FAFF !important;
}

/* Sections */
section,
.section,
.home-section {
  padding-top: 42px !important;
  padding-bottom: 42px !important;
}

/* Section titles */
.section-title,
.home-section-title {
  position: relative;
  display: inline-block;
  color: var(--neaml-dark) !important;
}

.section-title::after,
.home-section-title::after {
  content: "";
  display: block;
  width: 54px;
  height: 5px;
  margin-top: 10px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--neaml-green), var(--neaml-blue));
}

/* Product / Workshop Cards */
.product-card,
.product-item,
.card,
.products-list .item,
.product-box {
  background: rgba(255, 255, 255, 0.96) !important;
  border: 1px solid var(--neaml-border) !important;
  border-radius: 26px !important;
  overflow: hidden !important;
  box-shadow: 0 10px 26px rgba(11, 42, 74, 0.07) !important;
  transition: all 0.28s ease !important;
}

.product-card:hover,
.product-item:hover,
.card:hover,
.products-list .item:hover,
.product-box:hover {
  transform: translateY(-5px);
  box-shadow: var(--neaml-shadow) !important;
}

/* Product images */
.product-card img,
.product-item img,
.card img,
.product-box img {
  border-radius: 22px !important;
  transition: all 0.35s ease !important;
}

.product-card:hover img,
.product-item:hover img,
.card:hover img,
.product-box:hover img {
  transform: scale(1.025);
}

/* Product title */
.product-title,
.product-card__title,
.product-name,
.card-title {
  color: var(--neaml-dark) !important;
  font-weight: 800 !important;
  line-height: 1.6 !important;
}

/* Price */
.price,
.product-price,
.product__price,
.sale-price {
  color: var(--neaml-blue) !important;
  font-weight: 900 !important;
  font-size: 1.08rem !important;
}

/* Old price */
.old-price,
.compare-price {
  color: var(--neaml-muted) !important;
  opacity: 0.7;
}

/* Badges: sale / new / sold out */
.badge,
.label,
.product-badge,
.sale-badge,
.out-of-stock {
  border-radius: 999px !important;
  padding: 6px 12px !important;
  font-weight: 800 !important;
  background: linear-gradient(135deg, var(--neaml-green), var(--neaml-teal)) !important;
  color: #FFFFFF !important;
}

/* Product details page */
.product-details,
.product-info,
.product-single,
.product-page-info {
  background: #FFFFFF !important;
  border: 1px solid var(--neaml-border) !important;
  border-radius: 30px !important;
  padding: 26px !important;
  box-shadow: 0 14px 34px rgba(11, 42, 74, 0.08) !important;
}

/* Product description */
.product-description,
.description,
.product-details__description {
  color: var(--neaml-text) !important;
  line-height: 1.9 !important;
  font-size: 16px !important;
}

/* Quantity selector */
.quantity,
.qty,
.quantity-selector {
  border-radius: 999px !important;
  border: 1px solid var(--neaml-border) !important;
  overflow: hidden !important;
}

/* Inputs */
input,
textarea,
select {
  border-radius: 16px !important;
  border: 1px solid var(--neaml-border) !important;
  background: #FFFFFF !important;
}

input:focus,
textarea:focus,
select:focus {
  border-color: var(--neaml-blue) !important;
  box-shadow: 0 0 0 4px rgba(2, 105, 190, 0.10) !important;
  outline: none !important;
}

/* Cart / checkout boxes */
.cart,
.cart-item,
.checkout,
.order-summary,
.summary,
.sidebar {
  border-radius: 24px !important;
  border: 1px solid var(--neaml-border) !important;
  box-shadow: 0 10px 26px rgba(11, 42, 74, 0.06) !important;
}

/* Footer */
footer,
.footer,
.site-footer {
  background: linear-gradient(135deg, var(--neaml-dark), #063F6D) !important;
  color: #FFFFFF !important;
  border-radius: 34px 34px 0 0 !important;
  overflow: hidden !important;
}

footer a,
.footer a,
.site-footer a {
  color: #FFFFFF !important;
  opacity: 0.9;
}

footer a:hover,
.footer a:hover,
.site-footer a:hover {
  opacity: 1;
  color: #A8E86D !important;
}

/* WhatsApp / floating buttons */
.whatsapp,
.whatsapp-button,
.floating-button,
.float-btn {
  border-radius: 999px !important;
  box-shadow: 0 12px 28px rgba(11, 42, 74, 0.22) !important;
}

/* Mobile */
@media (max-width: 768px) {
  body {
    font-size: 15px !important;
  }

  header,
  .site-header,
  .header {
    border-radius: 0 0 22px 22px !important;
  }

  section,
  .section,
  .home-section {
    padding-top: 28px !important;
    padding-bottom: 28px !important;
  }

  .product-card,
  .product-item,
  .card,
  .product-box {
    border-radius: 22px !important;
  }

  .product-details,
  .product-info,
  .product-single,
  .product-page-info {
    padding: 18px !important;
    border-radius: 24px !important;
  }

  button,
  .btn,
  .button,
  a.btn,
  .add-to-cart,
  .product-form__submit,
  .product-add-to-cart,
  .checkout-btn {
    width: 100% !important;
    min-height: 50px !important;
    font-size: 15px !important;
  }

  .hero,
  .main-slider,
  .banner,
  .home-slider {
    border-radius: 0 0 24px 24px !important;
  }

  .product-description,
  .description,
  .product-details__description {
    font-size: 15px !important;
    line-height: 1.85 !important;
  }
}

/* Small premium touch: soft background blobs */
body::before {
  content: "";
  position: fixed;
  top: -120px;
  right: -120px;
  width: 320px;
  height: 320px;
  background: radial-gradient(circle, rgba(99, 189, 61, 0.18), transparent 65%);
  z-index: -1;
  pointer-events: none;
}

body::after {
  content: "";
  position: fixed;
  bottom: -140px;
  left: -120px;
  width: 360px;
  height: 360px;
  background: radial-gradient(circle, rgba(2, 105, 190, 0.16), transparent 65%);
  z-index: -1;
  pointer-events: none;
}