

:root[data-theme="dark"] {
  --bg:#0a0a0a; --bg-2:#111114; --fg:#edece8; --mut:rgba(237,236,232,.46);
  --line:rgba(237,236,232,.12); --line-2:rgba(237,236,232,.24);
  --gold:#cba63f; --gold-2:#e6cb78; --hover:rgba(203,166,63,.07); --scan:rgba(0,0,0,.26);
}

:root{ --ease-out:cubic-bezier(.23,1,.32,1); --ease-in-out:cubic-bezier(.77,0,.175,1); }

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:auto}
body{
  background:var(--bg); color:var(--fg);
  font-family:"JetBrains Mono",ui-monospace,monospace; font-size:16px; line-height:1.6;
  -webkit-font-smoothing:antialiased; cursor:crosshair; overflow-x:hidden;
}

.fx{position:fixed;inset:0;pointer-events:none}

.fx--vignette{z-index:0;background:
  radial-gradient(120% 95% at 50% 26%, rgba(255,255,255,.04), transparent 56%),
  radial-gradient(140% 130% at 50% 102%, transparent 58%, rgba(0,0,0,.6))}

.fx--palimpsest{z-index:0;overflow:hidden;
  -webkit-mask-image:radial-gradient(ellipse 82% 82% at 50% 40%,#000 28%,transparent 84%);
          mask-image:radial-gradient(ellipse 82% 82% at 50% 40%,#000 28%,transparent 84%)}
.palimpsest__text{margin:0;padding:5vmin 4vmin;font-family:"JetBrains Mono",monospace;
  font-size:clamp(2.1rem,5.5vw,4.6rem);line-height:1.18;letter-spacing:.02em;
  color:rgba(236,232,216,.03);word-break:break-word;user-select:none;-webkit-user-select:none}

.fx--grid{z-index:0;width:100%;height:100%;
  -webkit-mask-image:radial-gradient(ellipse 78% 76% at 50% 44%,#000 22%,transparent 80%);
          mask-image:radial-gradient(ellipse 78% 76% at 50% 44%,#000 22%,transparent 80%)}

.fx--grain{z-index:60;opacity:.05;mix-blend-mode:soft-light;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)'/%3E%3C/svg%3E");
  background-size:170px 170px}

.hero-halo{position:absolute;left:6%;top:42%;width:min(72vw,760px);height:min(52vh,460px);
  transform:translateY(-44%);z-index:0;pointer-events:none;
  background:radial-gradient(closest-side,rgba(201,162,39,.10),transparent 62%);filter:blur(6px)}
.incipit__inner{position:relative;z-index:1;width:100%}
.g{color:var(--gold)}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold);color:var(--bg)}
:focus-visible{outline:1px solid var(--gold);outline-offset:3px}
.skip-link{position:fixed;left:-999px;top:8px;z-index:200;background:var(--fg);color:var(--bg);padding:.5rem .9rem;font-size:12px}
.skip-link:focus{left:8px}

.status{position:fixed;top:0;left:0;right:0;z-index:40;display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:11px clamp(18px,4vw,40px);font-size:11px;letter-spacing:.14em;color:var(--mut);
  border-bottom:1px solid var(--line);background:color-mix(in srgb,var(--bg) 78%,transparent);-webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px)}
.status__id b{color:var(--fg);font-weight:500}
.status__folio{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);color:var(--gold)}

main{position:relative;z-index:1}
.incipit,.chap,.colophon,.trans{max-width:860px;margin-inline:auto;padding-inline:clamp(20px,5vw,48px)}

.incipit{position:relative;min-height:100vh;min-height:100svh;display:flex;flex-direction:column;justify-content:center;padding-top:60px}
.prompt{font-size:13px;color:var(--mut);margin-bottom:1.4rem}
.com{color:var(--mut)}
.title{font-family:"Space Grotesk",sans-serif;font-weight:700;font-size:clamp(3.6rem,14vw,10rem);line-height:.9;letter-spacing:-.03em}
.dot-g{color:var(--gold)}
.sacra{font-family:"UnifrakturMaguntia",serif;color:var(--gold);font-size:clamp(1.9rem,5vw,3rem);margin:1.3rem 0 0;line-height:1}
.def{font-size:13.5px;color:var(--mut);margin-top:.7rem;max-width:54ch;line-height:1.8}
.def .sep{color:var(--gold)}
.code{margin-top:2.4rem;border:1px solid var(--line);max-width:580px;background:color-mix(in srgb,var(--bg-2) 70%,transparent)}
.code__bar{display:flex;align-items:center;gap:7px;padding:9px 13px;border-bottom:1px solid var(--line)}
.code__bar i{width:9px;height:9px;border-radius:50%;border:1px solid var(--mut)}
.code__bar span{margin-left:8px;color:var(--mut);font-size:11px;letter-spacing:.1em}
.code__body{padding:15px 0;font-size:13.5px}
.cl{display:grid;grid-template-columns:44px 1fr;padding:3px 14px}
.ln{color:var(--gold);opacity:.8}
.kw{color:var(--gold-2)}
.op{color:var(--mut)}
.caret{display:inline-block;width:8px;height:1.05em;background:var(--gold);vertical-align:-2px;margin-left:2px;animation:blink 1.1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}

.trans{display:flex;align-items:center;gap:16px;margin:clamp(54px,10vh,104px) auto;font-size:12.5px;letter-spacing:.1em;color:var(--mut)}
.trans .cmd{white-space:nowrap}
.trans .rule{flex:1;height:1px;background:linear-gradient(to right,var(--line-2),transparent)}
.trans .mk{color:var(--gold)}

.chap__head{margin-bottom:2.4rem}
.chap__head--c{text-align:center}
.chap__liber{display:block;font-size:11px;letter-spacing:.34em;color:var(--gold);margin-bottom:.55rem}
.chap__title{font-family:"Space Grotesk",sans-serif;font-weight:700;font-size:clamp(2.4rem,7vw,4rem);line-height:1;letter-spacing:-.02em}
.chap__gloss{display:inline-block;font-size:11px;letter-spacing:.14em;color:var(--mut);margin-top:.7rem}

#confessio{display:grid;grid-template-columns:1fr 188px;grid-template-areas:"h h" "b m";gap:0 40px;align-items:start}
#confessio .chap__head{grid-area:h}
.scripture{grid-area:b}
.margin{grid-area:m}
.vs{position:relative;padding-left:2.3em;margin:0 0 1.1rem;font-family:"Space Grotesk",sans-serif;font-size:clamp(1.05rem,2.2vw,1.3rem);line-height:1.6}
.vs--com{font-family:"JetBrains Mono",monospace;font-size:13px}
.vn{position:absolute;left:0;top:.45em;font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--gold)}
.margin{font-size:11px;line-height:2;color:var(--mut);border-left:1px solid var(--line);padding-left:15px}
.margin p:first-child{color:var(--gold)}

