/* ============================================================
   CUSTOM PROPERTIES
   ============================================================ */
:root {
  --color-text:        #FAFAFA;
  --color-bg-dark:     #0d0d0d;
  --color-accent:      #C8A97A;
  --color-placeholder: #595959;
  --color-about:       #00796B;
  --color-contact:     #A52A2A;
  --color-social:      #F06292;
  --color-footer:      #F57C00;
  --color-sold:        #FF6347;
  --color-modal-bg:    rgba(0, 0, 0, 0.92);
  --font-main:         'Comfortaa', cursive;
  --transition-fast:   all 0.3s ease-in-out;
  --transition-art:    0.7s ease;
}

/* ============================================================
   RESET
   ============================================================ */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  border: 0;
}

body {
  min-height: 100vh;
  overflow-x: hidden;
  user-select: none;
  background: var(--color-bg-dark);
}

/* ============================================================
   FONT & SHARED TEXT
   ============================================================ */
@font-face {
  font-family: Comfortaa;
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(../res/font/Comfortaa-VariableFont_wght.ttf);
}

.text {
  letter-spacing: 2px;
  color: var(--color-text);
  padding: 15px 0;
  font-family: var(--font-main);
  font-size: 16px;
  text-shadow: 0 0 15px rgba(0, 0, 0, .5);
  transition: var(--transition-fast);
  animation: fadein 2s ease forwards;
}

@keyframes fadein {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* ============================================================
   NAVIGATION
   Fixed bar — transparent until scrolled, then frosted glass.
   pointer-events: none while transparent so hero interactions
   are not blocked; re-enabled on .scrolled.
   ============================================================ */
#main-nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 9000;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 2rem;
  height: 56px;
  background: transparent;
  transition: background 0.4s ease, backdrop-filter 0.4s ease;
  pointer-events: none;
}

#main-nav.scrolled {
  background: rgba(10, 10, 10, 0.88);
  backdrop-filter: blur(10px);
  pointer-events: auto;
}

.nav-logo {
  font-family: var(--font-main);
  color: var(--color-text);
  font-size: 18px;
  text-decoration: none;
  letter-spacing: 4px;
  opacity: 0;
  transition: opacity 0.4s ease, color 0.2s ease;
}

/* Desktop link list */
#main-nav ul {
  list-style: none;
  display: flex;
  gap: 2.5rem;
  opacity: 0;
  transition: opacity 0.4s ease;
}

/* Logo and links fade in once the nav becomes visible */
#main-nav.scrolled .nav-logo,
#main-nav.scrolled ul {
  opacity: 1;
}

#main-nav a {
  font-family: var(--font-main);
  color: var(--color-text);
  text-decoration: none;
  font-size: 13px;
  letter-spacing: 2px;
  transition: color 0.2s ease;
}

#main-nav a:hover,
.nav-logo:hover {
  color: var(--color-accent);
}

/* Hamburger button — hidden on desktop. */
#nav-hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px 6px;
  -webkit-appearance: none;
  appearance: none;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.4s ease;
}

#nav-hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--color-text);
  border-radius: 2px;
  transition: transform 0.3s ease, opacity 0.3s ease;
}

#main-nav.scrolled #nav-hamburger {
  opacity: 1;
  pointer-events: auto;
}

/* Three spans animate into an X when the menu is open */
#main-nav.menu-open #nav-hamburger span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
#main-nav.menu-open #nav-hamburger span:nth-child(2) { opacity: 0; }
#main-nav.menu-open #nav-hamburger span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ============================================================
   HERO
   Full-viewport cover image with vignette overlay and a
   bottom gradient that fades smoothly into the gallery.
   The hero content (title/subtitle) is position:fixed so it
   stays centred while the hero section scrolls away; JS fades
   it out via opacity once the hero leaves the viewport.
   ============================================================ */
#page-main {
  background: url(../res/img/bg-main.jpg) no-repeat fixed center center;
  background-size: cover;
  min-height: 100vh;
  overflow: hidden;
  pointer-events: none;
  position: relative;
  z-index: 8000;
}

