/* This site was custom designed by Sitethreesixty.com and is actively managed by Sitethreesixty.com */
/* ================================
   A/B TEST COMPONENTS - CURLY TAIL SCREEN & WINDOW
   New components for mobile conversion optimization
   Version: v2 (A/B Test)
   ================================ */

/* ================================
   STICKY PHONE BUTTON
   Fixed mobile CTA for easy calling
   Green background, visible on mobile only
   LARGER SIZE for better visibility
   ================================ */
.sticky-phone-btn {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: var(--z-sticky, 1040);
  display: none;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 16px 24px;
  background-color: #15803D;
  color: #FFFFFF !important;
  font-family: var(--font-body);
  font-size: var(--text-lg);
  font-weight: var(--weight-bold);
  text-decoration: none;
  border-radius: var(--radius-full);
  box-shadow: 0 6px 28px rgba(21, 128, 61, 0.5), var(--shadow-xl);
  opacity: 0;
  animation: fadeInButton 0.5s ease-out 0.5s forwards;
  transition: all var(--transition-base);
}

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

.sticky-phone-btn:hover {
  background-color: #14532D;
  transform: scale(1.05);
  box-shadow: 0 8px 32px rgba(21, 128, 61, 0.6), var(--shadow-2xl);
  color: #FFFFFF !important;
}

.sticky-phone-btn span {
  color: #FFFFFF !important;
}

.sticky-phone-btn:active {
  transform: scale(0.97);
}

.sticky-phone-btn svg {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}

@media (max-width: 768px) {
  .sticky-phone-btn {
    display: flex;
  }
}

@media (max-width: 480px) {
  .sticky-phone-btn {
    bottom: 20px;
    right: 20px;
    padding: 14px 20px;
    font-size: var(--text-base);
  }

  .sticky-phone-btn svg {
    width: 22px;
    height: 22px;
  }
}

/* ================================
   FORM TRUST BADGES
   Trust indicators above contact forms
   ================================ */
.form-trust-badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
  margin-bottom: 24px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--border-light);
}

.form-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  background-color: var(--color-blue-subtle);
  color: var(--color-blue);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  border-radius: var(--radius-full);
}

.form-badge::before {
  content: '✓';
  display: flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  background-color: var(--color-blue);
  color: var(--color-white);
  border-radius: var(--radius-full);
  font-size: 9px;
  font-weight: var(--weight-bold);
}

@media (max-width: 480px) {
  .form-trust-badges {
    gap: 4px;
    flex-wrap: nowrap;
  }

  .form-badge {
    padding: 3px 5px;
    font-size: 8px;
    white-space: nowrap;
    gap: 3px;
  }

  .form-badge::before {
    width: 10px;
    height: 10px;
    font-size: 6px;
  }
}

@media (max-width: 460px) {
  .form-trust-badges {
    gap: 3px;
  }

  .form-badge {
    padding: 2px 4px;
    font-size: 7px;
    gap: 2px;
  }

  .form-badge::before {
    width: 8px;
    height: 8px;
    font-size: 5px;
  }
}

/* ================================
   FORM CALLBACK NOTE
   Reassurance text below submit button
   ================================ */
.form-callback-note {
  text-align: center;
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin-top: 12px;
  font-style: italic;
}

/* ================================
   SERVICE PRICE INDICATORS
   Pricing display on service cards
   ================================ */
.service-price {
  display: inline-block;
  margin-top: 12px;
  padding: 6px 14px;
  background-color: var(--color-orange-subtle);
  color: var(--color-orange-accessible);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  border-radius: var(--radius-md);
}

.flip-card .service-price {
  margin-top: 16px;
  background-color: rgba(255, 255, 255, 0.15);
  color: var(--color-white);
}

/* ================================
   NAV CTA VISIBILITY
   Show/hide CTAs based on viewport
   ================================ */
.nav-cta-desktop {
  display: inline-flex;
  opacity: 0;
  animation: fadeInButton 0.5s ease-out 0.5s forwards;
}

