:root {
  --primary-dark:#110d0a; --primary:#1a1310; --primary-light:#241a14;
  --accent:#e8833a; --accent-light:#f5a05a; --accent-secondary:#c96820;
  --accent-glow:rgba(232,131,58,.18);
  --bg-dark:#0a0806; --bg-card:#131009; --bg-hover:#1c1610;
  --text-primary:#f0e4d0; --text-secondary:#c9b89c; --text-muted:#7d6a56;
  --border-color:#251d16; --border-glow:rgba(232,131,58,.22);
  --success:#3ecf6e; --warning:#f5c842; --danger:#e85c4a; --info:#4cb0e8;
  --github:#6e7681;
  --shadow:0 8px 32px rgba(0,0,0,.5); --shadow-lg:0 24px 56px rgba(0,0,0,.6);
  --shadow-glow:0 0 40px rgba(232,131,58,.12);
  --transition:all .22s cubic-bezier(.4,0,.2,1);
  --font:'Sora',system-ui,sans-serif;
  --mono:'JetBrains Mono',monospace;
  --radius:16px; --radius-sm:10px; --radius-xs:7px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
body{font-family:var(--font);background:var(--bg-dark);color:var(--text-primary);line-height:1.6;min-height:100vh;padding-bottom:max(20px,env(safe-area-inset-bottom));overflow-x:hidden;background-image:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(232,131,58,.06),transparent);}
a{color:var(--accent);text-decoration:none;transition:var(--transition);}
a:hover{color:var(--accent-light);}
button{cursor:pointer;font-family:inherit;outline:none;border:none;-webkit-appearance:none;}
::-webkit-scrollbar{width:4px;height:4px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px;}
::-webkit-scrollbar-thumb:hover{background:var(--accent);}
::selection{background:rgba(232,131,58,.25);color:var(--text-primary);}

