/*
Theme Name:   Vilmono Child
Theme URI:    https://vilmono.com
Description:  Vilmono Pet Store - Child Theme for Kadence
Author:       Vilmono
Author URI:   https://vilmono.com
Template:     kadence
Version:      1.0.0
Text Domain:  vilmono-child
*/

/* =============================================
   VILMONO DESIGN SYSTEM
   Brand Colors & Typography
   ============================================= */

:root {
  /* Brand Colors */
  --vilmono-primary:       #1A1A2E;   /* Deep navy - primary text & header */
  --vilmono-accent:        #F4A01C;   /* Warm amber - CTA buttons */
  --vilmono-accent-hover:  #D4880C;   /* Darker amber on hover */
  --vilmono-light:         #F8F9FA;   /* Off-white background */
  --vilmono-white:         #FFFFFF;
  --vilmono-gray-100:      #F3F4F6;
  --vilmono-gray-200:      #E5E7EB;
  --vilmono-gray-400:      #9CA3AF;
  --vilmono-gray-600:      #6B7280;
  --vilmono-gray-800:      #1F2937;
  --vilmono-success:       #10B981;
  --vilmono-red:           #EF4444;

  /* Typography */
  --vilmono-font-heading: 'Plus Jakarta Sans', 'Inter', sans-serif;
  --vilmono-font-body:    'Inter', 'Helvetica Neue', sans-serif;

  /* Spacing */
  --vilmono-section-padding: 80px 0;
  --vilmono-container-max:   1280px;

  /* Borders */
  --vilmono-radius-sm:  6px;
  --vilmono-radius-md:  12px;
  --vilmono-radius-lg:  20px;

  /* Shadows */
  --vilmono-shadow-sm:  0 1px 3px rgba(0,0,0,0.08), 0 1px 2px rgba(0,0,0,0.05);
  --vilmono-shadow-md:  0 4px 16px rgba(0,0,0,0.10);
  --vilmono-shadow-lg:  0 10px 40px rgba(0,0,0,0.14);
  --vilmono-shadow-hover: 0 20px 60px rgba(0,0,0,0.18);
}

/* =============================================
   GOOGLE FONTS IMPORT
   ============================================= */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Inter:wght@300;400;500;600&display=swap');

/* =============================================
   GLOBAL BASE STYLES
   ============================================= */

*, *::before, *::after {
  box-sizing: border-box;
}

body {
  font-family: var(--vilmono-font-body);
  color: var(--vilmono-gray-800);
  background-color: var(--vilmono-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height: 1.6;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--vilmono-font-heading);
  font-weight: 700;
  color: var(--vilmono-primary);
  line-height: 1.2;
}

a {
  color: var(--vilmono-primary);
  text-decoration: none;
  transition: color 0.2s ease;
}

a:hover { color: var(--vilmono-accent); }

img {
  max-width: 100%;
  height: auto;
  display: block;
}

/* =============================================
   ANNOUNCEMENT BAR
   ============================================= */

.vilmono-announcement-bar {
  background: var(--vilmono-primary);
  color: var(--vilmono-white);
  text-align: center;
  padding: 10px 20px;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.3px;
  position: relative;
  z-index: 1000;
}

.vilmono-announcement-bar a {
  color: var(--vilmono-accent);
  font-weight: 600;
  margin-left: 8px;
}

.vilmono-announcement-bar .close-bar {
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: rgba(255,255,255,0.6);
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  padding: 0;
}

/* =============================================
   HEADER STYLES
   ============================================= */

.site-header,
.wp-block-kadence-header {
  background: var(--vilmono-white) !important;
  border-bottom: 1px solid var(--vilmono-gray-200);
  position: sticky;
  top: 0;
  z-index: 999;
  transition: box-shadow 0.3s ease;
}

.site-header.scrolled {
  box-shadow: var(--vilmono-shadow-md);
}

/* Logo — explicit height + auto width so the SVG logo (0×0 metadata) renders */
.site-logo img,
.custom-logo,
img.custom-logo,
.site-branding img.custom-logo {
  height: 44px !important;
  width: auto !important;
  max-height: 44px !important;
  max-width: 220px !important;
}

@media (max-width: 600px) {
  .site-logo img,
  .custom-logo,
  img.custom-logo {
    height: 38px !important;
    max-height: 38px !important;
  }
}

/* The SVG logo already contains the name → hide the redundant text site-title */
.site-title-wrap,
.site-branding .site-title,
.site-header .site-title,
p.site-title {
  display: none !important;
}

/* Navigation */
.primary-menu-container nav ul li a {
  font-family: var(--vilmono-font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--vilmono-gray-800);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 8px 14px;
  border-radius: var(--vilmono-radius-sm);
  transition: all 0.2s ease;
}

.primary-menu-container nav ul li a:hover {
  color: var(--vilmono-accent);
  background: rgba(244,160,28,0.08);
}

/* Header Icons */
.header-cart-button,
.header-account-link {
  color: var(--vilmono-primary) !important;
  transition: color 0.2s ease;
}

.header-cart-button:hover,
.header-account-link:hover {
  color: var(--vilmono-accent) !important;
}

