:root {
  --primary-blue: #233dff;
  --dark-blue: #12229d;
  --light-blue: #f4f6fc;
}

/* lightGallery Minimalist Styling - Contemporary Art Gallery */
#lightgallery .lg-item,
#lightgallery-if-i-forget .lg-item,
#lightgallery-limen .lg-item,
#lightgallery-no-alternatives .lg-item,
#lightgallery-water-air-breath .lg-item {
  background-color: #000;
}

.lg-backdrop {
  background-color: rgba(0, 0, 0, 0.98) !important;
}

.lg-toolbar {
  background-color: transparent !important;
  opacity: 0.6 !important;
}

.lg-toolbar .lg-icon {
  color: #fff !important;
  opacity: 0.7 !important;
  transition: opacity 0.3s ease !important;
}

.lg-toolbar .lg-icon:hover {
  opacity: 1 !important;
}

/* Exhibition Catalog Style Captions */
.lg-sub-html {
  background-color: transparent !important;
  color: rgba(255, 255, 255, 0.85) !important;
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 0.9rem !important;
  font-weight: 300 !important;
  letter-spacing: 0.05em !important;
  line-height: 1.6 !important;
  padding: 2rem 3rem !important;
  text-align: center !important;
  bottom: 3rem !important;
  max-width: 600px !important;
  margin: 0 auto !important;
  opacity: 0.9 !important;
  text-transform: none !important;
}

.lg-sub-html h4 {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 1rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.1em !important;
  margin-bottom: 0.5rem !important;
  color: rgba(255, 255, 255, 0.9) !important;
}

.lg-sub-html p {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 0.85rem !important;
  font-weight: 300 !important;
  letter-spacing: 0.05em !important;
  line-height: 1.8 !important;
  margin: 0 !important;
  color: rgba(255, 255, 255, 0.75) !important;
}

/* Hide thumbnails to reduce visual noise */
.lg-outer .lg-thumb {
  display: none !important;
}

.lg-actions .lg-next, .lg-actions .lg-prev {
  background-color: transparent !important;
  color: rgba(255, 255, 255, 0.7) !important;
  opacity: 0.6 !important;
  transition: opacity 0.3s ease !important;
}

.lg-actions .lg-next:hover, .lg-actions .lg-prev:hover {
  opacity: 1 !important;
  color: rgba(255, 255, 255, 0.95) !important;
}

/* Reduce visual noise - minimal UI */
.lg-counter {
  color: rgba(255, 255, 255, 0.6) !important;
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.75rem !important;
  letter-spacing: 0.1em !important;
}

.lg-toolbar .lg-close {
  opacity: 0.7 !important;
}

.lg-toolbar .lg-close:hover {
  opacity: 1 !important;
}

body {
  font-family: 'Montserrat', sans-serif;
  color: #050a30;
  position: relative;
  margin: 0;
  padding: 0;
}

.projects-page {
  background-color: #12229d;
  margin: 0;
  padding: 0;
}

.projects-page html {
  background-color: #12229d;
  margin: 0;
  padding: 0;
}

/* Navigation */
.navbar {
  background-color: transparent !important;
  padding: 1rem 0;
  transition: none;
}

.navbar.scrolled {
  background-color: transparent !important;
}

.navbar-brand {
  color: #050a30;
  font-weight: 400;
  text-transform: uppercase;
  font-size: 1rem;
  letter-spacing: -0.05em;
  text-decoration: none;
}

.navbar-brand:hover {
  color: #050a30;
  opacity: 0.8;
}

.navbar-nav .nav-link {
  color: #050a30;
  font-weight: 400;
  text-transform: lowercase;
  margin: 0 0.5rem;
}

.navbar-nav .nav-link:hover,
.navbar-nav .nav-link.active {
  color: #050a30;
  opacity: 0.8;
}

/* Hero Section */
.hero-section {
  position: relative;
  height: 100vh;
  width: 100%;
  overflow: hidden;
  margin-bottom: 0;
  z-index: 3;
}

.hero-background-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 1;
}

.hero-content {
  position: relative;
  z-index: 2;
  padding: 2rem 0;
}

.hero-title {
  color: #050a30;
  font-size: 1.35rem;
  font-weight: 400;
  letter-spacing: -0.05em;
  text-transform: uppercase;
  margin: 0;
  position: absolute;
  top: 2rem;
  left: 2rem;
}

.hero-bottom-text {
  position: absolute;
  bottom: calc(2rem * 1.38);
  right: 2rem;
  max-width: 274px;
  z-index: 2;
  text-align: right;
}

.hero-bottom-text p {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.8rem;
  line-height: 1.3;
  color: #050a30;
  margin-bottom: 1rem;
}

.hero-bottom-text p:last-child {
  margin-bottom: 0;
}

/* Workshop Hero Section */
.workshop-hero-section {
  position: relative;
  width: 100%;
  min-height: 250vh;
  overflow: visible;
  margin-top: 70px;
  padding: 0;
}

