.grid-3,
.grid-8,
.section-top,
.section-bottom,
.blib,
.footer,
.hero-profile,
.text-section {
  position: relative;
  z-index: 1;
}


/*SCROLL BAR */

/* Chrome, Edge, Safari */
::-webkit-scrollbar {
  width: 8px;
}

::-webkit-scrollbar-track {
  background: #000000;
}

::-webkit-scrollbar-thumb {
  background: #a020f0;
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: #c040ff;
}

/* Firefox */
* {
  scrollbar-width: thin;
  scrollbar-color: #a020f0 #000000;
}

/*FONT SECTION*/
.oswald-<uniquifier> {
  font-family: "Oswald", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
}
.great-vibes-regular {
  font-family: "Great Vibes", cursive;
  font-style: normal;
}
.delius-regular {
  font-family: "Delius", cursive;
  font-weight: 400;
  font-style: normal;
}


.open-sans- uniquifier {
  font-family: "Open Sans", sans-serif;
  font-optical-sizing: auto;
  font-weight: weight;
  font-style: normal;
  font-variation-settings:
    "wdth" 100;
}

/*End of Font section */


h2 {
	font-family: "Great Vibes", cursive; 
  letter-spacing: 0.9px;
	font-weight: 200;
	font-size: 2.5em;
	text-transform: capitalize;
	color:ghostwhite;
	padding-top:20px;
}
p {
	font-family: system-ui, BlinkMacSystemFont,
"Segoe UI", Roboto, sans-serif;
	 line-height: 1.8;
  letter-spacing: 0.2px;
  color: ghostwhite;
  max-width: 60ch;
  -webkit-font-smoothing: antialiased;
	margin:0;
	text-align: left;
  max-width: 60ch;
	
	
}


/*Header section!! */
.nav-logo {
  color: #a020f0;
  font-size: 23px;
  font-weight: 750;
  z-index: 999;
  position: relative;
  margin-right: auto;
  margin-left: -5px;
}

.nav-buttons {
  margin-left: auto;
  position: relative;
  z-index: 999;
  display: flex;
  flex-direction: row;
  align-items: right;
  padding-top: 3px;
  pointer-events: all;
  margin-bottom: 15px;
	padding-bottom: 5px;
}

.nav-buttons a {
  position: relative;
  display: inline-block;
  color: rgba(255, 255, 255, 0.75);
  background: transparent;
  text-decoration: none;
  padding: 6px 16px;
  transition: color 0.4s ease;
}

.nav-buttons a.active {
  color: #a020f0;
	transition: color 0.5s ease;
}

.nav-buttons a:hover {
  color: #a020f0;
  transition: color 0.4s ease;
}

/* the sliding line */
.nav-indicator {
  position: absolute;
  bottom: 0;
  height: 2px;
 background-color:#a020f0; 
  border-radius: 2px;
  transition: left 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              width 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  box-shadow: 0 0 8px rgba(160, 32, 240, 0.8),
              0 0 20px rgba(160, 32, 240, 0.4);
  pointer-events: none;
}
.satisfy-regular {
  font-family: "Satisfy", cursive;
  font-weight: 100;
  font-style: normal;
  z-index: 20; 
  font-size:25px;
}
.header {
	text-align: center;
	position: sticky;
	top: 0;
	z-index: 100;
	height: auto;
	min-height: 50px;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	width:100%;
	padding: 0 40px;
	box-sizing: border-box;
	overflow:hidden;
	border-bottom: thick 50px red;
	
}

#backdrop {
    position: absolute;
    inset: 0;
    height:150px;
    border-radius: 4px;
   background: rgba(5, 0, 15, 0.75);
    pointer-events: none !important;
   backdrop-filter: blur(5px) brightness(60%) saturate(120%);
  -webkit-backdrop-filter: blur(5px) brightness(60%) saturate(120%);
 
	/* mask-image: linear-gradient(
    to bottom,
    black 0,
    black 50%,
    transparent 50%
  );	*/
  }

.backdrop-edge {
 position: absolute;
  left: 0;
  right: 0;
  top: 40%;
  height: 1px;
  background: rgba(160, 32, 240, 0.2);
  /* box-shadow: 0 0 20px rgba(160, 32, 240, 0.6),
              0 0 20px rgba(160, 32, 240, 0.3); */
  pointer-events: none;
  z-index: 1;
	
}


	
	.hero-profile {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 55px 20px;
	position: relative;
  z-index: 2;
}

