/* Pink Theme Colors */
:root {
    --pink-primary: #3b5d60;      /* Main Pink */
    --pink-dark: #3d5e61;         /* Darker Pink for hover */
    --pink-light: #FCE5E9;        /* Light Pink Background */
    --gray-dark: #333;            /* Dark text */
    --gray-medium: #666;          /* Secondary text */
    --gray-light: #bbb;           /* Light text/placeholder */
    --white: #fff;
    --shadow-color: rgba(36, 82, 85, 0.15);
    --button-teal:#416b6f;
    --body-text:#374140;
  }
  
  /* Body & General */
  body {
    background-color: var(--pink-light);
    color: var(--body-text);
    font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
    line-height: 1.6;
    margin: 0;
    padding: 0;
        position: relative;
  }
  
  /* Links and Buttons */
  a, .btn {
    color: var(--button-teal);
    transition: color 0.3s ease, background-color 0.3s ease;
    font-weight: 400;
   
  }
  .shop-btn{ border:1px solid var(--button-teal); font-weight: 500;}
  a:hover, .btn:hover, .btn:focus {
    color: var(--white);
    background-color: var(--pink-dark);
    text-decoration: none;
    box-shadow: 0 4px 15px var(--shadow-color);
    outline: none;
    border-color: var(--pink-dark);
  }
  .text-primary{
    color: var(--button-teal)!important;
  }
  .text-secondary{
    color: #f36f6d !important
  }
  /* Navbar */
  .navbar {
    background-color: var(--pink-primary) !important;
  }
  
  .navbar .navbar-brand,
  .navbar .nav-link {
    color: var(--white) !important;
    font-weight: 700;
    letter-spacing: 0.03em;
  }
  .navbar-brand{
    font-size: 1.5rem;
  }
  
  .navbar .nav-link:hover,
  .navbar .nav-link.active {
    color: var(--pink-light) !important;
    text-shadow: 0 0 5px var(--white);
  }
  .navbar-light .navbar-toggler-icon {
    filter: brightness(0) invert(1);
}
.fa-shopping-cart:before {
    filter: brightness(0) invert(1);
}
  /* Headers */
  h1, h2, h3, h4, h5 {
    font-weight: 700;
    color: var(--pink-primary);
    margin-bottom: 0.75rem;
  }
  
  /* Cards */
  .card {
    border: none;
    border-radius: 12px;
    box-shadow: 0 4px 12px var(--shadow-color);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    background-color: var(--white);
  }
  
  .card:hover {
    box-shadow: 0 8px 24px var(--shadow-color);
    transform: translateY(-5px);
  }
  .bg-product{max-width:20%;}
  
  /* {Buttons} inside cards */
  .card .btn, .btn-primary,.btn-primary:disabled {
    background-color: var(--button-teal);
    border: none;
    color: var(--white);
    border-radius: 25px;
    padding: 0.4rem 1.2rem;
    font-weight: 600;
    opacity: 0.85;
    box-shadow: 0 2px 8px var(--shadow-color);
  }
  .btn-primary:disabled{
    opacity: 0.4;
  }
  .btn-primary:hover{
     opacity: 1;
  }
   .sticky-top {
    transition: all 0.3s ease-in-out;
    z-index: 50; /* Ensure it stays above content */
  }

  .card .btn:hover {
    background-color: var(--pink-dark);
    box-shadow: 0 4px 15px var(--shadow-color);
  }
  
  /* Forms */
  .form-control {
    border-radius: 8px;
    border: 1px solid var(--pink-primary);
    transition: border-color 0.3s ease;
    box-shadow: none;
  }
  
  .form-control:focus {
    border-color: var(--pink-dark);
    box-shadow: 0 0 6px var(--shadow-color);
    outline: none;
  }
  
  /* Labels */
  label {
    font-weight: 600;
    color: var(--pink-dark);
  }
  
  /* Carousel captions */
  .carousel-caption {
    background-color: rgba(233, 30, 99, 0.75);
    border-radius: 10px;
    padding: 1rem 2rem;
    box-shadow: 0 4px 12px var(--shadow-color);
  }
  
  .carousel-caption h3,
  .carousel-caption p {
    color: var(--white);
    text-shadow: 1px 1px 6px rgba(0,0,0,0.3);
  }

  .page-item.active .page-link{
    color: #fff;
    background-color: var(--button-teal);
    border-color: var(--button-teal);
  }
  .page-link{
    color:#000;
  }
  /* Responsive spacing */
  @media (max-width: 576px) {
    .carousel-caption {
      padding: 0.5rem 1rem;
      font-size: 0.9rem;
    }
  }
    /* Responsive spacing */
     @media (max-width: 767px) {
        .clock-time .small{
            display:none;
        }
       .clock-time {
            width: 42%;
            margin: 0 !important;
        }
        .animate-drop-zigzag {
          top: -6px !important;
        max-width: 118px !important;
            left:14px!important;
      } 
      .container-split{
        justify-content: right !important;
      }
      .carousel-inner img{
        height:100%!important;
      }
      .scroll-to-top{
        right:6px !important;
      }
      .modal-dialog {
        max-width: 95% !important;         /* responsive width */
        max-height: 95vh; }
    }
  /* Header */
