/* ========================================
   * Import das Variáveis CSS
   * ========================================
*/

@import "./variables.css";

/* ========================================
   * Import da Fonte Especial 
   * ========================================
*/

@font-face {
	font-family: "spaceregular";
	src: url("../assets/fonts/space-regular-webfont.woff2") format("woff2"), url("../assets/fonts/space-regular-webfont.woff") format("woff");
	font-weight: normal;
	font-style: normal;
	font-display: swap;
}

/* ========================================
  * 1- Reset Global e Modificação de Elementos
  * ========================================
*/

* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	text-decoration: none;
}

body {
	background-image: url("https://i.imgur.com/fzGmAYC.png");
	background-repeat: no-repeat;
	background-size: 100vw;
	background-color: var(--primary-ex-dark);
	color: var(--white);
	font-family: "Space Grotesk", "Inter", sans-serif;
	margin: 0 var(--spacing-8) 0;
}

hr {
	border: 1px solid var(--primary);
	margin: var(--spacing-2) 0;
}

a {
	text-decoration: none;
	color: var(--white);
}

hgroup h2 {
	font-family: "space", "Space Grotesk", "Inter", sans-serif;
	font-size: var(--font-size-5xl);
	font-weight: 700;
	background: linear-gradient(45deg, var(--secondary), var(--tertiary));
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent;
	display: inline-block;
	/* text-shadow: 5px 5px 5px rgba(0, 0, 0, 0.8); */
}

hgroup h3 {
	font-size: var(--font-size-lg);
	font-weight: 400;
	color: var(--tertiary-ex-light);
}

hgroup hr {
	border: 1px solid var(--secondary-light);
	margin: var(--spacing-4) 0;
}

blockquote {
  display: flex;
  flex-direction: column;
	margin: var(--spacing-6) 0;
	padding: var(--spacing-4);
	border-left: 4px solid var(--tertiary-dark);
	font-style: italic;
	font-size: var(--font-size-lg);
	color: var(--white);
	background-color: var(--auxiliary1-ex-dark);
	border-radius: 0 var(--radius-xl) var(--radius-xl) 0;
	transition: color var(--transition-ease) var(--transition-speed-slow);
	cursor: default;
}

blockquote cite {
  align-self: end;
	font-size: var(--font-size-sm);
	font-style: normal;
	color: var(--white);
	transition: color var(--transition-ease) var(--transition-speed-slow);
}

blockquote:hover {
	color: var(--secondary);
}

blockquote:hover cite {
	color: var(--tertiary);
}

mark {
	font-weight: bold;
	color: var(--tertiary);
	background-color: rgba(101, 25, 163, 0.1);
	padding: 0.1rem var(--spacing-1);
	border-radius: var(--radius-sm);
}

details {
	background-color: var(--auxiliary1-ex-dark);
	border-radius: var(--radius-xl);
	padding: var(--spacing-4) var(--spacing-6);
	box-shadow: 0 0.125rem 0.375rem rgba(0, 0, 0, 0.3);
	transition: all var(--transition-speed-slow) var(--transition-ease);
	cursor: pointer;
}

details:hover {
	background-color: var(--auxiliary1-dark);
}

details[open] {
	background-color: var(--auxiliary1-ex-dark-opacity);
	transform: scale(1.01);
	cursor: auto;
}

summary {
	font-size: var(--font-size-lg);
	font-weight: 600;
	color: var(--tertiary);
	display: flex;
	align-items: center;
	justify-content: space-between;
	list-style: none;
	cursor: pointer;
}

summary::-webkit-details-marker {
	display: none;
}

summary::after {
	content: "▶";
	font-size: var(--font-size-sm);
	transition: transform var(--transition-speed-normal) var(--transition-ease);
	color: var(--tertiary-light);
	margin-left: var(--spacing-2);
}

details[open] summary::after {
	transform: rotate(90deg);
}

details dl {
	margin-top: var(--spacing-4);
	padding: var(--spacing-4);
	border-left: 3px solid var(--tertiary);
	background-color: var(--primary-ex-light);
	border-radius: var(--radius-md);
	animation: fadeIn var(--transition-speed-slow) var(--transition-ease);
}