/* Radial + linear vignette for depth and contrast */
#page-main::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at center, transparent 40%, rgba(0,0,0,0.55) 100%),
    linear-gradient(to bottom, rgba(0,0,0,0.15) 0%, transparent 50%, rgba(0,0,0,0.4) 100%);
  pointer-events: none;
}

/* Gradient that blends the bottom of the hero into the gallery background */
#hero-gradient {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 180px;
  background: linear-gradient(to bottom, transparent, var(--color-bg-dark));
  pointer-events: none;
  z-index: 2;
}

/* Fixed overlay: stays centred while hero is in view, hidden by JS once hero scrolls out */
#page-main-content {
  position: fixed;
  top: 50%;
  transform: translateY(-50%);
  width: 100%;
  text-align: center;
  z-index: 1;
  transition: opacity 0.3s ease;
}

#title {
  font-size: 120px;
  margin: 0;
}

#subtitle {
  font-size: 56px;
  text-transform: uppercase;
}

.divider {
  margin: 50px 0;
  height: 1px;
  color: white;
  animation: fadein 2s ease forwards;
}

/* Gradient line rendered via ::before so it spans the full width */
.div-transparent::before {
  content: "";
  position: absolute;
  left: 10%;
  right: 10%;
  height: 2px;
  background-image: linear-gradient(to right, transparent, rgba(255,255,255,0.7), transparent);
}

/* Animated scroll prompt shown at the bottom of the hero */
.mouse-icon {
  position: fixed;
  bottom: 40px;
  left: 50%;
  transform: translateX(-50%);
  border: 2px solid var(--color-text);
  border-radius: 16px;
  height: 50px;
  width: 30px;
}

.mouse-icon .wheel {
  position: relative;
  border-radius: 10px;
  background: var(--color-text);
  width: 4px;
  height: 10px;
  top: 4px;
  margin: 0 auto;
  animation: drop 1.2s linear infinite;
}

@keyframes drop {
  0%   { top: 5px;  opacity: 0; }
  30%  { top: 10px; opacity: 1; }
  100% { top: 25px; opacity: 0; }
}

/* ============================================================
   GALLERY FILTER
   Three buttons (All / Available / Sold) that toggle tiles via JS.
   ============================================================ */
#gallery-filter {
  position: relative;
  z-index: 8490;
  background: var(--color-bg-dark);
  display: flex;
  justify-content: center;
  gap: 8px;
  padding: 18px 0;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}

.filter-btn {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 2px;
  color: rgba(250,250,250,0.5);
  font-family: var(--font-main);
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  padding: 7px 20px;
  cursor: pointer;
  transition: border-color 0.2s ease, color 0.2s ease;
  -webkit-appearance: none;
  appearance: none;
}

.filter-btn:hover {
  color: var(--color-text);
  border-color: rgba(255,255,255,0.45);
}

.filter-btn.active {
  border-color: var(--color-accent);
  color: var(--color-accent);
}

/* Tiles hidden by the active filter */
.art.filter-hidden,
.art-placeholder.filter-hidden {
  display: none;
}

/* ============================================================
   GALLERY
   CSS Grid, 4 columns by default (responsive overrides in media.css).
   Each tile is position:relative/overflow:hidden so the zoom
   effect on .art-content is clipped within the tile boundary.
   ============================================================ */
#page-drawing {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  overflow: hidden;
  box-shadow: 0 -10px 40px #000, 0 10px 40px #000;
  z-index: 8500;
}

.art,
.art-placeholder {
  height: 50vh;
  position: relative;
  overflow: hidden;
}

.art {
  cursor: pointer;
}

.art-placeholder {
  background: var(--color-placeholder) url(../res/img/placeholder.png) no-repeat center center;
  background-size: 80px auto;
  display: flex;
  align-items: flex-end;
}

/* Fills the tile absolutely so zoom (scale) is clipped by the parent overflow:hidden.
   Text and sold-ribbon are siblings of this element, not children,
   so they are unaffected by the transform. */
