/* ============================================================
   LAUBAIS — Ghost theme stylesheet
   Palette, typography and structure from the Laubais Design Brief
   ============================================================ */

:root{
  --paper:#f3ece0;
  --paper-2:#efe6d6;
  --ink:#2b2218;
  --ink-soft:#5c4f3c;
  --bronze:#8a6a3e;
  --bronze-deep:#6f5530;
  --line:#cbbb9c;
  --line-soft:#dccfb4;
  --gold:#a98a52;
  --max:1180px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:'EB Garamond',Garamond,Georgia,serif;
  font-size:18px;
  line-height:1.75;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
}
.wrap{max-width:var(--max);margin:0 auto;padding:0 40px;position:relative;z-index:2}
h1,h2,h3,.display{font-family:'Cormorant Garamond',Georgia,serif;font-weight:500;line-height:1.15}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.rule{display:flex;align-items:center;justify-content:center;gap:18px;color:var(--bronze)}
.rule .ln{height:1px;width:64px;background:var(--line)}
.rule .dot{width:5px;height:5px;background:var(--bronze);transform:rotate(45deg)}

/* ---------- top bar ---------- */
.site-head{position:fixed;top:0;left:0;right:0;z-index:50;
  background:var(--ink);box-shadow:0 1px 0 #463a28;
  transition:padding .4s ease;padding:22px 0}
.site-head.solid{padding:15px 0}
.nav{display:flex;align-items:center;justify-content:space-between}
.brandmark{font-family:'Cormorant Garamond',Georgia,serif;font-size:21px;letter-spacing:.42em;
  text-transform:uppercase;color:var(--paper);padding-left:.42em}
.nav ul{display:flex;gap:38px;list-style:none}
.nav ul a{font-family:'Cormorant Garamond',Georgia,serif;font-size:15px;letter-spacing:.22em;
  text-transform:uppercase;color:#bfae90;position:relative;padding-bottom:3px}
.nav ul a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;
  background:var(--gold);transition:width .35s ease}
.nav ul a:hover{color:var(--paper)}
.nav ul a:hover::after{width:100%}

.menu-toggle{display:none;background:none;border:0;cursor:pointer;
  width:30px;height:24px;padding:0;position:relative;z-index:60}
.menu-toggle span{display:block;height:1.5px;width:100%;background:var(--paper);
  position:absolute;left:0;transition:transform .3s ease,opacity .25s ease}
.menu-toggle span:nth-child(1){top:3px}
.menu-toggle span:nth-child(2){top:11px}
.menu-toggle span:nth-child(3){top:19px}
.menu-toggle.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.menu-toggle.open span:nth-child(2){opacity:0}
.menu-toggle.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ---------- hero ---------- */
.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;
  justify-content:center;text-align:center;padding:140px 40px 90px;position:relative}
.hero .frame{position:absolute;inset:34px;border:1px solid var(--line-soft);
  pointer-events:none;z-index:0}
.hero .frame::before,.hero .frame::after{content:"";position:absolute;width:14px;height:14px;
  border:1px solid var(--bronze)}
.hero .frame::before{top:-1px;left:-1px;border-right:0;border-bottom:0}
.hero .frame::after{bottom:-1px;right:-1px;border-left:0;border-top:0}
.hero-logo{width:min(420px,62vw);filter:drop-shadow(0 14px 30px rgba(80,60,30,.14));
  mix-blend-mode:multiply;opacity:0;transform:translateY(18px) scale(.985);
  animation:rise 1.5s cubic-bezier(.2,.7,.2,1) .15s forwards}
.hero .tagline{max-width:620px;margin:40px auto 0;color:var(--ink-soft);
  font-size:1.12rem;opacity:0;animation:rise 1.3s ease .55s forwards}
.hero .scrolldown{margin-top:54px;opacity:0;animation:fade 1.4s ease .9s forwards}
.hero .scrolldown span{display:block;font-family:'Cormorant Garamond',Georgia,serif;font-size:12px;
  letter-spacing:.34em;text-transform:uppercase;color:var(--bronze);margin-bottom:12px}
.hero .scrolldown .v{width:1px;height:46px;margin:0 auto;background:linear-gradient(var(--bronze),transparent);
  animation:drop 2.4s ease-in-out infinite}
@keyframes rise{to{opacity:1;transform:none}}
@keyframes fade{to{opacity:1}}
@keyframes drop{0%,100%{transform:scaleY(.4);transform-origin:top;opacity:.4}
  50%{transform:scaleY(1);opacity:1}}

/* ---------- section scaffolding ---------- */
section{padding:120px 0;position:relative}
.eyebrow{font-family:'Cormorant Garamond',Georgia,serif;font-size:14px;letter-spacing:.36em;
  text-transform:uppercase;color:var(--bronze);margin-bottom:20px}
.sec-title{font-size:clamp(2rem,4.4vw,3.4rem);letter-spacing:.03em;color:var(--ink);
  margin-bottom:26px}
