* {
    box-sizing:border-box;
}

@font-face {
    font-family: myFirstFont;
    src: url(WorkSans-Medium.ttf);
  }

  @font-face {
    font-family: WorkRegular;
    src: url(WorkSans-Regular.ttf);

  }

  @font-face {
    font-family: Trap;
    src: url(Trap-Black.otf);
  }

  .strokeme {
	color: #F2F1F0;
	text-shadow: -1px -1px 0 #070707, 1px -1px 0 #acacac, -1px 1px 0 #acacac, 1px 1px 0 #acacac;
  }

body {
  background-color: #F2F1F0;
  font-family: sans-serif;
  margin: 0;
}

.page-shell {
  max-width: 1200px;
  margin: 0 auto;
  padding: 1.75rem 2rem 0;
  box-sizing: border-box;
}

.page-shell > .content {
  max-width: 100%;
  margin: 0;
}

.content {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0;
}
	

hr {
	margin-top: 3rem;
	margin-bottom: 1rem;
	border: solid 0.5px;
}

hr.notes {
	margin-top: 0px;
	margin-bottom: 5px;
	border: solid 0.5px;
}

h2 {
    font-size: 1.75rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
}

.tldr {
	margin: 2rem auto;     /* Center the container and add top/bottom space */
	display: flex;
}
  
  /* Give all buttons subtle rounding */
  .myButton {
	border-radius: 1.5px;
	padding: 0.5rem 1rem;
	border: none;
	cursor: pointer;
	/* Customize colors, etc. as needed */
  }
  
  /* Give all images 3px rounding (use !important if something else overrides it) */
  img {
	border-radius: 3px;
	display: block;
	max-width: 100%;
	height: auto;
  }
  
  .grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 20px;
    margin: 4rem auto;
    /* Limit to four 250px columns + three 20px gaps = 1060px */
    max-width: 1060px;
    padding: 0 1rem;
  }
  
  .grid-item {
	break-inside: avoid;     
	margin-bottom: 20px;     /* vertical spacing */
  }
  
  
  
  /* Client Logos Section */
  .client-logos {
	max-width: 1200px;
	margin: 3rem auto;
	padding: 0 1rem;
	text-align: center;
  }
  
  .client-logos h2 {
	margin-bottom: 1.5rem;
	font-weight: normal;
  }
  
  /* Logo row layout */
  .logo-row {
	display: flex;
	flex-wrap: wrap;       /* Logos wrap to new lines if there's not enough space */
	justify-content: center;
	gap: 20px;             /* Horizontal & vertical spacing among the logos */
  }
  
 /* .logo-wrapper: bounding box for each logo 
   to keep them similarly sized even if they have different shapes. */
.logo-wrapper {
	width: 120px;            /* Adjust to your preference */
	height: 60px;            /* Adjust to your preference */
	display: flex;
	align-items: center;     /* Center logo within wrapper vertically */
	justify-content: center; /* Center logo within wrapper horizontally */
  }
  
  /* Logos fill the bounding box proportionally without distorting */
  .logo-wrapper img {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
  }

/* The container for all book items */
#books-grid {
  display: grid;
  /* Each book item will be at least 200px wide, 
     and stretch to fill the space (1fr) if there's room. */
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 2rem;
  max-width: 1200px;
  margin: 4rem auto;
  padding: 0 1rem;
}
  
  .book-item {
	/* Remove or make transparent the background so it’s not a white card */
	background-color: transparent; 
	padding: 0rem 1rem 1rem 1rem;
	text-align: center;
	border-radius: 4px;  /* Optional if you want a subtle rounding on the container */
	box-shadow: none;    /* Remove card-like shadow if previously present */
  }
  
  .book-item img {
	max-width: 100%;
	height: auto;
	margin-bottom: 2rem;
	border-radius: 4px;
  
	/* Drop shadow on the cover */
	box-shadow: 0 15px 8px rgba(39, 38, 38, 0.2);
	background-color: transparent;
  }
  
  .book-item h3 {
	margin: 0.5rem 0 0.25rem 0;
	font-size: 1rem;
  }
  
  .book-item p {
	margin: 0.25rem 0;
	font-size: 0.9rem;
  }

