:root{--bg:#08101a;--fg:#cce4f8;--blue:#4fc3f7;--dim:#3a607a;--accent:#80deea;--warn:#fc0;--card-bg:#060d14;--border:#0d2535;--font:"Consolas", "Monaco", "Menlo", "Courier New", monospace}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--fg);font-family:var(--font);min-height:100vh;font-size:15px;line-height:1.7}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--dim);border-radius:3px}.navbar{z-index:100;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0d0d0df5;justify-content:space-between;align-items:center;padding:.7rem 2rem;display:flex;position:fixed;top:0;left:0;right:0}.navbar-brand{color:var(--blue);white-space:nowrap;font-size:.9rem;font-weight:700}.navbar-brand span{color:var(--dim)}.navbar-links{flex-wrap:wrap;gap:.15rem;list-style:none;display:flex}.navbar-links a{color:var(--dim);border:1px solid #0000;border-radius:3px;padding:.25rem .65rem;font-size:.82rem;transition:all .18s}.navbar-links a:hover{color:var(--blue);border-color:var(--blue)}.section{max-width:920px;margin:0 auto;padding:5.5rem 1.5rem 3rem}.section-header{align-items:center;gap:.75rem;margin-bottom:2.5rem;display:flex}.prompt{color:var(--blue);-webkit-user-select:none;user-select:none;font-weight:700}.section-title{color:var(--fg);letter-spacing:.06em;text-transform:uppercase;font-size:1rem}.divider{background:var(--border);flex:1;height:1px}.hero{align-items:center;max-width:920px;min-height:100vh;margin:0 auto;padding:2rem 1.5rem;display:flex}.hero-inner{width:100%}.terminal-window{border:1px solid var(--border);background:var(--card-bg);border-radius:6px;margin-bottom:2.5rem;overflow:hidden}.terminal-titlebar{border-bottom:1px solid var(--border);background:#050d05;align-items:center;gap:.45rem;padding:.55rem 1rem;display:flex}.dot{border-radius:50%;width:11px;height:11px}.dot-r{background:#ff5f57}.dot-y{background:#febc2e}.dot-g{background:#28c840}.terminal-title{color:var(--dim);margin-left:.5rem;font-size:.75rem}.terminal-body{padding:1.25rem 1.5rem}.t-line{opacity:0;gap:.6rem;margin-bottom:.35rem;font-size:.88rem;animation:.4s forwards fadeIn;display:flex}.t-line:first-child{animation-delay:.1s}.t-line:nth-child(2){animation-delay:.5s}.t-line:nth-child(3){animation-delay:.9s}.t-line:nth-child(4){animation-delay:1.3s}.t-line:nth-child(5){animation-delay:1.7s}.t-line:nth-child(6){animation-delay:2.1s}.t-line:nth-child(7){animation-delay:2.5s}.t-line:nth-child(8){animation-delay:2.9s}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.t-prompt{color:var(--blue);flex-shrink:0}.t-cmd{color:var(--accent)}.t-out{color:var(--fg)}.t-dim{color:var(--dim)}.t-blue{color:var(--blue)}.t-warn{color:var(--warn)}.t-blank{height:.7rem}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.cursor{background:var(--blue);vertical-align:text-bottom;width:.55em;height:1em;animation:1s step-end infinite blink;display:inline-block}.hero-name{color:var(--blue);letter-spacing:-.01em;margin-bottom:.6rem;font-size:clamp(2rem,6vw,3.2rem);font-weight:700;line-height:1.05}.hero-title{color:var(--accent);margin-bottom:.4rem;font-size:1.05rem}.hero-location{color:var(--dim);margin-bottom:2rem;font-size:.85rem}.hero-cta{flex-wrap:wrap;gap:1rem;display:flex}.btn{border:1px solid var(--blue);color:var(--blue);font-family:var(--font);cursor:pointer;background:0 0;border-radius:3px;padding:.5rem 1.3rem;font-size:.85rem;transition:all .18s;display:inline-block}.btn:hover{background:var(--blue);color:var(--bg)}.btn-secondary{border-color:var(--dim);color:var(--dim)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent);background:0 0}.about-text{color:#a0c8e0;max-width:680px;line-height:1.95}.about-text p{margin-bottom:1.1rem}.hl{color:var(--blue)}.hl-accent{color:var(--accent)}.exp-list{flex-direction:column;gap:1.4rem;display:flex}.exp-card{border:1px solid var(--border);border-left:3px solid var(--blue);background:var(--card-bg);border-radius:0 5px 5px 0;padding:1.3rem 1.6rem;transition:border-left-color .2s}.exp-card:hover{border-left-color:var(--accent)}.exp-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:.4rem;margin-bottom:.3rem;display:flex}.exp-company{color:var(--blue);font-size:1rem;font-weight:700}.exp-date{color:var(--dim);font-size:.78rem}.exp-role{color:var(--accent);margin-bottom:.8rem;font-size:.88rem}.exp-bullets{flex-direction:column;gap:.35rem;list-style:none;display:flex}.exp-bullets li{color:#8ab8d0;padding-left:1.2rem;font-size:.87rem;line-height:1.65;position:relative}.exp-bullets li:before{content:">";color:var(--dim);position:absolute;left:0}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(420px,1fr));gap:1.2rem;display:grid}.project-card{border:1px solid var(--border);background:var(--card-bg);border-radius:6px;flex-direction:column;transition:border-color .2s,transform .2s;display:flex;overflow:hidden}.project-card:hover{border-color:var(--blue);transform:translateY(-3px)}.project-bar{border-bottom:1px solid var(--border);background:#050d05;align-items:center;gap:.45rem;padding:.55rem 1rem;display:flex}.project-file{color:var(--dim);margin-left:.4rem;font-size:.76rem}.project-body{flex-direction:column;flex:1;padding:1.25rem;display:flex}.project-name{color:var(--blue);margin-bottom:.5rem;font-size:1rem;font-weight:700}.project-status{color:var(--dim);border:1px solid var(--border);border-radius:3px;margin-left:.75rem;padding:.1rem .5rem;font-size:.72rem}.project-status.active{color:var(--blue);border-color:#1e3a1e}.project-status.shipped{color:var(--warn);border-color:#3a3000}.project-name-row{align-items:baseline;margin-bottom:.6rem;display:flex}.project-desc{color:#88b8d0;flex:1;margin-bottom:1rem;font-size:.84rem;line-height:1.72}.project-highlights{flex-direction:column;gap:.3rem;margin-bottom:1rem;list-style:none;display:flex}.project-highlights li{color:#6a9cb8;padding-left:1.2rem;font-size:.8rem;line-height:1.6;position:relative}.project-highlights li:before{content:"·";color:var(--dim);position:absolute;left:0}.meta-block{flex-direction:column;gap:.45rem;font-size:.77rem;display:flex}.meta-row{flex-wrap:wrap;align-items:flex-start;gap:.5rem;display:flex}.meta-key{color:var(--dim);flex-shrink:0;min-width:5rem}.tags{flex-wrap:wrap;gap:.3rem;display:flex}.tag{color:var(--accent);background:#04090a;border:1px solid #0a2a30;border-radius:3px;padding:.08rem .45rem;font-size:.73rem}.tag-g{color:#56b6d4;background:#040a10;border-color:#0a1e30}.project-footer{border-top:1px solid var(--border);gap:1rem;margin-top:1rem;padding-top:.75rem;display:flex}.project-link{color:var(--dim);align-items:center;gap:.3rem;font-size:.8rem;transition:color .2s;display:flex}.project-link:hover{color:var(--blue)}.skills-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.1rem;display:grid}.skill-group{border:1px solid var(--border);background:var(--card-bg);border-radius:4px;padding:1.1rem 1.2rem}.skill-cat{color:var(--accent);text-transform:uppercase;letter-spacing:.07em;margin-bottom:.8rem;font-size:.78rem}.skill-cat:before{content:"# ";color:var(--dim)}.skill-tags{flex-wrap:wrap;gap:.4rem;display:flex}.skill-tag{border:1px solid var(--border);color:var(--fg);cursor:default;background:#060d16;border-radius:3px;padding:.18rem .6rem;font-size:.77rem;transition:all .18s}.skill-tag:hover{border-color:var(--blue);color:var(--blue)}.contact-box{border:1px solid var(--border);background:var(--card-bg);border-radius:5px;max-width:540px;padding:1.8rem 2rem}.contact-row{align-items:center;gap:1.2rem;margin-bottom:.9rem;font-size:.88rem;display:flex}.contact-label{color:var(--dim);min-width:5.5rem}.contact-val{color:var(--fg);transition:color .18s}.contact-val:hover{color:var(--blue)}.footer{text-align:center;color:var(--dim);border-top:1px solid var(--border);margin-top:3rem;padding:2rem 1rem;font-size:.76rem}@media (max-width:680px){.navbar{padding:.6rem 1rem}.navbar-brand{font-size:.8rem}.section{padding:4.5rem 1rem 2rem}.projects-grid,.skills-grid{grid-template-columns:1fr}.terminal-body{padding:1rem}.contact-box{padding:1.2rem}}
