@import url('https://fonts.googleapis.com/css2?family=Outfit&family=Roboto:wght@400;700&family=Plus+Jakarta+Sans:wght@400;700&family=Source+Code+Pro:wght@300;500&display=swap');

@import url('https://fonts.googleapis.com/css2?family=Source+Serif+4:ital,opsz,wght@0,8..60,200..900;1,8..60,200..900&display=swap" rel="stylesheet');

/*
font-family: "Source Serif 4", serif;
font-family: 'Outfit', sans-serif;
font-family: 'Roboto', sans-serif;
font-family: 'Source Code Pro', monospace;
font-family: "Plus Jakarta Sans", serif;
*/

@keyframes fadeInDown {
	0% {
	  opacity: 0;
	  transform: translateY(-5rem);
	}
	100% {
	  opacity: 1;
	  transform: translateY(0);
	}
}

@keyframes sidadebarAnimation {
	to{
		transform: unset;
		opacity: 1;
	}
}

@keyframes showElementAnimation {
	to{
		transform: translate(0,0);
		opacity: 1;
	}
}

:root{
	--white:    #F5F5F5;
	--white-01: #F9F9F9;
	--grey-01:  #DDD;
	--grey-02:	#C4C4CC;
	--grey-03:  #121214;
	--grey-04:  #6b6b6b;
    --green-01: #00B37E;
	--green-02: #00875F;
	--green-03: #23693B;
	--green-04: #015F43;
	--green-05: #2d8b6f80;
	--purple-01:#8D6FC5;
    --purple-02:#3B2369;
	--blue: 	#81D8F7;
	--orange:   #FBA94C;
	--black:    #29292E;
}

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

html{
	height: 100%;
	scroll-behavior: smooth;
}


body{
	display: flex;
	flex-direction: column;

	width: 100%;
	height: 100vh;
	overflow: hidden;

	font-size: 1.375rem;
}

main{
	font-family: "Source Serif 4", serif;
	text-align: justify;
	transition: .4s;

	width: 100%;

	display: flex;
	min-height: 100vh; /* Alterado para min-height */
    overflow-y: auto; /* Permite rolagem */

	background-color: rgba(0, 179, 126, 0.1);
}

header{
	width: auto;
	border-bottom: 0.125rem solid var(--green-02);
}

header section{
	display: flex;
	flex-direction: row;
	justify-content: space-between;
}

.logo {
	width: 100%;
	max-width: 30rem;
	height: 6rem;
	margin-left: 2rem;
	transform: translate(0, -1rem);
	opacity: 0;
	animation: showElementAnimation .5s ease-in-out .3s forwards;
}

.cloudImageWrapper{
	border: 0.0625rem solid var(--green-01);
	position: absolute;
	bottom: 1vh;
	left: 1vw;
	border-radius: 50%;
	padding: .8rem;
	width: 4.5rem;
	height: 4.5rem;
	z-index: 2;

	opacity: 0;
	transition: opacity 0.2s ease-in-out;
	animation: showElementAnimation .4s ease-in-out 1s forwards;

}

.cloudImageWrapper img{
	width: 100%;
	opacity: 0.4;
	transition: opacity 0.2s ease-in-out;
}

.cloudImageWrapper:hover img {
	opacity: 1; /* opacidade total ao passar o mouse */
}

.cloudImageWrapper:hover {
	background-color: var(--white);
}

.replace{
	cursor: pointer;
}

.lateral-bar {
    width: 20rem;
    padding: 0.5rem 0.5rem 8rem 0.5rem;
    border: 0.0625rem solid var(--white);
    background-color: var(--white-01);
    box-shadow: 0px 0.5rem 0.5rem rgb(68, 39, 121);
    overflow-y: auto;
}

/* Container do genoma */
.genome-container {
    display: flex;
    flex-direction: column;
    gap: 1rem; 
}

/* Container da imagem */
.genome-image {
    flex: 1;
    width: 9rem;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto;

    opacity: 0;
    transform: translateY(-20px); 
    animation: showElementAnimation 0.4s ease-in-out 1s forwards;
    transition: all 0.3s ease;
}


.genome-image img {
    width: 100%; 
    height: auto; 
    border-radius: 8px;
}

/* Informações do genoma */
.genome-info {
    flex: 2;
}

/* Estilos para o cabeçalho e detalhes */
.genome-header {
	opacity: 0;
    transform: translateY(-20px); 
    animation: showElementAnimation 0.4s ease-in-out 1.2s forwards;
    transition: all 0.3s ease;
}