p {
	font-family: WorkRegular;
	font-size: 11pt;
	margin-top: 5px;
	margin-bottom: 5px;
	line-height: 24px;
	
}

.press-text {
	text-align: center;
	background-color: white;
	max-width: 250px;
}

p.job-years {
	font-family: WorkRegular;
	font-size: 15px;
	margin-top: 1px;
	margin-bottom: 5px;
	line-height: 24px;
	
}

.top-text-content {
	
	display: flex;
	flex-wrap: wrap;
	margin-right: 15px;
	margin-left: 15px;
	margin-bottom: 2rem;
	

}

.content-25 {
	flex: 25%;
	max-width: 25%;
	padding-left: 15px;
	padding-right: 15px;
	
	
}

.content-33 {
	flex: 33%;
	max-width: 33%;
	padding-left: 15px;
	padding-right: 15px;
	
	
}


.content-50 {
	flex: 50%;
	max-width: 50%;
	padding-left: 15px;
	padding-right: 15px;
	align-items: baseline;
	
}


/*.career-60 {
	flex: 60%;
	max-width: 60%;
	margin-right: 15px;
	margin-left: 15px;
}*/

.blog {
	flex: 60%;
	max-width: 60%;
	margin-top: 100px;
	margin-right: 15px;
	margin-left: 30px;
}

.blog strong{
	font-size: 15pt;
}

.career-box {
	margin-top: 0rem;
	margin-bottom: 3rem;
	display: flex;
	
}

.vl {
	border-left: 1px solid grey;
	height:max-content;
	margin-left: 30px;
	
  }

.career-content {
	display: flex;
	flex-wrap: wrap;
	margin-right: 15px;
	margin-left: 15px;
	margin-bottom: 1rem;
	margin-top: 1rem;
	
}

.container {
	width: 100%;

    padding-right: 2rem;
    padding-left: 2rem;
    margin-right: auto;
    margin-left: auto;
	margin-top: 0px;

}

.row {
	width: 100%;
    padding-right: 15px;
    padding-left: 15px;
    margin-right: auto;
    margin-left: auto;
	

}

.job-box {
	display: flex!important;
	min-width: 55px;
	width: 55px;
	height: 55px;
	margin-right: 20px;
	
}

.press-images {
	display: flex!important;
	min-height: 125px;
	height: 125px;
	margin-right: 10px;
	border-radius: 4px;

}


.course-images {
	display: flex!important;
	max-height: 325px;
	height: 325px;
	margin-right: 20px;
}


.job-data-text {
	padding-left: 0.25rem;
	display: block;
}


#main-content {

  align-items:center;
  margin: 0 auto;
  margin-top: 0px;
	border-width: 0px;
	border-style: solid;
	border-color: rgb(140, 0, 255);
	
  }


.big-word h2 {
	color: #acacac;
	text-align: center;
	font-family: Trap;
	font-size: 250px;
	padding: 0px;
	margin-top: 50px;
	
}



.grid a.hover {

	height: auto;
	  width: 100%;
	 
  
  }

  /* Contact section container */
.contact-section {
	max-width: 700px;    /* keep the form narrower for easy reading */
	margin: 4rem 2rem;   /* center horizontally on larger screens */
	padding: 0 1rem;
  }
  
  /* The form and its elements */
  .contact-form {
	display: flex;
	flex-direction: column;  /* stack labels and inputs */
	gap: 1rem;               /* space between form elements */
  }
  
  .contact-form label {
	font-weight: 400;        /* slightly bolder label text */
  }
  
  .contact-form input[type="text"],
  .contact-form input[type="email"],
  .contact-form textarea {
	width: 100%;
	padding: 0.75rem;
	border-radius: 4px;
	border: 1px solid #ccc;
	font-size: 1rem;
  }
  
  /* Adjust placeholder text if you like */
  .contact-form ::placeholder {
	color: #999;
  }
  
  /* Use an existing .myButton style for the submit button,
	 plus an extra class for custom form styling if needed. */
  .form-btn {
	background-color: #FFA737;  /* or your pink color, e.g. #F783AC */
	color: #fff;
	border: none;
	padding: 0.75rem 1.25rem;
	cursor: pointer;
	/* rest is inherited from .myButton or do your own */
  }
  
  /* Optionally make .form-btn stand out on hover */
  .form-btn:hover {
	opacity: 0.9;
  }

  /* Example: ensuring .press-list uses the same font & style as your contact text */
