@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";*{box-sizing:border-box}html,body{height:100%;margin:0;scroll-behavior:smooth}img{max-width:100%;display:block}button,input,textarea{font:inherit;border:none;background:none}:root,.dark{--color-bg: #080b14;--color-surface: #0f1629;--color-surface-hover: #162040;--color-border: #1e2d4a;--color-border-accent: #2a3f6f;--color-primary: #4f7cff;--color-primary-hover: #6b93ff;--color-primary-glow: rgba(79, 124, 255, .25);--color-secondary: #00e5b0;--color-secondary-hover: #00ffca;--color-secondary-glow: rgba(0, 229, 176, .2);--color-text-primary: #e8edf8;--color-text-secondary: #8b9ab8;--color-text-muted: #4a5a7a;--color-error: #ff4d6d;--color-success: #00e5b0;--color-warning: #ffb347;--font-family-base: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;--font-family-mono: "JetBrains Mono", "Fira Code", monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-size-5xl: 3rem;--font-size-6xl: 3.75rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.1;--line-height-base: 1.6;--line-height-relaxed: 1.75;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--space-4xl: 6rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 4px 16px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .6);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease;--color-gradient-a: rgba(30, 0, 60, .6);--color-gradient-b: rgba(0, 30, 50, .5)}.light{--color-bg: #f4f6fc;--color-surface: #ffffff;--color-surface-hover: #eef1fa;--color-border: #dde3f0;--color-border-accent: #c4cfe8;--color-primary: #3d6be8;--color-primary-hover: #2d5bd4;--color-primary-glow: rgba(61, 107, 232, .15);--color-secondary: #00b890;--color-secondary-hover: #009e7a;--color-secondary-glow: rgba(0, 184, 144, .15);--color-text-primary: #0d1530;--color-text-secondary: #4a5a7a;--color-text-muted: #8b9ab8;--color-error: #d63651;--color-success: #00b890;--color-warning: #e09030;--color-gradient-a: rgba(180, 200, 255, .4);--color-gradient-b: rgba(180, 240, 220, .3)}*,*:before,*:after{transition:background-color .35s ease,border-color .35s ease,color .25s ease,box-shadow .35s ease!important}img,canvas,video,.carousel__container,.carousel__viewport{transition:none!important}html{color-scheme:dark;scroll-behavior:smooth}html.light{color-scheme:light}body{font-family:var(--font-family-base);font-size:var(--font-size-base);font-weight:var(--font-weight-normal);line-height:var(--line-height-base);color:var(--color-text-primary);background-color:var(--color-bg);background-image:radial-gradient(600px 500px at 90% 0,var(--color-gradient-a) 0%,transparent 70%),radial-gradient(600px 500px at 10% 0,var(--color-gradient-b) 0%,transparent 70%);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh}#app{width:100%;height:100%}.page-container{display:flex;flex-direction:column;height:100%}.center-page-content{display:flex;flex-direction:column;align-items:center}.skip-link{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden}.skip-link:focus{position:fixed;left:var(--space-md);top:var(--space-md);width:auto;height:auto;background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border-accent);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-weight:var(--font-weight-medium);z-index:9999}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);color:var(--color-text-primary)}p{color:var(--color-text-secondary);line-height:var(--line-height-base)}a{color:var(--color-primary);text-decoration:none}a:hover{color:var(--color-primary-hover)}code,pre,.mono{font-family:var(--font-family-mono);font-size:var(--font-size-sm)}.me-image{width:200px;height:180px;border-radius:var(--radius-full);object-fit:contain;margin-bottom:var(--space-lg)}.intro-text{max-width:100%;overflow-x:hidden}.intro-text h1{font-size:var(--font-size-4xl);line-height:var(--line-height-tight);margin-bottom:var(--space-xs)}.intro-text h2{font-size:var(--font-size-xl);line-height:1.45;font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:var(--space-sm)}.intro-text p.muted{font-size:var(--font-size-base);line-height:var(--line-height-base);color:var(--color-text-muted);margin:var(--space-xs) 0}@media (max-width: 768px){.intro-text h1{font-size:var(--font-size-2xl)}.intro-text h2{font-size:var(--font-size-lg)}.intro-text p.muted{font-size:var(--font-size-sm)}}.row{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:center}.col{display:flex;flex-direction:column}.center-col-h{justify-self:center;align-items:center}.align-bottom{align-items:end}.w-full{width:100%}.text-center{text-align:center}.mt-10{margin-top:10px}.relative{position:relative}.px-2rem{padding-right:2rem;padding-left:2rem}.pt-2rem{padding-top:2rem}.pb-2rem{padding-bottom:2rem}.layout{display:flex;flex-direction:column;overflow:auto;height:100%;padding:var(--space-lg)}main{height:100%;display:flex}.site-header,.site-footer{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-md) var(--space-lg);max-width:1200px;margin:0 auto;width:100%}.site-footer{color:var(--color-text-muted);font-size:var(--font-size-sm)}.navigation-app{position:fixed;bottom:var(--space-lg);width:100%;display:flex;justify-content:center;z-index:100;pointer-events:none}.navigation-app-container{pointer-events:all;background:var(--color-surface);-webkit-backdrop-filter:blur(20px) saturate(150%);backdrop-filter:blur(20px) saturate(150%);border:1px solid var(--color-border-accent);border-radius:var(--radius-xl);width:clamp(260px,50%,480px);box-shadow:var(--shadow-lg);transition:transform var(--transition-base),box-shadow var(--transition-base)}@media (hover: hover) and (pointer: fine){.navigation-app-container:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg),0 0 24px var(--color-primary-glow)}}.navigation-app-container nav{width:100%;padding:0 var(--space-lg)}#portfolio-nav ul{display:flex;align-items:center;justify-content:space-around;list-style:none;margin:0;padding:0;gap:var(--space-sm);height:60px}#portfolio-nav a{position:relative;display:inline-flex;align-items:center;justify-content:center;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-full);color:var(--color-text-secondary);text-decoration:none;font-size:var(--font-size-xl);transition:color var(--transition-fast),background-color var(--transition-fast)}#portfolio-nav a:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}#portfolio-nav a:not(.logo):after{content:"";position:absolute;bottom:4px;left:50%;transform:translate(-50%) scaleX(0);width:60%;height:2px;background:var(--color-primary);border-radius:var(--radius-full);opacity:0;transition:transform var(--transition-base),opacity var(--transition-base)}#portfolio-nav a.active:not(.logo):after,#portfolio-nav a[aria-current=page]:not(.logo):after{transform:translate(-50%) scaleX(1);opacity:1}#portfolio-nav a.active:not(.logo),#portfolio-nav a[aria-current=page]:not(.logo){color:var(--color-primary)}#portfolio-nav a.logo{position:relative;padding:2px;border-radius:var(--radius-full);border:1px solid transparent;z-index:2}#portfolio-nav a.logo:after{content:"";position:absolute;top:-6px;right:-6px;bottom:-6px;left:-6px;border-radius:var(--radius-full);border:2px solid var(--color-primary);opacity:0;transform:scale(.85);transition:opacity var(--transition-base),transform var(--transition-base),box-shadow var(--transition-base);pointer-events:none}#portfolio-nav a.logo[aria-current=page]:after{opacity:1;transform:scale(1);box-shadow:0 0 16px var(--color-primary-glow);animation:logoPulse 2.2s ease-in-out infinite}#portfolio-nav a.logo[aria-current=page] img{box-shadow:0 0 20px var(--color-primary-glow)}.nav-logo{width:36px;height:36px;border-radius:var(--radius-full);object-fit:cover;position:relative;z-index:3;transition:box-shadow var(--transition-base)}@keyframes logoPulse{0%,to{box-shadow:0 0 16px var(--color-primary-glow);transform:scale(.92)}50%{box-shadow:0 0 28px var(--color-primary-glow);transform:scale(1)}}@media (max-width: 768px){.navigation-app{bottom:var(--space-md)}.navigation-app-container{width:90%;border-radius:var(--radius-lg)}#portfolio-nav ul{height:56px;padding:0 var(--space-sm)}#portfolio-nav a:not(.logo){padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-lg)}.nav-logo{width:30px;height:30px}}.nav-logo,.icon-home{filter:none;transition:filter var(--transition-base),opacity var(--transition-base)}.light .nav-logo,.light .icon-home{filter:invert(1) hue-rotate(180deg)}.light #linkedin .icon-home,.light #linkedin .nav-logo{filter:none}.carousel{position:relative;overflow:hidden;border-radius:var(--radius-xl);background:var(--color-surface);border:1px solid var(--color-border)}.carousel__viewport{overflow:hidden;touch-action:pan-y pinch-zoom;will-change:transform;height:100%}.carousel__container{display:flex;height:100%;width:100%}.slide{flex:0 0 100%;height:100%;display:grid;grid-template-columns:1fr;gap:var(--space-md);align-items:start;padding:clamp(var(--space-lg),5vw,var(--space-2xl)) clamp(var(--space-lg),5vw,var(--space-2xl)) calc(clamp(var(--space-lg),5vw,var(--space-2xl)) + 20px);overflow-y:auto;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.slide h1,.slide h2{margin:.2rem 0}.kpi{display:flex;gap:var(--space-md);flex-wrap:wrap}@media (max-width: 768px){.slide{padding-bottom:calc(72px + var(--space-xl))}}.home{display:flex;flex-direction:column}.home__hero,.home__value,.home__services,.home__final-cta{padding:clamp(var(--space-3xl),12vw,var(--space-4xl)) clamp(var(--space-md),6vw,var(--space-3xl))}.home__hero{display:flex;align-items:center;justify-content:center;text-align:center;min-height:80vh;background:radial-gradient(circle at 50% 30%,var(--color-primary-glow),transparent 60%)}.home__hero-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg);max-width:760px}.home__badge{display:inline-block;font-family:var(--font-family-mono);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);letter-spacing:.12em;text-transform:uppercase;color:var(--color-primary);background:var(--color-primary-glow);border:1px solid var(--color-primary);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full)}.home__title{font-size:clamp(var(--font-size-3xl),5vw,var(--font-size-6xl));font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);color:var(--color-text-primary);margin:0}.home__subtitle{font-size:var(--font-size-lg);color:var(--color-text-secondary);line-height:var(--line-height-relaxed);max-width:560px;margin:0}.home__cta{display:flex;gap:var(--space-md);flex-wrap:wrap;justify-content:center;margin-top:var(--space-sm)}.home__value{text-align:center;max-width:800px;margin-inline:auto}.home__value-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--space-md)}.home__value-desc{font-size:var(--font-size-lg);color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin:0}.home__services{display:flex;flex-direction:column;gap:var(--space-2xl)}.home__section-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);text-align:center;margin:0}.home__service-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--space-lg);max-width:1100px;margin-inline:auto;width:100%}.service-card{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-xl);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:border-color var(--transition-base),box-shadow var(--transition-base),transform var(--transition-base)}@media (hover: hover) and (pointer: fine){.service-card:hover{transform:translateY(-4px);border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary),0 8px 32px var(--color-primary-glow)}}.service-card__icon{font-size:var(--font-size-2xl);color:var(--color-primary);line-height:1}.service-card__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.service-card__desc{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:var(--line-height-base);margin:0}.home__final-cta{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);text-align:center;background:radial-gradient(circle at 50% 50%,var(--color-secondary-glow),transparent 65%);border-top:1px solid var(--color-border)}.home__final-cta-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.home__final-cta-desc{font-size:var(--font-size-lg);color:var(--color-text-secondary);max-width:500px;margin:0}.home__footer{padding:var(--space-2xl) var(--space-xl);text-align:center;border-top:1px solid var(--color-border);color:var(--color-text-muted);font-size:var(--font-size-sm);display:flex;flex-direction:column;gap:var(--space-sm)}.home__legal-links{display:flex;align-items:center;justify-content:center;gap:var(--space-sm)}.home__legal-links a{color:var(--color-text-muted);transition:color var(--transition-fast)}.home__legal-links a:hover{color:var(--color-text-primary)}@media (max-width: 768px){.home__hero{min-height:70vh}.home__cta{flex-direction:column;align-items:center}.home__value-title,.home__section-title,.home__final-cta-title{font-size:var(--font-size-2xl)}.home__service-grid{grid-template-columns:1fr}}.portfolio-home{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:var(--space-lg);padding:var(--space-2xl) var(--space-md);min-height:100%}.portfolio-home__avatar{width:160px;height:160px;border-radius:var(--radius-full);object-fit:cover;border:2px solid var(--color-border-accent);box-shadow:0 0 32px var(--color-primary-glow);transition:box-shadow var(--transition-base)}.portfolio-home__avatar:hover{box-shadow:0 0 48px var(--color-primary-glow)}.portfolio-home__intro{display:flex;flex-direction:column;gap:var(--space-sm);max-width:560px}.portfolio-home__name{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0;line-height:var(--line-height-tight)}.portfolio-home__role{font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin:0;line-height:var(--line-height-base)}.portfolio-home__stack{font-size:var(--font-size-sm);font-family:var(--font-family-mono);color:var(--color-text-secondary);margin:0;line-height:var(--line-height-relaxed)}.portfolio-home__bio{font-size:var(--font-size-base);color:var(--color-text-muted);margin:0;line-height:var(--line-height-relaxed)}.portfolio-home__links{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:center;gap:var(--space-sm);margin-top:var(--space-sm)}@media (max-width: 768px){.portfolio-home__name{font-size:var(--font-size-2xl)}.portfolio-home__role{font-size:var(--font-size-base)}.portfolio-home__avatar{width:120px;height:120px}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-xl);border-radius:var(--radius-md);border:1px solid transparent;font-family:var(--font-family-base);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);line-height:1;text-decoration:none;cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.btn:active{transform:translateY(0)!important}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px}.btn.primary,.btn--primary{background:var(--color-primary);color:#fff;border-color:transparent}.btn.primary:hover,.btn--primary:hover{background:var(--color-primary-hover);box-shadow:0 4px 20px var(--color-primary-glow);transform:translateY(-1px)}.btn.ghost,.btn.secondary,.btn--secondary{background:transparent;color:var(--color-text-primary);border-color:var(--color-border-accent)}.btn.ghost:hover,.btn.secondary:hover,.btn--secondary:hover{border-color:var(--color-primary);background:var(--color-primary-glow);transform:translateY(-1px)}.btn-transparent{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:1px solid transparent;font-family:var(--font-family-base);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary);background:transparent;text-decoration:none;cursor:pointer;transition:border-color var(--transition-fast),background-color var(--transition-fast),transform var(--transition-fast)}.btn-transparent:hover{border-color:var(--color-primary);background:var(--color-primary-glow);transform:translateY(-1px)}.btn-transparent:active{transform:translateY(0)}.btn-transparent:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px}.btn.large,.btn--large{padding:var(--space-md) var(--space-2xl);font-size:var(--font-size-lg);border-radius:var(--radius-lg)}.btn.small,.btn--small{padding:var(--space-xs) var(--space-md);font-size:var(--font-size-sm)}.chip{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);border:1px solid var(--color-border-accent);border-radius:var(--radius-full);color:var(--color-text-muted);font-size:var(--font-size-xs);font-family:var(--font-family-mono);line-height:1;transition:border-color var(--transition-fast),color var(--transition-fast)}.chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.card-grid{display:grid;grid-template-columns:repeat(2,minmax(260px,1fr));gap:var(--space-lg);padding:var(--space-md) 0}@media (max-width: 768px){.card-grid{grid-template-columns:1fr;gap:var(--space-md);padding:var(--space-sm) 0}}.card{position:relative;display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-lg);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:border-color var(--transition-base),box-shadow var(--transition-base),transform var(--transition-base)}@media (hover: hover) and (pointer: fine){.card:hover{transform:translateY(-4px);border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary),0 8px 32px var(--color-primary-glow)}}.card h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.card .tagline{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.card .desc{font-size:var(--font-size-base);line-height:var(--line-height-base);color:var(--color-text-secondary);margin:0}.card .tags{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin:var(--space-xs) 0}.card .meta{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:var(--space-sm)}.card .role{font-size:var(--font-size-sm);color:var(--color-text-muted)}.card .status{font-size:var(--font-size-xs);font-family:var(--font-family-mono);color:var(--color-primary)}@media (max-width: 768px){.card{padding:var(--space-md);border-radius:var(--radius-md);gap:var(--space-xs)}.card h3{font-size:var(--font-size-base)}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity var(--transition-base);z-index:999}.modal-backdrop.active{opacity:1;pointer-events:all}.modal{position:relative;background:var(--color-surface);border:1px solid var(--color-border-accent);width:80%;max-width:760px;height:80%;padding:0;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow-y:auto}.modal .close{position:absolute;top:var(--space-md);right:var(--space-lg);color:var(--color-text-secondary);font-size:var(--font-size-xl);cursor:pointer;transition:color var(--transition-fast);z-index:20}.modal .close:hover{color:var(--color-text-primary)}.modal-header{position:sticky;top:0;z-index:10;background:var(--color-surface);border-bottom:1px solid var(--color-border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:var(--space-lg) var(--space-xl) var(--space-md)}.modal-header__title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--space-xs)}.modal-header__tagline{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.modal-desc{padding:var(--space-md) var(--space-xl);color:var(--color-text-secondary);line-height:var(--line-height-relaxed)}.modal-stack{display:flex;flex-wrap:wrap;gap:var(--space-xs);padding:0 var(--space-xl) var(--space-md)}.modal-section{padding:var(--space-md) var(--space-xl);border-top:1px solid var(--color-border)}.modal-section__title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-primary);margin:0 0 var(--space-sm);font-family:var(--font-family-mono);text-transform:uppercase;letter-spacing:.08em}.modal-section p{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin:0}.modal-section__list{padding-left:var(--space-lg);margin:0;display:flex;flex-direction:column;gap:var(--space-xs)}.modal-section__list li{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-base)}.modal-actions{display:flex;gap:var(--space-sm);padding:var(--space-lg) var(--space-xl) var(--space-xl);border-top:1px solid var(--color-border)}.is-disabled{opacity:.4;cursor:not-allowed;pointer-events:none;filter:grayscale(1)}.modal-carousel{position:relative;overflow:hidden;border-radius:var(--radius-lg);margin:var(--space-md) var(--space-xl);border:1px solid var(--color-border)}.modal-carousel__track{display:flex;transition:transform var(--transition-slow);width:100%}.modal-carousel__item{flex:0 0 100%;display:flex;justify-content:center;align-items:center}.modal-carousel img,.modal-carousel video{width:100%;border-radius:var(--radius-md);object-fit:contain;max-height:360px}.modal-carousel__btn{position:absolute;top:50%;transform:translateY(-50%);background:#00000080;border:1px solid var(--color-border-accent);color:var(--color-text-primary);font-size:var(--font-size-2xl);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-md);cursor:pointer;z-index:10;transition:background-color var(--transition-fast),border-color var(--transition-fast)}.modal-carousel__btn:hover{background:var(--color-surface-hover);border-color:var(--color-primary)}.modal-carousel__btn--prev{left:var(--space-sm)}.modal-carousel__btn--next{right:var(--space-sm)}.modal-carousel:fullscreen{background:#000;display:flex;justify-content:center;align-items:center}.modal-carousel:fullscreen .modal-carousel__track{height:100vh}.modal-carousel:fullscreen .modal-carousel__item{display:flex;justify-content:center;align-items:center}.modal-carousel:fullscreen img,.modal-carousel:fullscreen video{width:auto!important;height:auto!important;max-width:100vw!important;max-height:100vh!important;object-fit:contain!important}@media (max-width: 768px){.modal{width:95%;height:90%;border-radius:var(--radius-lg)}.modal-header,.modal-desc,.modal-stack,.modal-section,.modal-actions{padding-left:var(--space-md);padding-right:var(--space-md)}.modal-carousel{margin-left:var(--space-md);margin-right:var(--space-md)}}.toast-container{position:fixed;top:var(--space-lg);right:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-sm);z-index:2000;pointer-events:none}.toast{background:var(--color-surface);border:1px solid var(--color-primary);color:var(--color-text-primary);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);box-shadow:var(--shadow-md),0 0 12px var(--color-primary-glow);opacity:0;transform:translateY(-12px);animation:toastIn .3s ease forwards,toastOut .4s ease 2.5s forwards;pointer-events:all}@keyframes toastOut{to{opacity:0;transform:translateY(-8px)}}@media (max-width: 768px){.toast-container{top:var(--space-md);right:var(--space-md);left:var(--space-md)}.toast{text-align:center}}.icon-home{max-width:100%;max-height:100%}.icon-wrapper{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;will-change:transform;animation:buzzX var(--buzz-duration, 15s) ease-in-out infinite;animation-delay:var(--buzz-delay, 0s)}.icon-wrapper img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;will-change:transform;animation:floatY var(--float-duration, 18s) ease-in-out infinite;animation-delay:var(--float-delay, 0s);transform-origin:center}@media (max-width: 768px){.icon-wrapper{width:34px;height:34px}}.about{display:flex;flex-direction:column;gap:var(--space-2xl);max-width:720px;margin-inline:auto;width:100%}.about__header{display:flex;flex-direction:column;gap:var(--space-sm)}.about__badge{display:inline-block;font-family:var(--font-family-mono);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);letter-spacing:.12em;text-transform:uppercase;color:var(--color-secondary);background:var(--color-secondary-glow);border:1px solid var(--color-secondary);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);width:fit-content}.about__title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0;line-height:var(--line-height-tight)}.about__body{display:flex;flex-direction:column;gap:var(--space-md)}.about__body p{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin:0}.about__body strong{color:var(--color-primary);font-weight:var(--font-weight-semibold)}.about__stats{display:flex;gap:var(--space-lg);flex-wrap:wrap;padding-top:var(--space-lg);border-top:1px solid var(--color-border)}.about__stat{display:flex;flex-direction:column;gap:var(--space-xs)}.about__stat-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-primary);font-family:var(--font-family-mono);line-height:1}.about__stat-label{font-size:var(--font-size-sm);color:var(--color-text-muted)}@media (max-width: 768px){.about__title{font-size:var(--font-size-xl)}.about__stats{gap:var(--space-xl)}.about__stat-value{font-size:var(--font-size-2xl)}}#skills-area{position:relative;width:100%;height:100%}#skills-orbital{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1}#skills-orbital canvas{position:absolute;z-index:1}#skills-bubbles{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;pointer-events:none}.bubble{position:absolute;top:-20px;left:50%;width:85%;max-width:820px;opacity:0;pointer-events:none;transform:translate(-50%) translateY(-20px) scale(.95);background:color-mix(in srgb,var(--color-surface) 80%,transparent);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-radius:var(--radius-xl);border:1px solid var(--color-border-accent);padding:0;overflow:hidden;z-index:15;transition:opacity var(--transition-base),transform var(--transition-base),padding var(--transition-base)}.bubble.active{opacity:1;pointer-events:auto;transform:translate(-50%) translateY(0) scale(1);padding:var(--space-lg) var(--space-2xl)}.bubble ul{margin:0;padding:0;list-style:none;display:grid;grid-template-columns:repeat(2,minmax(200px,1fr));gap:var(--space-sm) var(--space-xl)}.bubble li{opacity:0;transform:translateY(10px);color:var(--color-text-secondary);font-size:var(--font-size-sm);padding-left:var(--space-md);position:relative;transition:opacity var(--transition-base),transform var(--transition-base)}.bubble li:before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;border-radius:var(--radius-full);background:var(--color-secondary);box-shadow:0 0 6px var(--color-secondary-glow)}.bubble.active li:nth-child(1){opacity:1;transform:translateY(0);transition-delay:.05s}.bubble.active li:nth-child(2){opacity:1;transform:translateY(0);transition-delay:.1s}.bubble.active li:nth-child(3){opacity:1;transform:translateY(0);transition-delay:.15s}.bubble.active li:nth-child(4){opacity:1;transform:translateY(0);transition-delay:.2s}.bubble.active li:nth-child(5){opacity:1;transform:translateY(0);transition-delay:.25s}.bubble.active li:nth-child(6){opacity:1;transform:translateY(0);transition-delay:.3s}.bubble.active li:nth-child(7){opacity:1;transform:translateY(0);transition-delay:.35s}.bubble.active li:nth-child(8){opacity:1;transform:translateY(0);transition-delay:.4s}.bubble.active li:nth-child(9){opacity:1;transform:translateY(0);transition-delay:.45s}.bubble.active li:nth-child(10){opacity:1;transform:translateY(0);transition-delay:.5s}.bubble.active li:nth-child(11){opacity:1;transform:translateY(0);transition-delay:.55s}.bubble.active li:nth-child(12){opacity:1;transform:translateY(0);transition-delay:.6s}#skills-controls{position:absolute;top:var(--space-lg);right:var(--space-md);display:flex;flex-direction:column;gap:var(--space-xs);z-index:2000}.ctrl-btn{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--radius-md);border:1px solid var(--color-border-accent);background:color-mix(in srgb,var(--color-surface) 85%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--color-text-secondary);font-size:var(--font-size-lg);cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),transform var(--transition-fast)}.ctrl-btn:hover{background:var(--color-surface-hover);border-color:var(--color-primary);color:var(--color-primary);transform:scale(1.08)}.ctrl-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}#global-tooltip{position:fixed;pointer-events:none;z-index:999999;padding:var(--space-xs) var(--space-sm);background:var(--color-surface);border:1px solid var(--color-border-accent);color:var(--color-text-primary);font-size:var(--font-size-xs);border-radius:var(--radius-sm);opacity:0;transform:translate(-50%,-70%);transition:opacity var(--transition-fast);white-space:nowrap;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:var(--shadow-md)}@media (max-width: 720px){.bubble{width:94%;max-width:none;transform:translate(-50%) translateY(-15px) scale(.96)}.bubble.active{transform:translate(-50%) translateY(0) scale(1);padding:var(--space-md) var(--space-lg)}.bubble ul{grid-template-columns:1fr;gap:var(--space-xs) 0}.bubble li{font-size:var(--font-size-sm);line-height:var(--line-height-base)}#skills-controls{top:var(--space-sm);right:var(--space-sm)}}@media (min-width: 1440px){.bubble{max-width:960px}.bubble.active{padding:var(--space-xl) var(--space-3xl)}.bubble ul{grid-template-columns:repeat(2,minmax(260px,1fr));gap:var(--space-md) var(--space-2xl)}.bubble li{font-size:var(--font-size-base)}}.theme-toggle{position:fixed;top:var(--space-lg);right:var(--space-lg);z-index:1000;display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border-radius:var(--radius-full);border:1px solid var(--color-border-accent);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;box-shadow:var(--shadow-md);transition:color var(--transition-fast),border-color var(--transition-fast),background-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.theme-toggle:hover{color:var(--color-text-primary);border-color:var(--color-primary);box-shadow:var(--shadow-md),0 0 12px var(--color-primary-glow);transform:scale(1.08)}.theme-toggle:active{transform:scale(.95)}.theme-toggle:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px}@keyframes toggle-spin{0%{transform:rotate(0) scale(1)}50%{transform:rotate(180deg) scale(.85)}to{transform:rotate(360deg) scale(1)}}.theme-toggle--spinning{animation:toggle-spin .4s var(--transition-base) forwards}@media (max-width: 768px){.theme-toggle{top:var(--space-md);right:var(--space-md);width:36px;height:36px}}.projects{display:flex;flex-direction:column;gap:var(--space-2xl);width:100%}.projects__header{display:flex;flex-direction:column;gap:var(--space-sm)}.projects__badge{display:inline-block;font-family:var(--font-family-mono);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);letter-spacing:.12em;text-transform:uppercase;color:var(--color-primary);background:var(--color-primary-glow);border:1px solid var(--color-primary);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);width:fit-content}.projects__title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0;line-height:var(--line-height-tight)}@media (max-width: 768px){.projects__title{font-size:var(--font-size-xl)}}.legal-page{display:flex;justify-content:center;padding:var(--space-2xl) var(--space-md)}.legal{width:100%;max-width:760px;display:flex;flex-direction:column;gap:var(--space-sm)}.legal h1{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--space-sm);line-height:var(--line-height-tight)}.legal h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:var(--space-xl) 0 var(--space-xs);padding-bottom:var(--space-xs);border-bottom:1px solid var(--color-border)}.legal p{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin:0}.legal strong{color:var(--color-text-primary);font-weight:var(--font-weight-semibold)}.legal a{color:var(--color-primary);text-decoration:underline;text-underline-offset:3px;transition:color var(--transition-fast)}.legal a:hover{color:var(--color-primary-hover)}.legal ul{padding-left:var(--space-lg);margin:var(--space-xs) 0;display:flex;flex-direction:column;gap:var(--space-xs)}.legal ul li{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:var(--line-height-base)}@media (max-width: 768px){.legal-page{padding:var(--space-xl) var(--space-md)}.legal h1{font-size:var(--font-size-2xl)}.legal h2{font-size:var(--font-size-base)}}@keyframes buzzX{0%,to{transform:translate(0) rotate(0)}10%{transform:translate(3px) rotate(1.2deg)}20%{transform:translate(-3px) rotate(-1.2deg)}50%{transform:translate(0) rotate(0)}}@keyframes floatY{0%,to{transform:translateY(0)}50%{transform:translateY(var(--float-amp, -6px))}}@keyframes toastIn{to{opacity:1;transform:translateY(0)}}@keyframes toastOut{to{opacity:0;transform:translateY(20px)}}
