@import url('https://cdn.jsdelivr.net/npm/@fontsource/metamorphous@5/index.css');
@import url('https://cdn.jsdelivr.net/npm/@fontsource/new-rocker@5/index.css');
@import url('https://cdn.jsdelivr.net/npm/@fontsource/medievalsharp@5/index.css');

:root {
  --bg:#191a1c; --bg-panel:#1d1d1f; --bg-deep:#131314;
  --border:#262626; --border-soft:#242424;
  --ink:#cec8c0; --ink-bright:#c4c8ce;
  --body:#9aa0aa; --body-soft:#8c919b; --body-faint:#7d8189;
  --aside:#a4a9b1; --quote:#8a8e96;
  --gold:#c8a45a; --gold-dim:#b18d4c; --gold-deeper:#a48340;
  --gold-line:#c8a45a28; --gold-edge:#302810;
  --serif:'IM Fell English', Georgia, serif;
  --display:'Metamorphous','Pirata One',Georgia,serif;
  --blackletter:'Pirata One',Georgia,serif;
  --mono:'Courier New',ui-monospace,monospace;
  --col:710px; --pad-x:44px; --pad-top:48px; --pad-bottom:68px;
  --rhythm:38px; --para-leading:1.78;
}

* { box-sizing:border-box; margin:0; padding:0; }
html, body { background:var(--bg); }
body {
  font-family:var(--serif);
  color:var(--body);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a { color:inherit; }

.page { position:relative; min-height:100vh; padding:var(--pad-top) var(--pad-x) var(--pad-bottom); }
.col { position:relative; z-index:2; max-width:var(--col); margin:0 auto; }

.mainnav {
  position:sticky; top:0; z-index:50;
  margin:0; padding:12px 0;
  background:var(--bg);
  font-family:var(--mono); font-size:9.5px; letter-spacing:.28em; text-transform:uppercase;
}
.mainnav-inner {
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap;
  row-gap:14px; column-gap:28px; max-width:1080px; margin:0 auto; padding:0 var(--pad-x);
}
.mainnav::after {
  content:''; position:absolute; left:50%; bottom:0; transform:translateX(-50%);
  width:min(380px,42vw); height:1px;
  background:linear-gradient(to right, transparent, rgba(200,164,90,.42), transparent);
  pointer-events:none;
}
.mainnav .brand-wordmark {
  font-family:var(--display); color:var(--ink); text-decoration:none;
  font-size:22px; letter-spacing:.08em; line-height:1; flex:0 0 auto; text-transform:none;
  transition:color 220ms ease;
}
.mainnav .brand-wordmark:hover { color:var(--ink-bright); }
.mainnav .brand-wordmark .est {
  display:block; font-family:var(--mono); color:var(--body-soft);
  font-size:8px; letter-spacing:.32em; margin-top:4px; text-transform:uppercase;
}
.mainnav-links { display:flex; align-items:center; gap:0; flex-wrap:wrap; justify-content:center; flex-basis:100%; order:2; }
.mainnav-links a { color:#898e98; text-decoration:none; padding:10px 14px; position:relative; transition:color 220ms ease; }
.mainnav-links a + a::before { content:''; position:absolute; left:-1px; top:50%; width:1px; height:10px; background:#262626; transform:translateY(-50%); }
.mainnav-links a:hover { color:var(--ink-bright); }
.mainnav-links a.current { color:var(--gold); }
.mainnav-links a.current::after { content:''; position:absolute; left:14px; right:14px; bottom:4px; height:1px; background:var(--gold); opacity:.55; }

.subnav {
  position:sticky; top:86px; z-index:45; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap;
  row-gap:26px; column-gap:22px; max-width:1080px; margin:40px auto 72px; padding:0 8px;
  background:rgba(25,26,28,.94);
  backdrop-filter:blur(8px);
  font-family:var(--mono); font-size:9.5px; letter-spacing:.28em; text-transform:uppercase;
}
.subnav .brand { display:inline-flex; align-items:center; gap:12px; color:var(--gold-dim); text-decoration:none; white-space:nowrap; flex:0 0 auto; }
.subnav .brand .sep { color:#2a2620; }
.subnav .brand .here { color:var(--gold); }
.subnav .nav { display:flex; align-items:center; gap:0; flex-wrap:wrap; justify-content:center; flex-basis:100%; order:2; }
.subnav .nav a { color:#898e98; text-decoration:none; padding:10px 14px; position:relative; transition:color 220ms ease; }
.subnav .nav a + a::before { content:''; position:absolute; left:-1px; top:50%; width:1px; height:10px; background:#262626; transform:translateY(-50%); }
.subnav .nav a:hover { color:var(--ink-bright); }
.subnav .nav a.current { color:var(--gold); }
.subnav .nav a.current::after { content:''; position:absolute; left:14px; right:14px; bottom:4px; height:1px; background:var(--gold); opacity:.55; }

.eyebrow { font-family:var(--mono); font-size:10px; letter-spacing:.32em; color:var(--gold-dim); text-transform:uppercase; }
.eyebrow.sm { font-size:9px; letter-spacing:.3em; }
.eyebrow.xs { font-size:8.5px; letter-spacing:.22em; }
.display { font-family:var(--display); font-weight:400; color:var(--ink); text-align:center; line-height:1.04; letter-spacing:.015em; font-size:clamp(46px,8.2vw,84px); }
.h2-black { font-family:var(--blackletter); font-size:27px; color:var(--ink-bright); font-weight:normal; }
.h3-fell { font-family:var(--serif); font-size:19px; color:var(--ink-bright); font-style:italic; font-weight:normal; }
.dek { font-style:italic; color:var(--quote); text-align:center; }
.lede { font-style:italic; color:var(--aside); line-height:2.08; }
p { font-size:15px; color:var(--body); line-height:var(--para-leading); }
p + p { margin-top:18px; }
p.large { font-size:16px; }
em.literary { color:var(--aside); }

.ivy { display:block; width:100%; max-width:580px; height:auto; margin:0 auto; opacity:.88; }
.ivy.sm { max-width:300px; opacity:.62; }
.ivy.ft { max-width:520px; opacity:.42; }
.ivy.flip { transform:scaleY(-1); }
.ivy.subtle { max-width:420px; opacity:.46; margin-top:-10px; }

.card { position:relative; border:1px solid var(--border); border-radius:2px; background:var(--bg-panel); overflow:visible; }
.card::before, .card::after, .card > .corner-bl, .card > .corner-br { content:''; position:absolute; width:16px; height:16px; pointer-events:none; }
.card::before { top:-1px; left:-1px; border-top:2px solid var(--gold); border-left:2px solid var(--gold); }
.card::after { top:-1px; right:-1px; border-top:2px solid var(--gold); border-right:2px solid var(--gold); }
.card .corner-bl, .card .corner-br { bottom:-1px; }
.card .corner-bl { left:-1px; border-bottom:2px solid var(--gold); border-left:2px solid var(--gold); }
.card .corner-br { right:-1px; border-bottom:2px solid var(--gold); border-right:2px solid var(--gold); }
.card .card-body { padding:28px 32px; }
.card .card-body p { margin-bottom:20px; }
.card .card-body p:last-child { margin-bottom:0; }

.panel { position:relative; border:1px solid var(--border-soft); background:var(--bg-panel); padding:24px 20px; }
.panel .glint { position:absolute; bottom:0; left:16px; right:16px; height:1px; background:linear-gradient(to right, transparent, var(--gold-line), transparent); }
.panel .title-italic { font-family:var(--serif); font-size:15px; color:var(--gold); margin-bottom:10px; font-style:italic; }
.panel p { font-size:13px; color:var(--body-soft); line-height:1.85; }

.return { display:inline-block; font-family:var(--mono); font-size:9px; letter-spacing:.26em; text-transform:uppercase; color:var(--gold-deeper); text-decoration:none; border:1px solid var(--gold-edge); padding:11px 24px; transition:color 220ms ease,border-color 220ms ease; }
.return:hover { color:var(--gold); border-color:#4a3a18; }
.return.right::after { content:' →'; }
.return.left::before { content:'← '; }

.divider { display:flex; align-items:center; gap:18px; margin:32px auto; max-width:580px; }
.divider .line { flex:1; height:1px; background:linear-gradient(to right, transparent, #2a2620, transparent); }
.divider .glyph { color:var(--gold-dim); font-family:var(--mono); font-size:9px; letter-spacing:.32em; text-transform:uppercase; }

.portrait { position:relative; margin:36px auto 28px; width:100%; max-width:320px; aspect-ratio:4/5; border:1px solid var(--border); background:repeating-linear-gradient(135deg, transparent 0, transparent 16px, rgba(200,164,90,.04) 16px, rgba(200,164,90,.04) 17px), var(--bg-deep); display:flex; align-items:center; justify-content:center; }
.portrait::before, .portrait::after { content:''; position:absolute; width:14px; height:14px; border:1.5px solid var(--gold); }
.portrait::before { top:-1px; left:-1px; border-right:0; border-bottom:0; }
.portrait::after { top:-1px; right:-1px; border-left:0; border-bottom:0; }
.portrait .stub { font-family:var(--mono); font-size:9px; letter-spacing:.26em; color:var(--body-faint); text-transform:uppercase; }

.doors { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; margin:36px 0 56px; }
.doors-temp { grid-template-columns:1fr; }
.door { position:relative; display:block; text-decoration:none; padding:30px 26px 26px; background:var(--bg-panel); border:1px solid var(--border-soft); min-height:196px; overflow:hidden; transition:border-color 280ms ease,background 280ms ease; }
.door::before, .door::after { content:''; position:absolute; width:18px; height:18px; pointer-events:none; opacity:0; transition:opacity 280ms ease; }
.door::before { top:-1px; left:-1px; border-top:2px solid var(--gold); border-left:2px solid var(--gold); }
.door::after { bottom:-1px; right:-1px; border-bottom:2px solid var(--gold); border-right:2px solid var(--gold); }
.door:hover { border-color:var(--gold-edge); background:#1f1f21; }
.door:hover::before, .door:hover::after { opacity:1; }
.door .door-num { font-family:var(--mono); font-size:9px; letter-spacing:.32em; color:var(--gold-dim); text-transform:uppercase; }
.door .door-title { font-family:var(--blackletter); font-size:30px; color:var(--ink-bright); margin:14px 0 10px; letter-spacing:.01em; line-height:1; }
.door .door-tag { font-family:var(--serif); font-style:italic; font-size:14px; color:var(--aside); line-height:1.55; margin-bottom:24px; }
.door .door-enter { font-family:var(--mono); font-size:9px; letter-spacing:.28em; color:var(--gold-deeper); text-transform:uppercase; }
.door .door-enter::after { content:' →'; }
.door--writing .door-title { color:#d6c9b3; }

.section-eyebrow { font-family:var(--mono); font-size:10px; letter-spacing:.32em; text-transform:uppercase; color:var(--gold-dim); text-align:center; margin:56px 0 22px; }
.featured-link { text-decoration:none; display:block; margin-bottom:56px; }
.featured-link .card { transition:background 240ms ease; }
.featured-link:hover .card { background:#1f1f22; }
.featured-link .card .card-body { padding:32px 36px 30px; }
.featured-card-head { display:flex; justify-content:space-between; align-items:flex-start; gap:20px; margin-bottom:14px; }
.featured-link .meta-stack { display:flex; flex-direction:column; gap:5px; font-family:var(--mono); font-size:9px; letter-spacing:.24em; color:var(--gold-dim); text-transform:uppercase; }
.featured-tags { display:flex; flex-wrap:wrap; justify-content:flex-end; gap:7px; max-width:48%; font-family:var(--mono); font-size:8px; letter-spacing:.16em; color:var(--body-soft); text-transform:uppercase; text-align:right; }
.featured-link h2 { font-family:var(--display); font-weight:normal; font-size:28px; color:var(--ink-bright); margin:0 0 14px; line-height:1.18; letter-spacing:.01em; }
.featured-link p { font-size:15px; font-style:italic; color:var(--aside); line-height:1.78; }
.featured-link .return { margin-top:18px; }
.inquire-block { text-align:center; margin:0 auto 24px; max-width:520px; }
.inquire-block .dek { margin-bottom:22px; font-size:15px; }
.footer-line { text-align:center; font-family:var(--mono); font-size:9px; letter-spacing:.32em; color:var(--gold-dim); text-transform:uppercase; margin-top:18px; }

body[data-screen-label] .writing-watermark {
  position:fixed;
  left:50%;
  transform:translateX(-50%);
  width:100vw;
  max-width:none;
  height:auto;
  opacity:.055;
  pointer-events:none;
  z-index:0;
}
body[data-screen-label="Ivy — Home"] .writing-watermark { top:82px; }
body[data-screen-label="Writing — Archive"] .writing-watermark,
body[data-screen-label="Writing — Piece"] .writing-watermark { top:168px; }

body .filter-divider {
  width:min(260px, 70%);
  height:1px;
  margin:3px auto 16px;
  background:linear-gradient(to right, transparent, var(--gold-line), transparent);
}
body .filter-chip--format {
  font-size:9.5px;
  padding:8px 16px;
}
body .entry-tag::before,
body .entry-tags span::before,
body .related-tag::before { content:none; }

@media (max-width:600px) {
  .mainnav { font-size:8.5px; column-gap:12px; }
  .mainnav .brand-wordmark { font-size:18px; }
  .mainnav-links a { padding:8px 9px; }
  .subnav { top:76px; }
  .door .door-title { font-size:24px; }
  .featured-card-head { display:block; }
  .featured-tags { justify-content:flex-start; max-width:none; margin-top:12px; text-align:left; }
  body[data-screen-label] .writing-watermark { width:128vw; }
  body[data-screen-label="Ivy — Home"] .writing-watermark { top:92px; }
  body[data-screen-label="Writing — Archive"] .writing-watermark,
  body[data-screen-label="Writing — Piece"] .writing-watermark { top:150px; }
}
@media (max-width:540px) { .doors { grid-template-columns:1fr; } }


/* // BlueSky // */
.bsky {
  margin:40px 0 48px;
  border:1px solid var(--border-soft);
  background:var(--bg-deep);
  padding:24px 22px;
}
.bsky h3,
.vault-card h2 {
  font-family:var(--display);
  font-weight:normal;
  color:var(--ink-bright);
  letter-spacing:.015em;
}
.bsky h3 { font-size:22px; margin-bottom:14px; text-align:center; }
.bsky-stub {
  border:1px dashed var(--border);
  padding:18px;
  text-align:center;
  color:var(--body-soft);
}
.bsky-stub strong {
  display:block;
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:.22em;
  color:var(--gold-dim);
  text-transform:uppercase;
  margin-bottom:10px;
}
.bsky-stub p { font-size:13px; color:var(--body-soft); }