@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Crimson+Pro:ital,wght@0,300;0,400;0,600;1,300;1,400&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#0d0c0a;
  --surface:#161510;
  --surface2:#1f1e18;
  --border:rgba(255,255,255,0.07);
  --border2:rgba(255,255,255,0.13);
  --text:#e5ddd0;
  --text2:#8a7f72;
  --text3:#4f4840;
  --gold:#c09438;
  --gold2:#d4aa52;
  --gold-dim:rgba(192,148,56,0.12);
  --serif:'Playfair Display',Georgia,serif;
  --body:'Crimson Pro',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
  --rad:12px;
  --rad-sm:8px;
}

html{font-size:16px;scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--sans);line-height:1.6;min-height:100vh}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}

/* ===== NAVIGATION ===== */
.site-nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:.9rem 2rem;
  display:flex;align-items:center;justify-content:space-between;gap:2rem;
  transition:background .3s,border .3s;
}
.site-nav.scrolled{
  background:rgba(13,12,10,.95);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
}
.nav-logo{display:flex;align-items:center}
.nav-logo img{height:52px;width:auto}
.nav-logo-text{font-family:var(--serif);font-size:1.25rem;font-weight:600;color:var(--text);letter-spacing:.03em;transition:color .2s;}
.nav-logo-text:hover{color:var(--gold2);}
.nav-logo-OLD{
  font-family:var(--serif);
  font-size:1.2rem;font-weight:600;
  color:var(--text);letter-spacing:.04em;
}
.nav-links{display:flex;align-items:center;gap:1.75rem}
.nav-links a{
  font-size:.82rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;
  color:var(--text2);transition:color .2s;
}
.nav-links a:hover{color:var(--gold2)}
.nav-links a.active{color:var(--gold)}
.nav-subscribe{
  padding:7px 18px;border:1px solid var(--gold);border-radius:999px;
  font-size:.78rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;
  color:var(--gold2);background:var(--gold-dim);
  transition:all .2s;white-space:nowrap;
}
.nav-subscribe:hover{background:rgba(192,148,56,.22)}
.nav-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.nav-mobile{display:none}
.nav-toggle span{display:block;width:22px;height:1.5px;background:var(--text2);transition:all .3s}

/* ===== HERO ===== */
.site-hero{
  position:relative;height:100vh;min-height:600px;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
#hero-canvas{
  position:absolute;inset:0;width:100%;height:100%;
  pointer-events:none;
}
.hero-bg{
  position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 60%,rgba(192,148,56,.06) 0%,transparent 65%);
}
.hero-content{
  position:relative;z-index:2;
  text-align:center;padding:0 1.5rem;max-width:800px;
}
.hero-eyebrow{
  font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;
  color:var(--gold);margin-bottom:1.2rem;
  display:flex;align-items:center;justify-content:center;gap:.75rem;
}
.hero-eyebrow::before,.hero-eyebrow::after{
  content:'';display:block;width:40px;height:1px;background:var(--gold);opacity:.5;
}
.hero-title{
  font-family:var(--serif);
  font-size:clamp(2.8rem,7vw,5.5rem);
  font-weight:600;line-height:1.05;
  color:var(--text);margin-bottom:1.25rem;letter-spacing:-.01em;
}
.hero-title em{color:var(--gold2);font-style:italic}
.hero-desc{
  font-family:var(--body);font-style:italic;
  font-size:clamp(1.05rem,2vw,1.3rem);
  color:var(--text2);line-height:1.6;max-width:520px;margin:0 auto 2.5rem;
}
.hero-scroll{
  display:inline-flex;flex-direction:column;align-items:center;gap:.5rem;
  color:var(--text3);font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;
  cursor:pointer;transition:color .2s;
}
.hero-scroll:hover{color:var(--gold)}
.hero-scroll-line{
  width:1px;height:40px;background:linear-gradient(to bottom,var(--gold),transparent);
  animation:scrollline 1.8s ease-in-out infinite;
}
@keyframes scrollline{0%,100%{opacity:.4;transform:scaleY(.8)}50%{opacity:1;transform:scaleY(1)}}

