/* ==========================================================================
   Denton Wilde — Editorial Design System
   ========================================================================== */

/* ==========================================================================
   1) Design tokens
   ========================================================================== */

:root{
  /* Color */
  --dw-ink:#111827;
  --dw-ink-2:#374151;
  --dw-paper:#ffffff;
  --dw-bg:#f4f4f4;
  --dw-border:#e5e7eb;
  --dw-accent:#004f7a;
  --dw-shadow:0 14px 30px rgba(0,0,0,.18);

  /* Typography */
  --dw-font-sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen,Ubuntu,Cantarell,"Helvetica Neue",Arial,sans-serif;
  --dw-font-serif:ui-serif,"Iowan Old Style","Palatino Linotype",Palatino,"Cormorant Garamond",Georgia,serif;

  /* Type scale */
  --dw-step--1:.92rem;
  --dw-step-0:1rem;
  --dw-step-1:1.125rem;
  --dw-step-2:1.35rem;
  --dw-step-3:1.7rem;
  --dw-step-4:2.15rem;
  --dw-step-5:2.7rem;

  /* Layout */
  --dw-page-max:1140px;
  --dw-content-max:900px;
  --dw-radius:18px;
  --dw-radius-sm:8px;
  --dw-gutter:20px;

  /* Nav tuning */
  --dw-nav-pad-y:8px;
  --dw-nav-pad-x:12px;
  --dw-nav-track:.12em;
}

/* ==========================================================================
   2) Base / reset
   ========================================================================== */

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}

body{
  margin:0;
  padding:0;
  font-family:var(--dw-font-sans);
  background:var(--dw-bg);
  color:var(--dw-ink);
  line-height:1.65;
}

a{
  color:var(--dw-accent);
  text-decoration:none;
}

a:hover{
  text-decoration:underline;
}

img,
video{
  max-width:100%;
  height:auto;
}

/* ==========================================================================
   3) Layout primitives
   ========================================================================== */

.dw-shell{
  max-width:var(--dw-page-max);
  margin:0 auto;
  padding:0 var(--dw-gutter);
}

.dw-prose{
  max-width:var(--dw-content-max);
  margin:0 auto;
  font-family:var(--dw-font-sans);
  font-size:1.06rem;
  line-height:1.7;
}

/* Generic card surface */
.dw-card,
.article-body{
  background:var(--dw-paper);
  border:1px solid var(--dw-border);
  border-radius:var(--dw-radius-sm);
  box-shadow:0 2px 6px rgba(0,0,0,.04);
}

/* ==========================================================================
   4) Typography
   ========================================================================== */

.dw-title{
  font-family:var(--dw-font-sans);
  font-size:var(--dw-step-4);
  text-transform:uppercase;
  letter-spacing:.14em;
  line-height:1.15;
  margin:0 0 .5rem;
}

.dw-subtitle{
  font-family:var(--dw-font-sans);
  font-size:var(--dw-step-1);
  color:var(--dw-ink-2);
  max-width:52rem;
  margin:0 auto;
}

/* Prose copy */
.dw-prose p{
  margin:0 0 1.15rem;
  font-size:1.06rem;
  line-height:1.7;
}

/* Headings */
.dw-prose h1{font-size:2.25rem;}
.dw-prose h2{font-size:1.85rem;}
.dw-prose h3{font-size:1.55rem;}
.dw-prose h4{font-size:1.35rem;}
.dw-prose h5{font-size:1.15rem;}
.dw-prose h6{font-size:1rem;}

.dw-prose h1,
.dw-prose h2,
.dw-prose h3,
.dw-prose h4,
.dw-prose h5,
.dw-prose h6{
  font-family:var(--dw-font-sans);
  text-transform:uppercase;
  letter-spacing:.05em;
  line-height:1.2;
  margin:1.6rem 0 .6rem;
  font-weight:600;
}

.dw-kicker{
  display:inline-block;
  font-family:var(--dw-font-sans);
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.10em;
  color:var(--dw-ink-2);
  border:1px solid var(--dw-border);
  padding:.22rem .6rem;
  border-radius:999px;
}

.dw-quote{
  margin:1.4rem 0;
  padding:.9rem 1rem;
  border-left:4px solid var(--dw-accent);
  background:#f9fafb;
  font-style:italic;
}

.dw-prose ul,
.dw-prose ol{
  margin:0 0 1.15rem 1.4rem;
  padding:0;
}

.dw-prose li{
  margin:.25rem 0;
  font-size:1.06rem;
  line-height:1.7;
  font-family:var(--dw-font-sans);
}

