/* Skincare Times — editorial design system.
   Fraunces (headlines/masthead), DM Sans (UI/labels), Hanken Grotesk (body).
   Carbon ink #252525 · almond #DAC8C8 · blush #FFD9D9 · white field. */

:root {
  --ink: #252525;
  --soft: rgba(37, 37, 37, 0.66);
  --note: rgba(37, 37, 37, 0.5);
  --line: rgba(37, 37, 37, 0.12);
  --line-soft: rgba(37, 37, 37, 0.07);
  --almond: #dac8c8;
  --blush: #ffd9d9;
  --bg: #fff;
  --wash: #faf7f6;
  --serif: 'Fraunces', Georgia, 'Times New Roman', serif;
  --disp: 'DM Sans', system-ui, -apple-system, sans-serif;
  --body: 'Hanken Grotesk', system-ui, -apple-system, 'Helvetica Neue', Arial, sans-serif;
  --wrap: 1200px;
  --gut: 24px;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--body);
  color: var(--ink);
  background: var(--bg);
  font-size: 17px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: inherit; }
.wrap { max-width: var(--wrap); margin: 0 auto; padding: 0 var(--gut); }

/* ---------- masthead ---------- */
.utility { border-bottom: 1px solid var(--line-soft); font-family: var(--disp); font-size: 12px; color: var(--note); }
.utility__in { display: flex; justify-content: space-between; align-items: center; padding: 8px 0; }
.utility__date { letter-spacing: .02em; }
.utility__links a { margin-left: 18px; text-decoration: none; color: var(--note); }
.utility__links a:hover { color: var(--ink); }
@media (max-width: 640px) { .utility__date { display: none; } .utility__links a:first-child { margin-left: 0; } }

.masthead__brand { text-align: center; padding: 26px 24px 18px; }
.brand {
  font-family: var(--serif);
  font-weight: 900;
  font-size: clamp(40px, 8vw, 76px);
  letter-spacing: -0.01em;
  line-height: 1;
  text-decoration: none;
  color: var(--ink);
  display: inline-block;
}
.brand__tag {
  font-family: var(--disp);
  text-transform: uppercase;
  letter-spacing: .42em;
  font-size: 10px;
  font-weight: 500;
  color: var(--note);
  margin: 12px 0 0;
  padding-left: .42em;
}
.nav { border-top: 1px solid var(--ink); border-bottom: 1px solid var(--ink); position: sticky; top: 0; z-index: 40; background: rgba(255,255,255,.96); backdrop-filter: saturate(1.1) blur(6px); }
.nav__in { display: flex; gap: 26px; justify-content: center; align-items: center; padding: 13px 0; font-family: var(--disp); font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .12em; overflow-x: auto; scrollbar-width: none; }
.nav__in::-webkit-scrollbar { display: none; }
.nav a { text-decoration: none; color: var(--ink); white-space: nowrap; padding-bottom: 2px; border-bottom: 2px solid transparent; }
.nav a:hover { border-color: var(--almond); }
.nav a[aria-current="page"] { border-color: var(--ink); }
.nav__home { opacity: .55; }

/* ---------- kicker / labels ---------- */
.kicker {
  font-family: var(--disp);
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: 11px;
  font-weight: 700;
  color: #b06b6c;
  text-decoration: none;
  display: inline-block;
  margin: 0 0 8px;
}
.kicker--lg { font-size: 12px; margin-bottom: 14px; }

/* ---------- cards / grids ---------- */
.grid { display: grid; gap: 38px 32px; }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px) { .grid--3, .grid--4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .grid--3, .grid--4 { grid-template-columns: 1fr; } }

.card { display: flex; flex-direction: column; }
.card__media { display: block; border-radius: 10px; overflow: hidden; background: var(--wash); aspect-ratio: 3/2; }
.card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.card__media:hover img { transform: scale(1.03); }
.card__body { padding-top: 14px; }
.card__title { font-family: var(--serif); font-weight: 600; line-height: 1.18; letter-spacing: -.01em; margin: 6px 0 8px; font-size: 21px; }
.card--sm .card__title { font-size: 18px; }
.card--lg .card__title { font-size: clamp(26px, 3.4vw, 34px); }
.card__title a { text-decoration: none; }
.card__title a:hover { text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }
.card__dek { color: var(--soft); margin: 0 0 10px; font-size: 15px; }
.card__meta { font-family: var(--disp); font-size: 12px; color: var(--note); margin: 0; }
.card--lg { display: grid; grid-template-columns: 1.2fr 1fr; gap: 32px; align-items: center; }
@media (max-width: 700px) { .card--lg { grid-template-columns: 1fr; } }

