:root{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-tertiary: #1a1a24;--bg-elevated: #22222e;--accent-primary: #6366f1;--accent-primary-light: #818cf8;--accent-primary-dark: #4f46e5;--accent-secondary: #f59e0b;--accent-secondary-light: #fbbf24;--accent-success: #10b981;--accent-error: #ef4444;--glow-primary: rgba(99, 102, 241, .2);--glow-secondary: rgba(245, 158, 11, .2);--glow-success: rgba(16, 185, 129, .2);--text-primary: #f8fafc;--text-secondary: #94a3b8;--text-tertiary: #64748b;--text-muted: #475569;--border-subtle: rgba(255, 255, 255, .06);--border-visible: rgba(255, 255, 255, .12);--border-focus: var(--accent-primary);--font-heading: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--text-6xl: 3.75rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--font-extrabold: 800;--leading-tight: 1.1;--leading-snug: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.625;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--space-32: 8rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .5);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .6);--shadow-glow: 0 0 20px var(--glow-primary);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .35s ease;--transition-bounce: .5s cubic-bezier(.34, 1.56, .64, 1);--z-base: 0;--z-dropdown: 10;--z-sticky: 20;--z-fixed: 30;--z-modal-backdrop: 40;--z-modal: 50;--z-tooltip: 60;--z-toast: 70;--container-max: 1200px;--container-padding: var(--space-6);--header-height: 72px;--progress-bar-height: 4px}@media (max-width: 768px){:root{--text-5xl: 2.25rem;--text-6xl: 2.75rem;--container-padding: var(--space-4);--header-height: 64px}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;scroll-padding-top:calc(var(--header-height) + var(--progress-bar-height) - var(--space-4))}body{font-family:var(--font-body);font-size:var(--text-base);font-weight:var(--font-normal);line-height:var(--leading-normal);color:var(--text-primary);background-color:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{background:var(--accent-primary);color:var(--text-primary)}a{color:inherit;text-decoration:none;transition:color var(--transition-fast)}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit;color:inherit}button{cursor:pointer;background:none;border:none}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:var(--font-bold);line-height:var(--leading-tight);color:var(--text-primary)}h1{font-size:var(--text-5xl)}h2{font-size:var(--text-4xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-base)}p{color:var(--text-secondary)}:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-size:var(--text-sm);font-weight:var(--font-semibold);line-height:1;border-radius:var(--radius-lg);transition:all var(--transition-base);white-space:nowrap;position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,.1) 50%,transparent 60%);transform:translate(-100%);transition:transform .6s ease}.btn:hover:before{transform:translate(100%)}.btn__icon{width:16px;height:16px;transition:transform var(--transition-fast)}.btn:hover .btn__icon{transform:translate(2px)}.btn--primary{background:var(--accent-primary);color:var(--text-primary);box-shadow:0 0 0 0 var(--glow-primary)}.btn--primary:hover{background:var(--accent-primary-light);box-shadow:0 0 20px var(--glow-primary);transform:translateY(-2px)}.btn--primary:active{transform:translateY(0)}.btn--secondary{background:transparent;color:var(--text-primary);border:1px solid var(--border-visible)}.btn--secondary:hover{background:var(--bg-tertiary);border-color:var(--text-muted);transform:translateY(-2px)}.btn--full{width:100%}.card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);transition:all var(--transition-base)}.card:hover{border-color:var(--border-visible);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.section-header{text-align:center;margin-bottom:var(--space-16)}.section-header__label{display:inline-block;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--accent-primary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--space-4)}.section-header__title{font-size:var(--text-4xl);margin-bottom:var(--space-4)}.section-header__description{font-size:var(--text-lg);color:var(--text-secondary);max-width:600px;margin:0 auto}.form-group{margin-bottom:var(--space-6)}.form-label{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary);margin-bottom:var(--space-2)}.form-input{width:100%;padding:var(--space-4);background:var(--bg-tertiary);border:1px solid var(--border-visible);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--text-base);transition:all var(--transition-fast)}.form-input::placeholder{color:var(--text-muted)}.form-input:hover{border-color:var(--text-muted)}.form-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--glow-primary)}.form-input--textarea{resize:vertical;min-height:120px}.tag{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--text-secondary);background:var(--bg-tertiary);border-radius:var(--radius-full);transition:all var(--transition-fast)}.tag:hover{background:var(--bg-elevated);color:var(--text-primary)}.skill-bar{height:6px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.skill-bar__fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-primary-light));border-radius:var(--radius-full);width:0;transition:width 1s ease-out}.tooltip{position:relative}.tooltip:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(-4px);padding:var(--space-2) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--text-primary);background:var(--bg-elevated);border-radius:var(--radius-md);white-space:nowrap;opacity:0;visibility:hidden;transition:all var(--transition-fast);pointer-events:none;z-index:var(--z-tooltip)}.tooltip:hover:after{opacity:1;visibility:visible;transform:translate(-50%) translateY(-8px)}.progress-bar{position:fixed;top:0;left:0;right:0;height:var(--progress-bar-height);background:var(--bg-tertiary);z-index:var(--z-fixed)}.progress-bar__fill{height:100%;width:0;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));transition:width .1s ease-out}.progress-bar__xp{position:absolute;right:var(--space-4);top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:var(--space-2);opacity:0;transition:opacity var(--transition-base)}.progress-bar:hover .progress-bar__xp{opacity:1}.progress-bar__xp-text{font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--accent-secondary);text-shadow:0 0 10px var(--glow-secondary)}.header{position:fixed;top:var(--progress-bar-height);left:0;right:0;height:var(--header-height);background:#0a0a0fcc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-subtle);z-index:var(--z-sticky);transition:transform var(--transition-base),background var(--transition-base)}.header--hidden{transform:translateY(-100%)}.header__container{max-width:var(--container-max);margin:0 auto;padding:0 var(--container-padding);height:100%;display:flex;align-items:center;justify-content:space-between}.header__logo{display:flex;align-items:center;gap:2px;font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);transition:color var(--transition-fast)}.header__logo:hover{color:var(--accent-primary-light)}.header__logo-cursor{animation:blink 1s step-end infinite;color:var(--accent-primary)}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.header__nav-list{display:flex;gap:var(--space-8)}.header__nav-link{position:relative;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary);padding:var(--space-2) 0;transition:color var(--transition-fast)}.header__nav-link:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--accent-primary);transform:scaleX(0);transform-origin:right;transition:transform var(--transition-base)}.header__nav-link:hover,.header__nav-link.active{color:var(--text-primary)}.header__nav-link:hover:after,.header__nav-link.active:after{transform:scaleX(1);transform-origin:left}.header__actions{display:flex;align-items:center;gap:var(--space-4)}.header__play-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:linear-gradient(135deg,#ff6b9d,#c44569,#ff9a56);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-bold);color:#fff;text-decoration:none;transition:all var(--transition-fast);box-shadow:0 2px 10px #ff6b9d4d}.header__play-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ff6b9d80}.header__play-icon{font-size:var(--text-base)}.header__play-text{white-space:nowrap}@media (max-width: 900px){.header__play-text{display:none}}@media (max-width: 768px){.header__play-btn{display:none}}.mobile-menu__link--game{background:linear-gradient(135deg,#ff6b9d,#c44569,#ff9a56);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:var(--font-bold)}.header__achievements-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--bg-tertiary);border:1px solid var(--border-visible);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-secondary);transition:all var(--transition-fast)}.header__achievements-btn:hover{background:var(--bg-elevated);border-color:var(--accent-secondary);color:var(--accent-secondary);box-shadow:0 0 15px var(--glow-secondary)}.header__achievements-icon{font-size:var(--text-base)}.header__menu-btn{display:none;flex-direction:column;justify-content:center;gap:5px;width:32px;height:32px;padding:4px}.header__menu-line{width:100%;height:2px;background:var(--text-secondary);border-radius:var(--radius-full);transition:all var(--transition-fast)}.header__menu-btn.active .header__menu-line:nth-child(1){transform:translateY(7px) rotate(45deg)}.header__menu-btn.active .header__menu-line:nth-child(2){opacity:0}.header__menu-btn.active .header__menu-line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.mobile-menu{position:fixed;top:calc(var(--header-height) + var(--progress-bar-height));left:0;right:0;bottom:0;background:var(--bg-primary);z-index:var(--z-dropdown);opacity:0;visibility:hidden;transition:all var(--transition-base)}.mobile-menu.active{opacity:1;visibility:visible}.mobile-menu__nav{display:flex;flex-direction:column;padding:var(--space-8) var(--container-padding)}.mobile-menu__link{padding:var(--space-4) 0;font-size:var(--text-2xl);font-weight:var(--font-semibold);color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);transition:all var(--transition-fast)}.mobile-menu__link:hover{color:var(--text-primary);padding-left:var(--space-4)}.footer{background:var(--bg-primary);border-top:1px solid var(--border-subtle);padding:var(--space-8) var(--container-padding);position:relative}.footer:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:var(--bg-primary);z-index:1}.footer__container{position:relative;z-index:2}.footer__peeking{position:absolute;top:0;left:20%;transform:translate(-50%);cursor:pointer;display:flex;flex-direction:column;align-items:center;z-index:0}.footer__peeking-head{position:relative;z-index:0;transform:translateY(-45px);transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.footer__peeking:hover .footer__peeking-head{transform:translateY(-53px)}.footer__peeking.footer__peeking--waving .footer__peeking-head,.footer__peeking.footer__peeking--waving:hover .footer__peeking-head{transform:translateY(-53px);transition:none}.footer__peeking.footer__peeking--scared .footer__peeking-head{animation:peekHeadScared .5s ease-in-out}.footer__peeking.footer__peeking--hidden .footer__peeking-head{transform:translateY(40px);transition:transform .4s cubic-bezier(.4,0,1,1)}.footer__peeking.footer__peeking--waving .footer__peeking-img--head{animation:peekHeadWave .6s ease-in-out}.footer__peeking.footer__peeking--hidden .footer__peeking-bubble{opacity:0!important;visibility:hidden!important}.footer__peeking-img{width:128px;height:auto;image-rendering:pixelated;image-rendering:crisp-edges;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3));transition:filter .2s ease;display:block}.footer__peeking:hover .footer__peeking-img{filter:drop-shadow(0 6px 12px rgba(0,0,0,.4))}.footer__peeking-img--head{position:relative}.footer__peeking-hands-wrapper{position:absolute;top:0;left:20%;transform:translate(-50%);z-index:10;pointer-events:none}.footer__peeking-img--hands{position:relative;transform:translateY(-80%)}.footer__peeking-bubble{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:var(--bg-elevated);border:1px solid var(--border-visible);border-radius:var(--radius-lg);padding:var(--space-2) var(--space-3);white-space:nowrap;opacity:0;visibility:hidden;transition:all .2s ease;pointer-events:none;margin-bottom:var(--space-2)}.footer__peeking-bubble:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--border-visible)}.footer__peeking-bubble:before{content:"";position:absolute;top:calc(100% - 1px);left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:var(--bg-elevated);z-index:1}.footer__peeking:hover .footer__peeking-bubble,.footer__peeking-bubble.footer__peeking-bubble--visible{opacity:1;visibility:visible}.footer__peeking-text{font-size:var(--text-sm);color:var(--text-primary);font-weight:var(--font-medium)}@keyframes peekHeadScared{0%,to{transform:translateY(-45px)}25%{transform:translateY(5px)}50%{transform:translateY(-30px)}75%{transform:translateY(-45px)}}@keyframes peekHeadWave{0%,to{transform:rotate(0) scale(1)}15%{transform:rotate(-8deg) scale(1.05)}30%{transform:rotate(6deg) scale(1.02)}45%{transform:rotate(-6deg) scale(1.05)}60%{transform:rotate(4deg) scale(1.02)}75%{transform:rotate(-3deg) scale(1.03)}90%{transform:rotate(2deg) scale(1.01)}}.footer__content{text-align:center}.footer__social{display:flex;justify-content:center;gap:var(--space-4);margin-bottom:var(--space-4)}.footer__social-link{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-muted);transition:all var(--transition-base)}.footer__social-link:hover{background:var(--accent-primary);color:var(--bg-primary);transform:translateY(-3px);box-shadow:0 4px 12px var(--glow-primary)}.footer__social-icon{width:20px;height:20px}.footer__copyright{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-2)}.footer__emoji{cursor:pointer;transition:transform var(--transition-fast);display:inline-block}.footer__emoji:hover{transform:scale(1.2)}.footer__hint{font-size:var(--text-xs);color:var(--text-muted);opacity:.5}.footer__hint-text{font-family:var(--font-mono)}@media (max-width: 768px){.header__nav{display:none}.header__menu-btn{display:flex}}.main{min-height:100vh}section{padding:var(--space-24) var(--container-padding)}section>.skills__container,section>.projects__container,section>.contact__container,section>.hero__container{max-width:var(--container-max);margin:0 auto}.hero__badge,.hero__title-line,.hero__title-name,.hero__subtitle,.hero__description,.hero__cta .btn,.hero__avatar,.hero__scroll-hint{opacity:0}.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding-top:calc(var(--header-height) + var(--progress-bar-height) + var(--space-12));position:relative;overflow:hidden}.hero:before{content:"";position:absolute;top:0;left:50%;width:800px;height:800px;background:radial-gradient(circle,var(--glow-primary) 0%,transparent 70%);transform:translate(-50%) translateY(-30%);pointer-events:none;opacity:.5}.hero__container{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-16);align-items:center;position:relative;z-index:1}.hero__content{max-width:600px}.hero__badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--bg-secondary);border:1px solid var(--border-visible);border-radius:var(--radius-full);margin-bottom:var(--space-6)}.hero__badge-dot{width:8px;height:8px;background:var(--accent-success);border-radius:var(--radius-full);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.hero__badge-text{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary)}.hero__title{margin-bottom:var(--space-6)}.hero__title-line{display:block;font-size:var(--text-2xl);font-weight:var(--font-medium);color:var(--text-secondary);margin-bottom:var(--space-2)}.hero__title-name{display:block;font-size:var(--text-6xl);font-weight:var(--font-extrabold);background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent-primary-light) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero__subtitle{font-size:var(--text-xl);color:var(--text-secondary);margin-bottom:var(--space-4);line-height:var(--leading-relaxed)}.hero__highlight{color:var(--accent-primary-light);font-weight:var(--font-semibold)}.hero__description{font-size:var(--text-base);color:var(--text-tertiary);margin-bottom:var(--space-8);line-height:var(--leading-relaxed)}.hero__cta{display:flex;gap:var(--space-4);flex-wrap:wrap}.hero__visual{display:flex;justify-content:center;align-items:center;position:relative}.hero__avatar{position:relative;width:420px;height:420px}.hero__avatar-ring{position:absolute;top:0;right:0;bottom:0;left:0;border:2px solid var(--border-visible);border-radius:var(--radius-full);animation:rotate 20s linear infinite}.hero__avatar-ring:before{content:"";position:absolute;top:-4px;left:50%;width:8px;height:8px;background:var(--accent-primary);border-radius:var(--radius-full);box-shadow:0 0 10px var(--accent-primary)}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.hero__avatar-inner{position:absolute;top:12px;right:12px;bottom:12px;left:12px;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;overflow:hidden}.hero__avatar-emoji{font-size:80px}.hero__avatar-image{width:100%;height:100%;object-fit:cover;border-radius:50%}.hero__scroll-hint{position:absolute;bottom:var(--space-8);left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:var(--space-2);color:var(--text-muted);font-size:var(--text-sm);animation:float 2s ease-in-out infinite}@keyframes float{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(-8px)}}.hero__scroll-arrow{width:24px;height:24px;border-right:2px solid var(--text-muted);border-bottom:2px solid var(--text-muted);transform:rotate(45deg)}.skills{background:var(--bg-secondary)}.skills__container{max-width:var(--container-max);margin:0 auto}.skills__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-8)}.skill-category{display:flex;flex-direction:column;gap:var(--space-4)}.skill-category__title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--accent-primary-light);padding-bottom:var(--space-3);border-bottom:2px solid var(--accent-primary);margin-bottom:var(--space-2)}.skill-category__list{display:flex;flex-direction:column;gap:var(--space-4)}.skill-card{background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);transition:all var(--transition-base);cursor:default}.skill-card:hover{border-color:var(--accent-primary);transform:translateY(-4px);box-shadow:0 0 30px var(--glow-primary)}.skill-card__header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-4)}.skill-card__icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:var(--radius-lg);font-size:var(--text-2xl)}.skill-card__title{font-size:var(--text-lg);font-weight:var(--font-semibold)}.skill-card__level{font-size:var(--text-sm);color:var(--text-muted)}.skill-card__bar{height:4px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.skill-card__bar-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-primary-light));border-radius:var(--radius-full);width:0;transition:width 1.5s cubic-bezier(.4,0,.2,1)}.projects__container{max-width:var(--container-max);margin:0 auto}.projects__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-8)}.project-card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-base);cursor:pointer}.project-card:hover{border-color:var(--border-visible);transform:translateY(-8px);box-shadow:var(--shadow-xl)}.project-card__image{position:relative;height:200px;background:var(--bg-tertiary);overflow:hidden;transition:height var(--transition-slow)}.project-card:hover .project-card__image{height:300px}.project-card__image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow),opacity var(--transition-base)}.project-card__thumbnail{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2}.project-card__video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0;z-index:1;transition:opacity var(--transition-base)}.project-card:hover .project-card__image img:not(.project-card__thumbnail){transform:scale(1.05)}.project-card__image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:48px;background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-elevated) 100%)}.project-card__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(0,0,0,.8) 0%,transparent 50%);opacity:0;transition:opacity var(--transition-base)}.project-card:hover .project-card__overlay{opacity:1}.project-card__content{padding:var(--space-6)}.project-card__title{font-size:var(--text-xl);font-weight:var(--font-semibold);margin-bottom:var(--space-2)}.project-card__description{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-4);line-height:var(--leading-relaxed)}.project-card__tags{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-4)}.project-card__links{display:flex;gap:var(--space-3)}.project-card__link{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--accent-primary-light);transition:color var(--transition-fast)}.project-card__link:hover{color:var(--text-primary)}.project-card__link svg{width:16px;height:16px}.contact{background:var(--bg-secondary)}.contact__container{max-width:var(--container-max);margin:0 auto}.contact__content{display:flex;justify-content:center}.contact__info{display:flex;flex-direction:column;gap:var(--space-8);max-width:500px;width:100%}.contact__info-card{background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-8);text-align:center}.contact__info-title{font-size:var(--text-xl);margin-bottom:var(--space-2)}.contact__info-text{font-size:var(--text-sm);color:var(--text-tertiary);margin-bottom:var(--space-6)}.contact__socials{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-3)}.contact__social-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:var(--font-medium);transition:all var(--transition-fast);cursor:pointer}.contact__social-link:hover{background:var(--bg-elevated);border-color:var(--border-visible);transform:translateY(-2px)}.contact__social-link svg{width:20px;height:20px;color:var(--text-secondary)}.contact__email-btn{position:relative;min-width:280px;justify-content:center}.contact__email-text{color:var(--text-primary);min-width:180px;text-align:left}.contact__email-copy{display:flex;align-items:center;justify-content:center;margin-left:var(--space-2);padding:var(--space-1);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.contact__email-copy:hover{background:var(--bg-secondary)}.contact__email-copy svg{width:16px;height:16px}.contact__email-btn.copied .contact__email-copy svg{color:var(--accent-success)}.contact__targets{background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6)}.contact__targets-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-secondary);margin-bottom:var(--space-4)}.contact__targets-list{display:flex;flex-wrap:wrap;gap:var(--space-2)}.contact__target{padding:var(--space-2) var(--space-4);background:var(--bg-tertiary);border:1px solid var(--accent-primary);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--accent-primary-light)}@media (max-width: 1024px){.hero__container{grid-template-columns:1fr;text-align:center}.hero__content{max-width:100%}.hero__cta{justify-content:center}.hero__visual{order:-1}.hero__avatar{width:200px;height:200px}.hero__avatar-emoji{font-size:60px}.skills__grid{grid-template-columns:repeat(2,1fr)}.projects__grid,.contact__content{grid-template-columns:1fr}}@media (max-width: 640px){.skills__grid{grid-template-columns:1fr}.hero__title-name{font-size:var(--text-4xl)}.hero__scroll-hint{display:none}}.experience{background:var(--bg-primary)}.experience__container{max-width:var(--container-max);margin:0 auto}.experience__timeline{display:flex;flex-direction:column;gap:var(--space-6)}.experience__card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-8);transition:border-color var(--transition-base),box-shadow var(--transition-base)}.experience__card:hover{border-color:var(--border-visible);box-shadow:0 8px 32px #0000004d}.experience__card-header{display:flex;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-6)}.experience__card-icon{font-size:2.5rem;line-height:1;flex-shrink:0}.experience__card-info{flex:1}.experience__card-title{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-1)}.experience__card-org{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--accent-primary-light);margin-bottom:var(--space-1)}.experience__card-org-link{color:inherit;text-decoration:none;display:inline-flex;align-items:center;gap:var(--space-2);transition:opacity var(--transition-base)}.experience__card-org-link:hover{opacity:.8}.experience__card-org-icon{width:18px;height:18px;opacity:.7;transition:opacity var(--transition-base)}.experience__card-org-link:hover .experience__card-org-icon{opacity:1}.experience__card-date{font-size:var(--text-sm);color:var(--text-tertiary)}.experience__card-body{padding-left:calc(2.5rem + var(--space-4))}.experience__card-description{font-size:var(--text-base);color:var(--text-secondary);line-height:var(--leading-relaxed);margin-bottom:var(--space-4)}.experience__card-highlights{list-style:none;padding:0;margin:0 0 var(--space-6) 0}.experience__card-highlights li{position:relative;padding-left:var(--space-5);font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);margin-bottom:var(--space-2)}.experience__card-highlights li:before{content:"▹";position:absolute;left:0;color:var(--accent-primary);font-weight:var(--font-bold)}.experience__card-tags{display:flex;flex-wrap:wrap;gap:var(--space-2)}.experience__tag{display:inline-block;padding:var(--space-1) var(--space-3);background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--text-secondary);font-family:var(--font-mono)}@media (max-width: 768px){.experience__card{padding:var(--space-6)}.experience__card-body{padding-left:0}.experience__card-header{flex-direction:column;gap:var(--space-3)}}.achievement-toast-container{position:fixed;top:calc(var(--header-height) + var(--progress-bar-height) + var(--space-4));right:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3);z-index:var(--z-toast);pointer-events:none}.achievement-toast{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-6);background:var(--bg-elevated);border:1px solid var(--accent-secondary);border-radius:var(--radius-xl);box-shadow:0 0 30px var(--glow-secondary);transform:translate(120%);opacity:0;animation:toastSlideIn .5s cubic-bezier(.34,1.56,.64,1) forwards;pointer-events:auto}.achievement-toast.removing{animation:toastSlideOut .3s ease forwards}@keyframes toastSlideIn{to{transform:translate(0);opacity:1}}@keyframes toastSlideOut{to{transform:translate(120%);opacity:0}}.achievement-toast__icon{font-size:var(--text-3xl);animation:iconBounce .6s ease .3s}@keyframes iconBounce{0%,to{transform:scale(1)}50%{transform:scale(1.3)}}.achievement-toast__content{flex:1}.achievement-toast__label{font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--accent-secondary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--space-1)}.achievement-toast__name{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary)}.achievement-panel{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);opacity:0;visibility:hidden;transition:all var(--transition-base)}.achievement-panel.active{opacity:1;visibility:visible}.achievement-panel__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.achievement-panel__content{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.9);width:90%;max-width:600px;max-height:80vh;background:var(--bg-secondary);border:1px solid var(--border-visible);border-radius:var(--radius-2xl);overflow:hidden;transition:transform var(--transition-bounce)}.achievement-panel.active .achievement-panel__content{transform:translate(-50%,-50%) scale(1)}.achievement-panel__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--border-subtle)}.achievement-panel__title{font-size:var(--text-2xl);font-weight:var(--font-bold)}.achievement-panel__close{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:var(--radius-lg);color:var(--text-secondary);transition:all var(--transition-fast)}.achievement-panel__close:hover{background:var(--bg-elevated);color:var(--text-primary)}.achievement-panel__close svg{width:20px;height:20px}.achievement-panel__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4);padding:var(--space-6);max-height:60vh;overflow-y:auto}.achievement-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.achievement-item.unlocked{border-color:var(--accent-secondary);box-shadow:0 0 15px var(--glow-secondary)}.achievement-item.locked{opacity:.5;filter:grayscale(.8)}.achievement-item__icon{font-size:var(--text-2xl);width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border-radius:var(--radius-lg)}.achievement-item.locked .achievement-item__icon{filter:blur(2px)}.achievement-item__info{flex:1}.achievement-item__name{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-1)}.achievement-item__description{font-size:var(--text-xs);color:var(--text-muted)}.achievement-item.unlocked .achievement-item__description{color:var(--text-secondary)}.game-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);opacity:0;visibility:hidden;transition:all var(--transition-base)}.game-modal.active{opacity:1;visibility:visible}.game-modal__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000e6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.game-modal__content{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.9);background:var(--bg-secondary);border:2px solid var(--accent-primary);border-radius:var(--radius-2xl);overflow:hidden;transition:transform var(--transition-bounce);box-shadow:0 0 50px var(--glow-primary)}.game-modal.active .game-modal__content{transform:translate(-50%,-50%) scale(1)}.game-modal__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-4) var(--space-6);background:var(--bg-tertiary);border-bottom:1px solid var(--border-subtle)}.game-modal__title{font-size:var(--text-xl);font-weight:var(--font-bold)}.game-modal__score{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--accent-secondary);font-family:var(--font-mono)}.game-modal__close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border-radius:var(--radius-lg);color:var(--text-secondary);transition:all var(--transition-fast)}.game-modal__close:hover{background:var(--accent-error);color:var(--text-primary)}.game-modal__close svg{width:18px;height:18px}.game-modal__board{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-2);padding:var(--space-6);background:var(--bg-primary)}.game-tile{width:60px;height:60px;display:flex;align-items:center;justify-content:center;font-size:var(--text-lg);font-weight:var(--font-bold);background:var(--bg-tertiary);border:2px solid var(--border-visible);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.game-tile:hover{transform:scale(1.05);z-index:1}.game-tile.selected{border-color:var(--accent-primary);box-shadow:0 0 15px var(--glow-primary);transform:scale(1.1)}.game-tile.matched{animation:tileMatch .3s ease forwards}@keyframes tileMatch{0%{transform:scale(1)}50%{transform:scale(1.2);opacity:.5}to{transform:scale(0);opacity:0}}.game-tile.falling{animation:tileFall .3s ease forwards}@keyframes tileFall{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.game-modal__footer{display:flex;justify-content:center;gap:var(--space-4);padding:var(--space-4) var(--space-6);background:var(--bg-tertiary);border-top:1px solid var(--border-subtle)}.game-win-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000000e6;z-index:10;animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.game-win-overlay__title{font-size:var(--text-4xl);font-weight:var(--font-extrabold);color:var(--accent-secondary);margin-bottom:var(--space-2);animation:winPulse 1s ease infinite}@keyframes winPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.game-win-overlay__score{font-size:var(--text-xl);color:var(--text-secondary);margin-bottom:var(--space-6)}.confetti{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:var(--z-toast);overflow:hidden}.confetti-piece{position:absolute;width:10px;height:10px;opacity:0;animation:confettiFall 3s ease-out forwards}@keyframes confettiFall{0%{opacity:1;transform:translateY(-100%) rotate(0)}to{opacity:0;transform:translateY(100vh) rotate(720deg)}}.achievement-item--boss{position:relative;background:linear-gradient(135deg,var(--bg-tertiary) 0%,rgba(239,68,68,.1) 100%);border-color:#ef44444d}.achievement-item--boss.locked{opacity:1;filter:none;cursor:pointer}.achievement-item--boss.locked:hover{border-color:#ef444499;box-shadow:0 0 20px #ef444433}.achievement-item--boss .achievement-item__icon{filter:none;animation:bossIconPulse 2s ease-in-out infinite}@keyframes bossIconPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.achievement-item__boss-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#ef444433;border:1px solid rgba(239,68,68,.4);border-radius:var(--radius-full);color:#ef4444;transition:all var(--transition-fast);flex-shrink:0}.achievement-item__boss-btn:hover{background:#ef444466;transform:translate(4px)}.achievement-item__boss-btn svg{width:20px;height:20px}.boss-confirm{position:fixed;top:0;right:0;bottom:0;left:0;z-index:calc(var(--z-modal) + 1);opacity:0;visibility:hidden;transition:all var(--transition-base)}.boss-confirm.active{opacity:1;visibility:visible}.boss-confirm__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000e6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.boss-confirm__content{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.9);width:90%;max-width:450px;padding:var(--space-10);background:linear-gradient(180deg,var(--bg-secondary) 0%,rgba(239,68,68,.05) 100%);border:2px solid rgba(239,68,68,.5);border-radius:var(--radius-2xl);text-align:center;transition:transform var(--transition-bounce);box-shadow:0 0 60px #ef44444d}.boss-confirm.active .boss-confirm__content{transform:translate(-50%,-50%) scale(1)}.boss-confirm__icon{font-size:4rem;margin-bottom:var(--space-4);animation:bossIconFloat 3s ease-in-out infinite}@keyframes bossIconFloat{0%,to{transform:translateY(0) rotate(-5deg)}50%{transform:translateY(-10px) rotate(5deg)}}.boss-confirm__title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-4)}.boss-confirm__text{font-size:var(--text-base);color:var(--text-secondary);line-height:var(--leading-relaxed);margin-bottom:var(--space-2)}.boss-confirm__achievement{color:#f59e0b;font-weight:var(--font-semibold)}.boss-confirm__question{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:var(--space-6) 0}.boss-confirm__buttons{display:flex;gap:var(--space-4);justify-content:center}.boss-confirm__btn{min-width:140px}.boss-game{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);opacity:0;visibility:hidden;transition:all var(--transition-base)}.boss-game.active{opacity:1;visibility:visible}.boss-game__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000f2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.boss-game__content{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.9);width:95%;max-width:800px;max-height:90vh;background:var(--bg-secondary);border:2px solid #ef4444;border-radius:var(--radius-2xl);overflow:hidden;transition:transform var(--transition-bounce);box-shadow:0 0 80px #ef444466}.boss-game.active .boss-game__content{transform:translate(-50%,-50%) scale(1)}.boss-game__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);background:linear-gradient(90deg,rgba(239,68,68,.2) 0%,transparent 100%);border-bottom:1px solid rgba(239,68,68,.3)}.boss-game__title{font-size:var(--text-xl);font-weight:var(--font-bold);color:#ef4444}.boss-game__close{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:var(--radius-lg);color:var(--text-secondary);transition:all var(--transition-fast)}.boss-game__close:hover{background:#ef44444d;color:#ef4444}.boss-game__close svg{width:20px;height:20px}.boss-game__arena{padding:var(--space-4);min-height:auto;display:flex;align-items:flex-start;justify-content:center}.boss-game__placeholder{font-size:var(--text-2xl);color:var(--text-muted)}.boss-game__coming-soon{text-align:center;padding:var(--space-8)}.boss-game__boss-icon{font-size:5rem;margin-bottom:var(--space-4);animation:bossTaunt 2s ease-in-out infinite}@keyframes bossTaunt{0%,to{transform:scale(1) rotate(0)}25%{transform:scale(1.1) rotate(-5deg)}75%{transform:scale(1.1) rotate(5deg)}}.boss-game__coming-soon h3{font-size:var(--text-2xl);font-weight:var(--font-bold);color:#ef4444;margin-bottom:var(--space-2)}.boss-game__coming-soon p{font-size:var(--text-base);color:var(--text-secondary)}.boss-battle{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-3);min-height:auto;max-height:calc(90vh - 60px);overflow-y:auto;position:relative}.boss-section{text-align:center;padding:var(--space-3);background:linear-gradient(180deg,rgba(239,68,68,.1) 0%,transparent 100%);border-radius:var(--radius-xl)}.boss-character{position:relative;display:inline-block;transition:transform .3s ease}.boss-emoji{font-size:4rem;animation:bossIdle 2s ease-in-out infinite;transition:transform .2s ease}@keyframes bossIdle{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.boss-phase-2 .boss-emoji{animation:bossAngry 1s ease-in-out infinite}.boss-phase-3 .boss-emoji{animation:bossFurious .5s ease-in-out infinite;filter:drop-shadow(0 0 10px #ef4444)}@keyframes bossAngry{0%,to{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-5px) rotate(2deg)}}@keyframes bossFurious{0%,to{transform:translateY(0) rotate(-5deg) scale(1.05)}50%{transform:translateY(-3px) rotate(5deg) scale(1.1)}}.boss-character.hit-small{animation:hitSmall .3s ease}.boss-character.hit-big{animation:hitBig .4s ease}.boss-character.hit-critical{animation:hitCritical .5s ease}@keyframes hitSmall{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@keyframes hitBig{0%,to{transform:translate(0) scale(1);filter:brightness(1)}50%{transform:translate(-10px) scale(.95);filter:brightness(2)}}@keyframes hitCritical{0%{transform:rotate(0) scale(1);filter:brightness(1)}25%{transform:rotate(-15deg) scale(.9);filter:brightness(3)}50%{transform:rotate(15deg) scale(.9);filter:brightness(2)}75%{transform:rotate(-10deg) scale(.95);filter:brightness(1.5)}to{transform:rotate(0) scale(1);filter:brightness(1)}}.boss-character.attacking{animation:bossAttack .6s ease}@keyframes bossAttack{0%{transform:translateY(0) scale(1)}30%{transform:translateY(-30px) scale(1.3)}60%{transform:translateY(20px) scale(1.4)}to{transform:translateY(0) scale(1)}}.boss-character.defeated{animation:bossDefeated 1s ease forwards}.boss-character.dying{animation:bossDying .4s ease forwards}.boss-character.dying .boss-emoji{animation:bossDying .4s ease forwards!important;filter:none!important}@keyframes bossDying{0%{transform:scale(1);filter:brightness(1)}50%{transform:scale(1.3);filter:brightness(3) saturate(0)}to{transform:scale(1.5);filter:brightness(5) saturate(0)}}.explosion-overlay{position:absolute;top:80px;left:50%;transform:translate(-50%);width:100px;height:100px;z-index:1000;pointer-events:none}.explosion-piece{position:absolute;top:50%;left:50%;font-size:var(--size, 1.5rem);transform:translate(-50%,-50%);animation:explosionPiecefly 1s cubic-bezier(.25,.46,.45,.94) forwards;animation-delay:var(--delay, 0s);z-index:1001;filter:drop-shadow(0 0 5px rgba(255,200,0,.8))}@keyframes explosionPiecefly{0%{transform:translate(-50%,-50%) scale(.5) rotate(0);opacity:1}15%{transform:translate(-50%,-50%) scale(2) rotate(30deg);opacity:1}to{transform:translate(calc(-50% + var(--x-move)),calc(-50% + var(--y-move))) scale(.3) rotate(720deg);opacity:0}}.central-boom{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:5rem;animation:centralBoomPulse .8s ease-out forwards;z-index:1002;filter:drop-shadow(0 0 20px rgba(255,100,0,1))}@keyframes centralBoomPulse{0%{transform:translate(-50%,-50%) scale(0);opacity:1}30%{transform:translate(-50%,-50%) scale(3);opacity:1}to{transform:translate(-50%,-50%) scale(5);opacity:0}}.boss-death-explosion{position:absolute;top:50px;left:50%;transform:translate(-50%);width:80px;height:80px;z-index:50;pointer-events:none}.death-piece{position:absolute;top:50%;left:50%;font-size:2rem;transform:translate(-50%,-50%);animation:deathPieceExplode .8s cubic-bezier(.25,.46,.45,.94) forwards;animation-delay:var(--delay, 0s);z-index:51;--x-move: 0px;--y-move: 0px}@keyframes deathPieceExplode{0%{transform:translate(-50%,-50%) scale(1.5) rotate(0);opacity:1}20%{transform:translate(-50%,-50%) scale(2) rotate(45deg);opacity:1}to{transform:translate(calc(-50% + var(--x-move)),calc(-50% + var(--y-move))) scale(.5) rotate(720deg);opacity:0}}.death-particles{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;height:100%;pointer-events:none;z-index:100}.death-particle{position:absolute;top:50%;left:50%;font-size:1.5rem;animation:deathParticle var(--duration) ease forwards;animation-delay:var(--delay);opacity:0}@keyframes deathParticle{0%{transform:translate(-50%,-50%) scale(0);opacity:1}20%{transform:translate(-50%,-50%) scale(1.5);opacity:1}to{transform:translate(calc(-50% + var(--x)),calc(-50% + var(--y))) rotate(var(--r)) scale(0);opacity:0}}.boss-battle.victory-flash:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#fff;z-index:200;animation:victoryFlash .6s ease forwards;border-radius:var(--radius-xl)}@keyframes victoryFlash{0%{opacity:1}to{opacity:0}}.victory-sparkles{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none}.victory-sparkle{position:absolute;animation:sparkle 2s ease-in-out infinite}@keyframes sparkle{0%,to{opacity:0;transform:scale(0) rotate(0)}50%{opacity:1;transform:scale(1) rotate(180deg)}}@keyframes bossDefeated{0%{transform:rotate(0) scale(1);opacity:1}50%{transform:rotate(720deg) scale(.5);opacity:.5}to{transform:rotate(1080deg) scale(0);opacity:0}}.boss-info{margin-top:var(--space-2)}.boss-name{font-size:var(--text-lg);font-weight:var(--font-bold);color:#ef4444;margin-bottom:var(--space-2)}.boss-hp-bar{position:relative;height:24px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden;border:2px solid rgba(239,68,68,.3);max-width:300px;margin:0 auto}.boss-hp-fill{height:100%;background:linear-gradient(90deg,#ef4444,#f97316);border-radius:var(--radius-full);transition:width .3s ease}.boss-hp-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:var(--font-bold);color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}.boss-quote{font-size:var(--text-sm);font-style:italic;color:var(--text-muted);margin-top:var(--space-2)}.boss-turn-warning{margin-top:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary);padding:var(--space-2) var(--space-4);background:var(--bg-tertiary);border-radius:var(--radius-lg);display:inline-block}.boss-turn-warning.danger{color:#ef4444;background:#ef444433;animation:dangerPulse .5s ease infinite}@keyframes dangerPulse{0%,to{opacity:1}50%{opacity:.6}}.boss-grid-container{position:relative;display:flex;justify-content:center;overflow:hidden}.boss-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;padding:var(--space-4);background:var(--bg-tertiary);border-radius:var(--radius-xl);border:2px solid var(--border-visible);overflow:hidden}.boss-tile{width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:var(--bg-secondary);border-radius:var(--radius-lg);cursor:pointer;transition:all .15s ease;-webkit-user-select:none;user-select:none}.boss-tile:hover{transform:scale(1.1);background:var(--bg-elevated)}.boss-tile.selected{transform:scale(1.15);box-shadow:0 0 15px var(--accent-primary),0 0 30px var(--accent-primary);animation:tileSelected .5s ease infinite}@keyframes tileSelected{0%,to{box-shadow:0 0 15px var(--accent-primary)}50%{box-shadow:0 0 25px var(--accent-primary),0 0 40px var(--accent-primary)}}.boss-tile.popping{animation:tilePop .3s ease forwards}@keyframes tilePop{0%{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.5}to{transform:scale(0);opacity:0}}.boss-tile.dropping{animation:tileDropDown calc(.15s + var(--drop-distance) * .05s) cubic-bezier(.34,1.56,.64,1) var(--anim-delay) both}@keyframes tileDropDown{0%{transform:translateY(calc(var(--drop-distance) * -52px));opacity:.8}60%{transform:translateY(4px);opacity:1}80%{transform:translateY(-2px)}to{transform:translateY(0);opacity:1}}.boss-tile.spawning{animation:tileSpawnDrop calc(.2s + var(--drop-distance) * .04s) cubic-bezier(.34,1.56,.64,1) var(--anim-delay) both}@keyframes tileSpawnDrop{0%{transform:translateY(calc(var(--drop-distance) * -52px)) scale(.5);opacity:0}30%{opacity:1;transform:translateY(calc(var(--drop-distance) * -26px)) scale(.9)}70%{transform:translateY(6px) scale(1.05)}85%{transform:translateY(-3px) scale(.98)}to{transform:translateY(0) scale(1);opacity:1}}.combo-display{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);font-size:var(--text-3xl);font-weight:var(--font-extrabold);color:#f59e0b;text-shadow:0 0 20px #f59e0b,0 2px 4px rgba(0,0,0,.5);pointer-events:none;opacity:0;z-index:10}.combo-display.active{animation:comboShow .8s ease forwards}.combo-display.pop{animation:comboPop .3s ease}@keyframes comboShow{0%{transform:translate(-50%,-50%) scale(0);opacity:0}20%{transform:translate(-50%,-50%) scale(1.2);opacity:1}80%{transform:translate(-50%,-50%) scale(1);opacity:1}to{transform:translate(-50%,-50%) scale(.8);opacity:0}}@keyframes comboPop{0%,to{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.3)}}.player-section{display:flex;justify-content:center;align-items:center;gap:var(--space-6);padding:var(--space-4);background:var(--bg-secondary);border-radius:var(--radius-xl);transition:all .2s ease}.player-section.hit{animation:playerHit .4s ease}@keyframes playerHit{0%,to{background:var(--bg-secondary);transform:translate(0)}25%{background:#ef44444d;transform:translate(-5px)}75%{background:#ef444433;transform:translate(5px)}}.player-hearts{font-size:var(--text-2xl);letter-spacing:4px}.damage-dealt{font-size:var(--text-sm);color:var(--text-secondary);font-weight:var(--font-medium)}.boss-battle.player-hurt:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#ef44444d;pointer-events:none;animation:hurtFlash .4s ease forwards;border-radius:var(--radius-xl);z-index:100}@keyframes hurtFlash{0%{opacity:1}to{opacity:0}}.damage-numbers{position:absolute;top:80px;left:0;right:0;pointer-events:none;z-index:50}.damage-number{position:absolute;font-size:var(--text-xl);font-weight:var(--font-extrabold);color:#ef4444;animation:damageFloat 1s ease forwards;text-shadow:0 2px 4px rgba(0,0,0,.5)}.damage-number.big{font-size:var(--text-2xl);color:#f97316}.damage-number.critical{font-size:var(--text-3xl);color:#fbbf24;text-shadow:0 0 20px #fbbf24,0 2px 4px rgba(0,0,0,.5)}@keyframes damageFloat{0%{transform:translateY(0) scale(.5);opacity:0}20%{transform:translateY(-20px) scale(1.2);opacity:1}80%{transform:translateY(-60px) scale(1);opacity:1}to{transform:translateY(-80px) scale(.8);opacity:0}}.boss-battle.shake-small{animation:shakeSmall .4s ease}.boss-battle.shake-big{animation:shakeBig .4s ease}@keyframes shakeSmall{0%,to{transform:translate(0)}20%{transform:translate(-3px)}40%{transform:translate(3px)}60%{transform:translate(-2px)}80%{transform:translate(2px)}}@keyframes shakeBig{0%,to{transform:translate(0)}10%{transform:translate(-8px,-4px)}20%{transform:translate(8px,4px)}30%{transform:translate(-6px,-2px)}40%{transform:translate(6px,2px)}50%{transform:translate(-4px,-1px)}60%{transform:translate(4px,1px)}70%{transform:translate(-2px)}80%{transform:translate(2px)}}.shake-invalid{animation:shakeInvalid .3s ease}@keyframes shakeInvalid{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.boss-victory{position:relative;text-align:center;padding:var(--space-10);min-height:400px;display:flex;align-items:center;justify-content:center}.victory-confetti{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none}.victory-content{position:relative;z-index:1}.victory-emoji{font-size:5rem;animation:victoryBounce 1s ease infinite}@keyframes victoryBounce{0%,to{transform:translateY(0) rotate(-5deg)}50%{transform:translateY(-20px) rotate(5deg)}}.victory-title{font-size:var(--text-4xl);font-weight:var(--font-extrabold);background:linear-gradient(135deg,#fbbf24,#f59e0b,#ef4444);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:var(--space-4) 0;animation:victoryPulse 1s ease infinite}@keyframes victoryPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.victory-text{font-size:var(--text-lg);color:var(--text-secondary);margin-bottom:var(--space-2)}.victory-damage{font-size:var(--text-base);color:var(--text-muted);margin-bottom:var(--space-6)}.victory-achievement{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);background:linear-gradient(135deg,#fbbf2433,#f59e0b33);border:2px solid #f59e0b;border-radius:var(--radius-full);margin-bottom:var(--space-6);animation:achievementGlow 2s ease infinite}@keyframes achievementGlow{0%,to{box-shadow:0 0 20px #f59e0b4d}50%{box-shadow:0 0 40px #f59e0b99}}.victory-achievement-icon{font-size:var(--text-xl)}.victory-achievement-text{font-size:var(--text-sm);font-weight:var(--font-semibold);color:#f59e0b}.victory-btn{margin-top:var(--space-4)}.boss-defeat{text-align:center;padding:var(--space-10);min-height:400px;display:flex;align-items:center;justify-content:center}.defeat-emoji{font-size:5rem;animation:defeatShake 2s ease infinite}@keyframes defeatShake{0%,to{transform:rotate(0)}25%{transform:rotate(-5deg)}75%{transform:rotate(5deg)}}.defeat-title{font-size:var(--text-4xl);font-weight:var(--font-extrabold);color:#6b7280;margin:var(--space-4) 0}.defeat-text{font-size:var(--text-lg);color:var(--text-secondary);margin-bottom:var(--space-2)}.defeat-damage{font-size:var(--text-base);color:var(--text-muted);margin-bottom:var(--space-6)}.defeat-buttons{display:flex;gap:var(--space-4);justify-content:center}@media (max-width: 640px){.boss-tile{width:40px;height:40px;font-size:1.2rem}.boss-grid{gap:3px;padding:var(--space-3)}.boss-emoji{font-size:3rem}.boss-battle{padding:var(--space-2);gap:var(--space-2);max-height:calc(100vh - 80px)}.boss-section{padding:var(--space-2)}.player-section{flex-direction:row;gap:var(--space-4);padding:var(--space-3);position:sticky;bottom:0;background:var(--bg-secondary);border-top:1px solid var(--border-subtle);margin:0 calc(var(--space-2) * -1);margin-bottom:calc(var(--space-2) * -1);border-radius:0}.player-hearts{font-size:var(--text-xl)}.defeat-buttons{flex-direction:column}}@media (max-width: 640px){.achievement-panel__grid{grid-template-columns:1fr}.game-tile{width:50px;height:50px;font-size:var(--text-base)}.game-modal__board{padding:var(--space-4);gap:var(--space-1)}.boss-confirm__content{padding:var(--space-6)}.boss-confirm__buttons{flex-direction:column}.boss-confirm__btn{width:100%}}
