:root{--primary-color: #3e7135;--primary-color-hover: #2b4926;--light-grey: #e7e7e7;--text-color: #333;--secondary-text-color: #666}body{padding-top:56px;--bs-primary: var(--primary-color);--bs-primary-rgb: 107, 157, 58;font-family:Arial,sans-serif}.hero{background:url(/assets/Provo_Canyon-BIEVfq9G.jpg) center center/cover no-repeat;height:calc(100vh - 56px);display:flex;justify-content:center;align-items:center;color:#fff;text-align:center;position:relative;overflow:hidden;background-attachment:fixed;background-position:center}.hero:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:#0000004d;z-index:0}.hero .glass{position:relative;z-index:1}.hero h1{font-size:3rem;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.5);min-height:1.2em}.hero .lead{font-size:1.5rem;text-shadow:1px 1px 3px rgba(0,0,0,.5)}#years-of-experience{display:inline-block;font-weight:700;color:gold;text-shadow:2px 2px 4px rgba(0,0,0,.8);font-size:1.8rem}@media (max-width: 768px){.hero{background-attachment:scroll}.hero h1{font-size:2rem}.hero .lead{font-size:1.2rem}#years-of-experience{font-size:1.4rem}}.glass{background:#08080866;padding:20px;border-radius:10px}.footer{padding:20px 0;background:#f8f9fa;text-align:center}.resume-header{font-size:18px;font-weight:700}.date-range{font-size:14px;font-weight:700;color:var(--text-color)}#resume{padding:20px}.resume-content{padding:10px 0}.resume-item{margin:0 0 20px;opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}.resume-item.animate-in{opacity:1;transform:translateY(0)}.responsibilities li{opacity:0;transform:translate(-20px)}.responsibilities li.stagger-in{animation:slideInLeft .5s ease forwards}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.resume-section{margin-bottom:30px}.section-title{margin-left:0;font-size:24px;color:var(--text-color);font-weight:700;border-top:1px solid var(--text-color);border-bottom:1px solid var(--text-color);padding-top:5px;padding-bottom:5px}.position-title{font-size:16px;color:var(--text-color);margin-top:0}.company-details,.location{font-size:14px;color:var(--secondary-text-color)}ul{padding-left:20px}ul li{margin-bottom:5px}.feature{font-weight:700}@media (max-width: 576px){.d-flex{display:block!important}.justify-content-between{justify-content:flex-start!important}.align-items-center{align-items:flex-start!important}.date-range,.location{text-align:left;margin-top:5px}#resume{padding:10px}}.bio-image{max-height:100%;object-fit:cover}@media (min-width: 768px){.bio-image{height:100%}}.navbar-nav .nav-item{padding-left:10px;padding-right:10px}.nav-link-button{margin-left:10px;top:2.5px;position:relative;display:inline-flex;align-items:center;gap:.5rem}.download-icon{width:18px;height:18px}.download-resume-container{display:flex;align-items:center;gap:.5rem;position:relative}.pdf-tech-badge{position:relative;cursor:help}.badge-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background:linear-gradient(135deg,gold,#ffed4e);border-radius:50%;font-size:16px;box-shadow:0 2px 8px #ffd70066;transition:all .3s ease;position:relative}.badge-icon:before{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:50%;padding:3px;background:conic-gradient(from 0deg,transparent 0%,transparent 70%,#ffd700 80%,#ffed4e 90%,transparent 100%);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;animation:borderChase 3s linear infinite;pointer-events:none}@keyframes borderChase{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.pdf-tech-badge:hover .badge-icon{transform:rotate(20deg) scale(1.2);box-shadow:0 4px 12px #ffd70099}.pdf-tech-badge:hover .badge-icon:before{animation-play-state:paused}.pdf-tech-badge.tooltip-viewed .badge-icon:before{animation:none}.tooltip-content{position:absolute;top:calc(100% + 10px);right:0;background:#fff;border:2px solid var(--primary-color);border-radius:12px;padding:1rem;width:320px;box-shadow:0 8px 24px #00000026;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .3s ease;z-index:1000;pointer-events:none}.pdf-tech-badge:hover .tooltip-content{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto}.tooltip-content:before{content:"";position:absolute;top:-8px;right:20px;width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:8px solid var(--primary-color)}.tooltip-content strong{display:block;color:var(--primary-color);font-size:1.1rem;margin-bottom:.5rem}.tooltip-content p{color:var(--text-color);font-size:.9rem;line-height:1.5;margin-bottom:.75rem}.tooltip-link{display:inline-block;color:var(--primary-color);font-weight:600;text-decoration:none;transition:all .2s ease}.tooltip-link:hover{color:var(--primary-color-hover);transform:translate(3px)}.navbar-nav .nav-item .nav-link{padding:10px 15px}.btn-custom{background-color:var(--primary-color);border-color:var(--primary-color);color:#fff}.btn-custom:hover{background-color:var(--primary-color-hover);border-color:var(--primary-color-hover);color:#fff}.side-nav-sticky{position:sticky;top:70px;height:fit-content;max-height:calc(100vh - 90px);overflow-y:auto}.side-nav{padding:1.5rem 0}.side-nav-link{display:block;padding:.75rem 1rem!important;margin:.125rem 0;color:var(--secondary-text-color)!important;transition:color .2s ease,border-color .2s ease;position:relative;font-weight:400;font-size:.95rem;border-left:3px solid transparent;text-decoration:none}.side-nav-link:hover{color:var(--text-color)!important;border-left-color:#d0d0d0}.side-nav-link.active{color:var(--primary-color)!important;font-weight:600;border-left-color:var(--primary-color)}#on-platform-name{white-space:nowrap;font-weight:700}#explainer{padding:2rem 0}#explainer .tip{display:flex;align-items:center;background-color:#f6f8fa;border-left:3px solid #28a745;padding:1rem;margin:1rem 0;border-radius:5px;flex-wrap:wrap}#explainer .tip svg{fill:#28a745;margin-right:.5rem}#explainer .tip span{color:#586069}#explainer-title{font-size:1.5rem;font-weight:700;margin-top:.5rem}#explainer-text{flex-basis:100%;margin-top:1rem}@media (min-width: 576px){#explainer .tip{flex-wrap:nowrap}#explainer-text{margin-top:0;margin-left:1rem;flex-basis:auto}#explainer-title{font-size:1rem;font-weight:700}}#portfolio{padding:20px}.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.portfolio-item{padding:8px;border-radius:10px;transition:box-shadow .3s ease-in-out;width:100%;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-start;align-items:center;perspective:1000px;cursor:pointer;aspect-ratio:1 / 1}.portfolio-item:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;border-radius:10px;border:5px solid #ccc;transition:border .3s ease-in-out;z-index:1}.portfolio-item:hover:before{border:7px solid transparent;border-image:linear-gradient(45deg,red,orange,#ff0,green,#00f,indigo,violet,red);border-image-slice:1;animation:glow 5s linear}@keyframes glow{0%{border-image-source:linear-gradient(45deg,red,orange,yellow,green,blue,indigo,violet,red)}14.28%{border-image-source:linear-gradient(90deg,red,orange,yellow,green,blue,indigo,violet,red)}28.56%{border-image-source:linear-gradient(135deg,red,orange,yellow,green,blue,indigo,violet,red)}42.84%{border-image-source:linear-gradient(180deg,red,orange,yellow,green,blue,indigo,violet,red)}57.12%{border-image-source:linear-gradient(225deg,red,orange,yellow,green,blue,indigo,violet,red)}71.4%{border-image-source:linear-gradient(270deg,red,orange,yellow,green,blue,indigo,violet,red)}85.68%{border-image-source:linear-gradient(315deg,red,orange,yellow,green,blue,indigo,violet,red)}to{border-image-source:linear-gradient(360deg,red,orange,yellow,green,blue,indigo,violet,red)}}.portfolio-header{display:flex;align-items:center}.portfolio-header h4{display:flex;align-items:center;text-align:center;font-size:1.75rem;margin:1rem}.portfolio-icon{width:40px;height:40px;margin-right:10px}.portfolio-description{position:absolute;top:5px;left:5px;width:calc(100% - 10px);height:calc(100% - 10px);background:#fff;color:var(--text-color);text-align:left;padding:20px;border-radius:5px;backface-visibility:hidden;transform:rotateY(180deg);transform-style:preserve-3d;transition:transform .6s;display:flex;align-items:center;justify-content:center;z-index:2}.portfolio-item:hover .portfolio-description{transform:rotateY(0)}.portfolio-image-container{width:100%;height:100%;display:flex;justify-content:center;align-items:center;z-index:0}.portfolio-image{width:100%;height:auto;border-radius:10px}.architecture-diagram{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:20px;display:flex;align-items:center;justify-content:center}.arch-svg{width:100%;height:auto;max-width:400px}@media (max-width: 576px){.portfolio-grid{display:block}.portfolio-item{width:100%;height:auto;aspect-ratio:auto;margin-bottom:16px}.portfolio-item:last-child{margin-bottom:0}.portfolio-item:hover .portfolio-description{transform:none}.portfolio-description{position:static;transform:none;width:100%;height:auto;padding:10px;margin-top:10px}}#contact{position:relative}#contact h2{font-size:2.5rem;font-weight:700;color:var(--text-color)}#contact .lead{color:var(--secondary-text-color);font-size:1.1rem}.primary-contact-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn-primary-contact{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 2rem;font-size:1.1rem;font-weight:600;border-radius:50px;text-decoration:none;transition:all .3s ease;border:none;box-shadow:0 4px 6px #0000001a;min-width:180px}.btn-primary-contact:hover{transform:translateY(-3px);box-shadow:0 8px 15px #0003;text-decoration:none}.btn-primary-contact:active{transform:translateY(-1px);box-shadow:0 5px 10px #0003}.btn-email{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-email:hover{background:linear-gradient(135deg,#5568d3,#61398e);color:#fff}.btn-phone{background:linear-gradient(135deg,var(--primary-color) 0%,#2b4926 100%);color:#fff}.btn-phone:hover{background:linear-gradient(135deg,#2b4926,#1a2e17);color:#fff}.contact-icon{width:24px;height:24px}.social-links{display:flex;gap:1.5rem;justify-content:center;align-items:center;flex-wrap:wrap;margin-top:1rem}.social-btn{display:flex;align-items:center;justify-content:center;width:60px;height:60px;border-radius:50%;transition:all .3s ease;text-decoration:none;box-shadow:0 4px 6px #0000001a;position:relative;overflow:hidden}.social-btn svg{width:30px;height:30px;position:relative;z-index:2;transition:transform .3s ease}.social-btn:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;border-radius:50%;transition:transform .3s ease;z-index:1}.social-btn:hover{transform:translateY(-5px) scale(1.1);box-shadow:0 10px 20px #0003;text-decoration:none}.social-btn:hover svg{transform:scale(1.1)}.social-btn:active{transform:translateY(-3px) scale(1.05)}.social-btn-linkedin{background-color:#0077b5;color:#fff}.social-btn-linkedin:before{background:linear-gradient(135deg,#0077b5,#00a0dc)}.social-btn-linkedin:hover{background-color:#006399}.social-btn-github{background-color:#333;color:#fff}.social-btn-github:before{background:linear-gradient(135deg,#24292e,#444)}.social-btn-github:hover{background-color:#24292e}.social-btn-twitter{background-color:#000;color:#fff}.social-btn-twitter:before{background:linear-gradient(135deg,#000,#333)}.social-btn-twitter:hover{background-color:#14171a}@media (max-width: 768px){.primary-contact-buttons{flex-direction:column;align-items:stretch}.btn-primary-contact{width:100%;min-width:auto}.social-links{gap:1rem}.social-btn{width:50px;height:50px}.social-btn svg{width:25px;height:25px}#contact h2{font-size:2rem}#contact .lead{font-size:1rem}}
