/**
 * Dynamo Header – CTA animations, hover effects, modal styling,
 * header entrance animations, marquee, and navigation dropdown CSS.
 *
 * Extracted from inline @once <style> blocks in site-header.blade.php
 * and navigation-menu.blade.php to reduce per-page HTML size (~475 lines).
 */

/* ═══════════════════════════════════════════════════════════════════════════
   Marquee animation (top-bar)
   ═══════════════════════════════════════════════════════════════════════════ */
@keyframes marquee {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}
.animate-marquee {
    animation: marquee 30s linear infinite;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Header entrance animations
   ═══════════════════════════════════════════════════════════════════════════ */
@keyframes headerSlideDown {
    from { transform: translateY(-100%); opacity: 0; }
    to   { transform: translateY(0); opacity: 1; }
}
@keyframes headerFadeIn {
    from { opacity: 0; }
    to   { opacity: 1; }
}
[data-header-animation="slideDown"] {
    animation: headerSlideDown 0.5s ease-out;
}
[data-header-animation="fadeIn"] {
    animation: headerFadeIn 0.6s ease-out;
}

/* ═══════════════════════════════════════════════════════════════════════════
   CTA Entrance Animations
   ═══════════════════════════════════════════════════════════════════════════ */
@keyframes ctaFadeIn {
    from { opacity: 0; }
    to   { opacity: 1; }
}
@keyframes ctaSlideUp {
    from { opacity: 0; transform: translateY(20px); }
    to   { opacity: 1; transform: translateY(0); }
}
@keyframes ctaSlideDown {
    from { opacity: 0; transform: translateY(-20px); }
    to   { opacity: 1; transform: translateY(0); }
}
@keyframes ctaBounce {
    0%, 20%, 50%, 80%, 100% { transform: translateY(0); }
    40%  { transform: translateY(-12px); }
    60%  { transform: translateY(-6px); }
}
@keyframes ctaPulse {
    0%, 100% { transform: scale(1); }
    50%      { transform: scale(1.05); }
}
@keyframes ctaShake {
    0%, 100%             { transform: translateX(0); }
    10%, 30%, 50%, 70%, 90% { transform: translateX(-4px); }
    20%, 40%, 60%, 80%      { transform: translateX(4px); }
}
@keyframes ctaZoomIn {
    from { opacity: 0; transform: scale(0.5); }
    to   { opacity: 1; transform: scale(1); }
}

.cta-anim-fadeIn    { animation: ctaFadeIn    0.6s ease-out both; }
.cta-anim-slideUp   { animation: ctaSlideUp   0.5s ease-out both; }
.cta-anim-slideDown { animation: ctaSlideDown 0.5s ease-out both; }
.cta-anim-bounce    { animation: ctaBounce    1s   ease     both; }
.cta-anim-pulse     { animation: ctaPulse     2s   ease-in-out infinite; }
.cta-anim-shake     { animation: ctaShake     0.6s ease-in-out both; }
.cta-anim-zoomIn    { animation: ctaZoomIn    0.4s ease-out both; }

/* ═══════════════════════════════════════════════════════════════════════════
   CTA Hover Effects
   ═══════════════════════════════════════════════════════════════════════════ */
.cta-hover-scale {
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.cta-hover-scale:hover {
    transform: scale(1.08);
}

.cta-hover-glow {
    transition: box-shadow 0.3s ease;
}
.cta-hover-glow:hover {
    box-shadow: 0 0 20px rgba(79, 70, 229, 0.4), 0 0 40px rgba(79, 70, 229, 0.2);
}

.cta-hover-shadow {
    transition: box-shadow 0.3s ease, transform 0.3s ease;
}
.cta-hover-shadow:hover {
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
}

.cta-hover-lift {
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.cta-hover-lift:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
}

.cta-hover-underline {
    position: relative;
    overflow: hidden;
}
.cta-hover-underline::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 2px;
    background: currentColor;
    transform: translateX(-100%);
    transition: transform 0.3s ease;
}
.cta-hover-underline:hover::after {
    transform: translateX(0);
}

/* Solid + underline-slide: invert colors on hover */
.cta-hover-underline-solid {
    position: relative;
    overflow: hidden;
    transition: background 0.3s ease, color 0.3s ease;
}
.cta-hover-underline-solid:hover {
    background: transparent !important;
    color: var(--cta-bg) !important;
}
.cta-hover-underline-solid::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 2px;
    background: var(--cta-bg);
    transform: translateX(-100%);
    transition: transform 0.3s ease;
}
.cta-hover-underline-solid:hover::after {
    transform: translateX(0);
}