/* Code blocks */
pre{
  background:#0f172a;
  color:#e5e7eb;
  padding:1rem 1.1rem;
  border-radius:var(--dw-radius-sm);
  overflow-x:auto;
  font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;
  font-size:.92rem;
  line-height:1.55;
  margin:1.2rem 0;
}

code{
  font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;
  font-size:.92em;
}



/* ==========================================================================
   Editorial article components
   ========================================================================== */

.dw-article{
  max-width:var(--dw-content-max);
  margin:0 auto;
}

.dw-intro,
.dw-body{
  max-width:var(--dw-content-max);
  margin:0 auto;
}

.dw-intro p{
  font-size:var(--dw-step-2);
  line-height:1.65;
  color:var(--dw-ink-2);
  margin:0 0 1.4rem;
}

.dw-body p{
  margin:0 0 1.15rem;
  font-size:1.06rem;
  line-height:1.7;
}

.dw-body h2,
.dw-body h3,
.dw-body h4,
.dw-body h5,
.dw-body h6{
  font-family:var(--dw-font-sans);
  text-transform:uppercase;
  letter-spacing:.05em;
  line-height:1.2;
  margin:1.6rem 0 .6rem;
  font-weight:600;
}

.dw-body h2{font-size:1.85rem;}
.dw-body h3{font-size:1.55rem;}
.dw-body h4{font-size:1.35rem;}
.dw-body h5{font-size:1.15rem;}
.dw-body h6{font-size:1rem;}

.dw-steps{
  margin:0 0 1.15rem 1.4rem;
  padding:0;
}

.dw-steps li{
  margin:.25rem 0;
  font-size:1.06rem;
  line-height:1.7;
  font-family:var(--dw-font-sans);
}

.dw-signoff{
  margin-top:1.75rem;
  font-size:var(--dw-step-1);
  font-weight:600;
  color:var(--dw-ink);
}

.dw-pull{
  margin:2rem auto;
  padding:1.35rem 1.5rem;
  max-width:720px;
  border-left:4px solid var(--dw-accent);
  border-right:4px solid var(--dw-accent);
  border-radius:12px;
  background:rgba(0,79,122,.05);
  color:var(--dw-accent);
  font-size:1.35rem;
  line-height:1.5;
  font-weight:500;
  text-align:center;
}

.dw-pull::before{
  content:"\201C";
  font-size:2.2rem;
  line-height:0;
  vertical-align:-.2em;
  margin-right:.12rem;
  color:var(--dw-accent);
}

.dw-pull::after{
  content:"\201D";
  font-size:2.2rem;
  line-height:0;
  vertical-align:-.35em;
  margin-left:.12rem;
  color:var(--dw-accent);
}

/* ==========================================================================
   5) Header + navigation
   ========================================================================== */

.dw-header{
  background:var(--dw-paper);
  border-bottom:1px solid var(--dw-border);
  position:sticky;
  top:0;
  z-index:2000;
}

.dw-header__row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:nowrap;
  min-height:68px;
}

/* Brand */
.dw-brand{
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  white-space:nowrap;
  text-decoration:none;
  color:var(--dw-ink);
}

/* Brand logo */
.dw-brand__mark{
  width:80px;
  height:80px;
  display:block;
}

/* SubStack icon */
.dw-nav__icon{
  height:20px;
  width:auto;
  display:block;
}

.dw-brand__text{
  font-family:var(--dw-font-sans);
  font-weight:700;
  font-size:.85rem;
  text-transform:uppercase;
  letter-spacing:.10em;
}

/* Nav container */
.dw-nav{
  flex:1 1 auto;
  min-width:0;
  font-family:var(--dw-font-sans);
}

/* Desktop nav list */
.dw-nav__list{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:nowrap;
  white-space:nowrap;
  overflow:visible;
}

.dw-nav__item{
  position:relative;
}

/* Top-level nav buttons */
.dw-nav__link{
  appearance:none;
  background:var(--dw-paper);
  border:1px solid var(--dw-border);
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:var(--dw-nav-pad-y) var(--dw-nav-pad-x);
  min-height:38px;
  font-size:.74rem;
  letter-spacing:var(--dw-nav-track);
  text-transform:uppercase;
  color:var(--dw-ink);
  border-radius:999px;
}

.dw-nav__link:hover{
  background:#f9fafb;
  text-decoration:none;
}

