<div style='display: flex; align-items: center;	justify-content: center; height: 100vh; font-size: 3rem; text-align: center;'>
  <a href="#" id="search-btn"></a>
</div>
<div class="container ">
  <div id="morphsearch" class="morphsearch">
    <form class="morphsearch-form" role="search" method="GET" action="{{ route('search') }}">
      <input class="morphsearch-input" type="text" class="form-control" placeholder="Search" name="q" id="srch-term" />
      <button class="morphsearch-submit" type="submit">Search</button>
    </form>
    <span class="morphsearch-close"></span>
  </div>
  <div class="overlay"></div>
</div>
body {
  background: url(http://thepatternlibrary.com/img/ax.jpg);
  overflow: hidden;
}
.morphsearch {
	width: 200px;
	min-height: 40px;
	background: #000;
	position: absolute;
	z-index: 10000;
	top: 0;
	right: 0;
	-webkit-transform-origin: 100% 0;
	transform-origin: 100% 0;
	-webkit-transition-property: min-height, width, center, center;
	transition-property: min-height, width, center, center;
	-webkit-transition-duration: 0.5s;
	transition-duration: 0.5s;
	-webkit-transition-timing-function: cubic-bezier(0.7,0,0.3,1);
	transition-timing-function: cubic-bezier(0.7,0,0.3,1);
	opacity: 0;
}

.morphsearch.open {
	width: 100%;
	min-height: 100%;
	top: 0px;
	right: 0px;
	opacity: .93;
}

.morphsearch-form {
	width: 100%;
	height: 40px;
	margin: 0 auto;
	position: relative;
	-webkit-transition-property: width, height, -webkit-transform;
	transition-property: width, height, transform;
	-webkit-transition-duration: 0.5s;
	transition-duration: 0.5s;
	-webkit-transition-timing-function: cubic-bezier(0.7,0,0.3,1);
	transition-timing-function: cubic-bezier(0.7,0,0.3,1);
}

.morphsearch.open .morphsearch-form {
	width: 80%;
	height: 160px;
	-webkit-transform: translate3d(0,3em,0);
	transform: translate3d(0,3em,0);
}

.morphsearch-input {
	width: 100%;
	height: 100%;
	padding: 0 10% 0 10px;
	font-weight: 700;
	border: none;
	background: transparent;
	font-size: 0.8em;
	color: #FFF;
	-webkit-transition: font-size 0.5s cubic-bezier(0.7,0,0.3,1);
	transition: font-size 0.5s cubic-bezier(0.7,0,0.3,1);
}

.morphsearch-input::-ms-clear { /* remove cross in IE */
    display: none;
}

.morphsearch.hideInput .morphsearch-input {
	color: transparent;
	-webkit-transition: color 0.3s;
	transition: color 0.3s;
}

.morphsearch.open .morphsearch-input {
	font-size: 7em;
}

/* placeholder */
.morphsearch-input::-webkit-input-placeholder {
	color: #FFF;
}

.morphsearch-input:-moz-placeholder {
	color: #FFF;
}

.morphsearch-input::-moz-placeholder {
	color: #FFF;
}

.morphsearch-input:-ms-input-placeholder {
	color: #FFF;
}

/* hide placeholder when active in Chrome */
.gn-search:focus::-webkit-input-placeholder {
	color: transparent;
}

input[type="search"] { /* reset normalize */
	-webkit-box-sizing: border-box; 
	box-sizing: border-box;	
}

.morphsearch-input:focus,
.morphsearch-submit:focus {
	outline: none;
}

.morphsearch-submit {
	position: absolute;
	width: 80px;
	height: 80px;
	text-indent: 100px;
	overflow: hidden;
	right: 0;
	top: 50%;
	background: transparent url(../img/magnifier.svg) no-repeat center center;
	background-size: 100%;
	border: none;
	pointer-events: none;
	transform-origin: 50% 50%;
	opacity: 0;
	-webkit-transform: translate3d(-30px,-50%,0) scale3d(0,0,1);
	transform: translate3d(-30px,-50%,0) scale3d(0,0,1);
}

.morphsearch.open .morphsearch-submit {
	pointer-events: auto;
	opacity: 1;
	-webkit-transform: translate3d(-30px,-50%,0) scale3d(1,1,1);
	transform: translate3d(-30px,-50%,0) scale3d(1,1,1);
	-webkit-transition: opacity 0.3s, -webkit-transform 0.3s;
	transition: opacity 0.3s, transform 0.3s;
	-webkit-transition-delay: 0.5s;
	transition-delay: 0.5s;
}

.morphsearch-close {
	width: 36px;
	height: 36px;
	position: absolute;
	right: 1em;
	top: 1em;
	overflow: hidden;
	text-indent: 100%;
	cursor: pointer;
	pointer-events: none;
	opacity: 0;
	-webkit-transform: scale3d(0,0,1);
	transform: scale3d(0,0,1);
}

.morphsearch.open .morphsearch-close {
	opacity: 1;
	pointer-events: auto;
	-webkit-transform: scale3d(1,1,1);
	transform: scale3d(1,1,1);
	-webkit-transition: opacity 0.3s, -webkit-transform 0.3s;
	transition: opacity 0.3s, transform 0.3s;
	-webkit-transition-delay: 0.5s;
	transition-delay: 0.5s;
}

.morphsearch-close::before,
.morphsearch-close::after {
	content: '';
	position: absolute;
	width: 2px;
	height: 100%;
	top: 0;
	left: 50%;
	border-radius: 3px;
	opacity: 0.5;
	background: #FFF;
}

.morphsearch-close:hover.morphsearch-close::before,
.morphsearch-close:hover.morphsearch-close::after {
	opacity: .8;
}

.morphsearch-close::before {
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

.morphsearch-close::after {
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}

.morphsearch-content {
	color: #FFF;
	margin-top: 4.5em;
	width: 100%;
	height: 0;
	overflow: hidden;
	padding: 0 10.5%;
	background: #f1f1f1;
	position: absolute;
	pointer-events: none;
	opacity: 0;
}

.morphsearch.open .morphsearch-content {
	opacity: 1;
	height: auto;
	overflow: visible; /* this breaks the transition of the children in FF: https://bugzilla.mozilla.org/show_bug.cgi?id=625289 */
	pointer-events: auto;
	-webkit-transition: opacity 0.3s 0.5s;
	transition: opacity 0.3s 0.5s;
}

.dummy-column {
	width: 30%;
	padding: 0 0 6em;
	float: left;
	opacity: 0;
	-webkit-transform: translate3d(0,100px,0);
	transform: translateY(100px);
	-webkit-transition: -webkit-transform 0.5s, opacity 0.5s;
	transition: transform 0.5s, opacity 0.5s;
}

.morphsearch.open .dummy-column:first-child {
	-webkit-transition-delay: 0.4s;
	transition-delay: 0.4s;
}

.morphsearch.open .dummy-column:nth-child(2) {
	-webkit-transition-delay: 0.45s;
	transition-delay: 0.45s;
}

.morphsearch.open .dummy-column:nth-child(3) {
	-webkit-transition-delay: 0.5s;
	transition-delay: 0.5s;
}

.morphsearch.open .dummy-column {
	opacity: 1;
	-webkit-transform: translate3d(0,0,0);
	transform: translate3d(0,0,0);
}

.dummy-column:nth-child(2) {
	margin: 0 5%;
}

.dummy-column h2 {
	font-size: 1em;
	letter-spacing: 1px;
	text-transform: uppercase;
	font-weight: 800;
	color: #c2c2c2;
	padding: 0.5em 0;
}

.round {
	border-radius: 50%;
}

.dummy-media-object {
	padding: 0.75em;
	display: block;
	margin: 0.3em 0;
	cursor: pointer;
	border-radius: 5px;
	background: rgba(118,117,128,0.05);
}

.dummy-media-object:hover,
.dummy-media-object:focus {
	background: rgba(118,117,128,0.1);
}

.dummy-media-object img {
	display: inline-block;
	width: 50px;	
	margin: 0 10px 0 0;
	vertical-align: middle;
}

.dummy-media-object h3 {
	vertical-align: middle;
	font-size: 0.85em;
	display: inline-block;
	font-weight: 700;
	margin: 0 0 0 0;
	width: calc(100% - 70px);
	color: rgba(145,145,145,0.7);
}

.dummy-media-object:hover h3 {
	color: rgba(236,90,98,1);
}

/* Overlay */
.overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,0.5);
	opacity: 0;
	pointer-events: none;
	-webkit-transition: opacity 0.5s;
	transition: opacity 0.5s;
	-webkit-transition-timing-function: cubic-bezier(0.7,0,0.3,1);
	transition-timing-function: cubic-bezier(0.7,0,0.3,1);
}

