body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,system-ui,-apple-system,sans-serif}#root{min-height:100vh}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a0f;--surface:#12121a;--surface2:#1a1a26;--accent:#6c63ff;--accent2:#a78bfa;--accent-glow:#6c63ff26;--text:#e8eaf0;--text-muted:#8892a4;--border:#1e2030;--radius:16px;--radius-sm:10px;--shadow:0 4px 32px #00000080;--font:"Inter", system-ui, -apple-system, sans-serif;--transition:.25s ease}body{background:var(--bg);color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.7}a{color:var(--accent2);transition:color var(--transition);text-decoration:none}a:hover{color:var(--accent)}.app{flex-direction:column;min-height:100vh;display:flex}.main{flex:1;width:100%;max-width:960px;margin:0 auto;padding:3rem 1.5rem 5rem}.header{-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);z-index:100;background:#0a0a0fd9;position:sticky;top:0}.header__inner{justify-content:space-between;align-items:center;gap:1rem;max-width:960px;margin:0 auto;padding:.75rem 1.5rem;display:flex}.header__brand{flex-direction:column;line-height:1.2;text-decoration:none;display:flex}.header__name{color:var(--text);transition:color var(--transition);font-size:1.05rem;font-weight:700}.header__brand:hover .header__name{color:var(--accent2)}.header__title{color:var(--text-muted);letter-spacing:.02em;font-size:.72rem}.header__nav{gap:.25rem;display:flex}.header__nav-link{color:var(--text-muted);transition:all var(--transition);border-radius:8px;padding:.4rem .85rem;font-size:.9rem;font-weight:500}.header__nav-link:hover{color:var(--text);background:var(--surface);text-decoration:none}.header__nav-link--active{color:var(--accent2);background:var(--accent-glow)}.hero{text-align:center;border-bottom:1px solid var(--border);padding:5rem 1.5rem 4rem;position:relative;overflow:hidden}.hero__glow{pointer-events:none;z-index:0;background:radial-gradient(#6c63ff1f 0%,#a855fa0f 40%,#0000 70%);width:600px;height:400px;position:absolute;top:-120px;left:50%;transform:translate(-50%)}.hero__inner{z-index:1;flex-direction:column;align-items:center;gap:.75rem;max-width:960px;margin:0 auto;display:flex;position:relative}.hero__avatar{background:linear-gradient(135deg, var(--accent), var(--accent2));color:#fff;width:88px;height:88px;box-shadow:0 0 0 4px var(--bg), 0 0 0 6px #6c63ff4d;border-radius:50%;justify-content:center;align-items:center;margin-bottom:.5rem;font-size:1.6rem;font-weight:700;display:flex}.hero__name{letter-spacing:-.03em;background:linear-gradient(135deg, var(--accent2) 0%, var(--accent) 50%, var(--accent2) 100%);-webkit-text-fill-color:transparent;background-size:200%;-webkit-background-clip:text;background-clip:text;font-size:2.75rem;font-weight:800;animation:4s ease-in-out infinite gradient-shift}@keyframes gradient-shift{0%,to{background-position:0%}50%{background-position:100%}}.hero__subtitle{color:var(--text-muted);font-size:1.1rem;font-weight:400}.hero__links{gap:.75rem;margin-top:.75rem;display:flex}.hero__link{border:1px solid var(--border);color:var(--text-muted);transition:all var(--transition);border-radius:999px;padding:.5rem 1.25rem;font-size:.88rem;font-weight:500}.hero__link:hover{border-color:var(--accent);color:var(--accent2);background:var(--accent-glow);text-decoration:none}.section{margin-bottom:4rem}.section__title{color:var(--text);margin-bottom:1.5rem;padding-bottom:.6rem;font-size:1.5rem;font-weight:700;display:inline-block;position:relative}.section__title:after{content:"";background:linear-gradient(90deg, var(--accent), var(--accent2));border-radius:999px;width:100%;height:3px;position:absolute;bottom:0;left:0}.section p{color:var(--text-muted);margin-bottom:.75rem;font-size:.95rem}.section__cta{text-align:center;margin-top:2rem}.btn{cursor:pointer;transition:all var(--transition);border:none;border-radius:999px;align-items:center;gap:.4rem;padding:.55rem 1.3rem;font-size:.88rem;font-weight:600;text-decoration:none;display:inline-flex}.btn--primary{background:linear-gradient(135deg, var(--accent), var(--accent2));color:#fff}.btn--primary:hover{color:#fff;transform:translateY(-1px);box-shadow:0 4px 20px #6c63ff59}.btn--outline{border:1px solid var(--border);color:var(--accent2);background:0 0}.btn--outline:hover{border-color:var(--accent);background:var(--accent-glow);color:var(--accent2)}.timeline{flex-direction:column;gap:1rem;display:flex}.timeline__item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:all var(--transition);gap:1.25rem;padding:1.25rem 1.5rem;display:flex}.timeline__item:hover{border-color:#6c63ff40;transform:translate(4px)}.timeline__period{color:var(--accent2);white-space:nowrap;min-width:115px;padding-top:3px;font-size:.78rem;font-weight:500}.timeline__body strong{color:var(--text);font-weight:600}.timeline__at{color:var(--accent);font-weight:400}.timeline__body p{margin-top:.35rem;font-size:.88rem}.cards{grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.25rem;display:grid}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:all var(--transition);flex-direction:column;gap:.5rem;padding:1.5rem;display:flex}.card:hover{border-color:#6c63ff40;transform:translateY(-2px);box-shadow:0 8px 32px #0000004d}.card__header{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.card__title{color:var(--text);font-size:1rem;font-weight:600}.card__year{color:var(--text-muted);background:var(--surface2);white-space:nowrap;border-radius:999px;padding:.15rem .6rem;font-size:.72rem}.card__date{color:var(--text-muted);font-size:.78rem;font-weight:500}.card__external-badge{color:var(--accent2);background:var(--accent-glow);border-radius:999px;padding:.15rem .55rem;font-size:.68rem;font-weight:600}.card__desc{color:var(--text-muted);font-size:.88rem;line-height:1.55}.card__tags{flex-wrap:wrap;gap:.35rem;display:flex}.card__action{margin-top:auto;padding-top:.75rem}.card--blog{gap:.65rem}.card--blog .card__title{font-size:1.05rem;line-height:1.35}.tag{color:var(--accent2);white-space:nowrap;background:#6c63ff14;border:1px solid #6c63ff2e;border-radius:999px;padding:.2rem .6rem;font-size:.72rem;font-weight:500}.skills-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.25rem;display:grid}.skill-group{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:border-color var(--transition);padding:1.25rem}.skill-group:hover{border-color:#6c63ff33}.skill-group__title{color:var(--accent2);margin-bottom:.7rem;font-size:.88rem;font-weight:600}.skill-group__tags{flex-wrap:wrap;gap:.4rem;display:flex}.academic{flex-direction:column;gap:1.5rem;display:flex}.academic__degree{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);align-items:flex-start;gap:1rem;padding:1.25rem;display:flex}.academic__icon{font-size:2rem}.academic__degree strong{color:var(--text)}.academic__certs h4{color:var(--accent2);margin-bottom:.6rem;font-weight:600}.academic__certs ul{color:var(--text-muted);flex-direction:column;gap:.35rem;padding-left:1.25rem;font-size:.92rem;display:flex}.hobbies{flex-wrap:wrap;gap:.75rem;display:flex}.hobby-chip{background:var(--surface);border:1px solid var(--border);color:var(--text-muted);transition:all var(--transition);border-radius:999px;align-items:center;gap:.5rem;padding:.55rem 1.1rem;font-size:.9rem;display:flex}.hobby-chip:hover{border-color:var(--accent);color:var(--text);transform:translateY(-2px)}.ai-chat-intro{margin-bottom:1rem}.ai-chat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.ai-chat__header{background:linear-gradient(135deg, var(--accent), var(--accent2));color:#fff;align-items:center;gap:.6rem;padding:.85rem 1.25rem;font-size:.95rem;font-weight:600;display:flex}.ai-chat__icon{font-size:1.2rem}.ai-chat__messages{scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex-direction:column;gap:.75rem;min-height:280px;max-height:400px;padding:1rem;display:flex;overflow-y:auto}.chat-bubble{flex-direction:column;max-width:80%;display:flex}.chat-bubble--user{align-self:flex-end;align-items:flex-end}.chat-bubble--ai{align-self:flex-start;align-items:flex-start}.chat-bubble__label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.2rem;font-size:.68rem;font-weight:600}.chat-bubble__text{background:var(--surface2);border-radius:var(--radius-sm);white-space:pre-wrap;color:var(--text);padding:.7rem 1rem;font-size:.9rem;line-height:1.55}.chat-bubble--user .chat-bubble__text{background:linear-gradient(135deg, var(--accent), var(--accent2));color:#fff}.chat-bubble__text--loading{color:var(--text-muted);animation:1.2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.ai-chat__input-row{border-top:1px solid var(--border);background:var(--surface2);gap:.5rem;padding:.75rem 1rem;display:flex}.ai-chat__input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);resize:none;transition:border-color var(--transition);flex:1;padding:.6rem .9rem;font-family:inherit;font-size:.9rem;line-height:1.4}.ai-chat__input:focus{border-color:var(--accent);outline:none}.ai-chat__send{background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);border:none;align-self:flex-end;padding:.6rem 1.25rem;font-family:inherit;font-size:.88rem;font-weight:600}.ai-chat__send:hover:not(:disabled){background:var(--accent2)}.ai-chat__send:disabled{opacity:.5;cursor:not-allowed}.footer{border-top:1px solid var(--border);z-index:1;padding:2rem 1.5rem;position:relative}.footer__inner{max-width:960px;color:var(--text-muted);justify-content:space-between;align-items:center;margin:0 auto;font-size:.85rem;display:flex}.footer__links{gap:1.25rem;display:flex}.footer__links a{color:var(--text-muted);transition:color var(--transition);font-size:.85rem}.footer__links a:hover{color:var(--accent2)}.main--post{max-width:760px;padding-top:2rem}.post__back{color:var(--text-muted);transition:color var(--transition);align-items:center;gap:.4rem;margin-bottom:2rem;font-size:.88rem;font-weight:500;display:inline-flex}.post__back:hover{color:var(--accent2);text-decoration:none}.post__header{margin-bottom:2.5rem}.post__date{color:var(--text-muted);margin-bottom:.75rem;font-size:.85rem;font-weight:500;display:block}.post__title{letter-spacing:-.02em;color:var(--text);margin-bottom:1rem;font-size:2rem;font-weight:800;line-height:1.3}.post__content{flex-direction:column;gap:1rem;display:flex}.post__p{color:var(--text-muted);font-size:1rem;line-height:1.8}.cms__grid{grid-template-columns:320px 1fr;gap:1.25rem;display:grid}.cms__panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.cms__panel--auth{max-width:480px}.cms__top-actions{flex-wrap:wrap;gap:.65rem;margin-top:.9rem;display:flex}.cms__panel h2{margin-bottom:.9rem;font-size:1rem}.cms__panel-header{justify-content:space-between;align-items:center;margin-bottom:.9rem;display:flex}.cms__list{flex-direction:column;gap:.6rem;list-style:none;display:flex}.cms__item{text-align:left;border:1px solid var(--border);background:var(--surface2);width:100%;color:var(--text);cursor:pointer;border-radius:10px;flex-direction:column;gap:.15rem;padding:.7rem .75rem;display:flex}.cms__item--active{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}.cms__item-type{color:var(--accent2);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem}.cms__form{flex-direction:column;gap:.8rem;display:flex}.cms__form label{color:var(--text-muted);flex-direction:column;gap:.35rem;font-size:.9rem;display:flex}.cms__form input,.cms__form textarea,.cms__form select{background:var(--bg);border:1px solid var(--border);color:var(--text);font:inherit;border-radius:10px;padding:.6rem .75rem}.cms__form input:focus,.cms__form textarea:focus,.cms__form select:focus{border-color:var(--accent);outline:none}.cms__actions{gap:.7rem;margin-top:.25rem;display:flex}.cms__msg{border-radius:10px;padding:.55rem .7rem;font-size:.88rem}.cms__msg--error{color:#ff9c9c;background:#ff5c5c1f;border:1px solid #ff5c5c47}.cms__msg--success{color:#80efc4;background:#4cc9991f;border:1px solid #4cc9993d}@media (width<=640px){.header__nav{gap:.1rem}.header__nav-link{padding:.35rem .6rem;font-size:.82rem}.hero{padding:3.5rem 1rem 3rem}.hero__name{font-size:2rem}.hero__subtitle{font-size:.95rem}.main{padding:2rem 1rem 3rem}.timeline__item{flex-direction:column;gap:.5rem}.timeline__period{min-width:auto}.cards,.skills-grid{grid-template-columns:1fr}.footer__inner{text-align:center;flex-direction:column;gap:.75rem}.post__title{font-size:1.5rem}.cms__grid{grid-template-columns:1fr}.cms__actions{flex-direction:column}}