header {
    background-color: var(--pink-primary);
    color: var(--white);
    padding: 1.5rem 0;
    text-align: center;
    font-weight: 700;
    font-size: 2rem;
    letter-spacing: 0.05em;
    box-shadow: 0 4px 15px var(--shadow-color);
  }
  
  /* Navbar */
  .navbar {
    background-color: var(--pink-primary) !important;
    box-shadow: 0 4px 15px var(--shadow-color);
  }
  
  .navbar .navbar-brand,
  .navbar .nav-link {
    color: var(--white) !important;
    font-weight: 600;
    letter-spacing: 0.03em;
  }
  
  .navbar .nav-link:hover,
  .navbar .nav-link.active {
    color: var(--pink-light) !important;
    text-shadow: 0 0 5px var(--white);
  }
  footer {
    background-color: var(--pink-primary) !important;
    color: var(--white);
    text-align: center;
    padding: 1.2rem 0;
    font-weight: 500;
    letter-spacing: 0.04em;
    box-shadow: inset 0 3px 6px rgba(255 255 255 / 0.15);

  }
  .contact-form .form-control {
    border-radius: 8px;
    border: 1.5px solid var(--pink-primary);
    transition: border-color 0.3s ease;
    box-shadow: none;
  }
  
  .contact-form .form-control:focus {
    border-color: var(--pink-dark);
    box-shadow: 0 0 6px var(--shadow-color);
    outline: none;
  }
  
  .contact-form label {
    font-weight: 600;
    color: var(--pink-dark);
  }
  
  .contact-form button {
    background-color: var(--pink-primary);
    border: none;
    color: var(--white);
    border-radius: 25px;
    padding: 0.5rem 1.5rem;
    font-weight: 600;
    box-shadow: 0 2px 8px var(--shadow-color);
    transition: background-color 0.3s ease;
  }
  
  .contact-form button:hover {
    background-color: var(--pink-dark);
    box-shadow: 0 4px 15px var(--shadow-color);
  }
  .cart-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 1rem;
    box-shadow: 0 4px 12px var(--shadow-color);
    border-radius: 10px;
    overflow: hidden;
  }
  
  .cart-table th,
  .cart-table td {
    padding: 12px 15px;
    text-align: left;
    border-bottom: 1px solid var(--pink-light);
  }
  
  .cart-table th {
    background-color: var(--pink-primary);
    color: var(--white);
    font-weight: 700;
  }
  
  .cart-table tbody tr:hover {
    background-color: var(--pink-light);
  }
  
  .cart-action-btn {
    background-color: var(--pink-primary);
    border: none;
    color: var(--white);
    padding: 5px 12px;
    border-radius: 20px;
    cursor: pointer;
    transition: background-color 0.3s ease;
  }
  
  .cart-action-btn:hover {
    background-color: var(--pink-dark);
  }
  .product-card {
    border: none;
    border-radius: 12px;
    box-shadow: 0 4px 12px var(--shadow-color);
    background-color: var(--white);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
  }
  
  .product-card:hover {
    box-shadow: 0 8px 24px var(--shadow-color);
    transform: translateY(-5px);
  }
  
  .product-card .card-title {
    color: var(--pink-dark);
    font-weight: 700;
  }
  
  .product-card p {
    font-size: 1.1rem;
    color: var(--pink-primary);
    font-weight: 600;
  }
  
  /* Checkbox labels */
  .form-check-label {
    font-weight: 600;
    color: var(--gray-dark);
  }
  
  .form-check-input:checked + .form-check-label {
    color: var(--pink-primary);
    font-weight: 700;
  }
          
  .theme-intro {
    background-color: #fff0f6;
  }
  
  .text-pink {
    color: #4b7174;
    font-weight: 700;
  }
  
  .carousel-inner img {
    border-radius: 10px;
    height: 350px;
    object-fit: cover;
  }

  .card-img-top {
    border-top-left-radius: calc(.25rem - 1px);
    border-top-right-radius: calc(.25rem - 1px);
    height: 250px;
    object-fit: cover;
     border-top-left-radius:12px;
    border-top-right-radius:12px;
    cursor:pointer;
}
  .footer a {
    text-decoration: none;
    transition: color 0.3s ease;
  }
  .footer h5{  color:var(--pink-light);}
  .footer a:hover {
    color: #fff;
  }
  .header-gradient {
     background-color: var(--pink-light);
 
  }
  span#pageInfo {
    font-size: 0.75rem;
}
  .text-lightpink {
    color: #ff69b4;
  }
  .carousel-control-prev:hover,.carousel-control-next:hover{
    background-color: var(--pink-primary);
    opacity: 0.2;
  }
  @keyframes fadeInDown {
    from {
      opacity: 0;
      transform: translateY(-20px);
    }
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }
  
  .form-inline input[type="search"] {
    max-width: 180px;
  }
  .date-time,.fa-clock:before{font-size:50%;color: var(--body-text);}

  .container-split{
    justify-content: space-around;
    position:relative;
  }
  

  .table .thead-light th{
    background-color: #495057;
    color: #fff;
  }
