/* Global Variables */
:root {
    --face-opacity: 90%;
    --flip-opacity: 100%;
} 

/* Page Globals */
body {
    /*background-color: #333333;
    color: #FFFFFF;*/
    margin: 0;
    width: 100%;
    height: 100%;
    
    font-family: "Raleway", sans-serif;
    font-weight: 400;

    background-color: #eeeeee; /* deep base */
    color: #05070d; /* adjust depending on overlay text */
    position: relative;
}

/* Page Sections */
header {
    position: fixed;
    top: 0;
    background-color: #05070d;
    z-index: 999;
    width: 100%;
    box-sizing: border-box;
    padding-top: 1vw;
    padding-bottom: 1vw;
    padding-left: 2vw;
    padding-right: 2vw;
    pointer-events: auto;
    border-bottom: 1px solid #FFFFFF;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: nowrap;
}

nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
}

nav ul {
    display: flex;
    gap: 2rem;
    justify-content: flex-end;
    list-style-type: none;
    margin: 0;
    padding: 0;
}

nav ul li {
    margin: 0;
    padding: 0;
}

nav ul li a {
    display: inline-flex;
    color: #FFFFFF;
    text-decoration: none;
}

nav ul li a:hover {
    color: #FFA500;
}

#headerContact {
    width: 20%;
    text-align: right;
}

main {
    position: relative;
    top: 80px;
    z-index: 2;
    width: 100%;
    box-sizing: border-box;
    padding-top: 1vw;
    padding-bottom: 1vw;
    padding-left: 2vw;
    padding-right: 2vw;
    pointer-events: auto;
    display: grid;
    grid-template-columns: repeat(12, 1fr);
}

section {
    grid-column: 1 / span 12;
    display: grid;
    grid-template-columns: subgrid;
    border-bottom: 1px dotted #05070d;
}

/*#about {

}

#experience {

}

#work {

}*/

.section-head {
    grid-column: 1 / span 4;
    text-align: left;
    position: sticky;
    top: 80px;
    align-self: start;
    z-index: 10;
    background-color: #eeeeee;
    padding-top: 1vw;
}

.section-body {
    grid-column: auto / span 8;
    display: flex;
    flex-wrap: wrap;
}

.list-section-head {
    grid-column: 1 / span 4;
    text-align: left;
    position: sticky;
    top: 80px;
    align-self: start;
    z-index: 10;
    background-color: #eeeeee;
    padding-top: 1vw;
}

.list-section-body {
    grid-column: auto / span 8;
    display: flex;
    flex-wrap: wrap;
}

.container {
    min-height: 250px;
    height: auto;
    display: flex;
    flex-wrap: wrap;

    justify-content: center;
    flex-grow: 1;
    margin-top: 4px;
    margin-bottom: 4px;
    margin-left: 4px;
    padding: 4px;
    min-width: 250px;
    text-align: center;
    opacity: var(--face-opacity);
    color: #FFFFFF;
}

.about-container {
    justify-content: flex-start;
    align-items: flex-start;
    text-align: left;
    width: 100%;
    background-color: #05070d;
    padding: 48px;
    min-height: auto;
    height: auto;
}