@keyframes ctaRingPulse {
    0%   { box-shadow: 0 0 0 0 rgba(79, 70, 229, 0.4); }
    70%  { box-shadow: 0 0 0 10px rgba(79, 70, 229, 0); }
    100% { box-shadow: 0 0 0 0 rgba(79, 70, 229, 0); }
}
.cta-hover-ring:hover {
    animation: ctaRingPulse 1.5s infinite;
}

/* ═══════════════════════════════════════════════════════════════════════════
   CTA Modal Content — Dynamic Color Form Styling
   Uses CSS custom properties set via inline styles on the panel:
   --modal-accent (hex), --modal-accent-r/g/b (0-255),
   --modal-text (hex), --modal-bg (hex)
   ═══════════════════════════════════════════════════════════════════════════ */
.cta-modal-content {
    padding: 0;
    color: var(--modal-text, #1e293b);
    line-height: 1.6;
}

/* Minimalist scrollbar for CTA modal scroll area */
.cta-modal-scroll {
    scrollbar-width: thin;
    scrollbar-color: rgba(0, 0, 0, .15) transparent;
}

.cta-modal-scroll::-webkit-scrollbar {
    width: 3px;
}

.cta-modal-scroll::-webkit-scrollbar-track {
    background: transparent;
}

.cta-modal-scroll::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, .15);
    border-radius: 10px;
}

.cta-modal-scroll::-webkit-scrollbar-thumb:hover {
    background: rgba(0, 0, 0, .28);
}

