:root{--bg: #091018;--panel: #101a24;--panel-border: #1f2f3f;--text: #f2f7ff;--muted: #a7b8cc;--accent: #3ecf8e;--accent-soft: #203a35}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:radial-gradient(circle at 15% 10%,#122535 0%,transparent 45%),radial-gradient(circle at 80% 0%,#12302a 0%,transparent 40%),var(--bg);color:var(--text)}a{color:inherit}.page{max-width:1100px;margin:0 auto;padding:2rem 1.1rem 3rem;display:grid;gap:1rem}.panel{background:linear-gradient(160deg,#101a24f0,#0c141deb);border:1px solid var(--panel-border);border-radius:16px;padding:1.2rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.intro{display:grid;gap:1.4rem}.hero .eyebrow{margin:0 0 .65rem;color:var(--accent);letter-spacing:.18em;text-transform:uppercase;font-size:.78rem;font-weight:700}.hero h1{margin:0;font-size:clamp(2rem,5vw,3rem);line-height:1.08;letter-spacing:-.03em}.hero h2{margin:.65rem 0 .8rem;font-weight:500;font-size:clamp(1rem,2.5vw,1.28rem);color:var(--muted)}.hero p{margin:0;max-width:65ch;line-height:1.72;color:#d2e1ef}.social-links{display:flex;align-items:center;flex-wrap:wrap;gap:.9rem}.social-links a{display:inline-flex;align-items:center;justify-content:center;min-height:40px;min-width:40px;border-radius:10px;border:1px solid transparent;transition:transform .2s ease,border-color .2s ease,background .2s ease}.social-links a:hover{transform:translateY(-1px);border-color:var(--panel-border);background:#ffffff08}.split{display:grid;gap:1.2rem}.section-title{margin:0 0 .7rem;text-transform:uppercase;letter-spacing:.09em;font-size:.84rem;color:var(--muted);font-weight:700}.copy{margin:0;line-height:1.64;color:#d4e2ef}.list{margin:0;padding-left:1rem;color:#d4e2ef;display:grid;gap:.45rem}.tags{margin:0;padding:0;list-style:none;display:flex;gap:.6rem;flex-wrap:wrap}.tags li{padding:.4rem .7rem;border-radius:999px;border:1px solid #274657;background:#3ecf8e14;color:#d9f9ec;font-size:.88rem}.experience .role{margin:0;font-size:1.1rem;font-weight:700}.experience .org{margin:.25rem 0 0;color:#c9dcf0}.experience .duration{margin:.3rem 0 .8rem;color:var(--muted);font-size:.9rem}.experience-list{margin:.8rem 0 0;padding-left:1rem;display:grid;gap:.45rem;color:#d4e2ef}.project-grid{display:grid;gap:.8rem}.project-card{padding:.95rem;border-radius:12px;border:1px solid #264253;background:linear-gradient(160deg,#0f1a24f2,#0b121af2);transition:transform .2s ease,box-shadow .2s ease}.project-card h4{margin:0 0 .5rem}.project-card p{margin:0;color:#c9dae8;line-height:1.55;font-size:.96rem}.project-card:hover{transform:translateY(-4px);box-shadow:0 10px 28px #00000040}.project-title-link{color:#d1ff86;text-decoration:none;font-weight:600;transition:all .2s ease}.project-title-link .arrow{margin-left:6px;opacity:.6;transition:transform .2s ease,opacity .2s ease}.project-card:hover .project-title-link{color:#caff4a;text-shadow:0 0 10px rgba(158,240,26,.75)}.project-card:hover .project-title-link .arrow{transform:translate(4px);opacity:1}.project-link{display:block;text-decoration:none;color:inherit}.project-link:hover .project-title-link{color:#caff4a;text-shadow:0 0 10px rgba(158,240,26,.75)}.project-link:hover .arrow{transform:translate(4px);opacity:1}.footer-panel{padding-top:1rem;padding-bottom:1rem}.footer{display:grid;gap:.6rem}.footer-cta{margin:0;color:#dce8f3;font-weight:600}.footer-contact{display:flex;gap:.55rem;flex-wrap:wrap;align-items:center;color:var(--muted)}.footer-contact a{color:#e5f0fa;text-decoration:none}.footer-contact a:hover{color:var(--accent)}.footer-separator{color:#587087}.footer-links{display:flex;gap:.85rem;flex-wrap:wrap}.footer-links a{color:#d7e8f8;text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s ease,color .2s ease}.footer-links a:hover{color:var(--accent);border-color:#3ecf8eb3}.footer-copy{margin:.1rem 0 0;color:#93a7ba;font-size:.88rem}@media(min-width:768px){.page{padding:2.4rem 1.6rem 3.5rem;gap:1.15rem}.panel{padding:1.5rem}.split{grid-template-columns:1.2fr 1fr;align-items:start}.project-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