.about-content {
    width: 100%;
    max-width: 800px;
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.about-content p {
    margin: 0;
    line-height: 1.6;
}

.about-content .intro {
    font-size: 18px;
    font-weight: 400;
    letter-spacing: 0.3px;
}

.about-content .focus {
    font-size: 16px;
    font-weight: 300;
    opacity: 0.95;
    border-left: 3px solid #FFA500;
    padding-left: 20px;
}

.experience-container {
    justify-content: flex-start;
    align-items: flex-start;
    width: 100%;
    padding: 24px;
    text-align: left;
    min-height: auto;
    height: auto;
}

.experience-content {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.experience-content h3 {
    margin: 0 0 12px 0;
    font-size: 20px;
    font-weight: 600;
}

.role {
    display: flex;
    flex-direction: column;
    gap: 2px;
    margin-bottom: 4px;
}

.role .dates {
    font-size: 12px;
    opacity: 0.8;
    font-weight: 500;
}

.role .title {
    font-size: 14px;
    line-height: 1.4;
}

#atlassian {
    /*background-color: #0C66E4;
    color: #FFFFFF;*/

    background: #172B4D; /* deep blue base */
    background-image:
        linear-gradient(135deg, rgba(76,154,255,0.70) 0%, rgba(0,184,217,0.40) 100%);
    position: relative;
    color: #ffffff; /* for overlay text */
}

#sierra-space {
    background: #0d0f14; /* dark base */
    background-image:
        radial-gradient(circle at 20% 80%, rgba(11,197,179,0.35) 0%, transparent 80%),
        linear-gradient(135deg, rgba(0,170,255,0.15) 0%, transparent 70%);
    /* optionally add subtle star noise overlay */
    /* background-image: url('starfield.png'), ...; */
    position: relative;
    color: #ffffff;
}

#splunk {
    background: #0C1724; /* dark base */
    background-image:
        radial-gradient(circle at 30% 30%, rgba(255,94,94,0.6) 0%, transparent 70%),
        linear-gradient(135deg, rgba(255,94,94,0.4) 0%, rgba(255,165,0,0.4) 100%);
    position: relative;
    color: #ffffff; /* overlay text */
}

#american-airlines {
    background: #FFFFFF; /* white base */
    background-image:
        linear-gradient(135deg, rgba(0,120,210,0.4) 0%, rgba(195,0,25,0.3) 100%);
    background-blend-mode: normal;
    position: relative;
    color: #36495A; /* overlay text dark */
}

.education-container {
    justify-content: flex-start;
    align-items: flex-start;
    width: 100%;
    padding: 24px;
    text-align: left;
    min-height: auto;
    height: auto;
}

.education-content {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.education-content h3 {
    margin: 0 0 12px 0;
    font-size: 20px;
    font-weight: 600;
}

.degree {
    display: flex;
    flex-direction: column;
    gap: 2px;
    margin-bottom: 8px;
}

.degree .dates {
    font-size: 12px;
    opacity: 0.8;
    font-weight: 500;
}

.degree .program {
    font-size: 14px;
    line-height: 1.4;
}

.activities {
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-size: 13px;
    opacity: 0.9;
}

#cu {
    background: #000000; /* black base */
    background-image:
        radial-gradient(circle at 30% 70%, rgba(207,184,124,0.35) 0%, transparent 80%),
        linear-gradient(135deg, rgba(86,90,92,0.20) 0%, transparent 70%);
    position: relative;
    color: #FFFFFF; /* overlay text in white */
}

#tamu {
    background: #500000; /* Aggie Maroon base */
    background-image:
        radial-gradient(circle at 20% 20%, rgba(80,0,0,0.6) 0%, transparent 70%);
    position: relative;
    color: #ffffff; /* overlay text colour */
}

.work-container {
    width: 45%;
    justify-content: center;
    align-items: center;
    background-color: #05070d;
    text-align: center;
}

footer {
    position: fixed;
    bottom: 0;
    background-color: #05070d;
    z-index: 999;
    width: 100%;
    box-sizing: border-box;
    padding-top: 1vw;
    padding-bottom: 1vw;
    padding-left: 2vw;
    padding-right: 2vw;
    pointer-events: auto;
    border-top: 1px solid #FFFFFF;
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
    flex: 1 0 67%;
    font-size: 10px;
}

/* Heading Styles */
h1 {
    width: 20%;
    font-size: 18px;
    font-weight: 600;
}

h1 a {
    color: #FFFFFF;
    text-decoration: none;
}

h2 {
    font-size: 20px;
    font-weight: 500;
    text-decoration: none;
}

h3 {
    font-size: 16px;
    font-weight: 400;
}