.lede{font-size:1.18rem;color:var(--ink-soft);max-width:62ch}
.reveal{opacity:1;transform:none}
.js-anim .reveal{opacity:0;transform:translateY(26px);
  transition:opacity 1s ease,transform 1s cubic-bezier(.2,.7,.2,1)}
.js-anim .reveal.in{opacity:1;transform:none}

/* ---------- the house ---------- */
.house{background:var(--paper-2)}
.house-inner{max-width:760px;margin:0 auto;text-align:center}
.house-inner p+p{margin-top:20px}
.house-inner p{color:var(--ink-soft)}
.pull{font-family:'Cormorant Garamond',Georgia,serif;font-style:italic;font-size:1.6rem;
  line-height:1.5;color:var(--bronze-deep);margin:40px auto;max-width:34ch;
  position:relative;padding:26px 0}
.pull::before,.pull::after{content:"";position:absolute;left:50%;transform:translateX(-50%);
  width:54px;height:1px;background:var(--gold)}
.pull::before{top:0}
.pull::after{bottom:0}

/* ---------- reading room ---------- */
.room-head{display:flex;justify-content:space-between;align-items:flex-end;
  flex-wrap:wrap;gap:24px;margin-bottom:14px}
.filters{display:flex;flex-wrap:wrap;gap:10px;margin:30px 0 56px}
.filters a{font-family:'Cormorant Garamond',Georgia,serif;font-size:13px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-soft);background:transparent;
  border:1px solid var(--line);padding:9px 18px;cursor:pointer;
  transition:all .3s ease;text-decoration:none}
.filters a:hover{border-color:var(--bronze);color:var(--ink)}
.filters a.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}

.journal{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;
  background:var(--line-soft);border:1px solid var(--line-soft)}
.entry{background:var(--paper);padding:46px 44px;display:flex;flex-direction:column;
  min-height:300px;transition:background .4s ease;cursor:pointer;text-decoration:none}
.entry:hover{background:var(--paper-2)}
.entry .meta{display:flex;gap:16px;align-items:center;font-family:'Cormorant Garamond',Georgia,serif;
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--bronze);
  margin-bottom:22px;flex-wrap:wrap}
.entry .meta .cat{color:var(--ink);border:1px solid var(--line);padding:3px 11px}
.entry h3{font-size:1.74rem;line-height:1.25;color:var(--ink);margin-bottom:16px;
  transition:color .3s ease}
.entry:hover h3{color:var(--bronze-deep)}
.entry p{color:var(--ink-soft);font-size:1.02rem;flex:1}
.entry .more{font-family:'Cormorant Garamond',Georgia,serif;font-size:13px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--bronze);margin-top:26px;display:inline-flex;
  align-items:center;gap:10px}
.entry .more .arr{transition:transform .35s ease}
.entry:hover .more .arr{transform:translateX(7px)}
.archive-note{text-align:center;margin-top:54px;color:var(--ink-soft);font-style:italic}
.empty-note{text-align:center;color:var(--ink-soft);font-style:italic;padding:40px 0}

.pagination{display:flex;justify-content:center;gap:30px;margin-top:60px;
  font-family:'Cormorant Garamond',Georgia,serif;letter-spacing:.18em;
  text-transform:uppercase;font-size:13px}
.pagination a{color:var(--bronze)}
.pagination a:hover{color:var(--ink)}
.pagination .page-number{color:var(--ink-soft)}

/* ---------- services ---------- */
.services{background:var(--paper-2)}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--line)}
.svc{padding:54px 38px 50px;border-bottom:1px solid var(--line);
  border-right:1px solid var(--line);position:relative}
.svc:nth-child(3n){border-right:0}
.svc .num{font-family:'Cormorant Garamond',Georgia,serif;font-size:13px;letter-spacing:.3em;
  color:var(--gold);margin-bottom:26px}
.svc h3{font-size:1.6rem;color:var(--ink);margin-bottom:18px;min-height:2.4em}
.svc p{color:var(--ink-soft);font-size:1.02rem}
@media(min-width:861px){
  .svc:nth-child(1),.svc:nth-child(2),.svc:nth-child(3){border-top:0}
}

/* ---------- contact ---------- */
.contact{text-align:center;padding:140px 0}
.contact .sec-title{margin-bottom:20px}
.contact .lede{margin:0 auto 44px}
.contact-mail{font-family:'Cormorant Garamond',Georgia,serif;
  font-size:clamp(1.5rem,3.4vw,2.5rem);letter-spacing:.06em;color:var(--ink);
  border-bottom:1px solid var(--line);padding-bottom:8px;transition:border-color .35s ease}
.contact-mail:hover{border-color:var(--bronze)}
.contact .place{margin-top:40px;font-family:'Cormorant Garamond',Georgia,serif;
  letter-spacing:.34em;text-transform:uppercase;font-size:13px;color:var(--bronze)}

/* ---------- post / page article ---------- */
.article{padding:160px 0 120px;position:relative}
.article-inner{max-width:740px;margin:0 auto}
.article .meta{display:flex;gap:16px;align-items:center;justify-content:center;
  font-family:'Cormorant Garamond',Georgia,serif;font-size:12px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--bronze);margin-bottom:26px;flex-wrap:wrap}