.profile-image img {
  width: 180px;
  height: 180px;
  border-radius: 50%; 
  object-fit: cover;
   border: 2px solid #a020f0;
  box-shadow: 0 0 8px rgba(160, 32, 240, 0.9),
              0 0 20px rgba(160, 32, 240, 0.7),
              0 0 40px rgba(160, 32, 240, 0.5),
              0 0 80px rgba(160, 32, 240, 0.3),
              inset 0 0 15px rgba(255, 255, 255, 0.05);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  
}

.hero-name {
  margin-top: 20px;
  font-size: 2rem;
  font-weight: 700;
  font-family: "system-ui", -apple-system;
 
}

.hero-subtitle {
  margin-top: 10px;
  font-size: 1rem;
  opacity: 0.8;
	font-family: system-ui, -apple-system;
}

.social-icons {
  display: flex;
  gap: 20px;
  
}

.social-icons img {
  width: 40px;
  height: 40px;
  transition: 0.3s;
}

.social-icons img:hover {
  transform: scale(1.1);
}

/*END of Header section!! */

/*BODY SECTION */

body {
  margin: 0;
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont,
               "Segoe UI", Roboto, sans-serif;
  position: relative;
  background: #000000;
  min-height: 100vh;
  transform-style: flat;
  overflow-x: hidden;
}

body::after {
  content: '';
  position: fixed;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 80% 100%, rgba(160, 32, 240, 0.18) 0%, transparent 70%),
    radial-gradient(ellipse 60% 50% at 20% 80%, rgba(75, 0, 130, 0.15) 0%, transparent 65%),
    radial-gradient(ellipse 50% 40% at 50% 20%, rgba(100, 0, 180, 0.08) 0%, transparent 60%);
  filter: blur(40px);
  z-index: -1;
  pointer-events: none;
}

section .footer{
  position: relative;
  z-index: 1;
}
/* 8-column grid */
/* general row spacing */
.row {
  width: 100%;
  padding: 40px;
  box-sizing: border-box;
position:relative;
	 z-index: 1;

}


.row footer {
  background:#dddcc;
  text-align: center;
	padding: 20px 40px;
  position: relative;
  z-index: 2;
}

/* 3 COLUMN ROW */
.grid-3 {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 50px;
	justify-items:center;
}
/* Header style */
.grid-3 h1{
	margin: auto;
	margin-left: 350px;
}

.grid-3 #img1{
	width:350px;
	height:250px;
	border-radius:15px;
	margin:auto;
	position:relative;
	overflow: hidden;
	background-color:ghostwhite;	
}
.grid-3 #img1 {
  width: 350px;
  height: 250px;
  border-radius: 15px;
  margin: auto;
  position: relative;
  overflow: hidden;
}

.slideshow-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 15px;
  opacity: 0;
  transition: opacity 1.5s ease;
}

.slideshow-img.active {
  opacity: 1;
}
.grid-3 #caption1{
	float:right;
	height:auto;
	text-align:center;
	padding:16px;
	border-radius:15px;
	 max-width: 500px;   
  width: 100%; 	
display: flex;
  flex-direction: column;
	 justify-content: center;
  align-items: center;

}
#caption1 p{
	color: ghostwhite;
}
/* TESTING THE FUNCTION */ 
.grid-3,
.grid-8,
.section-top,
.section-bottom,
.blib,
.footer{
  opacity:0;
  transform: translateY(10px);
  transition: opacity 0.9s ease, transform 0.9s ease; 
}


.slide-up {
  opacity: 1;
  transform: translateY(0);
}

 
/* 8 COLUMN SYSTEM */

.grid-8 {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 20px;
	max-width: 1100px;   /* controls how wide the layout is */
  margin: 0 auto;     /* THIS centers the whole grid */
}

/* default boxes */

