:root{--bg:#f6f7fb;--bg-2:#fff;--surface:#1118270a;--surface-2:#1118270f;--border:#1118271a;--text:#0f172a;--text-2:#0f172ab8;--text-3:#0f172a80;--accent:#334155;--accent-strong:#0f172a;--card-bg:#ffffffeb;--card-bg-2:#ffffffd1;--soft:#0f172a0f;--soft-2:#0f172a14;--r-xs:10px;--r-sm:12px;--r-md:16px;--r-lg:20px;--r-xl:24px;--r-full:9999px;--s-2:2px;--s-4:4px;--s-6:6px;--s-8:8px;--s-10:10px;--s-12:12px;--s-16:16px;--s-20:20px;--s-24:24px;--s-32:32px;--s-40:40px;--s-48:48px;--s-64:64px;--font-sys:-apple-system,BlinkMacSystemFont,"SF Pro Display","Segoe UI",system-ui,sans-serif;--shadow-sm:0 2px 10px #0f172a14;--shadow-md:0 10px 26px #0f172a1a;--shadow-lg:0 18px 44px #0f172a1f;--ease:cubic-bezier(.22,1,.36,1);--ease-2:cubic-bezier(.16,1,.3,1);--dur-1:.16s;--dur-2:.26s;--container:1120px}[data-theme=android]{--r-sm:14px;--r-md:18px;--r-lg:22px;--r-xl:26px}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-size:16px}body{font-family:var(--font-sys);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5;overflow-x:hidden}body:before{content:"";pointer-events:none;opacity:.1;z-index:0;background-image:radial-gradient(#0f172a0d 1px,#0000 1px);background-size:28px 28px;position:fixed;inset:0}a{color:inherit;text-decoration:none}button{cursor:pointer;-webkit-user-select:none;user-select:none;font-family:inherit}img{max-width:100%;display:block}:focus-visible{outline-offset:2px;border-radius:10px;outline:2px solid #0f172a40}.cursor-pointer{cursor:pointer}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.app-shell{z-index:1;min-height:100vh;position:relative}.preloader{background:var(--bg);z-index:99999;opacity:1;pointer-events:all;justify-content:center;align-items:center;transition:opacity .6s cubic-bezier(.22,1,.36,1),visibility 0s .6s;display:flex;position:fixed;inset:0}.preloader.is-done{opacity:0;pointer-events:none;visibility:hidden}.preloader-center{justify-content:center;align-items:center;width:80px;height:80px;display:flex;position:relative}.preloader-logo{opacity:0;border-radius:50%;width:56px;height:56px;animation:.5s cubic-bezier(.22,1,.36,1) .15s forwards preloaderLogoIn;transform:scale(.85)}.preloader-spinner{border:2px solid #0f172a0f;border-top-color:#0f172a59;border-radius:50%;animation:.8s linear infinite preloaderSpin;position:absolute;inset:0}@keyframes preloaderLogoIn{to{opacity:1;transform:scale(1)}}@keyframes preloaderSpin{to{transform:rotate(360deg)}}.theme-switcher{top:var(--s-16);right:var(--s-16);z-index:10000;gap:var(--s-6);padding:var(--s-6);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--r-sm);box-shadow:var(--shadow-sm);background:#ffffffb8;display:flex;position:fixed}.theme-toggle{min-width:44px;height:36px;padding:0 var(--s-12);border-radius:var(--r-xs);color:var(--text-2);transition:transform var(--dur-1)var(--ease),background var(--dur-1)var(--ease),color var(--dur-1)var(--ease),border-color var(--dur-1)var(--ease);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;display:flex}.theme-toggle.active{color:var(--text);background:#0f172a0f;border-color:#0f172a1f}.theme-toggle:active{transform:scale(.96)}.app-header{padding:var(--s-12)var(--s-16);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border);z-index:999;background:#ffffffb8;position:sticky;top:0}.header-content{align-items:center;gap:var(--s-12);display:flex}.header-avatar{justify-content:center;align-items:center;width:44px;height:44px;display:flex;box-shadow:none!important;background:0 0!important;border:none!important;border-radius:0!important;padding:0!important;overflow:visible!important}.header-avatar:before,.header-avatar:after{content:none!important;display:none!important}.header-avatar .logo-img,.header-avatar img{width:44px;height:44px;object-fit:contain!important;box-shadow:none!important;filter:none!important;background:0 0!important;border-radius:0!important;outline:none!important}.header-info h1{letter-spacing:-.2px;font-size:16px;font-weight:750;line-height:1.2}.header-info p{color:var(--text-2);font-size:13px;font-weight:550}.desktop-nav{display:none}.nav-wrapper{max-width:var(--container);padding:0 var(--s-24);justify-content:space-between;align-items:center;height:64px;margin:0 auto;display:flex}.nav-logo{letter-spacing:-.6px;color:var(--text);cursor:pointer;transition:opacity var(--dur-1)var(--ease);align-items:center;gap:12px;font-size:18px;font-weight:900;text-decoration:none;display:flex}.nav-logo:hover{opacity:.8}.nav-logo-img{object-fit:contain;width:32px;height:32px}.nav-links{align-items:center;gap:12px;display:flex}.nav-item{color:var(--text-2);border-radius:var(--r-full);transition:background var(--dur-1)var(--ease),color var(--dur-1)var(--ease),border-color var(--dur-1)var(--ease);cursor:pointer;border:1px solid #0000;justify-content:center;align-items:center;padding:8px 12px;font-size:13.5px;font-weight:750;text-decoration:none;display:inline-flex}.nav-item:hover{color:var(--text);background:#0f172a0f}.nav-item.active{color:var(--text);background:#0f172a14;border-color:#0f172a1a}.app-content{padding-bottom:calc(70px + env(safe-area-inset-bottom))}.view{opacity:1;display:block}.view.active{animation:viewFadeIn var(--dur-2)var(--ease)forwards;display:block}.view-inner{padding:var(--s-24);max-width:var(--container);margin:0 auto}.tab-bar{-webkit-backdrop-filter:blur(24px);padding:0 4px;padding-bottom:calc(8px + env(safe-area-inset-bottom));z-index:1000;background:#ffffffb8;border-top:1px solid #0f172a0f;align-items:flex-end;display:flex;position:fixed;bottom:0;left:0;right:0}.tab-item{color:var(--text-3);min-height:56px;transition:color var(--dur-1)var(--ease);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:4px;padding:10px 4px 8px;text-decoration:none;display:flex;position:relative}.tab-item.active{color:var(--text)}.tab-item.active:after{content:"";background:var(--text);width:4px;height:4px;animation:dotIn .3s var(--ease)forwards;border-radius:50%;position:absolute;bottom:2px}@keyframes dotIn{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.tab-icon{width:22px;height:22px;transition:transform var(--dur-1)var(--ease)}.tab-item.active .tab-icon{transform:translateY(-1px)}.tab-label{letter-spacing:.2px;font-size:10px;font-weight:600}.tab-item.tab-home{margin-top:-18px;padding-top:0}.tab-home-circle{background:var(--text);width:50px;height:50px;transition:transform var(--dur-1)var(--ease),box-shadow var(--dur-1)var(--ease);border-radius:50%;justify-content:center;align-items:center;display:flex;box-shadow:0 4px 16px #0f172a33,0 1.5px 4px #0f172a1a}.tab-icon-home{color:#fff!important;width:16px!important;height:16px!important}.tab-item.tab-home .tab-label{color:var(--text);margin-top:2px;font-weight:700}.tab-item.tab-home.active .tab-home-circle{transform:translateY(-2px)scale(1.04);box-shadow:0 8px 24px #0f172a40,0 2px 6px #0f172a1f}.tab-item.tab-home:active .tab-home-circle{transform:scale(.94);box-shadow:0 2px 8px #0f172a26}.tab-item.tab-home.active:after{display:none}.tab-icon-home{color:#fff!important;stroke:#fff!important;width:16px!important;height:16px!important}.tab-home-circle{background:var(--text);color:#fff;width:50px;height:50px;transition:transform var(--dur-1)var(--ease),box-shadow var(--dur-1)var(--ease);border-radius:50%;justify-content:center;align-items:center;display:flex;box-shadow:0 4px 16px #0f172a33,0 1.5px 4px #0f172a1a}.tab-item.tab-home .tab-home-circle .tab-icon{width:24px;height:24px}@media (min-width:768px){.app-header,.tab-bar{display:none}.desktop-nav{z-index:1000;-webkit-backdrop-filter:blur(14px);background:#ffffffb8;border-bottom:1px solid #0f172a1a;display:block;position:fixed;top:0;left:0;right:0}.app-content{padding-top:64px;padding-bottom:0}.view-inner{padding:var(--s-64)var(--s-24)}.theme-switcher{top:84px}}@media (max-width:768px){html{font-size:15px}.view-inner{padding:var(--s-16)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes viewFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{opacity:0;transform:translateY(18px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes skillGrow{0%{transform:scaleX(0)}to{transform:scaleX(1)}}@keyframes sanityFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes skeletonShimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.hero-section{text-align:center;padding:var(--s-48)0}.status-badge{border-radius:var(--r-full);color:var(--text-2);margin-bottom:var(--s-24);background:#0f172a0a;border:1px solid #0f172a1a;align-items:center;gap:10px;padding:10px 14px;font-size:13px;font-weight:650;display:inline-flex}.status-indicator{background:#22c55e;border-radius:50%;width:9px;height:9px;box-shadow:0 0 0 3px #22c55e2e,0 0 12px #22c55e73}.status-badge[data-status=available] .status-indicator{background:#22c55e}.status-badge[data-status=busy] .status-indicator{background:#ef4444}.status-badge[data-status=limited] .status-indicator{background:#f59e0b}.status-badge[data-status=break] .status-indicator{background:#94a3b8}.hero-title{letter-spacing:-2px;margin-bottom:var(--s-16);font-size:clamp(34px,7vw,56px);font-weight:900;line-height:1.06}.gradient-text{color:var(--text)}.hero-desc{color:var(--text-2);max-width:720px;margin:0 auto var(--s-32);font-size:16px;line-height:1.7}.hero-buttons{gap:var(--s-12);flex-direction:column;align-items:center;display:flex}.full-width{width:100%}.stats-grid{gap:var(--s-12);margin-top:var(--s-40);grid-template-columns:repeat(3,1fr);display:grid}.stat-card{padding:var(--s-20);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);text-align:center;transition:transform var(--dur-1)var(--ease),border-color var(--dur-1)var(--ease);background:#ffffffb8;border:1px solid #0f172a1a}.stat-card:hover{border-color:#0f172a29;transform:translateY(-2px)}.stat-value{letter-spacing:-.8px;color:var(--text);margin-bottom:6px;font-size:28px;font-weight:850}.stat-label{color:var(--text-2);font-size:12px;font-weight:650}.view-header{text-align:center;margin-bottom:var(--s-40)}.view-tag{border-radius:var(--r-full);color:var(--text-2);letter-spacing:.8px;text-transform:uppercase;margin-bottom:var(--s-16);background:#0f172a0a;border:1px solid #0f172a1a;align-items:center;gap:8px;padding:8px 14px;font-size:12px;font-weight:700;display:inline-flex}.view-title{letter-spacing:-1.2px;margin-bottom:var(--s-12);color:var(--text);font-size:clamp(28px,4.8vw,40px);font-weight:850}.view-subtitle,.about-intro{color:var(--text-2);max-width:640px;margin:0 auto;font-size:15px}@media (min-width:768px){.hero-section{padding:78px 0}.hero-buttons{flex-direction:row;justify-content:center}.view-header{margin-bottom:var(--s-24)}}@media (max-width:768px){.hero-section{padding:var(--s-32)0 var(--s-40)}.hero-title{letter-spacing:-1.2px}.hero-desc{margin-bottom:var(--s-24);font-size:14.5px}.stats-grid{grid-template-columns:repeat(3,1fr);gap:10px}.stat-card{border-radius:var(--r-md);padding:14px}.stat-value{font-size:20px}}.about-subtitle{color:var(--text-3);letter-spacing:.2px;margin-top:6px;font-size:14px;font-weight:600}.about-summary{color:var(--text-2);margin-top:8px;font-size:13px;font-weight:650}.about-timeline{margin-top:var(--s-24);gap:14px;display:grid}.timeline-item{border-radius:var(--r-md);transition:transform var(--dur-1)var(--ease),border-color var(--dur-1)var(--ease);background:#ffffffc7;border:1px solid #0f172a1a;gap:16px;padding:16px 18px;display:flex}.timeline-item:hover{border-color:#0f172a29;transform:translateY(-1px)}.timeline-item .year{min-width:90px;color:var(--text);opacity:.8;font-weight:800}.timeline-item .content h4{color:var(--text);margin-bottom:4px;font-size:14px;font-weight:850}.timeline-item .content p{color:var(--text-2);font-size:13.5px;line-height:1.65}.timeline-item.highlight{background:#0f172a08;border-color:#0f172a1f}.about-quote{border-radius:var(--r-md);color:var(--text-2);background:#ffffffc7;border-left:3px solid #0f172a33;margin-top:24px;padding:16px 18px;font-style:italic}.profile-card{text-align:center}.profile-avatar{border-radius:var(--r-xl);width:88px;height:88px;margin:0 auto var(--s-16);box-shadow:var(--shadow-md);background:#0f172a0a;border:1px solid #0f172a1a;justify-content:center;align-items:center;display:flex;overflow:hidden}.logo-img,.nav-logo-img{box-shadow:none!important;filter:none!important;background:0 0!important;border-radius:0!important;outline:none!important}.logo-img{object-fit:contain;width:100%;height:100%}.profile-card h3{letter-spacing:-.6px;margin-bottom:4px;font-size:22px;font-weight:850}.profile-card p{color:var(--text-2);font-size:14px}.content-card .lead{margin-bottom:var(--s-12);color:var(--text);font-size:16px;font-weight:700}.content-card p{color:var(--text-2);margin-bottom:12px;font-size:14px;line-height:1.75}.feature-list{gap:var(--s-12);margin-top:var(--s-16);display:grid}.feature-item{align-items:center;gap:var(--s-12);padding:var(--s-14);border-radius:var(--r-md);transition:transform var(--dur-1)var(--ease),border-color var(--dur-1)var(--ease);background:#0f172a08;border:1px solid #0f172a14;display:flex}.feature-item:hover{border-color:#0f172a24;transform:translateY(-1px)}.feature-icon{border-radius:var(--r-sm);width:30px;height:30px;color:var(--text);background:#0f172a0f;border:1px solid #0f172a1a;flex-shrink:0;justify-content:center;align-items:center;font-weight:900;display:inline-flex}.feature-item span{color:var(--text);font-size:14px;font-weight:650}.skills-list{gap:var(--s-16);display:grid}.skills-grid{gap:18px;display:grid}.skill-card{padding:var(--s-24);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);transition:transform var(--dur-2)var(--ease-2),border-color var(--dur-2)var(--ease-2),box-shadow var(--dur-2)var(--ease-2);background:#ffffffc7;border:1px solid #0f172a1a;position:relative;overflow:hidden}.skill-card:hover{box-shadow:var(--shadow-md);border-color:#0f172a29;transform:translateY(-2px)}.skill-icon{border-radius:var(--r-md);background:#0f172a0f;border:1px solid #0f172a1a;justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:14px;display:inline-flex}.skill-card h3{letter-spacing:-.2px;color:var(--text);margin-bottom:12px;font-size:16px;font-weight:850}.skill-tags{flex-wrap:wrap;gap:10px;display:flex}.skill-tag{border-radius:var(--r-full);color:var(--text-2);transition:border-color var(--dur-1)var(--ease),background var(--dur-1)var(--ease),color var(--dur-1)var(--ease);background:#0f172a0a;border:1px solid #0f172a1a;padding:7px 12px;font-size:12px;font-weight:650}.skill-tag:hover{color:var(--text);background:#0f172a0f;border-color:#0f172a24}.tech-chips{gap:var(--s-8);flex-wrap:wrap;display:flex}.chip{border-radius:var(--r-full);color:var(--text-2);background:#0f172a0a;border:1px solid #0f172a1a;padding:8px 12px;font-size:12px;font-weight:650}.chip:hover{border-color:#0f172a24}.skills-modern{gap:12px;display:grid}.skill-block{border-radius:var(--r-lg);box-shadow:var(--shadow-sm);transition:transform var(--dur-2)var(--ease-2),box-shadow var(--dur-2)var(--ease-2),border-color var(--dur-2)var(--ease-2);break-inside:avoid;background:#ffffffd6;border:1px solid #0f172a1a;padding:12px}.skill-block:hover{box-shadow:var(--shadow-md);border-color:#0f172a24;transform:translateY(-2px)}.skill-block-header{border-bottom:1px solid #0f172a14;align-items:center;gap:10px;margin-bottom:6px;padding:0 2px 8px;display:flex}.skill-block-icon{border-radius:var(--r-sm);background:#0f172a0d;border:1px solid #0f172a1a;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.skill-block-icon svg{width:16px;height:16px;color:var(--text)}.skill-block-title h3{letter-spacing:-.3px;color:var(--text);margin-bottom:0;font-size:13px;font-weight:900}.skill-block-title p{color:var(--text-2);font-size:11px;line-height:1.4}.skill-list-modern{gap:6px;padding-top:4px;display:grid}.skill-item{border-radius:var(--r-sm);transition:border-color var(--dur-2)var(--ease-2),background var(--dur-2)var(--ease-2);background:#0f172a08;border:1px solid #0f172a14;padding:7px 10px}.skill-item:hover{background:#0f172a0a;border-color:#0f172a1f}.skill-top{justify-content:space-between;align-items:center;gap:8px;margin-bottom:5px;display:flex}.skill-left{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.skill-name{letter-spacing:-.2px;color:var(--text);font-size:12px;font-weight:850}.skill-right{white-space:nowrap;align-items:center;gap:6px;display:flex}.skill-meta{color:var(--text-3);font-size:10px;font-weight:700}.skill-percent{color:var(--text);border-radius:var(--r-full);background:#ffffffbf;border:1px solid #0f172a1a;padding:3px 7px;font-size:10px;font-weight:900}.skill-badge{border-radius:var(--r-full);letter-spacing:.5px;text-transform:uppercase;color:#0f172ac7;background:#ffffffb3;border:1px solid #0f172a1a;padding:3px 7px;font-size:9px;font-weight:900}.skill-badge.expert{color:var(--text);background:#0f172a14}.skill-badge.advanced{color:#0f172adb;background:#0f172a0f}.skill-badge.intermediate{color:#0f172ac2;background:#0f172a0a}.skill-bar-modern{border-radius:var(--r-full);background:#ffffffd9;border:1px solid #0f172a1a;height:6px;position:relative;overflow:hidden}.skill-bar-modern:before{content:"";pointer-events:none;background:linear-gradient(#0f172a0a,#0f172a00);position:absolute;inset:0}.skill-bar-modern .fill{border-radius:var(--r-full);transform-origin:0;height:100%;animation:skillGrow .9s var(--ease)both;background:linear-gradient(90deg,#0f172aeb,#0f172a8c);position:absolute;top:0;left:0;box-shadow:0 4px 12px #0f172a1a}.skill-bar-modern .marker{background:#fffffff2;border:1px solid #0f172a2e;border-radius:999px;width:6px;height:6px;position:absolute;top:50%;transform:translate(-50%,-50%);box-shadow:0 4px 12px #0f172a1a}@media (min-width:768px){#skills .view-inner{padding-top:var(--s-32);padding-bottom:var(--s-16)}#skills .view-header{margin-bottom:var(--s-16)}#skills .view-title{margin-bottom:var(--s-6);font-size:28px}#skills .about-intro{font-size:13px}.skills-modern{columns:2;column-gap:12px;display:block}.skill-block{border-radius:var(--r-lg);margin-bottom:12px;padding:12px}.skill-block:hover{transform:none}.skill-block-header{gap:8px;margin-bottom:4px;padding:0 2px 6px}.skill-block-icon{border-radius:var(--r-sm);width:30px;height:30px}.skill-block-icon svg{width:15px;height:15px}.skill-block-title h3{font-size:12.5px;line-height:30px}.skill-list-modern{gap:5px;padding-top:2px}.skill-item{border-radius:var(--r-sm);padding:5px 8px}.skill-item:hover{transform:none}.skill-top{gap:6px;margin-bottom:4px}.skill-name{font-size:11.5px}.skill-meta{font-size:10px}.skill-percent{padding:2px 6px;font-size:10px}.skill-badge{padding:2px 6px;font-size:9px}.skill-bar-modern{height:5px}.skill-bar-modern .marker{width:5px;height:5px}}@media (max-width:420px){.skill-block{padding:10px}.skill-item{padding:6px 8px}.skill-top{margin-bottom:4px}.skill-percent{padding:2px 6px}.skill-bar-modern{height:5px}.skill-bar-modern .marker{width:5px;height:5px}}.projects-list{gap:var(--s-20);display:grid}.loading-projects,.no-projects{text-align:center;padding:var(--s-64)var(--s-20);color:var(--text-2)}.no-projects i{color:var(--text-3);margin-bottom:var(--s-12);font-size:44px}.projects-controls{gap:12px;margin-bottom:14px;display:grid}.projects-filter{border-radius:var(--r-lg);background:#0f172a05;border:1px solid #0f172a14;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:18px;padding:12px;display:grid}.filter-btn{border-radius:var(--r-md);color:var(--text-2);transition:transform var(--dur-1)var(--ease),background var(--dur-1)var(--ease),border-color var(--dur-1)var(--ease),color var(--dur-1)var(--ease),box-shadow var(--dur-1)var(--ease);background:#ffffffe6;border:1px solid #0f172a1a;justify-content:center;align-items:center;gap:8px;padding:10px 12px;font-size:13px;font-weight:650;display:inline-flex}.filter-btn:hover{color:var(--text);background:#fff;border-color:#0f172a24;transform:translateY(-1px);box-shadow:0 8px 18px #0f172a14}.filter-btn.active{color:var(--text);background:#0f172a0f;border-color:#0f172a24;box-shadow:0 10px 24px #0f172a1a}.filter-btn i{width:18px;height:18px}#projectsTechFilter{margin-top:0;margin-bottom:0}#projectsTechFilter.tech-filter{background:0 0;border:none;padding:0}#projectsTechFilter .filter-btn{width:100%}.projects-view-switch{border-radius:var(--r-lg);background:#0f172a05;border:1px solid #0f172a14;align-self:start;gap:10px;padding:12px;display:flex}.projects-controls-right{flex-direction:column;align-self:start;gap:8px;display:flex}.view-btn{border-radius:var(--r-md);color:var(--text-2);transition:transform var(--dur-1)var(--ease),background var(--dur-1)var(--ease),border-color var(--dur-1)var(--ease),color var(--dur-1)var(--ease),box-shadow var(--dur-1)var(--ease);background:#ffffffe6;border:1px solid #0f172a1a;justify-content:center;align-items:center;gap:8px;min-width:110px;padding:10px 12px;font-size:13px;font-weight:650;display:inline-flex}.view-btn i,.view-btn svg{width:18px;height:18px}.view-btn:hover{color:var(--text);background:#fff;border-color:#0f172a24;transform:translateY(-1px);box-shadow:0 8px 18px #0f172a14}.view-btn.active{color:var(--text);background:#0f172a0f;border-color:#0f172a24;box-shadow:0 10px 24px #0f172a1a}.project-card{border-radius:var(--r-xl);background:var(--card-bg);box-shadow:var(--shadow-sm);transition:transform var(--dur-2)var(--ease-2),box-shadow var(--dur-2)var(--ease-2),border-color var(--dur-2)var(--ease-2);cursor:pointer;animation:fadeInUp .42s var(--ease)both;border:1px solid #0f172a1a;overflow:hidden}.project-card:hover{box-shadow:var(--shadow-md);border-color:#0f172a24;transform:translateY(-4px)}.project-card.filter-hide{display:none}.project-image{background:#0f172a0a 50%/cover no-repeat;border-bottom:1px solid #0f172a14;width:100%;height:230px;position:relative}.project-image:not([style*=background-image]){background:linear-gradient(#0f172a08,#0f172a0f)}.project-overlay{padding:var(--s-16);background:linear-gradient(#fff0 55%,#0f172a66 100%);flex-wrap:wrap;justify-content:flex-start;align-items:flex-end;gap:6px;display:flex;position:absolute;inset:0}.project-badge{border-radius:var(--r-full);-webkit-backdrop-filter:blur(10px);letter-spacing:.6px;color:#0f172ae6;background:#ffffffe0;border:1px solid #0f172a1a;padding:7px 11px;font-size:11px;font-weight:800}.project-content{gap:10px;padding:18px 18px 20px;display:grid}.project-title-row{align-items:center;gap:8px;display:flex}.project-version{letter-spacing:.4px;white-space:nowrap;border-radius:var(--r-full);color:#0f172a7a;background:#0f172a0f;border:1px solid #0f172a14;flex-shrink:0;padding:3px 7px;font-size:9.5px;font-weight:700;line-height:1;translate:0 -.5px}.project-title{letter-spacing:-.3px;color:var(--text);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:18px;font-weight:850;line-height:1.25;display:-webkit-box;overflow:hidden}.project-desc{color:var(--text-2);-webkit-line-clamp:3;-webkit-box-orient:vertical;font-size:14px;line-height:1.65;display:-webkit-box;overflow:hidden}.project-tags{flex-wrap:wrap;gap:8px;padding-top:2px;display:flex}.tag{border-radius:var(--r-full);letter-spacing:.35px;text-transform:uppercase;color:#0f172ab8;background:#0f172a0a;border:1px solid #0f172a1a;padding:6px 10px;font-size:10.5px;font-weight:750}.project-card.coming-soon{background:#0f172a08}.project-card.coming-soon .project-image{border-bottom:none}.project-card.coming-soon .project-overlay{background:linear-gradient(#0f172a00 40%,#0f172a8c 100%)}.project-card.coming-soon .project-badge{color:#fffffff7;-webkit-backdrop-filter:blur(10px);letter-spacing:.8px;background:#dc2626e0;border-color:#dc262633;font-weight:850;box-shadow:0 1px 6px #dc26262e}@media (min-width:768px){.project-card.coming-soon{box-shadow:none;background:0 0;border:none;overflow:visible}.project-card.coming-soon .project-image{border-radius:var(--r-xl);overflow:hidden}.project-card.coming-soon:hover{box-shadow:none;background:0 0;transform:none}}.no-results{text-align:center;color:var(--text-3);padding:56px 20px}.no-results i{opacity:.35;width:60px;height:60px;margin-bottom:14px}.projects-list[data-viewmode=icons]{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.projects-list[data-viewmode=icons] .project-card{box-shadow:none;cursor:pointer;animation:fadeInUp .42s var(--ease)both;background:0 0;border:none;border-radius:22px;overflow:visible;transform:none}.projects-list[data-viewmode=icons] .project-image{aspect-ratio:1;height:auto;box-shadow:var(--shadow-sm);background-position:50%;background-repeat:no-repeat;background-size:cover;border:1px solid #0f172a1a;border-radius:22px}.projects-list[data-viewmode=icons] .project-overlay{display:none!important}.projects-list[data-viewmode=icons] .project-content{box-shadow:none;background:0 0;border:none;padding:10px 2px 0;display:block}.projects-list[data-viewmode=icons] .project-title-row{justify-content:center}.projects-list[data-viewmode=icons] .project-desc,.projects-list[data-viewmode=icons] .project-tags{display:none!important}.projects-list[data-viewmode=icons] .project-title{letter-spacing:-.2px;text-align:center;-webkit-line-clamp:2;color:var(--text);opacity:.92;font-size:12.5px;font-weight:850;line-height:1.25}.projects-list[data-viewmode=icons] .project-card:hover .project-image{box-shadow:var(--shadow-md);border-color:#0f172a24;transform:translateY(-2px)}.projects-list[data-viewmode=icons] .project-image{transition:transform var(--dur-2)var(--ease-2),box-shadow var(--dur-2)var(--ease-2),border-color var(--dur-2)var(--ease-2)}.projects-list[data-viewmode=cards]{gap:var(--s-20);display:grid}@media (min-width:520px){.projects-list[data-viewmode=icons]{grid-template-columns:repeat(4,1fr)}}@media (min-width:768px){.projects-controls{grid-template-columns:1fr auto;align-items:start;gap:14px}.projects-controls>.projects-filter{grid-column:1}.projects-controls-right{grid-column:2}.project-image{height:250px}.project-title{font-size:19px}.project-desc{-webkit-line-clamp:3;font-size:14.25px}}@media (min-width:1024px){.projects-list{grid-template-columns:repeat(2,1fr)}.projects-list[data-viewmode=icons]{grid-template-columns:repeat(6,1fr);gap:16px}.projects-list[data-viewmode=cards]{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.projects-list{gap:var(--s-16)}.project-image{height:190px}.project-title{font-size:17px}.project-desc{-webkit-line-clamp:3}.projects-filter{grid-template-columns:repeat(2,1fr);gap:10px;padding:10px}.filter-btn{font-size:13px}.projects-view-switch{padding:10px;margin-top:-8px!important}.view-btn{flex:1;min-width:0}.projects-controls{gap:8px!important;margin-bottom:10px!important}.projects-filter{margin-bottom:0!important}.projects-view-switch{margin-top:0!important}.projects-controls{gap:8px!important;width:100%!important;margin-bottom:12px!important}.projects-controls .projects-filter,.projects-controls .projects-view-switch,.projects-controls #projectsTechFilter,.projects-controls #projectsTechFilter.tech-filter{background:#0f172a08!important;border:1px solid #0f172a14!important;border-radius:16px!important;width:100%!important;padding:8px!important}.projects-controls-right{flex-direction:column!important;gap:8px!important;width:100%!important;display:flex!important}.projects-controls .projects-filter{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:6px!important;display:grid!important}.projects-controls .filter-btn,.projects-controls .view-btn{letter-spacing:.1px!important;background:#fffffff2!important;border:1px solid #0f172a1a!important;border-radius:12px!important;justify-content:center!important;align-items:center!important;gap:6px!important;height:38px!important;padding:0 10px!important;font-size:12.5px!important;font-weight:650!important;display:flex!important}.projects-controls .filter-btn.active,.projects-controls .view-btn.active{background:#0f172a14!important;border-color:#0f172a24!important}.projects-controls .filter-btn svg,.projects-controls .view-btn svg{opacity:.85!important;width:16px!important;height:16px!important}.projects-controls .projects-view-switch{gap:6px!important;display:flex!important}.projects-controls .projects-view-switch .view-btn{flex:1 1 0!important}#projectsTechFilter .filter-btn{justify-content:center!important;width:100%!important}}@media (max-width:420px){.project-badge{font-size:10px}}.contact-list{gap:14px;display:grid}.contact-card{border-radius:var(--r-lg);box-shadow:var(--shadow-sm);transition:transform var(--dur-2)var(--ease-2),border-color var(--dur-2)var(--ease-2),box-shadow var(--dur-2)var(--ease-2);cursor:pointer;background:#ffffffc7;border:1px solid #0f172a1a;align-items:center;gap:14px;padding:18px;display:flex;position:relative;overflow:hidden}.contact-card:hover{box-shadow:var(--shadow-md);border-color:#0f172a24;transform:translateY(-2px)}.contact-icon{border-radius:var(--r-md);background:#0f172a0f;border:1px solid #0f172a1a;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.contact-icon svg{width:22px;height:22px;color:var(--text)}.contact-text{flex:1}.contact-label{letter-spacing:.9px;text-transform:uppercase;color:var(--text-3);margin-bottom:4px;font-size:11px;font-weight:750}.contact-value{color:var(--text);font-size:15px;font-weight:850}.contact-arrow{color:var(--text-3);transition:transform var(--dur-1)var(--ease),color var(--dur-1)var(--ease)}.contact-card:hover .contact-arrow{color:var(--text-2);transform:translate(4px)}#contactExtraLinks{display:none!important}@media (min-width:1024px){.contact-list{grid-template-columns:repeat(3,1fr)}}.card{border-radius:var(--r-lg);padding:var(--s-24);box-shadow:var(--shadow-sm);background:#ffffffc7;border:1px solid #0f172a1a}.primary-btn,.secondary-btn{border-radius:var(--r-md);letter-spacing:-.2px;min-height:52px;transition:transform var(--dur-1)var(--ease),background var(--dur-1)var(--ease),border-color var(--dur-1)var(--ease),box-shadow var(--dur-1)var(--ease);border:1px solid #0000;justify-content:center;align-items:center;gap:10px;padding:0 22px;font-size:15px;font-weight:700;display:inline-flex}.primary-btn{color:#fff;background:#0f172a;border-color:#0f172a24;box-shadow:0 10px 26px #0f172a1f}.primary-btn:hover{transform:translateY(-1px);box-shadow:0 14px 36px #0f172a29}.primary-btn:active{transform:translateY(0)}.secondary-btn{color:var(--text);background:#ffffffb3;border-color:#0f172a1f}.secondary-btn:hover{background:#ffffffeb;border-color:#0f172a29;transform:translateY(-1px)}@media (min-width:768px){.primary-btn,.secondary-btn{min-width:200px}}.toast{bottom:calc(86px + env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--r-lg);width:calc(100% - 32px);max-width:420px;box-shadow:var(--shadow-md);opacity:0;pointer-events:none;transition:opacity var(--dur-2)var(--ease),transform var(--dur-2)var(--ease);z-index:10001;background:#ffffffeb;border:1px solid #0f172a1a;align-items:center;gap:10px;padding:14px 16px;display:flex;position:fixed;left:50%;transform:translate(-50%)translateY(20px)}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}.toast svg{color:#0f172ad9;flex-shrink:0}#toastText{color:var(--text);font-size:14px;font-weight:750}@media (min-width:768px){.toast{bottom:var(--s-40)}}.modal-badges{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.modal-badge-pill{letter-spacing:-.2px;color:#0f172aeb;white-space:nowrap;background:#ffffffb8;border:1px solid #0f172a1a;border-radius:999px;align-items:center;gap:6px;padding:12px;font-size:13px;font-weight:800;line-height:1;display:inline-flex}.modal-badge-pill i{opacity:.9;width:14px;height:14px}.project-badges .modal-badge-pill{gap:0;margin:2px;padding:12px}.project-modal{z-index:10000;padding:var(--s-20);justify-content:center;align-items:center;display:none;position:fixed;inset:0}.project-modal.active{display:flex}.modal-overlay{-webkit-backdrop-filter:blur(6px);animation:fadeIn var(--dur-2)var(--ease);background:#0f172a59;position:absolute;inset:0}.modal-container{border-radius:var(--r-xl);width:100%;max-width:1100px;max-height:92vh;box-shadow:var(--shadow-lg);z-index:1;animation:modalIn var(--dur-2)var(--ease);background:#fffffff5;border:1px solid #0f172a1a;flex-direction:column;display:flex;position:relative;overflow:hidden}.modal-header{top:var(--s-16);right:var(--s-16);z-index:100;position:absolute}.modal-close{border-radius:var(--r-md);width:44px;height:44px;color:var(--text);transition:transform var(--dur-1)var(--ease),background var(--dur-1)var(--ease),border-color var(--dur-1)var(--ease);background:#0f172a0f;border:1px solid #0f172a1a;justify-content:center;align-items:center;display:flex}.modal-close:hover{background:#0f172a14;border-color:#0f172a24;transform:rotate(6deg)}.modal-close:active{transform:scale(.96)}.modal-content{flex:1;overflow-y:auto}.modal-slider{background:#0f172a0a;border-bottom:1px solid #0f172a14;height:420px;position:relative;overflow:hidden}.slider-container{height:100%;display:flex;position:relative}.slider-slide{justify-content:center;align-items:center;min-width:100%;height:100%;padding:18px;display:none;position:relative}.slider-slide.active{display:flex}.slider-slide img{object-fit:contain;border-radius:var(--r-md);max-width:100%;max-height:100%;box-shadow:var(--shadow-md);background:#fffc;border:1px solid #0f172a1a}.no-images{height:100%;color:var(--text-2);justify-content:center;align-items:center;font-weight:650;display:flex}.slider-btn{border-radius:var(--r-md);width:44px;height:44px;color:var(--text);transition:transform var(--dur-1)var(--ease),background var(--dur-1)var(--ease),border-color var(--dur-1)var(--ease);z-index:10;background:#ffffffdb;border:1px solid #0f172a1a;justify-content:center;align-items:center;display:inline-flex;position:absolute;top:50%;transform:translateY(-50%)}.slider-btn:hover{background:#fffffff5;border-color:#0f172a24;transform:translateY(-50%)scale(1.04)}.slider-btn:active{transform:translateY(-50%)scale(.98)}.slider-btn:disabled{opacity:.35;cursor:not-allowed}.slider-prev{left:14px}.slider-next{right:14px}.slider-dots{border-radius:var(--r-full);background:#ffffffdb;border:1px solid #0f172a1a;gap:8px;padding:8px 10px;display:flex;position:absolute;bottom:12px;left:50%;transform:translate(-50%)}.slider-dot{width:8px;height:8px;transition:width var(--dur-1)var(--ease),background var(--dur-1)var(--ease);background:#0f172a33;border-radius:50%}.slider-dot.active{border-radius:var(--r-full);background:#0f172a8c;width:18px}.modal-body{padding:24px 22px 26px}.modal-meta{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:14px;display:flex}.modal-badge{border-radius:var(--r-full);letter-spacing:.7px;color:var(--text);background:#0f172a0f;border:1px solid #0f172a1a;padding:7px 12px;font-size:12px;font-weight:750}.modal-tags{flex-wrap:wrap;gap:8px;display:flex}.modal-title{letter-spacing:-1px;margin-bottom:10px;font-size:clamp(20px,3.2vw,34px);font-weight:900}.modal-description{color:var(--text-2);margin-bottom:18px;font-size:14.5px;line-height:1.75}.modal-submeta{border-radius:var(--r-lg);background:#0f172a08;border:1px solid #0f172a14;justify-content:space-between;align-items:center;gap:12px;margin:10px 0 16px;padding:12px;display:flex}.submeta-left{align-items:center;gap:10px;min-width:0;display:flex}.status-dot{background:#0f172a40;border-radius:999px;flex:none;width:10px;height:10px;box-shadow:0 0 0 3px #0f172a0f}.submeta-status{letter-spacing:-.2px;color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:850;overflow:hidden}.submeta-updated{color:var(--text-2);white-space:nowrap;font-size:12.5px;font-weight:700}.submeta-updated:before{content:"Updated";color:var(--text-3);letter-spacing:.3px;text-transform:uppercase;margin-right:8px;font-size:10.5px;font-weight:800}#modalMetaBar[data-status=done] .status-dot,#modalMetaBar[data-status=completed] .status-dot,#modalMetaBar[data-status=active] .status-dot,#modalMetaBar[data-status=in_progress] .status-dot{background:#22c55e;box-shadow:0 0 0 3px #22c55e24}#modalMetaBar[data-status=maintenance] .status-dot{background:#eab308;box-shadow:0 0 0 3px #eab3082e}#modalMetaBar[data-status=paused] .status-dot{background:#94a3b8;box-shadow:0 0 0 3px #94a3b82e}#modalMetaBar[data-status=concept] .status-dot{background:#a855f7;box-shadow:0 0 0 3px #a855f72e}#modalMetaBar.modal-submeta{box-shadow:none!important;background:0 0!important;border:0!important;border-radius:0!important;flex-flow:wrap!important;justify-content:flex-start!important;align-items:center!important;gap:12px!important;margin:10px 0 16px!important;padding:0!important;display:flex!important}#modalMetaBar .submeta-left,#modalMetaBar .submeta-right{box-shadow:none!important;background:0 0!important;border:0!important;border-radius:0!important;flex-wrap:nowrap!important;flex-shrink:1!important;align-items:center!important;gap:10px!important;min-width:0!important;padding:0!important;display:inline-flex!important}#modalStatusDot{display:none!important}#modalStatus.submeta-status{letter-spacing:-.2px!important;color:var(--text)!important;white-space:nowrap!important;text-overflow:ellipsis!important;border:1px solid var(--border-color,#e5e5e5)!important;background:#fff!important;border-radius:24px!important;flex-shrink:1!important;min-width:0!important;padding:8px 20px!important;font-size:14px!important;font-weight:900!important;display:inline-block!important;overflow:hidden!important}#modalLastUpdated.submeta-updated{color:var(--text)!important;white-space:nowrap!important;border:1px solid var(--border-color,#e5e5e5)!important;background:#fff!important;border-radius:24px!important;flex-shrink:0!important;align-items:center!important;gap:8px!important;padding:8px 20px!important;font-size:14px!important;font-weight:900!important;display:inline-flex!important}#modalLastUpdated.submeta-updated:before{content:"UPDATED"!important;letter-spacing:.22em!important;color:var(--text-3)!important;font-size:11px!important;font-weight:900!important}.modal-stats-inline{border-radius:var(--r-lg);background:#0f172a08;border:1px solid #0f172a14;flex-wrap:wrap;gap:14px;margin-bottom:18px;padding:12px;display:flex}.stat-inline{border-radius:var(--r-md);background:#ffffffb8;border:1px solid #0f172a14;align-items:center;gap:8px;padding:8px 10px;display:flex}.stat-inline svg{color:#0f172abf;flex-shrink:0}.stat-inline span{color:var(--text);font-size:13px;font-weight:700}.modal-section{margin-top:18px}.modal-section h3{color:var(--text);letter-spacing:-.2px;align-items:center;gap:10px;margin-bottom:10px;font-size:14px;font-weight:850;display:flex}.modal-features{gap:10px;list-style:none;display:grid}.modal-features li{border-radius:var(--r-md);color:var(--text-2);white-space:normal;word-break:break-word;background:#0f172a08;border:1px solid #0f172a14;align-items:flex-start;gap:10px;max-height:none;padding:12px;font-size:13.5px;line-height:1.65;display:flex;overflow:visible}.modal-features li:before{content:"✓";color:#0f172ad9;background:#0f172a0f;border:1px solid #0f172a1a;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;margin-top:1px;font-weight:900;display:inline-flex}.modal-tech{flex-wrap:wrap;gap:10px;display:flex}.tech-tag{border-radius:var(--r-full);color:var(--text-2);background:#0f172a0a;border:1px solid #0f172a1a;padding:8px 12px;font-size:12.5px;font-weight:700}.tech-tag:hover{color:var(--text);border-color:#0f172a24}.modal-highlights{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.highlight-item{border-radius:var(--r-lg);text-align:center;background:#0f172a08;border:1px solid #0f172a14;padding:14px}.highlight-value{letter-spacing:-.6px;color:var(--text);margin-bottom:6px;font-size:26px;font-weight:900}.highlight-label{color:var(--text-2);font-size:12px;font-weight:700}.modal-actions{gap:12px;margin-top:18px;display:flex}.modal-actions .primary-btn,.modal-actions .secondary-btn{flex:1;min-height:50px}.modal-changelog-hint{opacity:.72;margin:0 0 10px;font-size:13px;font-weight:650}.changelog-accordion{flex-direction:column;gap:10px;display:flex}details.changelog-item{background:#0f172a08;border:1px solid #0f172a14;border-radius:16px;overflow:hidden}details.changelog-item>summary{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;gap:12px;padding:12px;list-style:none;display:flex}details.changelog-item>summary::-webkit-details-marker{display:none}.changelog-summary-left{flex-direction:column;gap:4px;min-width:0;display:flex}.changelog-version{letter-spacing:-.2px;text-overflow:ellipsis;white-space:nowrap;color:#0f172aeb;font-weight:900;overflow:hidden}.changelog-sub{opacity:.75;text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:750;overflow:hidden}.changelog-chevron{background:#ffffffb8;border:1px solid #0f172a1a;border-radius:12px;flex:none;place-items:center;width:34px;height:34px;transition:transform .15s;display:grid;transform:rotate(0)}details.changelog-item[open] .changelog-chevron{transform:rotate(180deg)}.changelog-body{padding:0 12px 12px}.changelog-list{flex-direction:column;gap:10px;margin:0;padding-left:0;list-style:none;display:flex}.changelog-entry{background:#ffffffa8;border:1px solid #0f172a14;border-radius:14px;padding:10px}.changelog-entry-top{justify-content:space-between;align-items:center;gap:10px;margin-bottom:6px;display:flex}.changelog-entry-title{text-overflow:ellipsis;white-space:nowrap;color:#0f172aeb;margin:0;font-size:13px;font-weight:900;overflow:hidden}.changelog-entry-meta{opacity:.85;white-space:nowrap;flex:none;align-items:center;gap:8px;font-size:12px;font-weight:800;display:flex}.changelog-pill{background:#0f172a0a;border:1px solid #0f172a1a;border-radius:999px;padding:5px 8px;line-height:1}.changelog-entry-desc{opacity:.82;margin:0;font-size:13px;font-weight:650;line-height:1.45}.coming-soon-body{text-align:center;padding:24px 16px 16px}.coming-soon-body .modal-description{color:var(--text-2);margin:0;font-size:15px;font-weight:700}@media (max-width:768px){.project-modal{align-items:flex-end;padding:0}.modal-container{border-radius:var(--r-xl)var(--r-xl)0 0;width:100%;max-height:95vh}.modal-slider{height:52vh}.modal-body{padding:16px 16px 18px}.modal-actions{flex-direction:column}.modal-close{width:42px;height:42px}.slider-btn{width:40px;height:40px}.slider-prev{left:10px}.slider-next{right:10px}.modal-submeta{flex-flow:wrap;align-items:center}.modal-features li{padding:10px;font-size:13px;line-height:1.65;white-space:normal!important;word-break:break-word!important;-webkit-line-clamp:unset!important;-webkit-box-orient:unset!important;max-height:none!important;overflow:visible!important}.changelog-entry-top{flex-direction:column!important;align-items:flex-start!important;gap:6px!important}.changelog-entry-title{white-space:normal!important;text-overflow:unset!important;word-break:break-word!important;font-size:13px!important;overflow:visible!important}.changelog-entry-meta{flex-wrap:wrap!important}#modalMetaBar.modal-submeta{flex-flow:wrap!important;align-items:center!important;gap:10px!important}}@media (max-width:480px){#modalMetaBar.modal-submeta{flex-flow:wrap!important;gap:8px!important}#modalStatus.submeta-status{flex:0 auto!important;min-width:0!important;padding:6px 14px!important;font-size:12px!important}#modalLastUpdated.submeta-updated{flex:0 auto!important;gap:5px!important;padding:6px 14px!important;font-size:12px!important}#modalLastUpdated.submeta-updated:before{letter-spacing:.15em!important;font-size:9px!important}}@media (max-width:420px){.modal-title{font-size:20px}}@media (max-width:768px) and (orientation:landscape){.modal-slider{height:60vh}}#techSheet.ui-sheet{z-index:99999;display:none;position:fixed;inset:0}#techSheet.ui-sheet.is-open{display:block}#techSheet .ui-overlay{position:absolute;inset:0;-webkit-backdrop-filter:blur(10px)!important;background:#0a011847!important}#techSheet .ui-panel{width:min(760px,100vw - 20px);max-height:min(78vh,720px);position:absolute;bottom:0;left:50%;transform:translate(-50%);padding-bottom:max(14px,env(safe-area-inset-bottom))!important;background:#eef0f3f2!important;border:1px solid #141e321a!important;border-bottom:0!important;border-radius:22px 22px 0 0!important;overflow:hidden!important;box-shadow:0 -30px 80px #00000038,inset 0 2px #ffffffa6!important}#techSheet .ui-head{background:#eef0f3fa!important;border-bottom:1px solid #141e321a!important;justify-content:space-between!important;align-items:center!important;gap:12px!important;padding:14px 16px 10px!important;display:flex!important}#techSheet .ui-title h3{letter-spacing:.2px!important;color:#12161eeb!important;margin:0!important;font-size:16px!important;font-weight:800!important}#techSheet .ui-title p{color:#12161e9e!important;margin:0!important;font-size:12px!important}#techSheet .ui-close{color:#12161ecc!important;cursor:pointer!important;background:#ffffffb3!important;border:1px solid #141e321a!important;border-radius:12px!important;justify-content:center!important;align-items:center!important;width:38px!important;height:38px!important;display:inline-flex!important;box-shadow:0 10px 24px #00000014!important}#techSheet .ui-close:hover{transform:translateY(-1px);background:#ffffffe6!important}#techSheet .ui-close:active{transform:translateY(0)}#techSheet .ui-body{color:#12161ee6!important;background:#eef0f3f2!important;max-height:calc(min(78vh,720px) - 120px)!important;padding:14px 16px 16px!important;overflow:auto!important}#techSheet .tech-list{flex-wrap:wrap!important;gap:10px!important;margin-top:6px!important;display:flex!important}#techSheet .tech-item{appearance:none!important;color:#12161edb!important;cursor:pointer!important;-webkit-user-select:none!important;user-select:none!important;background:#fff9!important;border:1px solid #141e321a!important;border-radius:999px!important;justify-content:space-between!important;align-items:center!important;gap:10px!important;padding:10px 12px!important;font-size:12px!important;font-weight:700!important;transition:transform .15s,background .15s,border-color .15s,box-shadow .15s!important;display:inline-flex!important;box-shadow:0 10px 24px #0000000f!important}#techSheet .tech-item:hover{background:#ffffffd9!important;border-color:#141e3229!important;transform:translateY(-1px)!important}#techSheet .tech-item span:last-child{opacity:.7!important;font-weight:800!important}#techSheet .tech-item[aria-pressed=true]{background:#7c5cff24!important;border-color:#7c5cff8c!important;box-shadow:0 10px 26px #7c5cff24,inset 0 0 0 2px #7c5cff1a!important}#techSheet .tech-item[aria-pressed=true] span:last-child{color:#7c5cfff2!important;opacity:.95!important}#techSheet .tech-item:focus-visible,#techSheet .ui-close:focus-visible{outline:0!important;box-shadow:0 0 0 3px #7c5cff40!important}body.ui-lock{touch-action:none!important;overflow:hidden!important}@media (max-width:860px){#techSheet .ui-panel{width:100vw!important;max-width:100vw!important;max-height:calc(100vh - 64px)!important;padding-bottom:max(14px,env(safe-area-inset-bottom))!important;border-radius:22px 22px 0 0!important;bottom:0!important;left:0!important;right:0!important;transform:none!important}#techSheet .ui-head{z-index:2!important;position:sticky!important;top:0!important}#techSheet .ui-body{-webkit-overflow-scrolling:touch;max-height:calc(100vh - 170px)!important}}[data-sanity-preload]{visibility:hidden;pointer-events:none;height:0;position:absolute;overflow:hidden}[data-sanity-loaded]{animation:.35s both sanityFadeIn;visibility:visible!important;pointer-events:auto!important;height:auto!important;position:relative!important;overflow:visible!important}.sanity-skeleton{flex-direction:column;gap:14px;padding:0;display:flex}.sanity-skeleton-line{background:linear-gradient(90deg,#ffffff0f 25%,#ffffff1f 50%,#ffffff0f 75%) 0 0/800px 100%;border-radius:8px;height:14px;animation:1.6s infinite skeletonShimmer}.sanity-skeleton-block{background:linear-gradient(90deg,#ffffff0a 25%,#ffffff14 50%,#ffffff0a 75%) 0 0/800px 100%;border-radius:16px;animation:1.6s infinite skeletonShimmer}.hero-skeleton .sanity-skeleton-line:first-child{border-radius:999px;width:140px;height:28px}.hero-skeleton .sanity-skeleton-line:nth-child(2){width:70%;height:36px}.hero-skeleton .sanity-skeleton-line:nth-child(3){width:90%;height:14px}.hero-skeleton .sanity-skeleton-line:nth-child(4){width:60%;height:14px}.about-skeleton .sanity-skeleton-block{height:120px;margin-bottom:12px}.about-skeleton .sanity-skeleton-line:nth-child(2){width:50%}.about-skeleton .sanity-skeleton-line:nth-child(3){width:80%}.about-skeleton .sanity-skeleton-line:nth-child(4){width:65%}.contact-skeleton{flex-direction:column;gap:10px;display:flex}.contact-skeleton .sanity-skeleton-block{border-radius:16px;height:68px}.timeline-skeleton{flex-direction:column;gap:16px;margin-top:20px;display:flex}.timeline-skeleton .sanity-skeleton-block{border-radius:14px;height:80px}.sanity-skeleton-container{transition:opacity .2s}.sanity-skeleton-container[data-skeleton-hidden]{opacity:0;pointer-events:none;height:0;position:absolute;overflow:hidden}#skillsSkeleton .sanity-skeleton{gap:20px}#skillsSkeleton .sanity-skeleton-block:first-child,#skillsSkeleton .sanity-skeleton-block:nth-child(2){border-radius:16px;height:180px}#skillsSkeleton .sanity-skeleton-block:nth-child(3){border-radius:16px;height:140px}.header-burger{width:38px;height:38px;color:var(--text);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .18s var(--ease),border-color .18s var(--ease),transform .18s var(--ease);background:#0f172a12;border:1.5px solid #0f172a1a;border-radius:10px;justify-content:center;align-items:center;margin-left:auto;display:flex}.header-burger:hover{background:#0f172a1a;border-color:#0f172a24}.header-burger:active{background:#0f172a1f;transform:scale(.92)}.sidebar-drawer-overlay{z-index:10001;pointer-events:none;visibility:hidden;position:fixed;inset:0}.sidebar-drawer-overlay.active{pointer-events:auto;visibility:visible}.sidebar-drawer-overlay:before{content:"";-webkit-backdrop-filter:blur(6px);opacity:0;transition:opacity .3s var(--ease);background:#00000073;position:absolute;inset:0}.sidebar-drawer-overlay.active:before{opacity:1}.sidebar-drawer{z-index:1;background:#fff;border-right:1px solid #0f172a0f;flex-direction:column;width:290px;max-width:82vw;transition:transform .35s cubic-bezier(.32,.72,0,1);display:flex;position:absolute;top:0;bottom:0;left:0;overflow:hidden;transform:translate(-105%);box-shadow:6px 0 24px #0000001a,20px 0 60px #0000000d}.sidebar-drawer.open{transform:translate(0)}.sidebar-drawer-head{background:#0f172a05;border-bottom:1px solid #0f172a12;justify-content:space-between;align-items:center;padding:18px 18px 16px;display:flex}.sidebar-drawer-brand{align-items:center;gap:12px;display:flex}.sidebar-drawer-logo{object-fit:contain;flex-shrink:0;width:38px;height:38px}.sidebar-drawer-title{letter-spacing:-.3px;color:var(--text);font-size:16px;font-weight:850;line-height:1.2}.sidebar-drawer-subtitle{color:var(--text-3);text-transform:uppercase;letter-spacing:.6px;margin-top:2px;font-size:11px;font-weight:650}.sidebar-drawer-close{width:36px;height:36px;color:var(--text-2);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .18s var(--ease),color .18s var(--ease),transform .18s var(--ease);background:#0f172a0f;border:1px solid #0f172a14;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-drawer-close:hover{color:var(--text);background:#0f172a1a}.sidebar-drawer-close:active{transform:scale(.92)}.sidebar-drawer-nav{flex-direction:column;flex:1;gap:2px;padding:14px 14px 32px;display:flex;overflow-y:auto}.sidebar-drawer-link{letter-spacing:-.1px;color:var(--text-2);-webkit-tap-highlight-color:transparent;transition:background .18s var(--ease),color .18s var(--ease),transform .18s var(--ease);border-radius:12px;align-items:center;gap:12px;padding:13px 14px;font-size:15px;font-weight:700;text-decoration:none;display:flex}.sidebar-drawer-link:hover{color:var(--text);background:#0f172a0d}.sidebar-drawer-link:active{background:#0f172a12;transform:scale(.97)}.sidebar-drawer-link.active{color:var(--text);background:#0f172a12;font-weight:800}.sidebar-drawer-link.active:before{content:"";background:var(--text);border-radius:50%;flex-shrink:0;width:4px;height:4px;margin-right:-4px}@media (min-width:768px){.header-burger{display:none}.sidebar-drawer-overlay{display:none!important}}.nav-more-wrapper{display:none;position:relative}@media (min-width:768px){.nav-more-wrapper{align-items:center;display:flex}.nav-more-btn{width:36px;height:36px;color:var(--text-2);cursor:pointer;transition:background .2s var(--ease),border-color .2s var(--ease),color .2s var(--ease),transform .15s var(--ease);background:0 0;border:1px solid #0000;border-radius:10px;justify-content:center;align-items:center;display:flex}.nav-more-btn:hover{color:var(--text);background:#0f172a0f}.nav-more-btn.active{color:var(--text);background:#0f172a14;border-color:#0f172a1a}.nav-more-btn:active{transform:scale(.93)}.nav-popover{opacity:0;visibility:hidden;transform-origin:100% 0;min-width:200px;transition:opacity .15s var(--ease),transform .15s var(--ease),visibility 0s linear .15s;background:#fff;border:1px solid #0f172a1a;border-radius:12px;padding:4px;position:absolute;top:calc(100% + 8px);right:-4px;transform:translateY(-4px);box-shadow:0 1px 2px #0000000a,0 4px 12px #0000000f,0 16px 40px #0000000f}.nav-popover.open{opacity:1;visibility:visible;transition:opacity .2s var(--ease),transform .2s var(--ease),visibility 0s linear 0s;transform:translateY(0)}.nav-popover-header{letter-spacing:.4px;text-transform:uppercase;color:var(--text-3);-webkit-user-select:none;user-select:none;padding:8px 10px 5px;font-size:11px;font-weight:700}.nav-popover-link{letter-spacing:-.1px;color:var(--text);transition:background .12s var(--ease);border-radius:8px;align-items:center;gap:8px;padding:9px 10px;font-size:13.5px;font-weight:600;text-decoration:none;display:flex}.nav-popover-link:hover{background:#0f172a0d}.nav-popover-link.active{background:#0f172a0f;font-weight:700}}.site-footer{display:none}@media (min-width:768px){.site-footer{text-align:center;border-top:1px solid #0f172a0f;padding:28px 24px 32px;display:block}.site-footer-inner{align-items:center;gap:8px;display:inline-flex}.site-footer-copy{color:var(--text-3);letter-spacing:-.1px;font-size:12.5px;font-weight:600}.site-footer-dot{color:var(--text-3);opacity:.6;font-size:13px}.site-footer-version{letter-spacing:.2px;color:var(--text-3);background:#0f172a0a;border:1px solid #0f172a0f;border-radius:6px;padding:3px 9px;font-size:11.5px;font-weight:700}}.sidebar-drawer-footer{border-top:1px solid #0f172a0f;justify-content:space-between;align-items:center;gap:8px;margin-top:auto;padding:16px 18px;display:flex}.sidebar-drawer-version{letter-spacing:.2px;color:var(--text-3);background:#0f172a0a;border:1px solid #0f172a0f;border-radius:6px;padding:3px 8px;font-size:11px;font-weight:700}.sidebar-drawer-copy{color:var(--text-3);letter-spacing:-.1px;font-size:11px;font-weight:600}
