@import "https://fonts.googleapis.com/css2?family=Cinzel:wght@500;600;700&family=Cormorant+Garamond:wght@500;600;700&family=Crimson+Pro:wght@400;500;600&family=Inter:wght@400;500;600;700&family=Lexend:wght@400;500;600&family=Lora:wght@400;500;600&family=Merriweather:wght@400;700&family=Montserrat:wght@500;600&family=Oswald:wght@500;600&family=Playfair+Display:wght@600;700&family=Sora:wght@500;600&family=Source+Serif+4:wght@400;500;600&family=Space+Grotesk:wght@400;500;600&family=Spectral:wght@400;500;600&display=swap";@import "https://cdn.jsdelivr.net/npm/tabulator-tables@6.3.1/dist/css/tabulator.min.css";:root{--font-body:"Lexend", sans-serif;--font-heading:"Space Grotesk", sans-serif;--font-ui:"Space Grotesk", sans-serif;--font-entry:"Oswald", sans-serif;--font-title:"Space Grotesk", sans-serif;--font-code:"SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;--radius-sm:8px;--radius-md:12px;--radius-lg:24px;--shadow-sm:0 2px 4px rgba(0,0,0,0.1);--shadow-md:0 8px 30px rgba(0,0,0,0.12);--shadow-lg:0 20px 50px rgba(0,0,0,0.15);--transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1)}body.colorscheme-light{--site-bg:#f8fafc;--site-fg:#0f172a;--ui-text:#1e293b;--ui-muted:#64748b;--ui-accent:#0ea5e9;--ui-accent-hover:#0284c7;--ui-panel-bg:rgba(255, 255, 255, 0.7);--ui-panel-border:rgba(226, 232, 240, 0.8);--card-bg:#ffffff;--card-shadow:0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);--btn-primary-bg:#0f172a;--btn-primary-text:#ffffff}body.colorscheme-dark{--site-bg:#020617;--site-fg:#f1f5f9;--ui-text:#f8fafc;--ui-muted:#94a3b8;--ui-accent:#38bdf8;--ui-accent-hover:#7dd3fc;--ui-panel-bg:rgba(15, 23, 42, 0.6);--ui-panel-border:rgba(30, 41, 59, 0.7);--card-bg:#0f172a;--card-shadow:0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);--btn-primary-bg:#38bdf8;--btn-primary-text:#020617}body.colorscheme-auto{--site-bg:#f8fafc;--site-fg:#0f172a;--ui-text:#1e293b;--ui-muted:#64748b;--ui-accent:#0ea5e9;--ui-accent-hover:#0284c7;--ui-panel-bg:rgba(255, 255, 255, 0.7);--ui-panel-border:rgba(226, 232, 240, 0.8);--card-bg:#ffffff;--card-shadow:var(--shadow-md);--btn-primary-bg:#0f172a;--btn-primary-text:#ffffff}@media(prefers-color-scheme:dark){body.colorscheme-auto{--site-bg:#020617;--site-fg:#f1f5f9;--ui-text:#f8fafc;--ui-muted:#94a3b8;--ui-accent:#38bdf8;--ui-accent-hover:#7dd3fc;--ui-panel-bg:rgba(15, 23, 42, 0.6);--ui-panel-border:rgba(30, 41, 59, 0.7);--card-bg:#0f172a;--card-shadow:var(--shadow-lg);--btn-primary-bg:#38bdf8;--btn-primary-text:#020617}}body{font-family:var(--font-body);background-color:var(--site-bg);color:var(--site-fg);line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--site-fg);letter-spacing:-.02em}.navigation,.float-container,button,input,select,label{font-family:var(--font-ui)}.non-post-list{margin-top:1.4rem;list-style:none;padding-left:0}.non-post-item{display:block;position:relative;margin:1.5rem 0;line-height:1.4;padding-left:2rem}.non-post-list .non-post-item::before{content:"\2022";position:absolute;left:0;top:50%;transform:translateY(-50%);color:var(--books-head-bg);font-size:2.8rem;line-height:1}.non-post-title{font-size:inherit;font-weight:700;font-family:var(--font-entry)}.list ul.non-post-list li .non-post-title{font-size:3.4rem}@media only screen and (max-width:768px){.list ul.non-post-list li .non-post-title{font-size:2.8rem}}.list ul li .title{font-family:var(--font-entry)}.post-author-icons{display:inline-flex;align-items:center;gap:.22rem;margin:0 .45rem;vertical-align:middle;font-size:1em}.post-author-icon,.post-author-fallback{width:1em;height:1em;border-radius:9999px;border:1px solid var(--ui-panel-border);vertical-align:middle}.post-author-fallback{display:inline-flex;align-items:center;justify-content:center;font-size:.62rem;font-weight:700;color:var(--ui-text);background:var(--ui-panel-bg)}.navigation .navigation-title{font-size:2.8rem;font-weight:800;letter-spacing:.02em;font-family:var(--font-title);color:var(--site-fg)!important}.navigation .navigation-title .brand-word{font-weight:900}.navigation .navigation-title .brand-gold{color:var(--ui-accent)}.navigation .navigation-title .brand-velvet{color:#f43f5e}.hero-section{padding:4rem 0;position:relative;overflow:hidden;display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 160px);width:100%;flex:1}.home-single{max-width:900px;width:100%;margin:0 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.hero-theater{display:block;margin-bottom:1rem;text-decoration:none}.hero-theater-stage{position:relative;border-radius:12px;overflow:hidden}.hero-theater-main{display:block;width:100%;height:auto;border-radius:0}.hero-theater-side{position:absolute;top:-2.4%;bottom:auto;width:auto;max-width:30%;height:86%;object-fit:contain;opacity:.94;z-index:2;pointer-events:none;border:0;box-shadow:none;border-radius:0;filter:none;transform:none}.hero-theater-side-left{left:0;object-position:left center;transform-origin:top left;transform:scale(1.1);filter:drop-shadow(18px 0 16px rgba(0,0,0,.85))}.hero-theater-side-right{right:0;object-position:right center;transform-origin:top right;transform:scale(1.1);filter:drop-shadow(-18px 0 16px rgba(0,0,0,.85))}.hero-theater-clickable{transition:transform .15s ease,filter .15s ease}.hero-theater-clickable:hover{transform:translateY(-2px);filter:brightness(1.02)}.hero-theater-clickable:focus-visible{outline:2px solid var(--books-head-bg);outline-offset:4px;border-radius:14px}.home-avatar{margin-top:0;margin-bottom:16px;display:flex;justify-content:center}.home-avatar img{width:168px;height:168px;border-radius:9999px;object-fit:cover;border:4px solid #fff}@media only screen and (max-width:768px){.hero-theater-side{display:none}.blog-palette-table{display:table;width:100%;table-layout:auto}.blog-table-shell{width:100%;margin:0;overflow:visible}}.search-label{display:block;margin-top:1rem;margin-bottom:.4rem;font-weight:600;color:var(--ui-text)}.search-input{width:100%;padding:.65rem .8rem;border:1px solid var(--ui-input-border);border-radius:8px;font:inherit;color:var(--ui-text);background:var(--ui-input-bg)}.search-status{margin-top:.8rem;color:var(--ui-muted)}.search-results{list-style:none;padding-left:0;margin-top:1rem}.search-results li{padding:.7rem 0;border-bottom:1px solid var(--ui-panel-border)}.search-result-title{font-weight:600}.search-result-meta{margin:.15rem 0 0;font-size:.9rem;color:var(--ui-muted)}.color-palette-table{width:100%;border-collapse:separate;border-spacing:0;table-layout:fixed;margin-top:1.2rem;border:1px solid var(--ui-panel-border);border-radius:12px;overflow:hidden;background:var(--ui-panel-bg)}.color-palette-table th,.color-palette-table td{border:0;border-bottom:1px solid var(--ui-panel-border);padding:.85rem .9rem;vertical-align:middle;color:var(--ui-text)}.color-palette-table thead th{background:var(--books-head-bg);color:var(--books-head-text);font-family:var(--font-ui);font-weight:700}.color-palette-table tbody tr:nth-child(odd){background:var(--books-row-red)}.color-palette-table tbody tr:nth-child(even){background:var(--books-row-gold)}.color-palette-table tbody tr:last-child td{border-bottom:0}.color-swatch{display:inline-block;width:100%;min-width:120px;height:1.7rem;border-radius:6px;border:1px solid rgba(0,0,0,.25)}.font-palette-table .font-example{font-size:2.9rem;letter-spacing:.01em}.blog-table-shell{width:66.666vw;margin-left:calc(50% - 33.333vw);margin-right:calc(50% - 33.333vw);overflow:visible}@media only screen and (max-width:1400px) and (min-width:769px){.blog-table-shell{width:90vw;margin-left:calc(50% - 45vw);margin-right:calc(50% - 45vw)}}.blog-palette-table{table-layout:fixed;width:100%;font-size:1.4rem}.blog-palette-table thead th{font-size:1.46rem}.blog-palette-table td{font-size:1.4rem}.blog-site-link{display:inline-block;color:inherit;font-weight:700;text-decoration:none}.blog-site-link:hover,.blog-site-link:focus-visible{text-decoration:underline}.blog-favicon{width:1.15rem;height:1.15rem;border-radius:4px;border:1px solid var(--ui-panel-border);background:#fff;object-fit:contain;flex:none}.blog-favicon-large{width:4rem;height:4rem;border-radius:8px}.blog-palette-table th:first-child,.blog-palette-table td:first-child{width:5.2rem;text-align:center}.blog-palette-table td{word-break:break-word;overflow-wrap:anywhere;hyphens:auto;white-space:normal}.font-lexend{font-family:lexend,sans-serif}.font-source-serif-4{font-family:"source serif 4",serif}.font-lora{font-family:lora,serif}.font-inter{font-family:inter,sans-serif}.font-crimson-pro{font-family:crimson pro,serif}.font-spectral{font-family:spectral,serif}.font-cinzel{font-family:cinzel,serif}.font-playfair-display{font-family:playfair display,serif}.font-cormorant-garamond{font-family:cormorant garamond,serif}.font-merriweather{font-family:merriweather,serif}.font-oswald{font-family:oswald,sans-serif}.font-space-grotesk{font-family:space grotesk,sans-serif}.font-sora{font-family:sora,sans-serif}.font-montserrat{font-family:montserrat,sans-serif}.books-controls{margin-top:1rem;padding:1rem;border:1px solid var(--ui-panel-border);background:linear-gradient(180deg,var(--ui-panel-bg) 0%,var(--books-shell-bg) 100%);border-radius:12px}.books-search-label{display:block;margin-bottom:.35rem;font-weight:600;color:var(--ui-text)}.books-search-input{width:100%;padding:.65rem .8rem;border:1px solid var(--ui-input-border);border-radius:8px;font:inherit;color:var(--ui-text);background:var(--ui-input-bg)}.books-meta{margin:.6rem 0 0;color:var(--ui-muted)}.books-pagination{margin-top:.9rem;padding:.75rem 1rem;border:1px solid var(--ui-panel-border);background:var(--ui-panel-bg);border-radius:10px;display:flex;align-items:center;gap:.65rem;flex-wrap:wrap;color:var(--ui-text)}.books-page-btn{border:1px solid var(--ui-btn-border);background:var(--ui-btn-bg);color:var(--ui-btn-text);border-radius:8px;padding:.4rem .7rem;font:inherit;cursor:pointer}.books-page-btn:disabled{opacity:.5;cursor:not-allowed}.books-page-indicator{color:var(--ui-text);min-width:7.5rem}.books-page-size-label{margin-left:auto;color:var(--ui-text)}.books-page-size{border:1px solid var(--ui-input-border);background:var(--ui-input-bg);color:var(--ui-text);border-radius:8px;padding:.35rem .45rem;font:inherit}.books-page-size option{color:#111}body.colorscheme-dark .books-page-size option{color:#f5e7d2;background:#2d2520}.books-table-wrap{margin-top:1rem;overflow-x:auto;border:1px solid var(--books-shell-border);border-radius:12px;box-shadow:0 8px 20px rgba(86,63,24,.12);background:var(--books-shell-bg)}.books-column-filter{width:100%;padding:.35rem .45rem;border:1px solid var(--ui-input-border);border-radius:6px;font:inherit;background:var(--ui-input-bg);color:var(--ui-text)}.books-table tbody tr:nth-child(odd){background:var(--books-row-red)}.books-table tbody tr:nth-child(even){background:var(--books-row-gold)}.books-table tbody tr:hover{background:var(--books-row-hover)}.column-picker{margin-top:.8rem;border:1px solid var(--ui-panel-border);border-radius:10px;background:var(--ui-panel-bg);padding:.5rem .7rem}.column-picker>summary{cursor:pointer;color:var(--ui-text);font-weight:600}.column-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:.45rem .7rem;margin-top:.65rem}.column-picker-item{display:inline-flex;align-items:center;gap:.4rem;color:var(--ui-text);font-size:1.35rem}.tabulator{background:var(--books-shell-bg);border:0;color:var(--ui-text);font-size:1.45rem}.tabulator .tabulator-header{background:var(--books-head-bg);border-bottom:1px solid var(--books-shell-border)}.tabulator .tabulator-header .tabulator-col{background:var(--books-head-bg);color:var(--books-head-text);border-right:1px solid rgba(255,255,255,.18)}.tabulator .tabulator-header .tabulator-col .tabulator-col-content .tabulator-col-title{font-family:var(--font-ui);font-weight:700}.tabulator .tabulator-header .tabulator-col .tabulator-header-filter input{background:var(--ui-input-bg);color:var(--ui-text);border:1px solid var(--ui-input-border);border-radius:6px}.tabulator .tabulator-tableholder .tabulator-table .tabulator-row{border-bottom:1px solid var(--books-shell-border)}.tabulator .tabulator-tableholder .tabulator-table .tabulator-row:nth-child(odd){background:var(--books-row-red)}.tabulator .tabulator-tableholder .tabulator-table .tabulator-row:nth-child(even){background:var(--books-row-gold)}.tabulator .tabulator-tableholder .tabulator-table .tabulator-row:hover{background:var(--books-row-hover)}.tabulator .tabulator-cell{color:var(--ui-text);border-right:1px solid rgba(0,0,0,5%)}.tabulator .tabulator-footer{background:var(--ui-panel-bg);color:var(--ui-text);border-top:1px solid var(--books-shell-border)}.tabulator .tabulator-footer .tabulator-page{background:var(--ui-btn-bg);color:var(--ui-btn-text);border:1px solid var(--ui-btn-border)}.tabulator .tabulator-footer .tabulator-page.active{background:var(--books-head-bg);color:var(--books-head-text)}.float-container{display:flex;flex-direction:column;gap:.6rem;align-items:flex-end}.font-switcher{position:relative}.font-switcher-toggle{width:3rem;height:3rem;border-radius:.2rem;border:1px solid var(--ui-btn-border);background:var(--ui-btn-bg);color:var(--ui-btn-text);cursor:pointer;font:inherit;display:inline-flex;align-items:center;justify-content:center;opacity:.95}.font-switcher-toggle:hover,.font-switcher-toggle:focus{color:var(--ui-text);opacity:1}.font-switcher-panel{position:absolute;right:0;bottom:3.6rem;width:170px;padding:.55rem;border-radius:10px;border:1px solid var(--ui-panel-border);background:var(--ui-panel-bg);color:var(--ui-text);display:grid;gap:.25rem;opacity:.96;box-shadow:0 8px 20px rgba(0,0,0,.18)}.font-switcher-panel[hidden]{display:none!important}.font-switcher-panel label{font-size:1.2rem;line-height:1.3;color:var(--ui-text)}.font-switcher-panel select{width:100%;padding:.2rem .35rem;border:1px solid var(--ui-input-border);border-radius:6px;background:var(--ui-input-bg);color:var(--ui-text);font-size:1.2rem}.float-container .colorscheme-toggle{color:var(--ui-btn-text);background-color:var(--ui-btn-bg);border:1px solid var(--ui-btn-border);opacity:.95}.float-container .colorscheme-toggle:hover,.float-container .colorscheme-toggle:focus{color:var(--ui-text);opacity:1}@media(max-width:700px){.books-page-size-label{margin-left:0}.font-switcher-panel{width:150px}}body.colorscheme-dark,body.colorscheme-dark .content,body.colorscheme-dark article,body.colorscheme-dark p,body.colorscheme-dark li,body.colorscheme-dark span{color:var(--site-fg)}body.colorscheme-dark h1,body.colorscheme-dark h2,body.colorscheme-dark h3,body.colorscheme-dark h4,body.colorscheme-dark h5,body.colorscheme-dark h6,body.colorscheme-dark .title-link,body.colorscheme-dark .navigation-title,body.colorscheme-dark .navigation .navigation-link,body.colorscheme-dark .list .title,body.colorscheme-dark .content .title{color:var(--site-fg)}body.colorscheme-dark a{color:#8dc3ff}body.colorscheme-dark .navigation-title:hover,body.colorscheme-dark .navigation .navigation-link:hover,body.colorscheme-dark .title-link:hover{color:#b7d8ff}@media(prefers-color-scheme:dark){body.colorscheme-auto,body.colorscheme-auto .content,body.colorscheme-auto article,body.colorscheme-auto p,body.colorscheme-auto li,body.colorscheme-auto span{color:var(--site-fg)}body.colorscheme-auto h1,body.colorscheme-auto h2,body.colorscheme-auto h3,body.colorscheme-auto h4,body.colorscheme-auto h5,body.colorscheme-auto h6,body.colorscheme-auto .title-link,body.colorscheme-auto .navigation-title,body.colorscheme-auto .navigation .navigation-link,body.colorscheme-auto .list .title,body.colorscheme-auto .content .title{color:var(--site-fg)}body.colorscheme-auto a{color:#8dc3ff}body.colorscheme-auto .navigation-title:hover,body.colorscheme-auto .navigation .navigation-link:hover,body.colorscheme-auto .title-link:hover{color:#b7d8ff}}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(420px,1fr));gap:4rem;margin-top:3.5rem;width:100%}@media(max-width:768px){.projects-grid{grid-template-columns:1fr}}.project-card{background:var(--card-bg);border:1px solid var(--ui-panel-border);border-radius:var(--radius-md);transition:var(--transition);height:100%;display:flex;flex-direction:column;position:relative;overflow:hidden;box-shadow:var(--card-shadow)}.project-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:var(--ui-accent)}.project-card-inner{padding:2.5rem;display:flex;flex-direction:column;height:100%}.project-card-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.project-title{font-family:var(--font-heading);font-size:4.2rem;font-weight:800;color:var(--site-fg);margin:0!important;line-height:1.1}.project-status-badge{font-family:var(--font-ui);font-size:1.6rem;font-weight:700;padding:.4rem 1.2rem;border-radius:999px;text-transform:uppercase;letter-spacing:.05em}.project-status-badge.active{background:rgba(16,185,129,.1);color:#10b981;border:1px solid rgba(16,185,129,.2)}.project-description{font-size:2.1rem;color:var(--ui-muted);line-height:1.5;margin-bottom:2rem;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.project-tech-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;list-style:none;padding:0}.tech-tag{font-family:var(--font-ui);font-size:1.6rem;font-weight:600;background:var(--ui-panel-bg);color:var(--ui-text);padding:.35rem 1rem;border-radius:6px;border:1px solid var(--ui-panel-border)}.project-meta-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:auto;padding-top:1.5rem;border-top:1px solid var(--ui-panel-border);margin-bottom:1.5rem}.meta-item{display:flex;flex-direction:column;gap:.25rem}.meta-label{font-size:1.5rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ui-muted);font-weight:700}.meta-value{font-size:1.9rem;font-weight:600;color:var(--site-fg)}.project-links-footer{display:flex;gap:.75rem}.btn-project{flex:1;display:inline-flex;justify-content:center;align-items:center;padding:1.2rem 1.5rem;border-radius:var(--radius-sm);font-family:var(--font-ui);font-size:1.8rem;font-weight:700;text-decoration:none;transition:var(--transition);text-align:center}.btn-project:not(.secondary):not(.accent){background:var(--btn-primary-bg);color:var(--btn-primary-text)}.btn-project.secondary{background:0 0;border:1px solid var(--ui-panel-border);color:var(--site-fg)}.btn-project.accent{background:rgba(56,189,248,.1);color:var(--ui-accent);border:1px solid rgba(56,189,248,.2)}.btn-project:hover{filter:brightness(1.1);transform:translateY(-2px)}.hero-section::before{content:'';position:absolute;top:-10%;right:-10%;width:40%;height:40%;background:radial-gradient(circle,var(--ui-accent) 0%,transparent 70%);opacity:.05;filter:blur(60px);z-index:-1}.home-avatar img{width:180px;height:180px;border-radius:30% 70% 70% 30%/30% 30% 70% 70%;border:4px solid var(--ui-accent);padding:6px;transition:var(--transition);animation:morph 8s ease-in-out infinite}@keyframes morph{0%{border-radius:30% 70% 70% 30%/30% 30% 70% 70%}50%{border-radius:70% 30% 30% 70%/70% 70% 30% 30%}100%{border-radius:30% 70% 70% 30%/30% 30% 70% 70%}}.home-body{text-align:center;display:flex;flex-direction:column;align-items:center;width:100%}.home-body h1{font-size:5rem;font-weight:900;margin-bottom:1.5rem;background:linear-gradient(to right,var(--site-fg),var(--ui-accent));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1.1;text-align:center}.home-body p{font-size:1.8rem;max-width:800px;margin:0 auto 2.5rem;color:var(--ui-muted);line-height:1.6;text-align:center}.home-body ul{list-style:none;padding:0;display:flex;flex-wrap:wrap;justify-content:center;gap:1.25rem;margin-top:1rem}.home-body ul li{margin:0}.home-body ul li a{display:inline-block;padding:.8rem 1.5rem;border-radius:var(--radius-sm);background:var(--ui-panel-bg);border:1px solid var(--ui-panel-border);color:var(--site-fg);text-decoration:none;font-family:var(--font-ui);font-weight:700;transition:var(--transition)}.home-body ul li a:hover{background:var(--ui-accent);color:#fff;border-color:var(--ui-accent);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.animate-fade-in{animation:fadeIn .8s ease-out forwards}@keyframes fadeIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-on-scroll{opacity:0;transform:translateY(30px);transition:opacity .6s ease-out,transform .6s ease-out}.animate-on-scroll.visible{opacity:1;transform:translateY(0)}