/* ============================================
   Reusable Components
   ============================================ */

/* === Buttons === */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-xs);
    font-family: var(--font-body);
    font-size: var(--fs-sm);
    font-weight: var(--fw-medium);
    letter-spacing: var(--ls-wide);
    text-transform: uppercase;
    padding: var(--space-sm) var(--space-lg);
    border: 1px solid transparent;
    cursor: pointer;
    transition: all var(--duration-normal) var(--ease-out);
    text-decoration: none;
    line-height: 1;
}

.btn--primary {
    background-color: var(--color-accent);
    color: var(--color-white);
    border-color: var(--color-accent);
}

.btn--primary:hover {
    background-color: var(--color-accent-hover);
    border-color: var(--color-accent-hover);
    color: var(--color-white);
}

.btn--outline {
    background-color: transparent;
    color: var(--color-white);
    border-color: var(--color-white);
}

.btn--outline:hover {
    background-color: var(--color-white);
    color: var(--color-charcoal);
}

.btn--outline-dark {
    background-color: transparent;
    color: var(--color-charcoal);
    border-color: var(--color-charcoal);
}

.btn--outline-dark:hover {
    background-color: var(--color-charcoal);
    color: var(--color-white);
}

.btn--full { width: 100%; }
.btn--lg   { padding: var(--space-md) var(--space-xl); font-size: var(--fs-base); }
.btn--sm   { padding: var(--space-xs) var(--space-sm); font-size: var(--fs-xs); }

.btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* === Collection Preview Card === */
.collection-card {
    position: relative;
    overflow: hidden;
    cursor: pointer;
    display: block;
    text-decoration: none;
    color: var(--color-white);
}

.collection-card__image {
    width: 100%;
    aspect-ratio: 3 / 4;
    object-fit: cover;
    transition: transform var(--duration-slow) var(--ease-out);
    background-color: var(--color-sand);
}

.collection-card:hover .collection-card__image {
    transform: scale(1.03);
}

.collection-card__overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: var(--space-md) var(--space-sm);
    background: linear-gradient(transparent, rgba(0, 0, 0, 0.55));
}

.collection-card__title {
    font-family: var(--font-display);
    font-size: var(--fs-lg);
    font-weight: var(--fw-regular);
    letter-spacing: var(--ls-wide);
}

/* === Collection Preview Grid === */
.collection-preview__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-sm);
    margin: var(--space-xl) 0;
}

@media (min-width: 768px) {
    .collection-preview__grid {
        grid-template-columns: repeat(3, 1fr);
        gap: var(--space-md);
    }
}

@media (min-width: 1200px) {
    .collection-preview__grid {
        grid-template-columns: repeat(5, 1fr);
    }
}

.collection-preview__header {
    text-align: center;
    max-width: 700px;
    margin: 0 auto var(--space-lg);
}

.collection-preview__header .section__body {
    margin: 0 auto;
}

.collection-preview__cta {
    text-align: center;
    margin-top: var(--space-xl);
}

/* === Collection Showcase (split editorial layout) === */
.showcase {
    padding: var(--section-py) 0;
    background-color: var(--color-bg-dark);
    color: var(--color-white);
    overflow: hidden;
}

.showcase--reverse {
    background-color: var(--color-cream);
    color: var(--color-charcoal);
}

.showcase__inner {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-2xl);
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--container-padding);
    align-items: center;
}

@media (min-width: 768px) {
    .showcase__inner {
        grid-template-columns: 1fr 1fr;
        gap: var(--space-3xl);
    }
}

@media (min-width: 1200px) {
    .showcase__inner {
        grid-template-columns: 2fr 3fr;
        gap: var(--space-4xl);
    }

    .showcase--reverse .showcase__inner {
        grid-template-columns: 3fr 2fr;
    }
}

/* Reverse layout: images on left, text on right */
.showcase--reverse .showcase__images-wrap,
.showcase--reverse .showcase__images {
    order: -1;
}

@media (max-width: 767px) {
    .showcase--reverse .showcase__images-wrap,
    .showcase--reverse .showcase__images {
        order: 1;
    }
}

/* Showcase images wrapper (for hover button overlay) */
.showcase__images-wrap {
    position: relative;
}

.showcase__hover-btn {
    position: absolute;
    top: var(--space-md);
    left: 50%;
    transform: translateX(-50%) translateY(-6px);
    z-index: 10;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-sm) var(--space-lg);
    background: rgba(255, 255, 255, 0.95);
    color: var(--color-charcoal);
    font-family: var(--font-body);
    font-size: var(--fs-xs);
    font-weight: var(--fw-medium);
    letter-spacing: var(--ls-wider);
    text-transform: uppercase;
    text-decoration: none;
    opacity: 0;
    transition: opacity var(--duration-normal) var(--ease-out), transform var(--duration-normal) var(--ease-out);
    pointer-events: none;
}

.showcase__images-wrap:hover .showcase__hover-btn {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
    pointer-events: auto;
}

.showcase__hover-btn:hover {
    background: var(--color-charcoal);
    color: var(--color-white);
}

