﻿/* ---------------------------------------------- /*
 * General styles
/* ---------------------------------------------- */

'@import url(../fonts/css?family=Dosis:200,300,400,500,600,700,800);
'@import url(../fonts/css?family=Roboto:100,300,400,500,700,900);
'@import url(../fonts/css?family=Tangerine);

body {
  font: 300 14px/1.6 'Roboto', sans-serif;
	color: #666e70;
	overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    -webkit-text-size-adjust: 100%;
}

img {
	max-width: 100%;
	height: auto;
}
:focus {
    outline: 0 !important;
}

a {
	color: #777;
}

a:hover {
	text-decoration: none;
	color: #999;
}

p {
  padding-bottom: 0;
  margin-bottom: 20px;
  margin-top: 0;
}

p.dropcap:first-letter {
	float: left;
	font: 64px 'Tangerine', sans-serif;
	margin-right: 20px;
	margin-top: 2px;
	display:inline-block;
	color:#222;
}

::-moz-selection { background: #777; color: #fff; text-shadow: none; }
::selection { background: #777; color: #fff; text-shadow: none; }

/* ---------------------------------------------- /*
 * Transition elements
/* ---------------------------------------------- */


.navbar a,
.form-control {
	-webkit-transition: all 0.4s ease-in-out 0s;
	   -moz-transition: all 0.4s ease-in-out 0s;
		-ms-transition: all 0.4s ease-in-out 0s;
		 -o-transition: all 0.4s ease-in-out 0s;
			transition: all 0.4s ease-in-out 0s;
}

a,
.btn {
	-webkit-transition: all 0.125s ease-in-out 0s;
	   -moz-transition: all 0.125s ease-in-out 0s;
		-ms-transition: all 0.125s ease-in-out 0s;
		 -o-transition: all 0.125s ease-in-out 0s;
			transition: all 0.125s ease-in-out 0s;
}


/* ---------------------------------------------- /*
 * Typography
/* ---------------------------------------------- */

h1 {
	font: 300 40px/1.2 'Dosis', sans-serif;
	text-transform: uppercase;
	letter-spacing: 2px;
	margin: 5px 0 5px;
	color: #000000;
}
 


h2, h3, h4, h5, h6 {
	font: 400 40px/1.2 'Dosis', sans-serif;
	text-transform: uppercase;
	letter-spacing: 2px;
	margin: 5px 0 5px;
	color: #222;
}

h2 {
	font-size: 32px;
	font-weight: 400;
	margin: 0 0 30px;
}

h3 {
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 1px;
	margin: 0 0 5px;
}

h4 {
	font-size: 12px;
	letter-spacing: 1px;
	font-weight: 400;
}

h5 {
	font-size: 12px;
	letter-spacing: 1px;
	font-weight: 400;
}

h6 {
	font-size: 11px;
	letter-spacing: 1px;
	font-weight: 400;
}

/* ---------------------------------------------- /*
 * Reset border-radius
/* ---------------------------------------------- */

.btn,
.iconbox,
.progress,
#filter li,
.scroll-up a,
.form-control,
.input-group-addon {
	-webkit-border-radius: 0px;
	   -moz-border-radius: 0px;
		 -o-border-radius: 0px;
			border-radius: 0px;
}

/* ---------------------------------------------- /*
 * Reset box-shadow
/* ---------------------------------------------- */

.btn,
.form-control,
.form-control:hover,
.form-control:focus,
.navbar-custom .dropdown-menu {
	border-bottom: 1px solid #000;
	-webkit-box-shadow: none;
			box-shadow: none;
}

/* ---------------------------------------------- /*
 * Alerts style
/* ---------------------------------------------- */

.alert {
	border: 0;
}

/* ---------------------------------------------- /*
 * Labels
/* ---------------------------------------------- */

.label {
	padding: .2em .6em .2em;
	font-size: 70%;
}

/* ---------------------------------------------- /*
 * Input-group
/* ---------------------------------------------- */

.input-group .form-control {
	z-index: auto;
}

/* ---------------------------------------------- /*
 * Inputs styles
/* ---------------------------------------------- */

.form-control {
	background: none;
	border: none;
	border-bottom: 1px solid #2e343c;
	font-size: 12px;
	padding: 0 15px;
}

textarea.form-control {
	padding: 15px;
}

/* ---------------------------------------------- /*
 * Buttons
/* ---------------------------------------------- */

.btn {
	font-family: 'Dosis', sans-serif;
	text-transform: uppercase;
	letter-spacing: 2px;
	font-size: 13px;
	font-weight: 700;
	padding: 12px 28px;
	border: 0;
}

.btn:hover,
.btn:focus,
.btn.active {
	outline: inherit !important;
}

.btn-custom {
	background: none;
	border: 1px solid #222;
	color: #222;
}

.btn-custom:hover,
.btn-custom:focus,
.btn-custom.active {
	background: #222;
	color: #FFF;
}

/* ---------------------------------------------- /*
 * Navigation
/* ---------------------------------------------- */

.header {
	border-bottom: 1px solid #f5f5f5;
	position: relative;
	width: 100%;
	z-index: 998;
}

.navbar-custom {
	border: 0;
	border-radius: 0;
	margin: 0;
	text-transform: uppercase;
	font-family: 'Dosis', sans-serif;
}

.navbar-custom,
.navbar-custom .dropdown-menu {
	background: #fff;
	padding: 0;
}

.navbar-custom .navbar-brand,
.navbar-custom .navbar-nav > li > a,
.navbar-custom .navbar-nav .dropdown-menu > li > a {
	font-size: 14px;
	letter-spacing: 2px;
	color: #222;
	padding: 20px 10px;
}

.navbar-custom .nav li.active,
.navbar-custom .nav li a:hover,
.navbar-custom .nav li a:focus,
.navbar-custom .navbar-nav > li.active a {
	background: none;
	outline: 0;
	color: #777;
}

.navbar-custom .navbar-brand {
	font-weight: 700;
	font-size: 18px;
}

.navbar-custom .dropdown-menu {
	border: 0;
	border-top: 2px solid #777;
	border-radius: 0;
}


.navbar-custom .nav .open > a,
.navbar-custom .dropdown-menu > li > a:hover,
.navbar-custom .dropdown-menu > li > a:focus {
	background: #f5f5f5;
}

.navbar-custom .navbar-toggle .icon-bar {
	background: #222;
}

/* ---------------------------------------------- /*
 * Main
/* ---------------------------------------------- */

.section {
	padding: 120px 0 100px;
}

.section-about {
	background-color: #f2f2f2 ;
	margin: 0 0 60px;
	padding: 120px 0 0;
}

.section-services {
	background: url(../images/services.png) bottom left no-repeat;
}

.section-education {
	background: url(../images/edu.png) bottom right no-repeat;
}

.section-skills {
	background: none;
}

.section-contact {
	background: url(../images/contact.png) bottom right no-repeat;
}

.section-dark {
	background-color: #f2f2f2;
}

.section-image {
	padding: 0;
}


.paddingb-none {
	padding-bottom: 0;
}

.section-header {
	text-align: center;
	margin: 0 0 60px;
}

.section-header-left {
	text-align: left;
}

.section-header-left .section-line {
	width: 15%;
	margin: 30px 0;
}

.section-subtitle {
  font: 28px/1.2 'Tangerine', sans-serif;
  color: #2e343c;
}

.section-text {
	font-size: 14px;
}

.section-text-name {
	margin: 60px 0 0;
  font: 52px 'Tangerine', sans-serif;
  color: #000;
}

.section-line {
	background: #000;
	width: 20%;
	height: 1px;
	margin: 30px auto;
}

.section-space {
	background: none;
	width: inherit;
	margin: 30px 0;
}

.section-icon {
	font-size: 32px;
}

.cta-box {
	padding:100px 0;
	margin-top:50px;
	letter-spacing:1px;
	background-color: #f2f2f2;
}
.cta {
	display:table;
	width:100%;
	height:100%;
}
.cta-col {
	display: table-cell;
	vertical-align: middle;
	float: none;
}
.cta-heading{
	text-transform: uppercase;
	margin: 0 0 15px;
}
.cta-subtitle {
	margin-bottom:40px;
	font-weight: 500;
}
.cta-parallax { 
	background-size: 100%;
	background-attachment: fixed;
}
.cta-image {
	margin-top:-170px;
	margin-bottom:50px;
}

/* ---------------------------------------------- /*
 * Home
/* ---------------------------------------------- */

#home {
    position: relative;
    background: url(../images/Main.JPG);
    background-color: #222;
    background-attachment: fixed;
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    height: 60vh; /* Weniger Höhe */
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

#home::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.6); /* Dunklerer Overlay */
    z-index: 1;
}

.intro {
    position: relative;
    z-index: 2;
}

.subtitle {
    font-size: 18px;
    color: white;
    text-transform: uppercase;
    text-align: right;
    opacity: 0.8;
    margin-bottom: 5px;
}

.hello {
    font-family: 'Oswald', sans-serif; /* Coole, moderne Schrift */
    font-size: 50px;
    color: white;
    text-transform: uppercase;
    font-weight: 700;
    letter-spacing: 2px;
}

/* ---------------------------------------------- /*
 * Contact Details
/* ---------------------------------------------- */

.margin-0 {
	margin: 0!important;
}

.position-relative {
	position: relative;
}

.side-image {
	position: absolute;
	background: url(../images/c_details.jpg) scroll center no-repeat;
	-webkit-background-size: cover;
	   -moz-background-size: cover;
		 -o-background-size: cover;
			background-size: cover;
	height: 100%;
}

.side-image-text {
	background: #f2f2f2;
	padding: 100px 60px 50px;
}

.detailsbox {
	position: relative;
	margin: 0 0 50px;
}

.detailsbox-icon {
	position: absolute;
	width: 48px;
	height: 48px;
	left: 0;
	top: 0;
	color: #222;
	font-size: 24px;
	line-height: 1;
}

.detailsbox-text {
	padding-left: 30px;
	font: 400 14px/1.2 'Dosis', sans-serif;
}


/* ---------------------------------------------- /*
 * Services
/* ---------------------------------------------- */

.services {
	background: none;
	text-align: left;
	padding: 5px;
	margin: 0 0 20px;
}

.services-icon {
        padding: 0px;
        margin-top: 30px;
        margin-bottom: 30px;
        display: block;
        font-family:"Flaticon";
        font-size: 64px;
        line-height: 1;
}
    .services-icon:before {
        font-size: 64px;
        color: #222;
        margin-left: 0;
    }

.services-title {
	margin: 0 0 15px;
	padding: 0;
}


/* ---------------------------------------------- /*
 * Portfolio
/* ---------------------------------------------- */

/* Filter */

#filter {
	list-style-type: none;
	text-align: center;
	margin: 0 0 40px 0;
	padding: 0;
}

