/* ============================================================
   OPULENCE BEAUTY — The Journal (blog hub + article)
   Hub uses the dark site theme. Articles use a warm
   cream "paper" reading surface framed by dark site chrome.
   ============================================================ */

/* ─────────────────────────────────────────────
   HUB — index of entries (dark theme)
   ───────────────────────────────────────────── */

/* Editorial standfirst under the hero — sets topical authority for AEO */
.journal-intro{ max-width:780px; }
.journal-intro p{ font-size:clamp(1.05rem,1.6vw,1.28rem); color:var(--cream-dim); line-height:1.9; font-weight:300; }
.journal-intro p + p{ margin-top:1.1em; }
.journal-intro strong{ color:var(--cream); font-weight:400; }

/* Author / expertise strip (E-E-A-T) */
.journal-author{ display:flex; align-items:center; gap:20px; margin-top:40px; padding-top:30px; border-top:1px solid var(--line-soft); }
.journal-author img{ width:66px; height:66px; border-radius:50%; object-fit:cover; border:1px solid var(--gold); flex:none; }
.journal-author .ja-name{ font-family:var(--font-display); font-size:1.35rem; color:var(--cream); line-height:1.2; }
.journal-author .ja-role{ font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); margin-top:5px; }
.journal-author .ja-meta{ font-size:.9rem; color:var(--cream-mute); margin-top:7px; max-width:54ch; line-height:1.6; }

/* Topic chips — content shape for browse + AI topical mapping */
.topic-row{ display:flex; flex-wrap:wrap; gap:12px; margin-top:8px; }
.topic-chip{ font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--cream-dim); border:1px solid var(--line); border-radius:100px; padding:9px 18px; transition:color .4s var(--ease), border-color .4s var(--ease), background .4s var(--ease); }
.topic-chip:hover{ color:var(--gold); border-color:var(--gold); }
.topic-chip.is-on{ color:var(--ink); background:var(--gold); border-color:var(--gold); }

/* Featured entry */
.feat-card{ display:grid; grid-template-columns:1.15fr 1fr; gap:clamp(28px,5vw,64px); align-items:center; border:1px solid var(--line); border-radius:6px; overflow:hidden; background:linear-gradient(180deg,rgba(27,23,18,0.5),rgba(16,14,11,0.3)); transition:border-color .5s var(--ease); }
.feat-card:hover{ border-color:rgba(201,162,75,0.5); }
.feat-card .fc-media{ position:relative; aspect-ratio:5/4; overflow:hidden; }
.feat-card .fc-media img{ width:100%; height:100%; object-fit:cover; transition:transform 1.2s var(--ease-out); }
.feat-card:hover .fc-media img{ transform:scale(1.05); }
.feat-card .fc-body{ padding:clamp(28px,4vw,52px) clamp(28px,4vw,52px) clamp(28px,4vw,52px) 0; }
.feat-card .fc-cat{ font-size:.68rem; letter-spacing:.24em; text-transform:uppercase; color:var(--gold); }
.feat-card .fc-title{ font-family:var(--font-display); font-weight:300; font-size:clamp(1.9rem,3.6vw,3rem); line-height:1.08; color:var(--cream); margin:16px 0 18px; }
.feat-card .fc-excerpt{ color:var(--cream-dim); font-size:1.02rem; line-height:1.8; margin-bottom:26px; max-width:48ch; }
.feat-card .fc-meta{ display:flex; gap:14px; align-items:center; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--cream-mute); margin-bottom:26px; }
.feat-card .fc-meta .dot{ width:4px; height:4px; border-radius:50%; background:var(--gold); }
.feat-card .fc-flag{ position:absolute; top:18px; left:18px; z-index:3; font-size:.6rem; letter-spacing:.22em; text-transform:uppercase; color:var(--ink); background:var(--gold); padding:6px 14px; border-radius:100px; }

/* Grid of further entries */
.post-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(22px,3vw,38px); margin-top:clamp(40px,6vw,72px); }
.post-card{ display:flex; flex-direction:column; border:1px solid var(--line); border-radius:6px; overflow:hidden; background:linear-gradient(180deg,rgba(27,23,18,0.45),rgba(16,14,11,0.25)); transition:border-color .5s var(--ease), transform .5s var(--ease); }
.post-card:hover{ border-color:rgba(201,162,75,0.5); transform:translateY(-6px); }
.post-card .pc-media{ aspect-ratio:4/3; overflow:hidden; }
.post-card .pc-media img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease-out); }
.post-card:hover .pc-media img{ transform:scale(1.06); }
.post-card .pc-body{ padding:26px 26px 30px; display:flex; flex-direction:column; flex:1; }
.post-card .pc-cat{ font-size:.64rem; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); }
.post-card .pc-title{ font-family:var(--font-display); font-weight:300; font-size:1.55rem; line-height:1.15; color:var(--cream); margin:13px 0 12px; }
.post-card .pc-excerpt{ font-size:.92rem; color:var(--cream-mute); line-height:1.7; margin-bottom:20px; }
.post-card .pc-meta{ margin-top:auto; font-size:.68rem; letter-spacing:.14em; text-transform:uppercase; color:var(--cream-faint); }

