:root{
  --mono: "Roboto Mono", "Noto Sans Symbols 2", "Apple Symbols", "Segoe UI Symbol", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;

  --ink: #000;
  --bg: #fff;
  --line: #000;
  --lineStyle: solid;

  --muted: rgba(0,0,0,.72);
  --muted2: rgba(0,0,0,.58);

  /* Hover inversion helpers (keeps contrast correct across modes) */
  --hoverAccent: rgba(255,255,255,.86);
  --hoverLine: rgba(255,255,255,.92);

  --gap: 12px;
  --min: 280px;

  --tTiny: 11px;
  --tSmall: 12px;
  --tMid: 14px;
  --tBig: 16px;

  --radius: 0px;
  --thumb: 88px;
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  font-variant-emoji: text;
  margin:0;
  font-family: var(--mono);
  background: var(--bg);
  color: var(--ink);
  overflow-x:hidden;
}

a{ color: inherit; text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }
a:hover{ text-decoration-thickness: 2px; }

button, input, textarea, select { font-family: var(--mono); }

/* Theme variants */
body[data-theme="specter"]{
  --bg: #fbfbff;
  --ink: #0b0b0c;
  --line: rgba(0,0,0,.88);
  --muted: rgba(0,0,0,.70);
  --muted2: rgba(0,0,0,.55);
}
body[data-theme="void"]{
  --bg: #0b0b0c;
  --ink: #ffffff;
  --line: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.80);
  --muted2: rgba(255,255,255,.62);

  /* On hover we invert to a light card, so accents need to go dark */
  --hoverAccent: rgba(0,0,0,.86);
  --hoverLine: rgba(0,0,0,.88);
}
@media (prefers-color-scheme: dark){
  body:not([data-theme]){
    --bg: #0b0b0c;
    --ink: #ffffff;
    --line: rgba(255,255,255,.92);
    --muted: rgba(255,255,255,.80);
    --muted2: rgba(255,255,255,.62);

    /* Same inversion logic as void */
    --hoverAccent: rgba(0,0,0,.86);
    --hoverLine: rgba(0,0,0,.88);
  }
}

/* Top bar (Astro Cards energy, blog edition) */
.bar{
  position: sticky;
  top: 0;
  z-index: 10;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
  padding: 10px 12px;
  background: var(--bg);
  border-bottom: 1px var(--lineStyle) var(--line);
}

.brand{
  display:inline-flex;
  gap:10px;
  align-items:baseline;
  text-decoration:none;
  border: 1px var(--lineStyle) var(--line);
  padding: 10px 12px;
  text-transform: uppercase;
  letter-spacing: .08em;
  font: 700 12px/1.1 var(--mono);
  background: var(--bg);
}
.brand:hover{ text-decoration:none; }
.brandMark{ font-weight: 400; }

.nav{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}

/* Ghost Navigation helper outputs a <ul class="nav"> list */
nav.nav ul.nav{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}
nav.nav li{ margin:0; padding:0; }
.nav ul.nav{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}
.nav li{ margin:0; padding:0; }
.nav a{
  text-decoration:none;
  border: 1px var(--lineStyle) var(--line);
  padding: 10px 12px;
  text-transform: uppercase;
  letter-spacing: .08em;
  font: 600 12px/1.1 var(--mono);
  background: var(--bg);
  color: var(--ink);
}
.nav a:hover{ text-decoration:none; }

.spacer{ flex: 1; }

.btn{
  font: 600 12px/1.1 var(--mono);
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 10px 12px;
  border-radius: var(--radius);
  border: 1px var(--lineStyle) var(--line);
  background: var(--ink);
  color: var(--bg);
  cursor: pointer;
  text-decoration:none;
}
.btn.ghost{
  background: var(--bg);
  color: var(--ink);
}
.btn:active{ transform: translateY(1px); }

.wrap{
  max-width: 1120px;
  margin: 0 auto;
  padding: 18px 12px 40px;
}

/* Mast */
.mast{
  display:flex;
  justify-content: space-between;
  align-items:flex-end;
  gap: 16px;
  flex-wrap: wrap;
  padding: 10px 2px 18px;
}
.title{
  font: 300 clamp(28px, 4.5vw, 68px)/1 var(--mono);
  letter-spacing: .06em;
  text-transform: uppercase;
  margin:0;
}
.sub{
  margin: 6px 0 0;
  font: 500 12px/1.45 var(--mono);
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--muted);
}

.mast{
  display:flex;
  justify-content: space-between;
  align-items:center;
  gap: 16px;
  flex-wrap: wrap;
  padding: 10px 2px 18px;
}

.mastChips{
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
  align-items:center;
}

.mastChip{
  font: 700 12px/1.1 var(--mono);
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 10px 14px;
}

.k{
  margin:0 0 6px;
  font: 700 11px/1 var(--mono);
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--muted);
}