.press-list {
	list-style-type: disc;       /* or none, circle, etc. */
	margin-left: 1.5rem;        /* indent for bullets */
	font-family: "Helvetica", sans-serif;  /* match your contact page font */
	font-size: 1rem;            /* or whatever the contact page uses */
	line-height: 1.6;           /* comfortable line-height */
  }
  
  .press-list li {
	margin-bottom: 0.5rem;      /* spacing between list items */
  }


.collapsible {
	max-height: 0;
	overflow: hidden;          /* hide content while collapsed */
	transition: max-height 0.4s ease; 
	/* 0.4s is an example; tweak to your preference */
  }
  
  .collapsible.open {
	/* We’ll set this via JS. 
	   By using a large max-height, the element "slides" to reveal its full content. */
	max-height: 1000px; 
	/* or use “max-height: none;” and a JS approach that sets exact scrollHeight. 
	   But 1000px is often enough unless your content is extremely tall. */
  }

  /* 1) Style the small, gray explanatory text */
.section-description {
	font-size: 0.8rem;   /* slightly smaller than normal */
	color: #999;         /* medium gray */
	margin-left: 0.5rem; /* small spacing after the ▾ arrow */
  }
  
  /* 2) Ensure consistent spacing around .tldr and hr */
  .tldr {
	margin: 1rem 0;      /* top & bottom spacing for each heading block */
  }
  
  hr {
	margin: 1rem 0;      /* keep uniform spacing around horizontal rules */
  }

/* .job-row: overall row container for each role */
.job-row {
	display: flex;
	align-items: flex-start; /* ensures content lines up at the top */
	justify-content: space-between;
	gap: 2rem;
	margin-bottom: 2rem;
  }
  
  /* .job-left: holds the “logo + role info” together */
  .job-left {
	flex: 1;
	max-width: 60%;
  }
  
  /* This new .job-left-inner is a small flex container for the logo + role text */
  .job-left-inner {
	display: flex;
	gap: 1rem;          /* spacing between logo and the text block */
	align-items: flex-start; /* logo and text top-aligned */
  }
  
  .job-left-inner img {
	width: 50px;        /* or your desired size */
	height: auto;
  }
  
  /* .job-right stays the same, for milestones on the far right */
  .job-right {
	flex: 1;
	max-width: 40%;
	color: #3b3b3b;
	font-style: normal;
	line-height: 1.4;
	display: flex;
	align-items: center;
	justify-content: flex-start; /* or 'flex-start', if you want them left-aligned in the column */
  }

  /* A small flex container for the job title and line */
.title-line-row {
	display: flex;
	align-items: center; 
	margin-bottom: 0.5rem; /* small spacing below the row if desired */
  }

