/*! HTML5 Boilerplate v4.3.0 | MIT License | http://h5bp.com/ */

/*
 * What follows is the result of much research on cross-browser styling.
 * Credit left inline and big thanks to Nicolas Gallagher, Jonathan Neal,
 * Kroc Camen, and the H5BP dev community and team.
 */

/* ==========================================================================
   Base styles: opinionated defaults
   ========================================================================== */

html,
button,
input,
select,
textarea {
    color: #222;
}

html {
    font-size: 1em;
    line-height: 1.4;
}

/*
 * Remove text-shadow in selection highlight: h5bp.com/i
 * These selection rule sets have to be separate.
 * Customize the background color to match your design.
 */

::-moz-selection {
    background: #b3d4fc;
    text-shadow: none;
}

::selection {
    background: #b3d4fc;
    text-shadow: none;
}

/*
 * A better looking default horizontal rule
 */

hr {
    display: block;
    height: 1px;
    border: 0;
    border-top: 1px solid #ccc;
    margin: 1em 0;
    padding: 0;
}

/*
 * Remove the gap between images, videos, audio and canvas and the bottom of
 * their containers: h5bp.com/i/440
 */

audio,
canvas,
img,
video {
    vertical-align: middle;
}

/*
 * Remove default fieldset styles.
 */

fieldset {
    border: 0;
    margin: 0;
    padding: 0;
}

/*
 * Allow only vertical resizing of textareas.
 */

textarea {
    resize: vertical;
}

/* ==========================================================================
   Browse Happy prompt
   ========================================================================== */

.browsehappy {
    margin: 0.2em 0;
    background: #ccc;
    color: #000;
    padding: 0.2em 0;
}

/* ==========================================================================
   GLOBAL styles & layout
   ========================================================================== */

body {
	background-image:url('/img/bg.jpg');
	background-size:580px 800px;
	background-repeat:repeat;
	font-family: 'TradeGothic', serif;
}

h1, h2, h3, h4, h5, h6 {
	font-weight:normal;
}

.out {
	width:100%;
}

.middle-col {
	width: 70%;
	max-width: 850px;
	margin: 0 auto;
}

hr.dotted {
	border-top: none;
	border-bottom:1px dashed rgba(0,0,0,0.2);
}

.hand-headline {
	font-family:'TrashHand',sans-serif;
	font-size:1.8em;
	letter-spacing:0.05em;
}

.descriptor-sm {
	text-transform:uppercase;
	color:rgba(0,0,0,0.6);
	letter-spacing:0.2em;
	font-size:0.55em;
}

.btn {
	font-family: 'TradeGothicCnd',sans-serif;
	font-size: 2.5em;
	color: #fff;
	background-color: #FF4800;
	border-radius: 8px;
	border-bottom: 8px solid #99310D;
	padding: 30px 10% 25px;
	width: 80%;
	text-transform: uppercase;
	text-decoration: none;
	display: block;
	text-align: center;
	transition:background-color 0.2s ease, border-bottom-color 0.2s ease;
	line-height: 1;
}

.btn:hover, .btn:focus {
	background-color: #DB440F;
	border-bottom-color: #7C2711;
}

.videoWrapper {
	position: relative;
	padding-bottom: 56.25%; /* 16:9 */
	padding-top: 25px;
	height: 0;
}
.videoWrapper iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}




/* ==========================================================================
   HEADER styles & layout
   ========================================================================== */

.the-header .twi-credit, .the-header .social-btns {
	text-align:center;
	position:absolute;
	top:18px;
}

.the-header .twi-credit .descriptor-sm, .the-header .social-btns .descriptor-sm {display:block;}

.the-header .twi-credit {left:20px;}
.the-header .social-btns {right:0;}

.the-header .twi-credit a {
	display:inline-block;
	background-image:url('/img/iTWI-logo.svg');
	background-size:55px 55px;
	width:55px;
	height:55px;
	background-repeat:no-repeat;
	margin-top: 6px;
	opacity:1;
	transition:opacity 0.2s ease;
}

.the-header .twi-credit a:hover {
	opacity:0.7;
}

.the-header .social-btns .fb {
	margin-top:8px;
}

.the-header .social-btns .tw {
	margin-top:10px;
	padding-left: 28px;
}

.the-header .logo-intro {
	margin:20px auto 0;
	width:70%;
	text-align:center;
}

.the-header .logo-intro p {
	font-size:0.625em;
	text-transform:uppercase;
	color:rgba(0,0,0,0.7);
	line-height:1.5;
	letter-spacing:0.2em;
	margin: 50px auto 0;
	width: 75%;
}

.the-logo {
	width:320px;
	height:340px;
	margin: -80px 0 -70px;
}