.workshop-hero-text {
  position: absolute;
  top: 100px;
  left: 50%;
  transform: translateX(-50%);
  text-align: center;
  z-index: 2;
  width: 100%;
}

.workshop-text-creative {
  font-family: 'Montserrat', sans-serif;
  font-size: 72px;
  color: #050a30;
}

.workshop-text-workshops {
  font-family: 'Cormorant Garamond', serif;
  font-size: 72px;
  color: #050a30;
}

/* Workshops page - Change all text colors to #f1f1f1 */
.workshops-page-body .workshop-text-creative,
.workshops-page-body .workshop-text-workshops {
  color: #f1f1f1;
}

.workshop-description-text {
  position: absolute;
  left: 50%;
  top: 340px;
  transform: translateX(-50%);
  width: calc(100% - 4rem);
  max-width: 1200px;
  z-index: 2;
  display: flex;
  gap: 3rem;
}

.workshop-text-column-left {
  flex: 1;
  max-width: 50%;
}

.workshop-text-column-right {
  flex: 1;
  max-width: 50%;
}

.workshop-description-text p {
  font-family: 'Montserrat', sans-serif;
  font-size: 17px;
  color: #050a30;
  line-height: 1.6;
  margin: 0;
}

/* Workshops page - Change description text color */
.workshops-page-body .workshop-description-text p {
  color: #f1f1f1;
}

.workshop-process-text {
  position: absolute;
  left: 50%;
  top: calc(650px + 50vh + 310px);
  transform: translateX(-50%);
  width: calc(100% - 4rem);
  max-width: 1200px;
  z-index: 2;
  display: flex;
  gap: 3rem;
}

.workshop-process-column-left {
  flex: 1;
  max-width: 50%;
}

.workshop-process-column-right {
  flex: 1;
  max-width: 50%;
}

.workshop-process-text p {
  font-family: 'Montserrat', sans-serif;
  font-size: 17px;
  color: #050a30;
  line-height: 1.6;
  margin: 0;
}

/* Workshops page - Change process text color */
.workshops-page-body .workshop-process-text p {
  color: #f1f1f1;
}

.workshop-sun-container {
  position: absolute;
  left: 0;
  top: 650px;
  width: 100%;
  overflow: hidden;
}

.workshop-sun-image {
  width: 100%;
  height: auto;
  display: block;
  margin: 0;
  padding: 0;
  opacity: 0.93;
  clip-path: inset(17% 0 15% 0);
  object-fit: cover;
}

.workshop-sun-text {
  position: absolute;
  top: 30%;
  left: 30%;
  transform: translate(-50%, -50%);
  font-family: 'Montserrat', sans-serif;
  font-size: 72px;
  color: #050a30;
  z-index: 2;
}

.workshop-sun-text-anthotype {
  position: absolute;
  top: 70%;
  left: 70%;
  transform: translate(-50%, -50%);
  font-family: 'Cormorant Garamond', serif;
  font-size: 88px;
  color: #050a30;
  z-index: 2;
}

/* Workshops page - Change sun text colors */
.workshops-page-body .workshop-sun-text,
.workshops-page-body .workshop-sun-text-anthotype {
  color: #f1f1f1;
}

/* Section Styling */
section {
  padding: 0;
}

.bio-section {
  position: relative;
  height: 100vh;
  width: 100%;
  overflow: hidden;
  margin-top: 0;
  z-index: 1;
}

.bio-background-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}

.bio-content {
  position: relative;
  z-index: 1;
  height: 100%;
  display: flex;
  align-items: flex-end;
  padding: 2rem 0;
}

.bio-text {
  font-size: 0.9rem;
  line-height: 1.6;
  color: #050a30;
  max-width: 600px;
  position: absolute;
  bottom: 2rem;
  left: 2rem;
  z-index: 10;
}

/* Whale Section */
.whale-section {
  width: 100%;
  overflow: hidden;
}

.whale-image {
  width: 100%;
  height: auto;
  display: block;
}

.projects-section {
  background-color: #12229d;
  padding: 0;
  min-height: 100vh;
  margin: 0;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: calc(50vh * 0.35);
}

.projects-list {
  font-size: 1rem;
  line-height: 1.2;
  color: #ffffff;
  width: 100%;
}

.projects-page .projects-list {
  color: #000;
}

.project-item {
  font-family: 'Cormorant Garamond', serif;
  font-size: 32px;
  font-weight: 400;
  margin-bottom: 0.1rem;
  cursor: pointer;
  transition: opacity 0.3s ease;
  text-transform: uppercase;
  color: #ffffff;
  text-decoration: none;
  display: block;
}

.project-item:hover {
  opacity: 0.7;
  text-decoration: none;
  color: #ffffff;
}

.projects-page .project-item {
  color: #000;
}

.projects-page .project-item:hover {
  color: #000;
}

.projects-preview-section {
  background-color: var(--light-blue);
  padding: 4rem 0;
}