.opera{list-style:none;border-top:1px solid var(--line)}
.opus{display:grid;grid-template-columns:3em 1fr auto;gap:20px;align-items:baseline;padding:22px 8px;border-bottom:1px solid var(--line);position:relative;transition:background .25s}
.opus__vn{color:var(--gold);font-size:13px;transition:transform .25s var(--ease-out)}
.opus__b{transition:transform .25s var(--ease-out)}
.opus__t{font-family:"Space Grotesk",sans-serif;font-weight:500;font-size:clamp(1.3rem,3.2vw,2rem);line-height:1.1;margin-bottom:.3rem}
.opus__c code{font-size:12px;color:var(--mut);letter-spacing:.04em}
.opus__ref{font-size:12px;letter-spacing:.12em;color:var(--mut);transition:color .25s}

.colophon{text-align:center}
.explicit{font-family:"Space Grotesk",sans-serif;font-size:clamp(1.15rem,2.8vw,1.6rem);line-height:1.6;margin-bottom:2.4rem}
.explicit .dim{color:var(--mut)}
.roman{font-variant:small-caps;letter-spacing:.06em;color:var(--gold)}
.epist{list-style:none;max-width:460px;margin:0 auto 2rem;text-align:left;border-top:1px solid var(--line)}
.epist li{display:flex;align-items:baseline;gap:16px;padding:15px 8px;border-bottom:1px solid var(--line);transition:background .25s}
.epist li>*{transition:transform .25s var(--ease-out)}
.ek{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);min-width:78px}
.epist code{font-size:14px;color:var(--fg)}
.commit{font-size:11px;letter-spacing:.14em;color:var(--mut)}

