/* REGGIE COMPACT TITLE */

.reggie-title {
    position: relative;
    padding: 7px 10px;
    margin: 0px 0 10px 0;
    background: linear-gradient(135deg, #1a1a1a 0%, #151515 60%, #191919 100%);
    border: 1px solid rgba(212,169,92,0.35);
    text-align: center;
    overflow: hidden;
}

/* Haupttitel */

.reggie-title h2 {
    margin: 0;
    font-size: 22px;
    letter-spacing: 4px;
    text-transform: uppercase;
    color: #e7d3a0;
    text-shadow: 0 0 6px rgba(212,169,92,0.25);
    font-family: "Zen Tokyo Zoo", system-ui;
    font-weight: 400;
    font-style: normal;
}

/* Untertitel */

.reggie-title span {
    display: block;
    margin-top: -12px;
    font-size: 8px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.55);
}

/* kleine Dekorlinie */

.reggie-title::after {
    content: "";
    display: block;
    width: 180px;
    height: 1px;
    margin: 2px auto 4px auto;
    background: linear-gradient(90deg, transparent, #d4a95c, transparent);
}


.reggie-box {
    font-size: 13px;
    padding: 0px 25px 0px 10px;
    line-height: 15px;
    border-left: 3px solid #caa158;
    margin-left: 16px;
    margin-bottom: 12px;
}

.reggie-box-story {
    /* font-size: 14px; */
    padding: 0px 25px 0px 10px;
    line-height: 22px;
    border-left: 3px solid #caa158;
    margin-left: 16px;
    margin-bottom: 26px;
}


.vega-scene{
    width:100%;
    max-width:600px;
    margin:20px auto 25px auto;
    text-align:center;
    padding-bottom:10px;
    border-bottom:1px solid rgba(255,255,255,0.15);
}

.vega-title {
    font-size: 20px;
    letter-spacing: 2px;
    text-transform: uppercase;
    font-weight: 600;
    color: #d7c18a;
    font-family: Georgia, serif;
    margin-bottom: -9px;
}

.vega-sub {
    font-size: 10px;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: #9a9a9a;
}

.dex-facts {
    padding: 0px 15px;
    margin-bottom: 20px;
    line-height: 16px;
}

.dex-char {
    padding: 0px 20px;
    margin-bottom: 20px;
}

.dex-vita {
    padding: 0px 60px;
    margin-bottom: 20px;
}

/* DEXTER HEADLINE – MINIMAL STREET */

.dex-headline {
    margin: 0px 0 17px;
    font-family: Arial, Helvetica, sans-serif;
}

/* kleine Oberzeile */

.dex-headline-kicker{
    display:block;
    font-size:10px;
    letter-spacing:3px;
    text-transform:uppercase;
    color:#8e8e8e;
    margin-bottom:6px;
}

/* Haupttitel */

.dex-headline-title {
    position: relative;
    display: inline-block;
    font-size: 30px;
    font-weight: 800;
    letter-spacing: 6px;
    text-transform: uppercase;
    color: #aba7a5;
    font-family: "Smooch Sans", sans-serif;
}

/* rote Unterstreichung */

.dex-headline-title:after {
    content: "";
    display: block;
    width: 60px;
    height: 3px;
    margin-top: -6px;
    background: #a72a2a;
}

/* dezente Linie im Hintergrund */

.dex-headline-title:before{
    content:"";
    position:absolute;
    left:0;
    bottom:-9px;
    width:100%;
    height:1px;
    background:rgba(255,255,255,0.08);
}

/* Subtitle */

.dex-headline-sub{
    margin-top:10px;
    font-size:11px;
    letter-spacing:2px;
    text-transform:uppercase;
    color:#9b9b9b;
}

.dex-headline-sub span{
    color:#d2d2d2;
}

/* Varianten */

.dex-headline.is-funfacts .dex-headline-title:after{
    background:#5f7b50;
}

.dex-headline.is-vita .dex-headline-title:after{
    background:#8a6533;
}

.sol-facts {
    margin-bottom: 10px;
    line-height: 17px;
    padding: 0px 40px;
}

.sol-vita {
    margin-bottom: 10px;
    line-height: 19px;
    padding: 0px 90px;
}

.sol-headline {
    font-family: "Georgia", serif;
    text-transform: uppercase;
    letter-spacing: 2px;
    font-size: 18px;
    color: #e6c78f;
    text-align: center;
    margin: 0px 0 15px 0;
    position: relative;
}

.sol-headline:before,
.sol-headline:after {
    content: "";
    display: block;
    height: 1px;
    background: linear-gradient(to right, transparent, #e6c78f, transparent);
    margin: 8px auto;
    width: 80%;
}

.sol-headline span:before {
    content: "☾ ✦ ";
    color: #caa85f;
}

.sol-headline span:after {
    content: " ✦ ☽";
    color: #caa85f;
}

.sol-scene {
    text-align: center;
    margin: 30px 0 0px;
    font-family: Georgia, serif;
}

.sol-scene-title {
    font-size: 24px;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: #d6b77a;
}

.sol-scene-title:before {
    content: "☾ ✦ ";
    color: #bfa060;
}

.sol-scene-title:after {
    content: " ✦ ☽";
    color: #bfa060;
}

.sol-scene-line {
    height: 1px;
    width: 60%;
    margin: 10px auto;
    background: linear-gradient(to right, transparent, #bfa060, transparent);
}

.sol-scene-info {
    font-size: 11px;
    letter-spacing: 3px;
    color: #9c8b6a;
    text-transform: uppercase;
}

.hitch-head {
    position: relative;
    margin: 12px 0 10px;
    padding-left: 16px;
}

.hitch-head:before {
    content: "";
    position: absolute;
    left: 0;
    top: 3px;
    width: 3px;
    height: 38px;
    background: #7c2d2d;
}

.hitch-head:after {
    content: "";
    position: absolute;
    left: 12px;
    top: 9px;
    width: 257px;
    height: 1px;
    background: rgba(160,160,160,0.35);
}

.hitch-kicker {
    font: 9px/1 Arial, Helvetica, sans-serif;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: #7f776d;
    margin-bottom: -6px;
}

.hitch-title {
    text-transform: uppercase;
    color: #d7d0c4;
    font-family: "Rubik Dirt", system-ui;
    font-size: 24px;
    letter-spacing: 7px;
}

.hitch-sub {
    margin-top: -9px;
    padding-left: 2px;
    font: normal 10px/1.35 Georgia, "Times New Roman", serif;
    letter-spacing: 1.5px;
    color: #9a8f81;
}

.hitch-text {
    margin-top: 16px;
    line-height: 15px;
    padding: 0px 18px;
}

.hitch-text2 {
    padding: 10px 30px 10px 30px;
    border-right: 6px solid #7c2d2d;
    margin-right: 250px;
}

/* Titus "The Narcissist" Headline */
.titus-header-container {
    text-align: center;
    padding: 6px 20px;
    cursor: default;
    transition: all 0.5s ease;
}

.titus-main-title {
    font-family: 'Cinzel Decorative', cursive;
    font-size: 26px;
    font-weight: 700;
    margin: 0;
    background: linear-gradient(135deg, #bf953f, #fcf6ba, #b38728, #fcf6ba, #aa771c);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    transition: all 0.6s cubic-bezier(0.4, 0, 0.2, 1);
    display: inline-block;
    filter: drop-shadow(0px 2px 2px rgba(0,0,0,0.1));
}

/* Hover-Effekt: Der Titel scheint zu glühen */
.titus-header-container:hover .titus-main-title {
    filter: drop-shadow(0 0 10px rgba(212, 175, 55, 0.6));
    transform: scale(1.02);
}

/* Die animierte Linie */
.titus-gold-line {
    width: 60px;
    height: 2px;
    background: linear-gradient(90deg, transparent, #d4af37, transparent);
    margin: -2px auto 5px;
    transition: width 0.8s cubic-bezier(0.68, -0.55, 0.27, 1.55);
}

/* Hover-Effekt: Die Linie breitet sich herrschaftlich aus */
.titus-header-container:hover .titus-gold-line {
    width: 300px;
}

.titus-sub-block-gold {
    font-family: 'Syncopate', sans-serif;
    font-size: 9px;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: #888;
    opacity: 0.7;
    transition: all 0.5s ease;
}

.titus-header-container:hover .titus-sub-block-gold {
    color: #b38728;
    opacity: 1;
    letter-spacing: 3px;
}

.titus-text {
    padding: 10px 25px;
    line-height: 16px;
}

.titus-text2 {
    padding: 10px 270px;
    line-height: 16px;
}

.golden-dropcap {
    float: left;
    font-size: 30px;
    line-height: 0.85;
    margin-right: 12px;
    font-weight: bold;
    font-family: 'Georgia', 'Times New Roman', serif;
    text-transform: uppercase;
    background: linear-gradient(135deg, #f1d37e 0%, #b58d3d 50%, #f1d37e 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    text-shadow: 0px 2px 3px rgb(0 0 0 / 49%), 0px 0px 8px rgba(181, 141, 61, 0.4);
}

/* MIN-SOO BROKEN HEADLINE + KOREAN SUBLINE */

.minsoo-headline-wrap {
    position: relative;
    width: 100%;
    margin: 0px auto 5px auto;
    text-align: center;
    overflow: visible;
}

.minsoo-headline-wrap::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 17px;
  transform: translateX(-50%);
  width: 240px;
  height: 1px;
  background: linear-gradient(
    to right,
    transparent,
    rgba(255, 216, 200, 0.10) 10%,
    rgba(255, 216, 200, 0.55) 30%,
    rgba(164, 198, 222, 0.38) 70%,
    rgba(164, 198, 222, 0.08) 90%,
    transparent
  );
  opacity: 0.85;
}

.minsoo-headline {
    position: relative;
    display: inline-block;
    padding: 0 18px 4px 18px;
    font-family: "Gamja Flower", sans-serif;
    font-size: 31px;
    font-style: italic;
    font-weight: normal;
    line-height: 1;
    letter-spacing: 1px;
    text-transform: lowercase;
    color: #a37a65;
    text-shadow: 0 0 10px rgba(255, 233, 223, 0.05),
    -1px 0 rgba(255, 175, 190, 0.14),
     1px 0 rgba(166, 207, 229, 0.12);
    animation: minsoo-mainflicker 5.5s infinite linear;
}

.minsoo-headline::before,
.minsoo-headline::after {
  content: attr(data-text);
  position: absolute;
  top: 0;
  width: 100%;
  pointer-events: none;
}

.minsoo-headline::before {
  left: -1.2px;
  color: rgba(255, 186, 208, 0.26);
  text-shadow: -1px 0 rgba(255, 186, 208, 0.18);
  clip-path: polygon(0 0, 100% 0, 100% 28%, 0 18%);
  animation: minsoo-break-top 2.9s infinite steps(1, end);
}

.minsoo-headline::after {
  left: 1.1px;
  color: rgba(173, 216, 230, 0.22);
  text-shadow: 1px 0 rgba(173, 216, 230, 0.16);
  clip-path: polygon(0 52%, 100% 40%, 100% 100%, 0 100%);
  animation: minsoo-break-bottom 3.7s infinite steps(1, end);
}

/* Korean-friendly subline */
.minsoo-subline {
    position: relative;
    display: inline-block;
    margin-top: 10px;
    padding: 2px 10px 0;
    max-width: 90%;
    font-family: "Nanum Brush Script", cursive;
    color: #546261;
    opacity: 0.88;
    text-align: center;
    text-shadow: 0 0 6px rgba(255, 223, 214, 0.08),
    0 0 10px rgba(173, 216, 230, 0.05);
}

.minsoo-subline::before,
.minsoo-subline::after {
  content: "·";
  width: auto;
  height: auto;
  background: none;
  margin: 0 8px;
  color: rgba(255, 214, 197, 0.65);
}

/* optional: softer style only for Korean text */
.minsoo-subline.kr {
    font-size: 20px;
    letter-spacing: 0;
    line-height: 1.9;
}

/* broken signal traces */
.minsoo-noise {
    position: relative;
    width: 490px;
    height: 10px;
    margin: -1px auto -18px auto;
    overflow: hidden;
}

.minsoo-noise::before,
.minsoo-noise::after {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
}

.minsoo-noise::before {
  top: 2px;
  height: 1px;
  background: linear-gradient(
    to right,
    transparent 0%,
    rgba(255, 214, 196, 0.0) 8%,
    rgba(255, 214, 196, 0.45) 18%,
    rgba(255, 214, 196, 0.10) 28%,
    rgba(173, 216, 230, 0.40) 40%,
    rgba(173, 216, 230, 0.08) 52%,
    rgba(255, 214, 196, 0.35) 64%,
    transparent 100%
  );
  animation: minsoo-noiseline1 2.3s infinite steps(1, end);
}

.minsoo-noise::after {
  top: 6px;
  height: 1px;
  background: linear-gradient(
    to right,
    transparent 0%,
    rgba(173, 216, 230, 0.0) 10%,
    rgba(173, 216, 230, 0.30) 22%,
    rgba(255, 188, 208, 0.40) 34%,
    rgba(255, 188, 208, 0.08) 45%,
    rgba(173, 216, 230, 0.28) 60%,
    transparent 100%
  );
  animation: minsoo-noiseline2 1.8s infinite steps(1, end);
}

.minsoo-crack {
  position: absolute;
  left: 50%;
  top: -3px;
  width: 260px;
  height: 42px;
  transform: translateX(-50%);
  pointer-events: none;
  opacity: 0.18;
}

.minsoo-crack::before,
.minsoo-crack::after {
  content: "";
  position: absolute;
  background: rgba(255,255,255,0.12);
  filter: blur(0.2px);
}

.minsoo-crack::before {
  width: 40px;
  height: 1px;
  top: 14px;
  left: 22px;
  transform: rotate(-8deg);
  animation: minsoo-crack1 4.2s infinite steps(1, end);
}

.minsoo-crack::after {
  width: 56px;
  height: 1px;
  top: 25px;
  right: 18px;
  transform: rotate(6deg);
  animation: minsoo-crack2 3.4s infinite steps(1, end);
}

@keyframes minsoo-mainflicker {
  0%, 100% {
    transform: translate(0,0);
    opacity: 0.97;
  }
  8% {
    transform: translate(-0.2px,0);
  }
  9% {
    transform: translate(0.9px,0);
  }
  10% {
    transform: translate(0,0);
  }
  33% {
    opacity: 1;
  }
  34% {
    opacity: 0.88;
  }
  35% {
    opacity: 1;
  }
  61% {
    transform: translate(0.2px,0.1px);
  }
  62% {
    transform: translate(-0.7px,-0.1px);
  }
  63% {
    transform: translate(0,0);
  }
}

@keyframes minsoo-break-top {
  0%, 100% {
    transform: translate(0,0);
    opacity: 0.18;
  }
  12% {
    transform: translate(-2px,-0.3px);
    opacity: 0.34;
  }
  13% {
    transform: translate(1px,0);
    opacity: 0.08;
  }
  36% {
    transform: translate(0,0);
    opacity: 0.18;
  }
  37% {
    transform: translate(-3px,0.2px);
    opacity: 0.30;
  }
  38% {
    transform: translate(0,0);
    opacity: 0.14;
  }
  73% {
    transform: translate(2px,0);
    opacity: 0.28;
  }
  74% {
    transform: translate(-1px,0);
    opacity: 0.10;
  }
}

@keyframes minsoo-break-bottom {
  0%, 100% {
    transform: translate(0,0);
    opacity: 0.15;
  }
  21% {
    transform: translate(2.5px,0.3px);
    opacity: 0.30;
  }
  22% {
    transform: translate(-1px,0);
    opacity: 0.08;
  }
  49% {
    transform: translate(0,0);
    opacity: 0.14;
  }
  50% {
    transform: translate(3px,-0.2px);
    opacity: 0.27;
  }
  51% {
    transform: translate(0,0);
    opacity: 0.12;
  }
  84% {
    transform: translate(-2px,0.1px);
    opacity: 0.24;
  }
  85% {
    transform: translate(0,0);
    opacity: 0.12;
  }
}

@keyframes minsoo-noiseline1 {
  0%, 100% { transform: translateX(0); opacity: 0.18; }
  20% { transform: translateX(-12px); opacity: 0.48; }
  21% { transform: translateX(8px); opacity: 0.10; }
  52% { transform: translateX(0); opacity: 0.20; }
  53% { transform: translateX(10px); opacity: 0.42; }
  54% { transform: translateX(-5px); opacity: 0.12; }
}

@keyframes minsoo-noiseline2 {
  0%, 100% { transform: translateX(0); opacity: 0.16; }
  31% { transform: translateX(9px); opacity: 0.38; }
  32% { transform: translateX(-7px); opacity: 0.08; }
  68% { transform: translateX(-10px); opacity: 0.36; }
  69% { transform: translateX(5px); opacity: 0.09; }
}

@keyframes minsoo-crack1 {
  0%, 100% { opacity: 0.12; transform: rotate(-8deg) translateX(0); }
  44% { opacity: 0.28; transform: rotate(-8deg) translateX(-6px); }
  45% { opacity: 0.08; transform: rotate(-8deg) translateX(3px); }
}

@keyframes minsoo-crack2 {
  0%, 100% { opacity: 0.10; transform: rotate(6deg) translateX(0); }
  60% { opacity: 0.24; transform: rotate(6deg) translateX(7px); }
  61% { opacity: 0.07; transform: rotate(6deg) translateX(-3px); }
}

.minsoo-point {
    float: left;
    padding-right: 5px;
    color: #966d59;
    text-shadow: 2px 0px 2px #547875;
    font-weight: 700;
}

.minsoo-facts-text {
    font-size: 12px;
    line-height: 14px;
    max-width: 430px;
    margin: 0 auto;
}

.minsoo-vita-text {
    font-size: 12px;
    line-height: 14px;
    max-width: 660px;
    margin: 0 auto;
}

.minsoo-frame {
    position: relative;
    display: block;
    /* width: 88px; */
    padding: 4px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: 0 0 14px rgba(0,0,0,0.20),
        inset 0 0 10px rgba(255,255,255,0.02);
}

.minsoo-frame.left {
    float: left;
    margin: 3px 16px 10px -10px;
    transform: rotate(-2deg);
}

.minsoo-frame.right {
    float: right;
    margin: 8px -10px 10px 16px;
    transform: rotate(2deg);
}

.minsoo-frame::before {
    content: "";
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(
        to bottom,
        rgba(255,255,255,0.02) 0px,
        rgba(255,255,255,0.02) 1px,
        transparent 1px,
        transparent 3px
    );
    pointer-events: none;
    opacity: 0.25;
}

.minsoo-photo {
    display: block;
    width: 80px;
    height: 160px;
    object-fit: cover;
    filter: grayscale(50%) contrast(92%) brightness(96%) sepia(60%);
}

/* verhindert float-chaos am Ende */
.minsoo-facts-text::after {
    content: "";
    display: block;
    clear: both;
}

.minsoo-br {
    padding: 4px 0px;
}

.dante-offset {
    position: relative;
    display: inline-block;
    margin: 28px 0 24px;
    padding: 0 0 0 2px;
}

.dante-offset .dante-small {
    position: relative;
    display: block;
    margin-left: 64px;
    margin-bottom: 2px;
    font: 700 8px/1 Arial, sans-serif;
    letter-spacing: 6px;
    text-transform: uppercase;
    color: rgba(156, 121, 95, 0.62);
}

.dante-offset .dante-main {
    position: relative;
    display: flex;
    align-items: flex-end;
    gap: 14px;
    flex-wrap: wrap;
}

.dante-offset .dante-main::before {
    content: "";
    position: absolute;
    left: 0;
    top: 16px;
    width: 52px;
    height: 1px;
    background: linear-gradient(90deg, rgba(194,149,108,0), rgba(194,149,108,0.75));
}

.dante-offset .dante-word {
    font-family: "Pirata One", system-ui;
    font-size: 37px;
    line-height: 0.9;
    text-transform: uppercase;
    letter-spacing: 12px;
    color: #e8d6c3;
    font-weight: normal;
    margin-left: 62px;
}

.dante-offset .dante-tag {
    font: 700 10px/1 Arial, sans-serif;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: rgba(194,149,108,0.65);
    transform: translateY(-3px);
    position: relative;
}

.dante-offset .dante-tag::before {
    content: "";
    display: inline-block;
    width: 18px;
    height: 1px;
    margin: 0 8px 3px 0;
    background: rgba(194,149,108,0.45);
}

.dante-offset::after {
    content: "";
    position: absolute;
    left: 62px;
    right: 0;
    bottom: -6px;
    height: 1px;
    background: linear-gradient(90deg, rgba(194,149,108,0.55), rgba(194,149,108,0));
}

.dante-text {
    padding: 0px 5px 15px 5px;
    line-height: 1.4;
}

.dante-text2 {
    padding: 0px 320px 15px 20px;
    line-height: 1.4;
}

.dante-offset-ip {
    position: relative;
    display: block;
    margin: 28px auto 24px;
    padding: 0 0 0 2px;
    width: 90%;
}