/*
Theme Name: NY Design Edit
Theme URI: https://thedesignlensny.com
Description: An editorial magazine theme for NY Design Edit. Fraunces display, Newsreader body, vermillion accent, paper-and-ink palette. Hero, card grids, ruled reading lists, and a dark dispatch band.
Author: NY Design Edit
Version: 1.0
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: nydesignedit
*/

:root{
  --paper:#F4EFE3; --paper-2:#ECE6D6; --paper-3:#E4DCC8;
  --ink:#1B1813; --ink-2:#4A453B; --ink-3:#8A8373;
  --ink-surface:#1B1813; --on-dark:#F1ECDF; --on-dark-muted:#C9C2B0; --on-dark-subtle:#928B79;
  --vermillion:#D7472B; --vermillion-press:#B23A22; --vermillion-tint:rgba(215,71,43,.10);
  --line:#DAD2C0;
  --content-max:1280px;
  --font-display:'Fraunces', Georgia, serif;
  --font-serif:'Newsreader', Georgia, serif;
  --font-sans:'Public Sans', system-ui, -apple-system, sans-serif;
  --font-mono:'Spline Sans Mono', ui-monospace, monospace;
  --ease:cubic-bezier(.2,.6,.2,1);
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{background:var(--paper);color:var(--ink);font-family:var(--font-serif);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
::selection{background:var(--vermillion);color:#fff;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
.wrap{max-width:var(--content-max);margin:0 auto;padding-inline:40px;}

/* utility rail */
.util{border-bottom:1px solid var(--line);}
.util .wrap{display:flex;align-items:center;justify-content:space-between;height:38px;}
.util .meta{color:var(--ink-3);font-family:var(--font-mono);font-size:12px;letter-spacing:.02em;}
.util .meta .v{color:var(--vermillion);}

/* masthead */
.masthead{border-bottom:1.5px solid var(--ink);position:sticky;top:0;z-index:30;background:var(--paper);}
.masthead .bar{display:flex;align-items:flex-end;justify-content:space-between;padding:24px 0 18px;}
.brand{display:block;line-height:.86;}
.brand .word{font-family:var(--font-display);font-weight:800;font-size:46px;letter-spacing:-.01em;color:var(--ink);}
.brand .word .dot{color:var(--vermillion);}
.brand .tag{display:block;margin-top:9px;white-space:nowrap;font-family:var(--font-sans);font-weight:600;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--vermillion);}
.actions{display:flex;align-items:center;gap:12px;}
.icon-btn{width:42px;height:42px;border:1.5px solid var(--ink);border-radius:2px;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s var(--ease);}
.icon-btn:hover{background:var(--paper-2);}
.btn{font-family:var(--font-sans);font-weight:600;font-size:14px;white-space:nowrap;padding:12px 22px;border-radius:2px;cursor:pointer;border:1.5px solid var(--vermillion);background:var(--vermillion);color:#fff;transition:background .15s var(--ease);}
.btn:hover{background:var(--vermillion-press);border-color:var(--vermillion-press);}
nav.sections{border-top:1px solid var(--line);}
nav.sections .wrap{display:flex;gap:30px;}
nav.sections a{font-family:var(--font-sans);font-weight:600;font-size:14px;color:var(--ink-2);padding:13px 0;margin-bottom:-1px;white-space:nowrap;border-bottom:2px solid transparent;transition:color .15s var(--ease);}
nav.sections a:hover{color:var(--ink);}
nav.sections a.active,nav.sections li.current-menu-item a{color:var(--ink);border-bottom-color:var(--vermillion);}
nav.sections ul{display:flex;gap:30px;list-style:none;margin:0;padding:0;}
nav.sections .loc{margin-left:auto;color:var(--ink-3);font-family:var(--font-mono);font-weight:400;font-size:12px;letter-spacing:.04em;text-transform:uppercase;align-self:center;}

/* hero */
.hero{display:grid;grid-template-columns:1.08fr .92fr;gap:52px;align-items:stretch;padding:56px 0 52px;border-bottom:1.5px solid var(--ink);}
.hero .copy{display:flex;flex-direction:column;justify-content:center;}
.kicker{font-family:var(--font-sans);font-weight:700;font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--vermillion);}
.hero h1{font-family:var(--font-display);font-weight:700;font-size:clamp(42px,4.6vw,66px);line-height:.98;letter-spacing:-.018em;color:var(--ink);margin:18px 0 22px;text-wrap:balance;}
.hero h1 a:hover{color:var(--vermillion);}
.hero .lede{font-family:var(--font-serif);font-weight:380;font-size:22px;line-height:1.45;color:var(--ink-2);margin:0 0 28px;max-width:46ch;text-wrap:pretty;}
.hero .row{display:flex;align-items:center;gap:18px;}
.hero .meta{color:var(--ink-3);font-family:var(--font-mono);font-size:12px;text-transform:uppercase;letter-spacing:.04em;}
.hero figure{position:relative;margin:0;overflow:hidden;border:1px solid var(--line);}
.hero figure img{width:100%;height:100%;min-height:440px;object-fit:cover;}
.badge{position:absolute;top:14px;left:14px;z-index:2;background:var(--vermillion);color:#fff;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.06em;padding:5px 11px;}

/* section heads */
.sec-head{display:flex;align-items:baseline;justify-content:space-between;margin:48px 0 28px;}
.sec-head h2{font-family:var(--font-serif);font-weight:560;font-size:28px;color:var(--ink);margin:0;}
.link{font-family:var(--font-sans);font-weight:600;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--vermillion);display:inline-flex;align-items:center;gap:7px;}
.link .ar{font-family:var(--font-serif);font-size:16px;transition:transform .15s var(--ease);}
.link:hover .ar{transform:translateX(3px);}

/* card grid */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;}
.card{display:flex;flex-direction:column;}
.card .ph{margin-bottom:16px;overflow:hidden;}
.card .ph img,.card .tonal{width:100%;aspect-ratio:3/2;object-fit:cover;display:block;border:1px solid var(--line);}
.card .ph img{transition:transform .4s var(--ease);}
.card:hover .ph img{transform:scale(1.03);}
.tonal{display:flex;align-items:center;justify-content:center;background:var(--paper-3);}
.tonal.dark{background:var(--ink-surface);}
.tonal span{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);}
.tonal.dark span{color:var(--on-dark-subtle);}
.card .cat{font-family:var(--font-sans);font-weight:700;font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--vermillion);}
.card h3{font-family:var(--font-display);font-weight:700;font-size:25px;line-height:1.06;letter-spacing:-.01em;color:var(--ink);margin:11px 0 10px;text-wrap:balance;transition:color .18s var(--ease);}
.card:hover h3{color:var(--vermillion);}
.card p{font-family:var(--font-serif);font-size:16px;line-height:1.5;color:var(--ink-2);margin:0 0 12px;text-wrap:pretty;}
.card .byl{font-family:var(--font-mono);font-size:11px;letter-spacing:.03em;text-transform:uppercase;color:var(--ink-3);margin-top:auto;}

