:root{--accent: #2337ff;--accent-dark: #000d8a;--black: 15, 18, 25;--gray: 96, 115, 159;--gray-light: 229, 233, 240;--gray-dark: 34, 41, 57;--gray-gradient: rgba(var(--gray-light), 50%), #fff;--box-shadow: 0 2px 6px rgba(var(--gray), 25%), 0 8px 24px rgba(var(--gray), 33%), 0 16px 32px rgba(var(--gray), 33%)}@font-face{font-family:Atkinson;src:url(/fonts/atkinson-regular.woff) format("woff");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Atkinson;src:url(/fonts/atkinson-bold.woff) format("woff");font-weight:700;font-style:normal;font-display:swap}body{font-family:Atkinson,sans-serif;margin:0;padding:0;text-align:left;background:linear-gradient(var(--gray-gradient)) no-repeat;background-size:100% 600px;word-wrap:break-word;overflow-wrap:break-word;color:rgb(var(--gray-dark));font-size:20px;line-height:1.7}main{width:720px;max-width:calc(100% - 2em);margin:auto;padding:3em 1em}h1,h2,h3,h4,h5,h6{margin:0 0 .5rem;color:rgb(var(--black));line-height:1.2}h1{font-size:3.052em}h2{font-size:2.441em}h3{font-size:1.953em}h4{font-size:1.563em}h5{font-size:1.25em}strong,b{font-weight:700}a,a:hover{color:var(--accent)}p{margin-bottom:1em}.prose p{margin-bottom:2em}textarea{width:100%;font-size:16px}input{font-size:16px}table{width:100%}img{max-width:100%;height:auto;border-radius:8px}code{padding:2px 5px;background-color:rgb(var(--gray-light));border-radius:2px}pre{padding:1.5em;border-radius:8px}pre>code{all:unset}blockquote{border-left:4px solid var(--accent);padding:0 0 0 20px;margin:0;font-size:1.333em}hr{border:none;border-top:1px solid rgb(var(--gray-light))}@media(max-width:720px){body{font-size:18px}main{padding:1em}}.sr-only{border:0;padding:0;margin:0;position:absolute!important;height:1px;width:1px;overflow:hidden;clip:rect(1px 1px 1px 1px);clip:rect(1px,1px,1px,1px);clip-path:inset(50%);white-space:nowrap}a[data-astro-cid-eimmu3lg]{display:inline-block;text-decoration:none}a[data-astro-cid-eimmu3lg].active{font-weight:bolder;text-decoration:underline}html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,main,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;font-size:100%;font:inherit;vertical-align:baseline}article,aside,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section{display:block}body{line-height:1}ol,ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:"";content:none}table{border-collapse:collapse;border-spacing:0}body{background:#f5f5f5}body main{margin:66px auto;width:100%}section{width:100%;padding:2rem 0}.prose.container{max-width:980px;margin:0 auto}.container{padding:2rem 1rem}.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem}select{padding:.5rem;border-radius:.25rem;border:none}@media(width<=980px){.grid{grid-template-columns:repeat(6,1fr)}}@media(max-width:768px){.grid{grid-template-columns:repeat(4,1fr)}}body{font-family:Inter,sans-serif;font-size:16px;line-height:1.6;color:#2b2b2b}h1,h2,h3,h4{font-weight:700;margin-bottom:.5rem}h1{font-size:clamp(2rem,5vw,2.5rem)}h2{font-size:clamp(1.5rem,4vw,2rem)}h3{font-size:clamp(1.25rem,3vw,1.75rem)}h4{font-size:clamp(1rem,2vw,1.5rem)}a{color:#2b2b2b;text-decoration:none}p{font-size:clamp(.875rem,2vw,1rem);margin-bottom:.5rem}strong{font-weight:700}accent{font-size:clamp(1.5rem,2vw,1.75rem);color:#ff7e5f;font-style:italic}.site-header{position:fixed;z-index:1;background:#f5f5f5;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:1rem}.site-header nav{display:flex;gap:1rem}.site-header nav a{padding:.25rem 1rem}.app-footer{position:fixed;z-index:1;background:#f5f5f5;bottom:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:1rem}.app-footer .chat{display:flex;align-items:center;color:#2b2b2b;text-decoration:none;transition:color .3s ease}.app-footer .chat:hover{color:#ff7e5f;transition:color .3s ease}.app-footer .chat .size-5{margin-left:.5rem}.app-footer .nav-links{display:flex;gap:1rem}.btn{display:inline-block;padding:.25rem 0rem;font-size:1rem;color:#2b2b2b;border:none;border-radius:200px;cursor:pointer;text-decoration:none;transition:color .3s ease}.btn:hover{color:#ff7e5f;transition:color .3s ease}.blog-card-tags{list-style:none;padding:0;margin:.5rem 0 0;display:flex;gap:.5rem}.blog-card-tags .blog-tag{background:#e9ecef;color:#495057;font-size:.75rem;padding:.25rem .5rem;border-radius:200px;font-weight:500}.blog-tag{background:#e9ecef;color:#495057;font-size:.75rem;padding:.25rem .5rem;border-radius:200px;font-weight:500;cursor:default}.blog-grid .section-header{margin-bottom:2rem}.blog-grid .section-header p{max-width:600px}.blog-grid .blog-cards .blog-card{grid-column:span 4}.blog-grid .blog-cards .blog-card a{display:block;position:relative;border-radius:.25rem;overflow:hidden}.blog-grid .blog-cards .blog-card a .blog-card-rollover{position:absolute;top:0;left:0;z-index:0;width:100%;height:5px;overflow:hidden;border-radius:.25rem;background:linear-gradient(to bottom right,#ff7e5f,#feb47b);transition:height .5s ease-in-out}.blog-grid .blog-cards .blog-card a .blog-card-content{position:relative;z-index:1;padding:1.5rem}.blog-grid .blog-cards .blog-card a .blog-card-content h4{margin-bottom:.5rem}.blog-grid .blog-cards .blog-card a .blog-card-content .blog-card-date{color:#666;font-size:.875rem;font-style:italic;transition:color 0s ease-in-out}.blog-grid .blog-cards .blog-card a:hover .blog-card-rollover{height:100%;transition:height .5s ease-in-out}.blog-grid .blog-cards .blog-card a:hover .blog-card-content h4,.blog-grid .blog-cards .blog-card a:hover .blog-card-date{color:#f5f5f5;transition:color .5s ease-in-out}@media(width<=980px){.blog-grid .blog-cards .blog-card{grid-column:span 6}}@media(width<=768px){.blog-grid .blog-cards .blog-card{grid-column:1/-1}}.card .card-image{width:100%;display:block;height:70vh;border-radius:.25rem;overflow:hidden}.card .card-image.sm{height:550px}.card .card-image.sm img{mix-blend-mode:luminosity}.card .card-image img{width:100%;height:100%;object-fit:cover;transform:scale(1);transition:transform .5s ease-in-out}.card .card-image:hover img{transform:scale(1.025);transition:transform .5s ease-in-out}.card:hover .card-content{color:#ff7e5f;transition:color .5s ease-in-out}.project-card{background:#fff;border-radius:.5rem;overflow:hidden;transition:transform .5s ease-in-out,box-shadow .3s ease;height:100%;display:flex;flex-direction:column;grid-column:span 4}.project-card:hover .project-image img{transform:scale(1.05);transition:transform .5s ease-in-out}.project-card:hover .project-overlay{opacity:75}.project-card .project-image{position:relative;height:auto;aspect-ratio:16/9;overflow:hidden}.project-card .project-image img{width:100%;height:100%;object-fit:cover}.project-card .project-overlay{position:absolute;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.project-card .project-links{display:flex;gap:1rem}.project-card .btn{padding:.5rem 1rem;border-radius:200px;text-decoration:none;font-weight:500;transition:transform .2s ease}.project-card .btn:hover{transform:scale(1.05)}.project-card .btn.btn-primary{background:#ff7e5f;color:#fff}.project-card .btn.btn-secondary{background:#6c757d;color:#fff}.project-card .project-content{padding:1.5rem;flex:1;display:flex;flex-direction:column}.project-card .project-content .project-header{display:flex;align-items:start;justify-content:space-between;margin-bottom:.75rem}.project-card .project-content .project-header .project-title{margin:0}.project-card .project-content .project-header .featured-badge{background:#ff7e5f;color:#fff;font-size:.75rem;padding:.25rem .5rem;border-radius:200px;font-weight:500;cursor:default}.project-card .project-content .project-description{margin-bottom:1rem;flex:1}.project-card .project-content .project-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;font-size:.875rem}.project-card .project-content .project-meta .project-category{background:#f8f9fa;color:#495057;padding:.25rem .5rem;border-radius:200px;font-weight:500}.project-card .project-content .project-meta .project-date{color:#6c757d}.project-card .project-content .project-technologies{display:flex;flex-wrap:wrap;gap:.5rem}.project-card .project-content .project-technologies .tech-tag{background:#e9ecef;color:#495057;font-size:.75rem;padding:.25rem .5rem;border-radius:200px;font-weight:500;cursor:default}@media(max-width:768px){.project-card .project-content{padding:1rem}.project-card .project-content .project-header,.project-card .project-content .project-meta{flex-direction:column;align-items:flex-start;gap:.5rem}}.hero{height:70vh}.hero .card{grid-column:span 6}.hero .statement{grid-column:8/11;align-self:end}@media(width<=980px){.hero .card{grid-column:1/-1;grid-row:1/2}.hero .statement{grid-column:1/-1;grid-row:2}}@media(width<=600px){.hero .card{grid-column:1/-1;grid-row:1/2}.hero .statement{grid-column:1/-1;grid-row:2}}.card-grid .card{grid-column:span 4}@media(width<=980px){.card-grid .card{grid-column:span 6}}@media(width<=768px){.card-grid .card{grid-column:span 4}}.pagination{display:flex;list-style:none;padding:0;margin:2rem 0 1rem;justify-content:center;gap:.5rem;align-items:center}.pagination button{padding:.5rem 1rem;border:none;background:#f5f5f5;cursor:pointer;border-radius:200px;transition:all .5s ease-in-out}.pagination button.active{background:#ff7e5f;color:#f5f5f5;font-weight:700}.pagination button:hover:not(.active){background:#ff552c;color:#f5f5f5;transition:all .5s ease-in-out}.pagination button:disabled{opacity:.5;cursor:not-allowed}.project-list{background:#f8f9fa}.project-list .section-header{margin-bottom:3rem}.project-list .section-header p{max-width:600px}.project-list .filter{margin-bottom:2rem;display:flex;align-items:center;gap:1rem}.project-list .filter select{box-shadow:0 2px 8px #00000014}.project-list .projects-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem;margin-bottom:3rem}.project-list .section-footer{text-align:center}.project-list .view-all-btn{display:inline-flex;align-items:center;padding:1rem 2rem;background:#007bff;color:#fff;text-decoration:none;border-radius:8px;font-weight:600;transition:background .3s ease,transform .2s ease}.project-list .view-all-btn:hover{background:#0056b3;transform:translateY(-2px)}@media(max-width:768px){.project-list{padding:2rem 0}.project-list .projects-grid{grid-template-columns:1fr;gap:1.5rem}.project-list .view-all-btn{padding:.75rem 1.5rem}}.tag-filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.tag-filters .tag-filter{padding:.4rem .85rem;border:1px solid var(--color-text, currentColor);border-radius:999px;background:transparent;color:inherit;font-size:.85rem;cursor:pointer;transition:background .5s,color .5s}.tag-filters .tag-filter.is-active{background:linear-gradient(to bottom right,#ff7e5f,#feb47b);color:#f5f5f5}.tag-filters .tag-filter:hover{opacity:.8;background:linear-gradient(to bottom right,#ff7e5f,#feb47b);color:#f5f5f5}.about-section .about-content{grid-column:2/7}.about-section .generative-art{grid-column:8/12;display:flex;flex-direction:column;gap:1rem}.about-section .generative-art .generative-canvas{width:100%;height:600px;display:block;border-radius:12px}@media(width<=980px){.about-section .about-content{grid-column:1/13}.about-section .generative-art{grid-column:1/13;margin-top:2rem}.about-section .generative-art .generative-canvas{height:400px}}article{display:flex;flex-direction:column}article .post-header .container{max-width:980px;margin:0 auto;border-top:1px solid}article .post-header .container .breadcrumb{grid-column:1/-1}article .post-header .container .blog-header-image{grid-column:1/-1;height:50dvh;filter:grayscale(100%)}article .post-header .container .blog-header-image img{width:100%;height:100%;border-radius:.5rem;object-fit:cover}article .post-header .container .blog-header-content{grid-column:1/-1;display:flex;justify-content:space-between;align-items:start;flex-wrap:wrap}article .post-header .container .blog-header-content .date{display:flex;gap:1rem;align-items:baseline}article .post-header .container .blog-header-content .header-subtitle{font-style:italic;width:30%;text-align:right}article .post-content .container>div{max-width:800px;margin:0 auto}@media(width<=980px){article{display:block;gap:2rem}article .post-header .container .blog-header-content{flex-direction:column;align-items:flex-start}article .post-header .container .blog-header-content .header-subtitle{width:100%;text-align:left;margin-top:1rem}article .post-content .container>div{max-width:100%}}
