From 6c5b9379f9b4a5ffc271f09665413397400643fb Mon Sep 17 00:00:00 2001 From: Danni Luo <danni.luo@utsouthwestern.edu> Date: Wed, 2 May 2018 22:40:36 -0500 Subject: [PATCH] update shiny code in vizapp --- vizapp/server.R | 68 +++---- vizapp/tools/altsplice.R | 307 ++++++++++++++++++++++++------ vizapp/tools/altsplice_ui.R | 56 +++--- vizapp/tools/dea.R | 356 +++++++++++++++++++++++++++-------- vizapp/tools/dea_ui.R | 122 ++++++------ vizapp/tools/gc.R | 263 ++++++++++++++++++++++---- vizapp/tools/gc_ui.R | 55 +++--- vizapp/tools/gsea.R | 129 +++++++++---- vizapp/tools/gsea_ui.R | 48 ++--- vizapp/tools/intro.R | 47 +++-- vizapp/tools/intro_ui.R | 120 ++++++++++++ vizapp/tools/qc.R | 213 ++++++++++++++++++--- vizapp/tools/qc_ui.R | 82 ++++---- vizapp/ui.R | 50 +++-- vizapp/www/bootstrap.min.css | 13 ++ vizapp/www/style.css | 169 ++++++++++++++++- 16 files changed, 1640 insertions(+), 458 deletions(-) create mode 100644 vizapp/tools/intro_ui.R create mode 100644 vizapp/www/bootstrap.min.css diff --git a/vizapp/server.R b/vizapp/server.R index a37441d..10aeef5 100644 --- a/vizapp/server.R +++ b/vizapp/server.R @@ -1,33 +1,35 @@ -library(shiny) -library(Vennerable) -library(qusage) -library(DT) -library(ggplot2) -library(ballgown) -library(sqldf) -library(reshape2) -library("gplots") - -shinyServer(function(input, output, session) { - - data.dir <- Sys.getenv('outputDir') - rda.dir <- data.dir - symsyn <- read.table(file='symbol2synonym.txt',header=FALSE) - names(symsyn) <- c('symbol','synonyms') - source('functions.R', local = TRUE) - source('tools/intro.R', local = TRUE) - source('tools/gc.R', local = TRUE) - source('tools/qc.R', local = TRUE) - source('tools/altsplice.R', local = TRUE) - source('tools/dea.R', local = TRUE) - source('tools/gsea.R', local = TRUE) - #source('tools/fastqc.R', local = TRUE) - source('tools/gc_ui.R', local = TRUE) - source('tools/qc_ui.R', local = TRUE) - source('tools/dea_ui.R', local = TRUE) - source('tools/gsea_ui.R', local = TRUE) - #source('tools/fastqc_ui.R', local = TRUE) - source('tools/altsplice_ui.R', local = TRUE) - -}) - +library(shiny) +library(Vennerable) +library(qusage) +library(DT) +library(ggplot2) +library(ballgown) +library(sqldf) +library(reshape2) +library("gplots") + +shinyServer(function(input, output, session) { + + # data.dir <- Sys.getenv('outputDir') + data.dir <-"workflow_322_output" + rda.dir <- data.dir + symsyn <- read.table(file='symbol2synonym.txt',header=FALSE) + names(symsyn) <- c('symbol','synonyms') + source('functions.R', local = TRUE) + source('tools/intro.R', local = TRUE) + source('tools/intro_ui.R', local = TRUE) + source('tools/gc.R', local = TRUE) + source('tools/qc.R', local = TRUE) + source('tools/altsplice.R', local = TRUE) + source('tools/dea.R', local = TRUE) + source('tools/gsea.R', local = TRUE) + #source('tools/fastqc.R', local = TRUE) + source('tools/gc_ui.R', local = TRUE) + source('tools/qc_ui.R', local = TRUE) + source('tools/dea_ui.R', local = TRUE) + source('tools/gsea_ui.R', local = TRUE) + #source('tools/fastqc_ui.R', local = TRUE) + source('tools/altsplice_ui.R', local = TRUE) + +}) + diff --git a/vizapp/tools/altsplice.R b/vizapp/tools/altsplice.R index 2aa81c6..3eb2df7 100644 --- a/vizapp/tools/altsplice.R +++ b/vizapp/tools/altsplice.R @@ -1,86 +1,285 @@ - get.bgdata <- function(var) { - rdafile <- paste(data.dir,'bg.rda',sep='/') - load(rdafile) - genetrx <- indexes(bg)$t2g - genetrx$SYMBOL <- geneNames(bg) - - geneid <- as.character(unique(genetrx[genetrx$SYMBOL %in% var$symsearch,]$g_id)) - if (exists("var$enssearch") && var$enssearch != '') { - geneid <- as.character(unique(genetrx$g_id[grep(enssearch,genetrx$g_id)])) - } - genebg <- subset(bg,paste0("gene_id=='",geneid,"'")) - rownames(genetrx) <- transcriptNames(bg) - fpkm <- texpr(bg,meas='FPKM') - keep <- genetrx[genetrx$g_id == geneid,]$t_id - cttbl <- fpkm[keep,] - grps <- pData(bg)$group - trxnames <- genetrx[genetrx$g_id == geneid,] - dtm <- melt(t(cttbl)) - names(dtm) <- c('sample','transcript','value') - dtm$grps <- rep(grps,length(keep)) - if (length(keep) < 2) { - dtm$transcript <- rep(keep,length(keep)) - } - dtm$grptrx <- paste(dtm$grps,dtm$transcript,sep='.') - test <- stattest(gown=genebg, pData=pData(bg), feature='transcript',covariate='group', libadjust=FALSE,getFC=TRUE) - if (length(keep) > 1) { - agg = collapseTranscripts(gene=geneid, gown=bg, k=var$kct, method='kmeans') - test <- stattest(gowntable=agg$tab, pData=pData(bg), feature='transcript_cluster',covariate='group', libadjust=FALSE,getFC=TRUE) - } - return(list(stattbl=test,gid=geneid,obj=genebg,cttbl=dtm,tname=trxnames)) - } + +get.bgdata <- function(var) { + rdafile <- paste(data.dir, 'bg.rda', sep = '/') + load(rdafile) + genetrx <- indexes(bg)$t2g + genetrx$SYMBOL <- geneNames(bg) + + geneid <- as.character(unique(genetrx[genetrx$SYMBOL %in% var$symsearch, ]$g_id)) + if (exists("var$enssearch") && var$enssearch != '') { + geneid <- as.character(unique(genetrx$g_id[grep(enssearch, genetrx$g_id)])) + } + genebg <- subset(bg, paste0("gene_id=='", geneid, "'")) + rownames(genetrx) <- transcriptNames(bg) + fpkm <- texpr(bg, meas = 'FPKM') + keep <- genetrx[genetrx$g_id == geneid, ]$t_id + cttbl <- fpkm[keep, ] + grps <- pData(bg)$group + trxnames <- genetrx[genetrx$g_id == geneid, ] + dtm <- melt(t(cttbl)) + names(dtm) <- c('sample', 'transcript', 'value') + dtm$grps <- rep(grps, length(keep)) + if (length(keep) < 2) { + dtm$transcript <- rep(keep, length(keep)) + } + dtm$grptrx <- paste(dtm$grps, dtm$transcript, sep = '.') + test <- + stattest( + gown = genebg, + pData = pData(bg), + feature = 'transcript', + covariate = 'group', + libadjust = FALSE, + getFC = TRUE + ) + if (length(keep) > 1) { + agg = collapseTranscripts( + gene = geneid, + gown = bg, + k = var$kct, + method = 'kmeans' + ) + test <- + stattest( + gowntable = agg$tab, + pData = pData(bg), + feature = 'transcript_cluster', + covariate = 'group', + libadjust = FALSE, + getFC = TRUE + ) + } + return(list( + stattbl = test, + gid = geneid, + obj = genebg, + cttbl = dtm, + tname = trxnames + )) +} find_sym <- function (sym) { -if (!(toupper(sym) %in% toupper(symsyn$symbol))) { - syns <- symsyn[grep(input$symsearch,symsyn$synonym,ignore.case=TRUE),]$symbol - synlist <- paste(as.character(syns),collapse=',') - if (length(syns) > 1) { - paste("Please Use Official Gene Symbols",synlist,sep=':') - }else {"Please Use Official Gene Symbols"} - }else {NULL} -} - -getgeneid <- eventReactive(input$altButton,{ - if (input$symsearch == '' & input$enssearch != '') { + if (!(toupper(sym) %in% toupper(symsyn$symbol))) { + syns <- + symsyn[grep(input$symsearch, symsyn$synonym, ignore.case = TRUE), ]$symbol + synlist <- paste(as.character(syns), collapse = ',') + if (length(syns) > 1) { + paste("Please Use Official Gene Symbols", synlist, sep = ':') + } else { + "Please Use Official Gene Symbols" + } + } else { + NULL + } +} + +getgeneid <- eventReactive(input$altButton, { + if (input$symsearch == '' & input$enssearch != '') { validate (find_sym(input$symsearch)) - } -get.bgdata(input) + } + get.bgdata(input) }) output$plot.cluster <- renderPlot({ - par(oma=c(4,4,1,1)) + par(oma = c(0, 0, 0, 0)) gid <- getgeneid()$gid bg <- getgeneid()$obj tname <- getgeneid()$tname if (nrow(tname) > 1) { - plotLatentTranscripts(gene=gid, gown=bg, k=input$kct, method='kmeans', returncluster=FALSE) + plotLatentTranscripts( + gene = gid, + gown = bg, + k = input$kct, + method = 'kmeans', + returncluster = FALSE + ) + } +}, height = "auto", width = 'auto') + +output$dlplotcluster <- renderUI({ + if (!is.null(getgeneid()$gid) & + !is.null(getgeneid()$obj) & !is.null(getgeneid()$tname)) { + downloadButton('Downloadpcluster', 'Download PNG') } }) +output$Downloadpcluster <- downloadHandler( + file = function() { + paste('plotcluster', 'png', sep = ".") + }, + content <- function(file) { + png( + file, + width = 8 * 120, + height = 4 * 120, + res = 120, + pointsize = 5 + ) + if (is.null(getgeneid()$gid) & + is.null(getgeneid()$obj) & is.null(getgeneid()$tname)) { + return() + } + par(oma = c(4, 4, 1, 1)) + gid <- getgeneid()$gid + bg <- getgeneid()$obj + tname <- getgeneid()$tname + if (nrow(tname) > 1) { + plot <- + plotLatentTranscripts( + gene = gid, + gown = bg, + k = input$kct, + method = 'kmeans', + returncluster = FALSE + ) + } + print(plot) + dev.off() + }, + contentType = "image/png" +) + + output$gene.stat <- DT::renderDataTable({ getgeneid()$stattbl -},escape=FALSE) +}, escape = FALSE, options = list(dom = 'ft')) output$trx.name <- DT::renderDataTable({ getgeneid()$tname -},escape=FALSE) +}, escape = FALSE , options = list(dom = 'ft')) +output$downloadTrx <- renderUI({ + if (!is.null(getgeneid()$tname)) { + downloadButton('DownloadTrx', 'Download CSV') + } +}) +output$DownloadTrx <- downloadHandler( + file <- paste('Gene.trxname.txt'), + content = function(file) { + write.table( + getgeneid()$tname, + file, + quote = FALSE, + row.names = FALSE, + sep = '\t' + ) + } +) output$plot.means <- renderPlot({ - par(oma=c(4,4,1,1)) - par(cex.main=0.75) + par(oma = c(1, 4, 1, 8)) + par(cex.main = 0.75) gid <- getgeneid()$gid bg <- getgeneid()$obj tname <- getgeneid()$tname if (nrow(tname) > 1) { - plotMeans(gid, bg, groupvar='group', meas='cov', colorby='transcript') + plotMeans(gid, + bg, + groupvar = 'group', + meas = 'cov', + colorby = 'transcript') + } +}, height = 900, width = "auto") + +output$dlplotmean <- renderUI({ + if (!is.null(getgeneid()$gid) & !is.null(getgeneid()$obj) & !is.null(getgeneid()$tname)) { + downloadButton('Downloadmean', 'Download PNG') } -}, height = 900, width = 900) +}) + +output$Downloadmean <- downloadHandler( + file = function() { + paste('mean', 'png', sep = ".") + }, + content <- function(file) { + png( + file, + width = 8 * 120, + height = 4 * 180, + res = 140, + pointsize = 5 + ) + if (is.null(getgeneid()$gid) & is.null(getgeneid()$obj) & is.null(getgeneid()$tname)) { + return() + } + countTable <- getgeneid()$cttbl + par(oma = c(1, 4, 1, 8)) + par(cex.main = 0.75) + gid <- getgeneid()$gid + bg <- getgeneid()$obj + tname <- getgeneid()$tname + if (nrow(tname) > 1) { + plot <- plotMeans(gid, + bg, + groupvar = 'group', + meas = 'cov', + colorby = 'transcript') + } + print(plot) + dev.off() + }, + contentType = "image/png" +) + + output$trx.gene <- renderPlot({ countTable <- getgeneid()$cttbl - par(oma=c(4,4,1,1)) - p <- ggplot(countTable,aes(x=grptrx,y=log2(value+1))) + geom_boxplot(aes(fill = factor(grptrx))) + geom_jitter(height = 0) + theme(legend.position="left",axis.text.x=element_text(angle=45,hjust=1, vjust=1),legend.key.height=unit(0.5,"line"),legend.text=element_text(size=8),legend.title=element_blank()) + ylab("Relative Abundance (FPKM)") + xlab("") + par(oma = c(4, 1, 4, 1)) + p <- + ggplot(countTable, aes(x = grptrx, y = log2(value + 1))) + geom_boxplot(aes(fill = factor(grptrx))) + geom_jitter(height = 0) + theme( + legend.position = "left", + axis.text.x = element_text( + angle = 45, + hjust = 1, + vjust = 1 + ), + legend.key.height = unit(0.5, "line"), + legend.text = element_text(size = 8), + legend.title = element_blank() + ) + ylab("Relative Abundance (FPKM)") + xlab("") print(p) +}, height = 'auto', width = 'auto') + +output$dltrxgene <- renderUI({ + if (!is.null(getgeneid()$cttbl)) { + downloadButton('Downloadtregene', 'Download PNG') + } }) + +output$Downloadtregene <- downloadHandler( + file = function() { + paste('tregene', 'png', sep = ".") + }, + content <- function(file) { + png( + file, + width = 8 * 160, + height = 4 * 120, + res = 120, + pointsize = 5 + ) + if (is.null(getgeneid()$cttbl)) { + return() + } + countTable <- getgeneid()$cttbl + par(oma = c(4, 1, 4, 1)) + p <- + ggplot(countTable, aes(x = grptrx, y = log2(value + 1))) + geom_boxplot(aes(fill = factor(grptrx))) + geom_jitter(height = 0) + theme( + legend.position = "left", + axis.text.x = element_text( + angle = 45, + hjust = 1, + vjust = 1 + ), + legend.key.height = unit(0.5, "line"), + legend.text = element_text(size = 8), + legend.title = element_blank() + ) + ylab("Relative Abundance (FPKM)") + xlab("") + print(p) + dev.off() + }, + contentType = "image/png" +) + diff --git a/vizapp/tools/altsplice_ui.R b/vizapp/tools/altsplice_ui.R index 087b3a1..30bd1a9 100644 --- a/vizapp/tools/altsplice_ui.R +++ b/vizapp/tools/altsplice_ui.R @@ -1,27 +1,35 @@ output$ui_altsplice <- renderUI({ - fluidPage( - includeCSS("www/style.css"), - sidebarLayout( - sidebarPanel( - uiOutput("dir.splice"), - textInput("symsearch", "Search By Gene Symbol", 'IL1B'), - textInput("enssearch", "Search By ENS ID",''), - numericInput("kct",label = "Number of Clusters",value = 2), - actionButton("altButton", "GO") - ), - mainPanel( - tabsetPanel( - tabPanel("Gene Compare", - dataTableOutput('gene.stat'), - dataTableOutput('trx.name'), - plotOutput("plot.cluster"), - plotOutput("trx.gene"), - plotOutput("plot.means") - ) - ) - ) - ) - ) - + list(fluidPage( + includeCSS("www/style.css"), + fluidRow( + sidebarPanel( + uiOutput("dir.splice"), + textInput("symsearch", "Search By Gene Symbol", 'IL1B'), + textInput("enssearch", "Search By ENS ID", ''), + numericInput("kct", label = "Number of Clusters", value = 2), + actionButton("altButton", "GO", class = "btn btn-primary btn-bg centerbtn") + ), + column(7, + tabsetPanel( + tabPanel( + "Gene Compare", + br(),br(), + dataTableOutput('gene.stat'), + br(),br(), + dataTableOutput('trx.name'), + br(), + uiOutput('downloadTrx'), + plotOutput("plot.cluster"), + uiOutput('dlplotcluster'), + br(),br(), + plotOutput("trx.gene"), + uiOutput('dltrxgene'), + plotOutput("plot.means", height = 900, width = 'auto'), + uiOutput('dlplotmean') + ) + )) + ) + )) + }) diff --git a/vizapp/tools/dea.R b/vizapp/tools/dea.R index 1676e6f..de9b93d 100644 --- a/vizapp/tools/dea.R +++ b/vizapp/tools/dea.R @@ -1,101 +1,309 @@ # UI-elements for DEA -ctfile <- paste(data.dir,'countTable.logCPM.txt',sep='/') -samfile <- paste(data.dir,'design.shiny.txt',sep='/') -cts <- read.table(file=ctfile,header=TRUE,sep='\t') -samtbl <- read.table(samfile,header=TRUE,sep="\t") -samples <- colnames(cts[,4:length(cts)]) -mergetbl <- merge(as.data.frame(samples),samtbl,by.x="samples",by.y="SampleID",all.x=TRUE,sort=FALSE) +ctfile <- paste(data.dir, 'countTable.logCPM.txt', sep = '/') +samfile <- paste(data.dir, 'design.shiny.txt', sep = '/') +cts <- read.table(file = ctfile, header = TRUE, sep = '\t') +samtbl <- read.table(samfile, header = TRUE, sep = "\t") +samples <- colnames(cts[, 4:length(cts)]) +mergetbl <- + merge( + as.data.frame(samples), + samtbl, + by.x = "samples", + by.y = "SampleID", + all.x = TRUE, + sort = FALSE + ) grps <- mergetbl$SampleGroup grpnames <- levels(factor(grps)) -col.blocks <-col.grp(grps,grpnames) -MSIG.geneSets <- read.gmt(paste(data.dir,'geneset.shiny.gmt',sep='/')) +col.blocks <- col.grp(grps, grpnames) +MSIG.geneSets <- + read.gmt(paste(data.dir, 'geneset.shiny.gmt', sep = '/')) output$pick.dea <- renderUI({ - flist <- list.files(data.dir,pattern="*edgeR.txt$") - selectInput("file", "Choose Pair", choices=flist) + flist <- list.files(data.dir, pattern = "*edgeR.txt$") + selectInput("file", "Choose Pair", choices=flist, width = "100%") }) output$pick.pathway <- renderUI({ - pathways <- names(MSIG.geneSets) - pathchoices = setNames(1:length(pathways),pathways) - selectInput("deapathname", "Choose Pair", choices=pathchoices) + pathways <- names(MSIG.geneSets) + pathchoices = setNames(1:length(pathways), pathways) + selectInput("deapathname", "Choose Pair", choices = pathchoices) }) get.data <- function(var) { - f <- paste(data.dir,var$file,sep='/') - comp <- read.table(f,header=TRUE,sep='\t') - comp.filt <- na.omit(comp[abs(comp$logFC) >= var$fc.thresh & comp$rawP <= var$pval.thresh,]) - if (var$adjust == 'FDR') { - comp.filt <- na.omit(comp[abs(comp$logFC) >= var$fc.thresh & comp$fdr <= var$pval.thresh,]) - } - if (var$adjust == 'BONF') { - comp.filt <- na.omit(comp[abs(comp$logFC) >= var$fc.thresh & comp$bonf <= var$pval.thresh,]) - } - genelist <- as.character(head(comp.filt[order(comp.filt$fdr),]$symbol,n=var$numgenes)) - if (var$heatmap == 'hgeneset') { - genelist <- unlist(MSIG.geneSets[as.numeric(var$deapathname)]) - } - if (var$heatmap == 'cgeneset') { - genelist <- unlist(strsplit(as.character(var$genes), "[;\n]+")) - } - return(list(filt=comp.filt,glist=genelist)) + f <- paste(data.dir, var$file, sep = '/') + # f <-paste(f, "edgeR.txt", sep = ".") #This line needs to comment out if input is fullname + f1 <- paste(data.dir, input$file, sep = '/') + hmcomp <-paste("Heatmap of all genes with an FDR < 0.05 using EdgeR Results", sep ='') + top50 <- paste("Top 50 User Defined Genes") + allgene <- paste("All Differentially Expressed Genes") + comp <- read.table(f, header = TRUE, sep = '\t') + comp.filt <- + na.omit(comp[abs(comp$logFC) >= var$fc.thresh & + comp$rawP <= var$pval.thresh,]) + if (var$adjust == 'FDR') { + comp.filt <- + na.omit(comp[abs(comp$logFC) >= var$fc.thresh & + comp$fdr <= var$pval.thresh,]) + } + if (var$adjust == 'BONF') { + comp.filt <- + na.omit(comp[abs(comp$logFC) >= var$fc.thresh & + comp$bonf <= var$pval.thresh,]) + } + genelist <- + as.character(head(comp.filt[order(comp.filt$fdr),]$symbol, n = var$numgenes)) + if (var$heatmap == 'hgeneset') { + genelist <- unlist(MSIG.geneSets[as.numeric(var$deapathname)]) + } + if (var$heatmap == 'cgeneset') { + genelist <- unlist(strsplit(as.character(var$genes), "[;\n]+")) + } + return( + list( + filt = comp.filt, + glist = genelist, + f1 = f1, + hmcomp = hmcomp, + top50 = top50, + allgene = allgene + ) + ) } -tbls <- eventReactive(input$deButton,{get.data(input)}) +tbls <- eventReactive(input$deButton, + { + get.data(input) + }) output$selectgenes <- renderUI({ - symnames <- tbls()$glist - textAreaInput("genes", "Gene Symbols separated by ';'",value=paste(symnames,collapse=";"), width = '95%',rows=10) + symnames <- tbls()$glist + textAreaInput( + "genes", + "Gene Symbols separated by ';'", + value = paste(symnames, collapse = ";"), + width = '95%', + rows = 10 + ) }) output$dge.c <- DT::renderDataTable({ - t1 <- tbls()$filt - t1$symbol <- paste("<a href=http://www.genecards.org/cgi-bin/carddisp.pl?gene=",t1$symbol,'>',t1$symbol,"</a>",sep='') - t1$ensembl <- paste("<a href=http://www.ensembl.org/Homo_sapiens/Gene/Summary?g=",t1$ensembl,'>',t1$ensembl,"</a>",sep='') - t1 -},escape=FALSE,filter = 'top',options = list(lengthMenu = c(10, 25, 50, 200, -1))) - -output$downloadC <- downloadHandler( - file <- paste(input$file,".filt.txt",sep=""), - content = function(file) { - write.table(tbls()$filt,file,quote=FALSE,row.names=FALSE,sep='\t') - }) + t1 <- tbls()$filt + t1$symbol <- + paste( + "<a href=http://www.genecards.org/cgi-bin/carddisp.pl?gene=", + t1$symbol, + '>', + t1$symbol, + "</a>", + sep = '' + ) + t1$ensembl <- + paste( + "<a href=http://www.ensembl.org/Homo_sapiens/Gene/Summary?g=", + t1$ensembl, + '>', + t1$ensembl, + "</a>", + sep = '' + ) + t1 +}, escape = FALSE, filter = 'top', options = list( + lengthMenu = list(c(10, 25, 50, 100, -1), list('10', '25', '50', '100', 'All')), + autoWidth = TRUE, + columnDefs = list(list(width = '5%', targets = '0')), + scrollX = TRUE +)) +output$downloadC <- renderUI({ + if (!is.null(tbls()$filt)) { + downloadButton('OutputFile', 'Download CSV') + } +}) +output$OutputFile <- downloadHandler( + file <- paste(input$file, ".filt.txt", sep = ""), + content = function(file) { + write.table( + tbls()$filt, + file, + quote = FALSE, + row.names = FALSE, + sep = '\t' + ) + } +) plotHeatmap <- reactive({ - syms <- tbls()$glist - ct2 <- cts[cts$SYMBOL %in% syms,] - subset <- ct2[,4:length(ct2)] - row.names(subset) <- ct2$SYMBOL - STREE <- hclust(dist(t(subset))) - zscores <- scale(t(subset)) - ngenes <- length(colnames(zscores)) - textscale <- (1/(ngenes/30)) - if (textscale > 1) { - textscale <-1 - } - if (textscale < 0.1) { - textscale <- 0.1 - } - heatmap.2(zscores, col = bluered(100),Rowv = as.dendrogram(STREE), RowSideColors = col.blocks,dendrogram='row', cexCol=textscale,srtRow=45,srtCol=45,trace="none",margins=c(8,16)) - legend("topright",legend=grpnames,col=rainbow(length(grpnames)),pch=20) + syms <- tbls()$glist + ct2 <- cts[cts$SYMBOL %in% syms,] + subset <- ct2[, 4:length(ct2)] + row.names(subset) <- ct2$SYMBOL + STREE <- hclust(dist(t(subset))) + zscores <- scale(t(subset)) + ngenes <- length(colnames(zscores)) + textscale <- (1 / (ngenes/30)) + if (textscale > 1) { + textscale <- 12 + } + if (textscale < 0.1) { + textscale <- 12 + } + if (input$cluster == 2) { + heatmap.2( + zscores, + col = bluered(100), + #Rowv = as.dendrogram(STREE), + Rowv = FALSE, + Colv = FALSE, + lwid = c(0.5,3), + RowSideColors = col.blocks, + dendrogram = 'row', + cexCol = 1.1, + srtRow = 45, + srtCol = 45, + trace = "none", + margins = c(8, 7) + ) + } else{ + heatmap.2( + zscores, + col = bluered(100), + Rowv = as.dendrogram(STREE), + RowSideColors = col.blocks, + dendrogram = 'row', + cexCol = 1.1, + srtRow = 45, + srtCol = 45, + lwid = c(0.5,3), + trace = "none", + margins = c(8, 7) + ) + } + legend("top", + legend = grpnames, + col = rainbow(length(grpnames)), + pch = 20) }) output$plot.heatmap <- renderPlot({ - plotHeatmap() + plotHeatmap() }) + +output$dlheatmap <- renderUI({ + if (!is.null(tbls()$glist)) { + downloadButton('Downloadhp', 'Download PNG') + } +}) + +output$Downloadhp <- downloadHandler( + file = function() { + paste('mean', 'png', sep = ".") + }, + content <- function(file) { + png( + file, + width = 8 * 140, + height = 4 * 100, + res = 140, + pointsize = 5 + ) + if (is.null(tbls()$glist)) { + return() + } + syms <- tbls()$glist + ct2 <- cts[cts$SYMBOL %in% syms,] + subset <- ct2[, 4:length(ct2)] + row.names(subset) <- ct2$SYMBOL + STREE <- hclust(dist(t(subset))) + zscores <- scale(t(subset)) + ngenes <- length(colnames(zscores)) + textscale <- (1 / (ngenes/30)) + if (textscale > 1) { + textscale <- 12 + } + if (textscale < 0.1) { + textscale <- 12 + } + if (input$cluster == 2) { + plot <- heatmap.2( + zscores, + col = bluered(100), + Rowv = FALSE, + Colv = FALSE, + lwid = c(0.5,3), + RowSideColors = col.blocks, + dendrogram = 'row', + cexCol = 1.1, + srtRow = 45, + srtCol = 45, + trace = "none", + margins = c(8, 7) + ) + } else{ + plot <- heatmap.2( + zscores, + col = bluered(100), + Rowv = as.dendrogram(STREE), + RowSideColors = col.blocks, + dendrogram = 'row', + cexCol = 1.1, + srtRow = 45, + srtCol = 45, + lwid = c(0.5,3), + trace = "none", + margins = c(8, 7) + ) + } + legend("top", + legend = grpnames, + col = rainbow(length(grpnames)), + pch = 20) + print(plot) + dev.off() + }, + contentType = "image/png" +) + output$downloadpdf = downloadHandler( - filename = "output.heatmap.pdf", - content = function(file) { - pdf(file = file,paper="letter") - plotHeatmap() - dev.off() - }) + filename = "output.heatmap.pdf", + content = function(file) { + pdf(file = file, paper = "letter") + plotHeatmap() + dev.off() + } +) output$hm.comp <- renderImage({ - f1 <- paste(data.dir,input$file,sep='/') - png <- gsub('edgeR.txt','heatmap.edgeR.png',f1) - list(src=png, alt=paste("HeatMap Comparison")) -},deleteFile=FALSE) + f1 <- paste(tbls()$f1) + png <- gsub('edgeR.txt', 'heatmap.edgeR.png', f1) + list( + src = png, + alt = paste("HeatMap Comparison"), + width = "100%", + height = "auto" + ) +}, deleteFile = FALSE) -output$hmcomp.desc <- renderText({ - paste("Heatmap of all genes with an FDR < 0.05 using EdgeR Results",sep='') - }) +output$dlhmcomp <- renderUI({ + if (!is.null(tbls()$f1)) { + downloadButton('Downloadhm', 'Download PNG') + } +}) +output$Downloadhm <- downloadHandler( + file = function() { + paste('heatmap_comp', 'png', sep = ".") + }, + content <- function(file) { + f1 <- paste(tbls()$f1) + png <- gsub('edgeR.txt', 'heatmap.edgeR.png', f1) + file.copy(png, file) + } +) + +output$hmcomp.allgene <- renderText({ + paste(tbls()$allgene) +}) +output$hmcomp.top50 <- renderText({ + paste(tbls()$top50) +}) +output$hmcomp.desc <- renderText({ + paste(tbls()$hmcomp) +}) diff --git a/vizapp/tools/dea_ui.R b/vizapp/tools/dea_ui.R index 6c0a448..a0d88eb 100644 --- a/vizapp/tools/dea_ui.R +++ b/vizapp/tools/dea_ui.R @@ -1,57 +1,65 @@ -####################################### -# Shiny interface for data functions -####################################### -# data ui and tabs -output$ui_dea <- renderUI({ - list( - includeCSS("www/style.css"), - sidebarLayout( - sidebarPanel( - numericInput("fc.thresh", - "LogFold Change Threshold:", 1), - numericInput("gene.thresh", - "Gene Mean Threshold:", 5), - numericInput("pval.thresh", - "P-Value Threshold:", 0.05), - selectInput("adjust", "Choose P-Value Correction", choices=c("raw","FDR",'BONF'),selected='FDR'), - uiOutput("pick.dea"), - selectInput( - "heatmap", "HeatMap", - c(Top = "top", - HallmarkGeneSet = "hgeneset", - CustomGeneSet= "cgeneset") - ), - conditionalPanel( - condition = "input.heatmap == 'cgeneset'", - uiOutput("selectgenes") - ), - conditionalPanel( - condition = "input.heatmap == 'top'", - numericInput("numgenes","Number Top Genes:", 50) - ), - conditionalPanel( - condition = "input.heatmap == 'hgeneset'", - uiOutput("pick.pathway") - ), - actionButton("deButton", "Go") - ), - mainPanel( - tabsetPanel( - tabPanel("Differential Gene Set Comparison", - downloadButton('downloadC', 'Download CSV'), - dataTableOutput('dge.c') - ), - tabPanel("Heatmap", - #downloadButton('downloadpdf', 'Download Heatmap'), - h1("HeatMap Comparison"), - h3("Top 50 User Defined Genes"), - plotOutput("plot.heatmap"), - h3("All Differentially Expressed Genes"), - imageOutput("hm.comp",width="1200px",height="1200px"), - textOutput("hmcomp.desc") - ) - ) - ) - ) - ) -}) +####################################### +# Shiny interface for data functions +####################################### +# data ui and tabs +output$ui_dea <- renderUI({ + list(fluidPage( + includeCSS("www/style.css"), + fluidRow( + sidebarPanel( + numericInput("fc.thresh", + "LogFold Change Threshold:", 1), + numericInput("gene.thresh", + "Gene Mean Threshold:", 5), + numericInput("pval.thresh", + "P-Value Threshold:", 0.05), + selectInput( + "adjust", + "Choose P-Value Correction", + choices = c("raw", "FDR", 'BONF'), + selected = 'FDR' + ), + uiOutput("pick.dea"), + selectInput( + "heatmap", + "HeatMap", + c( + Top = "top", + HallmarkGeneSet = "hgeneset", + CustomGeneSet = "cgeneset" + ) + ), + conditionalPanel(condition = "input.heatmap == 'cgeneset'", + uiOutput("selectgenes")), + conditionalPanel(condition = "input.heatmap == 'top'", + numericInput("numgenes", "Number Top Genes:", 50)), + conditionalPanel(condition = "input.heatmap == 'hgeneset'", + uiOutput("pick.pathway")), + radioButtons("cluster", label = "Cluster", + choices = list("Display Cluster" = 1, "Hide Cluster" = 2), + selected = 1), + actionButton("deButton", "Go", class = "btn btn-primary btn-bg centerbtn") + ), + column(7, + tabsetPanel( + tabPanel( + "Differential Gene Set Comparison", + br(),br(), + dataTableOutput('dge.c', width = '100%'), + uiOutput('downloadC') + ), + tabPanel( + "Heatmap Comparison", + #downloadButton('downloadpdf', 'Download Heatmap'), + h3(textOutput("hmcomp.top50")), + plotOutput("plot.heatmap"), + uiOutput("dlheatmap"), + h3(textOutput("hmcomp.allgene")), + imageOutput("hm.comp", width = "100%", height = "auto"), + uiOutput('dlhmcomp'), + textOutput("hmcomp.desc") + ) + )) + ) + )) +}) diff --git a/vizapp/tools/gc.R b/vizapp/tools/gc.R index d105b2e..e0bf506 100644 --- a/vizapp/tools/gc.R +++ b/vizapp/tools/gc.R @@ -1,60 +1,243 @@ - -samfile <- paste(data.dir,'design.shiny.txt',sep='/') -samtbl <- read.table(samfile,header=TRUE,sep="\t") +samfile <- paste(data.dir, 'design.shiny.txt', sep = '/') +samtbl <- read.table(samfile, header = TRUE, sep = "\t") output$pick.group <- renderUI({ - opts <- names(samtbl) - selectInput("groupname", "Plot By", choices=opts,selected='SampleGroup') + opts <- names(samtbl) + selectInput("groupname", + "Plot By", + choices = opts, + selected = 'SampleGroup') }) get.ct <- function(var) { - ctfile <- paste(data.dir,'countTable.logCPM.txt',sep='/') - statfile <- paste(data.dir,'edgeR.results.txt',sep='/') - wp.df <- data.frame(Column1 = c(0), Column2 = c(0)) - - if (nchar(as.vector(var$symsearch)) > 2) { - cts <- read.csv.sql(ctfile, sql = paste("select * from file where symbol ='",var$symsearch,"'",sep=''),sep = "\t") - if (file.exists(statfile)) { - wp.df <- read.csv.sql(statfile, sql = paste("select * from file where symbol ='",var$symsearch,"'",sep=''),sep = "\t") - } + ctfile <- paste(data.dir, 'countTable.logCPM.txt', sep = '/') + statfile <- paste(data.dir, 'edgeR.results.txt', sep = '/') + wp.df <- data.frame(Column1 = c(0), Column2 = c(0)) + bx <- + paste( + "Relative Abudance of", + input$symsearch, + "calculated by Log2(Counts Per Million Reads). Boxplots draw to represent the 25th and 75th percentile (the lower and upper quartiles, respectively) as a box with a band in the box representing 50th percentile (the median). The upper whisker is located at the 'smaller' of the maximum x value and Q_3 + 1.5 inner quantile range(IRQ), whereas the lower whisker is located at the 'larger' of the smallest x value and Q_1 - 1.5 IQR", + sep = ' ' + ) + vio <- paste( + "Relative Abudance of", + input$symsearch, + input$enssearch, + "calculated by Log2(Counts Per Million Reads). Violin plot is similar to box plots above, except that it also show the kernel probability density of the data at different value. Violin plots include a marker for the median of the data and a box indicating the interquartile range, as in boxplot above.", + sep = ' ' + ) + if (nchar(as.vector(var$symsearch)) > 2) { + cts <- + read.csv.sql( + ctfile, + sql = paste("select * from file where symbol ='", var$symsearch, "'", sep = + ''), + sep = "\t" + ) + if (file.exists(statfile)) { + wp.df <- + read.csv.sql( + statfile, + sql = paste( + "select * from file where symbol ='", + var$symsearch, + "'", + sep = '' + ), + sep = "\t" + ) } - else { - if (nchar(as.vector(var$enssearch)) > 2) { - cts <- read.csv.sql(ctfile, sql = paste("select * from file where ENSEMBL ='",var$enssearch,"'",sep=''),sep = "\t") - if (file.exists(statfile)) { - wp.df <- read.csv.sql(statfile, sql = paste("select * from file where ENSEMBL ='",var$enssearch,"'",sep=''),sep = "\t") - } + } + else { + if (nchar(as.vector(var$enssearch)) > 2) { + cts <- + read.csv.sql( + ctfile, + sql = paste( + "select * from file where ENSEMBL ='", + var$enssearch, + "'", + sep = '' + ), + sep = "\t" + ) + if (file.exists(statfile)) { + wp.df <- + read.csv.sql( + statfile, + sql = paste( + "select * from file where ENSEMBL ='", + var$enssearch, + "'", + sep = '' + ), + sep = "\t" + ) } } - countTable <- cts[,4:length(cts)] - samples <- colnames(countTable) - mergetbl <- merge(as.data.frame(samples),samtbl,by.x="samples",by.y="SampleID",all.x=TRUE,sort=FALSE) - grps <- mergetbl[,var$groupname] - newdf <- data.frame(ct=t(countTable),grp=as.character(grps)) - names(newdf) = c('cts','grp') - return(list(ctable=newdf,tbl=cts,design=samtbl,stats=wp.df)) } + countTable <- cts[, 4:length(cts)] + samples <- colnames(countTable) + mergetbl <- + merge( + as.data.frame(samples), + samtbl, + by.x = "samples", + by.y = "SampleID", + all.x = TRUE, + sort = FALSE + ) + grps <- mergetbl[, var$groupname] + newdf <- data.frame(ct = t(countTable), grp = as.character(grps)) + names(newdf) = c('cts', 'grp') + return(list( + ctable = newdf, + tbl = cts, + design = samtbl, + stats = wp.df, + bx = bx, + vio = vio + )) +} -forct <- eventReactive(input$gcButton,{get.ct(input)}) +forct <- eventReactive(input$gcButton, { + get.ct(input) +}) output$plot.gene <- renderPlot({ + countTable <- forct()$ctable + par(oma = c(4, 4, 1, 1)) + grpnames <- levels(factor(as.character(countTable$grp))) + #boxplot( + # countTable$cts ~ countTable$grp, + # col = rainbow(length(grpnames)), + #cex.axis = 0.7, + # ylab = 'Relative Abundance (logCPM)', + # las = 1, + # main = input$groupname + # ) + p <- + ggplot(countTable, aes(x = grp, y = cts)) + ggtitle(input$groupname) + + theme(plot.title = element_text( + hjust = 0.5, + size = 18, + margin = margin(b = 20, unit = "pt") + )) + geom_boxplot(trim = FALSE, aes(fill = factor(grp))) + theme(legend.position = + "none", + axis.title.y = element_text(size=14), + axis.text.y = element_text(size=14), + axis.text.x = element_text( + angle = 45, + hjust = 1, + vjust = 1, + size=14 + )) + ylab("Relative Abundance (logCPM)") + xlab("") + print(p) +}, height = "auto", width = 'auto') + +output$dlboxplot <- renderUI({ + if (!is.null(forct()$ctable)) { + downloadButton('Downloadbp', 'Download PNG') + } +}) +output$Downloadbp <- downloadHandler( + file = function() { + paste('boxplot', 'png', sep = ".") + }, + content <- function(file) { + png( + file, + width = 8 * 120, + height = 4 * 120, + res = 120, + pointsize = 5 + ) + if (is.null(forct()$ctable)) { + return() + } countTable <- forct()$ctable - par(oma=c(4,4,1,1)) + par(oma = c(4, 4, 1, 1)) grpnames <- levels(factor(as.character(countTable$grp))) - boxplot(countTable$cts ~ countTable$grp,col=rainbow(length(grpnames)),cex.axis=0.7,ylab='Relative Abundance (logCPM)',las=2,main=input$groupname) - }) + plot <- + ggplot(countTable, aes(x = grp, y = cts)) + ggtitle(input$groupname) + + theme(plot.title = element_text( + hjust = 0.5, + size = 18, + margin = margin(b = 20, unit = "pt") + )) + geom_boxplot(trim = FALSE, aes(fill = factor(grp))) + theme(legend.position = + "none", + axis.text.x = element_text( + angle = 45, + hjust = 1, + vjust = 1 + )) + ylab("Relative Abundance (logCPM)") + xlab("") + print(plot) + dev.off() + }, + contentType = "image/png" +) -output$bxplot.desc <- renderText({ - paste("Relative Abudance of",input$symsearch,"calculated by Log2(Counts Per Million Reads). Boxplots draw to represent the 25th and 75th percentile (the lower and upper quartiles, respectively) as a box with a band in the box representing 50th percentile (the median). The upper whisker is located at the 'smaller' of the maximum x value and Q_3 + 1.5 inner quantile range(IRQ), whereas the lower whisker is located at the 'larger' of the smallest x value and Q_1 - 1.5 IQR",sep=' ') - }) +output$bxplot.desc <- renderText({ + paste(forct()$bx) +}) output$violin.gene <- renderPlot({ countTable <- forct()$ctable - par(oma=c(4,4,1,1)) - p <- ggplot(countTable,aes(x=grp,y=cts)) + geom_violin(trim=FALSE,aes(fill = factor(grp))) + geom_jitter(height = 0) + theme(legend.position="none",axis.text.x=element_text(angle=45,hjust=1, vjust=1)) + ylab("Relative Abundance (logCPM)") + xlab("") + par(oma = c(4, 4, 1, 1)) + p <- + ggplot(countTable, aes(x = grp, y = cts)) + geom_violin(trim = FALSE, aes(fill = factor(grp))) + geom_jitter(height = 0) + theme(legend.position = + "none", + axis.title.y = element_text(size=14), + axis.text.y = element_text(size=14), + axis.text.x = element_text( + angle = 45, + hjust = 1, + vjust = 1, + size = 14 + )) + ylab("Relative Abundance (logCPM)") + xlab("") print(p) -}, height = 400, width = 900) +}, height = "auto", width = 'auto') + +output$dlviolinplot <- renderUI({ + if (!is.null(forct()$ctable)) { + downloadButton('Downloadvp', 'Download PNG') + } +}) -output$violin.desc <- renderText({ - paste("Relative Abudance of",input$symsearch,input$enssearch,"calculated by Log2(Counts Per Million Reads). Violin plot is similar to box plots above, except that it also show the kernel probability density of the data at different value. Violin plots include a marker for the median of the data and a box indicating the interquartile range, as in boxplot above.",sep=' ') - }) +output$Downloadvp <- downloadHandler( + file = function() { + paste('violinplot', 'png', sep = ".") + }, + content <- function(file) { + png( + file, + width = 8 * 120, + height = 4 * 120, + res = 120, + pointsize = 5 + ) + if (is.null(forct()$ctable)) { + return() + } + countTable <- forct()$ctable + par(oma = c(4, 4, 1, 1)) + grpnames <- levels(factor(as.character(countTable$grp))) + par(oma = c(4, 4, 1, 1)) + plot <- + ggplot(countTable, aes(x = grp, y = cts)) + geom_violin(trim = FALSE, aes(fill = factor(grp))) + geom_jitter(height = 0) + theme(legend.position = + "none", + axis.text.x = element_text( + angle = 45, + hjust = 1, + vjust = 1 + )) + ylab("Relative Abundance (logCPM)") + xlab("") + print(plot) + dev.off() + }, + contentType = "image/png" +) + +output$violin.desc <- renderText({ + paste(forct()$vio) +}) diff --git a/vizapp/tools/gc_ui.R b/vizapp/tools/gc_ui.R index 4840ade..b9903c0 100644 --- a/vizapp/tools/gc_ui.R +++ b/vizapp/tools/gc_ui.R @@ -1,26 +1,33 @@ output$ui_gc <- renderUI({ - fluidPage( - includeCSS("www/style.css"), - sidebarLayout( - sidebarPanel( - uiOutput("pick.group"), - textInput("symsearch", "Search By Gene Symbol", 'IL1B'), - textInput("enssearch", "Search By ENS ID",''), - actionButton("gcButton", "GO") - ), - mainPanel( - tabsetPanel( - tabPanel("Gene Compare", - dataTableOutput('gc.stats'), - plotOutput("plot.gene"), - textOutput("bxplot.desc"), - plotOutput("violin.gene"), - textOutput("violin.desc") - ) - ) - ) - ) - ) - + list(fluidPage( + includeCSS("www/style.css"), + fluidRow( + sidebarPanel( + uiOutput("pick.group"), + textInput("symsearch", "Search By Gene Symbol", 'IL1B'), + textInput("enssearch", "Search By ENS ID", ''), + actionButton("gcButton", "GO", class = "btn btn-primary btn-bg centerbtn") + ), + column(7, + tabsetPanel( + tabPanel( + "Gene Compare", + dataTableOutput('gc.stats'), + br(), + plotOutput("plot.gene"), + uiOutput('dlboxplot'), + br(), + textOutput("bxplot.desc"), + br(), + plotOutput("violin.gene"), + uiOutput('dlviolinplot'), + br(), + textOutput("violin.desc") + ) + )), + tags$style(type='text/css', "#dlboxplot { width:100%;margin-left: 35px;}"), + tags$style(type='text/css', "#dlviolinplot { width:100%;margin-left: 35px;}") + ) + )) + }) - diff --git a/vizapp/tools/gsea.R b/vizapp/tools/gsea.R index a3d0a7b..ca19618 100644 --- a/vizapp/tools/gsea.R +++ b/vizapp/tools/gsea.R @@ -1,33 +1,96 @@ - -output$quresult <- renderUI({ - flist <- list.files(data.dir,pattern="*qusage.rda$") - selectInput('fname', "Choose Comparison", choices=flist) -}) - -updateData <- function(input) { - f1 <- paste(data.dir,input$fname,sep='/') - load(file = f1, envir = .GlobalEnv) - results <- qsTable(qs.results,number=100,sort.by='fdr') - return(list(obj=qs.results,tbl=results)) -} -values <- eventReactive(input$quButton,{updateData(input)}) - -output$gset <- renderUI({ - tbl <- values()$tbl - choices = setNames(row.names(tbl),tbl$pathway.name) - selectInput("pathname", "Choose Pathway", choices=choices) -}) - -output$gsea.tbl <- renderDataTable({ - values()$tbl -}) - -output$plot.cis <- renderPlot({ - qs.results <- values()$obj - plotCIsGenes(qs.results,path.index=as.numeric(input$pathname)) -}) - -output$plot.genedist <- renderPlot({ - qs.results <- values()$obj - plotGeneSetDistributions(qs.results,path.index=as.numeric(input$pathname)) -}) + +output$quresult <- renderUI({ + flist <- list.files(data.dir,pattern="*qusage.rda$") + selectInput('fname', "Choose Comparison", choices=flist) +}) + +updateData <- function(input) { + f1 <- paste(data.dir,input$fname,sep='/') + load(file = f1, envir = .GlobalEnv) + results <- qsTable(qs.results,number=100,sort.by='fdr') + return(list(obj=qs.results,tbl=results)) +} +values <- eventReactive(input$quButton,{updateData(input)}) + +output$gset <- renderUI({ + tbl <- values()$tbl + choices = setNames(row.names(tbl),tbl$pathway.name) + selectInput("pathname", "Choose Pathway", choices=choices) +}) + +output$gsea.tbl <- renderDataTable({ + values()$tbl +}) +output$downloadGS <- renderUI({ + if(!is.null(values()$tbl)){ + downloadButton('DownloadGS', 'Download CSV') + } +}) +output$DownloadGS <- downloadHandler( + file <- paste(input$fname,".txt",sep=""), + content = function(file) { + write.table(values()$tbl,file,quote=FALSE,row.names=FALSE,sep='\t') + }) +output$plot.cis <- renderPlot({ + qs.results <- values()$obj + plotCIsGenes(qs.results,path.index=as.numeric(input$pathname), cex.xaxis = 1.3) +}) +output$dlcis <- renderUI({ + if (!is.null(values()$obj)) { + downloadButton('Downloadcis', 'Download PNG') + } +}) +output$Downloadcis <- downloadHandler( + file = function() { + paste('cisplot', 'png', sep = ".") + }, + content <- function(file) { + png( + file, + width = 8 * 120, + height = 4 * 120, + res = 120, + pointsize = 5 + ) + if (is.null(values()$obj)) { + return() + } + qs.results <- values()$obj + plot <- plotCIsGenes(qs.results,path.index=as.numeric(input$pathname), cex.xaxis = 1.3) + print(plot) + dev.off() + }, + contentType = "image/png" +) +output$plot.genedist <- renderPlot({ + qs.results <- values()$obj + plotGeneSetDistributions(qs.results,path.index=as.numeric(input$pathname), cex =1.6) +}) + +output$dlgenedist <- renderUI({ + if (!is.null(values()$obj)) { + downloadButton('Downloadgenedist', 'Download PNG') + } +}) +output$Downloadgenedist <- downloadHandler( + file = function() { + paste('cisplot', 'png', sep = ".") + }, + content <- function(file) { + png( + file, + width = 8 * 120, + height = 4 * 120, + res = 140, + pointsize = 5 + ) + if (is.null(values()$obj)) { + return() + } + qs.results <- values()$obj + plot <- plotGeneSetDistributions(qs.results,path.index=as.numeric(input$pathname), cex =1.6) + print(plot) + dev.off() + }, + contentType = "image/png" +) diff --git a/vizapp/tools/gsea_ui.R b/vizapp/tools/gsea_ui.R index 226b0ae..8385253 100644 --- a/vizapp/tools/gsea_ui.R +++ b/vizapp/tools/gsea_ui.R @@ -1,23 +1,29 @@ output$ui_gsea <- renderUI({ - list( - includeCSS("www/style.css"), - sidebarLayout( - sidebarPanel( - uiOutput("quresult"), - uiOutput("gset"), - actionButton("quButton", "Go") - ), - mainPanel( - tabsetPanel( - tabPanel("Gene Set Comparisons", - dataTableOutput('gsea.tbl') - ), - tabPanel("Gene Set Comparison", - plotOutput("plot.cis"), - plotOutput("plot.genedist") - ) - ) - ) - ) - ) + list(fluidPage( + includeCSS("www/style.css"), + fluidRow( + sidebarPanel( + uiOutput("quresult"), + uiOutput("gset"), + actionButton("quButton", "Go", class = "btn btn-primary btn-bg centerbtn") + ), + column(7, + tabsetPanel( + tabPanel( + "Gene Set Comparisons", + br(), + br(), + dataTableOutput('gsea.tbl'), + uiOutput("downloadGS") + ), + tabPanel( + "Gene Set Comparison", + plotOutput("plot.cis"), + uiOutput("dlcis"), + plotOutput("plot.genedist"), + uiOutput("dlgenedist") + ) + )) + ) + )) }) diff --git a/vizapp/tools/intro.R b/vizapp/tools/intro.R index 56a610d..fca052e 100644 --- a/vizapp/tools/intro.R +++ b/vizapp/tools/intro.R @@ -1,25 +1,24 @@ -output$ui_intro <- renderUI({ - list( - includeCSS("www/style.css"), - sidebarLayout( - sidebarPanel( - ), - mainPanel( - h1("Welcome to the RNASeq Analysis Portal", align = "center"), - br(), - br(), - h4("To Compare Gene Abundances Use Gene Compare", align = "center"), - p("Here you will be able explore gene abundances by (1) Transmembrane Proteins, (2) Transcription Fractors and (3) Chemocytokines. Also you can compare the gene abundances of genes by Available Clinicial Data",style = "color:red"), - h4("To Examine Differential Gene Analysis Use DEA", align = "center"), - p("Here you will be able explore Differential Gene Expresss by Group. You will also be able to compare two comparisons: such as Case1 vs Control and Case2 vs Control.",style = "color:red"), - h4("To Examine Gene Set Enrichment Analysis Use GSEA", align = "center"), - p("Here you will be able explore Gene Set Enrichment Analysis by Group and Gene Set List.",style = "color:red"), - br(), - br(), - p("Note:Error messages can indicate data processing or missing data. Please wait 30 seconds for the program to catch up to any changes in data loading."), - h6("Questions? Contract Brandi Cantarel brandi.cantarel@baylorhealth.edu") - ) - ) - ) - +# x <- reactiveVal(1) +observeEvent(input$actionbtgc, { + #x(x() + 1) + # if (input$actionbtgc > 0){ + # updateNavbarPage(session, "rnaseqnav", selected = "panelgc") + # output$Text <-renderText({"lailailailailaillai"}) + #} + updateNavbarPage(session, 'nav_shinyapp', 'panelgc') }) + +observeEvent(input$actionbtdea, { + updateNavbarPage(session, 'nav_shinyapp', 'paneldea') +}) + +observeEvent(input$actionbtgsea, { + updateNavbarPage(session, 'nav_shinyapp', 'panelgsea') +}) +# output$tb1 <- renderPrint({x()}) +# output$tb1 <- renderText({ +# updateNavbarPage(session, '') +# }) +# output$ui_intro <-renderUI({ +# source('tools/gc.R', local = TRUE) +#}) diff --git a/vizapp/tools/intro_ui.R b/vizapp/tools/intro_ui.R new file mode 100644 index 0000000..cd8ea85 --- /dev/null +++ b/vizapp/tools/intro_ui.R @@ -0,0 +1,120 @@ +output$ui_intro <- renderUI({ + list( + #includeCSS("www/style.css"), + tags$link(rel = "stylesheet", type = "text/css", href = "style.css"), + fluidPage(id = 'intropage', + fluidRow( + br(), + column( + 8, + offset = 2, + h1("Welcome to the RNASeq Analysis Portal", align = "center"), + br(), + br(), + div(column( + 4, + div( + class = "card text-center", + div(class = "card-header", + "Gene Compare"), + div( + class = "card-body", + h5( + class = "card-title", + "To Compare Gene Abundances", + align = "center" + ), + p( + class = "card-text", + "Here you will be able explore gene abundances by (1) Transmembrane Proteins, (2) Transcription Fractors and (3) Chemocytokines. Also you can compare the gene abundances of genes by Available Clinicial Data" + ) + ), + div( + class = "card-footer", + # a(class="btn btn-primary btn-sm", 'data-toggle'="tab", 'data-value'="Gene Compare", 'id'="btgc", "Gene Compare") + actionButton( + class = "btn btn-primary btn-sm", + inputId = "actionbtgc", + label = "Gene Compare", + icon = NULL + ) + ) + ) + ), + column( + 4, + div( + class = "card text-center", + div(class = "card-header", + "DEA"), + div( + class = "card-body", + h5(class = "card-title", "To Examine Differential Gene Analysis"), + p( + class = "card-text", + "Here you will be able explore Differential Gene Expresss by Group. You will also be able to compare two comparisons: such as Case1 vs Control and Case2 vs Control." + ) + ), + div( + class = "card-footer", + # a(class="btn btn-primary btn-sm", 'data-toggle'="tab",'data-value'="DEA",id="dea","DEA") + actionButton( + class = "btn btn-primary btn-sm", + inputId = "actionbtdea", + label = "DEA", + icon = NULL + ) + ) + ) + ), + column( + 4, + div( + class = "card text-center", + div(class = "card-header", + "QuSAGE"), + div( + class = "card-body", + h5(class = "card-title", "To Examine Gene Set Enrichment Analysis"), + p( + class = "card-text", + "Here you will be able explore Gene Set Enrichment Analysis by Group and Gene Set List." + ) + ), + div( + class = "card-footer", + #a(class="btn btn-primary btn-sm",'data-toggle'="tab", 'data-value'="QuSAGE",id="gsea","GSEA") + actionButton( + class = "btn btn-primary btn-sm", + inputId = "actionbtgsea", + label = "QuSAGE" + ) + ) + ) + )) + ) + ), + fluidRow(column( + 8, offset = 2, + br(), + br(), + div( + class = "alert alert-info", + a( + icon("new-window", lib = "glyphicon"), + strong("CITATION LINK"), + href = "https://git.biohpc.swmed.edu/BICF/Astrocyte/rnaseq", + target = "_blank", + style = "color:white" + ), + p( + strong("Note:"), + "Error messages can indicate data processing or missing data. Please wait 30 seconds for the program to catch up to any changes in data loading.", + style = "font-size:14px" + ) + ) + ))) + + ) + +}) diff --git a/vizapp/tools/qc.R b/vizapp/tools/qc.R index 0a472e0..43a1728 100644 --- a/vizapp/tools/qc.R +++ b/vizapp/tools/qc.R @@ -1,40 +1,207 @@ get.qc <- function(var) { - ctfile <- paste(data.dir,'countTable.stats.txt',sep='/') - alfile <- paste(data.dir,'alignment.summary.txt',sep='/') - stats <- read.table(file=ctfile,header=TRUE,sep='\t') - align <- read.table(file=alfile,header=TRUE,sep='\t') - return(list(featurestat=stats,alignstat=align)) - } + ctfile <- paste(data.dir, 'countTable.stats.txt', sep = '/') + alfile <- paste(data.dir, 'alignment.summary.txt', sep = '/') + stats <- read.table(file = ctfile,header = TRUE,sep = '\t') + align <- read.table(file = alfile,header = TRUE,sep = '\t') + fsdes <- paste( + "Percent of Total Reads for each gene type. Boxplots draw to represent the 25th and 75th percentile (the lower and upper quartiles, respectively) as a box with a band in the box representing 50th percentile (the median). The upper whisker is located at the 'smaller' of the maximum x value and Q_3 + 1.5 inner quantile range(IRQ), whereas the lower whisker is located at the 'larger' of the smallest x value and Q_1 - 1.5 IQR", + sep = ' ' + ) + pca <- paste(data.dir, 'pca.png', sep = "/") + mds <- paste(data.dir, 'mds.png', sep = "/") + sheat <- paste(data.dir, 'samples_heatmap.png', sep = "/") + return( + list( + featurestat = stats, + alignstat = align, + fsdes = fsdes, + pca = pca, + mds = mds, + sheat = sheat + ) + ) +} -forstat <- eventReactive(input$qcButton,{get.qc(input)}) +forstat <- eventReactive(input$qcButton, {get.qc(input)}) output$plot.fs <- renderPlot({ + countTable <- forstat()$featurestat + grpnames <- levels(factor(as.character(countTable$Type))) + boxplot( + countTable$ReadPerc ~ countTable$Type, + col = rainbow(length(grpnames)), + cex.axis = 0.7, + ylab = 'Percent of Total Reads', + las = 2, + par(mar = c(12, 5, 2, 2)) + ) +}, height = "auto", width = 'auto') + +#Download Button for plot.fs +output$dlplot <- renderUI({ + if (!is.null(forstat()$featurestat)) { + downloadButton('Downloadplot', 'Download PNG') + } +}) +output$Downloadplot <- downloadHandler( + file = function() { + paste('plot', 'png', sep = ".") + }, + content <- function(file) { + png( + file, + width = 8 * 120, + height = 5 * 120, + res = 200, + pointsize = 6 + ) + if (is.null(forstat()$featurestat)) { + return() + } countTable <- forstat()$featurestat - par(oma=c(4,4,1,1)) + par(oma = c(4, 4, 1, 1)) grpnames <- levels(factor(as.character(countTable$Type))) - boxplot(countTable$ReadPerc ~ countTable$Type,col=rainbow(length(grpnames)),cex.axis=0.7,ylab='Percent of Total Reads',las=2) - }, height = 400, width = 900) + plot <- boxplot( + countTable$ReadPerc ~ countTable$Type, + col = rainbow(length(grpnames)), + cex.axis = 0.7, + ylab = 'Percent of Total Reads', + las = 2, + par(mar = c(12, 5, 2, 2)) + ) + print(plot) + dev.off() + }, + contentType = "image/png" +) -output$fs.desc <- renderText({ - paste("Percent of Total Reads for each gene type. Boxplots draw to represent the 25th and 75th percentile (the lower and upper quartiles, respectively) as a box with a band in the box representing 50th percentile (the median). The upper whisker is located at the 'smaller' of the maximum x value and Q_3 + 1.5 inner quantile range(IRQ), whereas the lower whisker is located at the 'larger' of the smallest x value and Q_1 - 1.5 IQR",sep=' ') - }) +#display description for the plot +output$fs.desc <- renderText({ + paste(forstat()$fsdes) +}) output$feature.stats <- DT::renderDataTable({ t1 <- forstat()$featurestat - t1 -},escape=FALSE,filter = 'top',options = list(lengthMenu = c(10, 25, 50, 200, -1))) + DT::datatable( + t1, + escape = FALSE, + filter = 'top', + options = list(lengthMenu = list( + c(10, 25, 50, 100,-1), list('10', '25', '50', '100', 'All') + )) + ) +}) output$align.stats <- DT::renderDataTable({ t1 <- forstat()$alignstat - t1 -},escape=FALSE,filter = 'top',options = list(lengthMenu = c(10, 25, 50, 200, -1))) + DT::datatable( + t1, + escape = FALSE, + filter = 'top', + options = list(lengthMenu = list( + c(10, 25, 50, 100,-1), list('10', '25', '50', '100', 'All') + )) + ) +}) +output$downloadAlign <- renderUI({ + if (!is.null(forstat()$alignstat)) { + downloadButton('DownloadAlign', 'Download CSV') + } +}) +output$DownloadAlign <- downloadHandler( + file <- paste('alignment.summary.txt'), + content = function(file) { + write.table( + forstat()$alignstat, + file, + quote = FALSE, + row.names = FALSE, + sep = '\t' + ) + } +) +output$downloadGT <- renderUI({ + if (!is.null(forstat()$featurestat)) { + downloadButton('DownloadGT', 'Download CSV') + } +}) +output$DownloadGT <- downloadHandler( + file <- paste('countTable.stats.txt'), + content = function(file) { + write.table( + forstat()$featurestat, + file, + quote = FALSE, + row.names = FALSE, + sep = '\t' + ) + } +) output$pca1 <- renderImage({ - list(src=paste(data.dir,'pca.png',sep="/"), alt=paste("Sample Comparison 1")) -},deleteFile=FALSE) + list( + src = forstat()$pca, + alt = paste("Sample Comparison 1"), + width = "100%", + height = "100%" + ) +}, deleteFile = FALSE) + +output$dlpca <- renderUI({ + if (!is.null(forstat()$pca)) { + downloadButton('Downloadpca', 'Download PNG') + } +}) +output$Downloadpca <- downloadHandler( + file = function() { + paste('pca_analysis', 'png', sep = ".") + }, + content <- function(file) { + file.copy(forstat()$pca, file) + } +) + output$pca2 <- renderImage({ - list(src=paste(data.dir,'mds.png',sep="/"), alt=paste("Sample Comparison 2")) -},deleteFile=FALSE) + list( + src = forstat()$mds, + alt = paste("Sample Comparison 2"), + width = "100%", + height = "auto" + ) +}, deleteFile = FALSE) + +output$dlmds <- renderUI({ + if (!is.null(forstat()$mds)) { + downloadButton('Downloadmds', 'Download PNG') + } +}) +output$Downloadmds <- downloadHandler( + file = function() { + paste('mds', 'png', sep = ".") + }, + content <- function(file) { + file.copy(forstat()$mds, file) + } +) output$hmap <- renderImage({ - list(src=paste(data.dir,'samples_heatmap.png',sep="/"), alt=paste("Sample Comparison 3")) -},deleteFile=FALSE) + list( + src = forstat()$sheat, + alt = paste("Sample Comparison 3"), + width = "100%", + height = "auto" + ) +}, deleteFile = FALSE) + +output$dlhmap <- renderUI({ + if (!is.null(forstat()$sheat)) { + downloadButton('Downloadhmap', 'Download PNG') + } +}) +output$Downloadhmap <- downloadHandler( + file = function() { + paste('sample_distance', 'png', sep = ".") + }, + content <- function(file) { + file.copy(forstat()$sheat, file) + } +) \ No newline at end of file diff --git a/vizapp/tools/qc_ui.R b/vizapp/tools/qc_ui.R index b9aad7b..5c9168c 100644 --- a/vizapp/tools/qc_ui.R +++ b/vizapp/tools/qc_ui.R @@ -1,37 +1,53 @@ output$ui_qc <- renderUI({ - fluidPage( - includeCSS("www/style.css"), - sidebarLayout( - sidebarPanel( - uiOutput("dir.qc"), - actionButton("qcButton", "GO") - ), - mainPanel( - tabsetPanel( - tabPanel("Align Stats", - dataTableOutput('align.stats') - ), - tabPanel("Gene Type Stats", - dataTableOutput('feature.stats'), - plotOutput("plot.fs"), - textOutput("fs.desc") - ), - tabPanel("MDS ANALYSIS", - h1("MDS"), - imageOutput("pca2",width="1200px",height="1200px") - ), - tabPanel("Sample Distances", - h1("Sample Distances"), - imageOutput("hmap",width="1200px",height="1200px") - ), - tabPanel("PCA ANALYSIS", - h1("PCA"), - imageOutput("pca1",width="1200px",height="1200px") - ) - ) - ) - ) + list(fluidPage( + includeCSS("www/style.css"), + fluidRow( + sidebarPanel( + uiOutput("dir.qc"), + p("Click it to load data"), + actionButton("qcButton", "GO", class = "btn btn-primary btn-bg centerbtn") + ), + column(7, + tabsetPanel( + tabPanel( + "Align Stats", + br(),br(), + dataTableOutput('align.stats'), + br(), + uiOutput('downloadAlign') + ), + + tabPanel( + "Gene Type Stats", + br(),br(), + dataTableOutput('feature.stats'), + uiOutput('downloadGT'), + plotOutput("plot.fs"), + uiOutput('dlplot'), + br(), + textOutput("fs.desc") + ), + tabPanel( + "MDS Analysis", + br(),br(), + imageOutput("pca2", width = "100%", height = "auto"), + uiOutput('dlmds') + ), + tabPanel( + "Sample Distances", + br(),br(), + imageOutput("hmap", width = "100%", height = "auto"), + uiOutput('dlhmap') + ), + tabPanel( + "PCA Analysis", + br(),br(), + imageOutput("pca1", width = "100%", height = "auto"), + uiOutput('dlpca') + ) ) + ) + ) + )) }) - diff --git a/vizapp/ui.R b/vizapp/ui.R index 3afa28a..defef96 100755 --- a/vizapp/ui.R +++ b/vizapp/ui.R @@ -1,14 +1,38 @@ library(shiny) - -shinyUI(navbarPage("RNASeq Analysis", - id = "nav_shinyapp", inverse = TRUE, collapsible = TRUE, - tabPanel("Introduction",uiOutput('ui_intro')), - tabPanel("Dataset QC", uiOutput('ui_qc')), - #tabPanel("Sample Sequencing QC", uiOutput('ui_fastqc')), - tabPanel("Gene Compare", uiOutput('ui_gc')), - tabPanel("Gene Alt Splicing", uiOutput('ui_altsplice')), - tabPanel("DEA", uiOutput('ui_dea')), - tabPanel("QuSAGE", uiOutput('ui_gsea')) - )) - - +library(shinythemes) +shinyUI(list( + navbarPage( + title = "RNASeq Analysis", + id = "nav_shinyapp", + inverse = TRUE, + collapsible = TRUE, + theme = shinytheme("yeti"), + + tabPanel("Introduction", uiOutput('ui_intro')), + tabPanel("Dataset QC", uiOutput('ui_qc')), + #tabPanel("Sample Sequencing QC", uiOutput('ui_fastqc')), + tabPanel( + "Gene Compare", + id = "panelgc", + value = "panelgc", + uiOutput('ui_gc') + ), + tabPanel("Gene Alt Splicing", uiOutput('ui_altsplice')), + tabPanel("DEA", id = "paneldea", value = "paneldea", uiOutput('ui_dea')), + tabPanel( + "QuSAGE", + id = "panelgsea", + value = "panelgsea", + uiOutput('ui_gsea') + ) + ), + fluidRow(style = "margin-top:40px", tags$footer(class = "footer", + div(class = "container", + style = "padding-bottom:0; margin-bottom:0", + p(icon("envelope", lib = "glyphicon"), + "brandi.cantarel@utsouthwestern.edu | @ UT Southwestern Medical Center", + style = "margin-bottom:-40px;") + ) + ) + ) +)) diff --git a/vizapp/www/bootstrap.min.css b/vizapp/www/bootstrap.min.css new file mode 100644 index 0000000..078c429 --- /dev/null +++ b/vizapp/www/bootstrap.min.css @@ -0,0 +1,13 @@ +/*! + * Bootswatch v4.0.0 + * Homepage: https://bootswatch.com + * Copyright 2012-2018 Thomas Park + * Licensed under MIT + * Based on Bootstrap +*//*! + * Bootstrap v4.0.0 (https://getbootstrap.com) + * Copyright 2011-2018 The Bootstrap Authors + * Copyright 2011-2018 Twitter, Inc. + * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE) + */@import url("https://fonts.googleapis.com/css?family=Open+Sans:300italic,400italic,700italic,400,300,700");:root{--blue:#008cba;--indigo:#6610f2;--purple:#6f42c1;--pink:#e83e8c;--red:#F04124;--orange:#fd7e14;--yellow:#E99002;--green:#43ac6a;--teal:#20c997;--cyan:#5bc0de;--white:#fff;--gray:#888;--gray-dark:#333;--primary:#008cba;--secondary:#eee;--success:#43ac6a;--info:#5bc0de;--warning:#E99002;--danger:#F04124;--light:#eee;--dark:#222;--breakpoint-xs:0;--breakpoint-sm:576px;--breakpoint-md:768px;--breakpoint-lg:992px;--breakpoint-xl:1200px;--font-family-sans-serif:"Open Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";--font-family-monospace:SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace}*,*::before,*::after{-webkit-box-sizing:border-box;box-sizing:border-box}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-ms-overflow-style:scrollbar;-webkit-tap-highlight-color:transparent}@-ms-viewport{width:device-width}article,aside,dialog,figcaption,figure,footer,header,hgroup,main,nav,section{display:block}body{margin:0;font-family:"Open Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";font-size:0.9375rem;font-weight:400;line-height:1.5;color:#222;text-align:left;background-color:#fff}[tabindex="-1"]:focus{outline:0 !important}hr{-webkit-box-sizing:content-box;box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:0.5rem}p{margin-top:0;margin-bottom:1rem}abbr[title],abbr[data-original-title]{text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted;cursor:help;border-bottom:0}address{margin-bottom:1rem;font-style:normal;line-height:inherit}ol,ul,dl{margin-top:0;margin-bottom:1rem}ol ol,ul ul,ol ul,ul ol{margin-bottom:0}dt{font-weight:700}dd{margin-bottom:.5rem;margin-left:0}blockquote{margin:0 0 1rem}dfn{font-style:italic}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}a{color:#008cba;text-decoration:none;background-color:transparent;-webkit-text-decoration-skip:objects}a:hover{color:#00526e;text-decoration:underline}a:not([href]):not([tabindex]){color:inherit;text-decoration:none}a:not([href]):not([tabindex]):hover,a:not([href]):not([tabindex]):focus{color:inherit;text-decoration:none}a:not([href]):not([tabindex]):focus{outline:0}pre,code,kbd,samp{font-family:monospace, monospace;font-size:1em}pre{margin-top:0;margin-bottom:1rem;overflow:auto;-ms-overflow-style:scrollbar}figure{margin:0 0 1rem}img{vertical-align:middle;border-style:none}svg:not(:root){overflow:hidden}table{border-collapse:collapse}caption{padding-top:0.75rem;padding-bottom:0.75rem;color:#888;text-align:left;caption-side:bottom}th{text-align:inherit}label{display:inline-block;margin-bottom:.5rem}button{border-radius:0}button:focus{outline:1px dotted;outline:5px auto -webkit-focus-ring-color}input,button,select,optgroup,textarea{margin:0;font-family:inherit;font-size:inherit;line-height:inherit}button,input{overflow:visible}button,select{text-transform:none}button,html [type="button"],[type="reset"],[type="submit"]{-webkit-appearance:button}button::-moz-focus-inner,[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner{padding:0;border-style:none}input[type="radio"],input[type="checkbox"]{-webkit-box-sizing:border-box;box-sizing:border-box;padding:0}input[type="date"],input[type="time"],input[type="datetime-local"],input[type="month"]{-webkit-appearance:listbox}textarea{overflow:auto;resize:vertical}fieldset{min-width:0;padding:0;margin:0;border:0}legend{display:block;width:100%;max-width:100%;padding:0;margin-bottom:.5rem;font-size:1.5rem;line-height:inherit;color:inherit;white-space:normal}progress{vertical-align:baseline}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{height:auto}[type="search"]{outline-offset:-2px;-webkit-appearance:none}[type="search"]::-webkit-search-cancel-button,[type="search"]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}summary{display:list-item;cursor:pointer}template{display:none}[hidden]{display:none !important}h1,h2,h3,h4,h5,h6,.h1,.h2,.h3,.h4,.h5,.h6{margin-bottom:0.5rem;font-family:inherit;font-weight:300;line-height:1.2;color:inherit}h1,.h1{font-size:2.34375rem}h2,.h2{font-size:1.875rem}h3,.h3{font-size:1.640625rem}h4,.h4{font-size:1.40625rem}h5,.h5{font-size:1.171875rem}h6,.h6{font-size:0.9375rem}.lead{font-size:1.171875rem;font-weight:300}.display-1{font-size:6rem;font-weight:300;line-height:1.2}.display-2{font-size:5.5rem;font-weight:300;line-height:1.2}.display-3{font-size:4.5rem;font-weight:300;line-height:1.2}.display-4{font-size:3.5rem;font-weight:300;line-height:1.2}hr{margin-top:1rem;margin-bottom:1rem;border:0;border-top:1px solid rgba(0,0,0,0.1)}small,.small{font-size:80%;font-weight:400}mark,.mark{padding:0.2em;background-color:#fcf8e3}.list-unstyled{padding-left:0;list-style:none}.list-inline{padding-left:0;list-style:none}.list-inline-item{display:inline-block}.list-inline-item:not(:last-child){margin-right:0.5rem}.initialism{font-size:90%;text-transform:uppercase}.blockquote{margin-bottom:1rem;font-size:1.171875rem}.blockquote-footer{display:block;font-size:80%;color:#888}.blockquote-footer::before{content:"\2014 \00A0"}.img-fluid{max-width:100%;height:auto}.img-thumbnail{padding:0.25rem;background-color:#fff;border:1px solid #dee2e6;border-radius:0;max-width:100%;height:auto}.figure{display:inline-block}.figure-img{margin-bottom:0.5rem;line-height:1}.figure-caption{font-size:90%;color:#888}code,kbd,pre,samp{font-family:SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace}code{font-size:87.5%;color:#e83e8c;word-break:break-word}a>code{color:inherit}kbd{padding:0.2rem 0.4rem;font-size:87.5%;color:#fff;background-color:#222;border-radius:0}kbd kbd{padding:0;font-size:100%;font-weight:700}pre{display:block;font-size:87.5%;color:#222}pre code{font-size:inherit;color:inherit;word-break:normal}.pre-scrollable{max-height:340px;overflow-y:scroll}.container{width:100%;padding-right:15px;padding-left:15px;margin-right:auto;margin-left:auto}@media (min-width: 576px){.container{max-width:540px}}@media (min-width: 768px){.container{max-width:720px}}@media (min-width: 992px){.container{max-width:960px}}@media (min-width: 1200px){.container{max-width:1140px}}.container-fluid{width:100%;padding-right:15px;padding-left:15px;margin-right:auto;margin-left:auto}.row{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;margin-right:-15px;margin-left:-15px}.no-gutters{margin-right:0;margin-left:0}.no-gutters>.col,.no-gutters>[class*="col-"]{padding-right:0;padding-left:0}.col-1,.col-2,.col-3,.col-4,.col-5,.col-6,.col-7,.col-8,.col-9,.col-10,.col-11,.col-12,.col,.col-auto,.col-sm-1,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9,.col-sm-10,.col-sm-11,.col-sm-12,.col-sm,.col-sm-auto,.col-md-1,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9,.col-md-10,.col-md-11,.col-md-12,.col-md,.col-md-auto,.col-lg-1,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9,.col-lg-10,.col-lg-11,.col-lg-12,.col-lg,.col-lg-auto,.col-xl-1,.col-xl-2,.col-xl-3,.col-xl-4,.col-xl-5,.col-xl-6,.col-xl-7,.col-xl-8,.col-xl-9,.col-xl-10,.col-xl-11,.col-xl-12,.col-xl,.col-xl-auto{position:relative;width:100%;min-height:1px;padding-right:15px;padding-left:15px}.col{-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-auto{-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-1{-webkit-box-flex:0;-ms-flex:0 0 8.3333333333%;flex:0 0 8.3333333333%;max-width:8.3333333333%}.col-2{-webkit-box-flex:0;-ms-flex:0 0 16.6666666667%;flex:0 0 16.6666666667%;max-width:16.6666666667%}.col-3{-webkit-box-flex:0;-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-4{-webkit-box-flex:0;-ms-flex:0 0 33.3333333333%;flex:0 0 33.3333333333%;max-width:33.3333333333%}.col-5{-webkit-box-flex:0;-ms-flex:0 0 41.6666666667%;flex:0 0 41.6666666667%;max-width:41.6666666667%}.col-6{-webkit-box-flex:0;-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-7{-webkit-box-flex:0;-ms-flex:0 0 58.3333333333%;flex:0 0 58.3333333333%;max-width:58.3333333333%}.col-8{-webkit-box-flex:0;-ms-flex:0 0 66.6666666667%;flex:0 0 66.6666666667%;max-width:66.6666666667%}.col-9{-webkit-box-flex:0;-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-10{-webkit-box-flex:0;-ms-flex:0 0 83.3333333333%;flex:0 0 83.3333333333%;max-width:83.3333333333%}.col-11{-webkit-box-flex:0;-ms-flex:0 0 91.6666666667%;flex:0 0 91.6666666667%;max-width:91.6666666667%}.col-12{-webkit-box-flex:0;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-first{-webkit-box-ordinal-group:0;-ms-flex-order:-1;order:-1}.order-last{-webkit-box-ordinal-group:14;-ms-flex-order:13;order:13}.order-0{-webkit-box-ordinal-group:1;-ms-flex-order:0;order:0}.order-1{-webkit-box-ordinal-group:2;-ms-flex-order:1;order:1}.order-2{-webkit-box-ordinal-group:3;-ms-flex-order:2;order:2}.order-3{-webkit-box-ordinal-group:4;-ms-flex-order:3;order:3}.order-4{-webkit-box-ordinal-group:5;-ms-flex-order:4;order:4}.order-5{-webkit-box-ordinal-group:6;-ms-flex-order:5;order:5}.order-6{-webkit-box-ordinal-group:7;-ms-flex-order:6;order:6}.order-7{-webkit-box-ordinal-group:8;-ms-flex-order:7;order:7}.order-8{-webkit-box-ordinal-group:9;-ms-flex-order:8;order:8}.order-9{-webkit-box-ordinal-group:10;-ms-flex-order:9;order:9}.order-10{-webkit-box-ordinal-group:11;-ms-flex-order:10;order:10}.order-11{-webkit-box-ordinal-group:12;-ms-flex-order:11;order:11}.order-12{-webkit-box-ordinal-group:13;-ms-flex-order:12;order:12}.offset-1{margin-left:8.3333333333%}.offset-2{margin-left:16.6666666667%}.offset-3{margin-left:25%}.offset-4{margin-left:33.3333333333%}.offset-5{margin-left:41.6666666667%}.offset-6{margin-left:50%}.offset-7{margin-left:58.3333333333%}.offset-8{margin-left:66.6666666667%}.offset-9{margin-left:75%}.offset-10{margin-left:83.3333333333%}.offset-11{margin-left:91.6666666667%}@media (min-width: 576px){.col-sm{-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-sm-auto{-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-sm-1{-webkit-box-flex:0;-ms-flex:0 0 8.3333333333%;flex:0 0 8.3333333333%;max-width:8.3333333333%}.col-sm-2{-webkit-box-flex:0;-ms-flex:0 0 16.6666666667%;flex:0 0 16.6666666667%;max-width:16.6666666667%}.col-sm-3{-webkit-box-flex:0;-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-sm-4{-webkit-box-flex:0;-ms-flex:0 0 33.3333333333%;flex:0 0 33.3333333333%;max-width:33.3333333333%}.col-sm-5{-webkit-box-flex:0;-ms-flex:0 0 41.6666666667%;flex:0 0 41.6666666667%;max-width:41.6666666667%}.col-sm-6{-webkit-box-flex:0;-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-sm-7{-webkit-box-flex:0;-ms-flex:0 0 58.3333333333%;flex:0 0 58.3333333333%;max-width:58.3333333333%}.col-sm-8{-webkit-box-flex:0;-ms-flex:0 0 66.6666666667%;flex:0 0 66.6666666667%;max-width:66.6666666667%}.col-sm-9{-webkit-box-flex:0;-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-sm-10{-webkit-box-flex:0;-ms-flex:0 0 83.3333333333%;flex:0 0 83.3333333333%;max-width:83.3333333333%}.col-sm-11{-webkit-box-flex:0;-ms-flex:0 0 91.6666666667%;flex:0 0 91.6666666667%;max-width:91.6666666667%}.col-sm-12{-webkit-box-flex:0;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-sm-first{-webkit-box-ordinal-group:0;-ms-flex-order:-1;order:-1}.order-sm-last{-webkit-box-ordinal-group:14;-ms-flex-order:13;order:13}.order-sm-0{-webkit-box-ordinal-group:1;-ms-flex-order:0;order:0}.order-sm-1{-webkit-box-ordinal-group:2;-ms-flex-order:1;order:1}.order-sm-2{-webkit-box-ordinal-group:3;-ms-flex-order:2;order:2}.order-sm-3{-webkit-box-ordinal-group:4;-ms-flex-order:3;order:3}.order-sm-4{-webkit-box-ordinal-group:5;-ms-flex-order:4;order:4}.order-sm-5{-webkit-box-ordinal-group:6;-ms-flex-order:5;order:5}.order-sm-6{-webkit-box-ordinal-group:7;-ms-flex-order:6;order:6}.order-sm-7{-webkit-box-ordinal-group:8;-ms-flex-order:7;order:7}.order-sm-8{-webkit-box-ordinal-group:9;-ms-flex-order:8;order:8}.order-sm-9{-webkit-box-ordinal-group:10;-ms-flex-order:9;order:9}.order-sm-10{-webkit-box-ordinal-group:11;-ms-flex-order:10;order:10}.order-sm-11{-webkit-box-ordinal-group:12;-ms-flex-order:11;order:11}.order-sm-12{-webkit-box-ordinal-group:13;-ms-flex-order:12;order:12}.offset-sm-0{margin-left:0}.offset-sm-1{margin-left:8.3333333333%}.offset-sm-2{margin-left:16.6666666667%}.offset-sm-3{margin-left:25%}.offset-sm-4{margin-left:33.3333333333%}.offset-sm-5{margin-left:41.6666666667%}.offset-sm-6{margin-left:50%}.offset-sm-7{margin-left:58.3333333333%}.offset-sm-8{margin-left:66.6666666667%}.offset-sm-9{margin-left:75%}.offset-sm-10{margin-left:83.3333333333%}.offset-sm-11{margin-left:91.6666666667%}}@media (min-width: 768px){.col-md{-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-md-auto{-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-md-1{-webkit-box-flex:0;-ms-flex:0 0 8.3333333333%;flex:0 0 8.3333333333%;max-width:8.3333333333%}.col-md-2{-webkit-box-flex:0;-ms-flex:0 0 16.6666666667%;flex:0 0 16.6666666667%;max-width:16.6666666667%}.col-md-3{-webkit-box-flex:0;-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-md-4{-webkit-box-flex:0;-ms-flex:0 0 33.3333333333%;flex:0 0 33.3333333333%;max-width:33.3333333333%}.col-md-5{-webkit-box-flex:0;-ms-flex:0 0 41.6666666667%;flex:0 0 41.6666666667%;max-width:41.6666666667%}.col-md-6{-webkit-box-flex:0;-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-md-7{-webkit-box-flex:0;-ms-flex:0 0 58.3333333333%;flex:0 0 58.3333333333%;max-width:58.3333333333%}.col-md-8{-webkit-box-flex:0;-ms-flex:0 0 66.6666666667%;flex:0 0 66.6666666667%;max-width:66.6666666667%}.col-md-9{-webkit-box-flex:0;-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-md-10{-webkit-box-flex:0;-ms-flex:0 0 83.3333333333%;flex:0 0 83.3333333333%;max-width:83.3333333333%}.col-md-11{-webkit-box-flex:0;-ms-flex:0 0 91.6666666667%;flex:0 0 91.6666666667%;max-width:91.6666666667%}.col-md-12{-webkit-box-flex:0;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-md-first{-webkit-box-ordinal-group:0;-ms-flex-order:-1;order:-1}.order-md-last{-webkit-box-ordinal-group:14;-ms-flex-order:13;order:13}.order-md-0{-webkit-box-ordinal-group:1;-ms-flex-order:0;order:0}.order-md-1{-webkit-box-ordinal-group:2;-ms-flex-order:1;order:1}.order-md-2{-webkit-box-ordinal-group:3;-ms-flex-order:2;order:2}.order-md-3{-webkit-box-ordinal-group:4;-ms-flex-order:3;order:3}.order-md-4{-webkit-box-ordinal-group:5;-ms-flex-order:4;order:4}.order-md-5{-webkit-box-ordinal-group:6;-ms-flex-order:5;order:5}.order-md-6{-webkit-box-ordinal-group:7;-ms-flex-order:6;order:6}.order-md-7{-webkit-box-ordinal-group:8;-ms-flex-order:7;order:7}.order-md-8{-webkit-box-ordinal-group:9;-ms-flex-order:8;order:8}.order-md-9{-webkit-box-ordinal-group:10;-ms-flex-order:9;order:9}.order-md-10{-webkit-box-ordinal-group:11;-ms-flex-order:10;order:10}.order-md-11{-webkit-box-ordinal-group:12;-ms-flex-order:11;order:11}.order-md-12{-webkit-box-ordinal-group:13;-ms-flex-order:12;order:12}.offset-md-0{margin-left:0}.offset-md-1{margin-left:8.3333333333%}.offset-md-2{margin-left:16.6666666667%}.offset-md-3{margin-left:25%}.offset-md-4{margin-left:33.3333333333%}.offset-md-5{margin-left:41.6666666667%}.offset-md-6{margin-left:50%}.offset-md-7{margin-left:58.3333333333%}.offset-md-8{margin-left:66.6666666667%}.offset-md-9{margin-left:75%}.offset-md-10{margin-left:83.3333333333%}.offset-md-11{margin-left:91.6666666667%}}@media (min-width: 992px){.col-lg{-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-lg-auto{-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-lg-1{-webkit-box-flex:0;-ms-flex:0 0 8.3333333333%;flex:0 0 8.3333333333%;max-width:8.3333333333%}.col-lg-2{-webkit-box-flex:0;-ms-flex:0 0 16.6666666667%;flex:0 0 16.6666666667%;max-width:16.6666666667%}.col-lg-3{-webkit-box-flex:0;-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-lg-4{-webkit-box-flex:0;-ms-flex:0 0 33.3333333333%;flex:0 0 33.3333333333%;max-width:33.3333333333%}.col-lg-5{-webkit-box-flex:0;-ms-flex:0 0 41.6666666667%;flex:0 0 41.6666666667%;max-width:41.6666666667%}.col-lg-6{-webkit-box-flex:0;-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-lg-7{-webkit-box-flex:0;-ms-flex:0 0 58.3333333333%;flex:0 0 58.3333333333%;max-width:58.3333333333%}.col-lg-8{-webkit-box-flex:0;-ms-flex:0 0 66.6666666667%;flex:0 0 66.6666666667%;max-width:66.6666666667%}.col-lg-9{-webkit-box-flex:0;-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-lg-10{-webkit-box-flex:0;-ms-flex:0 0 83.3333333333%;flex:0 0 83.3333333333%;max-width:83.3333333333%}.col-lg-11{-webkit-box-flex:0;-ms-flex:0 0 91.6666666667%;flex:0 0 91.6666666667%;max-width:91.6666666667%}.col-lg-12{-webkit-box-flex:0;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-lg-first{-webkit-box-ordinal-group:0;-ms-flex-order:-1;order:-1}.order-lg-last{-webkit-box-ordinal-group:14;-ms-flex-order:13;order:13}.order-lg-0{-webkit-box-ordinal-group:1;-ms-flex-order:0;order:0}.order-lg-1{-webkit-box-ordinal-group:2;-ms-flex-order:1;order:1}.order-lg-2{-webkit-box-ordinal-group:3;-ms-flex-order:2;order:2}.order-lg-3{-webkit-box-ordinal-group:4;-ms-flex-order:3;order:3}.order-lg-4{-webkit-box-ordinal-group:5;-ms-flex-order:4;order:4}.order-lg-5{-webkit-box-ordinal-group:6;-ms-flex-order:5;order:5}.order-lg-6{-webkit-box-ordinal-group:7;-ms-flex-order:6;order:6}.order-lg-7{-webkit-box-ordinal-group:8;-ms-flex-order:7;order:7}.order-lg-8{-webkit-box-ordinal-group:9;-ms-flex-order:8;order:8}.order-lg-9{-webkit-box-ordinal-group:10;-ms-flex-order:9;order:9}.order-lg-10{-webkit-box-ordinal-group:11;-ms-flex-order:10;order:10}.order-lg-11{-webkit-box-ordinal-group:12;-ms-flex-order:11;order:11}.order-lg-12{-webkit-box-ordinal-group:13;-ms-flex-order:12;order:12}.offset-lg-0{margin-left:0}.offset-lg-1{margin-left:8.3333333333%}.offset-lg-2{margin-left:16.6666666667%}.offset-lg-3{margin-left:25%}.offset-lg-4{margin-left:33.3333333333%}.offset-lg-5{margin-left:41.6666666667%}.offset-lg-6{margin-left:50%}.offset-lg-7{margin-left:58.3333333333%}.offset-lg-8{margin-left:66.6666666667%}.offset-lg-9{margin-left:75%}.offset-lg-10{margin-left:83.3333333333%}.offset-lg-11{margin-left:91.6666666667%}}@media (min-width: 1200px){.col-xl{-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;max-width:100%}.col-xl-auto{-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;width:auto;max-width:none}.col-xl-1{-webkit-box-flex:0;-ms-flex:0 0 8.3333333333%;flex:0 0 8.3333333333%;max-width:8.3333333333%}.col-xl-2{-webkit-box-flex:0;-ms-flex:0 0 16.6666666667%;flex:0 0 16.6666666667%;max-width:16.6666666667%}.col-xl-3{-webkit-box-flex:0;-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.col-xl-4{-webkit-box-flex:0;-ms-flex:0 0 33.3333333333%;flex:0 0 33.3333333333%;max-width:33.3333333333%}.col-xl-5{-webkit-box-flex:0;-ms-flex:0 0 41.6666666667%;flex:0 0 41.6666666667%;max-width:41.6666666667%}.col-xl-6{-webkit-box-flex:0;-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.col-xl-7{-webkit-box-flex:0;-ms-flex:0 0 58.3333333333%;flex:0 0 58.3333333333%;max-width:58.3333333333%}.col-xl-8{-webkit-box-flex:0;-ms-flex:0 0 66.6666666667%;flex:0 0 66.6666666667%;max-width:66.6666666667%}.col-xl-9{-webkit-box-flex:0;-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.col-xl-10{-webkit-box-flex:0;-ms-flex:0 0 83.3333333333%;flex:0 0 83.3333333333%;max-width:83.3333333333%}.col-xl-11{-webkit-box-flex:0;-ms-flex:0 0 91.6666666667%;flex:0 0 91.6666666667%;max-width:91.6666666667%}.col-xl-12{-webkit-box-flex:0;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.order-xl-first{-webkit-box-ordinal-group:0;-ms-flex-order:-1;order:-1}.order-xl-last{-webkit-box-ordinal-group:14;-ms-flex-order:13;order:13}.order-xl-0{-webkit-box-ordinal-group:1;-ms-flex-order:0;order:0}.order-xl-1{-webkit-box-ordinal-group:2;-ms-flex-order:1;order:1}.order-xl-2{-webkit-box-ordinal-group:3;-ms-flex-order:2;order:2}.order-xl-3{-webkit-box-ordinal-group:4;-ms-flex-order:3;order:3}.order-xl-4{-webkit-box-ordinal-group:5;-ms-flex-order:4;order:4}.order-xl-5{-webkit-box-ordinal-group:6;-ms-flex-order:5;order:5}.order-xl-6{-webkit-box-ordinal-group:7;-ms-flex-order:6;order:6}.order-xl-7{-webkit-box-ordinal-group:8;-ms-flex-order:7;order:7}.order-xl-8{-webkit-box-ordinal-group:9;-ms-flex-order:8;order:8}.order-xl-9{-webkit-box-ordinal-group:10;-ms-flex-order:9;order:9}.order-xl-10{-webkit-box-ordinal-group:11;-ms-flex-order:10;order:10}.order-xl-11{-webkit-box-ordinal-group:12;-ms-flex-order:11;order:11}.order-xl-12{-webkit-box-ordinal-group:13;-ms-flex-order:12;order:12}.offset-xl-0{margin-left:0}.offset-xl-1{margin-left:8.3333333333%}.offset-xl-2{margin-left:16.6666666667%}.offset-xl-3{margin-left:25%}.offset-xl-4{margin-left:33.3333333333%}.offset-xl-5{margin-left:41.6666666667%}.offset-xl-6{margin-left:50%}.offset-xl-7{margin-left:58.3333333333%}.offset-xl-8{margin-left:66.6666666667%}.offset-xl-9{margin-left:75%}.offset-xl-10{margin-left:83.3333333333%}.offset-xl-11{margin-left:91.6666666667%}}.table{width:100%;max-width:100%;margin-bottom:1rem;background-color:transparent}.table th,.table td{padding:0.75rem;vertical-align:top;border-top:1px solid #dee2e6}.table thead th{vertical-align:bottom;border-bottom:2px solid #dee2e6}.table tbody+tbody{border-top:2px solid #dee2e6}.table .table{background-color:#fff}.table-sm th,.table-sm td{padding:0.3rem}.table-bordered{border:1px solid #dee2e6}.table-bordered th,.table-bordered td{border:1px solid #dee2e6}.table-bordered thead th,.table-bordered thead td{border-bottom-width:2px}.table-striped tbody tr:nth-of-type(odd){background-color:rgba(0,0,0,0.05)}.table-hover tbody tr:hover{background-color:rgba(0,0,0,0.075)}.table-primary,.table-primary>th,.table-primary>td{background-color:#b8dfec}.table-hover .table-primary:hover{background-color:#a4d6e7}.table-hover .table-primary:hover>td,.table-hover .table-primary:hover>th{background-color:#a4d6e7}.table-secondary,.table-secondary>th,.table-secondary>td{background-color:#fafafa}.table-hover .table-secondary:hover{background-color:#ededed}.table-hover .table-secondary:hover>td,.table-hover .table-secondary:hover>th{background-color:#ededed}.table-success,.table-success>th,.table-success>td{background-color:#cae8d5}.table-hover .table-success:hover{background-color:#b8e0c7}.table-hover .table-success:hover>td,.table-hover .table-success:hover>th{background-color:#b8e0c7}.table-info,.table-info>th,.table-info>td{background-color:#d1edf6}.table-hover .table-info:hover{background-color:#bce5f2}.table-hover .table-info:hover>td,.table-hover .table-info:hover>th{background-color:#bce5f2}.table-warning,.table-warning>th,.table-warning>td{background-color:#f9e0b8}.table-hover .table-warning:hover{background-color:#f7d6a0}.table-hover .table-warning:hover>td,.table-hover .table-warning:hover>th{background-color:#f7d6a0}.table-danger,.table-danger>th,.table-danger>td{background-color:#fbcac2}.table-hover .table-danger:hover{background-color:#f9b5aa}.table-hover .table-danger:hover>td,.table-hover .table-danger:hover>th{background-color:#f9b5aa}.table-light,.table-light>th,.table-light>td{background-color:#fafafa}.table-hover .table-light:hover{background-color:#ededed}.table-hover .table-light:hover>td,.table-hover .table-light:hover>th{background-color:#ededed}.table-dark,.table-dark>th,.table-dark>td{background-color:#c1c1c1}.table-hover .table-dark:hover{background-color:#b4b4b4}.table-hover .table-dark:hover>td,.table-hover .table-dark:hover>th{background-color:#b4b4b4}.table-active,.table-active>th,.table-active>td{background-color:rgba(0,0,0,0.075)}.table-hover .table-active:hover{background-color:rgba(0,0,0,0.075)}.table-hover .table-active:hover>td,.table-hover .table-active:hover>th{background-color:rgba(0,0,0,0.075)}.table .thead-dark th{color:#fff;background-color:#222;border-color:#353535}.table .thead-light th{color:#495057;background-color:#eee;border-color:#dee2e6}.table-dark{color:#fff;background-color:#222}.table-dark th,.table-dark td,.table-dark thead th{border-color:#353535}.table-dark.table-bordered{border:0}.table-dark.table-striped tbody tr:nth-of-type(odd){background-color:rgba(255,255,255,0.05)}.table-dark.table-hover tbody tr:hover{background-color:rgba(255,255,255,0.075)}@media (max-width: 575.98px){.table-responsive-sm{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.table-responsive-sm>.table-bordered{border:0}}@media (max-width: 767.98px){.table-responsive-md{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.table-responsive-md>.table-bordered{border:0}}@media (max-width: 991.98px){.table-responsive-lg{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.table-responsive-lg>.table-bordered{border:0}}@media (max-width: 1199.98px){.table-responsive-xl{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.table-responsive-xl>.table-bordered{border:0}}.table-responsive{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.table-responsive>.table-bordered{border:0}.form-control{display:block;width:100%;padding:0.375rem 1rem;font-size:0.9375rem;line-height:1.5;color:#495057;background-color:#fff;background-clip:padding-box;border:1px solid #ccc;border-radius:0;-webkit-transition:border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;transition:border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;transition:border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;transition:border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out}.form-control::-ms-expand{background-color:transparent;border:0}.form-control:focus{color:#495057;background-color:#fff;border-color:#3bceff;outline:0;-webkit-box-shadow:0 0 0 0.2rem rgba(0,140,186,0.25);box-shadow:0 0 0 0.2rem rgba(0,140,186,0.25)}.form-control::-webkit-input-placeholder{color:#888;opacity:1}.form-control:-ms-input-placeholder{color:#888;opacity:1}.form-control::-ms-input-placeholder{color:#888;opacity:1}.form-control::placeholder{color:#888;opacity:1}.form-control:disabled,.form-control[readonly]{background-color:#eee;opacity:1}select.form-control:not([size]):not([multiple]){height:calc(2.15625rem + 2px)}select.form-control:focus::-ms-value{color:#495057;background-color:#fff}.form-control-file,.form-control-range{display:block;width:100%}.col-form-label{padding-top:calc(0.375rem + 1px);padding-bottom:calc(0.375rem + 1px);margin-bottom:0;font-size:inherit;line-height:1.5}.col-form-label-lg{padding-top:calc(0.5rem + 1px);padding-bottom:calc(0.5rem + 1px);font-size:1.171875rem;line-height:1.5}.col-form-label-sm{padding-top:calc(0.25rem + 1px);padding-bottom:calc(0.25rem + 1px);font-size:0.8203125rem;line-height:1.5}.form-control-plaintext{display:block;width:100%;padding-top:0.375rem;padding-bottom:0.375rem;margin-bottom:0;line-height:1.5;background-color:transparent;border:solid transparent;border-width:1px 0}.form-control-plaintext.form-control-sm,.input-group-sm>.form-control-plaintext.form-control,.input-group-sm>.input-group-prepend>.form-control-plaintext.input-group-text,.input-group-sm>.input-group-append>.form-control-plaintext.input-group-text,.input-group-sm>.input-group-prepend>.form-control-plaintext.btn,.input-group-sm>.input-group-append>.form-control-plaintext.btn,.form-control-plaintext.form-control-lg,.input-group-lg>.form-control-plaintext.form-control,.input-group-lg>.input-group-prepend>.form-control-plaintext.input-group-text,.input-group-lg>.input-group-append>.form-control-plaintext.input-group-text,.input-group-lg>.input-group-prepend>.form-control-plaintext.btn,.input-group-lg>.input-group-append>.form-control-plaintext.btn{padding-right:0;padding-left:0}.form-control-sm,.input-group-sm>.form-control,.input-group-sm>.input-group-prepend>.input-group-text,.input-group-sm>.input-group-append>.input-group-text,.input-group-sm>.input-group-prepend>.btn,.input-group-sm>.input-group-append>.btn{padding:0.25rem 0.5rem;font-size:0.8203125rem;line-height:1.5;border-radius:0}select.form-control-sm:not([size]):not([multiple]),.input-group-sm>select.form-control:not([size]):not([multiple]),.input-group-sm>.input-group-prepend>select.input-group-text:not([size]):not([multiple]),.input-group-sm>.input-group-append>select.input-group-text:not([size]):not([multiple]),.input-group-sm>.input-group-prepend>select.btn:not([size]):not([multiple]),.input-group-sm>.input-group-append>select.btn:not([size]):not([multiple]){height:calc(1.73046875rem + 2px)}.form-control-lg,.input-group-lg>.form-control,.input-group-lg>.input-group-prepend>.input-group-text,.input-group-lg>.input-group-append>.input-group-text,.input-group-lg>.input-group-prepend>.btn,.input-group-lg>.input-group-append>.btn{padding:0.5rem 1rem;font-size:1.171875rem;line-height:1.5;border-radius:0}select.form-control-lg:not([size]):not([multiple]),.input-group-lg>select.form-control:not([size]):not([multiple]),.input-group-lg>.input-group-prepend>select.input-group-text:not([size]):not([multiple]),.input-group-lg>.input-group-append>select.input-group-text:not([size]):not([multiple]),.input-group-lg>.input-group-prepend>select.btn:not([size]):not([multiple]),.input-group-lg>.input-group-append>select.btn:not([size]):not([multiple]){height:calc(2.7578125rem + 2px)}.form-group{margin-bottom:1rem}.form-text{display:block;margin-top:0.25rem}.form-row{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;margin-right:-5px;margin-left:-5px}.form-row>.col,.form-row>[class*="col-"]{padding-right:5px;padding-left:5px}.form-check{position:relative;display:block;padding-left:1.25rem}.form-check-input{position:absolute;margin-top:0.3rem;margin-left:-1.25rem}.form-check-input:disabled ~ .form-check-label{color:#888}.form-check-label{margin-bottom:0}.form-check-inline{display:-webkit-inline-box;display:-ms-inline-flexbox;display:inline-flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;padding-left:0;margin-right:0.75rem}.form-check-inline .form-check-input{position:static;margin-top:0;margin-right:0.3125rem;margin-left:0}.valid-feedback{display:none;width:100%;margin-top:0.25rem;font-size:80%;color:#43ac6a}.valid-tooltip{position:absolute;top:100%;z-index:5;display:none;max-width:100%;padding:.5rem;margin-top:.1rem;font-size:.875rem;line-height:1;color:#fff;background-color:rgba(67,172,106,0.8);border-radius:.2rem}.was-validated .form-control:valid,.form-control.is-valid,.was-validated .custom-select:valid,.custom-select.is-valid{border-color:#43ac6a}.was-validated .form-control:valid:focus,.form-control.is-valid:focus,.was-validated .custom-select:valid:focus,.custom-select.is-valid:focus{border-color:#43ac6a;-webkit-box-shadow:0 0 0 0.2rem rgba(67,172,106,0.25);box-shadow:0 0 0 0.2rem rgba(67,172,106,0.25)}.was-validated .form-control:valid ~ .valid-feedback,.was-validated .form-control:valid ~ .valid-tooltip,.form-control.is-valid ~ .valid-feedback,.form-control.is-valid ~ .valid-tooltip,.was-validated .custom-select:valid ~ .valid-feedback,.was-validated .custom-select:valid ~ .valid-tooltip,.custom-select.is-valid ~ .valid-feedback,.custom-select.is-valid ~ .valid-tooltip{display:block}.was-validated .form-check-input:valid ~ .form-check-label,.form-check-input.is-valid ~ .form-check-label{color:#43ac6a}.was-validated .form-check-input:valid ~ .valid-feedback,.was-validated .form-check-input:valid ~ .valid-tooltip,.form-check-input.is-valid ~ .valid-feedback,.form-check-input.is-valid ~ .valid-tooltip{display:block}.was-validated .custom-control-input:valid ~ .custom-control-label,.custom-control-input.is-valid ~ .custom-control-label{color:#43ac6a}.was-validated .custom-control-input:valid ~ .custom-control-label::before,.custom-control-input.is-valid ~ .custom-control-label::before{background-color:#98d7af}.was-validated .custom-control-input:valid ~ .valid-feedback,.was-validated .custom-control-input:valid ~ .valid-tooltip,.custom-control-input.is-valid ~ .valid-feedback,.custom-control-input.is-valid ~ .valid-tooltip{display:block}.was-validated .custom-control-input:valid:checked ~ .custom-control-label::before,.custom-control-input.is-valid:checked ~ .custom-control-label::before{background-color:#61c185}.was-validated .custom-control-input:valid:focus ~ .custom-control-label::before,.custom-control-input.is-valid:focus ~ .custom-control-label::before{-webkit-box-shadow:0 0 0 1px #fff,0 0 0 0.2rem rgba(67,172,106,0.25);box-shadow:0 0 0 1px #fff,0 0 0 0.2rem rgba(67,172,106,0.25)}.was-validated .custom-file-input:valid ~ .custom-file-label,.custom-file-input.is-valid ~ .custom-file-label{border-color:#43ac6a}.was-validated .custom-file-input:valid ~ .custom-file-label::before,.custom-file-input.is-valid ~ .custom-file-label::before{border-color:inherit}.was-validated .custom-file-input:valid ~ .valid-feedback,.was-validated .custom-file-input:valid ~ .valid-tooltip,.custom-file-input.is-valid ~ .valid-feedback,.custom-file-input.is-valid ~ .valid-tooltip{display:block}.was-validated .custom-file-input:valid:focus ~ .custom-file-label,.custom-file-input.is-valid:focus ~ .custom-file-label{-webkit-box-shadow:0 0 0 0.2rem rgba(67,172,106,0.25);box-shadow:0 0 0 0.2rem rgba(67,172,106,0.25)}.invalid-feedback{display:none;width:100%;margin-top:0.25rem;font-size:80%;color:#F04124}.invalid-tooltip{position:absolute;top:100%;z-index:5;display:none;max-width:100%;padding:.5rem;margin-top:.1rem;font-size:.875rem;line-height:1;color:#fff;background-color:rgba(240,65,36,0.8);border-radius:.2rem}.was-validated .form-control:invalid,.form-control.is-invalid,.was-validated .custom-select:invalid,.custom-select.is-invalid{border-color:#F04124}.was-validated .form-control:invalid:focus,.form-control.is-invalid:focus,.was-validated .custom-select:invalid:focus,.custom-select.is-invalid:focus{border-color:#F04124;-webkit-box-shadow:0 0 0 0.2rem rgba(240,65,36,0.25);box-shadow:0 0 0 0.2rem rgba(240,65,36,0.25)}.was-validated .form-control:invalid ~ .invalid-feedback,.was-validated .form-control:invalid ~ .invalid-tooltip,.form-control.is-invalid ~ .invalid-feedback,.form-control.is-invalid ~ .invalid-tooltip,.was-validated .custom-select:invalid ~ .invalid-feedback,.was-validated .custom-select:invalid ~ .invalid-tooltip,.custom-select.is-invalid ~ .invalid-feedback,.custom-select.is-invalid ~ .invalid-tooltip{display:block}.was-validated .form-check-input:invalid ~ .form-check-label,.form-check-input.is-invalid ~ .form-check-label{color:#F04124}.was-validated .form-check-input:invalid ~ .invalid-feedback,.was-validated .form-check-input:invalid ~ .invalid-tooltip,.form-check-input.is-invalid ~ .invalid-feedback,.form-check-input.is-invalid ~ .invalid-tooltip{display:block}.was-validated .custom-control-input:invalid ~ .custom-control-label,.custom-control-input.is-invalid ~ .custom-control-label{color:#F04124}.was-validated .custom-control-input:invalid ~ .custom-control-label::before,.custom-control-input.is-invalid ~ .custom-control-label::before{background-color:#f8a99b}.was-validated .custom-control-input:invalid ~ .invalid-feedback,.was-validated .custom-control-input:invalid ~ .invalid-tooltip,.custom-control-input.is-invalid ~ .invalid-feedback,.custom-control-input.is-invalid ~ .invalid-tooltip{display:block}.was-validated .custom-control-input:invalid:checked ~ .custom-control-label::before,.custom-control-input.is-invalid:checked ~ .custom-control-label::before{background-color:#f36a54}.was-validated .custom-control-input:invalid:focus ~ .custom-control-label::before,.custom-control-input.is-invalid:focus ~ .custom-control-label::before{-webkit-box-shadow:0 0 0 1px #fff,0 0 0 0.2rem rgba(240,65,36,0.25);box-shadow:0 0 0 1px #fff,0 0 0 0.2rem rgba(240,65,36,0.25)}.was-validated .custom-file-input:invalid ~ .custom-file-label,.custom-file-input.is-invalid ~ .custom-file-label{border-color:#F04124}.was-validated .custom-file-input:invalid ~ .custom-file-label::before,.custom-file-input.is-invalid ~ .custom-file-label::before{border-color:inherit}.was-validated .custom-file-input:invalid ~ .invalid-feedback,.was-validated .custom-file-input:invalid ~ .invalid-tooltip,.custom-file-input.is-invalid ~ .invalid-feedback,.custom-file-input.is-invalid ~ .invalid-tooltip{display:block}.was-validated .custom-file-input:invalid:focus ~ .custom-file-label,.custom-file-input.is-invalid:focus ~ .custom-file-label{-webkit-box-shadow:0 0 0 0.2rem rgba(240,65,36,0.25);box-shadow:0 0 0 0.2rem rgba(240,65,36,0.25)}.form-inline{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row wrap;flex-flow:row wrap;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.form-inline .form-check{width:100%}@media (min-width: 576px){.form-inline label{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;margin-bottom:0}.form-inline .form-group{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row wrap;flex-flow:row wrap;-webkit-box-align:center;-ms-flex-align:center;align-items:center;margin-bottom:0}.form-inline .form-control{display:inline-block;width:auto;vertical-align:middle}.form-inline .form-control-plaintext{display:inline-block}.form-inline .input-group{width:auto}.form-inline .form-check{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;width:auto;padding-left:0}.form-inline .form-check-input{position:relative;margin-top:0;margin-right:0.25rem;margin-left:0}.form-inline .custom-control{-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center}.form-inline .custom-control-label{margin-bottom:0}}.btn{display:inline-block;font-weight:300;text-align:center;white-space:nowrap;vertical-align:middle;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;border:1px solid transparent;padding:0.375rem 1rem;font-size:0.9375rem;line-height:1.5;border-radius:0;-webkit-transition:color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;transition:color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out;transition:color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;transition:color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out, -webkit-box-shadow 0.15s ease-in-out}.btn:hover,.btn:focus{text-decoration:none}.btn:focus,.btn.focus{outline:0;-webkit-box-shadow:0 0 0 0.2rem rgba(0,140,186,0.25);box-shadow:0 0 0 0.2rem rgba(0,140,186,0.25)}.btn.disabled,.btn:disabled{opacity:0.65}.btn:not(:disabled):not(.disabled){cursor:pointer}.btn:not(:disabled):not(.disabled):active,.btn:not(:disabled):not(.disabled).active{background-image:none}a.btn.disabled,fieldset:disabled a.btn{pointer-events:none}.btn-primary{color:#fff;background-color:#008cba;border-color:#008cba}.btn-primary:hover{color:#fff;background-color:#006f94;border-color:#006687}.btn-primary:focus,.btn-primary.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(0,140,186,0.5);box-shadow:0 0 0 0.2rem rgba(0,140,186,0.5)}.btn-primary.disabled,.btn-primary:disabled{color:#fff;background-color:#008cba;border-color:#008cba}.btn-primary:not(:disabled):not(.disabled):active,.btn-primary:not(:disabled):not(.disabled).active,.show>.btn-primary.dropdown-toggle{color:#fff;background-color:#006687;border-color:#005c7a}.btn-primary:not(:disabled):not(.disabled):active:focus,.btn-primary:not(:disabled):not(.disabled).active:focus,.show>.btn-primary.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(0,140,186,0.5);box-shadow:0 0 0 0.2rem rgba(0,140,186,0.5)}.btn-secondary{color:#222;background-color:#eee;border-color:#eee}.btn-secondary:hover{color:#222;background-color:#dbdbdb;border-color:#d5d4d4}.btn-secondary:focus,.btn-secondary.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(238,238,238,0.5);box-shadow:0 0 0 0.2rem rgba(238,238,238,0.5)}.btn-secondary.disabled,.btn-secondary:disabled{color:#222;background-color:#eee;border-color:#eee}.btn-secondary:not(:disabled):not(.disabled):active,.btn-secondary:not(:disabled):not(.disabled).active,.show>.btn-secondary.dropdown-toggle{color:#222;background-color:#d5d4d4;border-color:#cecece}.btn-secondary:not(:disabled):not(.disabled):active:focus,.btn-secondary:not(:disabled):not(.disabled).active:focus,.show>.btn-secondary.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(238,238,238,0.5);box-shadow:0 0 0 0.2rem rgba(238,238,238,0.5)}.btn-success{color:#fff;background-color:#43ac6a;border-color:#43ac6a}.btn-success:hover{color:#fff;background-color:#389059;border-color:#358753}.btn-success:focus,.btn-success.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(67,172,106,0.5);box-shadow:0 0 0 0.2rem rgba(67,172,106,0.5)}.btn-success.disabled,.btn-success:disabled{color:#fff;background-color:#43ac6a;border-color:#43ac6a}.btn-success:not(:disabled):not(.disabled):active,.btn-success:not(:disabled):not(.disabled).active,.show>.btn-success.dropdown-toggle{color:#fff;background-color:#358753;border-color:#317e4e}.btn-success:not(:disabled):not(.disabled):active:focus,.btn-success:not(:disabled):not(.disabled).active:focus,.show>.btn-success.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(67,172,106,0.5);box-shadow:0 0 0 0.2rem rgba(67,172,106,0.5)}.btn-info{color:#fff;background-color:#5bc0de;border-color:#5bc0de}.btn-info:hover{color:#fff;background-color:#3bb4d8;border-color:#31b0d5}.btn-info:focus,.btn-info.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(91,192,222,0.5);box-shadow:0 0 0 0.2rem rgba(91,192,222,0.5)}.btn-info.disabled,.btn-info:disabled{color:#fff;background-color:#5bc0de;border-color:#5bc0de}.btn-info:not(:disabled):not(.disabled):active,.btn-info:not(:disabled):not(.disabled).active,.show>.btn-info.dropdown-toggle{color:#fff;background-color:#31b0d5;border-color:#2aaacf}.btn-info:not(:disabled):not(.disabled):active:focus,.btn-info:not(:disabled):not(.disabled).active:focus,.show>.btn-info.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(91,192,222,0.5);box-shadow:0 0 0 0.2rem rgba(91,192,222,0.5)}.btn-warning{color:#fff;background-color:#E99002;border-color:#E99002}.btn-warning:hover{color:#fff;background-color:#c37902;border-color:#b67102}.btn-warning:focus,.btn-warning.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(233,144,2,0.5);box-shadow:0 0 0 0.2rem rgba(233,144,2,0.5)}.btn-warning.disabled,.btn-warning:disabled{color:#fff;background-color:#E99002;border-color:#E99002}.btn-warning:not(:disabled):not(.disabled):active,.btn-warning:not(:disabled):not(.disabled).active,.show>.btn-warning.dropdown-toggle{color:#fff;background-color:#b67102;border-color:#aa6901}.btn-warning:not(:disabled):not(.disabled):active:focus,.btn-warning:not(:disabled):not(.disabled).active:focus,.show>.btn-warning.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(233,144,2,0.5);box-shadow:0 0 0 0.2rem rgba(233,144,2,0.5)}.btn-danger{color:#fff;background-color:#F04124;border-color:#F04124}.btn-danger:hover{color:#fff;background-color:#df2d0f;border-color:#d32a0e}.btn-danger:focus,.btn-danger.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(240,65,36,0.5);box-shadow:0 0 0 0.2rem rgba(240,65,36,0.5)}.btn-danger.disabled,.btn-danger:disabled{color:#fff;background-color:#F04124;border-color:#F04124}.btn-danger:not(:disabled):not(.disabled):active,.btn-danger:not(:disabled):not(.disabled).active,.show>.btn-danger.dropdown-toggle{color:#fff;background-color:#d32a0e;border-color:#c7280e}.btn-danger:not(:disabled):not(.disabled):active:focus,.btn-danger:not(:disabled):not(.disabled).active:focus,.show>.btn-danger.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(240,65,36,0.5);box-shadow:0 0 0 0.2rem rgba(240,65,36,0.5)}.btn-light{color:#222;background-color:#eee;border-color:#eee}.btn-light:hover{color:#222;background-color:#dbdbdb;border-color:#d5d4d4}.btn-light:focus,.btn-light.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(238,238,238,0.5);box-shadow:0 0 0 0.2rem rgba(238,238,238,0.5)}.btn-light.disabled,.btn-light:disabled{color:#222;background-color:#eee;border-color:#eee}.btn-light:not(:disabled):not(.disabled):active,.btn-light:not(:disabled):not(.disabled).active,.show>.btn-light.dropdown-toggle{color:#222;background-color:#d5d4d4;border-color:#cecece}.btn-light:not(:disabled):not(.disabled):active:focus,.btn-light:not(:disabled):not(.disabled).active:focus,.show>.btn-light.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(238,238,238,0.5);box-shadow:0 0 0 0.2rem rgba(238,238,238,0.5)}.btn-dark{color:#fff;background-color:#222;border-color:#222}.btn-dark:hover{color:#fff;background-color:#0f0f0f;border-color:#090808}.btn-dark:focus,.btn-dark.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(34,34,34,0.5);box-shadow:0 0 0 0.2rem rgba(34,34,34,0.5)}.btn-dark.disabled,.btn-dark:disabled{color:#fff;background-color:#222;border-color:#222}.btn-dark:not(:disabled):not(.disabled):active,.btn-dark:not(:disabled):not(.disabled).active,.show>.btn-dark.dropdown-toggle{color:#fff;background-color:#090808;border-color:#020202}.btn-dark:not(:disabled):not(.disabled):active:focus,.btn-dark:not(:disabled):not(.disabled).active:focus,.show>.btn-dark.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(34,34,34,0.5);box-shadow:0 0 0 0.2rem rgba(34,34,34,0.5)}.btn-outline-primary{color:#008cba;background-color:transparent;background-image:none;border-color:#008cba}.btn-outline-primary:hover{color:#fff;background-color:#008cba;border-color:#008cba}.btn-outline-primary:focus,.btn-outline-primary.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(0,140,186,0.5);box-shadow:0 0 0 0.2rem rgba(0,140,186,0.5)}.btn-outline-primary.disabled,.btn-outline-primary:disabled{color:#008cba;background-color:transparent}.btn-outline-primary:not(:disabled):not(.disabled):active,.btn-outline-primary:not(:disabled):not(.disabled).active,.show>.btn-outline-primary.dropdown-toggle{color:#fff;background-color:#008cba;border-color:#008cba}.btn-outline-primary:not(:disabled):not(.disabled):active:focus,.btn-outline-primary:not(:disabled):not(.disabled).active:focus,.show>.btn-outline-primary.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(0,140,186,0.5);box-shadow:0 0 0 0.2rem rgba(0,140,186,0.5)}.btn-outline-secondary{color:#eee;background-color:transparent;background-image:none;border-color:#eee}.btn-outline-secondary:hover{color:#222;background-color:#eee;border-color:#eee}.btn-outline-secondary:focus,.btn-outline-secondary.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(238,238,238,0.5);box-shadow:0 0 0 0.2rem rgba(238,238,238,0.5)}.btn-outline-secondary.disabled,.btn-outline-secondary:disabled{color:#eee;background-color:transparent}.btn-outline-secondary:not(:disabled):not(.disabled):active,.btn-outline-secondary:not(:disabled):not(.disabled).active,.show>.btn-outline-secondary.dropdown-toggle{color:#222;background-color:#eee;border-color:#eee}.btn-outline-secondary:not(:disabled):not(.disabled):active:focus,.btn-outline-secondary:not(:disabled):not(.disabled).active:focus,.show>.btn-outline-secondary.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(238,238,238,0.5);box-shadow:0 0 0 0.2rem rgba(238,238,238,0.5)}.btn-outline-success{color:#43ac6a;background-color:transparent;background-image:none;border-color:#43ac6a}.btn-outline-success:hover{color:#fff;background-color:#43ac6a;border-color:#43ac6a}.btn-outline-success:focus,.btn-outline-success.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(67,172,106,0.5);box-shadow:0 0 0 0.2rem rgba(67,172,106,0.5)}.btn-outline-success.disabled,.btn-outline-success:disabled{color:#43ac6a;background-color:transparent}.btn-outline-success:not(:disabled):not(.disabled):active,.btn-outline-success:not(:disabled):not(.disabled).active,.show>.btn-outline-success.dropdown-toggle{color:#fff;background-color:#43ac6a;border-color:#43ac6a}.btn-outline-success:not(:disabled):not(.disabled):active:focus,.btn-outline-success:not(:disabled):not(.disabled).active:focus,.show>.btn-outline-success.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(67,172,106,0.5);box-shadow:0 0 0 0.2rem rgba(67,172,106,0.5)}.btn-outline-info{color:#5bc0de;background-color:transparent;background-image:none;border-color:#5bc0de}.btn-outline-info:hover{color:#fff;background-color:#5bc0de;border-color:#5bc0de}.btn-outline-info:focus,.btn-outline-info.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(91,192,222,0.5);box-shadow:0 0 0 0.2rem rgba(91,192,222,0.5)}.btn-outline-info.disabled,.btn-outline-info:disabled{color:#5bc0de;background-color:transparent}.btn-outline-info:not(:disabled):not(.disabled):active,.btn-outline-info:not(:disabled):not(.disabled).active,.show>.btn-outline-info.dropdown-toggle{color:#fff;background-color:#5bc0de;border-color:#5bc0de}.btn-outline-info:not(:disabled):not(.disabled):active:focus,.btn-outline-info:not(:disabled):not(.disabled).active:focus,.show>.btn-outline-info.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(91,192,222,0.5);box-shadow:0 0 0 0.2rem rgba(91,192,222,0.5)}.btn-outline-warning{color:#E99002;background-color:transparent;background-image:none;border-color:#E99002}.btn-outline-warning:hover{color:#fff;background-color:#E99002;border-color:#E99002}.btn-outline-warning:focus,.btn-outline-warning.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(233,144,2,0.5);box-shadow:0 0 0 0.2rem rgba(233,144,2,0.5)}.btn-outline-warning.disabled,.btn-outline-warning:disabled{color:#E99002;background-color:transparent}.btn-outline-warning:not(:disabled):not(.disabled):active,.btn-outline-warning:not(:disabled):not(.disabled).active,.show>.btn-outline-warning.dropdown-toggle{color:#fff;background-color:#E99002;border-color:#E99002}.btn-outline-warning:not(:disabled):not(.disabled):active:focus,.btn-outline-warning:not(:disabled):not(.disabled).active:focus,.show>.btn-outline-warning.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(233,144,2,0.5);box-shadow:0 0 0 0.2rem rgba(233,144,2,0.5)}.btn-outline-danger{color:#F04124;background-color:transparent;background-image:none;border-color:#F04124}.btn-outline-danger:hover{color:#fff;background-color:#F04124;border-color:#F04124}.btn-outline-danger:focus,.btn-outline-danger.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(240,65,36,0.5);box-shadow:0 0 0 0.2rem rgba(240,65,36,0.5)}.btn-outline-danger.disabled,.btn-outline-danger:disabled{color:#F04124;background-color:transparent}.btn-outline-danger:not(:disabled):not(.disabled):active,.btn-outline-danger:not(:disabled):not(.disabled).active,.show>.btn-outline-danger.dropdown-toggle{color:#fff;background-color:#F04124;border-color:#F04124}.btn-outline-danger:not(:disabled):not(.disabled):active:focus,.btn-outline-danger:not(:disabled):not(.disabled).active:focus,.show>.btn-outline-danger.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(240,65,36,0.5);box-shadow:0 0 0 0.2rem rgba(240,65,36,0.5)}.btn-outline-light{color:#eee;background-color:transparent;background-image:none;border-color:#eee}.btn-outline-light:hover{color:#222;background-color:#eee;border-color:#eee}.btn-outline-light:focus,.btn-outline-light.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(238,238,238,0.5);box-shadow:0 0 0 0.2rem rgba(238,238,238,0.5)}.btn-outline-light.disabled,.btn-outline-light:disabled{color:#eee;background-color:transparent}.btn-outline-light:not(:disabled):not(.disabled):active,.btn-outline-light:not(:disabled):not(.disabled).active,.show>.btn-outline-light.dropdown-toggle{color:#222;background-color:#eee;border-color:#eee}.btn-outline-light:not(:disabled):not(.disabled):active:focus,.btn-outline-light:not(:disabled):not(.disabled).active:focus,.show>.btn-outline-light.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(238,238,238,0.5);box-shadow:0 0 0 0.2rem rgba(238,238,238,0.5)}.btn-outline-dark{color:#222;background-color:transparent;background-image:none;border-color:#222}.btn-outline-dark:hover{color:#fff;background-color:#222;border-color:#222}.btn-outline-dark:focus,.btn-outline-dark.focus{-webkit-box-shadow:0 0 0 0.2rem rgba(34,34,34,0.5);box-shadow:0 0 0 0.2rem rgba(34,34,34,0.5)}.btn-outline-dark.disabled,.btn-outline-dark:disabled{color:#222;background-color:transparent}.btn-outline-dark:not(:disabled):not(.disabled):active,.btn-outline-dark:not(:disabled):not(.disabled).active,.show>.btn-outline-dark.dropdown-toggle{color:#fff;background-color:#222;border-color:#222}.btn-outline-dark:not(:disabled):not(.disabled):active:focus,.btn-outline-dark:not(:disabled):not(.disabled).active:focus,.show>.btn-outline-dark.dropdown-toggle:focus{-webkit-box-shadow:0 0 0 0.2rem rgba(34,34,34,0.5);box-shadow:0 0 0 0.2rem rgba(34,34,34,0.5)}.btn-link{font-weight:400;color:#008cba;background-color:transparent}.btn-link:hover{color:#00526e;text-decoration:underline;background-color:transparent;border-color:transparent}.btn-link:focus,.btn-link.focus{text-decoration:underline;border-color:transparent;-webkit-box-shadow:none;box-shadow:none}.btn-link:disabled,.btn-link.disabled{color:#888}.btn-lg,.btn-group-lg>.btn{padding:0.5rem 1rem;font-size:1.171875rem;line-height:1.5;border-radius:0}.btn-sm,.btn-group-sm>.btn{padding:0.25rem 0.5rem;font-size:0.8203125rem;line-height:1.5;border-radius:0}.btn-block{display:block;width:100%}.btn-block+.btn-block{margin-top:0.5rem}input[type="submit"].btn-block,input[type="reset"].btn-block,input[type="button"].btn-block{width:100%}.fade{opacity:0;-webkit-transition:opacity 0.15s linear;transition:opacity 0.15s linear}.fade.show{opacity:1}.collapse{display:none}.collapse.show{display:block}tr.collapse.show{display:table-row}tbody.collapse.show{display:table-row-group}.collapsing{position:relative;height:0;overflow:hidden;-webkit-transition:height 0.35s ease;transition:height 0.35s ease}.dropup,.dropdown{position:relative}.dropdown-toggle::after{display:inline-block;width:0;height:0;margin-left:0.255em;vertical-align:0.255em;content:"";border-top:0.3em solid;border-right:0.3em solid transparent;border-bottom:0;border-left:0.3em solid transparent}.dropdown-toggle:empty::after{margin-left:0}.dropdown-menu{position:absolute;top:100%;left:0;z-index:1000;display:none;float:left;min-width:10rem;padding:0.5rem 0;margin:0.125rem 0 0;font-size:0.9375rem;color:#222;text-align:left;list-style:none;background-color:#fff;background-clip:padding-box;border:1px solid rgba(0,0,0,0.1);border-radius:0}.dropup .dropdown-menu{margin-top:0;margin-bottom:0.125rem}.dropup .dropdown-toggle::after{display:inline-block;width:0;height:0;margin-left:0.255em;vertical-align:0.255em;content:"";border-top:0;border-right:0.3em solid transparent;border-bottom:0.3em solid;border-left:0.3em solid transparent}.dropup .dropdown-toggle:empty::after{margin-left:0}.dropright .dropdown-menu{margin-top:0;margin-left:0.125rem}.dropright .dropdown-toggle::after{display:inline-block;width:0;height:0;margin-left:0.255em;vertical-align:0.255em;content:"";border-top:0.3em solid transparent;border-bottom:0.3em solid transparent;border-left:0.3em solid}.dropright .dropdown-toggle:empty::after{margin-left:0}.dropright .dropdown-toggle::after{vertical-align:0}.dropleft .dropdown-menu{margin-top:0;margin-right:0.125rem}.dropleft .dropdown-toggle::after{display:inline-block;width:0;height:0;margin-left:0.255em;vertical-align:0.255em;content:""}.dropleft .dropdown-toggle::after{display:none}.dropleft .dropdown-toggle::before{display:inline-block;width:0;height:0;margin-right:0.255em;vertical-align:0.255em;content:"";border-top:0.3em solid transparent;border-right:0.3em solid;border-bottom:0.3em solid transparent}.dropleft .dropdown-toggle:empty::after{margin-left:0}.dropleft .dropdown-toggle::before{vertical-align:0}.dropdown-divider{height:0;margin:0.5rem 0;overflow:hidden;border-top:1px solid rgba(0,0,0,0.1)}.dropdown-item{display:block;width:100%;padding:0.25rem 1.5rem;clear:both;font-weight:400;color:#222;text-align:inherit;white-space:nowrap;background-color:transparent;border:0}.dropdown-item:hover,.dropdown-item:focus{color:#151515;text-decoration:none;background-color:#f8f9fa}.dropdown-item.active,.dropdown-item:active{color:#fff;text-decoration:none;background-color:#008cba}.dropdown-item.disabled,.dropdown-item:disabled{color:#888;background-color:transparent}.dropdown-menu.show{display:block}.dropdown-header{display:block;padding:0.5rem 1.5rem;margin-bottom:0;font-size:0.8203125rem;color:#888;white-space:nowrap}.btn-group,.btn-group-vertical{position:relative;display:-webkit-inline-box;display:-ms-inline-flexbox;display:inline-flex;vertical-align:middle}.btn-group>.btn,.btn-group-vertical>.btn{position:relative;-webkit-box-flex:0;-ms-flex:0 1 auto;flex:0 1 auto}.btn-group>.btn:hover,.btn-group-vertical>.btn:hover{z-index:1}.btn-group>.btn:focus,.btn-group>.btn:active,.btn-group>.btn.active,.btn-group-vertical>.btn:focus,.btn-group-vertical>.btn:active,.btn-group-vertical>.btn.active{z-index:1}.btn-group .btn+.btn,.btn-group .btn+.btn-group,.btn-group .btn-group+.btn,.btn-group .btn-group+.btn-group,.btn-group-vertical .btn+.btn,.btn-group-vertical .btn+.btn-group,.btn-group-vertical .btn-group+.btn,.btn-group-vertical .btn-group+.btn-group{margin-left:-1px}.btn-toolbar{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-pack:start;-ms-flex-pack:start;justify-content:flex-start}.btn-toolbar .input-group{width:auto}.btn-group>.btn:first-child{margin-left:0}.btn-group>.btn:not(:last-child):not(.dropdown-toggle),.btn-group>.btn-group:not(:last-child)>.btn{border-top-right-radius:0;border-bottom-right-radius:0}.btn-group>.btn:not(:first-child),.btn-group>.btn-group:not(:first-child)>.btn{border-top-left-radius:0;border-bottom-left-radius:0}.dropdown-toggle-split{padding-right:0.75rem;padding-left:0.75rem}.dropdown-toggle-split::after{margin-left:0}.btn-sm+.dropdown-toggle-split,.btn-group-sm>.btn+.dropdown-toggle-split{padding-right:0.375rem;padding-left:0.375rem}.btn-lg+.dropdown-toggle-split,.btn-group-lg>.btn+.dropdown-toggle-split{padding-right:0.75rem;padding-left:0.75rem}.btn-group-vertical{-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center}.btn-group-vertical .btn,.btn-group-vertical .btn-group{width:100%}.btn-group-vertical>.btn+.btn,.btn-group-vertical>.btn+.btn-group,.btn-group-vertical>.btn-group+.btn,.btn-group-vertical>.btn-group+.btn-group{margin-top:-1px;margin-left:0}.btn-group-vertical>.btn:not(:last-child):not(.dropdown-toggle),.btn-group-vertical>.btn-group:not(:last-child)>.btn{border-bottom-right-radius:0;border-bottom-left-radius:0}.btn-group-vertical>.btn:not(:first-child),.btn-group-vertical>.btn-group:not(:first-child)>.btn{border-top-left-radius:0;border-top-right-radius:0}.btn-group-toggle>.btn,.btn-group-toggle>.btn-group>.btn{margin-bottom:0}.btn-group-toggle>.btn input[type="radio"],.btn-group-toggle>.btn input[type="checkbox"],.btn-group-toggle>.btn-group>.btn input[type="radio"],.btn-group-toggle>.btn-group>.btn input[type="checkbox"]{position:absolute;clip:rect(0, 0, 0, 0);pointer-events:none}.input-group{position:relative;display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-align:stretch;-ms-flex-align:stretch;align-items:stretch;width:100%}.input-group>.form-control,.input-group>.custom-select,.input-group>.custom-file{position:relative;-webkit-box-flex:1;-ms-flex:1 1 auto;flex:1 1 auto;width:1%;margin-bottom:0}.input-group>.form-control:focus,.input-group>.custom-select:focus,.input-group>.custom-file:focus{z-index:3}.input-group>.form-control+.form-control,.input-group>.form-control+.custom-select,.input-group>.form-control+.custom-file,.input-group>.custom-select+.form-control,.input-group>.custom-select+.custom-select,.input-group>.custom-select+.custom-file,.input-group>.custom-file+.form-control,.input-group>.custom-file+.custom-select,.input-group>.custom-file+.custom-file{margin-left:-1px}.input-group>.form-control:not(:last-child),.input-group>.custom-select:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0}.input-group>.form-control:not(:first-child),.input-group>.custom-select:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.input-group>.custom-file{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.input-group>.custom-file:not(:last-child) .custom-file-label,.input-group>.custom-file:not(:last-child) .custom-file-label::before{border-top-right-radius:0;border-bottom-right-radius:0}.input-group>.custom-file:not(:first-child) .custom-file-label,.input-group>.custom-file:not(:first-child) .custom-file-label::before{border-top-left-radius:0;border-bottom-left-radius:0}.input-group-prepend,.input-group-append{display:-webkit-box;display:-ms-flexbox;display:flex}.input-group-prepend .btn,.input-group-append .btn{position:relative;z-index:2}.input-group-prepend .btn+.btn,.input-group-prepend .btn+.input-group-text,.input-group-prepend .input-group-text+.input-group-text,.input-group-prepend .input-group-text+.btn,.input-group-append .btn+.btn,.input-group-append .btn+.input-group-text,.input-group-append .input-group-text+.input-group-text,.input-group-append .input-group-text+.btn{margin-left:-1px}.input-group-prepend{margin-right:-1px}.input-group-append{margin-left:-1px}.input-group-text{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;padding:0.375rem 1rem;margin-bottom:0;font-size:0.9375rem;font-weight:400;line-height:1.5;color:#495057;text-align:center;white-space:nowrap;background-color:#eee;border:1px solid #ccc;border-radius:0}.input-group-text input[type="radio"],.input-group-text input[type="checkbox"]{margin-top:0}.input-group>.input-group-prepend>.btn,.input-group>.input-group-prepend>.input-group-text,.input-group>.input-group-append:not(:last-child)>.btn,.input-group>.input-group-append:not(:last-child)>.input-group-text,.input-group>.input-group-append:last-child>.btn:not(:last-child):not(.dropdown-toggle),.input-group>.input-group-append:last-child>.input-group-text:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0}.input-group>.input-group-append>.btn,.input-group>.input-group-append>.input-group-text,.input-group>.input-group-prepend:not(:first-child)>.btn,.input-group>.input-group-prepend:not(:first-child)>.input-group-text,.input-group>.input-group-prepend:first-child>.btn:not(:first-child),.input-group>.input-group-prepend:first-child>.input-group-text:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.custom-control{position:relative;display:block;min-height:1.5rem;padding-left:1.5rem}.custom-control-inline{display:-webkit-inline-box;display:-ms-inline-flexbox;display:inline-flex;margin-right:1rem}.custom-control-input{position:absolute;z-index:-1;opacity:0}.custom-control-input:checked ~ .custom-control-label::before{color:#fff;background-color:#008cba}.custom-control-input:focus ~ .custom-control-label::before{-webkit-box-shadow:0 0 0 1px #fff,0 0 0 0.2rem rgba(0,140,186,0.25);box-shadow:0 0 0 1px #fff,0 0 0 0.2rem rgba(0,140,186,0.25)}.custom-control-input:active ~ .custom-control-label::before{color:#fff;background-color:#6edbff}.custom-control-input:disabled ~ .custom-control-label{color:#888}.custom-control-input:disabled ~ .custom-control-label::before{background-color:#eee}.custom-control-label{margin-bottom:0}.custom-control-label::before{position:absolute;top:0.25rem;left:0;display:block;width:1rem;height:1rem;pointer-events:none;content:"";-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;background-color:#dee2e6}.custom-control-label::after{position:absolute;top:0.25rem;left:0;display:block;width:1rem;height:1rem;content:"";background-repeat:no-repeat;background-position:center center;background-size:50% 50%}.custom-checkbox .custom-control-label::before{border-radius:0}.custom-checkbox .custom-control-input:checked ~ .custom-control-label::before{background-color:#008cba}.custom-checkbox .custom-control-input:checked ~ .custom-control-label::after{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3E%3Cpath fill='%23fff' d='M6.564.75l-3.59 3.612-1.538-1.55L0 4.26 2.974 7.25 8 2.193z'/%3E%3C/svg%3E")}.custom-checkbox .custom-control-input:indeterminate ~ .custom-control-label::before{background-color:#008cba}.custom-checkbox .custom-control-input:indeterminate ~ .custom-control-label::after{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 4'%3E%3Cpath stroke='%23fff' d='M0 2h4'/%3E%3C/svg%3E")}.custom-checkbox .custom-control-input:disabled:checked ~ .custom-control-label::before{background-color:rgba(0,140,186,0.5)}.custom-checkbox .custom-control-input:disabled:indeterminate ~ .custom-control-label::before{background-color:rgba(0,140,186,0.5)}.custom-radio .custom-control-label::before{border-radius:50%}.custom-radio .custom-control-input:checked ~ .custom-control-label::before{background-color:#008cba}.custom-radio .custom-control-input:checked ~ .custom-control-label::after{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3E%3Ccircle r='3' fill='%23fff'/%3E%3C/svg%3E")}.custom-radio .custom-control-input:disabled:checked ~ .custom-control-label::before{background-color:rgba(0,140,186,0.5)}.custom-select{display:inline-block;width:100%;height:calc(2.15625rem + 2px);padding:0.375rem 1.75rem 0.375rem 0.75rem;line-height:1.5;color:#495057;vertical-align:middle;background:#fff url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 5'%3E%3Cpath fill='%23333' d='M2 0L0 2h4zm0 5L0 3h4z'/%3E%3C/svg%3E") no-repeat right 0.75rem center;background-size:8px 10px;border:1px solid #ccc;border-radius:0;-webkit-appearance:none;-moz-appearance:none;appearance:none}.custom-select:focus{border-color:#3bceff;outline:0;-webkit-box-shadow:inset 0 1px 2px rgba(0,0,0,0.075),0 0 5px rgba(59,206,255,0.5);box-shadow:inset 0 1px 2px rgba(0,0,0,0.075),0 0 5px rgba(59,206,255,0.5)}.custom-select:focus::-ms-value{color:#495057;background-color:#fff}.custom-select[multiple],.custom-select[size]:not([size="1"]){height:auto;padding-right:0.75rem;background-image:none}.custom-select:disabled{color:#888;background-color:#eee}.custom-select::-ms-expand{opacity:0}.custom-select-sm{height:calc(1.73046875rem + 2px);padding-top:0.375rem;padding-bottom:0.375rem;font-size:75%}.custom-select-lg{height:calc(2.7578125rem + 2px);padding-top:0.375rem;padding-bottom:0.375rem;font-size:125%}.custom-file{position:relative;display:inline-block;width:100%;height:calc(2.15625rem + 2px);margin-bottom:0}.custom-file-input{position:relative;z-index:2;width:100%;height:calc(2.15625rem + 2px);margin:0;opacity:0}.custom-file-input:focus ~ .custom-file-control{border-color:#3bceff;-webkit-box-shadow:0 0 0 0.2rem rgba(0,140,186,0.25);box-shadow:0 0 0 0.2rem rgba(0,140,186,0.25)}.custom-file-input:focus ~ .custom-file-control::before{border-color:#3bceff}.custom-file-input:lang(en) ~ .custom-file-label::after{content:"Browse"}.custom-file-label{position:absolute;top:0;right:0;left:0;z-index:1;height:calc(2.15625rem + 2px);padding:0.375rem 1rem;line-height:1.5;color:#495057;background-color:#fff;border:1px solid #ccc;border-radius:0}.custom-file-label::after{position:absolute;top:0;right:0;bottom:0;z-index:3;display:block;height:calc(calc(2.15625rem + 2px) - 1px * 2);padding:0.375rem 1rem;line-height:1.5;color:#495057;content:"Browse";background-color:#eee;border-left:1px solid #ccc;border-radius:0 0 0 0}.nav{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;padding-left:0;margin-bottom:0;list-style:none}.nav-link{display:block;padding:0.5rem 1rem}.nav-link:hover,.nav-link:focus{text-decoration:none}.nav-link.disabled{color:#ccc}.nav-tabs{border-bottom:1px solid rgba(0,0,0,0.1)}.nav-tabs .nav-item{margin-bottom:-1px}.nav-tabs .nav-link{border:1px solid transparent;border-top-left-radius:0;border-top-right-radius:0}.nav-tabs .nav-link:hover,.nav-tabs .nav-link:focus{border-color:rgba(0,0,0,0.1)}.nav-tabs .nav-link.disabled{color:#ccc;background-color:transparent;border-color:transparent}.nav-tabs .nav-link.active,.nav-tabs .nav-item.show .nav-link{color:#495057;background-color:#fff;border-color:rgba(0,0,0,0.1)}.nav-tabs .dropdown-menu{margin-top:-1px;border-top-left-radius:0;border-top-right-radius:0}.nav-pills .nav-link{border-radius:0}.nav-pills .nav-link.active,.nav-pills .show>.nav-link{color:#fff;background-color:#008cba}.nav-fill .nav-item{-webkit-box-flex:1;-ms-flex:1 1 auto;flex:1 1 auto;text-align:center}.nav-justified .nav-item{-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;text-align:center}.tab-content>.tab-pane{display:none}.tab-content>.active{display:block}.navbar{position:relative;display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;padding:0.5rem 1rem}.navbar>.container,.navbar>.container-fluid{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between}.navbar-brand{display:inline-block;padding-top:0.32421875rem;padding-bottom:0.32421875rem;margin-right:1rem;font-size:1.171875rem;line-height:inherit;white-space:nowrap}.navbar-brand:hover,.navbar-brand:focus{text-decoration:none}.navbar-nav{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;padding-left:0;margin-bottom:0;list-style:none}.navbar-nav .nav-link{padding-right:0;padding-left:0}.navbar-nav .dropdown-menu{position:static;float:none}.navbar-text{display:inline-block;padding-top:0.5rem;padding-bottom:0.5rem}.navbar-collapse{-ms-flex-preferred-size:100%;flex-basis:100%;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.navbar-toggler{padding:0.25rem 0.75rem;font-size:1.171875rem;line-height:1;background-color:transparent;border:1px solid transparent;border-radius:0}.navbar-toggler:hover,.navbar-toggler:focus{text-decoration:none}.navbar-toggler:not(:disabled):not(.disabled){cursor:pointer}.navbar-toggler-icon{display:inline-block;width:1.5em;height:1.5em;vertical-align:middle;content:"";background:no-repeat center center;background-size:100% 100%}@media (max-width: 575.98px){.navbar-expand-sm>.container,.navbar-expand-sm>.container-fluid{padding-right:0;padding-left:0}}@media (min-width: 576px){.navbar-expand-sm{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row nowrap;flex-flow:row nowrap;-webkit-box-pack:start;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand-sm .navbar-nav{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.navbar-expand-sm .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-sm .navbar-nav .dropdown-menu-right{right:0;left:auto}.navbar-expand-sm .navbar-nav .nav-link{padding-right:0.5rem;padding-left:0.5rem}.navbar-expand-sm>.container,.navbar-expand-sm>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand-sm .navbar-collapse{display:-webkit-box !important;display:-ms-flexbox !important;display:flex !important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand-sm .navbar-toggler{display:none}.navbar-expand-sm .dropup .dropdown-menu{top:auto;bottom:100%}}@media (max-width: 767.98px){.navbar-expand-md>.container,.navbar-expand-md>.container-fluid{padding-right:0;padding-left:0}}@media (min-width: 768px){.navbar-expand-md{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row nowrap;flex-flow:row nowrap;-webkit-box-pack:start;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand-md .navbar-nav{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.navbar-expand-md .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-md .navbar-nav .dropdown-menu-right{right:0;left:auto}.navbar-expand-md .navbar-nav .nav-link{padding-right:0.5rem;padding-left:0.5rem}.navbar-expand-md>.container,.navbar-expand-md>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand-md .navbar-collapse{display:-webkit-box !important;display:-ms-flexbox !important;display:flex !important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand-md .navbar-toggler{display:none}.navbar-expand-md .dropup .dropdown-menu{top:auto;bottom:100%}}@media (max-width: 991.98px){.navbar-expand-lg>.container,.navbar-expand-lg>.container-fluid{padding-right:0;padding-left:0}}@media (min-width: 992px){.navbar-expand-lg{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row nowrap;flex-flow:row nowrap;-webkit-box-pack:start;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand-lg .navbar-nav{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.navbar-expand-lg .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-lg .navbar-nav .dropdown-menu-right{right:0;left:auto}.navbar-expand-lg .navbar-nav .nav-link{padding-right:0.5rem;padding-left:0.5rem}.navbar-expand-lg>.container,.navbar-expand-lg>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand-lg .navbar-collapse{display:-webkit-box !important;display:-ms-flexbox !important;display:flex !important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand-lg .navbar-toggler{display:none}.navbar-expand-lg .dropup .dropdown-menu{top:auto;bottom:100%}}@media (max-width: 1199.98px){.navbar-expand-xl>.container,.navbar-expand-xl>.container-fluid{padding-right:0;padding-left:0}}@media (min-width: 1200px){.navbar-expand-xl{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row nowrap;flex-flow:row nowrap;-webkit-box-pack:start;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand-xl .navbar-nav{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.navbar-expand-xl .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-xl .navbar-nav .dropdown-menu-right{right:0;left:auto}.navbar-expand-xl .navbar-nav .nav-link{padding-right:0.5rem;padding-left:0.5rem}.navbar-expand-xl>.container,.navbar-expand-xl>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand-xl .navbar-collapse{display:-webkit-box !important;display:-ms-flexbox !important;display:flex !important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand-xl .navbar-toggler{display:none}.navbar-expand-xl .dropup .dropdown-menu{top:auto;bottom:100%}}.navbar-expand{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row nowrap;flex-flow:row nowrap;-webkit-box-pack:start;-ms-flex-pack:start;justify-content:flex-start}.navbar-expand>.container,.navbar-expand>.container-fluid{padding-right:0;padding-left:0}.navbar-expand .navbar-nav{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.navbar-expand .navbar-nav .dropdown-menu{position:absolute}.navbar-expand .navbar-nav .dropdown-menu-right{right:0;left:auto}.navbar-expand .navbar-nav .nav-link{padding-right:0.5rem;padding-left:0.5rem}.navbar-expand>.container,.navbar-expand>.container-fluid{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.navbar-expand .navbar-collapse{display:-webkit-box !important;display:-ms-flexbox !important;display:flex !important;-ms-flex-preferred-size:auto;flex-basis:auto}.navbar-expand .navbar-toggler{display:none}.navbar-expand .dropup .dropdown-menu{top:auto;bottom:100%}.navbar-light .navbar-brand{color:rgba(0,0,0,0.9)}.navbar-light .navbar-brand:hover,.navbar-light .navbar-brand:focus{color:rgba(0,0,0,0.9)}.navbar-light .navbar-nav .nav-link{color:rgba(0,0,0,0.5)}.navbar-light .navbar-nav .nav-link:hover,.navbar-light .navbar-nav .nav-link:focus{color:rgba(0,0,0,0.7)}.navbar-light .navbar-nav .nav-link.disabled{color:rgba(0,0,0,0.3)}.navbar-light .navbar-nav .show>.nav-link,.navbar-light .navbar-nav .active>.nav-link,.navbar-light .navbar-nav .nav-link.show,.navbar-light .navbar-nav .nav-link.active{color:rgba(0,0,0,0.9)}.navbar-light .navbar-toggler{color:rgba(0,0,0,0.5);border-color:rgba(0,0,0,0.1)}.navbar-light .navbar-toggler-icon{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(0, 0, 0, 0.5)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E")}.navbar-light .navbar-text{color:rgba(0,0,0,0.5)}.navbar-light .navbar-text a{color:rgba(0,0,0,0.9)}.navbar-light .navbar-text a:hover,.navbar-light .navbar-text a:focus{color:rgba(0,0,0,0.9)}.navbar-dark .navbar-brand{color:#fff}.navbar-dark .navbar-brand:hover,.navbar-dark .navbar-brand:focus{color:#fff}.navbar-dark .navbar-nav .nav-link{color:rgba(255,255,255,0.7)}.navbar-dark .navbar-nav .nav-link:hover,.navbar-dark .navbar-nav .nav-link:focus{color:#fff}.navbar-dark .navbar-nav .nav-link.disabled{color:rgba(255,255,255,0.25)}.navbar-dark .navbar-nav .show>.nav-link,.navbar-dark .navbar-nav .active>.nav-link,.navbar-dark .navbar-nav .nav-link.show,.navbar-dark .navbar-nav .nav-link.active{color:#fff}.navbar-dark .navbar-toggler{color:rgba(255,255,255,0.7);border-color:rgba(255,255,255,0.1)}.navbar-dark .navbar-toggler-icon{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(255, 255, 255, 0.7)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E")}.navbar-dark .navbar-text{color:rgba(255,255,255,0.7)}.navbar-dark .navbar-text a{color:#fff}.navbar-dark .navbar-text a:hover,.navbar-dark .navbar-text a:focus{color:#fff}.card{position:relative;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;min-width:0;word-wrap:break-word;background-color:#fff;background-clip:border-box;border:1px solid rgba(0,0,0,0.125);border-radius:0}.card>hr{margin-right:0;margin-left:0}.card>.list-group:first-child .list-group-item:first-child{border-top-left-radius:0;border-top-right-radius:0}.card>.list-group:last-child .list-group-item:last-child{border-bottom-right-radius:0;border-bottom-left-radius:0}.card-body{-webkit-box-flex:1;-ms-flex:1 1 auto;flex:1 1 auto;padding:1.25rem}.card-title{margin-bottom:0.75rem}.card-subtitle{margin-top:-0.375rem;margin-bottom:0}.card-text:last-child{margin-bottom:0}.card-link:hover{text-decoration:none}.card-link+.card-link{margin-left:1.25rem}.card-header{padding:0.75rem 1.25rem;margin-bottom:0;background-color:rgba(0,0,0,0.03);border-bottom:1px solid rgba(0,0,0,0.125)}.card-header:first-child{border-radius:calc(0 - 1px) calc(0 - 1px) 0 0}.card-header+.list-group .list-group-item:first-child{border-top:0}.card-footer{padding:0.75rem 1.25rem;background-color:rgba(0,0,0,0.03);border-top:1px solid rgba(0,0,0,0.125)}.card-footer:last-child{border-radius:0 0 calc(0 - 1px) calc(0 - 1px)}.card-header-tabs{margin-right:-0.625rem;margin-bottom:-0.75rem;margin-left:-0.625rem;border-bottom:0}.card-header-pills{margin-right:-0.625rem;margin-left:-0.625rem}.card-img-overlay{position:absolute;top:0;right:0;bottom:0;left:0;padding:1.25rem}.card-img{width:100%;border-radius:calc(0 - 1px)}.card-img-top{width:100%;border-top-left-radius:calc(0 - 1px);border-top-right-radius:calc(0 - 1px)}.card-img-bottom{width:100%;border-bottom-right-radius:calc(0 - 1px);border-bottom-left-radius:calc(0 - 1px)}.card-deck{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.card-deck .card{margin-bottom:15px}@media (min-width: 576px){.card-deck{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row wrap;flex-flow:row wrap;margin-right:-15px;margin-left:-15px}.card-deck .card{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:1;-ms-flex:1 0 0%;flex:1 0 0%;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;margin-right:15px;margin-bottom:0;margin-left:15px}}.card-group{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.card-group>.card{margin-bottom:15px}@media (min-width: 576px){.card-group{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-flow:row wrap;flex-flow:row wrap}.card-group>.card{-webkit-box-flex:1;-ms-flex:1 0 0%;flex:1 0 0%;margin-bottom:0}.card-group>.card+.card{margin-left:0;border-left:0}.card-group>.card:first-child{border-top-right-radius:0;border-bottom-right-radius:0}.card-group>.card:first-child .card-img-top,.card-group>.card:first-child .card-header{border-top-right-radius:0}.card-group>.card:first-child .card-img-bottom,.card-group>.card:first-child .card-footer{border-bottom-right-radius:0}.card-group>.card:last-child{border-top-left-radius:0;border-bottom-left-radius:0}.card-group>.card:last-child .card-img-top,.card-group>.card:last-child .card-header{border-top-left-radius:0}.card-group>.card:last-child .card-img-bottom,.card-group>.card:last-child .card-footer{border-bottom-left-radius:0}.card-group>.card:only-child{border-radius:0}.card-group>.card:only-child .card-img-top,.card-group>.card:only-child .card-header{border-top-left-radius:0;border-top-right-radius:0}.card-group>.card:only-child .card-img-bottom,.card-group>.card:only-child .card-footer{border-bottom-right-radius:0;border-bottom-left-radius:0}.card-group>.card:not(:first-child):not(:last-child):not(:only-child){border-radius:0}.card-group>.card:not(:first-child):not(:last-child):not(:only-child) .card-img-top,.card-group>.card:not(:first-child):not(:last-child):not(:only-child) .card-img-bottom,.card-group>.card:not(:first-child):not(:last-child):not(:only-child) .card-header,.card-group>.card:not(:first-child):not(:last-child):not(:only-child) .card-footer{border-radius:0}}.card-columns .card{margin-bottom:0.75rem}@media (min-width: 576px){.card-columns{-webkit-column-count:3;column-count:3;-webkit-column-gap:1.25rem;column-gap:1.25rem}.card-columns .card{display:inline-block;width:100%}}.breadcrumb{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;padding:0.75rem 1rem;margin-bottom:1rem;list-style:none;background-color:#eee;border-radius:0}.breadcrumb-item+.breadcrumb-item::before{display:inline-block;padding-right:0.5rem;padding-left:0.5rem;color:#888;content:"/"}.breadcrumb-item+.breadcrumb-item:hover::before{text-decoration:underline}.breadcrumb-item+.breadcrumb-item:hover::before{text-decoration:none}.breadcrumb-item.active{color:#888}.pagination{display:-webkit-box;display:-ms-flexbox;display:flex;padding-left:0;list-style:none;border-radius:0}.page-link{position:relative;display:block;padding:0.5rem 0.75rem;margin-left:-1px;line-height:1.25;color:#888;background-color:#fff;border:1px solid rgba(0,0,0,0.1)}.page-link:hover{color:#00526e;text-decoration:none;background-color:#eee;border-color:#dee2e6}.page-link:focus{z-index:2;outline:0;-webkit-box-shadow:0 0 0 0.2rem rgba(0,140,186,0.25);box-shadow:0 0 0 0.2rem rgba(0,140,186,0.25)}.page-link:not(:disabled):not(.disabled){cursor:pointer}.page-item:first-child .page-link{margin-left:0;border-top-left-radius:0;border-bottom-left-radius:0}.page-item:last-child .page-link{border-top-right-radius:0;border-bottom-right-radius:0}.page-item.active .page-link{z-index:1;color:#fff;background-color:#008cba;border-color:#0079a1}.page-item.disabled .page-link{color:#eee;pointer-events:none;cursor:auto;background-color:#fff;border-color:#dee2e6}.pagination-lg .page-link{padding:0.75rem 1.5rem;font-size:1.171875rem;line-height:1.5}.pagination-lg .page-item:first-child .page-link{border-top-left-radius:0;border-bottom-left-radius:0}.pagination-lg .page-item:last-child .page-link{border-top-right-radius:0;border-bottom-right-radius:0}.pagination-sm .page-link{padding:0.25rem 0.5rem;font-size:0.8203125rem;line-height:1.5}.pagination-sm .page-item:first-child .page-link{border-top-left-radius:0;border-bottom-left-radius:0}.pagination-sm .page-item:last-child .page-link{border-top-right-radius:0;border-bottom-right-radius:0}.badge{display:inline-block;padding:0.25em 1rem;font-size:75%;font-weight:300;line-height:1;text-align:center;white-space:nowrap;vertical-align:baseline;border-radius:0}.badge:empty{display:none}.btn .badge{position:relative;top:-1px}.badge-pill{padding-right:0.6em;padding-left:0.6em;border-radius:10rem}.badge-primary{color:#fff;background-color:#008cba}.badge-primary[href]:hover,.badge-primary[href]:focus{color:#fff;text-decoration:none;background-color:#006687}.badge-secondary{color:#222;background-color:#eee}.badge-secondary[href]:hover,.badge-secondary[href]:focus{color:#222;text-decoration:none;background-color:#d5d4d4}.badge-success{color:#fff;background-color:#43ac6a}.badge-success[href]:hover,.badge-success[href]:focus{color:#fff;text-decoration:none;background-color:#358753}.badge-info{color:#fff;background-color:#5bc0de}.badge-info[href]:hover,.badge-info[href]:focus{color:#fff;text-decoration:none;background-color:#31b0d5}.badge-warning{color:#fff;background-color:#E99002}.badge-warning[href]:hover,.badge-warning[href]:focus{color:#fff;text-decoration:none;background-color:#b67102}.badge-danger{color:#fff;background-color:#F04124}.badge-danger[href]:hover,.badge-danger[href]:focus{color:#fff;text-decoration:none;background-color:#d32a0e}.badge-light{color:#222;background-color:#eee}.badge-light[href]:hover,.badge-light[href]:focus{color:#222;text-decoration:none;background-color:#d5d4d4}.badge-dark{color:#fff;background-color:#222}.badge-dark[href]:hover,.badge-dark[href]:focus{color:#fff;text-decoration:none;background-color:#090808}.jumbotron{padding:4rem 2rem;margin-bottom:4rem;background-color:#eee;border-radius:0}@media (min-width: 576px){.jumbotron{padding:8rem 4rem}}.jumbotron-fluid{padding-right:0;padding-left:0;border-radius:0}.alert{position:relative;padding:0.75rem 1.25rem;margin-bottom:1rem;border:1px solid transparent;border-radius:0}.alert-heading{color:inherit}.alert-link{font-weight:700}.alert-dismissible{padding-right:3.90625rem}.alert-dismissible .close{position:absolute;top:0;right:0;padding:0.75rem 1.25rem;color:inherit}.alert-primary{color:#004961;background-color:#cce8f1;border-color:#b8dfec}.alert-primary hr{border-top-color:#a4d6e7}.alert-primary .alert-link{color:#00232e}.alert-secondary{color:#7c7c7c;background-color:#fcfcfc;border-color:#fafafa}.alert-secondary hr{border-top-color:#ededed}.alert-secondary .alert-link{color:#636262}.alert-success{color:#235937;background-color:#d9eee1;border-color:#cae8d5}.alert-success hr{border-top-color:#b8e0c7}.alert-success .alert-link{color:#153420}.alert-info{color:#2f6473;background-color:#def2f8;border-color:#d1edf6}.alert-info hr{border-top-color:#bce5f2}.alert-info .alert-link{color:#20454f}.alert-warning{color:#794b01;background-color:#fbe9cc;border-color:#f9e0b8}.alert-warning hr{border-top-color:#f7d6a0}.alert-warning .alert-link{color:#462c01}.alert-danger{color:#7d2213;background-color:#fcd9d3;border-color:#fbcac2}.alert-danger hr{border-top-color:#f9b5aa}.alert-danger .alert-link{color:#51160c}.alert-light{color:#7c7c7c;background-color:#fcfcfc;border-color:#fafafa}.alert-light hr{border-top-color:#ededed}.alert-light .alert-link{color:#636262}.alert-dark{color:#121212;background-color:lightgray;border-color:#c1c1c1}.alert-dark hr{border-top-color:#b4b4b4}.alert-dark .alert-link{color:black}@-webkit-keyframes progress-bar-stripes{from{background-position:1rem 0}to{background-position:0 0}}@keyframes progress-bar-stripes{from{background-position:1rem 0}to{background-position:0 0}}.progress{display:-webkit-box;display:-ms-flexbox;display:flex;height:1rem;overflow:hidden;font-size:0.703125rem;background-color:#f6f6f6;border-radius:0}.progress-bar{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;color:#008cba;text-align:center;background-color:#008cba;-webkit-transition:width 0.6s ease;transition:width 0.6s ease}.progress-bar-striped{background-image:linear-gradient(45deg, rgba(255,255,255,0.15) 25%, transparent 25%, transparent 50%, rgba(255,255,255,0.15) 50%, rgba(255,255,255,0.15) 75%, transparent 75%, transparent);background-size:1rem 1rem}.progress-bar-animated{-webkit-animation:progress-bar-stripes 1s linear infinite;animation:progress-bar-stripes 1s linear infinite}.media{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start}.media-body{-webkit-box-flex:1;-ms-flex:1;flex:1}.list-group{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;padding-left:0;margin-bottom:0}.list-group-item-action{width:100%;color:#495057;text-align:inherit}.list-group-item-action:hover,.list-group-item-action:focus{color:#495057;text-decoration:none;background-color:#f8f9fa}.list-group-item-action:active{color:#222;background-color:#eee}.list-group-item{position:relative;display:block;padding:0.75rem 1.25rem;margin-bottom:-1px;background-color:#fff;border:1px solid rgba(0,0,0,0.125)}.list-group-item:first-child{border-top-left-radius:0;border-top-right-radius:0}.list-group-item:last-child{margin-bottom:0;border-bottom-right-radius:0;border-bottom-left-radius:0}.list-group-item:hover,.list-group-item:focus{z-index:1;text-decoration:none}.list-group-item.disabled,.list-group-item:disabled{color:#888;background-color:#eee}.list-group-item.active{z-index:2;color:#fff;background-color:#008cba;border-color:#008cba}.list-group-flush .list-group-item{border-right:0;border-left:0;border-radius:0}.list-group-flush:first-child .list-group-item:first-child{border-top:0}.list-group-flush:last-child .list-group-item:last-child{border-bottom:0}.list-group-item-primary{color:#004961;background-color:#b8dfec}.list-group-item-primary.list-group-item-action:hover,.list-group-item-primary.list-group-item-action:focus{color:#004961;background-color:#a4d6e7}.list-group-item-primary.list-group-item-action.active{color:#fff;background-color:#004961;border-color:#004961}.list-group-item-secondary{color:#7c7c7c;background-color:#fafafa}.list-group-item-secondary.list-group-item-action:hover,.list-group-item-secondary.list-group-item-action:focus{color:#7c7c7c;background-color:#ededed}.list-group-item-secondary.list-group-item-action.active{color:#fff;background-color:#7c7c7c;border-color:#7c7c7c}.list-group-item-success{color:#235937;background-color:#cae8d5}.list-group-item-success.list-group-item-action:hover,.list-group-item-success.list-group-item-action:focus{color:#235937;background-color:#b8e0c7}.list-group-item-success.list-group-item-action.active{color:#fff;background-color:#235937;border-color:#235937}.list-group-item-info{color:#2f6473;background-color:#d1edf6}.list-group-item-info.list-group-item-action:hover,.list-group-item-info.list-group-item-action:focus{color:#2f6473;background-color:#bce5f2}.list-group-item-info.list-group-item-action.active{color:#fff;background-color:#2f6473;border-color:#2f6473}.list-group-item-warning{color:#794b01;background-color:#f9e0b8}.list-group-item-warning.list-group-item-action:hover,.list-group-item-warning.list-group-item-action:focus{color:#794b01;background-color:#f7d6a0}.list-group-item-warning.list-group-item-action.active{color:#fff;background-color:#794b01;border-color:#794b01}.list-group-item-danger{color:#7d2213;background-color:#fbcac2}.list-group-item-danger.list-group-item-action:hover,.list-group-item-danger.list-group-item-action:focus{color:#7d2213;background-color:#f9b5aa}.list-group-item-danger.list-group-item-action.active{color:#fff;background-color:#7d2213;border-color:#7d2213}.list-group-item-light{color:#7c7c7c;background-color:#fafafa}.list-group-item-light.list-group-item-action:hover,.list-group-item-light.list-group-item-action:focus{color:#7c7c7c;background-color:#ededed}.list-group-item-light.list-group-item-action.active{color:#fff;background-color:#7c7c7c;border-color:#7c7c7c}.list-group-item-dark{color:#121212;background-color:#c1c1c1}.list-group-item-dark.list-group-item-action:hover,.list-group-item-dark.list-group-item-action:focus{color:#121212;background-color:#b4b4b4}.list-group-item-dark.list-group-item-action.active{color:#fff;background-color:#121212;border-color:#121212}.close{float:right;font-size:1.40625rem;font-weight:700;line-height:1;color:#888;text-shadow:none;opacity:.5}.close:hover,.close:focus{color:#888;text-decoration:none;opacity:.75}.close:not(:disabled):not(.disabled){cursor:pointer}button.close{padding:0;background-color:transparent;border:0;-webkit-appearance:none}.modal-open{overflow:hidden}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1050;display:none;overflow:hidden;outline:0}.modal-open .modal{overflow-x:hidden;overflow-y:auto}.modal-dialog{position:relative;width:auto;margin:0.5rem;pointer-events:none}.modal.fade .modal-dialog{-webkit-transition:-webkit-transform 0.3s ease-out;transition:-webkit-transform 0.3s ease-out;transition:transform 0.3s ease-out;transition:transform 0.3s ease-out, -webkit-transform 0.3s ease-out;-webkit-transform:translate(0, -25%);transform:translate(0, -25%)}.modal.show .modal-dialog{-webkit-transform:translate(0, 0);transform:translate(0, 0)}.modal-dialog-centered{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;min-height:calc(100% - (0.5rem * 2))}.modal-content{position:relative;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;width:100%;pointer-events:auto;background-color:#fff;background-clip:padding-box;border:1px solid rgba(0,0,0,0.2);border-radius:0;outline:0}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1040;background-color:#000}.modal-backdrop.fade{opacity:0}.modal-backdrop.show{opacity:0.5}.modal-header{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;padding:1rem;border-bottom:1px solid #eee;border-top-left-radius:0;border-top-right-radius:0}.modal-header .close{padding:1rem;margin:-1rem -1rem -1rem auto}.modal-title{margin-bottom:0;line-height:1.5}.modal-body{position:relative;-webkit-box-flex:1;-ms-flex:1 1 auto;flex:1 1 auto;padding:1rem}.modal-footer{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:end;-ms-flex-pack:end;justify-content:flex-end;padding:1rem;border-top:1px solid #eee}.modal-footer>:not(:first-child){margin-left:.25rem}.modal-footer>:not(:last-child){margin-right:.25rem}.modal-scrollbar-measure{position:absolute;top:-9999px;width:50px;height:50px;overflow:scroll}@media (min-width: 576px){.modal-dialog{max-width:500px;margin:1.75rem auto}.modal-dialog-centered{min-height:calc(100% - (1.75rem * 2))}.modal-sm{max-width:300px}}@media (min-width: 992px){.modal-lg{max-width:800px}}.tooltip{position:absolute;z-index:1070;display:block;margin:0;font-family:"Open Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";font-style:normal;font-weight:400;line-height:1.5;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;word-spacing:normal;white-space:normal;line-break:auto;font-size:0.8203125rem;word-wrap:break-word;opacity:0}.tooltip.show{opacity:0.9}.tooltip .arrow{position:absolute;display:block;width:0.8rem;height:0.4rem}.tooltip .arrow::before{position:absolute;content:"";border-color:transparent;border-style:solid}.bs-tooltip-top,.bs-tooltip-auto[x-placement^="top"]{padding:0.4rem 0}.bs-tooltip-top .arrow,.bs-tooltip-auto[x-placement^="top"] .arrow{bottom:0}.bs-tooltip-top .arrow::before,.bs-tooltip-auto[x-placement^="top"] .arrow::before{top:0;border-width:0.4rem 0.4rem 0;border-top-color:#000}.bs-tooltip-right,.bs-tooltip-auto[x-placement^="right"]{padding:0 0.4rem}.bs-tooltip-right .arrow,.bs-tooltip-auto[x-placement^="right"] .arrow{left:0;width:0.4rem;height:0.8rem}.bs-tooltip-right .arrow::before,.bs-tooltip-auto[x-placement^="right"] .arrow::before{right:0;border-width:0.4rem 0.4rem 0.4rem 0;border-right-color:#000}.bs-tooltip-bottom,.bs-tooltip-auto[x-placement^="bottom"]{padding:0.4rem 0}.bs-tooltip-bottom .arrow,.bs-tooltip-auto[x-placement^="bottom"] .arrow{top:0}.bs-tooltip-bottom .arrow::before,.bs-tooltip-auto[x-placement^="bottom"] .arrow::before{bottom:0;border-width:0 0.4rem 0.4rem;border-bottom-color:#000}.bs-tooltip-left,.bs-tooltip-auto[x-placement^="left"]{padding:0 0.4rem}.bs-tooltip-left .arrow,.bs-tooltip-auto[x-placement^="left"] .arrow{right:0;width:0.4rem;height:0.8rem}.bs-tooltip-left .arrow::before,.bs-tooltip-auto[x-placement^="left"] .arrow::before{left:0;border-width:0.4rem 0 0.4rem 0.4rem;border-left-color:#000}.tooltip-inner{max-width:200px;padding:0.25rem 0.5rem;color:#fff;text-align:center;background-color:#000;border-radius:0}.popover{position:absolute;top:0;left:0;z-index:1060;display:block;max-width:276px;font-family:"Open Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";font-style:normal;font-weight:400;line-height:1.5;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;word-spacing:normal;white-space:normal;line-break:auto;font-size:0.8203125rem;word-wrap:break-word;background-color:#fff;background-clip:padding-box;border:1px solid rgba(0,0,0,0.2);border-radius:0}.popover .arrow{position:absolute;display:block;width:1rem;height:0.5rem;margin:0 0}.popover .arrow::before,.popover .arrow::after{position:absolute;display:block;content:"";border-color:transparent;border-style:solid}.bs-popover-top,.bs-popover-auto[x-placement^="top"]{margin-bottom:0.5rem}.bs-popover-top .arrow,.bs-popover-auto[x-placement^="top"] .arrow{bottom:calc((0.5rem + 1px) * -1)}.bs-popover-top .arrow::before,.bs-popover-auto[x-placement^="top"] .arrow::before,.bs-popover-top .arrow::after,.bs-popover-auto[x-placement^="top"] .arrow::after{border-width:0.5rem 0.5rem 0}.bs-popover-top .arrow::before,.bs-popover-auto[x-placement^="top"] .arrow::before{bottom:0;border-top-color:rgba(0,0,0,0.25)}.bs-popover-top .arrow::after,.bs-popover-auto[x-placement^="top"] .arrow::after{bottom:1px;border-top-color:#fff}.bs-popover-right,.bs-popover-auto[x-placement^="right"]{margin-left:0.5rem}.bs-popover-right .arrow,.bs-popover-auto[x-placement^="right"] .arrow{left:calc((0.5rem + 1px) * -1);width:0.5rem;height:1rem;margin:0 0}.bs-popover-right .arrow::before,.bs-popover-auto[x-placement^="right"] .arrow::before,.bs-popover-right .arrow::after,.bs-popover-auto[x-placement^="right"] .arrow::after{border-width:0.5rem 0.5rem 0.5rem 0}.bs-popover-right .arrow::before,.bs-popover-auto[x-placement^="right"] .arrow::before{left:0;border-right-color:rgba(0,0,0,0.25)}.bs-popover-right .arrow::after,.bs-popover-auto[x-placement^="right"] .arrow::after{left:1px;border-right-color:#fff}.bs-popover-bottom,.bs-popover-auto[x-placement^="bottom"]{margin-top:0.5rem}.bs-popover-bottom .arrow,.bs-popover-auto[x-placement^="bottom"] .arrow{top:calc((0.5rem + 1px) * -1)}.bs-popover-bottom .arrow::before,.bs-popover-auto[x-placement^="bottom"] .arrow::before,.bs-popover-bottom .arrow::after,.bs-popover-auto[x-placement^="bottom"] .arrow::after{border-width:0 0.5rem 0.5rem 0.5rem}.bs-popover-bottom .arrow::before,.bs-popover-auto[x-placement^="bottom"] .arrow::before{top:0;border-bottom-color:rgba(0,0,0,0.25)}.bs-popover-bottom .arrow::after,.bs-popover-auto[x-placement^="bottom"] .arrow::after{top:1px;border-bottom-color:#fff}.bs-popover-bottom .popover-header::before,.bs-popover-auto[x-placement^="bottom"] .popover-header::before{position:absolute;top:0;left:50%;display:block;width:1rem;margin-left:-0.5rem;content:"";border-bottom:1px solid #f7f7f7}.bs-popover-left,.bs-popover-auto[x-placement^="left"]{margin-right:0.5rem}.bs-popover-left .arrow,.bs-popover-auto[x-placement^="left"] .arrow{right:calc((0.5rem + 1px) * -1);width:0.5rem;height:1rem;margin:0 0}.bs-popover-left .arrow::before,.bs-popover-auto[x-placement^="left"] .arrow::before,.bs-popover-left .arrow::after,.bs-popover-auto[x-placement^="left"] .arrow::after{border-width:0.5rem 0 0.5rem 0.5rem}.bs-popover-left .arrow::before,.bs-popover-auto[x-placement^="left"] .arrow::before{right:0;border-left-color:rgba(0,0,0,0.25)}.bs-popover-left .arrow::after,.bs-popover-auto[x-placement^="left"] .arrow::after{right:1px;border-left-color:#fff}.popover-header{padding:0.5rem 0.75rem;margin-bottom:0;font-size:0.9375rem;color:inherit;background-color:#f7f7f7;border-bottom:1px solid #ebebeb;border-top-left-radius:calc(0 - 1px);border-top-right-radius:calc(0 - 1px)}.popover-header:empty{display:none}.popover-body{padding:0.5rem 0.75rem;color:#222}.carousel{position:relative}.carousel-inner{position:relative;width:100%;overflow:hidden}.carousel-item{position:relative;display:none;-webkit-box-align:center;-ms-flex-align:center;align-items:center;width:100%;-webkit-transition:-webkit-transform 0.6s ease;transition:-webkit-transform 0.6s ease;transition:transform 0.6s ease;transition:transform 0.6s ease, -webkit-transform 0.6s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-perspective:1000px;perspective:1000px}.carousel-item.active,.carousel-item-next,.carousel-item-prev{display:block}.carousel-item-next,.carousel-item-prev{position:absolute;top:0}.carousel-item-next.carousel-item-left,.carousel-item-prev.carousel-item-right{-webkit-transform:translateX(0);transform:translateX(0)}@supports (-webkit-transform-style: preserve-3d) or (transform-style: preserve-3d){.carousel-item-next.carousel-item-left,.carousel-item-prev.carousel-item-right{-webkit-transform:translate3d(0, 0, 0);transform:translate3d(0, 0, 0)}}.carousel-item-next,.active.carousel-item-right{-webkit-transform:translateX(100%);transform:translateX(100%)}@supports (-webkit-transform-style: preserve-3d) or (transform-style: preserve-3d){.carousel-item-next,.active.carousel-item-right{-webkit-transform:translate3d(100%, 0, 0);transform:translate3d(100%, 0, 0)}}.carousel-item-prev,.active.carousel-item-left{-webkit-transform:translateX(-100%);transform:translateX(-100%)}@supports (-webkit-transform-style: preserve-3d) or (transform-style: preserve-3d){.carousel-item-prev,.active.carousel-item-left{-webkit-transform:translate3d(-100%, 0, 0);transform:translate3d(-100%, 0, 0)}}.carousel-control-prev,.carousel-control-next{position:absolute;top:0;bottom:0;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;width:15%;color:#fff;text-align:center;opacity:0.5}.carousel-control-prev:hover,.carousel-control-prev:focus,.carousel-control-next:hover,.carousel-control-next:focus{color:#fff;text-decoration:none;outline:0;opacity:.9}.carousel-control-prev{left:0}.carousel-control-next{right:0}.carousel-control-prev-icon,.carousel-control-next-icon{display:inline-block;width:20px;height:20px;background:transparent no-repeat center center;background-size:100% 100%}.carousel-control-prev-icon{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 8 8'%3E%3Cpath d='M5.25 0l-4 4 4 4 1.5-1.5-2.5-2.5 2.5-2.5-1.5-1.5z'/%3E%3C/svg%3E")}.carousel-control-next-icon{background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 8 8'%3E%3Cpath d='M2.75 0l-1.5 1.5 2.5 2.5-2.5 2.5 1.5 1.5 4-4-4-4z'/%3E%3C/svg%3E")}.carousel-indicators{position:absolute;right:0;bottom:10px;left:0;z-index:15;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;padding-left:0;margin-right:15%;margin-left:15%;list-style:none}.carousel-indicators li{position:relative;-webkit-box-flex:0;-ms-flex:0 1 auto;flex:0 1 auto;width:30px;height:3px;margin-right:3px;margin-left:3px;text-indent:-999px;background-color:rgba(255,255,255,0.5)}.carousel-indicators li::before{position:absolute;top:-10px;left:0;display:inline-block;width:100%;height:10px;content:""}.carousel-indicators li::after{position:absolute;bottom:-10px;left:0;display:inline-block;width:100%;height:10px;content:""}.carousel-indicators .active{background-color:#fff}.carousel-caption{position:absolute;right:15%;bottom:20px;left:15%;z-index:10;padding-top:20px;padding-bottom:20px;color:#fff;text-align:center}.align-baseline{vertical-align:baseline !important}.align-top{vertical-align:top !important}.align-middle{vertical-align:middle !important}.align-bottom{vertical-align:bottom !important}.align-text-bottom{vertical-align:text-bottom !important}.align-text-top{vertical-align:text-top !important}.bg-primary{background-color:#008cba !important}a.bg-primary:hover,a.bg-primary:focus,button.bg-primary:hover,button.bg-primary:focus{background-color:#006687 !important}.bg-secondary{background-color:#eee !important}a.bg-secondary:hover,a.bg-secondary:focus,button.bg-secondary:hover,button.bg-secondary:focus{background-color:#d5d4d4 !important}.bg-success{background-color:#43ac6a !important}a.bg-success:hover,a.bg-success:focus,button.bg-success:hover,button.bg-success:focus{background-color:#358753 !important}.bg-info{background-color:#5bc0de !important}a.bg-info:hover,a.bg-info:focus,button.bg-info:hover,button.bg-info:focus{background-color:#31b0d5 !important}.bg-warning{background-color:#E99002 !important}a.bg-warning:hover,a.bg-warning:focus,button.bg-warning:hover,button.bg-warning:focus{background-color:#b67102 !important}.bg-danger{background-color:#F04124 !important}a.bg-danger:hover,a.bg-danger:focus,button.bg-danger:hover,button.bg-danger:focus{background-color:#d32a0e !important}.bg-light{background-color:#eee !important}a.bg-light:hover,a.bg-light:focus,button.bg-light:hover,button.bg-light:focus{background-color:#d5d4d4 !important}.bg-dark{background-color:#222 !important}a.bg-dark:hover,a.bg-dark:focus,button.bg-dark:hover,button.bg-dark:focus{background-color:#090808 !important}.bg-white{background-color:#fff !important}.bg-transparent{background-color:transparent !important}.border{border:1px solid #dee2e6 !important}.border-top{border-top:1px solid #dee2e6 !important}.border-right{border-right:1px solid #dee2e6 !important}.border-bottom{border-bottom:1px solid #dee2e6 !important}.border-left{border-left:1px solid #dee2e6 !important}.border-0{border:0 !important}.border-top-0{border-top:0 !important}.border-right-0{border-right:0 !important}.border-bottom-0{border-bottom:0 !important}.border-left-0{border-left:0 !important}.border-primary{border-color:#008cba !important}.border-secondary{border-color:#eee !important}.border-success{border-color:#43ac6a !important}.border-info{border-color:#5bc0de !important}.border-warning{border-color:#E99002 !important}.border-danger{border-color:#F04124 !important}.border-light{border-color:#eee !important}.border-dark{border-color:#222 !important}.border-white{border-color:#fff !important}.rounded{border-radius:0 !important}.rounded-top{border-top-left-radius:0 !important;border-top-right-radius:0 !important}.rounded-right{border-top-right-radius:0 !important;border-bottom-right-radius:0 !important}.rounded-bottom{border-bottom-right-radius:0 !important;border-bottom-left-radius:0 !important}.rounded-left{border-top-left-radius:0 !important;border-bottom-left-radius:0 !important}.rounded-circle{border-radius:50% !important}.rounded-0{border-radius:0 !important}.clearfix::after{display:block;clear:both;content:""}.d-none{display:none !important}.d-inline{display:inline !important}.d-inline-block{display:inline-block !important}.d-block{display:block !important}.d-table{display:table !important}.d-table-row{display:table-row !important}.d-table-cell{display:table-cell !important}.d-flex{display:-webkit-box !important;display:-ms-flexbox !important;display:flex !important}.d-inline-flex{display:-webkit-inline-box !important;display:-ms-inline-flexbox !important;display:inline-flex !important}@media (min-width: 576px){.d-sm-none{display:none !important}.d-sm-inline{display:inline !important}.d-sm-inline-block{display:inline-block !important}.d-sm-block{display:block !important}.d-sm-table{display:table !important}.d-sm-table-row{display:table-row !important}.d-sm-table-cell{display:table-cell !important}.d-sm-flex{display:-webkit-box !important;display:-ms-flexbox !important;display:flex !important}.d-sm-inline-flex{display:-webkit-inline-box !important;display:-ms-inline-flexbox !important;display:inline-flex !important}}@media (min-width: 768px){.d-md-none{display:none !important}.d-md-inline{display:inline !important}.d-md-inline-block{display:inline-block !important}.d-md-block{display:block !important}.d-md-table{display:table !important}.d-md-table-row{display:table-row !important}.d-md-table-cell{display:table-cell !important}.d-md-flex{display:-webkit-box !important;display:-ms-flexbox !important;display:flex !important}.d-md-inline-flex{display:-webkit-inline-box !important;display:-ms-inline-flexbox !important;display:inline-flex !important}}@media (min-width: 992px){.d-lg-none{display:none !important}.d-lg-inline{display:inline !important}.d-lg-inline-block{display:inline-block !important}.d-lg-block{display:block !important}.d-lg-table{display:table !important}.d-lg-table-row{display:table-row !important}.d-lg-table-cell{display:table-cell !important}.d-lg-flex{display:-webkit-box !important;display:-ms-flexbox !important;display:flex !important}.d-lg-inline-flex{display:-webkit-inline-box !important;display:-ms-inline-flexbox !important;display:inline-flex !important}}@media (min-width: 1200px){.d-xl-none{display:none !important}.d-xl-inline{display:inline !important}.d-xl-inline-block{display:inline-block !important}.d-xl-block{display:block !important}.d-xl-table{display:table !important}.d-xl-table-row{display:table-row !important}.d-xl-table-cell{display:table-cell !important}.d-xl-flex{display:-webkit-box !important;display:-ms-flexbox !important;display:flex !important}.d-xl-inline-flex{display:-webkit-inline-box !important;display:-ms-inline-flexbox !important;display:inline-flex !important}}@media print{.d-print-none{display:none !important}.d-print-inline{display:inline !important}.d-print-inline-block{display:inline-block !important}.d-print-block{display:block !important}.d-print-table{display:table !important}.d-print-table-row{display:table-row !important}.d-print-table-cell{display:table-cell !important}.d-print-flex{display:-webkit-box !important;display:-ms-flexbox !important;display:flex !important}.d-print-inline-flex{display:-webkit-inline-box !important;display:-ms-inline-flexbox !important;display:inline-flex !important}}.embed-responsive{position:relative;display:block;width:100%;padding:0;overflow:hidden}.embed-responsive::before{display:block;content:""}.embed-responsive .embed-responsive-item,.embed-responsive iframe,.embed-responsive embed,.embed-responsive object,.embed-responsive video{position:absolute;top:0;bottom:0;left:0;width:100%;height:100%;border:0}.embed-responsive-21by9::before{padding-top:42.8571428571%}.embed-responsive-16by9::before{padding-top:56.25%}.embed-responsive-4by3::before{padding-top:75%}.embed-responsive-1by1::before{padding-top:100%}.flex-row{-webkit-box-orient:horizontal !important;-webkit-box-direction:normal !important;-ms-flex-direction:row !important;flex-direction:row !important}.flex-column{-webkit-box-orient:vertical !important;-webkit-box-direction:normal !important;-ms-flex-direction:column !important;flex-direction:column !important}.flex-row-reverse{-webkit-box-orient:horizontal !important;-webkit-box-direction:reverse !important;-ms-flex-direction:row-reverse !important;flex-direction:row-reverse !important}.flex-column-reverse{-webkit-box-orient:vertical !important;-webkit-box-direction:reverse !important;-ms-flex-direction:column-reverse !important;flex-direction:column-reverse !important}.flex-wrap{-ms-flex-wrap:wrap !important;flex-wrap:wrap !important}.flex-nowrap{-ms-flex-wrap:nowrap !important;flex-wrap:nowrap !important}.flex-wrap-reverse{-ms-flex-wrap:wrap-reverse !important;flex-wrap:wrap-reverse !important}.justify-content-start{-webkit-box-pack:start !important;-ms-flex-pack:start !important;justify-content:flex-start !important}.justify-content-end{-webkit-box-pack:end !important;-ms-flex-pack:end !important;justify-content:flex-end !important}.justify-content-center{-webkit-box-pack:center !important;-ms-flex-pack:center !important;justify-content:center !important}.justify-content-between{-webkit-box-pack:justify !important;-ms-flex-pack:justify !important;justify-content:space-between !important}.justify-content-around{-ms-flex-pack:distribute !important;justify-content:space-around !important}.align-items-start{-webkit-box-align:start !important;-ms-flex-align:start !important;align-items:flex-start !important}.align-items-end{-webkit-box-align:end !important;-ms-flex-align:end !important;align-items:flex-end !important}.align-items-center{-webkit-box-align:center !important;-ms-flex-align:center !important;align-items:center !important}.align-items-baseline{-webkit-box-align:baseline !important;-ms-flex-align:baseline !important;align-items:baseline !important}.align-items-stretch{-webkit-box-align:stretch !important;-ms-flex-align:stretch !important;align-items:stretch !important}.align-content-start{-ms-flex-line-pack:start !important;align-content:flex-start !important}.align-content-end{-ms-flex-line-pack:end !important;align-content:flex-end !important}.align-content-center{-ms-flex-line-pack:center !important;align-content:center !important}.align-content-between{-ms-flex-line-pack:justify !important;align-content:space-between !important}.align-content-around{-ms-flex-line-pack:distribute !important;align-content:space-around !important}.align-content-stretch{-ms-flex-line-pack:stretch !important;align-content:stretch !important}.align-self-auto{-ms-flex-item-align:auto !important;align-self:auto !important}.align-self-start{-ms-flex-item-align:start !important;align-self:flex-start !important}.align-self-end{-ms-flex-item-align:end !important;align-self:flex-end !important}.align-self-center{-ms-flex-item-align:center !important;align-self:center !important}.align-self-baseline{-ms-flex-item-align:baseline !important;align-self:baseline !important}.align-self-stretch{-ms-flex-item-align:stretch !important;align-self:stretch !important}@media (min-width: 576px){.flex-sm-row{-webkit-box-orient:horizontal !important;-webkit-box-direction:normal !important;-ms-flex-direction:row !important;flex-direction:row !important}.flex-sm-column{-webkit-box-orient:vertical !important;-webkit-box-direction:normal !important;-ms-flex-direction:column !important;flex-direction:column !important}.flex-sm-row-reverse{-webkit-box-orient:horizontal !important;-webkit-box-direction:reverse !important;-ms-flex-direction:row-reverse !important;flex-direction:row-reverse !important}.flex-sm-column-reverse{-webkit-box-orient:vertical !important;-webkit-box-direction:reverse !important;-ms-flex-direction:column-reverse !important;flex-direction:column-reverse !important}.flex-sm-wrap{-ms-flex-wrap:wrap !important;flex-wrap:wrap !important}.flex-sm-nowrap{-ms-flex-wrap:nowrap !important;flex-wrap:nowrap !important}.flex-sm-wrap-reverse{-ms-flex-wrap:wrap-reverse !important;flex-wrap:wrap-reverse !important}.justify-content-sm-start{-webkit-box-pack:start !important;-ms-flex-pack:start !important;justify-content:flex-start !important}.justify-content-sm-end{-webkit-box-pack:end !important;-ms-flex-pack:end !important;justify-content:flex-end !important}.justify-content-sm-center{-webkit-box-pack:center !important;-ms-flex-pack:center !important;justify-content:center !important}.justify-content-sm-between{-webkit-box-pack:justify !important;-ms-flex-pack:justify !important;justify-content:space-between !important}.justify-content-sm-around{-ms-flex-pack:distribute !important;justify-content:space-around !important}.align-items-sm-start{-webkit-box-align:start !important;-ms-flex-align:start !important;align-items:flex-start !important}.align-items-sm-end{-webkit-box-align:end !important;-ms-flex-align:end !important;align-items:flex-end !important}.align-items-sm-center{-webkit-box-align:center !important;-ms-flex-align:center !important;align-items:center !important}.align-items-sm-baseline{-webkit-box-align:baseline !important;-ms-flex-align:baseline !important;align-items:baseline !important}.align-items-sm-stretch{-webkit-box-align:stretch !important;-ms-flex-align:stretch !important;align-items:stretch !important}.align-content-sm-start{-ms-flex-line-pack:start !important;align-content:flex-start !important}.align-content-sm-end{-ms-flex-line-pack:end !important;align-content:flex-end !important}.align-content-sm-center{-ms-flex-line-pack:center !important;align-content:center !important}.align-content-sm-between{-ms-flex-line-pack:justify !important;align-content:space-between !important}.align-content-sm-around{-ms-flex-line-pack:distribute !important;align-content:space-around !important}.align-content-sm-stretch{-ms-flex-line-pack:stretch !important;align-content:stretch !important}.align-self-sm-auto{-ms-flex-item-align:auto !important;align-self:auto !important}.align-self-sm-start{-ms-flex-item-align:start !important;align-self:flex-start !important}.align-self-sm-end{-ms-flex-item-align:end !important;align-self:flex-end !important}.align-self-sm-center{-ms-flex-item-align:center !important;align-self:center !important}.align-self-sm-baseline{-ms-flex-item-align:baseline !important;align-self:baseline !important}.align-self-sm-stretch{-ms-flex-item-align:stretch !important;align-self:stretch !important}}@media (min-width: 768px){.flex-md-row{-webkit-box-orient:horizontal !important;-webkit-box-direction:normal !important;-ms-flex-direction:row !important;flex-direction:row !important}.flex-md-column{-webkit-box-orient:vertical !important;-webkit-box-direction:normal !important;-ms-flex-direction:column !important;flex-direction:column !important}.flex-md-row-reverse{-webkit-box-orient:horizontal !important;-webkit-box-direction:reverse !important;-ms-flex-direction:row-reverse !important;flex-direction:row-reverse !important}.flex-md-column-reverse{-webkit-box-orient:vertical !important;-webkit-box-direction:reverse !important;-ms-flex-direction:column-reverse !important;flex-direction:column-reverse !important}.flex-md-wrap{-ms-flex-wrap:wrap !important;flex-wrap:wrap !important}.flex-md-nowrap{-ms-flex-wrap:nowrap !important;flex-wrap:nowrap !important}.flex-md-wrap-reverse{-ms-flex-wrap:wrap-reverse !important;flex-wrap:wrap-reverse !important}.justify-content-md-start{-webkit-box-pack:start !important;-ms-flex-pack:start !important;justify-content:flex-start !important}.justify-content-md-end{-webkit-box-pack:end !important;-ms-flex-pack:end !important;justify-content:flex-end !important}.justify-content-md-center{-webkit-box-pack:center !important;-ms-flex-pack:center !important;justify-content:center !important}.justify-content-md-between{-webkit-box-pack:justify !important;-ms-flex-pack:justify !important;justify-content:space-between !important}.justify-content-md-around{-ms-flex-pack:distribute !important;justify-content:space-around !important}.align-items-md-start{-webkit-box-align:start !important;-ms-flex-align:start !important;align-items:flex-start !important}.align-items-md-end{-webkit-box-align:end !important;-ms-flex-align:end !important;align-items:flex-end !important}.align-items-md-center{-webkit-box-align:center !important;-ms-flex-align:center !important;align-items:center !important}.align-items-md-baseline{-webkit-box-align:baseline !important;-ms-flex-align:baseline !important;align-items:baseline !important}.align-items-md-stretch{-webkit-box-align:stretch !important;-ms-flex-align:stretch !important;align-items:stretch !important}.align-content-md-start{-ms-flex-line-pack:start !important;align-content:flex-start !important}.align-content-md-end{-ms-flex-line-pack:end !important;align-content:flex-end !important}.align-content-md-center{-ms-flex-line-pack:center !important;align-content:center !important}.align-content-md-between{-ms-flex-line-pack:justify !important;align-content:space-between !important}.align-content-md-around{-ms-flex-line-pack:distribute !important;align-content:space-around !important}.align-content-md-stretch{-ms-flex-line-pack:stretch !important;align-content:stretch !important}.align-self-md-auto{-ms-flex-item-align:auto !important;align-self:auto !important}.align-self-md-start{-ms-flex-item-align:start !important;align-self:flex-start !important}.align-self-md-end{-ms-flex-item-align:end !important;align-self:flex-end !important}.align-self-md-center{-ms-flex-item-align:center !important;align-self:center !important}.align-self-md-baseline{-ms-flex-item-align:baseline !important;align-self:baseline !important}.align-self-md-stretch{-ms-flex-item-align:stretch !important;align-self:stretch !important}}@media (min-width: 992px){.flex-lg-row{-webkit-box-orient:horizontal !important;-webkit-box-direction:normal !important;-ms-flex-direction:row !important;flex-direction:row !important}.flex-lg-column{-webkit-box-orient:vertical !important;-webkit-box-direction:normal !important;-ms-flex-direction:column !important;flex-direction:column !important}.flex-lg-row-reverse{-webkit-box-orient:horizontal !important;-webkit-box-direction:reverse !important;-ms-flex-direction:row-reverse !important;flex-direction:row-reverse !important}.flex-lg-column-reverse{-webkit-box-orient:vertical !important;-webkit-box-direction:reverse !important;-ms-flex-direction:column-reverse !important;flex-direction:column-reverse !important}.flex-lg-wrap{-ms-flex-wrap:wrap !important;flex-wrap:wrap !important}.flex-lg-nowrap{-ms-flex-wrap:nowrap !important;flex-wrap:nowrap !important}.flex-lg-wrap-reverse{-ms-flex-wrap:wrap-reverse !important;flex-wrap:wrap-reverse !important}.justify-content-lg-start{-webkit-box-pack:start !important;-ms-flex-pack:start !important;justify-content:flex-start !important}.justify-content-lg-end{-webkit-box-pack:end !important;-ms-flex-pack:end !important;justify-content:flex-end !important}.justify-content-lg-center{-webkit-box-pack:center !important;-ms-flex-pack:center !important;justify-content:center !important}.justify-content-lg-between{-webkit-box-pack:justify !important;-ms-flex-pack:justify !important;justify-content:space-between !important}.justify-content-lg-around{-ms-flex-pack:distribute !important;justify-content:space-around !important}.align-items-lg-start{-webkit-box-align:start !important;-ms-flex-align:start !important;align-items:flex-start !important}.align-items-lg-end{-webkit-box-align:end !important;-ms-flex-align:end !important;align-items:flex-end !important}.align-items-lg-center{-webkit-box-align:center !important;-ms-flex-align:center !important;align-items:center !important}.align-items-lg-baseline{-webkit-box-align:baseline !important;-ms-flex-align:baseline !important;align-items:baseline !important}.align-items-lg-stretch{-webkit-box-align:stretch !important;-ms-flex-align:stretch !important;align-items:stretch !important}.align-content-lg-start{-ms-flex-line-pack:start !important;align-content:flex-start !important}.align-content-lg-end{-ms-flex-line-pack:end !important;align-content:flex-end !important}.align-content-lg-center{-ms-flex-line-pack:center !important;align-content:center !important}.align-content-lg-between{-ms-flex-line-pack:justify !important;align-content:space-between !important}.align-content-lg-around{-ms-flex-line-pack:distribute !important;align-content:space-around !important}.align-content-lg-stretch{-ms-flex-line-pack:stretch !important;align-content:stretch !important}.align-self-lg-auto{-ms-flex-item-align:auto !important;align-self:auto !important}.align-self-lg-start{-ms-flex-item-align:start !important;align-self:flex-start !important}.align-self-lg-end{-ms-flex-item-align:end !important;align-self:flex-end !important}.align-self-lg-center{-ms-flex-item-align:center !important;align-self:center !important}.align-self-lg-baseline{-ms-flex-item-align:baseline !important;align-self:baseline !important}.align-self-lg-stretch{-ms-flex-item-align:stretch !important;align-self:stretch !important}}@media (min-width: 1200px){.flex-xl-row{-webkit-box-orient:horizontal !important;-webkit-box-direction:normal !important;-ms-flex-direction:row !important;flex-direction:row !important}.flex-xl-column{-webkit-box-orient:vertical !important;-webkit-box-direction:normal !important;-ms-flex-direction:column !important;flex-direction:column !important}.flex-xl-row-reverse{-webkit-box-orient:horizontal !important;-webkit-box-direction:reverse !important;-ms-flex-direction:row-reverse !important;flex-direction:row-reverse !important}.flex-xl-column-reverse{-webkit-box-orient:vertical !important;-webkit-box-direction:reverse !important;-ms-flex-direction:column-reverse !important;flex-direction:column-reverse !important}.flex-xl-wrap{-ms-flex-wrap:wrap !important;flex-wrap:wrap !important}.flex-xl-nowrap{-ms-flex-wrap:nowrap !important;flex-wrap:nowrap !important}.flex-xl-wrap-reverse{-ms-flex-wrap:wrap-reverse !important;flex-wrap:wrap-reverse !important}.justify-content-xl-start{-webkit-box-pack:start !important;-ms-flex-pack:start !important;justify-content:flex-start !important}.justify-content-xl-end{-webkit-box-pack:end !important;-ms-flex-pack:end !important;justify-content:flex-end !important}.justify-content-xl-center{-webkit-box-pack:center !important;-ms-flex-pack:center !important;justify-content:center !important}.justify-content-xl-between{-webkit-box-pack:justify !important;-ms-flex-pack:justify !important;justify-content:space-between !important}.justify-content-xl-around{-ms-flex-pack:distribute !important;justify-content:space-around !important}.align-items-xl-start{-webkit-box-align:start !important;-ms-flex-align:start !important;align-items:flex-start !important}.align-items-xl-end{-webkit-box-align:end !important;-ms-flex-align:end !important;align-items:flex-end !important}.align-items-xl-center{-webkit-box-align:center !important;-ms-flex-align:center !important;align-items:center !important}.align-items-xl-baseline{-webkit-box-align:baseline !important;-ms-flex-align:baseline !important;align-items:baseline !important}.align-items-xl-stretch{-webkit-box-align:stretch !important;-ms-flex-align:stretch !important;align-items:stretch !important}.align-content-xl-start{-ms-flex-line-pack:start !important;align-content:flex-start !important}.align-content-xl-end{-ms-flex-line-pack:end !important;align-content:flex-end !important}.align-content-xl-center{-ms-flex-line-pack:center !important;align-content:center !important}.align-content-xl-between{-ms-flex-line-pack:justify !important;align-content:space-between !important}.align-content-xl-around{-ms-flex-line-pack:distribute !important;align-content:space-around !important}.align-content-xl-stretch{-ms-flex-line-pack:stretch !important;align-content:stretch !important}.align-self-xl-auto{-ms-flex-item-align:auto !important;align-self:auto !important}.align-self-xl-start{-ms-flex-item-align:start !important;align-self:flex-start !important}.align-self-xl-end{-ms-flex-item-align:end !important;align-self:flex-end !important}.align-self-xl-center{-ms-flex-item-align:center !important;align-self:center !important}.align-self-xl-baseline{-ms-flex-item-align:baseline !important;align-self:baseline !important}.align-self-xl-stretch{-ms-flex-item-align:stretch !important;align-self:stretch !important}}.float-left{float:left !important}.float-right{float:right !important}.float-none{float:none !important}@media (min-width: 576px){.float-sm-left{float:left !important}.float-sm-right{float:right !important}.float-sm-none{float:none !important}}@media (min-width: 768px){.float-md-left{float:left !important}.float-md-right{float:right !important}.float-md-none{float:none !important}}@media (min-width: 992px){.float-lg-left{float:left !important}.float-lg-right{float:right !important}.float-lg-none{float:none !important}}@media (min-width: 1200px){.float-xl-left{float:left !important}.float-xl-right{float:right !important}.float-xl-none{float:none !important}}.position-static{position:static !important}.position-relative{position:relative !important}.position-absolute{position:absolute !important}.position-fixed{position:fixed !important}.position-sticky{position:-webkit-sticky !important;position:sticky !important}.fixed-top{position:fixed;top:0;right:0;left:0;z-index:1030}.fixed-bottom{position:fixed;right:0;bottom:0;left:0;z-index:1030}@supports (position: -webkit-sticky) or (position: sticky){.sticky-top{position:-webkit-sticky;position:sticky;top:0;z-index:1020}}.sr-only{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0, 0, 0, 0);white-space:nowrap;-webkit-clip-path:inset(50%);clip-path:inset(50%);border:0}.sr-only-focusable:active,.sr-only-focusable:focus{position:static;width:auto;height:auto;overflow:visible;clip:auto;white-space:normal;-webkit-clip-path:none;clip-path:none}.w-25{width:25% !important}.w-50{width:50% !important}.w-75{width:75% !important}.w-100{width:100% !important}.h-25{height:25% !important}.h-50{height:50% !important}.h-75{height:75% !important}.h-100{height:100% !important}.mw-100{max-width:100% !important}.mh-100{max-height:100% !important}.m-0{margin:0 !important}.mt-0,.my-0{margin-top:0 !important}.mr-0,.mx-0{margin-right:0 !important}.mb-0,.my-0{margin-bottom:0 !important}.ml-0,.mx-0{margin-left:0 !important}.m-1{margin:0.25rem !important}.mt-1,.my-1{margin-top:0.25rem !important}.mr-1,.mx-1{margin-right:0.25rem !important}.mb-1,.my-1{margin-bottom:0.25rem !important}.ml-1,.mx-1{margin-left:0.25rem !important}.m-2{margin:0.5rem !important}.mt-2,.my-2{margin-top:0.5rem !important}.mr-2,.mx-2{margin-right:0.5rem !important}.mb-2,.my-2{margin-bottom:0.5rem !important}.ml-2,.mx-2{margin-left:0.5rem !important}.m-3{margin:1rem !important}.mt-3,.my-3{margin-top:1rem !important}.mr-3,.mx-3{margin-right:1rem !important}.mb-3,.my-3{margin-bottom:1rem !important}.ml-3,.mx-3{margin-left:1rem !important}.m-4{margin:1.5rem !important}.mt-4,.my-4{margin-top:1.5rem !important}.mr-4,.mx-4{margin-right:1.5rem !important}.mb-4,.my-4{margin-bottom:1.5rem !important}.ml-4,.mx-4{margin-left:1.5rem !important}.m-5{margin:3rem !important}.mt-5,.my-5{margin-top:3rem !important}.mr-5,.mx-5{margin-right:3rem !important}.mb-5,.my-5{margin-bottom:3rem !important}.ml-5,.mx-5{margin-left:3rem !important}.p-0{padding:0 !important}.pt-0,.py-0{padding-top:0 !important}.pr-0,.px-0{padding-right:0 !important}.pb-0,.py-0{padding-bottom:0 !important}.pl-0,.px-0{padding-left:0 !important}.p-1{padding:0.25rem !important}.pt-1,.py-1{padding-top:0.25rem !important}.pr-1,.px-1{padding-right:0.25rem !important}.pb-1,.py-1{padding-bottom:0.25rem !important}.pl-1,.px-1{padding-left:0.25rem !important}.p-2{padding:0.5rem !important}.pt-2,.py-2{padding-top:0.5rem !important}.pr-2,.px-2{padding-right:0.5rem !important}.pb-2,.py-2{padding-bottom:0.5rem !important}.pl-2,.px-2{padding-left:0.5rem !important}.p-3{padding:1rem !important}.pt-3,.py-3{padding-top:1rem !important}.pr-3,.px-3{padding-right:1rem !important}.pb-3,.py-3{padding-bottom:1rem !important}.pl-3,.px-3{padding-left:1rem !important}.p-4{padding:1.5rem !important}.pt-4,.py-4{padding-top:1.5rem !important}.pr-4,.px-4{padding-right:1.5rem !important}.pb-4,.py-4{padding-bottom:1.5rem !important}.pl-4,.px-4{padding-left:1.5rem !important}.p-5{padding:3rem !important}.pt-5,.py-5{padding-top:3rem !important}.pr-5,.px-5{padding-right:3rem !important}.pb-5,.py-5{padding-bottom:3rem !important}.pl-5,.px-5{padding-left:3rem !important}.m-auto{margin:auto !important}.mt-auto,.my-auto{margin-top:auto !important}.mr-auto,.mx-auto{margin-right:auto !important}.mb-auto,.my-auto{margin-bottom:auto !important}.ml-auto,.mx-auto{margin-left:auto !important}@media (min-width: 576px){.m-sm-0{margin:0 !important}.mt-sm-0,.my-sm-0{margin-top:0 !important}.mr-sm-0,.mx-sm-0{margin-right:0 !important}.mb-sm-0,.my-sm-0{margin-bottom:0 !important}.ml-sm-0,.mx-sm-0{margin-left:0 !important}.m-sm-1{margin:0.25rem !important}.mt-sm-1,.my-sm-1{margin-top:0.25rem !important}.mr-sm-1,.mx-sm-1{margin-right:0.25rem !important}.mb-sm-1,.my-sm-1{margin-bottom:0.25rem !important}.ml-sm-1,.mx-sm-1{margin-left:0.25rem !important}.m-sm-2{margin:0.5rem !important}.mt-sm-2,.my-sm-2{margin-top:0.5rem !important}.mr-sm-2,.mx-sm-2{margin-right:0.5rem !important}.mb-sm-2,.my-sm-2{margin-bottom:0.5rem !important}.ml-sm-2,.mx-sm-2{margin-left:0.5rem !important}.m-sm-3{margin:1rem !important}.mt-sm-3,.my-sm-3{margin-top:1rem !important}.mr-sm-3,.mx-sm-3{margin-right:1rem !important}.mb-sm-3,.my-sm-3{margin-bottom:1rem !important}.ml-sm-3,.mx-sm-3{margin-left:1rem !important}.m-sm-4{margin:1.5rem !important}.mt-sm-4,.my-sm-4{margin-top:1.5rem !important}.mr-sm-4,.mx-sm-4{margin-right:1.5rem !important}.mb-sm-4,.my-sm-4{margin-bottom:1.5rem !important}.ml-sm-4,.mx-sm-4{margin-left:1.5rem !important}.m-sm-5{margin:3rem !important}.mt-sm-5,.my-sm-5{margin-top:3rem !important}.mr-sm-5,.mx-sm-5{margin-right:3rem !important}.mb-sm-5,.my-sm-5{margin-bottom:3rem !important}.ml-sm-5,.mx-sm-5{margin-left:3rem !important}.p-sm-0{padding:0 !important}.pt-sm-0,.py-sm-0{padding-top:0 !important}.pr-sm-0,.px-sm-0{padding-right:0 !important}.pb-sm-0,.py-sm-0{padding-bottom:0 !important}.pl-sm-0,.px-sm-0{padding-left:0 !important}.p-sm-1{padding:0.25rem !important}.pt-sm-1,.py-sm-1{padding-top:0.25rem !important}.pr-sm-1,.px-sm-1{padding-right:0.25rem !important}.pb-sm-1,.py-sm-1{padding-bottom:0.25rem !important}.pl-sm-1,.px-sm-1{padding-left:0.25rem !important}.p-sm-2{padding:0.5rem !important}.pt-sm-2,.py-sm-2{padding-top:0.5rem !important}.pr-sm-2,.px-sm-2{padding-right:0.5rem !important}.pb-sm-2,.py-sm-2{padding-bottom:0.5rem !important}.pl-sm-2,.px-sm-2{padding-left:0.5rem !important}.p-sm-3{padding:1rem !important}.pt-sm-3,.py-sm-3{padding-top:1rem !important}.pr-sm-3,.px-sm-3{padding-right:1rem !important}.pb-sm-3,.py-sm-3{padding-bottom:1rem !important}.pl-sm-3,.px-sm-3{padding-left:1rem !important}.p-sm-4{padding:1.5rem !important}.pt-sm-4,.py-sm-4{padding-top:1.5rem !important}.pr-sm-4,.px-sm-4{padding-right:1.5rem !important}.pb-sm-4,.py-sm-4{padding-bottom:1.5rem !important}.pl-sm-4,.px-sm-4{padding-left:1.5rem !important}.p-sm-5{padding:3rem !important}.pt-sm-5,.py-sm-5{padding-top:3rem !important}.pr-sm-5,.px-sm-5{padding-right:3rem !important}.pb-sm-5,.py-sm-5{padding-bottom:3rem !important}.pl-sm-5,.px-sm-5{padding-left:3rem !important}.m-sm-auto{margin:auto !important}.mt-sm-auto,.my-sm-auto{margin-top:auto !important}.mr-sm-auto,.mx-sm-auto{margin-right:auto !important}.mb-sm-auto,.my-sm-auto{margin-bottom:auto !important}.ml-sm-auto,.mx-sm-auto{margin-left:auto !important}}@media (min-width: 768px){.m-md-0{margin:0 !important}.mt-md-0,.my-md-0{margin-top:0 !important}.mr-md-0,.mx-md-0{margin-right:0 !important}.mb-md-0,.my-md-0{margin-bottom:0 !important}.ml-md-0,.mx-md-0{margin-left:0 !important}.m-md-1{margin:0.25rem !important}.mt-md-1,.my-md-1{margin-top:0.25rem !important}.mr-md-1,.mx-md-1{margin-right:0.25rem !important}.mb-md-1,.my-md-1{margin-bottom:0.25rem !important}.ml-md-1,.mx-md-1{margin-left:0.25rem !important}.m-md-2{margin:0.5rem !important}.mt-md-2,.my-md-2{margin-top:0.5rem !important}.mr-md-2,.mx-md-2{margin-right:0.5rem !important}.mb-md-2,.my-md-2{margin-bottom:0.5rem !important}.ml-md-2,.mx-md-2{margin-left:0.5rem !important}.m-md-3{margin:1rem !important}.mt-md-3,.my-md-3{margin-top:1rem !important}.mr-md-3,.mx-md-3{margin-right:1rem !important}.mb-md-3,.my-md-3{margin-bottom:1rem !important}.ml-md-3,.mx-md-3{margin-left:1rem !important}.m-md-4{margin:1.5rem !important}.mt-md-4,.my-md-4{margin-top:1.5rem !important}.mr-md-4,.mx-md-4{margin-right:1.5rem !important}.mb-md-4,.my-md-4{margin-bottom:1.5rem !important}.ml-md-4,.mx-md-4{margin-left:1.5rem !important}.m-md-5{margin:3rem !important}.mt-md-5,.my-md-5{margin-top:3rem !important}.mr-md-5,.mx-md-5{margin-right:3rem !important}.mb-md-5,.my-md-5{margin-bottom:3rem !important}.ml-md-5,.mx-md-5{margin-left:3rem !important}.p-md-0{padding:0 !important}.pt-md-0,.py-md-0{padding-top:0 !important}.pr-md-0,.px-md-0{padding-right:0 !important}.pb-md-0,.py-md-0{padding-bottom:0 !important}.pl-md-0,.px-md-0{padding-left:0 !important}.p-md-1{padding:0.25rem !important}.pt-md-1,.py-md-1{padding-top:0.25rem !important}.pr-md-1,.px-md-1{padding-right:0.25rem !important}.pb-md-1,.py-md-1{padding-bottom:0.25rem !important}.pl-md-1,.px-md-1{padding-left:0.25rem !important}.p-md-2{padding:0.5rem !important}.pt-md-2,.py-md-2{padding-top:0.5rem !important}.pr-md-2,.px-md-2{padding-right:0.5rem !important}.pb-md-2,.py-md-2{padding-bottom:0.5rem !important}.pl-md-2,.px-md-2{padding-left:0.5rem !important}.p-md-3{padding:1rem !important}.pt-md-3,.py-md-3{padding-top:1rem !important}.pr-md-3,.px-md-3{padding-right:1rem !important}.pb-md-3,.py-md-3{padding-bottom:1rem !important}.pl-md-3,.px-md-3{padding-left:1rem !important}.p-md-4{padding:1.5rem !important}.pt-md-4,.py-md-4{padding-top:1.5rem !important}.pr-md-4,.px-md-4{padding-right:1.5rem !important}.pb-md-4,.py-md-4{padding-bottom:1.5rem !important}.pl-md-4,.px-md-4{padding-left:1.5rem !important}.p-md-5{padding:3rem !important}.pt-md-5,.py-md-5{padding-top:3rem !important}.pr-md-5,.px-md-5{padding-right:3rem !important}.pb-md-5,.py-md-5{padding-bottom:3rem !important}.pl-md-5,.px-md-5{padding-left:3rem !important}.m-md-auto{margin:auto !important}.mt-md-auto,.my-md-auto{margin-top:auto !important}.mr-md-auto,.mx-md-auto{margin-right:auto !important}.mb-md-auto,.my-md-auto{margin-bottom:auto !important}.ml-md-auto,.mx-md-auto{margin-left:auto !important}}@media (min-width: 992px){.m-lg-0{margin:0 !important}.mt-lg-0,.my-lg-0{margin-top:0 !important}.mr-lg-0,.mx-lg-0{margin-right:0 !important}.mb-lg-0,.my-lg-0{margin-bottom:0 !important}.ml-lg-0,.mx-lg-0{margin-left:0 !important}.m-lg-1{margin:0.25rem !important}.mt-lg-1,.my-lg-1{margin-top:0.25rem !important}.mr-lg-1,.mx-lg-1{margin-right:0.25rem !important}.mb-lg-1,.my-lg-1{margin-bottom:0.25rem !important}.ml-lg-1,.mx-lg-1{margin-left:0.25rem !important}.m-lg-2{margin:0.5rem !important}.mt-lg-2,.my-lg-2{margin-top:0.5rem !important}.mr-lg-2,.mx-lg-2{margin-right:0.5rem !important}.mb-lg-2,.my-lg-2{margin-bottom:0.5rem !important}.ml-lg-2,.mx-lg-2{margin-left:0.5rem !important}.m-lg-3{margin:1rem !important}.mt-lg-3,.my-lg-3{margin-top:1rem !important}.mr-lg-3,.mx-lg-3{margin-right:1rem !important}.mb-lg-3,.my-lg-3{margin-bottom:1rem !important}.ml-lg-3,.mx-lg-3{margin-left:1rem !important}.m-lg-4{margin:1.5rem !important}.mt-lg-4,.my-lg-4{margin-top:1.5rem !important}.mr-lg-4,.mx-lg-4{margin-right:1.5rem !important}.mb-lg-4,.my-lg-4{margin-bottom:1.5rem !important}.ml-lg-4,.mx-lg-4{margin-left:1.5rem !important}.m-lg-5{margin:3rem !important}.mt-lg-5,.my-lg-5{margin-top:3rem !important}.mr-lg-5,.mx-lg-5{margin-right:3rem !important}.mb-lg-5,.my-lg-5{margin-bottom:3rem !important}.ml-lg-5,.mx-lg-5{margin-left:3rem !important}.p-lg-0{padding:0 !important}.pt-lg-0,.py-lg-0{padding-top:0 !important}.pr-lg-0,.px-lg-0{padding-right:0 !important}.pb-lg-0,.py-lg-0{padding-bottom:0 !important}.pl-lg-0,.px-lg-0{padding-left:0 !important}.p-lg-1{padding:0.25rem !important}.pt-lg-1,.py-lg-1{padding-top:0.25rem !important}.pr-lg-1,.px-lg-1{padding-right:0.25rem !important}.pb-lg-1,.py-lg-1{padding-bottom:0.25rem !important}.pl-lg-1,.px-lg-1{padding-left:0.25rem !important}.p-lg-2{padding:0.5rem !important}.pt-lg-2,.py-lg-2{padding-top:0.5rem !important}.pr-lg-2,.px-lg-2{padding-right:0.5rem !important}.pb-lg-2,.py-lg-2{padding-bottom:0.5rem !important}.pl-lg-2,.px-lg-2{padding-left:0.5rem !important}.p-lg-3{padding:1rem !important}.pt-lg-3,.py-lg-3{padding-top:1rem !important}.pr-lg-3,.px-lg-3{padding-right:1rem !important}.pb-lg-3,.py-lg-3{padding-bottom:1rem !important}.pl-lg-3,.px-lg-3{padding-left:1rem !important}.p-lg-4{padding:1.5rem !important}.pt-lg-4,.py-lg-4{padding-top:1.5rem !important}.pr-lg-4,.px-lg-4{padding-right:1.5rem !important}.pb-lg-4,.py-lg-4{padding-bottom:1.5rem !important}.pl-lg-4,.px-lg-4{padding-left:1.5rem !important}.p-lg-5{padding:3rem !important}.pt-lg-5,.py-lg-5{padding-top:3rem !important}.pr-lg-5,.px-lg-5{padding-right:3rem !important}.pb-lg-5,.py-lg-5{padding-bottom:3rem !important}.pl-lg-5,.px-lg-5{padding-left:3rem !important}.m-lg-auto{margin:auto !important}.mt-lg-auto,.my-lg-auto{margin-top:auto !important}.mr-lg-auto,.mx-lg-auto{margin-right:auto !important}.mb-lg-auto,.my-lg-auto{margin-bottom:auto !important}.ml-lg-auto,.mx-lg-auto{margin-left:auto !important}}@media (min-width: 1200px){.m-xl-0{margin:0 !important}.mt-xl-0,.my-xl-0{margin-top:0 !important}.mr-xl-0,.mx-xl-0{margin-right:0 !important}.mb-xl-0,.my-xl-0{margin-bottom:0 !important}.ml-xl-0,.mx-xl-0{margin-left:0 !important}.m-xl-1{margin:0.25rem !important}.mt-xl-1,.my-xl-1{margin-top:0.25rem !important}.mr-xl-1,.mx-xl-1{margin-right:0.25rem !important}.mb-xl-1,.my-xl-1{margin-bottom:0.25rem !important}.ml-xl-1,.mx-xl-1{margin-left:0.25rem !important}.m-xl-2{margin:0.5rem !important}.mt-xl-2,.my-xl-2{margin-top:0.5rem !important}.mr-xl-2,.mx-xl-2{margin-right:0.5rem !important}.mb-xl-2,.my-xl-2{margin-bottom:0.5rem !important}.ml-xl-2,.mx-xl-2{margin-left:0.5rem !important}.m-xl-3{margin:1rem !important}.mt-xl-3,.my-xl-3{margin-top:1rem !important}.mr-xl-3,.mx-xl-3{margin-right:1rem !important}.mb-xl-3,.my-xl-3{margin-bottom:1rem !important}.ml-xl-3,.mx-xl-3{margin-left:1rem !important}.m-xl-4{margin:1.5rem !important}.mt-xl-4,.my-xl-4{margin-top:1.5rem !important}.mr-xl-4,.mx-xl-4{margin-right:1.5rem !important}.mb-xl-4,.my-xl-4{margin-bottom:1.5rem !important}.ml-xl-4,.mx-xl-4{margin-left:1.5rem !important}.m-xl-5{margin:3rem !important}.mt-xl-5,.my-xl-5{margin-top:3rem !important}.mr-xl-5,.mx-xl-5{margin-right:3rem !important}.mb-xl-5,.my-xl-5{margin-bottom:3rem !important}.ml-xl-5,.mx-xl-5{margin-left:3rem !important}.p-xl-0{padding:0 !important}.pt-xl-0,.py-xl-0{padding-top:0 !important}.pr-xl-0,.px-xl-0{padding-right:0 !important}.pb-xl-0,.py-xl-0{padding-bottom:0 !important}.pl-xl-0,.px-xl-0{padding-left:0 !important}.p-xl-1{padding:0.25rem !important}.pt-xl-1,.py-xl-1{padding-top:0.25rem !important}.pr-xl-1,.px-xl-1{padding-right:0.25rem !important}.pb-xl-1,.py-xl-1{padding-bottom:0.25rem !important}.pl-xl-1,.px-xl-1{padding-left:0.25rem !important}.p-xl-2{padding:0.5rem !important}.pt-xl-2,.py-xl-2{padding-top:0.5rem !important}.pr-xl-2,.px-xl-2{padding-right:0.5rem !important}.pb-xl-2,.py-xl-2{padding-bottom:0.5rem !important}.pl-xl-2,.px-xl-2{padding-left:0.5rem !important}.p-xl-3{padding:1rem !important}.pt-xl-3,.py-xl-3{padding-top:1rem !important}.pr-xl-3,.px-xl-3{padding-right:1rem !important}.pb-xl-3,.py-xl-3{padding-bottom:1rem !important}.pl-xl-3,.px-xl-3{padding-left:1rem !important}.p-xl-4{padding:1.5rem !important}.pt-xl-4,.py-xl-4{padding-top:1.5rem !important}.pr-xl-4,.px-xl-4{padding-right:1.5rem !important}.pb-xl-4,.py-xl-4{padding-bottom:1.5rem !important}.pl-xl-4,.px-xl-4{padding-left:1.5rem !important}.p-xl-5{padding:3rem !important}.pt-xl-5,.py-xl-5{padding-top:3rem !important}.pr-xl-5,.px-xl-5{padding-right:3rem !important}.pb-xl-5,.py-xl-5{padding-bottom:3rem !important}.pl-xl-5,.px-xl-5{padding-left:3rem !important}.m-xl-auto{margin:auto !important}.mt-xl-auto,.my-xl-auto{margin-top:auto !important}.mr-xl-auto,.mx-xl-auto{margin-right:auto !important}.mb-xl-auto,.my-xl-auto{margin-bottom:auto !important}.ml-xl-auto,.mx-xl-auto{margin-left:auto !important}}.text-justify{text-align:justify !important}.text-nowrap{white-space:nowrap !important}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-left{text-align:left !important}.text-right{text-align:right !important}.text-center{text-align:center !important}@media (min-width: 576px){.text-sm-left{text-align:left !important}.text-sm-right{text-align:right !important}.text-sm-center{text-align:center !important}}@media (min-width: 768px){.text-md-left{text-align:left !important}.text-md-right{text-align:right !important}.text-md-center{text-align:center !important}}@media (min-width: 992px){.text-lg-left{text-align:left !important}.text-lg-right{text-align:right !important}.text-lg-center{text-align:center !important}}@media (min-width: 1200px){.text-xl-left{text-align:left !important}.text-xl-right{text-align:right !important}.text-xl-center{text-align:center !important}}.text-lowercase{text-transform:lowercase !important}.text-uppercase{text-transform:uppercase !important}.text-capitalize{text-transform:capitalize !important}.font-weight-light{font-weight:300 !important}.font-weight-normal{font-weight:400 !important}.font-weight-bold{font-weight:700 !important}.font-italic{font-style:italic !important}.text-white{color:#fff !important}.text-primary{color:#008cba !important}a.text-primary:hover,a.text-primary:focus{color:#006687 !important}.text-secondary{color:#eee !important}a.text-secondary:hover,a.text-secondary:focus{color:#d5d4d4 !important}.text-success{color:#43ac6a !important}a.text-success:hover,a.text-success:focus{color:#358753 !important}.text-info{color:#5bc0de !important}a.text-info:hover,a.text-info:focus{color:#31b0d5 !important}.text-warning{color:#E99002 !important}a.text-warning:hover,a.text-warning:focus{color:#b67102 !important}.text-danger{color:#F04124 !important}a.text-danger:hover,a.text-danger:focus{color:#d32a0e !important}.text-light{color:#eee !important}a.text-light:hover,a.text-light:focus{color:#d5d4d4 !important}.text-dark{color:#222 !important}a.text-dark:hover,a.text-dark:focus{color:#090808 !important}.text-muted{color:#888 !important}.text-hide{font:0/0 a;color:transparent;text-shadow:none;background-color:transparent;border:0}.visible{visibility:visible !important}.invisible{visibility:hidden !important}@media print{*,*::before,*::after{text-shadow:none !important;-webkit-box-shadow:none !important;box-shadow:none !important}a:not(.btn){text-decoration:underline}abbr[title]::after{content:" (" attr(title) ")"}pre{white-space:pre-wrap !important}pre,blockquote{border:1px solid #999;page-break-inside:avoid}thead{display:table-header-group}tr,img{page-break-inside:avoid}p,h2,h3{orphans:3;widows:3}h2,h3{page-break-after:avoid}@page{size:a3}body{min-width:992px !important}.container{min-width:992px !important}.navbar{display:none}.badge{border:1px solid #000}.table{border-collapse:collapse !important}.table td,.table th{background-color:#fff !important}.table-bordered th,.table-bordered td{border:1px solid #ddd !important}}.navbar{font-size:0.8203125rem;font-weight:300}.bg-primary .dropdown-menu{background-color:#008cba}.bg-primary .dropdown-menu .dropdown-item,.bg-primary .dropdown-menu .dropdown-item:focus{color:rgba(255,255,255,0.7)}.bg-primary .dropdown-menu .dropdown-item.active,.bg-primary .dropdown-menu .dropdown-item:hover,.bg-primary .dropdown-menu .dropdown-item:focus{background-color:#0079a1;color:#fff}.bg-dark{background-color:#333 !important}.bg-dark .dropdown-menu{background-color:#333}.bg-dark .dropdown-menu .dropdown-item,.bg-dark .dropdown-menu .dropdown-item:focus{color:rgba(255,255,255,0.7)}.bg-dark .dropdown-menu .dropdown-item.active,.bg-dark .dropdown-menu .dropdown-item:hover,.bg-dark .dropdown-menu .dropdown-item:focus{background-color:#262626;color:#fff}.bg-light .dropdown-menu{background-color:#eee}.bg-light .dropdown-menu .dropdown-item,.bg-light .dropdown-menu .dropdown-item:focus{color:rgba(0,0,0,0.5)}.bg-light .dropdown-menu .dropdown-item.active,.bg-light .dropdown-menu .dropdown-item:hover,.bg-light .dropdown-menu .dropdown-item:focus{background-color:#fbfbfb;color:rgba(0,0,0,0.7)}.btn-primary{border-color:#0079a1}.btn-secondary{border-color:#e1e1e1}.btn-success{border-color:#3c9a5f}.btn-info{border-color:#46b8da;color:#fff}.btn-danger{border-color:#ea2f10}.btn-warning{border-color:#d08002;color:#fff}.btn-light{border-color:#e1e1e1}.btn-dark{border-color:#151515}.btn-group .dropdown-menu{border-top-width:0}.btn-group .dropdown-toggle.btn-primary ~ .dropdown-menu{background-color:#008cba;border-color:#0079a1}.btn-group .dropdown-toggle.btn-primary ~ .dropdown-menu .dropdown-item{color:#fff}.btn-group .dropdown-toggle.btn-primary ~ .dropdown-menu .dropdown-item:hover,.btn-group .dropdown-toggle.btn-primary ~ .dropdown-menu .dropdown-item:focus{background-color:#006d91}.btn-group .dropdown-toggle.btn-secondary ~ .dropdown-menu{background-color:#eee;border-color:#e1e1e1}.btn-group .dropdown-toggle.btn-secondary ~ .dropdown-menu .dropdown-item{color:#fff}.btn-group .dropdown-toggle.btn-secondary ~ .dropdown-menu .dropdown-item:hover,.btn-group .dropdown-toggle.btn-secondary ~ .dropdown-menu .dropdown-item:focus{background-color:#dadada}.btn-group .dropdown-toggle.btn-success ~ .dropdown-menu{background-color:#43ac6a;border-color:#3c9a5f}.btn-group .dropdown-toggle.btn-success ~ .dropdown-menu .dropdown-item{color:#fff}.btn-group .dropdown-toggle.btn-success ~ .dropdown-menu .dropdown-item:hover,.btn-group .dropdown-toggle.btn-success ~ .dropdown-menu .dropdown-item:focus{background-color:#388f58}.btn-group .dropdown-toggle.btn-info ~ .dropdown-menu{background-color:#5bc0de;border-color:#46b8da}.btn-group .dropdown-toggle.btn-info ~ .dropdown-menu .dropdown-item{color:#fff}.btn-group .dropdown-toggle.btn-info ~ .dropdown-menu .dropdown-item:hover,.btn-group .dropdown-toggle.btn-info ~ .dropdown-menu .dropdown-item:focus{background-color:#39b3d7}.btn-group .dropdown-toggle.btn-warning ~ .dropdown-menu{background-color:#E99002;border-color:#d08002}.btn-group .dropdown-toggle.btn-warning ~ .dropdown-menu .dropdown-item{color:#fff}.btn-group .dropdown-toggle.btn-warning ~ .dropdown-menu .dropdown-item:hover,.btn-group .dropdown-toggle.btn-warning ~ .dropdown-menu .dropdown-item:focus{background-color:#c17702}.btn-group .dropdown-toggle.btn-danger ~ .dropdown-menu{background-color:#F04124;border-color:#0079a1}.btn-group .dropdown-toggle.btn-danger ~ .dropdown-menu .dropdown-item{color:#fff}.btn-group .dropdown-toggle.btn-danger ~ .dropdown-menu .dropdown-item:hover,.btn-group .dropdown-toggle.btn-danger ~ .dropdown-menu .dropdown-item:focus{background-color:#dc2c0f}.blockquote-footer{color:#888}table{font-size:0.8203125rem}.table-success,.table-info,.table-warning,.table-danger{color:#fff}.table-success,.table-success>th,.table-success>td{background-color:#43ac6a}.table-info,.table-info>th,.table-info>td{background-color:#5bc0de}.table-danger,.table-danger>th,.table-danger>td{background-color:#F04124}.table-warning,.table-warning>th,.table-warning>td{background-color:#E99002}.table-hover .table-success:hover,.table-hover .table-success:hover>th,.table-hover .table-success:hover>td{background-color:#3c9a5f}.table-hover .table-info:hover,.table-hover .table-info:hover>th,.table-hover .table-info:hover>td{background-color:#46b8da}.table-hover .table-danger:hover,.table-hover .table-danger:hover>th,.table-hover .table-danger:hover>td{background-color:#ea2f10}.table-hover .table-warning:hover,.table-hover .table-warning:hover>th,.table-hover .table-warning:hover>td{background-color:#d08002}label,.control-label,.help-block,.checkbox,.radio,.form-control-feedback{font-size:0.8203125rem}.dropdown-item{padding-top:0.75rem;padding-bottom:0.75rem;font-size:0.8203125rem;font-weight:300}.nav-tabs .nav-link,.nav-tabs .nav-link.disabled,.nav-tabs .nav-link.disabled:hover,.nav-tabs .nav-link.disabled:focus{border-color:rgba(0,0,0,0.1);background-color:#eee}.nav-tabs .nav-link:hover,.nav-tabs .nav-link:focus{background-color:#fbfbfb}.nav-pills .active{border:1px solid #0079a1}.breadcrumb{border:1px solid rgba(0,0,0,0.1);border-radius:3px;font-size:0.8203125rem;font-weight:300;text-transform:uppercase}.pagination{font-weight:300}.pagination .page-link{border-color:transparent;border-radius:3px;margin-left:0.1em;margin-right:0.1em}.pagination .page-link:hover,.pagination .page-link:focus{text-decoration:none}.pagination .page-item.disabled .page-link{border-color:transparent}.list-group{font-size:0.8203125rem;font-weight:300}.close{opacity:0.6;text-shadow:none}.close:hover,.close:focus{opacity:1}.alert{font-size:0.8203125rem;font-weight:300;color:#fff}.alert-primary,.alert-primary>th,.alert-primary>td{background-color:#008cba}.alert-secondary,.alert-secondary>th,.alert-secondary>td{background-color:#eee}.alert-success,.alert-success>th,.alert-success>td{background-color:#43ac6a}.alert-info,.alert-info>th,.alert-info>td{background-color:#5bc0de}.alert-danger,.alert-danger>th,.alert-danger>td{background-color:#F04124}.alert-warning,.alert-warning>th,.alert-warning>td{background-color:#E99002}.alert-dark,.alert-dark>th,.alert-dark>td{background-color:#222}.alert-light,.alert-light>th,.alert-light>td{background-color:#eee}.alert .alert-link{font-weight:normal;color:#fff;text-decoration:underline}.alert-secondary,.alert-secondary a:not(.btn),.alert-secondary .alert-link,.alert-light,.alert-light a:not(.btn),.alert-light .alert-link{color:#222}.badge{padding-bottom:.3em}.badge-warning,.badge-info{color:#fff}.progress[value]{height:22px;padding:2px;background-color:#f6f6f6;border:1px solid #ccc} + diff --git a/vizapp/www/style.css b/vizapp/www/style.css index f625c9d..cd2a65d 100755 --- a/vizapp/www/style.css +++ b/vizapp/www/style.css @@ -1,3 +1,7 @@ +body { + /* Margin bottom by footer height */ + margin-bottom: 60px; +} label.radio { padding-left: 18px; padding-right: 0px; @@ -137,7 +141,7 @@ input[type="number"] { float: right; } -div.busy { +.busy { position:absolute; top: 40%; left: 50%; @@ -146,9 +150,164 @@ div.busy { display:none; background: rgba(230, 230, 230, .8); text-align: center; - padding-top: 20px; - padding-left: 30px; - padding-bottom: 40px; - padding-right: 30px; + padding:20px 30px 40px 30px; border-radius: 5px; +} + +.card{ + max-height:100%; + display: flex; + padding-top:0; + flex-direction: column; + position:relative; + display:-webkit-box; + display:-ms-flexbox; + display:flex; + -webkit-box-orient:vertical; + -webkit-box-direction:normal; + -ms-flex-direction:column; + flex-direction:column; + min-width:0; + word-wrap:break-word; + background-color:#fff; + background-clip:border-box; + border:1px solid rgba(0,0,0,0.125); + border-radius:0 +} + +.card>hr{margin-right:0;margin-left:0} +.card>.list-group:first-child .list-group-item:first-child{border-top-left-radius:0;border-top-right-radius:0} +.card>.list-group:last-child .list-group-item:last-child{border-bottom-right-radius:0;border-bottom-left-radius:0} +.card-body{-webkit-box-flex:1;-ms-flex:1 1 auto;flex:1 1 auto;padding:1.25rem}.card-title{margin-bottom:0.75rem}.card-subtitle{margin-top:-0.375rem;margin-bottom:0}.card-text:last-child{margin-bottom:0} +.card-link:hover{text-decoration:none} +.card-link+.card-link{margin-left:1.25rem} +.card-header{padding:0.75rem 1.25rem;margin-bottom:0;background-color:rgba(0,0,0,0.03);border-bottom:1px solid rgba(0,0,0,0.125)}.card-header:first-child{border-radius:calc(0 - 1px) calc(0 - 1px) 0 0} +.card-header+.list-group .list-group-item:first-child{border-top:0} +.card-footer{ margin-top: auto;padding:0.75rem 1.25rem;background-color:rgba(0,0,0,0.03);border-top:1px solid rgba(0,0,0,0.125)} +.card-footer:last-child{border-radius:0 0 calc(0 - 1px) calc(0 - 1px)} +.card-header-tabs{margin-right:-0.625rem;margin-bottom:-0.75rem;margin-left:-0.625rem;border-bottom:0} +.card-header-pills{margin-right:-0.625rem;margin-left:-0.625rem} +.card-img-overlay{position:absolute;top:0;right:0;bottom:0;left:0;padding:1.25rem} +.card-img{width:100%;border-radius:calc(0 - 1px)} +.card-img-top{width:100%;border-top-left-radius:calc(0 - 1px);border-top-right-radius:calc(0 - 1px)} +.card-img-bottom{width:100%;border-bottom-right-radius:calc(0 - 1px);border-bottom-left-radius:calc(0 - 1px)} +.card-deck{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column} +.card-deck .card{margin-bottom:15px} +@media (min-width: 760px){ + .card{ + height:600px; + } +} +@media (min-width: 900px){ + .card{ + height:500px; + } +} +@media (min-width: 1100px){ + .card{ + height:400px; + } +} +@media (min-width:1350px){ + .card{ + height:330px; + } +} +@media (min-width: 576px){ + .card-deck{ + -webkit-box-orient:horizontal; + -webkit-box-direction:normal; + -ms-flex-flow:row wrap; + flex-flow:row wrap; + margin-right:-15px;margin-left:-15px} + .card-deck .card{ + display:-webkit-box; + display:-ms-flexbox; + display:flex;-webkit-box-flex:1; + -ms-flex:1 0 0; + flex:1 0 0; + -webkit-box-orient:vertical; + -webkit-box-direction:normal; + -ms-flex-direction:column; + flex-direction:column; + margin-right:15px; + margin-bottom:0;margin-left:15px + } +} +.card-group{ + display:-webkit-box; + display:-ms-flexbox; + display:flex;-webkit-box-orient:vertical; + -webkit-box-direction:normal; + -ms-flex-direction:column;flex-direction:column + +} + .card-group>.card{margin-bottom:15px} + +@media (min-width: 576px){ + .card-group{-webkit-box-orient:horizontal; + -webkit-box-direction:normal; + -ms-flex-flow:row wrap;flex-flow:row wrap} + .card-group>.card{ + -webkit-box-flex:1; + -ms-flex:1 0 0; + flex:1 0 0;margin-bottom:0 + } + .card-group>.card+.card{ + margin-left:0;border-left:0 + } + .card-group>.card:first-child{ + border-top-right-radius:0;border-bottom-right-radius:0} + .card-group>.card:first-child + .card-img-top,.card-group>.card:first-child + .card-header{border-top-right-radius:0} + .card-group>.card:first-child .card-img-bottom,.card-group>.card:first-child .card-footer{border-bottom-right-radius:0} + .card-group>.card:last-child{border-top-left-radius:0;border-bottom-left-radius:0} + .card-group>.card:last-child .card-img-top,.card-group>.card:last-child .card-header{border-top-left-radius:0} + .card-group>.card:last-child .card-img-bottom,.card-group>.card:last-child .card-footer{border-bottom-left-radius:0} + .card-group>.card:only-child{border-radius:0} + .card-group>.card:only-child .card-img-top,.card-group>.card:only-child .card-header{ + border-top-left-radius:0; + border-top-right-radius:0 + } + .card-group>.card:only-child .card-img-bottom,.card-group>.card:only-child .card-footer{ + border-bottom-right-radius:0; + border-bottom-left-radius:0 + }.card-group>.card:not(:first-child):not(:last-child):not(:only-child){border-radius:0} + .card-group>.card:not(:first-child):not(:last-child):not(:only-child) .card-img-top,.card-group>.card:not(:first-child):not(:last-child):not(:only-child) .card-img-bottom,.card-group>.card:not(:first-child):not(:last-child):not(:only-child) .card-header,.card-group>.card:not(:first-child):not(:last-child):not(:only-child) .card-footer{border-radius:0} +} + .card-columns .card{margin-bottom:0.75rem} + + @media (min-width: 576px){ + .card-columns{ + -webkit-column-count:3;column-count:3; + -webkit-column-gap:1.25rem;column-gap:1.25rem} + .card-columns .card{display:inline-block;width:100%;} + } + +.footer { + position: absolute; + bottom: 0; + width: 100%; + /* Set the fixed height of the footer here */ + height: 60px; + line-height: 60px; /* Vertically center the text there */ + background-color: #f5f5f5; +} +body > .container { + padding: 60px 15px 0; +} + +.footer > .container { + padding-right: 15px; + padding-left: 15px; +} + html { + position: relative; + min-height: 100%; +} +.centerbtn{ + width: 130px; + text-align: center; + margin:0 auto; } \ No newline at end of file -- GitLab