.the-header .logo-intro svg.the-logo {
	overflow: visible;
}

#red-dot {
	-webkit-animation: flash 3s infinite, slide-in 2.6s 1;
	-moz-animation: flash 3s infinite, slide-in 2.6s 1;
	-o-animation: flash 3s infinite, slide-in 2.6s 1;
	animation: flash 3s infinite, slide-in 2.6s 1;
}

#word-the, #word-world, #word-investigates {
	-webkit-animation-delay:0;
	-webkit-animation-timing-function:ease-in;
	-webkit-animation-name: slide-in;
	-webkit-animation-iteration-count:1;
	-moz-animation-delay:0;
	-moz-animation-timing-function:ease-in;
	-moz-animation-name: slide-in;
	-moz-animation-iteration-count:1;
	-o-animation-delay:0;
	-o-animation-timing-function:ease-in;
	-o-animation-name: slide-in;
	-o-animation-iteration-count:1;
	animation-delay:0;
	-webkit-animation-timing-function:ease-in;
	animation-name: slide-in;
	animation-iteration-count:1;
}

#word-the {
	-webkit-animation-duration:2s;
	-moz-animation-duration:2s;
	-o-animation-duration:2s;
	animation-duration:2s;
}

#word-world, #red-dot {
	-webkit-animation-duration:2.6s;
	-moz-animation-duration:2.6s;
	-o-animation-duration:2.6s;
	animation-duration:2.6s;
}

#word-investigates {
	-webkit-animation-duration:3.5s;
	-moz-animation-duration:3.5s;
	-o-animation-duration:3.5s;
	animation-duration:3.5s;
}

@-webkit-keyframes flash {
  0%, 20%, 100%   { opacity: 1; }
  10% { opacity: 0; }
}

@keyframes flash {
  0%, 20%, 100%   { opacity: 1; }
  10% { opacity: 0; }
}


@-webkit-keyframes slide-in {
  0% {
    -webkit-transform: translateY(-500px);
    transform: translateY(-500px);
  }

  30%, 100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}

@keyframes slide-in {
  0% {
    opacity: 0;
    -webkit-transform: translateY(-500px);
    -ms-transform: translateY(-500px);
    transform: translateY(-500px);
  }

  100% {
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
}



/* ==========================================================================
   INTRO styles & layout
   ========================================================================== */

.intro h1, .intro h3 {
	text-align:center;
	padding: 0 30px;
}

.intro h1 {
	margin:50px 0 0;
	line-height:1.2;
}

.intro h3 {
	font-family:'TradeGothicCnd',sans-serif;
	font-size:6.5em;
	text-transform:uppercase;
	margin: 10px 0 20px;
	letter-spacing:-0.025em;
	line-height: 0.9;
}

.intro .team-pic {
	background-image:url('/img/starburst.svg');
	background-size:1408px 800px;
	background-position:center center;
	margin:-200px auto 0;
	text-align:center;
	min-height:800px;
}

.intro .team-pic img.desk {
	max-width: 980px;
	margin-top: 200px;
	width: 90%;
}

.intro .team-pic img.mob {
	display:none;
}

.intro .description {
	margin-top: -80px;
}

.intro .description h4 {
	font-size: 2em;
	margin: 0;
	line-height: 1.3;
	width: 90%;
}

.intro .description p {
	font-size:1.25em;
	margin: 0.8em 0;
}

.intro .description .btn {
	margin:50px 0 80px;
}

.intro .vid-section h4 {
	font-weight:bold;
	text-transform:uppercase;
	letter-spacing:0.6em;
	text-align:center;
	font-size:0.75em;
	color:rgba(0,0,0,0.8);
	margin: 60px 0 25px;
}




/* ==========================================================================
   SIGNUP styles & layout
   ========================================================================== */

.sign-up {
	background-color:rgba(255,255,255,0.6);
	border-top:8px solid #FF4800;
	margin:150px 0 0;
}

.sign-up .hand-headline {
	text-align:center;
	margin:50px 0 0;
}

.sign-up h2 {
	font-family:'TradeGothicCnd',sans-serif;
	font-size:5.3em;
	letter-spacing:-0.025em;
	margin:5px 0;
	text-align:center;
	text-transform:uppercase;
	line-height: 0.9;
}

.sign-up .desc {
	text-align:center;
	margin: 25px 0;
}

.sign-up #mc_embed_signup .mc-field-group {
	width: 44%;
	float: left;
	margin: 0 3%;
	clear: none;
}

.sign-up #mc_embed_signup .mc-field-group label {
	font-weight:bold;
	letter-spacing:0.1em;
	font-size:0.8em;
	text-transform:uppercase;
	color:rgba(0,0,0,0.8);
	margin: 5px 0 0 2px;
}

