/* ================================================================
   NY.COM.BR - Complete Stylesheet
   Beautiful, Responsive Travel Guide Design
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;700;800;900&family=DM+Sans:wght@400;500;600;700&family=Inter:wght@400;500;600;700&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root {
  --black: #0d0d0d;
  --white: #ffffff;
  --off-white: #faf9f7;
  --cream: #f3efe8;
  --sand: #e8e0d4;
  --warm-100: #d4cdc3;
  --warm-300: #9e9588;
  --warm-500: #6b6158;
  --warm-700: #3d352e;
  --gold: #b8860b;
  --gold-light: #d4a93c;
  --gold-dark: #8b6508;
  --terracotta: #c0604b;
  --deep-blue: #1a365d;
  --sage: #7c9070;

  --font-display: 'Playfair Display', Georgia, 'Times New Roman', serif;
  --font-body: 'DM Sans', 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-ui: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;

  --max-w: 1440px;
  --content-w: 800px;
  --radius: 6px;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.08), 0 2px 4px rgba(0,0,0,0.04);
  --shadow-lg: 0 12px 40px rgba(0,0,0,0.12), 0 4px 12px rgba(0,0,0,0.06);
  --transition: 0.35s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

html { font-size:16px; scroll-behavior:smooth; -webkit-font-smoothing:antialiased; }
body { font-family:var(--font-body); color:var(--warm-700); background:var(--off-white); line-height:1.7; overflow-x:hidden; }
img { max-width:100%; height:auto; display:block; }
a { color:inherit; text-decoration:none; }
ul,ol { list-style:none; }

h1,h2,h3,h4,h5,h6 {
  font-family:var(--font-display);
  font-weight:700;
  line-height:1.12;
  color:var(--black);
  letter-spacing:-0.02em;
}

/* ─── CONTAINER ─── */
.container {
  max-width:var(--max-w);
  margin:0 auto;
  padding:0 2rem;
}

