/* ============================================
   SUPERLAC EPOXY — STYLES
   Design System Aligned
   ============================================ */

/* Hero Background */
.epoxy-hero-bg {
    position: relative;
    overflow: hidden;
}

/* Panel - Solid white background */
.epoxy-panel {
    background: #ffffff;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(111,143,122,0.12);
    border-radius: 20px;
    transition: transform 0.5s cubic-bezier(0.165, 0.84, 0.44, 1), box-shadow 0.5s ease;
}

.epoxy-panel:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-medium);
}

/* Showcase Image */
.epoxy-showcase-img {
    border-radius: 20px 20px 0 0;
    overflow: hidden;
}

.epoxy-showcase-img img {
    transition: transform 0.8s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.epoxy-showcase-img:hover img {
    transform: scale(1.06);
}

/* Ambient Glow Animations */
.epoxy-glow-1 {
    animation: epoxy-ambient-1 14s ease-in-out infinite;
}

.epoxy-glow-2 {
    animation: epoxy-ambient-2 18s ease-in-out infinite reverse;
}

.epoxy-glow-3 {
    animation: epoxy-ambient-1 16s ease-in-out infinite 3s;
}

@keyframes epoxy-ambient-1 {
    0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.5; }
    33% { transform: translate(30px, -20px) scale(1.1); opacity: 0.7; }
    66% { transform: translate(-20px, 10px) scale(0.95); opacity: 0.4; }
}

@keyframes epoxy-ambient-2 {
    0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.4; }
    50% { transform: translate(-30px, 20px) scale(1.15); opacity: 0.6; }
}

/* Application Icon */
.epoxy-app-icon {
    transition: all 0.3s ease;
}

.epoxy-app-icon:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(111,143,122,0.15);
}

/* Typography - Using design tokens */
.epoxy-hero-title {
    font-family: 'Outfit', sans-serif;
    color: #ffffff;
    line-height: 1.05;
    font-weight: 800;
    font-size: 4.5rem;
}

/* Card Body */
.epoxy-card-body {
    background: #ffffff;
    border-radius: 20px;
    padding: 40px 48px;
    box-shadow: var(--shadow-medium);
    transition: transform 0.4s ease, box-shadow 0.4s ease;
}

.epoxy-card-body:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-premium);
}

@media (max-width: 768px) {
    .epoxy-glow-1, .epoxy-glow-2, .epoxy-glow-3 { animation: none; }
    .epoxy-hero-title { font-size: 2.4rem; }
    .epoxy-card-body { padding: 24px; }
}

/* ============================================
   EPOXY SOLUTIONS SECTION - INDEX.HOME
   ============================================ */

#epoxy-solutions {
    position: relative;
    background: linear-gradient(135deg, #f8faf8 0%, #ffffff 30%, #e8f0e8 60%, #d4e5d4 100%);
    overflow: hidden;
    padding: 100px 0;
}

#epoxy-solutions::before {
    content: '';
    position: absolute;
    inset: 0;
    background: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
    opacity: 0.04;
    pointer-events: none;
}

.epoxy-atmosphere {
    position: absolute;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
}

.ambient-glow {
    position: absolute;
    border-radius: 50%;
    filter: blur(100px);
    opacity: 0.5;
}

.ambient-glow.glow-1 {
    width: 700px;
    height: 700px;
    background: radial-gradient(circle, rgba(111,143,122,0.25) 0%, transparent 70%);
    top: -250px;
    right: 5%;
    animation: epoxy-orb-1 20s ease-in-out infinite;
}

.ambient-glow.glow-2 {
    width: 500px;
    height: 500px;
    background: radial-gradient(circle, rgba(144,183,152,0.2) 0%, transparent 70%);
    bottom: -150px;
    left: -50px;
    animation: epoxy-orb-2 25s ease-in-out infinite reverse;
}