.btn-danger,.btn-success
{color:#fff;}
.btn-danger{
    background-color: #dc3545 !important;
    border: none;
    color: var(--white);
    border-radius: 25px;
    padding: 0.4rem 1.2rem;
    font-weight: 600;
    opacity: 0.85;
    box-shadow: 0 2px 8px var(--shadow-color);
}
.btn-danger:hover{
    background-color: rgb(194, 30, 47)!important;
    }
.dropdown-item:focus, .dropdown-item:hover{background-color: var(--pink-light);}
.btn-outline-primary {
    color: var(--pink-dark);
    border-color:var(--pink-light);
}
.btn-outline-primary:not(:disabled):not(.disabled):active, .show>.btn-outline-primary.dropdown-toggle {
    color: #fff;
    background-color:var(--pink-dark);
    border-color: var(--pink-dark);
}
  .running-light span {
    opacity: 0.2;
    display: inline-block;
    color: #fde8ef;
    font-weight: 500;
    font-size: 1.4rem;
    letter-spacing: 0.05em;
    animation: glow 1.3s infinite;
    transition: all 0.2s ease-in-out;
  }
   .logo-number{
    padding:0 0.3rem;
   }
  /* Delay each letter */
  .running-light span:nth-child(1)  { animation-delay: 0s;  
    font-size: 1.4rem;}
  .running-light span:nth-child(2)  { animation-delay: 0.1s; }
  .running-light span:nth-child(3)  { animation-delay: 0.2s; }
  .running-light span:nth-child(4)  { animation-delay: 0.3s; }
  .running-light span:nth-child(5)  { animation-delay: 0.4s; }
  .running-light span:nth-child(6)  { animation-delay: 0.5s; }
  .running-light span:nth-child(7)  { animation-delay: 0.6s; 
    font-size: 1.4rem; color:#fc817f;}
  .running-light span:nth-child(8)  { animation-delay: 0.7s;   
  }
  .running-light span:nth-child(9)  { animation-delay: 0.8s; }
  .running-light span:nth-child(10) { animation-delay: 0.9s; }
  .running-light span:nth-child(11) { animation-delay: 1s; }
  .running-light span:nth-child(12) { animation-delay: 1.1s; }
  .running-light span:nth-child(13) { animation-delay: 1.2s; }
  
  @keyframes glow {
    0%, 100% {
      opacity: 0.2;
      text-shadow: none;
    }
    50% {
      opacity: 1;
      text-shadow: 0 0 1px #222222, 0 0 10px #222222;
    }
  }
  
  /* Optional: stop animation class */
.no-animation span {
  animation: none !important;
  opacity: 1;
}

  .navbar-brand {
    font-weight: bold;
    font-size: 24px;
    color: #fde8ef;
    text-decoration: none;
   
  }

  @keyframes dropZigZag {
    0% {
      transform: translateY(-50px) translateX(0);
      opacity: 0;
    }
    25% {
      transform: translateY(-35px) translateX(15px);
      opacity: 0.4;
    }
    50% {
      transform: translateY(-20px) translateX(-15px);
      opacity: 0.7;
    }
    75% {
      transform: translateY(-10px) translateX(10px);
      opacity: 0.9;
    }
    100% {
      transform: translateY(0) translateX(0);
      opacity: 1;
    }
  }
  
  .animate-drop-zigzag {
    animation-name: dropZigZag;
    animation-duration: 2s;
    animation-timing-function: ease-out;
   
    animation-delay: 0.3s;
    left: 0px;
      top: -32px;
    max-width: 148px;
    position: absolute;
    z-index: 99;
    box-shadow: none !important;
    border-radius: 0 !important;
  }

  
  
  .btn-primary:not(:disabled):not(.disabled):active, .show>.btn-primary.dropdown-toggle{
    color: #fff;
    background-color: var(--pink-dark);
    border-color: var(--pink-dark);
    box-shadow: 0 0 0 .1rem rgb(255 38 98 / 50%);
  }
  .badge-danger {
    font-size: 0.75rem;
  }
  .hamburger-wrapper {
    display: flex;
    align-items: center;
  }
  .hamburger-wrapper .fas.fa-shopping-cart {
    position: relative;
  }
  #cart-count-mobile {
    position: absolute;
    top: -8px;
    right: -10px;
  }
  .navbar-toggler {
    border: none;
    outline: none;
    box-shadow: none;
  }
  .navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3e%3cpath stroke='rgba%280, 0, 0, 0.6%29' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
  }

  .footer a {
    transition: color 0.3s ease;
    font-size: 1rem;
    
    display: inline-block;
  }
  
  .footer a:hover,
  .footer a:focus {
    text-decoration: none;
    outline: none;
  }
  
  .footer h5,
  .footer h6 {
    letter-spacing: 0.8px;
  }
  
  @media (max-width: 575.98px) {
    .footer h5,
    .footer h6 {
      font-size: 1.5rem;
    }
  
    .footer p {
      font-size: 0.95rem;
      line-height: 1.4;
    }
  
    .footer .fab {
      font-size: 1.5rem;
    }
  
    .footer .d-flex > a {
      padding: 0 10px;
    }

  }

  .cart-total-bar {
    z-index: 1050;
    box-shadow: 0 1rem 3rem rgba(0, 0, 0, .775) !important;
  }