.js .colophon .epist li{transform:scale(.94);transition:opacity .5s var(--ease-out),transform .5s cubic-bezier(.34,1.45,.5,1)}

.seal{position:relative;display:inline-flex;align-items:center;justify-content:center;vertical-align:-.35em;margin-left:.1em}
.seal-check{width:1.6em;height:1.6em;position:relative;z-index:1;overflow:visible}
.js .seal-check path{stroke-dasharray:1;stroke-dashoffset:1}
.seal-halo{position:absolute;left:50%;top:50%;width:3.2em;height:3.2em;border-radius:50%;z-index:0;pointer-events:none;
  opacity:0;transform:translate(-50%,-50%) scale(.3);
  background:radial-gradient(circle,rgba(235,205,110,.5),rgba(201,162,39,.22) 42%,transparent 70%)}

.js .colophon.vis .commit.seal-go .seal-check path{animation:sealDraw .55s var(--ease-out) .25s forwards}
.js .colophon.vis .commit.seal-go .seal-halo{animation:sealHalo 1s var(--ease-out) .5s}
@keyframes sealDraw{to{stroke-dashoffset:0}}
@keyframes sealHalo{
  0%  {opacity:0;transform:translate(-50%,-50%) scale(.3)}
  35% {opacity:1;transform:translate(-50%,-50%) scale(1)}
  100%{opacity:0;transform:translate(-50%,-50%) scale(1.7)}
}

.footer{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr 1fr;max-width:860px;margin:clamp(56px,11vh,120px) auto 0;
  padding:18px clamp(20px,5vw,48px) 36px;border-top:1px solid var(--line);font-size:10px;letter-spacing:.16em;color:var(--mut)}
.footer span:nth-child(2){text-align:center;color:var(--gold)}
.footer span:last-child{text-align:right}

@media (hover:hover) and (pointer:fine){
  .status__toggle:hover{color:var(--gold)}
  .opus:hover{background:var(--hover)}
  .opus:hover .opus__vn,
  .opus:hover .opus__b{transform:translateX(8px)}
  .opus:hover .opus__ref{color:var(--gold)}
  .epist li:hover{background:var(--hover)}
  .epist li:hover>*{transform:translateX(6px)}
}

.js .trans,
.js .chap__head,
.js .scripture .vs,
.js .margin,
.js .opera .opus,
.js .explicit,
.js .epist li,
.js .commit{
  opacity:0; transform:translateY(14px);
  transition:opacity .6s var(--ease-out), transform .6s var(--ease-out);
}
.js .trans.vis,
.js .chap.vis .chap__head,
.js .chap.vis .scripture .vs,
.js .chap.vis .margin,
.js .chap.vis .opera .opus,
.js .colophon.vis .chap__head,
.js .colophon.vis .explicit,
.js .colophon.vis .epist li,
.js .colophon.vis .commit{
  opacity:1; transform:none;
}