/* ── HEADER ── */
.header{position:sticky;top:0;z-index:200;height:60px;padding:0 24px;background:rgba(10,8,6,.92);border-bottom:1px solid rgba(37,29,22,.8);display:flex;align-items:center;gap:12px;}
@supports(backdrop-filter:blur(1px)){.header{background:rgba(10,8,6,.8);backdrop-filter:blur(24px) saturate(1.4);}}
.logo{font-size:1.25rem;font-weight:800;letter-spacing:-1px;color:var(--text-primary);display:inline-block;font-family:var(--font);}
.logo span{color:var(--accent);background:linear-gradient(135deg,var(--accent),var(--accent-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.header-back{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--radius-xs);background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-muted);font-size:.8rem;font-weight:600;text-decoration:none;transition:var(--transition);}
.header-back:hover{color:var(--text-primary);border-color:var(--border-glow);box-shadow:0 0 12px var(--accent-glow);}
.header-spacer{flex:1;}
.header-btn{width:36px;height:36px;border-radius:var(--radius-xs);background:transparent;border:1px solid transparent;cursor:pointer;color:var(--text-muted);font-size:14px;display:flex;align-items:center;justify-content:center;transition:var(--transition);}
.header-btn:hover{background:rgba(255,255,255,.05);color:var(--text-primary);border-color:var(--border-color);}

/* ── LAYOUT ── */
.container{max-width:1380px;margin:0 auto;padding:0 16px;}
.main-layout{display:grid;grid-template-columns:290px 1fr;gap:22px;margin-top:22px;align-items:start;}
@media(max-width:1024px){.main-layout{grid-template-columns:1fr;}}
@media(max-width:768px){.main-layout{margin-top:14px;gap:14px;}}

/* ── SIDEBAR ── */
.sidebar{position:sticky;top:76px;display:flex;flex-direction:column;gap:14px;}
@media(max-width:1024px){.sidebar{position:static;}}

/* ── PROFILE CARD ── */
.profile-card{background:var(--bg-card);border-radius:20px;border:1px solid var(--border-color);overflow:hidden;box-shadow:var(--shadow),var(--shadow-glow);transition:var(--transition);}
.profile-card-inner{padding:4px 20px 20px;text-align:center;}

/* Avatar upload */
.avatar-wrapper{position:relative;width:130px;height:130px;margin:0 auto;cursor:pointer;}
.avatar-wrapper:hover .avatar-overlay{opacity:1;}
.avatar-overlay{position:absolute;inset:0;border-radius:50%;background:rgba(0,0,0,.55);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;opacity:0;transition:var(--transition);z-index:5;cursor:pointer;}
.avatar-overlay i{color:#fff;font-size:1.2rem;}
.avatar-overlay span{color:#fff;font-size:.62rem;font-weight:600;letter-spacing:.5px;}
#avatar-upload-input{display:none;}
.avatar-upload-progress{position:absolute;bottom:4px;left:50%;transform:translateX(-50%);background:var(--accent);color:#1a1310;font-size:.6rem;font-weight:700;padding:2px 8px;border-radius:20px;white-space:nowrap;display:none;z-index:6;}

/* XP ring */
.xp-ring-wrap{position:relative;width:130px;height:130px;margin:0 auto 14px;}
.xp-ring-svg{position:absolute;inset:-8px;width:calc(100% + 16px);height:calc(100% + 16px);overflow:visible;}
.xp-ring-track{fill:none;stroke:rgba(232,131,58,.1);stroke-width:4.5;}
.xp-ring-fill{fill:none;stroke:url(#xpGradient);stroke-width:4.5;stroke-linecap:round;transform:rotate(-90deg);transform-origin:center;transition:stroke-dashoffset 1.6s cubic-bezier(.34,1.56,.64,1);}
.xp-level-pip{position:absolute;bottom:2px;right:2px;background:linear-gradient(135deg,var(--accent),var(--accent-secondary));color:#1a1310;font-size:.6rem;font-weight:800;padding:2px 7px;border-radius:20px;border:2px solid var(--bg-card);z-index:10;white-space:nowrap;font-family:var(--mono);}
.xp-ring-header{padding:20px 20px 0;text-align:center;}
.avatar-img{width:130px;height:130px;border-radius:50%;object-fit:cover;border:2.5px solid var(--accent);display:block;box-shadow:0 0 28px rgba(232,131,58,.3),0 0 0 4px rgba(232,131,58,.08);transition:var(--transition);}
.online-status{position:absolute;bottom:10px;right:calc(50% - 40px);width:14px;height:14px;border-radius:50%;background:var(--success);border:2.5px solid var(--bg-card);box-shadow:0 0 8px rgba(62,207,110,.6);}
.xp-rank-badge-sidebar{display:inline-flex;align-items:center;gap:5px;background:rgba(232,131,58,.08);border:1px solid rgba(232,131,58,.2);border-radius:20px;padding:4px 12px;font-size:.74rem;font-weight:600;color:var(--accent);margin-bottom:14px;}
.xp-minibar-wrap{width:100%;margin-bottom:4px;}
.xp-minibar-labels{display:flex;justify-content:space-between;font-size:.68rem;color:var(--text-muted);margin-bottom:5px;font-family:var(--mono);}
.xp-minibar-labels span:last-child{color:var(--accent);font-weight:600;}
.xp-minibar-track{height:4px;background:rgba(255,255,255,.05);border-radius:2px;overflow:hidden;}
.xp-minibar-fill{height:100%;background:linear-gradient(90deg,var(--accent-secondary),var(--accent),var(--accent-light));border-radius:2px;width:0%;transition:width 1.6s cubic-bezier(.34,1.56,.64,1);}
.xp-minibar-next{font-size:.64rem;color:var(--text-muted);text-align:right;margin-top:4px;}
.profile-name{font-size:1.25rem;font-weight:700;letter-spacing:-.5px;margin-bottom:5px;word-break:break-word;}
.profile-title{color:var(--accent);font-size:.82rem;font-weight:600;margin-bottom:12px;opacity:.9;}
.profile-bio{color:var(--text-secondary);line-height:1.7;margin-bottom:14px;font-size:.84rem;padding:0 4px;}
.profile-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;padding:14px 0;background:rgba(0,0,0,.18);border-top:1px solid var(--border-color);}
.stat{text-align:center;padding:8px 4px;position:relative;}
.stat+.stat::before{content:'';position:absolute;left:0;top:20%;height:60%;width:1px;background:var(--border-color);}
.stat-number{font-size:1.2rem;font-weight:700;color:var(--accent);margin-bottom:3px;font-family:var(--mono);}
.stat-label{font-size:.62rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;}
.opp-badge{display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap;padding:8px 14px;background:rgba(232,131,58,.06);border:1px solid rgba(232,131,58,.25);border-radius:20px;font-size:.77rem;font-weight:600;color:var(--accent);}
.action-buttons{display:flex;flex-direction:column;gap:8px;padding:0 20px 20px;}
.contact-info{background:var(--bg-card);border-radius:16px;border:1px solid var(--border-color);padding:18px 20px;box-shadow:var(--shadow);}
.contact-title{font-size:.9rem;font-weight:700;margin-bottom:14px;color:var(--accent);display:flex;align-items:center;gap:8px;}
.contact-list{list-style:none;}
.contact-item{display:flex;align-items:center;gap:10px;padding:9px 0;color:var(--text-secondary);font-size:.84rem;border-bottom:1px solid rgba(42,34,28,.5);}
.contact-item:last-child{border-bottom:none;}
.contact-item i{color:var(--accent);width:18px;flex-shrink:0;}

/* ── BUTTONS ── */
.btn{padding:10px 18px;border-radius:var(--radius-sm);font-weight:600;font-size:.82rem;border:none;display:inline-flex;align-items:center;justify-content:center;gap:7px;transition:var(--transition);white-space:nowrap;cursor:pointer;font-family:var(--font);letter-spacing:.1px;}
.btn:hover{transform:translateY(-1px);}
.btn:active{transform:translateY(0) scale(.98);}
.btn-primary{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-secondary) 100%);color:#1a1310;box-shadow:0 4px 20px rgba(232,131,58,.22);}
.btn-primary:hover{box-shadow:0 8px 28px rgba(232,131,58,.38);filter:brightness(1.06);}
.btn-secondary{background:transparent;color:var(--accent);border:1px solid rgba(232,131,58,.4);}
.btn-secondary:hover{background:rgba(232,131,58,.08);border-color:var(--accent);}
.btn-outline{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);}
.btn-outline:hover{background:var(--bg-hover);color:var(--text-primary);border-color:rgba(232,131,58,.3);}
.btn-github{background:rgba(110,118,129,.12);color:#c9d1d9;border:1px solid rgba(110,118,129,.3);gap:8px;}
.btn-github:hover{background:rgba(110,118,129,.22);border-color:rgba(110,118,129,.5);}
.btn-sm{padding:6px 13px;font-size:.76rem;border-radius:var(--radius-xs);}

/* ── MAIN ── */
.main-section{display:flex;flex-direction:column;gap:16px;}
.tabs-navigation{background:var(--bg-card);border-radius:var(--radius-sm);padding:5px;display:flex;gap:3px;overflow-x:auto;scrollbar-width:none;border:1px solid var(--border-color);box-shadow:var(--shadow);}
.tabs-navigation::-webkit-scrollbar{display:none;}
.tab-btn{flex:1;min-width:90px;padding:9px 14px;background:transparent;border:none;color:var(--text-muted);font-weight:500;border-radius:var(--radius-xs);cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap;font-size:.8rem;font-family:var(--font);}
.tab-btn:hover{color:var(--text-primary);background:rgba(255,255,255,.04);}
.tab-btn.active{background:linear-gradient(135deg,rgba(232,131,58,.15),rgba(232,131,58,.08));color:var(--accent);border:1px solid rgba(232,131,58,.18);}
.tab-content{display:none;animation:fadeTabIn .28s ease;}
.tab-content.active{display:block;}
@keyframes fadeTabIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.section-card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border-color);padding:22px;box-shadow:var(--shadow);margin-bottom:14px;transition:border-color .2s;}
.section-card:hover{border-color:rgba(232,131,58,.15);}
.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;flex-wrap:wrap;gap:10px;}
.section-title{font-size:.95rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:8px;}
.section-title i{color:var(--accent);font-size:.9rem;}

/* ── POW HERO BANNER ── */
.pow-hero{position:relative;background:linear-gradient(135deg,rgba(14,11,9,1) 0%,rgba(30,18,10,1) 50%,rgba(14,11,9,1) 100%);border:1px solid rgba(232,131,58,.22);border-radius:var(--radius);padding:20px 22px;margin-bottom:16px;overflow:hidden;}
.pow-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 80% at 100% 0%,rgba(232,131,58,.09),transparent 60%),radial-gradient(ellipse 50% 60% at 0% 100%,rgba(232,131,58,.05),transparent 50%);pointer-events:none;}
.pow-hero-tag{display:inline-flex;align-items:center;gap:5px;font-size:.6rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--accent);background:rgba(232,131,58,.1);border:1px solid rgba(232,131,58,.25);border-radius:20px;padding:3px 10px;margin-bottom:14px;font-family:var(--mono);}
.pow-hero-tag i{font-size:.65rem;}
.pow-hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;}
@media(max-width:600px){.pow-hero-stats{grid-template-columns:repeat(2,1fr);}}
.pow-hero-stat{background:rgba(0,0,0,.25);border:1px solid rgba(232,131,58,.1);border-radius:var(--radius-sm);padding:12px 10px;text-align:center;transition:border-color .2s;}
.pow-hero-stat:hover{border-color:rgba(232,131,58,.3);}
.pow-hero-stat-val{font-size:1.6rem;font-weight:700;color:var(--accent);line-height:1;font-family:var(--mono);letter-spacing:-1px;}
.pow-hero-stat-lbl{font-size:.6rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;margin-top:5px;font-family:var(--mono);}
.pow-hero-stat-sub{font-size:.65rem;color:var(--text-secondary);margin-top:3px;}
.pow-hero-rank{display:flex;align-items:center;justify-content:space-between;margin-top:14px;padding:10px 14px;background:rgba(232,131,58,.06);border-radius:var(--radius-xs);border:1px solid rgba(232,131,58,.12);}
.pow-hero-rank-info{display:flex;align-items:center;gap:8px;}
.pow-hero-rank-icon{font-size:1.4rem;line-height:1;}
.pow-hero-rank-name{font-size:.85rem;font-weight:700;color:var(--text-primary);}
.pow-hero-rank-sub{font-size:.68rem;color:var(--text-muted);}
.pow-hero-bar-wrap{flex:1;max-width:160px;margin-left:16px;}
.pow-hero-bar-track{height:5px;background:rgba(255,255,255,.06);border-radius:3px;overflow:hidden;}
.pow-hero-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent-secondary),var(--accent-light));border-radius:3px;transition:width 1.4s cubic-bezier(.34,1.56,.64,1);}
.pow-hero-bar-pct{font-size:.6rem;color:var(--text-muted);text-align:right;margin-top:3px;font-family:var(--mono);}

