@import url("https://use.typekit.net/yup6mha.css");
@import url("https://fonts.googleapis.com/css2?family=Urbanist:ital,wght@0,100..900;1,100..900&display=swap");

:root {
  --port-blue-background: linear-gradient(180deg, #22262e 0%, #0E0E0E 100%);
  --port-red-background: linear-gradient(180deg, #180F0D 0%, #0E0E0E 100%);
  --port-tan-background: linear-gradient(180deg, #1D1D1A 0%, #0E0E0E 100%);
  --port-green-background: linear-gradient(180deg, #1A1E09 0%, #0E0E0E 100%);
  --port-tile-green: linear-gradient(180deg, #30380C 0%, #90A141 100%);
  --port-tile-blue: linear-gradient(180deg, #4F6B96 0%, #D2EAF7 100%);
  --port-tile-red:linear-gradient(180deg, #372222 0%, #6D4141 100%);
  --port-tile-tan:linear-gradient(180deg, #5F4931 0%, #e7bd92 100%);
  --port-blue:#5CB0F0;
  --port-red:#372222;
  --port-green:#e7ff78;
  --port-tan:#E7BD92;

}

/* Base Styles */
body {
  margin: 0;
  background-color: #0E0E0E;
  font-size: 10px;
  width: 100%;
  color: #fff;
}

h1, h2, h3, h4, h5, h6, span, div, article, p, pre, ul, ol, li, button {
  margin: 0;
  padding: 0;
}

.section01 figure.gridImage a {display:flex; justify-content:center; align-items:center;}

/* Header Styles */
header {
  width: 100%;
  max-width: 1400px;
  height: 240px;
  margin: 0 auto;
  display: flex;
  align-items: flex-end;
  background-repeat:no-repeat;
  background-position: left center;
}



.uxProjects header {background: url("../images/port/okcBanner.jpg");}
.manProjects header {background: url("../images/port/chico montana banner 2023.jpg");}
.prodProjects header {background: url("../images/port/chico montana banner 2025.jpg");}

header h1 {
  padding-left: 2.4em;
}

small.red {color:#ff0000;}

/* Button Styling */
button {
  font-family: 'mr-eaves-xl-modern', helvetica, 'Urbanist';
  font-size: 1.8em;
  font-weight: 700;
  line-height: 14px;
  letter-spacing: 1px;
  color: #fff;
  font-variant-caps: small-caps;
  border: 1px solid #fff;
  background: transparent;
  padding: 12px 14px;
  cursor: pointer;
  opacity: 1;
  transition: all 0.3s ease-in-out;
}

.active .tile button {
  opacity: 0;
  display: none;
}

button:hover {
  background-color: #fff;
  color: #000;
}

/* Header Title - Updated for <small> subtext in logo */
header h2 {
  font-family: 'mr-eaves-xl-modern', helvetica, urbanist;
  font-weight: 700;
  font-size: 3.6em;
  letter-spacing: 1px;
  min-height: 90px;
  display: flex;
  align-items: center;
  margin-left: 24px;
  line-height:94%;}

header h2 span {
  font-family: 'Urbanist', 'mr-eaves-xl-modern', Helvetica, sans-serif;
  font-weight: 400;
  margin-left: 12px;
  letter-spacing: 1.5px;
}
.uxProjects header h2 span {
  color:var(--port-green);}
.manProjects header h2 span {
  color:var(--port-tan);}
.prodProjects header h2 span {
  color:var(--port-blue);}

/* Headings */
h2 {
  font-family: 'mr-eaves-xl-modern', helvetica, 'Urbanist';
  font-weight: 700;
  font-size: 2.8em;
  line-height: 32px;
  letter-spacing: 1px;
}

.tile h2 {
  text-shadow: 0 4px 12px rgba(0, 0, 0, 0.45);
  transition: all 0.5s;
}

.tile .interactiveTitle h2 {
  max-width:310px;
}

.tile.active h2 {
  font-size: 2em;
  line-height: 26px;
  transition: all 0.5s;
}
h3 {
  font-family: 'mr-eaves-xl-modern', Helvetica, 'Urbanist';
  font-size: 1.8em;
  line-height: 24px;
  letter-spacing: 0.75px;
}
h4 {
  font-family: 'mr-eaves-xl-modern', helvetica, 'Urbanist';
  font-weight: 800;
  font-size: 1.4em;
  line-height: 40px;
  letter-spacing: 0.5px;
  margin: 16px 0 24px;
}

nav ol.breadcrumbs li {font-size:1.6em; min-width:fit-content;}

.summary p {
  width: 100%;
  font-family: "mr-eaves-xl-modern", sans-serif;
  font-weight: 400;
  font-size:1.8em;
  font-style: normal;
  line-height:160%;
}

.additionalInfo h2 {
  font-family: 'mr-eaves-xl-sans', Helvetica, 'Urbanist';
  margin-top: 40px;
  font-size: 2.4em;
}

.dropdownCaret {min-height:42px !important; min-width:42px !important;}

.additionalInfo h3 {
  font-size: 2.4em;
  margin-top: 16px;
}
.additionalInfo h3 span,
.additionalInfo h3 small {
  font-family: 'Urbanist', 'mr-eaves-xl-modern', Helvetica, sans-serif;
  font-weight: 500;
  font-size: 20px;
  letter-spacing: 0.75px;
  margin-left: 6px;
}

.prodprojects .additionalInfo h3 small
{color:var(--port-blue);}

.additionalInfo p {
  margin-top: 18px;
  color: #fff;
}

.additionalInfo p {
  margin-top: 8px;
}

.manprojects article:nth-of-type(2) additionalInfo p:nth-of-type(2) {margin-top:24px;}
.manprojects article:nth-of-type(4) .additionalInfo p:nth-of-type(2) {margin-top:24px;}

.additionalInfo ul {margin-top:16px; list-style:none;}
.additionalInfo li {font-size:1.8em; line-height:140%; color:white; font-family: 'mr-eaves-xl-sans', Helvetica, 'Urbanist';}
.additionalInfo li strong {font-weight:600; margin-right:1px;}
.additionalInfo li h4, .additionalInfo li p {line-height:160%; color:white; font-family: 'mr-eaves-xl-sans', Helvetica, 'Urbanist';}
.additionalInfo li h4 {font-weight:600; font-size:23px;}
.additionalInfo li p {font-size:23px;}

.manprojects .additionalInfo ul li strong {color:var(--port-tan);}
.manprojects article:nth-of-type(2) ul, .manprojects article:nth-of-type(4) ul {border-top:5px solid #323232; border-bottom:5px solid #323232; padding:16px 0; margin-top:24px;}
.manprojects article:nth-of-type(2) ul li:not(:first-of-type), .manprojects article:nth-of-type(3) ul li:not(:first-of-type) {margin-top:16px;}
.manprojects article:nth-of-type(3) ul li:not(:first-of-type) {margin-top:24px;}
.manprojects article:nth-of-type(3) ul li {color:var(--port-tan);}
.manprojects article:nth-of-type(4) ul {border-top: 5px solid #323232; border-bottom:5px solid #323232; padding:16px 0; margin-top:24px;}
.manprojects article:nth-of-type(4) ul li {list-style-type:none;}
.manprojects article:nth-of-type(4) ul li:not(:first-of-type) {margin-top:16px;}
.manprojects article:nth-of-type(4) li p:first-of-type {margin-top:4px;}

@media screen and (max-width:1080px) and (min-resolution: 144dpi) and (orientation: portrait) {
  .summary p {font-size:2.4em; line-height:110%;}
  h4.breadcrumbs {font-size:2.8em;}
  .tile .interactiveTitle h2 {max-width:unset;}
}
@media screen and (max-width:1080px) and (min-resolution: 144dpi) and (orientation: landscape) {
  .summary p {font-size:2.4em; line-height:110%;}
  h4.breadcrumbs {font-size:2.8em;}
  .tile .interactiveTitle h2 {max-width:unset;}
}
@media screen and (max-width:1080px) and (-webkit-min-device-pixel-ratio: 1.3) {
  .summary p {font-size:2.4em; line-height:110%;}
  h4.breadcrumbs {font-size:2.8em;}
  .tile .interactiveTitle h2 {max-width:unset;}
}



/* Breadcrumbs */
nav ol.breadcrumbs {
  text-transform: uppercase;
  margin: 12px 0 0 24px;
  display: flex;
  flex-flow: row nowrap;
  gap: 16px;
}
nav ol.breadcrumbs li a {
  font-size: 14px;
  color: #bababa;
  font-weight:800;
}

nav ol.breadcrumbs li:first-of-type a {color:#fff;}


nav ol.breadcrumbs li:first-of-type::marker {
  content: "";
}

nav ol.breadcrumbs li:nth-of-type(2)::marker {
  content: ">";
}

nav ol.breadcrumbs li:nth-of-type(2) a {
  padding-left: 6px;
}

/* Paragraphs */
p {
  font-family: 'mr-eaves-xl-sans', Helvetica, 'Urbanist';
  font-size: 1.8em;
  font-weight: 400;
  line-height: 24px;
  letter-spacing: 0.75px;
}

/* Layout Containers */
.pageWrap {
  height: auto;
  width: 100%;
  padding-bottom: 8.88vh;
  max-width: 140em;
  margin: 0 auto;
}

.manProjects .gridWrap {
  background:var(--port-tan-background);}
.uxProjects .gridWrap {
  background:var(--port-green-background);}
.prodProjects .gridWrap {
  background:var(--port-blue-background);}

.innerWrap {
  width: 100%;
  max-width: 960px;
  margin: 0 auto;
  padding-top:1em;
}

/* Article & Summary */
.articleWrap {
  width: 100%;
  display: flex;
  flex-flow: row wrap;
  gap: 3.6em;
  padding-bottom: 15em;
}

.summary div {
  min-height:64px;
  min-width:64px;
}

.articleWrap article {
  width: 100%;
  height: auto;
  display: flex;
  flex-flow: column nowrap;
  max-width:48%;
}
.innerWrap .summary {
  padding: 0 1.8em 3.6em;
  display: flex;
  flex-flow: row nowrap;
  gap: 1.8em;
  align-items: center;
  margin-top:36px;
}

/* Tile Styling */
.tile {
  height: auto;
  padding: 2.4em;
}

.uxProjects .tile {
  background: var(--port-tile-green);}
.manProjects .tile {
  background: var(--port-tile-tan);}
.prodProjects .tile {
  background: var(--port-tile-blue);}

.tile img {
  display: block;
}
.tile .innerTile {
  box-shadow: 2px 2px 9px rgba(0, 0, 0, 0.25);
}
.tile .innerTile .innerImg {
  content: "";
  height: 24em;
  width: 100%;
  background-size: cover;
  background-position: center;
  transition: all 0.5s;
}

.manProjects article:nth-child(3) .tile .innerTile .innerImg {
  background-position: top center;
}

.uxProjects article:nth-child(1) > div.tile > div > div {
  background-image: url("../images/port/port%20ui%20tile%2001.jpg");
}
.uxProjects article:nth-child(2) > div.tile > div > div {
  background-image: url("../images/port/port%20ui%20tile%2002.jpg");
}
.manProjects article:nth-child(1) > div.tile > div > div {
  background-image: url("../images/port/manProjects01");
}
.manProjects article:nth-child(2) > div.tile > div > div {
  background-image: url("../images/port/manProjects02");
}
.manProjects article:nth-child(3) > div.tile > div > div {
  background-image: url("../images/port/manProjects04.jpg");
}
.manProjects article:nth-child(4) > div.tile > div > div {
  background-image: url("../images/port/manProjects03");
}
.prodProjects article:nth-child(1) > div.tile > div > div {
  background-image: url("../images/port/port%20prod%20tile%2002.jpg");
}
.prodProjects article:nth-child(2) > div.tile > div > div {
  background-image: url("../images/port/port%20prod%20tile%2001.jpg");
}

.active .tile .innerTile .innerImg {
  height: 18em;
  transition: all 0.5s ease-in-out;
}
.tile .interactiveTitle svg {
  transition: all 0.5s ease-in-out;
  filter: drop-shadow(2px 2px 8px rgba(0,0,0,0.25));
  cursor: pointer;
  min-width:36px;
  max-width:36px;
}
.active .tile .interactiveTitle svg {
  transform: rotate(180deg);
  transition: all 0.35s ease-in-out;
}

.tile section {
  background-color: rgba(0, 0, 0, 0.5);
  padding: 3.2em 2.4em 2.4em;
  display: flex;
  flex-flow: column nowrap;
  gap: 18px;
  transition: all 0.5s ease-in-out;
}
.active .tile section {
  padding: 1.8em 2.4em 1.6em;
  transition: all 0.5s ease-in-out;
}
.tile .interactiveTitle {
  display: flex;
  flex-flow: row nowrap;
  justify-content: space-between;
}

/* Additional Info */
.additionalInfo {
  height: auto;
  max-height: 0;
  padding: 0 2.4em 0;
  opacity: 0;
  transform: translateY(40px);
  display: none;
  flex-flow: column nowrap;
  gap: 8px;
  transition: all 0.5s ease-in-out;
  overflow: hidden;
}
.active .additionalInfo {
  max-height: unset;
  padding: 0 2.4em 12em;
  opacity: 1;
  transform: translateY(0);
  display:flex;
  transition: all 0.5s ease-in-out;
  gap: 0;
  overflow: unset;
}

.additionalInfo img {
  display: block;
  max-width: 100%;
  height: auto;
  width: 100%;
  margin-top: 36px;
}
.additionalInfo img:not(:first-of-type) {
  margin-top: 48px;
}

.prodprojects .additionalInfo img:not(:first-of-type) {
  margin-top:60px;
}
.prodprojects .additionalInfo img:first-of-type {margin-top:36px;}

@media screen and (min-resolution: 144dpi) and (orientation: portrait) {
  .additionalInfo {max-height:unset; opacity:1; transform:none; gap:8px;}
}
@media screen and (min-resolution: 144dpi) and (orientation: landscape) {
  .additionalInfo {max-height:unset; opacity:1; transform:none; gap:8px;}
}
@media screen and (-webkit-min-device-pixel-ratio: 1.3) {
  .additionalInfo {max-height:unset; opacity:1; transform:none; gap:8px;}
}

/* Grid Adjustments */
@media screen and (min-resolution: 144dpi) and (orientation: landscape) {
  .section01 .gridWrap {
    grid-template-columns: 1fr;
    grid-template-rows: unset;
  }
}

@media (min-width: 900px) {
  .section01 .gridImage:nth-of-type(1) {
    height: 10vh;
  }
}

@media screen and (max-width: 900px) {
  .articleWrap {
    flex-flow: column nowrap;
    gap: 0;
    max-width: 94%;
    margin: 3em auto 0;
    padding-bottom: 15em;
  }
  article:nth-child(2) {
    margin-top: 3em;
  }
}

@media screen and (-webkit-min-device-pixel-ratio: 1.3) {
   nav ol.breadcrumbs li a {font-size:1.6em;}
   header h2 {font-size:5.6em; font-weight:400; margin-bottom:.2em; display:flex; gap:0;}
  .innerWrap .summary {flex-flow:column nowrap; gap:2.4em; margin-top:60px;}
  .innerWrap .summary > div {padding:0 2.4em;}
  .innerWrap .summary p {font-size:2.4em; line-height:160%;}
  .additionalInfo {max-height:unset; opacity:1; transform:none; margin-top:12px; display:flex; padding:0 60px; gap:10px;}
  .additionalInfo h2 {margin-top:0; font-size:3.0em; line-height:120%; font-weight:600;}
  /*
  .additionalInfo h2 span {display:table; font-size:inherit; line-height:inherit; font-weight:inherit;}
  */
  .additionalInfo p:first-of-type {margin-top:8px;}
  .additionalInfo p {font-size:2.4em; line-height:160%;}
  .tile {padding:0;}
  .tile section {padding:1.8em 2.4em 1em;}
  .active .tile .innerTile button {display:none;}
  .tile .innerTile .innerImg {height:240px;}
  .tile .interactiveTitle h2 {font-size:4em;}
  .articleWrap {flex-flow:column nowrap; align-items:center;}
  .articleWrap .tile {margin-top:24px;}
  .articleWrap article {width:100%; max-width:100%;}
  .articleWrap article:not(:first-of-type) {margin-top:48px;}
  .articleWrap summary {flex-flow:column; align-items:center;}
  
  .manProjects .summary svg {width:144px !important; height:192px !important;}
}

@media screen and (min-resolution: 144dpi) and (orientation: portrait) {
  
  .uxProjects header {background: url("../images/port/mobOkc.jpg");}
  .manProjects header {background: url("../images/port/mobCabin23");}
  .prodProjects header {background: url("../images/port/mobCabin25");}
  
   nav ol.breadcrumbs li a {font-size:1.8em;}
   header h2 {font-size:60px; letter-spacing:2px;}
  .innerWrap .summary {flex-flow:column nowrap; gap:2.4em; margin-top:90px;}
  .innerWrap .summary:first-of-type {margin-top:60px;}
  .innerWrap .summary p {font-size:36px; line-height:140%; margin-top:24px;}
  
   .manprojects article:nth-of-type(2) ul, .manprojects article:nth-of-type(4) ul {padding:16px 0 48px;}
   .manprojects .summary:first-of-type {padding:0 48px;}
  
  .uxprojects .innerWrap .summary p {color:var(--port-green);}
  .prodprojects .innerWrap .summary p {color:var(--port-blue);}
  .manprojects .innerWrap .summary p {color:var(--port-tan);}
  
  .additionalInfo {max-height:unset; opacity:1; transform:none; margin-top:90px; display:flex; gap:16px; padding:0 24px;}
  .additionalInfo h2 {font-size:4.2em; line-height:115%; padding-top:36px;}
  .additionalInfo p {font-size:36px; line-height:160%; padding-left:24px; margin-top:24px;}
  .additionalInfo li {font-size:36px; padding-left:24px;}
  .additionalInfo li h4 {margin-bottom:0; font-size:36px; line-height:140%;}
  .additionalInfo li:not(:first-of-type) h4 {margin-top:60px;}
  .additionalInfo li p {font-size:36px;}
  .additionalInfo li p:nth-of-type(2) {margin-top:48px;}
  .additionalInfo li p:first-of-type {margin-top:0px;}
  
  .manprojects .innerWrap {max-width:unset;}
  .manprojects article:nth-of-type(1) ul li:not(:first-of-type) {margin-top:56px;}
  .manprojects article:nth-of-type(2) ul li:not(:first-of-type) {margin-top:56px;}
  .manprojects article:nth-of-type(2) ul li h4, .manprojects article:nth-of-type(4) ul li h4 {color:var(--port-tan);}
  .manprojects article:nth-of-type(3) ul li:not(:first-of-type) {margin-top:56px;}

  .manprojects article:not(:first-of-type) .tile {margin-top:120px;} 
  
  .tile {padding:0;}
  .tile .innerTile button {display:none;}
  .tile .innerTile .innerImg {height:240px; min-height:240px;}
  .tile .interactiveTitle h2 {font-size:4em; line-height:40px; max-width:unset;}
  .tile .interactiveTitle svg {display:none;}
  .tile section {padding:3.2em 2.4em 2.4em;}
  .articleWrap {flex-flow:column nowrap; align-items:center;}
  .articleWrap .tile {margin-top:24px;}
  .articleWrap article:not(:first-of-type) {margin-top:48px;}
  .articleWrap summary {flex-flow:column; align-items:center;}
  
  .manProjects .summary svg, .uxprojects .summary svg, .prodprojects .summary svg {width:144px !important; height:192px !important;} 
  .manProjects .articleWrap > article:nth-child(1) > div.tile {margin-top:90px;}
  .prodprojects article:first-of-type .summary svg {width:190px !important;}
}  
@media screen and (min-resolution: 144dpi) and (orientation: landscape) {
  
  .uxProjects header {background: url("../images/port/mobOkc.jpg");}
  .manProjects header {background: url("../images/port/mobCabin23");}
  .prodProjects header {background: url("../images/port/mobCabin25");}
  
   nav ol.breadcrumbs li a {font-size:18px;}
   header h2 {font-size:48px;}
  .innerWrap .summary {flex-flow:column nowrap; gap:2.4em; margin-top:90px;}
  .innerWrap .summary p {font-size:28px; line-height:160%; margin-top:24px;}
  .additionalInfo {max-height:unset; opacity:1; transform:none; margin-top:24px; display:flex;}
  .additionalInfo h2 {margin-top:0; font-size:32px; line-height:115%;}
  .additionalInfo p:first-of-type {margin-top:0;}
  .additionalInfo p {font-size:28px; line-height:160%;}
  .additionalInfo li {font-size:32px; line-height:120%;}
  .additionalInfo li h4 {font-size:32px; line-height:120%;}
  .additionalInfo li p {font-size:28px; line-height:160%;}
  .additionalInfo li:not(:first-of-type) {margin-top:24px;}
  .tile {padding:0;}
  .tile .innerTile button {display:none;}
  .tile .innerTile .innerImg {height:240px;}
  .tile .interactiveTitle h2 {font-size:28px; line-height:100%; max-width:unset;}
  .articleWrap {flex-flow:column nowrap; align-items:center;}
  .articleWrap .tile {margin-top:24px;}
  .articleWrap article {width:760px; max-width:94%;}
  .articleWrap article:not(:first-of-type) {margin-top:48px;}
  .articleWrap summary {flex-flow:column; align-items:center;}
  
  .manProjects .summary svg {width:144px !important; height:192px !important;} 
}

@media screen and (min-width:1081px) {
  nav ol.breadcrumbs {margin-top:0;}
  nav ol.breadcrumbs li a {font-size:.9em;}
  header h2 {font-size:3.6em;}
  .innerWrap h4 {margin:0;}
  .innerWrap .summary {gap:0; flex-flow:row nowrap; margin-top:36px; padding:0 0 3.6em; min-height:120px; align-items:flex-start;}
  
  .manprojects .innerWrap .summary {align-items:center; max-width:760px; margin:36px auto 0;}

  .innerWrap .summary p {font-size:1.8em; line-height:145%; margin-top:unset;}
  .innerWrap .summary div {display:flex; justify-content:center; align-items:center; min-width:72px; padding-top:.5em;}
  
  .manprojects .innerWrap .summary div {padding-top:0;}
  
  .prodprojects article:nth-child(2) > .summary > div {min-width:72px;}
  .articleWrap {flex-flow:row wrap; align-items:flex-start;}
  .articleWrap article {min-width:48%; max-width:48%;}
  .articleWrap article:not(:first-of-type) {margin-top:0;}
  .interactiveTitle h2 {font-size:2.8em; max-width:unset;}
  .tile {padding:24px;}
  .tile .innerTile button {display:initial;}
  .active .additionalInfo {padding:0 1.8em 12em;}
  .additionalInfo {max-height:unset; opacity:1; transform:none; margin-top:24px; display:none;}
  .tile .interactiveTitle h2 span {display:table;}

  .additionalInfo p {font-size:18px;}
  .additionalInfo li {font-size:23px; line-height:160%;}
  
  .manprojects article:nth-of-type(1) .additionalInfo li {line-height:120%;}
  .manprojects article:nth-of-type(2) .additionalInfo li h4 {color:var(--port-tan);}
  .manprojects article:nth-of-type(3) li {font-size:20px;}
  
  .uxProjects .additionalInfo h2 span {display:inline;}
  
  .additionalInfo li h4, .additionalInfo li p {font-family: 'mr-eaves-xl-sans', Helvetica, 'Urbanist';}
  .additionalInfo li h4 {font-size:23px; font-weight:600; color:var(--port-tan); line-height:120%;}
  .additionalInfo li p {font-size:18px; line-height:140%; color:white;}
  .articleWrap .tile {margin-top:0;}
  .additionalInfo h2 {margin-top:0; font-size:24px;}
  .additionalInfo p {line-height:160%; margin-top:24px;}
  .additionalInfo p:first-of-type {margin-top:8px;}
  .additionalInfo li p:first-of-type {margin-top:4px;}
  .tile .additionalInfo p {font-size:22px;}
  
  
  .manProjects .summary svg {width:64px !important; height:128px !important;}
  .prodprojects article:first-of-type .summary svg {width:160px !important;}
  .prodprojects article:first-of-type .summary div {padding:0 1.8em 0 2.4em;}
 
}

@media screen and (max-width:1080px) {
  .tile .innerTile button {display:none;}
  .additionalInfo h2 {padding-top:8px;}
  .dropdownCaret {display:none;}
  .articleWrap article:not(:first-of-type) {margin-top:16px;}
}

@media screen and (max-width:720px) {
  header h2 {
    display:flex;
    flex-flow:column nowrap;
    align-items:flex-start;
    gap:4px;
  }
  header h2 span {
    font-size:.8em;
  }
  .additionalInfo {padding:0 24px;}
}