.article .meta .cat{color:var(--ink);border:1px solid var(--line);padding:3px 11px}
.article h1.article-title{font-size:clamp(2.2rem,5vw,3.6rem);text-align:center;
  color:var(--ink);margin-bottom:20px;letter-spacing:.02em}
.article .excerpt{text-align:center;font-style:italic;color:var(--bronze-deep);
  font-size:1.25rem;max-width:60ch;margin:0 auto 50px}
.feat{margin:0 auto 56px;max-width:920px}
.feat img{width:100%;border:1px solid var(--line-soft)}
.content{font-size:1.12rem;color:var(--ink-soft)}
.content p{margin:0 0 1.3em}
.content h2,.content h3,.content h4{font-family:'Cormorant Garamond',Georgia,serif;
  color:var(--ink);margin:1.6em 0 .6em;line-height:1.2}
.content h2{font-size:1.9rem}
.content h3{font-size:1.5rem}
.content a{color:var(--bronze-deep);border-bottom:1px solid var(--line)}
.content a:hover{border-color:var(--bronze)}
.content blockquote{border-left:2px solid var(--gold);padding-left:24px;
  font-style:italic;color:var(--bronze-deep);margin:1.6em 0;font-size:1.2rem}
.content img{margin:1.8em auto;border:1px solid var(--line-soft)}
.content .kg-width-wide{width:85vw;max-width:1100px;position:relative;
  left:50%;transform:translateX(-50%)}
.content .kg-width-full{width:100vw;max-width:100vw;position:relative;
  left:50%;transform:translateX(-50%)}
.content figure{margin:1.8em 0}
.content figcaption{text-align:center;font-size:.9rem;color:var(--bronze);
  margin-top:.7em;font-style:italic}
.kg-card-begin,.kg-card-end{display:none}
.content ul,.content ol{margin:0 0 1.3em 1.4em}
.content li{margin:.4em 0}
.content hr{border:0;border-top:1px solid var(--line);margin:2.4em 0}
.content code{background:var(--paper-2);padding:2px 7px;font-size:.92em;
  border:1px solid var(--line-soft)}
.content pre{background:var(--ink);color:var(--paper);padding:22px;overflow:auto;
  margin:1.6em 0;font-size:.95rem}
.content pre code{background:none;border:0;color:inherit;padding:0}
.back-link{display:block;text-align:center;margin-top:70px;
  font-family:'Cormorant Garamond',Georgia,serif;font-size:13px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--bronze)}
.back-link:hover{color:var(--ink)}

/* gated / members content */
.gh-content .gh-post-upgrade-cta{background:var(--paper-2);border:1px solid var(--line);
  padding:50px 40px;text-align:center;margin:50px 0}
.gh-post-upgrade-cta h2{font-family:'Cormorant Garamond',Georgia,serif;color:var(--ink);
  font-size:1.8rem;margin-bottom:14px}
.gh-post-upgrade-cta a{display:inline-block;margin-top:20px;background:var(--ink);
  color:var(--paper);padding:14px 34px;font-family:'Cormorant Garamond',Georgia,serif;
  letter-spacing:.2em;text-transform:uppercase;font-size:13px}

/* ---------- footer ---------- */
.site-foot{background:var(--ink);color:var(--paper);padding:64px 0 56px;
  position:relative;z-index:2}
.foot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:24px}
.foot .fb{font-family:'Cormorant Garamond',Georgia,serif;letter-spacing:.4em;
  text-transform:uppercase;font-size:18px}
.foot .fl{display:flex;gap:30px;font-family:'Cormorant Garamond',Georgia,serif;
  font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:#bfae90;list-style:none}
.foot .fl a:hover{color:var(--paper)}
.foot .cc{font-size:13px;color:#9c8d72;letter-spacing:.06em;width:100%;
  border-top:1px solid #463a28;padding-top:26px;margin-top:8px}

/* ---------- responsive ---------- */
@media(max-width:860px){
  .wrap{padding:0 24px}
  .menu-toggle{display:block}
  .site-nav{position:fixed;top:0;left:0;right:0;bottom:0;
    background:var(--ink);display:flex;align-items:center;justify-content:center;
    opacity:0;pointer-events:none;transition:opacity .35s ease;z-index:55}
  .site-nav.open{opacity:1;pointer-events:auto}
  .site-nav ul{flex-direction:column;align-items:center;gap:34px}
  .site-nav ul a{font-size:18px;letter-spacing:.28em;color:var(--paper)}
  .site-nav ul a::after{display:none}
  .brandmark{font-size:18px;letter-spacing:.3em;padding-left:.3em;
    position:relative;z-index:60}
  .journal{grid-template-columns:1fr}
  .svc-grid{grid-template-columns:1fr}
  .svc{border-right:0}
  section{padding:88px 0}
  .entry{padding:38px 30px;min-height:auto}
  .article{padding:130px 0 90px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}