.art-content {
  position: absolute;
  inset: 0;
  background-color: var(--color-placeholder);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  filter: grayscale(100%);
  transition: filter var(--transition-art), transform var(--transition-art);
}

.art:hover .art-content,
.art:focus .art-content {
  filter: none;
  transform: scale(1.05);
}

/* Title label at the bottom of each tile */
.art-text {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 10px 12px;
  background-color: rgba(0, 0, 0, 0.72);
  text-align: center;
  font-family: var(--font-main);
  font-size: 13px;
  letter-spacing: 2px;
  color: var(--color-text);
  text-shadow: 0 0 10px rgba(0, 0, 0, .6);
  transition: background-color 0.3s ease;
  z-index: 1;
}

.art:hover .art-text {
  background-color: rgba(0, 0, 0, 0.45);
}

/* Diagonal ribbon in the top-left corner of sold works.
   text-indent compensates for letter-spacing trailing gap. */
aside.banner-sold {
  position: absolute;
  top: 30px;
  left: -55px;
  width: 190px;
  background-color: var(--color-sold);
  padding: 8px 0;
  text-align: center;
  transform: rotate(-45deg);
  font-family: var(--font-main);
  font-size: 12px;
  letter-spacing: 2px;
  text-indent: 2px;
  color: var(--color-text);
  text-shadow: none;
  box-shadow: 0 2px 8px rgba(0,0,0,0.4);
  z-index: 2;
}

/* ============================================================
   GALLERY — BACKGROUND IMAGES
   Each .art-content div gets its image via its own ID selector.
   background-color/repeat/position/size are on .art-content above.
   ============================================================ */