/* Grid + cards */
.grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--min), 1fr));
  gap: var(--gap);
  align-items: stretch;
}

.card{
  border: 1px var(--lineStyle) var(--line);
  border-radius: var(--radius);
  background: var(--bg);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  min-height: unset;
  width: 100%;
}

.postCard{ position: relative; }
.cardLink{
  position:absolute;
  inset:0;
  z-index: 5;
  cursor: pointer;
  text-decoration:none;
}
.postCard > :not(.cardLink){ position: relative; z-index: 2; }
.cardLink{ display:block; }
.cardLink:focus-visible{
  outline: 2px solid var(--line);
  outline-offset: -2px;
}

.top{
  padding: 12px 12px 8px;
  border-bottom: 1px var(--lineStyle) var(--line);
  background: var(--bg);
}
.dow{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:10px;
  margin-bottom: 8px;
}
.name{
  font: 700 var(--tBig)/1 var(--mono);
  letter-spacing: .08em;
  text-transform: uppercase;
  display:flex;
  align-items: baseline;
  gap: 8px;
  min-width: 0;
}
.name .t{
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.date{
  font: 600 var(--tSmall)/1 var(--mono);
  letter-spacing: .08em;
  color: var(--muted);
  text-transform: uppercase;
  white-space: nowrap;
}
.dowGlyph{ font-size: 18px; line-height: 1; font-weight: 400; }

.chips{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  justify-content:flex-start;
}
.chip{
  background: var(--bg);
  border: 1px var(--lineStyle) var(--line);
  border-radius: var(--radius);
  padding: 6px 10px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font: 600 var(--tTiny)/1 var(--mono);
  letter-spacing:.07em;
  text-transform: uppercase;
  color: var(--ink);
  opacity:.95;
  user-select:none;
  white-space:nowrap;
  text-decoration:none;
}
a.chip:hover{ text-decoration:none; }

.mid{
  padding: 14px 12px 10px;
  display:flex;
  flex-direction:column;
  gap: 10px;
  flex:1;
}


/* Homepage card thumbnail (featured image) */
.mediaRow{
  --thumbCol: clamp(200px, 24vw, 320px);
  display:grid;
  gap: 14px;
  align-items: start; /* stop stretching/smushing */
  grid-template-columns: var(--thumbCol) 1fr; /* image left, text right */
  grid-template-areas: "thumb text";
}
.mediaRow.mediaRight{
  grid-template-columns: 1fr var(--thumbCol); /* image right */
  grid-template-areas: "text thumb";
}

.mediaRow .thumb{
  grid-area: thumb;
  width: 100%;
  min-height: 220px; /* the framed image panel */
  border: 1px var(--lineStyle) var(--line);
  border-radius: var(--radius);
  overflow:hidden;
  background: var(--bg);
  margin: 0;
}
.mediaRow .thumb img{
  display:block;
  width:100%;
  height:100%;
  object-fit: cover;
}

.mediaRow .text{
  min-width: 0;
  /* no bordered text panel; let the excerpt breathe */
  min-height: 0;
  border: 0;
  border-radius: 0;
  padding: 0;
}
.mediaRow .excerpt{
  margin:0;
  white-space: pre-wrap;
}

/* Mobile: stack */
@media (max-width: 720px){
  .mediaRow,
  .mediaRow.mediaRight{
    grid-template-columns: 1fr;
    grid-template-areas:
      "thumb"
      "text";
  }
  .thumb{
    min-height: 0;
    aspect-ratio: 16 / 9;
  }
}

.excerpt{

  margin:0;
  font: 400 var(--tMid)/1.75 var(--mono);
  letter-spacing: 0;
  color: var(--muted);
}


.bottom{
  border-top: 1px var(--lineStyle) var(--line);
  background: var(--bg);
  padding: 12px 12px 14px;
  display:flex;
  flex-direction:column;
  gap:6px;
  align-items:flex-start;
  justify-content:center;
}
.signLine{
  font: 600 var(--tSmall)/1.2 var(--mono);
  letter-spacing:.08em;
  text-transform: uppercase;
  color: var(--muted);
  display:flex;
  gap:8px;
  align-items:center;
}
.signGlyph{ font-size: 18px; line-height: 1; }

/* Hover = subtle inversion */
.postCard:hover{
  background: var(--ink);
  color: var(--bg);
  border-color: var(--hoverLine);
  box-shadow: inset 0 0 0 1px var(--hoverLine);
}
.postCard:hover .top,
.postCard:hover .mid,
.postCard:hover .bottom{
  background: var(--ink);
  color: var(--bg);
}
.postCard:hover .excerpt,
.postCard:hover .date,
.postCard:hover .signLine,
.postCard:hover .k{
  color: var(--hoverAccent);
}
.postCard:hover .chip{
  background: transparent;
  color: var(--bg);
  border-color: var(--hoverLine);
}

/* Keep internal borders visible on hover */
.postCard:hover .top{ border-bottom-color: var(--hoverLine); }
.postCard:hover .bottom{ border-top-color: var(--hoverLine); }
.postCard:hover .thumb{ border-color: var(--hoverLine); }



/* Hover styles can be configured via Ghost Design settings */
body[data-hover="borders"] .postCard:hover{
  background: var(--bg);
  color: inherit;
  border-color: var(--line);
  box-shadow: inset 0 0 0 1px var(--line);
}
body[data-hover="borders"] .postCard:hover .top,
body[data-hover="borders"] .postCard:hover .mid,
body[data-hover="borders"] .postCard:hover .bottom{
  background: var(--bg);
  color: inherit;
}
body[data-hover="borders"] .postCard:hover .excerpt,
body[data-hover="borders"] .postCard:hover .date,
body[data-hover="borders"] .postCard:hover .signLine,
body[data-hover="borders"] .postCard:hover .k{
  color: var(--muted);
}
body[data-hover="borders"] .postCard:hover .thumb{ border-color: var(--line); }
body[data-hover="borders"] .postCard:hover .chip{
  background: var(--bg);
  color: var(--ink);
  border-color: var(--line);
}

/* Pagination */
.pagination{
  display:flex;
  justify-content: space-between;
  align-items:center;
  gap:10px;
  margin: 18px 0 0;
  padding-top: 18px;
  border-top: 1px var(--lineStyle) var(--line);
}
.pagination a{
  text-decoration:none;
}
.pagination .page-number{
  font: 600 12px/1 var(--mono);
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--muted);
}

