/* app.css - bundled styles */

/* typography.css - Schwebepixel Style Guide */
.content-html {
  font-family: 'Open Sans', sans-serif;
  color: #002D43; /* primary */
  line-height: 1.6;
  text-align: center;
  padding: 0.5rem 1rem;
}
.content-html h1 {
  font-family: 'Montserrat', sans-serif;
  font-size: 2rem;
  font-weight: 700;
  margin-top: 1rem;
  margin-bottom: 0.5rem;
  color: #002D43;
}
.content-html h2 {
  font-family: 'Montserrat', sans-serif;
  font-size: 1.5rem;
  font-weight: 600;
  margin-top: 0.75rem;
  margin-bottom: 0.5rem;
  color: #00A7B5;
}
.content-html h3,
.content-html h4,
.content-html h5,
.content-html h6 {
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  margin-top: 1rem;
  margin-bottom: 0.5rem;
  color: #002D43;
}
.content-html p {
  margin-bottom: 1rem;
  font-size: 1rem;
  color: #4A6A7A; /* neutral */
  text-align: left;
}
.content-html ul,
.content-html ol {
  text-align: left;
  margin: 0.75rem auto 1rem auto;
  padding-left: 1.5rem;
  max-width: 700px;
  color: #002D43;
}
.content-html ul li,
.content-html ol li {
  margin-bottom: 0.5rem;
  line-height: 1.6;
}
.content-html strong { font-weight: bold; }
.content-html em { font-style: italic; }
.content-html br {
  display: block;
  margin: 0.25rem 0;
  line-height: 1rem;
}
footer .w-full { max-width: none !important; }

/* portfolio.css */
.filter-buttons button {
  margin: 5px;
  padding: 10px 20px;
  border: none;
  border-radius: 12px;
  background-color: #4A6A7A;
  color: white;
  cursor: pointer;
  font-size: 16px;
  transition: all 0.3s ease;
}
.filter-buttons button.active { background-color: #00A7B5 !important; }
.gallery img {
  width: 100%;
  max-width: 900px;
  border-radius: 12px;
  box-shadow: 0 2px 15px rgba(0, 0, 0, 0.2);
  transition: transform 0.2s ease-in-out, opacity 0.3s ease;
  margin: 0 auto;
  display: block;
}
.gallery img:hover { transform: scale(1.02); }

/* instagram.css */
.ig-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 1rem;
  margin: 0;
  padding: 0;
}
.ig-card {
  display: block;
  text-decoration: none;
  background: none;
  border: 0;
  margin: 0;
  padding: 0;
}
.ig-media {
  position: relative;
  display: block;
  width: 100%;
  padding-top: 0 !important;
  background: none;
  border-radius: 12px;
  overflow: hidden;
}
.ig-media > img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  transition: transform .25s ease;
}
.ig-card:hover .ig-media > img { transform: scale(1.02); }
.ig-badge {
  position: absolute;
  right: .5rem;
  top: .5rem;
  background: rgba(0, 0, 0, .55);
  color: #fff;
  font-weight: 700;
  font-size: .85rem;
  line-height: 1;
  padding: .35rem .5rem .3rem;
  border-radius: .5rem;
  backdrop-filter: blur(4px);
}
.ig-empty { display: none; }

/* header-fix.css */
header > .container {
  box-sizing: border-box;
  max-width: 100% !important;
  width: 100% !important;
  margin: 0 !important;
  height: 60px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  min-height: 60px !important;
  padding-left: 16px;
  padding-right: 16px;
}
@media (min-width: 1076px) {
  header > .container {
    padding-left: 24px;
    padding-right: 24px;
  }
}
header > .container > .flex:first-child {
  display: flex !important;
  align-items: center !important;
  flex-shrink: 0 !important;
  white-space: nowrap !important;
}
header .flex a img {
  display: block !important;
  width: auto !important;
  height: 40px !important;
}
@media (min-width: 768px) {
  header .flex a img { height: 56px !important; }
}
header .font-heading { line-height: 1.1 !important; }
header .text-accent  { line-height: 1 !important; margin-top: 4px !important; }
#menu-button{
  width: 40px !important;
  height: 40px !important;
  display: inline-grid !important;
  place-items: center !important;
  margin-left: auto !important;
  position: relative !important;
  z-index: 9999 !important;
}
@media (min-width: 768px) {
  #mobile-menu { display: block !important; }
  #mobile-menu.hidden { display: none !important; }
  #desktop-menu { display: none !important; }
}
@media (min-width: 1024px) {
  #desktop-menu{
    display: flex !important;
    align-items: center !important;
    white-space: nowrap !important;
    margin-left: auto !important;
    gap: 0px !important;
  }
  #desktop-menu a{
    display: flex !important;
    align-items: center !important;
    height: 60px !important;
    line-height: normal !important;
    padding: 0px !important;
    position: relative;
    top: -0.5px;
  }
  #menu-button { display: none !important; }
  #mobile-menu { display: none !important; }
  #desktop-menu { display: flex !important; }
}
#mobile-menu{
  left: auto !important;
  right: 0 !important;
  width: 70% !important;
  max-width: 340px !important;
  border-top: 1px solid #e5e7eb !important;
  border-left: 1px solid #e5e7eb !important;
  border-right: none !important;
  border-bottom: none !important;
  background: #fff !important;
  box-shadow: -4px 0 10px rgba(0,0,0,0.08);
  border-radius: 0 0 0 8px;
  z-index: 1000 !important;
}
#mobile-menu .mobile-link{
  display: block !important;
  width: 100% !important;
  padding-left: 20px !important;
  padding-right: 0 !important;
}
html.spx-lock, html.spx-lock body {
  overflow: hidden !important;
}
