@charset "UTF-8";@import"https://fonts.googleapis.com/css?family=Source+Sans+Pro:regular,bold,italic&subset=latin,latin-ext";.about{max-width:1100px;margin:0 auto;padding:80px 20px;display:flex;flex-wrap:wrap;align-items:flex-start;gap:40px;font-family:Poppins,sans-serif}.about-image{flex:1;display:flex;justify-content:center}.about-image img{width:280px;height:280px;border-radius:50%;object-fit:cover;box-shadow:0 12px 24px #00000026;border:4px solid #33383c;transition:transform .4s ease}.about-image img:hover{transform:scale(1.05)}.about-text{flex:2;display:flex;flex-direction:column;gap:20px}.about-text h2{font-size:clamp(26px,3vw,34px);font-weight:700;color:#33383c;margin-bottom:10px;position:relative}.about-text h2:after{content:"";position:absolute;left:0;bottom:-6px;width:60px;height:4px;background:#33383c;border-radius:2px}.about-text p{font-size:clamp(15px,1.2vw,18px);line-height:1.8;font-weight:300;text-align:justify;color:#444}.about-text .highlight{color:#26425a;font-weight:600}@media (max-width: 768px){.about{flex-direction:column;align-items:center}.about-image{flex:none;width:100%;display:flex;justify-content:center;margin-bottom:20px}.about-image img{width:220px;height:220px}.about-text{text-align:center}.about-text h2:after{left:50%;transform:translate(-50%)}.about-text p{text-align:left}}:root{--footer-bg: linear-gradient(135deg, #1f2937 0%, #111827 100%);--footer-text: #f3f4f6;--footer-muted: #9ca3af;--border: rgba(255, 255, 255, .1);--radius: 16px;--shadow: 0 6px 18px rgba(0, 0, 0, .25)}.site-footer{background:var(--footer-bg);border-top:1px solid var(--border);width:100%;padding:20px 0}.footer-bar{width:100%;max-width:1200px;margin:0 auto;padding:0;display:flex;justify-content:space-between;align-items:center}@media (max-width: 640px){.footer-bar{flex-direction:column;gap:16px;text-align:center}}.footer-copy{margin:0;color:var(--footer-muted);font-size:14px;font-weight:400}.footer-social{list-style:none;display:flex;gap:14px;margin:0;padding:0}@media (max-width: 640px){.footer-social{justify-content:center}}.footer-social__btn{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;background:#ffffff14;color:var(--footer-text);border:1px solid var(--border);transition:all .3s ease}.footer-social__btn:hover{background:#f9fafb;color:#111827;transform:translateY(-3px) scale(1.1);box-shadow:var(--shadow)}.footer-social__icon{font-size:20px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}:root{--header-bg: #ffffffcc;--text-strong: #2b2c34;--text-muted: #6b7280;--border: #e5e7eb;--shadow: 0 6px 18px rgba(0, 0, 0, .06);--radius: 16px}.site-header{position:sticky;top:0;z-index:50;-webkit-backdrop-filter:saturate(140%) blur(6px);backdrop-filter:saturate(140%) blur(6px);background:var(--header-bg);border-bottom:1px solid var(--border);box-shadow:var(--shadow);width:100%}.site-header>.container{width:100vw;margin:0;padding:10px 32px;display:flex;justify-content:space-between;align-items:center;box-sizing:border-box}.brand{display:flex;align-items:center;gap:12px}.brand__logo{display:block;height:clamp(36px,5vw,44px);width:auto;border-radius:8px}.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}.skip-link:focus{position:static;width:auto;height:auto;padding:4px 8px;background:#111827;color:#fff;border-radius:6px}.nav-toggle{display:inline-flex;flex-direction:column;gap:4px;padding:8px;border-radius:10px;border:1px solid var(--border);background:#fff;cursor:pointer}@media (min-width: 992px){.nav-toggle{display:none}}.nav-toggle__bar{width:22px;height:2px;background:var(--text-strong);border-radius:2px}.nav{display:none;position:absolute;left:0;right:0;top:calc(100% + 6px);padding:12px 16px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);margin:0 12px;box-shadow:var(--shadow)}.nav--open{display:block}@media (min-width: 992px){.nav{display:block!important;position:static;padding:0;margin:0;border:none;box-shadow:none;background:transparent}}.nav__list{list-style:none;margin:0;padding:0;display:grid;gap:6px}@media (min-width: 992px){.nav__list{display:flex;align-items:center;gap:clamp(8px,2vw,18px)}}.nav__item{display:contents}@media (min-width: 992px){.nav__item{display:block}}.nav__link{display:inline-flex;align-items:center;gap:8px;text-decoration:none;font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;font-weight:500;font-size:clamp(14px,1.8vw,16px);color:var(--text-strong);padding:10px 12px;border-radius:10px;transition:all .2s ease}.nav__link:hover{background:#f3f4f6;color:#111827}.nav__link.is-active{background:#eef2ff;color:#3730a3;box-shadow:inset 0 0 0 1px #c7d2fe}@media (min-width: 992px){.nav__cta{margin-left:auto}}.footer{background:transparent;color:var(--footer-text);padding:40px 0;width:100%}.footer .content{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:32px;max-width:1200px;margin:auto;align-items:start}.footer .logo img{width:120px;max-width:100%;border-radius:12px}.footer .content h4{font-size:16px;font-weight:600;margin-bottom:12px;text-transform:uppercase;border-bottom:2px solid var(--footer-muted);display:inline-block;padding-bottom:4px}.footer .content p{margin-bottom:8px;font-size:14px}.footer .content a{color:var(--footer-muted);text-decoration:none;transition:color .2s ease}.footer .content a:hover{color:#f9fafb}@media (max-width: 1024px){.footer .content{grid-template-columns:repeat(2,1fr);text-align:center}.footer .logo img{margin:0 auto 16px}}@media (max-width: 640px){.footer .content{grid-template-columns:1fr;text-align:center}.footer .logo img{margin:0 auto 20px;width:100px}}:root{--surface: #ffffff;--surface-2: #f6f8fb;--ink: #0f172a;--muted: #475569;--border: #e2e8f0;--brand: #33383c;--accent: #2563eb;--shadow: 0 12px 28px rgba(15, 23, 42, .08);--shadow-lg: 0 18px 40px rgba(15, 23, 42, .12)}.projects{max-width:1200px;margin:0 auto;padding:clamp(18px,4vw,28px) clamp(16px,5vw,24px) 40px;color:var(--ink)}.projects__head{display:flex;align-items:center;gap:12px;margin-bottom:14px}.projects__head h1{margin:0;font-size:clamp(22px,3.4vw,30px);font-weight:800;letter-spacing:-.02em}.pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#fff;border:1px solid var(--border);font-weight:700;font-size:12px;box-shadow:0 4px 12px #0208170d}.pill:before{content:"";width:8px;height:8px;border-radius:50%;background:#10b981;box-shadow:0 0 0 4px #10b9812e}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:clamp(14px,2.8vw,22px)}.project-card{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow);min-height:360px;display:flex}.project-card:focus-within{outline:none;box-shadow:0 0 0 4px #2563eb33}.project-card__bg{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#02081726,#020817ad 75%),var(--img) var(--img-pos, center)/var(--img-fit, cover) no-repeat;transform:scale(1.02);transition:transform .35s ease,filter .35s ease}.project-card:hover .project-card__bg{transform:scale(1.06);filter:saturate(1.08)}.project-card__content{position:relative;z-index:1;display:flex;flex-direction:column;justify-content:flex-end;gap:10px;width:100%;padding:18px;color:#fff}.project-card__title{margin:0;font-size:18px;font-weight:700;letter-spacing:.1px;text-shadow:0 2px 8px rgba(0,0,0,.25)}.project-card__tags{display:flex;flex-wrap:wrap;gap:8px;margin:0;list-style:none;padding:0}.project-card__tags .tag{padding:6px 10px;border-radius:999px;background:#ffffff29;border:1px solid rgba(255,255,255,.28);font-size:12px;font-weight:600;letter-spacing:.1px;color:#fff;-webkit-backdrop-filter:saturate(140%) blur(3px);backdrop-filter:saturate(140%) blur(3px);transition:transform .15s ease,filter .2s ease}.project-card__tags .tag:hover{transform:translateY(-1px);filter:saturate(1.08)}.project-card__tags .tag[data-tech=React]{background:linear-gradient(90deg,#b3ecff,#9cf);border-color:transparent;color:#0f172a}.project-card__tags .tag[data-tech=TypeScript]{background:#c7ddf5;border-color:#0000000d;color:#1e3a8a}.project-card__tags .tag[data-tech=Redux]{background:#d9c8f0;border-color:#0000000d;color:#4c1d95}.project-card__tags .tag[data-tech=SCSS],.project-card__tags .tag[data-tech=Sass]{background:#f5d0e0;border-color:#0000000d;color:#831843}.project-card__tags .tag[data-tech=Flutter]{background:linear-gradient(90deg,#b3f0ff,#a3c9e8);border-color:transparent;color:#083344}.project-card__tags .tag[data-tech=Riverpod]{background:linear-gradient(90deg,#bbf7d0,#86efac);border-color:transparent;color:#064e3b}.project-card__tags .tag[data-tech=Angular]{background:#fecaca;border-color:#0000000d;color:#7f1d1d}.project-card__tags .tag[data-tech=Vite]{background:linear-gradient(90deg,#fef3c7,#e0e7ff);border-color:transparent;color:#111827}.project-card__tags .tag[data-tech=TMDB]{background:#bbf7d0;border-color:#0000000d;color:#065f46}.project-card__tags .tag[data-tech=Web]{background:#e0e7ff;border-color:#0000000d;color:#3730a3}.project-card__tags .tag[data-tech=UI]{background:#bae6fd;border-color:#0000000d;color:#075985}.project-card__desc{margin:0;font-size:14px;line-height:1.6;color:#fffffff5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.project-card__actions{margin-top:4px;display:flex;gap:10px;align-items:center}.btn{--bg: linear-gradient(90deg, var(--accent), #0ea5e9);display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:12px;font-weight:600;font-size:13px;text-decoration:none;color:#fff;background:var(--bg);box-shadow:0 10px 20px #2563eb40;transition:transform .18s ease,filter .2s ease}.btn:hover{transform:translateY(-2px);filter:saturate(1.05)}.btn--primary svg{display:block}.btn--ghost{--bg: transparent;color:#fff;background:#ffffff29;border:1px solid rgba(255,255,255,.28);box-shadow:none}.btn--disabled{background:#ffffff2e;border:1px solid rgba(255,255,255,.3);cursor:default;box-shadow:none}.proj-hero{position:relative;background:radial-gradient(900px 360px at -10% 0,#eef2f7 0%,transparent 60%),radial-gradient(900px 360px at 110% 0,#eef2f7 0%,transparent 60%),linear-gradient(180deg,#fff,#f7f9fc);border-bottom:1px solid var(--border)}.proj-container{max-width:1200px;margin-inline:auto;padding:clamp(24px,5vw,48px) clamp(16px,5vw,24px)}.eyebrow{display:inline-block;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:#64748b;margin-bottom:6px}.proj-hero h1{margin:0 0 6px;font-weight:800;letter-spacing:-.02em;font-size:clamp(26px,4vw,36px);color:var(--ink)}.proj-hero .lead{margin:0 0 16px;color:var(--muted);font-size:clamp(14px,2.3vw,18px)}.proj-chips{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:12px}.proj-chips .chip{border:1px solid var(--border);background:#fff;color:var(--ink);padding:8px 12px;border-radius:999px;font-size:14px;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,border-color .2s ease,background .2s}.proj-chips .chip:hover{transform:translateY(-1px);border-color:#cbd5e1;box-shadow:0 6px 18px #0208170f}.proj-chips .chip.is-active{color:#fff;background:linear-gradient(90deg,var(--brand),#1f2937);border-color:transparent;box-shadow:0 10px 22px #0f172a2e}.proj-meta{color:#64748b;font-size:14px}@media (max-width: 560px){.proj-chips .chip{font-size:13px;padding:7px 11px}.proj-meta{font-size:13px}.project-card{min-height:320px;border-radius:16px}.project-card__content{padding:16px}.project-card__title{font-size:16px}}@media (prefers-reduced-motion: reduce){*{transition:none!important}}:root{--brand: #1d4ed8;--ink: #0f172a;--muted: #475569;--bg-soft: #f5f7fb;--ring: rgba(29, 78, 216, .22);--dot: #cfd6e6;--dot-size: 1.3px;--dot-gap: 18px;--about-dot: rgba(100, 116, 139, .55);--about-dot-size: 1.7px;--about-dot-gap: 18px;--orb-a: rgba(29, 78, 216, .2);--orb-b: rgba(14, 165, 233, .18);--orb-c: rgba(2, 132, 199, .16)}.home-root{font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--ink)}.hero-min{position:relative;overflow:hidden;min-height:100svh;display:grid;place-items:center;padding:clamp(28px,4vw,48px) clamp(18px,6vw,56px);padding-bottom:120px;background:linear-gradient(180deg,#fff,#fbfcff)}.hero-min__bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.hero-min__bg .pattern{position:absolute;top:-40px;right:0;bottom:-40px;left:0;background:radial-gradient(var(--dot) var(--dot-size),transparent var(--dot-size)) 0 0/var(--dot-gap) var(--dot-gap),radial-gradient(var(--dot) var(--dot-size),transparent var(--dot-size)) calc(var(--dot-gap) / 2) calc(var(--dot-gap) / 2)/var(--dot-gap) var(--dot-gap),linear-gradient(180deg,var(--bg-soft) 0%,#ffffff 100%);animation:dotsDrift 28s linear infinite;opacity:.6}@keyframes dotsDrift{0%{transform:translate(0)}to{transform:translate(-44px)}}.hero-min__bg .glow{position:absolute;top:-35%;right:-35%;bottom:-35%;left:-35%;background:radial-gradient(40% 50% at 25% 30%,rgba(37,99,235,.12) 0%,transparent 60%),radial-gradient(35% 45% at 80% 25%,rgba(6,182,212,.12) 0%,transparent 60%),radial-gradient(30% 35% at 60% 75%,rgba(2,132,199,.1) 0%,transparent 60%);filter:blur(2px);opacity:.28;animation:glowMove 24s ease-in-out infinite alternate}@keyframes glowMove{0%{transform:translate3d(-2%,-2%,0) scale(1)}50%{transform:translate3d(2%,1%,0) rotate(6deg) scale(1.02)}to{transform:translate3d(-1%,2%,0) rotate(-6deg) scale(1.01)}}.orbs{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden}.orb{position:absolute;border-radius:50%;filter:blur(18px);mix-blend-mode:multiply;will-change:transform}.orb--a{width:320px;height:320px;left:-80px;top:10%;background:var(--orb-a);animation:orbA 22s ease-in-out infinite}.orb--b{width:260px;height:260px;right:-60px;top:25%;background:var(--orb-b);animation:orbB 26s ease-in-out infinite reverse}.orb--c{width:300px;height:300px;left:40%;bottom:-120px;background:var(--orb-c);animation:orbC 30s ease-in-out infinite}@keyframes orbA{0%,to{transform:translate(0) scale(1)}40%{transform:translate(18vw,2vh) scale(1.05)}70%{transform:translate(8vw,-3vh) scale(.98)}}@keyframes orbB{0%,to{transform:translate(0) scale(1)}35%{transform:translate(-12vw,4vh) scale(1.04)}75%{transform:translate(-4vw,-2vh) scale(1.01)}}@keyframes orbC{0%,to{transform:translate(0) scale(1)}45%{transform:translate(6vw,-6vh) scale(1.06)}80%{transform:translate(-4vw,-2vh) scale(.99)}}.hero-min__inner{position:relative;z-index:1;width:100%;max-width:1200px;display:grid;gap:clamp(20px,4vw,56px);grid-template-columns:1.05fr .95fr}@media (max-width: 768px){.hero-min__inner{grid-template-columns:1fr;text-align:center;gap:28px}.hero-min__left{order:1}.hero-min__right{order:2}.cta,.stats{justify-content:center}.portrait{width:220px;aspect-ratio:1/1;margin:0 auto}.hero-min{padding-bottom:100px}}.eyebrow{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:#334155;background:#fff;border:1px solid #d1d5db;padding:6px 10px;border-radius:999px;margin-bottom:10px}.h-title{margin:0;font-weight:900;letter-spacing:-.02em;font-size:clamp(34px,7vw,62px);color:var(--brand)}.h-sub{margin:10px 0 18px;color:#1f2937;font-size:clamp(14px,2.1vw,18px);max-width:60ch}@media (max-width: 1000px){.h-sub{margin-inline:auto}}.cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:14px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 18px;border-radius:14px;font-weight:700;font-size:15px;text-decoration:none;transition:transform .18s ease,filter .2s ease,box-shadow .25s ease}.btn.primary{color:#fff;background:linear-gradient(90deg,var(--brand),#0ea5e9);box-shadow:0 12px 28px var(--ring);cursor:pointer}.btn.primary:hover{transform:translateY(-2px);filter:saturate(1.06)}.btn.ghost{color:var(--ink);background:#fffc;border:2px solid #e6eaf6}.btn.ghost:hover{transform:translateY(-2px);background:#fff}.stats{list-style:none;padding:0;margin:2px 0 0;display:flex;gap:10px;flex-wrap:wrap;color:#394150;font-weight:600}.stats li{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:10px 12px;box-shadow:0 8px 18px #0000000d;display:flex;align-items:baseline;gap:6px}.stats strong{color:var(--brand);font-size:16px}.hero-min__right{display:grid;place-items:center}.portrait{position:relative;width:clamp(260px,34vw,360px);aspect-ratio:4/5;border-radius:24px;overflow:hidden;padding:10px;background:linear-gradient(135deg,#e9f0ff,#e9fbff);box-shadow:0 20px 50px #02081712;animation:float 8s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.portrait:before{content:"";position:absolute;top:10px;right:10px;bottom:10px;left:10px;border-radius:18px;background:linear-gradient(180deg,#ffffffc7,#fffffffa);z-index:0}.portrait img{position:relative;z-index:1;width:100%;height:100%;border-radius:16px;object-fit:cover;display:block;transition:transform .35s ease}.portrait:hover img{transform:scale(1.02)}.scroll-hint{position:absolute;left:50%;transform:translate(-50%);bottom:24px;width:26px;height:42px;border:2px solid #cbd5e1;border-radius:20px;display:grid;place-items:start center;opacity:.75;text-decoration:none;transition:opacity .2s ease;z-index:2}.scroll-hint:hover{opacity:1}.scroll-hint .wheel{width:4px;height:8px;margin-top:6px;background:#94a3b8;border-radius:2px;animation:wheel 1.6s ease-in-out infinite}@keyframes wheel{0%{transform:translateY(0)}60%{transform:translateY(12px)}to{transform:translateY(0)}}.section{padding:clamp(48px,6vw,80px) clamp(18px,6vw,56px);background:#fff}.section.alt{background:#f7f8fb}.section-inner{max-width:1200px;margin-inline:auto}.section-head{display:flex;align-items:baseline;gap:12px;margin-bottom:18px}.section-head h2{margin:0;font-size:clamp(22px,3vw,28px);color:var(--ink)}.section-head .link{margin-left:auto;font-size:14px;color:var(--brand);text-decoration:none;border-bottom:1px dashed transparent}.section-head .link:hover{color:#1d4ed8;border-color:#bfdbfe}.home-grid{display:grid;gap:clamp(14px,2.8vw,22px);grid-template-columns:repeat(auto-fit,minmax(270px,1fr))}.home-grid__item{display:grid}:root{--about-bg: #f8fafc}.about-min{position:relative;padding:clamp(48px,6vw,80px) clamp(18px,6vw,56px);background:var(--about-bg);overflow:hidden}.about-min:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(var(--about-dot) var(--about-dot-size),transparent var(--about-dot-size)),radial-gradient(var(--about-dot) var(--about-dot-size),transparent var(--about-dot-size));background-size:var(--about-dot-gap) var(--about-dot-gap),var(--about-dot-gap) var(--about-dot-gap);background-position:0 0,calc(var(--about-dot-gap) / 2) calc(var(--about-dot-gap) / 2);opacity:.6;animation:aboutDrift 22s linear infinite;pointer-events:none;z-index:0}@keyframes aboutDrift{0%{background-position:0 0,calc(var(--about-dot-gap) / 2) calc(var(--about-dot-gap) / 2)}to{background-position:60px 40px,calc(60px + var(--about-dot-gap) / 2) calc(40px + var(--about-dot-gap) / 2)}}.about-min:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#ffffffb8,#ffffffeb);pointer-events:none;z-index:0}.about-min__inner{position:relative;z-index:1;max-width:1100px;margin-inline:auto}.about-card{background:#fff;border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 12px 28px #0f172a0f;padding:clamp(16px,3.6vw,22px)}.about-min__copy{max-width:760px}@media (max-width: 720px){.about-min__copy{max-width:100%}}.about-min__title{margin:6px 0 10px;font-weight:800;letter-spacing:-.02em;font-size:clamp(22px,3vw,28px);color:var(--ink)}.about-min__desc{margin:0 0 14px;color:var(--muted);font-size:clamp(14px,2.1vw,18px);line-height:1.65}.about-min__skills{list-style:none;padding:0;margin:10px 0 18px;display:flex;flex-wrap:wrap;gap:8px}.about-min__skills li{padding:8px 12px;border-radius:999px;background:#fff;border:1px solid #e5e7eb;font-size:13px;color:#0f172a;box-shadow:0 6px 16px #0000000a}.about-min__actions{display:flex;gap:10px;flex-wrap:wrap}@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}:root{--ink: #0f172a;--muted: #475569;--border: #e2e8f0;--accent: #2563eb;--accent-2: #0ea5e9;--shadow: 0 10px 24px rgba(15, 23, 42, .08);--shadow-lg: 0 18px 36px rgba(15, 23, 42, .12)}.card-article{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:16px;background:#fff;border:1px solid var(--border);transition:transform .2s ease,box-shadow .25s ease,border-color .25s ease;box-shadow:var(--shadow);display:grid;grid-template-rows:auto 1fr;outline:none}.card-article:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:#d1e0ff}.card-article:focus-visible{box-shadow:0 0 0 4px #2563eb33}.card-article__media{position:relative;border-top-left-radius:16px;border-top-right-radius:16px;overflow:hidden}.card-article__media img{display:block;width:100%;aspect-ratio:16/9;object-fit:cover;transition:transform .35s ease,filter .35s ease}.card-article:hover img{transform:scale(1.045);filter:saturate(1.06)}.card-article__body{padding:14px 16px 16px;display:grid;grid-template-rows:auto 1fr auto;gap:8px}.card-article__title{font-size:clamp(16px,2.6vw,18px);font-weight:600;letter-spacing:.1px;margin:0;color:var(--ink);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.card-article__desc{margin:0;color:var(--muted);font-size:14px;line-height:1.6}.card-article__meta{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:6px}.card-article__date{color:#64748b;font-size:12px}.card-article__cta{font-size:13px;color:#fff;font-weight:600;background:linear-gradient(90deg,var(--accent),var(--accent-2));padding:6px 12px;border-radius:10px;transition:transform .18s ease,filter .2s ease}.card-article__cta:hover{filter:saturate(1.08)}@media (max-width: 480px){.card-article__body{padding:12px 12px 14px}.card-article__desc{font-size:13px}}:root{--ink: #0f172a;--muted: #475569;--border: #e2e8f0;--bg: #ffffff;--bg-alt: #f6f8fb;--brand: #33383c;--accent: #2563eb;--shadow: 0 12px 28px rgba(15, 23, 42, .08);--shadow-lg: 0 18px 40px rgba(15, 23, 42, .12)}.article{color:var(--ink);background:var(--bg-alt)}.article__loading{min-height:70vh;display:grid;place-items:center}.article__hero{position:relative;border-bottom:1px solid var(--border);background:radial-gradient(900px 360px at -10% 0,#eef2f7 0%,transparent 60%),radial-gradient(900px 360px at 110% 0,#eef2f7 0%,transparent 60%),linear-gradient(180deg,#fff,#f7f9fc);padding:clamp(28px,6vw,64px) clamp(16px,5vw,24px)}.article__hero.has-cover{background:linear-gradient(180deg,#0f172a66,#0f172abf 70%),var(--cover) center/cover no-repeat;color:#fff;border-bottom:none;box-shadow:var(--shadow)}.article__hero-inner{max-width:900px;margin-inline:auto}.article__breadcrumbs{margin-bottom:8px}.article__breadcrumbs a{color:inherit;text-decoration:none;opacity:.9;transition:opacity .2s ease}.article__breadcrumbs a:hover{opacity:1}.article__title{margin:0 0 6px;font-weight:800;letter-spacing:-.02em;font-size:clamp(26px,4.2vw,38px)}.article__date{font-size:14px;opacity:.85}.article__container{max-width:900px;margin-inline:auto;padding:clamp(18px,4vw,28px) clamp(16px,5vw,24px) clamp(48px,6vw,64px)}.article__error{background:#fff;border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:var(--shadow)}.article__error h2{margin:0 0 8px}.article__error a{color:var(--accent);text-decoration:none}.prose{background:#fff;border:1px solid var(--border);border-radius:18px;padding:clamp(18px,3.5vw,28px);box-shadow:var(--shadow);line-height:1.75;font-size:1.02rem}.prose h1,.prose h2,.prose h3,.prose h4,.prose h5,.prose h6{color:var(--ink);font-weight:700;letter-spacing:-.01em;margin-top:1.6em;margin-bottom:.6em}.prose h1{font-size:clamp(28px,3.8vw,32px)}.prose h2{font-size:clamp(22px,3.2vw,28px)}.prose h3{font-size:clamp(18px,2.6vw,22px)}.prose p{margin:.9em 0;color:var(--ink)}.prose strong{font-weight:700}.prose em{font-style:italic}.prose a{color:var(--accent);text-decoration:none;border-bottom:1px dashed rgba(37,99,235,.35);transition:color .2s ease,border-color .2s ease;word-break:break-word}.prose a:hover{color:#1d4ed8;border-color:#2563eb8c}.prose ul,.prose ol{padding-left:1.25em;margin:.8em 0 1.2em}.prose li{margin:.3em 0}.prose blockquote{margin:1.2em 0;padding:14px 16px;background:#f8fafc;border-left:4px solid var(--brand);border-radius:10px;color:#0b1324}.prose img{display:block;max-width:100%;height:auto;margin:16px auto;border-radius:12px;box-shadow:0 8px 24px #02081714}.prose code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Courier New,monospace;font-size:.95em;background:#0b1220;color:#e5e7eb;padding:.15em .45em;border-radius:6px}.prose pre{margin:1.2em 0;background:#0b1220;color:#e5e7eb;border-radius:14px;border:1px solid #0f1b33;overflow:auto;box-shadow:0 14px 26px #02081738}.prose pre code{display:block;background:transparent;color:inherit;padding:16px 18px;line-height:1.6;font-size:.92rem}.prose table{width:100%;border-collapse:collapse;margin:1.2em 0;overflow:hidden;border-radius:12px;border:1px solid var(--border)}.prose thead{background:#f8fafc}.prose th,.prose td{padding:10px 12px;border-bottom:1px solid var(--border);text-align:left}.prose hr{border:none;border-top:1px solid var(--border);margin:1.6em 0}@media (max-width: 560px){.article__title{font-size:24px}.prose{padding:16px;border-radius:14px}.prose pre code{padding:14px;font-size:.9rem}}.skills{display:flex;justify-content:center;width:100%}.wrapper{max-width:85vw;margin:0 auto;display:grid;grid-template-columns:auto;grid-template-rows:auto;grid-auto-flow:column}figure{margin:0;padding:0}img{max-width:100%;height:auto;display:block;margin-left:auto;margin-right:auto;object-fit:cover}.wide{display:grid;grid-template-columns:100%;grid-template-rows:auto 1.25em}.wide-a{grid-column:1/2;grid-row:1/2}.composed{display:grid;grid-template-columns:49.295774647% 1.408450704% 49.295774647%}.composed-a{grid-column:1/2;grid-row:1/4}.composed-b{grid-column:3/4;grid-row:1/2;max-width:48%}.composed-c{grid-column:3/4;grid-row:3/4;max-width:48%}.button{display:inline-flex;align-items:center;justify-content:center;width:clamp(100px,12vw,160px);height:clamp(38px,5vh,50px);border-radius:16px;background-color:#33383c;color:#fff;border:2px solid #33383c;font-size:clamp(12px,1.6vw,16px);font-weight:500;transition:all .3s ease;cursor:pointer}.button:hover{background-color:#fff;color:#33383c;border:2px solid #33383c}@media (max-width: 1024px){.button{width:clamp(90px,20vw,140px);height:40px;font-size:14px}}@media (max-width: 767px){.button{width:clamp(80px,30vw,120px);height:36px;font-size:12px}}:root{--brand: #33383c;--ink: #0f172a;--muted: #475569;--border: #e5e7f0;--bg: #fff;--bg-alt: #f6f8fb;--ring: rgba(51, 56, 60, .18);--shadow: 0 12px 28px rgba(15, 23, 42, .08);--shadow-lg: 0 18px 40px rgba(15, 23, 42, .12)}.pub-v2{font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--ink)}.pub-hero{background:radial-gradient(900px 360px at -10% 0,#eef2f7 0%,transparent 60%),radial-gradient(900px 360px at 110% 0,#eef2f7 0%,transparent 60%),linear-gradient(180deg,#fff,#f7f9fc);border-bottom:1px solid var(--border)}.pub-hero .container{max-width:1200px;margin-inline:auto;padding:clamp(24px,5vw,48px) clamp(16px,5vw,24px)}.hero-top h1{margin:0 0 6px;font-weight:800;letter-spacing:-.02em;font-size:clamp(26px,4vw,36px)}.hero-top .lead{margin:0 0 14px;color:var(--muted);font-size:clamp(14px,2.3vw,18px)}.chips{display:flex;gap:10px;flex-wrap:wrap}.chips .chip{text-decoration:none;color:var(--ink);border:1px solid var(--border);background:#fff;padding:8px 12px;border-radius:999px;font-size:14px;transition:transform .15s ease,box-shadow .2s ease,border-color .2s ease}.chips .chip:hover{transform:translateY(-1px);border-color:#cbd5e1;box-shadow:0 6px 18px #0208170f}.feature-card{margin-top:18px;position:relative;width:100%;min-height:320px;display:block;border:1px solid var(--border);border-radius:20px;overflow:hidden;background-size:cover;background-position:center;box-shadow:var(--shadow);text-align:left;cursor:pointer;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:#d5dbe8}.feature-card .overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0f172a1a,#0f172aa6 70%)}.feature-card .content{position:absolute;inset:auto 0 0 0;padding:20px clamp(16px,4vw,24px);color:#fff;display:grid;gap:8px}.feature-card .badge{width:max-content;background:#ffffff2e;-webkit-backdrop-filter:saturate(140%) blur(4px);backdrop-filter:saturate(140%) blur(4px);border:1px solid rgba(255,255,255,.25);padding:6px 10px;border-radius:999px;font-size:12px}.feature-card h2{margin:2px 0 0;font-size:clamp(20px,3.2vw,28px);font-weight:700;letter-spacing:-.01em}.feature-card .desc{margin:0;font-size:14px;opacity:.95}.feature-card .meta{margin-top:6px;display:flex;justify-content:space-between;align-items:center;gap:10px}.feature-card .meta time{font-size:12px;opacity:.9}.feature-card .cta{background:linear-gradient(90deg,var(--brand),#1f2937);padding:8px 14px;border-radius:10px;font-weight:600;font-size:13px}.pub-section{background:var(--bg)}.pub-section:nth-of-type(2n){background:var(--bg-alt)}.pub-section .container{max-width:1200px;margin-inline:auto;padding:clamp(26px,5vw,44px) clamp(16px,5vw,24px)}.section-head{display:flex;align-items:center;gap:12px;margin-bottom:16px}.section-head h2{margin:0;font-size:clamp(20px,3vw,26px);font-weight:700;position:relative}.section-head h2:after{content:"";position:absolute;left:0;bottom:-8px;height:3px;width:38px;background:linear-gradient(90deg,var(--brand),#1f2937);border-radius:999px}.section-head .count{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#fff;color:var(--ink);font-weight:700;font-size:12px;line-height:1;border:1px solid var(--border);box-shadow:0 4px 12px #0208170d}.section-head .count:before{content:"";width:8px;height:8px;border-radius:50%;background:#10b981;box-shadow:0 0 0 4px #10b9812e}.pub-grid{display:flex;flex-wrap:wrap;gap:clamp(14px,2.8vw,22px);justify-content:flex-start;align-items:stretch}.pub-grid>*{flex:0 1 320px}@media (max-width: 520px){.pub-grid>*{flex-basis:100%}}html,body{margin:0;place-items:center;min-width:320px;min-height:100vh;padding:0;overflow-x:clip}
