/* Reset and Base Styles */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    line-height: 1.5;
    color: #111827;
}

/* Color Palette - Tailwind Colors */
:root {
    /* Site primary color (used by footer accent, etc.) */
    --primary-color: var(--blue-600);

    /* Gray scale */
    --gray-50: #f9fafb;
    --gray-100: #f3f4f6;
    --gray-200: #e5e7eb;
    --gray-300: #d1d5db;
    --gray-400: #9ca3af;
    --gray-600: #4b5563;
    --gray-700: #374151;
    --gray-800: #1f2937;
    --gray-900: #111827;
    
    /* Blue */
    --blue-50: #eff6ff;
    --blue-100: #dbeafe;
    --blue-200: #bfdbfe;
    --blue-300: #93c5fd;
    --blue-600: #2563eb;
    --blue-700: #1d4ed8;
    
    /* Green */
    --green-50: #f0fdf4;
    --green-100: #dcfce7;
    --green-200: #bbf7d0;
    --green-300: #86efac;
    --green-600: #16a34a;
    --green-700: #15803d;
    
    /* Orange */
    --orange-50: #fff7ed;
    --orange-100: #ffedd5;
    --orange-200: #fed7aa;
    --orange-300: #fdba74;
    --orange-600: #ea580c;
    --orange-700: #c2410c;
    
    /* Purple */
    --purple-50: #faf5ff;
    --purple-100: #f3e8ff;
    --purple-200: #e9d5ff;
    --purple-300: #d8b4fe;
    --purple-600: #9333ea;
    --purple-700: #7e22ce;
    
    /* Teal */
    --teal-50: #f0fdfa;
    --teal-100: #ccfbf1;
    --teal-200: #99f6e4;
    --teal-300: #5eead4;
    --teal-600: #0d9488;
    --teal-700: #0f766e;
    
    /* Indigo */
    --indigo-50: #eef2ff;
    --indigo-100: #e0e7ff;
    --indigo-200: #c7d2fe;
    --indigo-300: #a5b4fc;
    --indigo-600: #4f46e5;
    --indigo-700: #4338ca;

    /* Sky */
    --sky-50: #f0f9ff;
    --sky-100: #e0f2fe;
    --sky-200: #bae6fd;
    --sky-300: #7dd3fc;
    --sky-600: #0284c7;
    --sky-700: #0369a1;

    /* Rose */
    --rose-50: #fff1f2;
    --rose-100: #ffe4e6;
    --rose-200: #fecdd3;
    --rose-300: #fda4af;
    --rose-600: #e11d48;
    --rose-700: #be123c;
}

/* Layout Utilities */
.w-full {
    width: 100%;
}

.h-full {
    height: 100%;
}

.h-auto {
    height: auto;
}

.min-h-screen {
    min-height: 100vh;
}

.max-w-7xl {
    max-width: 80rem;
}

.mx-auto {
    margin-left: auto;
    margin-right: auto;
}

/* Spacing */
.pt-0 {
    padding-top: 0;
}

.px-4 {
    padding-left: 1rem;
    padding-right: 1rem;
}

.py-4 {
    padding-top: 1rem;
    padding-bottom: 1rem;
}

.py-12 {
    padding-top: 3rem;
    padding-bottom: 3rem;
}

.p-4 {
    padding: 1rem;
}

.p-6 {
    padding: 1.5rem;
}

.px-8 {
    padding-left: 2rem;
    padding-right: 2rem;
}

.py-1 {
    padding-top: 0.25rem;
    padding-bottom: 0.25rem;
}

.py-2 {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}

.mb-1 {
    margin-bottom: 0.25rem;
}

.mb-4 {
    margin-bottom: 1rem;
}

.mb-6 {
    margin-bottom: 1.5rem;
}

.mb-8 {
    margin-bottom: 2rem;
}

.mt-1 {
    margin-top: 0.25rem;
}

.mt-2 {
    margin-top: 0.5rem;
}

.mt-4 {
    margin-top: 1rem;
}

.mt-6 {
    margin-top: 1.5rem;
}

.mt-8 {
    margin-top: 2rem;
}

.mr-2 {
    margin-right: 0.5rem;
}

.mx-2 {
    margin-left: 0.5rem;
    margin-right: 0.5rem;
}

/* Flexbox */
.flex {
    display: flex;
}

.inline-flex {
    display: inline-flex;
}

.items-center {
    align-items: center;
}

.justify-center {
    justify-content: center;
}

.justify-start {
    justify-content: flex-start;
}

/* Grid */
.grid {
    display: grid;
}

.gap-3 {
    gap: 0.75rem;
}

.gap-12 {
    gap: 3rem;
}

/* Positioning */
.relative {
    position: relative;
}

.absolute {
    position: absolute;
}

/* Responsive Grid Columns */
.grid-cols-1 {
    grid-template-columns: repeat(1, minmax(0, 1fr));
}

@media (min-width: 768px) {
    .md\:grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    
    .md\:order-1 {
        order: 1;
    }
    
    .md\:order-2 {
        order: 2;
    }
    
    .md\:text-left {
        text-align: left;
    }
    
    .md\:text-5xl {
        font-size: 3rem;
        line-height: 1;
    }
    
    .md\:text-7xl {
        font-size: 4.5rem;
        line-height: 1;
    }
    
    .md\:mt-0 {
        margin-top: 0;
    }
    
    .md\:justify-start {
        justify-content: flex-start;
    }
    
    .md\:col-span-1 {
        grid-column: span 1 / span 1;
    }
}

