/*
 * PersonligPlast Page-Specific Styles
 * Homepage (Editorial Asymmetric) & Gallery page custom layouts
 */

/* ==========================================================================
   HOMEPAGE V2 — Editorial Asymmetric Layout
   ========================================================================== */

.pp-front-page {
    background: var(--pp-background);
}

/* ---------- Hero Section ---------- */

.pp-hero-v2 {
    padding: 3rem 1.5rem 5rem;
    max-width: 1400px;
    margin: 0 auto;
}

.pp-hero-v2__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 3rem;
    align-items: center;
}

@media (min-width: 1024px) {
    .pp-hero-v2__grid {
        grid-template-columns: 5fr 7fr;
        gap: 3rem;
    }

    .pp-hero-v2 {
        padding: 4rem 2rem 6rem;
    }
}

.pp-hero-v2__content {
    position: relative;
    z-index: 2;
}

.pp-hero-v2__title {
    font-family: var(--pp-font-primary);
    font-size: clamp(2.5rem, 5.5vw, 4.5rem);
    font-weight: 800;
    line-height: 1.08;
    letter-spacing: -0.03em;
    color: var(--pp-on-surface);
    margin: 0 0 1.5rem;
}

.pp-hero-v2__title em {
    color: var(--pp-primary);
    font-style: italic;
    font-weight: 500;
}

.pp-hero-v2__subtitle {
    font-family: var(--pp-font-secondary);
    font-size: clamp(1rem, 1.3vw, 1.25rem);
    color: var(--pp-on-surface-variant);
    line-height: 1.7;
    max-width: 28rem;
    margin: 0 0 2.5rem;
}

.pp-hero-v2__buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}

/* Button variations for hero */
.pp-btn--lg {
    padding: 1rem 2rem;
    font-size: 1rem;
}

.pp-btn--secondary-container {
    background: #d4e8d1;
    color: #455645;
    border: none;
    display: inline-block;
    text-decoration: none;
    font-family: var(--pp-font-primary);
    font-weight: 600;
    border-radius: var(--pp-border-radius-pill);
    transition: var(--pp-transition);
    cursor: pointer;
    text-align: center;
    line-height: 1;
}

.pp-btn--secondary-container:hover {
    opacity: 0.9;
    color: #455645;
    transform: translateY(-1px);
}

.pp-btn--secondary-solid {
    background: var(--pp-secondary);
    color: #ebfee7;
    border: none;
    display: inline-block;
    text-decoration: none;
    font-family: var(--pp-font-primary);
    font-weight: 700;
    border-radius: var(--pp-border-radius-pill);
    transition: var(--pp-transition);
    cursor: pointer;
    text-align: center;
    line-height: 1;
    padding: 1rem 2rem;
    font-size: 1rem;
    white-space: nowrap;
}

.pp-btn--secondary-solid:hover {
    opacity: 0.9;
    color: #ebfee7;
}

.pp-btn--ghost {
    background: var(--pp-surface-container-lowest);
    color: var(--pp-on-surface);
    border: 2px solid rgba(176, 179, 174, 0.2);
    display: inline-block;
    text-decoration: none;
    font-family: var(--pp-font-primary);
    font-weight: 600;
    font-size: 0.9rem;
    border-radius: var(--pp-border-radius-pill);
    transition: var(--pp-transition);
    cursor: pointer;
    text-align: center;
    line-height: 1;
    padding: 0.75rem 1.5rem;
}

.pp-btn--ghost:hover {
    background: #fff;
    color: var(--pp-on-surface);
}

/* Hero Image */
.pp-hero-v2__image-wrap {
    position: relative;
}

.pp-hero-v2__image-frame {
    border-radius: 1.5rem;
    overflow: hidden;
    box-shadow: 0 25px 50px -12px rgba(48, 51, 48, 0.08);
    transform: rotate(1deg);
}

@media (max-width: 1023px) {
    .pp-hero-v2__image-frame {
        transform: none;
    }
}

.pp-hero-v2__image {
    width: 100%;
    height: 500px;
    object-fit: cover;
    display: block;
}

@media (min-width: 1024px) {
    .pp-hero-v2__image {
        height: 600px;
    }
}

/* Floating Featured Card */
.pp-hero-v2__featured-card {
    display: none;
}

@media (min-width: 768px) {
    .pp-hero-v2__featured-card {
        display: block;
        position: absolute;
        bottom: -2rem;
        left: -2rem;
        background: var(--pp-surface-container-lowest);
        padding: 1.5rem;
        border-radius: 1.5rem;
        box-shadow: 0 20px 40px rgba(48, 51, 48, 0.12);
        max-width: 240px;
        z-index: 3;
    }
}

.pp-hero-v2__featured-label {
    font-family: var(--pp-font-primary);
    font-weight: 700;
    font-size: 0.8rem;
    color: var(--pp-primary);
    margin: 0 0 0.5rem;
}

