@import "https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;600;700;900&display=swap";#root{width:100%;overflow-x:hidden}:root{--color-light:#cad2c5;--color-sage:#84a98c;--color-dark-sage:#52796f;--color-slate:#354f52;--color-charcoal:#2f3e46}.no-copy{-webkit-user-select:none;user-select:none}*{box-sizing:border-box;margin:0;padding:0}html,body{max-width:100%;overflow-x:hidden}html{background-color:var(--color-light);width:100%;overflow:hidden scroll}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-light);width:100%;color:var(--color-charcoal);font-family:Montserrat,sans-serif;line-height:1.6;transition:opacity .6s ease-in-out;position:relative;overflow-x:hidden}@keyframes fadeIn{to{opacity:1}}.top-left-name{color:var(--color-charcoal);text-transform:uppercase;letter-spacing:2px;z-index:101;flex-direction:column;align-items:flex-start;font-size:1.2rem;font-weight:900;transition:opacity .4s;display:flex}body:not(.portfolio-page) .header-wrapper{flex-direction:column;align-items:flex-start;width:100%;max-width:1000px;margin:0 auto;padding:60px 5vw 0;display:flex}#loader-bg{background-color:var(--color-light);z-index:9999;opacity:0;visibility:hidden;transition:opacity .5s ease-in-out,visibility .5s;position:fixed;inset:0}#loader-bg.loader-finished{opacity:0;visibility:hidden}body:not(.portfolio-page) .top-left-name{color:var(--color-charcoal);text-transform:uppercase;letter-spacing:2px;flex-direction:column;margin-bottom:40px;font-size:1.2rem;font-weight:900;display:flex;position:static}.portfolio-page .top-left-name{pointer-events:none;z-index:101;width:90vw;position:fixed;top:30px;left:5vw;overflow:hidden}.name-line{pointer-events:auto;align-items:baseline;line-height:1;display:inline-flex}.initial{color:var(--color-dark-sage);display:inline-block;transform:translate(100vw)}.expand{color:var(--color-charcoal);white-space:nowrap;opacity:0;max-width:0;display:inline-block;overflow:hidden}.run-anim .initial{animation:1s cubic-bezier(.25,1,.5,1) forwards slideInInitial}.run-anim .expand{animation:1s cubic-bezier(.25,1,.5,1) 1s forwards expandName}.no-anim .initial{transform:translate(0)}.no-anim .expand{opacity:1;max-width:400px}@keyframes slideInInitial{to{transform:translate(0)}}@keyframes expandName{0%{opacity:0;max-width:0}to{opacity:1;max-width:200px}}body:not(.portfolio-page) nav{width:100%;padding:0}body:not(.portfolio-page) nav ul{justify-content:space-between;margin:0;list-style:none;display:flex}.portfolio-page nav{pointer-events:none;z-index:90;width:100%;padding:0 5vw;position:fixed;top:50%;left:0;transform:translateY(-50%)}.portfolio-page nav ul{pointer-events:auto;justify-content:space-between;list-style:none;display:flex}nav a{color:var(--color-charcoal);text-transform:uppercase;letter-spacing:2px;font-size:.8rem;font-weight:700;text-decoration:none;transition:all .3s}nav a:hover,nav a.active{color:var(--color-dark-sage);border-bottom:2px solid var(--color-dark-sage)}.full-screen-portfolio{align-items:center;width:100vw;height:100vh;display:flex;overflow:hidden}.portfolio-scroll{scrollbar-width:none;height:100%;padding:0 15vw;display:block;position:relative;overflow:hidden}.portfolio-scroll-inner{will-change:transform;transform-origin:0;align-items:center;gap:20vw;height:100%;display:flex}.portfolio-scroll::-webkit-scrollbar{display:none}.project{border-bottom:6px solid var(--color-dark-sage);cursor:pointer;will-change:transform;backface-visibility:hidden;background:#fff;border-radius:12px;flex:none;width:22vw;min-width:280px;max-width:400px;max-height:50vh;padding:5px;transition:transform .5s;overflow:hidden;transform:translateZ(0);box-shadow:10px 10px 30px #2f3e461a}.project:after{content:"";opacity:0;pointer-events:none;z-index:-1;border-radius:12px;transition:opacity .3s;position:absolute;inset:0;box-shadow:15px 15px 40px #2f3e4633}.project:hover:after{opacity:1}.project:hover{transform:scale(1.05)translateY(-10px)}.project img{object-fit:cover;border-radius:12px;width:100%;height:auto;max-height:40vh}.project:nth-child(odd){transform:translateZ(0)translateY(-28vh)}.project:nth-child(2n){transform:translateZ(0)translateY(28vh)}.project:nth-child(odd):hover{transform:translateZ(0)translateY(-28vh)scale(1.05)translateY(-10px)}.project:nth-child(2n):hover{transform:translateZ(0)translateY(28vh)scale(1.05)translateY(-10px)}.scroll-indicator-wrap{z-index:90;align-items:flex-end;gap:12px;display:none;position:fixed;bottom:40px;left:20px}.portfolio-page .scroll-indicator-wrap{display:flex}.scroll-text{writing-mode:vertical-rl;text-transform:uppercase;color:var(--color-slate);font-size:.6rem;font-weight:600;transition:opacity .5s;transform:rotate(180deg)}.progress-bar-container{background-color:var(--color-sage);width:2px;height:100px;position:relative;overflow:hidden}.progress-bar-fill{background-color:var(--color-slate);width:100%;height:0%;transition:height .1s ease-out;position:absolute;bottom:0}.scroll-hint{text-transform:uppercase;color:var(--color-slate);font-size:.9rem;font-weight:600;transition:opacity .5s,transform .5s}.scroll-hint.hidden,.scroll-text.hidden{opacity:0;pointer-events:none}.cv-page,.contact-page{box-sizing:border-box;width:100%;max-width:1000px;margin:0 auto;padding:80px 5vw 50px}.cv-header h1,.contact-form-section h1{border-bottom:2px solid var(--color-sage);color:var(--color-slate);margin-bottom:20px;padding-bottom:15px;font-size:3.5rem;font-weight:900}.cv-grid,.contact-wrapper{grid-template-columns:2fr 1fr;align-items:start;gap:60px;margin-top:20px;display:grid}.cv-main-col h2,.cv-side-col h2{text-transform:uppercase;border-bottom:1px solid var(--color-sage);color:var(--color-slate);margin-top:50px;margin-bottom:25px;padding-bottom:10px;font-size:.85rem}.cv-main-col p{margin-bottom:25px}.skills-list li{background:var(--color-dark-sage);color:#fff;border-left:4px solid var(--color-charcoal);border-radius:5px;margin-bottom:12px;padding:12px 20px;list-style:none}.contact-text-section{margin-top:15px;padding-top:20px}.contact-text-section p{color:var(--color-charcoal);font-size:1.05rem;line-height:1.6}.form-group{margin-bottom:25px}.form-group label{color:var(--color-slate);margin-bottom:10px;font-weight:600;display:block}.form-group input,.form-group textarea{border:1px solid var(--sage);width:100%;color:var(--color-charcoal);border:1px solid var(--sage);background-color:#fff9;border-radius:4px;padding:15px;font-family:inherit;transition:border-color .3s}.form-group input:focus,.form-group textarea:focus{border-color:var(--color-dark-sage);background-color:#fff;outline:none}.submit-btn{background-color:var(--color-slate);color:#fff;cursor:pointer;text-transform:uppercase;letter-spacing:1px;border:none;border-radius:4px;padding:15px 40px;font-weight:700;transition:background .3s}.submit-btn:hover{background-color:var(--color-dark-sage)}@keyframes fadeInModal{0%{opacity:0}to{opacity:1}}.modal{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1000;background:#2f3e46eb;justify-content:center;align-items:center;animation:.2s fadeInModal;display:none;position:fixed;inset:0}.modal-content{border-top:6px solid var(--color-dark-sage);text-align:left;text-align:center;background-color:#fff;border-radius:25px;flex-direction:column;align-items:center;width:90%;max-width:800px;max-height:90vh;padding:40px;animation:.3s slideIn;display:flex;position:relative;overflow:hidden}#modal-title,#modal-desc{text-align:center;width:100%;margin-left:auto;margin-right:auto}#modal-img{object-fit:contain;width:100%;max-height:45vh;margin-bottom:25px;display:block;border-radius:16px!important}.close{cursor:pointer;color:var(--color-sage);font-size:35px;font-weight:600;line-height:1;position:absolute;top:20px;right:25px}.close:hover{color:var(--color-dark-sage);transform:scale(1.1)}@keyframes slideIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal.closing{animation:.2s forwards fadeOutModal}.modal.closing .modal-content{animation:.2s forwards slideOut}@keyframes fadeOutModal{0%{opacity:1}to{opacity:0}}@keyframes slideOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.95)}}#modal-title{color:var(--color-slate);margin-top:10px;margin-bottom:15px;font-size:2rem;line-height:1.2}#modal-desc{color:var(--color-charcoal);margin-bottom:30px;font-size:1.05rem;line-height:1.6}.modal-links{flex-wrap:wrap;justify-content:center;gap:15px;margin-top:20px;display:flex}.modal-btn{text-transform:uppercase;letter-spacing:1px;text-align:center;border:none;border-radius:8px;padding:14px 28px;font-family:Montserrat,sans-serif;font-size:.85rem;font-weight:700;transition:all .3s;display:inline-block;box-shadow:0 4px 10px #0000001a;color:#fff!important;text-decoration:none!important}.modal-btn.primary-btn{background-color:#48a6a7}.modal-btn.primary-btn:hover{background-color:#3d8f90;transform:translateY(-2px)}.modal-btn:not(.primary-btn):not(.secondary){background-color:var(--color-dark-sage)}.modal-btn:not(.primary-btn):not(.secondary):hover{background-color:#42635a;transform:translateY(-2px)}.modal-btn.secondary{background-color:var(--color-charcoal)}.modal-btn.secondary:hover{background-color:#1a252b;transform:translateY(-2px)}@media (width<=1024px){body:not(.portfolio-page) .header-wrapper{flex-direction:column;align-items:center;gap:20px;padding:30px 5vw 0;display:flex}body:not(.portfolio-page) .top-left-name{align-items:center}body:not(.portfolio-page) nav{padding:0}body:not(.portfolio-page) nav ul{flex-wrap:wrap;justify-content:center;gap:20px}.portfolio-page nav ul{flex-wrap:wrap;justify-content:space-between;gap:20px}.cv-grid,.contact-wrapper{grid-template-columns:1fr;gap:40px}.cv-header h1,.contact-form-section h1{font-size:2.5rem}.full-screen-portfolio{min-height:100vh;height:auto!important;display:block!important;overflow:visible!important}.portfolio-scroll{flex-direction:column;gap:50px;padding:120px 5vw 80px;display:flex;height:auto!important;overflow:visible!important;transform:none!important}.portfolio-scroll-inner{will-change:auto;flex-direction:column;gap:50px;height:auto;display:flex;transform:none!important}.project{width:100%;max-width:500px;margin:0 auto}.project:nth-child(odd),.project:nth-child(2n){transform:none!important}.portfolio-page nav{pointer-events:auto;padding-top:80px;position:absolute;top:0;transform:none}.progress-bar-container{width:3px;height:100px}.scroll-indicator-wrap{bottom:20px;left:4px}.scroll-hint,.scroll-text{display:none!important}.portfolio-scroll-inner{will-change:auto;flex-direction:column;gap:50px;display:flex;transform:none!important}}@media print{nav,.portfolio-scroll,.submit-btn,.scroll-indicator-wrap{display:none!important}body{color:#000;opacity:1;background:#fff}}body.dark-theme{--color-light:#1a1c20;--color-charcoal:#e2e8f0;--color-slate:#9abf80;--color-sage:#48a6a7;background-color:var(--color-light);color:var(--color-charcoal);transition:background-color .5s,color .5s}body.dark-theme #loader-bg{background-color:var(--color-light)}body.dark-theme .project{background-color:#2a2d35;box-shadow:0 10px 30px #00000080}body.dark-theme input,body.dark-theme textarea{color:var(--color-charcoal);background-color:#2a2d35;border:1px solid #3f4450}body.jonathan-theme{background-color:#0000!important}body.jonathan-theme .cv-page,body.jonathan-theme .cv-main-col,body.jonathan-theme .cv-side-col,body.jonathan-theme .cv-sidebar-box,body.jonathan-theme .about-content,body.jonathan-theme .about-text,body.jonathan-theme main{box-shadow:none!important;background:0 0!important}
