﻿:root{--bg: #0b0e13;--fg: #e6e6e6;--muted: #a8b3c1;--acc: #4ade80;--card: #121722;--line: #1e2633;--gradient: linear-gradient(135deg, #4ade80, #22c55e);--bs-body-bg: #0b0e13;--bs-body-color: #e6e6e6;--bs-border-color: #1e2633;--shadow-strong: 0 20px 40px rgba(0, 0, 0, 0.3);--shadow-soft: 0 8px 32px rgba(0, 0, 0, 0.5);--radius-md: 12px;--radius-lg: 16px}*,*::before,*::after{box-sizing:border-box}html{scroll-behavior:smooth;height:100%}body{margin:0;min-height:100%;font-family:system-ui,"Segoe UI",Roboto,Inter,Arial,sans-serif;font-size:16px;line-height:1.6;color:var(--fg);background:radial-gradient(1200px 600px at 10% -10%, #0f1522 0%, #0b0e13 60%),var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none;transition:all .2s ease}a:hover{color:var(--acc)}h1,h2,h3,h4,h5,h6{margin:0;line-height:1.2;font-weight:600}p{margin:0 0 1rem}body::selection{background:rgba(74,222,128,.2)}.container{max-width:1200px}.skip-link{position:absolute;top:-40px;left:6px;background:var(--acc);color:var(--bg);padding:8px;text-decoration:none;z-index:1100;border-radius:4px}.skip-link:focus{top:6px}.custom-navbar{background:rgba(11,14,19,.95) !important;backdrop-filter:blur(20px);border-bottom:1px solid var(--line);transition:all .3s ease}.custom-navbar.scrolled{background:rgba(11,14,19,.98) !important;box-shadow:0 4px 20px rgba(0,0,0,.3)}.navbar-brand{display:flex;align-items:center;gap:12px}.brand-info strong{display:block;font-size:1.1rem;color:var(--fg)}.brand-info small{color:var(--muted);font-size:.85rem}.logo{width:200px;height:auto;display:inline-flex;align-items:center;justify-content:center;padding:0}.logo img{display:block;width:100%;height:auto}@media(max-width: 768px){.logo{width:150px}}.navbar-nav .nav-link{color:var(--muted) !important;font-weight:500;transition:color .2s;margin:0 .5rem}.navbar-nav .nav-link:hover,.navbar-nav .nav-link.active{color:var(--acc) !important}.hero-section{padding:5rem 0 3rem;min-height:60vh;display:flex;align-items:center;position:relative;overflow:hidden}.hero-banner{position:absolute;top:0;right:0;width:100%;height:100%;background-image:url("/banner.png");background-size:cover;background-position:center;background-attachment:fixed;border-radius:20px 0 0 20px;opacity:.25;z-index:1}.hero-banner::before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg, var(--bg) 0%, transparent 40%, rgba(11, 14, 19, 0.3) 100%);z-index:2}.hero-content{position:relative;z-index:3}.hero-title{font-size:clamp(2rem,4vw,3.5rem);text-shadow:2px 2px 8px rgba(0,0,0,.6);padding:1rem;border-radius:8px;background:rgba(11,14,19,.7);line-height:1.1;margin-bottom:1.25rem;font-weight:700}.hero-subtitle{color:var(--muted);font-size:1.15rem;text-shadow:1px 1px 4px rgba(0,0,0,.7);background:rgba(11,14,19,.7);margin-bottom:1.75rem;line-height:1.6;padding:.75rem 1rem;border-radius:10px}.section-title{font-size:2rem;margin-bottom:.75rem;color:var(--fg)}.section-subtitle{color:var(--muted);font-size:1.05rem;margin-bottom:2rem;line-height:1.6}.btn-custom{background:#0f1420;border:1px solid var(--line);color:var(--fg);border-radius:12px;padding:.5rem 1rem;transition:all .2s}.btn-custom:hover{border-color:var(--acc);color:var(--acc);transform:translateY(-1px)}.btn-primary-custom{background:var(--gradient);border:1px solid var(--acc);color:var(--bg);font-weight:500;border-radius:12px;padding:.75rem 1.5rem;transition:all .2s}.btn-primary-custom:hover{background:#22c55e;color:var(--bg);transform:translateY(-2px);box-shadow:0 8px 20px rgba(74,222,128,.3)}.btn-outline-custom{background:rgba(0,0,0,0);border:1px solid var(--line);color:var(--fg);border-radius:12px;padding:.75rem 1.5rem;transition:all .2s}.btn-outline-custom:hover{border-color:var(--acc);color:var(--acc);transform:translateY(-1px)}.project-card,.gallery-card{background:linear-gradient(180deg, #111725, #0c111b);border:1px solid var(--line);border-radius:var(--radius-lg);transition:all .3s ease;overflow:hidden;height:100%;position:relative}.project-card::before,.gallery-card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient);opacity:0;transition:opacity .3s ease}.project-card:hover,.gallery-card:hover{transform:translateY(-8px);border-color:#263247;box-shadow:var(--shadow-strong)}.project-card:hover::before,.gallery-card:hover::before{opacity:1}.card-header-custom{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.card-icon{font-size:2rem;opacity:.8}.card-thumb{height:200px;background:linear-gradient(45deg, #1e2633, #263247);display:flex;align-items:center;justify-content:center;font-size:2.5rem;position:relative;overflow:hidden}.card-thumb img{width:100%;height:100%;object-fit:cover}.card-body{color:var(--fg) !important}.card-title{color:var(--fg) !important;font-weight:600}.card-text{color:var(--muted) !important;font-size:.95rem;line-height:1.5}.project-tag,.badge-accent{display:inline-block;padding:.25rem .5rem;border:1px solid var(--line);border-radius:999px;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.badge-accent{color:var(--acc);background:rgba(74,222,128,.1)}.tag-ghost{border-color:#4338ca;color:#a5b4fc}.tag-code{border-color:#059669;color:#6ee7b7}.tag-gitea{border-color:#dc2626;color:#fca5a5}.tag-dashboard{border-color:#7c3aed;color:#c4b5fd}.tag-docs{border-color:#ea580c;color:#fdba74}.tag-contact{border-color:var(--acc);color:var(--acc)}.status-panel{background:rgba(18,23,34,.9);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.5rem;height:fit-content;box-shadow:var(--shadow-soft);border-left:4px solid var(--acc);position:relative;z-index:4}.status-title{margin-bottom:1rem;font-size:1.1rem;font-weight:600;color:var(--fg)}.status-list{list-style:none;padding:0;margin:0}.status-item{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;color:var(--muted);font-size:.9rem}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.active{background:#22c55e;box-shadow:0 0 8px #22c55e;animation:pulse 2s infinite}.status-dot.progress{background:#f59e0b;box-shadow:0 0 8px #f59e0b}.status-dot.testing{background:#3b82f6;box-shadow:0 0 8px #3b82f6}.achievement-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.5rem;height:100%;position:relative;overflow:hidden;text-align:center}.achievement-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient)}.achievement-icon{font-size:2.5rem;display:block;margin-bottom:1rem}.stat-card{background:var(--card) !important;border:1px solid var(--line) !important;border-radius:var(--radius-lg) !important;text-align:center;padding:1.5rem;height:100%;box-shadow:0 8px 20px rgba(0,0,0,.3)}.stat-number{font-size:2.4rem;font-weight:700;color:var(--acc);display:block}.stat-label{color:var(--muted);font-size:.95rem;margin-top:.35rem}.stat-card hr{border-color:var(--line)}.text-gradient{background:var(--gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:rgba(0,0,0,0)}.about-section{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:2rem;margin:4rem 0}.section-subtitle{color:var(--muted);font-size:1.1rem;margin-bottom:1.5rem;line-height:1.6}.social-links{display:flex;gap:1.5rem;flex-wrap:wrap}.social-link{display:flex;align-items:center;gap:.5rem;color:var(--muted);transition:color .2s;text-decoration:none}.social-link:hover{color:var(--acc)}.skills-panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.5rem}.skills-grid{display:flex;flex-wrap:wrap;gap:.5rem}.skill-tag{padding:.25rem .75rem;background:rgba(74,222,128,.1);border:1px solid rgba(74,222,128,.3);border-radius:8px;font-size:.85rem;color:var(--acc)}.contact-section{padding:4rem 0;text-align:center}.contact-description{font-size:1.2rem;color:var(--muted);margin-bottom:2rem}.contact-button{display:inline-flex;align-items:center;gap:1rem;padding:1rem 2rem;background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);color:var(--fg);text-decoration:none;transition:all .3s ease}.contact-button:hover{border-color:var(--acc);transform:translateY(-2px);box-shadow:0 12px 24px rgba(0,0,0,.3);color:var(--fg)}.contact-icon{font-size:1.5rem}.footer{background:var(--card);border-top:1px solid var(--line);padding:2rem 0;margin-top:4rem}.footer-content{display:flex;justify-content:space-between;align-items:center;color:var(--muted);font-size:.9rem}.footer-link{color:var(--muted);text-decoration:none;transition:color .2s}.footer-link:hover{color:var(--acc)}.section-spacing{padding:4rem 0}.hero-title .text-gradient{display:inline-block}.status-panel{margin-top:1rem}.projects-section{padding:4rem 0}.projects-section .section-title{text-align:center}.projects-section .section-subtitle{text-align:center;margin:0 auto 2.5rem;max-width:640px}.gallery-hero{position:relative;padding:5.5rem 0 6rem;background:radial-gradient(circle at 20% 20%, rgba(74, 222, 128, 0.12), transparent 55%),radial-gradient(circle at 80% 10%, rgba(34, 197, 94, 0.15), transparent 45%),linear-gradient(180deg, rgba(11, 14, 19, 0.9), rgba(11, 14, 19, 0.98))}.gallery-hero__intro{max-width:640px;margin-bottom:2.5rem}.gallery-hero__intro .eyebrow{text-transform:uppercase;letter-spacing:.2em;font-size:.8rem;margin-bottom:.75rem}.gallery-hero__intro .hero-title{font-size:clamp(2.4rem,4.2vw,3.8rem)}.gallery-carousel{position:relative;max-width:1200px;margin:0 auto;padding:0 2.5rem 2rem}.carousel-viewport{overflow:hidden;border-radius:24px;box-shadow:var(--shadow-strong);border:1px solid rgba(255, 255, 255, 0.08);background:#0a0f16;touch-action:pan-y;height:clamp(260px,55vw,520px)}.carousel-track{display:flex;transition:transform .45s ease;will-change:transform}.carousel-slide{min-width:100%;position:relative;background:#0b0f17;display:flex;align-items:center;justify-content:center;padding:1rem}.carousel-slide.is-active{cursor:zoom-in}.carousel-slide img{max-width:100%;max-height:100%;width:auto;height:auto;display:block;object-fit:contain;filter:saturate(1.05) contrast(1.05);background:#0b0f17}.carousel-slide::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(11, 14, 19, 0.05), rgba(11, 14, 19, 0.55));pointer-events:none}.carousel-control{position:absolute;top:45%;transform:translateY(-50%);width:48px;height:48px;border-radius:999px;border:1px solid rgba(255, 255, 255, 0.15);background:rgba(10, 14, 20, 0.7);color:var(--fg);display:grid;place-items:center;transition:transform .2s ease, background .2s ease, border .2s ease;z-index:2}.carousel-control:hover{transform:translateY(-50%) scale(1.05);background:rgba(20, 28, 38, 0.85);border-color:rgba(255, 255, 255, 0.3)}.carousel-control:focus-visible{outline:2px solid var(--acc);outline-offset:3px}.carousel-control.prev{left:.5rem}.carousel-control.next{right:.5rem}.carousel-meta{display:flex;flex-direction:column;gap:.4rem;margin-top:1.5rem;max-width:720px}.carousel-count{font-size:.95rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.carousel-caption{font-size:1.1rem;margin:0}.carousel-hint{margin:0;color:var(--muted);font-size:.95rem}@media(max-width: 992px){.gallery-carousel{padding:0 1.5rem 2rem}.carousel-control{width:42px;height:42px}}@media(max-width: 768px){.gallery-hero{padding:4.5rem 0 5rem}.carousel-control{top:auto;bottom:-18px;transform:none}.carousel-control.prev{left:30%}.carousel-control.next{right:30%}.carousel-control:hover{transform:none}}@media(prefers-reduced-motion: reduce){.carousel-track{transition:none}}body[data-page=cv]{background:linear-gradient(135deg, #020617 0%, #0f172a 50%, #1e293b 100%)}.cv-container{max-width:1200px;margin:0 auto;background:rgba(15,23,42,.98);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 25px 50px -12px rgba(0,0,0,.6);overflow:hidden;border:1px solid rgba(51,65,85,.4);display:grid;grid-template-columns:350px 1fr;min-height:100vh}.cv-sidebar{background:linear-gradient(180deg, #000000 0%, #0c0a09 100%);padding:40px 30px;color:#fff}.cv-profile-header{text-align:center;margin-bottom:40px}.cv-profile-name{font-size:2rem;font-weight:800;margin-bottom:10px;background:linear-gradient(135deg, #fff 0%, #e2e8f0 100%);-webkit-background-clip:text;-webkit-text-fill-color:rgba(0,0,0,0);background-clip:text}.cv-profile-subtitle{font-size:.9rem;opacity:.9;font-weight:300;letter-spacing:.5px;line-height:1.4}.cv-sidebar-section{margin-bottom:35px}.cv-sidebar-title{font-size:1.2rem;font-weight:700;color:#10b981;margin-bottom:15px;text-transform:uppercase;letter-spacing:1px}.cv-contact-item{margin-bottom:12px;display:flex;align-items:center;font-size:.9rem}.cv-contact-icon{font-size:1.1rem;margin-right:16px;min-width:24px;text-align:center}.cv-contact-label{font-weight:600;margin-right:8px;min-width:50px;color:#cbd5e1}.cv-contact-value{color:#f1f5f9}.cv-skills-list{list-style:none;padding-left:0}.cv-skills-list li{position:relative;padding-left:20px;margin-bottom:8px;color:#e2e8f0;font-size:.9rem}.cv-skills-list li::before{content:"▸";position:absolute;left:0;color:#10b981;font-weight:bold}.cv-opensource-item{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.3);border-radius:8px;padding:15px;margin-bottom:12px}.cv-opensource-title{font-weight:600;color:#fff;margin-bottom:5px;font-size:.95rem}.cv-opensource-desc{font-size:.85rem;color:#cbd5e1;line-height:1.4}.cv-main{padding:40px;overflow-y:auto}.cv-section{margin-bottom:40px}.cv-section-title{font-size:1.8rem;font-weight:700;color:#fff;margin-bottom:25px;position:relative;display:inline-block}.cv-section-title::after{content:"";position:absolute;bottom:-8px;left:0;width:50px;height:3px;background:linear-gradient(135deg, #059669 0%, #10b981 100%);border-radius:2px}.cv-card{background:rgba(30,41,59,.8);border:1px solid rgba(71,85,105,.5);border-radius:12px;padding:25px;margin-bottom:20px;transition:all .3s ease;position:relative;overflow:hidden}.cv-card:hover{transform:translateY(-2px);border-color:rgba(16,185,129,.4);box-shadow:0 10px 30px -12px rgba(0,0,0,.5)}.cv-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.cv-card-title{font-size:1.1rem;font-weight:700;color:#f8fafc}.cv-card-subtitle{color:#cbd5e1;font-size:.95rem}.cv-meta{color:#94a3b8;font-size:.9rem;margin-bottom:10px}.cv-badge{display:inline-block;padding:4px 10px;background:rgba(59,130,246,.15);color:#bfdbfe;border-radius:999px;font-size:.8rem;margin-right:6px}.cv-list{list-style:none;padding-left:0;margin:10px 0 0}.cv-list li{position:relative;padding-left:20px;margin-bottom:8px;color:#e2e8f0}.cv-list li::before{content:"•";position:absolute;left:0;color:#22c55e;font-weight:bold}.cv-highlight{color:#22c55e;font-weight:700}@media(max-width: 992px){.cv-container{grid-template-columns:1fr}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.7}}.fade-in-up{opacity:0;transform:translateY(30px);transition:all .8s ease}.fade-in-up.show{opacity:1;transform:translateY(0)}.fade-in-left{opacity:0;transform:translateX(-30px);transition:all .8s ease}.fade-in-left.show{opacity:1;transform:translateX(0)}.stagger-1{transition-delay:.1s}.stagger-2{transition-delay:.2s}.stagger-3{transition-delay:.3s}.stagger-4{transition-delay:.4s}.stagger-5{transition-delay:.5s}.stagger-6{transition-delay:.6s}@media(max-width: 992px){.hero-section{padding:3rem 0;text-align:center}.hero-banner{background-attachment:scroll}.footer-content{flex-direction:column;gap:1rem;text-align:center}}@media(max-width: 768px){.hero-title{font-size:2.5rem}.navbar-brand{flex-direction:column;gap:0;text-align:center}.navbar-brand .logo{margin-bottom:.5rem}}
.logo-wall{padding:3.5rem 0 4rem;border-top:1px solid var(--line);background:radial-gradient(circle at 15% 20%, rgba(74, 222, 128, 0.18), transparent 45%),radial-gradient(circle at 85% 10%, rgba(59, 130, 246, 0.18), transparent 40%),linear-gradient(180deg, rgba(9, 13, 20, 0.9), rgba(11, 14, 19, 0.98))}.logo-wall__label{color:#d4fbe3;text-transform:uppercase;letter-spacing:.2em;font-size:.75rem;margin-bottom:1.5rem}.logo-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(160px, 1fr));gap:1rem;align-items:center}.logo-grid__item{display:flex;align-items:center;justify-content:center;height:160px;padding:12px;border:1px solid rgba(148, 163, 184, 0.18);border-radius:16px;background:linear-gradient(145deg, rgba(16, 23, 35, 0.9), rgba(10, 14, 20, 0.6));box-shadow:inset 0 0 0 1px rgba(74, 222, 128, 0.08),0 12px 30px rgba(0,0,0,.35);transition:transform .2s ease, border .2s ease, background .2s ease, box-shadow .2s ease}.logo-grid__item img{max-height:120px;max-width:120px;width:auto;filter:grayscale(1) contrast(1.05);opacity:.8}.logo-grid__item:hover{transform:translateY(-3px);border-color:rgba(74, 222, 128, 0.5);background:linear-gradient(145deg, rgba(20, 30, 45, 0.95), rgba(10, 16, 26, 0.7));box-shadow:0 16px 36px rgba(0,0,0,.45),0 0 0 1px rgba(74, 222, 128, 0.2)}.logo-grid__item:hover img{filter:grayscale(.15) contrast(1.1);opacity:1}@media(max-width: 768px){.logo-wall{padding:2.5rem 0 3.5rem}.logo-grid{grid-template-columns:repeat(auto-fit, minmax(160px, 1fr));gap:.8rem}.logo-grid__item{height:160px;padding:10px}.logo-grid__item img{max-height:110px;max-width:110px}}

.no-scroll{overflow:hidden}.gallery-zoom{position:fixed;inset:0;background:rgba(5,8,12,.92);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .2s ease, visibility .2s ease;z-index:1200;padding:2rem}.gallery-zoom.is-open{opacity:1;visibility:visible;pointer-events:auto}.gallery-zoom__image{max-width:min(92vw,1200px);max-height:85vh;object-fit:contain;border-radius:18px;box-shadow:0 30px 80px rgba(0,0,0,.55);background:#0b0f17}.gallery-zoom__close{position:absolute;top:24px;right:24px;border:1px solid rgba(255,255,255,.2);background:rgba(15,20,30,.85);color:var(--fg);width:44px;height:44px;border-radius:999px;display:grid;place-items:center;cursor:pointer;transition:transform .2s ease, border .2s ease, background .2s ease}.gallery-zoom__close:hover{transform:scale(1.05);border-color:rgba(255,255,255,.5);background:rgba(30,40,55,.9)}@media(max-width: 768px){.gallery-zoom{padding:1.5rem}.gallery-zoom__image{max-height:80vh}.gallery-zoom__close{top:16px;right:16px;width:40px;height:40px}}

.playground-card{border:1px solid rgba(74,222,128,.4);background:radial-gradient(circle at 10% 20%, rgba(74, 222, 128, 0.25), transparent 45%),radial-gradient(circle at 90% 10%, rgba(59, 130, 246, 0.25), transparent 35%),linear-gradient(160deg, rgba(18, 26, 38, 0.98), rgba(12, 17, 27, 0.9));box-shadow:0 24px 50px rgba(0,0,0,.45),0 0 0 1px rgba(74, 222, 128, 0.2);position:relative;overflow:hidden}.playground-card::after{content:"";position:absolute;inset:-40%;background:conic-gradient(from 120deg, rgba(74,222,128,.15), rgba(59,130,246,.15), rgba(16,185,129,.15), rgba(74,222,128,.15));opacity:.45;animation:playground-spin 12s linear infinite}.playground-card .card-body{position:relative;z-index:1}.playground-card .card-title{font-size:1.6rem}.playground-cta{display:inline-flex;align-items:center;gap:.35rem;margin-top:.75rem;color:var(--acc);font-weight:600;letter-spacing:.02em;text-transform:uppercase;font-size:.85rem}.playground-card:hover{transform:translateY(-6px);border-color:rgba(74,222,128,.7)}@keyframes playground-spin{to{transform:rotate(360deg)}}

.carousel-viewport{height:auto}.carousel-slide{align-items:center;padding:0}.carousel-slide img{width:100%;height:auto;max-height:80vh;object-fit:contain}

.logo-wall{background:radial-gradient(circle at 15% 20%, rgba(74, 222, 128, 0.28), transparent 45%),radial-gradient(circle at 85% 10%, rgba(59, 130, 246, 0.28), transparent 40%),linear-gradient(180deg, rgba(7, 10, 16, 0.95), rgba(12, 17, 27, 0.98))}.logo-grid__item{border-color:rgba(148, 163, 184, 0.28);background:linear-gradient(145deg, rgba(18, 28, 45, 0.95), rgba(10, 15, 24, 0.7));box-shadow:inset 0 0 0 1px rgba(74, 222, 128, 0.15),0 18px 34px rgba(0,0,0,.45)}.logo-grid__item img{opacity:.9;filter:grayscale(.75) contrast(1.15)}.logo-grid__item:hover{border-color:rgba(74, 222, 128, 0.7);box-shadow:0 20px 42px rgba(0,0,0,.55),0 0 0 1px rgba(74, 222, 128, 0.35)}