#filter li {
	background: none;
	display: inline-block;
	font: 500 13px/1.2 'Dosis', sans-serif;
	text-transform: uppercase;
	text-decoration: none;
	letter-spacing: 1px;
	padding: 6px 20px;
	margin: 5px;
	color: #222;
	cursor: pointer;
}

#filter li:hover,
#filter li.active {
	color: #000;
}

#filter li.active {
     font-weight: 700;
}

/* Grid and portfolio items */

/* Layout für Portfolio */
.portfolio-items-container {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  justify-content: center;
  padding: 20px 20px;
}

.portfolio-items-container .portfolio-item {
  width: calc(25% - 20px);
  list-style: none;
  overflow: hidden;
  transition: transform 0.3s ease;
}

.portfolio-items-container .portfolio-item:hover {
  transform: scale(1.03);
}

.portfolio-items-container .portfolio-item img {
  width: 100%;
  height: auto;
  display: block;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

/* Responsives Verhalten */
@media (max-width: 991px) {
  .portfolio-items-container .portfolio-item {
    width: calc(50% - 20px);
  }
}

@media (max-width: 600px) {
  .portfolio-items-container .portfolio-item {
    width: 100%;
  }
}


/* ---------------------------------------------- /*
 * Skills
/* ---------------------------------------------- */


.progress {
  height: 28px;
  box-shadow: none;
background-color: #f9f9f9;
}
.progress .progress-bar {
  text-align: left;
  padding: 0 0 0 10px;
  line-height: 28px;
	-webkit-box-shadow: none;
			box-shadow: none;
}
.progress-bar {
	background-color: #222;
}

.progress.minimal {
  margin-bottom: 7px;
  background: none;
}
.indicator {
  position: relative;
  overflow: hidden;
  margin-top: 12px;
}
.indicator .indicator-line {
  display: block;
  height: 10px;
  background-size: 9.99% 10px;
  background-position: 0 0;
border-top: 1px solid #dddddd;
background-image: linear-gradient(90deg, #dddddd 1px, transparent 1px);
}
.indicator .middle {
  position: absolute;
  left: 0;
  right: 0;
  text-align: center;
}


/* ---------------------------------------------- /*
 * Process
/* ---------------------------------------------- */

.process {
	background: #fff;
	text-align: center;
	padding: 5px;
}

.process-icon {
	margin: 0 0 25px;
        display: block;
        font-family:"Flaticon";
        font-size: 64px;
        line-height: 1;
}

    .process-icon:before {
        font-size: 64px;
        color: #222;
        margin-left: 0;
    }

.process-icon-colored {
	margin: 0 0 25px;
        display: block;
        font-family:"Flaticon";
        font-size: 128px;
        line-height: 1;
}

.process-icon-colored:before {
      margin-left: 0;
	 font-size: 128px;
      color: #777;
}

.process-title {
	margin: 0 0 15px;
	padding: 0;
}




/* ---------------------------------------------- /*
 * Contact
/* ---------------------------------------------- */

.ajax-response {
	text-align: center;
	margin-top: 10px;
}

/* ---------------------------------------------- /*
 * Footer
/* ---------------------------------------------- */

#footer {
	background: #000;
	text-align: center;
	padding: 4px 0;
	font-size: 12px;
	color: #777;
	padding-top:20px;
}

.copyright {
	margin: 0;
}

.social-links {
	list-style: none;
	padding: 0;
	margin: 0 0 20px;
}

.social-links li {
	display: inline-block;
	margin: 5px;
}

.social-links a {
	width: 36px;
	height: 36px;
	display: block;
	line-height: 35px;
	text-align: center;
	font-size: 20px;
	color: #777;
}

.social-links a:hover {
	color: #c7c7c7;
}


/* ---------------------------------------------- /*
 * Scroll to top
/* ---------------------------------------------- */

.scroll-up {
	position: fixed;
	display: none;
	z-index: 999;
	bottom: 1.8em;
	right: 1.8em;
}

.scroll-up a {
	display: block;
	width: 28px;
	height: 28px;
	text-align: center;
	color: #e3e3e3;
	font-size: 24px;
	line-height: 30px;
}

.scroll-up a:hover,
.scroll-up a:active {
	color: #222;
}

/* ---------------------------------------------- /*
 * Mouse animate icon
/* ---------------------------------------------- */

.mouse-icon {
	position: absolute;
	left: 50%;
	bottom: 40px;
	border: 2px solid #fff;
	border-radius: 16px;
	height: 50px;
	width: 30px;
	margin-left: -15px;
	display: block;
	z-index: 10;
}

.mouse-icon .wheel {
	-webkit-animation-name: drop;
	-webkit-animation-duration: 1s;
	-webkit-animation-timing-function: linear;
	-webkit-animation-delay: 0s;
	-webkit-animation-iteration-count: infinite;
	-webkit-animation-play-state: running;
	animation-name: drop;
	animation-duration: 1s;
	animation-timing-function: linear;
	animation-delay: 0s;
	animation-iteration-count: infinite;
	animation-play-state: running;
}

.mouse-icon .wheel {
	position: relative;
	border-radius: 10px;
	background: #fff;
	width: 4px;
	height: 10px;
	top: 4px;
	margin-left: auto;
	margin-right: auto;
}

@-webkit-keyframes drop	{
	0%   { top:5px;  opacity: 0;}
	30%  { top:10px; opacity: 1;}
	100% { top:25px; opacity: 0;}
}

@keyframes drop	{
	0%   { top:5px;  opacity: 0;}
	30%  { top:10px; opacity: 1;}
	100% { top:25px; opacity: 0;}
}

/* ---------------------------------------------- /*
 * Preloader
/* ---------------------------------------------- */

#preloader {
	background: #FFF;
	bottom: 0;
	left: 0;
	position: fixed;
	right: 0;
	top: 0;
	z-index: 9999;
}