.morphsearch.open ~ .overlay {
	opacity: 0;
}

@media screen and (max-width: 53.125em) {
	.morphsearch-input {
		padding: 0 25% 0 10px;
	}
	.morphsearch.open .morphsearch-input {
		font-size: 2em;
	}
	.dummy-column {
		float: none;
		width: auto;
		padding: 0 0 2em;
	}
	.dummy-column:nth-child(2) {
		margin: 0;
	}
	.morphsearch.open .morphsearch-submit {
		-webkit-transform: translate3d(0,-50%,0) scale3d(0.5,0.5,1);
		transform: translate3d(0,-50%,0) scale3d(0.5,0.5,1);
	}
}

@media screen and (max-width: 60.625em) {
	.morphsearch {
		width: 80%;
		top: 10%;
		right: 10%;
	}
}
#search-btn {
  background: white url(data:image/svg+xml;base64,<svg xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:cc="http://creativecommons.org/ns#" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:svg="http://www.w3.org/2000/svg" xmlns="http://www.w3.org/2000/svg" xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" width="32px" height="32px" viewBox="0 0 32 32" id="svg2" version="1.1" inkscape:version="0.91 r13725" sodipodi:docname="32.svg">
  <defs id="defs4"></defs>
  <sodipodi:namedview id="base" pagecolor="#ffffff" bordercolor="#666666" borderopacity="1.0" inkscape:pageopacity="0.0" inkscape:pageshadow="2" inkscape:zoom="11.313709" inkscape:cx="-2.4965568" inkscape:cy="18.949848" inkscape:document-units="px" inkscape:current-layer="layer1" showgrid="true" units="px" inkscape:snap-bbox="true" inkscape:bbox-nodes="true" inkscape:bbox-paths="true" inkscape:snap-bbox-edge-midpoints="true" inkscape:snap-bbox-midpoints="true" inkscape:window-width="1366" inkscape:window-height="715" inkscape:window-x="-8" inkscape:window-y="-8" inkscape:window-maximized="1">
    <inkscape:grid type="xygrid" id="grid3366"></inkscape:grid>
  </sodipodi:namedview>
  
  <g inkscape:label="Layer 1" inkscape:groupmode="layer" id="layer1" transform="translate(0,-1020.3622)" style="fill: rgb(73, 73, 73);">
    <path style="color: rgb(0, 0, 0); font-style: normal; font-variant-ligatures: normal; font-variant-caps: normal; font-weight: normal; font-stretch: normal; font-size: medium; line-height: normal; font-family: sans-serif; text-indent: 0px; text-align: start; text-decoration: none solid rgb(0, 0, 0); letter-spacing: normal; word-spacing: normal; text-transform: none; direction: ltr; writing-mode: lr-tb; baseline-shift: baseline; text-anchor: start; white-space: normal; clip-rule: nonzero; display: inline; overflow: visible; visibility: visible; opacity: 1; isolation: auto; mix-blend-mode: normal; color-interpolation: sRGB; color-interpolation-filters: linearRGB; fill: rgb(73, 73, 73); fill-opacity: 1; fill-rule: nonzero; stroke: none; stroke-width: 1; stroke-linecap: butt; stroke-linejoin: miter; stroke-miterlimit: 4; stroke-dasharray: none; stroke-dashoffset: 0; stroke-opacity: 1; color-rendering: auto; image-rendering: auto; shape-rendering: auto; text-rendering: auto;" d="M 8 2 C 6.9006425 2 6 2.9007 6 4 L 6 29.015625 C 6 30.115025 6.9006425 31.015625 8 31.015625 L 22 31.015625 C 23.099357 31.015625 24 30.115025 24 29.015625 L 24 22.828125 C 24.441758 22.755893 24.87981 22.644784 25.310547 22.490234 L 29.212891 29.25 C 29.624045 29.9622 30.549527 30.209928 31.261719 29.798828 C 31.973911 29.387628 32.221731 28.4622 31.810547 27.75 L 27.890625 20.958984 A 0.50005 0.50005 0 0 0 27.875 20.933594 C 30.385048 18.607378 31.059037 14.773548 29.277344 11.6875 C 28.111081 9.667533 26.138741 8.4073153 24 8.0527344 L 24 4 C 24 2.9007 23.099357 2 22 2 L 8 2 z M 8 3 L 22 3 C 22.562661 3 23 3.4374 23 4 L 23 7.9550781 C 22.859982 7.9508345 22.720512 7.935805 22.580078 7.9394531 C 22.052119 7.9529858 21.522783 8.0319439 21 8.1601562 L 21 5.5 A 0.50005 0.50005 0 0 0 20.5 5 L 9.5 5 A 0.50005 0.50005 0 0 0 9 5.5 L 9 23.5 A 0.50005 0.50005 0 0 0 9.5 24 L 20.5 24 A 0.50005 0.50005 0 0 0 21 23.5 L 21 22.712891 C 21.651701 22.872559 22.324073 22.950188 23 22.931641 L 23 29.015625 C 23 29.578325 22.562661 30.015625 22 30.015625 L 8 30.015625 C 7.4373395 30.015625 7 29.578325 7 29.015625 L 7 4 C 7 3.4374 7.4373395 3 8 3 z M 10 6 L 20 6 L 20 8.4785156 C 19.671387 8.6103276 19.346316 8.7614285 19.03125 8.9433594 C 15.449652 11.011259 14.217304 15.6059 16.285156 19.1875 C 17.159721 20.70229 18.488857 21.79017 20 22.392578 L 20 23 L 10 23 L 10 6 z M 11 8 L 11 9 L 18 9 L 18 8 L 11 8 z M 22.607422 8.9375 C 24.911462 8.8775 27.174323 10.047 28.410156 12.1875 C 30.207652 15.3009 29.144632 19.270859 26.03125 21.068359 C 22.917898 22.865859 18.949853 21.8009 17.152344 18.6875 C 15.354848 15.5742 16.417868 11.606194 19.53125 9.8085938 C 20.504347 9.2467938 21.560479 8.9644 22.607422 8.9375 z M 11 10.03125 L 11 11.03125 L 16 11.03125 L 16 10.03125 L 11 10.03125 z M 22.884766 10.435547 C 22.643051 10.429987 22.400055 10.442731 22.158203 10.472656 L 22.15625 10.472656 C 21.49793 10.554656 20.866023 10.793259 20.28125 11.130859 C 17.897939 12.506859 17.064029 15.5518 18.441406 17.9375 C 19.819222 20.324 22.893741 21.155744 25.28125 19.777344 C 27.667682 18.399444 28.499517 15.3251 27.121094 12.9375 C 26.216391 11.370463 24.576766 10.474464 22.884766 10.435547 z M 22.861328 11.4375 C 22.907787 11.438536 22.953652 11.446576 23 11.449219 L 23 19.423828 C 22.307522 19.46056 21.617825 19.330331 21 19.023438 L 21 11.894531 C 21.422319 11.678004 21.851672 11.519799 22.279297 11.466797 A 0.50004997 0.50004997 0 0 0 22.28125 11.466797 C 22.474324 11.442834 22.668171 11.433192 22.861328 11.4375 z M 24 11.626953 C 24.91766 11.919301 25.735885 12.540252 26.253906 13.4375 C 27.360349 15.354 26.698732 17.805009 24.78125 18.912109 C 24.528867 19.057818 24.266582 19.168413 24 19.253906 L 24 11.626953 z M 11 12.015625 L 11 13.015625 L 15 13.015625 L 15 12.015625 L 11 12.015625 z M 20 12.599609 L 20 18.296875 C 19.73985 18.04396 19.498926 17.767171 19.308594 17.4375 C 18.370985 15.813538 18.711613 13.841573 20 12.599609 z M 11 14.046875 L 11 15.046875 L 13 15.046875 L 13 14.046875 L 11 14.046875 z M 11 16.015625 L 11 17.015625 L 14 17.015625 L 14 16.015625 L 11 16.015625 z M 27.087891 21.572266 L 30.945312 28.25 C 31.088134 28.4974 31.009082 28.790794 30.761719 28.933594 C 30.514355 29.076394 30.222928 28.9976 30.080078 28.75 L 26.232422 22.085938 C 26.331999 22.034218 26.433123 21.990248 26.53125 21.933594 C 26.724631 21.821947 26.908356 21.698099 27.087891 21.572266 z M 15 25 C 13.901353 25 13 25.9014 13 27 C 13 28.0987 13.901353 29 15 29 C 16.098647 29 17 28.0987 17 27 C 17 25.9014 16.098647 25 15 25 z M 15 26 C 15.558207 26 16 26.4418 16 27 C 16 27.5582 15.558207 28 15 28 C 14.441793 28 14 27.5582 14 27 C 14 26.4418 14.441793 26 15 26 z " transform="translate(0,1020.3622)" id="rect4429"></path>
  </g>

	
	
	<metadata>
		<rdf:rdf xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:rdfs="http://www.w3.org/2000/01/rdf-schema#" xmlns:dc="http://purl.org/dc/elements/1.1/">
			<rdf:description about="https://iconscout.com/legal#licenses" dc:title="Mobile, Phone, Device, Seo, Tool, Optimization, Search" dc:description="Mobile, Phone, Device, Seo, Tool, Optimization, Search" dc:publisher="Iconscout" dc:date="2016-12-14" dc:format="image/svg+xml" dc:language="en">
				<dc:creator>
					<rdf:bag>
						<rdf:li>Jemis Mali</rdf:li>
					</rdf:bag>
				</dc:creator>
			</rdf:description>
		</rdf:rdf>
    </metadata></svg>) no-repeat center;
  width: 50px;
  height: 50px;
  padding: 50px;
  border-radius:100px;
  box-shadow: 0 10px 150px rgba(0,0,0,.5);
}
/*!
 * classie - class helper functions
 * classie.has( elem, 'my-class' ) -> true/false
 * classie.add( elem, 'my-new-class' )
 * classie.remove( elem, 'my-unwanted-class' )
 * classie.toggle( elem, 'my-class' )
 */

