:root{--font-heading: "Syne", system-ui, sans-serif;--font-body: "DM Sans", system-ui, sans-serif;--bg-primary: #f8fafc;--bg-secondary: #f1f5f9;--bg-elevated: #ffffff;--bg-card: #ffffff;--bg-card-hover: #f8fafc;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #64748b;--text-on-accent: #ffffff;--accent: #7c3aed;--accent-hover: #6d28d9;--accent-soft: rgba(124, 58, 237, .1);--accent-border: rgba(124, 58, 237, .28);--accent-glow: rgba(124, 58, 237, .2);--color-tint-1: rgba(124, 58, 237, .06);--color-tint-2: rgba(124, 58, 237, .05);--color-tint-3: rgba(124, 58, 237, .05);--border: #e2e8f0;--border-subtle: #f1f5f9;--border-focus: #94a3b8;--shadow-xs: 0 1px 2px rgba(15, 23, 42, .04);--shadow-sm: 0 2px 8px rgba(15, 23, 42, .06), 0 1px 2px rgba(15, 23, 42, .04);--shadow-md: 0 4px 20px rgba(15, 23, 42, .08), 0 2px 6px rgba(15, 23, 42, .04);--shadow-lg: 0 12px 40px rgba(15, 23, 42, .1), 0 4px 12px rgba(15, 23, 42, .05);--shadow-xl: 0 24px 64px rgba(15, 23, 42, .12);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--space-4xl: 6rem;--section-padding-y: clamp(3.5rem, 10vw, 6rem);--section-padding-x: clamp(1.25rem, 5vw, 2.5rem);--container-max: 1140px;--header-height: 4.25rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 24px;--radius-full: 9999px;--ease-out: cubic-bezier(.22, 1, .36, 1);--ease-out-back: cubic-bezier(.34, 1.56, .64, 1);--transition-fast: .2s var(--ease-out);--transition-base: .28s var(--ease-out);--transition-slow: .4s var(--ease-out);--duration-slow: .6s}[data-theme=dark]{--bg-primary: #0a0a0c;--bg-secondary: #121216;--bg-elevated: #16161b;--bg-card: #16161b;--bg-card-hover: #1c1c22;--text-primary: #f4f4f5;--text-secondary: #a1a1aa;--text-muted: #71717a;--text-on-accent: #ffffff;--accent: #8b5cf6;--accent-hover: #a78bfa;--accent-soft: rgba(139, 92, 246, .14);--accent-border: rgba(139, 92, 246, .35);--accent-glow: rgba(139, 92, 246, .25);--color-tint-1: rgba(139, 92, 246, .08);--color-tint-2: rgba(139, 92, 246, .06);--color-tint-3: rgba(139, 92, 246, .06);--border: #27272a;--border-subtle: #1f1f23;--border-focus: #3f3f46;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .2);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .25);--shadow-md: 0 4px 20px rgba(0, 0, 0, .35);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .4);--shadow-xl: 0 24px 64px rgba(0, 0, 0, .5)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;background-color:var(--bg-primary);color:var(--text-primary)}body{font-family:var(--font-body);font-size:1rem;line-height:1.65;color:var(--text-primary);background-color:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;transition:background-color var(--transition-slow),color var(--transition-slow)}#root{min-height:100vh;background-color:var(--bg-primary)}img{max-width:100%;height:auto;display:block}a{color:var(--accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-hover)}button{font-family:var(--font-body);cursor:pointer;border:none;background:none}h1,h2,h3,h4{font-family:var(--font-heading);font-weight:700;line-height:1.2;letter-spacing:-.02em}h1{font-size:clamp(2.5rem,5.5vw,3.75rem);letter-spacing:-.03em}h2{font-size:clamp(1.875rem,4vw,2.625rem)}h3{font-size:clamp(1.25rem,2.5vw,1.5rem)}.section-label{font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin-bottom:var(--space-md);padding-left:var(--space-md);border-left:3px solid var(--accent);display:block}.container{width:100%;max-width:var(--container-max);margin-inline:auto;padding-inline:var(--section-padding-x)}.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}.animate-on-scroll{opacity:0;transform:translateY(24px);transition:opacity var(--duration-slow) var(--ease-out),transform var(--duration-slow) var(--ease-out)}.animate-on-scroll.is-visible{opacity:1;transform:translateY(0)}.animate-on-scroll--delay-1{transition-delay:.08s}.animate-on-scroll--delay-2{transition-delay:.16s}.animate-on-scroll--delay-3{transition-delay:.24s}.animate-on-scroll--delay-4{transition-delay:.32s}.animate-on-scroll--delay-5{transition-delay:.4s}@media(prefers-reduced-motion:reduce){.animate-on-scroll{opacity:1;transform:none;transition-duration:.01ms}}.header{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--header-height);background:#f8fafce0;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-subtle);transition:background var(--transition-base),border-color var(--transition-base),box-shadow var(--transition-base)}[data-theme=dark] .header{background:#0a0a0ce0;border-bottom-color:var(--border)}.header__inner{display:flex;align-items:center;justify-content:space-between;height:100%}.header__right{display:flex;align-items:center;gap:var(--space-xs)}.header__theme-btn{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;padding:0;color:var(--text-secondary);border-radius:var(--radius-md);transition:color var(--transition-fast),background var(--transition-fast),transform var(--transition-fast)}.header__theme-btn:hover{color:var(--accent);background:var(--accent-soft)}.header__theme-btn:active{transform:scale(.96)}.header__theme-icon{display:flex;align-items:center;justify-content:center;animation:theme-icon-in .35s var(--ease-out)}@keyframes theme-icon-in{0%{opacity:0;transform:rotate(-15deg)}to{opacity:1;transform:rotate(0)}}.header__logo{font-family:var(--font-heading);font-weight:700;font-size:1.25rem;letter-spacing:-.02em;color:var(--text-primary);transition:color var(--transition-fast)}.header__logo:hover{color:var(--accent)}.header__menu-btn{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;padding:0;color:var(--text-primary);border-radius:var(--radius-md);transition:background var(--transition-fast),color var(--transition-fast)}.header__menu-btn:hover{background:var(--bg-secondary);color:var(--accent)}@media(min-width:768px){.header__menu-btn{display:none}}.header__menu-icon{position:relative;width:1.25rem;height:2px;background:currentColor;transition:transform var(--transition-base),opacity var(--transition-base)}.header__menu-icon:before,.header__menu-icon:after{content:"";position:absolute;left:0;width:100%;height:2px;background:currentColor;transition:transform var(--transition-base)}.header__menu-icon:before{top:-6px}.header__menu-icon:after{top:6px}.header__menu-icon[data-open=true]{background:transparent}.header__menu-icon[data-open=true]:before{top:0;transform:rotate(45deg)}.header__menu-icon[data-open=true]:after{top:0;transform:rotate(-45deg)}.header__nav--desktop{display:none}@media(min-width:768px){.header__nav--desktop{display:block}}.header__nav-overlay{position:fixed;top:var(--header-height);left:0;right:0;bottom:0;z-index:9999;background:var(--bg-primary);padding:var(--space-2xl) var(--section-padding-x);overflow-y:auto;-webkit-overflow-scrolling:touch}.header__nav-overlay-inner{padding-top:var(--space-2xl)}.header__nav-overlay .header__list{flex-direction:column;padding-top:0}.header__list{list-style:none;display:flex;flex-direction:column;gap:var(--space-sm);padding-top:var(--space-2xl)}@media(min-width:768px){.header__list{flex-direction:row;align-items:center;gap:var(--space-md);padding-top:0}}.header__link{display:block;font-size:.9375rem;font-weight:500;color:var(--text-secondary);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);transition:color var(--transition-fast),background var(--transition-fast)}.header__link:hover{color:var(--accent);background:var(--accent-soft)}@media(min-width:768px){.header__link{padding:var(--space-xs) var(--space-md)}}.hero{--hero-bg: #111111;--hero-lime: #A8FF35;--hero-lime-soft: rgba(168, 255, 53, .15);--hero-text: #f4f4f5;--hero-text-muted: #a1a1aa;position:relative;min-height:100vh;display:flex;align-items:center;padding-top:var(--header-height);padding-bottom:var(--space-4xl);overflow:hidden;background:var(--hero-bg)}.hero__bg-blob{position:absolute;width:80%;max-width:600px;height:80%;max-height:700px;right:-10%;top:50%;transform:translateY(-50%);background:var(--hero-lime-soft);border-radius:60% 40% 50% 50%/50% 60% 40% 50%;pointer-events:none;will-change:transform;transition:transform .1s linear}.hero__inner{position:relative;width:100%;z-index:1}.hero__grid{display:grid;grid-template-columns:1fr;gap:var(--space-2xl);align-items:center}@media(min-width:900px){.hero__grid{grid-template-columns:1fr auto 1fr;gap:var(--space-3xl);min-height:70vh}}.hero__left{text-align:left;order:1}@media(min-width:900px){.hero__left{order:1}}.hero__badge{font-size:.9375rem;font-weight:400;color:var(--hero-text-muted);margin-bottom:var(--space-sm);text-transform:none;letter-spacing:0;background:none;padding:0;border:none;border-radius:0}.hero__title{margin-bottom:var(--space-md);line-height:1.1;display:flex;flex-direction:column;gap:.05em}.hero__name{display:block;font-size:clamp(2.5rem,6vw,4rem);font-weight:700;color:var(--hero-lime);letter-spacing:-.02em}.hero__role{display:block;font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;color:var(--hero-text);letter-spacing:-.01em}.hero__subtitle{font-size:1rem;color:var(--hero-text-muted);margin-bottom:var(--space-xl);line-height:1.65;max-width:28rem}.hero__actions{display:flex;flex-wrap:wrap;gap:var(--space-lg);align-items:center}.hero__btn{display:inline-flex;align-items:center;gap:var(--space-sm);font-weight:600;font-size:.9375rem;padding:var(--space-md) var(--space-xl);border-radius:var(--radius-md);transition:background var(--transition-base),color var(--transition-base),transform var(--transition-fast),opacity var(--transition-fast)}.hero__btn-arrow{font-size:1em;transition:transform var(--transition-fast)}.hero__btn:hover .hero__btn-arrow{transform:translate(4px)}.hero__btn--primary{background:var(--hero-lime);color:#111;border:none}.hero__btn--primary:hover{background:#b8ff4d;color:#111;transform:translateY(-2px)}.hero__btn--secondary{background:transparent;color:var(--hero-text);border:none;padding-left:0;padding-right:0}.hero__btn--secondary:hover{color:var(--hero-lime);opacity:.95}.hero__center{order:0;display:flex;justify-content:center;align-items:center}@media(min-width:900px){.hero__center{order:2}}.hero__image-wrap{position:relative;width:min(320px,85vw);aspect-ratio:5 / 6}.hero__image-blob{position:absolute;inset:-8%;background:var(--hero-lime);border-radius:55% 45% 50% 50%/45% 55%;opacity:.35;z-index:0}.hero__image-circle{position:relative;z-index:1;width:100%;height:100%;border-radius:50%;overflow:hidden;border:3px solid rgba(255,255,255,.06);box-shadow:0 24px 48px #0006}.hero__image{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}.hero__right{order:2;display:flex;justify-content:flex-start}@media(min-width:900px){.hero__right{order:3;justify-content:flex-end}}.hero__stats{display:flex;flex-direction:column;gap:0;padding:var(--space-lg) 0;border-left:1px solid rgba(255,255,255,.08);padding-left:var(--space-xl)}@media(min-width:900px){.hero__stats{min-width:200px}}.hero__stat{padding:var(--space-md) 0;border-bottom:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;gap:var(--space-xs)}.hero__stat:last-child{border-bottom:none}.hero__stat-value{font-size:clamp(1.75rem,3vw,2.25rem);font-weight:700;color:var(--hero-text);letter-spacing:-.02em;line-height:1.2}.hero__stat-label{font-size:.8125rem;color:var(--hero-text-muted);font-weight:400}.hero__animate{opacity:0;animation:hero-fade-in-up .75s var(--ease-out) forwards}.hero__animate--d1{animation-delay:.08s}.hero__animate--d2{animation-delay:.22s}.hero__animate--d3{animation-delay:.38s}@keyframes hero-fade-in-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.hero__animate{animation:none;opacity:1}.hero__bg-blob{transition:none}}.hero__scroll{position:absolute;bottom:var(--space-xl);left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);z-index:1}.hero__scroll-dot{width:5px;height:5px;border-radius:50%;background:var(--hero-text-muted);animation:hero-scroll 2.2s ease-in-out infinite}@keyframes hero-scroll{0%,to{opacity:.4;transform:translateY(0) scale(1)}50%{opacity:1;transform:translateY(8px) scale(1.2)}}.about{--about-bg: #0a0a0a;--about-lime: #A8FF35;--about-text: #f4f4f5;--about-text-muted: #a1a1aa;--about-card-bg: #161616;padding-block:var(--section-padding-y);background:var(--about-bg)}.about__inner{width:100%}.about__grid{display:grid;gap:var(--space-3xl);align-items:start}@media(min-width:900px){.about__grid{grid-template-columns:1fr 1fr;gap:var(--space-4xl);align-items:center}}.about__content{min-width:0}.about__label{display:block;font-size:.875rem;color:var(--about-text-muted);margin-bottom:var(--space-sm)}.about__title{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;color:var(--about-text);line-height:1.25;margin-bottom:var(--space-lg);letter-spacing:-.02em}.about__title-accent{color:var(--about-lime)}.about__lead{font-size:1.0625rem;color:var(--about-text-muted);margin-bottom:var(--space-md);line-height:1.65}.about__text{font-size:1rem;color:var(--about-text-muted);margin-bottom:var(--space-xl);line-height:1.7}.about__services{list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-sm) var(--space-xl);margin-bottom:var(--space-2xl)}.about__services li{display:flex;align-items:center;gap:var(--space-sm);font-size:.9375rem;font-weight:500;color:var(--about-text)}.about__check{display:inline-flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;flex-shrink:0;color:var(--about-lime);font-size:.75rem;font-weight:700}.about__contact{display:flex;flex-wrap:wrap;gap:var(--space-lg)}.about__contact-box{background:var(--about-card-bg);border-radius:var(--radius-lg);padding:var(--space-lg);min-width:200px;flex:1;border:1px solid rgba(255,255,255,.06)}.about__contact-label{display:block;font-size:.75rem;color:var(--about-text-muted);margin-bottom:var(--space-xs)}.about__contact-value{display:inline-flex;align-items:center;gap:var(--space-sm);font-size:1rem;font-weight:500;color:var(--about-text);text-decoration:none;transition:color var(--transition-fast)}.about__contact-value:hover{color:var(--about-lime)}.about__contact-icon{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;flex-shrink:0;background:#a8ff3526;color:var(--about-lime);border-radius:var(--radius-md)}.about__contact-icon svg{display:block}.about__visual{position:relative;min-width:0;display:flex;flex-direction:column;align-items:center}.about__image-wrap{position:relative;width:100%;max-width:480px;margin-inline:auto}.about__image{width:100%;height:auto;max-height:700px;display:block;border-radius:var(--radius-lg);object-fit:cover;object-position:center top;box-shadow:0 24px 48px #0006}.about__chip{position:absolute;left:0;display:inline-flex;align-items:center;gap:var(--space-sm);background:#fffffff2;color:#111;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;text-decoration:none;box-shadow:var(--shadow-md);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.about__chip:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.about__chip--1{top:28%;transform:translate(-8%)}.about__chip--2{top:48%;transform:translate(-5%)}@media(min-width:900px){.about__chip--1{transform:translate(-12%)}.about__chip--2{transform:translate(-8%)}}.about__chip-icon,.about__chip-avatar{width:32px;height:32px;flex-shrink:0;border-radius:var(--radius-sm)}.about__chip-icon--abstract{background:linear-gradient(135deg,#ec4899,#8b5cf6,#3b82f6)}.about__chip-avatar{background:var(--about-text-muted);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23666'%3E%3Cpath d='M12 12c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm0 2c-2.67 0-8 1.34-8 4v2h16v-2c0-2.66-5.33-4-8-4z'/%3E%3C/svg%3E");background-size:60%;background-repeat:no-repeat;background-position:center}.about__chip-text{flex:1;min-width:0}.about__chip-arrow{font-size:.75rem;color:var(--about-text-muted);flex-shrink:0}.about__deco{display:flex;gap:var(--space-sm);margin-top:var(--space-lg);justify-content:center}@media(min-width:900px){.about__deco{position:absolute;left:50%;top:50%;margin:0;transform:translate(-50%,-50%);pointer-events:none}}.about__deco-dot{width:8px;height:8px;background:var(--about-lime);transform:rotate(45deg);opacity:.8}.about__loading{color:var(--about-text-muted);text-align:center;padding:var(--space-2xl)}.skills{--skills-bg: #1a1a1a;--skills-lime: #A5F32C;--skills-card-bg: #282828;--skills-text: #f4f4f5;--skills-text-muted: rgba(255, 255, 255, .65);--skills-grid-line: rgba(255, 255, 255, .04);position:relative;padding-block:var(--section-padding-y);background:var(--skills-bg);overflow:hidden}.skills__grid-bg{position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(to right,var(--skills-grid-line) 1px,transparent 1px);background-size:8.333% 100%;background-position:0 0}.skills__inner{position:relative;z-index:1}.skills__header{text-align:center;margin-bottom:var(--space-3xl)}.skills__label{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--skills-text-muted);margin-bottom:var(--space-sm)}.skills__title{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;color:var(--skills-text);line-height:1.25;letter-spacing:-.02em;max-width:18em;margin-inline:auto}.skills__title-accent{color:var(--skills-lime)}.skills__grid{display:grid;grid-template-columns:1fr;gap:var(--space-xl)}@media(min-width:640px){.skills__grid{grid-template-columns:repeat(2,1fr);gap:var(--space-2xl)}}@media(min-width:960px){.skills__grid{grid-template-columns:repeat(2,1fr);gap:var(--space-2xl) var(--space-3xl)}}.skills__card{position:relative;background:var(--skills-card-bg);border-radius:var(--radius-lg);padding:var(--space-xl);border:1px solid rgba(255,255,255,.06);transition:border-color var(--transition-base),transform var(--transition-base),box-shadow var(--transition-base)}.skills__card:hover{border-color:#ffffff1a;box-shadow:0 8px 32px #0000004d;transform:translateY(-2px)}.skills__card-arrow{position:absolute;top:var(--space-lg);right:var(--space-lg);width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#0006;color:var(--skills-text);border-radius:50%;text-decoration:none;font-size:1.125rem;transition:background var(--transition-fast),color var(--transition-fast)}.skills__card-arrow:hover{background:var(--skills-lime);color:#111}.skills__card-num{display:block;font-size:1.125rem;font-weight:600;color:var(--skills-text);margin-bottom:var(--space-xs)}.skills__card-title{font-size:1.25rem;font-weight:700;color:var(--skills-text);margin-bottom:var(--space-sm);letter-spacing:-.01em;padding-right:3rem}.skills__card-desc{font-size:.9375rem;color:var(--skills-text-muted);line-height:1.55;margin:0}.projects{--projects-bg: #1a1a1a;--projects-lime: #A5F32C;--projects-text: #f4f4f5;--projects-text-muted: rgba(255, 255, 255, .65);--projects-card-bg: #e8e4df;padding-block:var(--section-padding-y);background:var(--projects-bg)}.projects__header{text-align:center;margin-bottom:var(--space-3xl)}.projects__label{display:block;font-size:.875rem;color:var(--projects-text-muted);margin-bottom:var(--space-sm)}.projects__title{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;color:var(--projects-text);line-height:1.25;letter-spacing:-.02em}.projects__title-accent{color:var(--projects-lime)}.projects__error{color:#ef4444;margin-bottom:var(--space-lg)}.projects__loading,.projects__empty{color:var(--projects-text-muted);margin-bottom:var(--space-2xl)}.projects__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-4xl)}.project-row{display:grid;grid-template-columns:1fr;gap:var(--space-xl);align-items:center}@media(min-width:900px){.project-row{grid-template-columns:1fr 1fr;gap:var(--space-3xl)}.project-row--image-first .project-row__media{order:1}.project-row--image-first .project-row__content,.project-row--text-first .project-row__media{order:2}.project-row--text-first .project-row__content{order:1}}.project-row__media{min-width:0}.project-row__media-inner{background:var(--projects-card-bg);border-radius:var(--radius-lg);padding:var(--space-xl);aspect-ratio:4 / 3;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;box-shadow:0 8px 32px #0003}.project-row__img{width:auto;height:auto;object-fit:cover;border-radius:var(--radius-md);display:block}.project-row__placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#0000000a;border-radius:var(--radius-md)}.project-row__placeholder-icon{font-size:3rem;color:var(--projects-text-muted);opacity:.4}.project-row__content{min-width:0}.project-row__category{display:inline-block;font-size:.8125rem;font-weight:600;color:var(--projects-lime);margin-bottom:var(--space-sm);text-transform:uppercase;letter-spacing:.05em}.project-row__title{font-size:clamp(1.5rem,3vw,2rem);font-weight:700;color:var(--projects-text);margin-bottom:var(--space-md);line-height:1.2;letter-spacing:-.02em}.project-row__desc{font-size:1rem;color:var(--projects-text-muted);line-height:1.65;margin-bottom:var(--space-xl)}.project-row__btn{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;background:#111;color:var(--projects-text);border-radius:50%;text-decoration:none;font-size:1.25rem;transition:background var(--transition-fast),color var(--transition-fast),transform var(--transition-fast)}.project-row__btn:hover{background:var(--projects-lime);color:#111;transform:scale(1.05)}.contact{--contact-bg: #1a1a1a;--contact-lime: #A5F32C;--contact-text: #f4f4f5;--contact-text-muted: rgba(255, 255, 255, .65);--contact-input-bg: #2a2a2a;--contact-input-border: rgba(255, 255, 255, .1);padding-block:var(--section-padding-y);background:var(--contact-bg);position:relative;overflow:hidden}.contact:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:40px 40px;pointer-events:none}.contact__inner{position:relative;z-index:1}.contact__grid{display:grid;grid-template-columns:1fr;gap:var(--space-3xl);align-items:start}@media(min-width:900px){.contact__grid{grid-template-columns:1fr 1fr;gap:var(--space-4xl)}}.contact__left{min-width:0}.contact__label{display:block;font-size:.875rem;color:var(--contact-text-muted);margin-bottom:var(--space-sm)}.contact__title{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;color:var(--contact-text);line-height:1.25;letter-spacing:-.02em;margin-bottom:var(--space-lg)}.contact__title-accent{color:var(--contact-lime)}.contact__intro{font-size:1rem;color:var(--contact-text-muted);line-height:1.65;margin-bottom:var(--space-2xl)}.contact__highlights{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-md)}.contact__highlight{display:flex;align-items:center;gap:var(--space-md);font-size:1rem;color:var(--contact-text)}.contact__highlight-icon{flex-shrink:0;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;background:#a5f32c26;color:var(--contact-lime);border-radius:var(--radius-sm)}.contact__right{min-width:0}.contact__form{display:flex;flex-direction:column;gap:var(--space-lg)}.contact__field{display:flex;flex-direction:column;gap:var(--space-xs)}.contact__field--full{grid-column:1 / -1}@media(min-width:600px){.contact__form{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg)}.contact__field--full{grid-column:1 / -1}}.contact__field-label{font-size:.9375rem;font-weight:500;color:var(--contact-text)}.contact__input-wrap{position:relative;display:flex;align-items:center}.contact__input{width:100%;padding:var(--space-md) var(--space-xl) var(--space-md) var(--space-md);padding-right:3rem;font-size:1rem;color:var(--contact-text);background:var(--contact-input-bg);border:1px solid var(--contact-input-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);appearance:none}.contact__input::placeholder{color:var(--contact-text-muted)}.contact__input:focus{outline:none;border-color:var(--contact-lime);box-shadow:0 0 0 2px #a5f32c33}.contact__input-icon{position:absolute;right:var(--space-md);top:50%;transform:translateY(-50%);color:var(--contact-text-muted);pointer-events:none;display:flex;align-items:center;justify-content:center}.contact__textarea{width:100%;min-height:140px;padding:var(--space-md);font-size:1rem;font-family:inherit;color:var(--contact-text);background:var(--contact-input-bg);border:1px solid var(--contact-input-border);border-radius:var(--radius-md);resize:vertical;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.contact__textarea::placeholder{color:var(--contact-text-muted)}.contact__textarea:focus{outline:none;border-color:var(--contact-lime);box-shadow:0 0 0 2px #a5f32c33}.contact__form-msg{font-size:.9375rem;margin-top:var(--space-sm);padding:var(--space-md);border-radius:var(--radius-md)}.contact__form-msg--success{color:#059669;background:#05966926}.contact__form-msg--error{color:#dc2626;background:#dc26261a}.contact__submit{margin-top:var(--space-sm);padding:var(--space-md) var(--space-xl);font-size:1rem;font-weight:600;color:#111;background:var(--contact-lime);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.contact__submit:hover:not(:disabled){background:#b8ff3d;transform:translateY(-1px);box-shadow:0 4px 20px #a5f32c59}.contact__submit:disabled{opacity:.8;cursor:not-allowed}.contact__submit:active{transform:translateY(0)}.footer{padding-block:var(--space-xl);background:var(--bg-secondary);border-top:1px solid var(--border-subtle)}.footer__inner{display:flex;flex-direction:column;gap:var(--space-md);align-items:center;text-align:center}@media(min-width:640px){.footer__inner{flex-direction:row;justify-content:space-between;text-align:left}}.footer__copy{font-size:.8125rem;color:var(--text-muted);letter-spacing:.01em}.footer__nav{display:flex;gap:var(--space-lg)}.footer__nav a{font-size:.8125rem;font-weight:500;color:var(--text-secondary);transition:color var(--transition-fast)}.footer__nav a:hover{color:var(--accent)}.project-detail{padding-top:var(--header-height);padding-bottom:var(--space-4xl);min-height:100vh}.project-detail__container{width:100%}.project-detail__content-wrap{max-width:720px;margin-inline:auto;padding-top:var(--space-xl)}.project-detail__not-found,.project-detail__loading{color:var(--text-secondary);margin-bottom:var(--space-lg)}.project-detail__back{display:inline-flex;align-items:center;font-size:.9375rem;font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-2xl);transition:color var(--transition-fast);padding:0;text-align:left}.project-detail__back:hover{color:var(--accent)}.project-detail__header{margin-bottom:var(--space-xl)}.project-detail__year{display:inline-block;font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:var(--space-sm)}.project-detail__title{font-size:clamp(2rem,5vw,2.75rem);margin-bottom:var(--space-md);color:var(--text-primary)}.project-detail__stack{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.project-detail__tech{font-size:.8125rem;font-weight:500;color:var(--accent);background:var(--accent-soft);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-sm);border:1px solid var(--accent-border)}.project-detail__lead{font-size:1.125rem;color:var(--text-secondary);line-height:1.7;margin-bottom:var(--space-2xl)}.project-detail__gallery{margin-bottom:var(--space-3xl)}.project-detail__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-lg)}@media(min-width:768px){.project-detail__grid{grid-template-columns:repeat(3,1fr);gap:var(--space-xl)}}.project-detail__gallery-item{display:block;width:100%;padding:0;margin:0;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-secondary);box-shadow:var(--shadow-xs);transition:box-shadow var(--transition-base),transform var(--transition-base);cursor:pointer;text-align:left}.project-detail__gallery-item:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.project-detail__gallery-img{width:100%;height:auto;display:block;aspect-ratio:4 / 3;object-fit:cover}.project-detail__gallery-item--wide{grid-column:span 2}.project-detail__gallery-item--wide .project-detail__gallery-img{aspect-ratio:16 / 9}.project-detail__body{margin-bottom:var(--space-2xl)}.project-detail__text{font-size:1rem;color:var(--text-secondary);line-height:1.75;margin-bottom:var(--space-2xl)}.project-detail__text p{margin-bottom:var(--space-md)}.project-detail__text p:last-child{margin-bottom:0}.project-detail__links{display:flex;flex-wrap:wrap;gap:var(--space-md)}.project-detail__btn{display:inline-flex;align-items:center;justify-content:center;font-weight:600;font-size:.9375rem;padding:var(--space-md) var(--space-xl);border-radius:var(--radius-md);transition:background var(--transition-base),color var(--transition-base),box-shadow var(--transition-base),transform var(--transition-fast)}.project-detail__btn--primary{background:var(--accent);color:var(--text-on-accent);box-shadow:var(--shadow-sm)}.project-detail__btn--primary:hover{background:var(--accent-hover);color:var(--text-on-accent);box-shadow:var(--shadow-md);transform:translateY(-1px)}.project-detail__btn--secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border)}.project-detail__btn--secondary:hover{border-color:var(--border-focus);color:var(--accent);background:var(--accent-soft)}.project-detail__lightbox{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;background:#000000e6;padding:var(--space-xl);animation:project-detail-lightbox-in .2s var(--ease-out)}@keyframes project-detail-lightbox-in{0%{opacity:0}to{opacity:1}}.project-detail__lightbox-close{position:absolute;top:var(--space-md);right:var(--space-md);z-index:2;width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:2rem;line-height:1;color:#fff;background:#ffffff1a;border:none;border-radius:50%;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.project-detail__lightbox-close:hover{background:#fff3}.project-detail__lightbox-prev,.project-detail__lightbox-next{position:absolute;top:50%;transform:translateY(-50%);z-index:2;width:56px;height:56px;display:flex;align-items:center;justify-content:center;font-size:2.5rem;line-height:1;color:#fff;background:#ffffff1a;border:none;border-radius:50%;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.project-detail__lightbox-prev:hover,.project-detail__lightbox-next:hover{background:#ffffff40}.project-detail__lightbox-prev{left:var(--space-md)}.project-detail__lightbox-next{right:var(--space-md)}.project-detail__lightbox-content{position:relative;max-width:95vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;justify-content:center}.project-detail__lightbox-img{max-width:100%;max-height:calc(90vh - 2.5rem);width:auto;height:auto;object-fit:contain;border-radius:var(--radius-md);box-shadow:0 24px 64px #00000080}.project-detail__lightbox-counter{margin-top:var(--space-md);font-size:.9375rem;color:#fffc}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-xl);background:var(--bg-secondary)}.login__card{width:100%;max-width:400px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-2xl);box-shadow:var(--shadow-lg)}.login__title{font-size:1.75rem;margin-bottom:var(--space-xs);color:var(--text-primary)}.login__subtitle{font-size:.9375rem;color:var(--text-muted);margin-bottom:var(--space-2xl)}.login__form{display:flex;flex-direction:column;gap:var(--space-lg)}.login__error{font-size:.875rem;color:#dc2626;background:#dc262614;padding:var(--space-md);border-radius:var(--radius-md);border:1px solid rgba(220,38,38,.2)}.login__label{display:flex;flex-direction:column;gap:var(--space-xs);font-size:.875rem;font-weight:500;color:var(--text-primary)}.login__input{width:100%;padding:var(--space-md);font-size:1rem;font-family:var(--font-body);color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);transition:border-color var(--transition-fast)}.login__input::placeholder{color:var(--text-muted)}.login__input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.login__btn{margin-top:var(--space-sm);padding:var(--space-md) var(--space-xl);font-size:1rem;font-weight:600;color:var(--text-on-accent);background:var(--accent);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-base),transform var(--transition-fast)}.login__btn:hover:not(:disabled){background:var(--accent-hover)}.login__btn:disabled{opacity:.7;cursor:not-allowed}.login__back{display:inline-block;margin-top:var(--space-xl);font-size:.9375rem;font-weight:500;color:var(--text-secondary);transition:color var(--transition-fast)}.login__back:hover{color:var(--accent)}.hero-form-placeholder{padding:var(--space-xl);text-align:center;color:var(--text-muted)}.dashboard-hero-form{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-xl);margin-bottom:var(--space-2xl);box-shadow:var(--shadow-sm)}.dashboard-hero-form__title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-xs)}.dashboard-hero-form__desc{font-size:.9375rem;color:var(--text-secondary);margin-bottom:var(--space-lg)}.dashboard-hero-form__form{display:flex;flex-direction:column;gap:var(--space-lg)}.dashboard-hero-form__label{display:flex;flex-direction:column;gap:var(--space-xs);font-size:.875rem;font-weight:500;color:var(--text-primary)}.dashboard-hero-form__input{width:100%;padding:var(--space-md);font-size:1rem;font-family:var(--font-body);color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);transition:border-color var(--transition-fast)}.dashboard-hero-form__input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.dashboard-hero-form__msg{font-size:.9375rem;padding:var(--space-md);border-radius:var(--radius-md)}.dashboard-hero-form__msg--success{color:#059669;background:#0596691a}.dashboard-hero-form__msg--error{color:#dc2626;background:#dc262614}.dashboard-hero-form__btn{align-self:flex-start;padding:var(--space-md) var(--space-xl);font-size:.9375rem;font-weight:600;color:var(--text-on-accent);background:var(--accent);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-base)}.dashboard-hero-form__btn:hover:not(:disabled){background:var(--accent-hover)}.dashboard-hero-form__btn:disabled{opacity:.7;cursor:not-allowed}.dashboard-hero-form__btn--secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border)}.dashboard-hero-form__btn--secondary:hover:not(:disabled){background:var(--border)}.dashboard-hero-form__btn--danger{background:#dc2626;color:#fff}.dashboard-hero-form__btn--danger:hover:not(:disabled){background:#b91c1c}.dashboard-hero-form__btn--small{padding:var(--space-xs) var(--space-md);font-size:.8125rem}.dashboard-hero-form__hint{font-size:.8125rem;color:var(--text-muted);margin-bottom:var(--space-sm)}.dashboard-hero-form__stat-row{display:flex;gap:var(--space-sm);align-items:center;margin-bottom:var(--space-sm)}.dashboard-hero-form__stat-row .dashboard-hero-form__input{flex:1}.dashboard-hero-form__input--short{max-width:6rem;flex:0 0 auto}.dashboard-hero-form__image-upload{display:flex;align-items:center;gap:var(--space-md);margin-top:var(--space-sm)}.dashboard-hero-form__image-upload-or{font-size:.875rem;color:var(--text-muted)}.dashboard-hero-form__image-upload .dashboard-hero-form__file{font-size:.875rem;color:var(--text-primary)}.dashboard-hero-form__subtitle{font-size:1.0625rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-sm)}.dashboard-hero-form__actions{display:flex;gap:var(--space-md);flex-wrap:wrap}.dashboard-projects-list{list-style:none;margin-bottom:var(--space-xl);padding:0}.dashboard-projects-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-md) 0;border-bottom:1px solid var(--border)}.dashboard-projects-item__title{font-weight:500;color:var(--text-primary)}.dashboard-projects-item__actions{display:flex;gap:var(--space-sm)}.dashboard-projects-empty{color:var(--text-secondary);margin-bottom:var(--space-lg)}.dashboard-projects-form{margin-top:var(--space-xl);padding-top:var(--space-xl);border-top:1px solid var(--border)}.dashboard-projects-images{display:flex;flex-direction:column;gap:var(--space-sm)}.dashboard-projects-images-upload{display:flex;align-items:center;gap:var(--space-md)}.dashboard-hero-form__file{font-size:.875rem;color:var(--text-primary)}.dashboard-projects-images-hint,.dashboard-projects-images-status{font-size:.875rem;color:var(--text-secondary)}.dashboard-projects-images-status{font-style:italic}.dashboard-projects-images-or{font-size:.8125rem;color:var(--text-muted)}.dashboard-header{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--header-height);background:var(--bg-card);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm)}.dashboard-header__inner{max-width:1280px;margin:0 auto;padding:0 var(--section-padding-x);height:100%;display:flex;align-items:center;justify-content:space-between}.dashboard-header__logo{font-family:var(--font-heading);font-weight:700;font-size:1.25rem;color:var(--text-primary);text-decoration:none;transition:color var(--transition-fast)}.dashboard-header__logo:hover{color:var(--accent)}.dashboard-header__user{display:flex;align-items:center;gap:var(--space-lg)}.dashboard-header__email{font-size:.875rem;color:var(--text-muted);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dashboard-header__logout{font-size:.875rem;font-weight:500;color:var(--text-secondary);background:none;border:1px solid var(--border);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-md);cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast),background var(--transition-fast)}.dashboard-header__logout:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}.dashboard-sidebar{width:260px;flex-shrink:0;background:var(--bg-card);border-right:1px solid var(--border);padding:var(--space-lg) 0}.dashboard-sidebar__nav{padding:0 var(--space-md)}.dashboard-sidebar__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-xs)}.dashboard-sidebar__item{margin:0}.dashboard-sidebar__link{display:flex;align-items:center;gap:var(--space-md);width:100%;padding:var(--space-md) var(--space-lg);font-size:.9375rem;font-weight:500;color:var(--text-secondary);background:none;border:none;border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:color var(--transition-fast),background var(--transition-fast)}.dashboard-sidebar__link:hover{color:var(--text-primary);background:var(--bg-secondary)}.dashboard-sidebar__link--active{color:var(--accent);background:var(--accent-soft)}.dashboard-sidebar__link--active:hover{color:var(--accent-hover);background:var(--accent-soft)}.dashboard-sidebar__icon{font-size:1.25rem;line-height:1;opacity:.9}.dashboard-sidebar__label{flex:1}@media(max-width:839px){.dashboard-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border);padding:var(--space-md) 0}.dashboard-sidebar__list{flex-direction:row;flex-wrap:wrap;justify-content:flex-start;gap:var(--space-sm)}.dashboard-sidebar__link{padding:var(--space-sm) var(--space-md)}.dashboard-sidebar__label{white-space:nowrap}}.dashboard-layout{display:flex;flex-direction:row;min-height:calc(100vh - var(--header-height));padding-top:var(--header-height);background:var(--bg-primary)}@media(max-width:839px){.dashboard-layout{flex-direction:column}}.dashboard{flex:1;min-width:0;padding-bottom:var(--space-4xl)}.dashboard__inner{max-width:900px;margin:0;padding:var(--space-2xl) var(--section-padding-x)}.dashboard__hero{margin-bottom:var(--space-3xl)}.dashboard__title{font-size:clamp(1.75rem,4vw,2.25rem);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-sm);letter-spacing:-.02em}.dashboard__welcome{font-size:1.125rem;color:var(--text-secondary)}.dashboard__welcome strong{color:var(--accent)}.dashboard__grid{display:grid;grid-template-columns:repeat(1,1fr);gap:var(--space-xl);margin-bottom:var(--space-3xl)}@media(min-width:640px){.dashboard__grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:960px){.dashboard__grid{grid-template-columns:repeat(3,1fr)}}.dashboard-card{position:relative;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:var(--shadow-sm);transition:border-color var(--transition-base),box-shadow var(--transition-base),transform var(--transition-base)}.dashboard-card:hover{border-color:var(--border-focus);box-shadow:var(--shadow-md);transform:translateY(-2px)}.dashboard-card__icon{font-size:2rem;margin-bottom:var(--space-md);line-height:1}.dashboard-card__title{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-xs)}.dashboard-card__desc{font-size:.9375rem;color:var(--text-secondary);line-height:1.5;margin-bottom:var(--space-md)}.dashboard-card__badge{display:inline-block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg-secondary);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm)}.dashboard__panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-xl);margin-bottom:var(--space-2xl);box-shadow:var(--shadow-sm)}.dashboard__panel-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-sm)}.dashboard__panel-desc{font-size:.9375rem;color:var(--text-secondary);margin-bottom:var(--space-md)}.dashboard__info{max-width:400px}.dashboard__info-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-xs)}.dashboard__info-title{font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:var(--space-md)}.dashboard__info-list{display:grid;gap:var(--space-sm);margin:0}.dashboard__info-list dt{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.dashboard__info-list dd{font-size:.9375rem;color:var(--text-primary);margin:0}.dashboard-messages-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-lg)}.dashboard-messages-item{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg)}.dashboard-messages-item__meta{display:flex;flex-wrap:wrap;align-items:baseline;gap:var(--space-sm);margin-bottom:var(--space-sm)}.dashboard-messages-item__name{font-size:1rem;color:var(--text-primary)}.dashboard-messages-item__date{font-size:.8125rem;color:var(--text-muted)}.dashboard-messages-item__row{display:flex;flex-wrap:wrap;gap:var(--space-md);margin-bottom:var(--space-sm)}.dashboard-messages-item__email{font-size:.9375rem;color:var(--accent)}.dashboard-messages-item__email:hover{color:var(--accent-hover)}.dashboard-messages-item__phone{font-size:.9375rem;color:var(--text-secondary)}.dashboard-messages-item__subject{font-size:.875rem;color:var(--text-secondary);margin-bottom:var(--space-sm)}.dashboard-messages-item__subject em{font-style:normal;color:var(--text-muted)}.dashboard-messages-item__message{font-size:.9375rem;color:var(--text-primary);line-height:1.6;margin:0;white-space:pre-wrap}