.sign-up #mc_embed_signup .mc-field-group input[type="text"], .sign-up #mc_embed_signup .mc-field-group input[type="email"], .sign-up #mc_embed_signup .mc-field-group select {
	border:0;
	background:transparent;
	border-bottom:3px solid #666666;
	height:30px;
	padding: 8px 0;
}

.sign-up #mc_embed_signup .mc-field-group input[type="text"], .sign-up #mc_embed_signup .mc-field-group input[type="email"] {
	font-family:'TrashHand',serif;
	letter-spacing:0.05em;
	font-size:2em;
}

 .sign-up #mc_embed_signup .mc-field-group select, .sign-up #mc_embed_signup .mc-field-group select option {
	font-family:'TrashHand',serif;
	letter-spacing:0.025em;
	height: 50px;
}

.sign-up #mc_embed_signup .mc-field-group input[type="text"]:focus, .sign-up #mc_embed_signup .mc-field-group input[type="email"]:focus, .mc-field-group select:focus {
	outline:none;
	box-shadow:none;
	background-color:#fff;
	border-bottom:3px solid #000;
}

.sign-up #mc_embed_signup .mc-field-group .asterisk {
	top: 54px;
	right: 3px;
}

.sign-up #mc_embed_signup #mc-embedded-subscribe {
	margin: 40px auto 0;
	width: 80%;
	border: 0;
	border-bottom: 8px solid #99310D;
	padding: 30px 10% 20px;
	display: inline-block;
}

.sign-up #mc_embed_signup #mc-embedded-subscribe:focus {
	outline:none;
}

.sign-up #mc_embed_signup form {
	padding:0;
	text-align: center;
	padding-bottom: 100px;
}

.sign-up #mc_embed_signup .mc-field-group input, .sign-up #mc_embed_signup .mc-field-group select, .sign-up #mc_embed_signup .mc-field-group label {
	text-align: left;
}

.sign-up #mc_embed_signup div.mce_inline_error {
	margin: 5px 0 0 0;
}

.sign-up #mc_embed_signup #mce-success-response {
	background-color: #529214;
	color: #fff;
	padding: 10px 20px;
	line-height: 1.3;
	margin: 0 auto;
}

.sign-up #mc_embed_signup .mc-field-group select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border-radius: 0;
}




/* ==========================================================================
   ABOUT styles & layout
   ========================================================================== */

.about {
	padding-top:100px;
}

.about h3 {
	font-family:'TradeGothicCnd',sans-serif;
	font-size:2.5em;
	letter-spacing:-0.025em;
	border-bottom:4px solid rgba(0,0,0,0.4);
	margin:0 0 30px;
	text-transform:uppercase;
	line-height: 1.2;
}

.about .awards img.desk {
	width:100%;
	height:auto;
}

.about .awards img.mob {
	display:none;
}

.about .awards {
	margin-top: 30px;
}





/* ==========================================================================
   FOOTER styles & layout
   ========================================================================== */

.the-footer {
	margin-top:140px;
	padding-top:3px;
	border-top:1px dashed rgba(0,0,0,0.2);
	text-align:center;
}

.the-footer p {
	padding:20px 0 50px;
	border-top:1px dashed rgba(0,0,0,0.2);
	font-size:0.7em;
	margin:0;
}





/* ==========================================================================
   MEDIA QUERY styles & layout
   ========================================================================== */



@media (max-width: 800px) {

	.hand-headline {
		font-size: 1.5em;
	}
	
	.intro h3 {
		font-size: 5em;
	}
	
	.intro .team-pic {
		background-size: 1408px 680px;
		min-height: 680px;
	}
	
	.middle-col {
		width: 85%;
	}
	
	.sign-up h2 {
		font-size:5em;
	}

}