#preloader-status,
.preloader-class {
	background-image: url(../images/preloader.gif);
	background-position: center;
	background-repeat: no-repeat;
	height: 200px;
	left: 50%;
	margin: -100px 0 0 -100px;
	position: absolute;
	top: 50%;
	width: 400px;
}

.preloader-class {
	background: none;
	left: 0;
	margin: 0;
	text-align: center;
	top: 65%;
}

/* ---------------------------------------------- /*
 * Media
/* ---------------------------------------------- */

@media (max-width: 991px) {

	.side-image {
		position: relative;
	height: 800px;
	}

	.portfolio-items-container .portfolio-item {
		width: 50%;
	}

	.cta-box {
		text-align: center;
		background-size: cover;
		height: 100%;	

	}
	.cta {
		margin:0;
	}
	.cta-col {
		display:block;
	}	
	.cta-parallax {
		background-attachment: scroll;
		background-size: cover;
	}	
}

@media (max-width: 767px) {

	.portfolio-items-container .portfolio-item {
		width: 100%;
	}

	.side-image-text {
		padding-left: 15px;
		padding-right: 15px;
	}

	.mouse-icon {
		display: none;
	}


  .tile.tile-horizontal {
    max-width: 400px;
  }
  .tile.tile-horizontal .tile-thumb,
  .tile.tile-horizontal .tile-content {
    float: none;
    width: 100%;
  }
  .tile.tile-horizontal .tile-content {
    padding: 0;
  }
  .tile.tile-horizontal .tile-content .tile-body,
  .tile.tile-horizontal .tile-content .tile-footer {
    text-align: center;
  }
  .tile.tile-horizontal .tile-content .tile-body {
    padding: 22px;
  }
  .tile.tile-horizontal .tile-content .tile-footer {
    padding: 8px 10px 22px 10px;
  }
}

@media (max-width: 480px) {

	h1 {
		font-size: 34px;
		letter-spacing: 3px;
	}

	h2 {
		font-size: 24px;
		margin: 0 0 30px;
		letter-spacing: 3px;
	}
}




.cta-box::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background-color: rgba(0, 0, 0, 0.6); /* dunkler Overlay */
  z-index: 1;
}

.cta-col {
  position: relative;
  z-index: 2;
  color: #fff;
}

.resume-preview {
  list-style: none;
  padding: 0;
  margin: 30px 0;
  color: #fff;
  font-size: 16px;
  line-height: 1.6;
}

.resume-preview li {
  margin-bottom: 10px;
}

#cv,
#cv h2,
#cv p,
#cv li,
#cv a,
#cv .resume-preview {
  color: #ffffff;
}

#cv .btn-custom {
  border: 1px solid #fff;
  color: #fff;
}

#cv .btn-custom:hover {
  background: #fff;
  color: #000;
}


#cv  .section-line {
	background-color: #ffffff !important;
}