.portfolio-section {
  background-color: var(--light-blue);
}

.workshops-page-body {
  background-image: url('../images/workshop_baner.jpg');
  background-size: cover;
  background-position: center top;
  background-repeat: no-repeat;
  background-attachment: scroll;
  min-height: 250vh;
}

.workshops-section {
  background-color: transparent;
  padding: 4rem 0;
}

.workshop-gallery-section {
  background-color: rgba(241, 241, 241, 0.97);
  padding: 4rem 0;
  min-height: 50vh;
  margin-top: calc((310px + 50px) * 0.5);
}

.workshop-gallery-image {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

.workshop-form-section {
  background-color: transparent;
  padding: 4rem 0;
  min-height: 50vh;
}

/* Workshops page - Change navigation colors */
.workshops-page-body .navbar-brand,
.workshops-page-body .navbar-nav .nav-link {
  color: #f1f1f1;
}

.workshops-page-body .navbar-brand:hover,
.workshops-page-body .navbar-nav .nav-link:hover,
.workshops-page-body .navbar-nav .nav-link.active {
  color: #f1f1f1;
  opacity: 0.8;
}

/* Workshops page - Change footer text color */
.workshops-page-body footer,
.workshops-page-body footer p {
  color: #f1f1f1;
}

/* Workshops page - Change form text colors */
.workshops-page-body .contact-form .form-label,
.workshops-page-body .contact-form .form-control,
.workshops-page-body .contact-form .form-control::placeholder {
  color: #f1f1f1;
}

.workshops-page-body .contact-form .form-control {
  border-color: rgba(241, 241, 241, 0.3);
}

.workshops-page-body .contact-form .form-control:focus {
  border-color: #f1f1f1;
  color: #f1f1f1;
}

.workshops-page-body .btn-submit {
  color: #f1f1f1;
  border-color: rgba(241, 241, 241, 0.3);
}

.workshops-page-body .btn-submit:hover {
  background-color: #f1f1f1;
  color: #050a30;
  border-color: #f1f1f1;
}

/* Workshop Calendar - Minimalist Style */
.workshop-calendar-container {
  font-family: 'Montserrat', sans-serif;
  max-width: 100%;
  margin: 0 auto;
}

/* Calendar Header - Month/Year and Navigation */
.calendar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 2rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid rgba(241, 241, 241, 0.2);
}

.calendar-month-year {
  font-family: 'Montserrat', sans-serif;
  font-size: 1rem;
  font-weight: 400;
  color: #f1f1f1;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0;
}

.calendar-nav-btn {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.85rem;
  color: #f1f1f1;
  background-color: transparent;
  border: 1px solid rgba(241, 241, 241, 0.3);
  padding: 0.5rem 1rem;
  cursor: pointer;
  transition: all 0.3s ease;
  text-decoration: none;
}

.calendar-nav-btn:hover,
.calendar-nav-btn:focus {
  border-color: #f1f1f1;
  outline: none;
}

/* Weekday Headers */
.calendar-weekdays {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 0.5rem;
  margin-bottom: 1rem;
}

.calendar-weekday {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.75rem;
  font-weight: 400;
  color: rgba(241, 241, 241, 0.6);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  text-align: center;
  padding: 0.5rem 0;
}

/* Calendar Days Grid */
.calendar-days {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 0.5rem;
}