/* ========================================
  * 2- IDs
  * ========================================
*/

#sidebar {
	background-color: var(--primary);
	width: 33%;
	border-radius: var(--radius-3xl) 0 0 var(--radius-3xl);
	display: flex;
	align-items: center;
	flex-direction: column;
	padding: var(--spacing-4) var(--spacing-6);
	gap: var(--spacing-4);
	cursor: default;
}

#main {
	background-color: var(--auxiliary2-ex-dark-opacity);
	width: 66%;
	padding: var(--spacing-4) var(--spacing-6);
	border-radius: 0 var(--radius-3xl) var(--radius-3xl) 0;
	display: flex;
	flex-direction: column;
	gap: var(--spacing-6);
}

#about {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-2);
	padding: var(--spacing-4);
	border-radius: 0 var(--radius-3xl) var(--radius-3xl) 0;
}

#about p {
	line-height: 1.6;
	text-align: justify;
}

#about dl {
	margin-top: var(--spacing-4);
	background-color: var(--auxiliary1-ex-dark);
	padding: var(--spacing-6);
	border-radius: var(--radius-xl);
}

#about dt {
	font-weight: 700;
	color: var(--tertiary);
	margin-bottom: var(--spacing-2);
	font-size: var(--font-size-lg);
}

#about dd {
	margin-left: var(--spacing-4);
	margin-bottom: var(--spacing-4);
	color: var(--auxiliary2-ex-light);
}

#about dd:last-child {
	margin-bottom: 0;
}

#video {
	display: flex;
	flex-direction: column;
	gap: var(--spacing-4);
}

#footer {
	height: 100%;
	/* background-color: var(--primary); */
	padding: var(--spacing-4);
	margin-top: var(--spacing-4);
}

#footer section {
	display: flex;
	justify-content: center;
	gap: var(--spacing-12);
}

#footer img {
	height: 50px;
	padding: var(--spacing-1);
	border-radius: var(--radius-md);
	transition: all var(--transition-ease) var(--transition-speed-normal);
}

#footer img:hover {
	height: 55px;
	background-color: var(--auxiliary2-dark);
	box-shadow: 0 0 15px var(--primary);
}

#footer h3 {
	margin-top: var(--spacing-2);
	font-size: var(--font-size-sm);
	justify-self: center;
}

#formulario {
	width: 45%;
}

#errNome,
#errEmail,
#errSubject {
	margin: var(--spacing-1) var(--spacing-2) var(--spacing-3);
	color: var(--alert);
	font-size: var(--font-size-sm);
	font-weight: bold;
}

/* ========================================
  * 3- Classes
  * ========================================
*/

.main {
	background-color: var(--auxiliary1-ex-dark-opacity);
	padding: var(--spacing-6);
	border-radius: var(--radius-3xl);
	display: flex;
	flex-direction: column;
	gap: var(--spacing-6);
	justify-content: center;
	align-items: center;
}

