:root{--color-primary-text:#333;--color-secondary-text:#999;--color-white:#fff;--color-lighter-gray:#f6f6f6;--color-light-gray:#e6e6e6;--color-mid-gray:#ccc;--color-dark-gray:#444;--color-darker-gray:#15171a;--color-black:#000;--font-sans:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;--font-serif:Georgia,serif;--font-mono:Menlo,Consolas,Monaco,Liberation Mono,Lucida Console,monospace;--head-nav-gap:2.8rem;--h1-size:4.6rem;--gap:3.6rem;--header-spacing:80px}@media (max-width:767px){:root{--h1-size:3.2rem!important;--gap:2rem;--header-spacing:48px}}*,:after,:before{box-sizing:border-box}blockquote,body,dd,dl,figure,h1,h2,h3,h4,h5,h6,p{margin:0}ol[role=list],ul[role=list]{list-style:none}html:focus-within{scroll-behavior:smooth}body{line-height:1.5;min-height:100vh;text-rendering:optimizespeed}a:not([class]){-webkit-text-decoration-skip:ink;text-decoration-skip-ink:auto}img,picture{display:block;max-width:100%}button,input,select,textarea{font:inherit}@media (prefers-reduced-motion:reduce){html:focus-within{scroll-behavior:auto}*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}html{font-size:62.5%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-white);color:var(--color-primary-text);font-family:var(--font-sans);font-size:1.6rem;line-height:1.6}img{height:auto}a{color:var(--color-darker-gray);text-decoration:none}a:hover{opacity:.8}h1,h2,h3,h4,h5,h6{color:var(--color-darker-gray);letter-spacing:-.02em;line-height:1.15}h1{font-size:var(--h1-size)}h2{font-size:2.8rem}h3{font-size:2.4rem}h4{font-size:2.2rem}h5{font-size:2rem}h6{font-size:1.8rem}hr{background-color:var(--color-light-gray);border:0;height:1px;width:100%}blockquote:not([class]){border-left:4px solid var(--ghost-accent-color);padding-left:2rem}figcaption{color:var(--color-secondary-text);font-size:1.4rem;line-height:1.4;margin-top:1.6rem;text-align:center}.kg-width-full figcaption{padding:0 1.6rem}.gh-content figcaption a{color:var(--color-darker-gray);text-decoration:none}pre{-webkit-overflow-scrolling:touch;background-color:var(--color-lighter-gray);-webkit-hyphens:none;hyphens:none;line-height:1.5;overflow-x:scroll;padding:1.6rem 2.4rem;white-space:pre}code{font-family:var(--font-mono);font-size:15px}:not(pre)>code{background-color:var(--color-lighter-gray);border-radius:3px;color:var(--ghost-accent-color);padding:.4rem}iframe{border:0;display:block;overflow:hidden;width:100%}@media (max-width:767px){h2{font-size:2.4rem}h3{font-size:2.1rem}}.gh-site{display:flex;flex-direction:column;min-height:100vh}.gh-main{flex-grow:1;padding-bottom:8rem;padding-top:8rem}.page-template .gh-main{padding-block:0}.gh-outer{padding-left:var(--gap);padding-right:var(--gap)}.gh-inner{margin:0 auto;max-width:var(--container-width,1200px)}.gh-canvas,.kg-width-full.kg-content-wide{--main:min(var(--content-width,720px),100% - var(--gap) * 2);--wide:minmax(0,calc((var(--container-width, 1200px) - var(--content-width, 720px))/2));--full:minmax(var(--gap),1fr);display:grid;grid-template-columns:[full-start] var(--full) [wide-start] var(--wide) [main-start] var(--main) [main-end] var(--wide) [wide-end] var(--full) [full-end]}.gh-canvas>*{grid-column:main}.kg-content-wide>div,.kg-width-wide{grid-column:wide}.kg-width-full{grid-column:full}.kg-width-full img{width:100%}@media (max-width:767px){#gh-main{padding-bottom:4.8rem;padding-top:4.8rem}}.gh-head{background-color:var(--color-white);height:100px}.gh-head-inner{align-items:center;-moz-column-gap:var(--head-nav-gap);column-gap:var(--head-nav-gap);display:grid;grid-auto-flow:row dense;grid-template-columns:1fr auto auto;height:100%}.gh-head-brand{line-height:1}.gh-head-brand-wrapper{align-items:center;display:flex}.gh-head-logo{font-size:2.4rem;font-weight:700;letter-spacing:-.02em;position:relative;white-space:nowrap}.gh-head-logo img{max-height:40px}.gh-head-logo img:nth-child(2){left:0;opacity:0;position:absolute;top:0}.gh-head-menu{display:flex}.gh-head .nav,.gh-head-menu{align-items:center;gap:var(--head-nav-gap)}.gh-head .nav{display:inline-flex;list-style:none;margin:0;padding:0;white-space:nowrap}.gh-head .nav-more-toggle{font-size:inherit;margin:0 -6px;position:relative;text-transform:inherit}.gh-head .nav-more-toggle svg{height:24px;width:24px}.gh-head-actions{align-items:center;display:flex;gap:var(--head-nav-gap);justify-content:flex-end}.gh-head-members{align-items:center;display:flex;gap:20px;white-space:nowrap}.gh-head-btn.gh-btn{font-size:inherit;font-weight:600}.gh-head-btn:not(.gh-btn){align-items:center;color:var(--ghost-accent-color);display:inline-flex}.gh-head-btn svg{height:1.3em;width:1.3em}.gh-search{margin-left:-6px;margin-right:-6px}.gh-search:hover{opacity:.9}.gh-head-brand .gh-search{margin-right:8px}@media (max-width:767px){.gh-head-members{flex-direction:column-reverse;gap:16px;width:100%}.gh-head-actions .gh-search{display:none}}@media (min-width:768px){.gh-head-brand .gh-search{display:none}body:not(.is-dropdown-loaded) .gh-head-menu .nav>li{opacity:0}}.is-head-left-logo .gh-head-inner{grid-template-columns:auto 1fr auto}@media (min-width:992px){.is-head-left-logo .gh-head-menu{margin-left:16px;margin-right:64px}}.is-head-middle-logo .gh-head-inner{grid-template-columns:1fr auto 1fr}.is-head-middle-logo .gh-head-brand{grid-column-start:2}.is-head-middle-logo .gh-head-actions{gap:28px}@media (min-width:992px){.is-head-middle-logo .gh-head-menu{margin-right:64px}}.is-head-stacked .gh-head{height:auto;position:relative}.is-head-stacked .gh-head-inner{grid-template-columns:1fr auto 1fr}.is-head-stacked .gh-head-brand{display:flex;grid-column-start:2;grid-row-start:1;min-height:80px}@media (max-width:767px){.is-head-stacked .gh-head-brand{min-height:unset}}@media (min-width:992px){.is-head-stacked .gh-head-inner{padding:0}.is-head-stacked .gh-head-brand{align-items:center;display:flex;height:80px}.is-head-stacked .gh-head-menu{grid-column:1/4;grid-row-start:2;height:56px;justify-content:center;margin:0 48px}.is-head-stacked .gh-head-menu:after,.is-head-stacked .gh-head-menu:before{background-color:var(--color-light-gray);content:"";height:1px;left:0;position:absolute;top:80px;width:100%}.is-head-stacked .gh-head-menu:after{top:136px}.is-head-stacked .gh-head-actions{grid-column:1/4;grid-row-start:1;justify-content:space-between}}.is-head-transparent .gh-head{background-color:transparent;left:0;position:absolute;right:0;z-index:90}.is-head-transparent .gh-head .nav>li a,.is-head-transparent .gh-head-description,.is-head-transparent .gh-head-link,.is-head-transparent .gh-head-logo,.is-head-transparent .gh-head-logo a,.is-head-transparent .gh-search,.is-head-transparent .gh-social,.is-head-transparent .nav-more-toggle{color:var(--color-white)}.is-head-transparent .gh-burger:after,.is-head-transparent .gh-burger:before{background-color:var(--color-white)}.is-head-transparent .gh-head-btn{background-color:#fff;color:#15171a}.is-head-transparent .gh-head-menu:after,.is-head-transparent .gh-head-menu:before{background-color:hsla(0,0%,100%,.2)}.is-head-transparent #announcement-bar-root{left:0;position:absolute;right:0}.is-head-transparent #announcement-bar-root:not(:empty)+:is(.site,.gh-site) .gh-head{margin-top:48px}.is-head-dark:not(.is-head-transparent) .gh-head{background-color:var(--color-darker-gray)}.is-head-dark:not(.is-head-transparent) .gh-head .nav a,.is-head-dark:not(.is-head-transparent) .gh-head-description,.is-head-dark:not(.is-head-transparent) .gh-head-link,.is-head-dark:not(.is-head-transparent) .gh-head-logo,.is-head-dark:not(.is-head-transparent) .gh-head-logo a,.is-head-dark:not(.is-head-transparent) .gh-search,.is-head-dark:not(.is-head-transparent) .gh-social,.is-head-dark:not(.is-head-transparent) .nav-more-toggle{color:var(--color-white)}.is-head-dark:not(.is-head-transparent) .gh-burger:after,.is-head-dark:not(.is-head-transparent) .gh-burger:before{background-color:var(--color-white)}.is-head-dark:not(.is-head-transparent) .gh-head-btn{background-color:#fff;color:#15171a}.is-head-dark:not(.is-head-transparent) .gh-head-menu:after,.is-head-dark:not(.is-head-transparent) .gh-head-menu:before{background-color:hsla(0,0%,100%,.2)}.is-head-brand:not(.is-head-transparent) .gh-head{background-color:var(--ghost-accent-color)}.is-head-brand:not(.is-head-transparent) .gh-head .nav a,.is-head-brand:not(.is-head-transparent) .gh-head-description,.is-head-brand:not(.is-head-transparent) .gh-head-link,.is-head-brand:not(.is-head-transparent) .gh-head-logo,.is-head-brand:not(.is-head-transparent) .gh-head-logo a,.is-head-brand:not(.is-head-transparent) .gh-search,.is-head-brand:not(.is-head-transparent) .gh-social,.is-head-brand:not(.is-head-transparent) .nav-more-toggle{color:var(--color-white)}.is-head-brand:not(.is-head-transparent) .gh-burger:after,.is-head-brand:not(.is-head-transparent) .gh-burger:before{background-color:var(--color-white)}.is-head-brand:not(.is-head-transparent) .gh-head-btn{background-color:#fff;color:#15171a}.is-head-brand:not(.is-head-transparent) .gh-head-menu:after,.is-head-brand:not(.is-head-transparent) .gh-head-menu:before{background-color:hsla(0,0%,100%,.3)}.gh-dropdown{background-color:#fff;border-radius:5px;box-shadow:0 0 0 1px rgba(0,0,0,.04),0 7px 20px -5px rgba(0,0,0,.15);margin-top:24px;opacity:0;padding:12px 0;position:absolute;right:-16px;text-align:left;top:100%;transform:translate3d(0,6px,0);transition:opacity .3s,transform .2s;visibility:hidden;width:200px;z-index:90}.is-head-middle-logo .gh-dropdown{left:-24px;right:auto}.is-dropdown-mega .gh-dropdown{-moz-column-gap:40px;column-gap:40px;display:grid;grid-auto-flow:column;grid-template-columns:1fr 1fr;padding:20px 32px;width:auto}.is-dropdown-open .gh-dropdown{opacity:1;transform:translateY(0);visibility:visible}.gh-dropdown li a{color:#15171a!important;display:block;padding:6px 20px}.is-dropdown-mega .gh-dropdown li a{padding:8px 0}.gh-burger{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:transparent;border:0;cursor:pointer;display:none;height:30px;margin-right:-3px;padding:0;position:relative;width:30px}.gh-burger:after,.gh-burger:before{background-color:var(--color-darker-gray);content:"";height:1px;left:3px;position:absolute;transition:all .2s cubic-bezier(.04,.04,.12,.96) .1008s;width:24px}.gh-burger:before{top:11px}.gh-burger:after{bottom:11px}.is-head-open .gh-burger:before{top:15px;transform:rotate(45deg)}.is-head-open .gh-burger:after{bottom:14px;transform:rotate(-45deg)}@media (max-width:767px){#gh-head{height:64px}#gh-head .gh-head-inner{gap:48px;grid-template-columns:1fr;grid-template-rows:auto 1fr auto}#gh-head .gh-head-brand{align-items:center;display:grid;grid-column-start:1;grid-template-columns:1fr auto auto;height:64px}#gh-head .gh-head-logo{font-size:2.2rem}.gh-burger{display:block}#gh-head .gh-head-actions,#gh-head .gh-head-menu{justify-content:center;opacity:0;position:fixed;visibility:hidden}#gh-head .gh-head-menu{transform:translateY(0);transition:none}#gh-head .nav{align-items:center;gap:20px;line-height:1.4}#gh-head .nav a{font-size:2.6rem;font-weight:600;text-transform:none}#gh-head .nav li{opacity:0;transform:translateY(-4px)}#gh-head .gh-head-actions{text-align:center}#gh-head :is(.gh-head-btn,.gh-head-link){opacity:0;transform:translateY(8px)}#gh-head .gh-head-btn{font-size:1.8rem;text-transform:none;width:100%}#gh-head .gh-head-btn:not(.gh-btn){font-size:2rem}#gh-main{transition:opacity .4s}.is-head-open #gh-head{-webkit-overflow-scrolling:touch;height:100%;inset:0;overflow-y:scroll;position:fixed;z-index:3999999}.is-head-open:not(.is-head-brand):not(.is-head-dark):not(.is-head-transparent) #gh-head{background-color:var(--color-white)}.is-head-open.is-head-transparent #gh-head,.is-head-open:is(.is-head-transparent,.is-head-brand) #gh-head .gh-head-actions{background-color:var(--ghost-accent-color)}.is-head-open.is-head-dark #gh-head,.is-head-open.is-head-dark #gh-head .gh-head-actions{background-color:var(--color-darker-gray)}.is-head-open #gh-head .gh-head-actions,.is-head-open #gh-head .gh-head-menu{opacity:1;position:static;visibility:visible}.is-head-open #gh-head .nav{display:flex;flex-direction:column}.is-head-open #gh-head .nav li{opacity:1;transform:translateY(0);transition:transform .2s,opacity .2s}.is-head-open #gh-head .gh-head-actions{align-items:center;background-color:var(--color-white);bottom:0;display:inline-flex;flex-direction:column;gap:12px;left:0;padding:var(--gap) 0 calc(var(--gap) + 8px);position:sticky;right:0}.is-head-open #gh-head :is(.gh-head-btn,.gh-head-link){opacity:1;transform:translateY(0);transition:transform .4s,opacity .4s;transition-delay:.2s}.is-head-open #gh-head .gh-head-link{transition-delay:.4s}.is-head-open #gh-main{opacity:0}}.gh-cover{min-height:var(--cover-height,50vh);padding-bottom:6.4rem;padding-top:6.4rem;position:relative}.gh-cover-image{height:100%;inset:0;-o-object-fit:cover;object-fit:cover;position:absolute;width:100%;z-index:-1}.has-serif-body .gh-cover-description,.has-serif-title .gh-cover-title{font-family:var(--font-serif)}.has-serif-title .gh-card-title{font-family:var(--font-serif);letter-spacing:-.01em}.has-serif-body .gh-card-excerpt{font-family:var(--font-serif)}.gh-card{word-break:break-word}.page-template .gh-article-header{margin-top:var(--header-spacing,80px)}.gh-article-tag{color:var(--ghost-accent-color)}.gh-article-title{word-break:break-word}.has-serif-title .gh-article-title{font-family:var(--font-serif);letter-spacing:-.01em}.gh-article-excerpt{color:var(--color-secondary-text);font-size:2.1rem;line-height:1.5;margin-top:2rem}.has-serif-body .gh-article-excerpt{font-family:var(--font-serif)}.gh-article-image{grid-column:wide-start/wide-end;margin-top:4rem}.gh-article-image img{width:100%}@media (max-width:767px){.gh-article-excerpt{font-size:1.9rem}.gh-article-image{margin-top:2.4rem}}.gh-content{font-size:var(--content-font-size,1.8rem);letter-spacing:var(--content-letter-spacing,0);margin-top:4rem;word-break:break-word}.gh-content>*+*{margin-bottom:0;margin-top:calc(1.6em*var(--content-spacing-multiplier, 1))}.gh-content>[id]{margin:0}.gh-content>.kg-card+[id]{margin-top:calc(2em*var(--content-spacing-multiplier, 1))!important}.has-serif-title .gh-content>[id]{font-family:var(--font-serif);letter-spacing:-.01em}.gh-content>[id]:not(:first-child){margin-top:calc(1.6em*var(--content-spacing-multiplier, 1))}.gh-content>[id]+*{margin-top:calc(.8em*var(--content-spacing-multiplier, 1))}.gh-content>blockquote,.gh-content>hr{position:relative}.gh-content>blockquote,.gh-content>blockquote+*,.gh-content>hr,.gh-content>hr+*{margin-top:calc(2.4em*var(--content-spacing-multiplier, 1))}.gh-content h2{font-size:1.6em}.gh-content h3{font-size:1.4em}.gh-content a{color:var(--ghost-accent-color);text-decoration:underline;word-break:break-word}.gh-content .kg-callout-card .kg-callout-text,.gh-content .kg-toggle-card .kg-toggle-content>ol,.gh-content .kg-toggle-card .kg-toggle-content>p,.gh-content .kg-toggle-card .kg-toggle-content>ul{font-size:.95em}.has-serif-body .gh-content .kg-callout-text,.has-serif-body .gh-content .kg-toggle-content>ol,.has-serif-body .gh-content .kg-toggle-content>p,.has-serif-body .gh-content .kg-toggle-content>ul,.has-serif-body .gh-content>blockquote,.has-serif-body .gh-content>dl,.has-serif-body .gh-content>ol,.has-serif-body .gh-content>p,.has-serif-body .gh-content>ul{font-family:var(--font-serif)}.gh-content dl,.gh-content ol,.gh-content ul{padding-left:2.8rem}.gh-content :is(li+li,li :is(ul,ol)){margin-top:.8rem}.gh-content ol ol li{list-style-type:lower-alpha}.gh-content ol ol ol li{list-style-type:lower-roman}.gh-content table:not(.gist table){-webkit-overflow-scrolling:touch;background:radial-gradient(ellipse at left,rgba(0,0,0,.2) 0,transparent 75%) 0,radial-gradient(ellipse at right,rgba(0,0,0,.2) 0,transparent 75%) 100%;background-attachment:scroll,scroll;background-repeat:no-repeat;background-size:10px 100%,10px 100%;border-collapse:collapse;border-spacing:0;display:inline-block;font-family:var(--font-sans);font-size:1.6rem;max-width:100%;overflow-x:auto;vertical-align:top;white-space:nowrap;width:auto}.gh-content table:not(.gist table) td:first-child{background-image:linear-gradient(90deg,#fff 50%,hsla(0,0%,100%,0));background-repeat:no-repeat;background-size:20px 100%}.gh-content table:not(.gist table) td:last-child{background-image:linear-gradient(270deg,#fff 50%,hsla(0,0%,100%,0));background-position:100% 0;background-repeat:no-repeat;background-size:20px 100%}.gh-content table:not(.gist table) th{background-color:var(--color-white);color:var(--color-darkgrey);font-size:1.2rem;font-weight:700;letter-spacing:.2px;text-align:left;text-transform:uppercase}.gh-content table:not(.gist table) td,.gh-content table:not(.gist table) th{border:1px solid var(--color-light-gray);padding:6px 12px}.page-template .gh-content:only-child{margin-top:0!important}.page-template .gh-content:only-child>:first-child:not(.kg-width-full){margin-top:var(--header-spacing,80px)}.page-template .gh-content>:last-child:not(.kg-width-full){margin-bottom:var(--footer-spacing,0)}@media (max-width:767px){.gh-content{font-size:1.7rem;margin-top:3.2rem}}.gh-comments{margin-bottom:-24px;margin-top:64px}.gh-comments-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:40px}.gh-comments .gh-comments-title{margin-bottom:28px}.gh-comments-header .gh-comments-title{margin-bottom:0}.gh-comments-count{color:var(--color-secondary-text)}.gh-cta-gradient{background:linear-gradient(180deg,hsla(0,0%,100%,0),var(--color-white));content:"";grid-column:full-start/full-end;height:160px;margin-bottom:4rem;margin-top:-16rem;position:relative}.gh-cta-gradient:first-child{display:none}.gh-cta{display:flex;flex-direction:column;margin-bottom:4rem;text-align:center}.gh-cta-title{font-size:2.2rem;letter-spacing:-.02em;margin-bottom:3.2rem}.gh-cta-actions{align-items:center;display:flex;flex-direction:column}.gh-cta-link{color:var(--color-secondary-text);cursor:pointer;font-size:1.4rem;margin-top:.8rem;text-decoration:none}.gh-cta-link:hover{color:var(--color-darker-gray)}@media (max-width:767px){.gh-cta-actions{-moz-column-gap:.8rem;column-gap:.8rem}}.gh-content :not(.kg-card):not(table):not([id])+:is(.kg-card,table){margin-top:calc(2em*var(--content-spacing-multiplier, 1))}.gh-content :is(.kg-card,table)+:not(.kg-card):not(table):not([id]){margin-top:calc(2em*var(--content-spacing-multiplier, 1))}.gh-content>.kg-width-full+.kg-width-full:not(.kg-width-full.kg-card-hascaption+.kg-width-full){margin-top:0}.kg-image{margin-left:auto;margin-right:auto}.kg-embed-card{align-items:center;display:flex;flex-direction:column;width:100%}.kg-gallery-image,.kg-image[width][height]{cursor:pointer}.kg-gallery-image a:hover,.kg-image-card a:hover{opacity:1!important}.kg-card.kg-toggle-card .kg-toggle-heading-text{font-size:2rem;font-weight:700}.has-serif-title .kg-toggle-card .kg-toggle-heading-text{font-family:var(--font-serif)}.kg-callout-card.kg-card{border-radius:.25em}.kg-callout-card-accent a{text-decoration:underline}blockquote.kg-blockquote-alt{color:var(--color-secondary-text);font-style:normal;font-weight:400}.kg-card.kg-button-card .kg-btn{font-size:1em}.has-serif-body .kg-header-card h3.kg-header-card-subheader,.has-serif-title .kg-card.kg-header-card h2.kg-header-card-header{font-family:var(--font-serif)}.kg-bookmark-card .kg-bookmark-container{border-radius:.25em!important}.kg-bookmark-card .kg-bookmark-content{padding:1.15em}.kg-bookmark-card .kg-bookmark-title{font-size:.9em}.kg-bookmark-card .kg-bookmark-description{font-size:.8em;margin-top:.3em;max-height:none}.kg-bookmark-card .kg-bookmark-metadata{font-size:.8em}.kg-bookmark-card .kg-bookmark-thumbnail img{border-radius:0 .2em .2em 0}.has-light-text .kg-audio-card button{color:#fff}.has-light-text .kg-audio-card .kg-audio-volume-slider{color:hsla(0,0%,100%,.3)}.pagination{display:grid;grid-template-columns:1fr auto 1fr;margin-top:6.4rem}.page-number{grid-column-start:2}.older-posts{text-align:right}.gh-navigation{align-items:center;-moz-column-gap:2.4rem;column-gap:2.4rem;display:grid;grid-template-columns:1fr auto 1fr}.gh-navigation>div{align-items:center;display:flex}.gh-navigation-next{justify-content:flex-end}.gh-navigation-link{align-items:center;display:inline-flex}.gh-navigation-link svg{height:16px;width:16px}.gh-navigation-previous svg{margin-right:.4rem}.gh-navigation-next svg{margin-left:.4rem}@media (max-width:767px){.gh-navigation-hide{display:none}}.gh-btn{align-items:center;background-color:var(--color-darker-gray);border:0;border-radius:100px;color:var(--color-white);cursor:pointer;display:inline-flex;font-size:1.6rem;font-weight:700;gap:.4em;justify-content:center;letter-spacing:inherit;line-height:1;padding:calc(.75em*var(--multiplier, 1)) calc(1.15em*var(--multiplier, 1))}.gh-btn:hover{opacity:.95}.gh-post-upgrade-cta .gh-btn{line-height:inherit}.gh-primary-btn{background-color:var(--ghost-accent-color)}.gh-outline-btn{background-color:transparent;border:1px solid var(--color-light-gray);color:var(--color-darker-gray);text-decoration:none}.gh-outline-btn:hover{border-color:var(--color-mid-gray);opacity:1}.gh-icon-btn{align-items:center;background-color:transparent;border:0;color:var(--darker-gray-color);cursor:pointer;display:inline-flex;height:30px;justify-content:center;outline:none;padding:0;width:30px}.gh-icon-btn svg{height:20px;width:20px}.gh-text-btn{align-items:center;background-color:transparent;border:0;color:var(--darker-gray-color);cursor:pointer;display:inline-flex;justify-content:center;letter-spacing:inherit;margin:0;outline:none;padding:0;will-change:opacity}.gh-text-btn:hover{opacity:.8}.gh-foot{color:var(--color-secondary-text);padding-bottom:8rem;padding-top:8rem;white-space:nowrap}.gh-foot-inner{display:grid;font-size:1.3rem;gap:40px;grid-template-columns:1fr auto 1fr}.no-menu .gh-foot-inner{align-items:center;display:flex;flex-direction:column;gap:24px}.gh-foot-menu .nav{align-items:center;display:inline-flex;flex-wrap:wrap;justify-content:center;list-style:none;margin:0;padding:0;row-gap:4px}.gh-foot-menu .nav li{align-items:center;display:flex}.gh-foot-menu .nav li+li:before{content:"•";font-size:.9rem;line-height:0;padding:0 1.2rem}.gh-powered-by{text-align:right}.gh-foot a{color:var(--color-secondary-text)}.gh-foot a:hover{color:var(--color-darker-gray);opacity:1}@media (max-width:767px){.gh-foot{padding-bottom:12rem;padding-top:6.4rem}.gh-foot-inner{grid-template-columns:1fr;text-align:center}.gh-foot-menu .nav{flex-direction:column}.gh-foot-menu .nav li+li{margin-top:.4rem}.gh-foot-menu .nav li+li:before{display:none}.gh-powered-by{text-align:center}}.pswp{-webkit-text-size-adjust:100%;backface-visibility:hidden;display:none;height:100%;left:0;outline:none;overflow:hidden;position:absolute;top:0;touch-action:none;width:100%;z-index:3999999}.pswp img{max-width:none}.pswp--animate_opacity{opacity:.001;transition:opacity 333ms cubic-bezier(.4,0,.22,1);will-change:opacity}.pswp--open{display:block}.pswp--zoom-allowed .pswp__img{cursor:zoom-in}.pswp--zoomed-in .pswp__img{cursor:grab}.pswp--dragging .pswp__img{cursor:grabbing}.pswp__bg{backface-visibility:hidden;background-color:rgba(0,0,0,.85);opacity:0;transform:translateZ(0);transition:opacity 333ms cubic-bezier(.4,0,.22,1);will-change:opacity}.pswp__bg,.pswp__scroll-wrap{height:100%;left:0;position:absolute;top:0;width:100%}.pswp__scroll-wrap{overflow:hidden}.pswp__container,.pswp__zoom-wrap{backface-visibility:hidden;bottom:0;left:0;position:absolute;right:0;top:0;touch-action:none}.pswp__container,.pswp__img{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.pswp__zoom-wrap{position:absolute;transform-origin:left top;transition:transform 333ms cubic-bezier(.4,0,.22,1);width:100%}.pswp--animated-in .pswp__bg,.pswp--animated-in .pswp__zoom-wrap{transition:none}.pswp__item{bottom:0;overflow:hidden;right:0}.pswp__img,.pswp__item{left:0;position:absolute;top:0}.pswp__img{height:auto;width:auto}.pswp__img--placeholder{backface-visibility:hidden}.pswp__img--placeholder--blank{background:var(--color-black)}.pswp--ie .pswp__img{height:auto!important;left:0;top:0;width:100%!important}.pswp__error-msg{color:var(--color-secondary-text);font-size:14px;left:0;line-height:16px;margin-top:-8px;position:absolute;text-align:center;top:50%;width:100%}.pswp__error-msg a{color:var(--color-secondary-text);text-decoration:underline}.pswp__button{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:none;border:0;box-shadow:none;cursor:pointer;display:block;float:right;height:44px;margin:0;overflow:visible;padding:0;position:relative;transition:opacity .2s;width:44px}.pswp__button:focus,.pswp__button:hover{opacity:1}.pswp__button:active{opacity:.9;outline:none}.pswp__button::-moz-focus-inner{border:0;padding:0}.pswp__ui--over-close .pswp__button--close{opacity:1}.pswp__button,.pswp__button--arrow--left:before,.pswp__button--arrow--right:before{background:url(../images/default-skin.png) 0 0 no-repeat;background-size:264px 88px;height:44px;width:44px}@media (-webkit-min-device-pixel-ratio:1.09375),(-webkit-min-device-pixel-ratio:1.1),(min-resolution:1.1dppx),(min-resolution:105dpi){.pswp--svg .pswp__button,.pswp--svg .pswp__button--arrow--left:before,.pswp--svg .pswp__button--arrow--right:before{background-image:url(../images/default-skin.svg)}.pswp--svg .pswp__button--arrow--left,.pswp--svg .pswp__button--arrow--right{background:none}}.pswp__button--close{background-position:0 -44px}.pswp__button--share{background-position:-44px -44px}.pswp__button--fs{display:none}.pswp--supports-fs .pswp__button--fs{display:block}.pswp--fs .pswp__button--fs{background-position:-44px 0}.pswp__button--zoom{background-position:-88px 0;display:none}.pswp--zoom-allowed .pswp__button--zoom{display:block}.pswp--zoomed-in .pswp__button--zoom{background-position:-132px 0}.pswp--touch .pswp__button--arrow--left,.pswp--touch .pswp__button--arrow--right{visibility:hidden}.pswp__button--arrow--left,.pswp__button--arrow--right{background:none;height:100px;margin-top:-50px;position:absolute;top:50%;width:70px}.pswp__button--arrow--left{left:0}.pswp__button--arrow--right{right:0}.pswp__button--arrow--left:before,.pswp__button--arrow--right:before{content:"";height:30px;position:absolute;top:35px;width:32px}.pswp__button--arrow--left:before{background-position:-138px -44px;left:6px}.pswp__button--arrow--right:before{background-position:-94px -44px;right:6px}.pswp__counter{color:var(--color-white);font-size:11px;font-weight:700;height:44px;left:0;line-height:44px;padding:0 15px;position:absolute;top:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.pswp__caption{bottom:0;left:0;min-height:44px;position:absolute;width:100%}.pswp__caption__center{color:var(--color-white);font-size:11px;line-height:1.6;margin:0 auto;max-width:420px;padding:25px 15px 30px;text-align:center}.pswp__caption__center .post-caption-title{font-size:15px;font-weight:500;margin-bottom:7px;text-transform:uppercase}.pswp__caption__center .post-caption-meta-item+.post-caption-meta-item:before{content:"\02022";padding:0 4px}.pswp__caption--empty{display:none}.pswp__caption--fake{visibility:hidden}.pswp__preloader{direction:ltr;height:44px;left:50%;margin-left:-22px;opacity:0;position:absolute;top:0;transition:opacity .25s ease-out;width:44px;will-change:opacity}.pswp__preloader__icn{height:20px;margin:12px;width:20px}.pswp__preloader--active{opacity:1}.pswp__preloader--active .pswp__preloader__icn{background:url(../images/preloader.gif) 0 0 no-repeat}.pswp--css_animation .pswp__preloader--active{opacity:1}.pswp--css_animation .pswp__preloader--active .pswp__preloader__icn{animation:clockwise .5s linear infinite}.pswp--css_animation .pswp__preloader--active .pswp__preloader__donut{animation:donut-rotate 1s cubic-bezier(.4,0,.22,1) infinite}.pswp--css_animation .pswp__preloader__icn{background:none;height:14px;left:15px;margin:0;opacity:.75;position:absolute;top:15px;width:14px}.pswp--css_animation .pswp__preloader__cut{height:14px;overflow:hidden;position:relative;width:7px}.pswp--css_animation .pswp__preloader__donut{background:none;border-bottom:2px solid transparent;border-left:2px solid transparent;border-radius:50%;border-right:2px solid var(--color-white);border-top:2px solid var(--color-white);box-sizing:border-box;height:14px;left:0;margin:0;position:absolute;top:0;width:14px}@media screen and (max-width:1024px){.pswp__preloader{float:right;left:auto;margin:0;position:relative;top:auto}}@keyframes clockwise{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes donut-rotate{0%{transform:rotate(0)}50%{transform:rotate(-140deg)}to{transform:rotate(0)}}.pswp__ui{-webkit-font-smoothing:auto;opacity:1;visibility:visible;z-index:1550}.pswp__top-bar{height:44px;left:0;position:absolute;top:0;width:100%}.pswp--has_mouse .pswp__button--arrow--left,.pswp--has_mouse .pswp__button--arrow--right,.pswp__caption,.pswp__top-bar{backface-visibility:hidden;transition:opacity 333ms cubic-bezier(.4,0,.22,1);will-change:opacity}.pswp--has_mouse .pswp__button--arrow--left,.pswp--has_mouse .pswp__button--arrow--right{visibility:visible}.pswp__ui--idle .pswp__button--arrow--left,.pswp__ui--idle .pswp__button--arrow--right,.pswp__ui--idle .pswp__top-bar{opacity:0}.pswp__ui--hidden .pswp__button--arrow--left,.pswp__ui--hidden .pswp__button--arrow--right,.pswp__ui--hidden .pswp__caption,.pswp__ui--hidden .pswp__top-bar{opacity:.001}.pswp__ui--one-slide .pswp__button--arrow--left,.pswp__ui--one-slide .pswp__button--arrow--right,.pswp__ui--one-slide .pswp__counter{display:none}.pswp__element--disabled{display:none!important}.pswp--minimal--dark .pswp__top-bar{background:none}@font-face{font-family:Manrope;font-weight:100 1000;src:url(../fonts/Manrope[wght].woff2) format("woff2-variations")}@font-face{font-family:Libre Baskerville;font-style:normal;font-weight:400;src:local(""),url(../fonts/libre-baskerville-v14-latin-regular.woff2) format("woff2")}@font-face{font-family:Libre Baskerville;font-style:normal;font-weight:700;src:local(""),url(../fonts/libre-baskerville-v14-latin-700.woff2) format("woff2")}@font-face{font-family:Libre Baskerville;font-style:italic;font-weight:400;src:local(""),url(../fonts/libre-baskerville-v14-latin-italic.woff2) format("woff2")}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400;src:local(""),url(../fonts/jetbrains-mono-v13-latin-regular.woff2) format("woff2")}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:700;src:local(""),url(../fonts/jetbrains-mono-v13-latin-700.woff2) format("woff2")}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:800;src:local(""),url(../fonts/jetbrains-mono-v13-latin-800.woff2) format("woff2")}@font-face{font-family:JetBrains Mono;font-style:italic;font-weight:400;src:local(""),url(../fonts/jetbrains-mono-v13-latin-italic.woff2) format("woff2")}@font-face{font-family:JetBrains Mono;font-style:italic;font-weight:700;src:local(""),url(../fonts/jetbrains-mono-v13-latin-700italic.woff2) format("woff2")}:root{--font-sans:Manrope,-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;--font-serif:Libre Baskerville,Georgia,Times,serif;--font-mono:JetBrains Mono,Menlo,Consolas,Monaco,Liberation Mono,Lucida Console,monospace;--color-primary-text:var(--color-darker-gray);--color-secondary-text-dark:rgba(0,0,0,.4);--color-secondary-text-light:hsla(0,0%,100%,.64);--color-secondary-text:var(--color-secondary-text-dark);--color-border:rgba(0,0,0,.08);--gap:clamp(24px,1.7032rem + 1.9355vw,48px);--head-nav-gap:32px;--container-width:1440px;--content-font-size:clamp(1.7rem,0.38vw + 1.4rem,2rem);--header-spacing:clamp(4.8rem,4rem + 2.5vw,8rem)}:root.has-light-text{--color-lighter-gray:rgba(0,0,0,.1);--color-darker-gray:#fff;--color-secondary-text:var(--color-secondary-text-light);--color-border:hsla(0,0%,100%,.2)}body{background-color:var(--background-color)}.gh-main{padding-top:clamp(4.8rem,4rem + 2.5vw,8rem)}figcaption{font-size:1.3rem;text-align:right}.kg-width-full figcaption{padding:0}hr{background-color:var(--color-border)}.gh-content h2{font-size:2.25em;letter-spacing:-.03em}.gh-content h3{font-size:1.6em}.gh-canvas{grid-template-columns:repeat(12,minmax(0,1fr))}.gh-canvas>*{grid-column:4/span 6}.gh-canvas>.kg-width-wide{grid-column:4/span 9}.gh-canvas>.kg-gallery-card.kg-width-wide,.gh-canvas>.kg-width-full{grid-column:1/span 12;position:relative;transform:translateZ(0);z-index:20}@media (max-width:991px){.gh-canvas>*{grid-column:3/span 8}.gh-canvas>.kg-width-wide{grid-column:3/span 10}}@media (max-width:767px){.gh-canvas>*{grid-column:2/span 10}.gh-canvas>.kg-width-wide{grid-column:1/span 12}}@media (max-width:480px){.gh-canvas>*{grid-column:1/span 12}}.gh-head{background-color:transparent;font-size:1.6rem}.gh-head-logo{font-weight:800}.gh-head-logo img{max-height:48px}.gh-head-link,.gh-head-menu{font-weight:700}.is-head-stacked .gh-head-menu:after,.is-head-stacked .gh-head-menu:before{background-color:var(--color-border)}.gh-head-menu a{color:inherit}@media (max-width:991px){.is-head-open:not(.is-head-brand):not(.is-head-dark):not(.is-head-transparent) :is(#gh-head,#gh-head .gh-head-actions){background-color:var(--background-color)}}.gh-about{margin-bottom:40px}.gh-about-content{word-break:break-word}.gh-about-primary{font-size:clamp(3.2rem,2.4452rem + 2.0968vw,5.8rem);font-weight:800;line-height:1.2;max-width:1200px}.has-serif-font .gh-about-primary{font-family:var(--font-serif)}.has-mono-font .gh-about-primary{font-family:var(--font-mono)}.gh-about-primary a{text-decoration:underline}.gh-about-secondary{font-size:clamp(2.4rem,.54vw + 2.14rem,3rem);font-weight:500;letter-spacing:-.008em;max-width:840px}.has-serif-font .gh-about-secondary{font-family:var(--font-serif)}.has-mono-font .gh-about-secondary{font-family:var(--font-mono)}.gh-about-primary+.gh-about-secondary{font-size:clamp(2rem,.36vw + 1.83rem,2.4rem);font-weight:450;margin-top:20px;max-width:640px}.gh-about-secondary a{text-decoration:underline}.has-side-about .gh-about{margin-top:48px}.has-side-about .gh-about.no-image{margin-bottom:48px;margin-top:80px}.has-side-about .gh-about-inner{display:grid;gap:clamp(4rem,.0842rem + 3.9474vw,6.4rem);grid-template-columns:1fr 1fr}.has-side-about .gh-about.no-image .gh-about-inner{grid-template-columns:1fr}.has-side-about .gh-about-content-inner{position:sticky;top:40px}@media (max-width:840px){.has-side-about .gh-about-inner{display:flex;flex-direction:column-reverse;gap:64px}}.has-background-about .gh-about{position:relative}.has-background-about .gh-about:before{background-color:var(--color-black);content:"";inset:0;position:absolute;transition:opacity 1.5s ease}.has-background-about .gh-about.initialized:before{opacity:.4}.has-background-about .gh-about-inner{align-items:flex-end;display:flex;min-height:var(--about-height,100vh)}.has-background-about .gh-about-image{height:100%;inset:0;-o-object-fit:cover;object-fit:cover;position:absolute;width:100%;z-index:-1}.has-background-about .gh-about-content{align-items:flex-start;bottom:calc(var(--gap) + 24px);display:flex;flex-direction:column;margin-bottom:calc(var(--gap) + 24px);margin-top:200px;max-width:50%;position:sticky;text-align:left}.has-background-about .gh-about-primary{color:#fff}.has-background-about .gh-about-secondary{color:#fff;opacity:.7}.has-background-about .gh-subscribe-input{background-color:#fff;border:0;color:var(--color-secondary-text-dark)}@media (max-width:991px){.has-background-about .gh-about-content{max-width:none}}.has-typographic-about .gh-about{display:flex;min-height:calc(100vh - 110px);padding-bottom:64px;padding-top:64px}.has-typographic-about .gh-about-inner{display:flex;flex-direction:column;gap:48px;justify-content:flex-end;padding-bottom:clamp(2.4rem,2rem + 1.25vw,4rem);width:100%}.has-typographic-about .gh-about-image{border-radius:50%;height:128px;-o-object-fit:cover;object-fit:cover;width:128px}.has-typographic-about .gh-subscribe-input{margin-top:48px}.gh-card-link:hover{opacity:1}.gh-card-wrapper{display:flex;flex-direction:column;flex-grow:1;justify-content:center}.gh-card-title{font-weight:800;word-break:break-word}.has-serif-font .gh-card-title{font-family:var(--font-serif)}.has-mono-font .gh-card-title{font-family:var(--font-mono)}.gh-card-link:hover .gh-card-title{opacity:.8}.gh-card-meta{color:var(--color-secondary-text);flex-wrap:wrap;font-size:1.4rem;font-weight:500;margin-top:16px}.gh-card-meta,.gh-card-meta>*{align-items:center;display:flex;gap:8px}.gh-card-meta>*+:not(script):not(.gh-card-access):before{background-color:currentColor;border-radius:50%;content:"";height:2px;width:2px}.gh-card-access{background-color:var(--color-border);border-radius:40px;margin-left:4px;padding:0 10px 0 8px}.has-parallax-feed .gh-card-access{background-color:var(--color-white);color:var(--color-darker-gray)}.gh-card-access svg{margin-right:-5px}.has-classic-feed .gh-card.no-image{max-width:1200px}.has-classic-feed .gh-card+.gh-card{margin-top:clamp(4.8rem,4rem + 2.5vw,8rem)}.has-classic-feed .gh-card+.gh-card.no-image,.has-classic-feed .gh-card.no-image+.gh-card{margin-top:clamp(8rem,7.14vw + 4.57rem,16rem)}.has-classic-feed .gh-card-link{display:flex;flex-direction:row-reverse;gap:clamp(4rem,3rem + 3.125vw,8rem)}.has-classic-feed .gh-card-image{flex:1;position:relative}.has-classic-feed .gh-card-image:before{content:"";display:block;padding-bottom:56.25%}.has-classic-feed .no-image .gh-card-image{display:none}.has-classic-feed .gh-card-image img{height:100%;inset:0;-o-object-fit:cover;object-fit:cover;position:absolute;width:100%}.has-classic-feed .gh-card-wrapper{flex:1;flex-shrink:0;width:100%}.has-classic-feed .gh-card-title{font-size:clamp(3.2rem,2.7rem + 1.5625vw,5.2rem)}.has-classic-feed .kg-width-full .gh-card-title{font-size:clamp(3.2rem,2.4rem + 2.5vw,6.4rem)}@media (max-width:991px){.has-classic-feed .gh-card-link{flex-direction:column;gap:32px}}.has-typographic-feed.home-template .gh-main{padding-top:0}.has-typographic-feed .gh-card{margin-top:clamp(8rem,6rem + 6.25vw,16rem)}.has-typographic-feed .gh-card-title{font-size:clamp(3.2rem,2.4rem + 2.5vw,6.4rem);line-height:1.1;max-width:1200px}.has-typographic-feed .gh-card-excerpt{font-size:clamp(1.8rem,.27vw + 1.67rem,2.1rem);font-weight:450;letter-spacing:-.005em;line-height:1.5;margin-top:16px;max-width:920px}.has-serif-font.has-typographic-feed .gh-card-excerpt{font-family:var(--font-serif)}.has-mono-font.has-typographic-feed .gh-card-excerpt{font-family:var(--font-mono)}.has-typographic-feed .gh-card-meta{margin-top:16px}.has-parallax-feed .gh-card{display:flex;min-height:640px}.has-parallax-feed .gh-card.no-image{background-color:var(--tag-color,var(--color-darker-gray))}.has-parallax-feed .kg-width-full .gh-card{min-height:800px}.has-parallax-feed .gh-card+.gh-card{margin-top:80px}.has-parallax-feed .gh-card-link{display:flex;flex-grow:1;position:relative}.has-parallax-feed .gh-card:not(.no-image) .gh-card-link:before{background-color:#000;content:"";height:100%;opacity:.6;position:absolute;transition:opacity .4s;width:100%}.has-parallax-feed .gh-card:not(.no-image):hover .gh-card-link:before{opacity:.4}.has-parallax-feed .gh-card-image{height:100%;position:absolute;width:100%;z-index:-1}.has-parallax-feed .gh-card-wrapper{justify-content:flex-end;padding:64px 48px;position:relative}.has-parallax-feed .kg-width-full .gh-card-wrapper{padding:64px 48px}.has-parallax-feed :is(.gh-card-title,.gh-card-meta){color:#fff}.has-parallax-feed .gh-card-title{font-size:clamp(3.2rem,2.4rem + 2.5vw,6.4rem);line-height:1.1}.has-parallax-feed .gh-card:not(.no-image) .gh-card-link:hover .gh-card-title{opacity:1}.has-parallax-feed .kg-width-full .gh-card-title{font-size:6.4rem}.has-parallax-feed .gh-card-meta{margin-top:12px}.gh-article-meta{bottom:0;grid-row-start:1;margin:0!important;top:0;width:100%;z-index:10}.gh-article-meta-inner{display:flex;flex-direction:column;position:sticky;top:48px}.gh-article-meta .gh-author-image{height:72px;margin-bottom:16px;width:72px}.gh-article-meta .gh-author-name{font-size:1.9rem;letter-spacing:-.01em}.gh-article-meta .gh-author-name a{color:var(--color-darker-gray);text-decoration:none}.gh-article-date{color:var(--color-secondary-text);font-size:1.4rem;font-weight:480;margin-top:4px}.gh-article-tag{border:2px solid var(--color-border);border-radius:24px;color:var(--tag-color,var(--color-darker-gray))!important;font-size:1.5rem;font-weight:700;letter-spacing:-.01em;margin-top:20px;padding:2px 12px;text-decoration:none!important;width:-moz-fit-content;width:fit-content}.gh-content .gh-article-header{grid-column:4/span 9;grid-row-start:1;margin-bottom:clamp(4.8rem,1.43vw + 4.11rem,6.4rem);margin-top:0}.gh-article-title{font-size:clamp(4rem,2.86vw + 2.63rem,7.2rem);font-weight:800;grid-column:1/span 9;letter-spacing:-.03em;line-height:1}.page-template .no-image .gh-article-title{grid-column:4/span 6}.has-serif-font .gh-article-title{font-family:var(--font-serif)}.has-mono-font .gh-article-title{font-family:var(--font-mono)}.gh-article-excerpt{font-size:clamp(1.8rem,.54vw + 1.54rem,2.4rem);font-weight:500;grid-column:1/span 9;line-height:1.45;max-width:840px}.page-template .no-image .gh-article-excerpt{grid-column:4/span 6}.has-serif-font .gh-article-excerpt{font-family:var(--font-serif)}.has-mono-font .gh-article-excerpt{font-family:var(--font-mono)}.gh-article-excerpt .emoji{color:initial}.gh-article-image{grid-column:1/span 12}.gh-article-image,.gh-content{margin-top:clamp(4rem,3rem + 3.125vw,8rem)}.gh-content{--content-spacing-multiplier:1.5;line-height:1.7;position:relative}:is(.post-template,.page-template) .no-image .gh-content{margin-top:clamp(4rem,2.14vw + 2.97rem,6.4rem)}.gh-content>[id]{font-weight:800}.gh-content>:is(p,ul,ol){font-weight:480}.has-serif-font .gh-content>:is([id],p,ul,ol){font-family:var(--font-serif)}.has-mono-font .gh-content>:is([id],p,ul,ol){font-family:var(--font-mono)}.gh-article-footer{margin-top:clamp(6.4rem,3rem + 10.625vw,20rem)}@media (min-width:992px){.gh-article-meta{grid-column:1/span 3;position:absolute}}@media (max-width:991px){.gh-content>.gh-article-header,:is(.gh-article-title,.gh-article-excerpt){grid-column:1/span 10}.gh-article-meta{margin-bottom:32px!important}.no-image .gh-article-meta{grid-row-start:2}.gh-article-meta-inner{align-items:center;flex-direction:row}.gh-article-meta .gh-author-image{height:64px;margin-bottom:0;margin-right:12px;width:64px}.gh-article-meta-wrapper{flex-grow:1}.gh-article-tag{margin-top:0}}@media (max-width:767px){.gh-content>.gh-article-header,:is(.gh-article-title,.gh-article-excerpt){grid-column:1/span 12}.gh-content{font-size:var(--content-font-size)}}.gh-cta{background-color:var(--color-lighter-gray);grid-column:1/span 12!important;margin-top:clamp(8rem,7.14vw + 4.57rem,16rem);padding:clamp(8rem,10.71vw + 2.86rem,20rem) clamp(4.8rem,4.64vw + 2.57rem,10rem);position:relative;transform:translateZ(0);z-index:20}.gh-cta-title{font-size:clamp(3rem,.71vw + 2.66rem,3.8rem);font-weight:800;letter-spacing:-.03em;margin-bottom:24px}.has-serif-font .gh-cta-title{font-family:var(--font-serif)}.has-mono-font .gh-cta-title{font-family:var(--font-mono)}.gh-cta .gh-btn{font-size:1.8rem;height:48px;letter-spacing:-.005em;padding-left:24px;padding-right:24px}.gh-navigation{font-size:clamp(2rem,1.7rem + .9375vw,3.2rem);font-weight:800;grid-column:1/span 12;letter-spacing:-.02em}.has-serif-font .gh-navigation{font-family:var(--font-serif)}.has-mono-font .gh-navigation{font-family:var(--font-mono)}.gh-comments{margin-top:clamp(4.8rem,4.64vw + 2.57rem,10rem)}.gh-comments .gh-comments-title{font-weight:800;margin-bottom:48px}.has-serif-font .gh-comments-title{font-family:var(--font-serif)}.has-mono-font .gh-comments-title{font-family:var(--font-mono)}.gh-subscribe-input{align-items:center;background-color:var(--color-border);border-radius:72px;color:var(--color-secondary-text);cursor:pointer;display:flex;font-size:1.7rem;height:52px;justify-content:space-between;margin-top:40px;max-width:480px;padding:0 8px 0 24px;width:100%}.gh-subscribe-input .gh-btn{font-weight:700}:is(.tag-template,.author-template) .gh-article{margin-bottom:80px}.gh-author-image{border-radius:50%;height:96px;margin-bottom:24px;overflow:hidden;width:96px}.gh-author-image img{height:100%;-o-object-fit:cover;object-fit:cover;width:100%}.gh-author-meta{color:var(--color-secondary-text);font-size:1.8rem;margin-top:16px}.gh-author-location{margin-bottom:6px}.gh-author-social{align-items:center;display:flex;gap:12px}.gh-author-social-link{line-height:0}.gh-foot{padding-bottom:clamp(8rem,4.55vw + 6.18rem,12rem);padding-top:clamp(8rem,4.55vw + 6.18rem,12rem)}.gh-foot-inner{align-items:center;display:flex;flex-direction:column;gap:24px}.gh-foot-menu{font-size:1.6rem;font-weight:700}.gh-copyright{font-size:1.4rem}
/*# sourceMappingURL=screen.css.map */

/* ============================================================
   QuantArmy — Bridgewater Dark Institutional Theme
   ============================================================ */

/* 1. Design Tokens */
:root {
    --bw-bg: #0b0d11;
    --bw-surface: #12151c;
    --bw-surface-2: #1a1e28;
    --bw-text: #e8e8e8;
    --bw-text-muted: #8a8f9a;
    --bw-text-dim: #5a6070;
    --bw-blue: #4a8ab5;
    --bw-burgundy: #c0453d;
    --bw-border: #1e2230;
    --bw-copyright-bg: #198dc7;

    /* Ghost variable overrides */
    --ghost-accent-color: #4a8ab5;
    --color-darker-gray: var(--bw-text);
    --color-secondary-text: var(--bw-text-muted);
    --color-border: var(--bw-border);
    --color-black: var(--bw-text);
    --color-white: var(--bw-bg);

    /* Font stacks */
    --font-serif: 'Libre Baskerville', Georgia, 'Times New Roman', serif;
    --font-sans: 'Roboto Condensed', 'Roboto', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-body: 'Roboto', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-mono: 'JetBrains Mono', 'Fira Code', 'Consolas', monospace;
}

/* 2. Base Overrides */
html {
    font-size: 62.5%;
}

body {
    background-color: var(--bw-bg);
    color: var(--bw-text);
    font-family: var(--font-body);
    font-weight: 400;
    font-size: 1.6rem;
    line-height: 1.7;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

::selection {
    background: rgba(74, 138, 181, 0.3);
    color: #fff;
}

::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--bw-bg); }
::-webkit-scrollbar-thumb { background: var(--bw-border); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--bw-text-dim); }

