:root{--font-main: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--bg: #0b1020;--bg-elevated: #101528;--bg-editor: #060a14;--accent: #3b82f6;--accent-soft: rgba(59, 130, 246, .2);--accent-strong: #2563eb;--text: #e5e7eb;--text-soft: #9ca3af;--border-subtle: #1f2933;--chip-bg: #111827;--pill-bg: #111827}:root[data-theme=light]{--bg: #f3f3f3;--bg-elevated: #ffffff;--bg-editor: #ffffff;--accent: #2563eb;--accent-soft: rgba(37, 99, 235, .08);--accent-strong: #1d4ed8;--text: #111827;--text-soft: #6b7280;--border-subtle: #d1d5db;--chip-bg: #f3f4f6;--pill-bg: #e5e7eb}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pulseSoft{0%{box-shadow:0 0 #2563eb66}70%{box-shadow:0 0 0 10px #2563eb00}to{box-shadow:0 0 #2563eb00}}@keyframes caretBlink{0%,40%{opacity:1}50%,to{opacity:0}}@keyframes skillShine{0%{transform:translate(-120%)}to{transform:translate(120%)}}@keyframes pillDrift{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font-main);background:var(--bg);color:var(--text);transition:background-color .25s ease,color .25s ease}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit}.app{display:flex;flex-direction:column;min-height:100vh;animation:fadeIn .35s ease-out}.app-main{display:flex;flex:1;min-height:0}.topbar{display:flex;align-items:center;justify-content:space-between;padding:.4rem 1rem;background:var(--bg-elevated);border-bottom:1px solid var(--border-subtle);transition:background-color .25s ease,border-color .25s ease}.topbar-left{display:flex;align-items:center;gap:.5rem}.traffic{width:10px;height:10px;border-radius:999px;display:inline-block}.traffic-red{background:#ef4444}.traffic-yellow{background:#f59e0b}.traffic-green{background:#22c55e}.topbar-title{font-size:.9rem;color:var(--text-soft)}.topbar-right{display:flex;gap:.5rem}.theme-toggle{font-size:.8rem;padding:.2rem .7rem;border-radius:999px;border:1px solid var(--border-subtle);background:transparent;color:var(--text-soft);cursor:pointer;transition:background-color .2s ease,color .2s ease,border-color .2s ease,transform .1s ease}.theme-toggle.theme-active{background:var(--accent-soft);color:var(--accent-strong);border-color:var(--accent)}.theme-toggle:hover{transform:translateY(-1px);border-color:var(--accent)}.sidebar{width:220px;background:#050814;border-right:1px solid var(--border-subtle);padding:.75rem .75rem .5rem;display:flex;flex-direction:column;transition:background-color .25s ease,border-color .25s ease}:root[data-theme=light] .sidebar{background:#f5f5f5}.sidebar-title{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-soft);margin-bottom:.4rem}.sidebar-section-title{font-size:.7rem;text-transform:uppercase;color:var(--text-soft);margin-bottom:.35rem}.sidebar-file-tree{font-size:.85rem}.folder,.file{display:flex;align-items:center;gap:.35rem;padding:.15rem .2rem}.folder-dot,.file-dot{width:10px;height:10px;border-radius:999px}.folder-dot{background:#fbbf24}.file-dot{background:#3b82f6}.folder-label{font-weight:500}.file{width:100%;border:none;background:transparent;color:var(--text-soft);cursor:pointer;justify-content:flex-start;border-radius:4px;padding:.15rem .35rem;transition:background-color .18s ease,color .18s ease,transform .08s ease}.file:hover{background:#94a3b814;transform:translate(2px)}.file-active{background:var(--accent-soft);color:var(--accent-strong)}.sidebar-footer{margin-top:auto;padding-top:.6rem;border-top:1px solid var(--border-subtle)}.sidebar-name{font-size:.9rem;font-weight:600}.sidebar-role{font-size:.75rem;color:var(--text-soft)}.editor{flex:1;display:flex;flex-direction:column;background:var(--bg-editor);transition:background-color .25s ease}.tabbar{display:flex;border-bottom:1px solid var(--border-subtle);background:var(--bg-elevated)}.tab{padding:.45rem .9rem;font-size:.8rem;border:none;background:transparent;color:var(--text-soft);cursor:pointer;border-right:1px solid var(--border-subtle);transition:background-color .18s ease,color .18s ease;white-space:nowrap}.tab:hover{background:#94a3b80f;color:var(--text)}.tab-active{background:var(--bg-editor);color:var(--text);border-bottom:2px solid var(--accent)}.scroll-bar{height:3px;width:100%;background:#94a3b840;overflow:hidden}.scroll-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-strong));width:0;transition:width .15s ease-out}.editor-content{flex:1;padding:1.3rem 1.6rem .9rem;overflow-y:auto}.statusbar{display:flex;justify-content:flex-end;gap:1rem;padding:.3rem 1rem;font-size:.75rem;border-top:1px solid var(--border-subtle);background:var(--bg-elevated);color:var(--text-soft)}.content{max-width:900px;margin:0 auto;animation:fadeInUp .25s ease-out}.typewriter{font-size:1.2rem;font-weight:600;margin-bottom:.6rem}.typewriter-caret{display:inline-block;width:1px;height:1.2em;background:var(--accent);margin-left:2px;animation:caretBlink .9s steps(2,start) infinite}.code-comment{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.8rem;color:var(--text-soft);margin-bottom:.4rem}.code-block{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;background:#020617;padding:.9rem;border-radius:10px;border:1px solid var(--border-subtle);font-size:.8rem;margin-bottom:1rem;overflow-x:auto}:root[data-theme=light] .code-block{background:#f9fafb}.code-keyword{color:#93c5fd}.code-variable{color:#facc15}.code-string{color:#6ee7b7}.paragraph{font-size:.92rem;line-height:1.65;color:var(--text-soft);margin-bottom:1rem}.chips-row{display:flex;flex-wrap:wrap;gap:.8rem;margin:1rem 0 1.3rem}.chip-card{background:var(--chip-bg);border-radius:14px;padding:.7rem .9rem;min-width:180px;transition:background-color .2s ease,border-color .2s ease,transform .15s ease,box-shadow .2s ease}:root[data-theme=light] .chip-card{border:1px solid var(--border-subtle)}.chip-card:hover{transform:translateY(-2px);box-shadow:0 12px 30px #0f172a59}.chip-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text-soft);margin-bottom:.25rem}.chip-value{font-size:.9rem}.primary-btn{margin-top:.4rem;padding:.6rem 1.2rem;border-radius:999px;border:none;background:var(--accent);color:#fff;font-size:.9rem;cursor:pointer;box-shadow:0 12px 35px #2563eb59;transition:background-color .2s ease,transform .12s ease,box-shadow .2s ease;display:inline-flex;align-items:center;gap:.35rem}.primary-btn:hover{background:var(--accent-strong);transform:translateY(-2px);animation:pulseSoft 1.2s ease-out}.secondary-btn{padding:.5rem 1rem;border-radius:999px;border:none;background:var(--accent-soft);color:var(--accent-strong);font-size:.85rem;cursor:pointer;transition:background-color .2s ease,transform .12s ease;display:inline-flex;align-items:center;gap:.3rem}.secondary-btn:hover{background:#2563eb2e;transform:translateY(-1px)}.disabled-btn{width:100%;border-radius:6px;border:none;padding:.55rem;background:#4b5563;color:#e5e7eb;font-size:.85rem}.skill-row{margin-bottom:.7rem;animation:fadeInUp .25s ease-out;animation-fill-mode:both;opacity:0}.skill-label{display:flex;justify-content:space-between;font-size:.85rem;margin-bottom:.2rem}.skill-percent{color:var(--text-soft)}.skill-bar{position:relative;height:6px;border-radius:999px;background:#111827;overflow:hidden}:root[data-theme=light] .skill-bar{background:#e5e7eb}.skill-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-strong));transition:width .6s ease-out}.skill-bar:after{content:"";position:absolute;top:0;bottom:0;width:40%;background:linear-gradient(120deg,#fff0,#ffffff59,#fff0);transform:translate(-120%)}.skill-row:hover .skill-bar:after{animation:skillShine 1.1s ease-out}.skill-row:hover .skill-bar-fill{box-shadow:0 0 18px #3b82f699}.pill-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.4rem}.pill{padding:.25rem .7rem;border-radius:999px;font-size:.78rem;background:var(--pill-bg);color:var(--text-soft)}.pill-floating{animation:fadeInUp .25s ease-out both,pillDrift 3.2s ease-in-out infinite}.card{background:var(--bg-elevated);border-radius:12px;padding:.9rem 1rem;margin-bottom:.8rem;border:1px solid var(--border-subtle);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,background-color .18s ease}.card:hover{transform:translateY(-4px);box-shadow:0 18px 40px #0f172a59;border-color:#94a3b8b3}.card-header{display:flex;justify-content:space-between;gap:.8rem;align-items:center;margin-bottom:.4rem}.card h3{margin:0;font-size:1rem}.card-subtitle{font-size:.8rem;color:var(--text-soft)}.card-tags{display:flex;flex-wrap:wrap;gap:.3rem}.list{margin:.3rem 0 .8rem;padding-left:1.1rem;font-size:.9rem;color:var(--text-soft)}.contact-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.9rem;margin-bottom:1.2rem;font-size:.9rem}.contact-form{display:flex;flex-direction:column;gap:.6rem;max-width:420px}.contact-form input,.contact-form textarea{border-radius:6px;border:1px solid var(--border-subtle);background:transparent;padding:.55rem .65rem;color:var(--text);font-size:.9rem}.contact-form input::placeholder,.contact-form textarea::placeholder{color:var(--text-soft)}.contact-form input:focus,.contact-form textarea:focus{outline:1px solid var(--accent)}@media(max-width:1024px){.content{padding-inline:.2rem}}@media(max-width:900px){.sidebar{display:none}.app-main{flex-direction:column}.editor{width:100%}.statusbar{justify-content:space-between;font-size:.72rem}}@media(max-width:600px){.topbar{padding-inline:.7rem}.topbar-title{font-size:.8rem}.topbar-right{gap:.3rem}.theme-toggle{font-size:.72rem;padding-inline:.5rem}.editor-content{padding:1rem .9rem .7rem}.content{max-width:100%}.typewriter{font-size:1rem}.paragraph{font-size:.88rem}.chip-card{width:100%}.tabbar{overflow-x:auto;-webkit-overflow-scrolling:touch}.tab{padding:.4rem .7rem;font-size:.78rem}.card{padding-inline:.85rem}.contact-form{max-width:100%}}@media(max-width:400px){.topbar{padding-inline:.45rem}.topbar-title{display:none}.statusbar{padding-inline:.6rem}}