/* Single post */
.postHeader{
  border: 1px var(--lineStyle) var(--line);
  padding: 14px 14px 12px;
  background: var(--bg);
}
.postHeaderChips{ margin: 0; }
.postHeaderChipsTop{ margin-bottom: 10px; }
.postHeaderChipsMeta{ margin-top: 6px; }
.postHeaderChipsMeta .planet{ margin-right: 2px; }
.postTitle{
  margin:0 0 10px;
  font: 400 clamp(22px, 3.2vw, 40px)/1.15 var(--mono);
  letter-spacing: .02em;
  text-transform: none;
}


.postImage{
  margin: 12px 0 0;
  border: 1px var(--lineStyle) var(--line);
  background: var(--bg);
}
.postImage img{ display:block; width:100%; height:auto; }
.postImage figcaption{
  padding: 10px 12px;
  border-top: 1px var(--lineStyle) var(--line);
  font: 500 12px/1.4 var(--mono);
  color: var(--muted);
}

/* Koenig content */
.content{
  border: 1px var(--lineStyle) var(--line);
  border-top: none;
  padding: 18px 16px;
  background: var(--bg);
}

.postFooter{
  border: 1px var(--lineStyle) var(--line);
  border-top: none;
  padding: 12px 14px;
  background: var(--bg);
}
.postCtas{
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
}

.content > :first-child{ margin-top: 0; }
.content > :last-child{ margin-bottom: 0; }

.content p, .content li{
  font: 400 16px/1.75 var(--mono);
  letter-spacing: .005em;
  color: var(--ink);
}
.content p{ margin: 0 0 14px; }
.content h2, .content h3, .content h4{
  margin: 22px 0 10px;
  font: 700 13px/1.2 var(--mono);
  text-transform: uppercase;
  letter-spacing: .08em;
}

/* Chip borders for headings */
.content h2,
.content h3{
  display: inline-block;
  width: fit-content;
  max-width: 100%;
  border: 1px var(--lineStyle) var(--line);
  border-radius: var(--radius);
  padding: 8px 10px;
  background: var(--bg);
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}

/* Size hierarchy: H2 bigger chip than H3 */
.content h2{
  font: 700 15px/1.15 var(--mono);
  padding: 10px 14px;
  letter-spacing: .09em;
}
.content h3{
  font: 700 12px/1.15 var(--mono);
  padding: 7px 10px;
  letter-spacing: .10em;
}

.content blockquote{
  margin: 18px 0;
  padding: 12px 14px;
  border-left: 3px solid var(--line);
  background: rgba(0,0,0,.03);
}
body[data-theme="void"] .content blockquote,
@media (prefers-color-scheme: dark){
  body:not([data-theme]) .content blockquote{ background: rgba(255,255,255,.06); }
}
.content code{
  font: 500 13px/1.5 var(--mono);
  padding: 2px 4px;
  border: 1px var(--lineStyle) var(--line);
}
.content pre{
  border: 1px var(--lineStyle) var(--line);
  padding: 12px 14px;
  overflow:auto;
}
.content pre code{ border: none; padding: 0; }

.content hr{
  border: none;
  border-top: 1px var(--lineStyle) var(--line);
  margin: 22px 0;
}