/* ─── TOPBAR ─── */
.topbar {
  background:var(--black);
  color:rgba(255,255,255,0.5);
  font-family:var(--font-ui);
  font-size:0.7rem;
  font-weight:500;
  letter-spacing:0.08em;
  text-transform:uppercase;
  padding:0.55rem 0;
}
.topbar__inner {
  max-width:var(--max-w);
  margin:0 auto;
  padding:0 2rem;
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.topbar a { color:rgba(255,255,255,0.5); transition:color var(--transition); }
.topbar a:hover { color:var(--gold-light); }
.topbar__links { display:flex; gap:1.5rem; }

/* ─── HEADER ─── */
.header {
  background:var(--off-white);
  border-bottom:1px solid var(--sand);
  position:sticky;
  top:0;
  z-index:100;
  transition:box-shadow var(--transition), background var(--transition);
}
.header.scrolled {
  background:rgba(250,249,247,0.95);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  box-shadow:0 1px 20px rgba(0,0,0,0.06);
}
.header__inner {
  max-width:var(--max-w);
  margin:0 auto;
  padding:0.85rem 2rem;
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.logo {
  font-family:var(--font-display);
  font-size:2rem;
  font-weight:900;
  letter-spacing:-0.04em;
  color:var(--black);
  line-height:1;
}
.logo span { color:var(--gold); }
.logo small {
  display:block;
  font-family:var(--font-ui);
  font-size:0.52rem;
  font-weight:600;
  letter-spacing:0.25em;
  text-transform:uppercase;
  color:var(--warm-300);
  margin-top:2px;
}

.nav { display:flex; align-items:center; gap:2rem; }
.nav__link {
  font-family:var(--font-ui);
  font-size:0.72rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.1em;
  color:var(--warm-500);
  position:relative;
  padding:0.25em 0;
  transition:color var(--transition);
}
.nav__link::after {
  content:'';
  position:absolute;
  bottom:-3px;
  left:0;
  width:0;
  height:2px;
  background:var(--gold);
  transition:width var(--transition);
}
.nav__link:hover { color:var(--black); }
.nav__link:hover::after { width:100%; }

.nav__search {
  width:36px; height:36px;
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--sand);
  border-radius:50%;
  cursor:pointer;
  transition:all var(--transition);
}
.nav__search:hover { border-color:var(--gold); color:var(--gold); }

/* ─── HAMBURGER MENU ─── */
.hamburger {
  display:none;
  flex-direction:column;
  gap:5px;
  background:none;
  border:none;
  cursor:pointer;
  padding:0.5rem;
  z-index:101;
}
.hamburger span {
  width:24px;
  height:2px;
  background:var(--black);
  border-radius:2px;
  transition:all var(--transition);
}
.hamburger.active span:nth-child(1) {
  transform:rotate(45deg) translate(8px, 8px);
}
.hamburger.active span:nth-child(2) {
  opacity:0;
}
.hamburger.active span:nth-child(3) {
  transform:rotate(-45deg) translate(8px, -8px);
}

/* ─── MOBILE NAVIGATION ─── */
.mobile-nav {
  display:none;
  position:fixed;
  inset:0;
  background:var(--off-white);
  z-index:99;
  padding:4rem 2rem 2rem;
  overflow-y:auto;
}
.mobile-nav.active { display:block; }
.mobile-nav__close {
  position:absolute;
  top:1.5rem;
  right:1.5rem;
  background:none;
  border:none;
  font-size:2rem;
  cursor:pointer;
}
.mobile-nav a {
  display:block;
  padding:0.75rem 0;
  font-family:var(--font-ui);
  font-size:0.9rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:var(--warm-700);
  border-bottom:1px solid var(--sand);
}

/* ─── SEARCH OVERLAY ─── */
.search-overlay {
  display:none;
  position:fixed;
  inset:0;
  background:rgba(13,13,13,0.85);
  backdrop-filter:blur(4px);
  z-index:102;
  justify-content:center;
  align-items:center;
}
.search-overlay.active { display:flex; }
.search-overlay__close {
  position:absolute;
  top:2rem;
  right:2rem;
  background:none;
  border:none;
  font-size:2rem;
  color:#fff;
  cursor:pointer;
}
.search-overlay__inner {
  width:100%;
  max-width:500px;
  padding:0 2rem;
}
.search-overlay__input {
  width:100%;
  padding:1.2em 1.5em;
  background:#fff;
  border:none;
  border-radius:var(--radius);
  font-family:var(--font-body);
  font-size:1.1rem;
  outline:none;
}

/* ─── HERO ─── */
.hero {
  position:relative;
  height:92vh;
  min-height:600px;
  display:flex;
  align-items:flex-end;
  overflow:hidden;
}
.hero__img {
  position:absolute;
  inset:0;
}
.hero__img img {
  width:100%; height:100%;
  object-fit:cover;
  filter:brightness(0.85) contrast(1.05);
}
.hero__overlay {
  position:absolute; inset:0;
  background:linear-gradient(
    175deg,
    transparent 30%,
    rgba(13,13,13,0.35) 50%,
    rgba(13,13,13,0.85) 75%,
    rgba(13,13,13,0.97) 100%
  );
}
.hero__content {
  position:relative;
  z-index:2;
  max-width:var(--max-w);
  margin:0 auto;
  padding:0 2rem 4.5rem;
  width:100%;
}
.hero__badge {
  display:inline-flex;
  align-items:center;
  gap:0.5rem;
  font-family:var(--font-ui);
  font-size:0.65rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.15em;
  color:var(--gold-light);
  margin-bottom:1.25rem;
  padding:0.5em 1em;
  border:1px solid rgba(212,169,60,0.4);
  border-radius:2px;
  backdrop-filter:blur(4px);
}
.hero__badge::before {
  content:'';
  width:6px; height:6px;
  background:var(--gold-light);
  border-radius:50%;
  animation:pulse 2s infinite;
}
@keyframes pulse {
  0%,100%{opacity:1} 50%{opacity:0.3}
}
.hero h1 {
  color:#fff;
  font-size:clamp(2.4rem, 5.5vw, 4.2rem);
  max-width:750px;
  margin-bottom:1rem;
  font-weight:800;
  line-height:1.08;
  letter-spacing:-0.03em;
}
.hero__excerpt {
  color:rgba(255,255,255,0.75);
  font-size:1.1rem;
  max-width:550px;
  line-height:1.65;
  margin-bottom:1.5rem;
}
.hero__meta {
  display:flex;
  align-items:center;
  gap:1rem;
  color:rgba(255,255,255,0.4);
  font-family:var(--font-ui);
  font-size:0.78rem;
  font-weight:500;
}
.hero__meta .dot { width:3px; height:3px; border-radius:50%; background:rgba(255,255,255,0.3); }

/* ─── SECTION ─── */
.section {
  max-width:var(--max-w);
  margin:0 auto;
  padding:4.5rem 2rem;
}
.section--gray { background:var(--cream); }
.section--dark { background:var(--black); }

.section-head {
  display:flex;
  align-items:baseline;
  gap:1.5rem;
  margin-bottom:2.5rem;
}
.section-head h2 {
  font-size:clamp(1.5rem, 3vw, 2.2rem);
  white-space:nowrap;
  position:relative;
}
.section-head__line {
  flex:1;
  height:1px;
  background:var(--sand);
  margin-top:0.5em;
}
.section-head__link {
  font-family:var(--font-ui);
  font-size:0.72rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:var(--gold);
  white-space:nowrap;
  transition:color var(--transition);
  display:flex;
  align-items:center;
  gap:0.4rem;
}
.section-head__link:hover { color:var(--gold-dark); }
.section-head__link svg { transition:transform var(--transition); }
.section-head__link:hover svg { transform:translateX(3px); }

/* ─── CARDS ─── */
.grid { display:grid; gap:1.75rem; }
.grid-4 { grid-template-columns:repeat(4, 1fr); }
.grid-3 { grid-template-columns:repeat(3, 1fr); }
.grid-2 { grid-template-columns:repeat(2, 1fr); }
.grid-featured { grid-template-columns:1.4fr 1fr 1fr; }

.card {
  display:flex;
  flex-direction:column;
  border-radius:var(--radius);
  overflow:hidden;
  background:var(--white);
  border:1px solid transparent;
  transition:all var(--transition);
  cursor:pointer;
}
.card:hover {
  border-color:var(--sand);
  box-shadow:var(--shadow-md);
  transform:translateY(-4px);
}
.card__img {
  position:relative;
  overflow:hidden;
  aspect-ratio:16/10;
}
.card__img img {
  width:100%; height:100%;
  object-fit:cover;
  transition:transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.card:hover .card__img img {
  transform:scale(1.06);
}
.card__badge {
  position:absolute;
  top:0.75rem;
  left:0.75rem;
  font-family:var(--font-ui);
  font-size:0.6rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.1em;
  color:#fff;
  background:var(--gold);
  padding:0.35em 0.75em;
  border-radius:2px;
  z-index:1;
}
.card__body {
  padding:1.25rem;
  display:flex;
  flex-direction:column;
  flex:1;
}
.card__cat {
  font-family:var(--font-ui);
  font-size:0.62rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.12em;
  color:var(--gold);
  margin-bottom:0.5rem;
}
.card__title {
  font-family:var(--font-display);
  font-size:1.15rem;
  font-weight:700;
  line-height:1.3;
  color:var(--black);
  margin-bottom:0.6rem;
  transition:color var(--transition);
}
.card:hover .card__title { color:var(--gold-dark); }

.card__excerpt {
  font-size:0.88rem;
  color:var(--warm-500);
  line-height:1.6;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  margin-bottom:auto;
}
.card__footer {
  display:flex;
  align-items:center;
  gap:0.75rem;
  margin-top:1rem;
  padding-top:0.85rem;
  border-top:1px solid var(--cream);
  font-family:var(--font-ui);
  font-size:0.7rem;
  color:var(--warm-300);
  font-weight:500;
}
.card__footer .dot { width:3px; height:3px; border-radius:50%; background:var(--warm-100); }

/* Card Large */
.card--lg .card__img { aspect-ratio:3/2; }
.card--lg .card__title { font-size:1.6rem; line-height:1.2; }
.card--lg .card__excerpt { -webkit-line-clamp:3; font-size:0.95rem; }

/* Card Horizontal */
.card--h {
  flex-direction:row;
  align-items:stretch;
}
.card--h .card__img {
  width:240px;
  flex-shrink:0;
  aspect-ratio:auto;
}
.card--h .card__body { justify-content:center; }

/* Card Minimal - Sidebar */
.card--min {
  background:transparent;
  border:none;
  border-radius:0;
  border-bottom:1px solid var(--sand);
  padding-bottom:1rem;
  flex-direction:row;
  gap:1rem;
  align-items:flex-start;
}
.card--min:hover {
  border-color:var(--sand);
  box-shadow:none;
  transform:none;
}
.card--min .card__num {
  font-family:var(--font-display);
  font-size:2.5rem;
  font-weight:800;
  color:var(--sand);
  line-height:1;
  flex-shrink:0;
  width:40px;
}
.card--min .card__title { font-size:0.95rem; margin-bottom:0.25rem; }
.card--min .card__cat { margin-bottom:0.3rem; }

/* ─── FEATURED BLOCK ─── */
.feature-block {
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:480px;
  overflow:hidden;
  border-radius:var(--radius);
  margin-bottom:0;
}
.feature-block__img {
  position:relative;
  overflow:hidden;
}
.feature-block__img img {
  width:100%; height:100%;
  object-fit:cover;
  transition:transform 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.feature-block:hover .feature-block__img img { transform:scale(1.04); }
.feature-block__body {
  background:var(--cream);
  padding:3.5rem;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.feature-block__body .label-tag {
  font-family:var(--font-ui);
  font-size:0.62rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.15em;
  color:var(--gold);
  margin-bottom:1rem;
  display:flex;
  align-items:center;
  gap:0.5rem;
}
.feature-block__body .label-tag::before {
  content:'';
  width:20px;
  height:2px;
  background:var(--gold);
}
.feature-block__body h2 {
  font-size:clamp(1.6rem, 3vw, 2.4rem);
  margin-bottom:1rem;
  line-height:1.15;
}
.feature-block__body p {
  font-size:1rem;
  color:var(--warm-500);
  line-height:1.7;
  margin-bottom:1.5rem;
}
.feature-block__body .cta {
  display:inline-flex;
  align-items:center;
  gap:0.5rem;
  font-family:var(--font-ui);
  font-size:0.75rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:var(--black);
  border-bottom:2px solid var(--gold);
  padding-bottom:0.2em;
  transition:all var(--transition);
}
.feature-block__body .cta:hover { color:var(--gold-dark); }

/* ─── EDITORIAL SPLIT ─── */
.editorial-split {
  display:grid;
  grid-template-columns:2fr 1fr;
  gap:3.5rem;
}
.sidebar-title {
  font-family:var(--font-ui);
  font-size:0.68rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.14em;
  color:var(--black);
  padding-bottom:0.75rem;
  border-bottom:2px solid var(--black);
  margin-bottom:1.25rem;
}

/* ─── CATEGORY PILLS ─── */
.pills {
  display:flex;
  flex-wrap:wrap;
  gap:0.6rem;
  justify-content:center;
}
.pill {
  display:inline-flex;
  align-items:center;
  gap:0.4rem;
  padding:0.65em 1.4em;
  font-family:var(--font-ui);
  font-size:0.75rem;
  font-weight:600;
  letter-spacing:0.03em;
  border:1px solid var(--sand);
  border-radius:100px;
  color:var(--warm-700);
  transition:all var(--transition);
  cursor:pointer;
  background:var(--white);
}
.pill:hover {
  background:var(--black);
  color:var(--white);
  border-color:var(--black);
  transform:translateY(-2px);
  box-shadow:var(--shadow-sm);
}
.pill__icon { font-size:1.05em; }

/* ─── NEWSLETTER ─── */
.newsletter {
  background:var(--black);
  padding:5rem 2rem;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.newsletter::before {
  content:'NYC';
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%, -50%);
  font-family:var(--font-display);
  font-size:25rem;
  font-weight:900;
  color:rgba(255,255,255,0.02);
  pointer-events:none;
  letter-spacing:-0.05em;
}
.newsletter h2 {
  color:#fff;
  font-size:clamp(1.6rem, 3vw, 2.4rem);
  margin-bottom:0.5rem;
}
.newsletter p {
  color:rgba(255,255,255,0.5);
  font-size:1rem;
  margin-bottom:2rem;
}
.newsletter__form {
  display:flex;
  max-width:460px;
  margin:0 auto;
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid rgba(255,255,255,0.12);
}
.newsletter__input {
  flex:1;
  padding:1em 1.3em;
  background:rgba(255,255,255,0.06);
  border:none;
  color:#fff;
  font-family:var(--font-body);
  font-size:0.9rem;
  outline:none;
}
.newsletter__input::placeholder { color:rgba(255,255,255,0.3); }
.newsletter__input:focus { background:rgba(255,255,255,0.1); }
.newsletter__btn {
  padding:1em 2em;
  background:var(--gold);
  color:#fff;
  border:none;
  font-family:var(--font-ui);
  font-size:0.75rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.1em;
  cursor:pointer;
  transition:background var(--transition);
}
.newsletter__btn:hover { background:var(--gold-dark); }

/* ─── STATS BAR ─── */
.stats-bar {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--sand);
  border-bottom:1px solid var(--sand);
  text-align:center;
}
.stats-bar__item {
  padding:2rem 1rem;
  border-right:1px solid var(--sand);
}
.stats-bar__item:last-child { border-right:none; }
.stats-bar__num {
  font-family:var(--font-display);
  font-size:2.4rem;
  font-weight:800;
  color:var(--black);
  line-height:1;
  margin-bottom:0.25rem;
}
.stats-bar__label {
  font-family:var(--font-ui);
  font-size:0.68rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.1em;
  color:var(--warm-300);
}

/* ─── FOOTER ─── */
.footer {
  background:var(--black);
  border-top:1px solid rgba(255,255,255,0.06);
  padding:4rem 2rem 2rem;
  color:rgba(255,255,255,0.4);
  font-size:0.85rem;
}
.footer__inner {
  max-width:var(--max-w);
  margin:0 auto;
}
.footer__grid {
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:3rem;
  margin-bottom:3rem;
}
.footer__brand {
  font-family:var(--font-display);
  font-size:1.6rem;
  font-weight:900;
  color:#fff;
  margin-bottom:0.75rem;
}
.footer__brand span { color:var(--gold); }
.footer h4 {
  font-family:var(--font-ui);
  font-size:0.65rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.14em;
  color:rgba(255,255,255,0.8);
  margin-bottom:1rem;
}
.footer li { margin-bottom:0.6em; }
.footer a { color:rgba(255,255,255,0.4); transition:color var(--transition); }
.footer a:hover { color:var(--gold-light); }
.footer__bottom {
  border-top:1px solid rgba(255,255,255,0.06);
  padding-top:1.5rem;
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:0.75rem;
  color:rgba(255,255,255,0.25);
}

/* ═══════════════════════════════════════════════════════════
   ARTICLE & PAGE STYLES
   ═══════════════════════════════════════════════════════════ */

/* ─── BREADCRUMBS ─── */
.breadcrumbs {
  display:flex;
  align-items:center;
  gap:0.5rem;
  font-family:var(--font-ui);
  font-size:0.75rem;
  font-weight:500;
  color:var(--warm-300);
  margin-bottom:1.5rem;
}
.breadcrumbs a { color:var(--warm-500); transition:color var(--transition); }
.breadcrumbs a:hover { color:var(--black); }

/* ─── ARTICLE HEADER ─── */
.article-header {
  background:var(--cream);
  padding:3rem 2rem;
  margin-bottom:2rem;
}
.article-header__inner {
  max-width:var(--content-w);
  margin:0 auto;
}
.article-header h1 {
  font-size:clamp(2rem, 4vw, 3rem);
  line-height:1.1;
  margin-bottom:1rem;
}
.article-header__meta {
  display:flex;
  align-items:center;
  gap:1rem;
  color:var(--warm-500);
  font-family:var(--font-ui);
  font-size:0.85rem;
  font-weight:500;
}
.article-header__meta .dot { width:4px; height:4px; border-radius:50%; background:var(--warm-100); }

/* ─── ARTICLE HERO ─── */
.article-hero {
  position:relative;
  width:100vw;
  margin-left:calc(-50vw + 50%);
  height:400px;
  overflow:hidden;
  margin-bottom:3rem;
}
.article-hero img {
  width:100%;
  height:100%;
  object-fit:cover;
}
.article-hero::after {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(to bottom, transparent 50%, rgba(13,13,13,0.1));
}

/* ─── ARTICLE BODY ─── */
.article-body {
  max-width:var(--content-w);
  margin:0 auto;
  padding:0 2rem 3rem;
}
.article-body p {
  font-size:1rem;
  line-height:1.85;
  margin-bottom:1.5rem;
  color:var(--warm-700);
}
.article-body p:first-child {
  font-size:1.15rem;
  line-height:1.8;
  color:var(--warm-500);
}
.article-body p.dropcap::first-letter {
  font-family:var(--font-display);
  font-size:3.5rem;
  font-weight:700;
  float:left;
  line-height:1;
  padding-right:0.5rem;
  padding-top:0.25rem;
  color:var(--gold);
}

.article-body h2 {
  font-size:1.8rem;
  line-height:1.3;
  margin-top:2.5rem;
  margin-bottom:1rem;
  color:var(--black);
  scroll-margin-top:100px;
}

.article-body h3 {
  font-size:1.3rem;
  line-height:1.4;
  margin-top:1.5rem;
  margin-bottom:0.75rem;
  color:var(--warm-700);
}

.article-body ul,
.article-body ol {
  margin:1.5rem 0;
  padding-left:1.5rem;
}
.article-body ul { list-style:disc; }
.article-body ol { list-style:decimal; }
.article-body li {
  margin-bottom:0.75rem;
  line-height:1.7;
  color:var(--warm-700);
}
.article-body li strong { font-weight:600; }

.article-body blockquote {
  border-left:4px solid var(--gold);
  padding-left:1.5rem;
  margin:2rem 0;
  font-size:1.05rem;
  font-style:italic;
  line-height:1.8;
  color:var(--warm-500);
}

.article-body figure {
  margin:2.5rem 0;
  padding:0;
}
.article-body figcaption {
  font-family:var(--font-ui);
  font-size:0.85rem;
  color:var(--warm-300);
  margin-top:0.75rem;
  font-weight:500;
}

.article-body a {
  color:var(--gold);
  border-bottom:1px solid transparent;
  transition:all var(--transition);
}
.article-body a:hover {
  border-bottom-color:var(--gold);
}

.article-body strong { font-weight:600; }
.article-body em { font-style:italic; }
.article-body code {
  background:var(--cream);
  padding:0.2em 0.5em;
  border-radius:3px;
  font-family:monospace;
  font-size:0.9em;
}

/* ─── INFO BOX ─── */
.info-box {
  background:rgba(212,169,60,0.08);
  border-left:4px solid var(--gold);
  border-radius:var(--radius);
  padding:1.5rem;
  margin:2rem 0;
}
.info-box__title {
  font-family:var(--font-ui);
  font-size:0.75rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.1em;
  color:var(--gold-dark);
  margin-bottom:0.5rem;
}
.info-box p {
  margin:0;
  font-size:0.95rem;
  line-height:1.7;
  color:var(--warm-700);
}

/* ─── TABLE OF CONTENTS ─── */
.toc {
  background:var(--cream);
  border:1px solid var(--sand);
  border-radius:var(--radius);
  padding:1.5rem;
  margin:2rem 0;
}
.toc__title {
  font-family:var(--font-ui);
  font-size:0.75rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.1em;
  color:var(--black);
  margin-bottom:1rem;
}
.toc__list { list-style:none; }
.toc__list li {
  margin-bottom:0.5rem;
}
.toc__list a {
  color:var(--warm-500);
  font-size:0.9rem;
  border-bottom:1px solid transparent;
  transition:all var(--transition);
}
.toc__list a:hover {
  color:var(--gold);
  border-bottom-color:var(--gold);
}

/* ─── AUTHOR BOX ─── */
.author-box {
  background:var(--cream);
  border-radius:var(--radius);
  padding:2rem;
  margin:3rem 0;
  display:flex;
  gap:1.5rem;
  align-items:flex-start;
}
.author-box__avatar {
  width:80px;
  height:80px;
  border-radius:50%;
  object-fit:cover;
  flex-shrink:0;
}
.author-box__content h3 {
  font-size:1rem;
  margin-bottom:0.25rem;
}
.author-box__content p {
  font-size:0.9rem;
  color:var(--warm-500);
  line-height:1.6;
  margin:0;
}

/* ─── SHARE BUTTONS ─── */
.share {
  display:flex;
  align-items:center;
  gap:0.75rem;
  border-top:1px solid var(--sand);
  border-bottom:1px solid var(--sand);
  padding:1.5rem 0;
  margin:2rem 0;
}
.share__label {
  font-family:var(--font-ui);
  font-size:0.75rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:var(--warm-500);
}
.share__btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
  border-radius:50%;
  background:var(--cream);
  color:var(--black);
  font-weight:700;
  font-size:1.1rem;
  transition:all var(--transition);
  cursor:pointer;
}
.share__btn:hover {
  background:var(--gold);
  color:#fff;
  transform:translateY(-3px);
}

/* ─── READING PROGRESS ─── */
.reading-progress {
  position:fixed;
  top:0;
  left:0;
  height:3px;
  background:var(--gold);
  z-index:101;
  width:0%;
  transition:width 0.2s ease-out;
}

/* ─── RELATED ARTICLES ─── */
.related {
  margin-top:4rem;
  padding-top:3rem;
  border-top:2px solid var(--sand);
}
.related h2 {
  font-size:1.8rem;
  margin-bottom:2rem;
  text-align:center;
}
.related__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.75rem; }

/* ─── CATEGORY HEADER ─── */
.category-header {
  background:var(--cream);
  padding:3rem 2rem;
  margin-bottom:2rem;
}
.category-header__inner {
  max-width:var(--max-w);
  margin:0 auto;
}
.category-header h1 {
  font-size:clamp(2rem, 4vw, 2.8rem);
  line-height:1.15;
  margin-bottom:0.75rem;
}
.category-header p {
  font-size:1rem;
  color:var(--warm-500);
  max-width:600px;
}
.category-header__icon {
  font-size:3rem;
  margin-bottom:1rem;
}

/* ─── PAGINATION ─── */
.pagination {
  display:flex;
  justify-content:center;
  align-items:center;
  gap:0.5rem;
  margin:3rem 0;
  font-family:var(--font-ui);
}
.pagination__item,
.pagination__link {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
  border:1px solid var(--sand);
  border-radius:var(--radius);
  font-weight:600;
  font-size:0.85rem;
  transition:all var(--transition);
}
.pagination__link {
  color:var(--warm-700);
  cursor:pointer;
  background:var(--white);
}
.pagination__link:hover {
  background:var(--black);
  color:#fff;
  border-color:var(--black);
}
.pagination__item.active {
  background:var(--black);
  color:#fff;
  border-color:var(--black);
}
.pagination__item.disabled {
  opacity:0.5;
  cursor:not-allowed;
}

/* ─── BACK TO TOP ─── */
.back-to-top {
  position:fixed;
  bottom:2rem;
  right:2rem;
  width:50px;
  height:50px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  background:var(--gold);
  color:#fff;
  cursor:pointer;
  opacity:0;
  visibility:hidden;
  transition:all var(--transition);
  z-index:50;
  font-weight:bold;
}
.back-to-top.active {
  opacity:1;
  visibility:visible;
}
.back-to-top:hover {
  background:var(--gold-dark);
  transform:translateY(-3px);
}

/* ═══════════════════════════════════════════════════════════
   ANIMATIONS
   ═══════════════════════════════════════════════════════════ */

@keyframes fadeUp {
  from { opacity:0; transform:translateY(24px); }
  to { opacity:1; transform:translateY(0); }
}

.anim {
  opacity:0;
  animation:fadeUp 0.65s ease-out forwards;
}
.anim-d1 { animation-delay:0.08s; }
.anim-d2 { animation-delay:0.16s; }
.anim-d3 { animation-delay:0.24s; }
.anim-d4 { animation-delay:0.32s; }

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE DESIGN
   ═══════════════════════════════════════════════════════════ */

@media (max-width:1024px) {
  .grid-4 { grid-template-columns:repeat(2,1fr); }
  .grid-featured { grid-template-columns:1fr 1fr; }
  .editorial-split { grid-template-columns:1fr; }
  .feature-block { grid-template-columns:1fr; }
  .feature-block__body { padding:2.5rem; }
  .footer__grid { grid-template-columns:repeat(2,1fr); }
  .stats-bar { grid-template-columns:repeat(2,1fr); }
  .stats-bar__item:nth-child(2) { border-right:none; }
  .related__grid { grid-template-columns:repeat(2,1fr); }
}

@media (max-width:768px) {
  :root { --max-w:100%; }

  .nav { display:none; }
  .hamburger { display:flex; }

  .grid-4,
  .grid-3,
  .grid-2,
  .grid-featured { grid-template-columns:1fr; }

  .hero { height:80vh; }
  .hero h1 { font-size:2rem; }
  .hero__content { padding:0 1.5rem 3rem; }

  .card--h { flex-direction:column; }
  .card--h .card__img { width:100%; aspect-ratio:16/10; }

  .newsletter__form { flex-direction:column; }
  .footer__grid { grid-template-columns:1fr; }
  .stats-bar { grid-template-columns:1fr; }
  .stats-bar__item {
    border-right:none;
    border-bottom:1px solid var(--sand);
  }

  .article-body {
    padding:0 1.5rem 2rem;
  }

  .author-box {
    flex-direction:column;
    text-align:center;
  }

  .related__grid { grid-template-columns:1fr; }

  .section { padding:3rem 1.5rem; }
  .feature-block__body { padding:2rem 1.5rem; }

  .article-header { padding:2rem 1.5rem; }
  .category-header { padding:2rem 1.5rem; }

  .footer { padding:3rem 1.5rem 1.5rem; }
  .footer__grid { gap:2rem; }

  .back-to-top {
    bottom:1.5rem;
    right:1.5rem;
    width:45px;
    height:45px;
  }
}

@media (max-width:480px) {
  html { font-size:14px; }

  .section { padding:2rem 1rem; }
  .article-body { padding:0 1rem 1.5rem; }

  .hero { height:70vh; min-height:500px; }
  .hero h1 { font-size:1.5rem; }
  .hero__excerpt { font-size:0.95rem; }

  .section-head {
    flex-direction:column;
    gap:0.75rem;
    align-items:flex-start;
  }
  .section-head h2 { white-space:normal; }
  .section-head__line { display:none; }
  .section-head__link { margin-top:0.5rem; }

  .card { border-radius:4px; }
  .card__body { padding:1rem; }
  .card--min .card__num { font-size:2rem; width:35px; }

  .pills { gap:0.4rem; }
  .pill { padding:0.5em 1em; font-size:0.65rem; }

  .newsletter { padding:3rem 1rem; }
  .newsletter h2 { font-size:1.5rem; }
  .newsletter__form { width:100%; }

  .article-header h1 { font-size:1.5rem; }
  .article-header__meta { flex-wrap:wrap; font-size:0.75rem; }

  .info-box { padding:1rem; }
  .toc { padding:1rem; }

  .author-box { padding:1.5rem; }
  .author-box__avatar { width:60px; height:60px; }

  .footer__grid { gap:1.5rem; }
  .footer h4 { font-size:0.6rem; }

  .pagination__item,
  .pagination__link { width:36px; height:36px; font-size:0.75rem; }

  .back-to-top {
    bottom:1rem;
    right:1rem;
    width:40px;
    height:40px;
  }
}

/* ═══════════════════════════════════════════════════════════
   PRINT STYLES
   ═══════════════════════════════════════════════════════════ */

@media print {
  .header,
  .footer,
  .topbar,
  .hamburger,
  .mobile-nav,
  .search-overlay,
  .back-to-top,
  .share,
  .newsletter,
  .related { display:none; }

  body { background:#fff; color:#000; }
  .article-body { max-width:100%; }
  .article-body h2 { page-break-after:avoid; }
  .article-body h3 { page-break-after:avoid; }

  a { text-decoration:underline; }
  img { max-width:100%; break-inside:avoid; }
}