/* ===== POSTS SECTION ===== */
.posts-section{padding:5rem 2rem 6rem;max-width:1280px;margin:0 auto}
.section-header{
  display:flex;align-items:baseline;justify-content:space-between;
  margin-bottom:2.5rem;padding-bottom:1rem;
  border-bottom:1px solid var(--border);
}
.section-title{
  font-family:var(--serif);font-size:1.4rem;font-weight:400;color:var(--text);
}
.section-link{
  font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--gold);transition:opacity .2s;
}
.section-link:hover{opacity:.7}

/* MASONRY GRID */
.posts-masonry{columns:3 280px;column-gap:1.5rem}

/* ===== POST CARD ===== */
.post-card{
  break-inside:avoid;page-break-inside:avoid;
  margin-bottom:1.5rem;display:inline-block;width:100%;
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--rad);overflow:hidden;
  transition:border-color .25s,transform .25s;
}
.post-card:hover{border-color:rgba(192,148,56,.35);transform:translateY(-3px)}
.post-card-image{
  position:relative;overflow:hidden;
  aspect-ratio:16/9;background:var(--surface2);
}
.post-card-image img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .4s;
}
.post-card:hover .post-card-image img{transform:scale(1.04)}
.post-card-image-placeholder{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
}
.post-card-image-placeholder svg{width:40px;height:40px;opacity:.2}
.post-card-body{padding:1.25rem}
.post-card-tag{
  display:inline-block;margin-bottom:.6rem;
  font-size:.68rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  color:var(--gold);padding:3px 10px;border:1px solid rgba(192,148,56,.3);border-radius:999px;
}
.post-card-title{
  font-family:var(--serif);font-size:1.2rem;font-weight:600;
  line-height:1.3;color:var(--text);margin-bottom:.6rem;
  transition:color .2s;
}
.post-card:hover .post-card-title{color:var(--gold2)}
.post-card-excerpt{
  font-family:var(--body);font-size:.95rem;line-height:1.6;
  color:var(--text2);margin-bottom:1rem;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.post-card-meta{
  display:flex;align-items:center;justify-content:space-between;
  font-size:.75rem;color:var(--text3);
  padding-top:.75rem;border-top:1px solid var(--border);
}
.post-card-date{}
.post-card-reading{display:flex;align-items:center;gap:.3rem}

/* ===== SINGLE POST ===== */
.post-hero{
  position:relative;min-height:55vh;
  display:flex;align-items:flex-end;
  overflow:hidden;
}
.post-hero-bg{
  position:absolute;inset:0;background:var(--surface);
}
.post-hero-bg img{
  width:100%;height:100%;object-fit:cover;opacity:.35;
}
.post-hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,var(--bg) 0%,rgba(13,12,10,.5) 60%,transparent 100%);
}
.post-hero-content{
  position:relative;z-index:2;
  max-width:780px;margin:0 auto;padding:4rem 2rem 3rem;width:100%;
}
.post-tags{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}
.post-tag{
  font-size:.68rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  color:var(--gold);padding:3px 10px;border:1px solid rgba(192,148,56,.3);border-radius:999px;
}
.post-title{
  font-family:var(--serif);
  font-size:clamp(2rem,5vw,3.2rem);
  font-weight:700;line-height:1.1;color:var(--text);
  margin-bottom:1.25rem;
}
.post-meta{
  display:flex;align-items:center;gap:1.5rem;
  font-size:.82rem;color:var(--text2);flex-wrap:wrap;
}
.post-meta-author{display:flex;align-items:center;gap:.5rem}
.post-meta-author img{
  width:28px;height:28px;border-radius:50%;object-fit:cover;
  border:1px solid var(--border2);
}
.post-meta-sep{color:var(--text3)}

/* Reading progress */
.reading-progress{
  position:fixed;top:0;left:0;right:0;height:2px;z-index:200;
  background:transparent;
}
.reading-progress-bar{
  height:100%;background:var(--gold);width:0%;transition:width .1s linear;
}

