body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{text-align:center}body{background:var(--theme-black)}:root{--theme-white:#fff;--theme-cream:#fff9f3;--theme-black:#292929;--theme-grey:#494949;--primary-dark:#6c8238;--primary-light:#b2c781;--primary-lightest:#cedfab;--secondary-light:#eb833b;--secondary-dark:#d4671a;--theme-shadow:#0006}.navbar{background:var(--theme-black);padding:1rem 0}.nav-mobile-view{display:none}.navbar ul{align-items:center;display:flex;justify-content:flex-end;list-style:none;margin:0;padding:0}.navbar li{margin:0 1.5rem}.navbar a{color:var(--theme-cream);font-size:1.1rem;font-weight:500;text-decoration:none;transition:color .2s}.navbar a:hover{color:var(--secondary-light)}.resume-link{background:var(--secondary-light);border-radius:24px;display:inline-block;font-weight:600;padding:.6rem 1.2rem;text-decoration:none;transition:background .2s}.resume-link:hover{background:var(--secondary-dark);color:var(--theme-cream)!important}.download-logo{height:20px;margin-right:8px;vertical-align:middle;width:20px}@media (max-width:800px){.navbar{padding:1.5rem}.nav-standard-view{display:none}.navbar ul{align-items:center;flex-direction:column}.resume-link{text-align:center}.download-logo{display:none}.nav-mobile-view{align-items:center;display:flex;flex-direction:column;justify-content:center}.nav-dropdown-toggle{background:var(--theme-black);border:none;color:var(--theme-cream);cursor:pointer;font-size:1.1rem}.nav-dropdown-list{background:var(--theme-cream);border-radius:16px;box-shadow:0 8px 32px #0000002e;left:50%;min-width:220px;opacity:0;pointer-events:none;position:absolute;top:55px;transform:translateX(-50%) translateY(-10px);transition:opacity .4s cubic-bezier(.4,0,.2,1),transform .4s cubic-bezier(.4,0,.2,1)}.nav-dropdown-list.open{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}.nav-dropdown-list li{text-align:center;width:100%}.nav-dropdown-list a{align-items:center;border-radius:8px;color:var(--theme-black);display:flex;font-size:1.08rem;font-weight:500;justify-content:center;margin:.25rem 2rem;padding:.5em;text-decoration:none;transition:background .2s}.nav-dropdown-list a:active,.nav-dropdown-list a:focus{-webkit-tap-highlight-color:transparent;box-shadow:none;color:var(--secondary-light)}.nav-dropdown-list .resume-link{align-self:center;margin:.25rem 2rem}.nav-dropdown-arrow{display:inline-block;margin-left:8px;transition:transform .4s}.nav-dropdown-arrow.open{transform:rotate(180deg)}}.home-container{background:var(--theme-cream);min-height:100vh;padding-bottom:5rem;padding-top:3rem}.home-container h1{align-self:flex-start;color:var(--theme-black);font-size:2.5rem}.home-container h2,.home-container h3{align-self:flex-start;color:var(--theme-black);font-size:2rem}.home-container h3{margin-bottom:1rem;margin-left:2rem}.home-container p{color:var(--theme-grey);font-size:1.25rem;margin-bottom:1.5rem;width:710px}.profile{justify-content:center}.profile,.profile-header{display:flex}.profile-content-float{overflow:hidden}.profile-photo-float{border-radius:50%;box-shadow:0 4px 16px var(--theme-shadow);float:left;height:245px;margin:1rem 2rem 1rem 1rem;object-fit:cover;width:245px}.profile-description-float{color:var(--theme-black);text-align:left}.fox-animation{height:110px;padding-left:.5rem;width:110px}.history{margin:auto;max-width:704px;padding:2rem}.accordion{width:704px}.accordion-item{border-bottom:1px solid var(--primary-light);width:704px}.history-icons{border-radius:50%;height:1.5em;margin-right:.5em;vertical-align:middle;width:1.5em}.skills{align-items:center;border-radius:24px;display:flex;flex-direction:column;margin-left:auto;margin-right:auto;margin-top:3rem;width:704px}.btn-skills{background:var(--primary-lightest);border:none;border-radius:4px;box-shadow:0 4px 8px var(--primary-light);color:var(--theme-grey);cursor:pointer;font-size:1.2rem;font-weight:700;margin:1rem 1rem 2.25rem;padding:.5rem 1rem;transition:background .3s}.btn-skills.active,.btn-skills:hover{background:var(--primary-light);box-shadow:0 var(--primary-lightest)}.icons-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));margin-top:1rem;max-width:704px}.icon-card{align-items:center;animation:glideUp .7s cubic-bezier(.22,1,.36,1) forwards;background:var(--primary-lightest);border-radius:16px;display:flex;flex-direction:column;margin-bottom:2rem;opacity:0;padding:1rem;transform:translateY(40px)}@keyframes glideUp{to{opacity:1;transform:translateY(0)}}.skill-icon{display:block;height:3rem;object-fit:contain;width:3rem}.icon{font-size:2rem;margin-bottom:.5rem}.icon,.label{text-align:center}.label{color:var(--theme-grey);font-size:1rem}@media (max-width:800px){.home-container h1{font-size:2rem;margin-bottom:0;padding-right:1rem}.home-container h2,.home-container h3{font-size:1.5rem}.home-container p{font-size:1rem;margin-bottom:1.5rem;margin-left:1rem;width:92%}.profile-photo-float{height:150px;width:150px}.fox-animation{display:none}.skills{width:90%}.skills>div{text-align:center}.btn-skills{font-size:1rem;margin:.5rem;padding:.5rem;width:100px}.icons-grid{gap:.5rem;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));margin-top:2rem;max-width:90%}.icon-card{margin-bottom:.5rem;padding:.5rem;text-align:center}}.accordion-title{align-items:center;background:none;border:none;color:var(--primary-dark);cursor:pointer;display:flex;font-size:1.2rem;font-weight:700;gap:.5rem;outline:none;padding:1rem;text-align:left;transition:background .2s;width:704px}.accordion-text{display:flex;flex-direction:column;gap:.25rem}.accordion-subtitle{color:var(--theme-grey);font-size:.9rem;font-weight:400}.accordion-arrow{color:var(--primary-dark);display:inline-block;font-size:.9rem;transition:transform .3s ease}.accordion-arrow.open{transform:rotate(90deg)}.accordion-item.open .accordion-title{background:var(--primary-lightest);border-radius:4px;color:var(--primary-dark)}.accordion-content{color:var(--theme-black);font-size:1rem;overflow:hidden;padding:.75rem .5rem 1.5rem 0}.accordion-content ul li{margin-bottom:.5rem}@media (max-width:800px){.accordion-title{font-size:1rem;width:100%}.history{padding:1rem}.accordion,.accordion-item{width:100%}.history-icons{padding-bottom:.3rem}}.project-link{text-decoration:none}.projects-container{align-items:center;background:var(--theme-cream);display:flex;flex-direction:column;min-height:100vh;padding:3rem 10rem 5rem}.projects-container h2{align-self:flex-start;color:var(--theme-black);font-size:2rem}.projects-container p{color:var(--theme-grey);font-size:1.25rem;margin-bottom:1.5rem}.projects-header{display:flex;flex-direction:column;width:600px}.projects-cards{flex-wrap:wrap;gap:2rem}.project-card{background:var(--primary-lightest);border-radius:8px;box-shadow:0 2px 8px var(--theme-shadow);display:flex;flex-direction:row;margin:24px 0;padding:24px;width:750px}.project-card:hover{background:var(--primary-light);box-shadow:var(--theme-cream)}.project-photo{border-radius:8px;height:180px;margin-right:1.5rem;width:310px}.projects-container h3{align-self:flex-start;color:var(--theme-black);font-size:1.5rem;margin:0}.project-tag{background-color:var(--primary-dark);border-radius:4px;color:var(--theme-cream);display:inline-block;font-size:.875rem;margin-right:.5rem;margin-top:.5rem;padding:4px 8px}.project-card p{color:var(--theme-grey);font-size:1.25rem;margin-bottom:0;margin-top:1rem}@media (max-width:800px){.projects-container{padding-left:0;padding-right:0}.projects-container h2{align-self:center;font-size:2rem}.projects-container p{font-size:1rem}.project-card{align-items:center;flex-direction:column;max-width:300px}.project-photo{margin-bottom:1rem;margin-right:0}}.blog-container{align-items:center;background:var(--theme-cream);display:flex;flex-direction:column;min-height:100vh;padding:3rem 10rem 5rem}.blog-container h2{align-self:flex-start;color:var(--theme-black);font-size:2rem}.blog-header-container{align-items:center;display:flex;justify-content:space-between;width:600px}.pagination{display:flex;justify-content:center;margin-top:2rem}.pagination button{background:var(--theme-cream);border:2px solid var(--secondary-light);border-radius:4px;color:var(--theme-grey);cursor:pointer;font-weight:700;margin:0 .5rem;padding:.5rem 1rem}.pagination button.active{font-weight:700}.pagination button.active,.post-blog-btn{background:var(--secondary-light);color:var(--theme-cream)}.post-blog-btn{align-items:center;border:none;border-radius:8px;box-shadow:0 2px 8px var(--theme-shadow);cursor:pointer;display:inline-flex;font-size:1.25rem;font-weight:600;gap:.5rem;padding:.7rem 1.5rem;transition:background .18s,color .18s,box-shadow .18s}.post-blog-btn:hover{background:var(--secondary-dark);box-shadow:var(--theme-cream);color:var(--theme-cream)}.blog-icon{display:inline-block;height:20px;vertical-align:middle;width:20px}.blog-loading-spinner{align-items:center;display:flex;justify-content:center;min-height:40vh}.spinner-circle{animation:spin 1s linear infinite;border-top:6px solid var(--theme-cream);border:6px solid var(--theme-cream);border-radius:50%;border-top-color:var(--secondary-light);height:48px;width:48px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:800px){.blog-container{padding-left:0;padding-right:0}.blog-container h2{align-self:center}.blog-header-container{flex-direction:column;width:100%}.post-blog-btn{align-self:center;margin-left:0;padding:.7rem 1rem}}.blog-modal-overlay{align-items:center;background:#00000059;display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw}.blog-modal{align-items:center;background:var(--theme-cream);border-radius:16px;box-shadow:0 8px 32px #0000002e;display:flex;flex-direction:column;padding:2rem 2.5rem;position:relative;text-align:center;width:700px}.blog-modal-tabs{align-items:flex-end;display:flex;gap:0;justify-content:stretch;left:0;margin-bottom:2.5rem;overflow:hidden;position:absolute;top:0;width:100%}.blog-modal-tab{background:var(--theme-cream);border:none;border-bottom:2px solid #0000;border-radius:16px 16px 0 0;color:var(--theme-black);cursor:pointer;flex:1 1;font-size:1.1rem;font-weight:600;padding:1.2rem 0;transition:border-color .18s,color .18s,background .18s}.blog-modal-tab-post{border-radius:16px 0 0 0}.blog-modal-tab-delete{border-radius:0 16px 0 0}.blog-modal-tab:not(.active){background:var(--primary-lightest);color:var(--primary-dark)}.blog-modal-tab:not(.active):hover{background:var(--primary-light);color:var(--primary-dark);z-index:1}.post-blog-form{align-items:center;display:flex;flex-direction:column;padding-top:3rem;width:100%}.post-blog-label{color:var(--theme-black);font-size:1rem;font-weight:700;margin-bottom:.5rem;text-align:center}.post-blog-input{background-color:var(--theme-white);border:3px solid var(--primary-light);border-radius:4px;color:var(--theme-grey);font-family:monospace;font-size:1rem;margin-bottom:1rem;margin-top:1rem;max-width:580px;padding:.5rem;transition:background-color .3s,border-color .3s;width:620px}.post-blog-input:focus{border-color:var(--primary-light);outline:none}.post-blog-input textarea:-webkit-autofill,.post-blog-input:-webkit-autofill{-webkit-text-fill-color:var(--theme-grey)!important;border:3px solid var(--primary-light);box-shadow:0 0 0 1000px var(--theme-white) inset!important;color:var(--theme-grey)!important}.post-blog-form-btn{background:var(--secondary-light);border:none;border-radius:8px;color:var(--theme-cream);cursor:pointer;font-size:1rem;font-weight:600;margin:.5rem .5rem 0 0;padding:.6rem 1.2rem;transition:background .18s}.post-blog-form-btn:hover{background:var(--secondary-dark);color:var(--theme-cream)}.blog-error{color:var(--secondary-dark);margin-bottom:.5rem}.delete-blog-table{background:var(--theme-cream);border-radius:12px;margin-top:2rem;max-height:400px;overflow-x:auto;padding-top:1.5rem;width:100%}.delete-blog-table table{border-collapse:collapse;width:100%}.delete-blog-table td,.delete-blog-table th{font-size:1.05rem;padding:.8rem 1rem;text-align:left}.delete-blog-table th{background:var(--theme-cream);border-bottom:2px solid var(--theme-grey);color:var(--theme-grey);font-weight:700}.delete-blog-table tr{border-bottom:1px solid var(--theme-grey)}.delete-blog-table tr:last-child{border-bottom:none}.delete-blog-btn{background:var(--secondary-light);border:none;border-radius:6px;color:var(--theme-cream);cursor:pointer;font-size:1rem;font-weight:600;padding:.5rem 1.2rem;transition:background .18s}.delete-blog-btn:hover{background:var(--secondary-dark)}@media (max-width:800px){.blog-modal{padding:1.5rem;width:80%}.post-blog-input{max-width:100%;width:85%}.delete-blog-table td:nth-child(2){max-width:10ch;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}.blog-post-link{text-decoration:none}.preserve-whitespace{white-space:pre-line}.blog-post{background:var(--primary-lightest);border-radius:8px;box-shadow:0 2px 8px var(--theme-shadow);margin:24px 0;max-width:600px;padding:24px;width:100%}.blog-container h3{align-self:flex-start;color:var(--theme-black);font-size:1.5rem;margin-bottom:1rem;margin-left:2rem}.blog-post:hover{background:var(--primary-light);box-shadow:var(--theme-cream)}.blog-container h4{align-self:flex-start;color:var(--theme-black);font-size:1rem;margin-bottom:1rem;margin-left:2rem;margin-top:0}.blog-container hr{border:0;border-top:2px solid var(--primary-dark);height:1px;margin-bottom:1rem;margin-left:2rem;margin-right:2rem}.blog-container p{color:var(--theme-grey);font-size:1.25rem;margin-bottom:1.5rem;margin-left:3rem;margin-right:2rem}@media (max-width:800px){.blog-post{max-width:300px;width:100%}.blog-container p{color:var(--theme-grey);font-size:1rem;margin-bottom:1.5rem;margin-left:3rem;margin-right:2rem}}.contact-container{background:var(--theme-cream);display:flex;justify-content:center;min-height:100vh;padding-left:10rem;padding-right:10rem;padding-top:3rem}.contact-container h2{color:var(--theme-black);font-size:2rem;margin-bottom:1rem}.contact-container p{color:var(--theme-grey);font-size:1.25rem;margin-bottom:1.5rem}.contact-header{align-items:center;display:flex}.contact-header-text{margin-right:30px;width:400px}.pointer-animation{width:160px}.contact-form{display:flex;flex-direction:column;max-width:622px}.contact-form label{color:var(--theme-black);display:block;font-size:1.25rem;margin-bottom:.25rem;margin-top:1rem}.contact-form input,.contact-form textarea{background-color:var(--theme-white);border:3px solid var(--primary-light);border-radius:4px;color:var(--theme-grey);font-family:monospace;font-size:1rem;margin-bottom:1rem;padding:.5rem;transition:background-color .3s,border-color .3s;width:600px}.contact-form input:focus,.contact-form textarea:focus{border-color:var(--primary-light);outline:none}.contact-form input:-webkit-autofill,.contact-form textarea:-webkit-autofill{-webkit-text-fill-color:var(--theme-black)!important;border:3px solid var(--primary-light);-webkit-box-shadow:0 0 0 1000px var(--theme-white) inset!important;color:var(--theme-black)!important}.contact-form button{background:var(--secondary-light);border:none;border-radius:4px;box-shadow:0 4px 8px var(--theme-shadow);color:var(--theme-cream);cursor:pointer;font-size:1.25rem;font-weight:700;margin-bottom:2rem;margin-top:.75rem;padding:.75rem;transition:background .3s}.contact-form button:hover{background:var(--secondary-dark);box-shadow:0 var(--theme-cream)}.char-count{color:var(--theme-grey);font-size:.9em;margin-bottom:.5em;text-align:right}.logos{display:flex;justify-content:center}.logos a{background-color:initial;border:none;margin:0 1rem;max-height:60px;max-width:60px}.logos a:hover{transform:scale(1.12);transition:transform .4s}.logos img{max-height:100%;max-width:100%}@media (max-width:800px){.contact-container{padding:2rem}.contact-form{max-width:800px}.contact-header{flex-direction:column;text-align:center}.contact-header-text{margin:0;width:100%}.pointer-animation{width:120px}.contact-form input,.contact-form textarea{width:95%}.logos a:hover{transform:scale(1)}}.not-found-container{background:var(--theme-cream);display:flex;justify-content:center;min-height:100vh;padding-left:10rem;padding-right:10rem;padding-top:3rem}.not-found-container h2{align-self:center;color:var(--theme-black);font-size:2rem}.not-found-container p{align-self:center;color:var(--theme-grey);font-size:1.25rem;margin-bottom:1.5rem;text-align:center}.not-found-header{display:flex;flex-direction:column;width:600px}.fox-programmer-animation{align-self:center;height:350px;width:350px}.site-footer{background:var(--theme-cream);color:var(--theme-grey);font-size:1rem;margin-top:auto;padding:1rem 0;position:static;text-align:center;width:100%}@media (max-width:800px){.site-footer{font-size:1rem}}.blog-detail-container{align-items:center;background:var(--theme-cream);display:flex;flex-direction:column;min-height:100vh;padding:3rem 10rem 5rem}.blog-detail-container h2{align-self:flex-start;color:var(--theme-black);font-size:2rem}.blog-detail-post{max-width:1000px;width:100%}.blog-detail-container h3{align-self:flex-start;color:var(--theme-black);font-size:1.5rem;margin-bottom:1rem;margin-left:2rem}.blog-detail-post p{color:var(--theme-grey);font-size:1.25rem;line-height:1.6;padding-left:2rem}.return-to-blog{align-self:flex-start;background:var(--secondary-light);border:none;border-radius:8px;box-shadow:0 2px 8px var(--theme-shadow);color:var(--theme-cream);cursor:pointer;font-size:1rem;font-weight:600;padding:.7rem 1.5rem;text-decoration:none;transition:background .18s,color .18s,box-shadow .18s}.return-to-blog:hover{background:var(--secondary-dark);box-shadow:var(--theme-cream);color:var(--theme-cream)}@media (max-width:800px){.blog-detail-container{padding-left:2rem;padding-right:2rem}.blog-detail-post{max-width:100%;width:100%}.blog-detail-container h3{font-size:1.25rem}.blog-detail-post p{font-size:1rem}}.project-detail-container{align-items:center;background:var(--theme-cream);display:flex;flex-direction:column;min-height:100vh;padding:3rem 10rem 5rem}.project-detail{display:flex;flex-direction:row;gap:2.5rem;margin-top:1rem}.project-detail-left{flex:1 1;min-width:650px}.project-detail-right{align-items:flex-start;display:flex;flex:1 1;flex-direction:column;justify-content:flex-start}.project-detail-header{display:flex;flex-direction:column;margin-bottom:1.5rem;width:1000px}.project-detail-container h2{align-self:flex-start;color:var(--theme-black);font-size:2rem}.project-detail-container p{color:var(--theme-grey);font-size:1.25rem;margin:0}.project-detail-image{border-radius:12px;box-shadow:0 2px 8px var(--theme-shadow);height:auto;width:650px}.project-detail-container h3{align-self:flex-start;color:var(--theme-black);font-size:1.5rem;margin-bottom:1rem}.project-detail-link{background:var(--secondary-light);border-radius:4px;color:var(--theme-cream);font-size:1.1rem;font-weight:700;margin-bottom:.75rem;padding:10px 14px;text-decoration:none;width:122px}.project-detail-link:hover{background:var(--secondary-dark)}.project-detail-icon{height:25px;margin-right:8px;vertical-align:middle;width:25px}.project-detail-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.project-detail-tag{background:var(--primary-lightest);border-radius:8px;color:var(--primary-dark);font-size:.95em;font-weight:500;padding:.3em .8em}.project-detail-description{color:var(--theme-grey);font-size:1.1rem;margin-top:1.5rem}@media (max-width:1000px){.project-detail-container{padding-left:1rem;padding-right:1rem}.project-detail-header{width:100%}.project-detail-container h2{align-self:center}.project-detail-container p{align-self:center;font-size:1rem;text-align:center}.project-detail{align-items:center;flex-direction:column}.project-detail-left{min-width:100%}.project-detail-image{max-width:650px;width:100%}}
/*# sourceMappingURL=main.59af955c.css.map*/