.dw-nav__link.is-active{
  background:var(--dw-ink);
  color:#fff;
  border-color:var(--dw-ink);
}

/* Desktop dropdown */
.dw-nav__menu{
  position:absolute;
  top:calc(100% + 6px);
  left:0;
  transform:none;
  min-width:220px;
  background:var(--dw-ink);
  display:none;
  z-index:3000;
  border-radius:14px;
  padding:8px 0;
  box-shadow:0 18px 40px rgba(0,0,0,.22);
}

/* Keep hidden state lightweight so hover can override it */
.dw-nav__menu[hidden]{
  display:none;
}

/* Hover bridge */
.dw-nav__item--has-menu::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:100%;
  height:10px;
}

/* Desktop show */
.dw-nav__item--has-menu:hover > .dw-nav__menu,
.dw-nav__item--has-menu:focus-within > .dw-nav__menu{
  display:block !important;
}

.dw-nav__menu-list{
  list-style:none;
  margin:0;
  padding:0;
}

.dw-nav__menu-link{
  display:block;
  padding:10px 14px;
  color:#fff;
  text-align:left;
  font-size:.76rem;
  letter-spacing:.10em;
  text-transform:uppercase;
}

.dw-nav__menu-link:hover{
  background:#1f2937;
  text-decoration:none;
}

/* ==========================================================================
   6) Mobile navigation
   ========================================================================== */

.dw-nav__toggle{
  display:none;
  background:none;
  border:0;
  padding:8px;
  cursor:pointer;
  margin-left:auto;
}

.dw-nav__toggle span{
  display:block;
  width:24px;
  height:2px;
  background:var(--dw-ink);
  margin:5px 0;
  transition:transform .2s ease, opacity .2s ease;
}

.dw-nav__toggle.is-open span:nth-child(1){
  transform:translateY(7px) rotate(45deg);
}

.dw-nav__toggle.is-open span:nth-child(2){
  opacity:0;
}

.dw-nav__toggle.is-open span:nth-child(3){
  transform:translateY(-7px) rotate(-45deg);
}

@media (max-width:860px){

  .dw-nav__toggle{
    display:block;
  }

  .dw-nav__list{
    display:none;
    position:absolute;
    top:100%;
    left:0;
    right:0;
    background:var(--dw-paper);
    border-bottom:1px solid var(--dw-border);
    padding:12px 16px 16px;
    flex-direction:column;
    align-items:stretch;
    gap:10px;
    box-shadow:0 12px 28px rgba(0,0,0,.18);
  }

  .dw-nav-open .dw-nav__list{
    display:flex;
  }

  .dw-nav__link{
    width:100%;
    justify-content:space-between;
  }

  .dw-nav__submenu-toggle{
    justify-content:space-between;
    width:100%;
  }

  .dw-nav__chev{
    width:10px;
    height:10px;
    border-right:2px solid var(--dw-ink);
    border-bottom:2px solid var(--dw-ink);
    transform:rotate(45deg);
    transition:transform .15s ease;
  }

  .dw-nav__submenu-toggle[aria-expanded="true"] .dw-nav__chev{
    transform:rotate(-135deg);
  }

  .dw-nav__menu{
    position:static;
    transform:none;
    margin-top:8px;
    background:#f3f4f6;
    border-radius:10px;
    box-shadow:none;
    padding:8px 0;
    display:block;
  }

  .dw-nav__menu[hidden]{
    display:none;
  }

  .dw-nav__menu-link{
    color:var(--dw-ink);
    text-align:left;
    padding:8px 12px;
    background:none;
  }

  .dw-nav__menu-link:hover{
    background:#e5e7eb;
  }

  .dw-nav__item--has-menu::after{
    display:none;
  }
}

/* ==========================================================================
   7) Hero + page intro alignment
   ========================================================================== */

.dw-hero{
  padding-top:18px;
}

.dw-hero__image{
  width:100%;
  max-width:var(--dw-content-max);
  margin:18px auto 0;
  display:block;
  border-radius:var(--dw-radius);
  box-shadow:var(--dw-shadow);
  object-fit:cover;
}

.dw-hero__inner{
  max-width:var(--dw-content-max);
  margin:0 auto;
  padding:0;
  text-align:left;
}

.dw-hero__inner h1,
.dw-hero__inner .dw-title{
  text-transform:uppercase;
  letter-spacing:.14em;
}

.dw-hero__swoosh{
  width:100%;
  overflow:hidden;
}

.dw-hero__swoosh svg{
  display:block;
  width:100%;
  height:100px;
}