@media (max-width: 640px) {
  .career-content .job-row {
    align-items: stretch;
    gap: 1.25rem;
  }
  .career-content .job-left {
    max-width: 100%;
    width: 100%;
  }
  .career-content .job-left-inner {
    width: 100%;
  }
  .career-content .job-left-inner .role-details {
    flex: 1 1 auto;
  }
}
  
  /* Give the <strong> minimal margin if needed */
  .title-line-row strong {
	margin: 0;
	padding: 0;
  }
  
  /* The thin line that extends to the right of the title */
  .job-title-line {
	flex: 1;                  /* take remaining horizontal space */
	height: 1px;              /* thin line */
	background-color: #ccc;   /* or #ddd, #666, etc. */
	margin-left: 1rem;        /* gap between title and line */
  }

  .site-footer {
    background-color: #3b3b3b;
    color: #fff;
    padding: 2rem;
    text-align: center;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    margin-top: 5rem;
    box-sizing: border-box;
  }
  
  /* Container for the links row */
  .footer-content {
	display: flex;
	flex-wrap: wrap;          /* allows wrapping on narrow screens */
	justify-content: center;  /* center the links horizontally */
	margin-bottom: 1rem;      /* small gap above the bottom line */
  }
  
  /* The ul that holds all links in one line */
  .footer-links {
	display: flex;
	flex-wrap: wrap;          /* wrap if the screen is too narrow */
	list-style: none;
	padding: 0;
	margin: 0;
	gap: 0.5rem;              /* horizontal spacing between list items */
  }
  
  /* Each <li> item: we’ll add the “|” separator after each */
  .footer-links li {
	position: relative;       /* for the separator pseudo-element */
	margin: 0;
  }
  
  /* Show “|” after each list item except the last */
  .footer-links li:not(:last-child)::after {
	content: "|";
	margin-left: 0.5rem;
	margin-right: 0.5rem;
	color: #ccc;             /* or your preferred separator color */
  }
  
  /* Style the links */
  .footer-links li a {
	color: #ccc;             /* link color in footer */
	text-decoration: none;
	font-size: 0.8rem;
  }
  
  .footer-links li a:hover {
	color: #fff;             /* hover effect */
  }
  
  /* Footer bottom for copyright */
  .footer-bottom {
	font-size: 0.8rem;
  }
/* --- Header Module Styles (moved from individual pages) --- */

/* Topline container */
.topline {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  width: 100%;
}
.topline-inner {
  display: flex;
  align-items: center;
  gap: 1rem;
  width: 100%;
}
.topline-actions {
  display: flex;
  align-items: center;
}

/* Left face image wrapper */
.left-face {
  display: flex;
  align-items: center;
}
.left-face img {
  width: 170px;
  max-width: 100%;
  height: auto;
  display: block;
}

/* Center heading + menu */
.heading-and-menu {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  flex: 1 1 auto;
}

/* Page-wide H2 in header */
.heading-and-menu h2 {
  font-size: 1.2rem;
  font-weight: 600;
  margin-top: 0;
  margin-bottom: 0.5rem;
}

/* Navigation buttons container */
.little-menu {
  display: flex;
  gap: 0.4rem;
  margin-top: 1rem;
  margin-bottom: 0;
}

/* Button base style (for header and general use) */
.myButton {
  border-radius: 4px;
  padding: 0.6rem 1.2rem;
  font-size: 14px;
  font-weight: 400;
  border: 1.5px solid #3b3b3b;
  box-sizing: border-box;
  background: none;
  background-color: transparent;
  color: #1a1a1a;
  appearance: none;
  box-shadow: none;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.myButton:hover {
  transform: translateY(-1px);
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.18);
}
.myButton.active {
  background-color: #3b3b3b;
  color: #F2F1F0;
  border: 1.5px solid #3b3b3b;
}

/* Social icons container in header */
.social-icons {
  display: flex;
  align-items: center;
}

/* Social icon images */
.social-icons img {
  height: 24px;
  margin: 0 0.5rem;
  transition: transform 0.2s ease;
}
.social-icons img:hover {
  transform: scale(1.1);
}

/* Responsive adjustments for header */
@media (max-width: 1068px) {
  .topline {
    flex-direction: column;
    align-items: center;
  }
  .left-face {
    margin-bottom: 1rem;
    display: flex;
    justify-content: center;
    width: 100%;
  }
  .heading-and-menu {
    width: 100%;
  }
  .little-menu {
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.5rem;
    max-width: 600px;
  }
  .social-icons {
    flex-wrap: wrap;
    justify-content: center;
  }
}
@media (max-width: 768px) {
  .topline {
    flex-direction: column;
    align-items: center;
  }
  .left-face {
    order: -1;
    margin-bottom: 1rem;
    display: flex;
    justify-content: center;
    width: 100%;
  }
  .heading-and-menu {
    width: 100%;
  }
  .little-menu {
    max-width: 300px;
  }
  .social-icons {
    flex-wrap: wrap;
    justify-content: center;
  }
}