/* ---------- homepage hero ---------- */
.hero { padding: 40px 0 18px; border-bottom: 1px solid var(--line); }
.hero__grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: 46px; }
@media (max-width: 880px) { .hero__grid { grid-template-columns: 1fr; gap: 34px; } }
.lead__media { display: block; border-radius: 12px; overflow: hidden; background: var(--wash); aspect-ratio: 3/2; margin-bottom: 18px; }
.lead__media img { width: 100%; height: 100%; object-fit: cover; }
.lead__title { font-family: var(--serif); font-weight: 700; line-height: 1.08; letter-spacing: -.02em; font-size: clamp(30px, 4.6vw, 50px); margin: 6px 0 14px; }
.lead__title a { text-decoration: none; }
.lead__dek { color: var(--soft); font-size: 19px; line-height: 1.5; margin: 0 0 14px; max-width: 42ch; }
.hero__side { display: flex; flex-direction: column; gap: 30px; border-left: 1px solid var(--line); padding-left: 46px; }
@media (max-width: 880px) { .hero__side { border-left: 0; padding-left: 0; } }
.hero__side .card--md { display: grid; grid-template-columns: 1fr 1.3fr; gap: 16px; align-items: start; }
.hero__side .card__media { aspect-ratio: 1/1; }
.hero__side .card__title { font-size: 18px; margin-top: 0; }

/* ---------- river + strips ---------- */
.river { padding: 44px 0; }
.river__head, .strip__head, .cat-head .wrap { margin-bottom: 24px; }
.river__head h2, .strip__head h2 { font-family: var(--disp); font-size: 14px; text-transform: uppercase; letter-spacing: .18em; font-weight: 700; margin: 0; padding-bottom: 10px; border-bottom: 2px solid var(--ink); display: inline-block; }
.strip { padding: 22px 0 40px; border-top: 1px solid var(--line-soft); }
.strip__head { display: flex; justify-content: space-between; align-items: flex-end; }
.strip__head h2 a { text-decoration: none; }
.strip__more { font-family: var(--disp); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--note); text-decoration: none; }
.strip__more:hover { color: var(--ink); }

/* ---------- category + author headers ---------- */
.cat-head { padding: 44px 0 8px; border-bottom: 1px solid var(--line); margin-bottom: 36px; }
.cat-head h1 { font-family: var(--serif); font-size: clamp(38px, 6vw, 62px); font-weight: 700; letter-spacing: -.02em; margin: 0 0 10px; }
.cat-head p { color: var(--soft); font-size: 19px; max-width: 52ch; margin: 0; }
.cat-lead { padding-bottom: 36px; }
.cat-grid { padding-bottom: 60px; }