/* Responsive Spacing */
@media (min-width: 640px) {
    .sm\:px-6 {
        padding-left: 1.5rem;
        padding-right: 1.5rem;
    }
}

@media (min-width: 1024px) {
    .lg\:px-8 {
        padding-left: 2rem;
        padding-right: 2rem;
    }
}

/* Typography */
.text-xs {
    font-size: 0.75rem;
    line-height: 1rem;
}

.text-sm {
    font-size: 0.875rem;
    line-height: 1.25rem;
}

.text-lg {
    font-size: 1.125rem;
    line-height: 1.75rem;
}

.text-xl {
    font-size: 1.25rem;
    line-height: 1.75rem;
}

.text-2xl {
    font-size: 1.5rem;
    line-height: 2rem;
}

.text-4xl {
    font-size: 2.25rem;
    line-height: 2.5rem;
}

.text-5xl {
    font-size: 3rem;
    line-height: 1;
}

.font-medium {
    font-weight: 500;
}

.font-semibold {
    font-weight: 600;
}

.font-bold {
    font-weight: 700;
}

.text-center {
    text-align: center;
}

.text-white {
    color: #ffffff;
}

.leading-relaxed {
    line-height: 1.625;
}

.uppercase {
    text-transform: uppercase;
}

.select-none {
    user-select: none;
}

/* Colors - Gray */
.text-gray-300 {
    color: var(--gray-300);
}

.text-gray-400 {
    color: var(--gray-400);
}

.text-gray-600 {
    color: var(--gray-600);
}

.text-gray-800 {
    color: var(--gray-800);
}

.text-gray-900 {
    color: var(--gray-900);
}

.bg-gray-50 {
    background-color: var(--gray-50);
}

.bg-gray-100 {
    background-color: var(--gray-100);
}

.bg-gray-800 {
    background-color: var(--gray-800);
}

.bg-white {
    background-color: #ffffff;
}

/* Colors - Blue */
.bg-blue-50 {
    background-color: var(--blue-50);
}

.bg-blue-100 {
    background-color: var(--blue-100);
}

.bg-blue-200 {
    background-color: var(--blue-200);
}

.bg-blue-300 {
    background-color: var(--blue-300);
}

.bg-blue-600 {
    background-color: var(--blue-600);
}

.bg-blue-700 {
    background-color: var(--blue-700);
}

.text-blue-700 {
    color: var(--blue-700);
}

/* Colors - Green */
.bg-green-50 {
    background-color: var(--green-50);
}

.bg-green-100 {
    background-color: var(--green-100);
}

.bg-green-200 {
    background-color: var(--green-200);
}

.bg-green-300 {
    background-color: var(--green-300);
}

.bg-green-600 {
    background-color: var(--green-600);
}

.bg-green-700 {
    background-color: var(--green-700);
}

.text-green-700 {
    color: var(--green-700);
}

/* Colors - Orange */
.bg-orange-50 {
    background-color: var(--orange-50);
}

.bg-orange-100 {
    background-color: var(--orange-100);
}

.bg-orange-200 {
    background-color: var(--orange-200);
}

.bg-orange-300 {
    background-color: var(--orange-300);
}

.bg-orange-600 {
    background-color: var(--orange-600);
}

.bg-orange-700 {
    background-color: var(--orange-700);
}

.text-orange-700 {
    color: var(--orange-700);
}

/* Colors - Purple */
.bg-purple-50 {
    background-color: var(--purple-50);
}

.bg-purple-100 {
    background-color: var(--purple-100);
}

.bg-purple-200 {
    background-color: var(--purple-200);
}

.bg-purple-300 {
    background-color: var(--purple-300);
}

.bg-purple-600 {
    background-color: var(--purple-600);
}

.bg-purple-700 {
    background-color: var(--purple-700);
}

.text-purple-700 {
    color: var(--purple-700);
}

/* Colors - Teal */
.bg-teal-50 {
    background-color: var(--teal-50);
}

.bg-teal-100 {
    background-color: var(--teal-100);
}

.bg-teal-200 {
    background-color: var(--teal-200);
}

.bg-teal-300 {
    background-color: var(--teal-300);
}

.bg-teal-600 {
    background-color: var(--teal-600);
}

.bg-teal-700 {
    background-color: var(--teal-700);
}

.text-teal-700 {
    color: var(--teal-700);
}

/* Colors - Indigo */
.bg-indigo-50 {
    background-color: var(--indigo-50);
}

.bg-indigo-100 {
    background-color: var(--indigo-100);
}

.bg-indigo-200 {
    background-color: var(--indigo-200);
}

.bg-indigo-300 {
    background-color: var(--indigo-300);
}

.bg-indigo-600 {
    background-color: var(--indigo-600);
}

.bg-indigo-700 {
    background-color: var(--indigo-700);
}

.text-indigo-700 {
    color: var(--indigo-700);
}