/* Post content */
.post-content-wrap{
  max-width:780px;margin:0 auto;padding:3rem 2rem 5rem;
}
.post-content{
  font-family:var(--body);font-size:1.15rem;line-height:1.85;color:#d4c9bc;
}
.post-content h2,.post-content h3,.post-content h4{
  font-family:var(--serif);color:var(--text);
  margin:2.5rem 0 1rem;line-height:1.2;
}
.post-content h2{font-size:1.8rem;font-weight:600}
.post-content h3{font-size:1.4rem;font-weight:600}
.post-content h4{font-size:1.1rem;font-weight:600}
.post-content p{margin-bottom:1.5rem}
.post-content p:last-child{margin-bottom:0}
.post-content a{color:var(--gold2);border-bottom:1px solid rgba(192,148,56,.3);transition:border-color .2s}
.post-content a:hover{border-color:var(--gold)}
.post-content blockquote{
  border-left:2px solid var(--gold);margin:2rem 0;
  padding:.75rem 1.5rem;background:var(--surface);border-radius:0 var(--rad-sm) var(--rad-sm) 0;
  font-style:italic;color:var(--text2);
}
.post-content img{border-radius:var(--rad-sm);margin:2rem auto}
.post-content code{
  font-size:.85em;background:var(--surface2);padding:2px 6px;border-radius:4px;
  font-family:monospace;color:var(--gold2);
}
.post-content pre{
  background:var(--surface2);border:1px solid var(--border);
  border-radius:var(--rad-sm);padding:1.25rem;overflow-x:auto;margin:2rem 0;
}
.post-content pre code{background:none;padding:0;color:var(--text)}
.post-content ul,.post-content ol{padding-left:1.5rem;margin-bottom:1.5rem}
.post-content li{margin-bottom:.4rem}
.post-content hr{border:none;border-top:1px solid var(--border);margin:3rem 0}
.post-content .kg-width-wide{margin-left:calc(-10vw);margin-right:calc(-10vw)}

/* Post first letter drop cap */
.post-content > p:first-of-type::first-letter{
  font-family:var(--serif);font-size:4rem;float:left;
  line-height:.72;margin-right:.1em;margin-top:.1em;
  color:var(--gold);font-weight:700;
}

/* Author box */
.post-author{
  max-width:780px;margin:0 auto;padding:0 2rem 4rem;
}
.post-author-box{
  display:flex;gap:1.25rem;align-items:flex-start;
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--rad);padding:1.5rem;
}
.post-author-avatar{
  width:56px;height:56px;border-radius:50%;object-fit:cover;
  border:2px solid var(--border2);flex-shrink:0;
}
.post-author-name{
  font-family:var(--serif);font-size:1.05rem;font-weight:600;
  color:var(--text);margin-bottom:.3rem;
}
.post-author-bio{font-size:.88rem;color:var(--text2);line-height:1.55}

/* ===== TAG PAGE ===== */
.tag-hero{
  padding:7rem 2rem 4rem;text-align:center;
  border-bottom:1px solid var(--border);
}
.tag-hero-label{
  font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--text3);margin-bottom:.5rem;
}
.tag-hero-title{
  font-family:var(--serif);font-size:clamp(2rem,5vw,3.5rem);
  font-weight:600;color:var(--text);margin-bottom:.75rem;
}
.tag-hero-desc{
  font-family:var(--body);font-style:italic;
  font-size:1.05rem;color:var(--text2);max-width:480px;margin:0 auto;
}

/* ===== PAGE ===== */
.page-hero{padding:7rem 2rem 3rem;text-align:center}
.page-title{
  font-family:var(--serif);font-size:clamp(2rem,5vw,3rem);
  font-weight:700;color:var(--text);
}
.page-content-wrap{max-width:720px;margin:0 auto;padding:2rem 2rem 5rem}

/* ===== FOOTER ===== */
.site-footer{
  border-top:1px solid var(--border);
  padding:2.5rem 2rem;
  display:flex;align-items:center;justify-content:space-between;
  gap:1.5rem;flex-wrap:wrap;
}
.footer-brand{
  font-family:var(--serif);font-size:1rem;
  color:var(--text2);
}
.footer-brand span{color:var(--gold)}
.footer-nav{display:flex;gap:1.25rem;flex-wrap:wrap}
.footer-nav a{
  font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--text3);transition:color .2s;
}
.footer-nav a:hover{color:var(--gold)}
.footer-copy{
  font-size:.75rem;color:var(--text3);
  width:100%;text-align:center;padding-top:1rem;
  border-top:1px solid var(--border);
}

