/* 3D Effects for Heylink Pro */

/* 3D Card Effect */
.card-3d {
    transform-style: preserve-3d;
    perspective: 1000px;
    transition: transform 0.5s ease;
}

.card-3d:hover {
    transform: rotateY(10deg) rotateX(5deg);
}

.card-3d .card-content {
    transform: translateZ(30px);
}

/* 3D Button */
.btn-3d {
    position: relative;
    transform-style: preserve-3d;
    transition: transform 0.3s ease;
}

.btn-3d::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.2);
    border-radius: inherit;
    transform: translateZ(-5px);
    transition: transform 0.3s ease;
}

.btn-3d:hover {
    transform: translateY(-2px);
}

.btn-3d:hover::before {
    transform: translateZ(-8px);
}

.btn-3d:active {
    transform: translateY(0);
}

.btn-3d:active::before {
    transform: translateZ(-3px);
}

/* 3D Input */
.input-3d {
    transform-style: preserve-3d;
    perspective: 500px;
}

.input-3d input {
    transform: translateZ(10px);
    transition: transform 0.3s ease;
}

.input-3d input:focus {
    transform: translateZ(20px);
}

/* 3D Avatar */
.avatar-3d {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    transform-style: preserve-3d;
    animation: float3d 6s ease-in-out infinite;
    box-shadow: 
        0 0 20px rgba(var(--primary-rgb), 0.3),
        inset 0 0 30px rgba(255,255,255,0.1);
}

@keyframes float3d {
    0%, 100% {
        transform: translateY(0) rotateY(0);
    }
    25% {
        transform: translateY(-10px) rotateY(90deg);
    }
    50% {
        transform: translateY(0) rotateY(180deg);
    }
    75% {
        transform: translateY(-10px) rotateY(270deg);
    }
}

/* 3D Stats Card */
.stat-card-3d {
    transform-style: preserve-3d;
    perspective: 1000px;
}

.stat-card-3d .stat-icon {
    transform: translateZ(20px);
}

.stat-card-3d .stat-info {
    transform: translateZ(10px);
}

.stat-card-3d:hover {
    transform: rotateY(5deg) rotateX(5deg);
}

/* 3D Navigation */
.nav-3d {
    transform-style: preserve-3d;
}

.nav-item-3d {
    transform-style: preserve-3d;
    transition: transform 0.3s ease;
}

.nav-item-3d::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: var(--primary-color);
    transform: translateZ(-5px);
    border-radius: 10px;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.nav-item-3d:hover {
    transform: translateZ(10px);
}

.nav-item-3d:hover::before {
    opacity: 0.1;
}

.nav-item-3d.active {
    transform: translateZ(15px);
}

.nav-item-3d.active::before {
    opacity: 0.2;
}

/* 3D Background */
.bg-3d {
    position: relative;
    overflow: hidden;
}

.bg-3d::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: linear-gradient(
        45deg,
        transparent 30%,
        rgba(59, 130, 246, 0.1) 50%,
        transparent 70%
    );
    animation: bgFloat 20s linear infinite;
    transform: rotate(45deg);
}

@keyframes bgFloat {
    0% {
        transform: translateX(-100%) translateY(-100%) rotate(45deg);
    }
    100% {
        transform: translateX(100%) translateY(100%) rotate(45deg);
    }
}

/* 3D Cube */
.cube-container {
    width: 200px;
    height: 200px;
    margin: 0 auto;
    perspective: 1000px;
}

.cube {
    width: 100%;
    height: 100%;
    position: relative;
    transform-style: preserve-3d;
    animation: rotateCube 10s infinite linear;
}

@keyframes rotateCube {
    0% { transform: rotateX(0) rotateY(0); }
    100% { transform: rotateX(360deg) rotateY(360deg); }
}