/* ==========================================================================
   8) Figures
   ========================================================================== */

.dw-figure{
  display:block;
  width:100%;
  max-width:var(--dw-content-max);
  margin:1.25rem auto 1.75rem;
  border-radius:var(--dw-radius);
  overflow:hidden;
  box-shadow:var(--dw-shadow);
}

.dw-figure img{
  display:block;
  width:100%;
  height:auto;
  object-fit:cover;
}

/* ==========================================================================
   9) Media embeds
   ========================================================================== */

.dw-prose iframe,
.article-body iframe{
  width:100% !important;
  aspect-ratio:16 / 9;
  border:0;
}

/* ==========================================================================
   10) Components
   ========================================================================== */

.dw-callout{
  background:#f0f9ff;
  border:1px solid #c2e0ff;
  border-radius:var(--dw-radius-sm);
  padding:.9rem 1rem;
  font-family:var(--dw-font-sans);
  font-size:.92rem;
  margin:1.1rem 0;
}

.dw-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.55rem .95rem;
  border-radius:999px;
  border:1px solid var(--dw-accent);
  color:var(--dw-accent);
  font-family:var(--dw-font-sans);
  font-size:.84rem;
  text-transform:uppercase;
  letter-spacing:.14em;
}

.dw-btn:hover{
  background:var(--dw-accent);
  color:#fff;
  text-decoration:none;
}

/* ==========================================================================
   11) Book pages
   Fix:
   - desktop stays as a stable two-column layout
   - long subtitles no longer push text below the cover
   - mobile stacks cleanly
   ========================================================================== */

.content-wrap{
  max-width:var(--dw-content-max);
  margin:0 auto;
  padding:20px var(--dw-gutter) 40px;
}

.content-header--no-cover{
  grid-template-columns:minmax(0, 1fr);
}

.content-header{
  display:grid;
  grid-template-columns:260px minmax(0, 1fr);
  gap:1.75rem;
  align-items:start;
  margin-bottom:1.75rem;
}

.book-cover{
  width:260px;
  max-width:100%;
}

.book-cover img{
  display:block;
  width:100%;
  border-radius:4px;
  box-shadow:0 6px 18px rgba(0,0,0,.2);
}

.book-meta{
  min-width:0;
}

.book-meta h1{
  margin:0 0 .35rem;
  font-size:1.8rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  line-height:1.15;
}

.book-meta h2{
  margin:0 0 .5rem;
  font-size:1rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.18em;
  line-height:1.35;
  color:#555;
}

.book-meta p{
  margin:.35rem 0;
  font-size:.96rem;
  line-height:1.65;
}

.buy-link{
  margin-top:.8rem;
  display:inline-block;
  padding:.5rem .9rem;
  border-radius:999px;
  border:1px solid var(--dw-accent);
  font-size:.85rem;
  text-transform:uppercase;
  letter-spacing:.14em;
}

.buy-link:hover{
  background:var(--dw-accent);
  color:#fff;
  text-decoration:none;
}

.article-body{
  padding:1.75rem 1.25rem;
  font-family:var(--dw-font-sans);
}

/* Book layout stacks only on smaller screens */
@media (max-width:760px){
  .content-header{
    grid-template-columns:1fr;
  }

  .book-cover{
    width:100%;
    max-width:260px;
  }
}

/* ==========================================================================
   12) Footer
   ========================================================================== */

.dw-footer{
  max-width:var(--dw-content-max);
  margin:1.8rem auto 2.5rem;
  padding-top:1rem;
  border-top:1px solid var(--dw-border);
  font-size:.82rem;
  color:#6b7280;
  text-align:center;
  font-family:var(--dw-font-sans);
}

/* ==========================================================================
   13) Global Sans Enforcement
   ========================================================================== */

body,
.dw-prose,
.dw-prose p,
.dw-prose li,
.dw-prose span,
.dw-prose strong,
.dw-prose em,
.dw-callout,
.dw-quote,
.dw-intro,
.dw-body,
.dw-steps,
.dw-pull,
.article-body{
  font-family:var(--dw-font-sans) !important;
}

blockquote {
  margin: 2.5rem 0;
  padding: 1.5rem 2rem;
  border-left: 5px solid var(--dw-accent);
  background: #ffffff;
  font-style: italic;
  font-size: 1.1rem;
  color: var(--dw-ink);
  box-shadow: var(--dw-shadow);
}

/* ==========================================================================
   12) Taxonomy + related content
   Added for tags, categories, archive listings, and related article threads
   ========================================================================== */

