:root{
	/* Background becomes white; use previous dark-blue as accent */
	--bg: #ffffff;
	--card: #f6f9fb;
	--text: #071226; /* previously the dark background color */
	--muted: #647993; /* subtle blue-gray for secondary text */
	--accent: #071226; /* use old background color for details */
	--accent-2: #28388f;
	--below-hero: var(--accent);
	--max-width: 1100px;
}

*{box-sizing:border-box}
html,body{height:100%}
.logo img{height:64px;filter:drop-shadow(0 2px 6px rgba(0,0,0,0.06))}

body{font-family:Roboto,system-ui,-apple-system,Segoe UI,"Helvetica Neue",Arial;line-height:1.6;color:var(--text);background:var(--bg);margin:0}
.container{max-width:var(--max-width);margin:0 auto;padding:2rem}

/* make the area below the hero match the site's dark accent */
main{background:var(--below-hero);color:#ffffff;border-radius:24px;overflow:hidden}

/* headings that sit on the dark page background */
main .services h2, main .gallery h2{color:#ffffff}
main .muted{color:rgba(255,255,255,0.82)}
/* keep service cards readable (light background + dark text) */
.service-grid article{color:#ffffff}

.site-header{background:transparent}
.site-header .container{display:flex;align-items:center;justify-content:space-between}
.nav a{margin-left:1rem;color:var(--text);text-decoration:none;opacity:0.95}
.nav .btn{background:var(--accent);color:#ffffff;padding:0.5rem 0.9rem;border-radius:8px;text-decoration:none;font-weight:600}

.hero{padding:5rem 0;text-align:center;display:flex;align-items:center;min-height:360px;border-bottom:1px solid rgba(7,18,38,0.06);background-image:url('../images/storefront.jpg');background-repeat:no-repeat;background-size:cover;background-position:center 18%;position:relative;will-change:background-position}
.hero h1{font-family:Poppins, sans-serif;font-weight:700;font-size:2.75rem;margin:0 0 0.5rem;color:#ffffff;letter-spacing:-0.5px;text-shadow:0 8px 26px rgba(7,18,38,0.7)}
.hero .lead{color:rgba(255,255,255,0.94);text-shadow:0 5px 14px rgba(7,18,38,0.6)}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,18,38,0.62),rgba(7,18,38,0.22));pointer-events:none}
.hero .container{position:relative;z-index:2}
.lead{color:var(--muted);margin-bottom:1.25rem}
.cta{background:var(--accent);color:#ffffff;padding:0.65rem 1.1rem;border-radius:9px;text-decoration:none;display:inline-block;font-weight:700;box-shadow:0 6px 18px rgba(7,18,38,0.06);transition:transform .16s ease,box-shadow .16s ease}
.cta:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(7,18,38,0.12)}

.services h2,.gallery h2{margin-top:0;color:var(--text);font-family:Poppins, sans-serif}
.service-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}
.service-grid .service-card{background:rgba(255,255,255,0.04);backdrop-filter:blur(6px);padding:2rem;border-radius:16px;text-align:center;border:1px solid rgba(255,255,255,0.08);transition:transform .18s ease,box-shadow .18s ease,background .18s ease;text-decoration:none;color:inherit;display:flex;flex-direction:column;align-items:center;height:100%}
.service-grid .service-card:hover{background:rgba(255,255,255,0.08);transform:translateY(-6px);box-shadow:0 14px 36px rgba(0,0,0,0.2)}
.service-grid img{max-width:100%;height:240px;object-fit:cover;filter:brightness(0.98);border-radius:8px;margin-bottom:1rem;width:100%}

.gallery-carousel {
  display: flex;
  overflow-x: auto;
  gap: 1.5rem;
  margin-top: 1rem;
  padding-bottom: 1.5rem;
  scroll-snap-type: none;
  scrollbar-width: none; /* Hide scrollbar for slideshow look */
}
.gallery-carousel::-webkit-scrollbar { display: none; }

.gallery-carousel img, .gallery-carousel video {
  flex: 0 0 85%; /* Mobile: show mostly one image */
  height: 360px;
  scroll-snap-align: none;
  object-fit: cover;
  border-radius: 12px;
  cursor: pointer;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.04);
  transition: transform 0.3s ease;
}
.gallery-carousel img:hover, .gallery-carousel video:hover {
  transform: scale(1.02);
  border-color: rgba(255,255,255,0.2);
}

