@import"https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;1,9..40,300&display=swap";:root{--color-primary: #2563EB;--color-primary-dark: #1D4ED8;--color-primary-light: #DBEAFE;--color-accent: #3B82F6;--color-bg: #F3F4F6;--color-surface: #FFFFFF;--color-surface-hover: #F8FAFF;--color-text-heading: #111827;--color-text-body: #4B5563;--color-text-muted: #9CA3AF;--color-border: #E5E7EB;--font-display: "Syne", sans-serif;--font-body: "DM Sans", sans-serif;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px;--shadow-card: 0 1px 3px rgba(0,0,0,.06), 0 4px 16px rgba(0,0,0,.07);--shadow-card-hover: 0 4px 12px rgba(37,99,235,.12), 0 16px 40px rgba(37,99,235,.1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-spring: .4s cubic-bezier(.34, 1.56, .64, 1);--header-h: 68px;--max-w: 1120px;--section-gap: 120px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;scroll-padding-top:var(--header-h);font-size:16px;-webkit-font-smoothing:antialiased}body{font-family:var(--font-body);background-color:var(--color-bg);color:var(--color-text-body);line-height:1.6;overflow-x:hidden}img{display:block;max-width:100%}a{color:inherit;text-decoration:none}ul{list-style:none}.container{max-width:var(--max-w);margin:0 auto;padding:0 clamp(20px,5vw,48px)}.section{padding-block:var(--section-gap)}.section-label{font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--color-primary);display:inline-flex;align-items:center;gap:10px;margin-bottom:16px}.section-label:before{content:"";display:block;width:28px;height:2px;background:var(--color-primary);border-radius:2px}.section-title{font-family:var(--font-display);font-size:clamp(28px,4vw,40px);font-weight:800;color:var(--color-text-heading);line-height:1.15;margin-bottom:12px}.section-subtitle{font-size:17px;font-weight:300;color:var(--color-text-body);max-width:560px;line-height:1.65}@keyframes fadeUp{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.reveal{animation:fadeUp .7s var(--transition-base) both}.reveal-delay-1{animation-delay:.08s}.reveal-delay-2{animation-delay:.16s}.reveal-delay-3{animation-delay:.24s}.reveal-delay-4{animation-delay:.32s}.reveal-delay-5{animation-delay:.4s}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--color-primary-light)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px;border-radius:var(--radius-sm)}@media(max-width:768px){:root{--section-gap: 80px}}.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:500;padding:12px 24px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-base),color var(--transition-base),transform var(--transition-spring),box-shadow var(--transition-base),border-color var(--transition-base);text-decoration:none;white-space:nowrap}.btn svg{width:16px;height:16px;flex-shrink:0}.btn--primary{background:var(--color-primary);color:#fff;box-shadow:0 2px 8px #2563eb40}.btn--primary:hover{background:var(--color-primary-dark);transform:translateY(-2px);box-shadow:0 6px 20px #2563eb59}.btn--ghost{background:transparent;color:var(--color-text-heading);border:1.5px solid var(--color-border)}.btn--ghost:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light);transform:translateY(-2px)}.hero{position:relative;padding-top:calc(var(--header-h) + 80px);padding-bottom:var(--section-gap);overflow:hidden}.hero__inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:flex-start;gap:28px;max-width:780px}.hero__badge{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--color-primary);background:var(--color-primary-light);padding:6px 14px;border-radius:99px;border:1px solid rgba(37,99,235,.2)}.hero__badge-dot{width:8px;height:8px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 2px #22c55e4d;animation:pulse 2s ease infinite}@keyframes pulse{0%,to{box-shadow:0 0 0 2px #22c55e4d}50%{box-shadow:0 0 0 5px #22c55e00}}.hero__title{font-family:var(--font-display);font-size:clamp(36px,6vw,68px);font-weight:800;line-height:1.08;letter-spacing:-.03em;color:var(--color-text-heading)}.hero__title-name{color:var(--color-primary)}.hero__title-role{color:var(--color-text-heading)}.hero__title-spec{color:var(--color-text-body);font-weight:400;font-style:italic}.hero__headline{font-size:clamp(17px,2.2vw,21px);font-weight:300;color:var(--color-text-body);line-height:1.6;max-width:600px}.hero__ctas{display:flex;flex-wrap:wrap;gap:12px}.hero__skills{display:flex;flex-wrap:wrap;gap:8px;padding-top:8px}.hero__skill-chip{font-size:12px;font-weight:500;letter-spacing:.04em;color:var(--color-text-body);background:var(--color-surface);border:1px solid var(--color-border);padding:5px 12px;border-radius:99px;transition:border-color var(--transition-base),color var(--transition-base)}.hero__skill-chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.hero__orb{position:absolute;top:-120px;right:-160px;width:640px;height:640px;border-radius:50%;background:radial-gradient(ellipse at center,rgba(37,99,235,.07) 0%,transparent 70%);pointer-events:none;z-index:0}.about{background:var(--color-surface);border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.about__grid{display:grid;grid-template-columns:1fr auto;gap:48px;align-items:start;margin-top:32px}.about__bio{font-size:17px;line-height:1.75;color:var(--color-text-body);font-weight:300;max-width:600px}.about__stats{display:flex;flex-direction:column;gap:28px;min-width:200px;padding:28px 32px;background:var(--color-bg);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.about__stat{display:flex;flex-direction:column;gap:4px}.about__stat-value{font-family:var(--font-display);font-size:32px;font-weight:800;color:var(--color-primary);letter-spacing:-.03em;line-height:1}.about__stat-label{font-size:13px;color:var(--color-text-muted);font-weight:500}@media(max-width:768px){.about__grid{grid-template-columns:1fr}.about__stats{flex-direction:row;justify-content:space-around;min-width:unset}}.about__bio{font-size:17px;line-height:1.75;color:var(--color-text-body);font-weight:300;max-width:600px;white-space:pre-line}.projects .section-subtitle{margin-bottom:48px}.projects__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}@media(max-width:1024px){.projects__grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.projects__grid{grid-template-columns:1fr}}.contact__card{background:linear-gradient(135deg,#1e3a8a,#2563eb 60%,#3b82f6);border-radius:var(--radius-lg);padding:clamp(40px,6vw,72px);display:flex;flex-direction:column;gap:20px;position:relative;overflow:hidden}.contact__card:before{content:"";position:absolute;top:-80px;right:-80px;width:360px;height:360px;border-radius:50%;background:#ffffff0d;pointer-events:none}.contact__card:after{content:"";position:absolute;bottom:-120px;left:-40px;width:280px;height:280px;border-radius:50%;background:#ffffff0a;pointer-events:none}.contact__card .section-label{color:#ffffffb3}.contact__card .section-label:before{background:#ffffff80}.contact__title{font-family:var(--font-display);font-size:clamp(28px,4vw,44px);font-weight:800;color:#fff;line-height:1.15;letter-spacing:-.03em;max-width:520px;position:relative;z-index:1}.contact__sub{font-size:17px;font-weight:300;color:#fffc;max-width:480px;line-height:1.65;position:relative;z-index:1}.contact__links{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px;position:relative;z-index:1}.contact__links .btn--primary{background:#fff;color:var(--color-primary);box-shadow:0 4px 20px #00000026}.contact__links .btn--primary:hover{background:#f0f7ff;transform:translateY(-2px);box-shadow:0 8px 28px #0003}.contact__links .btn--ghost{color:#fff;border-color:#fff6}.contact__links .btn--ghost:hover{border-color:#fff;color:#fff;background:#ffffff1f}.footer{border-top:1px solid var(--color-border);padding:28px 0;background:var(--color-surface)}.footer__inner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:13px;color:var(--color-text-muted)}.footer__made{font-style:italic}.header{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--header-h);transition:background var(--transition-base),box-shadow var(--transition-base)}.header--scrolled{background:#ffffffe0;backdrop-filter:blur(14px) saturate(180%);-webkit-backdrop-filter:blur(14px) saturate(180%);box-shadow:0 1px 0 var(--color-border),0 4px 24px #0000000f}.header__inner{height:100%;display:flex;align-items:center;gap:24px}.header__logo{display:flex;align-items:center;gap:10px;margin-right:auto;text-decoration:none}.header__logo-mark{width:36px;height:36px;background:var(--color-primary);color:#fff;font-family:var(--font-display);font-size:13px;font-weight:800;letter-spacing:.04em;border-radius:8px;display:grid;place-items:center;flex-shrink:0;transition:transform var(--transition-spring)}.header__logo:hover .header__logo-mark{transform:rotate(-8deg) scale(1.08)}.header__logo-text{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--color-text-heading);letter-spacing:-.02em}.header__nav-list{display:flex;align-items:center;gap:4px}.header__nav-link{font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--color-text-body);padding:6px 14px;border-radius:var(--radius-sm);transition:color var(--transition-base),background var(--transition-base);position:relative}.header__nav-link:after{content:"";position:absolute;bottom:-2px;left:50%;transform:translate(-50%) scaleX(0);width:calc(100% - 28px);height:2px;background:var(--color-primary);border-radius:2px;transition:transform var(--transition-base)}.header__nav-link:hover{color:var(--color-primary);background:var(--color-primary-light)}.header__nav-link--active{color:var(--color-primary);font-weight:600}.header__nav-link--active:after{transform:translate(-50%) scaleX(1)}.header__cta{font-family:var(--font-body);font-size:14px;font-weight:500;color:#fff;background:var(--color-primary);padding:8px 20px;border-radius:var(--radius-sm);transition:background var(--transition-base),transform var(--transition-spring),box-shadow var(--transition-base);white-space:nowrap}.header__cta:hover{background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 4px 14px #2563eb59}.header__hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;background:none;border:none;cursor:pointer;padding:6px;border-radius:var(--radius-sm)}.header__hamburger span{display:block;height:2px;background:var(--color-text-heading);border-radius:2px;transition:transform var(--transition-base),opacity var(--transition-base);transform-origin:center}.header__hamburger--open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.header__hamburger--open span:nth-child(2){opacity:0;transform:scaleX(0)}.header__hamburger--open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.header__drawer{position:fixed;top:var(--header-h);left:0;right:0;background:#fffffff5;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:0 clamp(20px,5vw,48px);max-height:0;overflow:hidden;transition:max-height .35s cubic-bezier(.4,0,.2,1),padding .35s;border-bottom:1px solid transparent}.header__drawer--open{max-height:320px;padding-block:16px;border-bottom-color:var(--color-border)}.header__drawer ul{display:flex;flex-direction:column;gap:4px}.header__drawer-link{display:block;font-size:16px;font-weight:500;color:var(--color-text-body);padding:12px 8px;border-radius:var(--radius-sm);transition:color var(--transition-base),background var(--transition-base)}.header__drawer-link:hover,.header__drawer-link--active{color:var(--color-primary);background:var(--color-primary-light)}@media(max-width:768px){.header__nav,.header__cta{display:none}.header__hamburger{display:flex}}.card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);border:1px solid var(--color-border);display:flex;flex-direction:column;overflow:hidden;transition:transform var(--transition-base),box-shadow var(--transition-base),border-color var(--transition-base);will-change:transform}.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-card-hover);border-color:var(--color-primary-light)}.card__thumb{position:relative;width:100%;height:200px;overflow:hidden;flex-shrink:0}.card__thumb-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;object-position:top center;display:block;opacity:0;transition:opacity .4s ease,transform var(--transition-base);will-change:opacity,transform}.card__thumb-img--loaded{opacity:1}.card:hover .card__thumb-img{transform:scale(1.04)}.card__thumb-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,transparent 45%,rgba(0,0,0,.18) 100%);pointer-events:none;z-index:1}.card__thumb-skeleton{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,var(--color-border) 25%,#e9ebee 50%,var(--color-border) 75%);background-size:200% 100%;animation:shimmer 1.4s ease infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.card__thumb-fallback{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.card__thumb-fallback svg{width:40px;height:40px;color:var(--color-text-muted);opacity:.5}.card__body{padding:20px 22px 16px;flex:1;display:flex;flex-direction:column;gap:10px}.card__tags{display:flex;flex-wrap:wrap;gap:6px}.card__tag{font-family:var(--font-body);font-size:11px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--color-primary);background:var(--color-primary-light);padding:3px 9px;border-radius:99px}.card__title{font-family:var(--font-display);font-size:17px;font-weight:700;color:var(--color-text-heading);line-height:1.3;letter-spacing:-.02em}.card__desc{font-size:14px;line-height:1.65;color:var(--color-text-body);font-weight:300;flex:1}.card__footer{padding:14px 22px 20px;border-top:1px solid var(--color-border);margin-top:4px}.card__btn{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--color-primary);transition:color var(--transition-base),gap var(--transition-spring)}.card__btn:hover{color:var(--color-primary-dark);gap:11px}.card__btn-icon{width:16px;height:16px;flex-shrink:0}.card__btn-arrow{width:14px;height:14px;flex-shrink:0;transition:transform var(--transition-spring)}.card__btn:hover .card__btn-arrow{transform:translate(3px)}