.nav-cta-mobile {
  display: none;
  opacity: 0;
  animation: fadeInButton 0.5s ease-out 0.5s forwards;
}

@media (max-width: 768px) {
  .nav-cta-desktop {
    display: none;
  }

  .nav-cta-mobile {
    display: inline-flex;
  }

  .nav-right .nav-cta-mobile {
    padding: 8px 14px;
    font-size: var(--text-xs);
    background-color: #15803D;
    color: #FFFFFF !important;
  }

  .nav-right .nav-cta-mobile:hover {
    background-color: #14532D;
    color: #FFFFFF !important;
  }
}

/* Mobile nav slide-out CTA styling */
.nav-links .nav-cta-desktop {
  width: 100%;
  text-align: center;
  margin-top: 24px;
  padding: 16px 24px;
}

.nav-links .nav-cta-mobile {
  width: 100%;
  text-align: center;
  margin-top: 12px;
  padding: 16px 24px;
  background-color: #15803D;
  color: #FFFFFF !important;
}

.nav-links .nav-cta-mobile:hover {
  background-color: #14532D;
  color: #FFFFFF !important;
}

.nav-links .nav-cta-mobile span {
  color: #FFFFFF !important;
}

/* ================================
   INTRO BAR
   Simplified hero introduction bar
   ================================ */
.intro-bar {
  background-color: var(--color-white);
  text-align: center;
  padding-top: 48px;
  padding-bottom: 48px;
  position: relative;
  overflow: hidden;
}

.intro-bar-content {
  max-width: 800px;
  margin: 0 auto;
}

.intro-headline {
  font-size: var(--text-2xl);
  font-weight: var(--weight-bold);
  color: var(--color-text);
  margin-bottom: 8px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.intro-headline.company-name {
  font-family: var(--font-logo);
  font-size: var(--text-5xl);
  letter-spacing: 0.02em;
  color: var(--color-blue-navy);
}

.intro-tagline {
  font-size: var(--text-base);
  color: var(--text-secondary);
  margin-bottom: 8px;
  margin-left: auto;
  margin-right: auto;
  font-style: italic;
  text-align: center;
}

.intro-areas {
  font-size: var(--text-base);
  color: var(--text-secondary);
  margin-bottom: 0;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

@media (max-width: 900px) {
  .intro-bar-content {
    max-width: calc(100% - 20px);
    padding: 0 10px;
  }

  .intro-headline.company-name {
    font-size: clamp(1rem, 7.5vw, var(--text-5xl)) !important;
    white-space: nowrap;
  }
}

@media (max-width: 768px) {
  .intro-headline {
    font-size: var(--text-xl);
  }

  .intro-headline.company-name {
    font-size: clamp(1rem, 7.5vw, var(--text-5xl)) !important;
    white-space: nowrap;
  }

  .intro-areas {
    font-size: var(--text-sm);
  }
}

/* ================================
   HERO LOCATION BADGE
   Service area indicator in hero
   ================================ */
.hero-location {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  background-color: var(--color-blue-subtle);
  color: var(--color-blue);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  border-radius: var(--radius-full);
  margin-bottom: 16px;
}

.hero-location svg {
  width: 16px;
  height: 16px;
}

/* ================================
   FOOTER MASCOT
   Lizard mascot in footer area
   ================================ */
.lizard-mascot-footer {
  position: absolute;
  right: 20px;
  bottom: 0;
  width: 60px;
  height: auto;
  pointer-events: none;
  opacity: 0.8;
}

@media (max-width: 768px) {
  .lizard-mascot-footer {
    width: 40px;
    right: 10px;
  }
}

/* ================================
   FULL WIDTH UTILITY
   For form submit buttons
   ================================ */
.w-full {
  width: 100%;
}

/* ================================
   ADDITIONAL SERVICE NOTE
   Small note on service cards
   ================================ */
.service-note {
  display: block;
  font-size: var(--text-xs);
  color: var(--text-muted);
  font-style: italic;
  margin-top: 8px;
}

/* ================================
   SERVICE LIST
   Bullet list within service cards
   ================================ */
.service-list {
  list-style: none;
  padding: 0;
  margin: 12px 0;
  text-align: left;
}

.service-list li {
  position: relative;
  padding-left: 20px;
  margin-bottom: 6px;
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

.service-list li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--color-blue);
  font-weight: var(--weight-bold);
}

/* ================================
   SERVICE GLASS NOTE
   Disclaimer about glass replacement
   ================================ */
.service-glass-note {
  font-size: var(--text-xs);
  color: var(--text-muted);
  font-style: italic;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--border-light);
}