.scroll-to-top {
  position: fixed;
  bottom: 20px;
  right: 15px;
  display: none;
  z-index: 1030;
  border-radius: 50%;
  padding: 7px 12px;
  font-size: 14px;
  transition: all 0.4s ease-in-out;
  opacity: 1;
  background-color: #dc3545;
  color:#fff;
}
.spinner-border{color:#dc3545 !important}
.scroll-to-top:hover {
  transform: translateY(-5px);
  opacity: 0.8;
  background-color: #1d1e1e;
}
.alert-danger {
    color: #ffffff;
    background-color: #dd0015;
    border-color: #f5c6cb;
}
.active-thumbnail {
  border: 3px solid var(--button-teal);
  border-radius: 5px;
}

#thumbnailContainer img {
  margin: 5px;
  height: 80px;
  cursor: pointer;
}

.zoom-container {
  overflow: hidden;
  position: relative;
}

.zoom-container img {
  transition: transform 0.3s ease;
}

.zoom-container img:hover {
  transform: scale(1.5);
}
.toast-body {
     background: #fff;
     color:var(--body-text);
}
#product-list .card-text{
    display: -webkit-box;
  -webkit-line-clamp: 5; 
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.card-body p {
    text-transform: capitalize;
}
 .contact-container {
    max-width: 600px;
    margin: 40px auto;
    padding: 30px;
    border-radius: 10px;
    background: #f9f9f9;
    font-family: 'Segoe UI', sans-serif;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  }

  .contact-container h2 {
    text-align: center;
    color: #333;
    margin-bottom: 20px;
  }

  .contact-container p {
    color: #555;
    line-height: 1.6;
    margin-bottom: 15px;
  }

  .contact-details {
    margin-top: 20px;
  }

  .contact-details div {
    display: flex;
    align-items: center;
    margin: 8px 0;
    color: #333;
  }

  .contact-details span {
    font-weight: 600;
    width: 100px;
  }

  .contact-details i {
    margin-right: 10px;
    color: #666;
  }

  .address {
    margin-top: 20px;
    color: #333;
  }

  .address strong {
    display: block;
    margin-bottom: 5px;
    color: #000;
  }
  .modal #mainModalImage{
      overflow-y: auto;
      width: 100%;
    max-height: 60vh;
    object-fit: contain;
  }
