/* ═══════════════════════════════════════════════════════════════
   HAUSFEEN — Animations & Modern Polish
   Scroll reveals, micro-interactions, floating elements
   ═══════════════════════════════════════════════════════════════ */

/* ─── Scroll Reveal Base ─── */
.reveal {
    opacity: 0;
    transform: translateY(32px);
    transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
                transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}
.reveal.visible {
    opacity: 1;
    transform: translateY(0);
}

/* Reveal from left */
.reveal-left {
    opacity: 0;
    transform: translateX(-40px);
    transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
                transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}
.reveal-left.visible {
    opacity: 1;
    transform: translateX(0);
}

/* Reveal from right */
.reveal-right {
    opacity: 0;
    transform: translateX(40px);
    transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1),
                transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}
.reveal-right.visible {
    opacity: 1;
    transform: translateX(0);
}

/* Reveal scale up */
.reveal-scale {
    opacity: 0;
    transform: scale(0.92);
    transition: opacity 0.6s cubic-bezier(0.16, 1, 0.3, 1),
                transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}
.reveal-scale.visible {
    opacity: 1;
    transform: scale(1);
}

/* Stagger children */
.stagger-children > * {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 0.5s cubic-bezier(0.16, 1, 0.3, 1),
                transform 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}
.stagger-children.visible > *:nth-child(1) { transition-delay: 0s; }
.stagger-children.visible > *:nth-child(2) { transition-delay: 0.08s; }
.stagger-children.visible > *:nth-child(3) { transition-delay: 0.16s; }
.stagger-children.visible > *:nth-child(4) { transition-delay: 0.24s; }
.stagger-children.visible > *:nth-child(5) { transition-delay: 0.32s; }
.stagger-children.visible > *:nth-child(6) { transition-delay: 0.4s; }
.stagger-children.visible > * {
    opacity: 1;
    transform: translateY(0);
}

/* ─── Page Fade In ─── */
@keyframes pageIn {
    from { opacity: 0; transform: translateY(12px); }
    to   { opacity: 1; transform: translateY(0); }
}
main {
    animation: pageIn 0.5s cubic-bezier(0.16, 1, 0.3, 1) both;
}

/* ─── Gradient Background Animation ─── */
@keyframes gradientShift {
    0%   { background-position: 0% 50%; }
    50%  { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}
.animated-gradient {
    background: linear-gradient(135deg,
        rgba(44,204,211,0.06) 0%,
        rgba(255,212,71,0.04) 25%,
        rgba(44,204,211,0.03) 50%,
        rgba(139,92,246,0.04) 75%,
        rgba(44,204,211,0.06) 100%
    );
    background-size: 400% 400%;
    animation: gradientShift 12s ease infinite;
}

/* ─── Floating Elements ─── */
@keyframes float1 {
    0%, 100% { transform: translate(0, 0) rotate(0deg); }
    25%      { transform: translate(12px, -18px) rotate(3deg); }
    50%      { transform: translate(-8px, -28px) rotate(-2deg); }
    75%      { transform: translate(6px, -12px) rotate(1deg); }
}
@keyframes float2 {
    0%, 100% { transform: translate(0, 0) rotate(0deg); }
    33%      { transform: translate(-15px, -20px) rotate(-4deg); }
    66%      { transform: translate(10px, -32px) rotate(3deg); }
}
@keyframes float3 {
    0%, 100% { transform: translate(0, 0) scale(1); }
    50%      { transform: translate(8px, -22px) scale(1.05); }
}

.float-1 { animation: float1 6s ease-in-out infinite; }
.float-2 { animation: float2 8s ease-in-out infinite; }
.float-3 { animation: float3 7s ease-in-out infinite; }

/* ─── Pulse Glow ─── */
@keyframes pulseGlow {
    0%, 100% { box-shadow: 0 0 0 0 rgba(44,204,211,0.3); }
    50%      { box-shadow: 0 0 0 12px rgba(44,204,211,0); }
}
.pulse-glow { animation: pulseGlow 2.5s ease-in-out infinite; }

/* ─── Shimmer Effect ─── */
@keyframes shimmer {
    0%   { background-position: -200% center; }
    100% { background-position: 200% center; }
}
.shimmer-text {
    background: linear-gradient(90deg,
        var(--dk) 0%, var(--dk) 40%,
        var(--pri) 50%,
        var(--dk) 60%, var(--dk) 100%
    );
    background-size: 200% auto;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    animation: shimmer 4s linear infinite;
}

/* ─── Counter Animation ─── */
.counter[data-target] {
    display: inline-block;
}

/* ─── Particle Dots ─── */
.particles {
    position: absolute;
    inset: 0;
    overflow: hidden;
    pointer-events: none;
    z-index: 0;
}
.particle {
    position: absolute;
    border-radius: 50%;
    opacity: 0.15;
    animation: particleDrift 20s linear infinite;
}
@keyframes particleDrift {
    0%   { transform: translateY(100vh) rotate(0deg); opacity: 0; }
    10%  { opacity: 0.15; }
    90%  { opacity: 0.15; }
    100% { transform: translateY(-10vh) rotate(360deg); opacity: 0; }
}

/* ─── Enhanced Button Hovers ─── */
.btn-primary {
    position: relative;
    overflow: hidden;
    z-index: 1;
}
.btn-primary::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(255,255,255,0.15), transparent);
    opacity: 0;
    transition: opacity 0.3s;
    z-index: -1;
}
.btn-primary:hover::after {
    opacity: 1;
}