/*THIS IS WHERE I WILL GLASSMORPHISM STYLE BOXES */

 .box  {
background: rgba(120, 0, 180, 0.08);
border-radius: 16px;
box-shadow: 0 8px 30px rgba(0, 0, 0, 0.35),
            0 0 15px rgba(160, 32, 240, 0.08);
backdrop-filter: blur(18px);
-webkit-backdrop-filter: blur(18px);
border: 1px solid rgba(160, 32, 240, 0.35); 
height: auto;
min-height: 120px;
gap: 20px;
	 

}
#proj{
	border:none;
	box-shadow: none;
	width:100%;
}
.projects-header {
  width: 100%;
  text-align: center;
  margin-bottom: 30px;
  position: relative;
  z-index: 1;
}
.projects-title {
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont,
               "Segoe UI", Roboto, sans-serif;
  display: block;
  text-align: center;
  font-size: 3em;
  font-weight: 700;
  margin-bottom: 10px;
  position: relative;
  z-index: 1;
  background: linear-gradient(to right, #ffffff 2%, #ffffff 48%, #c040ff 50%, #a020f0 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.projects-subtitle {
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont,
               "Segoe UI", Roboto, sans-serif;
  display: block;
  text-align: center;
  color: #D8B4FF;
  font-size: 17px;
  margin-bottom: 0px;
  position: relative;
  z-index: 1;
  opacity: 0.8;
}


/* ONLY 8-column grid boxes span 2 columns */
.grid-8 .box {
grid-column: span 2;
  border-radius: 12px;
  height: auto;
	width:100%;
	min-height:200px;
}
/*SECTION TOPPP*/

.section-top .box {
	  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding: 40px 20px;
  box-sizing: border-box;

}
.section-top .cards-wrapper {
  grid-column: span 8;
  width: 100%;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  gap: 16px;
}




.row,
.grid-8,
.section-bottom,
.section-top {
  justify-items: center;
  align-items: center;
  gap: 10px;
  margin: 0 auto;
  width: 100%; 
} 
/* Section Bottom */

.section-bottom .box {
	 background: rgba(220, 220, 225, 0.25);
  width: 200px;
  min-height: 100px;
	height:auto;
  padding: 16px;
  box-sizing: border-box;
  border-radius: 16px 16px 16px 4px; /* 12px */
  border: 1px solid #B983FF;
  backdrop-filter: blur(80px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2),
              inset 0 1px 0 rgba(255, 255, 255, 0.5);
  transition: box-shadow 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              border 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);

	/* light green */
}
.section-bottom .box .footer-text p,
.section-bottom .box .footer-text h2,
.section-bottom .box p,
.section-bottom .box h2{
  color: white;
}

.section-bottom .box:hover {
  border: 1px solid ;
  box-shadow: 0 0 25px #B983FF,
              0 0 60px rgba(255, 255, 255, 0.12),
              0 0 100px rgba(255, 255, 255, 0.06),
              0 8px 32px rgba(0, 0, 0, 0.2),
              inset 0 1px 0 rgba(255, 255, 255, 0.6);
  transform: translateY(-3px);
}

/*BLOG TIMELINE */

.blog-timeline {
  position: absolute;
  left: -30px;
  top: 0;
  height: 100%;
  display: flex;
  justify-content: center;
  z-index: 10;
  pointer-events: none;
	overflow: visible;
}

.timeline-track {
  position: relative;
  width: 5px;
  height: 100%;
  background: rgba(160, 32, 240, 0.15);

}