.ambient-glow.glow-3 {
    width: 400px;
    height: 400px;
    background: radial-gradient(circle, rgba(167,199,175,0.25) 0%, transparent 70%);
    top: 30%;
    left: 25%;
    animation: epoxy-orb-3 18s ease-in-out infinite;
}

.ambient-glow.glow-4 {
    width: 350px;
    height: 350px;
    background: radial-gradient(circle, rgba(111,143,122,0.2) 0%, transparent 70%);
    bottom: 10%;
    right: 20%;
    animation: epoxy-orb-4 22s ease-in-out infinite reverse;
}

@keyframes epoxy-orb-1 {
    0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.5; }
    33% { transform: translate(-60px, 50px) scale(1.15); opacity: 0.7; }
    66% { transform: translate(40px, -30px) scale(0.9); opacity: 0.4; }
}

@keyframes epoxy-orb-2 {
    0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.4; }
    50% { transform: translate(80px, -50px) scale(1.1); opacity: 0.6; }
}

@keyframes epoxy-orb-3 {
    0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.45; }
    25% { transform: translate(50px, 40px) scale(1.1); opacity: 0.65; }
    75% { transform: translate(-40px, -30px) scale(0.95); opacity: 0.35; }
}

@keyframes epoxy-orb-4 {
    0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.35; }
    50% { transform: translate(-50px, 50px) scale(1.15); opacity: 0.55; }
}

#epoxy-solutions .epoxy-container {
    position: relative;
    z-index: 10;
    display: grid;
    grid-template-columns: 1fr 1.4fr;
    gap: 80px;
    align-items: center;
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 48px;
}

@media (max-width: 1024px) {
    #epoxy-solutions .epoxy-container {
        grid-template-columns: 1fr;
        gap: 60px;
    }
}

#epoxy-solutions .epoxy-content {
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.8s cubic-bezier(0.165, 0.84, 0.44, 1);
}

#epoxy-solutions .epoxy-content.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* Badge - Using design tokens */
#epoxy-solutions .epoxy-badge {
    display: inline-block;
    padding: 8px 20px;
    background: linear-gradient(135deg, rgba(111,143,122,0.15) 0%, rgba(111,143,122,0.08) 100%);
    border: 1px solid rgba(111,143,122,0.25);
    border-radius: 100px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.15em;
    color: var(--primary);
    text-transform: uppercase;
    margin-bottom: 24px;
}

/* Title - Using design tokens */
#epoxy-solutions .epoxy-title {
    font-size: 3.5rem;
    font-weight: 800;
    line-height: 1.1;
    color: var(--text);
    margin-bottom: 24px;
    letter-spacing: -0.02em;
}

@media (max-width: 768px) {
    #epoxy-solutions .epoxy-title {
        font-size: 2.4rem;
    }
}

#epoxy-solutions .epoxy-title span {
    font-weight: 300;
    font-style: italic;
    color: var(--primary);
}

/* Description - Using design tokens */
#epoxy-solutions .epoxy-description {
    font-size: 1.1rem;
    line-height: 1.7;
    color: var(--text-soft);
    margin-bottom: 32px;
    max-width: 480px;
}

/* Primary Button */
#epoxy-solutions .btn-primary {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 16px 32px;
    background: linear-gradient(135deg, var(--primary) 0%, #5a7a63 100%);
    color: #fff;
    font-weight: 600;
    font-size: 15px;
    border-radius: 100px;
    text-decoration: none;
    transition: all 0.4s ease;
    box-shadow: 0 4px 20px rgba(111,143,122,0.3);
}

#epoxy-solutions .btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 30px rgba(111,143,122,0.4);
}

/* Carousel */
#epoxy-solutions .epoxy-slider-viewport {
    position: relative;
    overflow: hidden;
    cursor: grab;
    padding: 20px 0;
}

#epoxy-solutions .epoxy-slider-viewport:active {
    cursor: grabbing;
}

#epoxy-solutions .epoxy-slider-track {
    display: flex;
    gap: 30px;
    will-change: transform;
}