.cube-face {
    position: absolute;
    width: 200px;
    height: 200px;
    background: linear-gradient(45deg, var(--primary-color), var(--secondary-color));
    border: 2px solid rgba(255,255,255,0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    color: white;
    opacity: 0.8;
}

.cube-face.front { transform: translateZ(100px); }
.cube-face.back { transform: rotateY(180deg) translateZ(100px); }
.cube-face.right { transform: rotateY(90deg) translateZ(100px); }
.cube-face.left { transform: rotateY(-90deg) translateZ(100px); }
.cube-face.top { transform: rotateX(90deg) translateZ(100px); }
.cube-face.bottom { transform: rotateX(-90deg) translateZ(100px); }

/* 3D Text Effect */
.text-3d {
    color: var(--primary-color);
    text-shadow: 
        1px 1px 0 rgba(0,0,0,0.2),
        2px 2px 0 rgba(0,0,0,0.2),
        3px 3px 0 rgba(0,0,0,0.2),
        4px 4px 0 rgba(0,0,0,0.2);
    transform: translateZ(20px);
}

/* 3D Progress Circle */
.progress-circle-3d {
    position: relative;
    width: 120px;
    height: 120px;
    transform-style: preserve-3d;
}

.progress-circle-3d svg {
    width: 100%;
    height: 100%;
    transform: rotate(-90deg);
}

.progress-circle-3d circle {
    fill: none;
    stroke-width: 10;
    stroke-linecap: round;
    transform: translateZ(10px);
    animation: progressFill 2s ease-out;
}

@keyframes progressFill {
    from { stroke-dasharray: 0 100; }
}

/* 3D Floating Elements */
.float-3d {
    animation: float3dElement 6s ease-in-out infinite;
    transform-style: preserve-3d;
}

@keyframes float3dElement {
    0%, 100% {
        transform: translateY(0) rotateX(0) rotateY(0);
    }
    33% {
        transform: translateY(-20px) rotateX(10deg) rotateY(10deg);
    }
    66% {
        transform: translateY(-10px) rotateX(-10deg) rotateY(-10deg);
    }
}

/* 3D Panel */
.panel-3d {
    transform-style: preserve-3d;
    perspective: 1000px;
}

.panel-3d .panel-header {
    transform: translateZ(30px);
    background: linear-gradient(135deg, 
        var(--primary-color) 0%, 
        var(--secondary-color) 100%);
    color: white;
}

.panel-3d .panel-body {
    transform: translateZ(20px);
}

/* 3D Icon */
.icon-3d {
    display: inline-block;
    transform-style: preserve-3d;
    animation: iconFloat 4s ease-in-out infinite;
}

@keyframes iconFloat {
    0%, 100% {
        transform: translateY(0) rotateY(0);
    }
    50% {
        transform: translateY(-10px) rotateY(180deg);
    }
}

/* 3D Link */
.link-3d {
    position: relative;
    display: inline-block;
    transform-style: preserve-3d;
    transition: transform 0.3s ease;
}

.link-3d::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 100%;
    height: 2px;
    background: var(--primary-color);
    transform: scaleX(0) translateZ(10px);
    transition: transform 0.3s ease;
}

.link-3d:hover {
    transform: translateZ(5px);
}

.link-3d:hover::after {
    transform: scaleX(1) translateZ(10px);
}

/* 3D Badge */
.badge-3d {
    transform-style: preserve-3d;
    perspective: 500px;
}

.badge-3d::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: inherit;
    border-radius: inherit;
    transform: translateZ(-3px);
    opacity: 0.7;
}

/* 3D Table */
.table-3d {
    transform-style: preserve-3d;
}

.table-3d thead {
    transform: translateZ(20px);
}

.table-3d tbody tr {
    transition: transform 0.3s ease;
    transform-style: preserve-3d;
}

.table-3d tbody tr:hover {
    transform: translateZ(10px);
}

/* 3D Modal */
.modal-3d {
    transform-style: preserve-3d;
    perspective: 1000px;
}