#drei-weiber          { background-image: url(../res/drawings/drei-weiber/drei-weiber-1.jpg); }
#meditation           { background-image: url(../res/drawings/meditation/meditation-1.jpg); }
#das-kind-in-mir      { background-image: url(../res/drawings/das-kind-in-mir/das-kind-in-mir-1.jpg); }
#frida                { background-image: url(../res/drawings/frida/frida-1.jpg); }
#rueck-en-halt        { background-image: url(../res/drawings/rueck-en-halt/rueck-en-halt-1.jpg); }
#depression           { background-image: url(../res/drawings/depression/depression-1.jpg); }
#zum-leben-erfleckt   { background-image: url(../res/drawings/zum-leben-erfleckt/zum-leben-erfleckt-1.jpg); }
#bunte-tauben         { background-image: url(../res/drawings/bunte-tauben/bunte-tauben-1.jpg); }
#farbenspiel          { background-image: url(../res/drawings/farbenspiel/farbenspiel-1.jpg); }
#harmonie-4           { background-image: url(../res/drawings/harmonie-4/harmonie-4-1.jpg); }
#polaritaet           { background-image: url(../res/drawings/polaritaet/polaritaet-1.jpg); }
#es-war-einmal        { background-image: url(../res/drawings/es-war-einmal/es-war-einmal-1.jpg); }
#ausbruch             { background-image: url(../res/drawings/ausbruch/ausbruch-1.jpg); }
#mutterkraft          { background-image: url(../res/drawings/mutterkraft/mutterkraft-1.jpg); }
#freaks-2             { background-image: url(../res/drawings/freaks-2/freaks-2-1.jpg); }
#harmonie-3           { background-image: url(../res/drawings/harmonie-3/harmonie-3-1.jpg); }
#harmonie-2           { background-image: url(../res/drawings/harmonie-2/harmonie-2-1.jpg); }
#verlorene-familie    { background-image: url(../res/drawings/verlorene-familie/verlorene-familie-1.jpg); }
#fruchtbarkeit        { background-image: url(../res/drawings/fruchtbarkeit/fruchtbarkeit-1.jpg); }
#freaks               { background-image: url(../res/drawings/freaks/freaks-1.jpg); }
#hintergruende        { background-image: url(../res/drawings/hintergruende/hintergruende-1.jpg); }
#das-herz-am-rechten-fleck { background-image: url(../res/drawings/das-herz-am-rechten-fleck/das-herz-am-rechten-fleck-1.jpg); }
#mizaru-kikazaru-iwazaru   { background-image: url(../res/drawings/mizaru-kikazaru-iwazaru/mizaru-kikazaru-iwazaru-1.jpg); }
#im-gruenen-bereich   { background-image: url(../res/drawings/im-gruenen-bereich/im-gruenen-bereich-1.jpg); }
#froschkoenigin       { background-image: url(../res/drawings/froschkoenigin/froschkoenigin-1.jpg); }
#iyilik-iyidir        { background-image: url(../res/drawings/iyilik-iyidir/iyilik-iyidir-1.jpg); }
#erfahrungen          { background-image: url(../res/drawings/erfahrungen/erfahrungen-1.jpg); }
#harmonie             { background-image: url(../res/drawings/harmonie/harmonie-1.jpg); }
#gaffer               { background-image: url(../res/drawings/gaffer/gaffer-1.jpg); }
#experiment           { background-image: url(../res/drawings/experiment/experiment-1.jpg); }
#dasein               { background-image: url(../res/drawings/dasein/dasein-1.jpg); }
#prozess              { background-image: url(../res/drawings/prozess/prozess-1.jpg); }
#lebensphasen         { background-image: url(../res/drawings/lebensphasen/lebensphasen-1.jpg); }
#neugier              { background-image: url(../res/drawings/neugier/neugier-1.jpg); }
#glueckseligkeit      { background-image: url(../res/drawings/glueckseligkeit/glueckseligkeit-1.jpg); }
#fatimas-hand         { background-image: url(../res/drawings/fatimas-hand/fatimas-hand-1.jpg); }
#spiegelbild          { background-image: url(../res/drawings/spiegelbild/spiegelbild-1.jpg); }
#gleich-verschieden   { background-image: url(../res/drawings/gleich-verschieden/gleich-verschieden-1.jpg); }
#geschwister          { background-image: url(../res/drawings/geschwister/geschwister-1.jpg); }
#geborgenheit         { background-image: url(../res/drawings/geborgenheit/geborgenheit-1.jpg); }
#gemeinschaft         { background-image: url(../res/drawings/gemeinschaft/gemeinschaft-1.jpg); }

/* ============================================================
   GALLERY — SCROLL-REVEAL
   JS adds .pre-reveal after first paint (so background-images
   are not blocked by opacity:0 at parse time), then adds
   .revealed via IntersectionObserver as tiles enter the viewport.
   ============================================================ */
.art.pre-reveal,
.art-placeholder.pre-reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.55s ease, transform 0.55s ease;
}

.art.pre-reveal.revealed,
.art-placeholder.pre-reveal.revealed {
  opacity: 1;
  transform: translateY(0);
}

/* ============================================================
   MODALS — SHARED
   All modals share the same base: fixed full-screen overlay,
   hidden by default, fades in/out via opacity + visibility.
   ============================================================ */
#modal-drawing,
#modal-legal-notice {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.5s ease, visibility 0s 0.5s;
  position: fixed;
  inset: 0;
  background-color: var(--color-modal-bg);
  z-index: 9999;
  overflow-y: auto;
}

#modal-legal-notice {
  background-color: #000;
}

/* Shared close button (×) in the top-right corner */
.modal-close {
  position: absolute;
  top: 0;
  right: 0;
  font-size: 36px;
  padding: 4px 22px;
  font-family: var(--font-main);
  color: var(--color-text);
  background: transparent;
  border: none;
  -webkit-appearance: none;
  appearance: none;
  cursor: pointer;
  line-height: 1.5;
  letter-spacing: 0;
  transition: background-color 0.2s ease;
  z-index: 10;
}

/* Only highlight on keyboard focus, not on mouse click */
.modal-close:hover,
.modal-close:focus-visible {
  background-color: rgba(200, 200, 200, 0.15);
  outline: none;
}

