/* Custom overrides for branding, font, and dark mode logo switching */
/* Font loaded via <link> tags in HTML for better performance; this file only enforces usage */
html,body,.clmvh,.cbwmu{font-family:'Bricolage Grotesque',ui-sans-serif,system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif !important;font-optical-sizing:auto;}
input,button,select,textarea{font-family:inherit}

/* Smooth scrolling */
html { scroll-behavior: smooth; }

/* Logo container layout */
.site-logo{display:inline-flex;align-items:center;gap:.25rem;line-height:0}
.site-logo .logo-img{height:1.75rem;width:auto;display:block}
/* Ensure branding wrapper vertically centers contents */
.ctuhr{display:flex;align-items:center}

/* Swapped: show dark logo in light mode, light logo in dark mode */
.site-logo .logo-light{display:none}
.site-logo .logo-dark{display:block}
.dark .site-logo .logo-light{display:block}
.dark .site-logo .logo-dark{display:none}

/* Hero text adjustments */
.hero-headline{max-width:22ch;line-height:1.05}
.hero-sub{max-width:70ch;margin-left:auto;margin-right:auto}
@media (max-width:640px){
  .hero-headline{font-size:2.1rem !important}
  .hero-sub{font-size:.95rem}
}

/* Animations */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.fade-in-up {
    animation: fadeInUp 0.8s ease-out forwards;
}

.reveal-on-scroll {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}

.reveal-on-scroll.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* Card Styles & Hover Effects */
.feature-card, .step-card {
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.feature-card:hover, .step-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 30px -10px rgba(0, 0, 0, 0.15);
}

.dark .feature-card:hover, .dark .step-card:hover {
    box-shadow: 0 10px 30px -10px rgba(0, 0, 0, 0.5);
}

/* Optional shorter copy variant (not yet used) */
.short-hero-copy{display:none}

/* Waitlist button loading + success message */
#waitlist-form #waitlist-button.is-loading{position:relative;pointer-events:none;opacity:.85}
#waitlist-form #waitlist-button.is-loading::after{content:"";position:absolute;inset:0;display:block;background:repeating-linear-gradient(45deg,rgba(255,255,255,.15)0 10px,rgba(255,255,255,.05)10px 20px);animation:waitPulse .8s linear infinite;border-radius:inherit}
@keyframes waitPulse{0%{background-position:0 0}100%{background-position:200% 0}}
#waitlist-success{margin-top:.5rem;font-size:.85rem;color:#16a34a;display:none}
#waitlist-success.visible{display:block}
#waitlist-error{margin-top:.5rem;font-size:.85rem;color:#dc2626}

/* Different modal accent when using delay email variant */
#waitlist-modal[data-variant="delayed"] .th-modal__icon{filter:drop-shadow(0 2px 4px rgba(180,132,38,.4))}
#waitlist-button.rate-limited{animation:shake .5s ease;}
@keyframes shake{10%,90%{transform:translateX(-1px)}20%,80%{transform:translateX(2px)}30%,50%,70%{transform:translateX(-4px)}40%,60%{transform:translateX(4px)}}

