*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#0a0a0a;color:#fff;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;margin:0}code{font-family:JetBrains Mono,source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--primary-bg:#0a0a0a;--secondary-bg:#111;--card-bg:#1a1a1a;--accent-color:#6366f1;--accent-hover:#818cf8;--text-primary:#fff;--text-secondary:#a1a1aa;--text-muted:#71717a;--border-color:#27272a;--success-color:#10b981;--warning-color:#f59e0b;--error-color:#ef4444;--font-family-primary:"Inter",sans-serif;--font-family-mono:"JetBrains Mono",monospace;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--spacing-3xl:4rem;--radius-sm:0.375rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--radius-2xl:1.5rem;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a}.container{margin:0 auto;max-width:1200px;padding:0 1rem}@media (min-width:640px){.container{padding:0 2rem}}@media (min-width:1024px){.container{padding:0 3rem}}.section{padding:3rem 0}@media (min-width:768px){.section{padding:4.5rem 0}}.btn{align-items:center;border:none;border-radius:.75rem;border-radius:var(--radius-lg);cursor:pointer;display:inline-flex;font-family:Inter,sans-serif;font-family:var(--font-family-primary);font-size:.875rem;font-weight:500;justify-content:center;outline:none;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s ease-in-out}.btn-primary{background:linear-gradient(135deg,#6366f1,#818cf8);background:linear-gradient(135deg,var(--accent-color),var(--accent-hover));color:#fff;color:var(--text-primary)}.btn-primary:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-secondary{background:#0000;border:2px solid #6366f1;border:2px solid var(--accent-color);color:#fff;color:var(--text-primary)}.btn-secondary:hover{background:#6366f1;background:var(--accent-color);transform:translateY(-2px)}.btn-ghost{background:#0000;border:2px solid #27272a;border:2px solid var(--border-color);color:#a1a1aa;color:var(--text-secondary)}.btn-ghost:hover{border-color:#6366f1;border-color:var(--accent-color);color:#fff;color:var(--text-primary)}.text-gradient{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#6366f1,#818cf8);background:linear-gradient(135deg,var(--accent-color),var(--accent-hover));-webkit-background-clip:text;background-clip:text}.section-title{font-size:2.5rem;font-weight:800;margin-bottom:1rem;text-align:center}@media (min-width:768px){.section-title{font-size:3rem}}.section-subtitle{color:#a1a1aa;color:var(--text-secondary);font-size:1.125rem;margin:0 auto 3rem;max-width:600px;text-align:center}.grid{grid-gap:1.5rem;display:grid;gap:1.5rem}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}@media (min-width:640px){.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:768px){.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width:1024px){.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.card{background:#1a1a1a;background:var(--card-bg);border:1px solid #27272a;border:1px solid var(--border-color);border-radius:1rem;border-radius:var(--radius-xl);padding:1.5rem;transition:all .3s ease}.card:hover{border-color:#6366f1;border-color:var(--accent-color);box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;box-shadow:var(--shadow-xl);transform:translateY(-4px)}.fade-in{animation:fadeIn .6s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.slide-in-left{animation:slideInLeft .6s ease-out}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}.slide-in-right{animation:slideInRight .6s ease-out}@keyframes slideInRight{0%{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#111;background:var(--secondary-bg)}::-webkit-scrollbar-thumb{background:#6366f1;background:var(--accent-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#818cf8;background:var(--accent-hover)}:focus{outline:2px solid #6366f1;outline:2px solid var(--accent-color);outline-offset:2px}::selection{background:#6366f1;background:var(--accent-color);color:#fff;color:var(--text-primary)}::-moz-selection{background:#6366f1;background:var(--accent-color);color:#fff;color:var(--text-primary)}.hidden{display:none}@media (min-width:768px){.md\\:block{display:block}.md\\:hidden{display:none}}@media (min-width:1024px){.lg\\:block{display:block}.lg\\:hidden{display:none}}.App{background:var(--primary-bg);min-height:100vh}main{position:relative}.App:before{background:radial-gradient(circle at 20% 50%,#6366f11a 0,#0000 50%),radial-gradient(circle at 80% 20%,#6366f11a 0,#0000 50%),radial-gradient(circle at 40% 80%,#6366f10d 0,#0000 50%);content:"";height:100%;left:0;pointer-events:none;position:fixed;top:0;width:100%;z-index:-1}@media (max-width:640px){.App{overflow-x:hidden}}.page-enter{opacity:0;transform:translateY(20px)}.page-enter-active{transition:opacity .3s,transform .3s}.page-enter-active,.page-exit{opacity:1;transform:translateY(0)}.page-exit-active{opacity:0;transform:translateY(-20px);transition:opacity .3s,transform .3s}.header{left:0;position:fixed;right:0;top:0;transition:background .3s ease,border-color .3s ease,box-shadow .3s ease;z-index:1000}.header--scrolled{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#0a0a0ad9;border-bottom:1px solid #ffffff12;box-shadow:0 1px 0 #ffffff0a}.header__container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1100px;padding:1rem 2rem}.header__logo{-webkit-tap-highlight-color:transparent;cursor:pointer;outline:none;-webkit-user-select:none;user-select:none}.header__logo-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fff,#6366f1d9);-webkit-background-clip:text;background-clip:text;font-family:var(--font-family-mono);font-size:1.15rem;font-weight:800;letter-spacing:-.03em;transition:opacity .2s ease}.header__logo:hover .header__logo-text{opacity:.8}.header__nav{display:none}.header__nav-pill{align-items:center;background:#ffffff0a;border:1px solid #ffffff14;border-radius:999px;display:flex;gap:.15rem;padding:.3rem .4rem}.header__nav-link{background:none;border:none;border-radius:999px;color:var(--text-secondary);cursor:pointer;font-family:var(--font-family-primary);font-size:.875rem;font-weight:500;padding:.4rem .9rem;transition:color .2s ease,background .2s ease;white-space:nowrap}.header__nav-link:hover{background:#ffffff12;color:var(--text-primary)}.header__nav-link:focus{background:#6366f11f;color:var(--text-primary);outline:none}.header__actions{align-items:center;display:flex}.header__mobile-toggle{background:#0000;border:none;cursor:pointer;display:flex;flex-direction:column;height:1.5rem;justify-content:space-around;padding:0;position:relative;width:1.5rem;z-index:10}.header__mobile-toggle span{background:var(--text-primary);height:2px;transform-origin:center;transition:all .3s ease;width:100%}.header__mobile-toggle--active span:first-child{transform:rotate(45deg) translate(3px,3px)}.header__mobile-toggle--active span:nth-child(2){opacity:0}.header__mobile-toggle--active span:nth-child(3){transform:rotate(-45deg) translate(3px,-3px)}.header__mobile-menu{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#0c0c0cf7;border-bottom:1px solid #ffffff12;left:0;overflow:hidden;position:absolute;right:0;top:100%}.header__mobile-nav{padding:1rem 2rem 1.5rem}.header__mobile-nav-list{list-style:none;margin:0;padding:0}.header__mobile-nav-item{margin-bottom:.25rem}.header__mobile-nav-link{background:none;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:block;font-family:var(--font-family-primary);font-size:1rem;font-weight:500;padding:.65rem .75rem;text-align:left;transition:color .2s ease,background .2s ease;width:100%}.header__mobile-nav-link:hover{background:#ffffff0d;color:var(--text-primary)}.header__mobile-nav-link:focus,.header__mobile-toggle:focus{outline:2px solid var(--accent-color);outline-offset:2px}@media (min-width:768px){.header__nav{display:block}.header__mobile-menu,.header__mobile-toggle{display:none}}@media (min-width:1024px){.header__nav-link{font-size:.9rem;padding:.45rem 1rem}}.hero{align-items:center;display:flex;justify-content:center;overflow:hidden;padding:8rem 0 4rem;position:relative}.hero__container{margin:0 auto;max-width:680px;padding:0 2rem;position:relative;width:100%;z-index:2}.hero__content{align-items:center;display:flex;flex-direction:column;gap:1.25rem;text-align:center}.hero__badge{align-items:center;background:#6366f114;border:1px solid #6366f140;border-radius:999px;color:var(--accent-color);display:inline-flex;font-family:var(--font-family-mono);font-size:.75rem;font-weight:600;gap:.5rem;letter-spacing:.05em;padding:.3rem .9rem}.hero__badge-dot{animation:pulse-dot 2s infinite;background:var(--accent-color);border-radius:50%;flex-shrink:0;height:7px;width:7px}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.75)}}.hero__title{color:var(--text-primary);font-size:2.75rem;font-weight:800;line-height:1.1;margin:0}.hero__role{font-family:var(--font-family-mono);font-size:1rem}.hero__description,.hero__role{color:var(--text-secondary);margin:0}.hero__description{font-size:1.05rem;line-height:1.6;max-width:520px}.hero__cards{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-top:.5rem;width:100%}.hero__card{background:var(--card-bg);border:1px solid #6366f166;border-radius:var(--radius-xl);cursor:pointer;display:flex;flex-direction:column;gap:.4rem;padding:1.5rem 1.25rem;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}.hero__card:hover{border-color:var(--accent-color);box-shadow:0 8px 24px #6366f133}.hero__card-title{color:var(--text-primary);font-size:1rem;font-weight:700}.hero__card-sub{color:var(--text-muted);font-family:var(--font-family-mono);font-size:.8rem}.hero__background{inset:0;overflow:hidden;pointer-events:none;position:absolute;z-index:1}.hero__bg-element{background:linear-gradient(135deg,#6366f114,#818cf814);border-radius:50%;filter:blur(50px);position:absolute}.hero__bg-element--1{height:350px;right:5%;top:10%;width:350px}.hero__bg-element--2{bottom:10%;height:250px;left:5%;width:250px}@media (max-width:400px){.hero__cards{grid-template-columns:1fr}}@media (min-width:480px){.hero__title{font-size:3.25rem}}@media (min-width:768px){.hero__title{font-size:3.75rem}.hero__description{font-size:1.1rem}}@media (prefers-reduced-motion:reduce){.hero__badge-dot,.hero__bg-element,.hero__card--games,.hero__card--projects{animation:none}}.story-journey{position:relative}.story-journey__header{margin-bottom:2rem;text-align:center}.story-journey__eyebrow{background:#6366f11a;border:1px solid #6366f140;border-radius:999px;color:var(--accent-color);display:inline-block;font-family:var(--font-family-mono);font-size:.8rem;font-weight:600;letter-spacing:.15em;margin-bottom:1.25rem;padding:.3rem .9rem;text-transform:uppercase}.story-journey__spine{margin:0 auto;max-width:900px;position:relative}.story-chapter{grid-gap:0 1.5rem;display:grid;gap:0 1.5rem;grid-template-columns:56px 1fr;margin-bottom:1rem}.story-chapter:last-child{margin-bottom:0}.story-chapter__marker{flex-direction:column}.story-chapter__badge,.story-chapter__marker{align-items:center;display:flex;flex-shrink:0}.story-chapter__badge{background:var(--card-bg);border:2px solid;border-radius:50%;cursor:pointer;height:48px;justify-content:center;width:48px;z-index:2}.story-chapter__roman{font-family:Georgia,Times New Roman,serif;font-size:1rem;font-weight:700;line-height:1}.story-chapter__spine-line{border-radius:1px;flex:1 1;margin-top:.5rem;min-height:2rem;width:2px}.story-chapter__body{padding-bottom:2.5rem}.story-chapter:last-child .story-chapter__body{padding-bottom:0}.story-chapter__header{background:var(--card-bg);border:1px solid var(--border-color);border-left:3px solid;border-radius:var(--radius-xl);cursor:pointer;padding:1.5rem 1.75rem 1.5rem 1.5rem;position:relative;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;-webkit-user-select:none;user-select:none}.story-chapter__header:hover{box-shadow:0 10px 32px #00000040;transform:translateY(-2px)}.story-chapter__meta{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.story-chapter__eyebrow{font-family:var(--font-family-mono);font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.story-chapter__icon{font-size:1.4rem}.story-chapter__title{font-size:1.4rem;font-weight:800;line-height:1.2;margin:0 0 .35rem}.story-chapter__company-row{align-items:center;display:flex;flex-wrap:wrap;font-size:.9rem;gap:.4rem}.story-chapter__divider{color:var(--text-muted)}.story-chapter__position{color:var(--text-secondary);font-weight:500}.story-chapter__location{color:var(--text-muted);font-size:.85rem}.story-chapter__chapter-name{color:var(--text-muted);font-family:var(--font-family-mono);font-size:.82rem;font-style:italic}.story-chapter__expand-btn{align-items:center;border:1px solid;border-radius:50%;display:flex;font-size:1rem;font-weight:700;height:28px;justify-content:center;opacity:.7;position:absolute;right:1.25rem;top:50%;transform:translateY(-50%);transition:opacity .2s ease,transform .3s ease;width:28px}.story-chapter__header:hover .story-chapter__expand-btn{opacity:1}.story-chapter__narrative{border-bottom:1px solid var(--border-color);padding-bottom:.5rem}.story-chapter__narrative p{color:var(--text-secondary);font-size:.95rem;font-style:italic;line-height:1.8;margin:0}.story-chapter__details-inner{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-xl);display:flex;flex-direction:column;gap:1.5rem;margin-bottom:.75rem;padding:1.5rem 1.75rem}.story-chapter__section-label{color:var(--text-muted);font-size:.8rem;font-weight:700;letter-spacing:.1em;margin-bottom:.75rem;text-transform:uppercase}.story-chapter__list{display:flex;flex-direction:column;gap:.6rem;list-style:none;margin:0;padding:0}.story-chapter__list li{color:var(--text-secondary);font-size:.9rem;line-height:1.6;padding-left:1.25rem;position:relative}.story-chapter__list li:before{color:var(--accent-color);content:"▸";font-size:.75rem;left:0;position:absolute;top:.2em}.story-chapter__tech-tags{display:flex;flex-wrap:wrap;gap:.5rem}.story-chapter__tag{border:1px solid;border-radius:999px;cursor:default;font-size:.78rem;font-weight:600;padding:.3rem .75rem;transition:all .15s ease}.story-chapter__gained{background:#6366f10d;border-radius:var(--radius-lg);padding:.9rem 1.1rem}.story-chapter__gained p{color:var(--text-secondary);font-size:.9rem;line-height:1.7;margin:0}.story-chapter__gained-label{font-style:normal;font-weight:700}.story-chapter__transition{align-items:flex-start;display:flex;gap:.75rem;padding:.75rem 0 0 .25rem}.story-chapter__transition-arrow{color:var(--text-muted);flex-shrink:0;font-size:1.1rem;margin-top:.1em}.story-chapter__transition em{color:var(--text-muted);font-size:.875rem;line-height:1.6}@media (max-width:640px){.story-chapter{gap:0 1rem;grid-template-columns:40px 1fr}.story-chapter__badge{height:38px;width:38px}.story-chapter__roman{font-size:.875rem}.story-chapter__header{padding:1.25rem}.story-chapter__title{font-size:1.2rem;padding-right:1.5rem}.story-chapter__expand-btn{right:1rem}.story-chapter__details-inner{padding:1.25rem}}@media (min-width:768px){.story-chapter__title{font-size:1.6rem}.story-chapter__narrative p{font-size:1rem}.story-chapter__header{padding:1.75rem 2rem}.story-chapter__expand-btn{right:2rem}}@media (prefers-reduced-motion:reduce){.story-chapter__header{transition:none}}.skills{background:var(--secondary-bg)}.skills__eyebrow{background:#6366f11a;border:1px solid #6366f140;border-radius:999px;color:var(--accent-color);display:inline-block;font-family:var(--font-family-mono);font-size:.78rem;font-weight:600;letter-spacing:.15em;margin-bottom:1.25rem;padding:.3rem .9rem;text-transform:uppercase}.skills__primary{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr);margin-bottom:2rem}.skills__primary-card{align-items:center;border:1px solid;border-radius:var(--radius-xl);cursor:default;display:flex;flex-direction:column;gap:.4rem;padding:1.25rem 1rem;transition:transform .2s ease,box-shadow .2s ease}.skills__primary-card:hover{box-shadow:0 8px 30px #0003}.skills__primary-icon{font-size:1.8rem;line-height:1}.skills__primary-name{font-size:1rem;font-weight:700;text-align:center}.skills__primary-desc{color:var(--text-muted);font-family:var(--font-family-mono);font-size:.72rem;letter-spacing:.04em}.skills__secondary{margin-bottom:2.5rem}.skills__secondary-label{color:var(--text-muted);font-family:var(--font-family-mono);font-size:.78rem;font-weight:600;letter-spacing:.12em;margin-bottom:.875rem;text-transform:uppercase}.skills__tags{display:flex;flex-wrap:wrap;gap:.5rem}.skills__tag{background:var(--card-bg);border:1px solid var(--border-color);border-radius:999px;color:var(--text-secondary);cursor:default;font-size:.8rem;font-weight:500;padding:.35rem .8rem;transition:all .15s ease}.skills__contact{border-top:1px solid var(--border-color);padding-top:2.5rem;text-align:center}.skills__contact-headline{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin-bottom:1.5rem}.skills__contact-links{align-items:center;display:flex;flex-direction:column;gap:.75rem}.skills__contact-link{align-items:center;background:var(--card-bg);border:1px solid var(--border-color);border-radius:999px;display:inline-flex;gap:.6rem;padding:.6rem 1.4rem;text-decoration:none;transition:border-color .2s ease,box-shadow .2s ease}.skills__contact-link:hover{border-color:var(--accent-color);box-shadow:0 4px 20px #6366f133}.skills__contact-icon{font-size:1rem}.skills__contact-display{color:var(--text-secondary);font-family:var(--font-family-mono);font-size:.875rem}@media (min-width:480px){.skills__contact-links{flex-direction:row;justify-content:center}}@media (min-width:640px){.skills__primary{grid-template-columns:repeat(4,1fr)}}@media (min-width:768px){.skills__primary-card{padding:1.5rem 1.25rem}.skills__primary-icon{font-size:2.2rem}.skills__primary-name{font-size:1.05rem}.skills__contact-headline{font-size:1.5rem}}.tic-tac-toe{align-items:center;display:flex;flex-direction:column;margin:0 auto;max-width:400px;width:100%}.tic-tac-toe__scoreboard{display:flex;gap:3rem;justify-content:center;margin-bottom:2rem}.tic-tac-toe__score{text-align:center}.tic-tac-toe__score-label{display:block;font-size:1rem;font-weight:600;margin-bottom:.5rem}.tic-tac-toe__score-label--x{color:#6366f1}.tic-tac-toe__score-label--o{color:#8b5cf6}.tic-tac-toe__score-value{color:var(--text-primary);font-family:var(--font-family-mono);font-size:2rem;font-weight:800;margin:0}.tic-tac-toe__status{margin-bottom:2rem;text-align:center}.tic-tac-toe__status-text{color:var(--text-primary);font-size:1.2rem;font-weight:500;margin:0}.tic-tac-toe__current,.tic-tac-toe__winner{font-weight:800}.tic-tac-toe__current--x,.tic-tac-toe__winner--x{color:#6366f1}.tic-tac-toe__current--o,.tic-tac-toe__winner--o{color:#8b5cf6}.tic-tac-toe__board{grid-gap:.5rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-xl);display:grid;gap:.5rem;grid-template-columns:repeat(3,1fr);margin-bottom:2rem;padding:1rem}.tic-tac-toe__cell{align-items:center;background:var(--primary-bg);border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;display:flex;height:80px;justify-content:center;position:relative;transition:all .3s ease;width:80px}.tic-tac-toe__cell:hover:not(.tic-tac-toe__cell--disabled){background:#6366f10d;border-color:var(--accent-color)}.tic-tac-toe__cell--winning{background:#6366f11a;border-color:var(--accent-color);box-shadow:0 0 15px #6366f14d}.tic-tac-toe__cell--disabled{cursor:not-allowed;opacity:.7}.tic-tac-toe__symbol{font-size:2rem;font-weight:800;line-height:1}.tic-tac-toe__symbol--x{color:#6366f1}.tic-tac-toe__symbol--o{color:#8b5cf6}.tic-tac-toe__reset-btn{margin-top:1rem;padding:.75rem 2rem}@media (min-width:768px){.tic-tac-toe__cell{height:100px;width:100px}.tic-tac-toe__symbol{font-size:2.5rem}.tic-tac-toe__board{padding:1.5rem}}.rps{align-items:center;display:flex;flex-direction:column;margin:0 auto;max-width:500px;width:100%}.rps__scoreboard{display:flex;gap:4rem;justify-content:center;margin-bottom:2rem}.rps__score{text-align:center}.rps__score-label{color:var(--text-secondary);margin-bottom:.5rem}.rps__score-value{font-family:var(--font-family-mono);font-size:2.5rem;font-weight:800;margin:0}.rps__score-value--player{color:#10b981}.rps__score-value--computer{color:#ef4444}.rps__result{margin-bottom:2rem;text-align:center}.rps__battle{align-items:center;display:flex;gap:2rem;justify-content:center;margin-bottom:1rem}.rps__battle-choice{text-align:center}.rps__battle-label{color:var(--text-secondary);margin-bottom:.5rem}.rps__battle-symbol{display:block;font-size:3rem}.rps__battle-vs{color:var(--text-primary);font-size:1.2rem;font-weight:600}.rps__result-text{font-size:1.5rem;font-weight:600;margin:0}.rps__result-text--player{color:#10b981}.rps__result-text--computer{color:#ef4444}.rps__result-text--draw{color:var(--text-primary)}.rps__choices{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr);margin-bottom:2rem}.rps__choice{align-items:center;aspect-ratio:1;background:var(--card-bg);border:2px solid var(--border-color);border-radius:var(--radius-xl);cursor:pointer;display:flex;justify-content:center;padding:1.5rem 1rem;transition:all .3s ease}.rps__choice:hover:not(.rps__choice--disabled){background:#6366f10d;border-color:var(--accent-color)}.rps__choice--selected{background:#6366f11a;border-color:var(--accent-color)}.rps__choice--winner{background:#10b9811a;border-color:#10b981;box-shadow:0 0 20px #10b9814d}.rps__choice--disabled{cursor:not-allowed;opacity:.6}.rps__choice-content{align-items:center;display:flex;flex-direction:column;gap:.5rem}.rps__choice-symbol{font-size:2rem}.rps__choice-name{color:var(--text-secondary);font-size:.875rem;font-weight:500}.rps__play-again{margin-top:1rem;padding:.75rem 2rem}@media (min-width:768px){.rps__choice{padding:2rem 1.5rem}.rps__choice-symbol{font-size:2.5rem}.rps__battle-symbol{font-size:4rem}}.snake-game{align-items:center;display:flex;flex-direction:column;margin:0 auto;max-width:500px;width:100%}.snake-game__scoreboard{display:flex;gap:3rem;justify-content:center;margin-bottom:2rem}.snake-game__score{text-align:center}.snake-game__score-label{color:var(--text-secondary);font-size:.875rem;margin-bottom:.25rem}.snake-game__score-value{color:#10b981;font-family:var(--font-family-mono);font-size:1.75rem;font-weight:800;margin:0}.snake-game__score-value--high{color:#8b5cf6}.snake-game__board{background:var(--card-bg);border:2px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:2rem;overflow:hidden;position:relative}.snake-game__cell{border-radius:2px;position:absolute;z-index:1}.snake-game__cell--head{background:linear-gradient(135deg,#10b981,#059669);z-index:2}.snake-game__cell--body{background:linear-gradient(135deg,#34d399,#10b981)}.snake-game__cell--food{background:linear-gradient(135deg,#ef4444,#dc2626);font-size:14px;z-index:3}.snake-game__cell--food,.snake-game__overlay{align-items:center;display:flex;justify-content:center}.snake-game__overlay{background:#000c;border-radius:var(--radius-lg);inset:0;position:absolute;z-index:10}.snake-game__game-over{color:var(--text-primary);text-align:center}.snake-game__game-over-title{color:#ef4444;font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.snake-game__game-over-text{color:var(--text-secondary);margin:0}.snake-game__restart-btn,.snake-game__start-btn{margin-bottom:1.5rem;padding:.75rem 2rem}.snake-game__controls{color:var(--text-muted);font-size:.875rem;text-align:center}.snake-game__controls p{margin:0}.snake-game__mobile-controls{margin-bottom:1.5rem}.snake-game__d-pad{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-areas:". up ." "left . right" ". down .";margin:0 auto;width:-webkit-fit-content;width:fit-content}.snake-game__control-btn{-webkit-tap-highlight-color:transparent;align-items:center;background:var(--card-bg);border:2px solid var(--accent-color);border-radius:50%;color:var(--accent-color);cursor:pointer;display:flex;font-size:1.5rem;height:3.5rem;justify-content:center;transition:all .2s ease;-webkit-user-select:none;user-select:none;width:3.5rem}.snake-game__control-btn:active{background:var(--accent-color);color:var(--card-bg);transform:scale(.95)}.snake-game__control-btn:hover{background:#6366f11a;box-shadow:0 0 0 4px #6366f11a}.snake-game__control-btn--up{grid-area:up}.snake-game__control-btn--down{grid-area:down}.snake-game__control-btn--left{grid-area:left}.snake-game__control-btn--right{grid-area:right}.snake-game__horizontal-controls{display:flex;gap:4rem;grid-area:left/left/right/right;justify-content:space-between;width:100%}@media (max-width:480px){.snake-game{padding:1rem}.snake-game__board{margin-bottom:1rem;transform:scale(.9)}.snake-game__scoreboard{gap:2rem;margin-bottom:1.5rem}.snake-game__score-value{font-size:1.5rem}.snake-game__control-btn{font-size:1.25rem;height:3rem;width:3rem}.snake-game__horizontal-controls{gap:3rem}}@media (min-width:768px){.snake-game__board{margin:2rem 0 3rem;transform:scale(1.2)}.snake-game__scoreboard{gap:4rem}}.typing-test{margin:0 auto;max-width:800px;width:100%}.typing-test__stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr);margin-bottom:1.5rem}.typing-test__stat-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1rem;text-align:center}.typing-test__stat-label{color:var(--text-secondary);font-size:.875rem;margin-bottom:.25rem}.typing-test__stat-value{font-family:var(--font-family-mono);font-size:1.75rem;font-weight:800;margin:0}.typing-test__stat-unit{color:var(--text-secondary);font-size:.875rem;margin-left:.25rem}.typing-test__progress-bar{background:var(--card-bg);border-radius:var(--radius-md);height:.5rem;margin-bottom:1.5rem;overflow:hidden;width:100%}.typing-test__progress-fill{background:linear-gradient(90deg,var(--accent-color),var(--accent-hover));border-radius:var(--radius-md);height:100%}.typing-test__text-display{background:var(--card-bg);border:2px solid var(--border-color);border-radius:var(--radius-xl);margin-bottom:1.5rem;min-height:150px;padding:2rem}.typing-test__text{word-wrap:break-word;font-family:var(--font-family-mono);font-size:1rem;line-height:1.8}.typing-test__char{position:relative}.typing-test__char--correct{background:#10b9811a;color:#10b981}.typing-test__char--incorrect{background:#ef44441a;color:#ef4444}.typing-test__char--active{animation:blink 1s infinite;background:var(--accent-color);color:#fff}.typing-test__char--pending{color:var(--text-secondary)}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:.3}}.typing-test__input-area{margin-bottom:1.5rem}.typing-test__input{background:var(--primary-bg);border:2px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-primary);font-family:var(--font-family-mono);font-size:1rem;line-height:1.6;padding:1rem;resize:none;transition:border-color .3s ease;width:100%}.typing-test__input:focus{border-color:var(--accent-color);outline:none}.typing-test__input:disabled{cursor:not-allowed;opacity:.5}.typing-test__actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:1.5rem}.typing-test__modal{align-items:center;background:#000c;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1000}.typing-test__modal-content{background:var(--card-bg);border:2px solid var(--border-color);border-radius:var(--radius-2xl);max-width:400px;padding:2rem;text-align:center;width:100%}.typing-test__modal-header h3{color:var(--text-primary);font-size:1.5rem;font-weight:700;margin-bottom:1.5rem}.typing-test__modal-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr);margin-bottom:2rem}.typing-test__modal-stat{text-align:center}.typing-test__modal-stat-label{color:var(--text-secondary);font-size:.875rem;margin-bottom:.25rem}.typing-test__modal-stat-value{color:#10b981;font-family:var(--font-family-mono);font-size:2rem;font-weight:800;margin-bottom:.25rem}.typing-test__modal-stat-unit{color:var(--text-secondary);font-size:.75rem}.typing-test__modal-btn{padding:1rem;width:100%}.typing-test__instructions{color:var(--text-muted);font-size:.875rem;text-align:center}.typing-test__instructions p{margin:0}@media (min-width:640px){.typing-test__stats{grid-template-columns:repeat(4,1fr)}.typing-test__actions{flex-wrap:nowrap}}@media (min-width:768px){.typing-test__text-display{padding:2.5rem}.typing-test__text{font-size:1.1rem}}.memory-card-game{align-items:center;display:flex;justify-content:center;min-height:600px;padding:1rem;width:100%}.memory-card-game__container{max-width:650px;width:100%}.memory-card-game__header{margin-bottom:2rem;text-align:center}.memory-card-game__title{color:var(--text-primary);font-size:2rem;font-weight:700;margin:0 0 .5rem}.memory-card-game__subtitle{color:var(--text-secondary);font-size:1rem;margin:0}.memory-card-game__stats{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:2rem}.memory-card-game__stat{align-items:center;background:var(--surface-elevated);border:1px solid var(--border-color);border-radius:12px;display:flex;flex-direction:column;gap:.25rem;min-width:80px;padding:.75rem 1.25rem}.memory-card-game__stat--best{background:linear-gradient(135deg,#eab3081a,#ca8a041a);border-color:#eab3084d}.memory-card-game__stat-label{color:var(--text-secondary);font-size:.75rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.memory-card-game__stat-value{color:var(--text-primary);font-family:var(--font-family-mono);font-size:1.25rem;font-weight:700}.memory-card-game__stat--best .memory-card-game__stat-value{color:#ca8a04}.memory-card-game__new-game-btn{background:linear-gradient(135deg,var(--primary-color) 0,var(--secondary-color) 100%);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease;white-space:nowrap}.memory-card-game__new-game-btn:hover{box-shadow:0 4px 12px #6366f14d}.memory-card-game__board{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(4,1fr);margin:0 auto;max-width:500px;perspective:1000px}.memory-card-game__card{aspect-ratio:1;background:#0000;border-radius:12px;cursor:pointer;perspective:1000px;position:relative}.memory-card-game__card:hover:not(.memory-card-game__card--matched):not(.memory-card-game__card--flipped) .memory-card-game__card-inner{border-color:var(--primary-color)}.memory-card-game__card-inner{border:2px solid var(--border-color);border-radius:12px;height:100%;position:relative;transform-style:preserve-3d;transition:transform .6s;width:100%}.memory-card-game__card--flipped .memory-card-game__card-inner{transform:rotateY(180deg)}.memory-card-game__card--matched .memory-card-game__card-inner{background:linear-gradient(145deg,#34d39933,#10b98133);border-color:#34d39980;cursor:default}.memory-card-game__card-back,.memory-card-game__card-front{align-items:center;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:10px;display:flex;font-size:3rem;height:100%;justify-content:center;position:absolute;width:100%}.memory-card-game__card-front{background:linear-gradient(145deg,var(--surface-elevated) 0,var(--surface-base) 100%);color:var(--text-secondary);font-size:2.5rem;font-weight:700}.memory-card-game__card-back{background:linear-gradient(145deg,var(--primary-color) 0,var(--secondary-color) 100%);transform:rotateY(180deg)}.memory-card-game__modal-overlay{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.memory-card-game__modal{background:var(--surface-elevated);border:1px solid var(--border-color);border-radius:20px;box-shadow:0 20px 60px #0000004d;max-width:90%;padding:2.5rem;text-align:center;width:400px}.memory-card-game__modal-title{color:var(--text-primary);font-size:2rem;font-weight:800;margin:0 0 1rem}.memory-card-game__modal-message{color:var(--text-secondary);font-size:1.125rem;font-weight:500;margin:0 0 1.5rem}.memory-card-game__modal-stats{display:flex;gap:1.5rem;justify-content:center;margin:1.5rem 0}.memory-card-game__modal-stat{background:var(--surface-base);border:1px solid var(--border-color);border-radius:12px;display:flex;flex-direction:column;gap:.5rem;padding:1rem 2rem}.memory-card-game__modal-stat-label{color:var(--text-secondary);font-size:.875rem;font-weight:600;letter-spacing:1px;text-transform:uppercase}.memory-card-game__modal-stat-value{color:var(--primary-color);font-family:var(--font-family-mono);font-size:1.5rem;font-weight:800}.memory-card-game__modal-record{animation:pulse 1s ease infinite;color:#ca8a04;font-size:1.125rem;font-weight:700;margin:1rem 0 .5rem}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.memory-card-game__modal-btn{background:linear-gradient(135deg,var(--primary-color) 0,var(--secondary-color) 100%);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;margin-top:1.25rem;padding:.875rem 2.5rem;transition:all .3s ease}.memory-card-game__modal-btn:hover{box-shadow:0 6px 20px #6366f166}@media (max-width:768px){.memory-card-game__title{font-size:1.5rem}.memory-card-game__stats{gap:.5rem}.memory-card-game__stat{min-width:70px;padding:.5rem 1rem}.memory-card-game__stat-label{font-size:.7rem}.memory-card-game__stat-value{font-size:1rem}.memory-card-game__new-game-btn{font-size:.8rem;padding:.625rem 1.25rem}.memory-card-game__board{gap:.5rem;max-width:100%}.memory-card-game__card-back,.memory-card-game__card-front{font-size:2rem}.memory-card-game__card-front{font-size:1.75rem}.memory-card-game__modal{padding:2rem 1.5rem;width:90%}.memory-card-game__modal-title{font-size:1.5rem}.memory-card-game__modal-stats{flex-direction:column;gap:1rem}.memory-card-game__modal-stat{padding:.75rem 1.5rem}.memory-card-game__modal-stat-value{font-size:1.25rem}}@media (max-width:480px){.memory-card-game__board{gap:.375rem}.memory-card-game__card{border-radius:8px;border-width:1.5px}.memory-card-game__card-back,.memory-card-game__card-front{border-radius:6px;font-size:1.5rem}.memory-card-game__card-front,.memory-card-game__modal-title{font-size:1.25rem}.memory-card-game__modal-message{font-size:1rem}}.game-center{background:var(--primary-bg);color:var(--text-primary);min-height:100vh}.game-center__header{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#1a1a1acc;border-bottom:1px solid var(--border-color);position:-webkit-sticky;position:sticky;top:0;z-index:100}.game-center__header-container{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin:0 auto;max-width:1200px;padding:1.5rem 2rem}.game-center__title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--accent-color),var(--accent-hover));-webkit-background-clip:text;background-clip:text;font-family:var(--font-family-mono);font-size:1.75rem;font-weight:800;margin:0}.game-center__back-btn{font-size:.9rem;padding:.75rem 1.5rem}.game-center__main{align-items:center;display:flex;justify-content:center;min-height:calc(100vh - 100px);padding:2rem 0}.game-center__container{margin:0 auto;max-width:1200px;padding:0 2rem;width:100%}.game-center__selection{text-align:center}.game-center__intro{margin-bottom:3rem}.game-center__intro h2{color:var(--text-primary);font-size:2.5rem;font-weight:800;margin-bottom:1rem}.game-center__intro p{color:var(--text-secondary);font-size:1.2rem;margin:0}.game-center__grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr;margin:0 auto;max-width:800px}.game-card{background:var(--card-bg);border:2px solid var(--border-color);border-radius:var(--radius-xl);cursor:pointer;padding:2rem;transition:all .3s ease}.game-card:hover{border-color:var(--accent-color);box-shadow:var(--shadow-xl);transform:translateY(-4px)}.game-card--selected{border-color:var(--accent-color);box-shadow:0 0 20px #6366f14d}.game-card__content{align-items:center;display:flex;gap:1.5rem}.game-card__icon{flex-shrink:0;font-size:3rem}.game-card__info{flex:1 1;text-align:left}.game-card__title{color:var(--text-primary);font-family:var(--font-family-mono);font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.game-card__description{color:var(--text-secondary);font-size:1rem;margin:0}.game-center__game{margin:0 auto;max-width:1000px;width:100%}.game-center__game-header{margin-bottom:2rem;text-align:center}.game-center__back-game-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-family:var(--font-family-primary);font-size:1rem;transition:color .3s ease}.game-center__back-game-btn:hover{color:var(--accent-color)}.game-center__game-content{align-items:center;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-2xl);display:flex;justify-content:center;min-height:500px;padding:2rem}@media (min-width:640px){.game-center__grid{grid-template-columns:repeat(2,1fr)}.game-center__intro h2{font-size:3rem}}@media (min-width:768px){.game-center__header-container{padding:2rem 3rem}.game-center__container{padding:0 3rem}.game-center__title{font-size:2rem}.game-center__game-content{padding:3rem}}@media (min-width:1024px){.game-center__grid{gap:2rem;grid-template-columns:repeat(2,1fr)}.game-card{padding:2.5rem}}.projects-section{position:relative}.projects-header{margin-bottom:1.5rem;text-align:center}.projects-header .section-title{color:var(--text-primary);font-size:2.5rem;font-weight:800;margin-bottom:1rem}.projects-header .section-subtitle{color:var(--text-secondary);font-size:1.125rem;margin:0 auto;max-width:600px}@media (min-width:768px){.projects-header .section-title{font-size:3rem}}.projects-layout{grid-gap:2rem;align-items:start;display:grid;gap:2rem;grid-template-columns:260px 1fr;margin:0 auto;max-width:1400px}.projects-sidebar{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-2xl);height:-webkit-fit-content;height:fit-content;padding:1.25rem;position:-webkit-sticky;position:sticky;top:1rem;transition:all .3s ease}.projects-sidebar:hover{border-color:var(--accent-color);box-shadow:var(--shadow-lg)}.sidebar-title{align-items:center;color:var(--text-primary);display:flex;font-size:1.1rem;font-weight:600;gap:.5rem;margin-bottom:1rem}.sidebar-title:before{content:"📂";font-size:1.2rem}.category-list{display:flex;flex-direction:column;gap:.5rem}.category-item{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;display:flex;font-family:var(--font-family-primary);font-size:.9rem;gap:.75rem;padding:.75rem 1rem;text-align:left;transition:all .2s ease;width:100%}.category-item:hover{background:#6366f11a;border-color:#6366f133;color:var(--text-primary);transform:translateX(4px)}.category-item--active{background:var(--accent-color);border-color:var(--accent-color);box-shadow:var(--shadow-md);color:var(--text-primary);font-weight:600}.category-item--active:hover{background:var(--accent-color);transform:translateX(0)}.category-icon{flex-shrink:0;font-size:1.1rem}.category-name{flex:1 1}.category-count{background:#6366f133;border-radius:var(--radius-md);color:var(--accent-color);font-size:.75rem;font-weight:600;min-width:24px;padding:.2rem .5rem;text-align:center}.category-item--active .category-count{background:#fff3;color:var(--text-primary)}.projects-content{min-width:0}.projects-header-info{margin-bottom:1rem}.projects-count{color:var(--text-primary);font-size:1.5rem;font-weight:600;margin:0}.selected-category{color:var(--accent-color);font-weight:500}.projects-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr}.project-card{padding:1.5rem}.project-header{margin-bottom:1rem}.status-badge.in-progress{background:var(--warning-color);color:var(--text-primary)}.status-badge.planned{background:var(--text-muted);color:var(--text-primary)}.project-content{margin-bottom:2rem}.demo-content-section{margin-bottom:1rem}.demo-content-container{grid-gap:1.5rem;align-items:start;gap:1.5rem;grid-template-columns:minmax(300px,400px) 1fr}.demo-column,.demo-gif,.project-demo{max-width:400px;width:100%}.demo-gif{max-height:600px}.demo-container iframe{border:none;border-radius:var(--radius-lg);height:100%;left:0;position:absolute;top:0;width:100%}.demo-container:has(iframe){height:0;padding-bottom:56.25%}.demo-placeholder{align-items:center;background:var(--card-bg);border:2px dashed var(--border-color);border-radius:var(--radius-lg);display:flex;justify-content:center;min-height:200px;padding:2rem;text-align:center}.placeholder-content{max-width:400px}.placeholder-icon{display:block;font-size:3rem;margin-bottom:1rem}.placeholder-content p{color:var(--text-secondary);font-size:.95rem;line-height:1.5;margin-bottom:.5rem}.placeholder-hint{color:var(--text-muted)!important;font-family:var(--font-family-mono)!important;font-size:.8rem!important;margin-bottom:1rem!important}.placeholder-hint code{background:#6366f11a;border-radius:var(--radius-sm);color:var(--accent-color);font-size:.75rem;padding:.2rem .4rem}.placeholder-steps{background:#6366f10d;border-left:3px solid var(--accent-color);border-radius:var(--radius-md);margin-top:1rem;padding:1rem}.placeholder-steps p{color:var(--text-secondary)!important;font-size:.85rem!important;margin-bottom:.25rem!important}.placeholder-steps strong{color:var(--text-primary)}.project-actions{border-top:1px solid var(--border-color);display:flex;flex-wrap:wrap;gap:1rem;margin-top:1.5rem;padding-top:1.5rem}.action-btn.secondary{background:#0000;border:2px solid var(--accent-color);color:var(--text-primary)}.action-btn.secondary:hover{background:var(--accent-color);transform:translateY(-2px)}.action-btn.outline{background:#0000;border:2px solid var(--border-color);color:var(--text-secondary)}.action-btn.outline:hover{border-color:var(--accent-color);color:var(--text-primary)}.projects-cta{margin-top:2rem;padding:1.5rem}@media (max-width:1024px){.projects-layout{gap:2rem;grid-template-columns:1fr}.projects-sidebar{order:-1;position:static}.category-list{flex-direction:row;flex-wrap:wrap;gap:.75rem}.category-item{flex:0 0 auto;font-size:.85rem;min-width:auto;padding:.5rem .75rem}.category-item:hover{transform:translateY(-2px)}.projects-header-info{text-align:center}}@media (max-width:768px){.projects-sidebar{padding:1.25rem}.sidebar-title{font-size:1rem;text-align:center}.category-list{justify-content:center}.category-item{font-size:.8rem;padding:.5rem .75rem}.category-name{display:none}.projects-count{font-size:1.25rem}.project-card{padding:1.5rem}.project-title{font-size:1.5rem}.demo-content-container{gap:1.5rem;grid-template-columns:1fr}.demo-column{order:1}.project-info-column{height:auto;justify-content:flex-start;order:2}.project-status{align-items:flex-start;flex-direction:column;gap:.75rem}.project-actions-header{justify-content:flex-start;width:100%}.project-actions{flex-direction:column;gap:.75rem}.action-btn{justify-content:center;width:100%}}@media (max-width:480px){.projects-layout{gap:1.5rem}.projects-sidebar{padding:1rem}.sidebar-title{font-size:.9rem}.category-item{font-size:.75rem;padding:.4rem .6rem}.category-icon{font-size:1rem}.category-count{font-size:.7rem;min-width:20px;padding:.15rem .4rem}.projects-count{font-size:1.1rem}.project-card{padding:1.25rem}.projects-cta{margin-top:3rem;padding:1.5rem}}.projects-page{background:var(--primary-bg);color:var(--text-primary);min-height:100vh}.projects-page__header{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#1a1a1acc;border-bottom:1px solid var(--border-color);position:-webkit-sticky;position:sticky;top:0;z-index:100}.projects-page__header-container{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin:0 auto;max-width:1200px;padding:1.5rem 2rem}.projects-page__title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--accent-color),var(--accent-hover));-webkit-background-clip:text;background-clip:text;font-family:var(--font-family-mono);font-size:1.75rem;font-weight:800;margin:0}.projects-page__back-btn{font-size:.9rem;padding:.75rem 1.5rem}.projects-page__content{padding-bottom:2rem;padding-top:.75rem}.projects-page__content .projects-header{display:none}.projects-page__content .projects-section{padding-top:0}.projects-page__content .projects-layout{margin-top:0}.projects-page__grid{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:1fr;margin:0 auto;max-width:1000px}.project-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-2xl);cursor:default;padding:2rem;transition:all .3s ease}.project-card:hover{border-color:var(--accent-color);box-shadow:var(--shadow-xl);transform:translateY(-4px)}.project-header{margin-bottom:1.5rem}.project-status{justify-content:space-between;margin-bottom:1rem}.project-status,.status-badges{align-items:center;display:flex}.status-badges{gap:.75rem}.project-actions-header{align-items:center;display:flex}.action-btn.compact{font-size:.8rem;padding:.5rem 1rem}.status-badge{border-radius:var(--radius-md);font-family:var(--font-family-mono);font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.25rem .75rem;text-transform:uppercase}.status-badge.completed{background:var(--success-color);color:var(--text-primary)}.project-category{background:#6366f11a;border:1px solid #6366f133;border-radius:var(--radius-md);color:var(--accent-color);font-size:.8rem;font-weight:500;padding:.25rem .75rem}.project-title{color:var(--text-primary);font-size:1.75rem;font-weight:700;margin-bottom:.75rem}.project-description{color:var(--text-secondary);font-size:1.1rem;line-height:1.6;margin-bottom:0}.project-content h4{color:var(--text-primary);font-size:1.1rem;font-weight:600;margin-bottom:.75rem}.demo-content-section{margin-bottom:1.5rem}.demo-content-container{grid-gap:2rem;align-items:stretch;display:grid;gap:2rem;grid-template-columns:auto 1fr}.demo-column{flex:0 0 auto}.demo-column h4{color:var(--text-primary);margin-bottom:1rem}.project-demo{flex:0 0 auto}.demo-container{align-items:center;border:1px solid var(--border-color);border-radius:var(--radius-lg);display:flex;justify-content:center;overflow:hidden;position:relative}.demo-container,.demo-gif{background:var(--secondary-bg)}.demo-gif{border-radius:var(--radius-lg);display:block;height:auto;max-height:500px;max-width:100%;object-fit:contain}.project-info-column{display:flex;flex:1 1;flex-direction:column;gap:1.5rem;height:100%;justify-content:space-between;min-width:0}.project-info-column h4{color:var(--text-primary);margin-bottom:1rem}.project-highlights{display:flex;flex:1 1;flex-direction:column}.highlights-list{display:flex;flex:1 1;flex-direction:column;gap:.5rem}.highlight-item{background:#6366f11a;border:1px solid #6366f133;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.9rem;padding:.5rem .75rem}.project-tech{flex:0 0 auto;margin-top:auto}.tech-tags{display:flex;flex-wrap:wrap;gap:.5rem}.tech-tag{background:#6366f11a;border:1px solid #6366f133;border-radius:var(--radius-md);color:var(--accent-color);cursor:default;font-size:.8rem;font-weight:500;padding:.4rem .8rem;transition:all .2s ease}.tech-tag:hover{background:var(--accent-color);color:#fff;transform:translateY(-1px)}.action-btn{align-items:center;border:none;border-radius:var(--radius-lg);cursor:pointer;display:inline-flex;font-family:var(--font-family-primary);font-size:.875rem;font-weight:500;gap:.5rem;justify-content:center;outline:none;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s ease-in-out}.action-btn.primary{background:linear-gradient(135deg,var(--accent-color),var(--accent-hover));color:var(--text-primary)}.action-btn.primary:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-icon{font-size:1rem}.projects-cta{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-2xl);margin-top:4rem;padding:2rem;text-align:center;transition:all .3s ease}.projects-cta:hover{border-color:var(--accent-color);transform:translateY(-2px)}.projects-cta h3{color:var(--text-primary);font-size:1.5rem;font-weight:600;margin-bottom:.75rem}.projects-cta p{color:var(--text-secondary);font-size:1.1rem;margin-bottom:1.5rem}.cta-btn{align-items:center;background:#0000;border:2px solid var(--accent-color);border-radius:var(--radius-lg);color:var(--text-primary);display:inline-flex;font-family:var(--font-family-primary);font-weight:500;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s ease-in-out}.cta-btn:hover{background:var(--accent-color);transform:translateY(-2px)}@media (max-width:768px){.projects-page__header-container{flex-direction:column;gap:1rem;padding:1rem;text-align:center}.projects-page__title{font-size:1.5rem;order:1}.projects-page__back-btn{align-self:center;order:2}.projects-page__content{padding-top:.5rem}.project-card{padding:1.5rem}.project-title{font-size:1.5rem}.demo-content-container{gap:1.5rem;grid-template-columns:1fr}.demo-column{order:1}.project-info-column{order:2}}@media (max-width:480px){.projects-page__header-container{padding:.75rem}.projects-page__title{font-size:1.25rem}.project-card{padding:1.25rem}.projects-cta{margin-top:3rem;padding:1.5rem}}.footer{background:var(--secondary-bg);border-top:1px solid var(--border-color);padding:2rem 0}.footer__content{align-items:center;display:flex;flex-direction:column;gap:.5rem;text-align:center}.footer__copyright{color:var(--text-primary);font-weight:500;margin:0}.footer__built{color:var(--text-muted);font-size:.875rem;margin:0}@media (min-width:768px){.footer__content{flex-direction:row;justify-content:space-between}}
/*# sourceMappingURL=main.6a8f3fa7.css.map*/