a { color: var(--bw-blue); text-decoration: none; transition: color 0.2s; }
a:hover { color: #6aadda; }

.gh-site { min-height: 100vh; display: flex; flex-direction: column; }
.gh-main { flex: 1; }
.gh-inner { max-width: 1200px; }

/* 3. Typography */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-serif);
    font-weight: 700;
    color: var(--bw-text);
    line-height: 1.25;
    letter-spacing: -0.01em;
}

h1 { font-size: 3.6rem; }
h2 { font-size: 2.8rem; }
h3 { font-size: 2.2rem; }
h4 { font-size: 1.8rem; }

/* 4. Header */
.gh-head {
    background: var(--bw-bg);
    border-bottom: 1px solid var(--bw-border);
    position: sticky;
    top: 0;
    z-index: 100;
}

.gh-head-inner {
    padding-top: 1.2rem;
    padding-bottom: 1.2rem;
}

.gh-head-logo {
    font-family: var(--font-serif);
    font-weight: 700;
    font-size: 2rem;
    color: var(--bw-text) !important;
    letter-spacing: 0.02em;
}

.gh-head-logo img {
    max-height: 36px;
}

/* Fix: Force nav items visible (Ghost base hides them until JS loads) */
.gh-head-menu .nav > li { opacity: 1 !important; }