/* Cart Count Badge */
.cart-count,
.woo-cart-count {
  background: var(--vilmono-accent) !important;
  color: var(--vilmono-white) !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  min-width: 18px;
  height: 18px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

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

.vilmono-hero {
  min-height: 620px;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
}

.vilmono-hero-content {
  position: relative;
  z-index: 2;
  max-width: 600px;
}

.vilmono-hero-eyebrow {
  display: inline-block;
  background: rgba(244,160,28,0.15);
  color: var(--vilmono-accent);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  padding: 6px 14px;
  border-radius: 50px;
  margin-bottom: 20px;
}

.vilmono-hero h1 {
  font-size: clamp(36px, 5vw, 64px);
  font-weight: 800;
  line-height: 1.1;
  color: var(--vilmono-white);
  margin-bottom: 20px;
  text-shadow: 0 2px 20px rgba(0,0,0,0.3);
}

.vilmono-hero p {
  font-size: 18px;
  color: rgba(255,255,255,0.9);
  margin-bottom: 36px;
  line-height: 1.7;
}

/* =============================================
   BUTTONS
   ============================================= */

.btn-primary,
.vilmono-btn-primary,
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #payment #place_order {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--vilmono-accent) !important;
  color: var(--vilmono-white) !important;
  font-family: var(--vilmono-font-body) !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  padding: 14px 32px !important;
  border-radius: var(--vilmono-radius-sm) !important;
  border: none !important;
  cursor: pointer;
  text-decoration: none;
  transition: all 0.25s ease !important;
  letter-spacing: 0.3px;
  box-shadow: 0 4px 15px rgba(244,160,28,0.3);
}

.btn-primary:hover,
.vilmono-btn-primary:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
  background: var(--vilmono-accent-hover) !important;
  color: var(--vilmono-white) !important;
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(244,160,28,0.4) !important;
}

.btn-secondary,
.vilmono-btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: transparent;
  color: var(--vilmono-white);
  font-size: 15px;
  font-weight: 600;
  padding: 13px 30px;
  border-radius: var(--vilmono-radius-sm);
  border: 2px solid rgba(255,255,255,0.8);
  cursor: pointer;
  text-decoration: none;
  transition: all 0.25s ease;
}

.btn-secondary:hover,
.vilmono-btn-secondary:hover {
  background: rgba(255,255,255,0.15);
  border-color: var(--vilmono-white);
  color: var(--vilmono-white);
}

/* =============================================
   SECTION HEADERS
   ============================================= */

.vilmono-section-header {
  text-align: center;
  margin-bottom: 50px;
}

.vilmono-section-eyebrow {
  display: inline-block;
  color: var(--vilmono-accent);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-bottom: 12px;
}

.vilmono-section-title {
  font-size: clamp(28px, 4vw, 42px);
  font-weight: 800;
  color: var(--vilmono-primary);
  margin: 0 0 16px;
}

.vilmono-section-subtitle {
  font-size: 17px;
  color: var(--vilmono-gray-600);
  max-width: 560px;
  margin: 0 auto;
  line-height: 1.7;
}

/* =============================================
   COLLECTIONS GRID
   ============================================= */

.vilmono-collections-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

@media (max-width: 1024px) {
  .vilmono-collections-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
  .vilmono-collections-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
}

.vilmono-collection-card {
  position: relative;
  border-radius: var(--vilmono-radius-md);
  overflow: hidden;
  aspect-ratio: 3/4;
  cursor: pointer;
  background: var(--vilmono-gray-200);
}

.vilmono-collection-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}

.vilmono-collection-card:hover img {
  transform: scale(1.06);
}

.vilmono-collection-card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(26,26,46,0.85) 0%, rgba(26,26,46,0.1) 60%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 24px 20px;
}

.vilmono-collection-card-title {
  font-size: 18px;
  font-weight: 700;
  color: var(--vilmono-white);
  margin-bottom: 8px;
}

.vilmono-collection-card-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--vilmono-accent);
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  transition: gap 0.2s ease;
}

.vilmono-collection-card:hover .vilmono-collection-card-link {
  gap: 10px;
}

/* =============================================
   PRODUCT CARDS
   ============================================= */

.woocommerce ul.products li.product,
.vilmono-product-card {
  background: var(--vilmono-white);
  border: 1px solid var(--vilmono-gray-200);
  border-radius: var(--vilmono-radius-md);
  overflow: hidden;
  transition: all 0.3s ease;
  position: relative;
}

.woocommerce ul.products li.product:hover,
.vilmono-product-card:hover {
  box-shadow: var(--vilmono-shadow-lg);
  transform: translateY(-4px);
  border-color: transparent;
}

/* Product Image */
.woocommerce ul.products li.product .woocommerce-loop-product__link img,
.vilmono-product-card .product-image img {
  width: 100%;
  aspect-ratio: 1/1;
  object-fit: cover;
  transition: transform 0.5s ease;
}

.woocommerce ul.products li.product:hover img {
  transform: scale(1.04);
}

/* Product Info */
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--vilmono-font-body);
  font-size: 15px;
  font-weight: 600;
  color: var(--vilmono-gray-800);
  padding: 16px 16px 4px;
  line-height: 1.4;
}

.woocommerce ul.products li.product .price {
  padding: 0 16px;
  font-size: 16px;
  font-weight: 700;
  color: var(--vilmono-primary);
}

.woocommerce ul.products li.product .price del {
  color: var(--vilmono-gray-400);
  font-weight: 400;
  font-size: 13px;
  margin-right: 6px;
}

.woocommerce ul.products li.product .price ins {
  text-decoration: none;
  color: var(--vilmono-red);
}

/* Add to Cart button on card */
.woocommerce ul.products li.product .button {
  margin: 12px 16px 16px !important;
  width: calc(100% - 32px) !important;
  text-align: center !important;
  justify-content: center !important;
}

/* Sale Badge */
.woocommerce span.onsale,
.vilmono-badge-sale {
  background: var(--vilmono-red) !important;
  color: var(--vilmono-white) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  padding: 4px 10px !important;
  border-radius: 50px !important;
  top: 12px !important;
  left: 12px !important;
}

/* New Badge */
.vilmono-badge-new {
  position: absolute;
  top: 12px;
  left: 12px;
  background: var(--vilmono-success);
  color: var(--vilmono-white);
  font-size: 11px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 50px;
  z-index: 2;
}