/* Carousel Card - Solid white */
#epoxy-solutions .epoxy-card {
    flex-shrink: 0;
    width: 340px;
    height: 440px;
    position: relative;
    background: #ffffff;
    border-radius: 24px;
    overflow: hidden;
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(111,143,122,0.15);
    box-shadow: var(--shadow-medium);
    transition: all 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
}

#epoxy-solutions .epoxy-card:hover {
    transform: scale(1.03) translateY(-8px);
    border-color: rgba(111,143,122,0.35);
    box-shadow: 0 30px 60px rgba(0,0,0,0.1), 0 0 40px rgba(111,143,122,0.15);
}

#epoxy-solutions .epoxy-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(255,255,255,0.15) 0%, transparent 50%, transparent 100%);
    opacity: 0;
    transition: opacity 0.5s ease;
    z-index: 2;
    pointer-events: none;
}

#epoxy-solutions .epoxy-card:hover::before {
    opacity: 1;
}

#epoxy-solutions .epoxy-card-inner {
    position: relative;
    width: 100%;
    height: 65%;
    overflow: hidden;
}

#epoxy-solutions .epoxy-card-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.8s ease;
}

#epoxy-solutions .epoxy-card:hover .epoxy-card-image {
    transform: scale(1.08);
}

#epoxy-solutions .epoxy-card-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.5) 0%, transparent 60%);
    z-index: 1;
}

#epoxy-solutions .epoxy-card-gloss {
    position: absolute;
    top: 0;
    left: -100%;
    width: 50%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.15), transparent);
    transform: skewX(-20deg);
    transition: left 0.6s ease;
    z-index: 3;
    pointer-events: none;
}

#epoxy-solutions .epoxy-card:hover .epoxy-card-gloss {
    left: 200%;
    transition: left 0.8s ease;
}

#epoxy-solutions .epoxy-card-content {
    padding: 24px;
    position: relative;
    z-index: 5;
}

/* Card Category - Using design tokens */
#epoxy-solutions .epoxy-card-cat {
    display: inline-block;
    padding: 4px 12px;
    background: rgba(111,143,122,0.15);
    border-radius: 100px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.12em;
    color: var(--primary);
    text-transform: uppercase;
    margin-bottom: 12px;
}

/* Card Title - Using design tokens */
#epoxy-solutions .epoxy-card-title {
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 8px;
    line-height: 1.3;
}

/* Card Description - Using design tokens */
#epoxy-solutions .epoxy-card-desc {
    font-size: 0.85rem;
    color: var(--text-soft);
    line-height: 1.5;
}

/* Gradient shine border on hover */
#epoxy-solutions .epoxy-card::after {
    content: '';
    position: absolute;
    inset: -1px;
    border-radius: 25px;
    background: linear-gradient(135deg, transparent 40%, rgba(111,143,122,0.4) 50%, transparent 60%);
    opacity: 0;
    transition: opacity 0.4s ease;
    z-index: -1;
}

#epoxy-solutions .epoxy-card:hover::after {
    opacity: 1;
}

/* Mobile adjustments */
@media (max-width: 1024px) {
    #epoxy-solutions {
        padding: 80px 0;
    }
    
    #epoxy-solutions .epoxy-slider-track {
        gap: 20px;
    }
    
    #epoxy-solutions .epoxy-card {
        width: 280px;
        height: 380px;
    }
}

@media (max-width: 640px) {
    #epoxy-solutions .epoxy-card {
        width: 260px;
        height: 360px;
    }
}

/* ============================================
   EPOXY PAGE — STANDALONE STYLES
   ============================================ */