/* ============================================================
   MODAL — ARTWORK DETAIL
   ============================================================ */
#modal-drawing-content {
  position: relative;
  top: 50%;
  transform: translateY(-50%);
  padding: 20px 0;
}

#modal-drawing-1,
#modal-drawing-2,
#modal-drawing-3 {
  display: none;
  margin: 0 auto;
  width: 800px;
  height: 600px;
  object-fit: contain;
  background-color: #000;
}

#modal-control {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 800px;
  margin: 0 auto;
}

#modal-desc {
  text-align: center;
  flex: 1;
  padding: 0 10px;
}

/* Previous / Next image buttons */
.modal-nav {
  background: transparent;
  border: none;
  -webkit-appearance: none;
  appearance: none;
  color: var(--color-text);
  font-size: 22px;
  cursor: pointer;
  padding: 12px 18px;
  font-family: var(--font-main);
  transition: background-color 0.2s ease;
  border-radius: 3px;
  flex-shrink: 0;
}

.modal-nav:hover,
.modal-nav:focus-visible {
  background-color: rgba(255, 255, 255, 0.1);
  outline: none;
}

#drawing-measurement {
  text-align: center;
  font-size: 12px;
  padding: 4px 0 0;
  letter-spacing: 1px;
  opacity: 0.7;
}

/* ============================================================
   MODAL — IMPRESSUM / LEGAL NOTICE
   ============================================================ */
#modal-legal-notice-content {
  position: relative;
  top: 50%;
  transform: translateY(-50%);
  width: 900px;
  margin: 0 auto;
  padding: 40px 20px;
  text-align: justify;
}

.legal-heading {
  padding: 20px 0 4px;
  font-size: 14px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--color-accent);
}

address.text {
  font-style: normal;
  line-height: 1.8;
}

address a {
  color: var(--color-accent);
  text-decoration: none;
}

address a:hover {
  text-decoration: underline;
}

/* ============================================================
   MODAL — CONTACT FORM
   ============================================================ */
#modal-contact {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.5s ease, visibility 0s 0.5s;
  position: fixed;
  inset: 0;
  background-color: #000;
  z-index: 9999;
  overflow-y: auto;
  display: flex;
  align-items: center;
  justify-content: center;
}

#modal-contact-content {
  width: 560px;
  max-width: 90vw;
  padding: 56px 48px 48px;
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 2px;
  position: relative;
}

#modal-contact-title {
  font-family: var(--font-main);
  color: var(--color-text);
  font-size: 13px;
  letter-spacing: 5px;
  text-transform: uppercase;
  text-align: center;
  padding: 0 0 32px;
  opacity: 0.9;
}

/* Two-column row for Vorname / Name */
.contact-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 16px;
}

.contact-field {
  display: flex;
  flex-direction: column;
  margin-bottom: 16px;
}

.contact-field label {
  font-family: var(--font-main);
  color: var(--color-text);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  opacity: 0.55;
  margin-bottom: 6px;
}

/* Required marker (*) shown in accent colour at full opacity */
.contact-field label .required {
  color: var(--color-accent);
  opacity: 1;
  margin-left: 2px;
}

.contact-field label .optional {
  opacity: 0.4;
  text-transform: none;
  letter-spacing: 0;
  font-size: 9px;
}

.contact-field input,
.contact-field textarea {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: 2px;
  color: var(--color-text);
  font-family: var(--font-main);
  font-size: 13px;
  letter-spacing: 1px;
  padding: 10px 14px;
  outline: none;
  transition: border-color 0.2s ease, background 0.2s ease;
  -webkit-appearance: none;
  appearance: none;
}

.contact-field input:focus,
.contact-field textarea:focus {
  border-color: var(--color-accent);
  background: rgba(255, 255, 255, 0.07);
}

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

/* Prevent browser autofill from overriding the dark background */
.contact-field input:-webkit-autofill {
  -webkit-box-shadow: 0 0 0 100px #000 inset;
  -webkit-text-fill-color: var(--color-text);
}