.cta-modal-content h1,
.cta-modal-content h2,
.cta-modal-content h3,
.cta-modal-content h4 {
    font-weight: 700;
    line-height: 1.3;
    margin-bottom: 0.75rem;
    color: var(--modal-text, #0f172a);
}
.cta-modal-content h1 { font-size: 1.75rem; }
.cta-modal-content h2 { font-size: 1.375rem; }
.cta-modal-content h3 { font-size: 1.125rem; }
.cta-modal-content p  { margin-bottom: 1rem; opacity: 0.78; }

/* Form elements inside modal */
.cta-modal-content form {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}
.cta-modal-content label {
    display: block;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--modal-text, #334155);
    margin-bottom: 0.375rem;
    opacity: 0.85;
}

.cta-modal-content input[type="text"],
.cta-modal-content input[type="email"],
.cta-modal-content input[type="tel"],
.cta-modal-content input[type="url"],
.cta-modal-content input[type="number"],
.cta-modal-content input[type="date"],
.cta-modal-content input[type="password"],
.cta-modal-content textarea,
.cta-modal-content select {
    width: 100%;
    padding: 0.75rem 1rem;
    font-size: 0.875rem;
    border: 1.5px solid rgba(var(--modal-accent-r, 139), var(--modal-accent-g, 92), var(--modal-accent-b, 246), 0.18);
    border-radius: 0.75rem;
    background: rgba(var(--modal-accent-r, 139), var(--modal-accent-g, 92), var(--modal-accent-b, 246), 0.04);
    color: var(--modal-text, #0f172a);
    transition: all 0.2s ease;
    outline: none;
    box-sizing: border-box;
}

.cta-modal-content input:focus,
.cta-modal-content textarea:focus,
.cta-modal-content select:focus {
    border-color: var(--modal-accent, #8b5cf6);
    box-shadow: 0 0 0 3px rgba(var(--modal-accent-r, 139), var(--modal-accent-g, 92), var(--modal-accent-b, 246), 0.18);
    background: rgba(var(--modal-accent-r, 139), var(--modal-accent-g, 92), var(--modal-accent-b, 246), 0.06);
}

.cta-modal-content textarea {
    resize: vertical;
    min-height: 100px;
}

/* Buttons inside modal */
.cta-modal-content button[type="submit"],
.cta-modal-content input[type="submit"],
.cta-modal-content .btn-primary,
.cta-modal-content .submit-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    width: 100%;
    padding: 0.8125rem 1.5rem;
    font-size: 0.9375rem;
    font-weight: 600;
    color: #fff;
    background: var(--modal-accent, #8b5cf6);
    border: none;
    border-radius: 0.75rem;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0 4px 15px rgba(var(--modal-accent-r, 139), var(--modal-accent-g, 92), var(--modal-accent-b, 246), 0.3);
    letter-spacing: 0.01em;
}

.cta-modal-content button[type="submit"]:hover,
.cta-modal-content input[type="submit"]:hover,
.cta-modal-content .btn-primary:hover,
.cta-modal-content .submit-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 8px 25px rgba(var(--modal-accent-r, 139), var(--modal-accent-g, 92), var(--modal-accent-b, 246), 0.4);
    filter: brightness(1.1);
}

.cta-modal-content button[type="submit"]:active,
.cta-modal-content input[type="submit"]:active {
    transform: translateY(0);
}

/* Checkbox & radio */
.cta-modal-content input[type="checkbox"],
.cta-modal-content input[type="radio"] {
    accent-color: var(--modal-accent, #8b5cf6);
    width: 1.125rem;
    height: 1.125rem;
    cursor: pointer;
}

/* Links inside modal */
.cta-modal-content a {
    color: var(--modal-accent, #7c3aed);
    text-decoration: none;
    font-weight: 500;
    transition: color 0.2s;
}
.cta-modal-content a:hover {
    filter: brightness(0.85);
    text-decoration: underline;
}

/* Lists inside modal */
.cta-modal-content ul,
.cta-modal-content ol {
    padding-left: 1.25rem;
    margin-bottom: 1rem;
}
.cta-modal-content li {
    margin-bottom: 0.375rem;
}

/* Dividers */
.cta-modal-content hr {
    border: none;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(var(--modal-accent-r, 139), var(--modal-accent-g, 92), var(--modal-accent-b, 246), 0.2), transparent);
    margin: 1.5rem 0;
}

/* Images inside modal */
.cta-modal-content img {
    max-width: 100%;
    height: auto;
    border-radius: 0.75rem;
}

/* Responsive modal content */
@media (max-width: 640px) {
    .cta-modal-content {
        padding: 1.25rem;
    }
    .cta-modal-content h1 { font-size: 1.375rem; }
    .cta-modal-content h2 { font-size: 1.125rem; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   Floating CTA shadow
   ═══════════════════════════════════════════════════════════════════════════ */
.cta-floating {
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.15);
}
.cta-floating:hover {
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.25);
}

/* Responsive CTA */
@media (max-width: 640px) {
    .site-header-cta {
        gap: 0.5rem;
        padding: 0.5rem 0.75rem;
    }
    .site-header-cta a {
        font-size: 0.75rem;
        padding: 0.375rem 0.75rem;
        white-space: nowrap;
    }
}

/* Ensure CTA buttons never break across lines */
.site-header-cta a,
.cta-floating {
    white-space: nowrap;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Navigation – navShock hover keyframe
   ═══════════════════════════════════════════════════════════════════════════ */
@keyframes navShock {
    0%, 100% { transform: translate(0, 0) rotate(0deg); }
    20%      { transform: translate(-2px, 1px) rotate(-1deg); }
    40%      { transform: translate(2px, -1px) rotate(1deg); }
    60%      { transform: translate(-1px, -1px) rotate(-0.5deg); }
    80%      { transform: translate(1px, 1px) rotate(0.5deg); }
}

/* ═══════════════════════════════════════════════════════════════════════════
   Navigation – flyout submenu hover positioning
   ═══════════════════════════════════════════════════════════════════════════ */
.nav-dropdown-group .nav-has-children {
    position: relative;
}
.nav-dropdown-group .nav-submenu {
    display: none;
    position: absolute;
    left: 100%;
    top: 0;
}
.nav-dropdown-group .nav-has-children:hover > .nav-submenu {
    display: block;
}