.gh-head-menu .nav a {
    font-family: var(--font-sans);
    font-size: 1.4rem;
    font-weight: 400;
    color: var(--bw-text-muted);
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.gh-head-menu .nav a:hover {
    color: var(--bw-text);
}

.gh-head-members .gh-head-link {
    font-family: var(--font-sans);
    font-size: 1.4rem;
    color: var(--bw-text-muted);
}

.gh-head-members .gh-head-link:hover {
    color: var(--bw-text);
}

.gh-head-members .gh-head-btn {
    font-family: var(--font-sans);
    font-size: 1.3rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    background: transparent;
    color: var(--bw-text);
    border: 1px solid var(--bw-text-muted);
    border-radius: 0;
    padding: 0.6rem 1.6rem;
}

.gh-head-members .gh-head-btn:hover {
    background: var(--bw-text);
    color: var(--bw-bg);
    border-color: var(--bw-text);
}

.gh-head .gh-search svg {
    color: var(--bw-text-muted);
}

.gh-head .gh-burger::before,
.gh-head .gh-burger::after {
    background: var(--bw-text-muted);
}

/* Language switcher */
.qa-lang-switch {
    display: flex;
    align-items: center;
    gap: 0.6rem;
}

.qa-lang-sep {
    color: var(--bw-border);
    font-size: 1.2rem;
}

.qa-lang-flag {
    opacity: 0.5;
    transition: opacity 0.2s;
    display: flex;
    align-items: center;
}

.qa-lang-flag:hover,
.qa-lang-flag--active {
    opacity: 1;
}

/* 5. Hero — Institutional */
.bw-hero {
    position: relative;
    min-height: 50vh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    padding: 0;
}

.bw-hero-canvas {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
}

.bw-hero-content {
    position: relative;
    z-index: 1;
    text-align: center;
    max-width: 860px;
    margin: 0 auto;
    padding-top: 4rem;
    padding-bottom: 4rem;
    animation: hero-fade-in 0.8s ease-out both;
}

.bw-hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.8rem;
    font-family: var(--font-sans);
    font-size: 1.1rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--bw-text-muted);
    border: 1px solid var(--bw-border);
    border-radius: 9999px;
    padding: 0.6rem 1.8rem;
    margin-bottom: 3rem;
}