/* Character counter shown below the textarea */
#char-counter {
  font-family: var(--font-main);
  font-size: 10px;
  letter-spacing: 1px;
  color: rgba(250,250,250,0.3);
  text-align: right;
  margin-top: 4px;
  transition: color 0.2s ease;
}

/* Turns accent colour when approaching the character limit */
#char-counter.near-limit {
  color: var(--color-accent);
}

#contact-submit {
  width: 100%;
  margin-top: 8px;
  padding: 13px;
  background: transparent;
  border: 1px solid var(--color-accent);
  border-radius: 2px;
  color: var(--color-accent);
  font-family: var(--font-main);
  font-size: 12px;
  letter-spacing: 3px;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.25s ease, color 0.25s ease;
  -webkit-appearance: none;
  appearance: none;
}

#contact-submit:hover,
#contact-submit:focus-visible {
  background: var(--color-accent);
  color: #000;
  outline: none;
}

#contact-feedback {
  font-family: var(--font-main);
  font-size: 12px;
  letter-spacing: 1px;
  color: var(--color-accent);
  text-align: center;
  margin-top: 14px;
  min-height: 18px;
  opacity: 0;
  transition: opacity 0.3s ease;
}

#contact-feedback.visible {
  opacity: 1;
}

/* ============================================================
   TESTIMONIALS (Owl Carousel)
   ============================================================ */
#page-testimonial {
  position: relative;
  height: 100vh;
  overflow: hidden;
  background: linear-gradient(135deg, #3a1f72 0%, #512DA8 50%, #3d2494 100%);
  box-shadow: 0 -10px 40px #000;
  z-index: 8550;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

#page-testimonial-content {
  width: 100%;
  text-align: center;
}

/* Section label above the carousel */
#testimonial-heading {
  font-family: var(--font-main);
  color: var(--color-text);
  font-size: 13px;
  letter-spacing: 6px;
  text-transform: uppercase;
  margin-bottom: 40px;
  opacity: 0.6;
  padding: 0;
  text-shadow: none;
}

/* Individual review card */
.testimonial {
  background: rgba(255, 255, 255, 0.06);
  backdrop-filter: blur(6px);
  border: none;
  border-left: 4px solid #F1971F;
  border-radius: 2px;
  padding: 40px 44px 36px;
  margin: 20px 30px;
  text-align: left;
  position: relative;
  transition: background 0.3s ease;
}

.testimonial:hover {
  background: rgba(255, 255, 255, 0.1);
}

/* Decorative opening quotation mark per card */
.testimonial::before {
  content: '\201c';
  font-family: Georgia, serif;
  font-size: 80px;
  line-height: 1;
  color: #F1971F;
  position: absolute;
  top: 12px;
  left: 16px;
  opacity: 0.9;
}

/* Author / date line */
.testimonial-title {
  font-family: var(--font-main);
  letter-spacing: 3px;
  color: #F1971F;
  font-size: 12px;
  text-transform: uppercase;
  padding: 0 0 16px;
  margin: 0 0 20px;
  border-bottom: 1px solid rgba(241, 151, 31, 0.35);
  background: none;
  position: static;
  text-align: left;
  text-shadow: none;
}

/* Remove any lingering pseudo-elements from old ribbon style */
.testimonial-title::before,
.testimonial-title::after {
  display: none;
}

.testimonial .text {
  font-size: 15px;
  line-height: 1.8;
  letter-spacing: 1px;
  color: rgba(250, 250, 250, 0.88);
  text-align: left;
  padding: 0;
  text-shadow: none;
}

/* Owl Carousel: pagination dots */
.owl-theme .owl-controls {
  margin-top: 28px;
}

.owl-theme .owl-controls .owl-page span {
  width: 8px;
  height: 8px;
  background: rgba(255, 255, 255, 0.35);
  border-radius: 50%;
  margin: 5px 6px;
  opacity: 1;
  transition: background 0.3s ease, transform 0.3s ease;
}