.timeline-ball {
  position: absolute;
  left: 50%;
  top: var(--progress, 0%);
  transform: translate(-50%, -50%);
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #a020f0;
  box-shadow: 0 0 8px rgba(160, 32, 240, 0.9),
              0 0 20px rgba(160, 32, 240, 0.6),
              0 0 40px rgba(160, 32, 240, 0.3);
  transition: top 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.timeline-track::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: var(--progress, 0%);
  background: linear-gradient(to bottom, #a020f0, #c040ff);
  box-shadow: 0 0 8px rgba(160, 32, 240, 0.6),
              0 0 20px rgba(160, 32, 240, 0.3);
  transition: height 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

#mini-blog {
  position: relative;
	overflow: visible !important
}

/*BLOG section */

.blog-header {
  grid-column: 1 / -1;
  width: 100%;
  margin-bottom: 40px;
}

.blog-title {
	font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont,
               "Segoe UI", Roboto, sans-serif;
 display: block;
  text-align: center;
  font-size: 3em;
	font-weight: 700;
  color: #D8B4FF;
  margin-bottom: 10px;
	margin-top: -25px;
  position: relative;
  z-index: 1;
 background: linear-gradient(to right, #ffffff 2%, #ffffff 48%, #c040ff 50%, #a020f0 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
	opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.3s ease, transform 0.6s ease;
}


.blog-subtitle {
	font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont,
               "Segoe UI", Roboto, sans-serif;
  display: block;
  text-align: center;
	margin:auto;
  color: #D8B4FF;
  font-size: 17px;
  margin-bottom: 30px;
  position: relative;
  z-index: 1;
  margin-top: -10px;
	opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.3s ease 0.2s, transform 0.6s ease 0.2s;
}


.blog-title,
.blog-subtitle {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.9s ease, transform 0.4s ease;
}


.blog-title.blog-visible {
  opacity: 0.8;
  transform: translateY(0);
}

.blog-subtitle.blog-visible {
  opacity: 0.8;
  transform: translateY(0);
}

 #pic1 {
	background: radial-gradient(
  circle at 30% 107%,
  #fdf497 0%,
  #fdf497 5%,
  #fd5949 45%,
  #d6249f 60%,
  #285AEB 90%
);
} 
#pic2 {
	background: radial-gradient(
  circle at 30% 107%,
  #fdf497 0%,
  #fdf497 5%,
  #fd5949 45%,
  #d6249f 60%,
  #285AEB 90%
);
}
#pic3 {
	background: radial-gradient(
  circle at 30% 107%,
  #fdf497 0%,
  #fdf497 5%,
  #fd5949 45%,
  #d6249f 60%,
  #285AEB 90%
);
}
#pic4 {
	background: radial-gradient(
  circle at 30% 107%,
  #fdf497 0%,
  #fdf497 5%,
  #fd5949 45%,
  #d6249f 60%,
  #285AEB 90%
);
}
.section-bottom .box.pic {
  margin-right: 40px;
}
/* MINI BLOG TITLE */
.mini-blog-title {
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont,
               "Segoe UI", Roboto, sans-serif;
  display: block;
  text-align: center;
  font-size: 3em;
  font-weight: 700;
  margin-bottom: 10px;
  position: relative;
  z-index: 1;
  background: linear-gradient(to right, #ffffff 2%, #ffffff 48%, #c040ff 50%, #a020f0 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.9s ease, transform 0.4s ease;
}

.mini-blog-subtitle {
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont,
               "Segoe UI", Roboto, sans-serif;
  display: block;
  text-align: center;
  color: #D8B4FF;
  font-size: 17px;
  margin-bottom: 30px;
  position: relative;
  z-index: 1;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.9s ease 0.2s, transform 0.4s ease 0.2s;
}

.mini-blog-title.blog-visible {
  opacity: 0.8;
  transform: translateY(0);
}

.mini-blog-subtitle.blog-visible {
  opacity: 0.8;
  transform: translateY(0);
}
/*MINI BLOG TITLE */

/* Jobs entry boxes — bigger and more distinct */
.section-bottom .box.footer-text.jobs {
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(160, 32, 240, 0.3);
  border-radius: 16px;
  width: 100%;
  min-height: 160px;
	min-width: 300px;
  height: auto;
  padding: 24px 28px;
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
  backdrop-filter: blur(20px) saturate(150%);
  -webkit-backdrop-filter: blur(20px) saturate(150%);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.15),
              inset 0 1px 0 rgba(255, 255, 255, 1);
  transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              box-shadow 0.4s ease;
	
	
}

.section-bottom .box.footer-text.jobs:hover {
  transform: scale(1.02) translateY(-4px);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.2),
              0 0 20px rgba(160, 32, 240, 0.1);
}

.section-bottom .box.footer-text.jobs p {
  color: rgba(0, 0, 0, 0.8);
  font-size: 13.5px;
  line-height: 1.8;
  text-align: left;
  max-width: 100%;
}

/* purple accent bar on the left side */
.section-bottom .box.footer-text.jobs::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 4px;
  height: 100%;
  background: linear-gradient(to bottom, #a020f0, #4B0082);
  border-radius: 16px 0 0 16px;
  opacity: 1;
}

/* job pic boxes also bigger */
.section-bottom .box.pic#pic5,
.section-bottom .box.pic#pic6 {
  height: auto;
  min-height: 160px;
}