/*jshint browser: true, strict: true, undef: true */
/*global define: false */

( function( window ) {

'use strict';

// class helper functions from bonzo https://github.com/ded/bonzo

function classReg( className ) {
  return new RegExp("(^|\\s+)" + className + "(\\s+|$)");
}

// classList support for class management
// altho to be fair, the api sucks because it won't accept multiple classes at once
var hasClass, addClass, removeClass;

if ( 'classList' in document.documentElement ) {
  hasClass = function( elem, c ) {
    return elem.classList.contains( c );
  };
  addClass = function( elem, c ) {
    elem.classList.add( c );
  };
  removeClass = function( elem, c ) {
    elem.classList.remove( c );
  };
}
else {
  hasClass = function( elem, c ) {
    return classReg( c ).test( elem.className );
  };
  addClass = function( elem, c ) {
    if ( !hasClass( elem, c ) ) {
      elem.className = elem.className + ' ' + c;
    }
  };
  removeClass = function( elem, c ) {
    elem.className = elem.className.replace( classReg( c ), ' ' );
  };
}

function toggleClass( elem, c ) {
  var fn = hasClass( elem, c ) ? removeClass : addClass;
  fn( elem, c );
}

var classie = {
  // full names
  hasClass: hasClass,
  addClass: addClass,
  removeClass: removeClass,
  toggleClass: toggleClass,
  // short names
  has: hasClass,
  add: addClass,
  remove: removeClass,
  toggle: toggleClass
};

// transport
if ( typeof define === 'function' && define.amd ) {
  // AMD
  define( classie );
} else {
  // browser global
  window.classie = classie;
}

})( window );