/* Wishlist Button on Card */
.vilmono-wishlist-btn {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 36px;
  height: 36px;
  background: var(--vilmono-white);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  cursor: pointer;
  box-shadow: var(--vilmono-shadow-sm);
  transition: all 0.2s ease;
  z-index: 2;
  color: var(--vilmono-gray-400);
}

.vilmono-wishlist-btn:hover {
  color: var(--vilmono-red);
  transform: scale(1.1);
}

/* =============================================
   PRODUCT PAGE — SINGLE
   ============================================= */

.woocommerce div.product {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: start;
}

@media (max-width: 768px) {
  .woocommerce div.product {
    grid-template-columns: 1fr;
    gap: 30px;
  }
}

/* Product Gallery */
.woocommerce div.product div.images {
  position: sticky;
  top: 100px;
}

.woocommerce div.product div.images .woocommerce-product-gallery__image img {
  border-radius: var(--vilmono-radius-md);
  width: 100%;
}

/* Product Summary */
.woocommerce div.product div.summary {
  padding-top: 0;
}

.woocommerce div.product .product_title {
  font-size: clamp(22px, 3vw, 32px);
  font-weight: 800;
  color: var(--vilmono-primary);
  margin-bottom: 16px;
  line-height: 1.2;
}

/* Product Price */
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-size: 26px !important;
  font-weight: 700 !important;
  color: var(--vilmono-primary) !important;
  margin-bottom: 20px !important;
}

.woocommerce div.product p.price del {
  color: var(--vilmono-gray-400) !important;
  font-size: 18px !important;
  font-weight: 400 !important;
  margin-right: 8px;
}

.woocommerce div.product p.price ins {
  text-decoration: none !important;
  color: var(--vilmono-red) !important;
}

/* Star Rating */
.woocommerce .star-rating span::before {
  color: var(--vilmono-accent) !important;
}

.woocommerce .star-rating {
  color: var(--vilmono-accent) !important;
}

/* Product Short Description */
.woocommerce div.product .woocommerce-product-details__short-description {
  font-size: 15px;
  color: var(--vilmono-gray-600);
  line-height: 1.8;
  margin-bottom: 24px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--vilmono-gray-200);
}

/* Add to Cart Form */
.woocommerce div.product form.cart {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-bottom: 24px;
}

.woocommerce div.product form.cart .quantity {
  display: flex;
  align-items: center;
}

.woocommerce div.product form.cart .qty {
  width: 80px !important;
  height: 48px !important;
  text-align: center;
  font-size: 16px;
  font-weight: 600;
  border: 2px solid var(--vilmono-gray-200) !important;
  border-radius: var(--vilmono-radius-sm) !important;
  background: var(--vilmono-white);
}

.woocommerce div.product form.cart .button {
  flex: 1;
  height: 52px !important;
  font-size: 16px !important;
  letter-spacing: 0.3px;
}

/* Buy Now Button */
.vilmono-buy-now-btn {
  display: block;
  width: 100%;
  text-align: center;
  padding: 16px;
  background: var(--vilmono-primary);
  color: var(--vilmono-white);
  font-size: 15px;
  font-weight: 700;
  border-radius: var(--vilmono-radius-sm);
  border: none;
  cursor: pointer;
  transition: all 0.25s ease;
  text-decoration: none;
}

.vilmono-buy-now-btn:hover {
  background: #0D1117;
  color: var(--vilmono-white);
  transform: translateY(-1px);
  box-shadow: var(--vilmono-shadow-md);
}

/* Trust Badges under ATC */
.vilmono-product-trust {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  padding: 20px;
  background: var(--vilmono-gray-100);
  border-radius: var(--vilmono-radius-md);
  margin-top: 20px;
}

.vilmono-product-trust-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 500;
  color: var(--vilmono-gray-600);
}

.vilmono-product-trust-item svg,
.vilmono-product-trust-item .trust-icon {
  width: 20px;
  height: 20px;
  color: var(--vilmono-success);
  flex-shrink: 0;
}

/* Product Tabs */
.woocommerce div.product .woocommerce-tabs ul.tabs {
  padding: 0;
  border-bottom: 2px solid var(--vilmono-gray-200);
  margin-bottom: 0;
  display: flex;
  gap: 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
  background: none !important;
  border: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  font-size: 14px;
  font-weight: 600;
  color: var(--vilmono-gray-600);
  padding: 14px 24px;
  display: block;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: all 0.2s ease;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
  color: var(--vilmono-accent);
  border-bottom-color: var(--vilmono-accent);
}

.woocommerce div.product .woocommerce-tabs .panel {
  padding: 32px 0;
}

/* =============================================
   WHY CHOOSE US SECTION
   ============================================= */

.vilmono-features-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 30px;
}

@media (max-width: 1024px) {
  .vilmono-features-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
  .vilmono-features-grid { grid-template-columns: 1fr 1fr; gap: 16px; }
}

.vilmono-feature-card {
  text-align: center;
  padding: 36px 24px;
  background: var(--vilmono-white);
  border: 1px solid var(--vilmono-gray-200);
  border-radius: var(--vilmono-radius-md);
  transition: all 0.3s ease;
}

.vilmono-feature-card:hover {
  border-color: var(--vilmono-accent);
  box-shadow: var(--vilmono-shadow-md);
  transform: translateY(-4px);
}

.vilmono-feature-icon {
  width: 64px;
  height: 64px;
  background: rgba(244,160,28,0.1);
  border-radius: var(--vilmono-radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
  font-size: 28px;
  transition: background 0.2s ease;
}

.vilmono-feature-card:hover .vilmono-feature-icon {
  background: var(--vilmono-accent);
}

.vilmono-feature-card:hover .vilmono-feature-icon svg {
  color: var(--vilmono-white);
}

.vilmono-feature-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--vilmono-primary);
  margin-bottom: 10px;
}