/* ===== PAGINATION ===== */
.pagination{
  display:flex;align-items:center;justify-content:center;gap:1rem;
  padding:3rem 0;
}
.pagination a{
  padding:8px 20px;border:1px solid var(--border2);border-radius:999px;
  font-size:.82rem;color:var(--text2);transition:all .2s;
}
.pagination a:hover{border-color:var(--gold);color:var(--gold)}
.pagination .page-number{font-size:.82rem;color:var(--text3)}

/* ===== ERROR ===== */
.error-page{
  min-height:80vh;display:flex;align-items:center;justify-content:center;
  flex-direction:column;text-align:center;padding:2rem;
}
.error-code{
  font-family:var(--serif);font-size:7rem;font-weight:700;
  color:var(--surface2);line-height:1;margin-bottom:1rem;
}
.error-title{
  font-family:var(--serif);font-size:2rem;color:var(--text);margin-bottom:.75rem;
}
.error-desc{color:var(--text2);margin-bottom:2rem}
.error-link{
  padding:10px 24px;border:1px solid var(--gold);border-radius:999px;
  color:var(--gold2);font-size:.85rem;transition:all .2s;
}
.error-link:hover{background:var(--gold-dim)}

/* ===== MOBILE ===== */
@media(max-width:768px){
  .site-nav{padding:.8rem 1.25rem}
  .nav-links,.nav-subscribe{display:none}
  .nav-toggle{display:flex}
  .nav-mobile{
    display:none;position:fixed;inset:0;top:0;
    background:rgba(13,12,10,.98);backdrop-filter:blur(12px);
    flex-direction:column;align-items:center;justify-content:center;gap:2rem;
    z-index:200;
    padding-top:80px;
  }
  .nav-mobile.open{display:flex}
  .nav-mobile a{
    font-family:var(--serif);font-size:2rem;color:var(--text);
    transition:color .2s;
  }
  .nav-mobile a:hover{color:var(--gold2)}
  .posts-section{padding:3rem 1.25rem 4rem}
  .post-content-wrap,.post-author{padding-left:1.25rem;padding-right:1.25rem}
  .post-hero-content{padding:3rem 1.25rem 2rem}
  .site-footer{padding:2rem 1.25rem;flex-direction:column;align-items:flex-start;gap:1rem}
}

/* ===== SCROLLBAR ===== */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--text3);border-radius:3px}

/* ===== GHOST KG CARD WIDTHS (required) ===== */
.kg-width-wide{
  margin-left:calc(25% - 25vw);
  margin-right:calc(25% - 25vw);
}
.kg-width-full{
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  max-width:100vw;
}
.kg-image{max-width:100%}
.kg-gallery-container{display:flex;flex-direction:column;gap:1rem;margin:2rem 0}
.kg-gallery-row{display:flex;gap:1rem}
.kg-gallery-image img{width:100%;height:100%;object-fit:cover}
.kg-embed-card{margin:2rem 0}
.kg-bookmark-card{
  border:1px solid var(--border2);border-radius:var(--rad-sm);
  overflow:hidden;margin:2rem 0;display:flex;
  background:var(--surface);
}
.kg-bookmark-content{padding:1rem;flex:1}
.kg-bookmark-title{font-weight:500;color:var(--text);margin-bottom:.25rem}
.kg-bookmark-description{font-size:.85rem;color:var(--text2)}
.kg-bookmark-thumbnail img{width:160px;object-fit:cover}
.kg-callout-card{
  display:flex;gap:1rem;padding:1.25rem;border-radius:var(--rad-sm);
  background:var(--surface2);border:1px solid var(--border);margin:1.5rem 0;
}
.kg-toggle-card{border:1px solid var(--border);border-radius:var(--rad-sm);overflow:hidden;margin:1.5rem 0}
.kg-toggle-heading{padding:.85rem 1rem;background:var(--surface2);cursor:pointer;font-weight:500}
.kg-toggle-content{padding:1rem;display:none}
.kg-audio-card{border:1px solid var(--border);border-radius:var(--rad-sm);padding:1rem;margin:1.5rem 0;background:var(--surface)}

/* Ghost navigation helper styling */
.nav-links .nav,
.nav-links ul{
  display:flex;align-items:center;gap:1.75rem;
  list-style:none;margin:0;padding:0;
}
.nav-links .nav li a,
.nav-links ul li a{
  font-size:.82rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;
  color:var(--text2);transition:color .2s;
}
.nav-links .nav li a:hover,
.nav-links ul li a:hover{ color:var(--gold2) }
.nav-links .nav li.nav-current a,
.nav-links ul li.nav-current a{ color:var(--gold) }

