.hero{align-items:center;display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:3rem 0;padding:var(--spacing-2xl) 0;position:relative}@media(max-width:768px){.hero{min-height:100dvh;padding:2rem 0;padding:var(--spacing-xl) 0}}.hero-background{overflow:hidden;z-index:-1}.hero-background,.hero-gradient{height:100%;left:0;position:absolute;top:0;width:100%}.hero-gradient{background:radial-gradient(circle at 50% 50%,#312e81 0,#0000 50%);background:radial-gradient(circle at 50% 50%,var(--primary-900) 0,#0000 50%);opacity:.3}.hero-container{grid-gap:3rem;grid-gap:var(--spacing-2xl);align-items:center;display:grid;gap:3rem;gap:var(--spacing-2xl);grid-template-columns:1fr 1fr;margin:0 auto;max-width:1200px;max-width:var(--container-max-width);padding:0 1.5rem;padding:0 var(--container-padding);position:relative;width:100%;z-index:1}@media(min-width:769px)and (max-width:1024px){.hero-container{gap:2rem;gap:var(--spacing-xl);grid-template-columns:1fr;text-align:center}}@media(max-width:768px){.hero-container{gap:1.5rem;gap:var(--spacing-lg);padding:0 1rem;padding:0 var(--spacing-md)}}.hero-content{max-width:600px}@media(min-width:769px)and (max-width:1024px){.hero-content{margin:0 auto;max-width:100%}}.hero-badge{margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.hero-badge .badge-text{align-items:center;background:var(--bg-surface);border:1px solid var(--border-primary);border-radius:9999px;border-radius:var(--radius-full);color:var(--text-secondary);display:inline-flex;font-size:.875rem;font-size:var(--text-sm);font-weight:500;font-weight:var(--font-medium);padding:.5rem 1rem;padding:var(--spacing-sm) var(--spacing-md)}.hero-title{color:var(--text-primary);font-size:clamp(2.5rem,5vw,3.5rem);font-weight:700;font-weight:var(--font-bold);line-height:1.1;margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.hero-title .title-line{display:block}@media(max-width:768px){.hero-title .title-line{display:inline}}.hero-title .title-gradient{background:linear-gradient(135deg,#6366f1,#4338ca);background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;color:#0000}.hero-subtitle{color:var(--text-secondary);font-size:1.125rem;font-size:var(--text-lg);font-weight:500;font-weight:var(--font-medium);line-height:1.4;margin-bottom:1rem;margin-bottom:var(--spacing-md)}.hero-subtitle .text-highlight{color:var(--text-primary);position:relative}.hero-subtitle .text-highlight:after{background:linear-gradient(135deg,#6366f1,#4338ca);background:var(--gradient-primary);border-radius:9999px;border-radius:var(--radius-full);bottom:2px;content:"";height:4px;left:0;opacity:.3;position:absolute;width:100%;z-index:-1}@media(max-width:768px){.hero-subtitle{font-size:1rem;font-size:var(--text-base)}}.hero-description{color:var(--text-muted);font-size:1rem;font-size:var(--text-base);line-height:1.6;margin-bottom:2rem;margin-bottom:var(--spacing-xl)}@media(max-width:768px){.hero-description{font-size:.875rem;font-size:var(--text-sm)}}.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;gap:var(--spacing-md);margin-bottom:2rem;margin-bottom:var(--spacing-xl)}@media(max-width:768px){.hero-actions{justify-content:center}}.btn.btn-primary{background:linear-gradient(135deg,#6366f1,#4338ca);background:var(--gradient-primary);color:var(--text-on-primary)}.btn.btn-primary:hover:not(:disabled){box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn.btn-outline{background:var(--bg-surface);border:1px solid var(--border-primary);color:var(--text-primary)}.btn.btn-outline:hover:not(:disabled){background:var(--bg-secondary);transform:translateY(-1px)}.hero-social{display:flex;gap:1rem;gap:var(--spacing-md)}@media(max-width:768px){.hero-social{justify-content:center}}.social-link{font-size:1.1rem;height:44px;width:44px}.social-link:hover{background:var(--bg-secondary)}.hero-visual{align-items:center;display:flex;justify-content:center}@media(min-width:769px)and (max-width:1024px){.hero-visual{order:-1}}.visual-container{max-width:380px;position:relative;width:100%}.code-window{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);overflow:hidden}.window-header{align-items:center;background:var(--bg-tertiary);border-bottom:1px solid var(--border-primary);display:flex;padding:1rem;padding:var(--spacing-md)}.window-controls{display:flex;gap:.25rem;gap:var(--spacing-xs);margin-right:1rem;margin-right:var(--spacing-md)}.window-controls .control{border-radius:50%;height:10px;width:10px}.window-controls .control.red{background:#ff5f56}.window-controls .control.yellow{background:#ffbd2e}.window-controls .control.green{background:#27ca3f}.window-title{color:var(--text-muted);font-family:Fira Code,Monaco,Cascadia Code,Roboto Mono,monospace;font-family:var(--font-mono);font-size:.875rem;font-size:var(--text-sm)}.window-content{padding:1.5rem;padding:var(--spacing-lg);position:relative}.code-block{color:var(--text-primary);font-family:Fira Code,Monaco,Cascadia Code,Roboto Mono,monospace;font-family:var(--font-mono);font-size:.875rem;font-size:var(--text-sm);line-height:1.5;margin:0;min-height:180px;overflow-x:auto}.code-block code{word-wrap:break-word;display:block;white-space:pre-wrap}.typing-cursor{animation:blink 1s infinite;background:#818cf8;background:var(--primary-400);display:inline-block;height:1.2em;margin-left:2px;width:2px}.code-complete-indicator{background:#10b9811a;border:1px solid #10b98133;border-radius:.5rem;border-radius:var(--radius-md);bottom:.5rem;bottom:var(--spacing-sm);color:#10b981;color:var(--success);font-family:Fira Code,Monaco,Cascadia Code,Roboto Mono,monospace;font-family:var(--font-mono);font-size:.75rem;font-size:var(--text-xs);padding:.25rem .5rem;padding:var(--spacing-xs) var(--spacing-sm);position:absolute;right:.5rem;right:var(--spacing-sm)}.hero-scroll{align-items:center;bottom:2rem;bottom:var(--spacing-xl);color:var(--text-muted);display:flex;flex-direction:column;font-size:.875rem;font-size:var(--text-sm);left:50%;position:absolute;transform:translateX(-50%)}.hero-scroll .scroll-indicator{background:var(--text-muted);border-radius:9999px;border-radius:var(--radius-full);height:30px;margin-bottom:.25rem;margin-bottom:var(--spacing-xs);position:relative;width:2px}.hero-scroll .scroll-indicator:before{background:linear-gradient(135deg,#6366f1,#4338ca);background:var(--gradient-primary);border-radius:9999px;border-radius:var(--radius-full);content:"";height:6px;left:0;position:absolute;top:0;width:100%}@media(prefers-reduced-motion:reduce){.typing-cursor{animation:none}.btn:hover,.social-link:hover{transform:none}}@media(max-width:768px){.hero-actions{align-items:center;flex-direction:column}.btn{max-width:260px;width:100%}.code-window{transform:scale(.85)}.code-block{font-size:.75rem;min-height:160px}}.about-section{background-color:var(--bg-primary);overflow:hidden;padding:4rem 0;padding:var(--spacing-3xl) 0;position:relative}@media(max-width:768px){.about-section{padding:3rem 0;padding:var(--spacing-2xl) 0}}.about-container{margin:0 auto;max-width:1200px;max-width:var(--container-max-width);padding:0 1.5rem;padding:0 var(--container-padding);position:relative;z-index:1}.section-title{display:inline-block;font-size:clamp(1.875rem,5vw,2.25rem);font-size:clamp(var(--text-3xl),5vw,var(--text-4xl));position:relative}@media(max-width:768px){.section-title{display:block;margin-bottom:3rem;margin-bottom:var(--spacing-2xl);text-align:center}}.highlight{color:#818cf8;color:var(--primary-400);margin-right:.5rem;margin-right:var(--spacing-sm)}.about-grid{grid-gap:3rem;grid-gap:var(--spacing-2xl);align-items:center;display:grid;gap:3rem;gap:var(--spacing-2xl);grid-template-columns:1fr 1.5fr}@media(min-width:769px)and (max-width:1024px){.about-grid{gap:2rem;gap:var(--spacing-xl);grid-template-columns:1fr}}.about-image-container{position:relative}@media(min-width:769px)and (max-width:1024px){.about-image-container{margin:0 auto;max-width:400px}}.about-image-wrapper{border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 25px 50px -12px #00000040;box-shadow:var(--shadow-2xl);overflow:hidden;position:relative;transform:perspective(1000px) rotateY(-5deg)}@media(max-width:768px){.about-image-wrapper{transform:none}}.about-image{display:block;filter:grayscale(20%) contrast(110%);height:auto;position:relative;transition:filter .3s ease;transition:filter var(--transition-normal);width:100%;z-index:1}.about-image:hover{filter:grayscale(0) contrast(120%)}.about-image-border{border:2px solid #818cf8;border:2px solid var(--primary-400);border-radius:1rem;border-radius:var(--radius-xl);bottom:-10px;left:-10px;opacity:.5;position:absolute;right:-10px;top:-10px;z-index:0}.about-image-grid{background-image:linear-gradient(#ffffff0d 1px,#0000 0),linear-gradient(90deg,#ffffff0d 1px,#0000 0);background-size:20px 20px;pointer-events:none;z-index:2}.about-image-glow,.about-image-grid{height:100%;left:0;position:absolute;top:0;width:100%}.about-image-glow{background:radial-gradient(circle at center,#3a86ff26 0,#0000 70%);z-index:1}.about-content{color:var(--text-secondary)}@media(min-width:769px)and (max-width:1024px){.about-content{text-align:center}}.about-name{font-size:clamp(1.5rem,3vw,1.875rem);font-size:clamp(var(--text-2xl),3vw,var(--text-3xl));font-weight:700;font-weight:var(--font-bold);margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.name-gradient{text-fill-color:#0000;background:linear-gradient(135deg,#6366f1,#4338ca);background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;color:#0000}.about-role{color:var(--text-muted);font-size:1.125rem;font-size:var(--text-lg);margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}@media(max-width:768px){.about-role{font-size:1rem;font-size:var(--text-base)}}.role-outline{-webkit-text-stroke:1px #818cf8;-webkit-text-stroke:1px var(--primary-400);color:#0000}.about-bio{color:var(--text-primary);font-size:1.25rem;font-size:var(--text-xl);font-weight:500;font-weight:var(--font-medium);line-height:1.6;margin-bottom:2rem;margin-bottom:var(--spacing-xl)}@media(max-width:768px){.about-bio{font-size:1.125rem;font-size:var(--text-lg)}}.about-text{margin-bottom:3rem;margin-bottom:var(--spacing-2xl)}.about-text p{color:var(--text-secondary);font-size:1rem;font-size:var(--text-base);line-height:1.8;margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}@media(max-width:768px){.about-text p{font-size:.875rem;font-size:var(--text-sm)}}.text-highlight{display:inline-block}.text-highlight:after{height:6px;opacity:.5}.skills-heading{color:var(--text-primary);font-size:1.25rem;font-size:var(--text-xl);font-weight:600;font-weight:var(--font-semibold);margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}@media(max-width:768px){.skills-heading{font-size:1.125rem;font-size:var(--text-lg)}}.skills-grid{grid-gap:1rem;grid-gap:var(--spacing-md);display:grid;gap:1rem;gap:var(--spacing-md);grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}@media(max-width:768px){.skills-grid{gap:.5rem;gap:var(--spacing-sm);grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}.skill-item{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-card);border:1px solid var(--border-primary);border-radius:.75rem;border-radius:var(--radius-lg);color:var(--text-primary);cursor:default;display:flex;font-size:.875rem;font-size:var(--text-sm);font-weight:500;font-weight:var(--font-medium);padding:1rem;padding:var(--spacing-md);transition:all .3s ease;transition:all var(--transition-normal)}.skill-item:hover{border-color:var(--border-accent);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);transform:translateY(-4px)}.skill-icon{align-items:center;display:flex;flex-shrink:0;font-size:1.1rem;margin-right:.5rem;margin-right:var(--spacing-sm)}@media(prefers-reduced-motion:reduce){.about-image{filter:grayscale(0) contrast(120%);transition:none}.skill-item:hover{transform:none}}@media(prefers-contrast:high){.about-image-border{border-width:3px;opacity:1}.skill-item{border:2px solid var(--border-primary)}}@media print{.about-section{background:#fff!important;color:#000!important}.about-image{filter:grayscale(100%) contrast(100%)}.skill-item{border:1px solid #ccc;box-shadow:none!important}}.section.projects{background-color:var(--bg-primary);overflow:hidden;padding:4rem 0;padding:var(--spacing-3xl) 0;position:relative}@media(max-width:768px){.section.projects{padding:3rem 0;padding:var(--spacing-2xl) 0}}.ios-video-hidden{height:1px;opacity:0;position:absolute;width:1px}.ios-video-preview{cursor:pointer;height:100%;position:relative;width:100%}.ios-video-preview img{border-radius:.75rem;border-radius:var(--radius-lg);height:100%;object-fit:cover;width:100%}.ios-play-button{align-items:center;background:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:50px;justify-content:center;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:50px;z-index:3}.ios-play-button:hover{background:#000000e6}.ios-play-button-large{align-items:center;background:#000c;border:none;border-radius:.75rem;border-radius:var(--radius-lg);color:#fff;cursor:pointer;display:flex;font-weight:500;font-weight:var(--font-medium);gap:.5rem;gap:var(--spacing-sm);justify-content:center;left:50%;padding:1rem 1.5rem;padding:var(--spacing-md) var(--spacing-lg);position:absolute;top:50%;transform:translate(-50%,-50%);z-index:3}.ios-play-button-large:hover{background:#000000e6}.project-fallback{align-items:center;background:var(--bg-surface);border-radius:.75rem;border-radius:var(--radius-lg);color:var(--text-muted);display:flex;flex-direction:column;height:100%;justify-content:center;width:100%}.project-fallback svg{margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.project-fallback span{font-size:.875rem;font-size:var(--text-sm);padding:0 1rem;padding:0 var(--spacing-md);text-align:center}.thumbnail-fallback{align-items:center;background:var(--bg-surface);border-radius:.5rem;border-radius:var(--radius-md);color:var(--text-muted);height:100%;width:100%}.project-tabs,.thumbnail-fallback{display:flex;justify-content:center}.project-tabs{flex-wrap:wrap;gap:.5rem;gap:var(--spacing-sm);margin-bottom:3rem;margin-bottom:var(--spacing-2xl)}@media(max-width:768px){.project-tabs{gap:.25rem;gap:var(--spacing-xs);margin-bottom:2rem;margin-bottom:var(--spacing-xl)}}.tab-button{align-items:center;background:var(--bg-surface);border:none;border:1px solid var(--border-primary);border-radius:.5rem;border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;display:inline-flex;font-size:1rem;font-size:var(--text-base);font-size:.875rem;font-size:var(--text-sm);font-weight:500;font-weight:var(--font-medium);gap:.5rem;gap:var(--spacing-sm);justify-content:center;line-height:1;min-height:44px;min-width:44px;padding:.5rem 1rem;padding:var(--spacing-sm) var(--spacing-md);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast);white-space:nowrap}.tab-button:disabled{cursor:not-allowed;opacity:.6}@media(max-width:768px){.tab-button{min-height:48px;min-width:48px}}.tab-button:hover:not(:disabled){background:var(--bg-secondary);transform:translateY(-1px)}.tab-button.active{background:#3a86ff33;border-color:#818cf8;border-color:var(--primary-400);color:var(--text-primary)}.tab-button:hover:not(.active){background:var(--bg-surface)}@media(max-width:768px){.tab-button{font-size:.75rem;font-size:var(--text-xs);padding:.25rem .5rem;padding:var(--spacing-xs) var(--spacing-sm)}}.loading-grid{grid-gap:2rem;grid-gap:var(--spacing-xl);display:grid;gap:2rem;gap:var(--spacing-xl);grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}@media(max-width:768px){.loading-grid{gap:1.5rem;gap:var(--spacing-lg);grid-template-columns:1fr}}.project-skeleton{aspect-ratio:16/9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-card);border:1px solid var(--border-primary);border-radius:.75rem;border-radius:var(--radius-lg);overflow:hidden;padding:1.5rem;padding:var(--spacing-lg);position:relative;transition:all .3s ease;transition:all var(--transition-normal)}.project-skeleton:hover{border-color:var(--border-accent);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);transform:translateY(-4px)}.project-skeleton:after{animation:loading 1.5s infinite;background:linear-gradient(90deg,#fff0,#ffffff0d 50%,#fff0);bottom:0;content:"";left:0;position:absolute;right:0;top:0}.project-grid{grid-gap:2rem;grid-gap:var(--spacing-xl);display:grid;gap:2rem;gap:var(--spacing-xl);grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}@media(max-width:768px){.project-grid{gap:1.5rem;gap:var(--spacing-lg);grid-template-columns:1fr}}@media(min-width:769px)and (max-width:1024px){.project-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1025px){.project-grid{grid-template-columns:repeat(3,1fr)}}.project-card{aspect-ratio:16/9;cursor:pointer;overflow:hidden;position:relative}@media(max-width:768px){.project-card:hover{transform:none}}.project-media{height:100%;position:relative;width:100%}.project-media img,.project-media video{object-fit:cover}.project-media img,.project-media video,.project-overlay{height:100%;transition:.3s ease;transition:var(--transition-normal);width:100%}.project-overlay{background:linear-gradient(0deg,#000000e6 0,#0000004d 50%,#0000);display:flex;flex-direction:column;justify-content:flex-end;left:0;opacity:0;padding:1.5rem;padding:var(--spacing-lg);position:absolute;top:0}@media(max-width:768px){.project-overlay{background:linear-gradient(0deg,#000000e6 0,#00000080 50%,#0000);opacity:1;padding:1rem;padding:var(--spacing-md)}}.project-card:hover .project-overlay{opacity:1}.project-overlay-content{transform:translateY(20px);transition:.3s ease;transition:var(--transition-normal)}@media(max-width:768px){.project-overlay-content{transform:translateY(0)}}.project-card:hover .project-overlay-content{transform:translateY(0)}.project-description{-webkit-line-clamp:3;-webkit-box-orient:vertical;display:-webkit-box;line-height:1.5;overflow:hidden}@media(max-width:768px){.project-description{-webkit-line-clamp:2;font-size:.75rem;font-size:var(--text-xs);margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}}.project-links{display:flex;gap:.5rem;gap:var(--spacing-sm);justify-content:center}@media(max-width:768px){.project-links{flex-direction:column;gap:.25rem;gap:var(--spacing-xs)}}.project-link{align-items:center;background:var(--bg-surface);border:none;border:1px solid var(--border-primary);border-radius:.5rem;border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;display:inline-flex;display:flex;font-size:1rem;font-size:var(--text-base);font-size:.75rem;font-size:var(--text-xs);font-weight:500;font-weight:var(--font-medium);gap:.5rem;gap:var(--spacing-sm);gap:.25rem;gap:var(--spacing-xs);justify-content:center;line-height:1;min-height:44px;min-height:auto;min-width:44px;min-width:auto;padding:.25rem .5rem;padding:var(--spacing-xs) var(--spacing-sm);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast)}.project-link:disabled{cursor:not-allowed;opacity:.6}@media(max-width:768px){.project-link{min-height:48px;min-width:48px}}.project-link:hover:not(:disabled){background:var(--bg-secondary);transform:translateY(-1px)}.project-link:hover{background:#818cf8;background:var(--primary-400);color:var(--text-on-primary)}@media(max-width:768px){.project-link{font-size:.7rem;justify-content:center;padding:.25rem;padding:var(--spacing-xs)}}.project-info{background:linear-gradient(0deg,#000c 0,#0000);bottom:0;left:0;padding:1rem;padding:var(--spacing-md);position:absolute;right:0}@media(max-width:768px){.project-info{padding:.5rem;padding:var(--spacing-sm)}}.project-title{margin-bottom:.25rem;margin-bottom:var(--spacing-xs)}@media(max-width:768px){.project-title{font-size:.875rem;font-size:var(--text-sm)}}.project-tags{display:flex;flex-wrap:wrap;gap:.25rem;gap:var(--spacing-xs)}@media(max-width:768px){.project-tags{gap:.2rem}}.project-tag{background:#3a86ff1a;border-radius:9999px;border-radius:var(--radius-full);color:#818cf8;color:var(--primary-400);font-size:.75rem;font-size:var(--text-xs);font-weight:500;font-weight:var(--font-medium);padding:.25rem .5rem;padding:var(--spacing-xs) var(--spacing-sm)}@media(max-width:768px){.project-tag{font-size:.6rem;padding:.2rem .4rem}}.view-more-container{margin-top:3rem;margin-top:var(--spacing-2xl);text-align:center}@media(max-width:768px){.view-more-container{margin-top:2rem;margin-top:var(--spacing-xl)}}.view-more-btn{align-items:center;background:var(--bg-surface);border:none;border:1px solid var(--border-primary);border-radius:.5rem;border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;display:inline-flex;font-size:1rem;font-size:var(--text-base);font-weight:500;font-weight:var(--font-medium);font-weight:600;font-weight:var(--font-semibold);gap:.5rem;gap:var(--spacing-sm);justify-content:center;line-height:1;min-height:44px;min-width:44px;padding:1rem 2rem;padding:var(--spacing-md) var(--spacing-xl);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast)}.view-more-btn:disabled{cursor:not-allowed;opacity:.6}@media(max-width:768px){.view-more-btn{min-height:48px;min-width:48px}}.view-more-btn:hover:not(:disabled){background:var(--bg-secondary);transform:translateY(-1px)}.view-more-btn:hover{transform:translateY(-2px)}@media(max-width:768px){.view-more-btn{max-width:300px;padding:.5rem 1.5rem;padding:var(--spacing-sm) var(--spacing-lg);width:100%}}.projects-modal{align-items:center;display:flex;height:100%;justify-content:center;left:0;padding:1rem;padding:var(--spacing-md);position:fixed;top:0;width:100%;z-index:1040;z-index:var(--z-modal)}@media(max-width:768px){.projects-modal{align-items:flex-end;padding:0}}.modal-overlay{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000000e6;height:100%;left:0;position:absolute;top:0;width:100%}@media(max-width:768px){.modal-overlay{background:#000000f2}}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:1rem;border-radius:var(--radius-xl);box-shadow:0 25px 50px -12px #00000040;box-shadow:var(--shadow-2xl);display:flex;flex-direction:column;max-height:90vh;max-width:1200px;overflow:hidden;position:relative;width:100%}@media(max-width:768px){.modal-content{border-radius:0;height:100vh;max-height:100vh;max-width:100%;width:100%}}@media(min-width:769px)and (max-width:1024px){.modal-content{max-height:95vh}}.modal-close-btn{align-items:center;background:var(--bg-surface);border:none;border-radius:50%;color:var(--text-primary);cursor:pointer;display:flex;height:44px;justify-content:center;position:absolute;right:1.5rem;right:var(--spacing-lg);top:1.5rem;top:var(--spacing-lg);transition:.15s ease;transition:var(--transition-fast);width:44px;z-index:10}.modal-close-btn:hover{background:#818cf8;background:var(--primary-400);color:var(--text-on-primary)}@media(max-width:768px){.modal-close-btn{background:#000000b3;color:#fff;height:40px;right:1rem;right:var(--spacing-md);top:1rem;top:var(--spacing-md);width:40px}}.modal-header{padding:2rem 2rem 0;padding:var(--spacing-xl) var(--spacing-xl) 0}@media(max-width:768px){.modal-header{background:var(--bg-secondary);padding:1.5rem 1.5rem 0;padding:var(--spacing-lg) var(--spacing-lg) 0;padding-top:calc(1.5rem + 60px);padding-top:calc(var(--spacing-lg) + 60px);position:-webkit-sticky;position:sticky;top:0;z-index:5}}.modal-title{align-items:center;color:var(--text-primary);display:flex;font-size:1.5rem;font-size:var(--text-2xl);gap:.5rem;gap:var(--spacing-sm);margin:0}@media(max-width:768px){.modal-title{align-items:flex-start;flex-direction:column;font-size:1.25rem;font-size:var(--text-xl);gap:.25rem;gap:var(--spacing-xs)}}.project-count{color:var(--text-muted);font-size:1rem;font-size:var(--text-base);font-weight:var(--font-normal)}@media(max-width:768px){.project-count{font-size:.875rem;font-size:var(--text-sm)}}.modal-project-view{align-items:center;display:flex;flex:1 1;min-height:0;padding:0 2rem;padding:0 var(--spacing-xl)}@media(max-width:768px){.modal-project-view{flex-direction:column;height:calc(100vh - 200px);padding:0}}.nav-arrow{align-items:center;background:var(--bg-surface);border:none;border-radius:50%;color:var(--text-primary);cursor:pointer;display:flex;flex-shrink:0;height:44px;justify-content:center;transition:.15s ease;transition:var(--transition-fast);width:44px;z-index:3}.nav-arrow:hover{background:#818cf8;background:var(--primary-400);color:var(--text-on-primary)}@media(max-width:768px){.nav-arrow{background:#000000b3;color:#fff;height:36px;position:absolute;top:40%;transform:translateY(-50%);width:36px;z-index:2}.nav-arrow.prev{left:.5rem;left:var(--spacing-sm)}.nav-arrow.next{right:.5rem;right:var(--spacing-sm)}}@media(max-width:480px){.nav-arrow{height:32px;width:32px}.nav-arrow.prev{left:8px}.nav-arrow.next{right:8px}}.modal-project-container{align-items:center;display:flex;flex:1 1;min-height:400px;padding:2rem 0;padding:var(--spacing-xl) 0;position:relative}@media(max-width:768px){.modal-project-container{height:100%;min-height:auto;order:-1;overflow:hidden;padding:1.5rem 1rem;padding:var(--spacing-lg) var(--spacing-md);width:100%}}@media(min-width:769px)and (max-width:1024px){.modal-project-container{min-height:350px}}.modal-project{bottom:0;display:flex;flex-direction:column;left:0;opacity:0;pointer-events:none;position:absolute;right:0;top:0;transition:opacity .3s ease;transition:opacity var(--transition-normal)}@media(max-width:768px){.modal-project{display:flex;flex-direction:column;height:100%;position:relative}}.modal-project.active{opacity:1;pointer-events:all}@media(max-width:768px){.modal-project.active{display:flex;flex-direction:column;position:relative}}.modal-project-media{border-radius:.75rem;border-radius:var(--radius-lg);flex-shrink:0;height:400px;overflow:hidden;position:relative;width:100%}@media(max-width:768px){.modal-project-media{border-radius:.5rem;border-radius:var(--radius-md);height:200px;margin-bottom:1rem;margin-bottom:var(--spacing-md)}}@media(min-width:769px)and (max-width:1024px){.modal-project-media{height:300px}}.modal-project-media video{background:var(--bg-primary);height:100%;object-fit:contain;width:100%}.modal-project-media img{height:100%;object-fit:cover;width:100%}.modal-project-info{display:flex;flex:1 1;flex-direction:column;overflow-y:auto;padding:2rem;padding:var(--spacing-xl)}@media(max-width:768px){.modal-project-info{overflow-y:visible;padding:0 1rem 1rem;padding:0 var(--spacing-md) var(--spacing-md)}}.modal-project-header{margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}@media(max-width:768px){.modal-project-header{margin-bottom:1rem;margin-bottom:var(--spacing-md)}}.modal-project-header h4{color:var(--text-primary);font-size:1.25rem;font-size:var(--text-xl);font-weight:600;font-weight:var(--font-semibold);margin-bottom:1rem;margin-bottom:var(--spacing-md)}@media(max-width:768px){.modal-project-header h4{font-size:1.125rem;font-size:var(--text-lg);margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}}.modal-project-tags{display:flex;flex-wrap:wrap;gap:.25rem;gap:var(--spacing-xs);margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}@media(max-width:768px){.modal-project-tags{gap:4px;margin-bottom:1rem;margin-bottom:var(--spacing-md)}}.modal-project-tags span{background:#3a86ff1a;border-radius:9999px;border-radius:var(--radius-full);color:#818cf8;color:var(--primary-400);font-size:.75rem;font-size:var(--text-xs);font-weight:500;font-weight:var(--font-medium);padding:.25rem .5rem;padding:var(--spacing-xs) var(--spacing-sm)}@media(max-width:768px){.modal-project-tags span{font-size:.6rem;padding:4px 8px}}@media(max-width:360px){.modal-project-tags span{font-size:.55rem;padding:3px 6px}}.modal-project-description{color:var(--text-secondary);flex:1 1;line-height:1.7;margin-bottom:2rem;margin-bottom:var(--spacing-xl)}@media(max-width:768px){.modal-project-description{font-size:.875rem;font-size:var(--text-sm);line-height:1.6;margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}}.modal-project-links{display:flex;gap:1rem;gap:var(--spacing-md)}@media(max-width:768px){.modal-project-links{flex-direction:column;gap:.5rem;gap:var(--spacing-sm)}}.modal-project-link{align-items:center;background:linear-gradient(135deg,#6366f1,#4338ca);background:var(--gradient-primary);border:none;border-radius:.5rem;border-radius:var(--radius-md);color:var(--text-on-primary);cursor:pointer;display:inline-flex;display:flex;font-size:1rem;font-size:var(--text-base);font-weight:500;font-weight:var(--font-medium);gap:.5rem;gap:var(--spacing-sm);justify-content:center;line-height:1;min-height:44px;min-width:44px;padding:1rem 1.5rem;padding:var(--spacing-md) var(--spacing-lg);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast);white-space:nowrap}.modal-project-link:disabled{cursor:not-allowed;opacity:.6}@media(max-width:768px){.modal-project-link{min-height:48px;min-width:48px}}.modal-project-link:hover:not(:disabled){box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.modal-project-link:active:not(:disabled){transform:translateY(0)}@media(max-width:768px){.modal-project-link{font-size:.875rem;font-size:var(--text-sm);justify-content:center;padding:.5rem;padding:var(--spacing-sm)}}@media(max-width:360px){.modal-project-link{font-size:.75rem;font-size:var(--text-xs);padding:10px}}.modal-projects-grid{grid-gap:1rem;grid-gap:var(--spacing-md);display:grid;gap:1rem;gap:var(--spacing-md);grid-template-columns:repeat(auto-fill,minmax(100px,1fr));max-height:120px;overflow-y:auto;padding:0 2rem 2rem;padding:0 var(--spacing-xl) var(--spacing-xl)}@media(max-width:768px){.modal-projects-grid{gap:.5rem;gap:var(--spacing-sm);grid-template-columns:repeat(auto-fill,minmax(70px,1fr));margin-top:auto;max-height:100px;order:2;padding:0 1rem 1rem;padding:0 var(--spacing-md) var(--spacing-md)}}@media(max-width:360px){.modal-projects-grid{gap:8px;grid-template-columns:repeat(auto-fill,minmax(60px,1fr))}}.mobile-nav-dots{display:none}@media(max-width:768px){.mobile-nav-dots{display:flex;gap:.5rem;gap:var(--spacing-sm);justify-content:center;order:3;padding:1rem;padding:var(--spacing-md)}}.nav-dot{background:var(--text-muted);border:none;border-radius:50%;cursor:pointer;height:8px;padding:0;transition:all .15s ease;transition:all var(--transition-fast);width:8px}.nav-dot.active{background:#818cf8;background:var(--primary-400);transform:scale(1.2)}.nav-dot:hover{background:#a5b4fc;background:var(--primary-300)}.modal-thumbnail{aspect-ratio:16/9;border:2px solid #0000;border-radius:.5rem;border-radius:var(--radius-md);cursor:pointer;overflow:hidden;position:relative;transition:.15s ease;transition:var(--transition-fast)}.modal-thumbnail.active{border-color:#818cf8;border-color:var(--primary-400)}.modal-thumbnail img{height:100%;object-fit:cover;transition:transform .3s ease;transition:transform var(--transition-normal);width:100%}.modal-thumbnail:hover img{transform:scale(1.05)}.thumbnail-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:.15s ease;transition:var(--transition-fast)}.modal-thumbnail:hover .thumbnail-overlay{opacity:1}.thumbnail-overlay span{color:var(--text-primary);font-size:.75rem;font-size:var(--text-xs);padding:.5rem;padding:var(--spacing-sm);text-align:center}@media(max-width:768px){.thumbnail-overlay span{font-size:.6rem;padding:.25rem;padding:var(--spacing-xs)}}@media(max-width:360px){.modal-project-media{height:180px}.modal-project-info{padding:0 12px 12px}.modal-project-description{font-size:.75rem;font-size:var(--text-xs)}.modal-project-link{font-size:.7rem;padding:8px}}@media(max-height:500px)and (orientation:landscape){.modal-content{max-height:100vh}.modal-project-view{flex-direction:row;height:auto}.modal-project-container{padding:1rem 0;padding:var(--spacing-md) 0}.modal-project-media{flex-shrink:0;height:150px;margin-right:1rem;margin-right:var(--spacing-md);width:250px}.modal-project-info{max-height:150px;overflow-y:auto;padding:0}.modal-projects-grid{max-height:80px}}@media(prefers-reduced-motion:reduce){.modal-thumbnail,.project-card,.view-more-btn{transition:none}.modal-thumbnail:hover,.project-card:hover,.view-more-btn:hover{transform:none}.modal-project,.modal-project-link,.nav-arrow,.project-overlay-content{transition:none}}@media(prefers-contrast:high){.project-card{border:2px solid var(--border-primary)}.tab-button{border:2px solid}}@media print{.section.projects{background:#fff!important;color:#000!important}.project-card{box-shadow:none!important}.project-card,.tab-button{border:1px solid #ccc}}.contact-section{align-items:center;background-color:var(--bg-secondary);display:flex;min-height:100vh;overflow:hidden;padding:6rem 0;padding:var(--spacing-4xl) 0;position:relative}@media(max-width:768px){.contact-section{-webkit-tap-highlight-color:rgba(0,0,0,0);-webkit-overflow-scrolling:touch;min-height:100dvh;padding:3rem 0;padding:var(--spacing-2xl) 0}}.contact-grid-overlay{background-image:linear-gradient(#ffffff08 1px,#0000 0),linear-gradient(90deg,#ffffff08 1px,#0000 0);background-size:40px 40px;height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%;z-index:0}.contact-container{margin:0 auto;max-width:1200px;max-width:var(--container-max-width);padding:0 1.5rem;padding:0 var(--container-padding);position:relative;width:100%;z-index:1}.contact-grid{grid-gap:4rem;grid-gap:var(--spacing-3xl);display:grid;gap:4rem;gap:var(--spacing-3xl);grid-template-columns:1fr 1.25fr;margin-top:4rem;margin-top:var(--spacing-3xl)}@media(min-width:769px)and (max-width:1024px){.contact-grid{gap:3rem;gap:var(--spacing-2xl);grid-template-columns:1fr}}@media(max-width:768px){.contact-grid{display:flex;flex-direction:column;gap:2rem;gap:var(--spacing-xl);margin-top:3rem;margin-top:var(--spacing-2xl)}}.contact-info{padding-right:2rem;padding-right:var(--spacing-xl)}@media(min-width:769px)and (max-width:1024px){.contact-info{padding-right:0}}@media(max-width:768px){.contact-info{order:2;padding:0}}.contact-subtitle{color:var(--text-primary);font-size:1.875rem;font-size:var(--text-3xl);font-weight:700;font-weight:var(--font-bold);line-height:1.3;margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}@media(max-width:768px){.contact-subtitle{font-size:1.5rem;font-size:var(--text-2xl);margin-bottom:1rem;margin-bottom:var(--spacing-md);text-align:center}}.text-gradient{text-fill-color:#0000;background:linear-gradient(135deg,#6366f1,#4338ca);background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;color:#0000}.contact-text{color:var(--text-secondary);font-size:1.125rem;font-size:var(--text-lg);line-height:1.7;margin-bottom:3rem;margin-bottom:var(--spacing-2xl)}@media(max-width:768px){.contact-text{font-size:1rem;font-size:var(--text-base);line-height:1.6;margin-bottom:2rem;margin-bottom:var(--spacing-xl);text-align:center}}.text-highlight{color:var(--text-primary);font-weight:600;font-weight:var(--font-semibold);position:relative}.text-highlight:after{background:linear-gradient(135deg,#6366f1,#4338ca);background:var(--gradient-primary);border-radius:9999px;border-radius:var(--radius-full);bottom:2px;content:"";height:4px;left:0;opacity:.3;position:absolute;width:100%;z-index:-1}.contact-details{display:flex;flex-direction:column;gap:1.5rem;gap:var(--spacing-lg)}@media(max-width:768px){.contact-details{gap:1rem;gap:var(--spacing-md)}}.contact-item{align-items:flex-start;display:flex;gap:1.5rem;gap:var(--spacing-lg);transition:.15s ease;transition:var(--transition-fast)}@media(max-width:768px){.contact-item{align-items:center;background:var(--bg-surface);border-radius:.75rem;border-radius:var(--radius-lg);flex-direction:column;gap:1rem;gap:var(--spacing-md);margin:0;padding:1rem;padding:var(--spacing-md);text-align:center}.contact-item:active{background:var(--bg-tertiary);transform:scale(.98)}}.contact-icon-container{align-items:center;background:#3a86ff1a;border-radius:50%;color:#818cf8;color:var(--primary-400);display:flex;flex-shrink:0;font-size:1.25rem;height:50px;justify-content:center;width:50px}@media(max-width:768px){.contact-icon-container{font-size:1.1rem;height:44px;margin-bottom:.5rem;margin-bottom:var(--spacing-sm);width:44px}}.contact-item-content{flex:1 1}@media(max-width:768px){.contact-item-content{text-align:center}}.contact-item h4{color:var(--text-muted);font-size:.875rem;font-size:var(--text-sm);font-weight:500;font-weight:var(--font-medium);letter-spacing:1px;margin-bottom:.25rem;margin-bottom:var(--spacing-xs);text-transform:uppercase}@media(max-width:768px){.contact-item h4{font-size:.75rem;font-size:var(--text-xs)}}.contact-link,.contact-value{color:var(--text-primary);font-size:1rem;font-size:var(--text-base);font-weight:500;font-weight:var(--font-medium);transition:color .15s ease;transition:color var(--transition-fast)}@media(max-width:768px){.contact-link,.contact-value{font-size:.875rem;font-size:var(--text-sm)}}.contact-link:hover{color:#818cf8;color:var(--primary-400)}.contact-form-container{position:relative}@media(max-width:768px){.contact-form-container{order:1}}.form-grid-overlay{background-image:linear-gradient(#ffffff08 1px,#0000 0),linear-gradient(90deg,#ffffff08 1px,#0000 0);background-size:30px 30px;border-radius:.75rem;border-radius:var(--radius-lg);bottom:-20px;left:-20px;pointer-events:none;position:absolute;right:-20px;top:-20px;z-index:-1}.contact-form{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-card);border:1px solid var(--border-primary);border-radius:.75rem;border-radius:var(--radius-lg);padding:3rem;padding:var(--spacing-2xl);position:relative;transition:all .3s ease;transition:all var(--transition-normal)}.contact-form:hover{border-color:var(--border-accent);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);transform:translateY(-4px)}@media(max-width:768px){.contact-form{border:1px solid var(--border-primary);border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);margin:0;padding:2rem;padding:var(--spacing-xl)}}.form-group{margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);position:relative}@media(max-width:768px){.form-group{margin-bottom:1rem;margin-bottom:var(--spacing-md)}}.input-container{align-items:center;display:flex;position:relative}.input-icon{color:var(--text-muted);font-size:1.1rem;left:1rem;left:var(--spacing-md);position:absolute;z-index:2}@media(max-width:768px){.input-icon{font-size:1rem;left:.5rem;left:var(--spacing-sm)}}.form-input,.form-textarea{background:var(--bg-surface);border:1px solid var(--border-primary);border-radius:.5rem;border-radius:var(--radius-md);color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-sans);font-size:1rem;font-size:var(--text-base);padding:1rem 1.5rem;padding:var(--spacing-md) var(--spacing-lg);padding-left:3rem;padding-left:calc(var(--spacing-md)*2 + 1rem);transition:all .15s ease;transition:all var(--transition-fast);width:100%}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-input:focus,.form-textarea:focus{border-color:#818cf8;border-color:var(--primary-400);box-shadow:0 0 0 3px #3a86ff33;outline:none}.form-input:disabled,.form-textarea:disabled{cursor:not-allowed;opacity:.6}@media(max-width:768px){.form-input,.form-textarea{border-radius:.5rem;border-radius:var(--radius-md);font-size:1rem;font-size:var(--text-base);min-height:48px;padding:1rem 1rem 1rem 2.8rem;padding:var(--spacing-md) var(--spacing-md) var(--spacing-md) calc(var(--spacing-md)*2 + .8rem)}}.form-textarea{line-height:1.6;min-height:150px;padding-top:1rem;padding-top:var(--spacing-md);resize:vertical}@media(max-width:768px){.form-textarea{min-height:120px;padding-top:.5rem;padding-top:var(--spacing-sm)}}.success-message{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#10b9811a;border-left:3px solid #10b981;border-left:3px solid var(--success);border-radius:.5rem;border-radius:var(--radius-md);margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);padding:1.5rem;padding:var(--spacing-lg)}@media(max-width:768px){.success-message{border-left:3px solid #10b981;border-left:3px solid var(--success);border-radius:.5rem;border-radius:var(--radius-md);border-right:none;margin:0 0 1.5rem;margin:0 0 var(--spacing-lg) 0;padding:1rem;padding:var(--spacing-md)}}.success-message-content{align-items:center;display:flex;gap:1rem;gap:var(--spacing-md);position:relative}.success-icon-container{align-items:center;background:#10b98133;border-radius:50%;color:#10b981;color:var(--success);display:flex;flex-shrink:0;height:36px;justify-content:center;width:36px}.success-message h4{color:var(--text-primary);font-size:1rem;font-size:var(--text-base);font-weight:600;font-weight:var(--font-semibold);margin-bottom:.25rem;margin-bottom:var(--spacing-xs)}.success-message p{color:var(--text-muted);font-size:.875rem;font-size:var(--text-sm)}.success-close{background:none;border:none;border-radius:.25rem;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;margin-left:auto;padding:.25rem;padding:var(--spacing-xs);transition:.15s ease;transition:var(--transition-fast)}.success-close:hover{background:var(--bg-surface);color:var(--text-primary)}@media(max-width:768px){.success-close{position:absolute;right:.25rem;right:var(--spacing-xs);top:.25rem;top:var(--spacing-xs)}}.form-submit{font-size:1rem;font-size:var(--text-base);font-weight:600;font-weight:var(--font-semibold);margin-top:1.5rem;margin-top:var(--spacing-lg);min-height:52px;width:100%}.form-submit .button-icon{margin-right:.5rem;margin-right:var(--spacing-sm)}@media(max-width:768px){.form-submit{border-radius:.5rem;border-radius:var(--radius-md);font-size:1rem;font-size:var(--text-base);min-height:56px}}.loading-spinner{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:currentcolor;height:20px;width:20px}@media(max-width:768px){.contact-container{padding:0 1rem;padding:0 var(--spacing-md)}.contact-form{-webkit-tap-highlight-color:rgba(0,0,0,0);-webkit-overflow-scrolling:touch;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;border-radius:1rem;border-radius:var(--radius-xl);margin-bottom:2rem;margin-bottom:var(--spacing-xl)}.form-input:focus,.form-textarea:focus{border-color:#818cf8;border-color:var(--primary-400);box-shadow:0 0 0 2px #818cf8;box-shadow:0 0 0 2px var(--primary-400)}.contact-item{border-radius:.75rem;border-radius:var(--radius-lg);margin-bottom:.25rem;margin-bottom:var(--spacing-xs);padding:1.5rem;padding:var(--spacing-lg)}.contact-item:active{transform:scale(.98);transition:transform .15s ease;transition:transform var(--transition-fast)}.contact-details{gap:.5rem;gap:var(--spacing-sm)}}@media(hover:none){.contact-link:hover{color:var(--text-primary)}.contact-item:active{background:var(--bg-tertiary);transform:scale(.98)}.success-close:hover{background:#0000;color:var(--text-muted)}}@media(prefers-reduced-motion:reduce){.contact-form,.contact-item,.form-input,.form-textarea,.success-close{transition:none}.contact-form:active,.contact-item:active,.form-input:active,.form-textarea:active,.success-close:active{transform:none}.loading-spinner{animation:none;border-top-color:var(--text-muted)}}@media(prefers-contrast:high){.contact-form{border:2px solid var(--border-primary)}.contact-icon-container{border:1px solid}.form-input,.form-textarea{border:2px solid var(--border-primary)}.success-message{border:2px solid #10b981;border:2px solid var(--success)}}@media(max-width:360px){.contact-form{padding:1.5rem;padding:var(--spacing-lg)}.contact-item{padding:1rem;padding:var(--spacing-md)}.form-input,.form-textarea{font-size:.875rem;font-size:var(--text-sm);padding:.5rem .5rem .5rem 1.8rem;padding:var(--spacing-sm) var(--spacing-sm) var(--spacing-sm) calc(var(--spacing-md) + .8rem)}.input-icon{font-size:.9rem;left:.5rem;left:var(--spacing-sm)}}@media(max-width:768px)and (orientation:landscape){.contact-section{min-height:auto;padding:2rem 0;padding:var(--spacing-xl) 0}.contact-grid{gap:1.5rem;gap:var(--spacing-lg)}.contact-form{padding:1rem;padding:var(--spacing-md)}.form-textarea{min-height:100px}}@media(min-width:1600px){.contact-container{max-width:1400px}.contact-grid{gap:6rem;gap:var(--spacing-4xl)}}@media print{.contact-section{background:#fff!important;min-height:auto}.contact-grid-overlay,.form-grid-overlay{display:none}.contact-form{border:1px solid #ccc;box-shadow:none}.success-message{display:none}}.experience-section{background-color:var(--bg-secondary);overflow:hidden;padding:4rem 0;padding:var(--spacing-3xl) 0;position:relative}@media(max-width:768px){.experience-section{padding:3rem 0;padding:var(--spacing-2xl) 0}}.experience-container{margin:0 auto;max-width:1200px;max-width:var(--container-max-width);padding:0 1.5rem;padding:0 var(--container-padding);position:relative;z-index:1}.section-title{color:var(--text-primary);font-size:1.875rem;font-size:var(--text-3xl);font-weight:700;font-weight:var(--font-bold);margin-bottom:4rem;margin-bottom:var(--spacing-3xl);text-align:center}@media(max-width:768px){.section-title{font-size:1.5rem;font-size:var(--text-2xl);margin-bottom:3rem;margin-bottom:var(--spacing-2xl)}}.section-title .highlight{color:#818cf8;color:var(--primary-400)}.timeline{padding-left:2rem;padding-left:var(--spacing-xl);position:relative}@media(max-width:768px){.timeline{padding-left:1.5rem;padding-left:var(--spacing-lg)}}.timeline-item{margin-bottom:4rem;margin-bottom:var(--spacing-3xl);position:relative}.timeline-item:last-child{margin-bottom:0}.timeline-marker{left:-var(--spacing-xl);position:absolute;top:0}@media(max-width:768px){.timeline-marker{left:-var(--spacing-lg)}}.timeline-dot{background:linear-gradient(135deg,#6366f1,#4338ca);background:var(--gradient-primary);border:3px solid var(--bg-secondary);border-radius:50%;box-shadow:0 0 0 2px #818cf8;box-shadow:0 0 0 2px var(--primary-400);height:20px;position:relative;width:20px;z-index:2}@media(max-width:768px){.timeline-dot{border-width:2px;height:16px;width:16px}}.timeline-line{background:linear-gradient(180deg,#818cf8,#3a86ff33);background:linear-gradient(to bottom,var(--primary-400),#3a86ff33);height:calc(100% + 4rem);height:calc(100% + var(--spacing-3xl));left:7px;position:absolute;top:25px;width:2px}@media(max-width:768px){.timeline-line{height:calc(100% + 3rem);height:calc(100% + var(--spacing-2xl));left:5px;top:20px}}.experience-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-card);border:1px solid var(--border-primary);border-radius:.75rem;border-radius:var(--radius-lg);padding:2rem;padding:var(--spacing-xl);transition:all .3s ease;transition:all var(--transition-normal)}.experience-card:hover{border-color:var(--border-accent);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);transform:translateY(-4px);transform:translateY(-3px)}@media(max-width:768px){.experience-card{border-radius:.75rem;border-radius:var(--radius-lg);margin:0 .25rem;margin:0 var(--spacing-xs);padding:1.5rem;padding:var(--spacing-lg)}}.experience-header{align-items:flex-start;display:flex;gap:1.5rem;gap:var(--spacing-lg);margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}@media(max-width:768px){.experience-header{border-radius:.5rem;border-radius:var(--radius-md);gap:1rem;gap:var(--spacing-md);margin:-1rem;margin:calc(var(--spacing-md)*-1);padding:1rem;padding:var(--spacing-md);transition:background-color .15s ease;transition:background-color var(--transition-fast)}.experience-header:active{background-color:var(--bg-surface)}}.experience-icon{align-items:center;background:#3a86ff1a;border-radius:50%;color:#818cf8;color:var(--primary-400);display:flex;flex-shrink:0;font-size:1.2rem;height:50px;justify-content:center;width:50px}@media(max-width:768px){.experience-icon{font-size:1rem;height:40px;width:40px}}.experience-title{flex:1 1;min-width:0}.role{color:var(--text-primary);font-size:1.25rem;font-size:var(--text-xl);font-weight:600;font-weight:var(--font-semibold);line-height:1.3;margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}@media(max-width:768px){.role{font-size:1.125rem;font-size:var(--text-lg);margin-bottom:.25rem;margin-bottom:var(--spacing-xs)}}.company-period{color:var(--text-muted);display:flex;flex-wrap:wrap;font-size:.875rem;font-size:var(--text-sm);gap:1rem;gap:var(--spacing-md);margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}@media(max-width:768px){.company-period{flex-direction:column;gap:.25rem;gap:var(--spacing-xs);margin-bottom:.25rem;margin-bottom:var(--spacing-xs)}}.company{color:var(--text-primary);font-weight:500;font-weight:var(--font-medium)}@media(max-width:768px){.period{font-size:.75rem;font-size:var(--text-xs)}}.location{align-items:center;color:var(--text-muted);display:flex;font-size:.875rem;font-size:var(--text-sm);gap:.5rem;gap:var(--spacing-sm)}@media(max-width:768px){.location{font-size:.75rem;font-size:var(--text-xs)}}.expand-toggle{color:var(--text-muted);display:none;font-size:1.2rem}@media(max-width:768px){.expand-toggle{align-items:center;display:flex}}.experience-content{overflow:hidden}.experience-description{color:var(--text-secondary);font-size:1rem;font-size:var(--text-base);line-height:1.7;margin-bottom:2rem;margin-bottom:var(--spacing-xl)}@media(max-width:768px){.experience-description{font-size:.875rem;font-size:var(--text-sm);line-height:1.6;margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);padding:0 1rem;padding:0 var(--spacing-md)}}.projects-section{margin-top:2rem;margin-top:var(--spacing-xl)}@media(max-width:768px){.projects-section{margin-top:1.5rem;margin-top:var(--spacing-lg);padding:0 1rem;padding:0 var(--spacing-md)}}.projects-heading{align-items:center;color:var(--text-primary);display:flex;font-size:1.125rem;font-size:var(--text-lg);font-weight:600;font-weight:var(--font-semibold);gap:.5rem;gap:var(--spacing-sm);margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}@media(max-width:768px){.projects-heading{font-size:1rem;font-size:var(--text-base);margin-bottom:1rem;margin-bottom:var(--spacing-md)}}.projects-grid{grid-gap:1.5rem;grid-gap:var(--spacing-lg);display:grid;gap:1.5rem;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}@media(max-width:768px){.projects-grid{gap:1rem;gap:var(--spacing-md);grid-template-columns:1fr}}@media(min-width:769px)and (max-width:1024px){.projects-grid{grid-template-columns:repeat(2,1fr)}}.project-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-card);border:1px solid var(--border-primary);border-radius:.75rem;border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:.5rem;gap:var(--spacing-sm);padding:1.5rem;padding:var(--spacing-lg);transition:all .3s ease;transition:all var(--transition-normal)}.project-card:hover{border-color:var(--border-accent);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-4px);transform:translateY(-2px)}@media(max-width:768px){.project-card{border-radius:.5rem;border-radius:var(--radius-md);padding:1rem;padding:var(--spacing-md)}}.project-header{align-items:flex-start;display:flex;gap:.5rem;gap:var(--spacing-sm);justify-content:space-between;margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}@media(max-width:768px){.project-header{flex-direction:column;gap:.25rem;gap:var(--spacing-xs);margin-bottom:.25rem;margin-bottom:var(--spacing-xs)}}.project-title-wrapper{align-items:center;display:flex;flex:1 1;gap:.5rem;gap:var(--spacing-sm);min-width:0}.project-title{color:var(--text-primary);font-size:1rem;font-size:var(--text-base);font-weight:600;font-weight:var(--font-semibold);line-height:1.3;margin-bottom:0}@media(max-width:768px){.project-title{font-size:.875rem;font-size:var(--text-sm);font-weight:700;font-weight:var(--font-bold)}}.project-link{border-radius:.25rem;border-radius:var(--radius-sm);color:var(--text-muted);flex-shrink:0;padding:.25rem;padding:var(--spacing-xs);transition:color .15s ease;transition:color var(--transition-fast)}.project-link:hover{background:#3a86ff1a;color:#818cf8;color:var(--primary-400)}@media(max-width:768px){.project-link{display:none}.project-mobile-stats .stat-badge{background:linear-gradient(135deg,#6366f1,#4338ca);background:var(--gradient-primary);border-radius:9999px;border-radius:var(--radius-full);color:#fff;font-size:.7rem;font-weight:600;font-weight:var(--font-semibold);padding:.2rem .6rem;white-space:nowrap}}@media(min-width:769px)and (max-width:1024px){.project-mobile-stats{display:none}}.project-description{color:var(--text-secondary);font-size:.875rem;font-size:var(--text-sm);line-height:1.6;margin-bottom:1rem;margin-bottom:var(--spacing-md)}@media(max-width:768px){.project-description{-webkit-line-clamp:3;-webkit-box-orient:vertical;display:-webkit-box;font-size:.75rem;font-size:var(--text-xs);line-height:1.5;margin-bottom:.5rem;margin-bottom:var(--spacing-sm);overflow:hidden}}.project-impact{background:#3a86ff1a;border-radius:.5rem;border-radius:var(--radius-md);color:#818cf8;color:var(--primary-400);font-size:.75rem;font-size:var(--text-xs);font-weight:500;font-weight:var(--font-medium);margin-bottom:1rem;margin-bottom:var(--spacing-md);padding:.5rem;padding:var(--spacing-sm)}@media(max-width:768px){.project-impact{display:none}}.impact-label{font-weight:600;font-weight:var(--font-semibold);margin-right:.25rem;margin-right:var(--spacing-xs)}.technologies{display:flex;flex-wrap:wrap;gap:.25rem;gap:var(--spacing-xs);margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}@media(max-width:768px){.technologies{gap:.3rem;margin-bottom:.25rem;margin-bottom:var(--spacing-xs);max-height:3.5rem;overflow:hidden;position:relative}.technologies:after{background:linear-gradient(#0000,var(--bg-card));bottom:0;content:"";height:1.5rem;left:0;pointer-events:none;position:absolute;right:0}}.tech-tag{background:#3a86ff1a;border-radius:9999px;border-radius:var(--radius-full);color:#818cf8;color:var(--primary-400);font-size:.75rem;font-size:var(--text-xs);font-weight:500;font-weight:var(--font-medium);padding:.25rem .5rem;padding:var(--spacing-xs) var(--spacing-sm);transition:all .15s ease;transition:all var(--transition-fast);white-space:nowrap}.tech-tag:hover{background:#3a86ff33;transform:translateY(-1px)}@media(max-width:768px){.tech-tag{border:1px solid #3a86ff33;font-size:.65rem;padding:.25rem .6rem}.tech-tag[data-tech="React Native"]{background:#61dafb1a;border-color:#61dafb33;color:#61dafb}.tech-tag[data-tech=Firebase]{background:#ffa7241a;border-color:#ffa72433;color:#ffa724}.tech-tag[data-tech="Chart.js"]{background:#ff63841a;border-color:#ff638433;color:#ff6384}}.mobile-project-button{display:none}@media(max-width:768px){.mobile-project-button{align-items:center;background:linear-gradient(135deg,#6366f1,#4338ca);background:var(--gradient-primary);border-radius:.5rem;border-radius:var(--radius-md);color:#fff;display:flex;font-size:.75rem;font-size:var(--text-xs);font-weight:600;font-weight:var(--font-semibold);gap:.25rem;gap:var(--spacing-xs);justify-content:center;margin-top:auto;padding:.5rem 1rem;padding:var(--spacing-sm) var(--spacing-md);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast)}.mobile-project-button:active{opacity:.9;transform:scale(.98)}}.mobile-instructions{color:var(--text-muted);font-size:.875rem;font-size:var(--text-sm);margin-top:2rem;margin-top:var(--spacing-xl);text-align:center}@media(max-width:768px){.mobile-instructions{margin-top:1.5rem;margin-top:var(--spacing-lg)}.project-card[data-project-type=fitness]{border-left:3px solid #10b981;border-left:3px solid var(--success)}.project-card[data-project-type=fitness] .project-title:before{content:"🏋️ ";margin-right:.3rem}.experience-container{padding:0 1rem;padding:0 var(--spacing-md)}.timeline{padding-left:1rem;padding-left:var(--spacing-md)}.timeline-marker{left:-var(--spacing-md)}}@media(hover:none){.experience-card:hover,.project-card:hover,.tech-tag:hover{transform:none!important}.experience-card:active,.project-card:active{transform:scale(.98)!important}}@media(prefers-reduced-motion:reduce){.experience-card,.project-card,.tech-tag{transition:none}.experience-card:hover,.project-card:hover,.tech-tag:hover{transform:none}}@media(prefers-contrast:high){.experience-card,.project-card{border:2px solid var(--border-primary)}.tech-tag{border:1px solid #818cf8;border:1px solid var(--primary-400)}}@media(max-width:480px){.experience-card{border-radius:.5rem;border-radius:var(--radius-md);margin:0}.projects-grid{gap:.5rem;gap:var(--spacing-sm)}.project-card{padding:.5rem;padding:var(--spacing-sm)}}@media(max-width:768px)and (orientation:landscape){.experience-section{padding:2rem 0;padding:var(--spacing-xl) 0}.timeline-item{margin-bottom:2rem;margin-bottom:var(--spacing-xl)}}@media(max-width:360px){.project-card{padding:.5rem;padding:var(--spacing-sm)}.technologies{gap:.2rem}.tech-tag{font-size:.6rem;padding:.2rem .5rem}.mobile-project-button{font-size:.7rem;padding:.5rem;padding:.5rem var(--spacing-sm)}}@media print{.experience-section{background:#fff!important;color:#000!important}.experience-card,.project-card{border:1px solid #ccc;box-shadow:none!important}.timeline-dot{box-shadow:none}.timeline-dot,.timeline-line{background:#ccc}.mobile-project-button,.project-mobile-stats{display:none}}.home{background:var(--bg-primary);color:var(--text-primary);display:flex;flex-direction:column;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-sans);min-height:100vh;overflow-x:hidden}.home>section{padding:3rem 0;padding:var(--spacing-2xl) 0;scroll-margin-top:calc(80px + 1.5rem);scroll-margin-top:calc(var(--nav-height) + var(--spacing-lg))}@media(max-width:768px){.home>section{padding:2rem 0;padding:var(--spacing-xl) 0;scroll-margin-top:calc(70px + 1rem);scroll-margin-top:calc(var(--nav-height-mobile) + var(--spacing-md))}}.home-content{margin:0 auto;max-width:1200px;max-width:var(--container-max-width);padding:0 1.5rem;padding:0 var(--container-padding);width:100%}@media(max-width:768px){.home-content{padding:0 1rem;padding:0 var(--spacing-md)}}.home-section-hero{align-items:center;display:flex;min-height:100vh;padding:calc(80px + 3rem) 0 3rem!important;padding:calc(var(--nav-height) + var(--spacing-2xl)) 0 var(--spacing-2xl)!important}@media(max-width:768px){.home-section-hero{min-height:100dvh;padding:calc(70px + 2rem) 0 2rem!important;padding:calc(var(--nav-height-mobile) + var(--spacing-xl)) 0 var(--spacing-xl)!important}}.home-section-regular{padding:4rem 0;padding:var(--spacing-3xl) 0}@media(max-width:768px){.home-section-regular{padding:3rem 0;padding:var(--spacing-2xl) 0}}.home-section-alt{background:var(--bg-secondary);padding:4rem 0;padding:var(--spacing-3xl) 0}@media(max-width:768px){.home-section-alt{padding:3rem 0;padding:var(--spacing-2xl) 0}.home{-webkit-overflow-scrolling:touch}}@media(prefers-reduced-motion:reduce){.home>section{scroll-margin-top:80px;scroll-margin-top:var(--nav-height)}}@media print{.home-section-hero{min-height:auto;padding:2rem 0!important;padding:var(--spacing-xl) 0!important}.home-section-alt,.home-section-regular{break-inside:avoid;padding:2rem 0;padding:var(--spacing-xl) 0;page-break-inside:avoid}}.resume-section{align-items:center;background-color:var(--bg-secondary);display:flex;min-height:100vh;padding:4rem 0;padding:var(--spacing-3xl) 0;position:relative}@media(max-width:768px){.resume-section{min-height:100dvh;padding:3rem 0;padding:var(--spacing-2xl) 0}}.resume-content{margin-top:3rem;margin-top:var(--spacing-2xl);width:100%}.resume-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;gap:var(--spacing-md);justify-content:space-between;margin-bottom:2rem;margin-bottom:var(--spacing-xl)}@media(max-width:768px){.resume-header{align-items:stretch;flex-direction:column;gap:1.5rem;gap:var(--spacing-lg)}}.download-btn{align-items:center;background:linear-gradient(135deg,#6366f1,#4338ca);background:var(--gradient-primary);border:none;border-radius:.5rem;border-radius:var(--radius-md);color:var(--text-on-primary);cursor:pointer;display:inline-flex;flex-shrink:0;font-size:1rem;font-size:var(--text-base);font-weight:500;font-weight:var(--font-medium);gap:.5rem;gap:var(--spacing-sm);justify-content:center;line-height:1;min-height:44px;min-width:44px;padding:1rem 1.5rem;padding:var(--spacing-md) var(--spacing-lg);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast);white-space:nowrap}.download-btn:disabled{cursor:not-allowed;opacity:.6}@media(max-width:768px){.download-btn{min-height:48px;min-width:48px}}.download-btn:hover:not(:disabled){box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.download-btn:active:not(:disabled){transform:translateY(0)}.download-btn .download-icon{font-size:1.1rem}@media(max-width:768px){.download-btn{justify-content:center;order:2;width:100%}}.view-controls{align-items:center;display:flex;flex-wrap:wrap;gap:2rem;gap:var(--spacing-xl)}@media(max-width:768px){.view-controls{flex-direction:column;gap:1rem;gap:var(--spacing-md);order:1;width:100%}}@media(min-width:769px)and (max-width:1024px){.view-controls{gap:1.5rem;gap:var(--spacing-lg)}}.device-presets{background:var(--bg-surface);border-radius:.75rem;border-radius:var(--radius-lg);display:flex;gap:.25rem;gap:var(--spacing-xs);padding:.25rem;padding:var(--spacing-xs)}@media(max-width:768px){.device-presets{justify-content:center;width:100%}}.device-btn{align-items:center;background:var(--bg-surface);border:none;border:1px solid var(--border-primary);border-radius:.5rem;border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;display:inline-flex;font-size:1rem;font-size:var(--text-base);font-weight:500;font-weight:var(--font-medium);gap:.5rem;gap:var(--spacing-sm);justify-content:center;line-height:1;min-height:44px;min-width:44px;min-width:auto;padding:.5rem;padding:var(--spacing-sm);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast)}.device-btn:disabled{cursor:not-allowed;opacity:.6}@media(max-width:768px){.device-btn{min-height:48px;min-width:48px}}.device-btn:hover:not(:disabled){background:var(--bg-secondary);transform:translateY(-1px)}.device-btn:hover{background:var(--bg-tertiary)}.device-btn.active{background:#818cf8;background:var(--primary-400);color:var(--text-on-primary)}.zoom-controls{align-items:center;background:var(--bg-surface);border-radius:.75rem;border-radius:var(--radius-lg);display:flex;gap:.5rem;gap:var(--spacing-sm);padding:.5rem;padding:var(--spacing-sm)}@media(max-width:768px){.zoom-controls{justify-content:center;width:100%}}.control-btn{align-items:center;background:var(--bg-surface);border:none;border:1px solid var(--border-primary);border-radius:.5rem;border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;display:inline-flex;font-size:1rem;font-size:var(--text-base);font-size:.875rem;font-size:var(--text-sm);font-weight:500;font-weight:var(--font-medium);gap:.5rem;gap:var(--spacing-sm);justify-content:center;line-height:1;min-height:44px;min-width:44px;min-width:auto;padding:.5rem;padding:var(--spacing-sm);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast)}.control-btn:disabled{opacity:.6}@media(max-width:768px){.control-btn{min-height:48px;min-width:48px}}.control-btn:hover:not(:disabled){background:var(--bg-secondary);background:var(--bg-tertiary);transform:translateY(-1px)}.control-btn:disabled{cursor:not-allowed;opacity:.5}.zoom-level{color:var(--text-primary);font-size:.875rem;font-size:var(--text-sm);font-weight:500;font-weight:var(--font-medium);min-width:50px;text-align:center}.pdf-container{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:1rem;border-radius:var(--radius-xl);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);min-height:500px;overflow:hidden;position:relative}@media(max-width:768px){.pdf-container{border-radius:.75rem;border-radius:var(--radius-lg);min-height:400px}}.pdf-loading{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;justify-content:center;padding:4rem;padding:var(--spacing-3xl)}.pdf-loading .loading-spinner{animation:spin 1s linear infinite;border-top:3px solid #818cf8;border:3px solid var(--border-primary);border-radius:50%;border-top-color:var(--primary-400);height:40px;margin-bottom:1rem;margin-bottom:var(--spacing-md);width:40px}.pdf-error{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;justify-content:center;padding:4rem;padding:var(--spacing-3xl);text-align:center}.pdf-error p{font-size:1.125rem;font-size:var(--text-lg);margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.error-download-btn{align-items:center;background:linear-gradient(135deg,#6366f1,#4338ca);background:var(--gradient-primary);border:none;border-radius:.5rem;border-radius:var(--radius-md);color:var(--text-on-primary);cursor:pointer;display:inline-flex;font-size:1rem;font-size:var(--text-base);font-weight:500;font-weight:var(--font-medium);gap:.5rem;gap:var(--spacing-sm);justify-content:center;line-height:1;min-height:44px;min-width:44px;padding:1rem 1.5rem;padding:var(--spacing-md) var(--spacing-lg);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast)}.error-download-btn:disabled{cursor:not-allowed;opacity:.6}@media(max-width:768px){.error-download-btn{min-height:48px;min-width:48px}}.error-download-btn:hover:not(:disabled){box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.error-download-btn:active:not(:disabled){transform:translateY(0)}.pdf-viewer{align-items:center;display:flex;flex-direction:column;min-height:500px;padding:2rem;padding:var(--spacing-xl)}@media(max-width:768px){.pdf-viewer{min-height:400px;padding:1rem;padding:var(--spacing-md)}}.pdf-page{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);height:auto;margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);overflow:hidden}.pdf-page,.pdf-page canvas{border-radius:.5rem;border-radius:var(--radius-md);max-width:100%}.pdf-page canvas{height:auto!important}.page-loading{color:var(--text-muted);justify-content:center;min-height:300px}.page-loading,.pdf-controls{align-items:center;display:flex}.pdf-controls{flex-direction:column;gap:1rem;gap:var(--spacing-md);width:100%}.page-navigation{align-items:center;display:flex;gap:1.5rem;gap:var(--spacing-lg)}@media(max-width:768px){.page-navigation{gap:2rem;gap:var(--spacing-xl)}}.nav-button{align-items:center;background:var(--bg-surface);border:none;border:1px solid var(--border-primary);border-radius:.5rem;border-radius:var(--radius-md);border-radius:9999px;border-radius:var(--radius-full);color:var(--text-primary);cursor:pointer;display:inline-flex;font-size:1rem;font-size:var(--text-base);font-weight:500;font-weight:var(--font-medium);gap:.5rem;gap:var(--spacing-sm);justify-content:center;line-height:1;min-height:44px;min-width:44px;min-width:auto;padding:1rem;padding:var(--spacing-md);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast)}.nav-button:disabled{opacity:.6}@media(max-width:768px){.nav-button{min-height:48px;min-width:48px}}.nav-button:hover:not(:disabled){background:var(--bg-secondary);transform:translateY(-1px)}.nav-button:disabled{cursor:not-allowed;opacity:.5}@media(max-width:768px){.nav-button{padding:1.5rem;padding:var(--spacing-lg)}}.page-info{color:var(--text-secondary);font-size:1rem;font-size:var(--text-base);font-weight:500;font-weight:var(--font-medium)}.page-info .current-page{color:var(--text-primary);font-weight:600;font-weight:var(--font-semibold)}.page-info .total-pages{color:var(--text-muted)}.mobile-swipe-hint{display:none}@media(max-width:768px){.mobile-swipe-hint{animation:pulse 2s infinite;background:var(--bg-surface);border-radius:9999px;border-radius:var(--radius-full);color:var(--text-muted);display:block;font-size:.75rem;font-size:var(--text-xs);padding:.5rem;padding:var(--spacing-sm);text-align:center}}.resume-footer{margin-top:2rem;margin-top:var(--spacing-xl);text-align:center}.resume-note{color:var(--text-muted);font-size:.875rem;font-size:var(--text-sm);line-height:1.6;margin:0 auto;max-width:600px}@media(hover:none){.control-btn:hover,.device-btn:hover,.nav-button:hover{background:var(--bg-surface);transform:none}.download-btn:hover{transform:none}}@media(prefers-reduced-motion:reduce){.download-btn,.nav-button{transition:none}.download-btn:hover,.nav-button:hover{transform:none}.loading-spinner{animation:none;border-top-color:var(--text-muted)}.mobile-swipe-hint{animation:none}}@media(prefers-contrast:high){.pdf-container{border:2px solid var(--border-primary)}.device-presets,.zoom-controls{border:1px solid var(--border-primary)}.control-btn,.device-btn,.nav-button{border:1px solid}}@media print{.pdf-controls,.resume-footer,.resume-header{display:none!important}.pdf-container{background:#fff!important;border:none;box-shadow:none}.resume-section{background:#fff!important;min-height:auto!important;padding:0!important}}@media(max-width:360px){.view-controls{gap:.5rem;gap:var(--spacing-sm)}.control-btn,.device-btn,.device-presets,.zoom-controls{padding:.25rem;padding:var(--spacing-xs)}.control-btn,.device-btn,.zoom-level{font-size:.75rem;font-size:var(--text-xs)}.zoom-level{min-width:40px}.pdf-viewer{padding:.5rem;padding:var(--spacing-sm)}}@media(max-width:768px)and (orientation:landscape){.resume-section{padding:2rem 0;padding:var(--spacing-xl) 0}.pdf-container,.pdf-viewer{min-height:300px}.pdf-viewer{padding:1rem;padding:var(--spacing-md)}.pdf-page canvas{max-height:200px}}@media(min-width:1600px){.pdf-container{margin:0 auto;max-width:1200px}}.nav{background:#0000;height:80px;height:var(--nav-height);left:0;padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);position:fixed;top:0;transition:all .3s ease;transition:all var(--transition-normal);width:100%;z-index:1030;z-index:var(--z-fixed)}.nav.scrolled{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0f172afa;border-bottom:1px solid var(--border-primary);height:70px;height:calc(var(--nav-height) - 10px)}@media(max-width:768px){.nav{height:70px;height:var(--nav-height-mobile)}.nav.scrolled{height:65px;height:calc(var(--nav-height-mobile) - 5px)}}.nav-container{align-items:center;display:flex;gap:1.5rem;gap:var(--spacing-lg);height:100%;justify-content:space-between;margin:0 auto;max-width:1200px;max-width:var(--container-max-width);padding:0 1.5rem;padding:0 var(--container-padding);position:relative}.logo{flex-shrink:0;z-index:1030;z-index:var(--z-fixed)}.logo .logo-link{color:inherit;display:block;text-decoration:none}.logo .logo-text{color:var(--text-primary);font-size:1.5rem;font-size:var(--text-2xl);font-weight:700;font-weight:var(--font-bold);letter-spacing:-.5px}.logo .logo-gradient{text-fill-color:#0000;background:linear-gradient(135deg,#6366f1,#4338ca);background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;color:#0000}@media(max-width:768px){.logo .logo-text{font-size:1.25rem;font-size:var(--text-xl)}}.nav-menu{display:flex;gap:.5rem;gap:var(--spacing-sm);list-style:none;margin:0;padding:0}@media(max-width:768px){.nav-menu{display:none}}.auth-actions{align-items:center;display:flex;gap:.5rem;gap:var(--spacing-sm)}.auth-actions .auth-btn{gap:.5rem;line-height:1}.auth-actions .auth-btn,.avatar{align-items:center;display:inline-flex}.avatar{background:var(--bg-surface);border-radius:9999px;border-radius:var(--radius-full);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:var(--text-primary);font-weight:600;font-weight:var(--font-semibold);height:34px;justify-content:center;overflow:hidden;-webkit-user-select:none;user-select:none;width:34px}.avatar img{height:100%;object-fit:cover;width:100%}.avatar--mobile{height:40px;margin-bottom:.5rem;margin-bottom:var(--spacing-sm);width:40px}@media(max-width:1024px){.hide-sm{display:none}}.nav-mobile-auth{align-items:center;display:flex;flex-direction:column;gap:.5rem;gap:var(--spacing-sm);margin-top:1.5rem;margin-top:var(--spacing-lg)}.nav-mobile-auth .auth-buttons{grid-gap:.5rem;grid-gap:var(--spacing-sm);display:grid;gap:.5rem;gap:var(--spacing-sm);grid-template-columns:1fr 1fr;width:100%}.nav-mobile-auth .btn--full{justify-content:center;width:100%}.nav-item,.nav-link{position:relative}.nav-link{align-items:center;border-radius:.5rem;border-radius:var(--radius-md);color:var(--text-secondary);display:flex;font-size:.875rem;font-size:var(--text-sm);font-weight:500;font-weight:var(--font-medium);gap:.5rem;gap:var(--spacing-sm);min-height:44px;padding:.5rem 1rem;padding:var(--spacing-sm) var(--spacing-md);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast)}.nav-link:hover{background:var(--bg-surface)}.nav-link.active,.nav-link:hover{color:var(--text-primary)}.nav-link.active .nav-indicator{opacity:1;width:100%}.nav-indicator{background:linear-gradient(135deg,#6366f1,#4338ca);background:var(--gradient-primary);border-radius:9999px;border-radius:var(--radius-full);bottom:-2px;height:2px;left:50%;opacity:0;position:absolute;transform:translateX(-50%);transition:all .3s ease;transition:all var(--transition-normal);width:0}.nav-icon{font-size:1.1rem}.nav-icon,.nav-right{align-items:center;display:flex}.nav-right{gap:1rem;gap:var(--spacing-md)}.nav-social{display:flex;gap:.5rem;gap:var(--spacing-sm)}@media(max-width:768px){.nav-social{display:none}}.social-link{color:var(--text-secondary);height:40px;min-height:44px;min-width:44px;text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast);width:40px}.social-link:hover{background:var(--bg-surface);color:var(--text-primary);transform:translateY(-2px)}.theme-toggle,.theme-toggle-container{align-items:center;display:flex;position:relative}.theme-toggle{background:none;border:none;border-radius:9999px;border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;justify-content:center;min-height:44px;min-width:44px;padding:.5rem;padding:var(--spacing-sm);transition:all .15s ease;transition:all var(--transition-fast);z-index:2}.theme-toggle:focus{outline:2px solid #818cf8;outline:2px solid var(--primary-400);outline-offset:2px}.theme-toggle:hover{background:var(--bg-surface);color:var(--text-primary)}.theme-toggle:active{transform:scale(.95)}.theme-toggle svg{transition:transform .15s ease;transition:transform var(--transition-fast)}.theme-toggle[data-theme-mode=auto]{animation:pulse-gentle 2s ease-in-out infinite}.theme-toggle[data-theme-mode=auto]:hover{animation:none}.theme-options{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-primary);border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);margin-top:.5rem;margin-top:var(--spacing-sm);min-width:120px;padding:.5rem;padding:var(--spacing-sm);right:0;top:100%;z-index:1000;z-index:var(--z-dropdown)}.theme-options,.theme-options:before{background:var(--bg-secondary);position:absolute}.theme-options:before{border-left:1px solid var(--border-primary);border-top:1px solid var(--border-primary);content:"";height:12px;right:12px;top:-6px;transform:rotate(45deg);width:12px}@media(max-width:768px){.theme-options{right:-50%;transform:translateX(50%)}.theme-options:before{right:50%;transform:translateX(50%) rotate(45deg)}}.theme-option{align-items:center;background:none;border:none;border-radius:.5rem;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;font-size:.875rem;font-size:var(--text-sm);gap:.5rem;gap:var(--spacing-sm);padding:.5rem 1rem;padding:var(--spacing-sm) var(--spacing-md);text-align:left;transition:all .15s ease;transition:all var(--transition-fast);width:100%}.theme-option:hover{background:var(--bg-surface);color:var(--text-primary)}.theme-option.active{background:#3a86ff1a;color:#818cf8;color:var(--primary-400);font-weight:600;font-weight:var(--font-semibold)}.theme-option:focus{outline:2px solid #818cf8;outline:2px solid var(--primary-400);outline-offset:2px;outline-offset:-2px}.nav-toggle{background:none;border:none;border-radius:.5rem;border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;display:none;font-size:1.5rem;min-height:44px;min-width:44px;padding:.5rem;padding:var(--spacing-sm);transition:all .15s ease;transition:all var(--transition-fast);z-index:1030;z-index:var(--z-fixed)}.nav-toggle:hover{background:var(--bg-surface)}.nav-toggle:focus{outline:2px solid #818cf8;outline:2px solid var(--primary-400);outline-offset:2px}@media(max-width:768px){.nav-toggle{align-items:center;display:flex;justify-content:center}}.nav-backdrop{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#000000b3;left:0;width:100%}.nav-backdrop,.nav-mobile{height:100vh;position:fixed;top:0;z-index:1040;z-index:var(--z-modal)}.nav-mobile{background:var(--bg-secondary);box-shadow:0 25px 50px -12px #00000040;box-shadow:var(--shadow-2xl);display:flex;flex-direction:column;right:0;width:320px}@media(max-width:768px){.nav-mobile{width:100%}}.nav-mobile-content{display:flex;flex-direction:column;height:100%;overflow-y:auto;padding:calc(70px + 2rem) 2rem 2rem;padding:calc(var(--nav-height-mobile) + var(--spacing-xl)) var(--spacing-xl) var(--spacing-xl);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.nav-mobile-header{align-items:center;border-bottom:1px solid var(--border-primary);display:flex;justify-content:space-between;margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);padding-bottom:1.5rem;padding-bottom:var(--spacing-lg)}.nav-mobile-header .mobile-logo{text-fill-color:#0000;background:linear-gradient(135deg,#6366f1,#4338ca);background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;color:#0000;font-size:1.25rem;font-size:var(--text-xl);font-weight:700;font-weight:var(--font-bold)}.nav-mobile-header .mobile-close{background:none;border:none;border-radius:.5rem;border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:1.5rem;padding:.5rem;padding:var(--spacing-sm)}.nav-mobile-header .mobile-close:focus{outline:2px solid #818cf8;outline:2px solid var(--primary-400);outline-offset:2px}.nav-mobile-menu{display:flex;flex:1 1;flex-direction:column;gap:.25rem;gap:var(--spacing-xs);list-style:none;margin:0;padding:0}.nav-mobile-item{width:100%}.nav-mobile-link{align-items:center;border-radius:.5rem;border-radius:var(--radius-md);color:var(--text-secondary);display:flex;font-weight:500;font-weight:var(--font-medium);gap:1rem;gap:var(--spacing-md);min-height:48px;padding:1rem;padding:var(--spacing-md);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast)}.nav-mobile-link.active,.nav-mobile-link:hover{background:var(--bg-surface);color:var(--text-primary)}.nav-mobile-link:focus{outline:2px solid #818cf8;outline:2px solid var(--primary-400);outline-offset:2px}.nav-mobile-social{display:flex;gap:1rem;gap:var(--spacing-md);justify-content:center;margin-top:auto}.nav-mobile-footer,.nav-mobile-social{padding-top:2rem;padding-top:var(--spacing-xl)}.nav-mobile-footer{border-top:1px solid var(--border-primary);color:var(--text-muted);font-size:.875rem;font-size:var(--text-sm);margin-top:2rem;margin-top:var(--spacing-xl);text-align:center}.mobile-theme-options{display:flex;flex-direction:column;gap:.5rem;gap:var(--spacing-sm);margin-top:1rem;margin-top:var(--spacing-md)}.mobile-theme-options .theme-option{font-size:1rem;font-size:var(--text-base);justify-content:center;padding:1rem;padding:var(--spacing-md)}@media(max-width:768px){.mobile-theme-options .theme-option{font-size:.875rem;font-size:var(--text-sm);padding:.5rem;padding:var(--spacing-sm)}.nav-mobile{width:100%}.nav-mobile-content{padding:calc(70px + 1.5rem) 1.5rem 1.5rem;padding:calc(var(--nav-height-mobile) + var(--spacing-lg)) var(--spacing-lg) var(--spacing-lg)}.theme-toggle{min-height:48px;min-width:48px}.theme-toggle:active{background:var(--bg-tertiary);transform:scale(.9)}}@keyframes pulse-gentle{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}@media(prefers-reduced-motion:reduce){.nav-link,.nav-toggle,.social-link,.theme-option,.theme-toggle{transition:none}.nav-link:active,.nav-link:hover,.nav-toggle:active,.nav-toggle:hover,.social-link:active,.social-link:hover,.theme-option:active,.theme-option:hover,.theme-toggle:active,.theme-toggle:hover{transform:none}.theme-toggle[data-theme-mode=auto]{animation:none}.nav-indicator{transition:none}}@media(prefers-contrast:high){.nav-link,.nav-mobile-link{border:1px solid #0000}.nav-link.active,.nav-link:hover,.nav-mobile-link.active,.nav-mobile-link:hover{border-color:var(--border-primary)}.theme-toggle{border:1px solid}.theme-toggle:focus{outline:2px solid currentColor;outline-offset:2px}.theme-options,.theme-options:before{border:2px solid var(--border-primary)}.theme-options:before{background:var(--bg-secondary);border-bottom:none;border-right:none}.theme-option{border:1px solid #0000}.theme-option.active,.theme-option:hover{border-color:currentColor}}@media(hover:none){.theme-option:hover,.theme-toggle:hover{background:#0000}.theme-toggle:active{transform:scale(.9)}.theme-option:active,.theme-toggle:active{background:var(--bg-surface)}}.nav-link,.social-link,.theme-options,.theme-toggle{will-change:transform,opacity,background-color}.nav-mobile{transform:translateZ(0)}@media print{.nav-mobile-footer,.nav-toggle,.theme-toggle-container{display:none!important}}.header{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#ffffff1a;background:var(--glass-bg);border:1px solid #ffffff26;border:1px solid var(--glass-border);box-shadow:0 8px 32px 0 #1f26875e;box-shadow:var(--glass-shadow);left:0;position:fixed;top:0;transition:all .3s ease;transition:all var(--transition-normal);width:100%;z-index:1030;z-index:var(--z-fixed)}@media(max-width:768px){.header{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0f172afa}}.header.scrolled{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0f172afa;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg)}@media(prefers-reduced-motion:reduce){.header{transition:none}}.social-container{align-items:center;display:flex;flex-direction:column;gap:2rem;gap:var(--spacing-xl);width:100%}.social-title{color:var(--text-primary);font-size:1.5rem;font-size:var(--text-2xl);font-weight:700;font-weight:var(--font-bold);letter-spacing:2px;margin-bottom:.5rem;margin-bottom:var(--spacing-sm);text-align:center;text-transform:uppercase}@media(max-width:768px){.social-title{font-size:1.25rem;font-size:var(--text-xl);letter-spacing:1px}}.highlight{animation:textShine 3s ease-in-out infinite;background:linear-gradient(135deg,#6366f1,#4338ca);background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;background-size:200% 200%;color:#0000}@keyframes textShine{0%,to{background-position:0 50%}50%{background-position:100% 50%}}.social-links{display:flex;flex-wrap:wrap;gap:1.5rem;gap:var(--spacing-lg);justify-content:center}@media(max-width:768px){.social-links{gap:1rem;gap:var(--spacing-md)}}.social-link{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-surface);border:1px solid var(--border-primary);border-radius:9999px;border-radius:var(--radius-full);display:flex;font-size:1.5rem;height:60px;justify-content:center;overflow:hidden;position:relative;transition:all .3s ease;transition:all var(--transition-normal);width:60px}@media(max-width:768px){.social-link{font-size:1.3rem;height:50px;width:50px}}.social-link:before{background:linear-gradient(45deg,#0000,#ffffff1a,#0000);content:"";height:100%;left:0;position:absolute;top:0;transform:translateX(-100%);transition:transform .6s ease;width:100%}.social-link:hover:before{transform:translateX(100%)}.social-icon-wrapper{align-items:center;display:flex;justify-content:center;position:relative;z-index:2}.social-tooltip{border:1px solid var(--border-primary);border-radius:.5rem;border-radius:var(--radius-md);bottom:-35px;color:var(--text-primary);font-size:.75rem;font-size:var(--text-xs);opacity:0;padding:.25rem .5rem;padding:var(--spacing-xs) var(--spacing-sm);pointer-events:none;transition:all .3s ease;transition:all var(--transition-normal);white-space:nowrap;z-index:10}.social-tooltip,.social-tooltip:before{background:var(--bg-secondary);left:50%;position:absolute;transform:translateX(-50%)}.social-tooltip:before{border-left:1px solid var(--border-primary);border-top:1px solid var(--border-primary);content:"";height:10px;top:-5px;transform:rotate(45deg) translateX(-50%);width:10px}.social-link:hover .social-tooltip{opacity:1;transform:translateX(-50%) translateY(-5px)}.social-pulse{animation:pulse 2s infinite;background:var(--social-color);border-radius:50%;height:100%;opacity:0;position:absolute;width:100%}@media(prefers-reduced-motion:reduce){.social-pulse{animation:none}}.social-link:hover .social-icon-wrapper{animation:bounce .5s ease}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-5px)}60%{transform:translateY(-3px)}}html[data-theme=dark] .social-link{background:#ffffff0d}html[data-theme=dark] .social-link:hover{background:#ffffff1a}html[data-theme=light] .social-link{background:#00000008}html[data-theme=light] .social-link:hover{background:#0000000f}html[data-theme=light] .social-tooltip{background:var(--bg-primary);border:1px solid var(--border-primary)}html[data-theme=light] .social-tooltip:before{background:var(--bg-primary);border-left:1px solid var(--border-primary);border-top:1px solid var(--border-primary)}@media(prefers-reduced-motion:reduce){.social-link,.social-link:before,.social-tooltip{transition:none}.highlight,.social-link:hover .social-icon-wrapper{animation:none}}.footer{background:linear-gradient(180deg,#0000 0,var(--bg-secondary) 20%);border-top:1px solid var(--border-primary);overflow:hidden;padding:4rem 2rem 2rem;padding:var(--spacing-3xl) var(--spacing-xl) var(--spacing-xl);position:relative}@media(max-width:768px){.footer{padding:3rem 1.5rem 1.5rem;padding:var(--spacing-2xl) var(--spacing-lg) var(--spacing-lg)}}.footer-container{margin:0 auto;max-width:1200px;max-width:var(--container-max-width);position:relative}.footer-content{align-items:center;display:flex;flex-direction:column;gap:3rem;gap:var(--spacing-2xl)}@media(max-width:768px){.footer-content{gap:2rem;gap:var(--spacing-xl)}}.footer-legal{align-items:center;display:flex;flex-direction:column;gap:1rem;gap:var(--spacing-md)}.footer-copyright{color:var(--text-muted);font-size:.875rem;font-size:var(--text-sm);font-weight:300;font-weight:var(--font-light);text-align:center}.footer-links{align-items:center;display:flex;gap:1rem;gap:var(--spacing-md)}@media(max-width:768px){.footer-links{flex-direction:column;gap:.5rem;gap:var(--spacing-sm)}}.footer-links a{color:var(--text-muted);font-size:.75rem;font-size:var(--text-xs);position:relative;text-decoration:none;transition:all .3s ease;transition:all var(--transition-normal)}.footer-links a:after{background:#818cf8;background:var(--primary-400);bottom:-2px;content:"";height:1px;left:0;position:absolute;transition:width .3s ease;transition:width var(--transition-normal);width:0}.footer-links a:hover{color:var(--text-primary)}.footer-links a:hover:after{width:100%}.divider{color:var(--text-muted);opacity:.5}@media(max-width:768px){.divider{display:none}}.footer-accent{bottom:0;height:2px;left:0;position:absolute;transform-origin:left center;width:100%}.glow-bar{animation:gradientShift 3s ease infinite;background:linear-gradient(135deg,#6366f1,#4338ca);background:var(--gradient-primary);background-size:200% 200%;filter:blur(5px);height:100%;opacity:.7;width:100%}.footer:before{animation:floatParticles 20s linear infinite;background-image:radial-gradient(1px 1px at 20% 30%,var(--text-muted) 1px,#0000 50%),radial-gradient(1px 1px at 40% 70%,var(--text-muted) 1px,#0000 50%),radial-gradient(1px 1px at 60% 80%,var(--text-muted) 1px,#0000 50%),radial-gradient(1px 1px at 80% 10%,var(--text-muted) 1px,#0000 50%),radial-gradient(1px 1px at 90% 50%,var(--text-muted) 1px,#0000 50%);background-size:200px 200px;content:"";height:100%;left:0;opacity:.1;pointer-events:none;position:absolute;top:0;width:100%;z-index:-1}@keyframes floatParticles{0%{transform:translateY(0) translateX(0)}to{transform:translateY(-100px) translateX(50px)}}html[data-theme=dark] .footer{background:linear-gradient(180deg,#0000 0,var(--bg-secondary) 20%)}html[data-theme=dark] .footer:before{opacity:.15}html[data-theme=dark] .glow-bar{opacity:.8}html[data-theme=light] .footer{background:linear-gradient(180deg,#0000 0,var(--bg-secondary) 20%)}html[data-theme=light] .footer:before{opacity:.08}html[data-theme=light] .glow-bar{opacity:.6}@media(prefers-reduced-motion:reduce){.footer:before,.glow-bar{animation:none}.footer-links a:after{transition:none}}.projects-page{background:var(--bg-primary);color:var(--text-primary);min-height:100vh;padding-bottom:4rem;padding-bottom:var(--spacing-3xl);padding-top:calc(80px + 3rem);padding-top:calc(var(--nav-height) + var(--spacing-2xl))}.projects-page .container{margin:0 auto;max-width:1200px;max-width:var(--container-max-width);padding:0 1.5rem;padding:0 var(--container-padding)}.projects-page__header{background:linear-gradient(180deg,#00000026,#0000);padding:1rem 0;padding:var(--spacing-md) 0;position:-webkit-sticky;position:sticky;top:80px;top:var(--nav-height);z-index:1020;z-index:var(--z-sticky)}@media(max-width:768px){.projects-page__header{padding:.5rem 0;padding:var(--spacing-sm) 0;top:70px;top:var(--nav-height-mobile)}}.projects-page__header-inner{align-items:center;display:flex;gap:1rem;gap:var(--spacing-md);justify-content:space-between}.projects-page__back-btn{align-items:center;background:var(--bg-surface);border:none;border:1px solid var(--border-primary);border-radius:.5rem;border-radius:var(--radius-md);border-radius:9999px;border-radius:var(--radius-full);color:var(--text-primary);cursor:pointer;display:inline-flex;font-size:1rem;font-size:var(--text-base);font-weight:500;font-weight:var(--font-medium);gap:.5rem;gap:var(--spacing-sm);justify-content:center;line-height:1;min-height:44px;min-height:auto;min-width:44px;min-width:auto;padding:.5rem;padding:var(--spacing-sm);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast)}.projects-page__back-btn:disabled{cursor:not-allowed;opacity:.6}@media(max-width:768px){.projects-page__back-btn{min-height:48px;min-width:48px}}.projects-page__back-btn:hover:not(:disabled){background:var(--bg-secondary);transform:translateY(-1px)}.projects-page__back-btn:focus-visible{outline:2px solid #818cf8;outline:2px solid var(--primary-400);outline-offset:2px}.projects-page__title{align-items:baseline;display:flex;gap:.5rem;gap:var(--spacing-sm);margin:0}.projects-page__title .highlight{text-fill-color:#0000;background:linear-gradient(135deg,#6366f1,#4338ca);background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;color:#0000}.projects-page__count{color:var(--text-muted);font-size:.875rem;font-size:var(--text-sm)}.projects-page__header-actions{display:flex;gap:.5rem;gap:var(--spacing-sm)}.projects-page__view-toggle{align-items:center;background:var(--bg-surface);border:none;border:1px solid var(--border-primary);border-radius:.5rem;border-radius:var(--radius-md);border-radius:9999px;border-radius:var(--radius-full);color:var(--text-primary);cursor:pointer;display:inline-flex;font-size:1rem;font-size:var(--text-base);font-weight:500;font-weight:var(--font-medium);gap:.5rem;gap:var(--spacing-sm);height:44px;justify-content:center;line-height:1;min-height:44px;min-width:44px;padding:0;text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast);width:44px}.projects-page__view-toggle:disabled{cursor:not-allowed;opacity:.6}@media(max-width:768px){.projects-page__view-toggle{min-height:48px;min-width:48px}}.projects-page__view-toggle:hover:not(:disabled){background:var(--bg-secondary);transform:translateY(-1px)}.projects-page__controls{background:var(--bg-primary);border-bottom:1px solid var(--border-primary);padding:1rem 0 1.5rem;padding:var(--spacing-md) 0 var(--spacing-lg);position:relative;z-index:1020;z-index:var(--z-sticky)}.projects-page__controls-grid{grid-gap:1rem;grid-gap:var(--spacing-md);align-items:center;display:grid;gap:1rem;gap:var(--spacing-md);grid-template-columns:repeat(12,1fr)}@media(max-width:768px){.projects-page__controls-grid{gap:.5rem;gap:var(--spacing-sm)}}.projects-page__search{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:.75rem;border-radius:var(--radius-lg);display:flex;grid-column:span 6;padding:0 1rem;padding:0 var(--spacing-md);position:relative}@media(max-width:768px){.projects-page__search{grid-column:span 12}}.projects-page__search-icon{color:var(--text-muted);margin-right:.5rem;margin-right:var(--spacing-sm)}.projects-page__search-input{background:var(--bg-surface);background:#0000;border:none;border-radius:.5rem;border-radius:var(--radius-md);box-shadow:none;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-sans);font-size:1rem;font-size:var(--text-base);padding:1rem 0;padding:var(--spacing-md) 0;transition:all .15s ease;transition:all var(--transition-fast);width:100%}.projects-page__search-input::placeholder{color:var(--text-muted)}.projects-page__search-input:focus{border-color:#818cf8;border-color:var(--primary-400);box-shadow:0 0 0 3px #3a86ff33}.projects-page__search-input:disabled{cursor:not-allowed;opacity:.6}.projects-page__search-input:focus{border:none;box-shadow:none;outline:none}.projects-page__clear-search{align-items:center;background:var(--bg-surface);border:none;border:1px solid var(--border-primary);border-radius:.5rem;border-radius:var(--radius-md);border-radius:9999px;border-radius:var(--radius-full);color:var(--text-primary);cursor:pointer;display:inline-flex;font-size:1rem;font-size:var(--text-base);font-weight:500;font-weight:var(--font-medium);gap:.5rem;gap:var(--spacing-sm);justify-content:center;line-height:1;min-height:44px;min-height:auto;min-width:44px;min-width:auto;padding:.25rem;padding:var(--spacing-xs);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast)}.projects-page__clear-search:disabled{cursor:not-allowed;opacity:.6}@media(max-width:768px){.projects-page__clear-search{min-height:48px;min-width:48px}}.projects-page__clear-search:hover:not(:disabled){background:var(--bg-secondary);transform:translateY(-1px)}.projects-page__sort{grid-column:span 3;position:relative}@media(max-width:768px){.projects-page__sort{grid-column:span 6}}.projects-page__sort-select{-webkit-appearance:none;appearance:none;background:var(--bg-surface);border:1px solid var(--border-primary);border-radius:.5rem;border-radius:var(--radius-md);color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-sans);font-size:1rem;font-size:var(--text-base);padding:1rem 1.5rem;padding:var(--spacing-md) var(--spacing-lg);padding-right:calc(2rem + 6px);padding-right:calc(var(--spacing-xl) + 6px);transition:all .15s ease;transition:all var(--transition-fast);width:100%}.projects-page__sort-select::placeholder{color:var(--text-muted)}.projects-page__sort-select:focus{border-color:#818cf8;border-color:var(--primary-400);box-shadow:0 0 0 3px #3a86ff33;outline:none}.projects-page__sort-select:disabled{cursor:not-allowed;opacity:.6}.projects-page__select-arrow{color:var(--text-muted);pointer-events:none;position:absolute;right:1rem;right:var(--spacing-md);top:50%;transform:translateY(-50%)}.projects-page__filter-toggle{align-items:center;background:var(--bg-surface);border:none;border:1px solid var(--border-primary);border-radius:.5rem;border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;display:inline-flex;font-size:1rem;font-size:var(--text-base);font-weight:500;font-weight:var(--font-medium);gap:.5rem;gap:var(--spacing-sm);grid-column:span 3;justify-content:center;justify-self:end;line-height:1;min-height:44px;min-width:44px;padding:1rem 1.5rem;padding:var(--spacing-md) var(--spacing-lg);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast)}.projects-page__filter-toggle:disabled{cursor:not-allowed;opacity:.6}@media(max-width:768px){.projects-page__filter-toggle{min-height:48px;min-width:48px}}.projects-page__filter-toggle:hover:not(:disabled){background:var(--bg-secondary);transform:translateY(-1px)}@media(max-width:768px){.projects-page__filter-toggle{grid-column:span 6}}.projects-page__filter-toggle.is-active{border-color:var(--border-accent);box-shadow:0 0 0 3px #6366f133}.projects-page__mobile-filters{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:var(--bg-secondary);background:#ffffff1a;background:var(--glass-bg);border:1px solid #ffffff26;border:1px solid var(--glass-border);border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 8px 32px 0 #1f26875e;box-shadow:var(--glass-shadow);margin-top:1rem;margin-top:var(--spacing-md);overflow:hidden}.projects-page__desktop-filters{background:var(--bg-primary);padding:1rem 0;padding:var(--spacing-md) 0}.projects-page__results{padding-top:1.5rem;padding-top:var(--spacing-lg)}.projects-page__list{grid-gap:1.5rem;grid-gap:var(--spacing-lg);display:grid;gap:1.5rem;gap:var(--spacing-lg)}.projects-page__list--grid{grid-template-columns:repeat(12,1fr)}.projects-page__list--grid .projects-page__item{grid-column:span 4}@media(min-width:769px)and (max-width:1024px){.projects-page__list--grid .projects-page__item{grid-column:span 6}}@media(max-width:768px){.projects-page__list--grid .projects-page__item{grid-column:span 12}}.projects-page__list--list{grid-template-columns:1fr}.projects-page__list--list .projects-page__item{grid-column:1/-1}.projects-page__empty{align-items:center;display:flex;justify-content:center;padding:3rem 0;padding:var(--spacing-2xl) 0;text-align:center}.projects-page__empty-inner{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:var(--bg-secondary);background:#ffffff1a;background:var(--glass-bg);border:1px solid #ffffff26;border:1px solid var(--glass-border);border-radius:1rem;border-radius:var(--radius-xl);box-shadow:0 8px 32px 0 #1f26875e;box-shadow:var(--glass-shadow);margin:0 auto;max-width:520px;padding:2rem;padding:var(--spacing-xl)}.projects-page__empty-inner h3{margin:0 0 .5rem;margin:0 0 var(--spacing-sm)}.projects-page__empty-inner p{color:var(--text-secondary);margin-bottom:1rem;margin-bottom:var(--spacing-md)}.projects-page__empty-icon{color:var(--text-muted);margin-bottom:1rem;margin-bottom:var(--spacing-md)}.projects-page__results-info{color:var(--text-secondary);margin-top:1.5rem;margin-top:var(--spacing-lg)}.projects-page__filter-info{color:var(--text-muted);margin-left:.5rem;margin-left:var(--spacing-sm)}.projects-page__fab{align-items:center;background:linear-gradient(135deg,#6366f1,#4338ca);background:var(--gradient-primary);border:none;border-radius:.5rem;border-radius:var(--radius-md);border-radius:9999px;border-radius:var(--radius-full);bottom:1.5rem;bottom:var(--spacing-lg);color:var(--text-on-primary);cursor:pointer;display:inline-flex;font-size:1rem;font-size:var(--text-base);font-weight:500;font-weight:var(--font-medium);gap:.5rem;gap:var(--spacing-sm);height:56px;justify-content:center;line-height:1;min-height:44px;min-width:44px;padding:0;position:fixed;right:1.5rem;right:var(--spacing-lg);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast);width:56px;z-index:1050;z-index:var(--z-popover)}.projects-page__fab:disabled{cursor:not-allowed;opacity:.6}@media(max-width:768px){.projects-page__fab{min-height:48px;min-width:48px}}.projects-page__fab:hover:not(:disabled){box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.projects-page__fab:active:not(:disabled){transform:translateY(0)}@media(max-width:768px){.projects-page__fab{bottom:1rem;bottom:var(--spacing-md);right:1rem;right:var(--spacing-md)}}@media(prefers-reduced-motion:reduce){.projects-page *{animation:none!important;transition:none!important}}.auth-view{background:radial-gradient(1200px 600px at 10% -10%,#6366f140,#0000 60%),radial-gradient(1000px 400px at 110% -20%,#8338ec33,#0000 60%);display:grid;min-height:calc(100vh - 80px);min-height:calc(100vh - var(--nav-height));padding:3rem 1.5rem;padding:var(--spacing-2xl) var(--spacing-lg);place-items:center;position:relative}@media(max-width:768px){.auth-view{min-height:100vh;padding-bottom:3rem;padding-bottom:var(--spacing-2xl);padding-top:calc(70px + 2rem);padding-top:calc(var(--nav-height-mobile) + var(--spacing-xl))}}.auth-bg{background:linear-gradient(135deg,#ffffff0a,#fff0);inset:0;pointer-events:none;position:absolute}.auth-card{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:var(--bg-card);background:#ffffff1a;background:var(--glass-bg);border:1px solid #ffffff26;border:1px solid var(--glass-border);border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 8px 32px 0 #1f26875e;box-shadow:var(--glass-shadow);max-width:520px;padding:clamp(1.5rem,4vw,3rem);padding:clamp(var(--spacing-lg),4vw,var(--spacing-2xl));transition:all .3s ease;transition:all var(--transition-normal);width:100%}.auth-card:hover{border-color:var(--border-accent);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);transform:translateY(-4px)}.auth-head{margin-bottom:2rem;margin-bottom:var(--spacing-xl)}.auth-title{color:var(--text-primary);font-size:1.875rem;font-size:var(--text-3xl);margin:0 0 .25rem;margin:0 0 var(--spacing-xs)}.auth-subtitle{color:var(--text-muted)}.gradient{background:linear-gradient(135deg,#6366f1,#4338ca);background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;color:#0000}.auth-form{grid-gap:1.5rem;grid-gap:var(--spacing-lg);display:grid;gap:1.5rem;gap:var(--spacing-lg)}.form-field{grid-gap:.5rem;grid-gap:var(--spacing-sm);display:grid;gap:.5rem;gap:var(--spacing-sm)}.field-label{color:var(--text-secondary);font-size:.875rem;font-size:var(--text-sm)}.input-wrap{position:relative}.field-icon{color:var(--text-muted);left:14px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.input{background:var(--bg-surface);border:1px solid var(--border-primary);border-radius:.5rem;border-radius:var(--radius-md);color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-sans);font-size:1rem;font-size:var(--text-base);padding:1rem 1.5rem;padding:var(--spacing-md) var(--spacing-lg);padding-left:44px;transition:all .15s ease;transition:all var(--transition-fast);width:100%}.input::placeholder{color:var(--text-muted)}.input:focus{border-color:#818cf8;border-color:var(--primary-400);box-shadow:0 0 0 3px #3a86ff33;outline:none}.input:disabled{cursor:not-allowed;opacity:.6}.btn--primary{align-items:center;background:linear-gradient(135deg,#6366f1,#4338ca);background:var(--gradient-primary);border:none;border-radius:.5rem;border-radius:var(--radius-md);color:var(--text-on-primary);cursor:pointer;display:inline-flex;font-size:1rem;font-size:var(--text-base);font-weight:500;font-weight:var(--font-medium);gap:.5rem;gap:var(--spacing-sm);justify-content:center;line-height:1;min-height:44px;min-width:44px;padding:1rem 1.5rem;padding:var(--spacing-md) var(--spacing-lg);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast)}.btn--primary:disabled{cursor:not-allowed;opacity:.6}@media(max-width:768px){.btn--primary{min-height:48px;min-width:48px}}.btn--primary:hover:not(:disabled){box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn--primary:active:not(:disabled){transform:translateY(0)}.btn--secondary{align-items:center;background:var(--bg-surface);border:none;border:1px solid var(--border-primary);border-radius:.5rem;border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;display:inline-flex;font-size:1rem;font-size:var(--text-base);font-weight:500;font-weight:var(--font-medium);gap:.5rem;gap:var(--spacing-sm);justify-content:center;line-height:1;min-height:44px;min-width:44px;padding:1rem 1.5rem;padding:var(--spacing-md) var(--spacing-lg);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast)}.btn--secondary:disabled{cursor:not-allowed;opacity:.6}@media(max-width:768px){.btn--secondary{min-height:48px;min-width:48px}}.btn--secondary:hover:not(:disabled){background:var(--bg-secondary);transform:translateY(-1px)}.btn--full{width:100%}.auth-foot{color:var(--text-secondary);margin-top:1.5rem;margin-top:var(--spacing-lg);text-align:center}.auth-foot a{color:#818cf8;color:var(--primary-400);font-weight:500;font-weight:var(--font-medium);text-decoration:none}.auth-foot a:hover{text-decoration:underline}.dash-view{margin:0 auto;max-width:1200px;min-height:calc(100vh - 80px);min-height:calc(100vh - var(--nav-height));padding:calc(2rem + 80px) 1.5rem 3rem;padding:calc(var(--spacing-xl) + var(--nav-height)) var(--spacing-lg) var(--spacing-2xl)}@media(max-width:768px){.dash-view{min-height:100vh;padding:calc(70px + 1.5rem) 1rem 2rem;padding:calc(var(--nav-height-mobile) + var(--spacing-lg)) var(--spacing-md) var(--spacing-xl)}}.dash-header{align-items:center;display:flex;gap:1.5rem;gap:var(--spacing-lg);justify-content:space-between;margin-bottom:2rem;margin-bottom:var(--spacing-xl)}.dash-title{font-size:1.875rem;font-size:var(--text-3xl);margin:0}.dash-subtitle{color:var(--text-muted);margin-top:.25rem;margin-top:var(--spacing-xs)}.dash-right .btn{align-items:center;background:var(--bg-surface);border:none;border:1px solid var(--border-primary);border-radius:.5rem;border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;display:inline-flex;font-size:1rem;font-size:var(--text-base);font-weight:500;font-weight:var(--font-medium);gap:.5rem;gap:var(--spacing-sm);justify-content:center;line-height:1;min-height:44px;min-width:44px;padding:1rem 1.5rem;padding:var(--spacing-md) var(--spacing-lg);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast)}.dash-right .btn:disabled{cursor:not-allowed;opacity:.6}@media(max-width:768px){.dash-right .btn{min-height:48px;min-width:48px}}.dash-right .btn:hover:not(:disabled){background:var(--bg-secondary);transform:translateY(-1px)}.dash-grid{grid-gap:1.5rem;grid-gap:var(--spacing-lg);display:grid;gap:1.5rem;gap:var(--spacing-lg);grid-template-columns:repeat(12,1fr);margin-bottom:2rem;margin-bottom:var(--spacing-xl)}.dash-grid .kpi-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-card);border:1px solid var(--border-primary);border-radius:.75rem;border-radius:var(--radius-lg);grid-column:span 3;padding:1.5rem;padding:var(--spacing-lg);transition:all .3s ease;transition:all var(--transition-normal)}.dash-grid .kpi-card:hover{border-color:var(--border-accent);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);transform:translateY(-4px)}@media(min-width:769px)and (max-width:1024px){.dash-grid .kpi-card{grid-column:span 6}}@media(max-width:768px){.dash-grid .kpi-card{grid-column:span 12}}.dash-grid .kpi-card .kpi-head{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.dash-grid .kpi-card .kpi-head .kpi-icon{background:var(--bg-surface);border-radius:9999px;border-radius:var(--radius-full);display:grid;height:38px;place-items:center;width:38px}.dash-grid .kpi-card .kpi-head .kpi-label{color:var(--text-secondary)}.dash-grid .kpi-card .kpi-value{font-size:1.875rem;font-size:var(--text-3xl);font-weight:600;font-weight:var(--font-semibold);margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.dash-grid .kpi-card .kpi-foot{align-items:center;align-items:end;display:flex;gap:1rem;gap:var(--spacing-md);justify-content:space-between}.dash-grid .kpi-card .kpi-foot .trend{align-items:center;display:inline-flex;font-weight:500;font-weight:var(--font-medium);gap:6px}.dash-grid .kpi-card .kpi-foot .trend.up{color:#10b981;color:var(--success)}.dash-grid .kpi-card .kpi-foot .trend.down{color:#ef4444;color:var(--error)}.dash-grid .kpi-card .kpi-foot .bars{grid-gap:4px;align-items:end;display:grid;flex:1 1;gap:4px;grid-auto-flow:column;height:32px}.dash-grid .kpi-card .kpi-foot .bars span{background:linear-gradient(135deg,#8338ec,#3a86ff);background:var(--gradient-secondary);border-radius:4px;display:block;opacity:.9;width:100%}.dash-panels{grid-gap:1.5rem;grid-gap:var(--spacing-lg);display:grid;gap:1.5rem;gap:var(--spacing-lg);grid-template-columns:repeat(12,1fr)}.dash-panels .panel{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-card);border:1px solid var(--border-primary);border-radius:.75rem;border-radius:var(--radius-lg);grid-column:span 6;padding:1.5rem;padding:var(--spacing-lg);transition:all .3s ease;transition:all var(--transition-normal)}.dash-panels .panel:hover{border-color:var(--border-accent);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);transform:translateY(-4px)}@media(min-width:769px)and (max-width:1024px){.dash-panels .panel{grid-column:span 12}}@media(max-width:768px){.dash-panels .panel{grid-column:span 12}}.dash-panels .panel .panel-title{font-size:1.25rem;font-size:var(--text-xl);margin:0 0 1rem;margin:0 0 var(--spacing-md)}.dash-panels .panel .ref-list,.dash-panels .panel .review-list{grid-gap:1rem;grid-gap:var(--spacing-md);display:grid;gap:1rem;gap:var(--spacing-md);list-style:none;margin:0;padding:0}.dash-panels .panel .review-item{background:var(--bg-surface);border:1px solid var(--border-primary);border-radius:.5rem;border-radius:var(--radius-md);padding:1rem;padding:var(--spacing-md)}.dash-panels .panel .review-item .review-head{align-items:center;display:flex;justify-content:space-between;margin-bottom:.25rem;margin-bottom:var(--spacing-xs)}.dash-panels .panel .review-item .review-head .review-name{font-weight:500;font-weight:var(--font-medium)}.dash-panels .panel .review-item .review-head .review-rating{color:#f59e0b;color:var(--warning);font-weight:600;font-weight:var(--font-semibold)}.dash-panels .panel .review-item .review-comment{color:var(--text-secondary)}.dash-panels .panel .review-item .review-meta{color:var(--text-muted);display:flex;font-size:.875rem;font-size:var(--text-sm);gap:1rem;gap:var(--spacing-md);margin-top:.25rem;margin-top:var(--spacing-xs)}.dash-panels .panel .ref-list li{align-items:center;background:var(--bg-surface);border:1px solid var(--border-primary);border-radius:.5rem;border-radius:var(--radius-md);display:flex;justify-content:space-between;padding:1rem;padding:var(--spacing-md)}.dash-panels .panel .ref-list li .ref-name{max-width:70%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dash-panels .panel .ref-list li .ref-count{font-weight:600;font-weight:var(--font-semibold)}.dash-panels .panel .empty{color:var(--text-muted);padding:1.5rem;padding:var(--spacing-lg);text-align:center}.dash-error,.dash-loading{grid-gap:.5rem;grid-gap:var(--spacing-sm);color:var(--text-secondary);display:grid;gap:.5rem;gap:var(--spacing-sm);place-items:center}.dash-error .spinner,.dash-loading .spinner{animation:spin .9s linear infinite;border-top-color:#6366f1;border:3px solid var(--border-primary);border-radius:50%;border-top-color:var(--primary-500);height:36px;width:36px}:root{--primary-50:#eef4ff;--primary-100:#e0e7ff;--primary-200:#c7d2fe;--primary-300:#a5b4fc;--primary-400:#818cf8;--primary-500:#6366f1;--primary-600:#4f46e5;--primary-700:#4338ca;--primary-800:#3730a3;--primary-900:#312e81;--gradient-primary:linear-gradient(135deg,var(--primary-500),var(--primary-700));--gradient-secondary:linear-gradient(135deg,#8338ec,#3a86ff);--gradient-accent:linear-gradient(135deg,#f97316,#ec4899);--success:#10b981;--warning:#f59e0b;--error:#ef4444;--info:#3b82f6;--glass-bg:#ffffff1a;--glass-border:#ffffff26;--glass-shadow:0 8px 32px 0 #1f26875e}html[data-theme=dark]{--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-tertiary:#334155;--bg-surface:#ffffff0d;--bg-card:#ffffff08;--text-primary:#f8fafc;--text-secondary:#cbd5e1;--text-muted:#94a3b8;--text-on-primary:#fff;--border-primary:#ffffff1a;--border-secondary:#ffffff0d;--border-accent:var(--primary-500)}html[data-theme=light]{--bg-primary:#fff;--bg-secondary:#f8fafc;--bg-tertiary:#f1f5f9;--bg-surface:#0000000d;--bg-card:#00000008;--text-primary:#1e293b;--text-secondary:#475569;--text-muted:#94a3b8;--text-on-primary:#fff;--border-primary:#0000001a;--border-secondary:#0000000d;--border-accent:var(--primary-500)}:root{--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto",sans-serif;--font-mono:"Fira Code","Monaco","Cascadia Code","Roboto Mono",monospace;--font-light:300;--font-regular:400;--font-medium:500;--font-semibold:600;--font-bold:700;--font-extrabold:800;--text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--text-5xl:3rem;--text-6xl:3.75rem;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--spacing-3xl:4rem;--spacing-4xl:6rem;--radius-sm:0.25rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--radius-2xl:1.5rem;--radius-full:9999px;--transition-fast:150ms ease;--transition-normal:300ms ease;--transition-slow:500ms ease;--transition-bounce:600ms cubic-bezier(0.68,-0.55,0.265,1.55);--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;--shadow-2xl:0 25px 50px -12px #00000040;--z-dropdown:1000;--z-sticky:1020;--z-fixed:1030;--z-modal:1040;--z-popover:1050;--z-tooltip:1060;--z-toast:1070;--container-max-width:1200px;--container-padding:1.5rem;--nav-height:80px;--nav-height-mobile:70px}@keyframes gradientShift{0%,to{background-position:0 50%}50%{background-position:100% 50%}}@keyframes scrollIndicator{0%{opacity:0;top:0}50%{opacity:1;top:20px}to{opacity:0;top:40px}}@keyframes loading{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-2px)}}@media(max-width:768px){.btn,.modal-project-link,.nav-link,.nav-toggle,.project-card,.skill-item,.social-link,.tab-button,.tech-tag,.theme-toggle,.view-more-btn{align-items:center;cursor:pointer;display:flex;justify-content:center;min-height:44px;min-width:44px}.btn:active,.modal-project-link:active,.nav-link:active,.nav-toggle:active,.project-card:active,.skill-item:active,.social-link:active,.tab-button:active,.tech-tag:active,.theme-toggle:active,.view-more-btn:active{transform:scale(.97);transition:transform .15s ease;transition:transform var(--transition-fast)}button,input,select,textarea{border-radius:.5rem;border-radius:var(--radius-md);font-size:16px}button:focus,input:focus,select:focus,textarea:focus{outline:2px solid #818cf8;outline:2px solid var(--primary-400);outline-offset:2px}html{-webkit-overflow-scrolling:touch;scroll-behavior:smooth;scroll-padding-top:calc(70px + 1rem);scroll-padding-top:calc(var(--nav-height-mobile) + var(--spacing-md))}body{-webkit-tap-highlight-color:rgba(0,0,0,0);overscroll-behavior-y:none}.app{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.app,.main-content{padding-bottom:env(safe-area-inset-bottom)}.main-content{padding-top:70px;padding-top:var(--nav-height-mobile)}.interactive-element{transition:all .15s ease;transition:all var(--transition-fast)}.interactive-element:active{opacity:.9;transform:scale(.98)}.swipe-container{touch-action:pan-y;-webkit-user-select:none;user-select:none}.nav-mobile{-webkit-overflow-scrolling:touch;touch-action:pan-y}img,video{height:auto;max-width:100%}h1,h2,h3,h4,h5,h6{line-height:1.3}li,p{font-size:1rem;font-size:var(--text-base);line-height:1.6}.container{padding:0 1rem;padding:0 var(--spacing-md)}.section-title{margin-bottom:3rem;margin-bottom:var(--spacing-2xl);text-align:center}.nav{height:70px;height:var(--nav-height-mobile)}.nav.scrolled{height:65px;height:calc(var(--nav-height-mobile) - 5px)}.hero-container{gap:2rem;gap:var(--spacing-xl);grid-template-columns:1fr;text-align:center}.hero-actions{align-items:center;flex-direction:column}.hero-actions .btn{max-width:280px;width:100%}.about-grid{gap:2rem;gap:var(--spacing-xl);grid-template-columns:1fr}.about-image-wrapper{margin:0 auto;max-width:300px}.timeline{padding-left:1.5rem;padding-left:var(--spacing-lg)}.project-grid{gap:1.5rem;gap:var(--spacing-lg);grid-template-columns:1fr}.project-card{aspect-ratio:16/9}form{padding:1rem;padding:var(--spacing-md)}.footer{text-align:center}.footer .footer-content{gap:1.5rem;gap:var(--spacing-lg);grid-template-columns:1fr}.text-center-mobile{text-align:center}.hide-mobile{display:none!important}.modal-content{max-height:90vh;width:95%}.modal-project-view{flex-direction:column}.modal-project-container{order:-1}.modal-project-links{flex-direction:column}.modal-projects-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}}@media(min-width:769px)and (max-width:1024px){.about-grid{gap:2rem;gap:var(--spacing-xl);grid-template-columns:1fr 1.2fr}.project-grid{grid-template-columns:repeat(2,1fr)}.nav-menu{gap:1rem;gap:var(--spacing-md)}.container{padding:0 2rem;padding:0 var(--spacing-xl)}.section-title{font-size:clamp(1.5rem,4vw,1.875rem);font-size:clamp(var(--text-2xl),4vw,var(--text-3xl))}form{margin:0 auto;max-width:600px}.modal-project-media{height:300px}}@media(min-width:1025px){.nav-link:hover .nav-indicator{opacity:1;width:100%}.card:hover{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);transform:translateY(-4px)}.social-link:hover{color:var(--text-primary);transform:translateY(-2px)}.skill-item:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-4px)}.project-card:hover{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);transform:translateY(-4px)}.mobile-only{display:none}.desktop-only{display:block}.about-grid{gap:3rem;gap:var(--spacing-2xl);grid-template-columns:1fr 1.5fr}.project-grid{grid-template-columns:repeat(3,1fr)}.nav-menu{gap:1.5rem;gap:var(--spacing-lg)}.hero-container{gap:3rem;gap:var(--spacing-2xl);grid-template-columns:1.2fr 1fr;text-align:left}.hero-actions{flex-direction:row;justify-content:flex-start}.hero-actions .btn{width:auto}}@media(min-width:1440px){.container{max-width:1400px}.about-grid,.hero-container{gap:4rem;gap:var(--spacing-3xl)}}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px;scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-sans);line-height:1.6;overflow-x:hidden;transition:background-color .3s ease,color .3s ease}::selection{background:#818cf8;background:var(--primary-400);color:var(--text-on-primary)}::-moz-selection{background:#818cf8;background:var(--primary-400);color:var(--text-on-primary)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:#4f46e5;background:var(--primary-600);border-radius:9999px;border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#6366f1;background:var(--primary-500)}.app{-webkit-tap-highlight-color:rgba(0,0,0,0);-webkit-overflow-scrolling:touch;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);display:flex;flex-direction:column;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-sans);line-height:1.6;min-height:100vh;transition:background-color .3s ease,color .3s ease}.main-content{flex:1 1;overflow-x:hidden;padding-top:80px;padding-top:var(--nav-height);position:relative}@media(max-width:768px){.main-content{padding-top:70px;padding-top:var(--nav-height-mobile)}}.focus-ring:focus{outline:2px solid #818cf8;outline:2px solid var(--primary-400);outline-offset:2px}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mt-auto{margin-top:auto}.mb-auto{margin-bottom:auto}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes spin{to{transform:rotate(1turn)}}.container{margin:0 auto;max-width:1200px;max-width:var(--container-max-width);padding:0 1.5rem;padding:0 var(--container-padding);width:100%}@media(max-width:768px){.container{padding:0 1rem;padding:0 var(--spacing-md)}}.section{padding:4rem 0;padding:var(--spacing-3xl) 0;scroll-margin-top:calc(80px + 1.5rem);scroll-margin-top:calc(var(--nav-height) + var(--spacing-lg))}.section-alt{background:var(--bg-secondary)}@media(max-width:768px){.section{padding:3rem 0;padding:var(--spacing-2xl) 0;scroll-margin-top:calc(70px + 1rem);scroll-margin-top:calc(var(--nav-height-mobile) + var(--spacing-md))}}.card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-card);border:1px solid var(--border-primary);border-radius:.75rem;border-radius:var(--radius-lg);padding:1.5rem;padding:var(--spacing-lg);transition:all .3s ease;transition:all var(--transition-normal)}.card:hover{border-color:var(--border-accent);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);transform:translateY(-4px)}.card-header{border-bottom:1px solid var(--border-primary)}.card-body,.card-footer,.card-header{padding:1.5rem;padding:var(--spacing-lg)}.card-footer{border-top:1px solid var(--border-primary)}.btn{align-items:center;border:none;border-radius:.5rem;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-size:1rem;font-size:var(--text-base);font-weight:500;font-weight:var(--font-medium);gap:.5rem;gap:var(--spacing-sm);justify-content:center;line-height:1;min-height:44px;min-width:44px;padding:1rem 1.5rem;padding:var(--spacing-md) var(--spacing-lg);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast)}.btn:disabled{cursor:not-allowed;opacity:.6}@media(max-width:768px){.btn{min-height:48px;min-width:48px}}.btn-primary{align-items:center;background:linear-gradient(135deg,#6366f1,#4338ca);background:var(--gradient-primary);border:none;border-radius:.5rem;border-radius:var(--radius-md);color:var(--text-on-primary);cursor:pointer;display:inline-flex;font-size:1rem;font-size:var(--text-base);font-weight:500;font-weight:var(--font-medium);gap:.5rem;gap:var(--spacing-sm);justify-content:center;line-height:1;min-height:44px;min-width:44px;padding:1rem 1.5rem;padding:var(--spacing-md) var(--spacing-lg);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast)}.btn-primary:disabled{cursor:not-allowed;opacity:.6}@media(max-width:768px){.btn-primary{min-height:48px;min-width:48px}}.btn-primary:hover:not(:disabled){box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{align-items:center;background:var(--bg-surface);border:none;border:1px solid var(--border-primary);border-radius:.5rem;border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;display:inline-flex;font-size:1rem;font-size:var(--text-base);font-weight:500;font-weight:var(--font-medium);gap:.5rem;gap:var(--spacing-sm);justify-content:center;line-height:1;min-height:44px;min-width:44px;padding:1rem 1.5rem;padding:var(--spacing-md) var(--spacing-lg);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast)}.btn-secondary:disabled{cursor:not-allowed;opacity:.6}@media(max-width:768px){.btn-secondary{min-height:48px;min-width:48px}}.btn-secondary:hover:not(:disabled){background:var(--bg-secondary);transform:translateY(-1px)}.btn-outline{background:#0000;border:2px solid;color:var(--text-primary)}.btn-outline:hover:not(:disabled){background:var(--bg-surface)}.gradient-text{text-fill-color:#0000;background:linear-gradient(135deg,#6366f1,#4338ca);background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;color:#0000}.glass-effect{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#ffffff1a;background:var(--glass-bg);border:1px solid #ffffff26;border:1px solid var(--glass-border);box-shadow:0 8px 32px 0 #1f26875e;box-shadow:var(--glass-shadow)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.truncate-2{-webkit-line-clamp:2}.truncate-2,.truncate-3{-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.truncate-3{-webkit-line-clamp:3}.flex-center{justify-content:center}.flex-between,.flex-center{align-items:center;display:flex}.flex-between{justify-content:space-between}.flex-column{display:flex;flex-direction:column}.grid{grid-gap:1.5rem;grid-gap:var(--spacing-lg);grid-template-columns:repeat(12,1fr)}.grid,.grid-2{display:grid;gap:1.5rem;gap:var(--spacing-lg)}.grid-2{grid-gap:1.5rem;grid-gap:var(--spacing-lg);grid-template-columns:repeat(2,1fr)}.grid-3{grid-gap:1.5rem;grid-gap:var(--spacing-lg);grid-template-columns:repeat(3,1fr)}.grid-3,.grid-4{display:grid;gap:1.5rem;gap:var(--spacing-lg)}.grid-4{grid-gap:1.5rem;grid-gap:var(--spacing-lg);grid-template-columns:repeat(4,1fr)}.fade-in-up{opacity:0;transform:translateY(20px);transition:all .3s ease;transition:all var(--transition-normal)}.fade-in-up.visible{opacity:1;transform:translateY(0)}.scale-hover{transition:transform .15s ease;transition:transform var(--transition-fast)}.scale-hover:hover{transform:scale(1.05)}.scale-hover:active{transform:scale(.95)}.pulse{animation:pulse 2s infinite}.float{animation:float 6s ease-in-out infinite}.mobile-app{-webkit-tap-highlight-color:rgba(0,0,0,0);-webkit-overflow-scrolling:touch;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;-webkit-user-select:none;user-select:none}.safe-area{padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.safe-area-margin{margin-bottom:env(safe-area-inset-bottom);margin-left:env(safe-area-inset-left);margin-right:env(safe-area-inset-right)}.touch-feedback{transition:transform .15s ease;transition:transform var(--transition-fast)}.touch-feedback:active{transform:scale(.97)}.loading{align-items:center;display:flex;justify-content:center;min-height:200px}.loading:after{animation:spin 1s linear infinite;border-top:2px solid #818cf8;border:2px solid var(--border-primary);border-radius:50%;border-top-color:var(--primary-400);content:"";height:24px;width:24px}@media(prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}.btn,.card,.social-link{transition:none!important}.btn:hover,.card:hover,.social-link:hover{transform:none!important}}@media(prefers-contrast:high){.btn,.card{border:2px solid}.btn-primary{background:#000;border-color:#000;color:#fff}:focus{outline:3px solid currentColor!important;outline-offset:2px}}@media print{.app{background:#fff!important;color:#000!important}.btn,.footer,.nav{display:none!important}.main-content{padding-top:0}.section{break-inside:avoid;page-break-inside:avoid}.card{border:1px solid #ccc;box-shadow:none!important}a{color:#000!important;text-decoration:underline}*{-webkit-print-color-adjust:exact;print-color-adjust:exact}}:root{--toastify-color-light:#fff;--toastify-color-dark:#121212;--toastify-color-info:#3498db;--toastify-color-success:#07bc0c;--toastify-color-warning:#f1c40f;--toastify-color-error:#e74d3c;--toastify-color-transparent:#ffffffb3;--toastify-icon-color-info:var(--toastify-color-info);--toastify-icon-color-success:var(--toastify-color-success);--toastify-icon-color-warning:var(--toastify-color-warning);--toastify-icon-color-error:var(--toastify-color-error);--toastify-container-width:fit-content;--toastify-toast-width:320px;--toastify-toast-offset:16px;--toastify-toast-top:max(var(--toastify-toast-offset),env(safe-area-inset-top));--toastify-toast-right:max(var(--toastify-toast-offset),env(safe-area-inset-right));--toastify-toast-left:max(var(--toastify-toast-offset),env(safe-area-inset-left));--toastify-toast-bottom:max(var(--toastify-toast-offset),env(safe-area-inset-bottom));--toastify-toast-background:#fff;--toastify-toast-padding:14px;--toastify-toast-min-height:64px;--toastify-toast-max-height:800px;--toastify-toast-bd-radius:6px;--toastify-toast-shadow:0px 4px 12px #0000001a;--toastify-font-family:sans-serif;--toastify-z-index:9999;--toastify-text-color-light:#757575;--toastify-text-color-dark:#fff;--toastify-text-color-info:#fff;--toastify-text-color-success:#fff;--toastify-text-color-warning:#fff;--toastify-text-color-error:#fff;--toastify-spinner-color:#616161;--toastify-spinner-color-empty-area:#e0e0e0;--toastify-color-progress-light:linear-gradient(90deg,#4cd964,#5ac8fa,#007aff,#34aadc,#5856d6,#ff2d55);--toastify-color-progress-dark:#bb86fc;--toastify-color-progress-info:var(--toastify-color-info);--toastify-color-progress-success:var(--toastify-color-success);--toastify-color-progress-warning:var(--toastify-color-warning);--toastify-color-progress-error:var(--toastify-color-error);--toastify-color-progress-bgo:0.2}.Toastify__toast-container{box-sizing:border-box;color:#fff;display:flex;flex-direction:column;position:fixed;-webkit-transform:translateZ(9999);-webkit-transform:translateZ(var(--toastify-z-index));width:-webkit-fit-content;width:fit-content;width:var(--toastify-container-width);z-index:9999;z-index:var(--toastify-z-index)}.Toastify__toast-container--top-left{left:max(16px,env(safe-area-inset-left));left:var(--toastify-toast-left);top:max(16px,env(safe-area-inset-top));top:var(--toastify-toast-top)}.Toastify__toast-container--top-center{align-items:center;left:50%;top:max(16px,env(safe-area-inset-top));top:var(--toastify-toast-top);transform:translateX(-50%)}.Toastify__toast-container--top-right{align-items:end;right:max(16px,env(safe-area-inset-right));right:var(--toastify-toast-right);top:max(16px,env(safe-area-inset-top));top:var(--toastify-toast-top)}.Toastify__toast-container--bottom-left{bottom:max(16px,env(safe-area-inset-bottom));bottom:var(--toastify-toast-bottom);left:max(16px,env(safe-area-inset-left));left:var(--toastify-toast-left)}.Toastify__toast-container--bottom-center{align-items:center;bottom:max(16px,env(safe-area-inset-bottom));bottom:var(--toastify-toast-bottom);left:50%;transform:translateX(-50%)}.Toastify__toast-container--bottom-right{align-items:end;bottom:max(16px,env(safe-area-inset-bottom));bottom:var(--toastify-toast-bottom);right:max(16px,env(safe-area-inset-right));right:var(--toastify-toast-right)}.Toastify__toast{--y:0;align-items:center;border-radius:6px;border-radius:var(--toastify-toast-bd-radius);box-shadow:0 4px 12px #0000001a;box-shadow:var(--toastify-toast-shadow);box-sizing:border-box;display:flex;flex:1 1 auto;font-family:sans-serif;font-family:var(--toastify-font-family);margin-bottom:1rem;max-height:800px;max-height:var(--toastify-toast-max-height);min-height:64px;min-height:var(--toastify-toast-min-height);padding:14px;padding:var(--toastify-toast-padding);position:relative;touch-action:none;width:320px;width:var(--toastify-toast-width);word-break:break-word;z-index:0}@media only screen and (max-width:480px){.Toastify__toast-container{left:env(safe-area-inset-left);margin:0;width:100vw}.Toastify__toast-container--top-center,.Toastify__toast-container--top-left,.Toastify__toast-container--top-right{top:env(safe-area-inset-top);transform:translateX(0)}.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-right{bottom:env(safe-area-inset-bottom);transform:translateX(0)}.Toastify__toast-container--rtl{left:auto;right:env(safe-area-inset-right)}.Toastify__toast{--toastify-toast-width:100%;border-radius:0;margin-bottom:0}}.Toastify__toast-container[data-stacked=true]{width:320px;width:var(--toastify-toast-width)}.Toastify__toast--stacked{position:absolute;transform:translate3d(0,var(--y),0) scale(var(--s));transition:transform .3s;width:100%}.Toastify__toast--stacked[data-collapsed] .Toastify__close-button,.Toastify__toast--stacked[data-collapsed] .Toastify__toast-body{transition:opacity .1s}.Toastify__toast--stacked[data-collapsed=false]{overflow:visible}.Toastify__toast--stacked[data-collapsed=true]:not(:last-child)>*{opacity:0}.Toastify__toast--stacked:after{bottom:100%;content:"";height:calc(var(--g)*1px);left:0;position:absolute;right:0}.Toastify__toast--stacked[data-pos=top]{top:0}.Toastify__toast--stacked[data-pos=bot]{bottom:0}.Toastify__toast--stacked[data-pos=bot].Toastify__toast--stacked:before{transform-origin:top}.Toastify__toast--stacked[data-pos=top].Toastify__toast--stacked:before{transform-origin:bottom}.Toastify__toast--stacked:before{bottom:0;content:"";height:100%;left:0;position:absolute;right:0;transform:scaleY(3);z-index:-1}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-icon{-webkit-margin-end:10px;display:flex;flex-shrink:0;margin-inline-end:10px;width:22px}.Toastify--animate{animation-duration:.5s;animation-fill-mode:both}.Toastify--animate-icon{animation-duration:.3s;animation-fill-mode:both}.Toastify__toast-theme--dark{background:#121212;background:var(--toastify-color-dark);color:#fff;color:var(--toastify-text-color-dark)}.Toastify__toast-theme--colored.Toastify__toast--default,.Toastify__toast-theme--light{background:#fff;background:var(--toastify-color-light);color:#757575;color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{background:#3498db;background:var(--toastify-color-info);color:#fff;color:var(--toastify-text-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{background:#07bc0c;background:var(--toastify-color-success);color:#fff;color:var(--toastify-text-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{background:#f1c40f;background:var(--toastify-color-warning);color:#fff;color:var(--toastify-text-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{background:#e74d3c;background:var(--toastify-color-error);color:#fff;color:var(--toastify-text-color-error)}.Toastify__progress-bar-theme--light{background:linear-gradient(90deg,#4cd964,#5ac8fa,#007aff,#34aadc,#5856d6,#ff2d55);background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:#bb86fc;background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:#3498db;background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:#07bc0c;background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:#f1c40f;background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:#e74d3c;background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning{background:#ffffffb3;background:var(--toastify-color-transparent)}.Toastify__close-button{background:#0000;border:none;color:#fff;cursor:pointer;opacity:.7;outline:none;padding:0;position:absolute;right:6px;top:6px;transition:.3s ease;z-index:1}.Toastify__toast--rtl .Toastify__close-button{left:6px;right:auto}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;height:16px;width:14px}.Toastify__close-button:focus,.Toastify__close-button:hover{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{bottom:0;height:100%;left:0;opacity:.7;position:absolute;transform-origin:left;width:100%;z-index:1}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{border-bottom-left-radius:0;left:auto;right:0;transform-origin:right}.Toastify__progress-bar--wrp{border-bottom-left-radius:6px;border-bottom-left-radius:var(--toastify-toast-bd-radius);border-bottom-right-radius:6px;border-bottom-right-radius:var(--toastify-toast-bd-radius);bottom:0;height:5px;left:0;overflow:hidden;position:absolute;width:100%}.Toastify__progress-bar--wrp[data-hidden=true]{opacity:0}.Toastify__progress-bar--bg{height:100%;opacity:.2;opacity:var(--toastify-color-progress-bgo);width:100%}.Toastify__spinner{animation:Toastify__spin .65s linear infinite;border:2px solid #e0e0e0;border-color:var(--toastify-spinner-color-empty-area);border-radius:100%;border-right-color:#616161;border-right-color:var(--toastify-spinner-color);box-sizing:border-box;height:20px;width:20px}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,var(--y),0)}to{opacity:0;transform:translate3d(2000px,var(--y),0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,var(--y),0)}to{opacity:0;transform:translate3d(-2000px,var(--y),0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--bottom-left,.Toastify__bounce-enter--top-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--bottom-right,.Toastify__bounce-enter--top-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--bottom-left,.Toastify__bounce-exit--top-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--bottom-right,.Toastify__bounce-exit--top-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:translate3d(0,var(--y),0) scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{animation-timing-function:ease-in;opacity:0;transform:perspective(400px) rotateX(90deg)}40%{animation-timing-function:ease-in;transform:perspective(400px) rotateX(-20deg)}60%{opacity:1;transform:perspective(400px) rotateX(10deg)}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:translate3d(0,var(--y),0) perspective(400px)}30%{opacity:1;transform:translate3d(0,var(--y),0) perspective(400px) rotateX(-20deg)}to{opacity:0;transform:translate3d(0,var(--y),0) perspective(400px) rotateX(90deg)}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideOutRight{0%{transform:translate3d(0,var(--y),0)}to{transform:translate3d(110%,var(--y),0);visibility:hidden}}@keyframes Toastify__slideOutLeft{0%{transform:translate3d(0,var(--y),0)}to{transform:translate3d(-110%,var(--y),0);visibility:hidden}}@keyframes Toastify__slideOutDown{0%{transform:translate3d(0,var(--y),0)}to{transform:translate3d(0,500px,0);visibility:hidden}}@keyframes Toastify__slideOutUp{0%{transform:translate3d(0,var(--y),0)}to{transform:translate3d(0,-500px,0);visibility:hidden}}.Toastify__slide-enter--bottom-left,.Toastify__slide-enter--top-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--bottom-right,.Toastify__slide-enter--top-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--bottom-left,.Toastify__slide-exit--top-left{animation-duration:.3s;animation-name:Toastify__slideOutLeft;animation-timing-function:ease-in}.Toastify__slide-exit--bottom-right,.Toastify__slide-exit--top-right{animation-duration:.3s;animation-name:Toastify__slideOutRight;animation-timing-function:ease-in}.Toastify__slide-exit--top-center{animation-duration:.3s;animation-name:Toastify__slideOutUp;animation-timing-function:ease-in}.Toastify__slide-exit--bottom-center{animation-duration:.3s;animation-name:Toastify__slideOutDown;animation-timing-function:ease-in}@keyframes Toastify__spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.2c0b767f.css.map*/