/* Epoxy Hero - Standalone Page */
.epoxy-page-hero {
    position: relative;
    background: linear-gradient(135deg, #f8faf8 0%, #ffffff 30%, #e8f0e8 60%, #d4e5d4 100%);
    overflow: hidden;
    min-height: 85vh;
    display: flex;
    align-items: center;
}

.epoxy-page-hero::before {
    content: '';
    position: absolute;
    width: 800px;
    height: 800px;
    top: -300px;
    right: -200px;
    background: radial-gradient(circle, rgba(111,143,122,0.15) 0%, transparent 70%);
    border-radius: 50%;
    animation: epoxy-hero-orb-1 20s ease-in-out infinite;
}

.epoxy-page-hero::after {
    content: '';
    position: absolute;
    width: 600px;
    height: 600px;
    bottom: -200px;
    left: -150px;
    background: radial-gradient(circle, rgba(200,169,138,0.1) 0%, transparent 70%);
    border-radius: 50%;
    animation: epoxy-hero-orb-2 25s ease-in-out infinite reverse;
}

@keyframes epoxy-hero-orb-1 {
    0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.6; }
    33% { transform: translate(-70px, 60px) scale(1.15); opacity: 0.8; }
    66% { transform: translate(50px, -40px) scale(0.9); opacity: 0.4; }
}

@keyframes epoxy-hero-orb-2 {
    0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.5; }
    50% { transform: translate(90px, -60px) scale(1.1); opacity: 0.7; }
}

/* Epoxy Showcase Grid */
.epoxy-showcase-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 32px;
}

/* Showcase Card - Solid white */
.epoxy-showcase-card {
    background: #ffffff;
    backdrop-filter: blur(16px);
    border: 1px solid rgba(111,143,122,0.12);
    border-radius: 28px;
    overflow: hidden;
    transition: all 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
    position: relative;
}

.epoxy-showcase-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(111,143,122,0.05) 0%, transparent 60%);
    opacity: 0;
    transition: opacity 0.4s ease;
}

.epoxy-showcase-card:hover {
    transform: translateY(-10px) scale(1.02);
    box-shadow: 0 40px 80px rgba(111,143,122,0.15), 0 0 40px rgba(111,143,122,0.1);
    border-color: rgba(111,143,122,0.25);
}

.epoxy-showcase-card:hover::before {
    opacity: 1;
}

.epoxy-showcase-image {
    position: relative;
    aspect-ratio: 16/10;
    overflow: hidden;
}

.epoxy-showcase-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.8s ease;
}

.epoxy-showcase-card:hover .epoxy-showcase-image img {
    transform: scale(1.08);
}

.epoxy-showcase-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.5) 0%, transparent 50%);
}

.epoxy-showcase-content {
    padding: 28px 32px;
}

/* Showcase Badge - Darker background */
.epoxy-showcase-badge {
    display: inline-block;
    padding: 6px 14px;
    background: rgba(111,143,122,0.18);
    border-radius: 100px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.12em;
    color: var(--primary);
    text-transform: uppercase;
    margin-bottom: 12px;
}

/* Showcase Title - Using design tokens */
.epoxy-showcase-title {
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 10px;
}

/* Showcase Description - Using design tokens */
.epoxy-showcase-desc {
    font-size: 0.9rem;
    color: var(--text-soft);
    line-height: 1.6;
}

/* Epoxy Why Cards */
.epoxy-why-card {
    background: #ffffff;
    backdrop-filter: blur(16px);
    border: 1px solid rgba(111,143,122,0.1);
    border-radius: 24px;
    padding: 40px 32px;
    text-align: center;
    transition: all 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
    position: relative;
    overflow: hidden;
}

.epoxy-why-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 60px;
    height: 60px;
    background: radial-gradient(circle, rgba(111,143,122,0.15) 0%, transparent 70%);
    border-radius: 50%;
    opacity: 0;
    transition: opacity 0.4s ease;
}

.epoxy-why-card:hover {
    transform: translateY(-8px) scale(1.02);
    box-shadow: 0 30px 60px rgba(111,143,122,0.12);
    border-color: rgba(111,143,122,0.2);
}

.epoxy-why-card:hover::before {
    opacity: 1;
    animation: epoxy-why-pulse 2s ease-in-out infinite;
}

