:root{
  --bg:#0b0d12;
  --text:rgba(255,255,255,.92);
  --muted:rgba(255,255,255,.70);
  --faint:rgba(255,255,255,.55);
  --border:rgba(255,255,255,.12);
  --shadow:0 14px 34px rgba(0,0,0,.35);
  --radius:18px;

  --accent:#7c5cff;
  --accent2:#24d6a6;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(1000px 650px at 20% -10%, rgba(124,92,255,.22), transparent 60%),
    radial-gradient(900px 800px at 90% 10%, rgba(36,214,166,.14), transparent 60%),
    var(--bg);
}

a{color:inherit;text-decoration:none}
button{font-family:inherit}
.muted{color:var(--muted)}
code{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  padding:.12rem .4rem;
  border-radius:10px;
}

.container{
  width:100%;
  max-width:1120px;
  margin:0 auto;
  padding:0 16px;
}

/* Topbar */
.topbar{
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(12px);
  background:rgba(11,13,18,.62);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.topbar-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;padding:12px 0;
}
.brand{
  display:flex;align-items:center;gap:10px;
  font-weight:900;letter-spacing:-.02em;
}
.brand-dot{
  width:10px;height:10px;border-radius:999px;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  box-shadow:0 0 0 4px rgba(124,92,255,.16);
}
.nav,.topbar-cta{display:none}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:10px 14px;border-radius:999px;
  background:linear-gradient(135deg, rgba(124,92,255,.95), rgba(36,214,166,.70));
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 10px 22px rgba(0,0,0,.25);
  font-weight:800;
}
.btn:hover{filter:brightness(1.05);transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn-ghost{background:rgba(255,255,255,.06);box-shadow:none}
.btn-ghost:hover{background:rgba(255,255,255,.10)}
.btn-sm{padding:8px 12px;font-weight:800}

.iconbtn{
  display:inline-flex;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  border-radius:12px;
  padding:10px 12px;
  color:var(--text);
}
.iconbtn:hover{background:rgba(255,255,255,.10)}
.iconbtn-lines{display:block;width:18px;height:12px;position:relative}
.iconbtn-lines::before,.iconbtn-lines::after{
  content:"";position:absolute;left:0;right:0;height:2px;
  background:rgba(255,255,255,.85);border-radius:2px
}
.iconbtn-lines::before{top:0}
.iconbtn-lines::after{bottom:0}
.x{font-size:22px;line-height:1}

.mobilemenu{
  border-top:1px solid rgba(255,255,255,.08);
  background:rgba(11,13,18,.88);
}
.mobilemenu-inner{display:flex;flex-direction:column;gap:10px;padding:12px 0 16px}
.mobilemenu .nav-link{
  padding:10px 12px;border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  font-weight:800;color:var(--muted);
}
.mobilemenu-cta{display:flex;gap:10px;padding-top:6px}

/* Hero */
.hero{padding:28px 0 10px}
.hero-grid{display:grid;grid-template-columns:1fr;gap:16px;align-items:start}

.kicker{
  color:var(--muted);
  border:1px solid rgba(255,255,255,.12);
  display:inline-flex;
  padding:6px 10px;border-radius:999px;
  background:rgba(255,255,255,.04);
  font-weight:700;
}

h1{
  margin:12px 0 10px;
  font-size:clamp(1.9rem, 7.2vw, 3.2rem);
  letter-spacing:-.03em;
  line-height:1.05;
}
.lede{color:var(--muted);max-width:65ch;font-size:1.05rem;line-height:1.55}
.hero-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}

.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.chip{
  padding:6px 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  color:var(--muted);
  font-weight:700;font-size:.92rem;
}

.hero-card{
  border-radius:var(--radius);
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  box-shadow:var(--shadow);
}
.hero-card-inner{padding:14px;display:flex;flex-direction:column;gap:12px}
.hero-metric-label{color:var(--faint);font-size:.85rem;margin-bottom:4px}
.hero-metric-value{font-weight:800}
.sep{opacity:.6;padding:0 6px}
.hero-note{
  color:var(--muted);
  border-top:1px solid rgba(255,255,255,.10);
  padding-top:10px;
  font-size:.95rem;
}

/* Sections */
.section{padding:34px 0}
.section-head{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
h2{margin:0;font-size:1.6rem;letter-spacing:-.02em}

.filters{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.pill{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  color:var(--muted);
  padding:8px 12px;border-radius:999px;
  cursor:pointer;font-weight:900;
}
.pill:hover{background:rgba(255,255,255,.08);color:var(--text)}
.pill-active{
  background:rgba(124,92,255,.18);
  border-color:rgba(124,92,255,.35);
  color:var(--text);
}

/* Cards */
.grid{display:grid;grid-template-columns:1fr;gap:14px}

.card{
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius);
  background:rgba(255,255,255,.04);
  overflow:hidden;
  box-shadow:0 10px 24px rgba(0,0,0,.18);
  display:flex;flex-direction:column;
  transform:translateZ(0);
}
.card:hover{
  border-color:rgba(255,255,255,.18);
  background:rgba(255,255,255,.06);
  transform:translateY(-2px);
}
.card:focus{outline:2px solid rgba(124,92,255,.55);outline-offset:3px}

.card-img{
  height:160px;
  border-bottom:1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(700px 260px at 20% 20%, rgba(124,92,255,.35), transparent 60%),
    radial-gradient(600px 260px at 90% 25%, rgba(36,214,166,.16), transparent 60%),
    linear-gradient(135deg, rgba(255,255,255,.06), rgba(0,0,0,.12));
  position:relative;
}
.card-img img{width:100%;height:100%;object-fit:cover;display:block}
.card-img-label{
  position:absolute;left:12px;bottom:12px;
  padding:6px 10px;border-radius:999px;
  background:rgba(11,13,18,.65);
  border:1px solid rgba(255,255,255,.14);
  color:rgba(255,255,255,.85);
  font-weight:900;font-size:.9rem;
}

.card-body{padding:14px;display:flex;flex-direction:column;gap:8px;flex:1}
.card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.card-title{font-weight:950;letter-spacing:-.01em;font-size:1.05rem}
.card-sub{color:var(--muted);font-weight:700;margin-top:-2px}

.badge{
  font-size:.78rem;color:rgba(255,255,255,.85);
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  padding:4px 10px;border-radius:999px;
  white-space:nowrap;font-weight:900;
}

.card-desc{color:var(--muted);line-height:1.45}

.tech{display:flex;flex-wrap:wrap;gap:6px;margin-top:2px}
.tech span{
  font-size:.82rem;padding:5px 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  color:var(--muted);font-weight:700;
}

.card-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.card-actions .btn{padding:8px 12px}

/* About / Experience */
.two-col{display:grid;grid-template-columns:1fr;gap:14px;align-items:start}
.panel{
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius);
  background:rgba(255,255,255,.04);
  padding:14px;
}
.panel h3{margin:0 0 10px}

