/* ================================================================
   LA TRATTORIA – Presse Page Styles
   ================================================================ */

/* ─── HERO ─── */
.lt-p-hero {
  padding: calc(68px + 5rem) 3rem 3rem;
  text-align: center;
  position: relative;
}

.lt-p-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 30% 50%, rgba(201,169,110,0.06), transparent 60%),
    radial-gradient(ellipse at 70% 80%, rgba(139,47,47,0.05), transparent 50%),
    var(--lt-bg);
}

.lt-p-hero-c { position: relative; z-index: 1; }

.lt-p-hero .lt-p-ey {
  font-size: 0.65rem;
  letter-spacing: 0.5em;
  text-transform: uppercase;
  color: var(--lt-gold);
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
}

.lt-p-hero .lt-p-ey::before,
.lt-p-hero .lt-p-ey::after {
  content: '';
  width: 40px;
  height: 1px;
  background: var(--lt-gold-dim);
}

.lt-p-hero h1 {
  font-family: var(--lt-font-display);
  font-size: clamp(3rem, 6vw, 5.5rem);
  font-weight: 300;
  color: var(--lt-cream);
  line-height: 1.05;
  margin-bottom: 1rem;
}

.lt-p-hero h1 em { font-style: italic; color: var(--lt-gold); }

.lt-p-hero .lt-p-sub {
  font-size: 1.1rem;
  font-family: var(--lt-font-display);
  font-style: italic;
  color: var(--lt-cream-muted);
  max-width: 500px;
  margin: 0 auto;
  line-height: 1.7;
}

/* ─── MEDIA LOGOS BAR ─── */
.lt-p-logos-bar {
  border-top: 1px solid var(--lt-line);
  border-bottom: 1px solid var(--lt-line);
  padding: 2.5rem 3rem;
  text-align: center;
}

.lt-p-logos-label {
  font-size: 0.6rem;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--lt-text-muted);
  margin-bottom: 1.5rem;
}

.lt-p-logos-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 3rem;
  flex-wrap: wrap;
}

.lt-p-logo-item {
  font-family: var(--lt-font-display);
  font-size: 1.4rem;
  font-weight: 400;
  color: var(--lt-cream);
  opacity: 0.45;
  transition: opacity 0.4s;
  letter-spacing: 0.05em;
  white-space: nowrap;
}

.lt-p-logo-item:hover { opacity: 0.8; }

.lt-p-logo-sub {
  display: block;
  font-family: var(--lt-font-body);
  font-size: 0.55rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--lt-text-muted);
  margin-top: 0.1rem;
}

/* ─── FEATURED ARTICLE ─── */
.lt-p-featured {
  max-width: 1200px;
  margin: 0 auto;
  padding: 5rem 3rem;
}

.lt-p-featured-card {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 0;
  border: 1px solid var(--lt-line);
  overflow: hidden;
  transition: border-color 0.5s var(--lt-ease-expo);
  text-decoration: none;
  color: inherit;
}

.lt-p-featured-card:hover { border-color: rgba(201,169,110,0.3); }

.lt-p-featured-img {
  position: relative;
  overflow: hidden;
  min-height: 400px;
}

.lt-p-featured-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.85) contrast(1.06) sepia(0.08);
  transition: transform 1.5s var(--lt-ease-expo);
}

.lt-p-featured-card:hover .lt-p-featured-img img { transform: scale(1.04); }

.lt-p-featured-img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent 60%, var(--lt-bg-card));
  pointer-events: none;
}

.lt-p-featured-body {
  padding: 3.5rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: var(--lt-bg-card);
}

.lt-p-featured-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  font-size: 0.6rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--lt-gold);
  margin-bottom: 1.5rem;
  padding: 0.4rem 0.8rem;
  border: 1px solid rgba(201,169,110,0.2);
  width: fit-content;
}

.lt-p-featured-title {
  font-family: var(--lt-font-display);
  font-size: clamp(1.8rem, 3vw, 2.5rem);
  font-weight: 300;
  color: var(--lt-cream);
  line-height: 1.2;
  margin-bottom: 1rem;
}

.lt-p-featured-title em { font-style: italic; color: var(--lt-gold); }

.lt-p-featured-excerpt {
  font-size: 0.95rem;
  color: var(--lt-cream-muted);
  line-height: 1.9;
  margin-bottom: 2rem;
}

.lt-p-featured-meta {
  font-size: 0.65rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--lt-text-muted);
  display: flex;
  align-items: center;
  gap: 1rem;
}