/* ruled list */
.list{border-top:1.5px solid var(--ink);}
.list .row{display:grid;grid-template-columns:52px 1fr 180px;gap:28px;align-items:center;padding:24px 0;border-bottom:1px solid var(--line);transition:background .15s var(--ease),padding-inline .15s var(--ease);}
.list .row:hover{background:var(--paper-2);padding-inline:16px;margin-inline:-16px;}
.list .num{font-family:var(--font-mono);font-size:13px;color:var(--ink-3);}
.list .cat{font-family:var(--font-sans);font-weight:700;font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--vermillion);}
.list h3{font-family:var(--font-display);font-weight:700;font-size:26px;line-height:1.05;letter-spacing:-.01em;color:var(--ink);margin:8px 0 0;transition:color .15s var(--ease);}
.list .row:hover h3{color:var(--vermillion);}
.list .right{text-align:right;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-3);line-height:1.9;}

/* neighborhood quick-links */
.hoodlinks{display:flex;flex-wrap:wrap;gap:10px;margin:28px 0 0;}
.hoodlinks a{font-family:var(--font-sans);font-weight:600;font-size:13px;letter-spacing:.02em;color:var(--ink-2);border:1px solid var(--line);border-radius:999px;padding:9px 16px;transition:all .15s var(--ease);}
.hoodlinks a:hover{border-color:var(--vermillion);color:var(--vermillion);background:var(--vermillion-tint);}