.vilmono-feature-desc {
  font-size: 14px;
  color: var(--vilmono-gray-600);
  line-height: 1.6;
}

/* =============================================
   REVIEWS SECTION
   ============================================= */

.vilmono-reviews-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

@media (max-width: 1024px) {
  .vilmono-reviews-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
  .vilmono-reviews-grid { grid-template-columns: 1fr; }
}

.vilmono-review-card {
  background: var(--vilmono-white);
  border: 1px solid var(--vilmono-gray-200);
  border-radius: var(--vilmono-radius-md);
  padding: 28px;
  transition: box-shadow 0.3s ease;
}

.vilmono-review-card:hover {
  box-shadow: var(--vilmono-shadow-md);
}

.vilmono-review-stars {
  color: var(--vilmono-accent);
  font-size: 16px;
  margin-bottom: 12px;
  letter-spacing: 2px;
}

.vilmono-review-text {
  font-size: 15px;
  color: var(--vilmono-gray-600);
  line-height: 1.7;
  margin-bottom: 20px;
  font-style: italic;
}

.vilmono-review-author {
  display: flex;
  align-items: center;
  gap: 12px;
}

.vilmono-review-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  object-fit: cover;
  background: var(--vilmono-gray-200);
}

.vilmono-review-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--vilmono-primary);
}

.vilmono-review-location {
  font-size: 12px;
  color: var(--vilmono-gray-400);
}

.vilmono-verified-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: var(--vilmono-success);
  font-size: 11px;
  font-weight: 600;
}

/* =============================================
   TRUST BADGES BAR
   ============================================= */

.vilmono-trust-bar {
  background: var(--vilmono-gray-100);
  padding: 28px 0;
  border-top: 1px solid var(--vilmono-gray-200);
  border-bottom: 1px solid var(--vilmono-gray-200);
}

.vilmono-trust-bar-inner {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 40px;
}

.vilmono-trust-item {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 14px;
  font-weight: 600;
  color: var(--vilmono-gray-800);
}

.vilmono-trust-item svg {
  width: 28px;
  height: 28px;
  color: var(--vilmono-accent);
  flex-shrink: 0;
}

/* =============================================
   NEWSLETTER SECTION
   ============================================= */

.vilmono-newsletter {
  background: var(--vilmono-primary);
  padding: 80px 0;
  text-align: center;
}

.vilmono-newsletter h2 {
  color: var(--vilmono-white);
  font-size: clamp(26px, 4vw, 40px);
  margin-bottom: 12px;
}

.vilmono-newsletter p {
  color: rgba(255,255,255,0.75);
  font-size: 16px;
  margin-bottom: 36px;
  max-width: 480px;
  margin-left: auto;
  margin-right: auto;
}

.vilmono-newsletter-form {
  display: flex;
  gap: 0;
  max-width: 480px;
  margin: 0 auto;
  border-radius: var(--vilmono-radius-sm);
  overflow: hidden;
  box-shadow: 0 8px 30px rgba(0,0,0,0.3);
}

.vilmono-newsletter-form input[type="email"] {
  flex: 1;
  padding: 16px 20px;
  font-size: 15px;
  border: none;
  outline: none;
  background: var(--vilmono-white);
  color: var(--vilmono-gray-800);
}

.vilmono-newsletter-form input[type="email"]::placeholder {
  color: var(--vilmono-gray-400);
}

.vilmono-newsletter-form button {
  padding: 16px 28px;
  background: var(--vilmono-accent);
  color: var(--vilmono-white);
  font-size: 14px;
  font-weight: 700;
  border: none;
  cursor: pointer;
  transition: background 0.2s ease;
  white-space: nowrap;
  letter-spacing: 0.3px;
}

.vilmono-newsletter-form button:hover {
  background: var(--vilmono-accent-hover);
}

.vilmono-newsletter-disclaimer {
  color: rgba(255,255,255,0.45);
  font-size: 12px;
  margin-top: 16px;
}

/* =============================================
   FOOTER
   ============================================= */

.site-footer,
.wp-block-kadence-footer {
  background: #0D1117;
  color: rgba(255,255,255,0.7);
}

.vilmono-footer-top {
  padding: 70px 0 50px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.vilmono-footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 48px;
}

@media (max-width: 1024px) {
  .vilmono-footer-grid { grid-template-columns: 1fr 1fr; gap: 36px; }
}

@media (max-width: 600px) {
  .vilmono-footer-grid { grid-template-columns: 1fr; gap: 28px; }
}

.vilmono-footer-brand p {
  font-size: 14px;
  line-height: 1.7;
  color: rgba(255,255,255,0.55);
  margin: 16px 0 24px;
  max-width: 280px;
}

.vilmono-footer-logo img {
  max-height: 40px;
  filter: brightness(0) invert(1);
}

.vilmono-social-links {
  display: flex;
  gap: 12px;
}

.vilmono-social-links a {
  width: 38px;
  height: 38px;
  background: rgba(255,255,255,0.08);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,0.7);
  font-size: 15px;
  transition: all 0.2s ease;
  text-decoration: none;
}

.vilmono-social-links a:hover {
  background: var(--vilmono-accent);
  color: var(--vilmono-white);
  transform: translateY(-2px);
}

.vilmono-footer-heading {
  font-size: 13px;
  font-weight: 700;
  color: var(--vilmono-white);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 20px;
}

