/*
==========================================================================
  Component Styles
  (Moved from styles.css for better organization)
==========================================================================
*/

/* --- Logo Thumbnail & Modal (from index.html) --- */
.logo-thumb-btn {
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
}

.logo-thumb-btn img {
    width: 32px;
    height: 32px;
    object-fit: contain;
    border-radius: 6px;
    box-shadow: 0 1px 4px #0002;
}

.logo-modal {
    display: none;
    position: fixed;
    z-index: 9999;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.7);
    align-items: center;
    justify-content: center;
}

.logo-modal img {
    max-width: 90vw;
    max-height: 80vh;
    border-radius: 1rem;
    box-shadow: 0 4px 32px #000a;
}

/* --- Contact Form Inputs (from index.html) --- */
.form-group {
    margin-bottom: 1.25rem; /* Equivalent to mb-5 */
}
.form-input {
    width: 100%;
    padding: 0.75rem; /* p-3 */
    border-width: 1px;
    border-radius: 0.5rem; /* rounded-lg */
    outline: none;
    background-color: var(--color-background-dark);
    border-color: var(--color-secondary);
    color: var(--color-text-light);
}

/* --- General Components --- */
.card { 
    background-color: var(--color-light-background-alt); 
    border: 1px solid var(--color-light-gray); 
    box-shadow: 0 4px 12px var(--color-shadow); 
}
#contact .card { 
    background-color: rgba(39, 54, 63, 0.568); 
    border: 1px solid var(--color-mid-gray); 
}
.btn-primary { background-color: var(--color-primary); color: var(--color-text-light); }
.btn-secondary { background-color: var(--color-secondary); color: var(--color-light-text); }
.icon { 
    width: 24px; 
    height: 24px; 
    stroke-width: 2; 
    transition: color var(--transition-speed-fast) var(--transition-timing-function); 
}
.social-link:hover .icon { color: var(--color-primary); }

/* --- Project Accordion --- */
#projects .content-wrapper {
    width: 75%; /* Made the section narrower */
    max-width: 1100px;
}
.accordion-scroll-container {
    overflow-x: auto;
    padding-bottom: 1rem; /* Space for the scrollbar */
    scrollbar-width: thin; 
    scrollbar-color: var(--color-primary) var(--color-light-gray);
}
.accordion-scroll-container::-webkit-scrollbar { height: 8px; } 
.accordion-scroll-container::-webkit-scrollbar-track { background: var(--color-light-gray); border-radius: var(--border-radius-small); }
.accordion-scroll-container::-webkit-scrollbar-thumb { background-color: var(--color-primary); border-radius: var(--border-radius-small); }

.projects-accordion {
    display: inline-flex; /* Changed to inline-flex to allow horizontal overflow */
    gap: 1rem;
    min-height: 500px; /* Use min-height to ensure container has a size */
    width: max-content; /* Allow the container to grow with more cards */
}
.project-accordion-card {
    flex-shrink: 0; /* Prevent cards from shrinking */
    width: 110px; /* Set a smaller fixed width for collapsed cards */
    border-radius: var(--border-radius-large);
    background-size: cover;
    background-position: center;
    position: relative;
    overflow: hidden;
    cursor: pointer;
    transition: width var(--transition-speed-slow) var(--transition-timing-function-cubic), opacity var(--transition-speed-fast);
    opacity: 0.5;
}

/* Overlay for dimming background after 1s */
.project-accordion-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(20,20,30,0);
    pointer-events: none; 
    z-index: 2;
    transition: background var(--transition-speed-slow) var(--transition-timing-function-cubic);
}
.project-accordion-card.dimmed::before { 
    background: rgba(20,20,30,0.82);
}
.project-accordion-card::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%; 
    background: linear-gradient(to top, rgba(0,0,0,0.7), rgba(0,0,0,0.1)); 
    transition: background var(--transition-speed-normal) var(--transition-timing-function) var(--transition-speed-normal);
}
.project-accordion-card.active {
    width: 480px;
    opacity: 1;
}
.project-accordion-card.active::after { 
    background: linear-gradient(to top, rgba(0,0,0,0.9), rgba(0,0,0,0.4));
}
.project-accordion-card .card-content {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    color: white;
    z-index: 10;
    display: flex;
    flex-direction: column;
}
.text-content-area {
    position: relative;
    flex-grow: 1;
    overflow: hidden;
}
/* Collapsed State Content */
.collapsed-content {
    position: absolute;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity 0.5s ease;
    opacity: 1;
}
.collapsed-content h3 {
    font-size: 1.5rem;
    font-weight: bold;
    writing-mode: vertical-rl;
    transform: rotate(180deg);
}
/* Expanded State Content */
.expanded-content {
    position: absolute;
    width: 100%;
    height: 100%;
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.5s 0.3s ease, transform 0.5s 0.3s ease;
}

/* This new container will hold all the text and grow */
.expanded-content .main-text {
    flex-grow: 1;
    overflow-y: auto; /* Allows scrolling if content is too long */
    scrollbar-width: none; /* Hides scrollbar for a cleaner look */
    -ms-overflow-style: none; /* Hides scrollbar for IE/Edge */
}
.expanded-content .main-text::-webkit-scrollbar {
    display: none; /* Hides scrollbar for Chrome/Safari */
}

.expanded-content .tool-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 1rem;
}
.expanded-content .tool-list .tool-tag {
    background-color: rgba(255, 255, 255, 0.1);
    padding: 0.25rem 0.75rem;
    border-radius: var(--border-radius-circle);
    font-size: 0.875rem;
}

/* Tech Icons Styling (Visible in both states) */
.tech-icons {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.75rem;
    flex-direction: column; /* Default to vertical for collapsed state */
    min-height: 80px;
    transition: all 0.5s ease;
}
.tech-icons span {
    font-size: 1.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
}
.tech-icons .plus-indicator {
    font-size: 1rem;
    font-weight: bold;
    background-color: rgba(0,0,0,0.3);
    border-radius: var(--border-radius-circle);
    width: 28px;
    height: 28px;
}

/* Active State Changes */
.project-accordion-card.active .collapsed-content {
    opacity: 0;
}
.project-accordion-card.active .expanded-content {
    opacity: 1;
    transform: translateY(0);
}
.project-accordion-card.active .tech-icons {
    display: none !important;
}
.expanded-content h3 { font-size: 2.25rem; font-weight: 700; margin-bottom: 0.5rem; }
.expanded-content p {
    font-size: 1rem;
    margin-bottom: 1rem;
}
.visit-btn {
    display: none;
    background-color: var(--color-primary);
    color: var(--color-text-light);
    padding: 0.5rem var(--border-radius-large);
    border-radius: 0.5rem;
    text-decoration: none;
    font-weight: 600;
    flex-shrink: 0;
    margin-top: 1rem;
    align-self: flex-start;
}

.project-accordion-card.active .expanded-content .visit-btn {
    display: inline-block;
}