.nav-mobile .nav,
.nav-mobile ul{
  display:flex;flex-direction:column;align-items:center;gap:2rem;
  list-style:none;margin:0;padding:0;
}
.nav-mobile .nav li a,
.nav-mobile ul li a{
  font-family:var(--serif);font-size:2rem;color:var(--text);transition:color .2s;
}
.nav-mobile .nav li a:hover,
.nav-mobile ul li a:hover{ color:var(--gold2) }

.nav-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ===== MOBILE MENU FIX ===== */
.nav-mobile {
  top: 0;
  padding-top: 80px;
}
.nav-toggle.open span:nth-child(1) {
  transform: translateY(6.5px) rotate(45deg);
}
.nav-toggle.open span:nth-child(2) {
  opacity: 0;
}
.nav-toggle.open span:nth-child(3) {
  transform: translateY(-6.5px) rotate(-45deg);
}

/* Ghost navigation helper output */
.nav-links ul,.nav-mobile ul{list-style:none;display:flex;align-items:center;gap:1.75rem;margin:0;padding:0}
.nav-mobile ul{flex-direction:column;gap:2rem}
.nav-links ul li a{font-size:.82rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text2);transition:color .2s}
.nav-links ul li a:hover,.nav-links ul li.nav-current a{color:var(--gold2)}
.nav-mobile ul li a{font-family:var(--serif);font-size:2rem;color:var(--text);transition:color .2s}
.nav-mobile ul li a:hover{color:var(--gold2)}

/* Ghost navigation helper output */
.nav-links ul.nav,.nav-links .nav{display:flex;align-items:center;gap:1.75rem;list-style:none;margin:0;padding:0}
.nav-links ul.nav li,.nav-links .nav li{list-style:none;margin:0;padding:0}
.nav-links ul.nav li a,.nav-links .nav li a{font-size:.82rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text2);transition:color .2s}
.nav-links ul.nav li a:hover,.nav-links .nav li a:hover{color:var(--gold2)}
.nav-links ul.nav li.nav-current a,.nav-links .nav li.nav-current a{color:var(--gold)}

/* Footer nav ghost output */
.footer-nav ul.nav,.footer-nav .nav{display:flex;gap:1.25rem;flex-wrap:wrap;list-style:none;margin:0;padding:0}
.footer-nav ul.nav li a,.footer-nav .nav li a{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text3);transition:color .2s}
.footer-nav ul.nav li a:hover,.footer-nav .nav li a:hover{color:var(--gold)}

/* Mobile nav ghost output */
.nav-mobile ul.nav,.nav-mobile .nav{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;align-items:center;gap:2rem}
.nav-mobile ul.nav li a,.nav-mobile .nav li a{font-family:var(--serif);font-size:2rem;color:var(--text);transition:color .2s}
.nav-mobile ul.nav li a:hover,.nav-mobile .nav li a:hover{color:var(--gold2)}
.nav-mobile-subscribe{font-size:1rem;color:var(--gold);margin-top:1rem}

/* ===== POST PAGE (simplified) ===== */
.post-main{max-width:780px;margin:0 auto;padding:6rem 2rem 5rem}
.post-feature-img{
  width:100%;max-height:480px;overflow:hidden;
  border-radius:var(--rad);margin-bottom:2.5rem;
}
.post-feature-img img{width:100%;height:100%;object-fit:cover}
.post-header{margin-bottom:2.5rem;padding-bottom:2rem;border-bottom:1px solid var(--border)}
.post-tags{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}
.post-tag{
  font-size:.68rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  color:var(--gold);padding:3px 10px;border:1px solid rgba(192,148,56,.3);border-radius:999px;
}
.post-title{
  font-family:var(--serif);
  font-size:clamp(2rem,5vw,3rem);
  font-weight:700;line-height:1.15;color:var(--text);
  margin-bottom:1rem;
}
.post-meta{
  display:flex;align-items:center;gap:.75rem;
  font-size:.85rem;color:var(--text2);flex-wrap:wrap;
}
.post-meta-sep{color:var(--text3)}
