/* ABOUT */
.about-content { max-width: 1000px; margin: 0 auto; padding: 72px 32px 80px; text-align: center; }
.about-title {
  font-family: 'Inter Tight', sans-serif;
  font-size: clamp(48px, 6vw, 96px); font-weight: 700;
  letter-spacing: -0.02em; line-height: 1.04;
  color: var(--text); margin-bottom: 24px;
}
.about-desc {
  font-size: 16.5px; line-height: 1.72; color: var(--subtle);
  max-width: 480px; margin-bottom: 56px; margin-left: auto; margin-right: auto;
}
.about-lower { text-align: left; }

/* DRAGGABLE ABOUT CARDS */
.about-cards-wrap { position: relative; height: 434px; margin-top: 30px; }

.about-card {
  position: absolute; height: 420px;
  border-radius: var(--radius-md); overflow: hidden;
  cursor: grab; transform: rotate(var(--rot, 0deg));
  transition: box-shadow 0.2s, transform 0.2s;
  user-select: none; -webkit-user-select: none;
  background: var(--surface); border: 1.5px solid var(--border);
}
.about-card:hover {
  box-shadow: 0 10px 44px rgba(0,0,0,0.1);
  transform: translateY(-3px) rotate(var(--rot, 0deg));
}
.about-card.dragging-now {
  cursor: grabbing;
  box-shadow: 0 24px 64px rgba(0,0,0,0.16);
  transform: scale(1.02) rotate(0.8deg);
  transition: none;
}

/* Flip card fills its about-card wrapper */
.about-card .flip-outer { height: 100%; cursor: inherit; }
.about-card .flip-inner { width: 100%; height: 100%; }