.modal-3d .modal-content {
    transform: translateZ(50px);
    animation: modalPopIn 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

@keyframes modalPopIn {
    from {
        opacity: 0;
        transform: translateZ(-100px) rotateX(90deg);
    }
    to {
        opacity: 1;
        transform: translateZ(50px) rotateX(0);
    }
}

/* 3D Loader */
.loader-3d {
    width: 60px;
    height: 60px;
    transform-style: preserve-3d;
    animation: loaderRotate 2s infinite linear;
}

.loader-3d div {
    position: absolute;
    width: 100%;
    height: 100%;
    background: rgba(59, 130, 246, 0.1);
    border: 2px solid var(--primary-color);
}

.loader-3d div:nth-child(1) { transform: rotateY(0deg) translateZ(30px); }
.loader-3d div:nth-child(2) { transform: rotateY(90deg) translateZ(30px); }
.loader-3d div:nth-child(3) { transform: rotateY(180deg) translateZ(30px); }
.loader-3d div:nth-child(4) { transform: rotateY(270deg) translateZ(30px); }
.loader-3d div:nth-child(5) { transform: rotateX(90deg) translateZ(30px); }
.loader-3d div:nth-child(6) { transform: rotateX(270deg) translateZ(30px); }

@keyframes loaderRotate {
    0% { transform: rotateX(0) rotateY(0); }
    100% { transform: rotateX(360deg) rotateY(360deg); }
}

/* 3D Grid */
.grid-3d {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 20px;
    perspective: 1000px;
}

.grid-item-3d {
    transform-style: preserve-3d;
    transition: transform 0.5s ease;
}

.grid-item-3d:hover {
    transform: rotateY(10deg) scale(1.05);
}

/* 3D Form Group */
.form-group-3d {
    transform-style: preserve-3d;
}

.form-group-3d label {
    transform: translateZ(15px);
    display: block;
    margin-bottom: 8px;
}

.form-group-3d input,
.form-group-3d select,
.form-group-3d textarea {
    transform: translateZ(10px);
    transition: transform 0.3s ease;
}

.form-group-3d input:focus,
.form-group-3d select:focus,
.form-group-3d textarea:focus {
    transform: translateZ(20px);
}

/* 3D Alert */
.alert-3d {
    transform-style: preserve-3d;
    animation: alertPopIn 0.5s ease;
}

@keyframes alertPopIn {
    from {
        opacity: 0;
        transform: translateZ(-50px) scale(0.8);
    }
    to {
        opacity: 1;
        transform: translateZ(0) scale(1);
    }
}

/* 3D Chart */
.chart-3d {
    transform-style: preserve-3d;
    perspective: 1000px;
}

.chart-3d canvas {
    transform: translateZ(20px);
    transition: transform 0.3s ease;
}

.chart-3d:hover canvas {
    transform: translateZ(30px);
}

/* 3D Shadow */
.shadow-3d {
    box-shadow: 
        0 10px 20px rgba(0,0,0,0.1),
        0 20px 40px rgba(0,0,0,0.1),
        0 30px 60px rgba(0,0,0,0.1);
}

/* 3D Glass Effect */
.glass-3d {
    background: rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.2);
    transform-style: preserve-3d;
}

.glass-3d::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(
        135deg,
        rgba(255, 255, 255, 0.1) 0%,
        rgba(255, 255, 255, 0) 100%
    );
    transform: translateZ(-1px);
    border-radius: inherit;
}

/* 3D Parallax */
.parallax-3d {
    transform-style: preserve-3d;
}

.parallax-3d .parallax-layer {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.parallax-layer-1 { transform: translateZ(-100px); }
.parallax-layer-2 { transform: translateZ(-50px); }
.parallax-layer-3 { transform: translateZ(0); }
.parallax-layer-4 { transform: translateZ(50px); }
.parallax-layer-5 { transform: translateZ(100px); }