@media (max-width: 640px) {
  .topline {
    justify-content: flex-start;
    gap: 0.75rem;
  }
  .topline-inner {
    gap: 0.75rem;
  }
  .left-face,
  .little-menu,
  .social-icons {
    display: none;
  }
  .heading-and-menu {
    flex: 1 1 auto;
    width: auto;
    align-items: flex-start;
    text-align: left;
  }
  body.case-study .case-header {
    gap: 2.4rem;
  }
  .topline-actions {
    margin-left: auto;
    align-items: center;
  }
  .topline-actions .topline-mobile-toggle {
    margin-top: 0;
  }
}

@media (max-width: 640px) {
  .sticky-header .sticky-menu,
  .sticky-header .sticky-social {
    display: none !important;
  }
  .sticky-right {
    width: 100%;
    justify-content: flex-end;
    gap: 0.5rem;
  }
}
/* Fixed grey-placeholder grid with varied spans */
.fixed-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
  max-width: 1200px;
  margin: 4rem auto;
  padding: 0 1rem;
  grid-auto-flow: dense;
}

.placeholder {
  position: relative;
  padding-top: 100%; /* maintain a square container */
  width: 100%;
  border-radius: 3px;
  overflow: hidden;
}

.placeholder .gallery-card {
  position: relative;
  display: block;
  border-radius: inherit;
  overflow: hidden;
  position: absolute;
  inset: 0;
}

.placeholder .gallery-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.28s ease;
  will-change: transform;
}

.gallery-card__label {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  background: rgba(59, 59, 59, 0.95);
  color: #f5f5f5;
  padding: 0.65rem 1rem;
  font-size: 0.92rem;
  display: flex;
  justify-content: center;
  align-items: center;
  transform: translateY(-120%);
  transition: transform 0.28s ease;
  pointer-events: none;
  opacity: 0;
  transition: transform 0.28s ease, opacity 0.24s ease;
}

.placeholder .gallery-card:hover img,
.placeholder .gallery-card:focus-visible img {
  transform: translateY(12px);
}

.placeholder .gallery-card:hover .gallery-card__label,
.placeholder .gallery-card:focus-visible .gallery-card__label {
  transform: translateY(0);
  opacity: 1;
}

.placeholder .gallery-card:focus-visible {
  outline: 3px solid rgba(255, 255, 255, 0.6);
  outline-offset: 4px;
}

/* Span variant: tall tile spanning two rows, 1:2 aspect ratio */
.span-rows {
  grid-row: span 2;
  padding-top: 200%;
}

/* Span variant: wide tile spanning two columns, 2:1 aspect ratio */
.span-cols {
  grid-column: span 2;
  padding-top: 50%;
}

@media (max-width: 720px) {
  .fixed-grid {
    grid-template-columns: 1fr;
    gap: 14px;
    padding: 0 1.25rem;
  }
  .span-rows,
  .span-cols {
    grid-column: span 1;
    grid-row: span 1;
    padding-top: 100%;
  }
}

@media (hover: none) {
  .placeholder .gallery-card img {
    transform: none !important;
  }
  .gallery-card__label {
    transform: translateY(0);
    opacity: 1;
  }
}

.shade1 { background-color: #e0e0e0; }
.shade2 { background-color: #cccccc; }
.shade3 { background-color: #b8b8b8; }
.shade4 { background-color: #a4a4a4; }
.shade5 { background-color: #909090; }
.shade6 { background-color: #7c7c7c; }
.shade7 { background-color: #686868; }
.shade8 { background-color: #545454; }
.shade9 { background-color: #404040; }
.case-hero-media {
  display: flex;
  border-radius: 14px;
  overflow: hidden;
  height: clamp(320px, 34vw, 420px);
}
.case-hero-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
