.nav-bar{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;height:110px;background:#111827;border-bottom:1px solid #0b101a;gap:16px}.nav-text{display:flex;font-size:3.2em;font-weight:400;justify-content:left;align-items:left}.nav-image{width:200px;margin-right:12px}.search-bar{margin-left:auto;margin-right:20px;display:flex;align-items:center;gap:8px}.search-bar>input{width:260px;max-width:34vw;padding:10px 12px;border-radius:10px;border:1px solid #1E293B;outline:none;background:#0f172a;color:#e6eef4}.search-button{background:none;border:none;padding:4px;cursor:pointer;display:grid;place-items:center;border-radius:10px;transition:transform .18s ease,background-color .18s ease,opacity .18s ease}.search-button>img{width:28px;height:28px}.search-button:hover{transform:scale(1.1);opacity:.8}.search-button:active{transform:scale(.95)}.projects{display:grid;grid-template-columns:1fr;gap:16px;margin:20px 0}.project-card{background:#111827;color:#e6eef4;border:1px solid #1E293B;border-radius:10px;box-shadow:0 12px 30px #00000073;padding:18px;display:flex;align-items:stretch;gap:18px;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease;margin-top:20px}.project-card:hover{transform:translateY(-2px);border-color:#2c8db0;box-shadow:0 16px 38px #0000008c}.project-body{display:grid;grid-template-rows:auto auto auto auto;gap:10px;flex:1;min-width:0}.project-title{font-size:clamp(18px,2.2vw,24px);font-weight:700;margin:0}.project-desc{margin:0;color:#94a3b8;line-height:1.45}.tech-header{margin:0}.project-tech{display:flex;flex-wrap:wrap;gap:8px}.tech-badge{background:#223043;color:#e6eef4;border:1px solid #2C8DB0;padding:1px 14px;border-radius:8px;font-size:13px;font-weight:600;display:flex;align-items:center;height:fit-content}.project-actions{display:flex;gap:18px}.project-actions a{color:#3ba3c9;text-decoration:none;font-weight:600}.project-actions a:hover{color:#2c8db0;text-decoration:underline}.project-thumb{width:240px;max-width:32%;border-radius:10px;border:1px solid #1E293B;background:#0b1220;object-fit:cover;aspect-ratio:4 / 3;flex-shrink:0}@media (max-width: 700px){.project-card{flex-direction:column}.project-thumb{max-width:100%;width:100%;aspect-ratio:16 / 9}}.chat-minibar,.chat-widget{position:fixed;right:20px;bottom:20px;z-index:1000;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial}.chat-minibar{display:inline-flex;align-items:center;gap:10px;padding:10px 14px;background:#111827;color:#e6eef4;border:1px solid #1E293B;border-radius:8px;box-shadow:0 10px 28px #00000073;cursor:pointer}.chat-minibar .dot{width:8px;height:8px;border-radius:50%;background:#3ba3c9;display:inline-block}.chat-widget{width:clamp(320px,32vw,380px);height:520px;background:#111827;color:#e6eef4;border:1px solid #1E293B;border-radius:10px;box-shadow:0 16px 40px #0009;display:grid;grid-template-rows:auto 1fr auto;overflow:hidden}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid #1E293B;background:#111827}.chat-header .title{font-weight:700;display:flex;align-items:center;gap:8px}.chat-header .spark{color:#3ba3c9;font-weight:800}.icon-btn{background:transparent;color:#94a3b8;border:none;cursor:pointer;font-size:18px;padding:4px 8px;border-radius:6px}.icon-btn:hover{color:#3ba3c9}.chat-body{padding:12px;overflow-y:auto;display:grid;gap:8px;background:#0b1220}.msg{max-width:85%;padding:10px 12px;line-height:1.35;border-radius:10px;border:1px solid #1E293B;word-wrap:break-word;box-shadow:0 8px 18px #00000059}.msg-ai{background:#0f172a;color:#e6eef4;border-color:#1e293b;justify-self:start}.msg-user{background:#223043;color:#e6eef4;border-color:#2c8db0;justify-self:end}.chat-input{display:flex;gap:8px;padding:10px;border-top:1px solid #1E293B;background:#111827}.chat-input input{flex:1;padding:10px 12px;border-radius:8px;outline:none;background:#0b1220;color:#e6eef4;border:1px solid #1E293B}.chat-input input::placeholder{color:#94a3b8}.send-btn{padding:10px 14px;border-radius:8px;border:1px solid #2C8DB0;background:#3ba3c9;color:#0b1220;font-weight:700;cursor:pointer}.send-btn:hover{background:#2c8db0;border-color:#247896}.button-row{display:flex;justify-content:center;align-items:center;gap:95px;margin-top:90px}.fancy-button{width:120px;height:120px;padding:0;border:3px solid rgb(0,0,0);border-radius:30px;cursor:pointer;transition:all .3s ease}.fancy-button:hover{transform:scale(107%)}.fancy-button:active{transform:translateY(1px);box-shadow:0 3px 10px #ff768866}.logo-img{width:50%;object-fit:contain;transition:transform .2s ease;filter:invert(.8)}.fancy-button.github{background:#0b1220;box-shadow:0 0 15px #00000073;border:3px solid #3BA3C9}.fancy-button.github:hover{background:#415460;box-shadow:0 0 20px #0009}.logo-img.github{width:100%;scale:110%}.fancy-button.linkedin{background:#0b1220;box-shadow:0 0 20px #00000073;border:3px solid #94A3B8}.fancy-button.linkedin:hover{background:#415460;box-shadow:0 0 20px #0009}.logo-img.linkedin{width:75%;scale:100%;border-radius:35%}.btn{-webkit-tap-highlight-color:transparent;display:inline-flex;align-items:center;justify-content:center;gap:1rem;padding:.75rem 1.1rem;border-radius:7px;font-weight:600;letter-spacing:.2px;border:1px solid #1E293B;background:#111827;color:#e6eef4;box-shadow:0 10px 28px #00000073;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,background-color .16s ease,border-color .16s ease,opacity .16s ease}.btn:hover{transform:translateY(-2px)}.btn:active{transform:translateY(0);opacity:.9}.btn:focus-visible{outline:none;box-shadow:0 10px 28px #00000073,0 0 0 3px #3ba3c959}.btn-wrapper{display:flex;gap:20px;justify-content:center}.btn--primary{background:#3ba3c9;border-color:#2c8db0;color:#e6eef4}.btn--primary:hover{background:#2c8db0;border-color:#247896;box-shadow:0 14px 38px #3ba3c940}.btn--primary:active{background:#247896}.btn--primary--selected{background:#247896;border-color:#1e293b;color:#e6eef4;box-shadow:inset 0 2px 6px #0006}.btn--ghost{background:transparent;border-color:#1e293b;color:#e6eef4}.btn--ghost:hover{background:#3ba3c91a;border-color:#2c8db0}.btn--ghost:active{opacity:.9}.btn--ghost--selected{background:#1e293b;border-color:#3ba3c9;color:#3ba3c9;box-shadow:inset 0 2px 6px #0006}.btn--lg{padding:.9rem 1.25rem;font-size:1.05rem}.btn--sm{padding:.55rem .85rem;font-size:.92rem}html,body{height:100%}body{margin:0;background:#0b1220;color:#e6eef4;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,"Apple Color Emoji","Segoe UI Emoji"}.hero{max-width:1100px;margin:8vh auto 6vh;padding:0 24px;text-align:center}.hero h1{display:flex;align-items:center;justify-content:center;font-weight:200px;font-size:clamp(32px,6vw,64px);color:#e6eef4;line-height:1.1;margin:0 0 18px}.hero p{color:#94a3b8;font-size:clamp(14px,2.2vw,18px);margin:0 auto 40px;max-width:720px}.projects-wrap{overflow:hidden;max-height:0;opacity:0;transition:max-height .32s ease,opacity .22s ease}.projects-wrap.is-open{max-height:2000px;opacity:1}.projects-enter .project-list>*{opacity:0;transform:translateY(10px) scale(.98);animation:projIn .36s ease forwards}.projects-enter .project-list>*:nth-child(1){animation-delay:40ms}.projects-enter .project-list>*:nth-child(2){animation-delay:80ms}.projects-enter .project-list>*:nth-child(3){animation-delay:.12s}@keyframes projIn{to{opacity:1;transform:translateY(0) scale(1)}}.modal-backdrop{position:fixed;inset:0;background:#000000a6;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .25s ease}.modal{position:relative;background:#111827;color:#e6eef4;border:1px solid #1E293B;border-radius:8px;box-shadow:0 16px 40px #0009;width:90%;max-width:480px;padding:24px;z-index:1001;animation:slideUp .25s ease}.modal h2{margin-top:0;margin-bottom:12px;font-size:1.4rem}.modal-close{position:absolute;top:12px;right:12px;background:none;border:none;font-size:1.5rem;color:#94a3b8;cursor:pointer;transition:color .2s ease}.modal-close:hover{color:#3ba3c9}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.contact-email a{color:#e6eef4;text-decoration:none;font-weight:500;transition:color .2s ease}.contact-email a:hover{color:#3ba3c9;text-decoration:underline}
