.viewport{position:relative;height:100vh;width:100%;overflow:hidden;background:#0b0b0c}.grid-2x2{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;height:90vh;width:100%;position:relative;z-index:1}.quad{background-size:cover;background-position:center;box-shadow:inset 0 0 0 4px #ffffff0f;transition:transform .25s ease,box-shadow .25s ease,filter .25s ease;display:flex;flex-direction:column;align-items:center;justify-content:space-between;color:#fff;font-size:3rem;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.7);padding:1rem;min-height:0;overflow:hidden}.quad>div{margin-top:2rem}.quad:hover{transform:scale(1.01);box-shadow:inset 0 0 0 4px #ffffff1f;filter:brightness(1.05)}.q1{background:linear-gradient(135deg,#331f15,#906642)}.q2{background:linear-gradient(135deg,#324c47,#331f15)}.q3{background:linear-gradient(135deg,#5c464b,#324c47)}.q4{background:linear-gradient(135deg,#906642,#5c464b)}.center-overlay{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(60vmin,80vw);height:min(60vmin,80vh);border-radius:12px;background-image:url(/assets/alderman-aV337cvz.png);background-size:cover;background-position:center top;z-index:2;pointer-events:none}@media (max-width: 640px){.center-overlay{width:min(60vmin,70vw);height:min(60vmin,70vh);top:35%}.grid-2x2{height:70vh}.quad{font-size:1.5rem;padding:.5rem}.quad>div{margin-top:1rem}.q3>div,.q4>div{margin-top:auto;margin-bottom:1rem}.tooltip{font-size:12px;padding:6px 10px}.overlay-layer .q1-hat{top:12%;left:10%;width:25vmin}.overlay-layer .q2-hat{top:12%;right:10%;width:25vmin}.overlay-layer .q3-hat{bottom:40%;left:10%;width:25vmin}.overlay-layer .q4-hat{bottom:40%;right:10%;width:25vmin}.overlay-layer .q1-hat.hovered{opacity:1;transform:translate(-50%,-50%) scale(1.3);top:20%;left:50%}.overlay-layer .q2-hat.hovered{opacity:1;transform:translate(-50%,-50%) scale(1.4);top:22%;left:50%}.overlay-layer .q3-hat.hovered{opacity:1;transform:translate(-50%,-50%) scale(1.2);top:23%;left:50%}.overlay-layer .q4-hat.hovered{opacity:1;transform:translate(-50%,-50%) scale(1.1);top:24%;left:47%}}.hat-overlay{position:fixed;top:30vh;left:50vw;transform:translate(-50%,-50%) scale(.8);z-index:99999;opacity:0;transition:opacity .4s ease;pointer-events:none}.q1:hover~.q1-hat,.q2:hover~.q2-hat,.q3:hover~.q3-hat,.q4:hover~.q4-hat{opacity:1}.overlay-layer{position:absolute;top:0;left:0;width:100%;height:100%;z-index:10;pointer-events:none}.hat-image{position:absolute;width:15vmin;height:auto;opacity:1;transition:all .4s ease;pointer-events:none;z-index:20}.q1-hat{top:20%;left:20%}.q2-hat{top:20%;right:20%}.q3-hat{bottom:20%;left:20%}.q4-hat{bottom:20%;right:20%}.q1-hat.hovered{opacity:1;transform:translate(-50%,-50%) scale(1.8);top:18%;left:50%}.q2-hat.hovered{opacity:1;transform:translate(-50%,-50%) scale(2);top:22%;left:50%}.q3-hat.hovered{opacity:1;transform:translate(-50%,-50%) scale(2);top:23%;left:50%}.q4-hat.hovered{opacity:1;transform:translate(-50%,-50%) scale(1.8);top:26%;left:49%}.tooltip{position:absolute;background:#000c;color:#fff;padding:8px 12px;border-radius:6px;font-size:14px;font-weight:500;white-space:nowrap;opacity:0;transform:translateY(10px);transition:all .3s ease;pointer-events:none;z-index:30;box-shadow:0 2px 8px #0000004d}.tooltip.visible{opacity:1;transform:translateY(0)}.q1-tooltip{top:2%;left:2%}.q2-tooltip{top:2%;right:2%}.q3-tooltip{top:52%;left:2%}.q4-tooltip{top:52%;right:2%}:root{--brand: #6B0F9C;--brand-dark: #500B75;--accent: #ffc600;--ink: #0b0b0c;--muted: #666;--paper: #ffffff;--paper-tint: rgba(107, 15, 156, .05);--ring: rgba(107, 15, 156, .2)}html{box-sizing:border-box}*,*:before,*:after{box-sizing:inherit}.resume-container{max-width:1200px;margin:20px auto;padding:20px;background:var(--paper);color:var(--ink);border-radius:8px;box-shadow:0 0 10px #0000001a}.resume-section{margin-bottom:36px;padding:20px;background:var(--paper-tint);border-radius:6px}.resume-section h2{color:var(--brand);font-family:Amatic SC,cursive;font-size:clamp(1.8rem,5vw,2.2rem);margin:0 0 16px;text-transform:uppercase;letter-spacing:1px}.job-entry{margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--ring)}.job-entry:last-child{border-bottom:none;padding-bottom:0}.job-title{font-weight:700;color:var(--brand);font-size:1.05rem}.company-name{font-weight:600}.job-date{color:var(--muted);font-style:italic;margin-top:2px}.job-duties{margin-top:8px;line-height:1.6}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-top:10px}.skill-item{background:var(--brand);color:#fff;padding:12px;border-radius:6px;text-align:center;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 1px #0000000d}.skill-item:hover{transform:translateY(-2px);box-shadow:0 10px 20px #0000001f}@media (max-width: 768px){.resume-container{margin:20px;padding:16px}html{font-size:16px}}.volunteer-page{max-width:1200px;margin:0 auto;padding:40px 20px;min-height:100vh}.photo-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:32px;margin-bottom:80px}.photo-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:12px;overflow:hidden;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.photo-card:hover{transform:translateY(-8px);box-shadow:0 20px 40px #0000004d;border-color:#ffffff26}.photo-container{position:relative;overflow:hidden;aspect-ratio:4/3}.volunteer-photo{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.photo-card:hover .volunteer-photo{transform:scale(1.05)}.photo-info{padding:24px}.photo-info h3{margin:0 0 12px;font-size:1.4rem;font-weight:600;color:var(--text)}.photo-info p{margin:0;color:var(--muted);line-height:1.6;font-size:1rem}.volunteer-stats{text-align:center;padding:60px 0;border-top:1px solid rgba(255,255,255,.08)}.volunteer-stats h2{font-size:clamp(2rem,4vw,2.5rem);margin:0 0 48px;color:var(--text);font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:40px;max-width:800px;margin:0 auto}.stat-item{display:flex;flex-direction:column;align-items:center;gap:12px}.stat-number{font-size:clamp(2.5rem,5vw,3.5rem);font-weight:700;color:var(--accent);line-height:1}.stat-label{font-size:1.1rem;color:var(--muted);font-weight:500;text-transform:uppercase;letter-spacing:.5px}@media (max-width: 768px){.volunteer-page{padding:20px 16px}.photo-gallery{grid-template-columns:1fr;gap:24px}.stats-grid{grid-template-columns:1fr;gap:32px}.page-header{margin-bottom:40px}.volunteer-stats{padding:40px 0}}@media (max-width: 480px){.photo-info{padding:20px}.photo-info h3{font-size:1.2rem}.photo-info p{font-size:.95rem}}.engineer-page{max-width:1200px;margin:0 auto;padding:40px 20px;min-height:100vh}.home-button{display:inline-flex;align-items:center;padding:12px 24px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:8px;color:var(--text);text-decoration:none;font-size:16px;font-weight:500;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.home-button:hover{background:#ffffff1f;border-color:#ffffff40;transform:translateY(-2px);box-shadow:0 8px 25px #0003}.skills-section{margin-bottom:60px;text-align:center}.skills-section h2{font-size:clamp(1.8rem,3vw,2.2rem);margin:0 0 32px;color:var(--text);font-weight:600}.skills-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;max-width:800px;margin:0 auto}.skill-tag{display:inline-block;padding:8px 16px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:20px;color:var(--text);font-size:14px;font-weight:500;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.skill-tag:hover{background:#ffffff1f;border-color:var(--accent);transform:translateY(-2px)}.options-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-bottom:80px}.option-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:32px;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;flex-direction:column;gap:24px}.option-card:hover{transform:translateY(-8px);box-shadow:0 20px 40px #0000004d;border-color:#ffffff26}.option-icon{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:32px;transition:transform .3s ease}.option-card:hover .option-icon{transform:scale(1.1)}.option-content h3{margin:0 0 12px;font-size:1.5rem;font-weight:600;color:var(--text)}.option-content p{margin:0 0 24px;color:var(--muted);line-height:1.6;font-size:1rem;flex-grow:1}.option-link{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:8px;color:var(--text);text-decoration:none;font-size:16px;font-weight:500;transition:all .3s ease;align-self:flex-start}.option-link:hover{background:#ffffff1f;border-color:#ffffff40;transform:translateY(-2px);box-shadow:0 8px 25px #0003}.arrow{transition:transform .3s ease}.option-link:hover .arrow{transform:translate(4px)}.about-section{text-align:center;padding:60px 0;border-top:1px solid rgba(255,255,255,.08)}.about-section h2{font-size:clamp(1.8rem,3vw,2.2rem);margin:0 0 32px;color:var(--text);font-weight:600}.about-content{max-width:800px;margin:0 auto}.about-content p{margin:0 0 20px;color:var(--muted);line-height:1.7;font-size:1.1rem}.about-content p:last-child{margin-bottom:0}@media (max-width: 768px){.engineer-page{padding:20px 16px}.options-grid{grid-template-columns:1fr;gap:24px}.option-card{padding:24px}.skills-grid{gap:10px}.skill-tag{font-size:13px;padding:6px 12px}.page-header{margin-bottom:40px}.about-section{padding:40px 0}}@media (max-width: 480px){.option-content h3{font-size:1.3rem}.option-content p{font-size:.95rem}.about-content p{font-size:1rem}}.client-projects-page{max-width:1400px;margin:0 auto;padding:40px 20px;min-height:100vh}.page-header{text-align:center;margin-bottom:60px}.page-header h1{font-size:clamp(2.5rem,5vw,4rem);margin:0 0 16px;color:var(--text);font-weight:700}.subtitle{font-size:clamp(1.1rem,2.5vw,1.3rem);color:var(--muted);margin:0 0 32px;line-height:1.5}.back-button{display:inline-flex;align-items:center;padding:12px 24px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:8px;color:var(--text);text-decoration:none;font-size:16px;font-weight:500;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.back-button:hover{background:#ffffff1f;border-color:#ffffff40;transform:translateY(-2px);box-shadow:0 8px 25px #0003}.project-section{display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-bottom:80px;align-items:start}.project-info h2{font-size:clamp(1.8rem,3vw,2.2rem);margin:0 0 24px;color:var(--text);font-weight:600}.project-details p{margin:0 0 20px;color:var(--muted);line-height:1.7;font-size:1.1rem}.project-tech{margin:32px 0}.project-tech h3{font-size:1.2rem;margin:0 0 16px;color:var(--text);font-weight:600}.tech-tags{display:flex;flex-wrap:wrap;gap:8px}.tech-tag{display:inline-block;padding:6px 12px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:16px;color:var(--text);font-size:13px;font-weight:500;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tech-tag:hover{background:#ffffff1f;border-color:var(--accent);transform:translateY(-1px)}.project-links{margin-top:32px}.project-link{display:inline-flex;align-items:center;gap:8px;padding:14px 24px;background:var(--accent);border:1px solid var(--accent);border-radius:8px;color:#000;text-decoration:none;font-size:16px;font-weight:600;transition:all .3s ease}.project-link:hover{background:transparent;color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 25px #ffc6004d}.iframe-container{position:relative;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:12px;overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);min-height:800px}.project-iframe{width:100%;height:800px;border:none;background:#fff}.more-projects{text-align:center;padding:60px 0;border-top:1px solid rgba(255,255,255,.08)}.more-projects h2{font-size:clamp(1.8rem,3vw,2.2rem);margin:0 0 24px;color:var(--text);font-weight:600}.more-projects p{max-width:600px;margin:0 auto;color:var(--muted);line-height:1.7;font-size:1.1rem}@media (max-width: 1024px){.project-section{grid-template-columns:1fr;gap:40px}.iframe-container{order:-1}}@media (max-width: 768px){.client-projects-page{padding:20px 16px}.project-section{gap:32px}.project-iframe{height:500px}.iframe-container{min-height:500px}.page-header{margin-bottom:40px}.more-projects{padding:40px 0}.tech-tags{gap:6px}.tech-tag{font-size:12px;padding:4px 10px}}@media (max-width: 480px){.project-details p,.more-projects p{font-size:1rem}.project-iframe{height:400px}.iframe-container{min-height:400px}}:root{--bg: #0b0b0c;--text: #ffffff;--accent: #ffc600;--muted: #9aa0a6}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.app-shell{min-height:100%;display:grid;grid-template-rows:auto 1fr auto}.header{padding:20px;border-bottom:1px solid rgba(255,255,255,.08)}.header-content{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:20px}.brand-section{text-align:center;justify-self:center}.header-nav-left{justify-self:start}.header-nav-right{justify-self:end}.brand{margin:0;font-size:clamp(32px,5vw,56px);letter-spacing:.5px}.tagline{margin:6px 0 0;color:var(--muted);font-size:clamp(14px,2.2vw,18px)}.header-nav{display:flex;gap:8px}.main-area{display:grid;place-items:stretch}.site-nav{display:grid;grid-auto-flow:column;gap:8px;padding:16px 20px 24px;border-top:1px solid rgba(255,255,255,.08);justify-content:center}.nav-link{text-decoration:none;padding:10px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.12);color:var(--text);font-size:15px;transition:transform .15s ease,background .15s ease,border-color .15s ease}.nav-link:hover{transform:translateY(-1px);border-color:#ffffff59}.nav-link-active{background:#ffffff14;border-color:transparent}.site-footer{text-align:center;color:var(--muted);font-size:13px;padding:0 0 24px}.page{padding:24px;max-width:900px;margin:0 auto}@media (max-width: 640px){.header-content{grid-template-columns:1fr auto 1fr;gap:12px;align-items:center}.brand-section{text-align:center;order:1;grid-column:1 / -1}.header-nav-left{order:2;justify-self:start;display:flex;gap:8px}.header-nav-right{order:3;justify-self:end}.nav-link{padding:8px 12px;font-size:14px}}