/* Modal styles */
#waitlist-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;font-family:inherit}
#waitlist-modal[hidden]{display:none}
#waitlist-modal .th-modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(2px)}
#waitlist-modal .th-modal__dialog{position:relative;background:linear-gradient(135deg,#ffffff 0%,#f7fafc 100%);padding:2.2rem 2rem 2rem;border-radius:1.1rem;max-width:420px;width:100%;box-shadow:0 10px 25px -5px rgba(0,0,0,.25),0 0 0 1px rgba(0,0,0,.04)}
.dark #waitlist-modal .th-modal__dialog{background:linear-gradient(135deg,#1f2732 0%,#17202a 100%);box-shadow:0 10px 25px -5px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.05)}
#waitlist-modal h2{margin:0 0 .75rem;font-size:1.4rem;line-height:1.15;font-weight:600}
#waitlist-modal .th-modal__body{margin:0 0 1.25rem;font-size:.95rem;line-height:1.45}
#waitlist-modal .th-modal__icon{font-size:2rem;margin-bottom:.75rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.25))}
#waitlist-modal .th-modal__close{position:absolute;top:.55rem;right:.65rem;border:none;background:transparent;font-size:1.5rem;line-height:1;color:inherit;cursor:pointer;padding:.25rem}
#waitlist-modal .th-modal__close:hover{opacity:.75}
#waitlist-modal .th-modal__action{display:inline-flex;align-items:center;gap:.4rem;background:#16a34a;color:#fff;border:none;font-weight:600;font-size:.9rem;padding:.75rem 1.15rem;border-radius:.7rem;cursor:pointer;box-shadow:0 4px 10px -2px rgba(22,163,74,.5);transition:.25s}
#waitlist-modal .th-modal__action:hover{background:#15803d}
#waitlist-modal .th-modal__action:active{transform:translateY(1px)}
#waitlist-modal .th-modal__dialog:focus{outline:2px solid #2563eb;outline-offset:2px}
@media (max-width:520px){#waitlist-modal .th-modal__dialog{margin:0 1rem;padding:2rem 1.35rem}}

/* Extended form fields styling */
#waitlist-form label:not(.cz99u){font-size:.9rem;font-weight:500;display:block;margin-bottom:.35rem}
#waitlist-form select,#waitlist-form input[type="text"],#waitlist-form input[type="email"],#waitlist-form input[type="tel"],#waitlist-form input[type="url"]{width:100%}
#waitlist-form input[type="checkbox"]{width:auto;margin:0;cursor:pointer;accent-color:#2563eb}
#waitlist-form .cacgm{gap:1.25rem!important}

/* Checkbox labels proper styling */
#waitlist-form label[style*="cursor:pointer"]{
  display:flex!important;
  align-items:flex-start!important;
  gap:.5rem!important;
  font-size:.85rem!important;
  cursor:pointer!important;
  line-height:1.4
}
#waitlist-form label[style*="cursor:pointer"] input[type="checkbox"]{
  margin-top:.15rem;
  flex-shrink:0;
  width:16px;
  height:16px
}

/* Select dropdown styling */
#waitlist-form select{
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right .75rem center;
  background-size:12px;
  padding-right:2.5rem
}
.dark #waitlist-form select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23aaa' d='M6 9L1 4h10z'/%3E%3C/svg%3E")
}

/* Benefit/step cards responsive */
@media(max-width:768px){
  #waitlist-form .cacgm{gap:1rem!important}
}

/* Form width on desktop - increase max-width for join page */
.join-form-container{max-width:800px!important;margin:0 auto}
@media(min-width:1024px){
  .join-form-container{max-width:50vw!important;min-width:700px!important}
}
@media(min-width:1400px){
  .join-form-container{max-width:50vw!important;min-width:800px!important}
}

/* Join Waitlist button responsive styling */
.join-cta-btn{
  display:inline-block;
  font-size:1rem;
  padding:.85rem 2rem;
  text-align:center;
  transition:transform .2s,box-shadow .2s;
  max-width:280px
}
.join-cta-btn:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 20px -4px rgba(37,99,235,.4)
}
.join-cta-btn:active{
  transform:translateY(0)
}

/* Mobile responsiveness for join buttons */
@media(max-width:640px){
  .join-cta-btn{
    font-size:.95rem;
    padding:.85rem 1.75rem;
    width:100%;
    max-width:320px
  }
}
@media(max-width:480px){
  .join-cta-btn{
    font-size:.9rem;
    padding:.8rem 1.5rem;
    width:100%
  }
}

/* Nav join button specific styling */
nav .join-nav-btn{
  padding:.5rem 1.25rem;
  font-size:.9rem;
  white-space:nowrap
}
@media(max-width:768px){
  nav .join-nav-btn{
    padding:.45rem 1rem;
    font-size:.85rem
  }
}
@media(max-width:480px){
  nav .join-nav-btn{
    padding:.4rem .8rem;
    font-size:.8rem
  }
}