/**
 * Theme Name: Sophia Marie Fotografie 
 * Description: A theme for Sophia Marie Fotografie.
 * Author: Lufy
 * Author URI: https://lufy.at
 * Version: 1.0.0
 */

@font-face {
  font-family: "Plus Jakarta Sans";
  src: url("./assets/fonts/PlusJakartaSans-VariableFont_wght.ttf") format("truetype");
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
}

@font-face {
  font-family: "Plus Jakarta Sans";
  src: url("./assets/fonts/PlusJakartaSans-Italic-VariableFont_wght.ttf") format("truetype");
  font-style: italic;
  font-weight: 200 800;
  font-display: swap;
}

:root {
  --color-text: #000;
  --color-text-muted: #707070;
  --container-padding: 16px;
  --grid-gutter: 16px;
  --anchor-offset: 88px;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  color: var(--color-text);
  font-family: "Plus Jakarta Sans", sans-serif;
  margin: 0;
}

html.js .animate-in {
  opacity: 0;
  transform: translateY(24px);
  visibility: hidden;
}

html.js.gsap-ready .animate-in {
  visibility: visible;
}

html {
  scroll-behavior: smooth;
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
}

h1,
h2 {
  color: var(--color-text);
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 24px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  letter-spacing: -0.48px;
}

p {
  color: var(--color-text);
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 14px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
}

a {
  color: var(--color-text);
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 14px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  text-decoration-line: underline;
  text-decoration-style: solid;
}

/* Secondary link style for less prominent links. */
.link-secondary {
  color: rgba(0, 0, 0, 0.56);
  text-decoration: none;
}

.link-secondary[aria-current="page"],
.link-secondary[aria-current="location"] {
  color: var(--color-text);
}

/* Global 12-column layout grid. */
.layout-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  column-gap: var(--grid-gutter);
  padding-left: var(--container-padding);
  padding-right: var(--container-padding);
}

/* Desktop default column setup: 1-2 / 3-5 / 6-12 */
.col-1 {
  grid-column: 1 / -1;
}

.col-2 {
  grid-column: 1 / -1;
}

.col-3 {
  grid-column: 1 / -1;
}

/* Mobile off-canvas menu links */
.offcanvas-link {
  color: rgba(0, 0, 0, 0.56);
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 24px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  letter-spacing: -0.48px;
  text-decoration: none;
}

.offcanvas-link[aria-current="page"],
.offcanvas-link[aria-current="location"] {
  color: var(--color-text);
}

#referenzen,
#business,
#privat,
#sophia,
#kontakt {
  scroll-margin-top: var(--anchor-offset);
}

.site-header {
  background: #fff;
  left: 0;
  padding-top: 20px;
  padding-bottom: 20px;
  position: sticky;
  top: 0;
  width: 100%;
  z-index: 1200;
}

.site-header .layout-grid {
  align-items: center;
  position: relative;
}

.header-logo {
  display: flex;
  align-items: center;
  position: relative;
  z-index: 1502;
}

.header-logo img {
  display: block;
  max-width: 100%;
  height: auto;
}

.header-toggle {
  align-items: center;
  background: transparent;
  border: 0;
  cursor: pointer;
  display: inline-flex;
  flex-direction: column;
  gap: 8px;
  justify-content: center;
  padding: 0;
  position: absolute;
  right: var(--container-padding);
  top: 50%;
  transform: translateY(-50%);
  z-index: 1603;
}

.header-toggle-line {
  background: var(--color-text);
  display: block;
  height: 2px;
  transition: transform 0.25s ease;
  width: 26px;
}

body.nav-open {
  overflow: hidden;
}

body.nav-open .header-toggle-line:first-child {
  transform: translateY(5px) rotate(45deg);
}

body.nav-open .header-toggle-line:last-child {
  transform: translateY(-5px) rotate(-45deg);
}

.header-offcanvas {
  background: #fff;
  display: flex;
  flex-direction: column;
  inset: 0;
  opacity: 0;
  padding: 24px var(--container-padding) 120px;
  pointer-events: none;
  position: fixed;
  transition: opacity 0.25s ease;
  visibility: hidden;
  z-index: 1400;
}

.header-offcanvas-nav {
  display: flex;
  flex-direction: column;
  gap: 16px;
  list-style: none;
  margin: auto 0;
  padding: 0;
}

.header-offcanvas-contact {
  display: flex;
  flex-direction: column;
  gap: 8px;
  list-style: none;
  margin: auto 0 0;
  padding: 0;
}

body.nav-open .header-offcanvas {
  opacity: 1;
  pointer-events: auto;
  visibility: visible;
}