.js .chap.vis .scripture .vs:nth-child(1){transition-delay:.08s}
.js .chap.vis .scripture .vs:nth-child(2){transition-delay:.15s}
.js .chap.vis .scripture .vs:nth-child(3){transition-delay:.22s}
.js .chap.vis .scripture .vs:nth-child(4){transition-delay:.29s}
.js .chap.vis .margin{transition-delay:.12s}
.js .chap.vis .opera .opus:nth-child(1){transition-delay:.08s}
.js .chap.vis .opera .opus:nth-child(2){transition-delay:.15s}
.js .chap.vis .opera .opus:nth-child(3){transition-delay:.22s}
.js .colophon.vis .explicit{transition-delay:.06s}
.js .colophon.vis .epist li:nth-child(1){transition-delay:.14s}
.js .colophon.vis .epist li:nth-child(2){transition-delay:.21s}
.js .colophon.vis .epist li:nth-child(3){transition-delay:.28s}
.js .colophon.vis .commit{transition-delay:.34s}

.js #confessio .scripture .vs{
  opacity:1;transform:none;
  clip-path:none;
  transition-property:clip-path;
  transition-duration:.62s;
  transition-timing-function:var(--ease-out);
}

.js #confessio .margin{
  opacity:0;transform:translateX(22px);
  transition-property:opacity,transform;
  transition-duration:.6s;
  transition-timing-function:var(--ease-out);
  transition-delay:.42s;
}
.js #confessio.typed .margin{opacity:1;transform:none}

.opera .opus::after{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:1px;
  background:var(--gold);transform:scaleX(0);transform-origin:left;opacity:0;pointer-events:none;
}
.js #opera .opus{opacity:1;transform:none}
.js #opera .opus__vn{opacity:0}
.js #opera .opus__b,
.js #opera .opus__ref{opacity:0;transform:translateY(8px)}

.js #opera.vis .opus__vn{opacity:1}
.js #opera.vis .opus__b,
.js #opera.vis .opus__ref{opacity:1;transform:none}

.js #opera.vis .opus:nth-child(1)::after{animation:opusRule .55s var(--ease-out)}
.js #opera.vis .opus:nth-child(2)::after{animation:opusRule .55s var(--ease-out) .12s}
.js #opera.vis .opus:nth-child(3)::after{animation:opusRule .55s var(--ease-out) .24s}
.js #opera.vis .opus:nth-child(1) .opus__vn{animation:opusStamp .5s var(--ease-out) .1s backwards}
.js #opera.vis .opus:nth-child(2) .opus__vn{animation:opusStamp .5s var(--ease-out) .22s backwards}
.js #opera.vis .opus:nth-child(3) .opus__vn{animation:opusStamp .5s var(--ease-out) .34s backwards}
.js #opera.vis .opus:nth-child(1) .opus__b,
.js #opera.vis .opus:nth-child(1) .opus__ref{animation:opusRise .5s var(--ease-out) .16s backwards}
.js #opera.vis .opus:nth-child(2) .opus__b,
.js #opera.vis .opus:nth-child(2) .opus__ref{animation:opusRise .5s var(--ease-out) .28s backwards}
.js #opera.vis .opus:nth-child(3) .opus__b,
.js #opera.vis .opus:nth-child(3) .opus__ref{animation:opusRise .5s var(--ease-out) .4s backwards}
@keyframes opusRule{0%{transform:scaleX(0);opacity:.9}65%{opacity:.9}100%{transform:scaleX(1);opacity:0}}
@keyframes opusStamp{0%{opacity:0;transform:scale(1.55)}55%{opacity:1;transform:scale(.95)}100%{opacity:1;transform:scale(1)}}
@keyframes opusRise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

@media(max-width:720px){
  #confessio{grid-template-columns:1fr;grid-template-areas:"h" "b" "m"}
  .margin{border-left:0;border-top:1px solid var(--line);padding:14px 0 0;margin-top:18px}
}
@media(max-width:560px){
  .status__folio{display:none}
  .opus{grid-template-columns:2.4em 1fr}
  .opus__ref{display:none}
}
@media(pointer:coarse){body{cursor:auto}}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition-duration:.01ms!important}
  .js .trans,
  .js .chap__head,
  .js .scripture .vs,
  .js .margin,
  .js .opera .opus,
  .js .explicit,
  .js .epist li,
  .js .commit{opacity:1;transform:none}
  .js .seal-check path{stroke-dashoffset:0}
  .js #confessio .scripture .vs{clip-path:none}
}