.lt-p-featured-meta::before {
  content: '';
  width: 30px;
  height: 1px;
  background: var(--lt-gold-dim);
}

.lt-p-featured-link {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  margin-top: auto;
  padding-top: 2rem;
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--lt-gold);
  transition: gap 0.4s var(--lt-ease-expo);
}

.lt-p-featured-link:hover { gap: 1rem; }
.lt-p-featured-link span { transition: transform 0.4s var(--lt-ease-expo); }
.lt-p-featured-link:hover span { transform: translateX(4px); }

/* ─── PULL QUOTE ─── */
.lt-p-pull {
  text-align: center;
  padding: 5rem 3rem;
  position: relative;
  max-width: 900px;
  margin: 0 auto;
}

.lt-p-pull::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 1px;
  height: 50px;
  background: linear-gradient(var(--lt-gold-dim), transparent);
}

.lt-p-pull blockquote {
  font-family: var(--lt-font-display);
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  font-weight: 300;
  font-style: italic;
  color: var(--lt-cream);
  line-height: 1.6;
  border: none !important;
  border-left: none !important;
  padding: 0 !important;
  margin: 0 !important;
  background: none !important;
}

.lt-p-pull cite {
  display: block;
  margin-top: 1.2rem;
  font-size: 0.65rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--lt-gold);
  font-style: normal;
}

/* ─── ARTICLE GRID ─── */
.lt-p-articles {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 3rem 5rem;
}

.lt-p-articles-header {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  margin-bottom: 3rem;
}

.lt-p-articles-header::before {
  content: '';
  width: 50px;
  height: 1px;
  background: var(--lt-gold-dim);
}

.lt-p-articles-header h2 {
  font-family: var(--lt-font-display);
  font-size: 1.8rem;
  font-weight: 300;
  color: var(--lt-cream);
}

.lt-p-articles-header h2 em { font-style: italic; color: var(--lt-gold); }

.lt-p-articles-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}

.lt-p-article {
  border: 1px solid var(--lt-line);
  padding: 2.5rem;
  transition: all 0.5s var(--lt-ease-expo);
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
}

.lt-p-article::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--lt-gold);
  transform: scaleX(0);
  transition: transform 0.6s var(--lt-ease-expo);
  transform-origin: left;
}

.lt-p-article:hover { border-color: rgba(201,169,110,0.3); transform: translateY(-4px); }
.lt-p-article:hover::before { transform: scaleX(1); }

.lt-p-article-source {
  font-size: 0.55rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--lt-gold);
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.lt-p-article-source::before {
  content: '';
  width: 8px; height: 8px;
  border: 1px solid var(--lt-gold-dim);
  border-radius: 50%;
  flex-shrink: 0;
}

.lt-p-article-title {
  font-family: var(--lt-font-display);
  font-size: 1.35rem;
  font-weight: 400;
  color: var(--lt-cream);
  line-height: 1.35;
  margin-bottom: 0.8rem;
}

.lt-p-article-excerpt {
  font-size: 0.88rem;
  color: var(--lt-cream-muted);
  line-height: 1.8;
  flex-grow: 1;
}

.lt-p-article-date {
  margin-top: 1.5rem;
  padding-top: 1rem;
  border-top: 1px solid var(--lt-line);
  font-size: 0.6rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--lt-text-muted);
}

.lt-p-article-link {
  color: var(--lt-gold);
  font-size: 0.65rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  float: right;
  transition: opacity 0.3s;
  opacity: 0.6;
}

.lt-p-article-link:hover { opacity: 1; }

/* ─── RATINGS ─── */
.lt-p-ratings {
  border-top: 1px solid var(--lt-line);
  padding: 5rem 3rem;
  text-align: center;
}

.lt-p-ratings-inner { max-width: 800px; margin: 0 auto; }

.lt-p-ratings-label {
  font-size: 0.6rem;
  letter-spacing: 0.5em;
  text-transform: uppercase;
  color: var(--lt-gold);
  margin-bottom: 2.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
}

.lt-p-ratings-label::before,
.lt-p-ratings-label::after {
  content: '';
  width: 40px;
  height: 1px;
  background: var(--lt-gold-dim);
}

.lt-p-ratings-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
}

.lt-p-rating-card {
  padding: 3rem 2rem;
  border: 1px solid var(--lt-line);
  transition: all 0.5s var(--lt-ease-expo);
}

.lt-p-rating-card:hover { border-color: rgba(201,169,110,0.3); }