.genome-header div{
	display: flex;
	align-items: center; 
    justify-content: center; 
    margin: 0 auto;
}
.genome-header h1 {
    font-size: 1.5rem;
    color: var(--grey-03);
    margin-bottom: 0.625rem;
}

.common-name {
    font-size: 1.125rem;
    color: var(--grey-03);
}

.genome-details, .taxonomy-details, .parameters-used {
    margin-top: 1.25rem;

	opacity: 0;
    transform: translateY(-20px); 
    animation: showElementAnimation 0.4s ease-in-out 1.4s forwards;
    transition: all 0.3s ease;
}


h2 {
    font-size: 1.25rem;
    color: var(--grey-03);
    border-bottom: 0.125rem solid var(--purple-02);
    padding-bottom: 0.25rem;
    margin-bottom: 0.5rem;
}

ul {
    list-style-type: none;
    padding: 0;
}

ul li {
    font-size: 1rem;
    color: var(--grey-04);
    margin: 0.25rem 0;
}

ul li a{
    color: var(--green-01);
}

.parameters-used p {
    font-size: 1rem;
    color: #666;
}

.parameter-tag {
    display: inline-block;
    background-color: var(--grey-01);
    padding: 0.25rem;
    border-radius: 0.25rem;
    margin: 0.25rem 0;
    font-size: 0.875rem;
    color: var(--grey-04);
}

/* === Right ==== */
.compactdownload{
	transform: translate(0, -1rem);
	opacity: 0;

	animation: showElementAnimation .3s ease-in-out 1s forwards;
}

.container-table,
.container-downloaddata,
.container-downloadreport,
.wrapper-landscape-img,
.wrapper-ltr-phylogeny,
.wrapper-ltr-density,
.wrapper-ltr-copia,
.wrapper-ltr-gypsy,
.wrapper-report-chart{
	transform: translate(0, -1rem);
	opacity: 0;

	animation: showElementAnimation .3s ease-in-out 1.6s forwards;
}

.annotation_results{
	flex: 1; 
    overflow-y: auto; 

	padding-bottom: 6rem;
}

.container-data{
	margin:1rem;
	padding: 1rem 1rem 1.5rem 1rem;
	border: 0.0625rem solid var(--white);
	border-radius: 1rem;
	background-color: #FFF;
	box-shadow: 0px 0.0625rem 0.5rem rgb(68, 39, 121);
}

.container-data .container-compact{
	margin-top: 1rem;
}


.title-data{
	display: flex;
	flex-direction: row;
	gap: 0.5rem;
	align-items: center;
	font-size: 2rem;
	color: var(--grey-03);
	font-weight: 700;
	text-shadow: 0px 0.25rem 0.25rem rgba(0, 0, 0, 0.25);
	border-bottom: 0.125rem solid var(--purple-02);

	transform: translate(0, -1rem);
	opacity: 0;

	animation: showElementAnimation .3s ease-in-out 0.6s forwards;
}

.note{
	margin: 1rem 0;

	opacity: 0;
	animation: showElementAnimation .4s ease-in-out 1s forwards;
}


.container-compact{
	display: flex;
	flex-direction: row;
	justify-content: center;
	gap: 2rem;
}

.container-downloadreport,
.container-ltrtree,
.container-family{
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1rem;
}

.container-report-chart,
.container-landscape,
.container-ltrfamily,
.container-phylogeny,
.container-density{
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1.25rem;
}


/* ======== Button download ======= */

.compact-data,
.downloadreport,
.downloadfamily,
.downloadltrtree,
.downloaddata{
	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
	text-align: center;
	gap: 1rem;

	padding: 1rem;
	height: 3rem;

	border-radius: 0.3125rem;
	background: var(--green-01);
	border: 0;

	color: var(--white);
	font-size: 1rem;
	font-weight: bold;

	cursor: pointer;
	transition: all .3s ease;

	
}

.compact-data{
	width: 28rem;
	height: 4rem;
	
	border-radius: 0.8rem;
	font-size: 1.25rem;
}

.downloadreport{
	width: 26rem;
}

.downloadfamily,
.downloadltrtree{
	width: 23rem;
}

.downloaddata{
	width: 35rem;
}
.compact-data:hover,
.downloadreport:hover,
.downloadfamily:hover,
.downloadltrtree:hover,
.downloaddata:hover  {
	opacity: 0.8;
}

