:root{
  --paper:#fbfaf6;
  --ink:#111;
  --muted:#5f5f5f;
  --line:#dedad3;
  --line2:#ece7df;
  --soft:#f3f0e9;
  --accent:#0b57d0;

  --shadow: 0 10px 30px rgba(0,0,0,.06);
  --container: 1240px;

  --serif: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif;
  --sans: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial;

  /* system-only “NYT-ish” vibe */
  --blackletter: "Old English Text MT", "Engravers Old English BT", Georgia, "Times New Roman", serif;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  color:var(--ink);
  background:var(--paper);
  font-family:var(--sans);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
button,input{font:inherit}
::selection{background: rgba(11,87,208,.16)}

/* Shell */
.nyt-shell{
  width:min(var(--container), calc(100% - 56px));
  margin:0 auto;
}
@media (max-width: 760px){
  .nyt-shell{width:calc(100% - 28px)}
}

/* Header */
.nyt-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(251,250,246,.92);
  backdrop-filter:saturate(160%) blur(10px);
  border-bottom:1px solid var(--line);
}

/* Topbar */
.nyt-topbar{border-bottom:1px solid var(--line2)}
.nyt-topbar__inner{
  width:min(var(--container), calc(100% - 56px));
  margin:0 auto;
  height:46px;
  display:grid;
  grid-template-columns: 140px 1fr 140px;
  align-items:center;
}
@media (max-width: 760px){
  .nyt-topbar__inner{width:calc(100% - 28px)}
}
@media (max-width: 520px){
  .nyt-topbar__inner{grid-template-columns: 96px 1fr 40px}
}
.nyt-topbar__left{display:flex; align-items:center; gap:10px}
.nyt-topbar__center{display:flex; justify-content:center}
.nyt-topbar__right{display:flex; justify-content:flex-end}

.nyt-topbar__date{
  font-size:11px;
  letter-spacing:.10em;
  text-transform:uppercase;
  color:var(--muted);
  white-space:nowrap;            /* ✅ prevents wrapping (fixes click issues) */
  overflow:hidden;
  text-overflow:ellipsis;
}
@media (max-width: 420px){
  .nyt-topbar__center{display:none;}
}

/* Icon buttons */
.nyt-iconbtn{
  width:40px;height:28px;
  border:1px solid transparent;
  background:transparent;
  border-radius:999px;
  display:grid;
  place-items:center;
  cursor:pointer;
  -webkit-tap-highlight-color: transparent;
}
.nyt-iconbtn:hover{background: rgba(0,0,0,.04)}
.nyt-iconbtn svg{width:20px;height:20px; fill: var(--ink)}

/* Hamburger only on mobile */
.nyt-iconbtn--menu{
  display:none;
  place-items:center;
}
.nyt-iconbtn--menu span{
  display:block;
  width:18px;
  height:2px;
  background: var(--ink);
  border-radius:999px;
  margin:3px 0;
}
@media (max-width: 960px){
  .nyt-iconbtn--menu{display:grid}
}

/* Masthead */
.nyt-mast{
  padding:14px 0 12px;
  border-bottom:1px solid var(--line2);
}
.nyt-mast__inner{
  width:min(var(--container), calc(100% - 56px));
  margin:0 auto;
  text-align:center;
}
@media (max-width: 760px){
  .nyt-mast__inner{width:calc(100% - 28px)}
}
.nyt-brand{
  font-family:var(--blackletter);
  font-weight:700;
  font-size: clamp(28px, 4.2vw, 52px);
  letter-spacing:-.02em;
  line-height:1;
}
.nyt-brand__tag{
  margin-top:6px;
  color:var(--muted);
  font-size:13px;
  letter-spacing:.03em;
}