/* FLIP CARD INTERNALS */
.flip-outer { perspective: 1400px; }
.flip-inner {
  position: relative;
  border-radius: var(--radius-md);
  transform-style: preserve-3d;
  transition: transform 0.72s cubic-bezier(0.35,0,0.15,1);
}
.flip-inner.flipped { transform: rotateY(180deg); }
.flip-f, .flip-b {
  position: absolute; inset: 0; border-radius: var(--radius-md);
  backface-visibility: hidden; overflow: hidden;
}
.flip-f { background: #ffffff; }
[data-theme="dark"] .flip-f { background: #0f1e35; }

/* Slideshow */
.flip-slides { position: absolute; inset: 0; }
.flip-slide {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
  opacity: 0; transition: opacity 0.7s ease;
}
.flip-slide.active { opacity: 1; }

/* Video slide — cover fit, no blend mode */
.flip-slide--video {
  object-fit: cover;
  mix-blend-mode: normal !important;
}

/* Dot indicators */
.flip-slide-dots {
  position: absolute; bottom: 14px; left: 50%; transform: translateX(-50%);
  display: flex; gap: 6px; z-index: 2;
}
.flip-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: rgba(0,0,0,0.18); transition: background 0.25s, transform 0.25s;
  cursor: pointer;
}
.flip-dot.active { background: rgba(0,0,0,0.55); transform: scale(1.25); }
[data-theme="dark"] .flip-dot { background: rgba(255,255,255,0.25); }
[data-theme="dark"] .flip-dot.active { background: rgba(255,255,255,0.8); }

/* Video dot — slightly wider pill */
.flip-dot--video { width: 14px; border-radius: 3px; }
.flip-dot--video.active { width: 14px; }
.flip-f-badge {
  position: absolute; bottom: 14px; right: 16px;
  font-size: 11px; font-weight: 600; color: rgba(255,255,255,0.9);
  background: rgba(0,0,0,0.42); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  padding: 5px 13px; border-radius: 100px; letter-spacing: 0.02em;
}
.flip-b {
  background: #1b2b42; transform: rotateY(180deg);
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 28px 28px 44px;
}
.flip-b-tag { font-size: 10px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(255,255,255,0.4); margin-bottom: 12px; }
.flip-b-name { font-family: 'Inter Tight', sans-serif; font-size: 26px; font-weight: 400; letter-spacing: -0.02em; line-height: 1.15; color: #fff; margin-bottom: 18px; }
.flip-b-divider { width: 32px; height: 2px; background: rgba(255,255,255,0.2); border-radius: 2px; margin-bottom: 18px; }
.flip-b-bio { font-size: 13px; line-height: 1.78; color: rgba(255,255,255,0.6); }
.flip-b-badge { position: absolute; bottom: 14px; right: 16px; font-size: 11px; color: rgba(255,255,255,0.3); background: rgba(255,255,255,0.07); padding: 5px 13px; border-radius: 100px; }
[data-theme="dark"] .flip-b { background: #0f1e35; }

/* Quote & Connect card content */
.ac-content { padding: 28px 26px 30px; display: flex; flex-direction: column; justify-content: flex-end; height: 100%; }
.ac-label { font-size: 10px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); margin-bottom: 16px; }
.ac-quote-body { font-size: 17px; font-style: italic; line-height: 1.6; color: var(--text); margin-bottom: 12px; }
.ac-quote-attr { font-size: 12px; color: var(--muted); }
.ac-connect-body { font-size: 14px; line-height: 1.65; color: var(--subtle); margin-bottom: 20px; }

.social-row { display: flex; flex-wrap: wrap; gap: 8px; }
.social-btn {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: 'Söhne Buch', 'Inter', sans-serif;
  font-size: 12.5px; font-weight: 600; color: var(--text);
  border: 1.5px solid var(--border); border-radius: 100px;
  padding: 8px 15px; background: var(--surface);
  transition: background 0.15s, color 0.15s;
}
.social-btn:hover { background: var(--hover-bg); color: var(--text); }
.social-btn svg { width: 13px; height: 13px; }

/* ── COLORED CARDS ── */
/* Isometric dot grid SVG tile (30×52px, dots at hex-grid vertices) */
.about-card--quote,
.about-card--connect {
  border: none;
}

.about-card--quote {
  background:
    url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='30' height='52'><circle cx='0' cy='0' r='1.3' fill='white' fill-opacity='0.14'/><circle cx='30' cy='0' r='1.3' fill='white' fill-opacity='0.14'/><circle cx='15' cy='26' r='1.3' fill='white' fill-opacity='0.14'/><circle cx='0' cy='52' r='1.3' fill='white' fill-opacity='0.14'/><circle cx='30' cy='52' r='1.3' fill='white' fill-opacity='0.14'/></svg>") repeat,
    linear-gradient(152deg, #e8156c 0%, #ef3553 55%, #f0472e 100%);
}

.about-card--connect {
  background:
    url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='30' height='52'><circle cx='0' cy='0' r='1.3' fill='white' fill-opacity='0.14'/><circle cx='30' cy='0' r='1.3' fill='white' fill-opacity='0.14'/><circle cx='15' cy='26' r='1.3' fill='white' fill-opacity='0.14'/><circle cx='0' cy='52' r='1.3' fill='white' fill-opacity='0.14'/><circle cx='30' cy='52' r='1.3' fill='white' fill-opacity='0.14'/></svg>") repeat,
    linear-gradient(152deg, #3dbf70 0%, #2da85c 55%, #239650 100%);
}

/* Large decorative quote mark on quote card */
.about-card--quote::before {
  content: '\201C';
  position: absolute;
  top: 16px; left: 20px;
  font-size: 110px; line-height: 1;
  font-family: Georgia, 'Times New Roman', serif;
  color: rgba(255,255,255,0.13);
  pointer-events: none;
  user-select: none;
}

/* Text overrides — white on colored backgrounds */
.about-card--quote .ac-label,
.about-card--connect .ac-label { color: rgba(255,255,255,0.55); }

.about-card--quote .ac-quote-body { color: #fff; font-size: 16.5px; }
.about-card--quote .ac-quote-attr { color: rgba(255,255,255,0.6); }

.about-card--connect .ac-connect-body { color: rgba(255,255,255,0.82); }

.about-card--connect .social-btn {
  color: #fff;
  border-color: rgba(255,255,255,0.3);
  background: rgba(255,255,255,0.13);
}
.about-card--connect .social-btn:hover {
  background: rgba(255,255,255,0.24);
}