/* "More coming" placeholder card */
.post-card.soon{ align-items:center; justify-content:center; text-align:center; padding:46px 30px; border-style:dashed; background:none; }
.post-card.soon:hover{ transform:none; }
.post-card.soon .ps-mark{ font-family:var(--font-display); font-size:2.4rem; color:var(--gold); line-height:1; margin-bottom:16px; }
.post-card.soon p{ font-size:.92rem; color:var(--cream-mute); line-height:1.7; max-width:30ch; }

@media (max-width:980px){
  .feat-card{ grid-template-columns:1fr; }
  .feat-card .fc-body{ padding:0 clamp(24px,5vw,40px) clamp(30px,6vw,44px); }
  .feat-card .fc-media{ aspect-ratio:16/10; }
  .post-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:600px){
  .post-grid{ grid-template-columns:1fr; }
  .journal-author{ flex-direction:column; align-items:flex-start; }
}

/* ─────────────────────────────────────────────
   ARTICLE — cream reading surface
   ───────────────────────────────────────────── */
.journal-paper{ background:var(--cream); color:#1e1b18; position:relative; z-index:2; }
.journal-paper ::selection{ background:var(--gold); color:#fff; }

/* article-scoped tokens */
.jp{
  --jp-text:#272320;
  --jp-ink:#0a0908;
  --jp-muted:#6b6259;
  --jp-line:#e3d9c8;
  --jp-line-soft:#ece3d4;
  --jp-tint:rgba(201,162,75,0.07);
}

.jp-wrap{ max-width:752px; margin:0 auto; padding:clamp(48px,7vw,86px) var(--gutter) clamp(56px,8vw,96px); }

/* Quick-answer / TL;DR box — primes AI extraction + featured snippets */
.jp-tldr{ border:1px solid var(--jp-line); border-left:3px solid var(--gold); border-radius:0 6px 6px 0; background:var(--jp-tint); padding:24px 28px; margin-bottom:46px; }
.jp-tldr .tl-label{ font-family:var(--font-sans); font-size:.64rem; letter-spacing:.26em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:12px; }
.jp-tldr p{ font-family:var(--font-display); font-size:1.18rem; line-height:1.6; color:var(--jp-ink); margin:0; font-weight:400; }

/* Key takeaways */
.jp-takeaways{ border:1px solid var(--jp-line); border-radius:6px; padding:26px 30px; margin:14px 0 40px; }
.jp-takeaways h2{ font-family:var(--font-sans) !important; font-size:.68rem !important; letter-spacing:.26em; text-transform:uppercase; color:var(--gold-deep); margin:0 0 16px !important; font-weight:500; }
.jp-takeaways ul{ list-style:none; margin:0; padding:0; }
.jp-takeaways li{ position:relative; padding:8px 0 8px 26px; font-size:.97rem; line-height:1.6; color:var(--jp-text); border-top:1px solid var(--jp-line-soft); }
.jp-takeaways li:first-child{ border-top:none; }
.jp-takeaways li::before{ content:"✦"; position:absolute; left:0; top:9px; color:var(--gold); font-size:.7rem; }

.jp-lead{ font-family:var(--font-display); font-size:clamp(1.22rem,2.2vw,1.5rem); font-weight:400; line-height:1.62; color:var(--jp-ink); margin-bottom:40px; padding-bottom:38px; border-bottom:1px solid var(--jp-line); }

.jp-wrap p{ font-size:1.04rem; line-height:1.86; margin:0 0 1.4rem; color:var(--jp-text); }
.jp-wrap p a{ color:var(--gold-deep); border-bottom:1px solid var(--gold); }
.jp-wrap p a:hover{ color:var(--ink); }
.jp-wrap em{ font-style:italic; }
.jp-wrap strong{ font-weight:500; color:var(--jp-ink); }

.jp-wrap h2{ font-family:var(--font-display); font-weight:400; font-size:clamp(1.7rem,3.2vw,2.3rem); line-height:1.2; color:var(--jp-ink); margin:3.4rem 0 .5rem; }
.jp-wrap h3{ font-family:var(--font-display); font-weight:500; font-size:1.32rem; color:var(--jp-ink); margin:2.2rem 0 .6rem; }
.jp-rule{ display:block; width:50px; height:1px; background:var(--gold); margin:0 0 1.3rem; }

/* callout */
.jp-callout{ border-left:3px solid var(--gold); margin:2.6rem 0; padding:6px 0 6px 28px; }
.jp-callout p{ font-family:var(--font-display); font-size:1.42rem; font-style:italic; font-weight:400; color:var(--jp-ink); line-height:1.5; margin:0; }
.jp-callout cite{ display:block; margin-top:.7rem; font-family:var(--font-sans); font-size:.68rem; font-style:normal; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-deep); }

/* comparison table */
.jp-table{ width:100%; border-collapse:collapse; margin:2rem 0; font-size:.92rem; }
.jp-table th{ background:var(--jp-ink); color:var(--gold); font-family:var(--font-sans); font-weight:500; letter-spacing:.1em; text-transform:uppercase; font-size:.66rem; padding:13px 16px; text-align:left; }
.jp-table td{ padding:13px 16px; border-bottom:1px solid var(--jp-line); vertical-align:top; color:var(--jp-text); line-height:1.55; }
.jp-table tr:nth-child(even) td{ background:var(--jp-tint); }
.jp-table strong{ color:var(--jp-ink); }

/* checklist */
.jp-list{ list-style:none; margin:1rem 0 1.8rem; padding:0; }
.jp-list li{ position:relative; padding:.4rem 0 .4rem 1.7rem; font-size:1rem; line-height:1.6; color:var(--jp-text); }
.jp-list li::before{ content:"✦"; position:absolute; left:0; top:.62rem; color:var(--gold); font-size:.68rem; }

/* FAQ — visually distinct, schema-mirrored */
.jp-faq{ margin:1.6rem 0; }
.jp-faq .faq-item{ border-top:1px solid var(--jp-line); padding:1.5rem 0; }
.jp-faq .faq-item:last-child{ border-bottom:1px solid var(--jp-line); }
.jp-faq .faq-q{ font-family:var(--font-display); font-size:1.2rem; font-weight:500; color:var(--jp-ink); margin-bottom:.55rem; }
.jp-faq .faq-q::before{ content:"Q. "; color:var(--gold); }
.jp-faq .faq-item p{ margin:0; }

/* dark inset (about the studio) */
.jp-inset{ background:var(--jp-ink); color:var(--cream); padding:34px 38px; border-radius:6px; margin:3rem 0; }
.jp-inset h3{ color:var(--gold-soft); font-family:var(--font-display); font-size:1.4rem; font-weight:400; margin:0 0 .9rem; }
.jp-inset p{ color:var(--cream-dim); font-size:.97rem; line-height:1.8; margin-bottom:.8rem; }
.jp-inset p:last-of-type{ margin-bottom:0; }
.jp-inset .jp-btn{ display:inline-flex; margin-top:1.4rem; background:var(--gold); color:var(--jp-ink); font-family:var(--font-sans); font-size:.72rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; padding:14px 30px; border-radius:2px; transition:background .4s var(--ease); }
.jp-inset .jp-btn:hover{ background:var(--gold-soft); }

/* author bio (E-E-A-T) */
.jp-author{ display:flex; gap:22px; align-items:flex-start; padding:30px; background:#ece3d4; border-radius:6px; margin:4rem 0 0; }
.jp-author img{ width:84px; height:84px; border-radius:50%; object-fit:cover; flex:none; border:2px solid var(--gold); }
.jp-author h4{ font-family:var(--font-display); font-size:1.3rem; font-weight:500; color:var(--jp-ink); margin:0 0 .35rem; }
.jp-author .jp-au-role{ font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:.7rem; }
.jp-author p{ font-size:.92rem; color:var(--jp-muted); margin:0; line-height:1.68; }
.jp-author .jp-au-links{ margin-top:.85rem; display:flex; gap:18px; }
.jp-author .jp-au-links a{ font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--gold-deep); border-bottom:1px solid var(--gold); padding-bottom:2px; }

/* fact box / byline strip */
.jp-byline{ display:flex; flex-wrap:wrap; gap:10px 22px; align-items:center; font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--jp-muted); margin-bottom:8px; }
.jp-byline .sep{ width:4px; height:4px; border-radius:50%; background:var(--gold); }
.jp-byline b{ color:var(--gold-deep); font-weight:500; }

/* related / continue reading (internal links for crawl depth) */
.jp-related{ border-top:1px solid var(--jp-line); margin-top:3.2rem; padding-top:2.4rem; }
.jp-related .jr-label{ font-size:.66rem; letter-spacing:.24em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:20px; }
.jp-related-grid{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.jp-related a{ display:block; padding:20px 22px; border:1px solid var(--jp-line); border-radius:6px; transition:border-color .4s var(--ease), background .4s var(--ease); }
.jp-related a:hover{ border-color:var(--gold); background:var(--jp-tint); }
.jp-related a .jr-cat{ font-size:.62rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-deep); }
.jp-related a .jr-t{ font-family:var(--font-display); font-size:1.22rem; color:var(--jp-ink); line-height:1.2; margin-top:8px; }

@media (max-width:600px){
  .jp-author{ flex-direction:column; }
  .jp-table{ font-size:.82rem; }
  .jp-table th, .jp-table td{ padding:9px 10px; }
  .jp-related-grid{ grid-template-columns:1fr; }
}