.dw-taxonomy-meta{
  max-width:var(--dw-content-max);
  margin:2rem auto 0;
}

.dw-taxonomy-meta .dw-prose{
  background:var(--dw-paper);
  border:1px solid var(--dw-border);
  border-radius:var(--dw-radius-sm);
  box-shadow:0 2px 6px rgba(0,0,0,.04);
  padding:1rem 1.1rem;
}

.dw-taxonomy-meta p{
  margin:.35rem 0;
  font-size:.95rem;
  line-height:1.6;
  color:var(--dw-ink-2);
}

.dw-taxonomy-meta strong{
  color:var(--dw-ink);
  font-weight:700;
}

.dw-taxonomy-meta a{
  display:inline-flex;
  align-items:center;
  gap:.25rem;
  margin:.18rem .35rem .18rem 0;
  padding:.28rem .62rem;
  border-radius:999px;
  border:1px solid var(--dw-border);
  background:var(--dw-soft, #f8fafc);
  color:var(--dw-accent);
  font-size:.8rem;
  line-height:1;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.dw-taxonomy-meta a:hover{
  background:var(--dw-accent);
  border-color:var(--dw-accent);
  color:#fff;
  text-decoration:none;
}

.dw-related{
  max-width:var(--dw-content-max);
  margin:2.4rem auto 0;
}

.dw-related .dw-prose{
  background:var(--dw-paper);
  border:1px solid var(--dw-border);
  border-radius:var(--dw-radius);
  box-shadow:0 2px 8px rgba(0,0,0,.05);
  padding:1.35rem 1.25rem;
}

.dw-related h2{
  margin:0 0 1rem;
  font-size:1.2rem;
  text-transform:uppercase;
  letter-spacing:.12em;
}

.dw-related ul{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:1rem 1.1rem;
}

.dw-related li{
  margin:0;
  padding:.9rem .95rem;
  border:1px solid var(--dw-border);
  border-radius:var(--dw-radius-sm);
  background:#fafafa;
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}

.dw-related li:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 22px rgba(0,0,0,.08);
  border-color:#d1d5db;
}

.dw-related li h3{
  margin:0 0 .35rem;
  font-size:1rem;
  letter-spacing:.04em;
  text-transform:none;
  line-height:1.35;
}

.dw-related li p{
  margin:0 0 .35rem;
  font-size:.92rem;
  color:var(--dw-ink-2);
}

.dw-related li p:last-child{
  margin-bottom:0;
}

.dw-section-listing{
  max-width:var(--dw-content-max);
  margin:0 auto;
}

.dw-section-listing .dw-prose{
  background:var(--dw-paper);
  border:1px solid var(--dw-border);
  border-radius:var(--dw-radius);
  box-shadow:0 2px 8px rgba(0,0,0,.05);
  padding:1.35rem 1.25rem;
}

.dw-section-listing h2{
  margin-top:0;
  margin-bottom:1rem;
}

.dw-section-listing > .dw-shell{
  padding-top:1.25rem;
  padding-bottom:1.5rem;
}

.dw-section-listing ul{
  list-style:none;
  margin:0;
  padding:0;
}

.dw-section-listing li{
  margin:0 0 1rem;
  padding:0 0 1rem;
  border-bottom:1px solid var(--dw-border);
}

.dw-section-listing li:last-child{
  margin-bottom:0;
  padding-bottom:0;
  border-bottom:0;
}

.dw-section-listing li h3{
  margin:0 0 .3rem;
  font-size:1.08rem;
  text-transform:none;
  letter-spacing:.03em;
}

.dw-section-listing li p{
  margin:0 0 .25rem;
  color:var(--dw-ink-2);
}

.dw-nav__menu-link.is-active{
  background:#1f2937;
  color:#fff;
}

.dw-nav__menu-link[href*="/archive/"]{
  border-top:1px solid rgba(255,255,255,.14);
  margin-top:.25rem;
  padding-top:.8rem;
}

@media (max-width:860px){
  .dw-nav__menu-link.is-active{
    background:#dbeafe;
    color:var(--dw-accent);
  }

  .dw-nav__menu-link[href*="/archive/"]{
    border-top:1px solid #d1d5db;
  }
}

@media (max-width:760px){
  .dw-related ul{
    grid-template-columns:1fr;
  }

  .dw-taxonomy-meta .dw-prose,
  .dw-related .dw-prose,
  .dw-section-listing .dw-prose{
    padding:1rem .95rem;
  }
}