/* Text side */
.showcase__eyebrow {
    font-family: var(--font-body);
    font-size: var(--fs-xs);
    font-weight: var(--fw-medium);
    letter-spacing: var(--ls-widest);
    text-transform: uppercase;
    color: var(--color-accent);
    display: block;
    margin-bottom: var(--space-md);
}

.showcase__title {
    font-family: var(--font-display);
    font-size: clamp(var(--fs-3xl), 6vw, var(--fs-5xl));
    font-weight: var(--fw-light);
    line-height: 0.95;
    letter-spacing: -0.02em;
    margin-bottom: var(--space-xs);
}

.showcase__subtitle {
    font-family: var(--font-display);
    font-size: var(--fs-lg);
    font-weight: var(--fw-light);
    font-style: italic;
    opacity: 0.6;
    margin-bottom: var(--space-lg);
}

.showcase--reverse .showcase__subtitle {
    color: var(--color-text-muted);
}

.showcase__body {
    font-family: var(--font-body);
    font-size: var(--fs-base);
    font-weight: var(--fw-light);
    line-height: var(--lh-relaxed);
    opacity: 0.75;
    max-width: 440px;
    margin-bottom: var(--space-lg);
}

.showcase--reverse .showcase__body {
    color: var(--color-text-muted);
    opacity: 1;
}

/* Meta line (print count + edition) */
.showcase__meta {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    margin-bottom: var(--space-xl);
}

.showcase__count,
.showcase__edition {
    font-family: var(--font-body);
    font-size: var(--fs-xs);
    letter-spacing: var(--ls-wide);
    text-transform: uppercase;
    opacity: 0.5;
}

.showcase__divider {
    width: 20px;
    height: 1px;
    background: currentColor;
    opacity: 0.25;
}

/* CTA link with arrow */
.showcase__link {
    display: inline-flex;
    align-items: center;
    gap: var(--space-sm);
    font-family: var(--font-body);
    font-size: var(--fs-sm);
    font-weight: var(--fw-medium);
    letter-spacing: var(--ls-wider);
    text-transform: uppercase;
    text-decoration: none;
    color: var(--color-accent);
    transition: gap var(--duration-normal) var(--ease-out);
}

.showcase__link:hover {
    gap: var(--space-md);
}

.showcase__link svg {
    transition: transform var(--duration-normal) var(--ease-out);
}

.showcase__link:hover svg {
    transform: translateX(4px);
}

/* Image mosaic grid (asymmetric) */
.showcase__images {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr 1fr;
    gap: 6px;
}

/* First image spans full height on the left */
.showcase__images .mosaic__item:first-child {
    grid-row: 1 / 3;
}

.mosaic__item {
    position: relative;
    overflow: hidden;
    display: block;
    text-decoration: none;
}

.mosaic__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    background-color: var(--color-sand);
    transition: transform var(--duration-slow) var(--ease-out);
}

.mosaic__item:hover .mosaic__image {
    transform: scale(1.03);
}

/* Hover overlay */
.mosaic__overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: flex-end;
    padding: var(--space-sm);
    background: linear-gradient(transparent 50%, rgba(0,0,0,0.45));
    opacity: 0;
    transition: opacity var(--duration-normal) var(--ease-out);
}

.mosaic__item:hover .mosaic__overlay {
    opacity: 1;
}

.mosaic__name {
    font-family: var(--font-display);
    font-size: var(--fs-sm);
    font-weight: var(--fw-light);
    color: var(--color-white);
    letter-spacing: var(--ls-wide);
}

/* === Press Logos === */
.press-logos {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: var(--space-2xl);
    padding: var(--space-lg) 0;
}

.press-logos__item {
    font-family: var(--font-display);
    font-size: var(--fs-xl);
    font-weight: var(--fw-light);
    color: var(--color-text-muted);
    opacity: 0.6;
    letter-spacing: var(--ls-wider);
    white-space: nowrap;
}

/* === Marquee (Awards & Features) === */
.marquee {
    overflow: hidden;
    width: 100%;
    padding: var(--space-lg) 0;
    position: relative;
    /* Fade edges */
    -webkit-mask-image: linear-gradient(to right, transparent, black 8%, black 92%, transparent);
    mask-image: linear-gradient(to right, transparent, black 8%, black 92%, transparent);
}

.marquee__track {
    display: flex;
    align-items: center;
    gap: var(--space-2xl);
    white-space: nowrap;
    width: max-content;
    animation: marquee-scroll 40s linear infinite;
}

.marquee__track--reverse {
    animation: marquee-scroll-reverse 35s linear infinite;
}

/* Pause on hover for readability */
.marquee:hover .marquee__track {
    animation-play-state: paused;
}

/* Image logos (Awards) */
.marquee__logo {
    height: 40px;
    width: auto;
    flex-shrink: 0;
    opacity: 0.45;
    transition: opacity var(--duration-normal) var(--ease-out);
    user-select: none;
    -webkit-user-drag: none;
    object-fit: contain;
    mix-blend-mode: multiply;
}

@media (min-width: 768px) {
    .marquee__logo {
        height: 50px;
    }
}