.vilmono-footer-links {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.vilmono-footer-links li a {
  font-size: 14px;
  color: rgba(255,255,255,0.55);
  text-decoration: none;
  transition: color 0.2s ease;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.vilmono-footer-links li a:hover {
  color: var(--vilmono-accent);
}

.vilmono-footer-bottom {
  padding: 20px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
}

.vilmono-footer-copyright {
  font-size: 13px;
  color: rgba(255,255,255,0.35);
}

.vilmono-payment-icons {
  display: flex;
  gap: 8px;
  align-items: center;
}

.vilmono-payment-icons img {
  height: 26px;
  opacity: 0.6;
  transition: opacity 0.2s ease;
}

.vilmono-payment-icons img:hover {
  opacity: 1;
}

/* =============================================
   CART & CHECKOUT
   ============================================= */

.woocommerce-cart .cart-collaterals,
.woocommerce-cart table.cart {
  border-radius: var(--vilmono-radius-md) !important;
  border: 1px solid var(--vilmono-gray-200) !important;
  overflow: hidden;
}

.woocommerce table.shop_table th {
  background: var(--vilmono-gray-100) !important;
  font-size: 12px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.8px !important;
  font-weight: 700 !important;
  color: var(--vilmono-gray-600) !important;
  padding: 14px 16px !important;
}

.woocommerce table.shop_table td {
  padding: 16px !important;
  border-bottom: 1px solid var(--vilmono-gray-100) !important;
  vertical-align: middle !important;
}

/* Order Total Box */
.woocommerce-cart .cart_totals {
  background: var(--vilmono-gray-100);
  border-radius: var(--vilmono-radius-md);
  padding: 28px;
  border: 1px solid var(--vilmono-gray-200);
}

.woocommerce-cart .cart_totals h2 {
  font-size: 20px;
  margin-bottom: 20px;
}

/* Checkout */
.woocommerce-checkout .woocommerce-billing-fields__field-wrapper label,
.woocommerce-checkout .woocommerce-additional-fields__field-wrapper label {
  font-size: 13px;
  font-weight: 600;
  color: var(--vilmono-gray-600);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 6px;
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row select,
.woocommerce form .form-row textarea {
  border: 2px solid var(--vilmono-gray-200) !important;
  border-radius: var(--vilmono-radius-sm) !important;
  padding: 12px 16px !important;
  font-size: 15px !important;
  transition: border-color 0.2s ease !important;
  background: var(--vilmono-white) !important;
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row select:focus,
.woocommerce form .form-row textarea:focus {
  border-color: var(--vilmono-accent) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(244,160,28,0.15) !important;
}

/* Order Review */
.woocommerce-checkout #order_review {
  background: var(--vilmono-gray-100);
  border-radius: var(--vilmono-radius-md);
  padding: 28px;
  border: 1px solid var(--vilmono-gray-200);
}

/* =============================================
   STICKY ADD TO CART (MOBILE)
   ============================================= */

.vilmono-sticky-atc {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 900;
  background: var(--vilmono-white);
  border-top: 1px solid var(--vilmono-gray-200);
  padding: 12px 16px;
  box-shadow: 0 -4px 20px rgba(0,0,0,0.12);
  align-items: center;
  gap: 12px;
}

@media (max-width: 768px) {
  .vilmono-sticky-atc.is-visible {
    display: flex;
  }
}

.vilmono-sticky-atc-info {
  flex: 1;
  min-width: 0;
}

.vilmono-sticky-atc-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--vilmono-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.vilmono-sticky-atc-price {
  font-size: 15px;
  font-weight: 700;
  color: var(--vilmono-accent);
}

.vilmono-sticky-atc-btn {
  flex-shrink: 0;
  padding: 12px 24px;
  background: var(--vilmono-accent);
  color: var(--vilmono-white);
  font-size: 14px;
  font-weight: 700;
  border: none;
  border-radius: var(--vilmono-radius-sm);
  cursor: pointer;
  transition: background 0.2s ease;
}

.vilmono-sticky-atc-btn:hover {
  background: var(--vilmono-accent-hover);
}

/* =============================================
   PROMO BANNER
   ============================================= */

.vilmono-promo-banner {
  border-radius: var(--vilmono-radius-lg);
  overflow: hidden;
  position: relative;
  min-height: 300px;
  display: flex;
  align-items: center;
}

.vilmono-promo-banner img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.vilmono-promo-content {
  position: relative;
  z-index: 2;
  padding: 60px;
  max-width: 500px;
}

@media (max-width: 640px) {
  .vilmono-promo-content { padding: 32px; }
}

/* =============================================
   VIDEO SECTION
   ============================================= */

.vilmono-video-section {
  background: var(--vilmono-primary);
  padding: var(--vilmono-section-padding);
}

.vilmono-video-wrapper {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}

@media (max-width: 768px) {
  .vilmono-video-wrapper { grid-template-columns: 1fr; gap: 32px; }
}

.vilmono-video-embed {
  border-radius: var(--vilmono-radius-md);
  overflow: hidden;
  aspect-ratio: 16/9;
  box-shadow: var(--vilmono-shadow-lg);
}

.vilmono-video-embed iframe,
.vilmono-video-embed video {
  width: 100%;
  height: 100%;
  display: block;
}

.vilmono-video-content h2 {
  color: var(--vilmono-white);
  margin-bottom: 16px;
}

.vilmono-video-content p {
  color: rgba(255,255,255,0.7);
  line-height: 1.7;
  margin-bottom: 28px;
}

/* =============================================
   BREADCRUMBS
   ============================================= */

.woocommerce-breadcrumb {
  font-size: 13px;
  color: var(--vilmono-gray-400);
  margin-bottom: 24px;
}

.woocommerce-breadcrumb a {
  color: var(--vilmono-gray-600);
}

.woocommerce-breadcrumb a:hover {
  color: var(--vilmono-accent);
}

/* =============================================
   SHOP / ARCHIVE PAGE
   ============================================= */

.woocommerce-products-header__title {
  font-size: clamp(24px, 3vw, 36px) !important;
}

/* Filter bar */
.woocommerce-ordering select {
  border: 2px solid var(--vilmono-gray-200) !important;
  border-radius: var(--vilmono-radius-sm) !important;
  padding: 10px 16px !important;
  font-size: 14px !important;
  color: var(--vilmono-gray-800) !important;
  cursor: pointer;
}

/* =============================================
   PAGINATION
   ============================================= */

.woocommerce nav.woocommerce-pagination ul {
  border: none !important;
  display: flex;
  gap: 6px;
}

.woocommerce nav.woocommerce-pagination ul li {
  border: none !important;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  padding: 10px 16px !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  border: 2px solid var(--vilmono-gray-200) !important;
  border-radius: var(--vilmono-radius-sm) !important;
  transition: all 0.2s ease;
  color: var(--vilmono-gray-800) !important;
  background: var(--vilmono-white) !important;
}

.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li span.current {
  background: var(--vilmono-accent) !important;
  border-color: var(--vilmono-accent) !important;
  color: var(--vilmono-white) !important;
}

/* =============================================
   MOBILE MENU (Kadence off-canvas drawer)
   Kadence renders drawer links in near-white;
   force dark, readable text on a white drawer.
   ============================================= */

/* Drawer background white */
.drawer-content,
.mobile-drawer-content,
.popup-drawer-layout-fullwidth .drawer-inner {
  background: var(--vilmono-white) !important;
}

/* Drawer menu links — dark and clearly visible */
.mobile-drawer-content .menu-item a,
.mobile-drawer-content nav ul li a,
.drawer-content .menu-item a,
.drawer-content nav ul li a,
.mobile-navigation ul li a {
  color: var(--vilmono-primary) !important;
  opacity: 1 !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  padding: 15px 22px !important;
  display: block !important;
  border-bottom: 1px solid var(--vilmono-gray-100) !important;
  letter-spacing: 0.3px;
}

.mobile-drawer-content .menu-item a:hover,
.mobile-drawer-content .menu-item.current-menu-item > a,
.drawer-content .menu-item a:hover,
.mobile-navigation ul li a:hover {
  color: var(--vilmono-accent) !important;
  background: rgba(244,160,28,0.06) !important;
}

/* Drawer close (X) icon visible */
.drawer-content .menu-toggle-close,
.mobile-drawer-content .menu-toggle-close {
  color: var(--vilmono-primary) !important;
}

/* =============================================
   NOTIFICATIONS & ALERTS
   ============================================= */

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  border-radius: var(--vilmono-radius-sm) !important;
  padding: 14px 20px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  border-top: none !important;
}

.woocommerce-message {
  background: #ECFDF5 !important;
  border-left: 4px solid var(--vilmono-success) !important;
  color: #065F46 !important;
}

.woocommerce-error {
  background: #FEF2F2 !important;
  border-left: 4px solid var(--vilmono-red) !important;
  color: #991B1B !important;
}

.woocommerce-info {
  background: #EFF6FF !important;
  border-left: 4px solid #3B82F6 !important;
  color: #1E40AF !important;
}

/* =============================================
   LOADING SPINNER
   ============================================= */

.vilmono-loading {
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 2px solid rgba(255,255,255,0.3);
  border-radius: 50%;
  border-top-color: var(--vilmono-white);
  animation: vilmono-spin 0.7s linear infinite;
}

@keyframes vilmono-spin {
  to { transform: rotate(360deg); }
}

/* =============================================
   UTILITIES
   ============================================= */

.container,
.vilmono-container {
  max-width: var(--vilmono-container-max);
  margin: 0 auto;
  padding: 0 24px;
}

.vilmono-section {
  padding: var(--vilmono-section-padding);
}

.vilmono-section-light { background: var(--vilmono-white); }
.vilmono-section-gray  { background: var(--vilmono-gray-100); }

.text-center { text-align: center; }
.text-accent  { color: var(--vilmono-accent); }
.text-primary { color: var(--vilmono-primary); }

.d-flex { display: flex; }
.align-center { align-items: center; }
.justify-between { justify-content: space-between; }

.mt-1 { margin-top: 8px; }
.mt-2 { margin-top: 16px; }
.mt-3 { margin-top: 24px; }
.mt-4 { margin-top: 32px; }
.mt-5 { margin-top: 48px; }

.mb-1 { margin-bottom: 8px; }
.mb-2 { margin-bottom: 16px; }
.mb-3 { margin-bottom: 24px; }
.mb-4 { margin-bottom: 32px; }
.mb-5 { margin-bottom: 48px; }

/* Visually hidden */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  border: 0;
}

/* =============================================
   ANIMATIONS
   ============================================= */

@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}