.compact-data[disabled],
.downloadreport[disabled],
.downloadfamily[disabled],
.downloadltrtree[disabled],
.downloaddata[disabled] {
	cursor: default;
	opacity: 0.8; 
}

.compact-data[disabled]:hover,
.downloadreport[disabled]:hover,
.downloadfamily[disabled]:hover,
.downloadltrtree[disabled]:hover,
.downloaddata[disabled]:hover  {
	color: var(--white);
	border: 0.0625rem solid var(--green-02);
}

.downloadreport:hover .box-icon,
.downloadfamily:hover .box-icon,
.downloadltrtree:hover .box-icon,
.downloaddata:hover .box-icon,
.compact-data:hover .box-icon {
    transform: translateY(4px);
}

a.disabled,
a.disabled button {
    pointer-events: none;
    opacity: 0.5;
    cursor: not-allowed;

	font-family: "Source Serif 4", serif;
}



/* =============== Table ================ */
.container-table {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    padding: 0 1rem;
}

table, td, tr{
	border-collapse: collapse;
}

.table-top {
    width: 100%;
    max-width: 62rem;
    min-width: 280px;
}

.table-footer {
    width: 100%;
    max-width: 62rem;
    min-width: 280px;
    max-height: 31rem;
    padding: 0 1rem;
    margin-bottom: 2rem;
    overflow-y: auto;
    overflow-x: auto;
    border: 0.0625rem solid var(--green-01);
}

.table-footer span{
	width: 100%;
	font-size: 2rem;
	background-color: var(--green-01);
}

.report_complete {
    white-space: pre-wrap;
}

.title-td{
	background-color: var(--green-01);
	border-bottom: var(--grey-03);
	border-radius: 0.625rem 0.625rem 0 0;
	color: var(--white);

	font-size: 1.25rem;
}

td{
	width: 20rem;
	height: 3rem;
	text-align: center;
}

.main-td{
	font-weight: 700;
}


/*=====  Slides ====== */
.slider,
.slider-2,
.slider-3_1, 
.slider-3,
.slider-4,
.slider-5,
.slider-6  {
    position: relative;
   	width: 100%;
    margin: 0 auto;
    overflow: hidden;
}

.slider,
.slider-5,
.slider-6 {
	max-width: 80rem;
}

.slider-2,
.slider-3_1, .slider-3,
.slider-4  {
    max-width: 68rem;
}

.slides,
.slides-2, 
.slides-3_1, 
.slides-3,
.slides-4,
.slides-5,
.slides-6 {
    display: flex;
    transition: transform 0.5s ease;
}

.slide,
.slide-2, 
.slide-3_1, 
.slide-3,
.slide-4,
.slide-5,
.slide-6 {
    flex: 0 0 100%;
    max-width: 100%;
    padding: 0 1rem;
    display: flex;
    justify-content: center;
    align-items: center;
}

.slide img,
.slide-2 img, 
.slide-3_1 img, 
.slide-3 img,
.slide-4 img,
.slide-5 img,
.slide-6 img {
    width: 100%;
    max-width: 100%;
    padding: 0 2rem;
}

.slide-5 img,
.slide-6 img {
	background-color: white;
}

.prev-slide, .next-slide {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background-color: var(--green-01);
    color: white;
    border: none;
    cursor: pointer;
    padding: 1rem 0.5rem 1rem 0.5rem;
    z-index: 100;
	font-size: 2rem;
}

.prev-slide {
    left: 0.5rem;
}

.next-slide {
    right: 0.5rem;
}

.slides button:hover {
    background-color: rgba(0, 0, 0, 0.8);
}

.Landscape-img {
    width: 100%;
    height: auto;
    max-width: 100%;
}

/* =========== Dark Theme =============== */
.header.dark-theme{
	background-color: var(--black);
}

.lateral-bar.dark-theme{
	background-color: var(--black);
	box-shadow: 0px 0.5rem 0.5rem rgb(22, 100, 61);
	border: 0.0625rem solid var(--black);
}

h2.dark-theme,
.common-name.dark-theme,
.genome-header.dark-theme h1 {
    color: var(--grey-02);
}

h2.dark-theme {
    border-bottom: 0.125rem solid var(--purple-01);
}


ul.dark-theme li {
    font-size: 1rem;
    color: var(--grey-01);
    margin: 0.25rem 0;
}

ul.dark-theme li a{
    color: var(--blue);
}

.note.dark-theme{
	color: var(--grey-02);
}

.title-data.dark-theme{
	text-shadow: 0px 0.25rem 0.25rem rgba(83, 83, 83, 0.25);
	border-bottom: 0.125rem solid var(--purple-01);
	color: var(--grey-02);
}

