*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0b0d10;--bg2: #12151b;--bg3: #181c24;--card: #161a22;--border: rgba(255, 255, 255, .08);--border2: rgba(255, 255, 255, .14);--keyword: #e8c468;--func: #8eb5e8;--string: #7dd3a0;--comment: #7a8494;--number: #e8a87c;--accent: #d4a853;--accent2: #c9973f;--accent-grad: linear-gradient(145deg, #e4bc6a, #c9973f);--text: #f4f4f5;--muted: #a1a8b5;--radius: 12px;--shadow: 0 8px 30px rgba(0, 0, 0, .35);--shadow-lg: 0 20px 50px rgba(0, 0, 0, .45);--transition: .35s cubic-bezier(.22, 1, .36, 1);--font-sans: "DM Sans", system-ui, sans-serif;--font-display: "Lora", Georgia, "Times New Roman", serif;--mono: ui-monospace, "SF Mono", Menlo, monospace}html{scroll-behavior:smooth;font-size:16px;overflow-x:clip;max-width:100%}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);overflow-x:clip;max-width:100%;line-height:1.7;overscroll-behavior-x:none}#root,.wrapper{overflow-x:clip;max-width:100%;min-width:0}img,video,svg{max-width:100%;height:auto}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg3)}::-webkit-scrollbar-thumb{background:#d4a85373;border-radius:3px}body:before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;background:radial-gradient(ellipse 80% 50% at 15% -10%,rgba(212,168,83,.07),transparent 55%),radial-gradient(ellipse 60% 40% at 90% 20%,rgba(120,150,200,.05),transparent 50%),var(--bg)}.wrapper{position:relative;z-index:1}nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:1.15rem 6%;background:#0b0d10cc;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);transition:var(--transition)}nav.scrolled{padding:.85rem 6%;background:#0b0d10f2;box-shadow:var(--shadow)}.nav-logo{font-family:var(--font-display);font-size:1.65rem;font-weight:400;font-style:italic;color:var(--text);text-decoration:none;cursor:pointer;letter-spacing:-.02em}.nav-logo-mark{color:var(--accent);font-style:normal}.nav-links{display:flex;gap:2rem;list-style:none}.nav-links a{text-decoration:none;color:var(--muted);font-size:.92rem;font-weight:500;transition:color var(--transition);position:relative}.nav-links a:after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:1px;background:var(--accent);transition:width var(--transition)}.nav-links a:hover,.nav-links a.active{color:var(--text)}.nav-links a:hover:after,.nav-links a.active:after{width:100%}.nav-cta{padding:.5rem 1.15rem;background:var(--accent);border:none;border-radius:999px;color:#1a1408;font-weight:700;font-size:.88rem;cursor:pointer;text-decoration:none;transition:transform var(--transition),background var(--transition)}.nav-cta:hover{transform:translateY(-1px);background:#e4bc6a}.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none}.hamburger span{width:22px;height:2px;background:var(--text);border-radius:2px;transition:var(--transition);display:block}.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}section{padding:6rem 6%}.section-eyebrow,.section-label{display:block;font-size:.72rem;font-weight:700;color:var(--accent);margin-bottom:.65rem;letter-spacing:.14em;text-transform:uppercase}.section-label:before{content:none}.section-title{font-family:var(--font-display);font-size:clamp(2rem,4.5vw,3rem);font-weight:400;line-height:1.08;margin-bottom:.85rem;letter-spacing:-.02em;color:var(--text)}.section-sub{color:var(--muted);font-size:1rem;max-width:520px;line-height:1.75}#hero{min-height:100vh;display:flex;align-items:center;padding-top:100px;padding-bottom:4rem;position:relative;overflow:hidden}.hero-glow{position:absolute;top:8%;right:5%;width:min(480px,55vw);height:min(480px,55vw);background:radial-gradient(circle,rgba(212,168,83,.09) 0%,transparent 68%);pointer-events:none;z-index:0}.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:3rem 2.5rem;align-items:center;width:100%;max-width:1140px;margin:0 auto}.hero-content{padding-left:1.25rem;border-left:2px solid rgba(212,168,83,.45)}.hero-eyebrow{display:inline-flex;flex-wrap:wrap;align-items:center;gap:.45rem .55rem;font-size:.82rem;font-weight:500;color:var(--muted);margin-bottom:1.15rem}.hero-status-dot{width:7px;height:7px;border-radius:50%;background:#4ade80;box-shadow:0 0 0 3px #4ade8033;animation:hero-pulse 2.8s ease-in-out infinite}@keyframes hero-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.75;transform:scale(.92)}}.hero-eyebrow-sep{color:var(--border2);-webkit-user-select:none;user-select:none}.hero-name{display:flex;flex-direction:column;gap:.1rem;margin-bottom:.85rem}.hero-name-line{display:block;font-family:var(--font-display);font-size:clamp(2.35rem,5.8vw,3.75rem);font-weight:600;line-height:1.08;letter-spacing:-.025em;color:var(--text)}.hero-name-accent{display:block;font-family:var(--font-display);font-size:clamp(2.5rem,6.2vw,4rem);font-weight:500;font-style:italic;line-height:1;letter-spacing:-.02em;color:var(--accent)}.hero-role{font-size:1.08rem;font-weight:600;color:#e4e4e7;margin-bottom:.9rem;letter-spacing:-.01em}.hero-desc{color:var(--muted);font-size:1.02rem;margin:0 0 1.35rem;max-width:33rem;line-height:1.75}.hero-tags{list-style:none;display:flex;flex-wrap:wrap;gap:.45rem;margin:0 0 1.75rem;padding:0}.hero-tags li{font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);padding:.35rem .7rem;border-radius:6px;border:1px solid var(--border);background:#ffffff08;transition:border-color .25s ease,color .25s ease}.hero-tags li:hover{border-color:#d4a85359;color:var(--accent)}.hero-actions{display:flex;gap:.85rem;flex-wrap:wrap;align-items:center}.btn-arrow{display:inline-block;margin-left:.15rem;transition:transform .25s ease}.btn-primary:hover .btn-arrow{transform:translate(3px)}.btn-primary{display:inline-flex;align-items:center;justify-content:center;padding:.85rem 1.65rem;background:var(--accent);border-radius:999px;color:#1a1408;font-weight:700;font-size:.92rem;transition:transform var(--transition),background var(--transition);cursor:pointer;border:none}.btn-primary:hover{transform:translateY(-2px);background:#e4bc6a}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;padding:.85rem 1.65rem;border:1px solid var(--border2);border-radius:999px;color:var(--text);font-weight:600;font-size:.92rem;background:transparent;transition:all var(--transition);cursor:pointer}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.hero-portrait{display:flex;flex-direction:column;align-items:flex-end;gap:1rem}.hero-portrait-stack{position:relative;width:min(300px,100%)}.hero-portrait-shadow{position:absolute;inset:18% 5% -8%;border-radius:50%;background:radial-gradient(ellipse 80% 70% at 50% 45%,rgba(212,168,83,.22) 0%,transparent 72%);filter:blur(36px);opacity:.85;z-index:0;pointer-events:none}.hero-portrait-frame{position:relative;z-index:1;width:100%;aspect-ratio:4 / 5;border-radius:22px;overflow:hidden;border:1px solid rgba(255,255,255,.1);box-shadow:0 4px 6px #00000026,0 18px 42px #00000061,0 40px 80px #00000038,inset 0 1px #ffffff0f;background:var(--bg3);animation:hero-float 7s ease-in-out infinite}@keyframes hero-float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.hero-portrait-frame img{width:100%;height:100%;object-fit:cover;display:block}.hero-portrait-note{display:flex;align-items:baseline;gap:.65rem;font-size:.8rem;color:var(--muted);padding-right:.25rem}.hero-portrait-label{font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}@media(prefers-reduced-motion:reduce){.hero-status-dot,.hero-portrait-frame{animation:none}}#about{background:var(--bg2)}.about-inner{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}.about-img-wrap{position:relative}.about-img-frame{width:100%;aspect-ratio:1;border-radius:var(--radius);background:var(--accent-grad);padding:3px;overflow:hidden;box-shadow:var(--shadow-lg)}.about-img-frame img{width:100%;height:100%;object-fit:cover;border-radius:12px}.about-badge{position:absolute;bottom:-18px;right:-18px;background:var(--bg2);border:1px solid var(--border);box-shadow:var(--shadow-lg);border-radius:var(--radius);padding:1rem 1.5rem;text-align:center}.about-badge h4{font-size:1.6rem;font-weight:800;font-family:var(--mono);background:var(--accent-grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.about-badge p{font-size:.72rem;color:var(--comment);font-family:var(--mono)}.about-content{display:flex;flex-direction:column;gap:1.4rem}.about-text{color:var(--muted);line-height:1.9}.about-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin-top:.5rem}.info-item{display:flex;flex-direction:column;gap:.2rem}.info-label{font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--comment);font-family:var(--mono)}.info-value{font-weight:600;font-size:.9rem;color:var(--text)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,260px),1fr));gap:1.3rem;margin-top:3rem;width:100%;min-width:0}.skill-card{background:linear-gradient(160deg,#1b2538f2,#141d2df2);border:1px solid var(--border);border-radius:var(--radius);padding:1.6rem;transition:transform var(--transition),border-color var(--transition),box-shadow var(--transition);box-shadow:var(--shadow);position:relative;overflow:hidden;transform-style:preserve-3d}.skill-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent-grad);border-radius:3px 0 0 3px}.skill-card:hover{transform:translateY(-5px);border-color:var(--accent);box-shadow:var(--shadow-lg)}.skill-card-icon{display:flex;align-items:center;justify-content:flex-start;margin-bottom:.8rem}.skill-card-icon .skill-icon-svg{width:44px;height:44px;flex-shrink:0;display:block}.skill-card-title{font-size:.9rem;font-weight:700;margin-bottom:.9rem;color:var(--text);font-family:var(--mono)}.skill-tags{display:flex;flex-wrap:wrap;gap:.4rem}.skill-tag{padding:.25rem .7rem;font-size:.75rem;font-weight:500;border-radius:6px;border:1px solid var(--border);background:var(--bg3);color:var(--muted);transition:all var(--transition);font-family:var(--mono)}.skill-card:hover .skill-tag{border-color:#6366f166;color:var(--keyword);background:#3b82f61a}#experience{background:var(--bg)}.timeline{position:relative;margin-top:3rem;padding-left:2rem}.timeline:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--accent),var(--func));border-radius:2px}.timeline-item{position:relative;margin-bottom:2.5rem}.timeline-item:before{content:"";position:absolute;left:-2.45rem;top:.4rem;width:12px;height:12px;border-radius:50%;background:var(--accent-grad);box-shadow:0 0 0 4px #6366f133}.timeline-card{background:linear-gradient(160deg,#1b2538f0,#141d2df0);border:1px solid var(--border);border-radius:var(--radius);padding:1.6rem;transition:transform var(--transition),border-color var(--transition),box-shadow var(--transition);box-shadow:var(--shadow);transform-style:preserve-3d}.timeline-card:hover{transform:translate(5px);border-color:var(--accent);box-shadow:var(--shadow-lg)}.timeline-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:.5rem;margin-bottom:.3rem}.timeline-role{font-size:1.05rem;font-weight:700;color:var(--text)}.timeline-period{font-size:.75rem;color:var(--keyword);font-weight:600;font-family:var(--mono);background:#6366f11f;border:1px solid rgba(99,102,241,.3);padding:.2rem .75rem;border-radius:50px}.timeline-company{font-size:.88rem;color:var(--func);font-weight:600;margin-bottom:.25rem;font-family:var(--mono)}.timeline-location{font-size:.78rem;color:var(--comment);margin-bottom:1rem}.timeline-bullets{list-style:none;display:flex;flex-direction:column;gap:.55rem}.timeline-bullets li{display:flex;gap:.7rem;font-size:.88rem;color:var(--muted)}.timeline-bullets li:before{content:"▸";color:var(--string);flex-shrink:0;margin-top:.1rem}#projects{background:var(--bg2);border-top:1px solid var(--border)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,280px),1fr));gap:1.3rem;margin-top:3rem;width:100%;min-width:0}.project-card{background:linear-gradient(160deg,#1b2538f2,#141d2df2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;min-width:0;width:100%;max-width:100%;transition:transform var(--transition),border-color var(--transition),box-shadow var(--transition);display:flex;flex-direction:column;box-shadow:var(--shadow);transform-style:preserve-3d}.project-card:hover{transform:translateY(-7px);border-color:var(--accent);box-shadow:var(--shadow-lg)}.project-card-clickable{cursor:pointer}.project-card-clickable:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.project-card.featured{grid-column:1/-1;display:grid;grid-template-columns:1fr 1fr}.project-banner{height:190px;display:flex;flex-direction:column;align-items:flex-start;justify-content:space-between;position:relative;overflow:hidden;padding:1rem}.project-banner-live{background-size:cover;background-position:center}.project-banner-live:before{display:none}.project-banner-image{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .55s ease}.project-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#02061733,#020617b3);opacity:0;transition:opacity var(--transition);z-index:2}.project-overlay span{font-family:var(--mono);font-size:.78rem;letter-spacing:1px;text-transform:uppercase;color:#f8fafc;border:1px solid rgba(248,250,252,.4);border-radius:999px;padding:.38rem .85rem;background:#0f172a80}.project-card:hover .project-overlay{opacity:1}.project-card:hover .project-banner-image{transform:scale(1.08)}.project-card.featured .project-banner{height:auto;min-height:235px;border-right:1px solid rgba(129,140,248,.25)}.project-banner:before{content:"●  ●  ●";display:block;font-size:.55rem;letter-spacing:4px;color:#e5e7eb73;z-index:1;position:relative}.banner-hostel{background:#0b1220}.banner-hostel:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 60%,rgba(14,165,233,.25),transparent 60%),radial-gradient(circle at 70% 40%,rgba(124,58,237,.2),transparent 60%)}.banner-erp{background:#1a1a35}.banner-erp:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 40%,rgba(124,58,237,.25),transparent 60%)}.banner-infranex{background:#1a243d}.banner-infranex:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 28% 62%,rgba(56,189,248,.3),transparent 58%),radial-gradient(circle at 78% 28%,rgba(99,102,241,.24),transparent 60%)}.banner-alkhaira{background:#211b35}.banner-alkhaira:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 28% 35%,rgba(168,85,247,.25),transparent 60%),radial-gradient(circle at 75% 68%,rgba(251,191,36,.2),transparent 62%)}.banner-frontend-app{background:#13283a}.banner-frontend-app:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 22%,rgba(14,165,233,.3),transparent 60%),radial-gradient(circle at 66% 74%,rgba(16,185,129,.2),transparent 60%)}.banner-brazili{background:#2a1d2f}.banner-brazili:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 40%,rgba(244,114,182,.26),transparent 60%),radial-gradient(circle at 72% 60%,rgba(249,115,22,.22),transparent 62%)}.banner-umz{background:#162432}.banner-umz:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 25% 38%,rgba(59,130,246,.3),transparent 60%),radial-gradient(circle at 70% 62%,rgba(147,197,253,.22),transparent 64%)}.banner-trading{background:#0a1628}.banner-trading:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 45%,rgba(34,197,94,.22),transparent 58%),radial-gradient(circle at 82% 30%,rgba(245,158,11,.2),transparent 55%),radial-gradient(circle at 55% 75%,rgba(59,130,246,.18),transparent 60%)}.banner-icon{font-size:3.5rem;z-index:3;position:relative;text-shadow:0 12px 24px rgba(2,6,23,.35)}.project-body{padding:1.3rem;flex:1;display:flex;flex-direction:column;justify-content:space-between;gap:.8rem}.project-meta{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;justify-content:space-between}.project-badge{font-size:.68rem;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;padding:.22rem .75rem;border-radius:6px;font-family:var(--mono)}.badge-featured{background:#d4a8531f;color:var(--accent);border:1px solid rgba(212,168,83,.35)}.badge-normal{background:#ffffff0d;color:var(--muted);border:1px solid var(--border)}.project-links{display:flex;gap:.5rem}.proj-link{width:30px;height:30px;border-radius:7px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;text-decoration:none;color:var(--muted);font-size:.85rem;transition:all var(--transition);background:var(--bg3)}.proj-link:hover{border-color:var(--accent);color:var(--keyword);background:#6366f11f}.project-title{font-size:1.2rem;font-weight:800;margin:.8rem 0 .5rem;color:var(--text)}.project-desc{color:var(--muted);font-size:.85rem;line-height:1.65}.project-highlights{display:flex;flex-direction:column;gap:.38rem;margin-top:.35rem}.highlight-item{display:flex;gap:.55rem;font-size:.82rem;color:var(--muted);background:var(--bg3);border:1px solid var(--border);border-radius:7px;padding:.45rem .75rem;font-family:var(--mono)}.highlight-item:before{content:"✦";color:var(--string);font-size:.6rem;margin-top:.2rem;flex-shrink:0}.project-tech{display:flex;flex-wrap:wrap;gap:.38rem;margin-top:auto;padding-top:1rem;border-top:1px solid var(--border)}.project-visit{margin-top:.95rem;font-size:.76rem;font-weight:700;color:var(--keyword);text-transform:uppercase;letter-spacing:1px;font-family:var(--mono)}.project-live-btn{margin-top:1rem;width:fit-content;display:inline-flex;align-items:center;gap:.45rem;border:1px solid rgba(212,168,83,.4);background:#d4a8531a;color:var(--accent);border-radius:9px;padding:.5rem .88rem;font-size:.76rem;font-family:var(--mono);font-weight:700;letter-spacing:.4px;cursor:pointer;transition:all var(--transition)}.project-live-btn:hover{background:#3b82f62e;border-color:#3b82f68c;transform:translateY(-2px)}.project-card-compact .project-banner-compact{height:155px;padding:0}.project-body-compact{padding:1rem 1.1rem 1.1rem;gap:.55rem}.project-title-compact{margin:.35rem 0 0;font-size:1.05rem}.project-desc-compact{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-size:.8rem;line-height:1.55;margin:0}.project-card-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.65rem}.project-detail-btn{flex:1 1 140px;min-width:0;border:1px solid var(--border2);background:#0f172a8c;color:var(--text);border-radius:9px;padding:.52rem .75rem;font-size:.74rem;font-family:var(--mono);font-weight:700;letter-spacing:.3px;cursor:pointer;transition:all var(--transition)}.project-detail-btn:hover{border-color:var(--accent);background:#6366f124;color:var(--keyword);transform:translateY(-1px)}.project-live-btn-compact{flex:1 1 120px;margin-top:0;width:auto;justify-content:center}.project-overlay-btn{border:none;cursor:pointer;font:inherit;width:100%}.project-overlay-btn:focus-visible{opacity:1;outline:2px solid var(--accent);outline-offset:-2px}.project-modal-root{position:fixed;inset:0;z-index:1200;display:flex;align-items:center;justify-content:center;padding:1rem;width:100%;max-width:100vw;overflow-x:hidden;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.project-modal-backdrop{position:absolute;inset:0;border:none;background:#020617b8;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);cursor:pointer}.project-modal{position:relative;z-index:1;width:min(640px,calc(100vw - 2rem));max-width:100%;max-height:min(90vh,820px);display:flex;flex-direction:column;background:linear-gradient(165deg,#1b2538fa,#0f172afa);border:1px solid var(--border2);border-radius:calc(var(--radius) + 2px);box-shadow:var(--shadow-lg);overflow:hidden;min-width:0}.project-modal-close{position:absolute;top:.85rem;right:.85rem;z-index:3;width:36px;height:36px;border-radius:10px;border:1px solid var(--border);background:#0f172ad9;color:var(--muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition)}.project-modal-close:hover{color:var(--text);border-color:var(--accent)}.project-modal-banner{height:180px;position:relative;overflow:hidden;flex-shrink:0}.project-modal-banner img{width:100%;height:100%;object-fit:cover}.project-modal-scroll{flex:1;overflow-x:hidden;overflow-y:auto;padding:1.15rem 1.25rem .5rem;-webkit-overflow-scrolling:touch;min-width:0;word-break:break-word}.project-modal-head{display:flex;flex-direction:column;gap:.55rem;padding-right:2rem}.project-modal-head h3{font-size:1.35rem;font-weight:800;line-height:1.25}.project-modal-desc{color:var(--muted);font-size:.9rem;line-height:1.7;margin-top:.85rem}.project-modal-section{margin-top:1.1rem}.project-modal-section h4{font-size:.72rem;text-transform:uppercase;letter-spacing:1.2px;font-family:var(--mono);color:var(--keyword);margin-bottom:.55rem}.project-modal-highlights{list-style:none;display:flex;flex-direction:column;gap:.45rem}.project-modal-highlights li{font-size:.84rem;color:var(--muted);background:var(--bg3);border:1px solid var(--border);border-radius:7px;padding:.5rem .75rem .5rem 1.65rem;position:relative;line-height:1.55}.project-modal-highlights li:before{content:"✦";position:absolute;left:.65rem;top:.62rem;color:var(--string);font-size:.6rem}.project-modal-tech{border-top:none;padding-top:0;margin-top:0;overflow-x:hidden}.project-modal-footer{flex-shrink:0;padding:.85rem 1.25rem 1.15rem;border-top:1px solid var(--border);background:#0f172a8c}.project-modal-live-btn{width:100%;justify-content:center;margin-top:0}.tech-badge{font-size:.72rem;font-weight:600;padding:.22rem .7rem;border-radius:6px;background:#3b82f61a;color:var(--func);border:1px solid rgba(59,130,246,.25);font-family:var(--mono)}#contact{background:var(--bg)}.contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;margin-top:3rem}.contact-info{display:flex;flex-direction:column;gap:1.3rem}.contact-card{display:flex;gap:1rem;align-items:flex-start;background:linear-gradient(160deg,#1b2538f0,#141d2df0);border:1px solid var(--border);border-radius:var(--radius);padding:1.3rem;transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition);box-shadow:var(--shadow)}.contact-card:hover{border-color:var(--accent);transform:translate(4px);box-shadow:var(--shadow-lg)}.contact-card-icon{width:42px;height:42px;border-radius:10px;background:#6366f126;border:1px solid rgba(99,102,241,.3);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}.contact-card h4{font-size:.72rem;color:var(--comment);margin-bottom:.15rem;font-family:var(--mono);text-transform:uppercase;letter-spacing:1px}.contact-card p{font-size:.9rem;font-weight:600;color:var(--text)}.contact-card a{color:var(--text);text-decoration:none;transition:color var(--transition)}.contact-card a:hover{color:var(--keyword)}.social-links{display:flex;gap:.7rem}.social-link{width:42px;height:42px;border-radius:10px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;text-decoration:none;color:var(--muted);font-size:.95rem;transition:border-color .22s ease,color .22s ease,background .22s ease,transform .22s ease,box-shadow .22s ease;background:#1b2538e6;box-shadow:var(--shadow)}.social-link:hover{transform:translateY(-3px)}.social-link--linkedin:hover{border-color:#0a66c2;color:#fff;background:#0a66c2;box-shadow:0 10px 28px #0a66c273}.social-link--github:hover{border-color:#24292f;color:#fff;background:#24292f;box-shadow:0 10px 28px #24292f8c}.social-link--email:hover{border-color:#ea4335;color:#fff;background:#ea4335;box-shadow:0 10px 28px #ea43356b}.social-link--linkedin:focus-visible{outline:2px solid #0a66c2;outline-offset:3px}.social-link--github:focus-visible{outline:2px solid #58a6ff;outline-offset:3px}.social-link--email:focus-visible{outline:2px solid #ea4335;outline-offset:3px}.contact-form{display:flex;flex-direction:column;gap:1.1rem}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-group label{font-size:.78rem;font-weight:600;color:var(--muted);font-family:var(--mono)}.form-group input,.form-group textarea{background:#1b2538e0;border:1.5px solid var(--border);border-radius:9px;padding:.85rem 1.1rem;color:var(--text);font-family:Inter,sans-serif;font-size:.93rem;outline:none;transition:border-color var(--transition),box-shadow var(--transition);resize:none;box-shadow:var(--shadow)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--comment);opacity:.85}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6366f133}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.btn-submit{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.95rem;background:var(--accent-grad);border:none;border-radius:10px;color:#fff;font-weight:700;font-size:.95rem;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition);font-family:var(--mono);box-shadow:0 6px 16px #6366f159}.btn-submit:hover{transform:translateY(-3px);box-shadow:0 10px 24px #3b82f666}.btn-submit:disabled{opacity:.7;cursor:default}.form-success{text-align:center;padding:1rem;background:#22c55e24;border:1px solid rgba(34,197,94,.32);border-radius:10px;color:var(--string);font-weight:600;font-family:var(--mono)}.form-error{text-align:center;margin-top:.8rem;padding:.9rem;background:#f8717124;border:1px solid rgba(248,113,113,.32);border-radius:10px;color:#fca5a5;font-weight:600;font-family:var(--mono);font-size:.82rem}footer{padding:2.2rem 6%;border-top:1px solid var(--border);background:var(--bg2);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.footer-brand{font-family:var(--font-display);font-size:1.2rem;font-style:italic;font-weight:400;color:var(--text)}.footer-copy{color:var(--comment);font-size:.82rem;font-family:var(--mono)}.footer-links{display:flex;gap:1.5rem}.footer-links a{color:var(--muted);text-decoration:none;font-size:.82rem;font-family:var(--mono);transition:color var(--transition)}.footer-links a:hover{color:var(--keyword)}.reveal{opacity:0;transform:translateY(25px);transition:opacity .5s ease,transform .5s ease}.reveal.visible{opacity:1;transform:translateY(0)}.contact-card p,.contact-card a{word-break:break-word;overflow-wrap:anywhere}.contact-form input,.contact-form textarea{max-width:100%}@media(max-width:768px){section{padding:4rem clamp(1rem,5vw,2rem);overflow-x:clip}.projects-grid,.skills-grid{grid-template-columns:1fr;gap:1rem}.hero-inner{min-width:0;width:100%}.hero-desc,.section-sub{max-width:100%}nav{padding-left:clamp(1rem,4vw,1.5rem);padding-right:clamp(1rem,4vw,1.5rem)}.nav-links{display:none;flex-direction:column;gap:1rem;position:absolute;top:100%;left:0;right:0;background:#0f172afa;padding:2rem 6%;border-bottom:1px solid var(--border);box-shadow:var(--shadow-lg)}.nav-links.open,.hamburger{display:flex}.nav-cta{display:none}.hero-inner{grid-template-columns:1fr;text-align:center;gap:2rem}.hero-content{padding-left:0;border-left:none;padding-top:.5rem}.hero-eyebrow{justify-content:center}.hero-name{align-items:center}.hero-tags{justify-content:center}.hero-portrait{order:-1;align-items:center}.hero-portrait-stack{width:min(260px,78vw);margin:0 auto}.hero-portrait-note{justify-content:center;padding-right:0}.hero-actions{justify-content:center}.hero-desc{margin-left:auto;margin-right:auto}.hero-glow{left:50%;right:auto;transform:translate(-50%);top:0}.about-inner{grid-template-columns:1fr}.about-img-wrap{max-width:300px;margin:0 auto 2rem}.project-card.featured,.contact-inner,.form-row{grid-template-columns:1fr}footer{flex-direction:column;text-align:center}.project-modal-root{padding:0;align-items:flex-end}.project-modal{width:100%;max-width:100%;max-height:92dvh;border-radius:16px 16px 0 0}.project-modal-scroll{padding:1rem 1rem .5rem}.project-modal-footer{padding:.75rem 1rem 1rem;padding-bottom:max(1rem,env(safe-area-inset-bottom))}.project-modal-banner{height:150px}.project-card-actions{flex-direction:column}.project-detail-btn,.project-live-btn-compact{flex:1 1 auto;width:100%}}@media(max-width:480px){section{padding:3.5rem 1rem}.hero-name{font-size:2rem;letter-spacing:-1px}.project-title-compact{font-size:1rem}.tech-badge{font-size:.68rem;padding:.2rem .55rem}}