.animate-fade-in-up {
  animation: fadeInUp 0.6s ease both;
}

.animate-delay-1 { animation-delay: 0.1s; }
.animate-delay-2 { animation-delay: 0.2s; }
.animate-delay-3 { animation-delay: 0.3s; }
.animate-delay-4 { animation-delay: 0.4s; }

/* =============================================
   RESPONSIVE ADJUSTMENTS
   ============================================= */

@media (max-width: 768px) {
  :root {
    --vilmono-section-padding: 50px 0;
  }

  .vilmono-newsletter-form {
    flex-direction: column;
    border-radius: var(--vilmono-radius-sm);
    overflow: visible;
  }

  .vilmono-newsletter-form input[type="email"],
  .vilmono-newsletter-form button {
    border-radius: var(--vilmono-radius-sm);
    width: 100%;
  }

  .vilmono-trust-bar-inner {
    gap: 20px;
  }

  .vilmono-promo-content {
    padding: 32px 20px;
  }

  .woocommerce div.product div.images {
    position: static;
  }
}

@media (max-width: 480px) {
  .vilmono-footer-bottom {
    flex-direction: column;
    text-align: center;
  }
}

/* =============================================
   PRODUCT GRID — FORCE CONSISTENT COLUMNS
   Overrides theme float layout so products
   always sit in a clean responsive grid.
   ============================================= */