.bw-hero-badge-dot {
    width: 0.7rem;
    height: 0.7rem;
    border-radius: 50%;
    background: #22c55e;
    animation: badge-pulse 2s ease-in-out infinite;
}

.bw-hero-title {
    font-family: var(--font-serif);
    font-size: 5rem;
    font-weight: 700;
    color: #fff;
    line-height: 1.15;
    margin: 0 0 2rem;
}

.bw-hero-accent {
    color: var(--bw-blue);
}

.bw-hero-subtitle {
    font-family: var(--font-body);
    font-size: 1.8rem;
    color: rgba(255,255,255,0.65);
    line-height: 1.6;
    max-width: 640px;
    margin: 0 auto 3rem;
}

.bw-hero-ctas {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 1.6rem;
    margin-bottom: 0;
}

.bw-hero-cta-primary {
    display: inline-block;
    font-family: var(--font-sans);
    font-size: 1.4rem;
    font-weight: 700;
    color: #fff !important;
    background: var(--bw-orange);
    border: none;
    border-radius: 0.6rem;
    padding: 1.2rem 2.8rem;
    text-decoration: none;
    transition: background 0.2s;
}

.bw-hero-cta-primary:hover {
    background: #e55a0e;
}

.bw-hero-cta-secondary {
    display: inline-block;
    font-family: var(--font-sans);
    font-size: 1.4rem;
    font-weight: 700;
    color: #fff !important;
    background: transparent;
    border: 1px solid rgba(255,255,255,0.4);
    border-radius: 0.6rem;
    padding: 1.2rem 2.8rem;
    text-decoration: none;
    transition: all 0.2s;
}

