@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Fira+Code:wght@400;500&display=swap";.loading-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--accent);animation:dotBounce 1.2s ease-in-out infinite;margin:0 3px}.loading-dot:nth-child(2){animation-delay:.15s}.loading-dot:nth-child(3){animation-delay:.3s}@keyframes dotBounce{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.projects-loading,.admin-loading{padding:4rem 0;display:flex;align-items:center;gap:.4rem}.projects-loading{justify-content:center}.admin-shell{display:flex;min-height:100vh;background:var(--bg)}.admin-sidebar{width:240px;flex-shrink:0;background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}.admin-sidebar-logo{display:flex;align-items:center;gap:.6rem;padding:1.4rem 1.5rem;border-bottom:1px solid var(--border);font-family:var(--font-mono);font-size:1rem;font-weight:700;color:var(--text-bright)}.admin-badge{font-size:.6rem;font-weight:700;padding:.15rem .5rem;background:var(--accent-glow2);border:1px solid rgba(45,212,191,.3);border-radius:100px;color:var(--accent);text-transform:uppercase;letter-spacing:.08em}.admin-nav{flex:1;padding:1rem .75rem;display:flex;flex-direction:column;gap:.25rem}.admin-nav-link{display:flex;align-items:center;gap:.6rem;padding:.6rem .75rem;border-radius:var(--r-sm);font-size:.875rem;font-weight:500;color:var(--text-muted);transition:all var(--t);cursor:pointer;border:none;background:none;text-align:left;width:100%;text-decoration:none}.admin-nav-link:hover{color:var(--text-bright);background:#ffffff0a}.admin-nav-link.active{color:var(--accent);background:var(--accent-glow2)}.admin-sidebar-footer{padding:1rem .75rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.25rem}.admin-logout-btn{display:block;width:100%;padding:.6rem .75rem;border-radius:var(--r-sm);font-size:.875rem;font-weight:500;color:#f87171;background:none;border:none;cursor:pointer;text-align:left;transition:all var(--t);font-family:var(--font)}.admin-logout-btn:hover{background:#f8717114}.admin-main{flex:1;display:flex;flex-direction:column;min-width:0}.admin-topbar{height:56px;background:var(--bg-card);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 1.5rem;gap:1rem;position:sticky;top:0;z-index:100}.admin-topbar-title{font-size:.875rem;font-weight:600;color:var(--text-muted);flex:1}.admin-hamburger{display:none;background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;padding:.25rem}.admin-logout-btn-sm{font-size:.78rem;font-weight:500;color:var(--text-dim);background:none;border:1px solid var(--border);border-radius:var(--r-sm);padding:.3rem .75rem;cursor:pointer;transition:all var(--t);font-family:var(--font)}.admin-logout-btn-sm:hover{color:#f87171;border-color:#f8717166}.admin-content{padding:2rem;max-width:960px}.admin-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200}.admin-splash{min-height:100vh;display:flex;align-items:center;justify-content:center;gap:.4rem;background:var(--bg)}@media (max-width: 768px){.admin-sidebar{position:fixed;inset:0 auto 0 0;z-index:300;transform:translate(-100%);transition:transform var(--t)}.admin-sidebar.open{transform:none}.admin-hamburger{display:block}.admin-content{padding:1.25rem}}.admin-login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:1.5rem}.admin-login-card{width:100%;max-width:420px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);padding:2.5rem}.admin-login-logo{display:flex;align-items:center;gap:.6rem;font-family:var(--font-mono);font-size:1.1rem;font-weight:700;color:var(--text-bright);margin-bottom:1.5rem}.admin-login-title{font-size:1.1rem;font-weight:700;color:var(--text-bright);margin-bottom:1.5rem}.admin-back-link{display:block;margin-top:1.5rem;text-align:center;font-size:.82rem;color:var(--text-dim);transition:color var(--t)}.admin-back-link:hover{color:var(--accent)}.admin-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.admin-page-title{font-size:1.5rem;font-weight:800;color:var(--text-bright);margin-bottom:.25rem}.admin-page-sub{font-size:.85rem;color:var(--text-muted)}.admin-error{font-size:.85rem;color:#f87171;background:#f8717114;border:1px solid rgba(248,113,113,.2);border-radius:var(--r-sm);padding:.6rem .9rem;margin-bottom:.75rem}.admin-table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:.875rem}.admin-table th{background:var(--bg-2);color:var(--text-dim);font-weight:600;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}.admin-table td{padding:.9rem 1rem;border-bottom:1px solid var(--border);color:var(--text-muted);vertical-align:middle}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:#ffffff04}.project-row-info{display:flex;align-items:center;gap:.6rem}.project-row-emoji{font-size:1.4rem}.project-row-title{font-weight:600;color:var(--text-bright)}.order-btns{display:flex;flex-direction:column;gap:2px}.order-btns button{background:var(--bg-2);border:1px solid var(--border);border-radius:4px;color:var(--text-muted);cursor:pointer;font-size:.75rem;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:all var(--t)}.order-btns button:hover:not(:disabled){color:var(--accent);border-color:#2dd4bf66}.order-btns button:disabled{opacity:.25;cursor:not-allowed}.action-btns{display:flex;gap:.5rem}.admin-pill{display:inline-block;font-size:.7rem;font-weight:600;padding:.2rem .55rem;border-radius:100px}.admin-pill.on{color:var(--accent);background:var(--accent-glow2)}.admin-pill.off{color:var(--text-dim);background:#ffffff0a}.btn-sm-outline,.btn-sm-danger{font-size:.78rem;font-weight:600;padding:.3rem .75rem;border-radius:var(--r-sm);cursor:pointer;transition:all var(--t);border:1px solid;background:none;font-family:var(--font)}.btn-sm-outline{color:var(--text-muted);border-color:var(--border)}.btn-sm-outline:hover{color:var(--accent);border-color:#2dd4bf66}.btn-sm-danger{color:#f87171;border-color:#f871714d}.btn-sm-danger:hover{background:#f8717114}.btn-danger{display:inline-flex;align-items:center;gap:.4rem;padding:.8rem 1.8rem;border-radius:var(--r);font-size:.95rem;font-weight:600;cursor:pointer;background:#f871711f;color:#f87171;border:1px solid rgba(248,113,113,.3);transition:all var(--t);font-family:var(--font)}.btn-danger:hover{background:#f8717133;transform:translateY(-1px)}.admin-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:500;display:flex;align-items:center;justify-content:center;padding:1rem}.admin-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);width:100%;max-width:640px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.admin-modal-sm{max-width:420px}.admin-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.admin-modal-header h3{font-size:1rem;font-weight:700}.admin-modal-close{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:1.1rem;transition:color var(--t)}.admin-modal-close:hover{color:var(--text-bright)}.admin-modal-body{padding:1.5rem;overflow-y:auto;flex:1}.admin-modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:.75rem}.link-row{display:flex;align-items:center;gap:.6rem;margin-bottom:.6rem;flex-wrap:wrap}.check-primary{display:flex;align-items:center;gap:.35rem;font-size:.78rem;color:var(--text-muted);white-space:nowrap;cursor:pointer}.admin-label-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.form-check{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-muted);cursor:pointer;margin-bottom:.75rem}.form-check input{accent-color:var(--accent);width:15px;height:15px}.admin-cards-stack{display:flex;flex-direction:column;gap:1.5rem}.admin-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.75rem}.admin-card-title{font-size:1rem;font-weight:700;color:var(--text-bright);margin-bottom:1.25rem}.admin-hint{font-size:.78rem;color:var(--text-dim);margin-bottom:.9rem;font-style:italic}.bio-row{display:flex;align-items:flex-start;gap:.6rem;margin-bottom:.75rem}.bio-row textarea{flex:1}.skill-edit-row,.social-edit-row{display:flex;align-items:center;gap:.6rem;margin-bottom:.6rem;flex-wrap:wrap}:root{--bg: #090d1a;--bg-2: #0f1629;--bg-card: #141e30;--bg-card-2: #1a2540;--accent: #2dd4bf;--accent-dark: #0f766e;--accent-glow: rgba(45, 212, 191, .22);--accent-glow2: rgba(45, 212, 191, .08);--violet: #818cf8;--violet-glow: rgba(129, 140, 248, .13);--text: #e2e8f0;--text-muted: #94a3b8;--text-dim: #3d4a5c;--text-bright: #f8fafc;--border: rgba(255, 255, 255, .07);--border-hover: rgba(45, 212, 191, .35);--nav-h: 65px;--section-py: 7rem;--max-w: 1100px;--r-sm: 8px;--r: 14px;--r-lg: 20px;--r-xl: 28px;--shadow-lg: 0 12px 48px rgba(0, 0, 0, .55);--ease: cubic-bezier(.4, 0, .2, 1);--t: .25s cubic-bezier(.4, 0, .2, 1);--font: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "Fira Code", "Courier New", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;scroll-padding-top:var(--nav-h)}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.65;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}ul{list-style:none}button{font-family:var(--font)}h1,h2,h3,h4{color:var(--text-bright);line-height:1.2;letter-spacing:-.02em}.section-label{font-family:var(--font-mono);font-size:.78rem;font-weight:500;color:var(--accent);text-transform:uppercase;letter-spacing:.14em;margin-bottom:.8rem;display:block}.section-title{font-size:clamp(1.9rem,3.2vw,2.7rem);font-weight:800;margin-bottom:1rem;background:linear-gradient(135deg,var(--text-bright) 55%,var(--text-muted));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.section-sub{font-size:1.05rem;color:var(--text-muted);max-width:540px;line-height:1.7}.container{max-width:var(--max-w);margin:0 auto;padding:0 1.75rem}section{padding:var(--section-py) 0}.reveal{opacity:0;transform:translateY(36px);transition:opacity .65s var(--ease),transform .65s var(--ease)}.reveal.visible{opacity:1;transform:none}.reveal-d1{transition-delay:.1s}.reveal-d2{transition-delay:.2s}.reveal-d3{transition-delay:.3s}.btn-primary,.btn-outline{display:inline-flex;align-items:center;gap:.45rem;padding:.8rem 1.8rem;border-radius:var(--r);font-size:.95rem;font-weight:600;cursor:pointer;border:none;transition:all var(--t);text-decoration:none;white-space:nowrap}.btn-primary{background:var(--accent);color:#090d1a}.btn-primary:hover{background:#5eead4;transform:translateY(-2px);box-shadow:0 8px 28px var(--accent-glow);color:#090d1a}.btn-outline{background:transparent;color:var(--text);border:1.5px solid rgba(255,255,255,.15)}.btn-outline:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}.portfolio-nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:1000;background:#090d1ad1;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid var(--border);display:flex;align-items:center}.nav-inner{display:flex;align-items:center;width:100%;padding:0 2rem}.nav-logo{font-family:var(--font-mono);font-size:1.1rem;font-weight:700;color:var(--text-bright);transition:color var(--t);margin-right:auto}.nav-logo .logo-accent,.nav-logo:hover{color:var(--accent)}.nav-links{display:flex;align-items:center;gap:2rem}.nav-link{font-size:.875rem;font-weight:500;color:var(--text-muted);position:relative;transition:color var(--t);padding-bottom:2px}.nav-link:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--accent);border-radius:2px;transition:width var(--t)}.nav-link:hover{color:var(--text-bright)}.nav-link:hover:after{width:100%}.nav-cta{background:var(--accent);color:#090d1a;padding:.45rem 1.2rem;border-radius:var(--r-sm);font-size:.85rem;font-weight:700;transition:all var(--t);cursor:pointer;border:none}.nav-cta:hover{background:#5eead4;transform:translateY(-1px);color:#090d1a}.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none}.nav-hamburger span{display:block;width:22px;height:2px;background:var(--text-muted);border-radius:2px;transition:all var(--t)}.nav-mobile{display:none;position:fixed;inset:var(--nav-h) 0 0 0;background:#090d1af7;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);flex-direction:column;align-items:center;justify-content:center;gap:2.5rem;z-index:999;animation:fadeIn .2s ease}.nav-mobile.open{display:flex}.nav-mobile .nav-link{font-size:1.5rem;color:var(--text)}.nav-mobile .nav-link:hover{color:var(--accent)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 768px){.nav-links{display:none}.nav-hamburger{display:flex}}.hero-section{min-height:100vh;display:flex;align-items:center;position:relative;padding-top:calc(var(--nav-h) + 4rem);padding-bottom:4rem;overflow:hidden}.hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.hero-orb{position:absolute;border-radius:50%;filter:blur(100px);pointer-events:none}.hero-orb-1{width:650px;height:650px;background:radial-gradient(circle,rgba(45,212,191,.22),transparent 65%);top:-180px;left:-120px;animation:orbFloat 11s ease-in-out infinite}.hero-orb-2{width:550px;height:550px;background:radial-gradient(circle,rgba(129,140,248,.18),transparent 65%);bottom:-150px;right:-100px;animation:orbFloat 14s ease-in-out infinite reverse}@keyframes orbFloat{0%,to{transform:translate(0) scale(1)}33%{transform:translate(45px,-45px) scale(1.07)}66%{transform:translate(-30px,28px) scale(.93)}}.hero-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(rgba(255,255,255,.05) 1px,transparent 1px);background-size:40px 40px;-webkit-mask-image:radial-gradient(ellipse 75% 75% at 50% 50%,black 30%,transparent 100%);mask-image:radial-gradient(ellipse 75% 75% at 50% 50%,black 30%,transparent 100%)}.hero-content{position:relative;z-index:1;max-width:720px}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;font-size:.78rem;font-weight:500;color:var(--accent);background:var(--accent-glow2);border:1px solid rgba(45,212,191,.22);padding:.35rem 1rem;border-radius:100px;margin-bottom:1.75rem;letter-spacing:.02em}.pulse-dot{width:7px;height:7px;background:var(--accent);border-radius:50%;animation:pulseDot 2.2s ease-in-out infinite;flex-shrink:0}@keyframes pulseDot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(1.35)}}.hero-name{font-size:clamp(3rem,6.5vw,5.5rem);font-weight:900;line-height:1.04;margin-bottom:1rem;background:linear-gradient(135deg,#f8fafc 25%,#94a3b8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.03em}.hero-role-wrap{font-size:clamp(1.2rem,2.4vw,1.7rem);font-weight:600;color:var(--text-muted);margin-bottom:1.5rem;display:flex;align-items:center;gap:.6rem;min-height:2.6rem}.hero-role-prefix{color:var(--text-dim)}.hero-role-text{color:var(--accent);font-family:var(--font-mono);transition:opacity .3s ease,transform .3s ease}.hero-role-text.fading{opacity:0;transform:translateY(-10px)}.hero-desc{font-size:1.05rem;color:var(--text-muted);max-width:530px;margin-bottom:2.5rem;line-height:1.75}.hero-offers{list-style:none;margin:0 0 2.5rem;padding:0;display:flex;flex-wrap:wrap;gap:.45rem 2rem}.hero-offers li{position:relative;padding-left:1.1rem;font-size:.88rem;color:var(--text-dim)}.hero-offers li:before{content:"→";position:absolute;left:0;color:var(--accent);font-family:var(--font-mono)}.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:3rem}.hero-stack{display:flex;flex-wrap:wrap;gap:.5rem}.stack-badge{font-family:var(--font-mono);font-size:.73rem;padding:.28rem .75rem;background:var(--bg-card);border:1px solid var(--border);border-radius:100px;color:var(--text-muted);transition:all var(--t)}.stack-badge:hover{border-color:#2dd4bf59;color:var(--accent)}@keyframes heroEnter{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}.hero-badge{animation:heroEnter .7s var(--ease) .05s both}.hero-name{animation:heroEnter .7s var(--ease) .15s both}.hero-role-wrap{animation:heroEnter .7s var(--ease) .25s both}.hero-desc{animation:heroEnter .7s var(--ease) .35s both}.hero-offers{animation:heroEnter .7s var(--ease) .43s both}.hero-cta{animation:heroEnter .7s var(--ease) .53s both}.hero-stack{animation:heroEnter .7s var(--ease) .63s both}.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3.5rem}.service-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:2rem 1.75rem;transition:all var(--t);position:relative;overflow:hidden}.service-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(140deg,var(--accent-glow2) 0%,transparent 60%);opacity:0;transition:opacity var(--t)}.service-card:hover{border-color:var(--border-hover);transform:translateY(-7px);box-shadow:0 24px 64px #00000073}.service-card:hover:before{opacity:1}.service-icon{display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;border-radius:var(--r);background:#2dd4bf1a;color:var(--accent);margin-bottom:1.25rem}.service-title{font-size:1.1rem;font-weight:700;color:var(--text-bright);margin-bottom:.75rem}.service-desc{font-size:.875rem;color:var(--text-muted);line-height:1.72;margin-bottom:1.4rem}.service-tags{display:flex;flex-wrap:wrap;gap:.4rem}.service-tag{font-family:var(--font-mono);font-size:.68rem;padding:.2rem .6rem;background:var(--bg-2);border:1px solid var(--border);border-radius:4px;color:var(--text-dim);transition:all var(--t)}.service-card:hover .service-tag{border-color:#2dd4bf26;color:var(--text-muted)}#projets{background:var(--bg-2)}.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3.5rem}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:all var(--t);display:flex;flex-direction:column}.project-card:hover{border-color:var(--border-hover);transform:translateY(-7px);box-shadow:0 24px 64px #00000080}.project-thumb{height:175px;display:flex;align-items:center;justify-content:center;font-size:3.5rem;position:relative;overflow:hidden;color:#fff}.project-thumb svg{color:#fff!important;stroke:#fff!important}.project-thumb:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(0deg,var(--bg-card) 0%,transparent 55%)}.project-body{padding:1.5rem;flex:1;display:flex;flex-direction:column}.project-status{display:inline-flex;align-items:center;gap:.35rem;font-size:.7rem;font-weight:600;padding:.22rem .65rem;border-radius:100px;margin-bottom:.8rem;letter-spacing:.04em;width:fit-content}.project-status.live{color:var(--accent);background:var(--accent-glow2);border:1px solid rgba(45,212,191,.22)}.project-status.wip{color:#fbbf24;background:#fbbf2412;border:1px solid rgba(251,191,36,.22)}.project-status.client{color:var(--violet);background:var(--violet-glow);border:1px solid rgba(129,140,248,.22)}.project-title{font-size:1.05rem;font-weight:700;color:var(--text-bright);margin-bottom:.5rem}.project-desc{font-size:.86rem;color:var(--text-muted);line-height:1.68;margin-bottom:1.1rem;flex:1}.project-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:1.3rem}.project-tag{font-family:var(--font-mono);font-size:.67rem;padding:.18rem .55rem;background:var(--bg-2);border:1px solid var(--border);border-radius:4px;color:var(--text-muted)}.project-links{display:flex;gap:.65rem;flex-wrap:wrap}.project-link{display:inline-flex;align-items:center;gap:.35rem;font-size:.78rem;font-weight:600;color:var(--text-muted);padding:.4rem .9rem;border:1px solid var(--border);border-radius:var(--r-sm);transition:all var(--t)}.project-link:hover{color:var(--accent);border-color:#2dd4bf66;background:var(--accent-glow2)}.project-link.primary{color:var(--accent);border-color:#2dd4bf47}.project-link.primary:hover{background:var(--accent);color:#090d1a;border-color:var(--accent)}.about-grid{display:grid;grid-template-columns:260px 1fr;gap:5rem;align-items:start;margin-top:3.5rem}.about-left{display:flex;flex-direction:column;align-items:center;gap:1.5rem;position:sticky;top:calc(var(--nav-h) + 2rem)}.about-avatar-initials{font-family:Space Grotesk,sans-serif;font-size:4rem;font-weight:700;color:#fff;letter-spacing:-.05em;line-height:1;text-shadow:0 2px 20px rgba(0,0,0,.3)}.about-avatar{width:180px;height:180px;border-radius:50%;background:linear-gradient(135deg,#0f766e,#2dd4bf);display:flex;align-items:center;justify-content:center;border:3px solid rgba(45,212,191,.3);box-shadow:0 0 70px var(--accent-glow),0 0 140px #2dd4bf0d}.about-alias{font-family:var(--font-mono);font-size:1rem;color:var(--accent);font-weight:500;text-align:center}.about-social{display:flex;flex-direction:column;gap:.6rem;width:100%}.social-link{display:flex;align-items:center;gap:.6rem;font-size:.825rem;font-weight:500;color:var(--text-muted);padding:.5rem .9rem;border:1px solid var(--border);border-radius:var(--r-sm);transition:all var(--t)}.social-link:hover{color:var(--accent);border-color:#2dd4bf59;background:var(--accent-glow2);transform:translate(3px)}.social-icon{font-size:1rem}.about-text>h3{font-size:1.65rem;font-weight:800;margin-bottom:.4rem}.about-subtitle{font-family:var(--font-mono);font-size:.82rem;color:var(--accent);margin-bottom:1.5rem;display:block}.about-text p{color:var(--text-muted);line-height:1.78;margin-bottom:.9rem;font-size:.95rem}.about-skills{margin-top:2rem}.skills-category{margin-bottom:1.5rem}.skills-cat-label{font-family:var(--font-mono);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--text-dim);margin-bottom:.65rem}.skills-list{display:flex;flex-wrap:wrap;gap:.45rem}.skill-chip{font-size:.78rem;font-weight:500;padding:.3rem .75rem;border-radius:var(--r-sm);background:var(--bg-card);border:1px solid var(--border);color:var(--text-muted);transition:all var(--t)}.skill-chip:hover{background:var(--accent-glow2);border-color:#2dd4bf52;color:var(--accent);transform:translateY(-1px)}#contact{background:var(--bg-2)}.contact-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:4rem;margin-top:3.5rem;align-items:start}.contact-info>p{color:var(--text-muted);line-height:1.75;margin-bottom:2rem}.contact-items{display:flex;flex-direction:column;gap:.85rem}.contact-item{display:flex;align-items:center;gap:.85rem;font-size:.875rem;color:var(--text-muted);transition:color var(--t)}.contact-item:hover{color:var(--text-bright)}.ci-icon{width:38px;height:38px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:1.05rem;flex-shrink:0;transition:all var(--t)}.contact-item:hover .ci-icon{border-color:#2dd4bf66;background:var(--accent-glow2)}.contact-form-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);padding:2.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.45rem;margin-bottom:1.2rem}.form-label{font-size:.775rem;font-weight:500;color:var(--text-muted);letter-spacing:.03em}.form-control{background:var(--bg-2);border:1.5px solid var(--border);border-radius:var(--r);padding:.75rem 1rem;color:var(--text);font-family:var(--font);font-size:.9rem;transition:all var(--t);outline:none;resize:none;width:100%}.form-control:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow2);background:var(--bg-card-2)}.form-control::placeholder{color:var(--text-dim)}.form-submit{width:100%;padding:.9rem;background:var(--accent);color:#090d1a;border:none;border-radius:var(--r);font-family:var(--font);font-size:1rem;font-weight:700;cursor:pointer;transition:all var(--t);display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:.5rem}.form-submit:hover{background:#5eead4;transform:translateY(-2px);box-shadow:0 10px 30px var(--accent-glow)}.form-submit:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.form-success{text-align:center;padding:3rem 2rem}.form-success .success-icon{font-size:3rem;margin-bottom:1rem}.form-success h4{color:var(--accent);margin-bottom:.5rem;font-size:1.2rem}.form-success p{color:var(--text-muted);font-size:.9rem}.portfolio-footer{border-top:1px solid var(--border);padding:3rem 0 2rem}.footer-inner{display:flex;flex-direction:column;align-items:center;gap:1.75rem}.footer-logo{font-family:var(--font-mono);font-size:1.15rem;font-weight:700;color:var(--text-muted);letter-spacing:-.02em;transition:color var(--t)}.footer-logo:hover{color:var(--text)}.footer-social{display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem}.footer-social-link{display:inline-flex;align-items:center;gap:.45rem;font-size:.8rem;font-weight:500;color:var(--text-dim);padding:.4rem .9rem;border:1px solid var(--border);border-radius:999px;transition:color var(--t),border-color var(--t),background var(--t)}.footer-social-link:hover{color:var(--accent);border-color:#2dd4bf59;background:var(--accent-glow2)}.footer-social-icon{font-size:.9rem;line-height:1}.footer-copy{font-size:.78rem;color:var(--text-dim);padding-top:1.25rem;border-top:1px solid var(--border);width:100%;text-align:center}@media (max-width: 1024px){.about-grid{grid-template-columns:1fr;gap:3rem}.about-left{position:static;flex-direction:row;flex-wrap:wrap;justify-content:center}.about-social{flex-direction:row;flex-wrap:wrap;width:auto}}@media (max-width: 640px){.hero-section{padding-top:calc(var(--nav-h) + 2rem)}.about-left{flex-direction:column;align-items:center;gap:1rem}.about-avatar{width:130px;height:130px;font-size:3.5rem}.about-social{flex-direction:column;width:100%}.social-link{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.about-text>h3{font-size:1.35rem}.about-subtitle{font-size:.78rem}}@media (max-width: 900px){:root{--section-py: 5rem}.services-grid,.projects-grid{grid-template-columns:repeat(2,1fr)}.contact-grid,.form-row{grid-template-columns:1fr}}@media (max-width: 600px){:root{--section-py: 4rem}.services-grid,.projects-grid{grid-template-columns:1fr}.contact-form-wrap{padding:1.5rem}.form-success{padding:2rem 1rem}.form-success .btn-outline{width:100%}.hero-cta{flex-direction:column;align-items:flex-start}.hero-cta .btn-primary,.hero-cta .btn-outline{width:100%;justify-content:center}}