#cart-toast.toast {
  position: fixed;
  top: 25%;
  right: 3%;
  z-index: 1055;
  opacity: 1;
  box-shadow: 0 2px 10px rgba(0,0,0,0.2);
}
  @media (max-width: 600px) {
    .contact-container {
      margin: 20px;
      padding: 20px;
    }
    .contact-details span {
      width: 80px;
    }
  }
  .bg-success {
    background-color: #128d2e !important;
}
.text-success{
  color:#128d2e !important;
}
.alert-success,.btn-success {
    color: #ffffff;
    background-color:#128d2e !important; 
    border-color: #c3e6cb;
}
.cart-total-bar {
  z-index: 1050;
}
@media (max-width: 576px) {
  .cart-total-bar {
    padding: 1rem 1.25rem;
  }
}
footer a:hover {
    color: var(--pink-light) !important;
    text-shadow: 0 0 5px var(--white) !important;
    font-weight: 600;
    letter-spacing: 0.03em;
}
#thumbnailContainer button.active{
  background: var(--pink-primary);
  color:var(--white);
}
#thumbnailContainer button{
     font-size: 0.75rem;
    padding: 0.4rem 0.6rem !important;
}
#imageDetails p:first-child {
    text-transform:capitalize;
}
.btn:disabled {
    cursor: not-allowed;
    opacity: 0.55;
    pointer-events: none;
    touch-action: none;
}
.card-body button.btn-primary{
  background-color: #c95957;
}
/* Center the modal properly */
.modal-dialog {
  max-width: 75%;         /* responsive width */
  max-height: 95vh;       /* responsive height */
  margin: auto;           /* center horizontally & vertically */
  display: flex;
  align-items: center;
}

/* Make modal content fit and allow internal scrolling */
.modal-content {
  max-height: 95vh;       /* never exceed screen */
  display: flex;
  flex-direction: column;
}

/* Scrollable body */
.modal-body {
  overflow-y: auto;       /* scroll inside modal if content is tall */
  flex: 1;
}