/* Colors - Sky */
.bg-sky-50 {
    background-color: var(--sky-50);
}

.bg-sky-100 {
    background-color: var(--sky-100);
}

.bg-sky-200 {
    background-color: var(--sky-200);
}

.bg-sky-300 {
    background-color: var(--sky-300);
}

.bg-sky-600 {
    background-color: var(--sky-600);
}

.bg-sky-700 {
    background-color: var(--sky-700);
}

.text-sky-700 {
    color: var(--sky-700);
}

/* Colors - Rose */
.bg-rose-50 {
    background-color: var(--rose-50);
}

.bg-rose-100 {
    background-color: var(--rose-100);
}

.bg-rose-200 {
    background-color: var(--rose-200);
}

.bg-rose-300 {
    background-color: var(--rose-300);
}

.bg-rose-600 {
    background-color: var(--rose-600);
}

.bg-rose-700 {
    background-color: var(--rose-700);
}

.text-rose-700 {
    color: var(--rose-700);
}

/* Borders */
.rounded-full {
    border-radius: 9999px;
}

.rounded-lg {
    border-radius: 0.5rem;
}

.rounded-2xl {
    border-radius: 1rem;
}

.border {
    border-width: 1px;
}

.border-2 {
    border-width: 2px;
}

.border-blue-100 {
    border-color: var(--blue-100);
}

.border-blue-200 {
    border-color: var(--blue-200);
}

.border-green-100 {
    border-color: var(--green-100);
}

.border-green-200 {
    border-color: var(--green-200);
}

.border-orange-100 {
    border-color: var(--orange-100);
}

.border-orange-200 {
    border-color: var(--orange-200);
}

.border-purple-100 {
    border-color: var(--purple-100);
}

.border-purple-200 {
    border-color: var(--purple-200);
}

.border-teal-100 {
    border-color: var(--teal-100);
}

.border-teal-200 {
    border-color: var(--teal-200);
}

.border-indigo-100 {
    border-color: var(--indigo-100);
}

.border-indigo-200 {
    border-color: var(--indigo-200);
}

.border-sky-100 {
    border-color: var(--sky-100);
}

.border-sky-200 {
    border-color: var(--sky-200);
}

.border-rose-100 {
    border-color: var(--rose-100);
}

.border-rose-200 {
    border-color: var(--rose-200);
}

.border-gray-700 {
    border-color: var(--gray-700);
}

/* Border with opacity - using attribute selectors for classes with slashes */
[class*="border-blue-100/80"] {
    border-color: rgba(219, 234, 254, 0.8);
}

[class*="border-green-100/80"] {
    border-color: rgba(220, 252, 231, 0.8);
}

[class*="border-orange-100/80"] {
    border-color: rgba(255, 237, 213, 0.8);
}

[class*="border-purple-100/80"] {
    border-color: rgba(243, 232, 255, 0.8);
}

[class*="border-teal-100/80"] {
    border-color: rgba(204, 251, 241, 0.8);
}

[class*="border-indigo-100/80"] {
    border-color: rgba(224, 231, 255, 0.8);
}

[class*="border-sky-100/80"] {
    border-color: rgba(224, 242, 254, 0.8);
}

[class*="border-rose-100/80"] {
    border-color: rgba(255, 228, 230, 0.8);
}

/* Shadows */
.shadow-sm {
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}

.shadow-lg {
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
}

.shadow-xl {
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
}

.shadow-2xl {
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
}

.drop-shadow-2xl {
    filter: drop-shadow(0 25px 50px -12px rgba(0, 0, 0, 0.25));
}

/* Overflow */
.overflow-hidden {
    overflow: hidden;
}

/* Object Fit */
.object-cover {
    object-fit: cover;
}

/* Transitions */
.transition {
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
}

/* Hover States */
.hover\:bg-blue-700:hover {
    background-color: var(--blue-700);
}

.hover\:bg-green-700:hover {
    background-color: var(--green-700);
}

.hover\:bg-orange-700:hover {
    background-color: var(--orange-700);
}

.hover\:bg-purple-700:hover {
    background-color: var(--purple-700);
}

.hover\:bg-teal-700:hover {
    background-color: var(--teal-700);
}

.hover\:bg-indigo-700:hover {
    background-color: var(--indigo-700);
}

.hover\:bg-sky-700:hover {
    background-color: var(--sky-700);
}

.hover\:bg-rose-700:hover {
    background-color: var(--rose-700);
}

.hover\:text-white:hover {
    color: #ffffff;
}

.hover\:shadow-xl:hover {
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
}

/* Custom Height - using attribute selectors for arbitrary values */
[class*="h-[40vh]"] {
    height: 40vh;
}

[class*="h-[60vh]"] {
    height: 60vh;
}

@media (min-width: 768px) {
    [class*="md:h-[60vh]"] {
        height: 60vh;
    }
}

/* Tracking (letter-spacing) - using attribute selectors for arbitrary values */
[class*="tracking-[0.25em]"] {
    letter-spacing: 0.25em;
}

/* Height utilities */
.h-1\.5 {
    height: 0.375rem;
}

.h-10 {
    height: 2.5rem;
}

.w-8 {
    width: 2rem;
}

.w-10 {
    width: 2.5rem;
}

