@font-face{font-family:EB Garamond;src:url(/fonts/eb-garamond-regular.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:EB Garamond;src:url(/fonts/eb-garamond-italic.woff2) format("woff2");font-weight:400;font-style:italic;font-display:swap}@font-face{font-family:EB Garamond;src:url(/fonts/eb-garamond-bold.woff2) format("woff2");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:EB Garamond;src:url(/fonts/eb-garamond-bold-italic.woff2) format("woff2");font-weight:700;font-style:italic;font-display:swap}:root{--background: #EEEEE6;--accent: #9F370F;--accent-dark: #577753;--black: #000000;--gray: #7F9F9F;--gray-light: #CFC8B0;--gray-dark: #70705F;--gray-gradient: var(--gray-light);--box-shadow: 0 2px 6px #7F9F9F40, 0 8px 24px #7F9F9F54, 0 16px 32px #7F9F9F54;--font-serif: "EB Garamond", Georgia, "Times New Roman", Times, serif;--font-sans: "Helvetica Neue", "Helvetica", sans-serif;--text-xs: 12px;--text-sm: 14px;--text-base: 16px;--text-md: 18px;--text-lg: 20px;--text-xl: 24px;--text-2xl: 31px;--text-3xl: 39px;--text-4xl: 49px;--main-width: 800px;--accent-gold: #D6B564;--accent-muted: #B0B08F;--button-bg: #736956;--bg-accent-rss: #BD5814;--accent-info: #7F9F9F;--accent-info-dark: #536666;--category-blog: #913D1D;--category-photos: #697585;--category-projects: #5E7656;--category-uncategorized: #70705F;--foreground-secondary: #555554}*,*:before,*:after{box-sizing:border-box}body{font-family:var(--font-serif);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0;text-align:left;background:#000;word-wrap:break-word;overflow-wrap:break-word;color:var(--black);font-size:var(--text-base);line-height:1.5}main{width:var(--main-width);max-width:calc(100% - 2em);margin:0 auto;padding:0 .5rem;flex-grow:1;display:flex;flex-direction:column}.content-wrapper{background:var(--background);min-height:calc(100vh - 102px);display:flex;flex-direction:column;overflow:hidden}h1,h2,h3,h4,h5,h6{margin:0 0 .5rem;color:var(--black);line-height:1.2;font-weight:700}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}strong,b{font-weight:700}a,a:hover{color:var(--accent)}a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px}a:focus:not(:focus-visible),button:focus:not(:focus-visible),input:focus:not(:focus-visible),textarea:focus:not(:focus-visible),select:focus:not(:focus-visible){outline:none}p{margin-bottom:1em}textarea{width:100%;font-size:var(--text-base)}input{font-size:var(--text-base)}table{width:100%}img{max-width:100%;height:auto}code{padding:2px 5px;background-color:var(--gray-light)}ol>li::marker{font-weight:700;color:var(--foreground-secondary)}pre{padding:1.5em}pre>code{all:unset}blockquote{border-left:4px solid var(--accent);padding:0 0 0 20px;margin:0;font-size:var(--text-lg)}hr{border:none;border-top:2px solid var(--gray-dark);margin:2rem 0}.prose-container{width:var(--main-width);max-width:calc(100% - 2em);margin:auto}.sr-only{border:0;padding:0;margin:0;position:absolute!important;height:1px;width:1px;overflow:hidden;clip-path:inset(50%);white-space:nowrap}.skip-link{position:absolute;top:-60px;left:6px;background:var(--black);color:#fff;padding:8px;text-decoration:none;border-radius:4px;z-index:1000;transition:top .3s}.skip-link:focus{top:6px}header{margin:0;z-index:1;position:relative}.title-bar{background:var(--black);color:#fff;padding:.5em 1em 0;margin:0;text-align:center;font-family:var(--font-sans);font-size:var(--text-md);line-height:1}.title-bar h1{margin:0;color:#fff;text-transform:uppercase;letter-spacing:.5em;display:inline-block;font-family:var(--font-sans);font-weight:200;font-size:var(--text-base)}.title-bar a{color:#fff;text-decoration:none}.title-nav-wrapper{background:var(--black);width:100%}.title-nav{width:var(--main-width);max-width:calc(100% - 2em);margin:auto;padding:0 .5em .5em;display:flex;justify-content:space-between;align-items:center}.sub-nav-wrapper{width:100%;background:var(--accent)}.sub-nav-wrapper.category-projects{background:var(--category-projects)}.sub-nav-wrapper.category-blog{background:var(--category-blog)}.sub-nav-wrapper.category-uncategorized{background:var(--category-uncategorized)}.sub-nav-wrapper.category-photos{background:var(--category-photos)}.sub-nav{width:var(--main-width);max-width:calc(100% - 2em);margin:auto;color:#fff;display:flex;align-items:center;padding:.5em;justify-content:space-between;font-weight:700}.title-nav a,.sub-nav a,nav a{color:#fff;text-decoration:none;display:flex;align-items:center;gap:.5em;font-weight:700}.sub-nav .date{font-weight:400}.title-nav a.active,nav a.active{text-decoration:none;border-bottom-color:#fff}.nav-icon{flex-shrink:0}.nav-icon path{fill:var(--accent-gold);transition:fill .2s ease}.title-nav a:hover .nav-icon path{fill:#ffffffe6}.title-nav a.active .nav-icon path{fill:#fff}.header-link a{display:inline-block;text-decoration:none;font-weight:400}.header-link a.active{text-decoration:underline}footer{padding:1em;text-align:center;font-family:var(--font-sans);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:1px;color:var(--button-bg)}.prose{font-size:var(--text-md)}.prose h1{font-family:var(--font-sans)}.prose .title{padding-top:3rem}.prose .subtitle{font-style:italic;color:var(--foreground-secondary)}.prose main{padding:8px}.prose h2,.prose h3{margin-top:1em}.prose hr{border:none;border-top:1px dashed var(--accent-muted)}code,tt{font-size:var(--text-xs);padding:3px 6px;background:#e1e1e1;border-radius:3px;margin:3px}del{color:var(--foreground-secondary)}.has-bg{position:relative;padding:0 0 0 16rem;flex-grow:1}main[data-category=home],main[data-category=uncategorized]{--bg-image: url(/bg/main_bg.svg)}main[data-category=about]{--bg-image: url(/bg/about_bg.svg)}main[data-category=subscribe]{--bg-image: url(/bg/about-rss_bg.svg)}main[data-category=blog]{--bg-image: url(/bg/blog_bg.svg)}main[data-category=photos]{--bg-image: url(/bg/photos_bg.svg)}main[data-category=projects]{--bg-image: url(/bg/projects_bg.svg)}main[data-category=error]{--bg-image: url(/bg/error_bg.svg)}.has-bg:before{content:"";position:absolute;top:-2rem;left:-9rem;bottom:-10rem;width:25rem;background-image:var(--custom-bg-image, var(--bg-image, url(/bg/main_bg.svg)));background-repeat:no-repeat;background-size:25rem auto;pointer-events:none}.post-list-ul{list-style-type:none;margin:0 0 0 24px;padding:0}.post-list-ul li{padding:2rem 0;position:relative;border-bottom:1px dashed var(--gray-light)}.post-list-ul li:last-child{border-bottom:0 none}.post-list-ul li a{text-decoration:none;display:block}.title-line{display:flex;align-items:center;margin-bottom:.5em;position:relative}.title-line svg{position:absolute;left:-24px;top:.5em}.meta{display:flex;align-items:center;gap:.5rem;margin-top:1rem;font-family:var(--font-sans);font-size:var(--text-sm);font-weight:400}.post-list-title{margin:0;color:var(--black);line-height:1.2;font-size:var(--text-xl);font-weight:700}.category-tag{display:inline-block;color:#fff;font-size:var(--text-xs);text-transform:uppercase;margin:0;text-decoration:none;padding:.2em .5em;font-family:var(--font-sans);font-weight:700}.category-tag:hover{color:#fff;text-decoration:none}.category-tag.category-projects{background:var(--category-projects)}.category-tag.category-blog{background:var(--category-blog)}.category-tag.category-uncategorized{background:var(--category-uncategorized)}.category-tag.category-photos{background:var(--category-photos)}.category-tag.category-tech{background:var(--category-tech)}.post-list-subtitle{margin:.2em 0 0;color:var(--foreground-secondary);font-size:var(--text-md);font-style:italic}.post-list-date{margin:0;color:#70705f;font-size:var(--text-sm)}.post-list-ul li a:hover .post-list-title,.post-list-ul li a:hover .post-list-subtitle{color:var(--accent)}.post-list-ul li a:hover .post-list-title{text-decoration:underline}.photo-infobox{font-family:var(--font-sans);font-size:var(--text-sm);color:var(--accent-info-dark);display:flex;justify-content:center;align-items:center;gap:8px;margin-top:2em}.photo-infobox:before{content:"";width:16px;height:16px;background-image:url(/icon_info.svg)}.photo-list{display:flex;flex-direction:column;gap:2rem;margin:1rem 0}.photo-item{margin:0;padding:0}.photo-item img{display:block;width:100%;height:auto;border:3px solid black;border-radius:8px}.photo-item figcaption{margin-top:.5rem;font-size:var(--text-md);text-align:center}.photo-thumbnails{display:grid;grid-template-columns:repeat(5,minmax(0,100px));justify-content:start;background-color:#000;border-radius:12px;border:3px solid black;width:fit-content;margin-top:.75rem}.photo-thumbnails img{height:auto;border-radius:8px;border:3px solid black}.subscribe-btn{background-color:var(--bg-accent-rss);padding:3px 7px;border-radius:0;border:1px solid black;text-decoration:none;font-weight:700;font-family:var(--font-sans);font-size:var(--text-sm);transition:background-color .2s;display:inline-flex;align-items:center;margin-block:-4px;gap:.5em}.subscribe-btn:hover{background-color:var(--accent-muted)}.rss-onboarding-block{margin:2rem 0;display:flex;flex-direction:column;align-items:center;gap:.5rem}.rss-feed-button{display:inline-flex;align-items:center;gap:.75rem;color:var(--bg-accent-rss);padding:.75rem 1.5rem;text-decoration:none;font-weight:700;font-family:var(--font-sans)}@media (max-width: 640px){.title-bar{padding:1rem}.prose .title{padding-top:2rem}.photo-thumbnails{grid-template-columns:repeat(3,minmax(0,100px))}.has-bg{padding:0 .5rem}.has-bg:before{display:none}}body.lightbox-open{overflow:hidden}.lightbox-trigger{cursor:pointer}.lightbox{display:none;position:fixed;z-index:1000;inset:0;background-color:#000;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease;border:none;padding:0;margin:0;width:100%;height:100%;max-width:100%;max-height:100%;overflow:hidden}.lightbox::backdrop{background:transparent}.lightbox.active{display:flex;opacity:1}.lightbox-content{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.main-image-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.main-image-container img{max-width:100%;max-height:100%;object-fit:contain}.lightbox-info{position:absolute;bottom:80px;left:0;right:0;text-align:center;z-index:1010;pointer-events:none;display:flex;justify-content:center}.caption{color:#fff;font-family:var(--font-sans);font-size:var(--text-sm);background-color:#000000b3;padding:8px;margin:0;display:none;width:100%}.caption.has-content{display:inline-block}.thumbnail-bar{position:absolute;bottom:0;left:0;right:0;display:flex;gap:10px;padding:10px;background:#000;width:100%;overflow-x:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.3) transparent;z-index:1010;justify-content:flex-start;scroll-padding:0 10px;scroll-behavior:smooth}.thumbnail-bar,.nav-button,.close-button,.lightbox-info{transition:opacity .3s ease,transform .3s ease}.lightbox.hide-ui .thumbnail-bar,.lightbox.hide-ui .nav-button,.lightbox.hide-ui .close-button,.lightbox.hide-ui .lightbox-info{opacity:0;pointer-events:none}.thumbnail-bar::-webkit-scrollbar{height:6px}.thumbnail-bar::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:3px}.thumb-item{flex:0 0 80px;height:60px;cursor:pointer;border:2px solid transparent;border-radius:4px;overflow:hidden;opacity:1;transition:all .2s;background:none;padding:0;margin:0;appearance:none;-webkit-appearance:none}.thumb-item img{width:100%;height:100%;object-fit:cover}.thumb-item.active{border-color:#fff}.close-button{position:absolute;top:12px;right:12px;background:#000;border:1px solid #666;box-shadow:0 0 0 2px #000;color:#fff;width:60px;height:60px;display:flex;border-radius:4px;align-items:center;justify-content:center;cursor:pointer;z-index:1010;opacity:1;transition:all .2s}.close-button:hover{border-color:#fff}.nav-button{position:absolute;top:50%;transform:translateY(-50%);background:#000;box-shadow:0 0 0 2px #000;border:1px solid #666;border-radius:4px;color:#fff;width:60px;height:60px;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;z-index:1010;opacity:1}.nav-button.prev:before,.nav-button.next:before{content:"";position:absolute;top:-100px;bottom:-100px}.nav-button.prev:before{left:0;right:-4rem}.nav-button.next:before{right:0;left:-4rem}.nav-button:hover{border-color:#fff}.prev{left:12px}.next{right:12px}@media (max-width: 640px){.nav-button.prev,.nav-button.next{opacity:0}}
