/*
Theme Name: Pretty Little Page
Theme URI: https://prettylittlepage.com
Template: blocksy
Description: Child-Theme für prettylittlepage.com – editorial Mama-Blog Design
Author: Mama Redaktion
Version: 1.0.0
Text Domain: prettylittlepage
*/

:root {
  --plp-bg: #F7F4EE;
  --plp-text: #232019;
  --plp-text-soft: #5f574b;
  --plp-accent: #bb6f5e;
  --plp-accent-light: #F6D9C9;
  --plp-gray: #9b9183;
  --plp-border: #e6e0d4;
  --plp-white: #ffffff;
  --plp-radius: 4px;
  --plp-content-width: 1240px;
  --plp-pad: clamp(28px, 5vw, 64px);
  --plp-hero-pad: clamp(28px, 6vw, 88px);
}

/* ── Hero ── */
.plp-hero {
  position: relative;
  width: 100%;
  height: 100vh;
  min-height: 640px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.plp-hero__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}

.plp-hero__scrim {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(180deg,
    rgba(28,22,18,.42) 0%,
    rgba(28,22,18,.18) 32%,
    rgba(28,22,18,.30) 62%,
    rgba(28,22,18,.66) 100%);
}

/* nav */
.plp-hero__nav {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 34px var(--plp-hero-pad);
  max-width: var(--plp-content-width);
  width: 100%;
  margin: 0 auto;
  box-sizing: border-box;
}

.plp-logo {
  font-family: 'Playfair Display', serif;
  font-weight: 500;
  letter-spacing: .12em;
  text-decoration: none;
}

.plp-hero .plp-logo {
  font-size: 23px;
  color: var(--plp-white);
}

.plp-logo__little {
  font-style: italic;
  font-weight: 400;
  letter-spacing: 0;
}

.plp-hero .plp-logo__little {
  color: var(--plp-accent-light);
  text-shadow: 0 1px 10px rgba(0,0,0,.35);
}

.plp-hero__links {
  display: flex;
  gap: 34px;
  font: 500 11px/1 'Helvetica Neue', Arial, sans-serif;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.82);
}

.plp-hero__links a {
  color: inherit;
  text-decoration: none;
  transition: color .25s;
}

.plp-hero__links a:hover {
  color: var(--plp-white);
}

/* hero text */
.plp-hero__content {
  position: relative;
  z-index: 2;
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  max-width: var(--plp-content-width);
  width: 100%;
  margin: 0 auto;
  padding: 0 var(--plp-pad) 64px;
  box-sizing: border-box;
}

.plp-hero__eyebrow {
  font: 500 12px/1 'Helvetica Neue', Arial, sans-serif;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: rgba(255,255,255,.9);
}

.plp-hero__title {
  margin: 24px 0 0;
  font-family: 'Playfair Display', serif;
  font-weight: 400;
  color: var(--plp-white);
  font-size: clamp(40px, 11vw, 84px);
  line-height: 1.0;
  letter-spacing: -.01em;
  max-width: 880px;
  text-shadow: 0 2px 24px rgba(0,0,0,.28);
}

.plp-hero__title-accent {
  font-family: 'Pinyon Script', cursive;
  font-weight: 400;
  color: var(--plp-accent-light);
  font-size: 1.095em;
  line-height: .8;
  text-shadow: 0 2px 18px rgba(0,0,0,.4);
}

.plp-hero__subtitle {
  margin: 30px 0 0;
  max-width: 460px;
  font-family: 'EB Garamond', serif;
  font-size: 22px;
  line-height: 1.6;
  color: rgba(255,255,255,.92);
  text-shadow: 0 1px 16px rgba(0,0,0,.3);
}

.plp-hero__cta {
  margin-top: 38px;
  display: flex;
  align-items: center;
  gap: 14px;
  text-decoration: none;
}

.plp-hero__cta-text {
  font: 500 12px/1 'Helvetica Neue', Arial, sans-serif;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--plp-white);
  border-bottom: 1px solid rgba(255,255,255,.85);
  padding-bottom: 6px;
}

.plp-hero__cta-arrow {
  color: var(--plp-accent);
  font-size: 18px;
}

/* ── Posts section ── */
.plp-posts {
  border-top: 1px solid var(--plp-border);
  padding: 72px var(--plp-pad) 96px;
  max-width: var(--plp-content-width);
  margin: 0 auto;
  box-sizing: border-box;
}

.plp-posts__header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 48px;
}

.plp-section-label {
  font: 500 11px/1 'Helvetica Neue', Arial, sans-serif;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--plp-gray);
}