/* ── XP LEVEL CARD ── */
.xp-level-card{background:var(--bg-card);border-radius:var(--radius);padding:22px;border:1px solid var(--border-color);margin-bottom:14px;position:relative;overflow:hidden;box-shadow:var(--shadow);}
.xp-level-card::before{content:'';position:absolute;top:-80px;right:-80px;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(232,131,58,.07) 0%,transparent 70%);pointer-events:none;}
.xp-lc-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:12px;}
.xp-lc-subtitle{font-size:.65rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px;font-family:var(--mono);}
.xp-lc-number{font-size:3rem;font-weight:700;color:var(--accent);line-height:1;letter-spacing:-2px;font-family:var(--mono);}
.xp-lc-title{font-size:.88rem;color:var(--text-secondary);margin-top:5px;}
.xp-lc-icon{font-size:3.2rem;opacity:.8;flex-shrink:0;line-height:1;}
.xp-bar-meta{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px;}
.xp-bar-lbl{font-size:.73rem;color:var(--text-muted);}
.xp-bar-val{font-size:1.25rem;font-weight:700;color:var(--text-primary);font-family:var(--mono);}
.xp-bar-val span{font-size:.8rem;color:var(--text-muted);font-weight:400;}
.xp-bar-track{height:8px;background:rgba(255,255,255,.05);border-radius:4px;overflow:hidden;position:relative;}
.xp-bar-fill{height:100%;border-radius:4px;width:0%;background:linear-gradient(90deg,var(--accent-secondary) 0%,var(--accent) 60%,var(--accent-light) 100%);transition:width 1.6s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden;}
.xp-bar-fill::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.15) 50%,transparent 100%);animation:xpShimmer 2.5s infinite;}
@keyframes xpShimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
.xp-bar-miles{display:flex;justify-content:space-between;margin-top:5px;font-size:.62rem;color:var(--text-muted);font-family:var(--mono);}
.xp-next-row{display:flex;align-items:center;justify-content:space-between;margin-top:16px;padding:11px 14px;background:rgba(232,131,58,.05);border-radius:var(--radius-xs);border:1px solid rgba(232,131,58,.12);flex-wrap:wrap;gap:10px;}
.xp-next-info{font-size:.8rem;color:var(--text-secondary);}
.xp-next-info strong{color:var(--accent);}
.xp-next-pill{font-size:.68rem;color:var(--text-muted);background:rgba(255,255,255,.04);border:1px solid var(--border-color);border-radius:20px;padding:3px 10px;font-family:var(--mono);}
.xp-actions-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:4px;}
@media(max-width:600px){.xp-actions-grid{grid-template-columns:1fr;}}
.xp-action-item{display:flex;align-items:center;justify-content:space-between;background:var(--primary);border-radius:11px;padding:12px 14px;border:1px solid transparent;transition:border-color .2s,transform .15s;}
.xp-action-item:hover{border-color:rgba(230,126,34,.35);transform:translateY(-1px);}
.xp-action-left{display:flex;align-items:center;gap:10px;}
.xp-action-icon{font-size:1.15rem;width:36px;height:36px;background:rgba(255,255,255,.05);border-radius:9px;display:flex;align-items:center;justify-content:center;}
.xp-action-name{font-size:.82rem;font-weight:600;color:var(--text-primary);}
.xp-action-desc{font-size:.7rem;color:var(--text-muted);margin-top:1px;}
.xp-action-reward{font-size:.82rem;font-weight:800;color:var(--accent);white-space:nowrap;}
.xp-history-list{display:flex;flex-direction:column;gap:8px;margin-top:4px;}
.xp-history-item{display:flex;align-items:center;gap:12px;padding:10px 13px;background:var(--primary);border-radius:10px;animation:xpSlideIn .4s ease both;}
@keyframes xpSlideIn{from{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:translateX(0)}}
.xp-hdot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.xp-htext{flex:1;font-size:.82rem;color:var(--text-secondary);}
.xp-htime{font-size:.7rem;color:var(--text-muted);white-space:nowrap;}
.xp-hgain{font-size:.82rem;font-weight:700;color:var(--accent);white-space:nowrap;}
.xp-ranks-list{display:flex;flex-direction:column;gap:6px;margin-top:4px;}
.xp-rank-row{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:10px;background:var(--primary);border:1px solid transparent;transition:border-color .2s;}
.xp-rank-row.xp-current{border-color:rgba(230,126,34,.4);background:rgba(230,126,34,.07);}
.xp-rank-row.xp-locked{opacity:.4;}
.xp-rank-emoji{font-size:1.3rem;width:32px;text-align:center;flex-shrink:0;}
.xp-rank-info{flex:1;}
.xp-rank-name{font-size:.82rem;font-weight:600;color:var(--text-primary);}
.xp-rank-row.xp-current .xp-rank-name{color:var(--accent);}
.xp-rank-req{font-size:.7rem;color:var(--text-muted);margin-top:1px;}
.xp-rank-pill{font-size:.65rem;padding:3px 9px;border-radius:20px;font-weight:700;white-space:nowrap;}
.xp-p-current{background:rgba(230,126,34,.15);color:var(--accent);border:1px solid rgba(230,126,34,.3);}
.xp-p-unlocked{background:rgba(46,204,113,.1);color:#2ecc71;border:1px solid rgba(46,204,113,.2);}
.xp-p-locked{background:rgba(255,255,255,.04);color:var(--text-muted);border:1px solid var(--border-color);}
.xp-history-total{font-size:.7rem;color:var(--accent);font-weight:700;background:rgba(230,126,34,.1);border-radius:20px;padding:3px 10px;}
.xp-section-subheader{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;}
.xp-toast{position:fixed;bottom:24px;right:20px;background:var(--bg-card);border:1px solid rgba(232,131,58,.45);border-radius:var(--radius);padding:13px 18px;display:flex;align-items:center;gap:12px;font-size:.84rem;color:var(--text-primary);box-shadow:0 8px 32px rgba(0,0,0,.5);transform:translateY(90px);opacity:0;transition:transform .4s cubic-bezier(.34,1.56,.64,1),opacity .3s;z-index:9999;pointer-events:none;}
.xp-toast.show{transform:translateY(0);opacity:1;}
.xp-toast-icon{font-size:1.3rem;}
.xp-toast-xp{font-weight:700;color:var(--accent);font-family:var(--mono);}
.xp-toast-rsn{font-size:.72rem;color:var(--text-muted);margin-top:1px;}

/* ── GITHUB SECTION ── */
.github-connect-banner{background:linear-gradient(135deg,rgba(13,17,23,.9),rgba(22,27,34,.9));border:1px solid rgba(110,118,129,.25);border-radius:var(--radius);padding:28px 24px;text-align:center;margin-bottom:14px;}
.github-connect-icon{font-size:3rem;margin-bottom:12px;color:#c9d1d9;}
.github-connect-title{font-size:1.1rem;font-weight:700;margin-bottom:6px;color:#e6edf3;}
.github-connect-desc{font-size:.84rem;color:#8b949e;margin-bottom:20px;line-height:1.6;}
.github-username-input-wrap{display:flex;gap:10px;max-width:380px;margin:0 auto;}
.github-user-header{display:flex;align-items:center;gap:16px;padding:18px;background:rgba(13,17,23,.7);border:1px solid rgba(110,118,129,.2);border-radius:var(--radius);margin-bottom:18px;}
.github-user-avatar{width:56px;height:56px;border-radius:50%;border:2px solid rgba(110,118,129,.3);}
.github-user-info{flex:1;}
.github-user-name{font-size:1rem;font-weight:700;color:#e6edf3;margin-bottom:2px;}
.github-user-login{font-size:.8rem;color:#8b949e;font-family:var(--mono);}
.github-user-stats{display:flex;gap:16px;margin-top:8px;}
.github-user-stat{font-size:.76rem;color:#8b949e;display:flex;align-items:center;gap:5px;}
.github-user-stat strong{color:#c9d1d9;}
.github-repos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;}
.github-repo-card{background:rgba(13,17,23,.7);border:1px solid rgba(110,118,129,.18);border-radius:var(--radius-sm);padding:16px;transition:var(--transition);cursor:pointer;text-decoration:none;display:block;}
.github-repo-card:hover{border-color:rgba(110,118,129,.4);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.4);}
.github-repo-name{font-size:.9rem;font-weight:600;color:#58a6ff;margin-bottom:6px;font-family:var(--mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.github-repo-desc{font-size:.78rem;color:#8b949e;line-height:1.5;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.4em;}
.github-repo-footer{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.github-repo-lang{display:flex;align-items:center;gap:5px;font-size:.73rem;color:#8b949e;}
.github-repo-lang-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.github-repo-stat{display:flex;align-items:center;gap:4px;font-size:.73rem;color:#8b949e;}
.github-repo-topic{padding:2px 8px;background:rgba(56,139,253,.12);border:1px solid rgba(56,139,253,.2);border-radius:20px;font-size:.66rem;color:#58a6ff;font-family:var(--mono);}
.github-pinned-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.8px;color:#e3b341;background:rgba(227,179,65,.1);border:1px solid rgba(227,179,65,.2);border-radius:20px;padding:2px 8px;display:inline-flex;align-items:center;gap:4px;margin-bottom:12px;}
.github-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.github-filter-tabs{display:flex;gap:6px;flex-wrap:wrap;}
.github-filter-btn{padding:5px 12px;border-radius:20px;font-size:.74rem;font-weight:500;background:transparent;border:1px solid var(--border-color);color:var(--text-muted);cursor:pointer;transition:var(--transition);font-family:var(--font);}
.github-filter-btn.active,.github-filter-btn:hover{border-color:rgba(110,118,129,.4);color:#c9d1d9;background:rgba(110,118,129,.08);}
.github-loading{text-align:center;padding:32px;color:#8b949e;font-size:.86rem;}
.github-loading i{font-size:2rem;margin-bottom:10px;display:block;animation:spin .8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg)}}
.github-empty{text-align:center;padding:32px;color:#8b949e;}
.github-contributions-wrap{margin-top:18px;}
.github-contrib-title{font-size:.82rem;font-weight:600;color:#8b949e;margin-bottom:10px;font-family:var(--mono);}
.github-total-stat{display:flex;align-items:center;gap:8px;padding:10px 14px;background:rgba(13,17,23,.7);border:1px solid rgba(110,118,129,.15);border-radius:var(--radius-xs);font-size:.82rem;color:#8b949e;}
.github-total-stat strong{color:#c9d1d9;font-family:var(--mono);}

/* ── AVATAR UPLOAD MODAL ── */
.avatar-modal{position:fixed;inset:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:9998;opacity:0;pointer-events:none;transition:opacity .2s;backdrop-filter:blur(6px);}
.avatar-modal.active{opacity:1;pointer-events:all;}
.avatar-modal-box{background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;padding:28px;max-width:400px;width:90%;text-align:center;box-shadow:var(--shadow-lg);}
.avatar-preview-wrap{width:120px;height:120px;margin:0 auto 20px;border-radius:50%;overflow:hidden;border:2px solid var(--accent);background:var(--primary);}
.avatar-preview-wrap img{width:100%;height:100%;object-fit:cover;}
.avatar-drop-zone{border:2px dashed var(--border-color);border-radius:var(--radius-sm);padding:28px;cursor:pointer;transition:var(--transition);margin-bottom:16px;}
.avatar-drop-zone:hover,.avatar-drop-zone.drag-over{border-color:var(--accent);background:rgba(232,131,58,.05);}
.avatar-drop-zone i{font-size:2rem;color:var(--text-muted);margin-bottom:8px;display:block;}
.avatar-drop-zone p{font-size:.82rem;color:var(--text-muted);}
.avatar-drop-zone span{font-size:.76rem;color:var(--accent);font-weight:600;}

/* ── CONTACT CARD UPGRADE ── */
.contact-info{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border-color);padding:18px 20px;box-shadow:var(--shadow);}
.contact-title{font-size:.88rem;font-weight:700;margin-bottom:14px;color:var(--accent);display:flex;align-items:center;gap:8px;}
.contact-list{list-style:none;}
.contact-item{display:flex;align-items:center;gap:10px;padding:9px 0;color:var(--text-secondary);font-size:.82rem;border-bottom:1px solid rgba(37,29,22,.4);}
.contact-item:last-child{border-bottom:none;}
.contact-item i{color:var(--accent);width:18px;flex-shrink:0;opacity:.8;}

/* ── POSTS ── */
.posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;margin-top:14px;}
@media(max-width:768px){.posts-grid{grid-template-columns:1fr;gap:12px;}}
.post-card{background:var(--primary);border-radius:14px;border:1px solid var(--border-color);overflow:hidden;transition:var(--transition);}
.post-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:rgba(230,126,34,.2);}
.project-card{border-left:3px solid var(--accent);}
.post-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border-color);gap:10px;}
.post-user-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0;}
.post-user-avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;border:2px solid var(--accent);flex-shrink:0;}
.post-user-details{flex:1;min-width:0;}
.post-user-details h4{font-size:.86rem;font-weight:700;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.post-time{font-size:.7rem;color:var(--text-muted);}
.post-type-badge{padding:3px 9px;border-radius:20px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;flex-shrink:0;}
.badge-text{background:rgba(52,152,219,.18);color:var(--info);}
.badge-image{background:rgba(46,204,113,.18);color:var(--success);}
.badge-video{background:rgba(231,76,60,.18);color:var(--danger);}
.badge-audio{background:rgba(155,89,182,.18);color:#9b59b6;}
.badge-reel{background:rgba(241,196,15,.18);color:var(--warning);}
.badge-project{background:rgba(230,126,34,.18);color:var(--accent);}
.post-content{padding:14px 16px;}
.post-text{line-height:1.65;margin-bottom:12px;font-size:.88rem;word-break:break-word;color:var(--text-primary);}
.post-media-container{margin:12px 0;border-radius:10px;overflow:hidden;max-height:400px;}
.post-image{width:100%;max-height:400px;object-fit:contain;border-radius:10px;display:block;}
.post-video{width:100%;max-height:400px;border-radius:10px;background:#000;}
.video-container{position:relative;border-radius:10px;overflow:hidden;background:#000;}
.video-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.3);}
.play-btn{width:50px;height:50px;border-radius:50%;background:rgba(255,255,255,.92);border:none;color:#1b140f;font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:var(--transition);}
.play-btn:hover{transform:scale(1.12);background:white;}
.project-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px;flex-wrap:wrap;gap:8px;}
.project-title{font-size:1.05rem;font-weight:800;color:var(--accent);margin-bottom:3px;word-break:break-word;}
.project-status{padding:3px 9px;border-radius:20px;font-size:.7rem;font-weight:700;white-space:nowrap;}
.status-completed{background:rgba(46,204,113,.18);color:var(--success);}
.status-in-progress{background:rgba(52,152,219,.18);color:var(--info);}
.status-planning{background:rgba(241,196,15,.18);color:var(--warning);}
.status-on-hold{background:rgba(231,76,60,.18);color:var(--danger);}
.project-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin:14px 0;}
.project-detail{display:flex;flex-direction:column;}
.detail-label{font-size:.68rem;color:var(--text-muted);margin-bottom:3px;text-transform:uppercase;letter-spacing:.4px;}
.detail-value{font-weight:700;color:var(--text-primary);font-size:.86rem;}
.project-skills{display:flex;flex-wrap:wrap;gap:6px;margin:10px 0;}
.skill-chip{padding:4px 10px;background:rgba(230,126,34,.1);border:1px solid rgba(230,126,34,.25);border-radius:20px;font-size:.7rem;color:var(--accent);white-space:nowrap;}
.audio-player{background:var(--bg-card);border-radius:10px;padding:14px;display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.audio-icon{font-size:1.2rem;color:var(--accent);flex-shrink:0;}
.audio-info{flex:1;min-width:0;}
.audio-title{font-weight:700;margin-bottom:3px;font-size:.86rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.audio-artist{font-size:.74rem;color:var(--text-muted);}
.post-footer{padding:10px 16px;border-top:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;}
.post-stats{display:flex;gap:14px;flex:1;}
.post-stat{display:flex;align-items:center;gap:5px;color:var(--text-secondary);font-size:.82rem;cursor:pointer;transition:var(--transition);white-space:nowrap;}
.post-stat:hover{color:var(--accent);}
.post-actions{display:flex;gap:10px;}
.post-action-btn{background:none;border:none;color:var(--text-secondary);font-size:.86rem;padding:5px;border-radius:7px;transition:var(--transition);display:flex;align-items:center;gap:4px;}
.post-action-btn:hover{background:rgba(255,255,255,.07);color:var(--text-primary);}
.post-filters{display:flex;gap:7px;margin-bottom:14px;flex-wrap:wrap;}
.filter-btn{padding:5px 12px;background:var(--primary);border:1px solid var(--border-color);border-radius:20px;color:var(--text-secondary);font-size:.78rem;font-weight:600;cursor:pointer;transition:var(--transition);white-space:nowrap;font-family:var(--font);}
.filter-btn:hover{background:var(--bg-hover);color:var(--text-primary);}
.filter-btn.active{background:var(--accent);color:#1b140f;border-color:var(--accent);}

/* ── PRO INFO ── */
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px 24px;margin-bottom:20px;}
@media(max-width:600px){.form-grid{grid-template-columns:1fr;}}
.form-group{margin-bottom:14px;}
.form-label{display:block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:5px;}
.experience-level{display:flex;align-items:center;gap:12px;margin-top:6px;flex-wrap:wrap;}
.level-badge{padding:5px 12px;background:var(--primary);border-radius:20px;font-weight:700;color:var(--accent);font-size:.8rem;border:1px solid rgba(230,126,34,.25);}
.rating-stars{display:flex;gap:3px;margin-top:5px;}
.star{font-size:1.1rem;color:var(--border-color);cursor:pointer;transition:var(--transition);}
.star.active{color:var(--accent);}
.progress-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-top:18px;}
.progress-stat{background:var(--primary);padding:18px 16px;border-radius:13px;border-left:3px solid var(--accent);transition:var(--transition);}
.progress-stat:hover{transform:translateY(-2px);box-shadow:var(--shadow);}
.progress-stat-value{font-size:2rem;font-weight:800;color:var(--accent);margin-bottom:6px;}
.progress-stat-label{font-size:.82rem;color:var(--text-secondary);margin-bottom:3px;}
.progress-stat-desc{font-size:.72rem;color:var(--text-muted);}

/* ── SKILLS ── */
.skills-container{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px;}
.skill-tag{padding:7px 14px;background:linear-gradient(135deg,var(--primary),var(--primary-light));border-radius:40px;font-size:.82rem;font-weight:600;color:var(--accent);border:1px solid rgba(230,126,34,.2);transition:var(--transition);white-space:nowrap;}
.skill-tag:hover{transform:translateY(-2px);box-shadow:0 5px 15px rgba(230,126,34,.18);}
.languages-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:12px;margin-top:14px;}
.language-item{background:var(--primary);padding:14px;border-radius:12px;border-left:3px solid var(--accent);}
.language-name{font-weight:700;margin-bottom:3px;font-size:.88rem;}
.language-level{color:var(--text-muted);font-size:.78rem;}
.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-top:16px;}
.setting-tile{background:var(--primary);padding:16px;border-radius:13px;border:1px solid var(--border-color);transition:var(--transition);}
.setting-tile:hover{border-color:rgba(230,126,34,.2);}
.setting-tile-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;}
.setting-tile-header i{color:var(--accent);}
.setting-tile-label{font-weight:700;font-size:.88rem;}

/* ── MODALS ── */
.modal{display:none;position:fixed;inset:0;background:rgba(10,6,3,.95);backdrop-filter:blur(6px);z-index:1000;align-items:center;justify-content:center;padding:16px;overflow-y:auto;}
.modal.active{display:flex;animation:modalIn .3s ease;}
@keyframes modalIn{from{opacity:0}to{opacity:1}}
.modal-content{background:var(--bg-card);border-radius:20px;max-width:780px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);border:1px solid var(--border-color);animation:modalCardIn .3s cubic-bezier(.4,0,.2,1);}
@keyframes modalCardIn{from{opacity:0;transform:scale(.95) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}
.modal-header{padding:18px 22px;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background:var(--bg-card);border-radius:20px 20px 0 0;z-index:1;}
.modal-title{font-size:1.1rem;font-weight:800;color:var(--accent);}
.modal-close{background:none;border:none;color:var(--text-secondary);font-size:1.3rem;cursor:pointer;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:var(--transition);}
.modal-close:hover{background:rgba(255,255,255,.08);color:var(--text-primary);}
.modal-body{padding:22px;}
.form-input,.form-textarea,.form-select{width:100%;padding:10px 14px;border:1.5px solid var(--border-color);border-radius:11px;font-size:.88rem;background:var(--primary);color:var(--text-primary);font-family:var(--font);transition:var(--transition);}
.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:rgba(230,126,34,.55);box-shadow:0 0 0 3px rgba(230,126,34,.1);}
.form-textarea{min-height:90px;resize:vertical;}
.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted);}
@media(max-width:768px){.form-input,.form-textarea,.form-select{font-size:16px!important;}}

/* ── LOADING / EMPTY ── */
.loading{text-align:center;padding:40px;color:var(--text-secondary);}
.loading-spinner{width:36px;height:36px;border:3px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;animation:spin .9s linear infinite;margin:0 auto 14px;}
@keyframes spin{to{transform:rotate(360deg)}}
.empty-state{text-align:center;padding:40px 16px;color:var(--text-muted);}
.empty-state i{font-size:2.4rem;margin-bottom:14px;color:var(--border-color);display:block;}
.empty-state h3{font-size:1rem;margin-bottom:8px;color:var(--text-secondary);}
.empty-state p{font-size:.84rem;}

/* ── POPUP ── */
.popup-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);display:flex;justify-content:center;align-items:center;z-index:9999;padding:20px;}
.popup-content{background:var(--bg-card);padding:28px;border-radius:16px;text-align:center;max-width:380px;width:100%;box-shadow:var(--shadow-lg);border:1px solid var(--border-color);}
.popup-content h2{margin-bottom:10px;color:var(--text-primary);font-size:1.2rem;}
.popup-content p{margin-bottom:20px;color:var(--text-secondary);font-size:.88rem;}
.popup-content button{margin:6px;padding:10px 20px;border:none;border-radius:9px;cursor:pointer;font-weight:700;transition:var(--transition);font-family:var(--font);}
#loginBtn{background:linear-gradient(135deg,var(--accent),var(--accent-secondary));color:#1b140f;}
#closePopup{background:var(--primary);color:var(--text-secondary);}

/* ── MOBILE NAV ── */
.mobile-menu-btn{display:none;background:transparent;color:var(--text-secondary);font-size:1.3rem;padding:6px;border-radius:8px;}
.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--bg-card);border-top:1px solid var(--border-color);padding:10px 12px;z-index:200;padding-bottom:max(10px,env(safe-area-inset-bottom));}
.mobile-nav-content{display:flex;justify-content:space-around;align-items:center;}
.mobile-nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--text-muted);font-size:.68rem;padding:6px 8px;min-width:56px;text-align:center;text-decoration:none;transition:var(--transition);background:none;border:none;cursor:pointer;font-family:var(--font);}
.mobile-nav-item.active{color:var(--accent);}
.mobile-nav-item i{font-size:1.1rem;}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  .mobile-menu-btn{display:block;}
  .mobile-nav{display:block;}
  .tabs-navigation{display:none!important;}
  .desktop-only{display:none;}
  .mobile-only{display:block;}
  body{padding-bottom:80px;}
  .container{padding:0 10px;}
  .section-card{padding:16px;}
  .progress-stats{grid-template-columns:1fr 1fr;gap:10px;}
  .modal-content{border-radius:14px;}
}
@media(min-width:769px){.mobile-only{display:none;}}
@media(max-width:480px){
  .profile-stats{gap:6px;padding:12px 8px;}
  .stat-number{font-size:1.05rem;}
  .progress-stats{grid-template-columns:1fr;}
  .posts-grid{margin-left:-4px;margin-right:-4px;width:calc(100% + 8px);}
}
@media(hover:none) and (pointer:coarse){
  .post-card:hover{transform:none;}
  .post-action-btn{min-height:44px;min-width:44px;}
  .filter-btn{min-height:36px;}
  .tab-btn{min-height:44px;}
}
@supports(padding:max(0px)){
  @media(max-width:768px){
    .mobile-nav{padding-left:max(12px,env(safe-area-inset-left));padding-right:max(12px,env(safe-area-inset-right));}
    .container{padding-left:max(10px,env(safe-area-inset-left));padding-right:max(10px,env(safe-area-inset-right));}
  }
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;}}