.owl-theme .owl-controls .owl-page.active span,
.owl-theme .owl-controls.clickable .owl-page:hover span {
  background: #F1971F;
  transform: scale(1.3);
  opacity: 1;
}

/* Owl Carousel: prev/next arrow buttons */
.owl-theme .owl-controls .owl-buttons div {
  display: inline-block;
  width: 40px;
  height: 40px;
  line-height: 40px;
  text-align: center;
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.3);
  border-radius: 50%;
  color: var(--color-text);
  opacity: 1;
  transition: border-color 0.2s ease, background 0.2s ease;
  margin: 0 6px;
  position: relative;
}

.owl-theme .owl-controls.clickable .owl-buttons div:hover {
  background: rgba(241, 151, 31, 0.2);
  border-color: #F1971F;
  opacity: 1;
}

/* CSS-drawn chevron arrows — avoids unicode glyph alignment issues */
.owl-prev::before,
.owl-next::before {
  content: '';
  display: inline-block;
  width: 9px;
  height: 9px;
  border-top: 2px solid var(--color-text);
  border-right: 2px solid var(--color-text);
  position: absolute;
  top: 50%;
  left: 50%;
}

.owl-prev::before { transform: translate(-30%, -50%) rotate(-135deg); }
.owl-next::before { transform: translate(-70%, -50%) rotate(45deg); }

/* ============================================================
   ABOUT ME
   ============================================================ */
#page-about-me {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
  background-color: var(--color-about);
  box-shadow: 0 -10px 40px #000;
  z-index: 8600;
  display: flex;
  align-items: center;
  justify-content: center;
}

#page-about-me-content {
  text-align: center;
  padding: 60px 20px;
  width: 100%;
}

#greeting {
  margin: 0 auto 50px;
  width: 800px;
  text-transform: uppercase;
  font-size: 30px;
  letter-spacing: 6px;
}

.circle {
  margin: 0 auto;
  height: 400px;
  width: 400px;
  background: url(../res/img/avatar.jpg) no-repeat center center;
  background-size: cover;
  border-radius: 50%;
  transition: var(--transition-fast);
  pointer-events: none;
  animation: fadein 2s ease forwards;
  box-shadow: 0 0 60px rgba(0,0,0,0.5);
}

#about {
  margin: 50px auto 0;
  width: 800px;
  line-height: 1.7;
  text-align: justify;
}

/* ============================================================
   FOOTER
   Two equal-width halves (contact / social) above a copyright bar.
   ============================================================ */
#footer {
  position: relative;
  height: 15vh;
  z-index: 8600;
  background-color: var(--color-footer);
  box-shadow: 0 -10px 40px #000;
}

#contact {
  float: left;
  height: 10vh;
  width: 50%;
  background-color: var(--color-contact);
  text-align: center;
  cursor: pointer;
  transition: filter 0.2s ease;
}

#contact:hover,
#contact:focus {
  filter: brightness(1.15);
  outline: none;
}

#social-media {
  float: right;
  height: 10vh;
  width: 50%;
  background-color: var(--color-social);
  text-align: center;
  cursor: pointer;
  transition: filter 0.2s ease;
}

#social-media:hover,
#social-media:focus {
  filter: brightness(1.15);
  outline: none;
}

#contact-content,
#social-media-content {
  position: relative;
  top: 50%;
  transform: translateY(-50%);
}

#contact-text,
#social-media-text {
  padding: 0 0 8px;
}

.fa-envelope-o,
.fa-instagram {
  color: var(--color-text);
  font-size: 24px;
}

#copyright {
  clear: both;
  height: 5vh;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background-color 0.2s ease;
}

#copyright:hover,
#copyright:focus {
  background-color: rgba(255,255,255,0.08);
  outline: none;
}

#copyright-text {
  text-align: center;
  font-size: 12px;
  padding: 0;
  letter-spacing: 1.5px;
}

#impressum-link {
  text-decoration: underline;
  cursor: pointer;
}