nav{position:fixed;top:16px;left:50%;transform:translate(-50%);width:auto;max-width:720px;padding:10px 12px;background:#0c0c14a6;backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border:1px solid rgba(255,255,255,.08);border-radius:9999px;z-index:100;display:flex;justify-content:center;align-items:center;gap:6px;transition:all .4s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 24px #00000040,inset 0 0 0 1px #ffffff0a}:root[data-theme=light] nav{background:#ffffffb8;border:1px solid rgba(0,0,0,.06);box-shadow:0 4px 24px #00000014,inset 0 0 0 1px #ffffff80}nav.scrolled{background:#0c0c14d9;padding:8px 12px;box-shadow:0 8px 32px #00000059,inset 0 0 0 1px #ffffff0f}:root[data-theme=light] nav.scrolled{background:#ffffffe6;box-shadow:0 8px 32px #0000001a,inset 0 0 0 1px #fff9}.logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0;transition:transform .3s cubic-bezier(.4,0,.2,1)}.logo:hover{transform:scale(1.06)}.logo-img{width:34px;height:34px;object-fit:cover;border-radius:50%;border:2px solid rgba(124,77,255,.35);transition:border-color .3s ease}.logo:hover .logo-img{border-color:#7c4dffb3}.nav-links{display:flex;gap:2px;list-style:none;align-items:center;margin:0;padding:0}.nav-links li{margin:0;padding:0}.nav-links a{display:inline-flex;align-items:center;color:var(--color-text);opacity:.6;text-decoration:none;font-size:.82rem;font-weight:500;letter-spacing:.01em;padding:8px 16px;border-radius:9999px;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;white-space:nowrap}.nav-links a:after{display:none}.nav-links a:hover{opacity:1;background:#7c4dff1a;color:var(--color-text)}:root[data-theme=light] .nav-links a:hover{background:#7c4dff14}.nav-links a.active{opacity:1;background:#7c4dff26;color:#a78bfa;font-weight:600}:root[data-theme=light] .nav-links a.active{background:#7c4dff1a;color:#7c4dff}.nav-divider{width:1px;height:22px;background:#ffffff1a;margin:0 4px;flex-shrink:0}:root[data-theme=light] .nav-divider{background:#0000001a}.theme-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;padding:0;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid rgba(255,255,255,.08);background:#ffffff0f;flex-shrink:0}.theme-toggle:hover{transform:rotate(30deg) scale(1.1);background:#7c4dff26;border-color:#7c4dff4d}:root[data-theme=light] .theme-toggle{background:#0000000d;border:1px solid rgba(0,0,0,.08)}:root[data-theme=light] .theme-toggle:hover{background:#7c4dff1a;border-color:#7c4dff40}:root[data-theme=dark] .theme-toggle svg{stroke:#fff;color:#fff}:root[data-theme=light] .theme-toggle svg{stroke:#1a1a2e;color:#1a1a2e}.menu-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;z-index:101}.menu-toggle span{display:block;width:22px;height:2px;background:var(--color-text);border-radius:2px;transition:all .3s cubic-bezier(.4,0,.2,1)}.menu-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.menu-toggle.active span:nth-child(2){opacity:0;transform:scaleX(0)}.menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}@media (max-width: 768px){nav{display:none!important}.logo{margin-right:auto;position:relative;z-index:101}.theme-toggle{order:1;position:relative;z-index:101}.menu-toggle{display:flex;order:2;position:relative;z-index:101}.nav-links{position:absolute;top:100%;left:0;right:0;bottom:auto;margin-top:12px;flex-direction:column;justify-content:flex-start;align-items:stretch;gap:4px;background:#0c0c14f2;backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border:1px solid rgba(255,255,255,.08);border-radius:24px;padding:16px;opacity:0;pointer-events:none;transform:translateY(-16px) scale(.96);transform-origin:top center;transition:opacity .35s cubic-bezier(.4,0,.2,1),transform .35s cubic-bezier(.4,0,.2,1),visibility .35s;z-index:99;box-shadow:0 16px 40px #0006;visibility:hidden}:root[data-theme=light] .nav-links{background:#fffffff2;border-color:#00000014;box-shadow:0 16px 40px #0000001f}.nav-links.active{opacity:1;pointer-events:auto;transform:translateY(0) scale(1);visibility:visible}.nav-links li{width:100%;opacity:0;transform:translateY(-8px);transition:opacity .3s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.4,0,.2,1)}.nav-links.active li:nth-child(1){transition-delay:.05s;opacity:1;transform:translateY(0)}.nav-links.active li:nth-child(2){transition-delay:.1s;opacity:1;transform:translateY(0)}.nav-links.active li:nth-child(3){transition-delay:.15s;opacity:1;transform:translateY(0)}.nav-links.active li:nth-child(4){transition-delay:.2s;opacity:1;transform:translateY(0)}.nav-links.active li:nth-child(5){transition-delay:.25s;opacity:1;transform:translateY(0)}.nav-links a{display:flex;font-size:1.05rem;padding:14px 20px;border-radius:14px;justify-content:flex-start;align-items:center;width:100%;box-sizing:border-box;border:1px solid transparent;transition:all .2s cubic-bezier(.4,0,.2,1)}.nav-links a:active{transform:scale(.98);background:#7c4dff26}.nav-links a.active{background:#7c4dff1f;border-color:#7c4dff40;box-shadow:inset 0 0 0 1px #ffffff0d}:root[data-theme=light] .nav-links a.active{background:#7c4dff14;border-color:#7c4dff33;box-shadow:none}.nav-divider{display:none}}footer{background:var(--color-surface, #0a0a0a);border-top:1px solid var(--color-border, rgba(255, 255, 255, .1));position:relative;z-index:1;margin-top:100px}.footer-content{max-width:1200px;margin:0 auto;padding:60px 32px 40px;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:40px}.footer-left{display:flex;flex-direction:column;gap:12px}.footer-logo{font-size:1.5rem;font-weight:700;color:var(--color-text, #ffffff);letter-spacing:-.5px}.footer-tagline{color:var(--color-text-muted, #a0a0a0);font-size:.9rem;text-decoration:none;transition:all .3s ease;display:inline-block}.footer-tagline:hover{color:var(--color-primary, #7c4dff);transform:translate(4px)}.footer-center,.footer-right{display:flex;flex-direction:column;gap:16px}.footer-section-title{font-weight:600;font-size:.95rem;text-transform:uppercase;letter-spacing:1px;background:var(--gradient-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px}.footer-link{color:var(--color-text-muted, #a0a0a0);text-decoration:none;transition:all .3s ease;font-size:.9rem}.footer-link:hover{color:var(--color-text, #ffffff);transform:translate(4px)}.footer-social-container{display:flex;gap:16px;margin-top:8px}.footer-social{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--color-surface, #0a0a0a);border:1px solid var(--color-border, rgba(255, 255, 255, .1));color:var(--color-text-muted, #a0a0a0);transition:all .3s ease}.footer-social:hover{background:#7c4dff1a;color:#fff;transform:translateY(-4px);box-shadow:0 4px 15px #7c4dff66;border-color:#7c4dff80}.footer-bottom{border-top:1px solid var(--color-border, rgba(255, 255, 255, .1));padding:24px 32px;text-align:center}.footer-bottom p{color:var(--color-text-muted, #a0a0a0);font-size:.85rem;font-family:var(--font-mono, "JetBrains Mono", monospace)}.footer-bottom span{color:var(--color-text, #ffffff);font-weight:600}@media (max-width: 768px){.footer-content{grid-template-columns:1fr;gap:32px;padding:40px 20px 30px}.footer-bottom{padding:20px}}.cursor-dot,.cursor-outline{position:fixed;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:opacity .3s ease}.cursor-dot{width:8px;height:8px;background:var(--color-text, #ffffff);border-radius:50%;opacity:.8}.cursor-outline{width:32px;height:32px;border:2px solid var(--color-text, #ffffff);border-radius:50%;opacity:.5;transition:all .15s ease-out}.cursor-outline.hovering{width:48px;height:48px;opacity:.8;border-color:var(--color-primary, #ffffff)}@media (max-width: 768px),(hover: none){.cursor-dot,.cursor-outline{display:none}}.back-to-top{position:fixed;bottom:40px;right:40px;width:50px;height:50px;border-radius:50%;background:var(--color-text, #ffffff);color:var(--color-bg, #000000);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0000004d;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:90;opacity:0;visibility:hidden;transform:translateY(20px)}.back-to-top:hover{transform:translateY(-4px) scale(1.1);box-shadow:0 8px 20px #0006}.back-to-top.igniting{animation:rumble .3s ease-in-out}.back-to-top.launching{animation:launch 1s cubic-bezier(.5,0,.5,1) forwards}@keyframes rumble{0%,to{transform:translateY(0) translate(0)}25%{transform:translateY(-2px) translate(2px)}50%{transform:translateY(2px) translate(-2px)}75%{transform:translateY(-2px) translate(-2px)}}@keyframes launch{0%{transform:translateY(0) scale(1);opacity:1}50%{transform:translateY(-30px) scale(1.2);opacity:.8}to{transform:translateY(-100vh) scale(.5);opacity:0}}@media (max-width: 768px){.back-to-top{bottom:20px;right:20px;width:45px;height:45px}}.scroll-progress{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--color-primary, #ffffff),var(--color-accent, #ffffff));z-index:9999;transition:width .1s ease-out;box-shadow:0 0 10px #ffffff80}#particle-canvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:-2;pointer-events:none}.geometric-shapes{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:-1}:root[data-theme=light] .shape{background:linear-gradient(135deg,#00000008,#0000000d);border:1px solid rgba(0,0,0,.08)}.liquid-orb{position:absolute;border-radius:9999px;background:radial-gradient(circle at 30% 30%,rgba(120,50,255,.3),transparent 70%);filter:blur(40px);animation:liquidMove 25s infinite ease-in-out;will-change:transform}:root[data-theme=light] .liquid-orb{background:radial-gradient(circle at 30% 30%,rgba(120,80,255,.15),transparent 70%)}:root[data-theme=light] .liquid-orb:nth-child(2){background:radial-gradient(circle at 70% 70%,rgba(80,120,255,.12),transparent 70%)}:root[data-theme=light] .liquid-orb:nth-child(3){background:radial-gradient(circle at 50% 50%,rgba(150,100,255,.1),transparent 70%)}.triangle{width:0;height:0;border-left:60px solid transparent;border-right:60px solid transparent;border-bottom:100px solid rgba(255,255,255,.02);top:20%;left:10%;animation-delay:0s;background:none}:root[data-theme=light] .triangle{border-bottom:100px solid rgba(0,0,0,.04)}.circle{width:150px;height:150px;border-radius:9999px;top:60%;right:15%;animation-delay:5s}.hero{padding-top:100px}.about,.projects,.contact{padding:80px 0}:root[data-theme=light] .subtitle{background:linear-gradient(135deg,#000,#333,#000);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:none}:root[data-theme=light] .portfolio-label{color:var(--color-text-muted)}:root[data-theme=light] .hero{background:radial-gradient(ellipse at center,rgba(120,80,255,.05) 0%,transparent 70%)}:root[data-theme=light] .hero:before{background:radial-gradient(circle,rgba(120,80,255,.08) 0%,transparent 70%)}@media (max-width: 768px){.hero{padding-top:80px}.about,.projects,.contact{padding:60px 0}}.workshops-page{min-height:100vh;padding-bottom:100px;background:var(--color-bg);color:var(--color-text);font-family:var(--font-sans);line-height:1.7;-webkit-font-smoothing:antialiased;position:relative;overflow-x:hidden}.ws-orb{position:fixed;border-radius:9999px;filter:blur(90px);pointer-events:none;z-index:0;will-change:transform}.ws-orb--1{width:550px;height:550px;top:-220px;left:-220px;background:radial-gradient(circle at 30% 30%,rgba(124,77,255,.22),transparent 70%);animation:wsOrbFloat 22s ease-in-out infinite}.ws-orb--2{width:420px;height:420px;bottom:-160px;right:-160px;background:radial-gradient(circle at 70% 70%,rgba(0,110,255,.18),transparent 70%);animation:wsOrbFloat 28s ease-in-out infinite reverse;animation-delay:-6s}@keyframes wsOrbFloat{0%,to{transform:translate(0) scale(1)}33%{transform:translate(50px,-35px) scale(1.07)}66%{transform:translate(-35px,50px) scale(.95)}}.workshops-page .container{position:relative;z-index:1}.ws-hero{padding:110px 0 50px;text-align:center;opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.4,0,.2,1),transform .8s cubic-bezier(.4,0,.2,1)}.ws-hero--revealed{opacity:1;transform:translateY(0)}.ws-hero__label{display:block;color:var(--color-text);opacity:.55;text-transform:uppercase;letter-spacing:5px;font-size:var(--font-size-xs);margin-bottom:var(--spacing-sm)}.ws-hero__title{font-size:clamp(36px,7vw,78px);font-weight:800;margin-bottom:var(--spacing-sm);color:var(--color-text);text-shadow:0 4px 24px rgba(124,77,255,.35);letter-spacing:-2px;line-height:1.1}.ws-hero__title-accent{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ws-hero__subtitle{display:block;font-size:.78rem;letter-spacing:.2em;color:var(--color-text);opacity:.7;margin-bottom:var(--spacing-xl)}.ws-stats{display:inline-flex;align-items:center;background:var(--color-surface-glass);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--color-border);border-radius:var(--radius-full);padding:14px 36px;box-shadow:0 4px 24px #0000004d,inset 0 0 0 1px #ffffff0a;gap:0}.ws-stat{display:flex;flex-direction:column;align-items:center;gap:3px;padding:0 22px}.ws-stat__num{font-size:var(--font-size-2xl);font-weight:800;line-height:1;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ws-stat__label{font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:var(--color-text);opacity:.55;white-space:nowrap}.ws-stat-divider{width:1px;height:34px;background:var(--color-border);flex-shrink:0}.ws-filters{display:flex;justify-content:center;gap:8px;margin-bottom:12px;flex-wrap:wrap}.ws-filter-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;background:#ffffff0a;border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text);opacity:.65;font-size:var(--font-size-xs);letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:all var(--transition-base);position:relative;overflow:hidden}.ws-filter-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--gradient-primary);opacity:0;transition:opacity var(--transition-base)}.ws-filter-btn:hover{border-color:var(--color-border-hover);color:var(--color-text);opacity:1;transform:translateY(-1px)}.ws-filter-btn--active{border-color:transparent;color:#fff;opacity:1;box-shadow:0 4px 16px #7c4dff66}.ws-filter-btn--active:before{opacity:1}.ws-filter-btn>*{position:relative;z-index:1}.ws-filter-btn__count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;background:#ffffff24;border-radius:var(--radius-full);font-size:.6rem;font-weight:700}.ws-filter-btn--active .ws-filter-btn__count{background:#ffffff40}.ws-hint{text-align:center;font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--color-text);margin-bottom:var(--spacing-lg);opacity:.5}.ws-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.ws-card{background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;position:relative;box-shadow:inset 0 0 0 1px #ffffff0a,0 8px 32px #0000004d;display:flex;flex-direction:column;gap:0;cursor:pointer;outline:none;animation:wsCardIn .55s cubic-bezier(.16,1,.3,1) var(--card-delay, 0ms) both;transition:transform var(--transition-base),box-shadow var(--transition-base),border-color var(--transition-base);--card-color: #7c4dff}@keyframes wsCardIn{0%{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}.ws-card:hover{transform:translateY(-7px) scale(1.01);border-color:#7c4dff59;box-shadow:inset 0 0 0 1px #ffffff14,0 24px 60px #7c4dff2e,0 8px 20px #0006}.ws-card:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px}.ws-card__shimmer{position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--card-color, #7c4dff),rgba(0,210,255,.6),transparent);animation:wsShimmer 3.5s infinite linear;opacity:.8;z-index:1}@keyframes wsShimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.ws-card__top{display:flex;justify-content:space-between;align-items:flex-start;padding:22px 22px 0}.ws-card__icon-wrap{width:46px;height:46px;border-radius:var(--radius-md);background:linear-gradient(135deg,#7c4dff2e,#006eff2e);border:1px solid rgba(124,77,255,.22);display:flex;align-items:center;justify-content:center;color:var(--card-color, #7c4dff);flex-shrink:0;transition:all var(--transition-base)}.ws-card:hover .ws-card__icon-wrap{background:linear-gradient(135deg,var(--card-color, #7c4dff),rgba(0,110,255,.8));border-color:transparent;color:#fff;box-shadow:0 4px 18px #7c4dff73}.ws-card__top-meta{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.ws-card__number{font-size:.65rem;letter-spacing:.1em;color:var(--color-text)}.ws-card__type-chip{font-size:.58rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:4px 11px;border-radius:var(--radius-full);border:1px solid transparent}.ws-card__type-chip--workshop{background:#7c4dff24;border-color:#7c4dff52;color:#a78bfa}.ws-card__type-chip--event{background:#006eff24;border-color:#006eff52;color:#60a5fa}.ws-card__body{padding:18px 22px 10px;flex:1}.ws-card__subtitle{display:block;font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--color-text);margin-bottom:8px}.ws-card__title{font-size:1.45rem;font-weight:700;letter-spacing:-.03em;color:var(--color-text);margin-bottom:10px;line-height:1.2;transition:color var(--transition-base)}.ws-card:hover .ws-card__title{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ws-card__tagline{font-size:.9rem;color:var(--color-text);line-height:1.55;margin:0}.ws-card__badges{display:flex;flex-wrap:wrap;gap:6px;padding:0 22px 16px}.ws-card__badge{font-size:.58rem;letter-spacing:.08em;text-transform:uppercase;padding:4px 10px;background:#ffffff0d;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);transition:all var(--transition-fast)}.ws-card:hover .ws-card__badge{background:#7c4dff1a;border-color:#7c4dff40;color:var(--color-text);opacity:1}.ws-card__footer{border-top:1px solid var(--color-border);padding:14px 22px;display:flex;align-items:center;justify-content:space-between;transition:border-color var(--transition-base)}.ws-card:hover .ws-card__footer{border-color:#7c4dff33}.ws-card__cta{font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;color:var(--color-text);transition:color var(--transition-base)}.ws-card__arrow{width:28px;height:28px;border-radius:var(--radius-full);background:#7c4dff1a;border:1px solid rgba(124,77,255,.25);display:flex;align-items:center;justify-content:center;color:var(--color-primary);transition:all var(--transition-base)}.ws-card:hover .ws-card__arrow{background:var(--gradient-primary);border-color:transparent;color:#fff;transform:rotate(45deg) scale(1.08);box-shadow:0 4px 12px #7c4dff73}.ws-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;backdrop-filter:blur(16px) saturate(130%);-webkit-backdrop-filter:blur(16px) saturate(130%);z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;animation:wsBackdropIn .2s ease both;overflow-y:auto}@keyframes wsBackdropIn{0%{opacity:0}to{opacity:1}}.ws-modal{background:var(--color-bg);border:1px solid var(--color-border);border-radius:20px;width:100%;max-width:860px;max-height:92vh;overflow-y:auto;position:relative;box-shadow:0 0 0 1px #ffffff0a,0 32px 100px #0009,0 0 80px #7c4dff14;animation:wsModalIn .35s cubic-bezier(.16,1,.3,1) both;scrollbar-width:thin;scrollbar-color:rgba(124,77,255,.25) transparent;--card-color: #7c4dff}.ws-modal::-webkit-scrollbar{width:5px}.ws-modal::-webkit-scrollbar-thumb{background:#7c4dff40;border-radius:4px}@keyframes wsModalIn{0%{opacity:0;transform:scale(.95) translateY(16px)}to{opacity:1;transform:scale(1) translateY(0)}}.ws-modal__hero{position:relative;padding:40px 32px 32px;text-align:center;background:linear-gradient(180deg,rgba(124,77,255,.08) 0%,transparent 100%);border-bottom:1px solid var(--color-border);overflow:hidden}.ws-modal__hero-glow{position:absolute;top:-60px;left:50%;transform:translate(-50%);width:300px;height:200px;background:radial-gradient(ellipse,var(--card-color, rgba(124, 77, 255, .25)),transparent 70%);opacity:.25;filter:blur(50px);pointer-events:none}.ws-modal__close{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-surface-glass);color:var(--color-text);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);z-index:2}.ws-modal__close:hover{background:#ff3c3c1f;border-color:#ff3c3c59;color:#fc8181;transform:rotate(90deg) scale(1.05)}.ws-modal__hero-icon{width:64px;height:64px;border-radius:16px;background:var(--gradient-primary);display:inline-flex;align-items:center;justify-content:center;color:#fff;margin-bottom:16px;box-shadow:0 8px 28px #7c4dff59}.ws-modal__chip{display:inline-block;font-size:.6rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:5px 14px;border-radius:var(--radius-full);margin-bottom:14px}.ws-modal__chip--workshop{background:#7c4dff26;border:1px solid rgba(124,77,255,.35);color:#a78bfa}.ws-modal__chip--event{background:#006eff26;border:1px solid rgba(0,110,255,.35);color:#60a5fa}.ws-modal__title{font-size:clamp(1.7rem,5vw,2.2rem);font-weight:800;letter-spacing:-.03em;line-height:1.15;margin:0 0 8px;color:var(--color-text)}.ws-modal__tagline{font-size:1rem;color:var(--color-text);opacity:.72;line-height:1.6;margin:0;max-width:460px;margin-inline:auto}.ws-modal__meta-bar{display:grid;grid-template-columns:1fr 1fr;gap:0;border-bottom:1px solid var(--color-border)}.ws-modal__meta-item{display:flex;align-items:center;gap:14px;padding:18px 24px;border-right:1px solid var(--color-border);border-bottom:1px solid var(--color-border);transition:background var(--transition-fast)}.ws-modal__meta-item:nth-child(2n){border-right:none}.ws-modal__meta-item:nth-last-child(-n+2){border-bottom:none}.ws-modal__meta-item:hover{background:#7c4dff0a}.ws-modal__meta-icon{width:38px;height:38px;border-radius:var(--radius-md);background:#7c4dff1a;border:1px solid rgba(124,77,255,.2);display:flex;align-items:center;justify-content:center;color:var(--color-primary);flex-shrink:0}.ws-modal__meta-text{display:flex;flex-direction:column;gap:2px;min-width:0}.ws-modal__meta-label{font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;color:var(--color-text);opacity:.5}.ws-modal__meta-value{font-size:.95rem;font-weight:600;color:var(--color-text);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ws-modal__badges-wrap{display:flex;flex-wrap:wrap;gap:8px;padding:18px 28px;border-bottom:1px solid var(--color-border)}.ws-modal__badge{font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;padding:6px 14px;background:#ffffff0a;border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text);opacity:.8}.ws-modal__content{padding:28px 28px 36px;display:flex;flex-direction:column;gap:30px}.ws-modal__section-title{font-size:.85rem;font-weight:700;letter-spacing:.04em;color:var(--color-text);margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid var(--color-primary);display:inline-block}.ws-modal__section-intro{font-size:.95rem;color:var(--color-text);opacity:.72;font-style:italic;margin-bottom:14px;line-height:1.7}.ws-modal__section-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.ws-modal__section-list li{display:flex;align-items:flex-start;gap:14px;padding:12px 16px;border-radius:var(--radius-md);transition:background var(--transition-fast);cursor:default}.ws-modal__section-list li:hover{background:#7c4dff0f}.ws-modal__item-num{font-size:.62rem;font-weight:700;color:var(--color-primary);min-width:22px;height:22px;line-height:22px;text-align:center;background:#7c4dff1a;border-radius:var(--radius-sm);flex-shrink:0;margin-top:2px}.ws-modal__item-text{font-size:1rem;color:var(--color-text);opacity:.88;line-height:1.65}.ws-back-nav{display:flex;justify-content:center;margin-top:var(--spacing-xl)}.ws-back-btn{display:inline-flex;align-items:center;gap:10px}@media (max-width: 900px){.ws-grid{grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.ws-stats{padding:12px 20px;flex-wrap:wrap;justify-content:center;border-radius:var(--radius-xl)}.ws-stat{padding:0 14px}.ws-stat-divider{display:none}.ws-modal{max-height:95vh}}@media (max-width: 600px){.ws-hero{padding:80px 0 36px}.ws-grid{grid-template-columns:1fr;gap:var(--spacing-md)}.ws-modal-backdrop{padding:0}.ws-modal{width:100%;height:100%;max-width:100vw;max-height:100vh;border-radius:0;border:none;margin:0;display:flex;flex-direction:column}.ws-modal__hero{padding:30px 16px 12px;flex-shrink:0}.ws-modal__hero-glow{top:-40px;width:200px;height:150px}.ws-modal__hero-icon{width:44px;height:44px;margin-bottom:8px;border-radius:12px}.ws-modal__hero-icon svg{width:22px;height:22px}.ws-modal__title{font-size:1.4rem;margin-bottom:2px}.ws-modal__tagline{font-size:.75rem;line-height:1.3;margin-bottom:4px}.ws-modal__chip{padding:4px 10px;font-size:.55rem;margin-bottom:8px}.ws-modal__meta-bar{grid-template-columns:1fr 1fr;font-size:.8rem}.ws-modal__meta-item{padding:10px 12px;gap:8px}.ws-modal__meta-icon{width:28px;height:28px;border-radius:8px}.ws-modal__meta-icon svg{width:14px;height:14px}.ws-modal__meta-label{font-size:.45rem;letter-spacing:.1em}.ws-modal__meta-value{font-size:.75rem;line-height:1.2}.ws-modal__badges-wrap{padding:10px 16px;gap:6px;justify-content:center}.ws-modal__badge{padding:4px 8px;font-size:.5rem}.ws-modal__content{padding:16px 16px 24px;gap:16px;flex:1;overflow-y:auto}.ws-modal__section-title{font-size:.8rem;margin-bottom:12px;padding-bottom:6px}.ws-modal__section-list li{padding:6px 10px;gap:10px;align-items:flex-start}.ws-modal__item-num{min-width:18px;height:18px;line-height:18px;font-size:.5rem;margin-top:2px}.ws-modal__item-text{font-size:.8rem;line-height:1.4}.ws-modal__close{top:12px;right:12px;width:32px;height:32px}.ws-filter-btn{padding:8px 14px;font-size:.6rem}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.resume-page{min-height:100vh;padding-top:100px;padding-bottom:50px}.resume-page .container{max-width:1300px;margin:0 auto;padding:0 30px}.resume-page .header{text-align:center;margin-bottom:50px;animation:fadeInDown .6s ease-out}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.resume-page .header h1{font-size:3rem;font-weight:700;margin-bottom:12px;background:var(--gradient-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.resume-page .header p{font-family:var(--font-mono);font-size:1.1rem;color:var(--color-text-muted);font-weight:500}.resume-page .actions{display:flex;justify-content:center;gap:18px;margin-bottom:45px;flex-wrap:wrap;animation:fadeInUp .6s ease-out .2s backwards}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.pdf-viewer{background:#0f0f1966;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:25px;box-shadow:inset 0 0 0 1px #ffffff0d,0 8px 32px #0000004d;animation:fadeIn .6s ease-out .4s backwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.pdf-container{width:100%;height:95vh;min-height:900px;border-radius:12px;overflow:hidden;background:#fff;box-shadow:inset 0 2px 8px #0000001a}.pdf-container iframe,.pdf-container object,.pdf-container embed{width:100%;height:100%;border:none}.pdf-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;background:var(--color-surface);border-radius:12px;padding:50px;text-align:center}.pdf-fallback svg{width:90px;height:90px;stroke:var(--color-accent, var(--color-primary));margin-bottom:28px;opacity:.8;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.pdf-fallback h3{font-size:1.8rem;margin-bottom:10px;color:var(--color-text);font-weight:600}.pdf-fallback p{color:var(--color-text-muted);margin-bottom:30px;font-size:1.05rem}.pdf-fallback .btn{margin:0 10px}@media (max-width: 768px){.resume-page{padding-top:80px;padding-bottom:40px}.resume-page .container{padding:0 20px}.resume-page .header h1{font-size:2.2rem}.resume-page .header p{font-size:.95rem}.resume-page .actions{flex-direction:column;max-width:300px;margin:0 auto 40px}.resume-page .actions .btn{width:100%;justify-content:center}.pdf-container{height:75vh;min-height:600px}.pdf-viewer{padding:20px}}:root{--color-bg: #05050f;--color-surface: #0a0a14;--color-surface-glass: rgba(15, 15, 25, .7);--color-text: #f0f0f5;--color-text-muted: #a0a0b0;--color-text-dark: #707080;--color-border: rgba(255, 255, 255, .08);--color-border-hover: rgba(255, 255, 255, .2);--color-primary: #7c4dff;--color-secondary: #006eff;--color-accent: #ffffff;--gradient-primary: linear-gradient(135deg, var(--color-primary), var(--color-secondary));--gradient-text: linear-gradient(135deg, #ffffff 0%, #b3b3ff 100%);--color-particle-rgb: 124, 77, 255;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 32px;--spacing-xl: 64px;--spacing-2xl: 128px;--font-sans: "Exo 2", "Orbitron", sans-serif;--font-mono: "Space 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: 2rem;--font-size-4xl: 3rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .3s cubic-bezier(.4, 0, .2, 1);--transition-slow: .5s cubic-bezier(.4, 0, .2, 1);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .5);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .5), 0 2px 4px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5), 0 4px 6px -2px rgba(0, 0, 0, .3);--shadow-glow: 0 0 20px rgba(255, 255, 255, .15);--z-background: -2;--z-shapes: -1;--z-content: 1;--z-navbar: 100;--z-modal: 1000;--z-loader: 9999}:root[data-theme=light]{--color-bg: #ffffff;--color-surface: #f8f9fa;--color-surface-glass: rgba(248, 249, 250, .9);--color-text: #000000;--color-text-muted: #000000;--color-text-dark: #000000;--color-border: rgba(0, 0, 0, .15);--color-border-hover: rgba(0, 0, 0, .4);--color-primary: #2563eb;--color-accent: #3b82f6;--color-particle-rgb: 30, 30, 30;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .08);--shadow-md: 0 4px 8px rgba(0, 0, 0, .12);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .15);--shadow-glow: 0 0 20px rgba(37, 99, 235, .1)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);overflow-x:hidden;position:relative;scroll-behavior:smooth;overflow-wrap:break-word;line-height:1.7;font-size:var(--font-size-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::selection{background-color:var(--color-primary);color:#fff}h1,h2,h3,h4,h5,h6{font-family:var(--font-sans);font-weight:700;letter-spacing:-.02em}code,pre,.font-mono{font-family:var(--font-mono)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:#ffffff0d}::-webkit-scrollbar-thumb{background:var(--color-text-dark);border-radius:var(--radius-md);border:2px solid var(--color-bg)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}@keyframes gradientShift{0%,to{transform:scale(1) rotate(0)}33%{transform:scale(1.1) rotate(120deg)}66%{transform:scale(.9) rotate(240deg)}}nav{position:fixed;top:0;width:100%;padding:var(--spacing-md) var(--spacing-lg);background:#000c;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid rgba(255,255,255,.1);z-index:var(--z-navbar);display:flex;justify-content:space-between;align-items:center;transition:all var(--transition-base)}nav.scrolled{background:#000000e6;-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);padding:15px var(--spacing-lg)}.logo{display:flex;align-items:center;font-size:var(--font-size-xl);font-weight:600;color:var(--color-text);letter-spacing:-.5px;transition:all var(--transition-base);cursor:pointer}.logo:hover{opacity:.8}.logo-img{height:45px;width:auto;transition:all var(--transition-base)}.nav-resume{display:inline-block;padding:6px 10px;background:linear-gradient(90deg,#7c4dff,#4f7bff);color:#fff;border-radius:var(--radius-md);text-decoration:none;font-weight:600;border:1px solid rgba(255,255,255,.06)}.nav-resume:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.nav-links{display:flex;gap:var(--spacing-lg);list-style:none;align-items:center;margin-left:auto}.nav-links a{color:var(--color-text-muted);text-decoration:none;transition:all var(--transition-base);font-size:var(--font-size-sm);position:relative}.nav-links a:after{content:"";position:absolute;bottom:-5px;left:0;width:0;height:2px;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));transition:width var(--transition-base)}.nav-links a:hover:after,.nav-links a.active:after{width:100%}.nav-links a:hover,.nav-links a.active{color:var(--color-text)}.nav-links a:focus-visible{outline:2px solid var(--color-primary);outline-offset:4px;border-radius:2px}.geometric-shapes{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:var(--z-shapes)}.shape{position:absolute;background:linear-gradient(135deg,#ffffff1a,#ffffff1a);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid rgba(255,255,255,.1);animation:floatAdvanced 20s infinite ease-in-out;will-change:transform}.liquid-orb{position:absolute;border-radius:var(--radius-full);background:radial-gradient(circle at 30% 30%,rgba(120,50,255,.3),transparent 70%);filter:blur(40px);animation:liquidMove 25s infinite ease-in-out;will-change:transform}.liquid-orb:nth-child(1){width:400px;height:400px;top:-200px;left:-200px;animation-delay:0s}.liquid-orb:nth-child(2){width:300px;height:300px;bottom:-150px;right:-150px;background:radial-gradient(circle at 70% 70%,rgba(255,255,255,.3),transparent 70%);animation-delay:5s}.liquid-orb:nth-child(3){width:250px;height:250px;top:50%;left:50%;background:radial-gradient(circle at 50% 50%,rgba(255,255,255,.2),transparent 70%);animation-delay:10s}@keyframes liquidMove{0%,to{transform:translate(0) scale(1)}25%{transform:translate(100px,-50px) scale(1.1)}50%{transform:translate(-50px,100px) scale(.9)}75%{transform:translate(-100px,-100px) scale(1.05)}}.triangle{width:0;height:0;border-left:60px solid transparent;border-right:60px solid transparent;border-bottom:100px solid rgba(255,255,255,.02);top:20%;left:10%;animation-delay:0s}.circle{width:150px;height:150px;border-radius:var(--radius-full);top:60%;right:15%;animation-delay:5s}.square{width:100px;height:100px;top:70%;left:20%;transform:rotate(45deg);animation-delay:10s}.hexagon{width:80px;height:80px;top:15%;right:25%;clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);animation-delay:15s}@keyframes floatAdvanced{0%,to{transform:translateY(0) rotate(0) scale(1);opacity:.3}25%{transform:translateY(-30px) rotate(90deg) scale(1.1);opacity:.5}50%{transform:translateY(20px) rotate(180deg) scale(.9);opacity:.2}75%{transform:translateY(-15px) rotate(270deg) scale(1.05);opacity:.4}}#particle-canvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:var(--z-background);pointer-events:none}:root[data-theme=light] #particle-canvas{opacity:1;filter:brightness(.4) contrast(1.5)}.particles{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:var(--z-shapes);display:none}.particle{position:absolute;width:2px;height:2px;background:#ffffff80;border-radius:var(--radius-full);animation:particleFloat 20s infinite linear}@keyframes particleFloat{0%{transform:translateY(100vh) translate(0);opacity:0}10%{opacity:1}90%{opacity:1}to{transform:translateY(-100vh) translate(100px);opacity:0}}.container{max-width:1200px;width:100%;margin:0 auto;padding:0 var(--spacing-lg);position:relative;z-index:var(--z-content)}.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;position:relative;background:radial-gradient(ellipse at center,rgba(255,255,255,.1) 0%,transparent 70%)}.hero:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(600px,90vw);height:min(600px,90vw);background:radial-gradient(circle,rgba(255,255,255,.05) 0%,transparent 70%);animation:pulseGlow 4s ease-in-out infinite}@keyframes pulseGlow{0%,to{transform:translate(-50%,-50%) scale(1);opacity:.6;background:radial-gradient(circle,rgba(124,77,255,.15) 0%,transparent 70%)}50%{transform:translate(-50%,-50%) scale(1.3);opacity:.3;background:radial-gradient(circle,rgba(0,210,255,.1) 0%,transparent 70%)}}.portfolio-label{color:var(--color-text-dark);text-transform:uppercase;letter-spacing:5px;font-size:var(--font-size-xs);margin-bottom:30px;animation:fadeInUp 1s ease forwards;opacity:0;animation-delay:.2s;text-align:center}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}h1{font-size:clamp(36px,8vw,96px);font-weight:800;margin-bottom:var(--spacing-md);color:var(--color-text);text-shadow:0 4px 20px rgba(124,77,255,.4);animation:fadeInUp 1s ease forwards;opacity:0;animation-delay:.4s;line-height:1.1;text-align:center;letter-spacing:-2px}@keyframes gradientText{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.subtitle{font-size:clamp(16px,4vw,18px);margin-bottom:var(--spacing-lg);animation:fadeInUp 1s ease forwards;opacity:0;animation-delay:.6s;text-align:center;background:var(--gradient-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;background-size:200% auto;animation:fadeInUp 1s ease forwards,gradientText 3s ease infinite;text-shadow:0 0 30px rgba(124,77,255,.4)}.cta-buttons{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);animation:fadeInUp 1s ease forwards;opacity:0;animation-delay:.8s;flex-wrap:wrap;justify-content:center}.btn{padding:14px 35px;background:transparent;border:1px solid var(--color-border);color:var(--color-text);cursor:pointer;transition:all var(--transition-base);font-size:var(--font-size-sm);text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;position:relative;overflow:hidden;border-radius:var(--radius-full);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:1px;z-index:1}.btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--gradient-primary);opacity:0;transition:opacity var(--transition-base);z-index:-1}.btn.primary{background:var(--gradient-primary);color:#fff;border:none;box-shadow:0 4px 15px #7c4dff4d}.btn.primary:hover{transform:translateY(-2px);box-shadow:0 8px 25px #7c4dff80}.btn.secondary{background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}.btn.secondary:hover{background:#ffffff1a;transform:translateY(-2px);box-shadow:0 4px 15px #0000004d;border-color:#fff3}.btn.outline{border-color:var(--color-primary);color:var(--color-primary)}.btn.outline:hover{color:#fff;border-color:transparent;box-shadow:0 4px 15px #7c4dff4d}.btn.outline:hover:before{opacity:1}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:4px}.social-links{display:flex;gap:25px;justify-content:center;animation:fadeInUp 1s ease forwards;opacity:0;animation-delay:1s}.social-links a{color:var(--color-text-dark);transition:all var(--transition-base);position:relative;display:inline-flex}.social-links a:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:5px;height:5px;background:var(--color-primary);border-radius:var(--radius-full);opacity:0;transition:all var(--transition-base)}.social-links a:hover{color:var(--color-text);transform:translateY(-3px)}.social-links a:hover:after{opacity:1;box-shadow:0 0 10px #fff}.social-links a:focus-visible{outline:2px solid var(--color-primary);outline-offset:4px;border-radius:4px}.glass-card{background:#0f0f1966;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,255,255,.08);border-radius:24px;overflow:hidden;position:relative;box-shadow:inset 0 0 0 1px #ffffff0d,0 8px 32px #0000004d;transition:transform var(--transition-base),box-shadow var(--transition-base)}.glass-card:hover{transform:translateY(-5px);box-shadow:inset 0 0 0 1px #ffffff1a,0 15px 40px #7c4dff26}.glass-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(124,77,255,.5),rgba(0,210,255,.5),transparent);animation:shimmer 3s infinite linear}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.about{padding:var(--spacing-2xl) 0;position:relative;min-height:100vh}.about .container{display:flex;flex-direction:column;align-items:center;width:100%;max-width:1100px;margin:0 auto;padding:0 var(--spacing-lg)}.about h2{font-size:clamp(32px,6vw,48px);margin-bottom:var(--spacing-lg);background:var(--gradient-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-align:center}:root[data-theme=light] .about h2,:root[data-theme=light] .projects h2,:root[data-theme=light] .contact h2,:root[data-theme=light] h2{background:#000;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.about-content{max-width:800px;line-height:1.8;color:var(--color-text-muted);margin-bottom:var(--spacing-xl);font-size:var(--font-size-lg);text-align:center}.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;width:100%;max-width:1000px;margin:0 auto}@media (max-width: 768px){.about-grid{grid-template-columns:1fr;gap:30px}.about .container{padding:0 var(--spacing-md)}.about-content{padding:0 var(--spacing-sm)}}.timeline-section,.skills-section{background:var(--color-surface-glass);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:30px;transition:transform var(--transition-base),box-shadow var(--transition-base)}.timeline-section:hover,.skills-section:hover{transform:translateY(-5px);border-color:var(--color-border-hover);box-shadow:0 10px 40px #ffffff1a,0 0 30px #ffffff0d,inset 0 0 20px #ffffff05}:root[data-theme=light] .timeline-section:hover,:root[data-theme=light] .skills-section:hover{box-shadow:0 10px 40px #6464ff26,0 0 30px #6464ff1a,inset 0 0 20px #6464ff08}.section-title{font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:2px;color:var(--color-accent);margin-bottom:25px;font-weight:600;display:flex;align-items:center;gap:10px}.section-title:before{content:"";width:20px;height:2px;background:var(--color-accent)}.timeline{position:relative;padding-left:30px;border-left:1px solid var(--color-border)}.timeline-item{position:relative;margin-bottom:40px}.timeline-item:before{content:"";position:absolute;left:-35px;top:5px;width:10px;height:10px;background:var(--color-bg);border:2px solid var(--color-text);border-radius:50%}.timeline-date{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:5px}.timeline-content h3{font-size:var(--font-size-lg);color:var(--color-text);margin-bottom:5px}.timeline-content p{font-size:var(--font-size-sm);color:var(--color-text-dark);margin-bottom:5px}.grade{font-size:var(--font-size-xs);color:var(--color-text);padding:2px 8px;border:1px solid var(--color-border);border-radius:var(--radius-sm);display:inline-block}.skill-category{margin-bottom:var(--spacing-md);transition:all var(--transition-base)}.skill-category:hover{padding-left:var(--spacing-sm)}.skill-label{color:var(--color-text);font-size:var(--font-size-sm);margin-bottom:var(--spacing-xs);font-weight:500}.skill-items{color:var(--color-text-dark);font-size:var(--font-size-sm);line-height:1.6}.projects{padding:var(--spacing-2xl) 0;position:relative}.section-header{text-align:center;margin-bottom:60px}.section-header h2{font-size:clamp(36px,6vw,56px);margin-bottom:16px;background:var(--gradient-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700}.section-subtitle{font-size:var(--font-size-lg);color:var(--color-text-dark);max-width:600px;margin:0 auto;line-height:1.6}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(340px,100%),1fr));gap:32px;max-width:1200px;margin:0 auto}.project-card{background:#ffffff05;border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:32px;display:flex;flex-direction:column;gap:24px;transition:all .3s ease;position:relative;overflow:hidden}.project-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);opacity:0;transition:opacity .3s ease}.project-card:hover{border-color:#7c4dff66;background:#0f0f19cc;transform:translateY(-8px);box-shadow:0 15px 35px #0006,0 0 40px #7c4dff26,inset 0 0 0 1px #7c4dff33}.project-card:hover:before{opacity:1}:root[data-theme=light] .project-card{background:#00000005;border:1px solid rgba(0,0,0,.15);box-shadow:0 2px 8px #0000000f}:root[data-theme=light] .project-card:before{background:linear-gradient(90deg,transparent,rgba(0,0,0,.1),transparent)}:root[data-theme=light] .project-card:hover{border-color:#00000040;background:#0000000a;box-shadow:0 8px 32px #0000001f,0 0 40px #6464ff26,0 0 20px #6464ff1a}.project-header{display:flex;justify-content:space-between;align-items:flex-start}.project-icon{width:48px;height:48px;border-radius:12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:var(--color-text);transition:all .3s ease}.project-card:hover .project-icon{background:#ffffff1a;transform:scale(1.1)}.project-icon i{width:24px;height:24px}.project-meta{display:flex;align-items:center;gap:8px}.project-number{font-family:var(--font-mono);font-size:var(--font-size-xs);color:var(--color-text-muted);font-weight:600}.project-badge{padding:4px 12px;background:#6366f133;border:1px solid rgba(99,102,241,.3);border-radius:var(--radius-full);font-size:11px;font-weight:600;color:#a5b4fc;text-transform:uppercase;letter-spacing:.5px}.project-body{flex-grow:1;display:flex;flex-direction:column;gap:12px}.project-title{font-size:22px;font-weight:600;color:var(--color-text);line-height:1.3;margin:0}.project-description{font-size:15px;line-height:1.6;color:var(--color-text-dark);margin:0}.tech-stack{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}.tech-tag{font-size:13px;color:var(--color-text-muted);background:#7c4dff26;border:1px solid rgba(124,77,255,.3);padding:4px 12px;border-radius:20px;font-family:var(--font-mono);transition:all .3s ease}.project-card:hover .tech-tag{background:#7c4dff40;border-color:#7c4dff80;color:#fff}.project-footer{display:flex;gap:12px;padding-top:8px;border-top:1px solid rgba(255,255,255,.05)}.project-link{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:var(--color-text);text-decoration:none;font-size:14px;font-weight:500;transition:all .3s ease;cursor:pointer}.project-link i{width:16px;height:16px;transition:transform .3s ease}.project-link:hover{background:#ffffff1a;border-color:#ffffff4d;transform:translateY(-2px)}.project-link:hover i{transform:translate(2px) translateY(-2px)}.project-link.primary{background:#6366f1;border-color:#6366f1;color:#fff;font-weight:600}.project-link.primary:hover{background:#4f46e5;border-color:#4f46e5;color:#fff;box-shadow:0 0 20px #6366f166}.project-link.secondary{background:transparent;border-color:#fff3;color:var(--color-text)}.project-link.secondary:hover{background:#ffffff1a;border-color:#fff6}:root[data-theme=light] .project-link.primary{background:#4f46e5;border-color:#4f46e5;color:#fff}:root[data-theme=light] .project-link.primary:hover{background:#4338ca;border-color:#4338ca;box-shadow:0 0 20px #4f46e54d}:root[data-theme=light] .project-link.secondary{border-color:#0003;color:var(--color-text)}:root[data-theme=light] .project-link.secondary:hover{background:#0000000d;border-color:#0000004d}.project-card.featured{background:linear-gradient(135deg,#6366f10d,#8b5cf60d);border-color:#6366f133}.project-card.featured:hover{border-color:#6366f166;background:linear-gradient(135deg,#6366f11a,#8b5cf61a)}@media (max-width: 768px){.projects-grid{grid-template-columns:1fr;gap:24px}.project-card{padding:24px}.project-footer{flex-direction:column}.project-link{width:100%}}.contact{padding:var(--spacing-2xl) 0;text-align:center;position:relative}.contact h2{font-size:clamp(32px,6vw,48px);margin-bottom:30px;background:linear-gradient(135deg,#fff,#333);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.contact-description{color:var(--color-text-muted);font-size:var(--font-size-base);margin-bottom:var(--spacing-lg)}.contact-links{display:flex;gap:var(--spacing-lg);justify-content:center;flex-wrap:wrap}.contact-item{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--color-text-dark);text-decoration:none;transition:all var(--transition-base);padding:var(--spacing-sm) var(--spacing-md);background:#0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:25px}.contact-item:hover{color:var(--color-text);background:#ffffff1a;border-color:#ffffff4d;transform:translateY(-3px);box-shadow:var(--shadow-lg)}.contact-item:focus-visible{outline:2px solid var(--color-primary);outline-offset:4px}footer{background:linear-gradient(180deg,#0a0a0a00,#141414cc,#0f0f0f);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid rgba(100,100,100,.2);padding:var(--spacing-xl) var(--spacing-lg) 30px;position:relative;overflow:hidden}:root[data-theme=light] footer{background:linear-gradient(180deg,#fff0,#f8f9fae6,#fff);border-top:1px solid rgba(0,0,0,.1)}:root[data-theme=light] .footer-logo{background:#000;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}:root[data-theme=light] .footer-tagline,:root[data-theme=light] .footer-section-title,:root[data-theme=light] .footer-link,:root[data-theme=light] .footer-bottom p{color:#000}:root[data-theme=light] .footer-tagline{color:#2d3748}footer:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,#333,#555,#333,transparent);animation:shimmer 3s linear infinite}.footer-content{max-width:1200px;margin:0 auto 50px;display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:50px}.footer-left{display:flex;flex-direction:column;gap:15px}.footer-logo{font-size:32px;font-weight:700;background:linear-gradient(135deg,#fff,#fff,#fff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:1px;margin-bottom:var(--spacing-xs)}.footer-logo:hover{background:linear-gradient(135deg,#fff,#fff,#fff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.footer-tagline{color:#999;font-size:15px;line-height:1.6;max-width:300px}.footer-section-title{color:var(--color-text);font-size:var(--font-size-base);font-weight:600;margin-bottom:var(--spacing-md);text-transform:uppercase;letter-spacing:2px;position:relative;padding-bottom:var(--spacing-sm)}.footer-section-title:after{content:"";position:absolute;left:0;bottom:0;width:40px;height:2px;background:linear-gradient(90deg,#333,#555)}.footer-center{display:flex;flex-direction:column;gap:15px}.footer-link{color:var(--color-text-light);text-decoration:none;font-size:15px;transition:all var(--transition-base);position:relative;padding-left:0;width:fit-content}.footer-link:before{content:"→";position:absolute;left:-20px;opacity:0;transition:all var(--transition-base);color:#333}.footer-link:hover{color:var(--color-text);padding-left:var(--spacing-md);transform:translate(5px)}.footer-link:hover:before{opacity:1;left:0}.footer-link:focus-visible{outline:2px solid #333;outline-offset:4px;border-radius:2px}.footer-right{display:flex;flex-direction:column;gap:var(--spacing-md)}.footer-social-container{display:flex;gap:15px;flex-wrap:wrap}.footer-social{width:50px;height:50px;border-radius:var(--radius-xl);background:#0000004d;border:1px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;text-decoration:none;font-size:22px;transition:all var(--transition-base);position:relative;overflow:hidden;color:var(--color-text-light)}.footer-social:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:var(--radius-full);background:radial-gradient(circle,rgba(255,255,255,.4),transparent);transform:translate(-50%,-50%);transition:all var(--transition-slow)}.footer-social:hover:before{width:100px;height:100px}.footer-social:hover{transform:translateY(-5px);border-color:#fff;box-shadow:0 10px 30px #fff6;background:#fff3;color:var(--color-text)}.footer-social:focus-visible{outline:2px solid #333;outline-offset:4px}.footer-bottom{max-width:1200px;margin:0 auto;padding-top:30px;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md)}.footer-logo-svg{filter:drop-shadow(0 0 8px rgba(100,100,100,.6));transition:transform var(--transition-base)}.footer-logo-svg:hover{transform:scale(1.1)}.footer-bottom p{color:var(--color-text-dark);font-size:var(--font-size-sm);text-align:center}.footer-bottom span{color:#333;font-weight:600}.scroll-indicator{position:absolute;bottom:30px;left:50%;transform:translate(-50%);animation:bounce 2s infinite;cursor:pointer}.scroll-indicator:before{content:"";display:block;width:20px;height:30px;border:2px solid rgba(255,255,255,.3);border-radius:10px;position:relative}.scroll-indicator:after{content:"";display:block;width:4px;height:8px;background:var(--color-primary);border-radius:2px;position:absolute;top:8px;left:50%;transform:translate(-50%);animation:scrollDot 2s infinite}@keyframes bounce{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(10px)}}@keyframes scrollDot{0%,to{transform:translate(-50%) translateY(0);opacity:1}50%{transform:translate(-50%) translateY(5px);opacity:.5}}@media (max-width: 968px){:root{--spacing-lg: 30px;--spacing-xl: 50px;--spacing-2xl: 80px}.footer-content{grid-template-columns:1fr;gap:var(--spacing-lg);text-align:center}.footer-left,.footer-center,.footer-right{align-items:center}.footer-section-title:after{left:50%;transform:translate(-50%)}.footer-social-container{justify-content:center}.footer-link,.footer-tagline{margin:0 auto}}@media (max-width: 768px){:root{--spacing-md: 15px;--spacing-lg: 20px;--spacing-xl: 40px;--spacing-2xl: 60px}nav{padding:15px 20px}.logo{font-size:var(--font-size-lg)}.container{padding:0 var(--spacing-md);display:flex;flex-direction:column;align-items:center}.nav-links{position:fixed;top:60px;left:-100%;width:100%;height:calc(100vh - 60px);background:#000000fa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);flex-direction:column;align-items:center;justify-content:center;gap:30px;transition:left var(--transition-base);padding:var(--spacing-lg)}.nav-links.active{left:0}.nav-links a{font-size:var(--font-size-base);padding:var(--spacing-sm) 0;color:var(--color-text)}.hero .container{width:100%;max-width:100%;text-align:center;align-items:center}.portfolio-label,h1,.subtitle{width:100%;text-align:center;margin-left:auto;margin-right:auto}.subtitle{max-width:100%;padding:0 var(--spacing-md)}.cta-buttons{width:100%;max-width:400px;margin-left:auto;margin-right:auto;justify-content:center}.social-links{width:100%;justify-content:center}.about-grid,.projects-grid{grid-template-columns:1fr;gap:var(--spacing-md);width:100%}.about h2,.projects h2,.contact h2{text-align:center;width:100%}.about-content{text-align:center;width:100%;max-width:100%;margin-left:auto;margin-right:auto}.timeline-section,.skills-section{padding:var(--spacing-lg);width:100%;max-width:500px;margin:0 auto;text-align:left}.section-title{justify-content:center}.timeline{padding-left:25px}.timeline-item:before{left:-30px}.skill-category{text-align:left}.project-card{padding:25px var(--spacing-md);width:100%;max-width:500px;margin:0 auto}.project-header{flex-direction:row;justify-content:space-between;align-items:center}.project-body,.project-title,.project-description{text-align:left}.tech-stack{justify-content:flex-start}.project-footer{flex-direction:column;gap:12px}.project-link{width:100%;justify-content:center}.project-link.primary,.project-link.secondary{width:100%;text-align:center;justify-content:center}.view-project{display:inline-block;margin:0 auto}.contact-links{flex-direction:column;align-items:center;width:100%}.contact-item{width:100%;max-width:400px;justify-content:center}}@media (max-width: 600px){.container{padding:0 var(--spacing-md);display:flex;flex-direction:column;align-items:center}.hero .container,.about .container,.projects .container,.contact .container{align-items:center;text-align:center}.subtitle{font-size:var(--font-size-sm);padding:0 var(--spacing-md);text-align:center;width:100%}.social-links{gap:var(--spacing-md);width:100%;justify-content:center}.social-links a svg{width:20px;height:20px}.btn{font-size:13px;padding:12px 28px;width:100%;max-width:280px}.about-grid,.projects-grid{width:100%;display:flex;flex-direction:column;align-items:center}}@media (max-width: 480px){:root{--font-size-2xl: 36px}.container{padding:0 var(--spacing-md);display:flex;flex-direction:column;align-items:center}.footer-logo{font-size:24px}.footer-social{width:45px;height:45px;font-size:20px}h1{font-size:clamp(32px,10vw,48px);text-align:center;width:100%}.about h2,.projects h2,.contact h2{font-size:clamp(28px,8vw,36px);text-align:center;width:100%}.cta-buttons{flex-direction:column;width:100%;max-width:300px;gap:12px;margin-left:auto;margin-right:auto}.btn{width:100%;max-width:300px;text-align:center}.about-content{font-size:var(--font-size-sm);text-align:center;width:100%}.project-card{padding:var(--spacing-md);text-align:center;width:100%}.contact-links{max-width:280px;margin:0 auto;width:100%}.contact-description{text-align:center;width:100%}footer{padding:30px 15px 20px}.education-section,.skills-section{width:100%;text-align:center}.degree{justify-content:center;text-align:center}.institution{text-align:center}}@media (max-width: 375px){.container{padding:0 12px;display:flex;flex-direction:column;align-items:center}h1{font-size:clamp(28px,10vw,36px);text-align:center;width:100%}.btn{padding:11px 24px;font-size:12px;width:100%;max-width:260px;text-align:center}.cta-buttons{width:100%;max-width:260px}footer{padding:25px 10px 15px}.footer-content{gap:30px}.about h2,.projects h2,.contact h2{text-align:center;width:100%}}@media (max-height: 600px) and (orientation: landscape){.hero{min-height:auto;padding:100px 0 60px}.hero:before{width:400px;height:400px}h1{font-size:clamp(32px,6vw,48px);margin-bottom:15px}.subtitle{margin-bottom:25px}.cta-buttons{margin-bottom:30px}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.glass-card:before{height:2px}.nav-links a:after{height:3px}}@media print{.geometric-shapes,.particles,.scroll-indicator,nav,.cta-buttons,.social-links{display:none}body{background:#fff;color:#000}body:before{display:none}.container{max-width:100%}}@media (min-width: 900px){.project-card{overflow:visible}.project-card .view-project{display:inline-flex;align-items:center;gap:.4rem;margin:0 8px 8px 0;vertical-align:middle}.project-card .view-project:last-of-type{margin-right:0}.projects-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}}.cursor-dot,.cursor-outline{position:fixed;top:0;left:0;transform:translate(-50%,-50%);border-radius:50%;z-index:9999;pointer-events:none}.cursor-dot{width:8px;height:8px;background-color:var(--accent)}.cursor-outline{width:40px;height:40px;border:2px solid var(--accent);background-color:transparent;transition:width .2s,height .2s,background-color .2s}.back-to-top{position:fixed;bottom:30px;right:30px;width:50px;height:50px;border-radius:50%;background:var(--card-bg);border:1px solid var(--border);color:var(--accent);display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;visibility:hidden;transform:translateY(20px);transition:all .3s ease;z-index:1000;box-shadow:0 4px 12px #0000004d}.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}.back-to-top:hover{background:var(--accent);color:var(--bg-primary);transform:translateY(-5px);box-shadow:0 6px 16px #b794f666}.back-to-top.launching{background:var(--accent);color:var(--bg-primary);box-shadow:0 0 20px var(--accent)}.nav-links a.active{color:var(--accent)}.nav-links a.active:after{width:100%}.scroll-progress{position:fixed;top:0;left:0;width:0%;height:4px;background:linear-gradient(90deg,var(--accent),#9d74e3);z-index:9999;transition:width .1s linear;box-shadow:0 0 10px #b794f680}.project-card,.glass-card,.workshop-card{transform-style:preserve-3d;perspective:1000px;will-change:transform}.project-content,.workshop-title,.badges,.meta-grid,.section{transform:translateZ(20px);transform-style:preserve-3d}