/* ── GITHUB RESPONSIVE ── */
@media(max-width:768px){
  .github-user-header{flex-wrap:wrap;gap:12px;}
  .github-user-header .btn{width:100%;justify-content:center;}
  .github-user-stats{flex-wrap:wrap;gap:8px;}
  .github-repos-grid{grid-template-columns:1fr;}
  .github-section-header{flex-direction:column;align-items:flex-start;gap:10px;}
  .github-filter-tabs{width:100%;overflow-x:auto;scrollbar-width:none;padding-bottom:2px;}
  .github-filter-tabs::-webkit-scrollbar{display:none;}
  .github-username-input-wrap{flex-direction:column;}
  .github-username-input-wrap .btn{width:100%;}
  .github-connect-banner{padding:20px 16px;}
}
@media(max-width:480px){
  .github-user-header{padding:14px;}
  .github-user-avatar{width:46px;height:46px;}
  .github-user-name{font-size:.92rem;}
  .github-repo-card{padding:14px;}
}

/* ── PORTFOLIO GENERATED ── */
.pf-hero{background:linear-gradient(135deg,rgba(232,131,58,.08) 0%,rgba(10,8,6,0) 60%);border:1px solid rgba(232,131,58,.15);border-radius:var(--radius);padding:28px 24px;margin-bottom:14px;position:relative;overflow:hidden;}
.pf-hero::before{content:'';position:absolute;top:-60px;right:-60px;width:220px;height:220px;background:radial-gradient(circle,rgba(232,131,58,.1),transparent 70%);pointer-events:none;}
.pf-hero-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.pf-hero-name{font-size:1.6rem;font-weight:700;letter-spacing:-.5px;line-height:1.2;margin-bottom:6px;}
.pf-hero-title{color:var(--accent);font-size:.9rem;font-weight:500;margin-bottom:10px;}
.pf-hero-bio{font-size:.86rem;color:var(--text-secondary);line-height:1.7;max-width:560px;}
.pf-hero-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px;}
.pf-hero-stats{display:flex;gap:20px;margin-top:20px;padding-top:18px;border-top:1px solid var(--border-color);flex-wrap:wrap;}
.pf-hero-stat{text-align:center;}
.pf-hero-stat-num{font-size:1.5rem;font-weight:700;color:var(--accent);font-family:var(--mono);}
.pf-hero-stat-lbl{font-size:.65rem;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);}
.pf-section-label{font-size:.65rem;text-transform:uppercase;letter-spacing:2px;color:var(--text-muted);font-family:var(--mono);margin-bottom:14px;display:flex;align-items:center;gap:8px;}
.pf-section-label::after{content:'';flex:1;height:1px;background:var(--border-color);}
.pf-projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;}
.pf-project-card{background:var(--primary);border:1px solid var(--border-color);border-radius:var(--radius);overflow:hidden;transition:var(--transition);cursor:pointer;position:relative;}
.pf-project-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:rgba(232,131,58,.25);}
.pf-project-card.featured{border-color:rgba(232,131,58,.3);background:linear-gradient(135deg,rgba(232,131,58,.04),var(--primary));}
.pf-project-card.featured::before{content:'★ Mis en avant';position:absolute;top:12px;right:12px;font-size:.62rem;color:var(--accent);background:rgba(232,131,58,.12);border:1px solid rgba(232,131,58,.25);border-radius:20px;padding:2px 9px;font-weight:600;letter-spacing:.3px;}
.pf-project-cover{width:100%;height:140px;object-fit:cover;display:block;background:linear-gradient(135deg,var(--primary-light),var(--bg-card));}
.pf-project-cover-placeholder{width:100%;height:140px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-light),rgba(232,131,58,.05));font-size:2.5rem;color:rgba(232,131,58,.3);}
.pf-project-body{padding:16px;}
.pf-project-status-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.pf-project-name{font-size:.95rem;font-weight:700;color:var(--text-primary);margin-bottom:6px;line-height:1.3;}
.pf-project-desc{font-size:.8rem;color:var(--text-secondary);line-height:1.6;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.pf-project-tags{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:12px;}
.pf-project-tag{padding:3px 9px;background:rgba(232,131,58,.08);border:1px solid rgba(232,131,58,.18);border-radius:20px;font-size:.66rem;color:var(--accent);font-family:var(--mono);}
.pf-project-footer{display:flex;align-items:center;justify-content:space-between;padding-top:10px;border-top:1px solid var(--border-color);}
.pf-project-meta{font-size:.72rem;color:var(--text-muted);display:flex;align-items:center;gap:6px;}
.pf-project-links{display:flex;gap:6px;}
.pf-project-link{width:28px;height:28px;border-radius:var(--radius-xs);background:transparent;border:1px solid var(--border-color);color:var(--text-muted);display:flex;align-items:center;justify-content:center;font-size:.76rem;transition:var(--transition);text-decoration:none;}
.pf-project-link:hover{border-color:var(--accent);color:var(--accent);}
.pf-skills-cloud{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px;}
.pf-skill-pill{padding:6px 14px;background:rgba(255,255,255,.04);border:1px solid var(--border-color);border-radius:30px;font-size:.78rem;color:var(--text-secondary);transition:var(--transition);display:flex;align-items:center;gap:6px;}
.pf-skill-pill:hover{border-color:rgba(232,131,58,.3);color:var(--accent);}
.pf-skill-pill-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);flex-shrink:0;}
.pf-export-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);margin-bottom:14px;flex-wrap:wrap;gap:10px;}
.pf-export-label{font-size:.8rem;color:var(--text-secondary);display:flex;align-items:center;gap:8px;}
.pf-sort-bar{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap;}
.pf-sort-btn{padding:5px 12px;border-radius:20px;font-size:.74rem;font-weight:500;background:transparent;border:1px solid var(--border-color);color:var(--text-muted);cursor:pointer;transition:var(--transition);font-family:var(--font);}
.pf-sort-btn.active,.pf-sort-btn:hover{border-color:rgba(232,131,58,.35);color:var(--accent);background:rgba(232,131,58,.06);}
@media(max-width:768px){
  .pf-projects-grid{grid-template-columns:1fr;}
  .pf-hero{padding:20px 16px;}
  .pf-hero-name{font-size:1.3rem;}
  .pf-hero-stats{gap:14px;}
  .pf-export-bar{flex-direction:column;align-items:flex-start;}
}
@media(max-width:480px){
  .pf-hero-actions{flex-direction:column;}
  .pf-hero-actions .btn{width:100%;justify-content:center;}
}