.section-bottom .box.pic#pic5 .footer-img,
.section-bottom .box.pic#pic6 .footer-img {
  width: 150%;
  height: 250px;
  object-fit: cover;
  border-radius: 12px;
}
/* Job Entry seperator */
.blog-divider {
  grid-column: 1 / -1;
  width: 100%;
  height: 1px;
  background: linear-gradient(to right, 
    transparent 0%, 
    rgba(160, 32, 240, 0.8) 30%, 
    rgba(160, 32, 240, 1) 50%, 
    rgba(160, 32, 240, 0.8) 70%, 
    transparent 100%);
  box-shadow: 0 0 8px rgba(160, 32, 240, 0.6),
              0 0 20px rgba(160, 32, 240, 0.3);
 /* margin: 10px 0; */
	margin: 40px;
}




.blog-long-entry .box.footer-text {
  overflow: visible !important;
  height: auto !important;
  display: flex;
  flex-direction: column;
  align-items: flex-start !important;
  justify-content: flex-start !important;

}

.row.grid-8.section-bottom {
  position: relative;
	overflow: visible !important;
  padding-bottom: 120px;
  margin-bottom: 60px;
}
.row.footer{
	position:relative;
	padding-top: 60px;
}

footer {
  width: 100%;
  padding: 40px 20px 20px 20px;
  box-sizing: border-box;
  border-top: 1px solid rgba(160, 32, 240, 0.2);
	text-align:center;
}

.footer-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  max-width: 900px;
  margin: 0 auto;
}



.footer-links {
  display: flex;
  flex-direction: row;
  gap: 32px;
  align-items: center;
}

.footer-links a {
  color: rgba(255, 255, 255, 0.5);
  text-decoration: none;
  font-size: 16px;
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  letter-spacing: 0.05em;
  transition: color 0.3s ease;
}

.footer-links a:hover {
  color: #a020f0;
}

.footer-bottom {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 24px;
  padding-top: 16px;
  width: 100%;
  justify-content: center;
	 border-top: 5px solid rgba(160, 32, 240, 0.2);
	
}

.footer-bottom p {
  color: rgba(255, 255, 255, 0.3);
  font-size: 12px;
  margin: 0;
  max-width: 100%;
  text-align: center;
}

.footer-bottom a {
  color: rgba(160, 32, 240, 0.6);
  font-size: 12px;
  text-decoration: none;
  transition: color 0.3s ease;
}

.footer-bottom a:hover {
  color: #a020f0;
}




.section-bottom .box .footer-img {
  width: 200px;
  height: 200px;
  object-fit: cover;
  border-radius: 12px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);

}
/* long entry full width row */
.blog-long-entry {
	 grid-column: 1 / -1;
  width: 100%; /* change this */
  max-width: 900px; /* add this to cap it */
  margin: 0 auto; /* keeps it centered */
  display: flex;
  flex-direction: row;
  gap: 40px;
  align-items: flex-start;
	padding-top: 20px;

}


.long-pic {
  width: 100px;
  min-width: 220px;
  flex-shrink: 0;
}
.blog-long-entry{
	margin-top: 40px; /* add this */
  grid-column: 1 / -1;
  width: 90%;
  max-width: 900px;
  margin: 40px auto 0 auto;
  display: flex;
  flex-direction: row;
  gap: 40px;
  align-items: flex-start;
  padding-top: 20px;
}

.long-text {
  flex: 1;
  width: auto !important;
  max-width: 100%;
  transition: max-height 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              box-shadow 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  cursor: pointer;
	
}

/* preview text — truncated */
.blog-preview {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  color: white;
  font-size: 14px;
  line-height: 1.7;
  max-width: 100%;
  text-align: left;
	transition: opacity 0.1s ease;
}

/* full text — hidden by default */
.blog-full {
  color: white;
  font-size: 14px;
  line-height: 1.7;
  max-width: 100%;
  text-align: left;
	transition: opacity 0.1s ease;
}

.blog-full.hidden {
  display: none;
}

/* read more button */
.read-more-btn {
  margin-top: 12px;
  padding: 8px 20px;
  background: transparent;
  border: 2px solid rgba(160, 32, 240, 0.5);
  border-radius: 20px;
  color: #a020f0;
  font-size: 12px;
  cursor: pointer;
  transition: background 0.3s ease, box-shadow 0.3s ease, color 0.3s ease;
  align-self: flex-start;
}

.read-more-btn:hover {
  background: rgba(160, 32, 240, 0.1);
  box-shadow: 0 0 10px rgba(160, 32, 240, 0.3);
  color: #c040ff;
}