.calendar-day {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.9rem;
  color: #f1f1f1;
  background-color: transparent;
  border: 1px solid transparent;
  padding: 0.75rem 0;
  text-align: center;
  cursor: default;
  transition: all 0.3s ease;
  min-height: 2.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.calendar-day-empty {
  visibility: hidden;
}

/* Days with workshops - subtle highlight */
.calendar-day-workshop {
  border-bottom: 1px solid rgba(241, 241, 241, 0.4);
  cursor: pointer;
  position: relative;
}

.calendar-day-workshop:hover,
.calendar-day-workshop:focus {
  border-color: rgba(241, 241, 241, 0.6);
  outline: none;
}

.calendar-day-active {
  border-color: #f1f1f1;
  background-color: rgba(241, 241, 241, 0.05);
}

/* Calendar Tooltip */
.calendar-tooltip {
  display: none;
  position: absolute;
  background-color: rgba(241, 241, 241, 0.95);
  color: #050a30;
  padding: 1rem 1.5rem;
  border: 1px solid rgba(5, 10, 48, 0.2);
  font-family: 'Montserrat', sans-serif;
  font-size: 0.85rem;
  line-height: 1.6;
  z-index: 1000;
  max-width: 250px;
  pointer-events: none;
}

.tooltip-title {
  font-weight: 500;
  margin-bottom: 0.5rem;
  color: #050a30;
}

.tooltip-text {
  font-size: 0.75rem;
  color: rgba(5, 10, 48, 0.7);
  font-style: italic;
}

/* Workshop Form Intro Text */
.workshop-form-intro {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.85rem;
  line-height: 1.6;
  color: #f1f1f1;
  margin-bottom: 2rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid rgba(241, 241, 241, 0.2);
}

/* Responsive Calendar */
@media (max-width: 768px) {
  .calendar-header {
    margin-bottom: 1.5rem;
    padding-bottom: 0.75rem;
  }
  
  .calendar-month-year {
    font-size: 0.9rem;
  }
  
  .calendar-nav-btn {
    padding: 0.4rem 0.75rem;
    font-size: 0.75rem;
  }
  
  .calendar-weekday {
    font-size: 0.7rem;
    padding: 0.4rem 0;
  }
  
  .calendar-day {
    font-size: 0.8rem;
    padding: 0.5rem 0;
    min-height: 2rem;
  }
  
  .calendar-tooltip {
    max-width: 200px;
    padding: 0.75rem 1rem;
    font-size: 0.8rem;
  }
  
  .workshop-form-intro {
    font-size: 0.8rem;
    margin-bottom: 1.5rem;
  }
}

/* Contact Form Styling */
.contact-form {
  font-family: 'Montserrat', sans-serif;
}

.contact-form .form-label {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.85rem;
  font-weight: 400;
  color: #050a30;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 0.5rem;
}

.contact-form .form-control {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.9rem;
  color: #050a30;
  background-color: transparent;
  border: 1px solid rgba(5, 10, 48, 0.2);
  border-radius: 0;
  padding: 0.75rem 0;
  transition: border-color 0.3s ease;
}

.contact-form .form-control:focus {
  background-color: transparent;
  border-color: #050a30;
  color: #050a30;
  box-shadow: none;
  outline: none;
}

.contact-form textarea.form-control {
  resize: vertical;
  min-height: 120px;
}

.btn-submit {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.85rem;
  font-weight: 400;
  color: #050a30;
  background-color: transparent;
  border: 1px solid #050a30;
  padding: 0.75rem 2rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  border-radius: 0;
  transition: all 0.3s ease;
  margin-top: 1rem;
}

.btn-submit:hover {
  background-color: #050a30;
  color: #ffffff;
}

/* Map Container Styling */
.map-container {
  width: 100%;
  height: 100%;
  min-height: 400px;
  overflow: hidden;
  border: 1px solid rgba(5, 10, 48, 0.1);
}

.map-container iframe {
  width: 100%;
  height: 100%;
  min-height: 400px;
  opacity: 0.8;
  filter: grayscale(100%);
  transition: opacity 0.3s ease, filter 0.3s ease;
}

.map-container:hover iframe {
  opacity: 0.9;
  filter: grayscale(100%);
}

@media (max-width: 768px) {
  .workshop-form-section {
    padding: 2rem 0;
  }
  
  .map-container {
    margin-top: 2rem;
    min-height: 300px;
  }
  
  .map-container iframe {
    min-height: 300px;
  }
}

.contact-section {
  background-color: #f1f1f1;
  padding: 4rem 0;
}

/* Minimal Contact Form - Editorial Style */
.contact-section .contact-form {
  max-width: 100%;
  margin: 0 auto;
  font-family: 'Montserrat', sans-serif;
}

/* Form Group - Spacing between fields */
.contact-section .form-group {
  margin-bottom: 2rem;
}

/* Form Labels - Minimal, uppercase, subtle */
.contact-section .form-label {
  display: block;
  font-family: 'Montserrat', sans-serif;
  font-size: 0.75rem;
  font-weight: 400;
  color: #050a30;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  margin-bottom: 0.75rem;
}

/* Form Inputs - Clean, minimal borders */
.contact-section .form-input {
  width: 100%;
  font-family: 'Montserrat', sans-serif;
  font-size: 0.9rem;
  font-weight: 300;
  color: #050a30;
  background-color: transparent;
  border: none;
  border-bottom: 1px solid rgba(5, 10, 48, 0.2);
  padding: 0.5rem 0;
  transition: border-color 0.3s ease;
  outline: none;
}

/* Input Focus State - Subtle underline */
.contact-section .form-input:focus {
  border-bottom-color: #050a30;
}

/* Placeholder Text - Subtle, italic */
.contact-section .form-input::placeholder {
  color: rgba(5, 10, 48, 0.4);
  font-style: italic;
  font-weight: 300;
}

/* Textarea - Same styling as input */
.contact-section .form-textarea {
  resize: vertical;
  min-height: 120px;
  font-family: 'Montserrat', sans-serif;
  line-height: 1.6;
}

/* Submit Button - Minimal, elegant */
.contact-section .form-submit {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.85rem;
  font-weight: 400;
  color: #050a30;
  background-color: transparent;
  border: 1px solid rgba(5, 10, 48, 0.3);
  padding: 0.75rem 2.5rem;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  cursor: pointer;
  transition: all 0.3s ease;
  margin-top: 1rem;
}

/* Submit Button Hover - Subtle background fill */
.contact-section .form-submit:hover {
  background-color: #050a30;
  color: #ffffff;
  border-color: #050a30;
}

/* Submit Button Active State */
.contact-section .form-submit:active {
  opacity: 0.9;
}

/* Responsive Adjustments */
@media (max-width: 768px) {
  .contact-section {
    padding: 3rem 0;
  }
  
  .contact-section .form-group {
    margin-bottom: 1.5rem;
  }
  
  .contact-section .form-input {
    font-size: 0.85rem;
  }
  
  .contact-section .form-submit {
    width: 100%;
    padding: 0.875rem 2rem;
  }
}

/* Photo Sessions Page - Minimalist Typography-Driven Design */
.photo-sessions-page {
  background-color: #ffffff;
  padding-top: 100px;
}

.photo-sessions-section {
  padding: 4rem 0;
  min-height: calc(100vh - 200px);
}

/* Page Header */
.photo-sessions-header {
  margin-bottom: 3rem;
  text-align: center;
}

.photo-sessions-title {
  margin: 0;
  text-align: center;
}

.photo-sessions-text-photo {
  font-family: 'Montserrat', sans-serif;
  font-size: 72px;
  font-weight: 400;
  color: #050a30;
}

.photo-sessions-text-sessions {
  font-family: 'Cormorant Garamond', serif;
  font-size: 72px;
  font-weight: 400;
  color: #050a30;
}

/* Introductory Text */
.photo-sessions-intro {
  margin-bottom: 4rem;
  text-align: center;
}

.photo-sessions-intro p {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.95rem;
  font-weight: 300;
  line-height: 1.8;
  color: #050a30;
  max-width: 600px;
  margin: 0 auto;
}

/* Session Types */
.photo-sessions-types {
  margin-bottom: 4rem;
}

.session-type-item {
  margin-bottom: 3rem;
  padding-bottom: 2.5rem;
  border-bottom: 1px solid rgba(5, 10, 48, 0.1);
}

.session-type-item:last-child {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
}

.session-type-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 1.1rem;
  font-weight: 400;
  color: #050a30;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 1rem;
}

