:root {
  --bg:      #111210;
  --bg2:     #181917;
  --bg3:     #1E1F1D;
  --border:  rgba(255,255,255,0.07);
  --border2: rgba(255,255,255,0.13);
  --text:    #E8E6E0;
  --muted:   #6B6966;
  --accent:  #D4C8A8;
  --accent2: #8B7355;
  --hi:      #F0E8D0;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--text);font-family:'Inter',sans-serif;min-height:100vh;overflow-x:hidden;}
body::after{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");pointer-events:none;z-index:1000;opacity:.55;}

/* LOADER */
#loader{position:fixed;inset:0;background:var(--bg);z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;transition:opacity .7s ease,visibility .7s ease;}
#loader.out{opacity:0;visibility:hidden;}
.sk{background:linear-gradient(90deg,var(--bg3) 25%,var(--bg2) 50%,var(--bg3) 75%);background-size:600px 100%;animation:shim 1.6s infinite;border-radius:6px;}
.sk-c{border-radius:50%!important;}
@keyframes shim{0%{background-position:-600px 0}100%{background-position:600px 0}}

/* LAYOUT */
.shell{display:grid;grid-template-columns:290px 1fr;min-height:100vh;max-width:1160px;margin:0 auto;}

/* LEFT */
.left{position:sticky;top:0;height:100vh;overflow-y:auto;border-right:1px solid var(--border);padding:36px 24px;display:flex;flex-direction:column;gap:24px;}
.left::-webkit-scrollbar{display:none;}

.av-wrap{position:relative;width:78px;height:78px;}
.av-ring{position:absolute;inset:-3px;border-radius:50%;background:conic-gradient(from 0deg,var(--accent2),var(--accent),var(--bg3),var(--accent2));animation:spin 6s linear infinite;}
@keyframes spin{to{transform:rotate(360deg)}}
.av-inner{position:relative;z-index:1;width:78px;height:78px;border-radius:50%;background:var(--bg3);border:3px solid var(--bg);overflow:hidden;display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-size:24px;font-weight:700;color:var(--accent);}
.av-inner img{width:100%;height:100%;object-fit:cover;}
.av-dot{position:absolute;bottom:2px;right:2px;width:14px;height:14px;border-radius:50%;background:#4ADE80;border:2px solid var(--bg);z-index:2;}

.name-h1{font-family:'Syne',sans-serif;font-size:20px;font-weight:700;color:var(--hi);letter-spacing:-.02em;line-height:1.2;}
.name-role{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--accent2);letter-spacing:.12em;text-transform:uppercase;margin-top:4px;}
.name-bio{font-size:12.5px;color:var(--muted);line-height:1.65;margin-top:9px;}

.div{height:1px;background:var(--border);}

.socials{display:flex;flex-direction:column;gap:4px;}
.si{display:flex;align-items:center;gap:9px;padding:8px 11px;border-radius:10px;border:1px solid transparent;text-decoration:none;color:var(--muted);font-size:12.5px;transition:all .22s;cursor:pointer;}
.si:hover{background:var(--bg3);border-color:var(--border2);color:var(--text);}
.si svg{flex-shrink:0;opacity:.55;transition:opacity .2s;}
.si:hover svg{opacity:1;}
.si-h{margin-left:auto;font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--accent2);opacity:0;transition:opacity .2s;}
.si:hover .si-h{opacity:1;}

.stat-card{background:var(--bg3);border:1px solid var(--border);border-radius:12px;padding:13px 15px;}
.stat-lbl{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);margin-bottom:5px;}
.stat-txt{font-size:12.5px;color:var(--text);line-height:1.5;}

/* RIGHT */
.right{padding:36px 44px 56px;display:flex;flex-direction:column;gap:36px;}

.sec-lbl{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent2);margin-bottom:14px;display:flex;align-items:center;gap:10px;}
.sec-lbl::after{content:'';flex:1;height:1px;background:var(--border);}

.headline{font-family:'Syne',sans-serif;font-size:clamp(38px,5vw,62px);font-weight:800;line-height:1.0;letter-spacing:-.035em;color:var(--hi);}
.headline em{font-style:italic;font-weight:400;color:var(--accent2);}

/* Stats row */
.nums{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.num-card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:16px;transition:border-color .2s,transform .2s;}
.num-card:hover{border-color:var(--border2);transform:translateY(-2px);}
.num-val{font-family:'Syne',sans-serif;font-size:28px;font-weight:700;color:var(--hi);letter-spacing:-.04em;line-height:1;}
.num-u{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--accent2);margin-left:2px;}
.num-d{font-size:11.5px;color:var(--muted);margin-top:4px;}