/* ─── ROOT TOKENS ─── */
    :root {
      --primary-dark: #0e0b09 !important;
      --primary:      #141110 !important;
      --primary-light:#1c1814 !important;
      --accent:       #e07b35 !important;
      --accent-light: #f09050 !important;
      --accent-secondary: #c96820 !important;
      --accent-glow:  rgba(224,123,53,.16) !important;
      --bg-dark:      #0e0b09 !important;
      --bg-card:      #1c1814 !important;
      --bg-hover:     #221e19 !important;
      --text-primary: #ede0cc !important;
      --text-secondary: #c8b8a2 !important;
      --text-muted:   #7a6a58 !important;
      --border-color: #2e2520 !important;
      --border-glow:  rgba(224,123,53,.22) !important;
      --shadow:       0 8px 32px rgba(0,0,0,.55) !important;
      --shadow-lg:    0 24px 56px rgba(0,0,0,.65) !important;
      --shadow-glow:  0 0 40px rgba(224,123,53,.1) !important;
      --font:         'DM Sans', sans-serif !important;
      --head:         'Syne', system-ui, sans-serif !important;
    }

    html, body {
      background: var(--bg-dark) !important;
      background-image: radial-gradient(ellipse 80% 50% at 50% -20%, rgba(224,123,53,.05), transparent) !important;
      color: var(--text-primary) !important;
      font-family: var(--font) !important;
    }

    /* ─── DISPLAY TYPOGRAPHY (Syne) ─── */
    .profile-name, .pf-hero-name, .section-title, .contact-title,
    .sheet-verdict, .modal-title, h1, h2 {
      font-family: var(--head) !important;
      font-weight: 700 !important;
    }

    /* ─── HEADER ─── */
    .header {
      background: rgba(14,11,9,.88) !important;
      border-bottom: 1px solid rgba(46,37,32,.85) !important;
    }
    .logo { color: var(--text-primary) !important; font-family: 'Syne', sans-serif !important; }
    .logo span { color: var(--accent) !important; }
    .header-back {
      background: var(--bg-card) !important;
      border: 1px solid var(--border-color) !important;
      color: var(--text-muted) !important;
    }
    .header-back:hover { color: var(--text-primary) !important; border-color: var(--border-glow) !important; }
    .header-btn {
      background: transparent !important;
      border: 1px solid transparent !important;
      color: var(--text-muted) !important;
    }
    .header-btn:hover { background: rgba(255,255,255,.05) !important; color: var(--text-primary) !important; border-color: var(--border-color) !important; }

    /* ─── PROFILE CARD ─── */
    .profile-card {
      background: var(--bg-card) !important;
      border: 1px solid var(--border-color) !important;
      border-radius: 20px !important;
      box-shadow: var(--shadow), var(--shadow-glow) !important;
    }
    .avatar-img {
      border: 2.5px solid var(--accent) !important;
      box-shadow: 0 0 28px rgba(224,123,53,.3), 0 0 0 4px rgba(224,123,53,.08) !important;
    }
    .xp-ring-track { stroke: rgba(224,123,53,.1) !important; }
    .xp-level-pip { background: linear-gradient(135deg, var(--accent), var(--accent-secondary)) !important; color: #1a1310 !important; }
    .xp-rank-badge-sidebar {
      background: rgba(224,123,53,.08) !important;
      border: 1px solid rgba(224,123,53,.2) !important;
      color: var(--accent) !important;
    }
    .xp-minibar-track { background: rgba(255,255,255,.05) !important; }
    .xp-minibar-fill { background: linear-gradient(90deg, var(--accent-secondary), var(--accent), var(--accent-light)) !important; }
    .profile-name { color: var(--text-primary) !important; }
    .profile-title { color: var(--accent) !important; }
    .profile-bio { color: var(--text-secondary) !important; }
    .profile-stats {
      background: rgba(0,0,0,.18) !important;
      border-top: 1px solid var(--border-color) !important;
    }
    .stat-number { color: var(--accent) !important; }
    .stat-label { color: var(--text-muted) !important; }
    .stat::before { background: var(--border-color) !important; }
    .opp-badge {
      background: rgba(224,123,53,.06) !important;
      border: 1px solid rgba(224,123,53,.25) !important;
      color: var(--accent) !important;
    }

    /* ─── CONTACT CARD ─── */
    .contact-info {
      background: var(--bg-card) !important;
      border: 1px solid var(--border-color) !important;
      border-radius: 16px !important;
    }
    .contact-title { color: var(--accent) !important; }
    .contact-item { color: var(--text-secondary) !important; border-bottom: 1px solid rgba(46,37,32,.5) !important; }
    .contact-item i { color: var(--accent) !important; }

    /* ─── BUTTONS ─── */
    .btn-primary {
      background: linear-gradient(135deg, var(--accent) 0%, var(--accent-secondary) 100%) !important;
      color: #1a1310 !important;
      box-shadow: 0 4px 20px rgba(224,123,53,.22) !important;
    }
    .btn-primary:hover { box-shadow: 0 8px 28px rgba(224,123,53,.38) !important; filter: brightness(1.06) !important; }
    .btn-secondary { background: transparent !important; color: var(--accent) !important; border: 1px solid rgba(224,123,53,.4) !important; }
    .btn-secondary:hover { background: rgba(224,123,53,.08) !important; border-color: var(--accent) !important; }
    .btn-outline { background: transparent !important; color: var(--text-secondary) !important; border: 1px solid var(--border-color) !important; }
    .btn-outline:hover { background: var(--bg-hover) !important; color: var(--text-primary) !important; border-color: rgba(224,123,53,.3) !important; }
    .btn-github { background: rgba(110,118,129,.12) !important; color: #c9d1d9 !important; border: 1px solid rgba(110,118,129,.3) !important; }
    .btn-github:hover { background: rgba(110,118,129,.22) !important; border-color: rgba(110,118,129,.5) !important; }

    /* ─── TABS ─── */
    .tabs-navigation {
      background: var(--bg-card) !important;
      border: 1px solid var(--border-color) !important;
      border-radius: 10px !important;
    }
    .tab-btn { color: var(--text-muted) !important; font-family: var(--font) !important; }
    .tab-btn:hover { color: var(--text-primary) !important; background: rgba(255,255,255,.04) !important; }
    .tab-btn.active {
      background: linear-gradient(135deg, rgba(224,123,53,.15), rgba(224,123,53,.08)) !important;
      color: var(--accent) !important;
      border: 1px solid rgba(224,123,53,.18) !important;
    }

    /* ─── SECTION CARDS ─── */
    .section-card {
      background: var(--bg-card) !important;
      border: 1px solid var(--border-color) !important;
      border-radius: 16px !important;
    }
    .section-card:hover { border-color: rgba(224,123,53,.15) !important; }
    .section-title { color: var(--text-primary) !important; }
    .section-title i { color: var(--accent) !important; }

    /* ─── XP LEVEL CARD ─── */
    .xp-level-card {
      background: var(--bg-card) !important;
      border: 1px solid var(--border-color) !important;
    }
    .xp-lc-number { color: var(--accent) !important; }
    .xp-lc-title { color: var(--text-secondary) !important; }
    .xp-lc-subtitle { color: var(--text-muted) !important; }
    .xp-bar-track { background: rgba(255,255,255,.05) !important; }
    .xp-bar-fill { background: linear-gradient(90deg, var(--accent-secondary) 0%, var(--accent) 60%, var(--accent-light) 100%) !important; }
    .xp-bar-lbl { color: var(--text-muted) !important; }
    .xp-bar-val { color: var(--text-primary) !important; }
    .xp-bar-val span { color: var(--text-muted) !important; }
    .xp-bar-miles { color: var(--text-muted) !important; }
    .xp-next-row {
      background: rgba(224,123,53,.05) !important;
      border: 1px solid rgba(224,123,53,.12) !important;
    }
    .xp-next-info { color: var(--text-secondary) !important; }
    .xp-next-info strong { color: var(--accent) !important; }
    .xp-next-pill { color: var(--text-muted) !important; background: rgba(255,255,255,.04) !important; border: 1px solid var(--border-color) !important; }
    .xp-action-item { background: var(--primary-light) !important; }
    .xp-action-item:hover { border-color: rgba(224,123,53,.35) !important; }
    .xp-action-icon { background: rgba(255,255,255,.05) !important; }
    .xp-action-name { color: var(--text-primary) !important; }
    .xp-action-desc { color: var(--text-muted) !important; }
    .xp-action-reward { color: var(--accent) !important; }
    .xp-history-item { background: var(--primary-light) !important; }
    .xp-htext { color: var(--text-secondary) !important; }
    .xp-htime { color: var(--text-muted) !important; }
    .xp-hgain { color: var(--accent) !important; }
    .xp-rank-row { background: var(--primary-light) !important; }
    .xp-rank-row.xp-current { border-color: rgba(224,123,53,.4) !important; background: rgba(224,123,53,.07) !important; }
    .xp-rank-row.xp-current .xp-rank-name { color: var(--accent) !important; }
    .xp-rank-name { color: var(--text-primary) !important; }
    .xp-rank-req { color: var(--text-muted) !important; }
    .xp-p-current { background: rgba(224,123,53,.15) !important; color: var(--accent) !important; border: 1px solid rgba(224,123,53,.3) !important; }
    .xp-history-total { color: var(--accent) !important; background: rgba(224,123,53,.1) !important; }
    .xp-toast {
      background: var(--bg-card) !important;
      border: 1px solid rgba(224,123,53,.45) !important;
    }

    /* ─── PORTFOLIO ─── */
    .pf-hero {
      background: linear-gradient(135deg, rgba(224,123,53,.08) 0%, rgba(14,11,9,0) 60%) !important;
      border: 1px solid rgba(224,123,53,.15) !important;
    }
    .pf-hero-name { color: var(--text-primary) !important; }
    .pf-hero-title { color: var(--accent) !important; }
    .pf-hero-bio { color: var(--text-secondary) !important; }
    .pf-hero-stats { border-top: 1px solid var(--border-color) !important; }
    .pf-hero-stat-num { color: var(--accent) !important; }
    .pf-hero-stat-lbl { color: var(--text-muted) !important; }
    .pf-section-label { color: var(--text-muted) !important; }
    .pf-section-label::after { background: var(--border-color) !important; }
    .pf-project-card {
      background: var(--primary-light) !important;
      border: 1px solid var(--border-color) !important;
    }
    .pf-project-card:hover { border-color: rgba(224,123,53,.25) !important; }
    .pf-project-card.featured { border-color: rgba(224,123,53,.3) !important; background: linear-gradient(135deg, rgba(224,123,53,.04), var(--primary-light)) !important; }
    .pf-project-cover { background: linear-gradient(135deg, #1c1814, #221e19) !important; }
    .pf-project-cover-placeholder { background: linear-gradient(135deg, #1c1814, rgba(224,123,53,.05)) !important; color: rgba(224,123,53,.3) !important; }
    .pf-project-name { color: var(--text-primary) !important; }
    .pf-project-desc { color: var(--text-secondary) !important; }
    .pf-project-tag { background: rgba(224,123,53,.08) !important; border: 1px solid rgba(224,123,53,.18) !important; color: var(--accent) !important; }
    .pf-project-footer { border-top: 1px solid var(--border-color) !important; }
    .pf-project-meta { color: var(--text-muted) !important; }
    .pf-project-link { border: 1px solid var(--border-color) !important; color: var(--text-muted) !important; }
    .pf-project-link:hover { border-color: var(--accent) !important; color: var(--accent) !important; }
    .pf-skill-pill {
      background: rgba(255,255,255,.04) !important;
      border: 1px solid var(--border-color) !important;
      color: var(--text-secondary) !important;
    }
    .pf-skill-pill:hover { border-color: rgba(224,123,53,.3) !important; color: var(--accent) !important; }
    .pf-skill-pill-dot { background: var(--accent) !important; }
    .pf-export-bar { background: var(--primary-light) !important; border: 1px solid var(--border-color) !important; }
    .pf-export-label { color: var(--text-secondary) !important; }
    .pf-sort-btn { border: 1px solid var(--border-color) !important; color: var(--text-muted) !important; }
    .pf-sort-btn.active, .pf-sort-btn:hover { border-color: rgba(224,123,53,.35) !important; color: var(--accent) !important; background: rgba(224,123,53,.06) !important; }

    /* ─── GITHUB ─── */
    .github-connect-banner { background: linear-gradient(135deg, rgba(224,123,53,.06), rgba(14,11,9,.0)) !important; border: 1px solid rgba(224,123,53,.12) !important; }
    .github-user-header { background: var(--bg-card) !important; border: 1px solid var(--border-color) !important; }
    .github-repo-card { background: var(--bg-card) !important; border: 1px solid var(--border-color) !important; }
    .github-repo-card:hover { border-color: rgba(224,123,53,.25) !important; }
    .github-repo-name { color: var(--accent) !important; }
    .github-lang-dot { /* keep original */ }
    .github-filter-tabs button { color: var(--text-muted) !important; border: 1px solid transparent !important; }
    .github-filter-tabs button.active { color: var(--accent) !important; border-color: rgba(224,123,53,.3) !important; background: rgba(224,123,53,.07) !important; }

    /* ─── MOBILE MENU ─── */
    .mobile-menu {
      background: rgba(14,11,9,.97) !important;
      border-right: 1px solid var(--border-color) !important;
    }

    /* ─── FILTER BUTTONS ─── */
    .filter-btn {
      padding: 5px 13px; border-radius: 20px; font-size: .78rem; font-weight: 600;
      cursor: pointer; border: 1px solid var(--border-color); color: var(--text-muted);
      background: transparent; transition: all .18s; font-family: var(--font);
    }
    .filter-btn:hover  { border-color: rgba(224,123,53,.35); color: var(--text-primary); }
    .filter-btn.active { background: var(--accent); border-color: var(--accent); color: #0c0a08; }

    /* ─── PROJECT MODAL IMAGE PREVIEW ─── */
    #project-images-preview img { border-radius: 8px !important; }

    /* ─── COLLAB BADGE ─── */
    #collab-badge { vertical-align: middle; }

    /* ─── SCROLLBAR ─── */
    ::-webkit-scrollbar-thumb { background: #3a302a !important; }
    ::-webkit-scrollbar-thumb:hover { background: var(--accent) !important; }
    ::selection { background: rgba(224,123,53,.25) !important; color: var(--text-primary) !important; }

    /* ─── MISC ─── */
    .opp-badge { border-radius: 20px !important; }
    .profile-title { font-weight: 600 !important; }