.session-type-description {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.9rem;
  font-weight: 300;
  line-height: 1.7;
  color: #050a30;
  margin: 0;
}

/* Availability Note */
.photo-sessions-availability {
  margin-bottom: 3rem;
  text-align: center;
  padding: 2rem 0;
  border-top: 1px solid rgba(5, 10, 48, 0.1);
  border-bottom: 1px solid rgba(5, 10, 48, 0.1);
}

.photo-sessions-availability p {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.85rem;
  font-weight: 300;
  line-height: 1.7;
  color: #050a30;
  margin: 0;
  font-style: italic;
}

/* Call to Action */
.photo-sessions-cta {
  text-align: center;
  margin-top: 3rem;
}

.photo-sessions-cta-link {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.85rem;
  font-weight: 400;
  color: #050a30;
  background-color: transparent;
  border: 1px solid rgba(5, 10, 48, 0.3);
  padding: 0.75rem 2.5rem;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  text-decoration: none;
  display: inline-block;
  transition: all 0.3s ease;
}

.photo-sessions-cta-link:hover {
  background-color: #050a30;
  color: #ffffff;
  border-color: #050a30;
  text-decoration: none;
}

/* Responsive Design */
@media (max-width: 768px) {
  .photo-sessions-section {
    padding: 3rem 0;
  }
  
  .photo-sessions-text-photo,
  .photo-sessions-text-sessions {
    font-size: 48px;
  }
  
  .photo-sessions-intro {
    margin-bottom: 3rem;
  }
  
  .photo-sessions-intro p {
    font-size: 0.9rem;
  }
  
  .photo-sessions-types {
    margin-bottom: 3rem;
  }
  
  .session-type-item {
    margin-bottom: 2.5rem;
    padding-bottom: 2rem;
  }
  
  .session-type-title {
    font-size: 1rem;
  }
  
  .session-type-description {
    font-size: 0.85rem;
  }
  
  .photo-sessions-availability {
    margin-bottom: 2.5rem;
    padding: 1.5rem 0;
  }
  
  .photo-sessions-availability p {
    font-size: 0.8rem;
  }
  
  .photo-sessions-cta {
    margin-top: 2.5rem;
  }
  
  .photo-sessions-cta-link {
    width: 100%;
    padding: 0.875rem 2rem;
  }
}

.section-title {
  background-color: var(--dark-blue);
  color: var(--light-blue);
  padding: 0.5rem 1.5rem;
  display: inline-block;
  text-transform: uppercase;
  font-size: 0.85rem;
  font-weight: 500;
  letter-spacing: 0.17em;
  border-radius: 25px;
  margin-bottom: 2rem;
}

.content-text {
  font-size: 0.85rem;
  line-height: 1.5;
  color: #050a30;
  font-style: italic;
  font-weight: 300;
}

.content-text h5 {
  font-style: normal;
  font-weight: 300;
  margin-top: 1.5rem;
  margin-bottom: 0.5rem;
}

.content-text h5:first-child {
  margin-top: 0;
}