/* Nav (desktop only) */
.nyt-nav{background: var(--paper)}
.nyt-nav__inner{
  width:min(var(--container), calc(100% - 56px));
  margin:0 auto;
  display:flex;
  gap:14px;
  justify-content:center;
  flex-wrap:wrap;
  padding:10px 0 12px;
}
@media (max-width: 760px){
  .nyt-nav__inner{width:calc(100% - 28px)}
}
.nyt-nav__link{
  font-size:13px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#222;
  padding:6px 8px;
  border-radius:999px;
  border:1px solid transparent;
}
.nyt-nav__link:hover{border-color: var(--line)}
.nyt-nav__link.is-active{
  border-color: rgba(11,87,208,.25);
  background: rgba(11,87,208,.06);
}
@media (max-width: 960px){
  .nyt-nav{display:none}
}

/* Drawer (mobile) */
.nyt-drawer{
  position:fixed;
  inset:0;
  z-index:9999;                 /* ✅ always on top */
  pointer-events:none;
  opacity:0;
  visibility:hidden;
}
.nyt-drawer__scrim{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.35);
  border:0;
  cursor:pointer;
}
.nyt-drawer__panel{
  position:absolute;
  top:0; left:0;
  height:100vh;
  height:100dvh;                /* ✅ better on mobile browsers */
  width:min(420px, 92vw);
  background: var(--paper);
  border-right:1px solid var(--line);
  padding:16px;
  transform: translateX(-105%);
  transition: transform .22s ease;
  overflow:auto;
  -webkit-overflow-scrolling: touch;
}
.nyt-drawer__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding-bottom:10px;
  border-bottom:1px solid var(--line);
}
.nyt-drawer__title{
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size:11px;
}
.nyt-drawer__close{
  width:42px;height:42px;
  border:1px solid var(--line);
  border-radius:999px;
  background: var(--paper);
  cursor:pointer;
}
.nyt-drawer__group{padding-top:14px}
.nyt-drawer__label{
  color:var(--muted);
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  margin:0 0 10px;
}
.nyt-drawer__link{
  display:block;
  padding:12px 6px;
  border-top:1px solid var(--line2);
  font-size:15px;
}
body.is-menu-open .nyt-drawer{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}
body.is-menu-open .nyt-drawer__panel{transform:translateX(0)}

/* Main */
.nyt-page{padding:18px 0 42px}

/* Smaller section heads */
.nyt-sectionhead{
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:900;
  color:#222;
  padding:10px 0 10px;
  border-top:2px solid var(--line);
  border-bottom:1px solid var(--line2);
}

/* Home grid + RESPONSIVE ORDER FIX */
.nyt-homegrid{
  display:grid;
  grid-template-columns: 260px 1fr 300px;
  gap:22px;
  align-items:start;

  grid-template-areas: "left main right";
}
.nyt-col--left{grid-area:left}
.nyt-col--main{grid-area:main}
.nyt-col--right{grid-area:right}

.nyt-homegrid--category{
  grid-template-columns: 1fr 300px;
  grid-template-areas: "main right";
}

@media (max-width: 1120px){
  .nyt-homegrid{grid-template-columns: 240px 1fr 280px}
}

@media (max-width: 980px){
  /* ✅ mobile order: main -> right -> left */
  .nyt-homegrid,
  .nyt-homegrid--category{
    grid-template-columns: 1fr;
    grid-template-areas:
      "main"
      "right"
      "left";
    gap:18px;
  }
}