/* ─── Card Hover Glow ─── */
.card {
    position: relative;
}
.card::before {
    content: '';
    position: absolute;
    inset: -1px;
    background: linear-gradient(135deg, var(--pri), var(--acc));
    opacity: 0;
    transition: opacity 0.3s;
    z-index: -1;
    border-radius: inherit;
}
.card:hover::before {
    opacity: 0.08;
}

/* ─── Navbar Scroll Effect ─── */
.navbar {
    transition: box-shadow 0.3s, background 0.3s;
}
.navbar.scrolled {
    box-shadow: 0 4px 30px rgba(15,46,54,0.1);
}

/* ─── Link Underline Animation ─── */
.nav-link {
    position: relative;
}
.nav-link::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    width: 0;
    height: 2px;
    background: var(--acc);
    transition: width 0.3s, left 0.3s;
}
.nav-link:hover::after {
    width: 100%;
    left: 0;
}
.nav-link.active::after {
    width: 100%;
    left: 0;
}

/* ─── Smooth Image Load ─── */
img[loading="lazy"] {
    opacity: 0;
    transition: opacity 0.4s;
}
img[loading="lazy"].loaded,
img[loading="lazy"][src] {
    opacity: 1;
}

/* ─── Tooltip Fade ─── */
[data-tooltip] {
    position: relative;
}
[data-tooltip]::after {
    content: attr(data-tooltip);
    position: absolute;
    bottom: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%) translateY(4px);
    background: var(--dk);
    color: #fff;
    font-size: 0.72rem;
    padding: 0.35rem 0.7rem;
    border-radius: 6px;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s, transform 0.2s;
    z-index: 50;
}
[data-tooltip]:hover::after {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}

/* ─── Reduced Motion ─── */
@media (prefers-reduced-motion: reduce) {
    .reveal, .reveal-left, .reveal-right, .reveal-scale {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
    }
    .stagger-children > * {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
    }
    .float-1, .float-2, .float-3,
    .pulse-glow, .shimmer-text {
        animation: none !important;
    }
    .particles { display: none !important; }
    main { animation: none !important; }
}

/* ─── Global Radius Override ─── */
/* Force radius on all box-like elements that pages use with inline styles */
main section > .container > div[style*="box-shadow"],
main section > .container > div > div[style*="box-shadow"],
main section > .container > div > div > div[style*="box-shadow"],
main [style*="background:var(--w)"][style*="box-shadow"],
main [style*="background:#fff"][style*="box-shadow"],
main [style*="background: var(--w)"][style*="box-shadow"],
main [style*="background: #fff"][style*="box-shadow"],
main [style*="background:var(--g50)"][style*="padding"],
main section [style*="padding:1.3rem"],
main section [style*="padding:1.4rem"],
main section [style*="padding:1.5rem"] {
    border-radius: var(--radius-md) !important;
}