@keyframes epoxy-why-pulse {
    0%, 100% { transform: translateX(-50%) scale(1); opacity: 0.5; }
    50% { transform: translateX(-50%) scale(1.2); opacity: 0.8; }
}

.epoxy-why-icon {
    width: 72px;
    height: 72px;
    border-radius: 20px;
    background: linear-gradient(135deg, rgba(111,143,122,0.15) 0%, rgba(111,143,122,0.05) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 24px;
    transition: all 0.4s ease;
}

.epoxy-why-card:hover .epoxy-why-icon {
    transform: scale(1.1) rotate(5deg);
    background: linear-gradient(135deg, rgba(111,143,122,0.25) 0%, rgba(111,143,122,0.1) 100%);
}

/* Why Title - Using design tokens */
.epoxy-why-title {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 12px;
}

/* Why Description - Using design tokens */
.epoxy-why-desc {
    font-size: 0.9rem;
    color: var(--text-soft);
    line-height: 1.6;
}

/* Epoxy Applications Grid */
.epoxy-apps-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}

/* Application Item - Solid white */
.epoxy-app-item {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 24px 28px;
    background: #ffffff;
    backdrop-filter: blur(12px);
    border: 1px solid rgba(111,143,122,0.1);
    border-radius: 16px;
    transition: all 0.4s ease;
}

.epoxy-app-item:hover {
    transform: translateX(8px);
    background: #ffffff;
    border-color: rgba(111,143,122,0.2);
    box-shadow: 0 10px 30px rgba(111,143,122,0.1);
}

.epoxy-app-icon {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    background: linear-gradient(135deg, rgba(111,143,122,0.12) 0%, rgba(111,143,122,0.05) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: all 0.4s ease;
}

.epoxy-app-item:hover .epoxy-app-icon {
    background: linear-gradient(135deg, rgba(111,143,122,0.2) 0%, rgba(111,143,122,0.08) 100%);
    transform: scale(1.1);
}

/* Application Label - Using design tokens */
.epoxy-app-label {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--text);
}

/* Epoxy Page CTA */
.epoxy-page-cta {
    background: linear-gradient(135deg, rgba(111,143,122,0.1) 0%, rgba(111,143,122,0.03) 100%);
    border-radius: 32px;
    padding: 80px;
    position: relative;
    overflow: hidden;
}

.epoxy-page-cta::before {
    content: '';
    position: absolute;
    width: 500px;
    height: 500px;
    top: -200px;
    right: -150px;
    background: radial-gradient(circle, rgba(111,143,122,0.15) 0%, transparent 70%);
    border-radius: 50%;
    animation: epoxy-cta-orb 12s ease-in-out infinite;
}

.epoxy-page-cta::after {
    content: '';
    position: absolute;
    width: 400px;
    height: 400px;
    bottom: -150px;
    left: -100px;
    background: radial-gradient(circle, rgba(200,169,138,0.1) 0%, transparent 70%);
    border-radius: 50%;
    animation: epoxy-cta-orb-2 15s ease-in-out infinite reverse;
}

@keyframes epoxy-cta-orb {
    0%, 100% { transform: translate(0, 0) scale(1); }
    50% { transform: translate(-40px, 30px) scale(1.1); }
}

@keyframes epoxy-cta-orb-2 {
    0%, 100% { transform: translate(0, 0) scale(1); }
    50% { transform: translate(50px, -30px) scale(1.1); }
}

/* Responsive */
@media (max-width: 1024px) {
    .epoxy-showcase-grid { grid-template-columns: 1fr; }
    .epoxy-apps-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
    .epoxy-page-hero::before, .epoxy-page-hero::after { animation: none; }
    .epoxy-showcase-grid { gap: 20px; }
    .epoxy-apps-grid { grid-template-columns: 1fr; }
    .epoxy-page-cta { padding: 40px 24px; }
}