.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 24px !important;
  margin: 0 0 40px !important;
  padding: 0 !important;
  list-style: none !important;
}

/* Homepage carousels / 3-col contexts */
.woocommerce ul.products.columns-3 {
  grid-template-columns: repeat(3, 1fr) !important;
}
.woocommerce ul.products.columns-2 {
  grid-template-columns: repeat(2, 1fr) !important;
}

@media (max-width: 1100px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}
@media (max-width: 782px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 14px !important;
  }
}

/* Kill WooCommerce's default float/percentage widths */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  width: auto !important;
  margin: 0 !important;
  float: none !important;
  clear: none !important;
  display: flex !important;
  flex-direction: column !important;
}

/* =============================================
   PRODUCT CARD — CONSISTENT ALIGNMENT
   ============================================= */

.woocommerce ul.products li.product {
  position: relative;
  background: var(--vilmono-white);
  border: none !important;
  border-radius: 10px;
  overflow: visible;               /* allow stroke to draw on edges */
  box-shadow: 0 0 0 1px var(--vilmono-gray-200);
  transition: box-shadow .3s ease, transform .3s ease;
  text-align: left;
  padding-bottom: 4px;
}

/* Image: equal square, rounded top, sits flush */
.woocommerce ul.products li.product a.woocommerce-LoopProduct-link,
.woocommerce ul.products li.product a {
  display: block;
}
.woocommerce ul.products li.product img {
  width: 100% !important;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  margin: 0 0 0 0 !important;
  border-radius: 10px 10px 0 0;
  background: var(--vilmono-gray-100);
}

/* Consistent title block — clamped to 2 lines so all cards align */
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--vilmono-font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--vilmono-gray-800);
  line-height: 1.45;
  padding: 14px 16px 6px !important;
  margin: 0 !important;
  min-height: calc(1.45em * 2 + 20px);  /* reserves 2 lines → prices align */
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Star rating aligned */
.woocommerce ul.products li.product .star-rating {
  margin: 0 16px 8px !important;
  font-size: 13px;
}

/* Price pinned consistently */
.woocommerce ul.products li.product .price {
  padding: 0 16px !important;
  margin: 0 0 4px !important;
  font-size: 16px;
  font-weight: 700;
  color: var(--vilmono-primary);
  display: block;
}
.woocommerce ul.products li.product .price del {
  color: var(--vilmono-gray-400);
  font-weight: 400;
  font-size: 13px;
  margin-right: 6px;
  opacity: 1;
}
.woocommerce ul.products li.product .price ins {
  text-decoration: none;
  color: var(--vilmono-red);
}

/* Kadence hides the action buttons (opacity:0) until hover — keep CTA always visible */
.woocommerce ul.products li.product .product-action-wrap {
  opacity: 1 !important;
  transform: none !important;
  position: static !important;
  margin-top: auto !important;
  padding: 0 !important;
  background: transparent !important;
}

/* Button: compact, full width, pinned to bottom, always visible */
.woocommerce ul.products li.product a.button,
.woocommerce ul.products li.product a.add_to_cart_button,
.woocommerce ul.products li.product a.added_to_cart,
.woocommerce ul.products li.product .button {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  margin: 12px 14px 14px !important;
  margin-top: 12px !important;
  width: calc(100% - 28px) !important;
  height: 38px !important;
  padding: 0 10px !important;
  text-align: center !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.3px !important;
  text-transform: uppercase !important;
  box-shadow: 0 3px 10px rgba(244,160,28,0.25) !important;
  opacity: 1 !important;
  visibility: visible !important;
  position: static !important;
  transform: none !important;
}

/* Hide any theme-injected arrow/extra icon inside the loop button */
.woocommerce ul.products li.product a.button::after,
.woocommerce ul.products li.product a.add_to_cart_button::after {
  display: none !important;
}

/* =============================================
   MOBILE PRODUCT CARDS — compact, no overflow
   ============================================= */
@media (max-width: 600px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    gap: 12px !important;
  }

  .woocommerce ul.products li.product .woocommerce-loop-product__title {
    font-size: 13px !important;
    line-height: 1.35 !important;
    padding: 10px 12px 4px !important;
    min-height: calc(1.35em * 2 + 14px) !important;
  }

  .woocommerce ul.products li.product .price {
    padding: 0 12px !important;
    font-size: 14px !important;
  }
  .woocommerce ul.products li.product .price del {
    font-size: 12px !important;
  }

  /* Compact button that never overflows narrow cards */
  .woocommerce ul.products li.product a.button,
  .woocommerce ul.products li.product a.add_to_cart_button,
  .woocommerce ul.products li.product .button {
    margin: 10px 8px 12px !important;
    width: calc(100% - 16px) !important;
    height: 36px !important;
    padding: 0 4px !important;
    gap: 4px !important;
    font-size: 11px !important;
    letter-spacing: -0.3px !important;
    text-transform: none !important;   /* "Add to Cart" is narrower than uppercase */
  }

  .woocommerce ul.products li.product img {
    border-radius: 8px 8px 0 0;
  }

  /* Smaller discount badge on mobile */
  .woocommerce ul.products li.product .vilmono-badge-sale,
  .woocommerce ul.products li.product .vilmono-badge-new {
    top: 8px !important;
    left: 8px !important;
    font-size: 10px !important;
    padding: 3px 7px !important;
  }
}

