diff --git a/scss/_mixins.scss b/scss/_mixins.scss new file mode 100644 index 0000000..17e4122 --- /dev/null +++ b/scss/_mixins.scss @@ -0,0 +1,70 @@ +// Bootstrap Button Variant + +@mixin button-variant($color, $background, $border) { + color: $color; + background-color: $background; + border-color: $border; + @at-root { + &.active, + &:active, + &:focus, + &:hover, + .open .dropdown-toggle#{&} { + color: $color; + background-color: darken($background, 10%); + border-color: darken($border, 12%); + } + + &.active, + &:active, + .open .dropdown-toggle#{&} { + background-image: none; + } + + &.disabled, + &[disabled], + fieldset[disabled] #{&} { + &, + &.active, + &:active, + &:focus, + &:hover { + background-color: $background; + border-color: $border; + } + } + } + + .badge { + color: $background; + background-color: $color; + } +} + +// Background Features + +@mixin background-cover { + -webkit-background-size: cover; + -moz-background-size: cover; + background-size: cover; + -o-background-size: cover; +} + +// Font Selections + +@mixin serif-font { + font-family: "Droid Serif", "Helvetica Neue", Helvetica, Arial, sans-serif; +} + +@mixin script-font { + font-family: "Kaushan Script", "Helvetica Neue", Helvetica, Arial, cursive; +} + +@mixin body-font { + font-family: "Roboto Slab", "Helvetica Neue", Helvetica, Arial, sans-serif; +} + +@mixin heading-font { + font-family: "Montserrat", "Helvetica Neue", Helvetica, Arial, sans-serif; + text-transform: uppercase; +} diff --git a/scss/_variables.scss b/scss/_variables.scss new file mode 100644 index 0000000..44d7da4 --- /dev/null +++ b/scss/_variables.scss @@ -0,0 +1,8 @@ +// Variables + +$brand-primary: #fed136; +$brand-danger: #e74c3c; +$gray-darkest: #222; +$gray: #777; +$gray-lighter: #f7f7f7; +$placeholder-text: #bbbbbb; diff --git a/scss/agency.scss b/scss/agency.scss new file mode 100644 index 0000000..32fae57 --- /dev/null +++ b/scss/agency.scss @@ -0,0 +1,823 @@ +@import 'variables'; +@import 'mixins'; + +// Global Components + +body { + overflow-x: hidden; + @include body-font; +} + +.text-muted { + color: $gray; +} + +.text-primary { + color: $brand-primary; +} + +p { + font-size: 14px; + line-height: 1.75; +} + +p.large { + font-size: 16px; +} + +a, +a.active, +a:active, +a:focus, +a:hover { + outline: none; +} + +a { + color: $brand-primary; +} + +a.active, +a:active, +a:focus, +a:hover { + color: darken($brand-primary, 10%); +} + +h1, +h2, +h3, +h4, +h5, +h6 { + @include heading-font; + font-weight: 700; +} + +.img-centered { + margin: 0 auto; +} + +.bg-light-gray { + background-color: $gray-lighter; +} + +.bg-darkest-gray { + background-color: $gray-darkest; +} + +// Restyled Primary Buttons + +.btn-primary { + @include button-variant(white, $brand-primary, $brand-primary); + @include heading-font; + font-weight: 700; +} + +.btn-xl { + @include button-variant(white, $brand-primary, $brand-primary); + @include heading-font; + font-weight: 700; + border-radius: 3px; + font-size: 18px; + padding: 20px 40px; +} + +// Custom Navigation Bar + +.navbar-default { + background-color: $gray-darkest; + border-color: transparent; + + .navbar-brand { + color: $brand-primary; + @include script-font; + + &.active, + &:active, + &:focus, + &:hover { + color: darken($brand-primary, 10%); + } + } + + .navbar-collapse { + border-color: fade(white, 2%); + } + + .navbar-toggle { + background-color: $brand-primary; + border-color: $brand-primary; + + .icon-bar { + background-color: white; + } + + &:focus, + &:hover { + background-color: $brand-primary; + } + } + + .nav { + li { + a { + @include heading-font; + font-weight: 400; + letter-spacing: 1px; + color: white; + + &:focus, + &:hover { + color: $brand-primary; + outline: none; + } + } + } + } + + .navbar-nav > .active > a { + border-radius: 0; + color: white; + background-color: $brand-primary; + } + + .navbar-nav > .active > a:focus, + .navbar-nav > .active > a:hover { + color: white; + background-color: darken($brand-primary, 10%); + } +} + +@media(min-width:768px) { + .navbar-default { + background-color: transparent; + padding: 25px 0; + -webkit-transition: padding 0.3s; + -moz-transition: padding 0.3s; + transition: padding 0.3s; + border: none; + + .navbar-brand { + font-size: 2em; + -webkit-transition: all 0.3s; + -moz-transition: all 0.3s; + transition: all 0.3s; + } + + .navbar-nav > .active > a { + border-radius: 3px; + } + } + + .navbar-default.navbar-shrink { + background-color: $gray-darkest; + padding: 10px 0; + + .navbar-brand { + font-size: 1.5em; + } + } +} + +header { + background-image: url('../img/header-bg.jpg'); + background-repeat: none; + background-attachment: scroll; + background-position: center center; + @include background-cover; + text-align: center; + color: white; + + .intro-text { + padding-top: 100px; + padding-bottom: 50px; + + .intro-lead-in { + @include serif-font; + font-style: italic; + font-size: 22px; + line-height: 22px; + margin-bottom: 25px; + } + + .intro-heading { + @include heading-font; + font-weight: 700; + font-size: 50px; + line-height: 50px; + margin-bottom: 25px; + } + } +} + +@media(min-width:768px) { + header { + .intro-text { + padding-top: 300px; + padding-bottom: 200px; + + .intro-lead-in { + @include serif-font; + font-style: italic; + font-size: 40px; + line-height: 40px; + margin-bottom: 25px; + } + + .intro-heading { + @include heading-font; + font-weight: 700; + font-size: 75px; + line-height: 75px; + margin-bottom: 50px; + } + } + } +} + +// Global Section Styles + +section { + padding: 100px 0; + + h2.section-heading { + font-size: 40px; + margin-top: 0; + margin-bottom: 15px; + } + + h3.section-subheading { + font-size: 16px; + @include serif-font; + text-transform: none; + font-style: italic; + font-weight: 400; + margin-bottom: 75px; + } +} + +@media(min-width:768px) { + section { + padding: 150px 0; + } +} + +// Services Section + +.service-heading { + margin: 15px 0; + text-transform: none; +} + +// Portfolio Section + +#portfolio { + .portfolio-item { + margin: 0 0 15px; + right: 0; + + .portfolio-link { + display: block; + position: relative; + max-width: 400px; + margin: 0 auto; + + .portfolio-hover { + background: fade($brand-primary, 90%); + position: absolute; + width: 100%; + height: 100%; + opacity: 0; + transition: all ease 0.5s; + -webkit-transition: all ease 0.5s; + -moz-transition: all ease 0.5s; + + &:hover { + opacity: 1; + } + + .portfolio-hover-content { + position: absolute; + width: 100%; + height: 20px; + font-size: 20px; + text-align: center; + top: 50%; + margin-top: -12px; + color: white; + + i { + margin-top: -12px; + } + + h3, + h4 { + margin: 0; + } + } + } + } + + .portfolio-caption { + max-width: 400px; + margin: 0 auto; + background-color: white; + text-align: center; + padding: 25px; + + h4 { + text-transform: none; + margin: 0; + } + + p { + @include serif-font; + font-style: italic; + font-size: 16px; + margin: 0; + } + } + } + + * { + z-index: 2; + } +} + +@media(min-width:767px) { + #portfolio { + .portfolio-item { + margin: 0 0 30px; + } + } +} + +// Timeline + +.timeline { + list-style: none; + padding: 0; + position: relative; + + &:before { + top: 0; + bottom: 0; + position: absolute; + content: ""; + width: 2px; + background-color: #f1f1f1; + left: 40px; + margin-left: -1.5px; + } + + > li { + margin-bottom: 50px; + position: relative; + min-height: 50px; + + &:after, + &:before { + content: " "; + display: table; + } + + &:after { + clear: both; + } + + .timeline-panel { + width: 100%; + float: right; + padding: 0 20px 0 100px; + position: relative; + text-align: left; + + &:before { + border-left-width: 0; + border-right-width: 15px; + left: -15px; + right: auto; + } + + &:after { + border-left-width: 0; + border-right-width: 14px; + left: -14px; + right: auto; + } + } + + .timeline-image { + left: 0; + margin-left: 0; + width: 80px; + height: 80px; + position: absolute; + z-index: 100; + background-color: $brand-primary; + color: white; + border-radius: 100%; + border: 7px solid #f1f1f1; + text-align: center; + + h4 { + font-size: 10px; + margin-top: 12px; + line-height: 14px; + } + } + + &.timeline-inverted > .timeline-panel { + float: right; + text-align: left; + padding: 0 20px 0 100px; + + &:before { + border-left-width: 0; + border-right-width: 15px; + left: -15px; + right: auto; + } + + &:after { + border-left-width: 0; + border-right-width: 14px; + left: -14px; + right: auto; + } + } + + &:last-child { + margin-bottom: 0; + } + } + + .timeline-heading { + h4 { + margin-top: 0; + color: inherit; + + &.subheading { + text-transform: none; + } + } + } + + .timeline-body { + > p, + > ul { + margin-bottom: 0; + } + } +} + +@media(min-width:768px) { + .timeline { + &:before { + left: 50%; + } + + > li { + margin-bottom: 100px; + min-height: 100px; + + .timeline-panel { + width: 41%; + float: left; + padding: 0 20px 20px 30px; + text-align: right; + } + + .timeline-image { + width: 100px; + height: 100px; + left: 50%; + margin-left: -50px; + + h4 { + font-size: 13px; + margin-top: 16px; + line-height: 18px; + } + } + + &.timeline-inverted > .timeline-panel { + float: right; + text-align: left; + padding: 0 30px 20px 20px; + } + } + } +} + +@media(min-width:992px) { + .timeline { + > li { + min-height: 150px; + + .timeline-panel { + padding: 0 20px 20px; + } + + .timeline-image { + width: 150px; + height: 150px; + margin-left: -75px; + + h4 { + font-size: 18px; + margin-top: 30px; + line-height: 26px; + } + } + + &.timeline-inverted > .timeline-panel { + padding: 0 20px 20px; + } + } + } +} + +@media(min-width:1200px) { + .timeline { + > li { + min-height: 170px; + + .timeline-panel { + padding: 0 20px 20px 100px; + } + + .timeline-image { + width: 170px; + height: 170px; + margin-left: -85px; + + h4 { + margin-top: 40px; + } + } + + &.timeline-inverted > .timeline-panel { + padding: 0 100px 20px 20px; + } + } + } +} + +// Team Section + +.team-member { + text-align: center; + margin-bottom: 50px; + + img { + margin: 0 auto; + border: 7px solid white; + } + + h4 { + margin-top: 25px; + margin-bottom: 0; + text-transform: none; + } + + p { + margin-top: 0; + } +} + +// Clients Aside + +aside.clients { + img { + margin: 50px auto; + } +} + +// Contact Section + +section#contact { + background-color: $gray-darkest; + background-image: url('../img/map-image.png'); + background-position: center; + background-repeat: no-repeat; + + .section-heading { + color: white; + } + + .form-group { + margin-bottom: 25px; + + input, + textarea { + padding: 20px; + } + + input.form-control { + height: auto; + } + + textarea.form-control { + height: 236px; + } + } + + .form-control:focus { + border-color: $brand-primary; + box-shadow: none; + } + + ::-webkit-input-placeholder { + @include heading-font; + font-weight: 700; + color: $placeholder-text; + } + + :-moz-placeholder { + /* Firefox 18- */ + @include heading-font; + font-weight: 700; + color: $placeholder-text; + } + + ::-moz-placeholder { + /* Firefox 19+ */ + @include heading-font; + font-weight: 700; + color: $placeholder-text; + } + + :-ms-input-placeholder { + @include heading-font; + font-weight: 700; + color: $placeholder-text; + } + + .text-danger { + color: $brand-danger; + } +} + +// Footer + +footer { + padding: 25px 0; + text-align: center; + + span.copyright { + line-height: 40px; + @include heading-font; + text-transform: none; + } + + ul.quicklinks { + margin-bottom: 0; + line-height: 40px; + @include heading-font; + text-transform: none; + } +} + +// Social Buttons + +ul.social-buttons { + margin-bottom: 0; + + li { + a { + display: block; + background-color: $gray-darkest; + height: 40px; + width: 40px; + border-radius: 100%; + font-size: 20px; + line-height: 40px; + color: white; + outline: none; + -webkit-transition: all 0.3s; + -moz-transition: all 0.3s; + transition: all 0.3s; + + &:active, + &:focus, + &:hover { + background-color: $brand-primary; + } + } + } +} + +.btn.active, +.btn:active, +.btn:active:focus, +.btn:focus { + outline: none; +} + +.portfolio-modal { + .modal-content { + border-radius: 0; + background-clip: border-box; + -webkit-box-shadow: none; + box-shadow: none; + border: none; + min-height: 100%; + padding: 100px 0; + text-align: center; + + h2 { + margin-bottom: 15px; + font-size: 3em; + } + + p { + margin-bottom: 30px; + } + + p.item-intro { + margin: 20px 0 30px; + @include serif-font; + font-style: italic; + font-size: 16px; + } + + ul.list-inline { + margin-bottom: 30px; + margin-top: 0; + } + + img { + margin-bottom: 30px; + } + } + + .close-modal { + position: absolute; + width: 75px; + height: 75px; + background-color: transparent; + top: 25px; + right: 25px; + cursor: pointer; + + &:hover { + opacity: 0.3; + } + + .lr { + height: 75px; + width: 1px; + margin-left: 35px; + background-color: $gray-darkest; + transform: rotate(45deg); + -ms-transform: rotate(45deg); + /* IE 9 */ + -webkit-transform: rotate(45deg); + /* Safari and Chrome */ + z-index: 1051; + + .rl { + height: 75px; + width: 1px; + background-color: $gray-darkest; + transform: rotate(90deg); + -ms-transform: rotate(90deg); + /* IE 9 */ + -webkit-transform: rotate(90deg); + /* Safari and Chrome */ + z-index: 1052; + } + } + } + + .modal-backdrop { + opacity: 0; + display: none; + } +} + +// Highlight Color Customization + +::-moz-selection { + text-shadow: none; + background: $brand-primary; +} + +::selection { + text-shadow: none; + background: $brand-primary; +} + +img::selection { + background: transparent; +} + +img::-moz-selection { + background: transparent; +} + +body { + -webkit-tap-highlight-color: $brand-primary; +}