@import url(https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700&family=Source+Code+Pro:wght@400;600&family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Lora:ital,wght@0,400;0,500;1,400&display=swap);body,html{overflow-x:hidden}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}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}@tailwind base;@tailwind components;@tailwind utilities;.navbar{align-items:flex-end;display:flex;flex-direction:column;gap:6px;position:fixed;right:28px;top:50%;transform:translateY(-50%);z-index:100}.nav-item{align-items:center;cursor:pointer;display:flex;gap:10px;padding:6px 0;text-decoration:none}.nav-label{color:#e8e8e847;font-family:Courier New,Courier,monospace;font-size:11px;letter-spacing:2.5px;opacity:1;text-transform:uppercase;transform:translateX(0);transition:opacity .25s ease,transform .25s ease,color .25s ease,text-shadow .25s ease;white-space:nowrap}.nav-dot{background:#e8e8e82e;border-radius:50%;flex-shrink:0;height:7px;transition:background .25s ease,box-shadow .25s ease,transform .25s ease;width:7px}.nav-item:hover .nav-label{color:#e8e8e8a6;opacity:1;transform:translateX(0)}.nav-item:hover .nav-dot{background:#db3a34;box-shadow:0 0 8px #db3a34d9,0 0 18px #db3a344d;transform:scale(1.35)}.nav-item.active .nav-label{color:#db3a34b3;opacity:1;text-shadow:0 0 8px #db3a3466;transform:translateX(0)}.nav-item.active .nav-dot{animation:dotPulse 2.2s ease-in-out infinite;background:#db3a34;box-shadow:0 0 8px #db3a34d9,0 0 18px #db3a344d}@keyframes dotPulse{0%,to{box-shadow:0 0 6px #db3a34b3,0 0 14px #db3a3440}50%{box-shadow:0 0 12px #db3a34,0 0 28px #db3a3473}}.nav-divider{align-self:center;background:#177e8940;height:24px;margin:6px 3px;width:1px}.nav-item--external .nav-dot{background:#177e8940;height:5px;width:5px}.nav-item--external:hover .nav-dot{background:#177e89;box-shadow:0 0 8px #177e89d9,0 0 18px #177e894d;transform:scale(1.4)}.nav-item--external:hover .nav-label{color:#177e89bf;text-shadow:0 0 8px #177e8966}@media (max-width:768px){.navbar{display:none}}#home{align-items:center;display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:0 80px 80px;position:relative}.matrix-canvas{height:100%;inset:0;width:100%;z-index:0}#home:after,.matrix-canvas{pointer-events:none;position:absolute}#home:after{background:linear-gradient(180deg,#0000,#181718);bottom:0;content:"";height:140px;left:0;right:0;z-index:1}.hero-content{display:flex;flex-direction:column;max-width:700px;position:relative;width:100%;z-index:2}.hero-eyebrow{animation:heroFadeUp .6s ease .1s both;color:#177e89b3;font-family:Courier New,Courier,monospace;font-size:12px;letter-spacing:3px;margin:0 0 18px;text-transform:uppercase}.hero-eyebrow span{animation:heroBlink 2.8s ease-in-out 1.2s infinite;color:#177e89;text-shadow:0 0 8px #177e89b3}@keyframes heroBlink{0%,to{opacity:1}50%{opacity:.15}}.hero-name{animation:heroFadeUp .6s ease .25s both;color:#e8e8e8;cursor:pointer;display:inline-block;font-family:Franklin Gothic Medium,Arial Narrow,Arial,sans-serif;font-size:clamp(52px,7vw,88px);letter-spacing:1px;line-height:1;margin:0 0 12px;text-decoration:none;transition:color .3s ease,text-shadow .3s ease}.hero-name:hover{color:#177e89;text-shadow:0 0 18px #177e89d9,0 0 40px #177e8966}.hero-role{animation:heroFadeUp .6s ease .4s both;color:#db3a34;font-family:Franklin Gothic Medium,Arial Narrow,Arial,sans-serif;font-size:15px;letter-spacing:5px;margin:0 0 32px;text-shadow:0 0 8px #db3a3466;text-transform:uppercase}.hero-bio{animation:heroFadeUp .6s ease .55s both;color:#e8e8e894;font-family:Roboto,sans-serif;font-size:16px;line-height:1.8;margin:0 0 40px;max-width:560px}.hero-ctas{animation:heroFadeUp .6s ease .7s both;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:32px}.cta-primary,.cta-secondary{border-radius:3px;cursor:pointer;font-family:Franklin Gothic Medium,Arial Narrow,Arial,sans-serif;font-size:12px;letter-spacing:2.5px;padding:13px 30px;text-decoration:none;text-transform:uppercase;transition:background .25s ease,box-shadow .25s ease,transform .2s ease}.cta-primary{background:#177e8912;border:1px solid #177e8980;color:#177e89}.cta-primary:hover{background:#177e8926;border-color:#177e89;box-shadow:0 0 18px #177e8959;transform:translateY(-2px)}.cta-secondary{background:#db3a340d;border:1px solid #db3a3473;color:#db3a34}.cta-secondary:hover{background:#db3a3421;border-color:#db3a34;box-shadow:0 0 18px #db3a3459;transform:translateY(-2px)}.hero-quote{animation:heroFadeUp .6s ease 1s both;border-left:2px solid #177e892e;color:#e8e8e833;font-family:Courier New,Courier,monospace;font-size:12px;line-height:1.75;margin-top:44px;max-width:480px;padding-left:16px}@keyframes heroFadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@media (max-width:800px){#home{padding:80px 28px}.hero-content{max-width:100%}}@media (max-width:480px){#home{align-items:flex-start;padding:80px 20px 72px}.hero-eyebrow{font-size:10px;letter-spacing:2.5px;margin-bottom:14px}.hero-name{font-size:clamp(44px,11vw,64px);margin:0 0 10px}.hero-role{font-size:12px;letter-spacing:4px;margin:0 0 24px}.hero-bio{font-size:14px;line-height:1.75;margin:0 0 28px;max-width:100%}.hero-ctas{gap:12px;margin-bottom:24px}.cta-primary,.cta-secondary{font-size:10px;letter-spacing:2px;padding:11px 22px}.hero-quote{font-size:11px;margin-top:32px;max-width:100%}}@media (max-width:375px){#home{padding:72px 14px 60px}.hero-name{font-size:clamp(38px,12vw,52px)}.cta-primary,.cta-secondary{justify-content:center;text-align:center;width:100%}.hero-ctas{flex-direction:column;gap:10px}}.skills-strip{margin-bottom:48px}.skills-label{color:#177e898c;display:block;font-family:Courier New,Courier,monospace;font-size:10px;letter-spacing:3px;margin-bottom:14px;text-transform:uppercase}.skills-tags{display:flex;flex-wrap:wrap;gap:8px}.skill-tag{background:#177e8912;border:1px solid #177e8940;border-radius:3px;color:#e8e8e899;cursor:default;font-family:Courier New,Courier,monospace;font-size:11px;letter-spacing:1.2px;padding:5px 12px;text-transform:uppercase;transition:color .2s ease,border-color .2s ease,background .2s ease,box-shadow .2s ease;white-space:nowrap}.skill-tag:hover{background:#177e8924;border-color:#177e8999;box-shadow:0 0 10px #177e8933;color:#177e89}@media (max-width:480px){.skills-strip{margin-bottom:32px}.skill-tag{font-size:10px;letter-spacing:.8px;padding:4px 10px}}:root{--type-project:#177e89;--type-work:#db3a34;--type-education:gold}.projects-section{background-color:#0c1818;background-image:linear-gradient(#177e890a 1px,#0000 0),linear-gradient(90deg,#177e890a 1px,#0000 0);background-size:50px 50px;color:#e8e8e8;display:flex;min-height:100vh;opacity:0;padding:80px 180px 120px 60px;position:relative;transform:translateY(20px);transition:opacity 1s ease,transform 1s ease,visibility 1s;visibility:hidden;z-index:1}.projects-section.visible{opacity:1;transform:translateY(0);visibility:visible}.timeline{flex-shrink:0;position:relative;width:220px}.timeline-line{background:linear-gradient(180deg,#0000 0,#084c61 5%,#177e89 50%,#084c61 95%,#0000);box-shadow:0 0 8px #177e8966;height:100%;left:178px;position:absolute;top:0;width:2px}.timeline-entry{align-items:center;display:flex;left:0;position:absolute;transition:top .4s ease;width:100%}.timeline-label{color:#e8e8e847;font-family:Courier New,Courier,monospace;font-size:10.5px;letter-spacing:.8px;position:absolute;right:68px;text-align:right;transform:translateY(-50%);transition:color .25s ease;white-space:nowrap}.timeline-entry:hover .timeline-label{color:#e8e8e8b3}.timeline-marker{border-radius:50%;height:20px;left:168px;position:absolute;transform:translateY(-50%);transition:transform .25s ease,box-shadow .25s ease;width:20px;z-index:1}.timeline-entry--project .timeline-marker{background:#177e89;background:var(--type-project);box-shadow:0 0 8px #177e89b3,0 0 18px #177e894d}.timeline-entry--work .timeline-marker{background:#db3a34;background:var(--type-work);box-shadow:0 0 8px #db3a34b3,0 0 18px #db3a344d}.timeline-entry--education .timeline-marker{background:gold;background:var(--type-education);box-shadow:0 0 8px #ffd700b3,0 0 18px #ffd7004d}.timeline-entry:hover .timeline-marker{transform:translateY(-50%) scale(1.3)}.timeline-entry--project:hover .timeline-marker{box-shadow:0 0 14px #177e89,0 0 30px #177e8980}.timeline-entry--work:hover .timeline-marker{box-shadow:0 0 14px #db3a34,0 0 30px #db3a3480}.timeline-entry--education:hover .timeline-marker{box-shadow:0 0 14px gold,0 0 30px #ffd70080}.projects-content{display:flex;flex:1 1;flex-direction:column;min-width:0;padding-left:48px}.projects-title{color:#e8e8e8;font-family:Franklin Gothic Medium,Arial Narrow,Arial,sans-serif;font-size:48px;letter-spacing:2px;margin:0 0 52px}.timeline-hint{align-items:center;color:#177e89bf;display:flex;font-family:Courier New,Courier,monospace;font-size:11.5px;font-weight:700;gap:8px;letter-spacing:1.8px;margin:-16px 0 40px;text-transform:uppercase;-webkit-user-select:none;user-select:none}.timeline-hint-arrow{animation:hint-nudge 2.4s ease-in-out infinite;color:#177e89bf;display:inline-block}@keyframes hint-nudge{0%,to{opacity:.5;transform:translateX(0)}50%{opacity:1;transform:translateX(4px)}}.project-card{background:hsla(0,0%,100%,.018);border:1px solid hsla(0,0%,100%,.065);border-left:3px solid #0000;border-radius:5px;margin-bottom:40px;padding:24px 32px 20px;position:relative;transition:border-color .3s ease,box-shadow .3s ease,transform .3s ease,background .3s ease}.project-card--project{border-left-color:#177e898c}.project-card--work{border-left-color:#db3a348c}.project-card--education{border-left-color:#ffd70073}.project-card.clickable{cursor:pointer}.project-card:hover{transform:translateY(-3px)}.project-card--project:hover{background:rgba(23,126,137,.055);border-color:#177e8973 #177e8973 #177e8973 #177e89;border-left-color:var(--type-project);box-shadow:0 4px 24px #177e891a,inset 0 0 18px #177e8908}.project-card--work:hover{background:rgba(219,58,52,.045);border-color:#db3a3466 #db3a3466 #db3a3466 #db3a34;border-left-color:var(--type-work);box-shadow:0 4px 24px #db3a3417,inset 0 0 18px #db3a3408}.project-card--education:hover{background:rgba(255,215,0,.025);border-color:#ffd7004d #ffd7004d #ffd7004d gold;border-left-color:var(--type-education);box-shadow:0 4px 24px #ffd70012,inset 0 0 18px #ffd70005}.project-card:focus-visible{outline:2px solid #177e89;outline-offset:3px}.card-meta{flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:12px}.card-meta,.card-meta-left{align-items:center;display:flex}.card-meta-left{gap:8px}.card-meta-right{align-items:center;display:flex;gap:10px}.card-type{border-radius:2px;font-family:Courier New,Courier,monospace;font-size:10px;font-weight:600;letter-spacing:2px;padding:3px 9px;text-transform:uppercase;white-space:nowrap}.card-type--project{background:#177e891a;border:1px solid #177e8947;color:#177e89;color:var(--type-project)}.card-type--work{background:#db3a3414;border:1px solid #db3a3440;color:#db3a34;color:var(--type-work)}.card-type--education{background:#ffd70012;border:1px solid #ffd70038;color:gold;color:var(--type-education)}.card-status{border:1px solid #ffd70033;border-radius:2px;color:#ffd7008c;letter-spacing:1.5px;padding:3px 9px;text-transform:uppercase}.card-date,.card-status{font-family:Courier New,Courier,monospace;font-size:10px;white-space:nowrap}.card-date{color:#e8e8e859;display:none;letter-spacing:1px}.card-location{color:#e8e8e838;font-family:Courier New,Courier,monospace;font-size:11px;letter-spacing:1px;white-space:nowrap}.card-location:before{content:"·";margin-right:6px;opacity:.4}.card-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:10px}.card-title{color:#e8e8e8;font-family:Franklin Gothic Medium,Arial Narrow,Arial,sans-serif;font-size:19px;letter-spacing:.3px;line-height:1.3;margin:0;transition:color .25s ease}.project-card--project:hover .card-title{color:#177e89;color:var(--type-project)}.project-card--work:hover .card-title{color:#db3a34;color:var(--type-work)}.project-card--education:hover .card-title{color:gold;color:var(--type-education)}.card-org{color:#e8e8e852;flex-shrink:0;font-family:Courier New,Courier,monospace;font-size:12px;letter-spacing:.8px;white-space:nowrap}.card-desc{color:#e8e8e880;font-size:14px;line-height:1.75;margin:0 0 16px}.card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}.card-tag{border-radius:2px;font-family:Courier New,Courier,monospace;font-size:10px;letter-spacing:.8px;padding:2px 8px;text-transform:uppercase}.card-tag--project{background:rgba(23,126,137,.045);border:1px solid #177e892e;color:#177e89a6}.card-tag--work{background:rgba(219,58,52,.035);border:1px solid #db3a3429;color:#db3a34a6}.card-tag--education{background:rgba(255,215,0,.025);border:1px solid #ffd70021;color:#ffd7008c}.card-cta{display:block;font-family:Courier New,Courier,monospace;font-size:11px;letter-spacing:2px;opacity:0;text-transform:uppercase;transition:opacity .3s ease}.project-card--project .card-cta{color:#177e89;color:var(--type-project)}.project-card--work .card-cta{color:#db3a34;color:var(--type-work)}.project-card.clickable:hover .card-cta{opacity:1}.project-card--work:hover .card-cta{color:#db3a34;color:var(--type-work)}.project-card--education:hover .card-cta{color:gold;color:var(--type-education)}@media (max-width:768px){.projects-section{padding:60px 28px 80px 0}.timeline{flex-shrink:0;width:36px}.timeline-line{left:17px}.timeline-marker{height:16px;left:9px;width:16px}.timeline-label{display:none}.projects-content{padding-left:20px}.projects-title{font-size:36px;letter-spacing:1px;margin-bottom:40px}.project-card{margin-bottom:28px;padding:20px 20px 16px}}@media (max-width:480px){.projects-section{padding:44px 14px 60px 0}.timeline{width:26px}.timeline-line{left:12px}.timeline-marker{height:14px;left:5px;width:14px}.projects-content{padding-left:14px}.projects-title{font-size:28px;letter-spacing:.5px;margin-bottom:32px}.project-card{border-radius:4px;margin-bottom:20px;padding:16px 14px 14px}.card-date{display:block;text-align:right}.card-meta{align-items:flex-start;margin-bottom:10px}.card-meta-right{align-items:flex-end;display:flex;flex-direction:column;gap:2px}.card-location:before{display:none}.card-location{font-size:10px;text-align:right}.card-header{align-items:flex-start;flex-direction:column;gap:4px}.card-title{font-size:16px}.card-org{font-size:11px}.card-desc{font-size:13px;line-height:1.7}.card-tag{font-size:9px;padding:2px 7px}.project-card.clickable .card-cta{opacity:.55}}.footer{background-color:#0c1818;border-top:1px solid #177e8926;opacity:0;padding:90px 80px 50px;position:relative;transition:opacity 1s ease,visibility 1s;visibility:hidden;z-index:1}.footer.visible{opacity:1;visibility:visible}.footer-inner{align-items:center;display:flex;flex-direction:column;gap:32px;margin:0 auto;max-width:700px;text-align:center}.footer-headline{width:100%}.footer-eyebrow{color:#177e8999;display:block;font-family:Courier New,Courier,monospace;font-size:11px;letter-spacing:3px;margin-bottom:14px;text-transform:uppercase}.footer-title{color:#e8e8e8;font-family:Franklin Gothic Medium,Arial Narrow,Arial,sans-serif;font-size:clamp(32px,4vw,52px);letter-spacing:1px;line-height:1.1;margin:0 0 16px}.footer-sub{color:#e8e8e880;font-size:15px;line-height:1.7;margin:0 auto;max-width:420px}.footer-links{align-items:center;display:flex;flex-direction:column;gap:20px}.footer-cta{background:#177e890f;border:1px solid #177e8973;border-radius:3px;color:#177e89;font-family:Franklin Gothic Medium,Arial Narrow,Arial,sans-serif;font-size:13px;letter-spacing:2.5px;padding:13px 32px;text-decoration:none;text-transform:uppercase;transition:background .25s ease,box-shadow .25s ease,transform .2s ease;white-space:nowrap}.footer-cta:hover{background:#177e8924;border-color:#177e89;box-shadow:0 0 18px #177e8959;transform:translateY(-2px)}.footer-socials{display:flex;flex-wrap:wrap;gap:20px;justify-content:center}.footer-social{border-bottom:1px solid #0000;color:#e8e8e859;font-family:Courier New,Courier,monospace;font-size:11px;letter-spacing:2px;padding-bottom:2px;text-decoration:none;text-transform:uppercase;transition:color .25s ease,border-color .25s ease,text-shadow .25s ease}.footer-social:hover{border-color:#177e8980;color:#177e89;text-shadow:0 0 8px #177e8999}.footer-bottom{align-items:center;border-top:1px solid #177e891a;display:flex;gap:32px;justify-content:center;margin-left:auto;margin-right:auto;margin-top:64px;max-width:700px;padding-top:24px}.footer-built,.footer-copy{color:#e8e8e833;font-family:Courier New,Courier,monospace;font-size:10px;letter-spacing:2px;text-transform:uppercase}@media (max-width:768px){.footer{padding:64px 40px 40px}}@media (max-width:480px){.footer{padding:52px 22px 36px}.footer-title{font-size:clamp(26px,7vw,40px)}.footer-sub{font-size:13px}.footer-bottom{flex-direction:column;gap:12px;margin-top:44px}}@media (max-width:375px){.footer{padding:44px 16px 28px}.footer-cta{display:block;text-align:center;width:100%}.footer-socials{gap:14px}}.cursor-spotlight{background:radial-gradient(circle,#177e8912 0,#0000 70%);border-radius:50%;height:360px;pointer-events:none;position:fixed;transform:translate(-50%,-50%);transition:left .08s linear,top .08s linear;width:360px;will-change:left,top;z-index:0}@media (hover:none){.cursor-spotlight{display:none}}:root{--warm-bg:#0e0c0a;--warm-amber:#c9963a;--warm-amber-d:#a07828;--warm-text:#ede8e0;--warm-muted:#ede8e07a;--warm-faint:#ede8e02e;--warm-border:#c9963a33;--warm-glow:0 0 20px #c9963a40}.personal-overlay{background-color:#0e0c0a;background-color:var(--warm-bg);background-image:radial-gradient(#c9963a0f 1px,#0000 0),conic-gradient(from 200deg at 10% 5%,#c9963a12 0deg,#0000 52deg),linear-gradient(125deg,#0000 22%,#c9963a0a 42%,#c9963a08 56%,#0000 74%),radial-gradient(ellipse at 25% 20%,#c9963a17 0,#0000 55%),radial-gradient(ellipse at 50% 50%,#c9963a0f 0,#0000 50%),radial-gradient(ellipse at 75% 50%,#c9963a12 0,#0000 48%),radial-gradient(ellipse at 25% 80%,#c9963a17 0,#0000 55%),radial-gradient(ellipse at 75% 80%,#c9963a14 0,#0000 55%);background-size:28px 28px,100% 100%,100% 100%,100% 100%,100% 100%,100% 100%,100% 100%,100% 100%;inset:0;opacity:0;overflow-x:hidden;overflow-y:auto;pointer-events:none;position:fixed;transform:translateY(100%);transition:transform .6s cubic-bezier(.16,1,.3,1),opacity .45s ease;z-index:1001}.personal-overlay.open{opacity:1;pointer-events:all;transform:translateY(0)}.personal-overlay:before{animation:ambientPulse 12s ease-in-out infinite;background:radial-gradient(ellipse 22% 18% at 100% 75%,#c9963a21 0,#0000 100%);content:"";inset:0;pointer-events:none;position:fixed;z-index:0}@keyframes ambientPulse{0%,to{opacity:.35}50%{opacity:1}}.personal-close{background:linear-gradient(180deg,#0e0c0a 55%,#0000);background:linear-gradient(to bottom,var(--warm-bg) 55%,#0000);display:flex;justify-content:flex-end;padding:24px 56px 0;position:sticky;top:0;z-index:10}.personal-close-btn{background:none;border:1px solid #ede8e047;border-radius:30px;color:#ede8e08c;cursor:pointer;font-family:Courier New,Courier,monospace;font-size:10px;letter-spacing:2.5px;padding:8px 22px;text-transform:uppercase;transition:color .25s ease,border-color .25s ease,box-shadow .25s ease}.personal-close-btn:hover{border-color:#c9963a8c;box-shadow:0 0 20px #c9963a40;box-shadow:var(--warm-glow);color:#c9963a;color:var(--warm-amber)}.personal-content{margin:0 auto;max-width:780px;padding:32px 80px 140px;position:relative;z-index:1}.personal-header{border-bottom:1px solid #c9963a33;border-bottom:1px solid var(--warm-border);margin-bottom:80px;padding-bottom:56px}.personal-eyebrow{color:#c9963a;color:var(--warm-amber);display:block;font-family:Courier New,Courier,monospace;font-size:13px;letter-spacing:3px;margin-bottom:20px;opacity:.65;text-transform:uppercase}.personal-title{color:#ede8e0;color:var(--warm-text);font-family:Playfair Display,Georgia,serif;font-size:clamp(42px,6vw,72px);font-weight:700;letter-spacing:-.5px;line-height:1.08;margin:0 0 24px}.personal-intro{color:#ede8e07a;color:var(--warm-muted);font-family:Lora,Georgia,serif;font-size:17px;line-height:1.9;max-width:540px}.personal-section{margin-bottom:80px}.personal-section-label{color:#c9963a;color:var(--warm-amber);display:block;font-family:Courier New,Courier,monospace;font-size:13px;letter-spacing:2.5px;margin-bottom:28px;opacity:.5;text-transform:uppercase}.hobbies-grid{grid-gap:0 32px;display:grid;gap:0 32px;grid-template-columns:repeat(2,1fr)}.hobby-card{border-left:2px solid #c9963a38;padding:20px 0 20px 20px;transition:border-color .35s ease}.hobby-card:hover{border-color:#c9963a99}.hobby-name{color:#ede8e0;color:var(--warm-text);display:block;font-family:Playfair Display,Georgia,serif;font-size:18px;font-style:italic;font-weight:400;margin-bottom:6px}.hobby-desc{color:#ede8e07a;color:var(--warm-muted);font-family:Lora,Georgia,serif;font-size:12.5px;font-style:italic;line-height:1.7}.personal-section--poems .personal-section-label{margin-bottom:48px}.poems-nav{padding:0 52px;position:relative}.poem-carousel{transition:opacity .32s ease}.poems-arrow{-webkit-tap-highlight-color:transparent;background:none;border:none;color:#c9963a;color:var(--warm-amber);cursor:pointer;font-size:26px;line-height:1;opacity:.28;padding:0;position:absolute;top:50%;touch-action:manipulation;transform:translateY(calc(-50% - 40px));transition:opacity .3s ease}.poems-arrow:hover{opacity:.7}.poems-arrow--prev{left:0}.poems-arrow--next{right:0}.poems-nav--centered .poems-arrow{transform:translateY(-50%)}.poem-block{margin-bottom:56px;padding:0;text-align:center}.poem-block:last-child{padding-bottom:0}.poem-title{color:#c9963a;color:var(--warm-amber);font-family:Playfair Display,Georgia,serif;font-size:28px;font-style:italic;font-weight:400;margin:0 0 36px;opacity:.82}.poem-body{color:#ede8e099;font-family:Lora,Georgia,serif;font-size:16px;font-style:italic;line-height:2.2;margin:0 auto;max-width:500px;white-space:pre-line}.poem-body-wrap,.poem-body-wrap--clipped{-webkit-mask-image:linear-gradient(90deg,#0000,#000 1%,#000 99%,#0000);mask-image:linear-gradient(90deg,#0000,#000 1%,#000 99%,#0000)}.poem-body-wrap--clipped{overflow:hidden;position:relative;transition:height 1.1s cubic-bezier(.4,0,.2,1) .08s}.poem-block--expanded .poem-body-wrap--clipped{transition:height 1.85s cubic-bezier(.25,1,.35,1)}.poem-toggle{-webkit-tap-highlight-color:transparent;align-items:center;background:none;border:none;cursor:pointer;display:flex;gap:18px;margin:48px auto 0;padding:10px 0;position:relative;touch-action:manipulation;z-index:2}.poem-toggle-rule{background:#c9963a;background:var(--warm-amber);display:block;height:1px;opacity:.28;transition:width .55s cubic-bezier(.4,0,.2,1),opacity .35s ease;width:44px}.poem-toggle--open .poem-toggle-rule,.poem-toggle:hover .poem-toggle-rule{opacity:.52;width:68px}.poem-toggle-label{color:#c9963a;color:var(--warm-amber);font-family:Courier New,monospace;font-size:9px;letter-spacing:3.8px;opacity:.42;text-transform:uppercase;transition:opacity .35s ease,letter-spacing .55s cubic-bezier(.4,0,.2,1);white-space:nowrap}.poem-toggle--open .poem-toggle-label,.poem-toggle:hover .poem-toggle-label{letter-spacing:5px;opacity:.72}.hex-viewport{background:radial-gradient(ellipse 88% 82% at 50% 50%,#0000 42%,#00000042 80%);cursor:grab;height:520px;margin-top:48px;-webkit-mask-composite:destination-in;-webkit-mask-composite:source-in,xor;mask-composite:intersect;-webkit-mask-image:linear-gradient(90deg,#0000,#000 13%,#000 87%,#0000),linear-gradient(180deg,#0000,#000 10%,#000 90%,#0000);mask-image:linear-gradient(90deg,#0000,#000 13%,#000 87%,#0000),linear-gradient(180deg,#0000,#000 10%,#000 90%,#0000);overflow:visible;touch-action:none;user-select:none;-webkit-user-select:none;width:100%}.hex-viewport.is-dragging{cursor:grabbing}.hex-hint{color:#c9963a;color:var(--warm-amber);font-family:Courier New,Courier,monospace;font-size:10px;letter-spacing:2.8px;margin-top:22px;opacity:.38;text-align:center;text-transform:uppercase;transition:opacity .3s ease}.hex-hint:hover{opacity:.65}.hex-canvas{position:relative}.hex-cell{-webkit-user-drag:none;cursor:pointer;height:179px;position:absolute;transform-origin:center center;transition:filter .3s ease;-webkit-user-select:none;user-select:none;width:155px;will-change:transform}.hex-cell:hover{filter:drop-shadow(0 6px 20px rgba(201,150,58,.65));z-index:5}.hex-inner{clip-path:path("M 63.1 6 Q 73.5 0 83.9 6 L 136.6 36.75 Q 147 42.75 147 54.75 L 147 116.25 Q 147 128.25 136.6 134.25 L 83.9 165 Q 73.5 171 63.1 165 L 10.4 134.25 Q 0 128.25 0 116.25 L 0 54.75 Q 0 42.75 10.4 36.75 Z");inset:4px;overflow:hidden;position:absolute;transform-origin:center center;transition:filter .35s ease,transform .45s cubic-bezier(.25,1,.35,1)}.hex-cell:hover .hex-inner{filter:brightness(1.12) saturate(1.1);transform:scale(1.08)}.hex-inner img{-webkit-user-drag:none;draggable:false;display:block;height:100%;object-fit:cover;pointer-events:none;-webkit-user-select:none;user-select:none;width:100%}.lightbox{align-items:center;animation:lbOverlayIn .4s ease forwards;backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);background:#060402f7;display:flex;inset:0;justify-content:center;position:fixed;z-index:1002}@keyframes lbOverlayIn{0%{opacity:0}to{opacity:1}}@keyframes lbReveal{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}.lightbox-img{animation:lbReveal .55s cubic-bezier(.25,1,.35,1) forwards;border-radius:4px;display:block;max-height:80vh;max-width:min(78vw,900px);object-fit:contain}.lightbox-nav{background:none;border:none;color:#c9963a;color:var(--warm-amber);cursor:pointer;line-height:0;opacity:.25;padding:28px 22px;position:fixed;top:50%;transform:translateY(-50%);transition:opacity .3s ease}.lightbox-nav:hover{opacity:.75}.lightbox-nav--prev{left:0}.lightbox-nav--next{right:0}.lightbox-counter{bottom:36px;color:#c9963a73;font-family:Courier New,Courier,monospace;font-size:13px;left:50%;letter-spacing:4px;pointer-events:none;position:fixed;transform:translateX(-50%)}@media (max-width:768px){.personal-close{padding:18px 32px 0}.personal-content{padding:28px 40px 100px}.personal-header{margin-bottom:56px;padding-bottom:40px}.personal-intro{font-size:16px;max-width:100%}.personal-section{margin-bottom:64px}.personal-section--poems .personal-section-label{margin-bottom:36px}.poems-nav{padding:0 44px}.poem-body{max-width:100%}.hex-viewport{height:440px}.lightbox-nav{opacity:.45}.personal-trigger-section{padding:48px}.personal-trigger-card{padding:36px 36px 32px}}@media (max-width:480px){.personal-close{padding:16px 20px 0}.personal-content{max-width:100%;padding:24px 22px 72px}.personal-header{margin-bottom:44px;padding-bottom:32px}.personal-eyebrow{font-size:10px;letter-spacing:2.2px;margin-bottom:16px}.personal-title{font-size:clamp(34px,9vw,52px);margin:0 0 16px}.personal-intro{font-size:15px;line-height:1.85;max-width:100%}.personal-section{margin-bottom:48px}.personal-section-label{font-size:11px;letter-spacing:2px;margin-bottom:20px}.hobbies-grid{gap:0;grid-template-columns:1fr}.hobby-card{padding:14px 0 14px 16px}.hobby-name{font-size:16px}.hobby-desc{font-size:12px}.personal-section--poems .personal-section-label{margin-bottom:28px}.poems-nav{padding:0 36px}.poems-arrow{align-items:center;display:flex;font-size:20px;justify-content:center;min-height:44px;min-width:36px;padding:14px 8px}.poem-block{margin-bottom:40px}.poem-title{font-size:22px;margin:0 0 24px}.poem-body{font-size:14px;line-height:2;max-width:100%}.poem-toggle{gap:14px;margin-top:32px}.poem-toggle-rule{width:32px}.poem-toggle--open .poem-toggle-rule,.poem-toggle:hover .poem-toggle-rule{width:50px}.hex-viewport{height:360px;margin-top:32px}.hex-hint{font-size:9px;letter-spacing:2.2px;margin-top:16px}.lightbox-nav{align-items:center;display:flex;justify-content:center;min-height:44px;min-width:44px;opacity:.5;padding:20px 14px}.lightbox-img{max-height:75vh;max-width:92vw}.lightbox-counter{bottom:28px;font-size:11px;letter-spacing:3px}.personal-trigger-section{padding:40px 20px}.personal-trigger-card{padding:28px 22px 24px}.trigger-title{font-size:26px}.trigger-sub{font-size:13px;line-height:1.7}.trigger-btn{font-size:9px;padding:9px 22px}}.personal-trigger-section{background-color:#0c1818;display:flex;justify-content:center;opacity:0;padding:60px 80px;position:relative;transition:opacity 1s ease,visibility 1s;visibility:hidden;z-index:1}.personal-trigger-section.visible{opacity:1;visibility:visible}.personal-trigger-card{background:#c9963a08;border:1px solid #c9963a2e;border-radius:12px;cursor:pointer;max-width:500px;padding:44px 48px 40px;text-align:center;transition:border-color .3s ease,box-shadow .3s ease,background .3s ease,transform .3s ease;width:100%}.personal-trigger-card:hover{background:#c9963a0f;border-color:#c9963a61;box-shadow:0 0 40px #c9963a14;transform:translateY(-3px)}.trigger-eyebrow{color:#c9963a80;display:block;font-family:Courier New,Courier,monospace;font-size:10px;letter-spacing:3px;margin-bottom:16px;text-transform:uppercase}.trigger-title{color:#ede8e0;font-family:Playfair Display,Georgia,serif;font-size:32px;font-weight:700;letter-spacing:0;margin:0 0 14px;transition:color .25s ease,text-shadow .25s ease}.personal-trigger-card:hover .trigger-title{color:#c9963a;text-shadow:0 0 20px #c9963a4d}.trigger-sub{color:#ede8e061;font-family:Lora,Georgia,serif;font-size:14px;font-style:italic;line-height:1.75;margin:0 0 28px}.trigger-btn{background:#c9963a0d;border:1px solid #c9963a38;border-radius:30px;color:#c9963a99;cursor:pointer;font-family:Courier New,Courier,monospace;font-size:10px;letter-spacing:2.5px;padding:10px 28px;text-transform:uppercase;transition:color .25s ease,border-color .25s ease,box-shadow .25s ease}.personal-trigger-card:hover .trigger-btn{border-color:#c9963a80;box-shadow:0 0 16px #c9963a33;color:#c9963a}@font-face{font-family:notes;font-style:normal;font-weight:400;src:url(/static/media/notes.da91a9e8ac2bc9dbaf08.ttf) format("truetype")}@font-face{font-family:header;font-style:normal;font-weight:400;src:url(/static/media/header.bc9db3903019ef13a140.ttf) format("truetype")}:root{--bg:#181718;--bg-projects:#0c1818;--red:#db3a34;--teal:#177e89;--teal-dark:#084c61;--gold:gold;--text:#e8e8e8;--text-muted:#e8e8e880;--card-bg:#177e890f;--card-border:#177e892e;--glow-teal:0 0 8px #177e89d9,0 0 22px #177e8959;--glow-red:0 0 8px #db3a34d9,0 0 22px #db3a3459;--glow-gold:0 0 8px #ffd700d9,0 0 22px #ffd70059}*,:after,:before{box-sizing:border-box}body{background-color:#181718;background-color:var(--bg);background-image:linear-gradient(#177e890a 1px,#0000 0),linear-gradient(90deg,#177e890a 1px,#0000 0);background-size:50px 50px;color:#e8e8e8;color:var(--text);font-family:Roboto,sans-serif;margin:0;min-height:100vh;scroll-behavior:smooth}.App{position:relative}.App:before{background:radial-gradient(ellipse at 10% 45%,#db3a3412 0,#0000 52%),radial-gradient(ellipse at 88% 18%,#177e890f 0,#0000 52%);z-index:0}.App:after,.App:before{content:"";inset:0;pointer-events:none;position:fixed}.App:after{background:repeating-linear-gradient(0deg,#0000,#0000 3px,#0000000a 0,#0000000a 4px);z-index:999}.section{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:100vh;opacity:0;padding:80px 20px;position:relative;transform:translateY(20px);transition:opacity 1s ease,transform 1s ease,visibility 1s;visibility:hidden;z-index:1}.section.visible{opacity:1;transform:translateY(0);visibility:visible}@media (max-width:480px){.section{padding:60px 16px}}@media (max-width:768px){input,select,textarea{font-size:16px!important}}.portfolio-img{transition:box-shadow .4s ease,transform .4s ease}.portfolio-img:hover{box-shadow:0 0 8px #177e89d9,0 0 22px #177e8959;box-shadow:var(--glow-teal)}.carousel-container{aspect-ratio:16/9;height:auto;max-width:1200px;overflow:hidden;position:relative;width:100%}.carousel-container img{height:100%;max-height:110%;object-fit:contain;transition:opacity .5s ease,transform .5s ease;width:auto}.carousel-container img.hidden{opacity:0;transform:scale(.95)}.showcase-loading{align-items:center;background:#0a0a0f;color:#e8e8e84d;display:flex;font-family:Courier New,monospace;font-size:13px;justify-content:center;letter-spacing:2px;min-height:100vh}
/*# sourceMappingURL=main.64930e24.css.map*/