/* Space utilities */
.space-x-3 > * + * {
    margin-left: 0.75rem;
}

.space-x-4 > * + * {
    margin-left: 1rem;
}

.space-y-2 > * + * {
    margin-top: 0.5rem;
}

/* Order utilities */
.order-1 {
    order: 1;
}

.order-2 {
    order: 2;
}

/* Col span utilities */
.col-span-5 {
    grid-column: span 5 / span 5;
}

/* Extra vertical margin for pills below on mobile, override as needed */
@media (max-width: 767px) {
    .pill-group-mobile {
        margin-bottom: 2.25rem;
    }
}

/* Lava lamp background animation */
.lava-bg {
    position: relative;
    overflow: hidden;
    background: #0f0f1e;
}

/* Base pool at the bottom */
.lava-pool {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 40%;
    background: linear-gradient(to top, 
        rgba(239, 68, 68, 0.4) 0%,
        rgba(245, 158, 66, 0.3) 25%,
        rgba(99, 102, 241, 0.3) 50%,
        rgba(16, 185, 129, 0.2) 75%,
        transparent 100%);
    filter: blur(40px);
    z-index: 0;
}

/* Floating blobs */
.lava-blob {
    position: absolute;
    border-radius: 50%;
    filter: blur(60px);
    opacity: 0.8;
    z-index: 0;
}