img {
  max-width: 100%;
  height: auto;
}

/* Footer */
footer {
  position: static;
  width: 100%;
  background-color: transparent;
  color: #050a30;
  padding: 1rem 0;
  margin: 0;
}

footer p {
  margin: 0;
  color: #050a30;
}

/* Projects page specific styles */
.projects-page .navbar-brand,
.projects-page .navbar-nav .nav-link {
  color: #050a30;
}

.projects-page .navbar-brand:hover,
.projects-page .navbar-nav .nav-link:hover,
.projects-page .navbar-nav .nav-link.active {
  color: #050a30;
  opacity: 0.8;
}

.projects-page footer p {
  color: #050a30;
}

/* Individual project page styles */
.project-page {
  background-color: #ffffff;
  margin: 0;
  padding: 0;
}

.project-page html {
  background-color: #ffffff;
  margin: 0;
  padding: 0;
}

.project-page .navbar-brand,
.project-page .navbar-nav .nav-link {
  color: #050a30;
}

.project-page .navbar-brand:hover,
.project-page .navbar-nav .nav-link:hover,
.project-page .navbar-nav .nav-link.active {
  color: #050a30;
  opacity: 0.8;
}

.project-page footer p {
  color: #050a30;
}

.project-page .projects-section {
  background-color: #ffffff;
}

.project-page .projects-list {
  color: #050a30;
}

.project-page .project-item {
  color: #050a30;
}

.project-page .project-item:hover {
  color: #050a30;
}

/* Project Gallery */
.project-gallery {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  padding: 2rem 0;
  align-items: center;
  justify-items: center;
}

/* Project Gallery Grid with lightGallery */
.project-gallery-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem;
  padding: 2rem 0;
}

.project-gallery-grid a {
  display: block;
  overflow: hidden;
  cursor: pointer;
  transition: opacity 0.3s ease;
}

.project-gallery-grid a.gallery-item-full-width {
  grid-column: 1 / -1;
  max-width: 50%;
  margin: 0 auto;
}

.project-gallery-grid a:hover {
  opacity: 0.8;
}

.project-gallery-grid img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  aspect-ratio: auto;
}

/* Mobile optimization for gallery */
@media (max-width: 768px) {
  .project-gallery-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
    padding: 1rem 0;
  }
  
  .project-gallery-grid a.gallery-item-full-width {
    max-width: 100%;
  }
  
  .project-gallery-grid img {
    max-width: 100%;
    height: auto;
  }
  
  /* Optimize lightGallery for mobile */
  .lg-sub-html {
    padding: 1.5rem 1rem !important;
    font-size: 0.8rem !important;
    bottom: 2rem !important;
    max-width: 90% !important;
  }
}

@media (max-width: 768px) {
  .project-gallery-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
  
  .project-gallery-grid a.gallery-item-full-width {
    max-width: 100%;
  }
}

.project-gallery img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

.gallery-item-centered {
  grid-column: 1 / -1;
  display: flex;
  justify-content: center;
  align-items: center;
}

.gallery-item-centered img {
  width: 100%;
  max-width: 50%;
  height: auto;
}

.gallery-item-centered:last-child {
  margin-top: -2rem;
}

.gallery-item-side-by-side {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  justify-items: center;
  max-width: 50%;
  margin: 0 auto;
}

.gallery-item-side-by-side img {
  width: 100%;
  max-width: 100%;
  height: auto;
}

.gallery-text-item {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  align-items: center;
}

.gallery-text-item img {
  width: 65%;
  height: auto;
}

.gallery-text {
  color: #050a30;
  font-size: 1rem;
  line-height: 1.6;
}

.gallery-text p {
  margin-bottom: 1.5rem;
}

.gallery-item-left {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  justify-self: center;
}

.gallery-item-left img {
  width: 50%;
  height: auto;
}

.project-text {
  color: #050a30;
  font-size: 1rem;
  line-height: 1.6;
  padding: 2rem 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  height: 100%;
}

.project-text p {
  margin-bottom: 1.5rem;
}

.project-section-with-text {
  position: relative;
}

.project-section-with-text .hero-bottom-text {
  position: absolute;
  bottom: 2rem;
  right: 2rem;
  max-width: 600px;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2rem;
}

.bottom-text-content {
  text-align: right;
  max-width: 274px;
}

.project-section-with-text .hero-bottom-text p {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.8rem;
  line-height: 1.1;
  color: #050a30;
  margin-bottom: 0.5rem;
}

.bottom-images {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  max-width: 300px;
}

.bottom-images img {
  width: 100%;
  height: auto;
}

.project-image {
  padding: 2rem 0;
  display: flex;
  align-items: center;
  height: 100%;
}

.project-image img {
  width: 100%;
  height: auto;
  display: block;
}

/* Available Works Shop */
.available-works-page {
  background-color: #ffffff;
}

.available-works-page .projects-section {
  background-color: #ffffff;
}