.main hgroup {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

/* ========================================
  * 3.1- Header
  * ========================================
*/

.header {
	position: sticky;
	background-color: var(--auxiliary1-ex-dark-opacity);
	margin-top: 0;
	top: 0;
	z-index: 10;
	border-radius: 0 0 var(--radius-xl) var(--radius-xl);
	font-weight: 700;
}

.header,
.header a {
	height: fit-content;
	color: var(--tertiary);
}

.navbar_links {
	list-style: none;
	display: flex;
	justify-content: center;
	margin: 0 var(--spacing-2) var(--spacing-4);
	padding: var(--spacing-4);
	gap: var(--spacing-2);
}

.navbar_links li {
	padding: var(--spacing-2) var(--spacing-4);
	text-align: center;
}

.navbar_links a {
	border-radius: var(--radius-md);
	transition: all var(--transition-ease) var(--transition-speed-fast);
}

.navbar_links a:hover {
	color: var(--secondary-light);
	text-shadow: 0 0 2px var(--secondary-ex-light);
	background-color: var(--auxiliary2-ex-dark-opacity);
}

.active_page {
	color: var(--secondary);
	text-shadow: 0 0 8px var(--secondary-dark);
	cursor: default;
}

/* ========================================
  * 3.2 - Home Body
  * ========================================
*/

.content {
	display: flex;
}

.foto {
	width: 80%;
	max-width: 15rem;
	border-radius: var(--circle);
}

.sidebar-name {
	font-family: "space", "spacegrotesk", "inter", sans-serif;
	font-weight: 400;
	font-size: var(--font-size-4xl);
	text-align: center;
	text-shadow: 0 4px 3px rgba(0, 0, 0, 0.8);
}

.skills {
	font-weight: bold;
	color: var(--secondary-light);
}

.skills-list {
	background-color: var(--primary-ex-light);
	padding: var(--spacing-4);
	border-radius: var(--radius-xl);
	list-style: none;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: var(--spacing-2);
	flex-wrap: wrap;
	text-align: center;
}

.skills-list li span {
	transition: color var(--transition-ease) var(--transition-speed-fast);
}

.skills-list li:hover span {
	color: var(--tertiary-light);
}

.skills-list li:not(:last-child):after {
	margin-left: var(--spacing-2);
	content: "•";
}

.formacao table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0 0.3rem;
	font-size: var(--font-size-sm);
}

.formacao th {
	text-align: left;
	padding: var(--spacing-4) var(--spacing-6);
	background-color: var(--auxiliary1-ex-dark);
	color: var(--tertiary-light);
	font-weight: bold;
}

.formacao th:first-child {
	border-top-left-radius: var(--radius-xl);
}

.formacao th:last-child {
	border-top-right-radius: var(--radius-xl);
}

.formacao td {
	padding: var(--spacing-4) var(--spacing-6);
	background-color: var(--primary-light);
	border-bottom: 2px solid var(--tertiary-dark);
}

.formacao tr:last-child td:first-child {
	border-bottom-left-radius: var(--radius-xl);
}

.formacao tr:last-child td:last-child {
	border-bottom-right-radius: var(--radius-xl);
}

.formacao td:last-child {
	text-align: center;
}

.formacao tr:nth-child(even) td {
	background-color: var(--primary-ex-light);
}

.formacao tr:hover td {
	background-color: var(--auxiliary2-ex-dark-opacity);
	transition: background-color var(--transition-speed-slow) var(--transition-ease);
}

.video,
.legenda {
	align-self: center;
}

.video iframe {
	border-radius: var(--radius-3xl);
}

/* ========================================
  * 3.3 - Contato Body
  * ========================================
*/

.main_contato {
	width: 100%;
	display: flex;
	gap: var(--spacing-6);
	justify-content: center;
	align-items: center;
}

.main_contato-fieldset {
	display: flex;
	flex-direction: column;
	padding: var(--spacing-4);
	border-color: var(--primary-ex-light);
	border-radius: var(--radius-md);
}

.main_contato-fieldset legend {
	font-family: "Space Grotesk", "Inter", sans-serif;
	color: var(--tertiary-ex-light);
	padding: 0 var(--spacing-2);
	font-weight: bold;
	font-size: var(--font-size-xl);
}

.main_contato-fieldset input {
	background-color: var(--auxiliary1-ex-dark-opacity);
	border: 1px solid var(--primary-light);
	border-radius: var(--radius-md);
	color: var(--white);
	padding: var(--spacing-2);
	margin: var(--spacing-2);
	transition: all var(--transition-ease) var(--transition-speed-normal);
}

.main_contato-fieldset input:hover {
	border-color: var(--secondary-light);
}

.main_contato-fieldset input:focus {
	outline: 2px solid var(--secondary);
	background-color: var(--auxiliary1-ex-dark-opacity);
}

.main_contato-fieldset input:-webkit-autofill,
.main_contato-fieldset input:-webkit-autofill:hover,
.main_contato-fieldset input:-webkit-autofill:focus,
.main_contato-fieldset input:-webkit-autofill:active {
	-webkit-box-shadow: 0 0 0 30px var(--primary-ex-dark) inset;
	-webkit-text-fill-color: var(--white);
}