.header-nav-list {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 24px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.header-nav {
  display: none;
}

.hero {
  margin-top: 40vh;
  margin-bottom: 120px;
}

.hero h1 {
  margin: 0;
}

.hero-referenzen-swiper {
  margin-top: 80px;
}

.hero-referenzen-swiper.swiper-fade .swiper-slide {
  pointer-events: none;
}

.hero-referenzen-swiper.swiper-fade .swiper-slide-active {
  pointer-events: auto;
}

.hero-slide-meta {
  margin-bottom: 8px;
}

.hero-slide-meta .col-2 {
  grid-column: 1 / 3;
}

.hero-slide-meta .col-1 {
  grid-column: 3 / 5;
  text-align: left;
}

.hero-slide-meta .col-3 {
  grid-column: 3 / 5;
  margin-top: 0;
}

.hero-slide-title {
  font-size: 14px;
  letter-spacing: 0;
  margin: 0;
}

.hero-slide-meta p {
  margin: 0;
}

.hero-slide-categories {
  text-align: left;
}

.hero-slide-categories p {
  color: var(--color-text-muted);
}

.hero-slide-image {
  grid-column: 1 / 13;
  aspect-ratio: 3 / 2;
  overflow: hidden;
}

.hero-slide-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}

.hero-slide-image a {
  display: block;
  width: 100%;
  height: 100%;
}

.hero-slide-image a:hover img {
  transform: scale(1.04);
}

.hero-slider-controls {
  margin-top: 8px;
}

.hero-slider-controls .col-1 {
  grid-column: 1 / 3;
}

.hero-slider-controls .col-3 {
  align-items: center;
  display: flex;
  grid-column: 3 / 5;
  justify-content: flex-start;
}

.hero-slider-arrows {
  display: flex;
  align-items: center;
  gap: 12px;
}

.hero-slider-arrows button {
  border: 0;
  background: transparent;
  color: var(--color-text);
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
  padding: 0;
}

.hero-all-referenzen-link {
  text-align: right;
}

.referenzen-filter-wrap {
  margin-top: 80px;
}

.hero.referenzen-hero {
  margin-top: 32px;
  margin-bottom: 32px;
}

.referenzen-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 24px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.referenzen-list-section {
  margin-bottom: 120px;
}

.referenzen-list {
  row-gap: 32px;
}

.referenz-card {
  min-width: 0;
}

.referenz-card--left {
  grid-column: 1 / 5;
}

.referenz-card--right {
  grid-column: 1 / 5;
}

.referenz-card--full {
  grid-column: 1 / 5;
}

.referenz-card-image-link {
  aspect-ratio: 3 / 2;
  display: block;
  overflow: hidden;
  width: 100%;
}

.referenz-card-image-link img {
  display: block;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
  width: 100%;
}

.referenz-card-image-link:hover img {
  transform: scale(1.04);
}

.referenz-card-meta {
  align-items: flex-start;
  display: flex;
  gap: 16px;
  justify-content: space-between;
  margin-top: 8px;
}

.referenz-card-title {
  margin: 0;
}

.referenz-card-categories {
  color: var(--color-text-muted);
  margin: 0;
}

.referenz-card-meta-right p {
  margin: 0;
}

.referenz-detail-hero {
  margin-top: 80px;
}

.referenz-detail-hero-image {
  grid-column: 1 / 5;
}

.referenz-detail-hero-image img {
  aspect-ratio: 3 / 2;
  display: block;
  height: auto;
  object-fit: cover;
  width: 100%;
}

.referenz-detail-content {
  margin-top: 144px;
  margin-bottom: 144px;
}

.referenz-detail-content h1 {
  margin: 0;
}

.referenz-detail-year {
  margin: 32px 0 0;
}

.referenz-detail-categories {
  color: var(--color-text-muted);
  margin: 8px 0 0;
}

.referenz-detail-text {
  margin-top: 32px;
}

.referenz-detail-text p {
  margin: 0;
}

.referenz-detail-gallery-section {
  margin-bottom: 120px;
}

.referenz-detail-gallery .referenz-card-image-link img {
  transition: none;
}

.referenz-detail-gallery .referenz-card-image-link:hover img {
  transform: none;
}

.error-404-section {
  min-height: calc(100vh - 220px);
  padding: 80px 0;
}

.error-404-content {
  align-items: center;
  display: flex;
  flex-direction: column;
  grid-column: 1 / 5;
  justify-content: center;
  text-align: center;
}

.error-404-content h1 {
  margin: 0;
}

.error-404-content p {
  margin: 16px 0 0;
}

.error-404-content a {
  margin-top: 16px;
}

.site-footer {
  margin-bottom: 40px;
}

.footer-top {
  margin-top: 144px;
}