.lt-p-rating-platform {
  font-size: 0.65rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--lt-text-muted);
  margin-bottom: 1rem;
}

.lt-p-rating-score {
  font-family: var(--lt-font-display);
  font-size: 3.5rem;
  font-weight: 300;
  color: var(--lt-cream);
  line-height: 1;
}

.lt-p-rating-stars {
  color: var(--lt-gold);
  font-size: 1.1rem;
  letter-spacing: 0.1em;
  margin: 0.8rem 0;
}

.lt-p-rating-count {
  font-size: 0.75rem;
  color: var(--lt-text-muted);
}

.lt-p-rating-quote {
  margin-top: 1.5rem;
  padding-top: 1.2rem;
  border-top: 1px solid var(--lt-line);
  font-family: var(--lt-font-display);
  font-style: italic;
  font-size: 0.95rem;
  color: var(--lt-cream-muted);
  line-height: 1.7;
}

/* ─── PRESS CONTACT ─── */
.lt-p-press-contact {
  max-width: 700px;
  margin: 0 auto;
  padding: 5rem 3rem;
  text-align: center;
}

.lt-p-press-contact h2 {
  font-family: var(--lt-font-display);
  font-size: clamp(1.8rem, 3vw, 2.5rem);
  font-weight: 300;
  color: var(--lt-cream);
  margin-bottom: 1rem;
}

.lt-p-press-contact h2 em { font-style: italic; color: var(--lt-gold); }

.lt-p-press-contact > p {
  margin-bottom: 2rem;
  line-height: 1.9;
  color: var(--lt-cream-muted);
}

.lt-p-pc-info {
  display: flex;
  justify-content: center;
  gap: 3rem;
  flex-wrap: wrap;
}

.lt-p-pc-item {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  transition: color 0.3s;
  text-decoration: none;
  color: var(--lt-cream-muted);
}

.lt-p-pc-item:hover { color: var(--lt-gold); }

.lt-p-pc-icon {
  width: 44px; height: 44px;
  border: 1px solid var(--lt-line);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  transition: border-color 0.3s;
}

.lt-p-pc-item:hover .lt-p-pc-icon { border-color: var(--lt-gold-dim); }

.lt-p-pc-detail { text-align: left; }

.lt-p-pc-label {
  font-size: 0.55rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--lt-gold);
  margin-bottom: 0.1rem;
}

.lt-p-pc-value { font-size: 0.9rem; }

/* ─── CTA ─── */
.lt-p-cta {
  text-align: center;
  padding: 4rem 3rem;
  border-top: 1px solid var(--lt-line);
  position: relative;
}

.lt-p-cta::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 50% 0%, rgba(201,169,110,0.04), transparent 60%);
  pointer-events: none;
}

/* ─── REVEAL ─── */
.lt-p-rv {
  opacity: 0;
  transform: translateY(35px);
  transition: opacity 0.8s var(--lt-ease-expo), transform 0.8s var(--lt-ease-expo);
}

.lt-p-rv.lt-p-vis { opacity: 1; transform: translateY(0); }
.lt-p-rv-d1 { transition-delay: 0.1s; }
.lt-p-rv-d2 { transition-delay: 0.2s; }

/* ─── RESPONSIVE ─── */
@media (max-width: 900px) {
  .lt-p-hero { padding: calc(56px + 3rem) 1.5rem 2rem; }
  .lt-p-featured { padding: 3rem 1.5rem; }
  .lt-p-featured-card { grid-template-columns: 1fr; }
  .lt-p-featured-img { min-height: 250px; }
  .lt-p-featured-body { padding: 2rem; }
  .lt-p-articles { padding: 0 1.5rem 3rem; }
  .lt-p-articles-grid { grid-template-columns: 1fr; }
  .lt-p-pull { padding: 3rem 1.5rem; }
  .lt-p-logos-bar { padding: 1.5rem; }
  .lt-p-logos-row { gap: 1.5rem; }
  .lt-p-logo-item { font-size: 1.1rem; }
  .lt-p-ratings { padding: 3rem 1.5rem; }
  .lt-p-ratings-grid { grid-template-columns: 1fr; }
  .lt-p-press-contact { padding: 3rem 1.5rem; }
  .lt-p-pc-info { flex-direction: column; align-items: center; }
  .lt-p-cta { padding: 3rem 1.5rem; }
}

/* ─── DIVI OVERRIDES ─── */
body.page-presse .et_pb_section { overflow: visible !important; }