/* dispatch */
.dispatch{background:var(--ink-surface);color:var(--on-dark);margin-top:80px;}
.dispatch .wrap{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;padding:64px 40px;}
.dispatch .k{font-family:var(--font-sans);font-weight:700;font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--vermillion);}
.dispatch h2{font-family:var(--font-display);font-weight:700;font-size:40px;line-height:1.02;letter-spacing:-.015em;color:var(--on-dark);margin:16px 0 14px;text-wrap:balance;}
.dispatch p{font-family:var(--font-serif);font-weight:380;font-size:18px;line-height:1.5;color:var(--on-dark-muted);margin:0;max-width:40ch;}
.signup{display:flex;flex-direction:column;gap:12px;}
.signup .field{display:flex;}
.signup input{flex:1;border:1.5px solid var(--on-dark);border-right:none;border-radius:2px 0 0 2px;padding:14px 16px;font-family:var(--font-sans);font-size:15px;background:transparent;color:var(--on-dark);outline:none;}
.signup input::placeholder{color:var(--on-dark-subtle);}
.signup button{font-family:var(--font-sans);font-weight:600;font-size:13px;letter-spacing:.06em;text-transform:uppercase;background:var(--vermillion);color:#fff;border:1.5px solid var(--vermillion);border-radius:0 2px 2px 0;padding:0 22px;cursor:pointer;}
.signup button:hover{background:var(--vermillion-press);}
.signup .fine{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--on-dark-subtle);}

/* footer */
footer.site{background:var(--ink-surface);color:var(--on-dark);border-top:1px solid rgba(241,236,223,.14);}
footer.site .wrap{padding:56px 40px 40px;}
footer.site .top{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:40px;border-bottom:1px solid rgba(241,236,223,.14);padding-bottom:36px;}
footer.site .word{font-family:var(--font-display);font-weight:800;font-size:30px;color:var(--on-dark);}
footer.site .word .dot{color:var(--vermillion);}
footer.site .blurb{font-family:var(--font-serif);font-size:16px;line-height:1.5;color:var(--on-dark-muted);margin:16px 0 0;max-width:34ch;}
footer.site .cols{display:flex;gap:56px;}
footer.site .col h4{font-family:var(--font-sans);font-weight:700;font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--vermillion);margin:0 0 16px;}
footer.site .col a{display:block;font-family:var(--font-serif);font-size:16px;color:var(--on-dark);margin-bottom:11px;}
footer.site .col ul{list-style:none;margin:0;padding:0;}
footer.site .col a:hover{color:var(--vermillion);}
footer.site .legal{display:flex;justify-content:space-between;padding-top:24px;flex-wrap:wrap;gap:12px;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--on-dark-subtle);}