.available-works-section {
  padding-top: 120px;
  padding-bottom: 6rem;
  min-height: 100vh;
  background-color: #ffffff;
}

.coming-soon-note {
  text-align: center;
  padding: 4rem 0 2rem;
  margin-bottom: 2rem;
}

.coming-soon-text {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2rem;
  font-weight: 400;
  color: #050a30;
  margin: 0.5rem 0;
  letter-spacing: 0.02em;
  line-height: 1.4;
}

.shop-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 3rem;
  padding: 2rem 0 8rem 0;
  max-width: 1400px;
  margin: 0 auto;
}

.shop-item {
  display: flex;
  flex-direction: column;
  background-color: #ffffff;
  border: 1px solid rgba(5, 10, 48, 0.1);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  cursor: pointer;
}

.shop-item:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 30px rgba(5, 10, 48, 0.1);
}

.shop-item-image {
  width: 100%;
  overflow: hidden;
  background-color: #f5f5f5;
}

.shop-item-image img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.shop-item:hover .shop-item-image img {
  transform: scale(1.05);
}

.shop-item-info {
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.shop-item-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.5rem;
  font-weight: 500;
  color: #050a30;
  margin: 0;
}

.shop-item-description {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.875rem;
  color: #050a30;
  opacity: 0.7;
  margin: 0;
  line-height: 1.5;
}

.shop-item-price {
  font-family: 'Montserrat', sans-serif;
  font-size: 1.25rem;
  font-weight: 500;
  color: #050a30;
  margin: 0.5rem 0;
}

.shop-item-button {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.875rem;
  font-weight: 400;
  color: #050a30;
  background-color: transparent;
  border: 1px solid #050a30;
  padding: 0.75rem 1.5rem;
  cursor: pointer;
  transition: all 0.3s ease;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-top: 0.5rem;
}

.shop-item-button:hover {
  background-color: #050a30;
  color: #ffffff;
}

@media (max-width: 768px) {
  .shop-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
    padding: 1rem;
  }
  
  .available-works-section {
    padding-top: 100px;
  }
}

/* Snipcart customization */
.snipcart-modal__container {
  font-family: 'Montserrat', sans-serif;
}

.snipcart-modal__header-title {
  font-family: 'Cormorant Garamond', serif;
  color: #050a30;
}

.snipcart-button-primary {
  background-color: #050a30;
  border-color: #050a30;
}

.snipcart-button-primary:hover {
  background-color: #050a30;
  opacity: 0.9;
}

/* Limen Gallery Grid - Custom Layout */
.limen-gallery-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1.5rem;
  padding: 2rem 0;
}

.limen-gallery-grid a {
  display: block;
  overflow: hidden;
  cursor: pointer;
  transition: opacity 0.3s ease;
}

.limen-gallery-grid a:hover {
  opacity: 0.8;
}

.limen-gallery-grid img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

/* 2 columns desktop, 1 mobile */
.limen-item-2col {
  grid-column: span 3;
}

/* Pair of images centered together */
.limen-item-pair-left {
  grid-column: 2 / span 2;
  justify-self: center;
  height: 715px;
  display: flex;
  align-items: center;
}

.limen-item-pair-right {
  grid-column: 4 / span 2;
  justify-self: center;
  height: 715px;
  display: flex;
  align-items: center;
}

.limen-item-pair-left img,
.limen-item-pair-right img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (max-width: 768px) {
  .limen-item-pair-left,
  .limen-item-pair-right {
    grid-column: 1 / -1;
  }
  
  .limen-item-pair-left img,
  .limen-item-pair-right img {
    height: auto;
  }
}

/* No Alternatives Gallery Grid - Custom Layout */
.no-alternatives-gallery-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem;
  padding: 2rem 0;
}

.no-alternatives-gallery-grid a {
  display: block;
  overflow: hidden;
  cursor: pointer;
  transition: opacity 0.3s ease;
}

.no-alternatives-gallery-grid a:hover {
  opacity: 0.8;
}

.no-alternatives-gallery-grid img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

/* 1 column (full width) */
.no-alt-item-1col {
  grid-column: 1 / -1;
}

/* Smaller item - 25% smaller */
.no-alt-item-smaller {
  display: flex;
  justify-content: center;
  align-items: center;
}

.no-alt-item-smaller img {
  width: 75%;
  max-width: 75%;
  height: auto;
  margin: 0 auto;
}

/* Pair container - keeps images close together and centered */
.no-alt-pair-container {
  grid-column: 1 / -1;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1rem;
  max-width: 75%;
  margin: 0 auto;
}

.no-alt-pair-container a {
  flex: 0 0 calc(50% - 0.5rem);
  display: block;
  overflow: hidden;
  cursor: pointer;
  transition: opacity 0.3s ease;
}

.no-alt-pair-container a:hover {
  opacity: 0.8;
}

/* Pair of images - same size, matching image above */
.no-alt-item-pair-smaller {
  display: block;
}

.no-alt-item-pair-smaller img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

