:root {
    --background-color: darkslategray;
    --main-color: paleturquoise;
    --accent-color: mediumslateblue;
    --accent-opposite: rgb(250, 215, 15);
    --nav-font-size: 1.4em;
    --main-font-size: 1.1em;
    --transition-time: .8s;
    --margin: 10px;
    --margin-body: 20px;
    --logo-font-size: xxx-large;
    --subtitle-font-weight: 600;
    --button-background-color: dimgray;
    --button-hover-color: darkslategray
}

/****** Main Styles ******/

body {
    margin:var(--margin-body);
    margin-top: 0px;
    background-color :var(--background-color);
    color: var(--main-color);
    font-family: 'Montserrat', Helvetica, sans-serif;
}

h1 {
    display: flex;
    justify-content: center;
}

h2 {
    margin-left: 70px;
}


h3 {
    /* margin-left: 20px; */
    display: flex;
    justify-content: center;
}

.container {
    display: grid;
    grid-template-columns: 1fr; /* fractional unit */
}

.content {
    font-size: var(--main-font-size);
    margin-left: var(--margin-body);
    margin-right: var(--margin-body);
}

p { 
    font-size: var(--main-font-size);
    text-indent: 2em;
}

a {
    color: var(--main-color);
    transition: color var(--transition-time);
}

a:hover {
    color: var(--accent-color);
}

.note {
    font-size: .9em !important;
}

/****** Nav Styles ******/

.left {
    display: flex;
}

.right {
    display: flex;
    font-weight: 300;
}

.brand {
    margin-right: var(--margin);
    /* display: flex; */
    font-size: var(--nav-font-size);
}

.nav {
    display: flex;
    font-weight: 550;
    justify-content:space-between;
    text-transform: capitalize;
    margin: var(--margin);
}

.nav > .left > div {
    margin-right: 20px;
    font-size: var(--nav-font-size);
}

.nav-link {
    height: 22px;
    border-bottom: 2px solid transparent; /*hidden underline is necessary to stop stuff shifting around or jarring pop-in when visible one appears */
    transition: border-bottom var(--transition-time);
    margin-inline: var(--margin);
    font-size: var(--nav-font-size);
}

.nav-link:hover { /*this is a psuedo state*/
    border-bottom: 2px solid var(--accent-color);/*this is the definition of the bottom border once it becomes visible*/
}

.nav-link a {
    color: var(--main-color);
    text-decoration: none;
    transition: color var(--transition-time)
}

.nav-link a:hover {
    color: var(--accent-color);
}

/****** Portfolio Styles ******/
.portfolio-items {
    margin-left: calc(-1 * var(--margin-body));
    margin-right: calc(-1 * var(--margin-body));
    display: grid;
    grid-template-columns: 1fr 1fr; /* Add more for more portfolio item columns */
}

.portfolio-item {
    position: relative;
}

.portfolio-background {
    filter:brightness(.5);
    height: 500px;
    width: 100%;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.portfolio-content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
}

.portfolio-logo { /* This is for text-based logos */
    font-weight: 700;
    color: var(--main-color);
    font-size:var(--logo-font-size);
}

.portfolio-logo img {
    width: 50%;
    margin-bottom: 10px;
}

.portfolio-content .portfolio-subtitle {
    font-weight: var(--subtitle-font-weight);
    transition: 1s;
    font-size:var(--nav-font-size);
    /* margin: 10rem; */
    color: transparent;
}

.portfolio-content:hover .portfolio-subtitle {
    font-weight: var(--subtitle-font-weight);
    color: var(--main-color)
}

.img-darken { /* Use JavaScript to call this on hover events */
    transition: 1s;
    filter: brightness(.2);
}

.centered-image{
    display: block;
    margin-left: auto;
    margin-right: auto;
    width: 250px;
}

.two-column-section{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin-bottom: 60px;
    /* margin-left: 20px;
    margin-right: 20px; */
}

.two-column-text{
    display: flex;
    flex-direction: column;
    align-items:center;
    justify-content:start;
}

.two-column-image{
    display: flex;
    align-items: center;
    justify-content: center;
    /* margin:  40px; */
}

.centered h2 {
    display: flex;
    justify-content: center;
    margin-top: 0px;
    margin-bottom: 0px;
}

/* Geometry Generator Styles */
.svg-container{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

#svg-output{

}

svg{
    /* margin-top: var(--margin-body);
    margin-bottom: var(--margin-body); */
}

polygon{
    fill:none;
    stroke: var(--accent-opposite);
    stroke-width: 1px;
}

.ͼm{
    /* This is the PyScript comment style */
    color:var(--accent-opposite) !important;
}

/***** About Page Styles ****/
.columns {
    display: grid;
    grid-template-columns: 1fr 1fr;
    /* border: 1px solid rgb(255, 0, 0); */
    /* padding-right: 60px; */
    /* column-gap: 50; */
    padding-right: 0px;
    padding-left: 0px;

}

@media (max-width: 200px) {
    .columns {
        grid-template-columns: 1fr;
        grid-template-rows: auto auto;
    }
    
}

.column {
    display: flex;
    flex-wrap: wrap; /* this fixes children of column having flex and being in a single row */
    justify-content: center;
    align-content: start;
    /* border: 1px solid black; */
}

.profile-img img {
    max-width: 500px; /*% refers to grid*/
    /* border: 1px solid black; */
}

.profile-content h1 {
    color: var(--main-color);
}

/* Bebop Style */

input[type = "radio"]{
opacity: 0;
width: 0;
margin: 0;
}

input[type = "radio"]:checked + label.radioLabel{ /*Selected button*/
    outline-color: var(--accent-color);
	outline-style: solid;
	background-color: var(--button-background-color);

}
label.radioLabel:hover {
	background-color: var(--button-hover-color);
}
label.radioLabel {
	outline-color: var(--main-color);
	outline-style: solid;
	background-color: var(--button-background-color);
	box-sizing: border-box;
	padding:5px;
    margin: 7px;
	position: relative;
	line-height: 20px;
	display: inline-block;
	margin-top: 15px;
	transition:1s;
}

.button:hover {
	background-color: var(--button-hover-color);
}

#runBebop{
    display: flex;
    justify-content: center;
}

.button {
    font-size: 1.5em;
    font-weight: 1000;
    display: flex !important;
    justify-content: center !important; 
    width: 200px;
    border: 0px;
	outline-color: var(--main-color);
	outline-style: solid;
	background-color: var(--button-background-color);
	color:var(--main-color);
	padding:3px;
	/* line-height: 20px; */
	margin-top: 15px;
	transition: 1s;
}