.long-text.expanded .read-more-btn {
  border-color:rgba(160, 32, 240, 0.3);
  color: rgba(160, 32, 240, 0.6);
}
.long-text {
  max-height: 150px;
  overflow: hidden;
  transition: max-height 0.1s cubic-bezier(0.4, 0, 0.2, 1);
}

.long-text.expanded {
  max-height: 2000px;
  overflow: visible;
  transition: max-height 0.1s cubic-bezier(0.4, 0, 0.2, 1);
}



/* text/effects section */
.text-section {
  text-align: center;
  min-height: auto;
  padding: 0;
  background: transparent;
  overflow: hidden;
	 
}

.marquee-wrapper {
  width: 100%;
  overflow: hidden;
  background: rgba(30, 30, 35, 0.65);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-top: 1px solid rgba(30, 30, 35, 0.65);
  border-bottom: 1px solid rgba(30, 30, 35, 0.65);
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.3);
	height:80px;
	padding:26px
	   
}

.marquee-track {
  display: inline-flex;
  align-items: center;
  gap: 24px;
	white-space: nowrap;
	will-change: transform;
  animation: marquee 35s linear infinite;

	
}

.marquee-track span {
  font-family: "Oswald", sans-serif;
	font-size: 50px;
	color: white;
	font-weight:200px;
  /*color: rgba(255, 255, 255, 0.85); */
  white-space: nowrap;
  letter-spacing: 0.08em;
	margin-top: -27px;
	text-transform: uppercase;
}

.marquee-track .dot {
  color: rgba(160, 32, 240, 0.8);
  font-size: 18px;
}

@keyframes marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}


footer .copyright {
	font-size: 0.75em;
	text-align: center;
	color: #fff;
	padding: 2% 4%;
	float: left;
	width: 75%;
	margin: auto;
}

footer {
  width: 100%;
  border-top: 1px solid rgba(160, 32, 240, 0.2);
  padding-top: 20px;
	text-align: center;

}

.copyright {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 40px;
  width: 100%;
}

.copyright p {
  color: rgba(255, 255, 255, 0.4);
  font-size: 13px;
  max-width: none;
  text-align: center;
  white-space: nowrap;
	margin: auto;
	margin-right:0px;
	
}

.copyright a {
  color: #a020f0;
  text-decoration: none;
  transition: color 0.3s ease;
}

.copyright a:hover {
  color: #c040ff;
}


.social {
	float:right;
	width: 20%;
	padding: 2%;
}

.social img {
	display: inline-block;
	padding: 5%;
	
}
.contactme {
  display: block;
  text-align: center;
  font-size: 3em;
	font-weight: 700;
  color: #D8B4FF;
  margin-bottom: 20px;
  position: relative;
  z-index: 1;
 background: linear-gradient(to right, #ffffff 0%, #ffffff 39%, #c040ff 50%, #a020f0 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
	padding-top:5%;
}
.subtitle {
  display: block;
  text-align: center;
  color: #D8B4FF;
  font-size: 17px;
  opacity: 0.8;
  margin-bottom: 30px;
  position: relative;
  z-index: 1;
	margin-top: -10px;
}
.contactme,
.subtitle {
 transition:opacity 0.3s ease, transform 0.4s ease;
 
}

.contactme.contact-visible,
.subtitle.contact-visible {
  opacity: 0;
} 

.blib {
	 display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 40px;
  width: 90%;
  max-width: 1100px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
  padding: 20px;
  box-sizing: border-box;
  overflow: visible;
	height: 100%;
  /* display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 40px;
  width: 90%;
  max-width: 1100px;
  margin: 0 auto 50px auto;
  position: relative;
  z-index: 999; 
  padding: 20px;
  box-sizing: border-box;
	overflow:hidden;	*/
}
.blib-section {
  position: relative;
  width: 100%;
	background: rgba(0, 0, 0, 0.92);
backdrop-filter: blur(40px) saturate(80%);
-webkit-backdrop-filter: blur(40px) saturate(80%);
  z-index: 2;
  overflow: hidden;
  padding: 60px 0;
	min-height: 600px;

}



.blib::before {
  display:none;
}
.blib .contactme,
.blib .subtitle,
.blib .boxblib {
  position: relative;
  z-index: 2;
}

/* form box */
.boxblib-form {
  flex: 1;
  background: rgba(120, 0, 180, 0.08);
  border: 1px solid rgba(160, 32, 240, 0.35);
  border-radius: 16px;
  padding: 30px;
  box-sizing: border-box;
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.35),
	  		0 8px 30px rgba(0, 0, 0, 0.35),
              0 0 15px rgba(160, 32, 240, 0.08);
	overflow:hidden;
	position:relative;
}
.boxblib-form::before {
	
  content: '';
  position: absolute;
	padding:15px;
  width: 500px;
  height: 500px;
  background: radial-gradient(circle, rgba(160, 32, 240, 0.25) 0%, transparent 70%);
  border-radius: 50%;
  left: var(--mouse-x);
  top: var(--mouse-y);
  transform: translate(-50%, -50%);
  filter: blur(30px);
  pointer-events: none;
  opacity: var(--mouse-opacity, 1);
  transition: left 0.15s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              top 0.15s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              opacity 0.9s ease;
	

}