/* ================================
   INTRO BAR MOBILE VISIBILITY
   Now visible on mobile (previously hidden)
   ================================ */

/* ================================
   BREADCRUMBS MOBILE VISIBILITY
   Hide breadcrumbs on mobile to save space
   ================================ */
@media (max-width: 768px) {
  .breadcrumbs {
    display: none;
  }
}

/* ================================
   GOOGLE REVIEWS WITH ICON
   Fix missing Google G icon
   ================================ */
.google-reviews {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.google-g {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}

.google-g img,
.google-g svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* ================================
   FLIP CARDS MOBILE BEHAVIOR
   Show all content on mobile, no flip
   ================================ */
@media (max-width: 768px) {
  .flip-card {
    perspective: none;
    height: auto;
  }

  .flip-card-inner {
    transform: none !important;
    transform-style: flat;
    transition: none;
  }

  .flip-card:hover .flip-card-inner,
  .flip-card:focus-within .flip-card-inner {
    transform: none !important;
  }

  .flip-card-front {
    position: relative;
    backface-visibility: visible;
  }

  .flip-card-front img {
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  }

  .flip-card-front .card-overlay {
    position: relative;
    background: var(--color-blue);
    padding: 16px;
    border-radius: 0;
  }

  .flip-card-front .card-overlay h3 {
    margin-bottom: 0;
  }

  .flip-card-front .flip-hint {
    display: none;
  }

  .flip-card-back {
    position: relative;
    transform: none;
    backface-visibility: visible;
    background: var(--color-white);
    padding: 20px;
    border-radius: 0 0 var(--radius-lg) var(--radius-lg);
    border: 1px solid var(--border-light);
    border-top: none;
  }

  .flip-card-back h3 {
    display: none;
  }

  .flip-card-back .service-price {
    margin-top: 0;
    margin-bottom: 12px;
  }

  .flip-card-back p {
    color: var(--text-secondary);
    font-size: var(--text-sm);
    margin-bottom: 12px;
  }
}

/* ================================
   LEARN MORE LINK
   Expandable detail link on services
   ================================ */
.learn-more-link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: var(--color-blue);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  text-decoration: none;
  margin-top: 8px;
  cursor: pointer;
}

.learn-more-link:hover {
  text-decoration: underline;
}

.learn-more-link svg {
  width: 16px;
  height: 16px;
  transition: transform var(--transition-fast);
}

.learn-more-link.expanded svg {
  transform: rotate(180deg);
}

/* ================================
   RESPONSE TIME PROMISE
   Hero and form response time messaging
   ================================ */
.response-time-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  background-color: var(--color-orange-subtle);
  color: var(--color-orange-accessible);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  border-radius: var(--radius-full);
  margin-top: 16px;
}

.response-time-badge svg {
  width: 16px;
  height: 16px;
}

/* ================================
   LIGHT SHOW NAV CTA
   Different CTA for Light Show page
   ================================ */
.page-light-show .nav-cta-desktop {
  background-color: var(--color-blue);
}

.page-light-show .nav-cta-desktop:hover {
  background-color: var(--color-blue-dark);
}

/* This site was custom designed by Sitethreesixty.com and is actively managed by Sitethreesixty.com */