.plp-view-all {
  font: 500 11px/1 'Helvetica Neue', Arial, sans-serif;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--plp-accent);
  text-decoration: none;
  transition: opacity .25s;
}

.plp-view-all:hover { opacity: .7; }

/* category label */
.plp-cat {
  font: 500 11px/1 'Helvetica Neue', Arial, sans-serif;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--plp-accent);
}

/* post card base */
.plp-card {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1);
  cursor: pointer;
  text-decoration: none;
  color: inherit;
  display: block;
}

.plp-card.in {
  opacity: 1;
  transform: translateY(0);
}

.plp-card:hover {
  transform: translateY(-6px);
}

.plp-card.in:hover {
  transform: translateY(-6px);
}

/* image container */
.plp-card__media {
  overflow: hidden;
  border-radius: var(--plp-radius);
}

.plp-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .7s cubic-bezier(.2,.7,.2,1);
}

.plp-card:hover .plp-card__media img {
  transform: scale(1.06);
}

/* post title */
.plp-card__title {
  font-family: 'Playfair Display', serif;
  font-weight: 400;
  color: var(--plp-text);
  margin: 0;
  transition: color .25s ease;
}

.plp-card:hover .plp-card__title {
  color: var(--plp-accent);
}

/* featured post */
.plp-featured {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: clamp(28px, 4vw, 60px);
  align-items: center;
  margin-bottom: 84px;
}

.plp-featured .plp-card__media {
  aspect-ratio: 16 / 11;
}

.plp-featured__accent-line {
  display: flex;
  align-items: center;
  gap: 12px;
}

.plp-featured__accent-line::before {
  content: '';
  width: 26px;
  height: 1px;
  background: var(--plp-accent);
}

.plp-featured .plp-card__title {
  margin: 22px 0 0;
  font-size: clamp(28px, 3.4vw, 42px);
  line-height: 1.12;
}

.plp-featured__read-more {
  margin-top: 28px;
  display: flex;
  align-items: center;
  gap: 12px;
  transition: gap .25s ease;
}

.plp-card:hover .plp-featured__read-more {
  gap: 18px;
}

.plp-featured__read-more-text {
  font: 500 12px/1 'Helvetica Neue', Arial, sans-serif;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--plp-text);
  border-bottom: 1px solid var(--plp-text);
  padding-bottom: 5px;
}

.plp-featured__read-more-arrow {
  color: var(--plp-accent);
  font-size: 18px;
}

/* 3-col grid */
.plp-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 48px 36px;
}

.plp-grid-3 .plp-card__media {
  aspect-ratio: 4 / 5;
}

.plp-grid-3 .plp-cat {
  margin: 20px 0 10px;
}

.plp-grid-3 .plp-card__title {
  font-size: 23px;
  line-height: 1.26;
}

/* 2-col horizontal */
.plp-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px 48px;
  margin-top: 64px;
}

.plp-grid-2 .plp-card {
  display: grid;
  grid-template-columns: 0.85fr 1fr;
  gap: 24px;
  align-items: center;
}

.plp-grid-2 .plp-card__media {
  aspect-ratio: 1 / 1;
}

.plp-grid-2 .plp-cat {
  margin-bottom: 10px;
}

.plp-grid-2 .plp-card__title {
  font-size: 22px;
  line-height: 1.24;
}

/* ── Footer ── */
.plp-footer {
  border-top: 1px solid var(--plp-border);
  padding: 40px var(--plp-pad);
  max-width: var(--plp-content-width);
  margin: 0 auto;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.plp-footer .plp-logo {
  font-size: 17px;
  color: var(--plp-text);
}

.plp-footer .plp-logo__little {
  color: var(--plp-accent);
}

.plp-footer__slogan {
  font-family: 'EB Garamond', serif;
  font-style: italic;
  font-size: 16px;
  color: var(--plp-gray);
}

/* ── Responsive ── */
@media (max-width: 900px) {
  .plp-featured {
    grid-template-columns: 1fr;
  }
  .plp-grid-3 {
    grid-template-columns: repeat(2, 1fr);
  }
  .plp-grid-2 {
    grid-template-columns: 1fr;
  }
  .plp-grid-2 .plp-card {
    grid-template-columns: 0.85fr 1fr;
  }
  .plp-hero__links {
    display: none;
  }
}

@media (max-width: 600px) {
  .plp-grid-3 {
    grid-template-columns: 1fr;
  }
  .plp-grid-2 .plp-card {
    grid-template-columns: 1fr;
  }
  .plp-footer {
    flex-direction: column;
    gap: 16px;
    text-align: center;
  }
}