/* =============================================
   PRODUCT HOVER — ANIMATED ROUNDED FRAME
   An amber border draws around the card and
   follows its rounded corners until it closes.
   ============================================= */

/* Animatable angle (Chrome/Edge/Safari/FF support @property) */
@property --vilmono-frame {
  syntax: "<angle>";
  initial-value: 0deg;
  inherits: false;
}

.woocommerce ul.products li.product::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 10px;             /* matches the card → frame follows the curve */
  padding: 2px;                    /* = border thickness */
  background: conic-gradient(from -90deg,
              var(--vilmono-accent) var(--vilmono-frame),
              transparent 0deg);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
          mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  pointer-events: none;
  z-index: 4;
  transition: --vilmono-frame .55s ease;
}

.woocommerce ul.products li.product:hover::after {
  --vilmono-frame: 360deg;        /* draw the full rounded frame */
}

.woocommerce ul.products li.product:hover {
  box-shadow: var(--vilmono-shadow-md);
  transform: translateY(-4px);
}

/* Fallback for browsers without @property: show full frame on hover */
@supports not (background: conic-gradient(from -90deg, red var(--x, 0deg), transparent 0deg)) {
  .woocommerce ul.products li.product::after {
    border: 2px solid var(--vilmono-accent);
    background: none;
    -webkit-mask: none;
            mask: none;
    opacity: 0;
    transition: opacity .3s ease;
  }
  .woocommerce ul.products li.product:hover::after { opacity: 1; }
}

/* Badges: pinned to top-left corner, above the frame */
.woocommerce ul.products li.product .vilmono-badge-sale,
.woocommerce ul.products li.product .vilmono-badge-new {
  position: absolute !important;
  top: 12px !important;
  left: 12px !important;
  right: auto !important;
  width: auto !important;
  min-width: 0 !important;
  margin: 0 !important;
  z-index: 5;
  line-height: 1.4 !important;
}

/* Safeguard: hide WooCommerce's default "Sale!" flash in the loop
   (we show our own % badge). Belt-and-suspenders with the PHP remove_action. */
.woocommerce ul.products li.product .onsale {
  display: none !important;
}

/* =============================================
   HERO SLIDER — BUILT-IN ANIMATED SLIDESHOW
   ============================================= */

.vilmono-slider {
  position: relative;
  overflow: hidden;
  width: 100%;
}

.vilmono-slider-track {
  position: relative;
  width: 100%;
  min-height: 620px;
}

@media (max-width: 768px) {
  .vilmono-slider-track { min-height: 520px; }
}

.vilmono-slide {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  opacity: 0;
  visibility: hidden;
  transform: scale(1.04);
  transition: opacity .8s ease, transform 6s ease, visibility .8s ease;
  z-index: 1;
}

.vilmono-slide.is-active {
  opacity: 1;
  visibility: visible;
  transform: scale(1);
  z-index: 2;
}

/* Subtle dark overlay for text legibility on imagery */
.vilmono-slide::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(120% 120% at 20% 50%, rgba(0,0,0,0.15) 0%, rgba(0,0,0,0.45) 100%);
  z-index: 1;
  pointer-events: none;
}

.vilmono-slide .vilmono-container {
  position: relative;
  z-index: 2;
}

.vilmono-slide-content {
  max-width: 600px;
}

.vilmono-slide.is-active .vilmono-slide-content > * {
  animation: vilmonoSlideUp .7s ease both;
}
.vilmono-slide.is-active .vilmono-slide-content > *:nth-child(1) { animation-delay: .15s; }
.vilmono-slide.is-active .vilmono-slide-content > *:nth-child(2) { animation-delay: .28s; }
.vilmono-slide.is-active .vilmono-slide-content > *:nth-child(3) { animation-delay: .41s; }
.vilmono-slide.is-active .vilmono-slide-content > *:nth-child(4) { animation-delay: .54s; }

@keyframes vilmonoSlideUp {
  from { opacity: 0; transform: translateY(26px); }
  to   { opacity: 1; transform: translateY(0); }
}

.vilmono-slide h1 {
  font-size: clamp(36px, 5.2vw, 64px);
  font-weight: 800;
  line-height: 1.08;
  color: var(--vilmono-white);
  margin: 0 0 20px;
  text-shadow: 0 2px 24px rgba(0,0,0,0.35);
}

.vilmono-slide p {
  font-size: 18px;
  color: rgba(255,255,255,0.92);
  line-height: 1.7;
  margin: 0 0 36px;
  max-width: 520px;
}

.vilmono-slide-actions {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}

/* Arrows */
.vilmono-slider-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.25);
  color: var(--vilmono-white);
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  z-index: 6;
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(6px);
  transition: background .2s ease, transform .2s ease;
}
.vilmono-slider-arrow:hover {
  background: var(--vilmono-accent);
  border-color: var(--vilmono-accent);
}
.vilmono-slider-arrow.prev { left: 24px; }
.vilmono-slider-arrow.next { right: 24px; }

@media (max-width: 768px) {
  .vilmono-slider-arrow { width: 42px; height: 42px; font-size: 22px; }
  .vilmono-slider-arrow.prev { left: 10px; }
  .vilmono-slider-arrow.next { right: 10px; }
}

/* Dots */
.vilmono-slider-dots {
  position: absolute;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 10px;
  z-index: 6;
}
.vilmono-slider-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: none;
  background: rgba(255,255,255,0.4);
  cursor: pointer;
  padding: 0;
  transition: all .25s ease;
}
.vilmono-slider-dot.is-active {
  background: var(--vilmono-accent);
  width: 28px;
  border-radius: 5px;
}