/* 2 columns desktop, 1 mobile */
.no-alt-item-2col {
  grid-column: span 1;
}

/* 2 columns desktop, 2 mobile */
.no-alt-item-2col-mobile {
  grid-column: span 1;
}

/* Text block styling */
.no-alt-text-block {
  grid-column: 1 / -1;
  max-width: 800px;
  margin: 2rem auto;
  padding: 0 1rem;
}

.no-alt-text-block p {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.1rem;
  line-height: 1.8;
  color: #050a30;
  margin-bottom: 1.5rem;
  text-align: left;
}

.no-alt-text-block p:last-child {
  margin-bottom: 0;
}

/* Mobile optimization for No Alternatives gallery */
@media (max-width: 768px) {
  .no-alternatives-gallery-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
    padding: 1rem 0;
  }
  
  .no-alt-item-1col,
  .no-alt-item-2col {
    grid-column: 1 / -1;
  }
  
  /* 5th line: 2 columns on mobile */
  .no-alt-item-2col-mobile {
    grid-column: span 1;
  }
  
  /* Pair container on mobile */
  .no-alt-pair-container {
    max-width: 100%;
    gap: 0.5rem;
  }
  
  .no-alt-text-block {
    padding: 0 1rem;
    margin: 1.5rem auto;
  }
}

/* Water Air Breath Gallery Grid - Custom Layout */
.water-air-breath-gallery-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem;
  padding: 2rem 0;
}

.water-air-breath-gallery-grid a {
  display: block;
  overflow: hidden;
  cursor: pointer;
  transition: opacity 0.3s ease;
}

.water-air-breath-gallery-grid a:hover {
  opacity: 0.8;
}

.water-air-breath-gallery-grid img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

/* 1 column (full width) */
.water-air-item-1col {
  grid-column: 1 / -1;
}

/* 2 columns desktop, 1 mobile */
.water-air-item-2col {
  grid-column: span 1;
}

/* Text block styling */
.water-air-text-block {
  grid-column: 1 / -1;
  max-width: 800px;
  margin: 2rem auto;
  padding: 0 1rem;
}

.water-air-text-block p {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.1rem;
  line-height: 1.8;
  color: #050a30;
  margin-bottom: 1.5rem;
  text-align: left;
}

.water-air-text-block p:last-child {
  margin-bottom: 0;
}

/* Mobile optimization for Water Air Breath gallery */
@media (max-width: 768px) {
  .water-air-breath-gallery-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
    padding: 1rem 0;
  }
  
  .water-air-item-1col,
  .water-air-item-2col {
    grid-column: 1 / -1;
  }
  
  .water-air-text-block {
    padding: 0 1rem;
    margin: 1.5rem auto;
  }
  
  .water-air-text-block p {
    font-size: 1rem;
    line-height: 1.6;
  }
  
  .water-air-breath-gallery-grid img {
    max-width: 100%;
    height: auto;
  }
  
  .no-alt-text-block p {
    font-size: 1rem;
    line-height: 1.6;
  }
  
  .no-alternatives-gallery-grid img {
    max-width: 100%;
    height: auto;
  }
  
  /* Optimize lightGallery for mobile */
  .lg-sub-html {
    padding: 1.5rem 1rem !important;
    font-size: 0.8rem !important;
    bottom: 2rem !important;
    max-width: 90% !important;
  }
}

/* 1 column (full width) */
.limen-item-1col {
  grid-column: 1 / -1;
}

/* 3 columns desktop, 1 mobile */
.limen-item-3col {
  grid-column: span 2;
}

/* Centered item - 25% smaller */
.limen-item-centered {
  display: flex;
  justify-content: center;
  align-items: center;
}

.limen-item-centered img {
  width: 56%;
  max-width: 56%;
  height: auto;
  margin: 0 auto;
}

/* Smaller item - 30% smaller */
.limen-item-smaller {
  display: flex;
  justify-content: center;
  align-items: center;
  justify-self: center;
  align-self: center;
  grid-column: span 3;
}

.limen-item-smaller img {
  width: 70%;
  max-width: 70%;
  height: auto;
  margin: 0 auto;
}

/* Centered item - 15% smaller */
.limen-item-centered-15 {
  display: flex;
  justify-content: flex-start;
  align-items: center;
}

.limen-item-centered-15 img {
  width: 85%;
  max-width: 85%;
  height: auto;
  margin: 0;
}

/* Mobile optimization for Limen gallery */
@media (max-width: 768px) {
  .limen-gallery-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
    padding: 1rem 0;
  }
  
  .limen-item-2col,
  .limen-item-3col,
  .limen-item-1col {
    grid-column: 1 / -1;
  }
  
  .limen-gallery-grid img {
    max-width: 100%;
    height: auto;
  }
  
  /* Optimize lightGallery for mobile */
  .lg-sub-html {
    padding: 1.5rem 1rem !important;
    font-size: 0.8rem !important;
    bottom: 2rem !important;
    max-width: 90% !important;
  }
}