/* Left column links */
.nyt-stack{display:grid; gap:0}
.nyt-leftlink{
  display:block;
  padding:12px 0;
  border-bottom:1px solid var(--line2);
}
.nyt-leftlink__title{
  font-family:var(--serif);
  font-weight:800;
  font-size:16px;              /* ✅ smaller */
  line-height:1.18;
}
.nyt-leftlink__meta{
  margin-top:6px;
  color:var(--muted);
  font-size:11px;
  letter-spacing:.06em;
  text-transform:uppercase;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

/* Meta */
.nyt-meta{
  color:var(--muted);
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}
.nyt-dot{opacity:.7}
.nyt-time{color:var(--muted)}

/* Kicker */
.nyt-kicker{font-weight:900; color: var(--accent)}

/* Lead card */
.nyt-lead{
  display:grid;
  grid-template-columns: 1.05fr 1fr;
  gap:16px;
  padding:12px 0 16px;
  border-bottom:1px solid var(--line2);
}
.nyt-lead__media{
  background: var(--soft);
  border:1px solid var(--line2);
  overflow:hidden;
}
.nyt-lead__media img{
  width:100%;
  height:100%;
  aspect-ratio: 16/10;
  object-fit:cover;
}
.nyt-lead__body{padding-top:4px}
.nyt-lead__title{
  margin:8px 0 0;
  font-family:var(--serif);
  font-weight:900;
  font-size: clamp(22px, 2.1vw, 32px);
  line-height:1.08;
  letter-spacing:-.01em;
}
.nyt-lead__dek{
  margin:8px 0 0;
  color:#333;
  font-size:15px;
  line-height:1.65;
}
@media (max-width: 980px){
  .nyt-lead{grid-template-columns: 1fr}
}

/* Rows */
.nyt-mainrows{display:grid; gap:0}
.nyt-row{
  display:grid;
  grid-template-columns: 1fr 160px;
  gap:16px;
  padding:12px 0;
  border-bottom:1px solid var(--line2);
  align-items:start;
}
.nyt-row__title{
  margin:8px 0 0;
  font-family:var(--serif);
  font-weight:900;
  font-size: clamp(16px, 1.55vw, 20px);
  line-height:1.16;
}
.nyt-row__dek{
  margin:8px 0 0;
  color:#333;
  font-size:14px;
  line-height:1.6;
}
.nyt-row__media{
  background:var(--soft);
  border:1px solid var(--line2);
  overflow:hidden;
}
.nyt-row__media img{
  width:100%;
  height:100%;
  aspect-ratio: 4/3;
  object-fit:cover;
}
@media (max-width: 620px){
  .nyt-row{grid-template-columns: 1fr}
}

/* Latest (right) */
.nyt-latest{display:grid}
.nyt-mini{
  display:flex;
  justify-content:space-between;
  gap:14px;
  padding:12px 0;
  border-bottom:1px solid var(--line2);
  align-items:flex-start;
}
.nyt-mini__title{
  font-family:var(--serif);
  font-weight:800;
  font-size:15px;              /* ✅ smaller */
  line-height:1.25;
}
.nyt-mini__time{
  white-space:nowrap;
  color:var(--muted);
  font-size:11px;
  letter-spacing:.06em;
  text-transform:uppercase;
  margin-top:2px;
}

/* Category head */
.nyt-cathead{
  padding:16px 0 10px;
  border-bottom:1px solid var(--line);
  margin-bottom:16px;
}
.nyt-cathead__title{
  margin:0;
  font-family:var(--serif);
  font-weight:900;
  font-size: clamp(24px, 3.4vw, 40px);
  line-height:1.05;
}
.nyt-cathead__tag{
  margin:8px 0 0;
  color:var(--muted);
  font-size:15px;
  line-height:1.6;
  max-width:70ch;
}

/* Article page layout (article wider, sidebar smaller) */
.nyt-articlegrid{
  display:grid;
  grid-template-columns: 1fr 240px;
  gap:24px;
  align-items:start;
}
@media (max-width: 980px){
  .nyt-articlegrid{grid-template-columns: 1fr}
}
.nyt-article__header{
  border-bottom:1px solid var(--line);
  padding-bottom:12px;
  margin-bottom:16px;
}
.nyt-article__meta{
  color:var(--muted);
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}
.nyt-author{font-weight:800; color:#222}
.nyt-article__title{
  margin:12px 0 0;
  font-family:var(--serif);
  font-weight:900;
  font-size: clamp(26px, 4vw, 46px);
  line-height:1.06;
  letter-spacing:-.01em;
}
.nyt-article__figure{
  margin:14px 0 0;
  border:1px solid var(--line2);
  background:var(--soft);
  overflow:hidden;
}
.nyt-article__figure img{width:100%; height:auto}

/* Prose (slightly smaller) */
.nyt-prose{
  font-family:var(--serif);
  font-size:18px;
  line-height:1.9;
  color:#111;
}
.nyt-prose p{margin:0 0 16px}
.nyt-prose h2{
  margin:30px 0 10px;
  font-family:var(--serif);
  font-weight:900;
  font-size:26px;
  line-height:1.2;
}
.nyt-prose h3{
  margin:22px 0 10px;
  font-family:var(--serif);
  font-weight:900;
  font-size:20px;
  line-height:1.25;
}
.nyt-prose a{color:var(--accent); text-decoration:underline; text-underline-offset:3px}
.nyt-prose ul,.nyt-prose ol{margin:0 0 16px 1.2em}
.nyt-prose li{margin:8px 0}
.nyt-prose blockquote{
  margin:20px 0;
  padding:14px 16px;
  border-left:4px solid var(--accent);
  background: rgba(11,87,208,.05);
  color:#222;
}

/* More stories */
.nyt-more{margin-top:22px}
.nyt-moregrid{
  margin-top:12px;
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:16px;
}
@media (max-width: 1120px){ .nyt-moregrid{grid-template-columns: repeat(3, 1fr)} }
@media (max-width: 840px){ .nyt-moregrid{grid-template-columns: repeat(2, 1fr)} }
@media (max-width: 520px){ .nyt-moregrid{grid-template-columns: 1fr} }
.nyt-morecard{
  border:1px solid var(--line2);
  background:#fff;
  box-shadow: var(--shadow);
}
.nyt-morecard__img{background:var(--soft); border-bottom:1px solid var(--line2)}
.nyt-morecard__img img{width:100%; height:150px; object-fit:cover}
.nyt-morecard__body{padding:10px 10px 12px}
.nyt-morecard__title{
  margin-top:6px;
  font-family:var(--serif);
  font-weight:900;
  font-size:15px;
  line-height:1.22;
}

/* Placeholder */
.nyt-ph{
  width:100%;
  height:150px;
  background: repeating-linear-gradient(
    135deg,
    rgba(0,0,0,.05),
    rgba(0,0,0,.05) 10px,
    rgba(0,0,0,.02) 10px,
    rgba(0,0,0,.02) 20px
  );
}

/* Pager */
.nyt-pager{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:16px 0 0;
}
.nyt-pagebtn{
  padding:10px 12px;
  border:1px solid var(--line);
  background:#fff;
}
.nyt-pagebtn.is-disabled{opacity:.45; cursor:not-allowed}
.nyt-pagepills{display:flex; gap:10px; flex-wrap:wrap; justify-content:center}
.nyt-pagepill{
  min-width:38px;
  height:38px;
  display:grid;
  place-items:center;
  border:1px solid var(--line);
  background:#fff;
  font-weight:800;
  font-size:13px;
}
.nyt-pagepill.is-active{
  border-color: rgba(11,87,208,.28);
  box-shadow: 0 0 0 4px rgba(11,87,208,.10);
}

/* Search */
.is-search .nyt-page{ padding: 28px 0 56px; }

.nyt-searchdesk{
  background:
    radial-gradient(1200px 400px at 20% -10%, rgba(11,87,208,.10), transparent 60%),
    radial-gradient(900px 320px at 90% 0%, rgba(0,0,0,.06), transparent 60%),
    linear-gradient(#fff, #fff);
  border:1px solid var(--line2);
  box-shadow: var(--shadow);
  overflow:hidden;
}

.nyt-searchdesk__head{
  padding: 22px 22px 14px;
  border-bottom:1px solid var(--line2);
  background: rgba(251,250,246,.60);
}
.nyt-searchdesk__eyebrow{
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:900;
  color:#222;
}
.nyt-searchdesk__title{
  margin:10px 0 0;
  font-family: var(--serif);
  font-weight: 900;
  font-size: clamp(28px, 3.2vw, 44px);
  line-height:1.05;
}
.nyt-searchdesk__sub{
  margin:10px 0 0;
  color: var(--muted);
  font-size: 16px;
  line-height:1.6;
  max-width: 70ch;
}

.nyt-searchdesk__grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:0;
}
@media (max-width: 980px){
  .nyt-searchdesk__grid{ grid-template-columns: 1fr; }
}

.nyt-searchdesk__main{
  padding: 20px 22px 22px;
}
.nyt-searchdesk__side{
  border-left:1px solid var(--line2);
  background: rgba(251,250,246,.55);
  padding: 20px 18px 22px;
}
@media (max-width: 980px){
  .nyt-searchdesk__side{ border-left:0; border-top:1px solid var(--line2); }
}

.nyt-searchpanel{
  background:#fff;
  border:1px solid var(--line2);
  box-shadow: var(--shadow);
  padding: 14px;
}
.nyt-searchpanel__row{
  display:grid;
  grid-template-columns: 1fr 140px;
  gap:10px;
  align-items:center;
}
@media (max-width: 520px){
  .nyt-searchpanel__row{ grid-template-columns: 1fr; }
}

.nyt-searchpanel__input{
  height: 56px;
  border:1px solid var(--line);
  background:#fff;
  padding: 0 14px;
  font-size: 18px;
  outline: none;
}
.nyt-searchpanel__input:focus{
  border-color: rgba(11,87,208,.45);
  box-shadow: 0 0 0 4px rgba(11,87,208,.10);
}
.nyt-searchpanel__go{
  height: 56px;
  border:1px solid var(--ink);
  background: var(--ink);
  color: #fff;
  cursor:pointer;
  font-weight:900;
  letter-spacing:.10em;
  text-transform:uppercase;
  font-size:12px;
}
.nyt-searchpanel__go:hover{ filter: brightness(.95); }

.nyt-searchpanel__hint{
  margin-top: 10px;
  color: var(--muted);
  font-size: 13px;
  display:flex;
  justify-content: space-between;
  gap:12px;
  flex-wrap:wrap;
}
.nyt-searchpanel__home{
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.nyt-searchpanel__chips{
  margin-top: 14px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.nyt-chip{
  border:1px solid var(--line);
  background: rgba(0,0,0,.02);
  padding: 8px 10px;
  border-radius: 999px;
  cursor:pointer;
  font-size: 13px;
  letter-spacing:.02em;
}
.nyt-chip:hover{
  background: rgba(11,87,208,.06);
  border-color: rgba(11,87,208,.22);
}

.nyt-searchside__title{
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:900;
  color:#222;
  padding: 10px 0;
  border-top:2px solid var(--line);
  border-bottom:1px solid var(--line2);
}

.nyt-searchside__list{ margin-top: 10px; display:grid; }
.nyt-trend{
  display:block;
  padding: 12px 0;
  border-bottom:1px solid var(--line2);
}
.nyt-trend__k{
  color: var(--muted);
  font-size: 12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}
.nyt-trend__t{
  margin-top: 8px;
  font-family: var(--serif);
  font-weight: 900;
  font-size: 16px;
  line-height: 1.2;
}
.nyt-trend:hover .nyt-trend__t{ text-decoration: underline; }

.nyt-searchside__note{
  margin-top: 14px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.6;
}

/* Footer */
.nyt-footer{
  border-top:1px solid var(--line);
  padding:20px 0;
  margin-top:32px;
}
.nyt-footer__inner{
  width:min(var(--container), calc(100% - 56px));
  margin:0 auto;
  display:flex;
  gap:18px;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
}
@media (max-width: 760px){
  .nyt-footer__inner{width:calc(100% - 28px)}
}
.nyt-footer__links{display:flex; gap:14px; flex-wrap:wrap; font-size:14px}
.nyt-footer__links a:hover{text-decoration:underline}
.nyt-footer__copy{color:var(--muted); font-size:13px}
/* Drawer (mobile) - FIX scrim overlaying the panel */
.nyt-drawer{
  position:fixed;
  inset:0;
  z-index:9999;
}

/* scrim must be UNDER the panel */
.nyt-drawer__scrim{
  position:absolute;
  inset:0;
  z-index:0;          /* ✅ under */
}

/* panel must be ABOVE the scrim */
.nyt-drawer__panel{
  position:absolute;
  top:0; left:0;
  z-index:1;          /* ✅ above */
  background: var(--paper);
  box-shadow: 12px 0 40px rgba(0,0,0,.18); /* optional, looks better */
}
time[data-date], time[data-longdate] { visibility: hidden; }
body.js-dates-ready time[data-date],
body.js-dates-ready time[data-longdate] { visibility: visible; }