/* Registrieren button in navbar */
.navbar .btn-primary {
    border-radius: var(--radius-sm) !important;
}

/* Search bar container */
main form[style*="box-shadow"] {
    border-radius: var(--radius-md) !important;
    overflow: hidden;
}

/* Payment badges */
[style*="border:1px solid"][style*="padding:2px"],
[style*="border: 1px solid"][style*="padding:2px"] {
    border-radius: 6px !important;
}

/* Stat bar area */
section[style*="background:var(--dk)"] > .container > div[style*="text-align:center"] > div:first-child {
    border-radius: var(--radius-sm);
}

/* Inline style cards (components that use inline padding/bg) */
[style*="padding:1.4rem 1.3rem"],
[style*="padding: 1.4rem 1.3rem"] {
    border-radius: var(--radius-md) !important;
}

/* Cleaner profile cards */
.cards-grid > div,
.cards-grid > a {
    border-radius: var(--radius-md) !important;
    overflow: hidden;
}

/* Gold badge top banners on cards */
.cards-grid > div > div:first-child[style*="background"],
.cards-grid > a > div:first-child[style*="background"] {
    border-radius: var(--radius-md) var(--radius-md) 0 0;
}

/* Login/Register form cards */
main > div[style*="max-width"][style*="margin"] {
    border-radius: var(--radius-md);
}

/* All form containers */
form[style*="box-shadow"],
div[style*="box-shadow"][style*="padding:2"],
div[style*="box-shadow"][style*="padding: 2"],
div[style*="box-shadow"][style*="padding:1"] {
    border-radius: var(--radius-md) !important;
}

/* Footer logo badge */
footer [style*="padding:6px 14px"] {
    border-radius: var(--radius-sm) !important;
}

/* Trust/DSGVO badges in footer */
footer [style*="padding:0.2rem 0.5rem"] {
    border-radius: 6px !important;
}

/* Payment strip badges */
.payment-badge {
    border-radius: 6px !important;
}

/* ─── UNIVERSAL RADIUS FIX ─── */
/* Any element with box-shadow gets radius (covers all inline-styled containers) */
main [style*="box-shadow"] {
    border-radius: var(--radius-md) !important;
}

/* Any element with the form-input class */
.form-input {
    border-radius: var(--radius-sm) !important;
}

/* Buttons always get radius */
.btn {
    border-radius: var(--radius-sm) !important;
}

/* Cards always get radius */
.card {
    border-radius: var(--radius-md) !important;
}

/* Stat bar */
.stat-bar {
    border-radius: var(--radius-md) !important;
}

/* Search bar */
.search-bar {
    border-radius: var(--radius-md) !important;
}

/* Alerts */
.alert {
    border-radius: var(--radius-sm) !important;
}

/* Tags */
.tag {
    border-radius: 6px !important;
}

/* Job rows */
.job-row {
    border-radius: var(--radius-sm) !important;
}

/* Filter buttons */
.filter-btn {
    border-radius: 6px !important;
}

/* Message bubbles */
.msg-bubble {
    border-radius: var(--radius-md) !important;
}
.msg-mine {
    border-bottom-right-radius: 4px !important;
}
.msg-other {
    border-bottom-left-radius: 4px !important;
}

/* User dropdown */
.user-dropdown {
    border-radius: var(--radius-md) !important;
}

/* Any inline-styled container with padding and background */
main [style*="padding:2rem"][style*="background"],
main [style*="padding: 2rem"][style*="background"],
main [style*="padding:1.5rem"][style*="background"],
main [style*="padding: 1.5rem"][style*="background"],
main form[style*="padding"][style*="background"] {
    border-radius: var(--radius-md) !important;
}

/* Progress bar steps */
.progress-step {
    border-radius: 2px !important;
}
.progress {
    border-radius: 4px !important;
}

/* Day availability */
.day {
    border-radius: 6px !important;
}

/* Avatar small */
.avatar-small {
    border-radius: 50% !important;
}

/* Gold badge */
.gold-badge {
    border-radius: 20px !important;
}

/* Verified badge */
.verified {
    border-radius: 4px !important;
}

/* Navbar - slight radius on bottom */
.navbar {
    border-radius: 0 !important;
}