/* Skills */
.pills{display:flex;flex-wrap:wrap;gap:7px;}
.pill{display:flex;align-items:center;gap:5px;background:var(--bg2);border:1px solid var(--border);border-radius:7px;padding:5px 11px;font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text);transition:all .18s;cursor:default;}
.pill:hover{border-color:var(--accent2);color:var(--accent);background:rgba(212,200,168,.05);}
.pdot{width:5px;height:5px;border-radius:50%;background:var(--accent2);flex-shrink:0;}

/* Project grid */
.pgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.pc{background:var(--bg2);border:1px solid var(--border);border-radius:13px;padding:16px;cursor:pointer;transition:all .24s;position:relative;overflow:hidden;}
.pc::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(212,200,168,.04) 0%,transparent 60%);opacity:0;transition:opacity .24s;}
.pc:hover{border-color:var(--accent2);transform:translateY(-3px);box-shadow:0 14px 36px rgba(0,0,0,.45);}
.pc:hover::before{opacity:1;}
.pc-num{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--accent2);margin-bottom:8px;}
.pc-name{font-family:'Syne',sans-serif;font-size:14px;font-weight:600;color:var(--hi);margin-bottom:5px;}
.pc-desc{font-size:11.5px;color:var(--muted);line-height:1.6;margin-bottom:12px;}
.pc-tags{display:flex;flex-wrap:wrap;gap:4px;}
.pc-tag{font-family:'JetBrains Mono',monospace;font-size:10px;background:var(--bg3);border:1px solid var(--border);border-radius:4px;padding:2px 7px;color:var(--muted);}
.pc-arr{position:absolute;top:14px;right:14px;width:24px;height:24px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--muted);transition:all .2s;}
.pc:hover .pc-arr{background:var(--accent2);border-color:var(--accent2);color:var(--bg);transform:rotate(45deg);}

.more-btn{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;padding:13px;background:transparent;border:1px solid var(--border);border-radius:12px;color:var(--muted);font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.08em;cursor:pointer;transition:all .22s;margin-top:10px;}
.more-btn:hover{border-color:var(--accent2);color:var(--accent);background:rgba(212,200,168,.04);}

/* MODAL */
.mbk{display:none;position:fixed;inset:0;background:rgba(0,0,0,.78);backdrop-filter:blur(10px);z-index:500;align-items:center;justify-content:center;padding:24px;animation:fi .3s ease;}
.mbk.open{display:flex;}
@keyframes fi{from{opacity:0}to{opacity:1}}
.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:18px;width:100%;max-width:760px;max-height:88vh;overflow:hidden;display:flex;flex-direction:column;animation:su .35s cubic-bezier(.16,1,.3,1);}
@keyframes su{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
.mh{padding:22px 26px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.mt{font-family:'Syne',sans-serif;font-size:17px;font-weight:700;color:var(--hi);}
.mc{width:30px;height:30px;border-radius:7px;border:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;transition:all .18s;}
.mc:hover{background:var(--bg3);color:var(--text);}
.mb{overflow-y:auto;padding:22px 26px;display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.mb::-webkit-scrollbar{width:4px;}
.mb::-webkit-scrollbar-track{background:transparent;}
.mb::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px;}
.mp{background:var(--bg3);border:1px solid var(--border);border-radius:12px;padding:16px;transition:border-color .2s,transform .2s;cursor:pointer;}
.mp:hover{border-color:var(--accent2);transform:translateY(-2px);}
.mp-i{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--accent2);margin-bottom:7px;}
.mp-n{font-family:'Syne',sans-serif;font-size:13.5px;font-weight:600;color:var(--hi);margin-bottom:4px;}
.mp-d{font-size:11.5px;color:var(--muted);line-height:1.6;margin-bottom:11px;}
.mp-tags{display:flex;flex-wrap:wrap;gap:4px;}
.mp-tag{font-family:'JetBrains Mono',monospace;font-size:10px;background:rgba(212,200,168,.06);border:1px solid var(--border);border-radius:4px;padding:2px 6px;color:var(--muted);}

/* ANIMATIONS */
.fu{opacity:0;transform:translateY(18px);transition:opacity .65s ease,transform .65s ease;}
.fu.v{opacity:1;transform:none;}
.d1{transition-delay:.05s}.d2{transition-delay:.12s}.d3{transition-delay:.2s}.d4{transition-delay:.3s}.d5{transition-delay:.4s}

/* RESPONSIVE */
@media(max-width:760px){
  .shell{grid-template-columns:1fr;}
  .left{position:relative;height:auto;border-right:none;border-bottom:1px solid var(--border);}
  .pgrid{grid-template-columns:1fr;}
  .nums{grid-template-columns:repeat(2,1fr);}
  .mb{grid-template-columns:1fr;}
  .right{padding:28px 18px 48px;}
}

@keyframes pulse {
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.6;transform:scale(1.25)}
}