.blob-1 {
    width: 350px;
    height: 350px;
    background: radial-gradient(circle, #ef4444 0%, #dc2626 50%, transparent 70%);
    bottom: 10%;
    left: 15%;
    animation: floatUp1 8s ease-in-out infinite;
}

.blob-2 {
    width: 320px;
    height: 320px;
    background: radial-gradient(circle, #f59e42 0%, #d97706 50%, transparent 70%);
    bottom: 8%;
    left: 50%;
    animation: floatUp2 9s ease-in-out infinite;
}

.blob-3 {
    width: 380px;
    height: 380px;
    background: radial-gradient(circle, #6366f1 0%, #4f46e5 50%, transparent 70%);
    bottom: 12%;
    right: 20%;
    animation: floatUp3 10s ease-in-out infinite;
}

.blob-4 {
    width: 300px;
    height: 300px;
    background: radial-gradient(circle, #10b981 0%, #059669 50%, transparent 70%);
    bottom: 15%;
    left: 70%;
    animation: floatUp4 11s ease-in-out infinite;
}

.blob-5 {
    width: 340px;
    height: 340px;
    background: radial-gradient(circle, #8b5cf6 0%, #7c3aed 50%, transparent 70%);
    bottom: 9%;
    right: 10%;
    animation: floatUp5 9.5s ease-in-out infinite;
}

.blob-6 {
    width: 310px;
    height: 310px;
    background: radial-gradient(circle, #eab308 0%, #ca8a04 50%, transparent 70%);
    bottom: 11%;
    left: 35%;
    animation: floatUp6 10.5s ease-in-out infinite;
}

.blob-7 {
    width: 290px;
    height: 290px;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.6) 0%, rgba(255, 255, 255, 0.3) 50%, transparent 70%);
    bottom: 13%;
    right: 35%;
    animation: floatUp7 11.5s ease-in-out infinite;
}

/* Split blob parts that break off and go to top */
.blob-split {
    position: absolute;
    border-radius: 50%;
    filter: blur(40px);
    opacity: 0.7;
    z-index: 0;
}

.split-1 {
    width: 120px;
    height: 120px;
    background: radial-gradient(circle, #ef4444 0%, #dc2626 50%, transparent 70%);
    bottom: 10%;
    left: 20%;
    animation: splitToTop1 12s ease-in-out infinite;
}

.split-2 {
    width: 100px;
    height: 100px;
    background: radial-gradient(circle, #f59e42 0%, #d97706 50%, transparent 70%);
    bottom: 8%;
    left: 55%;
    animation: splitToTop2 14s ease-in-out infinite;
}

.split-3 {
    width: 140px;
    height: 140px;
    background: radial-gradient(circle, #6366f1 0%, #4f46e5 50%, transparent 70%);
    bottom: 12%;
    right: 25%;
    animation: splitToTop3 13s ease-in-out infinite;
}

.split-4 {
    width: 110px;
    height: 110px;
    background: radial-gradient(circle, #10b981 0%, #059669 50%, transparent 70%);
    bottom: 15%;
    left: 75%;
    animation: splitToTop4 15s ease-in-out infinite;
}

.split-5 {
    width: 130px;
    height: 130px;
    background: radial-gradient(circle, #8b5cf6 0%, #7c3aed 50%, transparent 70%);
    bottom: 9%;
    right: 15%;
    animation: splitToTop5 13.5s ease-in-out infinite;
}

.split-6 {
    width: 90px;
    height: 90px;
    background: radial-gradient(circle, #ef4444 0%, #dc2626 50%, transparent 70%);
    bottom: 10%;
    left: 10%;
    animation: splitToTop6 16s ease-in-out infinite;
}

.split-7 {
    width: 105px;
    height: 105px;
    background: radial-gradient(circle, #6366f1 0%, #4f46e5 50%, transparent 70%);
    bottom: 12%;
    right: 15%;
    animation: splitToTop7 14.5s ease-in-out infinite;
}

@keyframes floatUp1 {
    0% {
        transform: translateY(0) translateX(0) scale(1);
        opacity: 0.5;
    }
    50% {
        transform: translateY(-250px) translateX(30px) scale(1.2);
        opacity: 1.0;
    }
    100% {
        transform: translateY(0) translateX(0) scale(1);
        opacity: 0.5;
    }
}

@keyframes floatUp2 {
    0% {
        transform: translateY(0) translateX(0) scale(1);
        opacity: 0.5;
    }
    50% {
        transform: translateY(-280px) translateX(-20px) scale(1.15);
        opacity: 0.95;
    }
    100% {
        transform: translateY(0) translateX(0) scale(1);
        opacity: 0.5;
    }
}

@keyframes floatUp3 {
    0% {
        transform: translateY(0) translateX(0) scale(1);
        opacity: 0.5;
    }
    50% {
        transform: translateY(-300px) translateX(40px) scale(1.3);
        opacity: 1.0;
    }
    100% {
        transform: translateY(0) translateX(0) scale(1);
        opacity: 0.5;
    }
}

@keyframes floatUp4 {
    0% {
        transform: translateY(0) translateX(0) scale(1);
        opacity: 0.5;
    }
    50% {
        transform: translateY(-220px) translateX(-30px) scale(1.1);
        opacity: 0.95;
    }
    100% {
        transform: translateY(0) translateX(0) scale(1);
        opacity: 0.5;
    }
}

@keyframes floatUp5 {
    0% {
        transform: translateY(0) translateX(0) scale(1);
        opacity: 0.5;
    }
    50% {
        transform: translateY(-260px) translateX(25px) scale(1.25);
        opacity: 1.0;
    }
    100% {
        transform: translateY(0) translateX(0) scale(1);
        opacity: 0.5;
    }
}

@keyframes floatUp6 {
    0% {
        transform: translateY(0) translateX(0) scale(1);
        opacity: 0.5;
    }
    50% {
        transform: translateY(-270px) translateX(-35px) scale(1.18);
        opacity: 0.95;
    }
    100% {
        transform: translateY(0) translateX(0) scale(1);
        opacity: 0.5;
    }
}

@keyframes floatUp7 {
    0% {
        transform: translateY(0) translateX(0) scale(1);
        opacity: 0.4;
    }
    50% {
        transform: translateY(-240px) translateX(35px) scale(1.22);
        opacity: 0.9;
    }
    100% {
        transform: translateY(0) translateX(0) scale(1);
        opacity: 0.4;
    }
}

/* Split animations - go to top then fall back */
@keyframes splitToTop1 {
    0%, 10% {
        transform: translateY(0) translateX(0) scale(0.8);
        opacity: 0;
    }
    15% {
        opacity: 0.7;
    }
    50% {
        transform: translateY(-500px) translateX(50px) scale(1.1);
        opacity: 0.8;
    }
    85% {
        transform: translateY(-200px) translateX(30px) scale(0.9);
        opacity: 0.6;
    }
    100% {
        transform: translateY(0) translateX(0) scale(0.8);
        opacity: 0;
    }
}

@keyframes splitToTop2 {
    0%, 12% {
        transform: translateY(0) translateX(0) scale(0.8);
        opacity: 0;
    }
    18% {
        opacity: 0.7;
    }
    50% {
        transform: translateY(-550px) translateX(-40px) scale(1.2);
        opacity: 0.8;
    }
    85% {
        transform: translateY(-180px) translateX(-20px) scale(0.85);
        opacity: 0.5;
    }
    100% {
        transform: translateY(0) translateX(0) scale(0.8);
        opacity: 0;
    }
}

@keyframes splitToTop3 {
    0%, 8% {
        transform: translateY(0) translateX(0) scale(0.8);
        opacity: 0;
    }
    14% {
        opacity: 0.7;
    }
    50% {
        transform: translateY(-600px) translateX(60px) scale(1.3);
        opacity: 0.85;
    }
    85% {
        transform: translateY(-250px) translateX(40px) scale(0.95);
        opacity: 0.6;
    }
    100% {
        transform: translateY(0) translateX(0) scale(0.8);
        opacity: 0;
    }
}

@keyframes splitToTop4 {
    0%, 15% {
        transform: translateY(0) translateX(0) scale(0.8);
        opacity: 0;
    }
    20% {
        opacity: 0.7;
    }
    50% {
        transform: translateY(-520px) translateX(-50px) scale(1.15);
        opacity: 0.8;
    }
    85% {
        transform: translateY(-220px) translateX(-35px) scale(0.9);
        opacity: 0.55;
    }
    100% {
        transform: translateY(0) translateX(0) scale(0.8);
        opacity: 0;
    }
}

@keyframes splitToTop5 {
    0%, 10% {
        transform: translateY(0) translateX(0) scale(0.8);
        opacity: 0;
    }
    16% {
        opacity: 0.7;
    }
    50% {
        transform: translateY(-580px) translateX(45px) scale(1.25);
        opacity: 0.8;
    }
    85% {
        transform: translateY(-230px) translateX(25px) scale(0.88);
        opacity: 0.6;
    }
    100% {
        transform: translateY(0) translateX(0) scale(0.8);
        opacity: 0;
    }
}

@keyframes splitToTop6 {
    0%, 18% {
        transform: translateY(0) translateX(0) scale(0.8);
        opacity: 0;
    }
    22% {
        opacity: 0.7;
    }
    50% {
        transform: translateY(-480px) translateX(-30px) scale(1.05);
        opacity: 0.75;
    }
    85% {
        transform: translateY(-190px) translateX(-15px) scale(0.85);
        opacity: 0.5;
    }
    100% {
        transform: translateY(0) translateX(0) scale(0.8);
        opacity: 0;
    }
}

@keyframes splitToTop7 {
    0%, 11% {
        transform: translateY(0) translateX(0) scale(0.8);
        opacity: 0;
    }
    17% {
        opacity: 0.7;
    }
    50% {
        transform: translateY(-540px) translateX(55px) scale(1.2);
        opacity: 0.8;
    }
    85% {
        transform: translateY(-210px) translateX(35px) scale(0.92);
        opacity: 0.58;
    }
    100% {
        transform: translateY(0) translateX(0) scale(0.8);
        opacity: 0;
    }
}

.lava-h1 {
    position: relative;
    z-index: 1;
}

/* Fade-in animation (if needed) */
.fade-in {
    animation: fadeIn 0.6s ease-in;
}

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

/* =========================================================
   Vanilla (semantic) site styles for the portfolio page
   ========================================================= */

/* Page */
.page {
    background: var(--gray-100);
    padding-top: 0;
}

.container {
    max-width: 80rem;
    margin-left: auto;
    margin-right: auto;
    padding-left: 1rem;
    padding-right: 1rem;
    width: 100%;
}

@media (min-width: 640px) {
    .container {
        padding-left: 1.5rem;
        padding-right: 1.5rem;
    }
}

@media (min-width: 1024px) {
    .container {
        padding-left: 2rem;
        padding-right: 2rem;
    }
}

/* Hero */
.hero {
    width: 100%;
    height: 40vh;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}

@media (min-width: 768px) {
    .hero {
        height: 60vh;
    }
}

.hero__title {
    font-size: 3rem;
    line-height: 1;
    font-weight: 700;
    color: #ffffff;
    text-align: center;
    filter: drop-shadow(0 25px 50px -12px rgba(0, 0, 0, 0.25));
    user-select: none;
}

@media (min-width: 768px) {
    .hero__title {
        font-size: 4.5rem;
    }
}

/* Philosophy */
.philosophy {
    position: relative;
    overflow: hidden;
    padding: 6rem 0;
    background:
        radial-gradient(1200px 600px at 20% 20%, rgba(37, 99, 235, 0.12), transparent 55%),
        radial-gradient(900px 500px at 80% 30%, rgba(99, 102, 241, 0.10), transparent 60%),
        linear-gradient(180deg, #ffffff 0%, var(--accent-50) 100%);
    border-bottom: 1px solid var(--accent-100);
}

.philosophy__inner {
    max-width: 56rem;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
}

.philosophy__inner > * {
    text-align: left;
}

.philosophy__title,
.philosophy__subtitle {
    text-align: center;
}

.philosophy__meta {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.philosophy__title {
    font-size: 3rem;
    line-height: 1.2;
    font-weight: 800;
    color: var(--gray-900);
    margin-top: 0;
    margin-bottom: 2rem;
    text-align: center;
    letter-spacing: -0.02em;
}

@media (min-width: 768px) {
    .philosophy__title {
        font-size: 4.5rem;
        line-height: 1.1;
        margin-bottom: 2.5rem;
    }
}

.philosophy__lead {
    font-size: 1.125rem;
    line-height: 1.625;
    color: var(--gray-600);
    margin-bottom: 1.5rem;
}

.philosophy__subtitle {
    font-size: 1.125rem;
    line-height: 1.625;
    color: var(--gray-600);
    margin-bottom: 1.5rem;
    font-weight: 400;
    text-align: center;
}

.philosophy__points {
    list-style: none;
    padding-left: 0;
    margin: 0;
    margin-left: 0 !important;
    margin-right: 0;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    text-align: left !important;
    counter-reset: philosophy-counter;
    width: 100%;
    max-width: 100%;
    align-items: flex-start;
}

.philosophy__point {
    counter-increment: philosophy-counter;
    padding: 0.75rem 0;
    padding-left: 3rem;
    color: var(--gray-700);
    line-height: 1.625;
    position: relative;
}

.philosophy__point::before {
    content: counter(philosophy-counter) ")";
    position: absolute;
    left: 1rem;
    top: 1.5rem;
    font-weight: 800;
    font-size: 1.25rem;
    color: var(--accent-700);
}

.philosophy__point strong {
    color: var(--gray-900);
    font-weight: 800;
    font-size: 1.125rem;
    display: block;
    margin-bottom: 0.25rem;
}

/* Projects */
.project {
    /* Accent defaults (overridden by theme classes) */
    --accent-50: var(--blue-50);
    --accent-100: var(--blue-100);
    --accent-200: var(--blue-200);
    --accent-300: var(--blue-300);
    --accent-600: var(--blue-600);
    --accent-700: var(--blue-700);
    --accent-text: var(--blue-700);

    min-height: 100vh;
    display: flex;
    align-items: center;
}

.project--white {
    background: #ffffff;
}

.project--muted {
    background: var(--gray-50);
}

.project--tinted {
    background: var(--accent-50);
}

.project__grid {
    display: grid;
    gap: 3rem;
    align-items: center;
    width: 100%;
    grid-template-columns: 1fr;
    grid-template-areas:
        "media"
        "content";
}

@media (min-width: 768px) {
    .project__grid {
        grid-template-columns: 1fr 1fr;
        grid-template-areas: "content media";
    }
}

@media (min-width: 768px) {
    .project--image-left .project__grid {
        grid-template-areas: "media content";
    }
}

.project__content {
    grid-area: content;
}

.project__media {
    grid-area: media;
}

.project__meta {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

@media (max-width: 767px) {
    .project__meta {
        margin-bottom: 2.25rem;
    }
}

.tag {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 1rem;
    border-radius: 9999px;
    font-size: 0.875rem;
    font-weight: 500;
    background: var(--accent-100);
    color: var(--accent-text);
}

.pill-group {
    display: inline-flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.pill {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.75rem;
    border-radius: 9999px;
    font-size: 0.8125rem;
    font-weight: 600;
    background: rgba(255, 255, 255, 0.65);
    border: 1px solid var(--accent-200);
    color: var(--gray-800);
    backdrop-filter: blur(8px);
}

.project__title {
    font-size: 2.25rem;
    line-height: 2.5rem;
    font-weight: 700;
    color: var(--gray-900);
    margin-bottom: 1.5rem;
}

@media (min-width: 768px) {
    .project__title {
        font-size: 3rem;
        line-height: 1;
    }
}

.project__lead {
    font-size: 1.125rem;
    line-height: 1.625;
    color: var(--gray-600);
    margin-bottom: 2rem;
}

/* Feature block */
.feature-block {
    margin-bottom: 2rem;
}

.feature-block__title {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--gray-800);
    margin-bottom: 1rem;
}

.feature-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.5rem 1rem;
    border-radius: 9999px;
    background: var(--accent-50);
    color: var(--accent-text);
    text-transform: uppercase;
    letter-spacing: 0.25em;
    font-size: 0.75rem;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}

.feature-badge__bar {
    height: 0.375rem;
    width: 2rem;
    border-radius: 9999px;
    background: var(--accent-300);
}

.feature-list {
    display: grid;
    gap: 0.75rem;
}

.feature-card {
    padding: 1rem;
    border-radius: 1rem;
    background: #ffffff;
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
    border: 1px solid var(--accent-100);
}

.feature-card__title {
    font-weight: 600;
    color: var(--gray-900);
    margin-bottom: 0.25rem;
}

.feature-card__desc {
    color: var(--gray-600);
    font-size: 0.875rem;
    line-height: 1.625;
}

/* Pricing */
.pricing {
    margin-bottom: 2rem;
    padding: 1.5rem;
    background: var(--accent-50);
    border: 2px solid var(--accent-200);
    border-radius: 0.5rem;
}

.pricing__price {
    font-size: 2.25rem;
    line-height: 2.5rem;
    font-weight: 700;
    color: var(--gray-900);
}

.pricing__subtitle {
    margin-top: 0.25rem;
    font-size: 1.125rem;
    color: var(--gray-600);
}

.pricing__note {
    margin-top: 0.5rem;
    font-size: 0.875rem;
    color: var(--gray-600);
}

/* Buttons */
.btn {
    display: inline-flex;
    align-items: center;
    padding: 1rem 2rem;
    border-radius: 0.5rem;
    font-weight: 600;
    font-size: 1.125rem;
    color: #ffffff;
    text-decoration: none;
    background: var(--accent-600);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
    transition: background-color 150ms ease, box-shadow 150ms ease;
}

.btn:hover {
    background: var(--accent-700);
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
}

.btn__icon {
    margin-right: 0.5rem;
}

/* Media */
.project__image-wrap {
    border-radius: 1rem;
    overflow: hidden;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
    margin-top: 2rem;
}

@media (min-width: 768px) {
    .project__image-wrap {
        margin-top: 0;
    }
}

.project__image {
    width: 100%;
    height: auto;
    object-fit: cover;
    display: block;
}

/* Theme modifiers */
.theme-blue {
    --accent-50: var(--blue-50);
    --accent-100: var(--blue-100);
    --accent-200: var(--blue-200);
    --accent-300: var(--blue-300);
    --accent-600: var(--blue-600);
    --accent-700: var(--blue-700);
    --accent-text: var(--blue-700);
}

.theme-green {
    --accent-50: var(--green-50);
    --accent-100: var(--green-100);
    --accent-200: var(--green-200);
    --accent-300: var(--green-300);
    --accent-600: var(--green-600);
    --accent-700: var(--green-700);
    --accent-text: var(--green-700);
}

.theme-orange {
    --accent-50: var(--orange-50);
    --accent-100: var(--orange-100);
    --accent-200: var(--orange-200);
    --accent-300: var(--orange-300);
    --accent-600: var(--orange-600);
    --accent-700: var(--orange-700);
    --accent-text: var(--orange-700);
}

.theme-purple {
    --accent-50: var(--purple-50);
    --accent-100: var(--purple-100);
    --accent-200: var(--purple-200);
    --accent-300: var(--purple-300);
    --accent-600: var(--purple-600);
    --accent-700: var(--purple-700);
    --accent-text: var(--purple-700);
}

.theme-teal {
    --accent-50: var(--teal-50);
    --accent-100: var(--teal-100);
    --accent-200: var(--teal-200);
    --accent-300: var(--teal-300);
    --accent-600: var(--teal-600);
    --accent-700: var(--teal-700);
    --accent-text: var(--teal-700);
}

.theme-indigo {
    --accent-50: var(--indigo-50);
    --accent-100: var(--indigo-100);
    --accent-200: var(--indigo-200);
    --accent-300: var(--indigo-300);
    --accent-600: var(--indigo-600);
    --accent-700: var(--indigo-700);
    --accent-text: var(--indigo-700);
}

.theme-sky {
    --accent-50: var(--sky-50);
    --accent-100: var(--sky-100);
    --accent-200: var(--sky-200);
    --accent-300: var(--sky-300);
    --accent-600: var(--sky-600);
    --accent-700: var(--sky-700);
    --accent-text: var(--sky-700);
}

.theme-rose {
    --accent-50: var(--rose-50);
    --accent-100: var(--rose-100);
    --accent-200: var(--rose-200);
    --accent-300: var(--rose-300);
    --accent-600: var(--rose-600);
    --accent-700: var(--rose-700);
    --accent-text: var(--rose-700);
}

/* Privacy Policy Content */
.privacy-content {
    text-align: left;
    width: 100%;
    max-width: 100%;
}

.privacy-content .project__title {
    margin-top: 2rem;
    margin-bottom: 1rem;
}

.privacy-content .project__title:first-of-type {
    margin-top: 0;
}

.privacy-list {
    color: var(--gray-700);
    line-height: 1.625;
    margin-left: 1.5rem;
    margin-bottom: 1.5rem;
    padding-left: 0;
}

.privacy-list li {
    margin-bottom: 0.5rem;
}

/* Filter Section */
.filter-section {
    background: var(--gray-50);
    padding: 3rem 0;
    border-bottom: 1px solid var(--gray-200);
}

.filter-section__inner {
    text-align: center;
    max-width: 56rem;
    margin-left: auto;
    margin-right: auto;
}

.filter-section__title {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--gray-900);
    margin-bottom: 1.5rem;
}

.filter-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    justify-content: center;
    align-items: center;
}

.filter-btn {
    padding: 0.75rem 1.5rem;
    border-radius: 9999px;
    font-size: 1rem;
    font-weight: 600;
    border: 2px solid var(--gray-300);
    background: #ffffff;
    color: var(--gray-700);
    cursor: pointer;
    transition: all 150ms ease;
}

.filter-btn:hover {
    border-color: var(--blue-600);
    color: var(--blue-600);
    background: var(--blue-50);
}

.filter-btn--active {
    background: var(--blue-600);
    color: #ffffff;
    border-color: var(--blue-600);
}

.filter-btn--active:hover {
    background: var(--blue-700);
    border-color: var(--blue-700);
    color: #ffffff;
}

/* Footer */
.site-footer {
    background: var(--gray-800);
    color: #ffffff;
    width: 100%;
}

.site-footer__inner {
    padding-top: 3rem;
    padding-bottom: 3rem;
}

.site-footer__grid {
    display: grid;
    gap: 2rem;
    grid-template-columns: 1fr;
}

@media (min-width: 768px) {
    .site-footer__grid {
        grid-template-columns: repeat(5, minmax(0, 1fr));
        gap: 2rem;
        align-items: start;
    }
}

.site-footer__col {
    text-align: center;
}

@media (min-width: 768px) {
    .site-footer__col {
        text-align: left;
    }
}

.site-footer__brand-title {
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 1rem;
}

.site-footer__brand-subtitle {
    color: var(--gray-300);
    margin-bottom: 1rem;
}

.site-footer__social {
    display: flex;
    gap: 1rem;
    justify-content: center;
    margin-top: 1.5rem;
}

@media (min-width: 768px) {
    .site-footer__social {
        justify-content: flex-start;
    }
}

.site-footer__social-link {
    color: var(--gray-400);
    text-decoration: none;
    transition: color 150ms ease;
    font-size: 1.25rem;
}

.site-footer__social-link:hover {
    color: #ffffff;
}

.site-footer__title {
    font-size: 1.125rem;
    font-weight: 600;
    color: #ffffff;
    margin-bottom: 1rem;
}

.site-footer__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 0.5rem;
}

.site-footer__link {
    color: var(--gray-400);
    text-decoration: none;
    transition: color 150ms ease;
}

.site-footer__link:hover {
    color: #ffffff;
}

.site-footer__accent {
    color: var(--primary-color, #60a5fa);
}

.site-footer__legal {
    margin-top: 3rem;
    padding-top: 2rem;
    border-top: 1px solid var(--gray-700);
    text-align: center;
    color: var(--gray-400);
}

.site-footer__legal-links {
    margin-top: 1rem;
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
}
