body {
  background-color: #fff;
  padding:50px;
  font: 14px/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Fira Sans", "Droid Sans", "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
  color:#595959;
  font-weight:400;
}

p, ul, ol, table, pre, dl {
  margin:0 0 10px;
}

h1 {
  color:#264b6d;
  font-size:25px;
  font-weight: 500;
  margin:10px 0 15px;
}

h2 {
  color:#264b6d;
  font-weight: 500;
  line-height:1.0;
  margin:10px 0 6px;
}

h3, h4, h5, h6 {
  color:#0c1e2f;
  font-weight: 350;
  margin:0px 0 3px;
}

a {
  color: #20568c;
  text-decoration:none;
}

a:hover {
  color: #104221;
}

a small {
  font-size:9px;
  color:#777;
  margin-top:-0.3em;
  display:block;
}

a:hover small {
  color:#777;
}

.wrapper {
  width:900px;
  margin:0 auto;
}

blockquote {
  border-left:1px solid #e5e5e5;
  margin:0;
  padding:0 0 0 20px;
  font-style:italic;
}

code, pre {
  font-family:Monaco, Bitstream Vera Sans Mono, Lucida Console, Terminal, Consolas, Liberation Mono, DejaVu Sans Mono, Courier New, monospace;
  color:#333;
}

pre {
  padding:8px 15px;
  background: #f8f8f8;
  border-radius:5px;
  border:1px solid #e5e5e5;
  overflow-x: auto;
}

table {
  width:100%;
  border-collapse:collapse;
}

th, td {
  text-align:left;
  padding:5px 10px;
  border-bottom:1px solid #e5e5e5;
}

dt {
  color:#444;
  font-weight:500;
}

th {
  color:#444;
}

img {
  max-width:100%;
}

header {
  margin-left: -50px; 
  width:300px;
  float:left;
  position:fixed;
  -webkit-font-smoothing:subpixel-antialiased;
}

header ul {
  list-style:none;
  height:35px;
  padding:0;
  background: #f4f4f4;
  border-radius:5px;
  border:0px solid #e0e0e0;
  width:99%;
}

header li {
  width:24%;
  float:left;
  border-right:1px solid #e0e0e0;
  height:35px;
}

header li:first-child a {
  border-radius:5px 0 0 5px;
}

header li:last-child a {
  border-radius:0 5px 5px 0;
}

header ul a {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size:11px;
  color:#999;
  height: 35px;
  text-align:center;
  padding-top:0;
}

header ul a:hover {
  color:#999;
}

header ul a:active {
  background-color:#f0f0f0;
}

strong {
  color:#222;
  font-weight:500;
}

header ul li + li + li + li {
  border-right:none;
}

header ul a strong {
  font-size:14px;
  display:block;
  color:#222;
}

header ul a i {
  margin-right:1%;
  font-size: 11px;
}


section {
  width:650px;
  float:right;
  padding-left: 0px;
  padding-bottom: 0px;
  border: none;
  border-bottom: 1px solid #e5e5e5;
  margin-right: -30px; 
}

small {
  font-size:11px;
}

hr {
  border:0;
  background:#e5e5e5;
  height:1px;
  margin:0 0 20px;
}

footer {
  width:500px;
  float:left;
  bottom:50px;
  color:#bcbcbc;
  -webkit-font-smoothing:subpixel-antialiased;
  font-size:9px;
}

.project {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  margin-bottom: 40px;
}

.project-image {
  width: 200px;
  height: auto;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  flex-shrink: 0;
}

.project-description {
  flex: 1;
}

.project-description h3 {
  margin-top: 0;
  margin-bottom: 10px;
  color: #1f4367;
  font-weight: 500;
}

.project-description p {
  margin: 0 0 10px;
}

.project-description a {
  color: #1f4367;
  text-decoration: none;
}

.project-description a:hover {
  text-decoration: underline;
}


@media print, screen and (max-width: 960px) {

  div.wrapper {
    width:auto;
    margin:0;
  }

  header, section, footer {
    float:none;
    position:static;
    width:auto;
  }

  header {
    padding-right:320px;
    margin-left: 0;
  }

  section {
    padding:20px 0;
    margin:0 0 20px;
  }

  header a small {
    display:inline;
  }

  header ul {
    position:absolute;
    right:50px;
    top:52px;
  }

  h1, h2, h3, h4, h5, h6 {
    color:#222;
    margin:0px 0 15px;
  }

  .project {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .project-image {
    width: 100%;
    max-width: 300px;
    margin-bottom: 15px;
  }

  .project-description {
    text-align: left;
  }
}

@media print, screen and (max-width: 720px) {
  body {
    word-wrap:break-word;
  }

  header {
    padding:0;
    margin-left: 0;
  }

  header ul, header p.view {
    position:static;
  }

  pre, code {
    word-wrap:normal;
  }
}

@media print, screen and (max-width: 480px) {
  body {
    padding:15px;
  }

  /* header ul {
    width:96%;
  } */

  /* header li, header ul li + li + li + li {
    width:24%;
  } */
}

@media print {
  body {
    padding:0.3in;
    font-size:12pt;
    color:#444;
  }
}