.footer-brand {
  display: flex;
  flex-direction: column;
}

.footer-brand > a {
  display: block;
  width: 100%;
}

.footer-brand img {
  display: block;
  height: auto;
  max-width: 100%;
  width: 100%;
}

.footer-contact-links {
  display: flex;
  flex-direction: column;
  gap: 8px;
  list-style: none;
  margin: 32px 0 0;
  padding: 0;
}

.footer-bottom {
  margin-top: 144px;
}

.footer-bottom-inner {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 12px 24px;
  grid-column: 1 / 13;
  justify-content: space-between;
}

.footer-links-left,
.footer-links-right {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 8px 24px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.business-section {
  margin-bottom: 80px;
}

.privat-section {
  margin-bottom: 144px;
}

.sophia-section {
  margin-bottom: 120px;
}

.business-section h2 {
  margin: 0;
}

.privat-section h2 {
  margin: 0;
}

.sophia-section h2 {
  margin: 0;
}

.business-bereiche {
  color: var(--color-text-muted);
  max-width: calc(50% - (var(--grid-gutter) / 2));
  margin-top: 8px;
  margin-bottom: 0;
}

.privat-bereiche {
  color: var(--color-text-muted);
  max-width: calc(50% - (var(--grid-gutter) / 2));
  margin-top: 8px;
  margin-bottom: 0;
}

.sophia-eigenschaften {
  color: var(--color-text-muted);
  max-width: calc(50% - (var(--grid-gutter) / 2));
  margin-top: 8px;
  margin-bottom: 0;
}

.business-content p {
  margin: 0 0 40px;
}

.privat-content p {
  margin: 0 0 40px;
}

.sophia-content p {
  margin: 0 0 40px;
}

.business-content a {
  display: inline-block;
}

.privat-content a {
  display: inline-block;
}

.sophia-content a {
  display: inline-block;
}

.kontakt-section {
  margin-bottom: 80px;
}

.kontakt-section h2 {
  margin: 0;
}

.kontakt-content p {
  margin: 0 0 32px;
}

.kontakt-links {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.kontakt-links a {
  display: inline-block;
}

.kontakt-content {
  margin-top: 8px;
}

.kontakt-links {
  display: none;
}

.kontakt-form {
  margin-top: 24px;
}

.kontakt-form .wpcf7 {
  width: 100%;
}

.kontakt-form .wpcf7-form {
  margin: 0;
}

.kontakt-form p {
  font-size: 12px;
}

.kontakt-form .wpcf7-form > p {
  margin: 0 0 12px;
}

.kontakt-form .wpcf7-form > p:last-of-type {
  margin-bottom: 0;
}

.kontakt-form .wpcf7-form-control-wrap {
  display: block;
}

.kontakt-form input[type="text"],
.kontakt-form input[type="email"],
.kontakt-form input[type="tel"],
.kontakt-form select,
.kontakt-form textarea {
  appearance: none;
  background: transparent;
  border: 1px solid var(--color-text);
  border-radius: 0;
  box-shadow: none;
  color: var(--color-text);
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 12px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  margin: 0;
  outline: none;  
  padding: 12px 16px;
  width: 100%;
}

.kontakt-form textarea {
  min-height: 220px;
  resize: vertical;
}

.kontakt-form select:invalid {
  color: var(--color-text-muted);
}

.kontakt-form select option {
  color: var(--color-text);
}

.kontakt-form select option[value=""][disabled] {
  color: var(--color-text-muted);
}

.kontakt-form ::placeholder {
  color: var(--color-text-muted);
  font-size: 12px;
  opacity: 1;
}

.kontakt-form .wpcf7-acceptance .wpcf7-list-item {
  margin: 0;
}

.kontakt-form .wpcf7-acceptance .wpcf7-list-item label {
  align-items: flex-start;
  color: var(--color-text-muted);
  column-gap: 8px;
  display: inline-flex;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 14px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
}

.kontakt-form .wpcf7-acceptance input[type="checkbox"] {
  margin: 3px 0 0;
}

.kontakt-form input[type="submit"],
.kontakt-form button[type="submit"] {
  background: transparent;
  border: 0;
  color: var(--color-text);
  cursor: pointer;
  display: inline-block;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 14px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  margin-top: 24px;
  padding: 0;
  text-decoration-line: underline;
  text-decoration-style: solid;
}

.kontakt-form .wpcf7-response-output {
  background: transparent !important;
  border: none !important;
  color: var(--color-text);
  font-size: 12px;
  font-weight: 600;
  margin: 16px 0 0 !important;
  outline: 0;
  padding: 0 !important;
}

.kontakt-form .wpcf7-not-valid-tip {
  color: var(--color-text);
  font-size: 12px;
  font-weight: 600;
  margin-top: 8px;
}

.business-image {
  aspect-ratio: 3 / 2;
  margin-top: 24px;
  min-width: 0;
  order: 2;
  overflow: hidden;
}

.privat-image {
  aspect-ratio: 3 / 2;
  margin-top: 24px;
  min-width: 0;
  order: 2;
  overflow: hidden;
}

.sophia-image {
  aspect-ratio: 2 / 3;
  margin-top: 24px;
  min-width: 0;
  overflow: hidden;
}

.business-content {
  margin-top: 24px;
  order: 3;
}

.privat-content,
.sophia-content {
  margin-top: 24px;
}

.privat-content {
  order: 3;
}

.business-image img {
  height: 100%;
  max-width: 100%;
  object-fit: cover;
  width: 100%;
  display: block;
}

.privat-image img {
  height: 100%;
  max-width: 100%;
  object-fit: cover;
  width: 100%;
  display: block;
}

.sophia-image img {
  height: 100%;
  max-width: 100%;
  object-fit: cover;
  width: 100%;
  display: block;
}

@media (min-width: 768px) {
  :root {
    --container-padding: 40px;
    --grid-gutter: 24px;
    --anchor-offset: 104px;
  }

  .layout-grid {
    grid-template-columns: repeat(12, minmax(0, 1fr));
  }

  .header-toggle,
  .header-offcanvas {
    display: none;
  }

  .header-nav {
    display: flex;
    justify-content: flex-end;
  }

  .referenz-detail-hero {
    margin-top: 40px;
  }

  .referenz-detail-hero-image {
    grid-column: 1 / 13;
  }

  .referenz-detail-hero-image img {
    aspect-ratio: 2 / 1;
  }

  .referenz-detail-text {
    margin-top: 32px;
  }

  .referenz-card--left {
    grid-column: 1 / 6;
  }

  .referenz-card--right {
    grid-column: 6 / 13;
  }

  .referenz-card--full {
    grid-column: 1 / 13;
  }

  .referenz-card-image-link img {
    aspect-ratio: 3 / 2;
  }

  .error-404-content {
    grid-column: 1 / 13;
  }

  .col-1 {
    grid-column: 1 / 3;
  }

  .col-2 {
    grid-column: 3 / 6;
  }

  .col-3 {
    grid-column: 6 / 13;
  }

  .business-bereiche,
  .privat-bereiche,
  .sophia-eigenschaften {
    max-width: none;
  }

  .sophia-section {
    margin-bottom: 144px;
  }

  .kontakt-content,
  .kontakt-form {
    margin-top: 0;
  }

  .kontakt-links {
    display: flex;
  }

  .hero {
    margin-top: 64px;
    margin-bottom: 120px;
  }

  .hero-slide-meta .col-1 {
    grid-column: 1 / 3;
    text-align: left;
  }

  .hero-slide-meta .col-2 {
    grid-column: 3 / 6;
  }

  .hero-slide-meta .col-3 {
    grid-column: 6 / 13;
    margin-top: 0;
  }

  .hero-slider-controls .col-1 {
    grid-column: 1 / 3;
  }

  .hero-slider-controls .col-3 {
    display: block;
    grid-column: 6 / 13;
  }

  p {
    font-size: 16px;
  }

  a,
  .link-secondary {
    font-size: 16px;
  }

  .kontakt-form input[type="text"],
  .kontakt-form input[type="email"],
  .kontakt-form input[type="tel"],
  .kontakt-form select,
  .kontakt-form textarea,
  .kontakt-form .wpcf7-acceptance .wpcf7-list-item label,
  .kontakt-form input[type="submit"],
  .kontakt-form button[type="submit"] {
    font-size: 16px;
  }

  .kontakt-form input[type="text"],
  .kontakt-form input[type="email"],
  .kontakt-form input[type="tel"],
  .kontakt-form select,
  .kontakt-form textarea {
    font-size: 12px;
  }

  .hero-slide-title {
    font-size: 16px;
  }

  .hero-slide-categories {
    text-align: right;
  }

  .hero.referenzen-hero {
    margin-top: 32px;
    margin-bottom: 32px;
  }

  .hero-slide-image {
    aspect-ratio: 2 / 1;
  }

  .privat-image,
  .business-image,
  .sophia-image,
  .business-content,
  .privat-content,
  .sophia-content {
    margin-top: 0;
  }

  .business-image,
  .business-content,
  .privat-image,
  .privat-content {
    order: initial;
  }

  .business-content p,
  .privat-content p,
  .sophia-content p {
    margin: 0 0 32px;
  }
}