@media(min-width: 768px) {
  .gallery-carousel img, .gallery-carousel video {
    flex: 0 0 40%; /* Tablet: show 2.5 images */
  }
}
@media(min-width: 1024px) {
  .gallery-carousel img, .gallery-carousel video {
    flex: 0 0 30%; /* Desktop: show 3.5 images */
  }
}

.muted{color:var(--muted);font-size:0.95rem}

.site-footer{background:transparent;border-top:1px solid rgba(255,255,255,0.06);padding:1rem 0;margin-top:2rem}
.site-footer .container{display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center}
.footer-info p{margin:0.25rem 0;color:rgba(255,255,255,0.7)}
.footer-info a{color:inherit;text-decoration:none;transition:color 0.2s}
.footer-info a:hover{color:#fff}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;width:100%;border-top:1px solid rgba(255,255,255,0.06);padding-top:1rem;margin-top:0.5rem}
@media(max-width:600px){.footer-bottom{flex-direction:column;gap:0.5rem}}

.contact-page .contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.contact-page form{display:grid;gap:0.65rem}
label{font-size:0.95rem}

.contact-page .contact-grid > section {
	background: rgba(255,255,255,0.04);
	border-radius: 24px;
	padding: 2rem;
	border: 1px solid rgba(255,255,255,0.08);
}

input,textarea{padding:0.65rem;border:1px solid rgba(7,18,38,0.06);border-radius:8px;background:transparent;color:var(--text)}

/* contact page: make form fields clearly readable on dark page background */
.contact-page label{color:#ffffff}
.contact-page input,
.contact-page textarea{
	padding:0.75rem;
	border:1px solid rgba(7,18,38,0.12);
	border-radius:8px;
	background:#ffffff;
	color:var(--text);
	width:100%;
}
.contact-page input::placeholder,
.contact-page textarea::placeholder{
	color:rgba(7,18,38,0.45);
}
.contact-page input:focus,
.contact-page textarea:focus{
	outline:none;
	border-color:var(--accent-2);
	box-shadow:0 8px 22px rgba(40,56,143,0.16);
}

/* field error and validation UI */
.field-error{color:#9b1c1c;font-size:0.9rem;margin-top:0.35rem;min-height:1.1em}
.invalid{border-color:#c53030 !important;box-shadow:0 6px 18px rgba(197,48,48,0.08) !important}
.sent-summary{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.06);padding:0.9rem;border-radius:8px;color:#ffffff}
.sent-summary strong{display:block;margin-bottom:0.35rem}
.btn{background:var(--accent);color:#ffffff;padding:0.6rem 1rem;border-radius:8px;border:none;font-weight:700;transition:transform .16s ease,box-shadow .18s ease,opacity .12s ease}
.btn:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(7,18,38,0.16);opacity:0.98}
.btn:active{transform:translateY(-1px);box-shadow:0 8px 20px rgba(7,18,38,0.12)}
.btn:focus{outline:none;box-shadow:0 0 0 4px rgba(40,56,143,0.12)}

/* emphasize contact page submit button for visibility */
.contact-page .btn{background:var(--accent-2);padding:0.8rem 1.2rem;font-size:1rem;border-radius:10px;font-weight:800}
.contact-page .btn:hover{box-shadow:0 16px 40px rgba(40,56,143,0.18);transform:translateY(-4px)}

.lightbox{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(3,7,14,0.76);z-index:1000}
.lightbox[aria-hidden="false"]{display:flex}
.lightbox-img{max-width:90%;max-height:80%;border-radius:6px;box-shadow:0 10px 30px rgba(7,18,38,0.8)}
.lightbox-video{max-width:90%;max-height:80%;border-radius:6px;box-shadow:0 10px 30px rgba(7,18,38,0.8);display:none}
.lightbox-close{position:absolute;top:18px;right:18px;background:transparent;border:0;color:var(--text);font-size:22px}

/* Page enter/exit transitions */
body.is-loading main, body.is-loading .site-header, body.is-loading .site-footer{
	opacity:0;transform:translateY(6px);pointer-events:none}
body.is-loaded main, body.is-loaded .site-header, body.is-loaded .site-footer{
	opacity:1;transform:none;transition:opacity .45s ease, transform .45s ease}
body.is-exiting main, body.is-exiting .site-header, body.is-exiting .site-footer{
	opacity:0;transform:translateY(8px);transition:opacity .35s ease, transform .35s ease}

@media(max-width:880px){.hero h1{font-size:1.9rem}.service-grid img{height:90px}.gallery-grid img{height:240px}.contact-page .contact-grid{grid-template-columns:1fr}.logo img{height:48px}}

/* About Page Styles */
.about-intro{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;margin-bottom:4rem}
.about-intro img{width:100%;border-radius:16px;border:1px solid rgba(255,255,255,0.08);box-shadow:0 10px 30px rgba(0,0,0,0.2)}
.about-text h2{margin-top:0;font-family:Poppins,sans-serif;color:#fff}

.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem}
.team-member{background:rgba(255,255,255,0.04);backdrop-filter:blur(6px);padding:2rem;border-radius:16px;text-align:center;border:1px solid rgba(255,255,255,0.08);transition:transform .2s ease}
.team-member:hover{transform:translateY(-5px);background:rgba(255,255,255,0.06)}
.team-member img{width:140px;height:140px;border-radius:50%;object-fit:cover;margin-bottom:1rem;border:3px solid rgba(255,255,255,0.1)}
.team-member h3{margin:0.5rem 0 0.25rem;color:#fff;font-family:Poppins,sans-serif}
.team-member .role{color:#aab4be;font-weight:700;margin-bottom:0.75rem;font-size:0.85rem;text-transform:uppercase;letter-spacing:1px}
@media(max-width:768px){.about-intro{grid-template-columns:1fr;gap:1.5rem}}

/* Scroll Animations */
.fade-on-scroll {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
  will-change: opacity, transform;
}
.fade-on-scroll.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Navigation (Hamburger Style Global) */
.mobile-nav-toggle {
  display: block;
  background: none;
  border: none;
  padding: 0.5rem;
  cursor: pointer;
  z-index: 1001;
  position: relative;
}

.hamburger-line {
  display: block;
  width: 24px;
  height: 3px;
  background-color: var(--text);
  margin: 5px 0;
  transition: transform 0.3s ease, opacity 0.3s ease;
  border-radius: 2px;
}

/* Animate hamburger to 'X' */
.is-menu-open .mobile-nav-toggle .hamburger-line:nth-child(1) {
  transform: translateY(8px) rotate(45deg);
}
.is-menu-open .mobile-nav-toggle .hamburger-line:nth-child(2) {
  opacity: 0;
}
.is-menu-open .mobile-nav-toggle .hamburger-line:nth-child(3) {
  transform: translateY(-8px) rotate(-45deg);
}
.is-menu-open .mobile-nav-toggle .hamburger-line {
    background-color: #fff;
}

.nav-wrapper {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: rgba(7, 18, 38, 0.98);
  backdrop-filter: blur(10px);
  transform: translateX(100%);
  visibility: hidden;
  transition: transform 0.4s cubic-bezier(0.23, 1, 0.32, 1), visibility 0.4s;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
}

.is-menu-open .nav-wrapper {
  transform: translateX(0);
  visibility: visible;
}

.nav {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.5rem;
}

.nav-item {
  position: static;
  text-align: center;
}

.nav .nav-link {
  background: none;
  border: none;
  font-family: inherit;
  cursor: pointer;
  font-weight: 600;
  padding: 0.5rem 0.5rem;
  display: flex;
  align-items: center;
  gap: 4px;
  color: #fff;
  font-size: 1.5rem;
  text-decoration: none;
  justify-content: center;
  margin: 0;
}

.nav .nav-link:hover { color: var(--accent-2); }

.dropdown {
  position: static;
  transform: none;
  background: none;
  border: none;
  box-shadow: none;
  min-width: auto;
  opacity: 1;
  visibility: visible;
  padding: 0.5rem 0 0;
  display: none;
  transition: none;
}

.nav-item.is-open .dropdown { display: block; }

.dropdown a {
  display: block;
  padding: 0.5rem 1rem;
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
  font-size: 1rem;
  border-radius: 8px;
  margin: 0;
  text-align: center;
}

.dropdown a:hover {
  background: none;
  color: #fff;
}

/* Product Page Styles */
.product-page h1 {
  color: #fff;
  font-family: Poppins, sans-serif;
  margin-bottom: 2rem;
}

main.product-page {
  background: radial-gradient(circle at 90% 10%, #1f2d4d 0%, var(--below-hero) 70%);
  max-width: 1400px;
}

.product-grid-layout {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 3rem;
  align-items: start;
  margin-bottom: 2rem;
}

.product-visuals img.main-product-image {
  width: 100%;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 10px 30px rgba(0,0,0,0.2);
  margin-bottom: 1.5rem;
}

.product-thumbnails {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin-bottom: 2rem;
}

.thumb-btn {
  width: 100%;
  padding: 0.8rem;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2);
  color: #fff;
  border-radius: 8px;
  cursor: pointer;
  font-weight: 600;
  transition: background 0.2s, transform 0.2s;
}
.thumb-btn:hover {
  background: rgba(255,255,255,0.2);
  transform: translateY(-2px);
}

.product-description {
  margin-top: 2rem;
}

.product-description h2 {
  margin-top: 0;
  font-family: Poppins, sans-serif;
  color: #fff;
}

/* Configurator Box Updates */
.banner-configurator {
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-radius: 24px;
  padding: 2rem;
  border: 1px solid rgba(255, 255, 255, 0.2);
  box-shadow: 0 15px 35px rgba(0, 0, 0, 0.25);
  text-align: left; /* Align text left */
  position: sticky;
  top: 2rem;
}

.banner-configurator h2 {
  margin-top: 0;
  color: #fff;
  font-family: Poppins, sans-serif;
  text-shadow: 0 2px 4px rgba(0,0,0,0.3);
  text-align: center;
  margin-bottom: 1.5rem;
}

.banner-configurator .form-row {
  margin-bottom: 1rem;
  display: flex;
  flex-direction: column;
  align-items: flex-start; /* Align inputs left */
}

.banner-configurator label {
  display: block;
  margin-bottom: 0.4rem;
  font-weight: 600;
  color: #fff;
  font-size: 0.9rem;
}

.banner-configurator input[type="number"],
.banner-configurator input[type="file"],
.banner-configurator textarea,
.banner-configurator select {
  width: 100%;
  max-width: 100%; /* Fill the container */
  padding: 0.6rem;
  border: 1px solid rgba(7,18,38,0.12);
  border-radius: 8px;
  background: #ffffff;
  color: var(--text);
}

.banner-configurator .radio-group {
  display: flex;
  gap: 1rem;
  background: #ffffff;
  color: var(--text);
  padding: 0.6rem;
  border-radius: 8px;
  width: 100%;
  max-width: 100%;
}
.banner-configurator .radio-group label {
  color: var(--text);
  margin-bottom: 0;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.price-calculator {
  margin-top: 1.5rem;
  padding: 1rem;
  background: rgba(0,0,0,0.15);
  border-radius: 12px;
  text-align: center;
}

@media(max-width: 900px) {
  .product-grid-layout {
    grid-template-columns: 1fr;
  }
  .banner-configurator {
    position: static;
    max-width: 500px;
    margin: 0 auto;
  }
}

/* Removed old styles that are replaced above to avoid conflicts */
/*
.product-intro {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: center;
  margin-bottom: 2rem;
}
  .cart-table th:nth-child(3), .cart-table td:nth-child(3) { display: none; }
}
*/

/* Cart Styles */
.cart-container { background: rgba(255,255,255,0.04); border-radius: 24px; padding: 2rem; border: 1px solid rgba(255,255,255,0.08); }
.cart-table { width: 100%; border-collapse: collapse; margin-bottom: 2rem; color: #fff; }
.cart-table th { text-align: left; padding: 1rem; border-bottom: 1px solid rgba(255,255,255,0.1); font-family: Poppins, sans-serif; color: #fff; }
.cart-table td { padding: 1rem; border-bottom: 1px solid rgba(255,255,255,0.05); vertical-align: top; color: #fff; }
.cart-item-title { font-weight: 700; display: block; color: #fff; }
.cart-item-meta { font-size: 0.85rem; color: rgba(255, 255, 255, 0.7); display: block; }
.cart-remove { color: #ff6b6b; background: none; border: none; cursor: pointer; font-weight: 600; padding: 0; font-size: 0.9rem; transition: color 0.2s; }
.cart-remove:hover { color: #ff4c4c; text-decoration: underline; }
.cart-summary { text-align: right; margin-top: 2rem; border-top: 1px solid rgba(255,255,255,0.1); padding-top: 2rem; }
.cart-total { font-size: 1.8rem; font-weight: 700; color: #fff; margin-bottom: 1.5rem; font-family: Poppins, sans-serif; }
.empty-cart-msg { text-align: center; padding: 4rem 2rem; color: var(--muted); font-size: 1.1rem; }
.order-success-msg {
  text-align: center;
  padding: 4rem 2rem;
  background: rgba(255,255,255,0.04);
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,0.08);
}
.order-success-msg h2 {
  color: #fff;
  font-family: Poppins, sans-serif;
}

/* Checkout Form in Cart */
.checkout-section { margin-top: 3rem; padding-top: 2rem; border-top: 1px solid rgba(255,255,255,0.1); text-align: left; }
.checkout-section h2 { color: #fff; font-family: Poppins, sans-serif; }
.checkout-section label { color: #fff; display: block; margin-bottom: 0.5rem; font-weight: 600; }
.checkout-section input {
  width: 100%;
  padding: 0.75rem;
  border: 1px solid rgba(7,18,38,0.12);
  border-radius: 8px;
  background: #ffffff;
  color: var(--text);
  margin-bottom: 1rem;
}
.checkout-section h3 {
  color: #fff;
  margin-top: 1.5rem;
  margin-bottom: 1rem;
  font-family: Poppins, sans-serif;
  border-bottom: 1px solid rgba(255,255,255,0.1);
  padding-bottom: 0.5rem;
}
.checkout-section .form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
.checkout-section .form-grid-3 {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 1rem;
}
.checkout-section #paypal-button-container {
  margin: 2rem auto 0;
  max-width: 350px;
  width: 100%;
}
.nav-cart-count { 
  background: var(--accent-2); color: #fff; font-size: 0.75rem; 
  padding: 2px 6px; border-radius: 10px; margin-left: 4px; vertical-align: middle; 
  font-weight: 700;
  display: none; /* Hidden if 0 */
}

@media(max-width: 768px) {
  .checkout-section .form-grid,
  .checkout-section .form-grid-3 {
    grid-template-columns: 1fr;
    gap: 0;
  }
}

/* Service Card Carousel */
.img-carousel {
  position: relative;
  width: 100%;
  height: 240px;
  margin-bottom: 1rem;
  border-radius: 8px;
  overflow: hidden;
}
.img-carousel img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 1s ease-in-out;
  margin-bottom: 0;
  border-radius: 0;
}
.img-carousel img.active {
  opacity: 1;
  z-index: 1;
}