.bw-hero-cta-secondary:hover {
    background: #fff;
    color: var(--bw-bg) !important;
    border-color: #fff;
}

.bw-hero-metrics {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 0;
}

.bw-hero-metric {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 0 3rem;
    border-left: 1px solid var(--bw-border);
}

.bw-hero-metric:first-child {
    border-left: none;
}

.bw-hero-metric-value {
    font-family: var(--font-sans);
    font-size: 2.4rem;
    font-weight: 700;
    color: #fff;
    line-height: 1.2;
}

.bw-hero-metric-label {
    font-family: var(--font-body);
    font-size: 1.2rem;
    color: var(--bw-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-top: 0.3rem;
}

@keyframes badge-pulse {
    0%, 100% { opacity: 0.4; }
    50% { opacity: 1; }
}

@keyframes hero-fade-in {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

@media (max-width: 991px) {
    .bw-hero-title { font-size: 3.8rem; }
    .bw-hero-metrics { flex-wrap: wrap; gap: 2rem; }
    .bw-hero-metric { border-left: none; padding: 0 2rem; }
}

@media (max-width: 600px) {
    .bw-hero { min-height: 40vh; }
    .bw-hero-title { font-size: 2.8rem; }
    .bw-hero-ctas { flex-direction: column; gap: 1.2rem; }
    .bw-hero-cta-primary, .bw-hero-cta-secondary { width: 100%; text-align: center; }
}

/* 6. Disciplines Strip */
.bw-disciplines {
    border-bottom: 1px solid var(--bw-border);
    padding: 0;
}

.bw-disciplines-inner {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
}

.bw-discipline {
    display: block;
    padding: 2.4rem 2rem;
    color: var(--bw-text) !important;
    text-decoration: none;
    transition: background 0.2s;
    border-right: 1px solid var(--bw-border);
}

.bw-discipline:last-child {
    border-right: none;
}

.bw-discipline:hover {
    background: var(--bw-surface);
}

.bw-discipline-bar {
    width: 32px;
    height: 3px;
    margin-bottom: 1.4rem;
}

.bw-discipline-name {
    font-family: var(--font-serif);
    font-size: 1.6rem;
    font-weight: 700;
    margin: 0 0 0.6rem;
    color: var(--bw-text);
}

.bw-discipline-desc {
    font-family: var(--font-sans);
    font-size: 1.3rem;
    font-weight: 300;
    color: var(--bw-text-muted);
    line-height: 1.5;
    margin: 0;
}

/* 7. Section Title */
.bw-section-title {
    font-family: var(--font-serif);
    font-size: 2.4rem;
    font-weight: 700;
    color: var(--bw-text);
    margin: 0;
    padding: 4rem 0 2.4rem;
    border-bottom: 1px solid var(--bw-border);
    margin-bottom: 3rem;
}

/* 8. Post Feed / Editorial Grid */
.gh-feed {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 3rem;
    padding-bottom: 4rem;
}

.gh-card {
    background: transparent;
    border: none;
    border-radius: 0;
}

.gh-card-link {
    display: flex;
    flex-direction: column;
    color: var(--bw-text) !important;
    text-decoration: none;
    height: 100%;
}

.gh-card-image {
    margin: 0 0 1.4rem;
    overflow: hidden;
    aspect-ratio: 16 / 10;
}

.gh-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}

.gh-card:hover .gh-card-image img {
    transform: scale(1.03);
}

.gh-card-wrapper {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.gh-card-tag {
    font-family: var(--font-sans);
    font-size: 1.15rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--tag-color, var(--bw-blue));
    margin-bottom: 0.6rem;
}

.gh-card-title {
    font-family: var(--font-serif);
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.3;
    margin: 0 0 0.6rem;
    color: var(--bw-text);
}

.gh-card:hover .gh-card-title {
    color: var(--bw-blue);
}

.gh-card-excerpt {
    font-family: var(--font-body);
    font-size: 1.4rem;
    color: var(--bw-text-muted);
    line-height: 1.6;
    margin: 0 0 1rem;
    flex: 1;
}

.gh-card-meta {
    display: flex;
    align-items: center;
    gap: 1.2rem;
    font-family: var(--font-sans);
    font-size: 1.2rem;
    color: var(--bw-text-dim);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.gh-card-access {
    font-size: 1.1rem;
    color: var(--bw-blue);
    font-weight: 700;
}

/* 9. Header Market Ticker — Marquee */
.bw-header-ticker {
    background: var(--bw-surface);
    border-bottom: 1px solid var(--bw-border);
    overflow: hidden;
    white-space: nowrap;
}

.bw-ticker-track {
    display: inline-flex;
    animation: ticker-scroll 35s linear infinite;
}

.bw-ticker-content {
    display: inline-flex;
    align-items: center;
    gap: 2rem;
    padding: 0.6rem 0;
}

.bw-ticker-sep {
    display: inline-block;
    width: 1px;
    height: 1.2rem;
    background: var(--bw-border);
    flex-shrink: 0;
}

@keyframes ticker-scroll {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

.bw-header-ticker:hover .bw-ticker-track {
    animation-play-state: paused;
}

.bw-header-ticker .bw-market-item {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    flex-shrink: 0;
}

.bw-header-ticker .bw-market-ticker {
    font-family: var(--font-sans);
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--bw-text-dim);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.bw-header-ticker .bw-market-price {
    font-family: var(--font-sans);
    font-size: 1.2rem;
    font-weight: 400;
    color: var(--bw-text);
}

.bw-header-ticker .bw-market-change {
    font-family: var(--font-sans);
    font-size: 1.1rem;
}

.bw-market-up { color: #22c55e; }
.bw-market-down { color: #ef4444; }

/* ============================================================
   10–18. ARTICLE LAYOUT — Bloomberg Research Paper
   ============================================================ */

/* --- Reset base Solo grid to single-column paper layout --- */
.gh-article .gh-canvas {
    display: block !important;
    max-width: 780px;
    margin: 0;
    padding: 0;
}

.gh-article-header {
    display: block !important;
    grid-column: unset !important;
    position: relative !important;
    padding: 6rem 0 0;
    text-align: left;
    margin: 0 !important;
}

.gh-article-title {
    display: block !important;
    grid-column: unset !important;
    font-family: var(--font-serif);
    font-size: 3.6rem;
    font-weight: 700;
    color: var(--bw-text);
    line-height: 1.2;
    margin: 0 0 1.6rem;
    letter-spacing: -0.02em;
}

/* --- Byline (author · date · reading time) --- */
.gh-article-meta {
    display: flex !important;
    position: relative !important;
    grid-column: unset !important;
    grid-row-start: unset !important;
    align-items: center;
    padding: 0;
    border: none;
    margin: 0 0 2.4rem !important;
    width: 100%;
}

.gh-article-meta-inner {
    display: flex;
    flex-direction: row !important;
    align-items: center;
    position: relative !important;
    top: unset !important;
    gap: 0;
    width: 100%;
}

.gh-article-meta-wrapper {
    display: flex;
    align-items: center;
    gap: 0;
}

.gh-author-name {
    margin: 0;
}
.gh-author-name a {
    font-family: var(--font-body);
    font-size: 1.35rem;
    font-weight: 500;
    color: var(--bw-text-muted);
    text-decoration: none;
    letter-spacing: 0.01em;
}

.gh-article-date {
    font-family: var(--font-body);
    font-size: 1.3rem;
    color: var(--bw-text-dim);
    margin-top: 0 !important;
}
.gh-article-date::before {
    content: '\00b7';
    margin: 0 0.5rem;
    color: var(--bw-text-dim);
}

.gh-article-reading-time {
    font-family: var(--font-body);
    font-size: 1.3rem;
    color: var(--bw-text-dim);
}
.gh-article-reading-time::before {
    content: '\00b7';
    margin: 0 0.5rem;
    color: var(--bw-text-dim);
}

/* --- 11. Table of Contents --- */
.qa-toc {
    margin: 0 0 3rem;
    padding: 1.6rem 2rem;
    background: var(--bw-surface);
    border-left: 3px solid var(--bw-blue);
    border-radius: 0 4px 4px 0;
}

.qa-toc-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 0 1rem;
    cursor: pointer;
    user-select: none;
}

.qa-toc-label {
    font-family: var(--font-serif);
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: none;
    color: var(--bw-text);
}

.qa-toc-toggle {
    font-family: var(--font-mono);
    font-size: 0.9rem;
    color: var(--bw-text-dim);
    background: none;
    border: none;
    cursor: pointer;
    transition: color 0.15s;
}
.qa-toc-toggle:hover { color: var(--bw-blue); }
.qa-toc.is-collapsed .qa-toc-toggle { color: var(--bw-text-dim); }
.qa-toc.is-collapsed { padding-bottom: 0; }
.qa-toc.is-collapsed .qa-toc-header { padding-bottom: 0; }

.qa-toc-list {
    list-style: none;
    margin: 0;
    padding: 0;
    columns: 1;
}
.qa-toc.is-collapsed .qa-toc-list { display: none; }

.qa-toc-list li { margin: 0; padding: 0; break-inside: avoid; }

.qa-toc-list li a {
    display: block;
    font-family: var(--font-body);
    font-size: 1.35rem;
    font-weight: 500;
    color: var(--bw-text-muted);
    text-decoration: none;
    border-bottom: none;
    padding: 0.3rem 0;
    transition: color 0.15s;
    text-transform: none;
    letter-spacing: 0;
}
.qa-toc-list li a:hover,
.qa-toc-list li a.is-active { color: var(--bw-blue); }

.qa-toc-list li.qa-toc-h3 a {
    padding-left: 1.2rem;
    font-size: 1.25rem;
    font-weight: 400;
    color: var(--bw-text-dim);
}
.qa-toc-list li.qa-toc-h3 a:hover,
.qa-toc-list li.qa-toc-h3 a.is-active { color: var(--bw-blue); }

/* --- 12. Content Body --- */
.gh-content {
    font-family: var(--font-body);
    font-size: 1.8rem;
    font-weight: 400;
    line-height: 1.85;
    color: var(--bw-text);
    letter-spacing: 0.003em;
    text-align: justify;
    hyphens: auto;
    -webkit-hyphens: auto;
}

/* Drop cap on first paragraph */
.gh-content > p:first-of-type::first-letter {
    float: left;
    font-family: var(--font-serif);
    font-size: 5.4rem;
    font-weight: 700;
    line-height: 0.8;
    margin: 0.1em 0.12em 0 0;
    color: var(--bw-blue);
}

/* --- Headings --- */
.gh-content h2,
.gh-content h3,
.gh-content h4 {
    font-family: 'Roboto Condensed', var(--font-sans);
    color: var(--bw-text);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    margin-top: 4.5rem;
    margin-bottom: 1.4rem;
    padding-bottom: 0.6rem;
    border-bottom: 1px solid var(--bw-border);
    position: relative;
    scroll-margin-top: 2rem;
    text-align: left;
    hyphens: none;
}

.gh-content h2 {
    font-size: 2.2rem;
    border-bottom: 2px solid var(--bw-border);
}
.gh-content h2::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 48px;
    height: 2px;
    background: var(--bw-blue);
}

.gh-content h3 {
    font-size: 1.8rem;
    font-weight: 700;
    border-bottom-color: rgba(30,34,48,0.5);
}

.gh-content h4 {
    font-size: 1.5rem;
    border-bottom: none;
    color: var(--bw-text-muted);
    text-transform: none;
    font-weight: 700;
    margin-top: 3rem;
}

/* --- Paragraphs --- */
.gh-content > p { margin-bottom: 1.8rem; }

/* --- Links --- */
.gh-content a {
    color: var(--bw-blue);
    text-decoration: none;
    border-bottom: 1px solid rgba(74,138,181,0.25);
    transition: border-color 0.2s;
}
.gh-content a:hover { border-bottom-color: var(--bw-blue); }

/* --- Blockquotes --- */
.gh-content blockquote {
    border-left: 3px solid var(--bw-blue);
    background: rgba(74,138,181,0.035);
    padding: 1.8rem 2.4rem;
    margin: 3rem 0;
    font-family: var(--font-serif);
    font-style: italic;
    font-size: 1.65rem;
    line-height: 1.75;
    color: var(--bw-text-muted);
}
.gh-content blockquote p:last-child { margin-bottom: 0; }

/* --- Code blocks --- */
.gh-content pre {
    background: #080a0e;
    border: 1px solid var(--bw-border);
    border-left: 3px solid var(--bw-blue);
    border-radius: 0;
    padding: 0;
    overflow-x: auto;
    margin: 3rem 0;
    position: relative;
    text-align: left;
}

.gh-content pre code {
    display: block;
    background: none;
    padding: 1.6rem 2rem;
    border: none;
    font-size: 1.35rem;
    line-height: 1.8;
    tab-size: 4;
    -moz-tab-size: 4;
    color: #c9d1d9;
}

.gh-content code { font-family: var(--font-mono); font-size: 0.88em; }

.gh-content :not(pre) > code {
    background: var(--bw-surface-2);
    padding: 0.15em 0.45em;
    border-radius: 2px;
    font-size: 0.86em;
    color: #7ec8e3;
    border: 1px solid var(--bw-border);
}

/* Syntax highlighting */
.gh-content pre code .comment,
.gh-content pre code .prolog { color: #545d68; font-style: italic; }
.gh-content pre code .keyword,
.gh-content pre code .tag { color: #ff7b72; }
.gh-content pre code .function { color: #d2a8ff; }
.gh-content pre code .string,
.gh-content pre code .attr-value { color: #a5d6ff; }
.gh-content pre code .number { color: #79c0ff; }
.gh-content pre code .operator { color: #ff7b72; }
.gh-content pre code .class-name { color: #ffa657; }
.gh-content pre code .punctuation { color: #8b949e; }
.gh-content pre code .property { color: #79c0ff; }
.gh-content pre code .builtin { color: #ffa657; }
.gh-content pre code .decorator,
.gh-content pre code .annotation { color: #ffa657; }
.gh-content pre code .constant,
.gh-content pre code .boolean { color: #79c0ff; }

/* --- Images --- */
.gh-content img { border-radius: 0; border: 1px solid var(--bw-border); }
.gh-content .kg-image-card,
.gh-content .kg-gallery-card { margin: 3rem 0; }
.gh-content .kg-image-card img { margin: 0 auto; display: block; }

.gh-content figcaption {
    font-family: var(--font-mono);
    font-size: 1.1rem;
    color: var(--bw-text-dim);
    text-align: center;
    margin-top: 0.8rem;
    padding: 0.5rem 0;
}

/* --- Tables --- */
.gh-content table {
    border-collapse: collapse;
    width: 100%;
    font-family: var(--font-mono);
    font-size: 1.3rem;
    margin: 3rem 0;
    border: 1px solid var(--bw-border);
    background: var(--bw-surface);
    text-align: left;
}

.gh-content thead { position: relative; }
.gh-content thead::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 2px;
    background: var(--bw-blue);
}

.gh-content th {
    background: #0a0d14;
    font-weight: 700;
    text-transform: uppercase;
    font-size: 1rem;
    letter-spacing: 0.06em;
    color: var(--bw-blue);
    padding: 1rem 1.2rem;
    border: 1px solid var(--bw-border);
    border-bottom: none;
}

.gh-content td {
    border: 1px solid var(--bw-border);
    padding: 0.8rem 1.2rem;
    font-size: 1.25rem;
    color: var(--bw-text);
    background: var(--bw-surface);
}

.gh-content tbody tr { transition: background 0.1s; }
.gh-content tbody tr:nth-child(odd) td { background: var(--bw-surface); }
.gh-content tbody tr:nth-child(even) td { background: #0e1118; }
.gh-content tbody tr:hover td { background: rgba(74,138,181,0.07); }

/* --- HR --- */
.gh-content hr {
    border: none;
    height: 1px;
    background: var(--bw-border);
    margin: 4rem 0;
}

/* --- Lists --- */
.gh-content > ul,
.gh-content > ol { padding-left: 2.2rem; margin: 1.8rem 0; }
.gh-content li { margin-bottom: 0.7rem; line-height: 1.75; }
.gh-content li::marker { color: var(--bw-blue); }
.gh-content strong { font-weight: 700; color: var(--bw-text); }

/* --- Ghost kg-cards inside content --- */
.gh-content .kg-callout-card { border-left: 3px solid var(--bw-blue); border-radius: 0; background: var(--bw-surface) !important; }
.gh-content .kg-toggle-card { background: var(--bw-surface); border: 1px solid var(--bw-border); border-radius: 0; }
.gh-content .kg-bookmark-card { border: 1px solid var(--bw-border); border-radius: 0; background: var(--bw-surface); margin: 2.5rem 0; }
.gh-content .kg-file-card-container { background: var(--bw-surface); border: 1px solid var(--bw-border); border-radius: 0; }
.gh-content .kg-gallery-row { gap: 4px; }
.gh-content .kg-gallery-image img { border: 1px solid var(--bw-border); border-radius: 0; }

/* --- Post tags footer --- */
.qa-post-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    padding: 2rem 0;
    border-top: 1px solid var(--bw-border);
    margin-top: 3rem;
}

.qa-post-tag {
    font-family: 'Roboto Condensed', var(--font-sans);
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--bw-text-dim);
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    transition: color 0.15s;
}
.qa-post-tag::before { content: '#'; color: var(--bw-border); margin-right: 0.15em; }
.qa-post-tag:hover { color: var(--bw-blue); }

/* --- Prev/Next Navigation --- */
.gh-navigation {
    display: flex;
    justify-content: space-between;
    padding: 2rem 0;
    margin-top: 0;
    border-top: 1px solid var(--bw-border);
}

.gh-navigation-link {
    font-family: 'Roboto Condensed', var(--font-sans);
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--bw-blue);
    text-transform: uppercase;
    letter-spacing: 0.02em;
    transition: color 0.15s;
}
.gh-navigation-link:hover { color: #6bb3e0; }

/* Comments */
.gh-comments {
    padding-top: 3rem;
    border-top: 1px solid var(--bw-border);
}

.gh-comments-title {
    font-family: var(--font-sans);
    font-size: 1.4rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--bw-text-muted);
}

/* 12. Author Profile */
.author-profile {
    padding: 5rem 0 3rem;
}

.author-card {
    max-width: 680px;
}

.author-card-header {
    display: flex;
    align-items: center;
    gap: 2rem;
    margin-bottom: 1.6rem;
}

.author-avatar img {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    object-fit: cover;
}

.author-name {
    font-family: var(--font-serif);
    font-size: 2.8rem;
    font-weight: 700;
    margin: 0;
    color: var(--bw-text);
}

.author-location {
    font-family: var(--font-sans);
    font-size: 1.4rem;
    color: var(--bw-text-muted);
    margin: 0.4rem 0 0;
}

.author-bio {
    font-family: var(--font-body);
    font-size: 1.6rem;
    color: var(--bw-text-muted);
    line-height: 1.7;
    margin-bottom: 1.6rem;
}

.author-socials {
    display: flex;
    gap: 1.6rem;
    margin-bottom: 1.6rem;
}

.author-social-link {
    font-family: var(--font-sans);
    font-size: 1.3rem;
    color: var(--bw-blue);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.author-stats {
    font-family: var(--font-sans);
    font-size: 1.3rem;
    color: var(--bw-text-dim);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

/* 13. Tag Archive */
.tag-header {
    padding: 5rem 0 3rem;
    border-bottom: 1px solid var(--bw-border);
    margin-bottom: 3rem;
}

.tag-header-name {
    font-family: var(--font-serif);
    font-size: 3.2rem;
    font-weight: 700;
    color: var(--bw-text);
    margin: 0 0 0.8rem;
}

.tag-header-desc {
    font-family: var(--font-body);
    font-size: 1.6rem;
    color: var(--bw-text-muted);
    line-height: 1.6;
    margin: 0 0 0.8rem;
    max-width: 600px;
}

.tag-header-count {
    font-family: var(--font-sans);
    font-size: 1.3rem;
    color: var(--bw-text-dim);
    text-transform: uppercase;
    letter-spacing: 0.03em;
    margin: 0;
}

/* 14. Tags Index */
.tags-index {
    padding: 5rem 0 4rem;
}

.tags-index-title {
    font-family: var(--font-serif);
    font-size: 3.2rem;
    font-weight: 700;
    color: var(--bw-text);
    margin: 0 0 3rem;
    padding-bottom: 2rem;
    border-bottom: 1px solid var(--bw-border);
}

.tags-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
}

.tag-tile {
    display: flex;
    flex-direction: column;
    padding: 2rem;
    color: var(--bw-text) !important;
    text-decoration: none;
    border-bottom: 1px solid var(--bw-border);
    border-right: 1px solid var(--bw-border);
    transition: background 0.2s;
}

.tag-tile:nth-child(3n) {
    border-right: none;
}

.tag-tile:hover {
    background: var(--bw-surface);
}

.tag-tile-name {
    font-family: var(--font-serif);
    font-size: 1.8rem;
    font-weight: 700;
    margin-bottom: 0.4rem;
}

.tag-tile-count {
    font-family: var(--font-sans);
    font-size: 1.2rem;
    color: var(--bw-text-dim);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.tag-tile-desc {
    font-family: var(--font-body);
    font-size: 1.3rem;
    color: var(--bw-text-muted);
    margin-top: 0.4rem;
    line-height: 1.5;
}

/* 15. Contact Page */
.contact-section {
    padding: 6rem 0 8rem;
    display: flex;
    justify-content: center;
    position: relative;
}

.contact-card {
    width: 100%;
    max-width: 600px;
    text-align: center;
    position: relative;
    background: linear-gradient(170deg, rgba(45,127,249,0.03) 0%, transparent 40%);
    border: 1px solid rgba(45,127,249,0.08);
    padding: 4.5rem 4rem 4rem;
}

.contact-card::before,
.contact-card::after {
    content: '';
    position: absolute;
    width: 14px;
    height: 14px;
    border-color: rgba(45,127,249,0.35);
    border-style: solid;
}

.contact-card::before {
    top: -1px;
    left: -1px;
    border-width: 2px 0 0 2px;
}

.contact-card::after {
    bottom: -1px;
    right: -1px;
    border-width: 0 2px 2px 0;
}

.contact-header {
    margin-bottom: 3.5rem;
}

.contact-header-tag {
    font-family: var(--font-mono);
    font-size: 1.1rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--bw-blue);
    margin: 0 0 1.2rem;
    opacity: 0.7;
}

.contact-title {
    font-family: var(--font-serif);
    font-size: 3.4rem;
    font-weight: 700;
    color: var(--bw-text);
    margin: 0 0 1.4rem;
    letter-spacing: -0.01em;
}

.contact-rule {
    width: 50px;
    height: 1px;
    border: none;
    margin: 0 auto 1.6rem;
    background: linear-gradient(90deg, transparent, var(--bw-blue), transparent);
}

.contact-desc {
    font-family: var(--font-body);
    font-size: 1.45rem;
    color: var(--bw-text-dim);
    margin: 0;
    line-height: 1.7;
}

.contact-required { color: var(--bw-burgundy); }
.contact-optional { color: var(--bw-text-dim); font-size: 1.2rem; }

.contact-form {
    text-align: left;
}

.contact-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
    margin-bottom: 0;
}

.contact-field {
    display: flex;
    flex-direction: column;
    margin-bottom: 2.2rem;
    position: relative;
}

.contact-row .contact-field {
    margin-bottom: 2.2rem;
}

.contact-field-label {
    font-family: var(--font-mono);
    font-size: 1.05rem;
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--bw-text-muted);
    margin-bottom: 0.8rem;
    transition: color 0.3s;
}

.contact-field:focus-within .contact-field-label {
    color: var(--bw-blue);
}

.contact-input {
    font-family: var(--font-body);
    font-size: 1.5rem;
    color: var(--bw-text);
    background: rgba(255,255,255,0.015);
    border: 1px solid var(--bw-border);
    border-radius: 0;
    padding: 1rem 1.2rem;
    outline: none;
    transition: border-color 0.3s, box-shadow 0.3s, background 0.3s;
}

.contact-input::placeholder {
    color: var(--bw-text-dim);
    opacity: 0.4;
}

.contact-input:focus {
    border-color: rgba(45,127,249,0.5);
    box-shadow: 0 0 0 1px rgba(45,127,249,0.1), inset 0 0 20px rgba(45,127,249,0.03);
    background: rgba(45,127,249,0.02);
}

.contact-textarea {
    resize: vertical;
    min-height: 140px;
}

.contact-actions {
    display: flex;
    justify-content: center;
    margin-top: 0.5rem;
}

.contact-submit {
    font-family: var(--font-mono);
    font-size: 1.25rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: #fff;
    background: transparent;
    border: 1px solid var(--bw-blue);
    border-radius: 0;
    padding: 1.4rem 4.5rem;
    cursor: pointer;
    transition: all 0.3s;
    position: relative;
    overflow: hidden;
}

.contact-submit::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--bw-blue);
    opacity: 0.15;
    transition: opacity 0.3s;
}

.contact-submit:hover {
    border-color: #4a9aff;
    box-shadow: 0 0 20px rgba(45,127,249,0.2), inset 0 0 20px rgba(45,127,249,0.05);
}

.contact-submit:hover::before {
    opacity: 0.3;
}

.contact-submit:active {
    transform: scale(0.98);
}

.contact-submit:disabled {
    opacity: 0.4;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

.contact-dots::after {
    content: '';
    animation: dots 1.4s steps(4) infinite;
}

@keyframes dots {
    0% { content: ''; }
    25% { content: '.'; }
    50% { content: '..'; }
    75% { content: '...'; }
}

.contact-status {
    margin-top: 3rem;
    padding: 2.4rem;
    font-family: var(--font-body);
    font-size: 1.5rem;
    text-align: center;
}

.contact-status--ok {
    background: rgba(34, 197, 94, 0.04);
    border: 1px solid rgba(34, 197, 94, 0.2);
    color: #22c55e;
}

.contact-status--ok::before {
    content: '';
    display: block;
    width: 32px;
    height: 32px;
    margin: 0 auto 1rem;
    border: 2px solid #22c55e;
    border-radius: 50%;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2322c55e' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/16px no-repeat;
}

.contact-status--err {
    background: rgba(239, 68, 68, 0.04);
    border: 1px solid rgba(239, 68, 68, 0.2);
    color: #ef4444;
}

.contact-status p { margin: 0 0 0.4rem; font-weight: 600; }
.contact-status-sub { font-size: 1.3rem; color: var(--bw-text-muted); font-weight: 400; }

/* 16. CTA / Members */
.gh-cta {
    background: var(--bw-surface);
    border: 1px solid var(--bw-border);
    padding: 3rem;
    margin: 3rem 0;
    text-align: center;
}

.gh-cta-title {
    font-family: var(--font-serif);
    font-size: 2rem;
    color: var(--bw-text);
    margin: 0 0 1.6rem;
}

.gh-cta-actions {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}

.gh-cta-actions .gh-primary-btn {
    font-family: var(--font-sans);
    font-size: 1.4rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    background: var(--bw-blue);
    color: #fff;
    border: none;
    border-radius: 0;
    padding: 1rem 2.4rem;
    cursor: pointer;
    transition: background 0.2s;
}

.gh-cta-actions .gh-primary-btn:hover {
    background: #3a7aa5;
}

.gh-cta-link {
    font-family: var(--font-sans);
    font-size: 1.3rem;
    color: var(--bw-text-muted);
    cursor: pointer;
}

.gh-cta-link:hover {
    color: var(--bw-text);
}

/* 17. Footer */
.gh-foot {
    background: var(--bw-surface);
    border-top: 1px solid var(--bw-border);
    margin-top: auto;
    padding-top: 0;
    padding-bottom: 0;
}

.gh-foot-inner {
    padding-top: 0;
    padding-bottom: 0;
}

.gh-foot-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr;
    gap: 3rem;
    padding: 4rem 0;
}

.gh-foot-logo {
    display: inline-block;
    margin-bottom: 1.2rem;
}

.gh-foot-logo img {
    max-height: 30px;
}

.gh-foot-logo:not(:has(img)) {
    font-family: var(--font-serif);
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--bw-text) !important;
}

.gh-foot-description {
    font-family: var(--font-body);
    font-size: 1.4rem;
    color: var(--bw-text-muted);
    line-height: 1.6;
    margin: 0 0 1.6rem;
    max-width: 320px;
}

.gh-foot-network {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}

.gh-foot-network a {
    font-family: var(--font-sans);
    font-size: 1.3rem;
    color: var(--bw-text-dim);
}

.gh-foot-network a:hover {
    color: var(--bw-blue);
}

.gh-foot-col-title {
    font-family: var(--font-sans);
    font-size: 1.2rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--bw-text-muted);
    margin: 0 0 1.4rem;
}

.gh-foot-discipline-nav {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
}

.gh-foot-discipline-nav a {
    font-family: var(--font-sans);
    font-size: 1.4rem;
    color: var(--bw-text-dim);
}

.gh-foot-discipline-nav a:hover {
    color: var(--bw-text);
}

.gh-foot-menu .nav {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
}

.gh-foot-menu .nav li {
    list-style: none;
    padding: 0;
    margin: 0;
}

.gh-foot-menu .nav a {
    font-family: var(--font-sans);
    font-size: 1.4rem;
    color: var(--bw-text-dim);
}

.gh-foot-menu .nav a:hover {
    color: var(--bw-text);
}

.gh-foot-copyright-bar {
    background: var(--bw-copyright-bg);
    margin: 0 calc(-1 * var(--gap));
    padding: 1rem var(--gap);
}

.gh-copyright {
    font-family: var(--font-sans);
    font-size: 1.2rem;
    color: #fff;
    text-align: center;
}

.gh-copyright a {
    color: #fff;
    text-decoration: underline;
}

/* 18. Ghost Card Overrides (kg-* dark mode) — comprehensive */

/* Bookmark card */
.kg-bookmark-card {
    border: 1px solid var(--bw-border) !important;
    border-radius: 0 !important;
    background: var(--bw-surface) !important;
}
.kg-bookmark-container { color: var(--bw-text); }
.kg-bookmark-title { color: var(--bw-text); }
.kg-bookmark-description { color: var(--bw-text-muted); }
.kg-bookmark-metadata { color: var(--bw-text-dim); }
.kg-bookmark-publisher { color: var(--bw-text-dim); }
.kg-bookmark-thumbnail img { border-radius: 0; }

/* Callout card */
.kg-callout-card {
    border-radius: 0 !important;
    background: var(--bw-surface) !important;
    color: var(--bw-text) !important;
    border: 1px solid var(--bw-border);
}
.kg-callout-text { color: var(--bw-text); }

/* Toggle card */
.kg-toggle-card {
    border-radius: 0;
    background: var(--bw-surface) !important;
    border: 1px solid var(--bw-border);
    color: var(--bw-text);
}
.kg-toggle-heading-text { color: var(--bw-text); }
.kg-toggle-content { color: var(--bw-text-muted); }
.kg-toggle-card path { fill: var(--bw-text-muted); }

/* Product card */
.kg-product-card { border: 1px solid var(--bw-border); border-radius: 0; }
.kg-product-card-container {
    background: var(--bw-surface) !important;
    color: var(--bw-text) !important;
    box-shadow: none !important;
}
.kg-product-card-title { color: var(--bw-text); }
.kg-product-card-description { color: var(--bw-text-muted); }

/* Audio card */
.kg-audio-card {
    background: var(--bw-surface) !important;
    color: var(--bw-text) !important;
    box-shadow: none !important;
    border: 1px solid var(--bw-border);
    border-radius: 0 !important;
}
.kg-audio-title, .kg-audio-time { color: var(--bw-text-muted); }
.kg-audio-thumbnail { border-radius: 0; }

/* Video card */
.kg-video-card { border-radius: 0 !important; }
.kg-video-overlay { background: rgba(0,0,0,0.5); }

/* File card */
.kg-file-card-container {
    background: var(--bw-surface) !important;
    color: var(--bw-text) !important;
    border: 1px solid var(--bw-border) !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}
.kg-file-card-title { color: var(--bw-text); }
.kg-file-card-caption, .kg-file-card-metadata { color: var(--bw-text-dim); }

/* Header card */
.kg-header-card { border-radius: 0 !important; }
.kg-header-card-button {
    border-radius: 0 !important;
}
.kg-style-light {
    background-color: var(--bw-surface) !important;
    color: var(--bw-text) !important;
}

/* Signup card */
.kg-signup-card { border-radius: 0 !important; }
.kg-signup-card-fields {
    background: var(--bw-surface) !important;
    border-color: var(--bw-border) !important;
    border-radius: 0 !important;
}
.kg-signup-card-input {
    background: var(--bw-surface) !important;
    color: var(--bw-text) !important;
    border-radius: 0 !important;
}
.kg-signup-card-input::placeholder { color: var(--bw-text-dim); }
.kg-signup-card-button { border-radius: 0 !important; }

/* NFT card */
.kg-nft-card-container {
    background: var(--bw-surface) !important;
    color: var(--bw-text) !important;
    box-shadow: none !important;
    border: 1px solid var(--bw-border);
    border-radius: 0 !important;
}

/* Button card */
.kg-button-card .kg-btn { border-radius: 0; }

/* Gallery */
.kg-gallery-image img { border-radius: 0; }

/* Generic: any remaining white-background Ghost elements */
.gh-content [class*="kg-"] a { color: var(--bw-blue); }

/* CTA section dark mode */
.gh-cta {
    background: var(--bw-surface);
    border: 1px solid var(--bw-border);
    padding: 2.4rem;
    margin: 3rem 0;
}
.gh-cta-title { color: var(--bw-text); }
.gh-cta-actions .gh-primary-btn {
    background: var(--bw-blue);
    color: var(--bw-bg);
    border-radius: 0;
}
.gh-cta-link { color: var(--bw-text-muted); }

/* Pagination */
.gh-pagination {
    border-top: 1px solid var(--bw-border);
    padding: 3rem 0;
}

.gh-pagination a {
    font-family: var(--font-sans);
    font-size: 1.3rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--bw-blue);
}

/* Code copy button */
.qa-code-copy {
    position: absolute;
    top: 10px;
    right: 10px;
    font-family: var(--font-mono);
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    color: var(--bw-text-dim);
    background: var(--bw-surface-2);
    border: 1px solid var(--bw-border);
    padding: 0.3rem 0.8rem;
    cursor: pointer;
    z-index: 2;
    transition: color 0.15s, border-color 0.15s;
}

.qa-code-copy:hover {
    color: var(--bw-blue);
    border-color: var(--bw-blue);
}

.qa-code-copy.is-copied {
    color: #22c55e;
    border-color: #22c55e;
}

/* Page template */
.page-template .gh-article-header {
    padding-top: 5rem;
}

/* 19. Responsive Breakpoints */
@media (max-width: 991px) {
    .gh-feed {
        grid-template-columns: repeat(2, 1fr);
        gap: 2.4rem;
    }

    .bw-disciplines-inner {
        grid-template-columns: repeat(2, 1fr);
    }

    .bw-discipline {
        border-bottom: 1px solid var(--bw-border);
    }

    .bw-discipline:nth-child(2) {
        border-right: none;
    }

    .gh-foot-grid {
        grid-template-columns: 1fr 1fr;
        gap: 2rem;
    }

    .gh-foot-about {
        grid-column: 1 / -1;
    }

    .tags-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .tag-tile:nth-child(3n) {
        border-right: 1px solid var(--bw-border);
    }

    .tag-tile:nth-child(2n) {
        border-right: none;
    }

    .bw-hero-title { font-size: 3.2rem; }
    .gh-article-title { font-size: 3.2rem; }

}

@media (max-width: 767px) {
    .gh-feed {
        grid-template-columns: 1fr;
        gap: 2rem;
    }

    .bw-disciplines-inner {
        grid-template-columns: 1fr;
    }

    .bw-discipline {
        border-right: none;
    }

    .gh-foot-grid {
        grid-template-columns: 1fr;
    }

    .contact-card {
        padding: 3rem 2rem 2.5rem;
    }

    .contact-row {
        grid-template-columns: 1fr;
        gap: 0;
    }

    .tags-grid {
        grid-template-columns: 1fr;
    }

    .tag-tile {
        border-right: none !important;
    }

    .bw-hero { min-height: 40vh; }
    .bw-hero-link { min-height: 40vh; }
    .bw-hero-title { font-size: 2.6rem; }
    .bw-hero-excerpt { font-size: 1.6rem; }
    .gh-article-title { font-size: 2.8rem; }
    .gh-article-excerpt { font-size: 1.5rem; }

    .gh-content { text-align: left; hyphens: none; font-size: 1.65rem; }
    .gh-content > p:first-of-type::first-letter { font-size: 4.2rem; }
    .gh-content pre code { font-size: 1.2rem; padding: 1.2rem 1rem; }
    .gh-content table { font-size: 1.15rem; display: block; overflow-x: auto; background: var(--bw-surface); }
    .gh-content th, .gh-content td { padding: 0.6rem 0.8rem; white-space: nowrap; }

    .qa-toc { padding: 1.2rem 1.4rem; }
    .qa-toc-list li a { font-size: 1.25rem; }
    .qa-toc-list li.qa-toc-h3 a { padding-left: 1rem; font-size: 1.15rem; }

    .bw-section-title { font-size: 2rem; }
    .author-name { font-size: 2.4rem; }
    .tag-header-name { font-size: 2.6rem; }
    .tags-index-title { font-size: 2.6rem; }
    .contact-title { font-size: 2.6rem; }
}

/* Mobile menu overrides */
@media (max-width: 991px) {
    .gh-head-menu {
        background: var(--bw-bg);
    }

    .gh-head-menu .nav a {
        color: var(--bw-text);
        font-size: 1.6rem;
    }

    .gh-head-menu::before {
        background: var(--bw-bg);
    }
}

/* ═══════════════════════════════════════════════════
   17. About Page
   ═══════════════════════════════════════════════════ */

.about-section {
    padding: 5rem 0 6rem;
    max-width: 900px;
    margin: 0 auto;
}

/* ── Header ── */
.about-header {
    text-align: center;
    margin-bottom: 4rem;
}

.about-header-tag {
    font-family: var(--font-mono);
    font-size: 1.1rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--bw-blue);
    margin: 0 0 1.2rem;
    opacity: 0.7;
}

.about-title {
    font-family: var(--font-serif);
    font-size: 3.4rem;
    font-weight: 700;
    color: var(--bw-text);
    margin: 0 0 1.4rem;
    letter-spacing: -0.01em;
}

.about-rule {
    width: 50px;
    height: 1px;
    border: none;
    margin: 0 auto 1.6rem;
    background: linear-gradient(90deg, transparent, var(--bw-blue), transparent);
}

.about-subtitle {
    font-family: var(--font-body);
    font-size: 1.5rem;
    color: var(--bw-text-muted);
    line-height: 1.7;
    max-width: 620px;
    margin: 0 auto;
}

/* ── Mission Card ── */
.about-mission {
    margin-bottom: 4rem;
}

.about-mission-card {
    background: linear-gradient(170deg, rgba(45,127,249,0.04) 0%, transparent 40%);
    border: 1px solid rgba(45,127,249,0.1);
    padding: 3.5rem 3rem;
    position: relative;
}

.about-mission-card::before,
.about-mission-card::after {
    content: '';
    position: absolute;
    width: 14px;
    height: 14px;
    border-color: rgba(45,127,249,0.35);
    border-style: solid;
}

.about-mission-card::before {
    top: -1px;
    left: -1px;
    border-width: 2px 0 0 2px;
}

.about-mission-card::after {
    bottom: -1px;
    right: -1px;
    border-width: 0 2px 2px 0;
}

.about-mission-label {
    font-family: var(--font-mono);
    font-size: 1.05rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--bw-blue);
    margin: 0 0 1.6rem;
}

.about-mission-text {
    font-family: var(--font-body);
    font-size: 1.55rem;
    color: var(--bw-text-muted);
    line-height: 1.85;
    margin: 0 0 1.2rem;
}

.about-mission-text:last-child {
    margin-bottom: 0;
}

.about-mission-text strong {
    color: var(--bw-text);
    font-weight: 600;
}

/* ── Section Labels ── */
.about-section-label {
    font-family: var(--font-mono);
    font-size: 1.05rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--bw-blue);
    margin: 0 0 1.6rem;
}

.about-disciplines-header {
    margin-bottom: 2rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--bw-border);
}

/* ── Disciplines Grid ── */
.about-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    margin-bottom: 4rem;
    border: 1px solid var(--bw-border);
}

.about-discipline {
    padding: 2.4rem 2.2rem;
    border-bottom: 1px solid var(--bw-border);
    border-right: 1px solid var(--bw-border);
    transition: background 0.25s;
}

.about-discipline:nth-child(2n) {
    border-right: none;
}

.about-discipline:nth-child(n+3) {
    border-bottom: none;
}

.about-discipline:hover {
    background: rgba(45,127,249,0.02);
}

.about-discipline-bar {
    width: 32px;
    height: 3px;
    margin-bottom: 1.4rem;
}

.about-discipline-name {
    font-family: var(--font-serif);
    font-size: 1.7rem;
    font-weight: 700;
    color: var(--bw-text);
    margin: 0 0 0.8rem;
}

.about-discipline-desc {
    font-family: var(--font-body);
    font-size: 1.35rem;
    color: var(--bw-text-muted);
    line-height: 1.7;
    margin: 0 0 1.2rem;
}

.about-discipline-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.about-discipline-list li {
    font-family: var(--font-mono);
    font-size: 1.1rem;
    color: var(--bw-text-dim);
    padding: 0.35rem 0;
    padding-left: 1.2rem;
    position: relative;
}

.about-discipline-list li::before {
    content: '›';
    position: absolute;
    left: 0;
    color: var(--bw-blue);
    font-weight: 700;
}

/* ── Capabilities Strip ── */
.about-capabilities {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    margin-bottom: 4rem;
    border: 1px solid var(--bw-border);
    background: var(--bw-surface);
}

.about-capability {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 2rem 1rem;
    border-right: 1px solid var(--bw-border);
    text-align: center;
}

.about-capability:last-child {
    border-right: none;
}

.about-capability-value {
    font-family: var(--font-serif);
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--bw-text);
    margin-bottom: 0.4rem;
}