/* article */
.read{max-width:760px;margin:0 auto;}
.read-wide{max-width:1040px;margin:0 auto;}
.breadcrumb{border-bottom:1px solid var(--line);}
.breadcrumb a{display:inline-flex;align-items:center;gap:8px;padding:18px 0;font-family:var(--font-mono);font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);}
.breadcrumb a:hover{color:var(--vermillion);}
.arthead{text-align:center;padding:52px 0 26px;}
.arthead h1{font-family:var(--font-display);font-weight:700;font-size:clamp(40px,4.8vw,64px);line-height:1;letter-spacing:-.018em;color:var(--ink);margin:18px 0 22px;text-wrap:balance;}
.arthead .lede{font-family:var(--font-serif);font-weight:380;font-size:23px;line-height:1.45;color:var(--ink-2);margin:0 auto;max-width:46ch;text-wrap:pretty;}
.byline{display:flex;align-items:center;gap:14px;border-top:1.5px solid var(--ink);border-bottom:1px solid var(--line);padding:16px 0;}
.byline .av{width:46px;height:46px;border-radius:999px;background:var(--vermillion);color:#fff;font-family:var(--font-display);font-weight:700;font-size:21px;display:flex;align-items:center;justify-content:center;flex:none;}
.byline .nm{font-family:var(--font-sans);font-weight:700;font-size:14px;color:var(--ink);}
.byline .ro{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-3);margin-top:2px;}
figure.lead{margin:36px auto 10px;}
figure.lead img{width:100%;aspect-ratio:16/9;object-fit:cover;border:1px solid var(--line);}
figcaption{font-family:var(--font-sans);font-size:13px;color:var(--ink-3);margin-top:10px;text-align:center;}
.prose{font-family:var(--font-serif);font-weight:400;font-size:19px;line-height:1.64;color:var(--ink);margin:28px auto 0;text-wrap:pretty;}
.prose p{margin:0 0 1.15em;}
.prose>p:first-of-type::first-letter{font-family:var(--font-display);font-weight:800;font-size:78px;line-height:.72;float:left;margin:8px 12px 0 0;color:var(--vermillion);}
.prose a{color:var(--vermillion);box-shadow:inset 0 -1px 0 var(--vermillion);}
.prose a:hover{background:var(--vermillion-tint);}
.prose strong{font-weight:640;}
.prose h2{font-family:var(--font-serif);font-weight:560;font-size:29px;line-height:1.18;letter-spacing:-.006em;color:var(--ink);margin:44px 0 14px;}
.prose h3{font-family:var(--font-sans);font-weight:700;font-size:18px;color:var(--ink);margin:30px 0 10px;}
.prose ul,.prose ol{padding-left:1.2em;margin:0 0 1.15em;}
.prose li{margin:0 0 .5em;}
.prose img{margin:36px auto;border:1px solid var(--line);}
.prose table{width:100%;border-collapse:collapse;margin:28px 0;font-size:16px;}
.prose th,.prose td{border:1px solid var(--line);padding:10px 12px;text-align:left;}
.prose th{font-family:var(--font-sans);font-weight:700;background:var(--paper-2);}
.prose blockquote{margin:38px 0;border-left:3px solid var(--vermillion);padding-left:26px;font-family:var(--font-display);font-style:italic;font-size:26px;line-height:1.25;color:var(--ink);}
.endrule{border-top:1.5px solid var(--ink);margin:44px 0 18px;}
.tags{display:flex;gap:10px;flex-wrap:wrap;}
.tags a{font-family:var(--font-mono);font-size:12px;text-transform:uppercase;letter-spacing:.04em;padding:5px 12px;border-radius:999px;border:1px solid var(--line);color:var(--ink-2);}
.tags a:hover{border-color:var(--ink);color:var(--ink);}
.more{margin-top:80px;border-top:1.5px solid var(--ink);padding-top:32px;}
.more h2{font-family:var(--font-serif);font-weight:560;font-size:26px;color:var(--ink);margin:0 0 28px;}

/* page + archive head */
.pagehead{border-bottom:1.5px solid var(--ink);padding:56px 0 44px;}
.pagehead h1{font-family:var(--font-display);font-weight:700;font-size:clamp(46px,6vw,84px);line-height:.96;letter-spacing:-.018em;color:var(--ink);margin:16px 0 0;text-wrap:balance;}
.pagehead .lede{font-family:var(--font-serif);font-weight:380;font-size:22px;line-height:1.45;color:var(--ink-2);margin:22px 0 0;max-width:54ch;}
.page-body{padding:48px 0 0;}
.archive-grid{padding:48px 0 0;}

@media (max-width:900px){
  .hero,.dispatch .wrap,.grid3{grid-template-columns:1fr;}
  .grid3{gap:44px;}
  .hero figure img{min-height:300px;}
  .list .row{grid-template-columns:32px 1fr;}
  .list .right{display:none;}
  .wrap{padding-inline:22px;}
  nav.sections .wrap{overflow-x:auto;}
}
