/* 
   Project: Organic Minimalist
*/

.intro-grid {
    display: flex;             /* Using Flex for easier horizontal control */
    flex-direction: row;       /* Forces Side-by-Side */
    align-items: flex-start;
    gap: 4rem;                 /* Professional 'Cloud Dancer' spacing */
    width: 100%;
    margin-top: 2rem;
    animation: fadeIn 0.8s ease-out;
}

.intro-image {
    flex: 0 0 40%;             /* Image takes exactly 40% of the width */
    max-width: 450px;          /* Prevents it from getting too huge */
    perspective: 1000px;
}

.intro-image img {
    width: 100%;               /* Fills its 40% container */
    height: auto;
    border-radius: 15px;
    display: block;
    box-shadow: 0 15px 30px rgba(117, 71, 52, 0.1); /* Subtle Tortoise shadow */
    width: 100%;
    border-radius: 15px;

    backface-visibility: visible
    animation: spin3D 10s linear infinite;
    transform-style: preserve-3d;
    backface-visibility: hidden; /* Prevents flickering when the back shows */
}

.intro-text {
    flex: 1;                   /* Takes the remaining space */
    padding-top: 1rem;
}

.intro-text h1 {
    font-size: 2.5rem;
    color: var(--tortoise);
    margin: 1rem 0;
    line-height: 1.2;
}

.intro-text .subtitle {
    text-transform: uppercase;
    letter-spacing: 0.2em;
    font-size: 0.8rem;
    color: var(--slate-earth);
    opacity: 0.6;
}

.intro-button-stack {
    margin-bottom: 30px;
    display: flex;
    gap: 2rem; /* spacing between buttons */
}

/* --- MOBILE STACKING --- */
@media (max-width: 768px) {
    .intro-grid {
        flex-direction: column; /* Stacks vertically on smaller screens */
        align-items: center;
        text-align: center;
        gap: 2rem;
    }
    
    .intro-image {
        flex: 0 0 100%;
        max-width: 100%;       /* Allow image to be wider on mobile */
    }
}

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


@keyframes spin3D {
    from { transform: rotateY(0deg); }
    to { transform: rotateY(360deg); }
}