input[type="date"]::-webkit-calendar-picker-indicator {
	filter: invert(1);
}

.main_contato-fieldset textarea {
	background-color: var(--auxiliary1-ex-dark-opacity);
	border-color: var(--primary-light);
	border-radius: var(--radius-md);
	color: var(--white);
	padding: var(--spacing-2);
	margin: var(--spacing-2);
	height: 150px;
	resize: none;
	transition: all var(--transition-ease) var(--transition-speed-normal);
}

.main_contato-fieldset textarea:hover {
	border-color: var(--secondary-light);
}

.main_contato-fieldset textarea:focus {
	outline: 2px solid var(--secondary);
	background-color: var(--auxiliary1-ex-dark-opacity);
}

.main_contato-fieldset button {
	background-color: var(--tertiary);
	margin: var(--spacing-2) 0;
	align-self: center;
	width: 25%;
	height: 40px;
	border: none;
	border-radius: var(--radius-xl);
	color: var(--primary-dark);
	font-weight: 700;
	cursor: pointer;
	transition: all var(--transition-ease) var(--transition-speed-normal);
}

.main_contato-fieldset button:hover {
	background-color: var(--secondary);
	color: var(--white);
}

.required {
	color: var(--secondary-dark);
}

.section_map {
	width: 45%;
	text-align: center;
}

.section_map iframe {
	border-radius: var(--radius-xl);
	margin-top: 1rem;
	width: 100%;
	height: 70vh;
	transition: outline var(--transition-ease) var(--transition-speed-fast);
}

.section_map iframe:hover {
	outline: 2px solid var(--secondary);
}

/* ========================================
  * 3.4 - Projetos Body
  * ========================================
*/

.main_projetos {
	background-color: var(--auxiliary1-ex-dark-opacity);
	padding: var(--spacing-6);
	border-radius: var(--radius-3xl);
	display: flex;
	gap: var(--spacing-6);
	justify-content: center;
	align-items: center;
	flex-direction: column;
}

.main_projetos hgroup {
	display: flex;
	flex-direction: column;
	align-items: center;
}

.lista_projetos {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--spacing-6);
}

.projeto {
	min-width: 300px;
	width: 30%;
	border-radius: var(--radius-xl);
	background-color: var(--auxiliary2-ex-dark);
	overflow: hidden;
	transition: all var(--transition-ease) var(--transition-speed-normal);
}

.projeto img {
	width: 100%;
}

.projeto p {
	padding: var(--spacing-2);
	text-align: center;
}

.projeto:hover {
	width: 33%;
	background-color: var(--auxiliary2-dark);
	box-shadow: 0 0 10px var(--secondary-ex-dark);
}

/* ========================================
  * 4 - Keyframe
  * ========================================
*/

@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(-0.3rem);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@media (max-width: 768px) {
	.skills-list {
		font-size: var(--font-size-sm);
	}

	#video iframe {
		width: 100%;
	}
}

@media (max-width: 580px) {
	body {
		margin: 0 var(--spacing-3);
	}

  blockquote cite {
    margin-top: var(--spacing-4);
  }

	#sidebar {
		width: 100%;
		border-radius: var(--radius-xl) var(--radius-xl) 0 0;
		padding: var(--spacing-3);
	}

	#sidebar img {
		width: 100px;
	}

	#main {
		width: 100%;
		padding: var(--spacing-3);
		border-radius: 0 0 var(--radius-xl) var(--radius-xl);
		font-size: var(--font-size-sm);
	}

	.content {
		align-items: center;
		flex-direction: column;
	}

	.formacao {
		overflow: scroll;
		padding: 0 var(--spacing-2);
		font-size: var(--font-size-sm);
	}

	.main {
		justify-content: center;
		align-items: center;
		width: fit-content;
	}

	.main_contato {
		flex-direction: column;
	}

	.main_contato-fieldset {
		width: 80vw;
		justify-self: center;
	}

	.section_map {
		width: 80vw;
	}
}