(function() {
          var morphSearch = document.getElementById( 'morphsearch' ),
          input = morphSearch.querySelector( 'input.morphsearch-input' ),
          ctrlClose = morphSearch.querySelector( 'span.morphsearch-close' ),
          searchBtn = document.getElementById( 'search-btn' ),
          isOpen = isAnimating = false,
          // show/hide search area
          toggleSearch = function(evt) {
            // return if open and the input gets focused
            if( evt.type.toLowerCase() === 'focus' && isOpen ) return false;

            var offsets = morphsearch.getBoundingClientRect();
            if( isOpen ) {
              classie.remove( morphSearch, 'open' );

              // trick to hide input text once the search overlay closes 
              // todo: hardcoded times, should be done after transition ends
              if( input.value !== '' ) {
                setTimeout(function() {
                  classie.add( morphSearch, 'hideInput' );
                  setTimeout(function() {
                    classie.remove( morphSearch, 'hideInput' );
                    input.value = '';
                  }, 300 );
                }, 500);
              }
              
              input.blur();
            }
            else {
              classie.add( morphSearch, 'open' );
              history.pushState("", document.title, window.location.pathname);
            }
            isOpen = !isOpen;
          };

        // events
        input.addEventListener( 'focus', toggleSearch );
        ctrlClose.addEventListener( 'click', toggleSearch );
        searchBtn.addEventListener( 'focus', function(){ input.focus(); return false; } );

        // esc key closes search overlay, keyboard navigation events
        document.addEventListener( 'keydown', function( ev ) {
          var keyCode = ev.keyCode || ev.which;
          if( keyCode === 27 && isOpen ) {
            toggleSearch(ev);
          }
        } );
        /*for demo purposes only: don't allow to submit the form*/
        //morphSearch.querySelector( 'button[type="submit"]' ).addEventListener( 'click', function(ev) { ev.preventDefault(); } );
      })();

External CSS

This Pen doesn't use any external CSS resources.

External JavaScript

  1. https://cdnjs.cloudflare.com/ajax/libs/jquery/2.1.3/jquery.min.js