.kg-width-wide, .kg-width-full{ margin-left: 0; margin-right: 0; }
.kg-image-card img{ width: 100%; height: auto; display:block; border: 1px var(--lineStyle) var(--line); }

/* Footer */
.footer{
  margin-top: 26px;
  padding: 18px 12px 28px;
  border-top: 1px var(--lineStyle) var(--line);
}
.footerLine{
  margin:0;
  font: 600 12px/1.6 var(--mono);
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--muted);
}

/* Error */
.error{
  border: 1px var(--lineStyle) var(--line);
  padding: 18px 16px;
  background: var(--bg);
}


/* Feature image (pages/posts) */
.featureImage{
  margin: 10px 0 14px;
  border: 1px var(--lineStyle) var(--line);
  background: var(--bg);
}
.featureImage img{
  display:block;
  width:100%;
  height:auto;
}
.featureCaption{
  padding: 8px 10px;
  border-top: 1px var(--lineStyle) var(--line);
  font-size: 12px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .08em;
}


/* Small screens */
@media (max-width: 560px){
  :root{ --min: 220px; }
  .brandName{ display:none; }
  .wrap{ padding-top: 14px; }
  .postHeader, .content{ padding: 14px 12px; }
}


/* Embedded Astro Cards tool */
.toolFrameWrap{
  border: 1px var(--lineStyle) var(--line);
  background: var(--bg);
  overflow: hidden;
}
.toolFrame{
  display:block;
  width:100%;
  height: min(88vh, 980px);
  border: 0;
}


/* Planetary weekday glyph spacing */
.planet{ display:inline-block; width:1.2em; text-align:center; margin-right:8px; }
.date .planet{ color: var(--muted); }




/* ===== Homepage Mast: Today's transits (chips + fade-in list) ===== */
.mast{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 14px;
  margin: 10px 0 14px;
}
.mastNow{
  flex: 1 1 auto;
  min-width: 0;
}
.mastChips{
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
  align-items:center;
}
.mastTransits{
  margin-top: 10px;
  display:flex;
  flex-direction:column;
  gap: 8px;
}
.mastTransitRow{
  display:flex;
  gap: 10px;
  align-items:flex-start;
  font: 600 var(--tTiny)/1.35 var(--mono);
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--muted);
  opacity: 0;
  transform: translateY(4px);
  animation: mastFade .35s ease forwards;
}
.mastTransitRow .k{
  border: 1px var(--lineStyle) var(--line);
  border-radius: var(--radius);
  padding: 4px 8px;
  color: var(--ink);
  background: var(--bg);
  flex: 0 0 auto;
}
.mastTransitRow .v{
  min-width:0;
  flex: 1 1 auto;
}
@keyframes mastFade{
  to { opacity: 1; transform: translateY(0); }
}
@media (max-width: 780px){
  .mast{ flex-direction:column; }
  .mastRight{ align-self:flex-start; }
}


/* ===== Mast transit chips ===== */
.mastTransitValue{
  max-width: min(64ch, 70vw);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
@media (max-width: 520px){
  .mastTransitValue{
    max-width: 92vw;
  }
}


/* ===== Invert imagery in Void mode (for B/W dither assets) ===== */
body[data-theme="void"] .thumb img,
body[data-theme="void"] .article img,
body[data-theme="void"] .postCard img,
body[data-theme="void"] .kg-image,
body[data-theme="void"] figure img{
  filter: invert(1);
}
body[data-theme="void"] .thumb img,
body[data-theme="void"] .article img,
body[data-theme="void"] .postCard img,
body[data-theme="void"] .kg-image,
body[data-theme="void"] figure img{
  transition: filter .15s ease;
}


/* ===== Bullets: ✶ ===== */
.article ul{
  list-style: none;
  padding-left: 1.1em;
  margin: 10px 0;
}
.article ul li{
  position: relative;
  padding-left: .95em;
  margin: 6px 0;
}
.article ul li::before{
  content: "✶";
  position: absolute;
  left: 0;
  top: .15em;
  font: 600 9px/1 var(--mono);
  letter-spacing: .02em;
  opacity: .85;
}
.article ul ul{
  margin-top: 6px;
}

/* Manual transit chips you can paste into post content:
<div class="transitChips"><span class="chip">♀ △ ♃ 15° ♓</span> ... </div>
*/
.transitChips{
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
  margin: 12px 0 16px;
}
.transitChips .chip{
  padding: 8px 10px;
}


.postTransitSlot{
  margin-top: 0;
}
.postTransitSlot .transitChips{
  margin: 0;
}


/* Per-post transit chips: place inline with tag/featured chips */
.postHeaderChipsTop .transitChips{
  display: contents;
}
.postHeaderChipsTop .transitChips .chip{
  margin: 0;
}