.about-capability-label {
    font-family: var(--font-mono);
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--bw-text-dim);
}

/* ── Philosophy Card ── */
.about-philosophy {
    margin-bottom: 4rem;
}

.about-philosophy-card {
    background: var(--bw-surface);
    border: 1px solid var(--bw-border);
    padding: 3rem;
}

.about-philosophy-text {
    font-family: var(--font-body);
    font-size: 1.5rem;
    color: var(--bw-text-muted);
    line-height: 1.85;
    margin: 0 0 2rem;
}

.about-philosophy-text strong {
    color: var(--bw-text);
    font-weight: 600;
}

.about-philosophy-principles {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.about-principle {
    display: flex;
    align-items: baseline;
    gap: 1.2rem;
    padding: 0.9rem 0;
    border-top: 1px solid var(--bw-border);
}

.about-principle:last-child {
    padding-bottom: 0;
}

.about-principle-marker {
    font-family: var(--font-mono);
    font-size: 1.1rem;
    color: var(--bw-blue);
    font-weight: 700;
    flex-shrink: 0;
    min-width: 2rem;
}

.about-principle-text {
    font-family: var(--font-body);
    font-size: 1.4rem;
    color: var(--bw-text);
    line-height: 1.5;
}

/* ── CTA ── */
.about-cta {
    text-align: center;
    padding: 3rem;
    border: 1px solid var(--bw-border);
    background: linear-gradient(170deg, rgba(45,127,249,0.03) 0%, transparent 50%);
}

.about-cta-text {
    font-family: var(--font-serif);
    font-size: 1.8rem;
    color: var(--bw-text);
    margin: 0 0 2rem;
    font-weight: 700;
}

.about-cta-actions {
    display: flex;
    justify-content: center;
    gap: 1.6rem;
    flex-wrap: wrap;
}

.about-cta-btn {
    font-family: var(--font-mono);
    font-size: 1.15rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    padding: 1.2rem 3rem;
    text-decoration: none;
    transition: all 0.3s;
    position: relative;
    overflow: hidden;
}

.about-cta-primary {
    color: #fff;
    background: rgba(255,110,26,0.15);
    border: 1px solid var(--bw-copyright-bg);
}

.about-cta-primary:hover {
    background: rgba(255,110,26,0.25);
    box-shadow: 0 0 20px rgba(255,110,26,0.15);
    color: #fff;
}

.about-cta-secondary {
    color: var(--bw-text);
    background: transparent;
    border: 1px solid var(--bw-border);
}

.about-cta-secondary:hover {
    border-color: var(--bw-blue);
    box-shadow: 0 0 20px rgba(45,127,249,0.15);
    color: #fff;
}

/* ── About Responsive ── */
@media (max-width: 768px) {
    .about-section { padding: 3rem 0 4rem; }
    .about-title { font-size: 2.6rem; }
    .about-grid { grid-template-columns: 1fr; }
    .about-discipline { border-right: none !important; border-bottom: 1px solid var(--bw-border); }
    .about-discipline:last-child { border-bottom: none; }
    .about-capabilities { grid-template-columns: 1fr 1fr; }
    .about-capability:nth-child(2) { border-right: none; }
    .about-capability:nth-child(-n+2) { border-bottom: 1px solid var(--bw-border); }
    .about-mission-card, .about-philosophy-card, .about-cta { padding: 2rem 1.6rem; }
    .about-cta-actions { flex-direction: column; align-items: center; }
}
