@import"https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;0,900;1,400&family=DM+Mono:wght@300;400;500&family=DM+Sans:wght@300;400;500;600&display=swap";:root{--bg: #0a0a0a;--bg-2: #111111;--bg-3: #1a1a1a;--surface: #1e1e1e;--border: #2a2a2a;--border-light: #333;--text: #f0ede8;--text-muted: #888;--text-dim: #555;--accent: #e8c547;--accent-dim: rgba(232, 197, 71, .15);--accent-hover: #f0d060;--red: #e84747;--green: #47e87a;--radius: 4px;--radius-lg: 8px;--font-display: "Playfair Display", serif;--font-mono: "DM Mono", monospace;--font-body: "DM Sans", sans-serif;--transition: .2s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}::selection{background:var(--accent);color:#000}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;background:none;font-family:var(--font-body);font-size:inherit;color:inherit}input,textarea{font-family:var(--font-body);font-size:inherit;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem 1rem;width:100%;outline:none;transition:border-color var(--transition);resize:vertical}input::placeholder,textarea::placeholder{color:var(--text-dim)}input:focus,textarea:focus{border-color:var(--accent)}h1,h2,h3,h4{font-family:var(--font-display);line-height:1.2}img{max-width:100%;display:block}.container{max-width:1100px;margin:0 auto;padding:0 2rem}.page{min-height:100vh;padding-top:80px}.nav{position:fixed;top:0;left:0;right:0;z-index:100;height:80px;display:flex;align-items:center;background:#0a0a0ad9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.nav__inner{display:flex;align-items:center;justify-content:space-between;width:100%}.nav__logo{font-family:var(--font-display);font-size:1.4rem;font-weight:700;color:var(--text);letter-spacing:-.5px}.nav__logo span{color:var(--accent)}.nav__links{display:flex;gap:2.5rem;align-items:center}.nav__links a{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);transition:color var(--transition);position:relative}.nav__links a:hover,.nav__links a.active{color:var(--text)}.nav__links a.active:after{content:"";position:absolute;bottom:-4px;left:0;right:0;height:1px;background:var(--accent)}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.65rem 1.4rem;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;border-radius:var(--radius);transition:all var(--transition);border:1px solid transparent}.btn-primary{background:var(--accent);color:#000;font-weight:500}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px)}.btn-ghost{border-color:var(--border-light);color:var(--text-muted)}.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}.btn-danger{border-color:var(--red);color:var(--red)}.btn-danger:hover{background:var(--red);color:#fff}.btn-sm{padding:.4rem .9rem;font-size:.72rem}.tag{display:inline-block;padding:.2rem .6rem;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.04em;border-radius:2px;background:var(--bg-3);color:var(--text-muted);border:1px solid var(--border)}.tag-accent{background:var(--accent-dim);color:var(--accent);border-color:#e8c5474d}.tag-green{background:#47e87a1a;color:var(--green);border-color:#47e87a4d}.tag-red{background:#e847471a;color:var(--red);border-color:#e847474d}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem;transition:border-color var(--transition),transform var(--transition)}.card:hover{border-color:var(--border-light)}.section-label{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem}.section-title{font-size:clamp(2rem,4vw,3rem);font-weight:700;margin-bottom:1.5rem;color:var(--text)}.divider{border:none;border-top:1px solid var(--border);margin:3rem 0}.footer{border-top:1px solid var(--border);padding:2rem;text-align:center;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.06em;color:var(--text-dim)}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-up{animation:fadeUp .5s ease forwards}.fade-in{animation:fadeIn .4s ease forwards}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");opacity:.025;pointer-events:none;z-index:9999}@media (max-width: 768px){.nav__links{gap:1.5rem}.container{padding:0 1.25rem}}@media (max-width: 600px){.nav__links a{font-size:.7rem}}.fade-up{opacity:0;animation-fill-mode:forwards}.hero{display:flex;align-items:center;justify-content:space-between;gap:4rem;min-height:calc(100vh - 80px);padding-top:4rem;padding-bottom:4rem}.hero__content{flex:1;max-width:560px}.hero__title{font-size:clamp(2.8rem,6vw,4.5rem);font-weight:900;letter-spacing:-2px;line-height:1.05;margin-bottom:1.5rem;color:var(--text)}.hero__title-em{color:var(--accent);font-style:italic}.hero__bio{font-size:1.05rem;color:var(--text-muted);line-height:1.75;margin-bottom:2rem;max-width:480px}.hero__bio strong{color:var(--text);font-weight:600}.hero__actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2rem}.hero__social{display:flex;gap:1rem}.social-link{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-light);border-radius:var(--radius);color:var(--text-muted);transition:all var(--transition)}.social-link:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}.hero__photo-wrap{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:1rem;opacity:0;animation:fadeIn .6s ease forwards}.hero__photo{width:220px;height:220px;border-radius:50%;padding:3px;background:linear-gradient(135deg,var(--accent),transparent 60%);position:relative}.hero__photo:before{content:"";position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:50%;border:1px solid var(--border)}.hero__photo-inner{width:100%;height:100%;border-radius:50%;background:var(--bg-3);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:3rem;font-weight:700;color:var(--accent);letter-spacing:-2px}.hero__status{display:flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.04em;color:var(--text-muted);background:var(--surface);border:1px solid var(--border);padding:.4rem 1rem;border-radius:20px}.hero__status-dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green);animation:pulse 2s ease infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.85)}}.skills{padding:2rem 0}.skills__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1.25rem}.skills__category{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem;font-weight:500}.skills__items{display:flex;flex-wrap:wrap;gap:.5rem}.about{padding:2rem 0 4rem}.about__inner{display:grid;grid-template-columns:1fr 1.4fr;gap:4rem;align-items:start}.about__title{font-size:clamp(1.8rem,3vw,2.4rem);font-weight:700;letter-spacing:-1px}.about__text{display:flex;flex-direction:column;gap:1rem;color:var(--text-muted);line-height:1.75}@media (max-width: 768px){.hero{flex-direction:column-reverse;align-items:flex-start;gap:2.5rem;padding-top:2.5rem}.hero__photo{width:140px;height:140px}.hero__photo-inner{font-size:2rem}.about__inner{grid-template-columns:1fr;gap:2rem}}.projects__header{padding:4rem 0 3rem;max-width:600px}.projects__subtitle{color:var(--text-muted);font-size:1.05rem;line-height:1.7}.projects__list{display:flex;flex-direction:column;gap:1.5rem;padding-bottom:5rem}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;transition:border-color var(--transition),transform var(--transition);opacity:0;animation-fill-mode:forwards}.project-card:hover{border-color:var(--border-light);transform:translateY(-2px)}.project-card__meta{display:flex;gap:.5rem;margin-bottom:1.25rem}.project-card__inner{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem}.project-card__main{flex:1}.project-card__name{font-size:1.75rem;font-weight:700;letter-spacing:-.5px;margin-bottom:.3rem}.project-card__tagline{font-family:var(--font-mono);font-size:.78rem;color:var(--accent);letter-spacing:.04em;margin-bottom:1rem}.project-card__desc{color:var(--text-muted);line-height:1.7;margin-bottom:1.25rem;max-width:600px;font-size:.95rem}.project-card__highlights{list-style:none;display:flex;flex-direction:column;gap:.35rem;margin-bottom:1.5rem}.project-card__highlights li{font-size:.88rem;color:var(--text-muted);display:flex;align-items:center;gap:.5rem}.highlight-bullet{color:var(--accent);font-family:var(--font-mono);font-size:.75rem}.project-card__tech{display:flex;flex-wrap:wrap;gap:.4rem}.project-card__actions{display:flex;flex-direction:column;gap:.6rem;flex-shrink:0}@media (max-width: 640px){.project-card__inner{flex-direction:column}.project-card__actions{flex-direction:row}}.blog-header{padding:4rem 0 3rem;max-width:600px}.blog-subtitle{color:var(--text-muted);font-size:1.05rem;line-height:1.7}.blog-empty{padding:4rem 0;color:var(--text-dim);font-family:var(--font-mono);font-size:.85rem}.blog-list{display:flex;flex-direction:column;border-top:1px solid var(--border);padding-bottom:5rem}.blog-item{display:grid;grid-template-columns:130px 1fr;gap:2.5rem;padding:2.5rem 0;border-bottom:1px solid var(--border);opacity:0;animation-fill-mode:forwards;transition:background var(--transition)}.blog-item__left{padding-top:.25rem}.blog-item__date{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.04em;color:var(--text-dim)}.blog-item__tags{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.75rem}.blog-item__title-link{display:block}.blog-item__title{font-size:1.5rem;font-weight:700;letter-spacing:-.5px;margin-bottom:.75rem;transition:color var(--transition)}.blog-item__title-link:hover .blog-item__title{color:var(--accent)}.blog-item__excerpt{color:var(--text-muted);line-height:1.7;font-size:.95rem;margin-bottom:1.25rem;max-width:620px}.blog-item__footer{display:flex;align-items:center;justify-content:space-between}.blog-item__read-time{display:flex;align-items:center;gap:.35rem;font-family:var(--font-mono);font-size:.72rem;color:var(--text-dim)}.blog-item__read-more{display:flex;align-items:center;gap:.35rem;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.04em;color:var(--accent);transition:gap var(--transition)}.blog-item__read-more:hover{gap:.6rem}@media (max-width: 640px){.blog-item{grid-template-columns:1fr;gap:.75rem}}.post-back{margin-top:2.5rem;margin-bottom:2.5rem}.post-notfound{padding:6rem 0;color:var(--text-muted)}.post{max-width:720px;margin:0 auto;padding-bottom:6rem}.post-header{padding-bottom:2rem}.post-header__tags{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.25rem}.post-title{font-size:clamp(2rem,4vw,3rem);font-weight:900;letter-spacing:-1.5px;line-height:1.1;margin-bottom:1rem}.post-excerpt{font-size:1.1rem;color:var(--text-muted);line-height:1.7;margin-bottom:1.5rem}.post-meta{display:flex;gap:1.5rem;font-family:var(--font-mono);font-size:.72rem;color:var(--text-dim)}.post-meta span{display:flex;align-items:center;gap:.35rem}.post-divider{border:none;border-top:1px solid var(--border);margin:2rem 0}.post-body{display:flex;flex-direction:column;gap:1.25rem}.post-p{color:var(--text-muted);line-height:1.85;font-size:1rem}.post-h2{font-size:1.5rem;font-weight:700;letter-spacing:-.5px;margin-top:1rem;color:var(--text)}.post-h1{font-size:1.75rem;font-weight:700;margin-top:1rem}.post-code{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;overflow-x:auto;position:relative}.post-code code{font-family:var(--font-mono);font-size:.85rem;line-height:1.7;color:#c9d1d9;white-space:pre}.post-code__lang{position:absolute;top:.6rem;right:.75rem;font-family:var(--font-mono);font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim)}.login-page{display:flex;align-items:center;justify-content:center}.login-wrap{width:100%;max-width:420px;padding:2rem}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.5rem;animation:fadeUp .4s ease forwards}.login-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--accent-dim);border:1px solid rgba(232,197,71,.3);border-radius:var(--radius-lg);color:var(--accent);margin-bottom:1.5rem}.login-title{font-size:1.75rem;font-weight:700;letter-spacing:-.5px;margin-bottom:.4rem}.login-sub{color:var(--text-muted);font-size:.9rem;margin-bottom:2rem}.login-form{display:flex;flex-direction:column;gap:1.25rem}.form-field{display:flex;flex-direction:column;gap:.5rem}.form-field label{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.input-wrap{position:relative}.input-wrap input{padding-right:2.5rem}.input-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);color:var(--text-dim);transition:color var(--transition)}.input-toggle:hover{color:var(--text-muted)}.login-error{font-size:.85rem;color:var(--red);background:#e8474714;border:1px solid rgba(232,71,71,.2);border-radius:var(--radius);padding:.65rem .85rem}.login-btn{width:100%;justify-content:center;padding:.85rem}.login-hint{margin-top:1.5rem;font-size:.78rem;color:var(--text-dim);text-align:center;font-family:var(--font-mono)}.login-hint code{background:var(--bg-3);padding:.1rem .4rem;border-radius:2px;color:var(--accent)}.admin-page{padding-bottom:4rem}.admin-header{display:flex;align-items:flex-start;justify-content:space-between;padding:3rem 0 2rem;gap:1rem}.admin-title{font-size:2rem;font-weight:700;letter-spacing:-.5px}.admin-stats{display:flex;gap:1rem;margin-bottom:2rem}.stat-card{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.25rem}.stat-value{font-family:var(--font-display);font-size:2rem;font-weight:700}.stat-value--green{color:var(--green)}.stat-value--muted{color:var(--text-muted)}.stat-label{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim)}.admin-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;gap:1rem}.admin-filters{display:flex;gap:.4rem}.filter-btn{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.05em;padding:.4rem .9rem;border-radius:var(--radius);border:1px solid var(--border);color:var(--text-dim);transition:all var(--transition);text-transform:capitalize}.filter-btn:hover{border-color:var(--border-light);color:var(--text-muted)}.filter-btn.active{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.posts-table{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.post-row{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);transition:background var(--transition)}.post-row:last-child{border-bottom:none}.post-row:hover{background:var(--bg-2)}.post-row__main{flex:1;min-width:0}.post-row__title-wrap{display:flex;align-items:center;gap:.6rem;margin-bottom:.35rem}.post-row__status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.post-row__status-dot.published{background:var(--green);box-shadow:0 0 6px var(--green)}.post-row__status-dot.draft{background:var(--text-dim)}.post-row__title{font-size:.95rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:var(--font-body)}.post-row__excerpt{font-size:.82rem;color:var(--text-dim);margin-bottom:.6rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.post-row__meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.post-row__date{font-family:var(--font-mono);font-size:.68rem;color:var(--text-dim)}.post-row__actions{display:flex;gap:.4rem;flex-shrink:0}.icon-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);transition:all var(--transition)}.icon-btn:hover{border-color:var(--accent);color:var(--accent)}.icon-btn--danger:hover{border-color:var(--red);color:var(--red)}.posts-empty{padding:4rem 2rem;display:flex;flex-direction:column;align-items:center;gap:.75rem;color:var(--text-dim);font-size:.9rem}.post-editor{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.editor-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.75rem;border-bottom:1px solid var(--border);background:var(--bg-2)}.editor-title{font-size:1rem;font-weight:600;font-family:var(--font-body)}.editor-header__actions{display:flex;gap:.6rem}.editor-form{padding:2rem 1.75rem;display:flex;flex-direction:column;gap:1.25rem}.form-row{display:grid;grid-template-columns:1fr 160px;gap:1rem;align-items:end}.form-field{display:flex;flex-direction:column;gap:.45rem}.form-field label{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted)}.label-hint{text-transform:none;letter-spacing:0;font-size:.68rem;color:var(--text-dim)}.admin-select{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem 1rem;color:var(--text);font-family:var(--font-body);font-size:.9rem;width:100%;outline:none;cursor:pointer;transition:border-color var(--transition);-webkit-appearance:none;-moz-appearance:none;appearance:none}.admin-select:focus{border-color:var(--accent)}.content-textarea{font-family:var(--font-mono);font-size:.85rem;line-height:1.7;min-height:380px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:1.5rem;animation:fadeIn .15s ease}.modal{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:2rem;max-width:400px;width:100%;animation:fadeUp .2s ease}.modal h3{font-size:1.2rem;font-weight:700;margin-bottom:.75rem}.modal p{color:var(--text-muted);font-size:.9rem;line-height:1.6}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.75rem}@media (max-width: 640px){.admin-stats{flex-direction:column}.form-row{grid-template-columns:1fr}.post-row{flex-direction:column;align-items:flex-start;gap:.75rem}.post-row__actions{width:100%;justify-content:flex-end}}
