/* ============================================
   PAWSOME – Custom Visual Enhancements
   ============================================ */

/* --- Smooth scroll & custom scrollbar --- */
html {
  scroll-behavior: smooth;
}

::-webkit-scrollbar {
  width: 5px;
}
::-webkit-scrollbar-track {
  background: #f5f0eb;
}
::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, #c9a96e, #a07850);
  border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, #b8903a, #8a6030);
}

/* --- Page entrance --- */
#main {
  animation: pawsome-page-enter 0.65s cubic-bezier(0.22, 1, 0.36, 1) both;
}

@keyframes pawsome-page-enter {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* --- Scroll reveal --- */
.pawsome-reveal {
  opacity: 0;
  transform: translateY(30px);
  transition:
    opacity 0.75s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.75s cubic-bezier(0.22, 1, 0.36, 1);
}

.pawsome-reveal.pawsome-from-left {
  transform: translateX(-30px);
}

.pawsome-reveal.pawsome-from-right {
  transform: translateX(30px);
}

.pawsome-reveal.pawsome-scale {
  transform: scale(0.94);
}

.pawsome-reveal.is-visible {
  opacity: 1;
  transform: translate(0, 0) scale(1);
}

/* Stagger delays for siblings */
.pawsome-reveal:nth-child(2) { transition-delay: 0.08s; }
.pawsome-reveal:nth-child(3) { transition-delay: 0.16s; }
.pawsome-reveal:nth-child(4) { transition-delay: 0.24s; }
.pawsome-reveal:nth-child(5) { transition-delay: 0.32s; }
.pawsome-reveal:nth-child(6) { transition-delay: 0.40s; }

/* --- Image hover zoom --- */
#main img {
  transition: transform 0.55s cubic-bezier(0.22, 1, 0.36, 1),
              filter 0.55s ease !important;
}

#main img:hover {
  transform: scale(1.035) !important;
  filter: brightness(1.04) saturate(1.08) !important;
}

/* No zoom for FAQ section image */
#main [data-framer-name="FAQs"] img:hover {
  transform: none !important;
  filter: none !important;
}

/* --- Button / link hover lift --- */
#main a,
#main button {
  transition:
    transform 0.28s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.28s ease,
    filter 0.28s ease !important;
}

#main a:hover,
#main button:hover {
  transform: translateY(-2px) !important;
}

/* --- Floating animation for hero decorative elements --- */
@keyframes pawsome-float {
  0%, 100% { transform: translateY(0px); }
  50%       { transform: translateY(-8px); }
}

@keyframes pawsome-float-slow {
  0%, 100% { transform: translateY(0px) rotate(0deg); }
  50%       { transform: translateY(-6px) rotate(1.5deg); }
}

.pawsome-float {
  animation: pawsome-float 4s ease-in-out infinite;
}

.pawsome-float-slow {
  animation: pawsome-float-slow 6s ease-in-out infinite;
}

/* --- Shimmer text effect for headings --- */
@keyframes pawsome-shimmer {
  0%   { background-position: -200% center; }
  100% { background-position:  200% center; }
}

.pawsome-shimmer-text {
  background: linear-gradient(
    90deg,
    #1a1a1a 0%,
    #c9a96e 45%,
    #1a1a1a 55%,
    #1a1a1a 100%
  );
  background-size: 200% auto;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: pawsome-shimmer 3s linear infinite;
}

/* --- Glow pulse on CTA buttons --- */
@keyframes pawsome-glow-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(201, 169, 110, 0); }
  50%       { box-shadow: 0 0 18px 4px rgba(201, 169, 110, 0.35); }
}

.pawsome-cta-glow {
  animation: pawsome-glow-pulse 2.5s ease-in-out infinite;
  border-radius: inherit;
}

/* --- Card hover: lift + shadow --- */
.pawsome-card-hover {
  transition:
    transform 0.4s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.4s ease !important;
}

.pawsome-card-hover:hover {
  transform: translateY(-6px) scale(1.01) !important;
  box-shadow: 0 20px 48px rgba(0, 0, 0, 0.14) !important;
}

/* --- Section divider fade line --- */
.pawsome-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, #c9a96e55, transparent);
  margin: 0;
  border: none;
}

/* --- Staggered grid children --- */
.pawsome-grid-parent > * {
  opacity: 0;
  transform: translateY(20px);
  transition:
    opacity 0.6s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}

.pawsome-grid-parent.is-visible > *:nth-child(1) { opacity:1; transform:none; transition-delay: 0.00s; }
.pawsome-grid-parent.is-visible > *:nth-child(2) { opacity:1; transform:none; transition-delay: 0.08s; }
.pawsome-grid-parent.is-visible > *:nth-child(3) { opacity:1; transform:none; transition-delay: 0.16s; }
.pawsome-grid-parent.is-visible > *:nth-child(4) { opacity:1; transform:none; transition-delay: 0.24s; }
.pawsome-grid-parent.is-visible > *:nth-child(5) { opacity:1; transform:none; transition-delay: 0.32s; }
.pawsome-grid-parent.is-visible > *:nth-child(6) { opacity:1; transform:none; transition-delay: 0.40s; }
.pawsome-grid-parent.is-visible > *:nth-child(7) { opacity:1; transform:none; transition-delay: 0.48s; }
.pawsome-grid-parent.is-visible > *:nth-child(8) { opacity:1; transform:none; transition-delay: 0.56s; }

/* --- Magnetic border on hover for containers --- */
@keyframes pawsome-border-spin {
  to { --angle: 360deg; }
}

/* --- Smooth video section --- */
#main video {
  transition: filter 0.5s ease;
}
#main video:hover {
  filter: brightness(1.06) saturate(1.1);
}