.pp-hero-v2__featured-title {
    font-family: var(--pp-font-primary);
    font-weight: 600;
    font-size: 1rem;
    color: var(--pp-on-surface);
    margin: 0 0 0.25rem;
}

.pp-hero-v2__featured-desc {
    font-family: var(--pp-font-secondary);
    font-size: 0.85rem;
    color: var(--pp-on-surface-variant);
    font-style: italic;
    margin: 0;
}

/* ---------- Collections / Products Section ---------- */

.pp-collections {
    background: var(--pp-surface-container-low);
    padding: 5rem 1.5rem;
}

.pp-collections__inner {
    max-width: 1400px;
    margin: 0 auto;
}

.pp-collections__header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 3.5rem;
}

.pp-collections__header-text {
    max-width: 36rem;
}

.pp-collections__title {
    font-family: var(--pp-font-primary);
    font-size: clamp(1.75rem, 3.5vw, 2.5rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--pp-on-surface);
    margin: 0 0 0.75rem;
}

.pp-collections__subtitle {
    font-family: var(--pp-font-secondary);
    color: var(--pp-on-surface-variant);
    font-size: 1rem;
    margin: 0;
    line-height: 1.6;
}

.pp-collections__view-all {
    font-family: var(--pp-font-primary);
    font-weight: 700;
    color: var(--pp-primary);
    text-decoration: none;
    white-space: nowrap;
    transition: var(--pp-transition);
}

.pp-collections__view-all:hover {
    text-decoration: underline;
    text-underline-offset: 8px;
    color: var(--pp-primary);
}

/* Hide desktop "View all" on mobile, show mobile version */
.pp-collections__header .pp-collections__view-all {
    display: none;
}

@media (min-width: 768px) {
    .pp-collections__header .pp-collections__view-all {
        display: block;
    }
    .pp-collections__footer-link {
        display: none;
    }
}

.pp-collections__footer-link {
    text-align: center;
    margin-top: 2rem;
}

/* Product Cards Grid */
.pp-collections__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
}

@media (min-width: 768px) {
    .pp-collections__grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 2rem;
    }
}

.pp-collections__card {
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: inherit;
    cursor: pointer;
    transition: var(--pp-transition);
}

.pp-collections__card:hover {
    color: inherit;
}

.pp-collections__card--offset {
    /* Previously offset for bento stagger — cards now top-aligned */
}

.pp-collections__card-image {
    aspect-ratio: 1 / 1;
    border-radius: 1.5rem;
    overflow: hidden;
    background: var(--pp-surface-container);
    margin-bottom: 1.5rem;
    transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
    flex-shrink: 0;
}

.pp-collections__card:hover .pp-collections__card-image {
    transform: scale(1.02);
}

.pp-collections__card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: grayscale(0.2);
    transition: filter 0.5s ease, transform 0.5s ease;
}

.pp-collections__card:hover .pp-collections__card-image img {
    filter: grayscale(0);
}

.pp-collections__card-image--placeholder {
    background: var(--pp-surface-container);
}

.pp-collections__card-title {
    font-family: var(--pp-font-primary);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--pp-on-surface);
    margin: 0 0 0.25rem;
}

.pp-collections__card-desc {
    font-family: var(--pp-font-secondary);
    color: var(--pp-on-surface-variant);
    font-size: 0.95rem;
    margin: 0;
}

/* ---------- How It Works V2 ---------- */

.pp-how-it-works-v2 {
    background: var(--pp-background);
    padding: 5rem 1.5rem;
}

.pp-how-it-works-v2__inner {
    max-width: 1400px;
    margin: 0 auto;
}

.pp-how-it-works-v2__header {
    text-align: center;
    margin-bottom: 3.5rem;
}

.pp-how-it-works-v2__title {
    font-family: var(--pp-font-primary);
    font-size: clamp(1.75rem, 3.5vw, 2.5rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--pp-on-surface);
    margin: 0 0 1rem;
}

.pp-how-it-works-v2__subtitle {
    font-family: var(--pp-font-secondary);
    color: var(--pp-on-surface-variant);
    max-width: 40rem;
    margin: 0 auto;
    font-size: 1rem;
    line-height: 1.6;
}

.pp-how-it-works-v2__steps {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.5rem;
}

@media (min-width: 768px) {
    .pp-how-it-works-v2__steps {
        grid-template-columns: repeat(3, 1fr);
        gap: 3rem;
    }
}