main.dark-theme{
	background-color: var(--grey-03);
}

.container-data.dark-theme{
	border: 0.0625rem solid var(--black);
	background-color: var(--black);
	box-shadow: 0px 0.0625rem 0.5rem rgb(22, 100, 61);
}

.container-output.dark-theme{
	color: var(--grey-02);
}
/*=======================================*/

@media (max-width: 1279px) {
	html{
		font-size: 93.75%;
	}

	.note{
		font-size: 1.25rem;
	}

	#output {
        font-size: 1.25rem;
        line-height: 1.1;
        word-wrap: break-word;
        overflow-x: auto;
    }

	.slider-2 {
        width: 100%;
        max-width: 50rem;
        padding: 0 1rem;
    }
}

@media (max-width: 1200px) {
	main{
		flex-direction: column;
	}

	.lateral-bar {
		width: 96%;
		margin: 1rem 1rem 0 1rem;
    	padding: 1rem;
    	border: 0.0625rem solid var(--white);
    	border-radius: 1rem;
    	background-color: #FFF;
   	 	box-shadow: 0rem 0rem 0.5rem rgb(68, 39, 121);

		overflow-y: initial;
	}

	.lateral-bar.dark-theme{
		box-shadow: 0 0 0.5rem rgb(22, 100, 61);
	}
	
	/* Container do genoma */
	.genome-container {
		flex-direction: row;
	}

	.genome-image{
		flex: none;
		width: 15rem;
	}

	.annotation_results{
		flex: none; 
		overflow-y: initial; 
	}

	.container-compact{
		flex-wrap: wrap;
	}
}

@media (max-width: 768px) {
	.container-header{
		display: flex;
		align-items: center;
		justify-content: center;
	}

	.logo {
		margin-left: 1.5rem;
	}

	.cloudImageWrapper{
		bottom: 1vh;
		left: 1.5vw;
		padding: 0.7rem;
		width: 3.5rem;
		height: 3.5rem;
	}

	.container-table {
        padding: 0 0.5rem;
    }
    
    #output {
        font-size: 0.9rem;
    }
    
    .title-td {
        font-size: 0.9rem;
    }

	.compact-data, 
	.downloadreport,
	.downloaddata,
	.downloadltrtree {
		width: 20rem;
		height: 3rem;
		gap: 1rem;
	}

	.compact-data span,
	.downloadreport span,
	.downloaddata span,
	.downloadltrtree span{
		font-size: 1rem;
	}

	.note{
		font-size: 1rem;
	}
	
}

@media (max-width: 480px){
	.genome-container {
		flex-direction: column;
	}

	.genome-image{
		/* flex: 1; */
		width: 10rem;
	}

	.title-data{
		font-size: 1.5rem;
	}

	.logo {
		max-width: 20rem;
		margin-left: 0.5rem;
	}

	.container-compact{
		gap: 0.5rem;
	}

	.lateral-bar {
		width: 94%;
	}

	.cloudImageWrapper{
		bottom: 1vh;
		left: 1.5rem;
		padding: 0.7rem;
		width: 3.5rem;
		height: 3.5rem;
	}

	.title-data {
		justify-content: center;
	}

	.compact-data, 
	.downloadreport,
	.downloaddata,
	.downloadltrtree {
		width: 16rem;
		height: 3rem;
	}

	.box-icon{
		width: 1.25rem;
	}

	.compact-data span,
	.downloadreport span,
	.downloaddata span,
	.downloadltrtree span{
		font-size: 0.8rem;
	}

	.main-td {
		font-size: 1.2rem;
	}

	#output {
        font-size: 0.8rem;
    }
    
    .title-td {
        font-size: 0.8rem;
    }

	.container-downloadreport,
	.container-family,
	.container-ltrtree{
		gap: 0.5rem;
		flex-direction: column;
	}


	.container-report-chart,
	.container-landscape,
	.container-phylogeny{
		gap: 1rem;
	}

	.downloadreport,
	.downloaddata,
	.downloadltrtree{
		margin-top: 0;
		margin-bottom: 0;
	}

	.prev-slide,
	.next-slide{
		font-size: 1rem;
	}
	
}

@media (max-width: 400px) {
    #output {
        font-size: 0.5rem;
    }

	.compact-data, 
	.downloadreport,
	.downloaddata,
	.downloadltrtree {
		width: 16.rem;
		gap: 0.5rem;
	}

}