@media (max-width: 400px) {

	.the-header {
		text-align: center;
		padding-bottom: 60px;
	}
	
	.the-header .logo-intro {
		width: 85%;
	}
	
	.the-header .logo-intro p {
		margin: 25px auto 0;
		width: 100%;
	}

	.the-header .twi-credit, .the-header .social-btns {
		position: relative;
		display: inline-block;
		margin: 0 10px;
	}
	
	.the-header .twi-credit {
		left:0;
	}
	
	.the-header .social-btns {
		right:0;
	}
	
	.the-logo {
		width: 240px;
		height: 310px;
		margin: -85px 0 -90px 15px;
	}
	
	.middle-col.dotted {
		width: 70%;
	}
	
	.intro h3 {
		font-size: 5em;
		line-height: 0.9;
	}
	
	.hand-headline {
		font-size: 1.4em;
	}
	
	.intro h1 {
		margin: 50px auto 20px;
		line-height: 1.1;
		width: 85%;
	}
	
	.intro h3 {
		font-size: 4.5em;
		line-height: 0.9;
	}
	
	.btn {
		font-size: 2em;
		line-height: 1;
	}
	
	.intro .vid-section h4 {
		letter-spacing: 0.4em;
		font-size: 0.65em;
		margin: 50px 0 15px;
	}
	
	.sign-up h2 {
		margin: 10px 0;
		font-size: 4.5em;
		line-height: 0.9;
	}
	
	.sign-up #mc_embed_signup .mc-field-group {
		width: 100%;
		margin: 0 0 10px;
	}
	
	.sign-up #mc_embed_signup #mc-embedded-subscribe {
		width: 100%;
	}
	
	.intro .team-pic img.mob {
		width: 310px;
		height: 360px;
		top: 262px;
		display: inline-block;
		position: relative;
	}

	.intro .team-pic img.desk {
		display:none;
	}
	
	.intro .team-pic {
		background-size: 610px 900px;
		margin: -240px auto -90px;
		min-height: 760px;
	}
	
	.about .awards img.mob {
		width:90%;
		height:auto;
		display:block;
		margin: 0 auto;
	}
	
	.about .awards img.desk {
		display:none;
	}

}







/* ==========================================================================
   Helper classes
   ========================================================================== */

/*
 * Image replacement
 */

.ir {
    background-color: transparent;
    border: 0;
    overflow: hidden;
    /* IE 6/7 fallback */
    *text-indent: -9999px;
}

.ir:before {
    content: "";
    display: block;
    width: 0;
    height: 150%;
}

/*
 * Hide from both screenreaders and browsers: h5bp.com/u
 */

.hidden {
    display: none !important;
    visibility: hidden;
}

/*
 * Hide only visually, but have it available for screenreaders: h5bp.com/v
 */

.visuallyhidden {
    border: 0;
    clip: rect(0 0 0 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
}

/*
 * Extends the .visuallyhidden class to allow the element to be focusable
 * when navigated to via the keyboard: h5bp.com/p
 */

.visuallyhidden.focusable:active,
.visuallyhidden.focusable:focus {
    clip: auto;
    height: auto;
    margin: 0;
    overflow: visible;
    position: static;
    width: auto;
}

/*
 * Hide visually and from screenreaders, but maintain layout
 */

.invisible {
    visibility: hidden;
}

/*
 * Clearfix: contain floats
 *
 * For modern browsers
 * 1. The space content is one way to avoid an Opera bug when the
 *    `contenteditable` attribute is included anywhere else in the document.
 *    Otherwise it causes space to appear at the top and bottom of elements
 *    that receive the `clearfix` class.
 * 2. The use of `table` rather than `block` is only necessary if using
 *    `:before` to contain the top-margins of child elements.
 */

.clearfix:before,
.clearfix:after {
    content: " "; /* 1 */
    display: table; /* 2 */
}

.clearfix:after {
    clear: both;
}

/*
 * For IE 6/7 only
 * Include this rule to trigger hasLayout and contain floats.
 */

.clearfix {
    *zoom: 1;
}

/* ==========================================================================
   EXAMPLE Media Queries for Responsive Design.
   These examples override the primary ('mobile first') styles.
   Modify as content requires.
   ========================================================================== */

@media only screen and (min-width: 35em) {
    /* Style adjustments for viewports that meet the condition */
}

@media print,
       (-o-min-device-pixel-ratio: 5/4),
       (-webkit-min-device-pixel-ratio: 1.25),
       (min-resolution: 120dpi) {
    /* Style adjustments for high resolution devices */
}

/* ==========================================================================
   Print styles.
   Inlined to avoid required HTTP connection: h5bp.com/r
   ========================================================================== */

@media print {
    * {
        background: transparent !important;
        color: #000 !important; /* Black prints faster: h5bp.com/s */
        box-shadow: none !important;
        text-shadow: none !important;
    }

    a,
    a:visited {
        text-decoration: underline;
    }

    a[href]:after {
        content: " (" attr(href) ")";
    }

    abbr[title]:after {
        content: " (" attr(title) ")";
    }

    /*
     * Don't show links for images, or javascript/internal links
     */

    .ir a:after,
    a[href^="javascript:"]:after,
    a[href^="#"]:after {
        content: "";
    }

    pre,
    blockquote {
        border: 1px solid #999;
        page-break-inside: avoid;
    }

    thead {
        display: table-header-group; /* h5bp.com/t */
    }

    tr,
    img {
        page-break-inside: avoid;
    }

    img {
        max-width: 100% !important;
    }

    @page {
        margin: 0.5cm;
    }

    p,
    h2,
    h3 {
        orphans: 3;
        widows: 3;
    }

    h2,
    h3 {
        page-break-after: avoid;
    }
}