@media (min-width: 1200px) {
    .marquee__logo {
        height: 55px;
    }
}

.marquee:hover .marquee__logo {
    opacity: 0.35;
}

.marquee__logo:hover {
    opacity: 0.8 !important;
}

/* Black & white filter for all logos except NatGeo */
.marquee__logo--bw {
    filter: grayscale(100%);
}

.marquee__logo--bw:hover {
    filter: grayscale(100%);
}

/* Text items (Features) */
.marquee__item {
    font-family: var(--font-display);
    font-size: clamp(var(--fs-lg), 2.5vw, var(--fs-2xl));
    font-weight: var(--fw-light);
    color: var(--color-text-muted);
    letter-spacing: var(--ls-wider);
    white-space: nowrap;
    flex-shrink: 0;
}

.marquee__item--link {
    text-decoration: none;
    color: var(--color-text-muted);
    transition: color var(--duration-fast) var(--ease-out);
}

.marquee__item--link:hover {
    color: var(--color-accent);
}

.marquee__sep {
    font-size: var(--fs-sm);
    color: var(--color-stone);
    opacity: 0.4;
    flex-shrink: 0;
}

@keyframes marquee-scroll {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

@keyframes marquee-scroll-reverse {
    0% { transform: translateX(-50%); }
    100% { transform: translateX(0); }
}

/* === Features Grid (clickable publication boxes) === */
.features-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1px;
    margin-top: var(--space-xl);
    background-color: rgba(0, 0, 0, 0.06);
    border: 1px solid rgba(0, 0, 0, 0.06);
}

@media (min-width: 640px) {
    .features-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .features-grid {
        grid-template-columns: repeat(5, 1fr);
    }
}

.feature-card {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: var(--space-lg) var(--space-md);
    min-height: 140px;
    background-color: var(--color-cream);
    text-decoration: none;
    color: var(--color-charcoal);
    position: relative;
    transition: background-color var(--duration-normal) var(--ease-out),
                transform var(--duration-normal) var(--ease-out);
}

.feature-card:hover {
    background-color: var(--color-white);
    transform: translateY(-2px);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
    z-index: 1;
}

.feature-card__name {
    font-family: var(--font-display);
    font-size: var(--fs-lg);
    font-weight: var(--fw-regular);
    line-height: var(--lh-snug);
    letter-spacing: var(--ls-normal);
    display: block;
    margin-bottom: var(--space-xs);
}

.feature-card__desc {
    font-family: var(--font-body);
    font-size: var(--fs-xs);
    font-weight: var(--fw-light);
    line-height: var(--lh-normal);
    color: var(--color-text-muted);
    display: block;
    flex-grow: 1;
}

.feature-card__arrow {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    margin-top: var(--space-sm);
    color: var(--color-stone);
    transition: color var(--duration-fast) var(--ease-out),
                transform var(--duration-normal) var(--ease-out);
}

.feature-card:hover .feature-card__arrow {
    color: var(--color-accent);
    transform: translate(2px, -2px);
}

/* === Quote === */
.quote {
    text-align: center;
    max-width: 1050px;
    margin: 0 auto;
    padding: clamp(1.5rem, 3vw, 3rem) 0;
}

.quote__text {
    font-family: var(--font-display);
    font-size: clamp(var(--fs-2xl), 4vw, var(--fs-4xl));
    font-weight: var(--fw-light);
    font-style: italic;
    line-height: var(--lh-snug);
    color: var(--color-cream);
    margin-bottom: var(--space-lg);
}

.quote__cite {
    font-family: var(--font-body);
    font-size: var(--fs-sm);
    font-style: normal;
    letter-spacing: var(--ls-wider);
    text-transform: uppercase;
    color: var(--color-stone);
}

/* === About Section === */
.about__portrait {
    width: 100%;
    aspect-ratio: 3 / 4;
    object-fit: cover;
    background-color: var(--color-sand);
}

.about__text-col {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.about__text-col .section__body {
    margin-bottom: var(--space-md);
}

/* === Print Details Accordion === */
.print-details {
    margin-top: var(--space-2xl);
    border-top: 1px solid var(--color-sand);
}

.print-details__item {
    border-bottom: 1px solid var(--color-sand);
}

.print-details__summary {
    padding: var(--space-md) 0;
    font-family: var(--font-body);
    font-size: var(--fs-sm);
    font-weight: var(--fw-medium);
    letter-spacing: var(--ls-wide);
    text-transform: uppercase;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    list-style: none;
}

.print-details__summary::-webkit-details-marker {
    display: none;
}

.print-details__summary::after {
    content: '+';
    font-size: var(--fs-lg);
    font-weight: var(--fw-light);
    color: var(--color-text-muted);
    transition: transform var(--duration-fast) var(--ease-out);
}

details[open] .print-details__summary::after {
    content: '\2212';
}

.print-details__content {
    padding-bottom: var(--space-md);
    font-size: var(--fs-sm);
    line-height: var(--lh-relaxed);
    color: var(--color-text-muted);
}

.print-details__content p + p {
    margin-top: var(--space-sm);
}
