/* 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}

/* 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}
}

/* 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)}}

/* Role selector */
.role-selector{margin:1rem 0}
.role-label{display:block;margin-bottom:.75rem;font-size:.9rem}
.role-options{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.role-option{position:relative;cursor:pointer;display:block}
.role-option input[type="radio"]{position:absolute;opacity:0;width:0;height:0}
.role-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:1rem .75rem;border:2px solid rgba(0,0,0,.1);border-radius:.8rem;background:rgba(255,255,255,.6);backdrop-filter:blur(4px);transition:all .25s ease}
.dark .role-card{background:rgba(31,41,55,.5);border-color:rgba(255,255,255,.1)}
.role-icon{font-size:1.75rem;margin-bottom:.35rem;display:block}
.role-title{font-weight:600;font-size:.85rem;display:block;margin-bottom:.15rem}
.role-desc{font-size:.7rem;opacity:.7;display:block;line-height:1.2}
.role-option input:checked + .role-card{border-color:#2563eb;background:rgba(37,99,235,.08);box-shadow:0 4px 12px -2px rgba(37,99,235,.3)}
.dark .role-option input:checked + .role-card{border-color:#3b82f6;background:rgba(59,130,246,.15)}
.role-option:hover .role-card{transform:translateY(-2px);box-shadow:0 6px 16px -4px rgba(0,0,0,.15)}
@keyframes slideIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
@media (max-width:520px){.role-options{grid-template-columns:1fr;gap:.5rem}}

/* 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}}