.checklist{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.checklist li{padding-left:22px;position:relative;color:var(--muted);font-weight:600}
.checklist li::before{
  content:"✓";
  position:absolute;left:0;top:0;
  color:rgba(36,214,166,.9);
  font-weight:900;
}

.mini{margin-top:14px;display:grid;grid-template-columns:110px 1fr;gap:8px 10px}
.mini-k{color:var(--faint);font-size:.92rem;font-weight:900}
.mini-v{color:var(--muted);line-height:1.35}

.timeline{display:flex;flex-direction:column;gap:12px}
.titem{
  display:grid;grid-template-columns:1fr;gap:10px;
  padding:14px;border-radius:var(--radius);
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
}
.twhen{color:var(--faint);font-weight:950}
.twhat h3{margin:0 0 6px}
.twhat p{margin:0;color:var(--muted);line-height:1.45}

.contact-card{
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius);
  background:linear-gradient(135deg, rgba(124,92,255,.16), rgba(36,214,166,.10));
  padding:16px;
  display:flex;flex-direction:column;align-items:flex-start;
  gap:12px;
}
.contact-actions{display:flex;gap:10px;flex-wrap:wrap}
.footer{display:flex;flex-direction:column;gap:6px;padding:16px 0 4px}

/* Modal */
.modal{position:fixed;inset:0;z-index:80;display:none}
.modal.show{display:block}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.65)}
.modal-card{
  position:relative;
  width:min(920px, calc(100% - 24px));
  margin:5vh auto;
  border-radius:var(--radius);
  border:1px solid rgba(255,255,255,.14);
  background:rgba(11,13,18,.94);
  box-shadow:0 30px 80px rgba(0,0,0,.5);
  overflow:hidden;
}
.modal-head{
  display:flex;justify-content:space-between;align-items:center;
  padding:12px 14px;
  border-bottom:1px solid rgba(255,255,255,.10);
}
.modal-title{font-weight:950;letter-spacing:-.02em}
.modal-sub{color:var(--muted);font-size:.95rem;margin-top:2px}
.modal-body{padding:14px;display:flex;flex-direction:column;gap:12px}
.modal-imgwrap{
  border-radius:14px;overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
  height:min(52vh, 420px);
  background:
    radial-gradient(800px 240px at 20% 20%, rgba(124,92,255,.35), transparent 60%),
    radial-gradient(700px 260px at 80% 20%, rgba(36,214,166,.16), transparent 60%),
    rgba(255,255,255,.04);
}
.modal-imgwrap img{width:100%;height:100%;object-fit:cover;display:block}
.modal-links{display:flex;gap:10px;flex-wrap:wrap}
.modal-tech{display:flex;flex-wrap:wrap;gap:6px}
.modal-tech span{
  font-size:.86rem;padding:5px 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  color:var(--muted);font-weight:700;
}
.modal-desc{color:var(--muted);line-height:1.5}

/* Responsive */
@media (min-width:720px){
  .container{padding:0 20px}
  .grid{grid-template-columns:repeat(2,1fr)}
  .two-col{grid-template-columns:1.1fr .9fr}
  .contact-card{flex-direction:row;justify-content:space-between;align-items:center}
  .footer{flex-direction:row;justify-content:space-between}
  .titem{grid-template-columns:140px 1fr}
}
@media (min-width:980px){
  .nav{display:flex;gap:10px;align-items:center}
  .topbar-cta{display:flex;gap:10px;align-items:center}
  .iconbtn{display:none}
  .hero{padding:56px 0 18px}
  .hero-grid{grid-template-columns:1.35fr .85fr}
  .grid{grid-template-columns:repeat(3,1fr)}
}
.nav-link{
  padding:8px 10px;border-radius:999px;
  color:var(--muted);border:1px solid transparent;
  font-weight:800;
}
.nav-link:hover{
  color:var(--text);
  border-color:rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
}
.nav-link.active{
  color:var(--text);
  background:rgba(124,92,255,.16);
  border-color:rgba(124,92,255,.35);
}
/* ---- Fix "Tech I use" + chips layout in About panel ---- */
.mini{
  display: grid;
  grid-template-columns: 90px 1fr;   /* narrower label */
  align-items: start;
  gap: 10px 12px;
}

#skillsCloud{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  min-width: 0;                     /* allow wrapping inside grid */
}

#skillsCloud .chip{
  white-space: nowrap;
  max-width: 100%;
}

@media (max-width: 520px){
  .mini{
    grid-template-columns: 1fr;      /* stack label + value */
  }
  .mini-k{
    margin-top: 6px;
  }
}