.pp-how-it-works-v2__step {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.pp-how-it-works-v2__icon {
    width: 5rem;
    height: 5rem;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1.5rem;
}

.pp-how-it-works-v2__icon--terracotta {
    background: #f79877;
    color: #954a2e;
}

.pp-how-it-works-v2__icon--sage {
    background: #d4e8d1;
    color: #526452;
}

.pp-how-it-works-v2__icon--gold {
    background: #f7d693;
    color: #745c25;
}

.pp-how-it-works-v2__step-title {
    font-family: var(--pp-font-primary);
    font-weight: 700;
    font-size: 1.25rem;
    color: var(--pp-on-surface);
    margin: 0 0 0.75rem;
}

.pp-how-it-works-v2__step-desc {
    font-family: var(--pp-font-secondary);
    font-size: 0.9rem;
    color: var(--pp-on-surface-variant);
    line-height: 1.7;
    margin: 0;
    max-width: 20rem;
}

/* ---------- Gallery / Social Strip ---------- */

.pp-gallery-strip {
    background: var(--pp-surface-container);
    padding: 5rem 1.5rem;
}

.pp-gallery-strip__inner {
    max-width: 1400px;
    margin: 0 auto;
}

.pp-gallery-strip__header {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-bottom: 2.5rem;
    align-items: flex-start;
}

@media (min-width: 768px) {
    .pp-gallery-strip__header {
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
    }
}

.pp-gallery-strip__title {
    font-family: var(--pp-font-primary);
    font-size: clamp(1.5rem, 2.5vw, 1.875rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--pp-on-surface);
    margin: 0 0 0.25rem;
}

.pp-gallery-strip__subtitle {
    font-family: var(--pp-font-secondary);
    color: var(--pp-on-surface-variant);
    font-size: 0.95rem;
    margin: 0;
}

.pp-gallery-strip__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}

@media (min-width: 768px) {
    .pp-gallery-strip__grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

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

.pp-gallery-strip__item {
    aspect-ratio: 1 / 1;
    border-radius: 1.5rem;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(48, 51, 48, 0.06);
}

.pp-gallery-strip__item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.7s cubic-bezier(0.4, 0, 0.2, 1);
}

.pp-gallery-strip__item:hover img {
    transform: scale(1.1);
}

/* Hide 5th item on tablet */
.pp-gallery-strip__item:nth-child(n+5) {
    display: none;
}

@media (min-width: 1024px) {
    .pp-gallery-strip__item:nth-child(n+5) {
        display: block;
    }
}

/* ---------- Newsletter CTA V2 ---------- */

.pp-newsletter-v2 {
    padding: 5rem 1.5rem;
    max-width: 56rem;
    margin: 0 auto;
}

.pp-newsletter-v2__card {
    background: rgba(212, 232, 209, 0.5);
    border-radius: 1.5rem;
    padding: 3rem 2rem;
    text-align: center;
}

@media (min-width: 768px) {
    .pp-newsletter-v2__card {
        padding: 4rem;
    }
}

.pp-newsletter-v2__label {
    display: block;
    font-family: var(--pp-font-primary);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    font-size: 0.8rem;
    color: var(--pp-secondary);
    margin-bottom: 1rem;
}

.pp-newsletter-v2__title {
    font-family: var(--pp-font-primary);
    font-size: clamp(1.5rem, 3vw, 2.25rem);
    font-weight: 700;
    color: var(--pp-on-surface);
    margin: 0 0 1rem;
}

.pp-newsletter-v2__desc {
    font-family: var(--pp-font-secondary);
    color: #455645;
    font-size: 1.1rem;
    margin: 0 0 2rem;
    line-height: 1.6;
}

.pp-newsletter-v2__form {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    max-width: 28rem;
    margin: 0 auto;
}

@media (min-width: 768px) {
    .pp-newsletter-v2__form {
        flex-direction: row;
    }
}

.pp-newsletter-v2__input {
    flex: 1;
    padding: 1rem 1.5rem !important;
    border: none !important;
    border-radius: 1.5rem !important;
    background: var(--pp-surface-container-lowest) !important;
    font-family: var(--pp-font-secondary);
    font-size: 1rem;
    color: var(--pp-on-surface);
    outline: none;
}

.pp-newsletter-v2__input:focus {
    box-shadow: 0 0 0 2px rgba(82, 100, 82, 0.2) !important;
    border: none !important;
}

.pp-newsletter-v2__input::placeholder {
    color: var(--pp-on-surface-variant);
}

/* ---------- Legacy Homepage Styles (kept for backward compat) ---------- */

.pp-hero {
    background: var(--pp-background);
    padding: 5rem 1.5rem 4rem;
    text-align: center;
    max-width: 900px;
    margin: 0 auto;
}

.pp-section-heading {
    font-family: var(--pp-font-primary);
    font-size: clamp(1.75rem, 3.5vw, 2.5rem);
    font-weight: 700;
    color: var(--pp-on-surface);
    text-align: center;
    margin-bottom: 0.5rem;
}

.pp-section-subheading {
    font-family: var(--pp-font-secondary);
    color: var(--pp-on-surface-variant);
    text-align: center;
    font-size: var(--pp-font-size-base);
    margin-bottom: 3rem;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}

/* Gallery page styles moved to assets/css/gallery.css */
