:root {
  /* Background + surfaces */
  --bg: #0a1020;                 /* deep blue */
  --panel: rgba(17, 26, 45, .72); /* glassy card */
  --panel-strong: rgba(17, 26, 45, .88);

  /* Text */
  --text: #e6edf7;
  --muted: #9fb0c7;

  /* Lines */
  --border: rgba(255,255,255,.08);

  /* Accent (teal/cyan like the screenshot) */
  --accent: #5eead4;  /* cyan-teal */
  --accent-2: #7dd3fc; /* optional secondary */
}


* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  background:
    radial-gradient(900px 520px at 20% 10%, rgba(94,234,212,.10), transparent 60%),
    radial-gradient(900px 520px at 80% 20%, rgba(125,211,252,.08), transparent 60%),
    radial-gradient(900px 520px at 40% 90%, rgba(109,94,252,.08), transparent 60%),
    var(--bg);
  color: var(--text);
  line-height: 1.65;
  letter-spacing: .1px;
}

.container { max-width: 1050px; margin: 0 auto; padding: 24px; }

/* Make header layout more stable */
.header{
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: start;
  gap: 16px;
}

h1 {
  margin: 0;
  font-size: clamp(28px, 3.5vw, 44px);
  letter-spacing: -0.6px;
  line-height: 1.1;
}

h2 {
  margin: 0 0 10px;
  font-size: 22px;
  letter-spacing: -0.2px;
}

h3 {
  margin: 0 0 8px;
  font-size: 18px;
  letter-spacing: -0.2px;
}

.subtitle {
  margin: 10px 0 0;
  color: var(--muted);
  font-size: 15px;
}
p { margin: 10px 0 0; }
.muted { color: var(--muted); }


/* Social row under name */
.header-links{
  margin-top: 18px;         /* more space from your name/subtitle */
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: nowrap;        /* keep icons + email on ONE row */
}

/* Icons group */
.social{
  display: flex;
  gap: 10px;
  align-items: center;
}

/* === Unified header icon theme === */
.icon {
  width: 40px;
  height: 40px;
  border-radius: 17px;
  font-size: 12px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  color: var(--muted);
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid var(--border);

  text-decoration: none !important;
  transition: background .15s ease,
              color .15s ease,
              transform .15s ease,
              box-shadow .15s ease;
}

.icon:hover {
  color: var(--text);
  background: rgba(255, 255, 255, 0.12);
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(0,0,0,.25);
}


/* Email CTA to the right of icons */
.email-cta{
  display: inline-flex;
  align-items: center;
  padding: 10px 14px;
  border-radius: 12px;
  background: rgba(255,255,255,.06);
  border: 1px solid var(--border);
  color: var(--text);
  text-decoration: none !important;
  margin-left: 10px;        /* extra space from icons */
  white-space: nowrap;      /* don't split text */
}
.email-cta:hover { filter: brightness(1.06); }

.nav { display: flex; gap: 14px; justify-self: end; }
.nav a { padding: 8px 10px; border-radius: 10px; }
.nav a:hover { background: rgba(255,255,255,.06); text-decoration: none; }

.section { margin-top: 26px; }
.section-head { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; }
.muted { color: var(--muted); }

.card {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 18px;
  box-shadow: 0 18px 60px rgba(0,0,0,.35);
  backdrop-filter: blur(10px);
}


.hero { padding: 22px; }
.grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.project h3 { margin: 0 0 6px; }
.project-toplinks { margin-bottom: 10px; }

.placeholder { opacity: .7; }

.tags span {
  font-size: 12px;
  padding: 6px 10px;
  border-radius: 999px;

  color: rgba(94,234,212,.92);                 /* teal text */
  background: rgba(94,234,212,.08);            /* teal glass */
  border: 1px solid rgba(94,234,212,.18);      /* teal outline */
}


.btnrow { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 14px; }
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  border-radius: 12px;
  background: var(--accent);
  border: 1px solid rgba(255,255,255,.08);
  text-decoration: none !important;
}
.btn:hover { filter: brightness(1.05); }
.btn-ghost { background: rgba(255,255,255,.06); color: var(--text); }
.btn-sm { padding: 8px 12px; border-radius: 10px; font-size: 13px; }

.list { margin: 10px 0 0; padding-left: 18px; }
.list li { margin: 8px 0; color: var(--text); }

.footer { margin-top: 40px; text-align: center; }

@media (max-width: 850px){
  .header{ grid-template-columns: 1fr; }
  .nav{ justify-self: start; }
  .grid{ grid-template-columns: 1fr; }

  /* only on small screens allow wrap */
  .header-links{ flex-wrap: wrap; }
  .email-cta{ margin-left: 0; }
}


/* === Projects grid & mobile slider === */

.projects-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

/* Tablet */
@media (max-width: 1100px) {
  .projects-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* Mobile: swipeable slider */
@media (max-width: 720px) {
  .projects-grid {
    grid-auto-flow: column;
    grid-auto-columns: 85%;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }

  .projects-grid > * {
    scroll-snap-align: start;
  }
}

/* ===== Patch: reduce harsh blue contrast (nav + buttons) ===== */

/* Nav links: muted by default, subtle hover */
.nav a{
  color: var(--muted);
  background: transparent;
  border: 1px solid transparent;
  text-decoration: none;
}
.nav a:hover{
  color: var(--text);
  background: rgba(255,255,255,.05);
  border-color: rgba(255,255,255,.06);
  text-decoration: none;
}

/* Prevent default browser blue links */
a { color: inherit; }

/* Primary buttons: calm teal glass, dark readable text */
.btn{
  background: rgba(94,234,212,.18);
  border: 1px solid rgba(94,234,212,.22);
  color: #08131a;
  font-weight: 600;
  box-shadow: 0 10px 26px rgba(0,0,0,.22);
}
.btn:hover{
  filter: brightness(1.05);
  text-decoration: none;
}

/* Ghost buttons: neutral glass */
.btn-ghost{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  color: var(--text);
  font-weight: 600;
}
.btn-ghost:hover{
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.14);
  text-decoration: none;
}

/* Small buttons should not scream */
.btn-sm{
  font-weight: 600;
  opacity: .95;
}

/* Section headers polish */
.section-head h2{
  letter-spacing: -0.3px;
  font-size: 22px;
}
.section-head .muted{
  color: rgba(159,176,199,.85);
}
/* Tags layout: prevent pill overlap and keep spacing consistent */
.tags{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