#intro{position:fixed;inset:0;z-index:9999;overflow:hidden;background:#0a0a0a;transition:opacity .9s ease;animation:introFailsafe .6s ease 5.5s forwards}
#intro.gone{opacity:0;visibility:hidden;pointer-events:none}
#introCanvas{position:absolute;inset:0;width:100%;height:100%;display:block}
.intro-spark{position:absolute;left:0;top:0;border-radius:50%;pointer-events:none;opacity:0;
  transform:translate(-50%,-50%) scale(.2);will-change:transform,opacity}
@keyframes introFailsafe{to{opacity:0;visibility:hidden;pointer-events:none}}
@media(prefers-reduced-motion:reduce){#intro{display:none}}

html.intro-active .incipit__inner > *,
html.intro-active .hero-halo{opacity:0}

html.intro-active .incipit .prompt,
html.intro-active .incipit .sacra,
html.intro-active .incipit .def,
html.intro-active .incipit .code{transform:translateY(16px)}

.js .incipit__inner > *,
.js .hero-halo{transition:opacity .8s ease,transform .8s cubic-bezier(.2,.7,.3,1)}

html.incipit-in .incipit__inner > *,
html.incipit-in .hero-halo{opacity:1;transform:none}
html.incipit-in .hero-halo{transition-delay:.05s}

html.incipit-in .hero-halo{animation:halo-breathe 8s ease-in-out 1.4s infinite}
@keyframes halo-breathe{
  0%,100%{opacity:1;transform:scale(1)}
  50%    {opacity:.62;transform:scale(1.06)}
}
html.incipit-in .title    {transition-delay:.18s}
html.incipit-in .prompt   {transition-delay:.42s}
html.incipit-in .sacra    {transition-delay:.60s}
html.incipit-in .def      {transition-delay:.78s}
html.incipit-in .code     {transition-delay:.96s}

.intro-bloom{position:fixed;left:0;top:0;width:8px;height:8px;z-index:10000;border-radius:50%;pointer-events:none;opacity:0;
  background:radial-gradient(circle,rgba(246,226,154,.8),rgba(201,162,39,.3) 36%,rgba(201,162,39,0) 74%);
  transform:translate(-50%,-50%) scale(8);will-change:transform,opacity}
.intro-bloom.go{animation:introBloom 1.5s cubic-bezier(.2,.5,.18,1) forwards}
@keyframes introBloom{
  0%  {opacity:0;   transform:translate(-50%,-50%) scale(8)}
  35% {opacity:.62; transform:translate(-50%,-50%) scale(120)}
  100%{opacity:0;   transform:translate(-50%,-50%) scale(300)}
}

.rosace-sec{position:relative;width:100%;max-width:none;margin:0;padding:0;
  --g1:#fdfcf6;--g2:#f4eed9;--g3:#e6cf94;--g4:#cba63f;--glow:#cba63f;
  --st1:#e6ddc3;--st2:#c4b896;--st3:#7d745f;--halo1:#cba63f;--halo2:#7a5e1c;
  --ink:#1c160d;--lead:#2c2210;--behind:#0b0805;--litedge:#d9cfae}
.rosace-sec #glassGrad stop:nth-of-type(1){stop-color:var(--g1)} .rosace-sec #glassGrad stop:nth-of-type(2){stop-color:var(--g2)}
.rosace-sec #glassGrad stop:nth-of-type(3){stop-color:var(--g3)} .rosace-sec #glassGrad stop:nth-of-type(4){stop-color:var(--g4)}
.rosace-sec #warmLow stop{stop-color:var(--glow)}
.rosace-sec #stoneGrad stop:nth-of-type(1){stop-color:var(--st1)} .rosace-sec #stoneGrad stop:nth-of-type(2){stop-color:var(--st2)} .rosace-sec #stoneGrad stop:nth-of-type(3){stop-color:var(--st3)}
.rosace-sec #halo stop:nth-of-type(1){stop-color:var(--halo1)} .rosace-sec #halo stop:nth-of-type(2){stop-color:var(--halo2)}
.rosace-sec #bgGrad stop:nth-of-type(1){stop-color:#0e0c07} .rosace-sec #bgGrad stop:nth-of-type(2){stop-color:#0a0a0a} .rosace-sec #bgGrad stop:nth-of-type(3){stop-color:#070707}
.rosace-sec [stroke="#1c160d"]{stroke:var(--ink)} .rosace-sec [stroke="#2c2210"]{stroke:var(--lead)}
.rosace-sec [fill="#0b0805"]{fill:var(--behind)} .rosace-sec [stroke="#d9cfae"]{stroke:var(--litedge)}
.ros-stage{position:relative;height:100svh;display:flex;align-items:center;justify-content:center;overflow:hidden;background:transparent}
.ros-rose{position:relative;width:min(82vh,82vw)}
.ros-rose svg{width:100%;height:auto;display:block;opacity:0}
.rosace-sec #bg{display:none}
.rosace-sec #rose-spin{transform-box:view-box;transform-origin:500px 500px}
.rosace-sec .halo{animation:rosBreathe 7s ease-in-out infinite}
@keyframes rosBreathe{0%,100%{opacity:.34}50%{opacity:.55}}
.ros-beam{position:absolute;left:0;right:0;top:0;height:82%;pointer-events:none;mix-blend-mode:screen;opacity:0;transition:opacity .3s ease;
  background:
    radial-gradient(40% 62% at 50% 0%,rgba(255,248,222,.85),rgba(208,170,70,.20) 48%,transparent 80%),
    linear-gradient(180deg,rgba(208,170,70,.17),rgba(208,170,70,.06) 34%,transparent 88%)}
.ros-oculus{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:42%;text-align:center;pointer-events:none;opacity:0;transition:opacity .4s ease;z-index:5}
.ros-oculus::before{content:"";position:absolute;inset:-40% -20%;z-index:-1;border-radius:50%;background:radial-gradient(closest-side,rgba(6,5,3,.9),rgba(6,5,3,.5) 55%,transparent 75%)}
.ros-oculus.on{opacity:1}
.ros-oculus .op{font-size:10px;letter-spacing:.34em;color:var(--gold);margin-bottom:.5rem}
.ros-oculus .ti{font-family:"UnifrakturMaguntia",serif;font-size:clamp(1.4rem,3.4vw,2.3rem);line-height:1;color:var(--fg)}
.ros-oculus .lk{display:inline-block;margin-top:.8rem;font-size:11px;letter-spacing:.14em;color:var(--gold);border-bottom:1px solid color-mix(in srgb,var(--gold) 50%,transparent);pointer-events:auto}
.ros-dust{position:absolute;inset:0;pointer-events:none;mix-blend-mode:screen;z-index:4}
.ros-black{position:absolute;inset:0;background:var(--bg);opacity:0;pointer-events:none;z-index:6}
.rosace-sec g[stroke-width="3"]>*{stroke-dasharray:1400;stroke-dashoffset:1400}
@media (prefers-reduced-motion:reduce){.rosace-sec .halo{animation:none}}
@media (max-width:820px),(pointer:coarse){
  .ros-stage{height:auto;padding:48px 0}
  .ros-beam,.ros-dust,.ros-hint,.ros-black{display:none}
  .ros-rose svg{opacity:1}
  .ros-oculus{opacity:1;position:static;transform:none;width:auto;margin:22px auto 0}
}