.boxblib-form h3 {
  color: #D8B4FF;
  font-size: 1.7em;
  margin: 0 0 20px 0;
}

/* right column — no box wrapper */
.blib-right {
  width: 400px;
  display: flex;
  flex-direction: column;
  gap: 16px;
 
}

.blib-right h3 {
  color: #D8B4FF;
  font-size: 1.3em;
  margin: 0 0 10px 0;
}

/* each pill is its own visible box */
.contact-pill {
  display: flex;
  align-items: center;
  gap: 16px;
  background: rgba(120, 0, 180, 0.08);
  border: 1px solid rgba(160, 32, 240, 0.35);
  border-radius: 12px;
  padding: 20px 24px;
	width:100%;
  text-decoration: none;
  color: #D8B4FF;
  font-size: 15px;
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.35),
              0 0 15px rgba(160, 32, 240, 0.08);
	position:relative;
	overflow:hidden;
  transition: background 0.3s ease,
              box-shadow 0.3s ease,
              transform 0.3s ease;

}
.contact-pill svg,
.contact-pill span,
.pill-arrow {
  pointer-events: none;
}

.pill-arrow {
  position: absolute;
  top: 10px;
  right: 14px;
  opacity: 0.7;
  transition: transform 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              opacity 0.3s ease;
}


.contact-pill img {
  width: 28px;
  height: 28px;
  object-fit: contain;
  filter: brightness(0) invert(1);
}

.contact-pill:hover {
  background: rgba(160, 32, 240, 0.15);
  box-shadow: 0 0 15px rgba(160, 32, 240, 0.4);
  transform: translateX(5px);
}

.contact-form {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.contact-pill:hover .pill-arrow {
  transform: translate(3px, -3px);
  opacity: 1;
}
.contact-pill:hover .pill-arrow svg {
  stroke: #c040ff;
}
.form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.form-group label {
  color: #D8B4FF;
  font-size: 13px;
  letter-spacing: 0.3px;
}

.form-group input,
.form-group textarea {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(160, 32, 240, 0.35);
  border-radius: 8px;
  padding: 12px 16px;
  color: white;
  font-size: 14px;
letter-spacing:2px;
  outline: none;
  width: 100%;
  box-sizing: border-box;
  transition: border 0.3s ease, box-shadow 0.3s ease;
  resize: none;
}

.form-group input::placeholder,
.form-group textarea::placeholder {
  color: rgba(255, 255, 255, 0.3);
}

.form-group input:focus,
.form-group textarea:focus {
  border: 1px solid #a020f0;
  box-shadow: 0 0 10px rgba(160, 32, 240, 0.4);
  background: rgba(160, 32, 240, 0.05);
}

.contact-form button {
  margin-top: 8px;
  padding: 14px 28px;
  background: #a020f0;
  color: white;
  border: none;
  border-radius: 8px;
  font-size: 14px;
	width: 100%;
	min-height:55px;
  cursor: pointer;
  align-self: flex-start;
  letter-spacing: 0.5px;
  transition: background 0.3s ease, box-shadow 0.3s ease, transform 0.3s ease;
}

.contact-form button:hover {
  background: #c040ff;
  box-shadow: 0 0 20px rgba(160, 32, 240, 0.6);
  transform: translateY(-2px);
}
#particle-canvas {
   position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  pointer-events: none;
  
}
.item-description .vertical-part b {
  background: rgba(0, 0, 0, 0.85);
  padding: 2px 4px;
  border-radius: 4px;

}