.author-head { padding: 50px 0; border-bottom: 1px solid var(--line); margin-bottom: 36px; }
.author-head__in { display: flex; gap: 24px; align-items: flex-start; }
.author-head h1 { font-family: var(--serif); font-size: clamp(30px, 4vw, 44px); font-weight: 700; margin: 0 0 4px; }
.author-head__role { font-family: var(--disp); text-transform: uppercase; letter-spacing: .14em; font-size: 12px; font-weight: 700; color: #b06b6c; margin: 0 0 12px; }
.author-head__bio { color: var(--soft); max-width: 60ch; margin: 0; font-size: 17px; }

/* ---------- avatar / monogram ---------- */
.avatar { width: 46px; height: 46px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-family: var(--disp); font-weight: 700; font-size: 15px; flex: none; text-decoration: none; }
.author-head__in .avatar, .author-box .avatar { width: 70px; height: 70px; font-size: 22px; }

/* ---------- article ---------- */
.article-main { padding: 0 0 40px; }
.article { max-width: 720px; margin: 0 auto; padding: 0 var(--gut); }
.article--static { padding-top: 40px; }
.crumb { font-family: var(--disp); font-size: 12px; color: var(--note); margin: 30px 0 14px; }
.crumb a { text-decoration: none; } .crumb a:hover { color: var(--ink); }
.crumb span { margin: 0 6px; }
.article__title { font-family: var(--serif); font-weight: 700; font-size: clamp(32px, 5vw, 50px); line-height: 1.07; letter-spacing: -.02em; margin: 0 0 16px; }
.article__dek { font-family: var(--serif); font-style: italic; font-size: clamp(19px, 2.6vw, 24px); line-height: 1.4; color: var(--soft); margin: 0 0 26px; }
.byline { display: flex; align-items: center; gap: 14px; padding: 18px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.byline__txt { display: flex; flex-direction: column; line-height: 1.4; }
.byline__name { font-family: var(--disp); font-weight: 700; font-size: 15px; }
.byline__name a { text-decoration: none; }
.byline__sub { font-family: var(--disp); font-size: 12px; color: var(--note); }
.article__hero { margin: 26px 0 30px; border-radius: 12px; overflow: hidden; background: var(--wash); }
.article__hero img { width: 100%; }

/* prose */
.prose { font-size: 19px; line-height: 1.72; }
.prose p { margin: 0 0 1.35em; }
.prose h2 { font-family: var(--serif); font-weight: 600; font-size: 28px; line-height: 1.2; letter-spacing: -.01em; margin: 1.8em 0 .5em; }
.prose h3 { font-family: var(--disp); font-weight: 700; font-size: 19px; margin: 1.6em 0 .4em; }
.prose a { color: #a85f60; text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 2px; }
.prose strong { font-weight: 700; }
.prose ul, .prose ol { margin: 0 0 1.35em; padding-left: 1.3em; }
.prose li { margin: 0 0 .5em; }
.prose blockquote { margin: 1.6em 0; padding: 4px 0 4px 24px; border-left: 3px solid var(--almond); }
.prose blockquote p { font-family: var(--serif); font-style: italic; font-size: 24px; line-height: 1.35; color: var(--ink); margin: 0; }
.prose hr { border: 0; border-top: 1px solid var(--line); margin: 2.4em 0; }
.prose code { font-family: ui-monospace, monospace; font-size: .9em; background: var(--wash); padding: 1px 5px; border-radius: 4px; }
.prose .article-figure { margin: 1.8em 0; }
.prose .article-figure img { border-radius: 10px; width: 100%; }

.author-box { display: flex; gap: 18px; align-items: flex-start; margin: 44px 0 0; padding: 26px; background: var(--wash); border-radius: 12px; }
.author-box__name { font-family: var(--disp); font-weight: 700; font-size: 16px; display: block; }
.author-box__name a { text-decoration: none; }
.author-box__role { font-family: var(--disp); font-size: 12px; text-transform: uppercase; letter-spacing: .12em; color: #b06b6c; display: block; margin-bottom: 8px; }
.author-box p { margin: 0; color: var(--soft); font-size: 15px; }

.related { margin-top: 56px; padding: 40px 0; border-top: 1px solid var(--line); background: var(--wash); }
.related__h { font-family: var(--disp); font-size: 14px; text-transform: uppercase; letter-spacing: .16em; margin: 0 0 24px; }

/* ---------- newsletter + footer ---------- */
.newsletter { background: var(--ink); color: #fff; margin-top: 60px; }
.newsletter__in { display: flex; justify-content: space-between; align-items: center; gap: 30px; padding: 46px 0; flex-wrap: wrap; }
.newsletter h3 { font-family: var(--serif); font-weight: 600; font-size: clamp(24px, 3vw, 32px); margin: 0 0 6px; }
.newsletter p { color: rgba(255,255,255,.7); margin: 0; max-width: 46ch; }
.newsletter__form { display: flex; gap: 10px; flex: 1 1 320px; max-width: 440px; }
.newsletter__form input { flex: 1; border: 0; border-radius: 999px; padding: 14px 18px; font-family: var(--body); font-size: 15px; }
.newsletter__form button { border: 0; border-radius: 999px; background: var(--almond); color: var(--ink); font-family: var(--disp); font-weight: 700; padding: 14px 24px; cursor: pointer; }
.newsletter__form button:hover { background: #fff; }

.foot { background: #1b1b1b; color: rgba(255,255,255,.7); }
.foot__in { display: grid; grid-template-columns: 1.4fr 2fr; gap: 50px; padding: 56px 0 40px; }
@media (max-width: 760px) { .foot__in { grid-template-columns: 1fr; gap: 36px; } }
.foot__name { font-family: var(--serif); font-weight: 700; font-size: 26px; color: #fff; }
.foot__brand p { font-size: 14px; line-height: 1.6; margin: 14px 0 18px; max-width: 42ch; }
.foot__social a { font-family: var(--disp); font-size: 13px; font-weight: 700; color: #fff; text-decoration: none; margin-right: 18px; }
.foot__social a:hover { color: var(--almond); }
.foot__cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
@media (max-width: 480px) { .foot__cols { grid-template-columns: repeat(2, 1fr); } }
.foot__col h4 { font-family: var(--disp); font-size: 12px; text-transform: uppercase; letter-spacing: .14em; color: #fff; margin: 0 0 14px; }
.foot__col ul { list-style: none; margin: 0; padding: 0; }
.foot__col li { margin: 0 0 10px; }
.foot__col a { font-size: 14px; text-decoration: none; }
.foot__col a:hover { color: #fff; }
.foot__legal { display: flex; justify-content: space-between; gap: 12px; padding: 18px 0 40px; font-family: var(--disp); font-size: 12px; color: rgba(255,255,255,.5); flex-wrap: wrap; border-top: 1px solid rgba(255,255,255,.1); }
.foot__legal a { text-decoration: none; }
