:root{--bg:#09090b;--bg-card:#0f0f12;--bg-card-hover:#141418;--bg-elevated:#18181b;--border:#27272a99;--border-hover:#3f3f4699;--cyan:#06b6d4;--cyan-dim:#06b6d426;--cyan-glow:#06b6d466;--violet:#8b5cf6;--violet-dim:#8b5cf626;--emerald:#34d399;--emerald-dim:#34d39926;--amber:#f59e0b;--amber-dim:#f59e0b26;--rose:#f43f5e;--rose-dim:#f43f5e26;--text:#a1a1aa;--text-bright:#fafafa;--text-muted:#52525b;--font-display:"Bricolage Grotesque", sans-serif;--font-body:"Outfit", sans-serif;--font-mono:"JetBrains Mono", monospace;--ease-out-expo:cubic-bezier(.16, 1, .3, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);color:var(--text);background:var(--bg);font-size:16px;line-height:1.6;position:relative;overflow-x:hidden}a{color:inherit;text-decoration:none}.lang-toggle{z-index:100;border:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);cursor:pointer;background:#0f0f12cc;border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;transition:all .3s;display:flex;position:fixed;top:20px;right:20px}.lang-toggle:hover{border-color:var(--cyan);background:var(--cyan-dim);box-shadow:0 0 20px #06b6d426}.lang-flag{font-family:var(--font-mono);color:var(--text-bright);letter-spacing:.5px;font-size:13px;font-weight:600}.scanlines{pointer-events:none;z-index:9999;background:repeating-linear-gradient(0deg,#0000,#0000 2px,#00000008 2px 4px);position:fixed;inset:0}.grid-bg{pointer-events:none;z-index:0;background-image:linear-gradient(#06b6d408 1px,#0000 1px),linear-gradient(90deg,#06b6d408 1px,#0000 1px);background-size:60px 60px;position:fixed;inset:0;-webkit-mask-image:radial-gradient(80% 60% at 50% 30%,#000 20%,#0000 70%);mask-image:radial-gradient(80% 60% at 50% 30%,#000 20%,#0000 70%)}.section-header{text-align:center;margin-bottom:56px}.section-label{justify-content:center;align-items:center;gap:16px;margin-bottom:16px;display:flex}.label-line{background:linear-gradient(90deg, transparent, var(--cyan), transparent);width:40px;height:1px}.label-text{font-family:var(--font-mono);letter-spacing:3px;text-transform:uppercase;color:var(--cyan);font-size:12px;font-weight:500}.section-title{font-family:var(--font-display);color:var(--text-bright);letter-spacing:-.5px;font-size:clamp(28px,5vw,42px);font-weight:700;line-height:1.15}.section-subtitle{color:var(--text-muted);margin-top:8px;font-size:15px}.accent-text{background:linear-gradient(135deg, var(--cyan), var(--violet));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.reveal{opacity:0;transition:opacity .8s var(--ease-out-expo), transform .8s var(--ease-out-expo);transform:translateY(32px)}.reveal.visible{opacity:1;transform:translateY(0)}#hero{z-index:1;flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:40px 24px;display:flex;position:relative;overflow:hidden}#hero:before{content:"";pointer-events:none;background:radial-gradient(circle,#06b6d40f 0%,#0000 60%);width:800px;height:800px;position:absolute;top:-200px;left:50%;transform:translate(-50%)}.hero-content{animation:heroFadeIn 1s var(--ease-out-expo) both;flex-direction:column;align-items:center;gap:32px;display:flex}@keyframes heroFadeIn{0%{opacity:0;transform:translateY(24px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.terminal-window{border:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0f0f12cc;border-radius:12px;width:100%;max-width:520px;animation:4s ease-in-out infinite alternate terminalGlow;overflow:hidden;box-shadow:0 0 0 1px #06b6d40d,0 4px 24px #0006,0 0 60px #06b6d40a}@keyframes terminalGlow{0%{box-shadow:0 0 0 1px #06b6d40d,0 4px 24px #0006,0 0 60px #06b6d40a}to{box-shadow:0 0 0 1px #06b6d41a,0 4px 24px #0006,0 0 80px #06b6d414}}.terminal-bar{border-bottom:1px solid var(--border);background:#18181b99;align-items:center;gap:8px;padding:12px 16px;display:flex}.terminal-dot{border-radius:50%;width:10px;height:10px}.terminal-dot.red{background:#ff5f57}.terminal-dot.yellow{background:#febc2e}.terminal-dot.green{background:#28c840}.terminal-title{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.5px;margin-left:auto;font-size:11px}.terminal-body{padding:20px 20px 24px}.terminal-line{font-family:var(--font-mono);color:var(--text-bright);align-items:center;gap:10px;min-height:24px;font-size:15px;display:flex}.prompt{color:var(--cyan);flex-shrink:0;font-weight:600}.typed{white-space:nowrap;overflow:hidden}.cursor{color:var(--cyan);font-weight:600;animation:1s step-end infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-name{font-family:var(--font-display);color:var(--text-bright);letter-spacing:-2px;text-align:center;font-size:clamp(48px,10vw,80px);font-weight:800;line-height:1}.hero-title{font-family:var(--font-mono);color:var(--text);letter-spacing:2px;text-transform:uppercase;text-align:center;font-size:clamp(14px,2.5vw,18px);font-weight:400}.hero-tags{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.hero-tag{font-family:var(--font-mono);border:1px solid var(--border);color:var(--text);background:#18181b80;border-radius:20px;padding:5px 12px;font-size:11px;font-weight:500;transition:all .3s}.hero-tag:hover{border-color:var(--cyan);color:var(--cyan);background:var(--cyan-dim)}.scroll-indicator{color:var(--text-muted);transition:color .3s;animation:2s ease-in-out infinite scrollBounce;position:absolute;bottom:32px}.scroll-indicator:hover{color:var(--cyan)}@keyframes scrollBounce{0%,to{transform:translateY(0)}50%{transform:translateY(8px)}}#projects{z-index:1;max-width:1280px;margin:0 auto;padding:100px 24px;position:relative}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(min(340px,100%),1fr));gap:24px;display:grid}.project-card{border:1px solid var(--border);background:var(--bg-card);cursor:pointer;transition:all .4s var(--ease-out-expo);opacity:0;border-radius:16px;position:relative;overflow:hidden;transform:translateY(40px)}.project-card.visible{opacity:1;transform:translateY(0)}.project-card:hover{border-color:var(--border-hover);background:var(--bg-card-hover);transform:translateY(-4px);box-shadow:0 0 0 1px #06b6d414,0 8px 40px #0006,0 0 60px #06b6d40f}.project-card.visible:hover{transform:translateY(-4px)}.site-preview{background:#0a0a0c;width:100%;position:relative;overflow:hidden}.site-preview img{object-fit:cover;object-position:top;opacity:.8;width:100%;height:100%;transition:all .5s}.project-card:hover .site-preview img{opacity:1;transform:scale(1.02)}.site-preview iframe{transform-origin:0 0;border:none}.preview-fade{background:linear-gradient(to top, var(--bg-card) 0%, transparent 100%);pointer-events:none;z-index:2;height:40px;position:absolute;bottom:0;left:0;right:0}.preview-toggle{z-index:3;width:28px;height:28px;color:var(--text-muted);cursor:pointer;opacity:0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#09090bb3;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .3s;display:flex;position:absolute;bottom:8px;right:8px}.project-card:hover .preview-toggle{opacity:1}.preview-toggle:hover{color:var(--text-bright);background:#09090be6}@media (hover:none){.preview-toggle{opacity:.7}}.card-body{padding:20px}.card-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px;display:flex}.card-name{font-family:var(--font-display);color:var(--text-bright);letter-spacing:-.2px;font-size:17px;font-weight:600}.card-domain{font-family:var(--font-mono);color:var(--text-muted);align-items:center;gap:4px;margin-top:2px;font-size:11px;transition:color .3s;display:inline-flex}.card-domain:hover{color:var(--cyan)}.card-domain svg{flex-shrink:0;width:10px;height:10px}.card-external{border:1px solid var(--border);width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:all .3s;display:flex}.card-external:hover{border-color:var(--cyan);color:var(--cyan);background:var(--cyan-dim)}.card-description{color:var(--text-muted);margin-bottom:14px;font-size:13px;line-height:1.5}.tech-pills{flex-wrap:wrap;gap:6px;display:flex}.tech-pill{font-family:var(--font-mono);letter-spacing:.3px;border:1px solid;border-radius:20px;padding:3px 10px;font-size:10px;font-weight:500}.tech-pill.framework{color:var(--cyan);background:var(--cyan-dim);border-color:#06b6d440}.tech-pill.language{color:var(--violet);background:var(--violet-dim);border-color:#8b5cf640}.tech-pill.technology{color:var(--emerald);background:var(--emerald-dim);border-color:#34d39940}.tech-pill.database{color:var(--amber);background:var(--amber-dim);border-color:#f59e0b40}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:0;pointer-events:none;background:#000c;justify-content:center;align-items:center;padding:24px;transition:opacity .35s;display:flex;position:fixed;inset:0}.modal-overlay.active{opacity:1;pointer-events:auto}.modal-content{border:1px solid var(--border);background:var(--bg-card);width:100%;max-width:900px;max-height:90vh;transition:transform .4s var(--ease-spring);-webkit-overflow-scrolling:touch;border-radius:20px;flex-direction:column;display:flex;position:relative;overflow:hidden auto;transform:translateY(20px)scale(.96);box-shadow:0 0 0 1px #06b6d40f,0 24px 80px #0009}.modal-overlay.active .modal-content{transform:translateY(0)scale(1)}.modal-close{z-index:20;width:36px;height:36px;color:var(--text);cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009;border:1px solid #ffffff1a;border-radius:10px;justify-content:center;align-items:center;font-size:20px;line-height:1;transition:all .2s;display:flex;position:absolute;top:12px;right:12px}.modal-close:hover{color:var(--text-bright);background:#000c}.modal-preview{background:#0a0a0c;width:100%;height:55vh;min-height:300px;position:relative;overflow:hidden}.modal-preview iframe{transform-origin:0 0;border:none}.modal-preview img{object-fit:cover;object-position:top;width:100%;height:100%}.interact-overlay{z-index:10;cursor:pointer;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.interact-badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:0;background:#09090bcc;border:1px solid #3f3f4680;border-radius:10px;align-items:center;gap:8px;padding:8px 16px;transition:opacity .3s;display:flex}.interact-overlay:hover .interact-badge{opacity:1}@media (hover:none){.interact-badge{opacity:1}}.interact-badge svg{width:14px;height:14px;color:var(--text-muted)}.interact-badge span{font-family:var(--font-mono);color:var(--text-muted);font-size:11px;font-weight:500}.stop-interact{z-index:20;color:var(--text-muted);font-family:var(--font-mono);cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009;border:1px solid #ffffff1a;border-radius:10px;padding:6px 14px;font-size:11px;font-weight:500;transition:all .2s;position:absolute;top:12px;right:56px}.stop-interact:hover{color:var(--text-bright);background:#000c}.modal-info{border-top:1px solid var(--border);padding:24px 28px 28px}.modal-project-name{font-family:var(--font-display);color:var(--text-bright);margin-bottom:6px;font-size:22px;font-weight:700}.modal-description{color:var(--text);margin-bottom:16px;font-size:14px;line-height:1.6}.modal-tech-pills{flex-wrap:wrap;gap:6px;margin-bottom:20px;display:flex}.modal-actions{gap:12px;display:flex}.modal-btn{border:1px solid var(--border);color:var(--text);font-family:var(--font-mono);cursor:pointer;background:0 0;border-radius:10px;align-items:center;gap:8px;padding:10px 20px;font-size:12px;font-weight:500;text-decoration:none;transition:all .3s;display:inline-flex}.modal-btn:hover{border-color:var(--cyan);color:var(--cyan);background:var(--cyan-dim)}.modal-btn svg{width:14px;height:14px}#contact{z-index:1;max-width:800px;margin:0 auto;padding:100px 24px;position:relative}.contact-cards{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;display:grid}.contact-card{border:1px solid var(--border);background:var(--bg-card);transition:all .4s var(--ease-out-expo);text-align:center;border-radius:16px;flex-direction:column;align-items:center;gap:8px;padding:32px 24px;display:flex}.contact-card:hover{border-color:var(--border-hover);background:var(--bg-card-hover);transform:translateY(-4px);box-shadow:0 8px 32px #0000004d,0 0 40px #06b6d40a}.contact-icon{background:var(--cyan-dim);width:48px;height:48px;color:var(--cyan);border:1px solid #06b6d433;border-radius:12px;justify-content:center;align-items:center;margin-bottom:4px;transition:all .3s;display:flex}.contact-card:hover .contact-icon{background:#06b6d433;border-color:#06b6d459;box-shadow:0 0 20px #06b6d426}.contact-label{font-family:var(--font-mono);letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);font-size:11px;font-weight:500}.contact-value{color:var(--text-bright);word-break:break-word;font-size:15px;font-weight:500}#footer{z-index:1;text-align:center;padding:40px 24px 48px;position:relative}.footer-line{background:linear-gradient(90deg, transparent, var(--border-hover), transparent);width:60px;height:1px;margin:0 auto 24px}.footer-text{color:var(--text-muted);font-size:13px}@media (width<=640px){.hero-name{letter-spacing:-1px}.hero-content{gap:24px}.terminal-window{max-width:100%}.terminal-bar{padding:10px 12px}.terminal-title{font-size:10px}.terminal-line{font-size:13px}.terminal-body{padding:16px 14px 20px}.hero-title{letter-spacing:1px}#hero{padding:40px 16px}#projects,#contact{padding:60px 16px}.section-header{margin-bottom:36px}.card-body{padding:16px}.card-name{font-size:15px}.card-description{font-size:12px}.modal-overlay{padding:12px}.modal-content{border-radius:14px;max-height:95dvh}.modal-preview{flex-shrink:0;height:35vh;min-height:200px}.modal-info{padding:16px}.modal-project-name{font-size:18px}.modal-description{font-size:13px}.modal-actions{flex-direction:column}.modal-close{width:32px;height:32px;top:8px;right:8px}.stop-interact{top:8px;right:48px}.contact-cards{grid-template-columns:1fr}.contact-card{padding:24px 16px}.contact-value{font-size:14px}.lang-toggle{width:40px;height:40px;top:14px;right:14px}.scroll-indicator{bottom:20px}}@media (width<=360px){.hero-name{font-size:40px}.terminal-line{gap:6px;font-size:12px}.hero-tags{gap:6px}.hero-tag{padding:4px 10px;font-size:10px}.section-title{font-size:24px}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}.reveal,.project-card{opacity:1;transform:none}}
