:root {
--bg: #050008;
--violet: #a855f7;
--cyan: #06b6d4;
--text: #ffffff;
--soft: #d8c7ff;
--green: #86efac;
}
* { box-sizing: border-box; scroll-behavior: smooth; }
body {
margin: 0;
font-family: Arial, Helvetica, sans-serif;
background:
radial-gradient(circle at 50% 0%, rgba(168,85,247,0.35), transparent 35%),
radial-gradient(circle at 20% 80%, rgba(6,182,212,0.20), transparent 35%),
var(--bg);
color: var(--text);
line-height: 1.6;
}
a { color: inherit; }
.thofi-header {
position: sticky;
top: 0;
z-index: 20;
background: rgba(5,0,8,0.86);
backdrop-filter: blur(14px);
border-bottom: 1px solid rgba(255,255,255,0.1);
}
.thofi-nav {
max-width: 1120px;
margin: 0 auto;
padding: 14px 20px;
display: flex;
justify-content: space-between;
align-items: center;
gap: 18px;
}
.thofi-brand {
font-weight: 900;
letter-spacing: 1px;
text-decoration: none;
}
.thofi-links {
display: flex;
gap: 16px;
flex-wrap: wrap;
font-size: 14px;
color: var(--soft);
}
.thofi-links a { text-decoration: none; }
.thofi-wrap {
max-width: 1120px;
margin: 0 auto;
padding: 34px 20px;
}
.thofi-hero {
min-height: 80vh;
display: grid;
grid-template-columns: 1fr 1.1fr;
gap: 34px;
align-items: center;
}
.thofi-logo {
width: min(360px, 90vw);
display: block;
margin: 0 auto;
filter: drop-shadow(0 0 30px rgba(168,85,247,0.7));
}
.thofi-badge {
display: inline-flex;
gap: 8px;
align-items: center;
padding: 8px 13px;
border-radius: 999px;
background: rgba(34,197,94,0.14);
color: var(--green);
font-weight: 800;
font-size: 14px;
margin-bottom: 16px;
}
.thofi-dot {
width: 8px;
height: 8px;
border-radius: 50%;
background: #22c55e;
box-shadow: 0 0 12px #22c55e;
}
h1 {
font-size: clamp(42px, 7vw, 78px);
line-height: 0.95;
margin: 0 0 14px;
letter-spacing: 1px;
}
h2 {
font-size: clamp(28px, 4vw, 44px);
margin: 0 0 16px;
}
h3 { margin-top: 0; }
.thofi-claim {
font-size: 22px;
color: var(--soft);
margin-bottom: 24px;
}
.thofi-buttons {
display: flex;
flex-wrap: wrap;
gap: 12px;
margin-top: 20px;
}
.thofi-btn,
button.thofi-btn {
display: inline-block;
padding: 14px 19px;
border-radius: 16px;
text-decoration: none;
font-weight: 900;
background: linear-gradient(135deg, #8b5cf6, #06b6d4);
box-shadow: 0 14px 28px rgba(6,182,212,0.25);
border: 0;
color: white;
cursor: pointer;
font-size: 16px;
}
.thofi-btn.secondary {
background: rgba(255,255,255,0.08);
border: 1px solid rgba(255,255,255,0.15);
box-shadow: none;
}
.thofi-card {
padding: 24px;
border-radius: 28px;
background: rgba(255,255,255,0.08);
border: 1px solid rgba(255,255,255,0.14);
box-shadow: 0 18px 50px rgba(0,0,0,0.35);
backdrop-filter: blur(16px);
}
.thofi-section { padding: 60px 0; }
audio {
width: 100%;
margin-top: 12px;
}
.thofi-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 16px;
margin-top: 20px;
}
.thofi-mini {
padding: 20px;
border-radius: 22px;
background: rgba(0,0,0,0.25);
border: 1px solid rgba(255,255,255,0.1);
color: var(--soft);
}
.thofi-mini strong {
color: white;
display: block;
font-size: 18px;
margin-bottom: 6px;
}
.thofi-platforms {
display: flex;
flex-wrap: wrap;
gap: 12px;
margin: 18px 0;
}
.thofi-platforms a {
padding: 12px 18px;
border-radius: 14px;
text-decoration: none;
font-weight: 900;
background: rgba(255,255,255,0.09);
border: 1px solid rgba(255,255,255,0.12);
}
iframe {
border: 0;
width: 100%;
border-radius: 14px;
margin-top: 16px;
}
.thofi-about-text {
font-size: 18px;
color: #eee6ff;
}
.thofi-form {
display: grid;
gap: 12px;
margin-top: 20px;
}
.thofi-form input,
.thofi-form textarea {
width: 100%;
padding: 14px 15px;
border-radius: 14px;
border: 1px solid rgba(255,255,255,0.16);
background: rgba(0,0,0,0.28);
color: white;
font-size: 15px;
}
.thofi-form textarea { min-height: 130px; resize: vertical; }
.thofi-form label {
color: var(--soft);
font-size: 14px;
font-weight: 700;
}
.thofi-check {
display: flex;
gap: 10px;
align-items: flex-start;
color: var(--soft);
font-size: 14px;
}
.thofi-check input {
width: auto;
margin-top: 5px;
}
.thofi-note {
color: #bda7ff;
font-size: 14px;
margin-top: 12px;
}
.thofi-footer {
border-top: 1px solid rgba(255,255,255,0.1);
padding: 26px 20px;
text-align: center;
color: #a78bfa;
font-size: 14px;
}
.thofi-footer a {
color: #d8c7ff;
text-decoration: none;
margin: 0 8px;
}
.thofi-legal {
max-width: 900px;
margin: 0 auto;
padding: 70px 20px;
}
.thofi-legal h1 {
font-size: clamp(36px, 6vw, 58px);
}
.thofi-warning {
padding: 16px;
border-radius: 16px;
background: rgba(255,193,7,0.12);
border: 1px solid rgba(255,193,7,0.3);
color: #ffe8a3;
margin: 20px 0;
}
@media (max-width: 800px) {
.thofi-hero {
grid-template-columns: 1fr;
text-align: center;
}
.thofi-grid {
grid-template-columns: 1fr;
}
.thofi-nav {
align-items: flex-start;
flex-direction: column;
}
}
.thofi-spotify-note {
margin-top: 18px;
padding: 16px;
border-radius: 18px;
background: rgba(0,0,0,0.28);
border: 1px solid rgba(255,255,255,0.12);
color: #d8c7ff;
} .thofi-form-box {
margin-top: 22px;
}
.wpcf7 form {
display: grid;
gap: 14px;
}
.wpcf7 label {
display: block;
color: #d8c7ff;
font-size: 14px;
font-weight: 800;
margin-bottom: 6px;
}
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="url"],
.wpcf7 textarea {
width: 100%;
padding: 14px 15px;
border-radius: 14px;
border: 1px solid rgba(255,255,255,0.18);
background: rgba(0,0,0,0.32);
color: #ffffff;
font-size: 15px;
outline: none;
}
.wpcf7 input:focus,
.wpcf7 textarea:focus {
border-color: rgba(6,182,212,0.75);
box-shadow: 0 0 0 3px rgba(6,182,212,0.12);
}
.wpcf7 textarea {
min-height: 130px;
resize: vertical;
}
.wpcf7 .wpcf7-submit {
display: inline-block;
padding: 14px 19px;
border-radius: 16px;
text-decoration: none;
font-weight: 900;
background: linear-gradient(135deg, #8b5cf6, #06b6d4);
box-shadow: 0 14px 28px rgba(6,182,212,0.25);
border: 0;
color: white;
cursor: pointer;
font-size: 16px;
}
.wpcf7 .wpcf7-submit:hover {
filter: brightness(1.08);
}
.wpcf7-list-item {
margin: 0;
color: #d8c7ff;
}
.wpcf7-acceptance label {
display: flex;
align-items: flex-start;
gap: 10px;
line-height: 1.45;
}
.wpcf7-acceptance input {
margin-top: 5px;
}
.wpcf7-response-output {
border-radius: 14px !important;
padding: 12px 14px !important;
color: #ffffff;
}
.wpcf7-not-valid-tip {
color: #fca5a5;
font-size: 13px;
margin-top: 5px;
} .thofi-artist-grid {
display: grid;
grid-template-columns: 1fr;
gap: 18px;
margin: 24px 0 60px;
}
.thofi-artist-card {
display: grid;
grid-template-columns: 86px 1fr;
gap: 20px;
align-items: start;
padding: 24px;
border-radius: 28px;
background: rgba(255,255,255,0.08);
border: 1px solid rgba(255,255,255,0.14);
box-shadow: 0 18px 50px rgba(0,0,0,0.35);
backdrop-filter: blur(16px);
transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.thofi-artist-card:hover {
transform: translateY(-6px);
box-shadow: 0 25px 60px rgba(0,0,0,0.55);
}
.thofi-artist-avatar {
width: 76px;
height: 76px;
border-radius: 22px;
display: flex;
align-items: center;
justify-content: center;
background: linear-gradient(135deg, #8b5cf6, #06b6d4);
font-size: 34px;
font-weight: 900;
box-shadow: 0 0 24px rgba(6,182,212,0.35);
}
.thofi-artist-card h2 {
font-size: 28px;
margin-bottom: 8px;
}
.thofi-status {
display: inline-block;
padding: 5px 10px;
border-radius: 999px;
background: rgba(34,197,94,0.15);
color: #86efac;
font-weight: 800;
font-size: 13px;
}
@media (max-width: 650px) {
.thofi-artist-card {
grid-template-columns: 1fr;
}
}
.thofi-artist-description {
color: #d8c7ff;
margin: 10px 0 0;
}
.thofi-artist-description p {
margin: 0 0 10px;
} .thofi-artist-grid-cards {
grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}
.thofi-artist-card-compact {
grid-template-columns: 1fr;
}
.thofi-artist-image-link {
display: block;
text-decoration: none;
}
.thofi-artist-image {
width: 100%;
height: 230px;
object-fit: cover;
border-radius: 22px;
box-shadow: 0 0 24px rgba(6,182,212,0.22);
}
.thofi-artist-avatar-large {
width: 100%;
height: 230px;
border-radius: 22px;
font-size: 72px;
}
.thofi-detail-layout {
display: grid;
grid-template-columns: 320px 1fr;
gap: 28px;
align-items: center;
}
.thofi-detail-image {
width: 100%;
max-width: 320px;
aspect-ratio: 1 / 1;
object-fit: cover;
border-radius: 28px;
box-shadow: 0 0 34px rgba(168,85,247,0.38);
}
.thofi-detail-avatar {
width: 320px;
height: 320px;
font-size: 110px;
border-radius: 28px;
}
.thofi-back-link {
display: inline-block;
color: #d8c7ff;
text-decoration: none;
margin-bottom: 14px;
font-weight: 800;
}
.thofi-detail-content {
margin-top: 34px;
padding-top: 28px;
border-top: 1px solid rgba(255,255,255,0.14);
color: #eee6ff;
font-size: 18px;
}
@media (max-width: 800px) {
.thofi-detail-layout {
grid-template-columns: 1fr;
}
.thofi-detail-avatar {
width: 100%;
height: 240px;
}
} .thofi-artist-tools {
margin: 24px 0;
display: grid;
grid-template-columns: 1.5fr 1fr 0.7fr;
gap: 12px;
align-items: center;
}
.thofi-artist-search,
.thofi-artist-select {
width: 100%;
padding: 13px 14px;
border-radius: 14px;
border: 1px solid rgba(255,255,255,0.18);
background: rgba(0,0,0,0.32);
color: #ffffff;
font-size: 15px;
outline: none;
}
.thofi-artist-select option {
background: #050008;
color: #ffffff;
}
.thofi-artist-grid-cards {
grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
gap: 14px;
}
.thofi-artist-card-compact {
grid-template-columns: 72px 1fr !important;
align-items: center;
padding: 14px;
gap: 14px;
}
.thofi-artist-image,
.thofi-artist-avatar-large {
width: 72px !important;
height: 72px !important;
min-width: 72px;
object-fit: cover;
border-radius: 16px;
}
.thofi-artist-avatar-large {
font-size: 30px !important;
}
.thofi-artist-card-content h2 {
font-size: 18px;
margin: 0 0 5px;
}
.thofi-artist-card-content p {
font-size: 13px;
margin: 3px 0;
color: #d8c7ff;
}
.thofi-artist-card-content .thofi-buttons {
margin-top: 8px;
gap: 7px;
}
.thofi-artist-card-content .thofi-btn {
padding: 7px 10px;
font-size: 12px;
border-radius: 11px;
}
.thofi-load-wrap {
text-align: center;
margin: 28px 0 60px;
}
#artistCount {
margin-top: 10px;
}
@media (max-width: 760px) {
.thofi-artist-tools {
grid-template-columns: 1fr;
}
.thofi-artist-grid-cards {
grid-template-columns: 1fr;
}
} .thofi-preview-player,
.thofi-spotify-embed {
margin-top: 18px;
padding: 18px;
border-radius: 22px;
background: rgba(0,0,0,0.25);
border: 1px solid rgba(255,255,255,0.12);
}
.thofi-preview-player audio {
width: 100%;
display: block;
}
.thofi-preview-player p,
.thofi-spotify-embed p {
margin-top: 0;
color: #d8c7ff;
}
.thofi-spotify-embed iframe {
width: 100% !important;
max-width: 100% !important;
border-radius: 14px;
}
.thofi-artist-card-content .thofi-buttons .thofi-btn {
white-space: nowrap;
} .thofi-preview-player .wp-audio-shortcode {
width: 100% !important;
max-width: 100% !important;
}
.thofi-preview-player .mejs-container,
.thofi-preview-player .mejs-controls {
border-radius: 14px;
}
.thofi-preview-player {
overflow: hidden;
} .thofi-hero-platform {
padding: 80px 20px 50px;
text-align: center;
}
.thofi-hero-platform h1 {
font-size: 64px;
margin-bottom: 18px;
background: linear-gradient(90deg,#ffffff,#d8c7ff,#8be9fd);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
}
.thofi-platform-subtitle {
max-width: 900px;
margin: 0 auto 30px;
font-size: 22px;
color: #d8c7ff;
}
@media (max-width: 760px) {
.thofi-hero-platform h1 {
font-size: 42px;
}
.thofi-platform-subtitle {
font-size: 18px;
}
} .thofi-song-grid {
display: grid;
grid-template-columns: repeat(auto-fit,minmax(320px,1fr));
gap: 24px;
margin-top: 34px;
}
.thofi-song-card {
background: rgba(255,255,255,0.05);
border-radius: 26px;
overflow: hidden;
border: 1px solid rgba(255,255,255,0.08);
backdrop-filter: blur(10px);
}
.thofi-song-cover {
width: 100%;
aspect-ratio: 1/1;
object-fit: cover;
}
.thofi-song-content {
padding: 22px;
}
.thofi-song-player {
margin-top: 16px;
}
.thofi-song-detail {
max-width: 900px;
margin: auto;
}
.thofi-song-detail-cover {
width: 100%;
max-width: 420px;
border-radius: 24px;
display: block;
margin: 0 auto 28px;
} .thofi-featured-release {
padding: 70px 20px 40px;
}
.thofi-featured-grid {
display: grid;
grid-template-columns: 1fr 480px;
gap: 40px;
align-items: center;
}
.thofi-badge {
display: inline-block;
padding: 8px 16px;
border-radius: 999px;
background: rgba(139,233,253,0.12);
color: #8be9fd;
font-size: 13px;
letter-spacing: 1px;
margin-bottom: 18px;
}
.thofi-featured-left h1 {
font-size: 68px;
line-height: 1;
margin-bottom: 20px;
}
.thofi-feature-text {
font-size: 22px;
color: #d8c7ff;
margin-bottom: 30px;
max-width: 700px;
}
.thofi-featured-song-card {
background: rgba(255,255,255,0.05);
border-radius: 30px;
overflow: hidden;
border: 1px solid rgba(255,255,255,0.08);
backdrop-filter: blur(14px);
box-shadow: 0 0 40px rgba(139,233,253,0.12);
}
.thofi-featured-cover {
width: 100%;
aspect-ratio: 1/1;
object-fit: cover;
}
.thofi-featured-content {
padding: 24px;
}
.thofi-featured-player {
margin: 20px 0;
}
.thofi-section-headline {
margin-bottom: 30px;
}
.thofi-section-headline h2 {
font-size: 42px;
margin-bottom: 10px;
}
.thofi-section-headline p {
color: #d8c7ff;
}
.thofi-latest-songs-section {
padding: 30px 20px 70px;
}
.thofi-latest-grid {
display: grid;
grid-template-columns: repeat(auto-fit,minmax(240px,1fr));
gap: 20px;
}
.thofi-mini-song-card {
background: rgba(255,255,255,0.04);
border-radius: 24px;
overflow: hidden;
border: 1px solid rgba(255,255,255,0.08);
transition: transform .25s ease;
}
.thofi-mini-song-card:hover {
transform: translateY(-6px);
}
.thofi-mini-cover {
width: 100%;
aspect-ratio: 1/1;
object-fit: cover;
}
.thofi-mini-content {
padding: 18px;
}
.thofi-mini-content h3 {
margin-bottom: 8px;
}
.thofi-mini-content p {
color: #d8c7ff;
margin-bottom: 16px;
}
@media (max-width: 980px) {
.thofi-featured-grid {
grid-template-columns: 1fr;
}
.thofi-featured-left h1 {
font-size: 46px;
}
.thofi-feature-text {
font-size: 18px;
}
} .thofi-trending-section,
.thofi-focus-artist-section {
padding: 50px 20px 70px;
}
.thofi-trending-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
gap: 24px;
}
.thofi-trending-card {
position: relative;
overflow: hidden;
border-radius: 30px;
background: rgba(255,255,255,0.055);
border: 1px solid rgba(255,255,255,0.1);
box-shadow: 0 0 40px rgba(139,233,253,0.08);
transition: transform .28s ease, box-shadow .28s ease;
}
.thofi-trending-card:hover {
transform: translateY(-8px);
box-shadow: 0 0 55px rgba(168,85,247,0.22);
}
.thofi-trending-cover {
width: 100%;
aspect-ratio: 1/1;
object-fit: cover;
}
.thofi-trending-content {
padding: 24px;
}
.thofi-trending-content h3 {
font-size: 28px;
margin: 10px 0;
}
.thofi-trending-content p {
color: #d8c7ff;
}
.thofi-focus-artist-grid {
display: grid;
grid-template-columns: repeat(auto-fit,minmax(180px,1fr));
gap: 20px;
}
.thofi-focus-artist-card {
text-align: center;
padding: 20px;
border-radius: 26px;
background: rgba(255,255,255,0.045);
border: 1px solid rgba(255,255,255,0.09);
transition: transform .25s ease, box-shadow .25s ease;
}
.thofi-focus-artist-card:hover {
transform: translateY(-7px);
box-shadow: 0 0 35px rgba(139,233,253,0.16);
}
.thofi-focus-artist-image,
.thofi-focus-artist-avatar {
width: 120px;
height: 120px;
border-radius: 28px;
object-fit: cover;
margin: 0 auto 14px;
display: flex;
align-items: center;
justify-content: center;
}
.thofi-focus-artist-avatar {
background: linear-gradient(135deg,#8b5cf6,#06b6d4);
font-size: 52px;
font-weight: 900;
}
.thofi-focus-artist-card h3 {
margin: 10px 0 4px;
}
.thofi-focus-artist-card p {
color: #d8c7ff;
margin: 0 0 8px;
}
.thofi-focus-artist-card span {
display: inline-block;
font-size: 12px;
color: #8be9fd;
background: rgba(139,233,253,0.1);
border-radius: 999px;
padding: 5px 10px;
} .thofi-featured-song-card,
.thofi-mini-song-card,
.thofi-song-card,
.thofi-artist-card {
transition: transform .25s ease, box-shadow .25s ease;
}
.thofi-featured-song-card:hover,
.thofi-mini-song-card:hover,
.thofi-song-card:hover,
.thofi-artist-card:hover {
transform: translateY(-6px);
box-shadow: 0 0 45px rgba(168,85,247,0.18);
} .thofi-share-box {
margin-top: 34px;
padding-top: 28px;
border-top: 1px solid rgba(255,255,255,0.14);
}
.thofi-share-box h2 {
margin-bottom: 8px;
}
.thofi-share-box p {
color: #d8c7ff;
}
.thofi-share-buttons {
display: flex;
flex-wrap: wrap;
gap: 10px;
margin-top: 16px;
}
.thofi-share-btn {
display: inline-block;
padding: 10px 14px;
border-radius: 14px;
background: rgba(255,255,255,0.08);
border: 1px solid rgba(255,255,255,0.13);
color: #ffffff;
text-decoration: none;
font-weight: 800;
cursor: pointer;
transition: transform .2s ease, box-shadow .2s ease;
}
.thofi-share-btn:hover {
transform: translateY(-3px);
box-shadow: 0 0 24px rgba(139,233,253,0.18);
} .thofi-sticky-player {
position: fixed;
left: 20px;
right: 20px;
bottom: 20px;
z-index: 9999;
display: flex;
align-items: center;
justify-content: space-between;
padding: 16px 22px;
border-radius: 24px;
background: rgba(10,10,18,0.92);
backdrop-filter: blur(20px);
border: 1px solid rgba(255,255,255,0.08);
box-shadow: 0 0 40px rgba(139,233,253,0.14);
}
.thofi-player-left {
display: flex;
align-items: center;
gap: 16px;
}
.thofi-player-cover {
width: 60px;
height: 60px;
display: flex;
align-items: center;
justify-content: center;
border-radius: 18px;
background: linear-gradient(135deg,#8b5cf6,#06b6d4);
font-size: 28px;
}
.thofi-player-meta {
display: flex;
flex-direction: column;
}
.thofi-player-meta strong {
font-size: 16px;
}
.thofi-player-meta span {
color: #d8c7ff;
font-size: 13px;
}
.thofi-player-btn {
width: 62px;
height: 62px;
border-radius: 50%;
border: none;
background: linear-gradient(135deg,#8b5cf6,#06b6d4);
color: white;
font-size: 22px;
font-weight: bold;
cursor: pointer;
transition: transform .2s ease, box-shadow .2s ease;
}
.thofi-player-btn:hover {
transform: scale(1.06);
box-shadow: 0 0 28px rgba(139,233,253,0.3);
}
body {
padding-bottom: 120px;
}
@media (max-width: 760px) {
.thofi-sticky-player {
left: 10px;
right: 10px;
bottom: 10px;
padding: 12px 14px;
}
.thofi-player-cover {
width: 48px;
height: 48px;
}
.thofi-player-btn {
width: 52px;
height: 52px;
}
.thofi-player-meta strong {
font-size: 14px;
}
} .thofi-player-center {
display: flex;
align-items: center;
gap: 12px;
}
.thofi-player-btn.small {
width: 48px;
height: 48px;
font-size: 18px;
}
.thofi-player-btn.active {
box-shadow: 0 0 28px rgba(139,233,253,0.35);
transform: scale(1.08);
}
@media (max-width: 760px) {
.thofi-player-center {
gap: 8px;
}
.thofi-player-btn.small {
width: 42px;
height: 42px;
font-size: 15px;
}
} body {
position: relative;
overflow-x: hidden;
background:
radial-gradient(circle at top left, rgba(139,92,246,0.16), transparent 35%),
radial-gradient(circle at bottom right, rgba(6,182,212,0.14), transparent 35%),
#070710;
} .thofi-bg-glow {
position: fixed;
width: 520px;
height: 520px;
border-radius: 50%;
filter: blur(90px);
opacity: 0.18;
pointer-events: none;
z-index: -1;
animation: thofiGlowMove 18s ease-in-out infinite alternate;
}
.glow-1 {
top: -120px;
left: -120px;
background: #8b5cf6;
}
.glow-2 {
right: -140px;
top: 30%;
background: #06b6d4;
animation-duration: 24s;
}
.glow-3 {
bottom: -180px;
left: 30%;
background: #ec4899;
animation-duration: 30s;
}
@keyframes thofiGlowMove {
0% {
transform: translate3d(0,0,0) scale(1);
}
100% {
transform: translate3d(80px,-40px,0) scale(1.15);
}
} .thofi-particles {
position: fixed;
inset: 0;
pointer-events: none;
z-index: -1;
overflow: hidden;
}
.thofi-particles span {
position: absolute;
width: 6px;
height: 6px;
border-radius: 50%;
background: rgba(255,255,255,0.18);
animation: thofiFloat 20s linear infinite;
}
.thofi-particles span:nth-child(1){left:10%;animation-duration:22s;top:100%;}
.thofi-particles span:nth-child(2){left:20%;animation-duration:18s;top:100%;}
.thofi-particles span:nth-child(3){left:35%;animation-duration:25s;top:100%;}
.thofi-particles span:nth-child(4){left:48%;animation-duration:20s;top:100%;}
.thofi-particles span:nth-child(5){left:60%;animation-duration:27s;top:100%;}
.thofi-particles span:nth-child(6){left:72%;animation-duration:19s;top:100%;}
.thofi-particles span:nth-child(7){left:82%;animation-duration:23s;top:100%;}
.thofi-particles span:nth-child(8){left:90%;animation-duration:30s;top:100%;}
.thofi-particles span:nth-child(9){left:55%;animation-duration:17s;top:100%;}
.thofi-particles span:nth-child(10){left:15%;animation-duration:28s;top:100%;}
@keyframes thofiFloat {
from {
transform: translateY(0) scale(1);
opacity: 0;
}
10% {
opacity: .5;
}
to {
transform: translateY(-120vh) scale(1.8);
opacity: 0;
}
} .thofi-song-card,
.thofi-featured-song-card,
.thofi-mini-song-card,
.thofi-trending-card,
.thofi-artist-card,
.thofi-focus-artist-card {
transition:
transform .35s ease,
box-shadow .35s ease,
border-color .35s ease;
}
.thofi-song-card:hover,
.thofi-featured-song-card:hover,
.thofi-mini-song-card:hover,
.thofi-trending-card:hover,
.thofi-artist-card:hover,
.thofi-focus-artist-card:hover {
transform: translateY(-10px) scale(1.01);
border-color: rgba(139,233,253,0.3);
box-shadow:
0 0 60px rgba(139,233,253,0.12),
0 0 100px rgba(168,85,247,0.12);
} .thofi-song-cover,
.thofi-featured-cover,
.thofi-mini-cover,
.thofi-trending-cover,
.thofi-focus-artist-image {
transition: transform .45s ease;
}
.thofi-song-card:hover .thofi-song-cover,
.thofi-featured-song-card:hover .thofi-featured-cover,
.thofi-mini-song-card:hover .thofi-mini-cover,
.thofi-trending-card:hover .thofi-trending-cover,
.thofi-focus-artist-card:hover .thofi-focus-artist-image {
transform: scale(1.06);
} #thofiStickyPlayer.playing {
animation: thofiPlayerPulse 2.4s ease-in-out infinite;
}
@keyframes thofiPlayerPulse {
0%,100% {
box-shadow:
0 0 40px rgba(139,233,253,0.16),
0 0 0 rgba(168,85,247,0);
}
50% {
box-shadow:
0 0 70px rgba(139,233,253,0.28),
0 0 120px rgba(168,85,247,0.18);
}
} html {
scroll-behavior: smooth;
}
.thofi-btn {
transition:
transform .25s ease,
box-shadow .25s ease,
background .25s ease;
}
.thofi-btn:hover {
transform: translateY(-2px);
box-shadow: 0 0 28px rgba(139,233,253,0.24);
} .thofi-song-tools {
margin: 24px 0;
display: grid;
grid-template-columns: 1.5fr 1fr 0.8fr;
gap: 12px;
align-items: center;
}
.thofi-song-search,
.thofi-song-select {
width: 100%;
padding: 13px 14px;
border-radius: 14px;
border: 1px solid rgba(255,255,255,0.18);
background: rgba(0,0,0,0.32);
color: #ffffff;
font-size: 15px;
outline: none;
}
.thofi-song-select option {
background: #050008;
color: #ffffff;
}
.thofi-song-grid-compact {
grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
gap: 16px;
}
.thofi-song-card-compact {
display: grid;
grid-template-columns: 92px 1fr;
gap: 16px;
padding: 14px;
align-items: start;
}
.thofi-song-cover-small,
.thofi-song-cover-placeholder {
width: 92px;
height: 92px;
min-width: 92px;
border-radius: 18px;
object-fit: cover;
}
.thofi-song-cover-placeholder {
display: flex;
align-items: center;
justify-content: center;
background: linear-gradient(135deg,#8b5cf6,#06b6d4);
font-size: 34px;
}
.thofi-song-card-compact .thofi-song-content {
padding: 0;
}
.thofi-song-card-compact h2 {
font-size: 20px;
margin: 0 0 6px;
}
.thofi-song-card-compact p {
font-size: 13px;
margin: 3px 0;
color: #d8c7ff;
}
.thofi-song-card-compact .thofi-song-player {
margin-top: 10px;
}
.thofi-song-card-compact .thofi-buttons {
margin-top: 10px;
gap: 8px;
}
.thofi-song-card-compact .thofi-btn {
padding: 8px 11px;
font-size: 12px;
border-radius: 11px;
}
@media (max-width: 760px) {
.thofi-song-tools {
grid-template-columns: 1fr;
}
.thofi-song-grid-compact {
grid-template-columns: 1fr;
}
} .thofi-interaction-box {
margin-top: 40px;
padding-top: 26px;
border-top: 1px solid rgba(255,255,255,0.12);
}
.thofi-interaction-buttons {
display: flex;
flex-wrap: wrap;
gap: 14px;
margin: 18px 0;
}
.thofi-like-btn,
.thofi-favorite-btn {
border: none;
cursor: pointer;
padding: 14px 18px;
border-radius: 16px;
font-weight: 800;
color: #fff;
background: rgba(255,255,255,0.08);
border: 1px solid rgba(255,255,255,0.12);
transition: transform .2s ease, box-shadow .2s ease;
}
.thofi-like-btn:hover,
.thofi-favorite-btn:hover {
transform: translateY(-2px);
box-shadow: 0 0 24px rgba(139,233,253,0.18);
}
.thofi-like-btn.liked {
background: rgba(236,72,153,0.18);
}
.thofi-favorite-btn.saved {
background: rgba(139,233,253,0.16);
}
.thofi-interaction-note {
color: #d8c7ff;
}
.thofi-like-count {
display: inline-block;
margin: 8px 0 14px;
color: #ff7db8;
font-size: 14px;
font-weight: 700;
} .thofi-song-cover-small,.thofi-song-cover-placeholder{width:92px;height:92px;min-width:92px;border-radius:18px;object-fit:cover}.thofi-song-cover-placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#8b5cf6,#06b6d4);font-size:34px}.thofi-song-card-compact{display:grid;grid-template-columns:92px 1fr;gap:16px;padding:14px;align-items:start}.thofi-song-card-compact .thofi-song-content{padding:0}.thofi-song-tools{margin:24px 0;display:grid;grid-template-columns:1.5fr 1fr .8fr;gap:12px;align-items:center}.thofi-song-search,.thofi-song-select{width:100%;padding:13px 14px;border-radius:14px;border:1px solid rgba(255,255,255,.18);background:rgba(0,0,0,.32);color:#fff;font-size:15px;outline:none}.thofi-song-select option{background:#050008;color:#fff}.thofi-song-grid-compact{grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:16px}@media(max-width:760px){.thofi-song-tools{grid-template-columns:1fr}.thofi-song-grid-compact{grid-template-columns:1fr}}
.thofi-audio-fallback {
margin-top: 10px;
font-size: 14px;
color: #d8c7ff;
}
.thofi-audio-fallback a {
color: #8be9fd;
} .thofi-nowplaying-card {
overflow: hidden;
}
.thofi-nowplaying-layout {
display: grid;
grid-template-columns: 220px 1fr;
gap: 28px;
align-items: center;
}
.thofi-nowplaying-cover-wrap {
border-radius: 28px;
padding: 10px;
background: linear-gradient(135deg, rgba(139,92,246,.45), rgba(6,182,212,.35));
box-shadow: 0 0 45px rgba(6,182,212,.16);
}
.thofi-nowplaying-cover {
width: 100%;
aspect-ratio: 1 / 1;
object-fit: cover;
border-radius: 22px;
display: block;
background: rgba(0,0,0,.25);
}
.thofi-nowplaying-artist {
color: var(--soft);
font-size: 22px;
margin-top: -4px;
}
.thofi-player-cover-img {
width: 60px;
height: 60px;
object-fit: cover;
border-radius: 18px;
background: linear-gradient(135deg,#8b5cf6,#06b6d4);
box-shadow: 0 0 18px rgba(6,182,212,.20);
}
.thofi-sticky-player.playing {
border-color: rgba(134,239,172,.35);
box-shadow: 0 0 44px rgba(34,197,94,.20), 0 0 80px rgba(6,182,212,.12);
}
@media (max-width: 760px) {
.thofi-nowplaying-layout {
grid-template-columns: 1fr;
}
.thofi-nowplaying-cover-wrap {
max-width: 260px;
}
.thofi-player-cover-img {
width: 48px;
height: 48px;
}
} .thofi-hero {
gap: 56px;
}
.thofi-claim {
max-width: 760px;
font-size: clamp(24px, 3vw, 34px);
line-height: 1.2;
font-weight: 800;
color: #f5ecff;
}
.thofi-hero p {
max-width: 680px;
font-size: 18px;
line-height: 1.7;
}
.thofi-buttons .thofi-btn:first-child,
button.thofi-btn[data-thofi-radio-play] {
transform: translateY(0);
box-shadow: 0 0 28px rgba(6,182,212,.35), 0 14px 32px rgba(139,92,246,.28);
}
.thofi-nowplaying-card {
border-color: rgba(139,233,253,.26);
}
.thofi-sticky-player {
padding: 18px 24px;
border-radius: 28px;
}
.thofi-player-cover-img {
width: 82px;
height: 82px;
border-radius: 22px;
}
.thofi-player-meta {
gap: 4px;
}
.thofi-player-live-label {
display: inline-flex;
align-items: center;
gap: 7px;
color: #86efac;
font-weight: 900;
font-size: 12px;
letter-spacing: .08em;
}
.thofi-player-live-dot {
width: 8px;
height: 8px;
border-radius: 50%;
background: #22c55e;
box-shadow: 0 0 12px #22c55e;
}
.thofi-player-meta strong {
font-size: 21px;
line-height: 1.2;
}
.thofi-player-meta span {
font-size: 15px;
}
.thofi-player-btn {
width: 68px;
height: 68px;
}
body {
padding-bottom: 145px;
}
@media (max-width: 760px) {
.thofi-player-cover-img {
width: 58px;
height: 58px;
border-radius: 16px;
}
.thofi-player-live-label {
font-size: 10px;
}
.thofi-player-meta strong {
font-size: 15px;
}
.thofi-player-meta span {
font-size: 12px;
}
.thofi-sticky-player {
left: 10px;
right: 10px;
bottom: 10px;
padding: 12px 14px;
}
body {
padding-bottom: 110px;
}
} .thofi-nav-live {
display: inline-flex;
align-items: center;
gap: 7px;
padding: 6px 10px;
border-radius: 999px;
background: rgba(34,197,94,.12);
color: #86efac !important;
font-weight: 900;
}
.thofi-nav-live span {
width: 7px;
height: 7px;
border-radius: 999px;
background: #22c55e;
box-shadow: 0 0 12px #22c55e;
}
.thofi-submit-section {
padding-top: 70px;
}
.thofi-submit-grid {
display: grid;
grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr);
gap: 22px;
align-items: stretch;
}
.thofi-submit-card,
.thofi-submit-form-card {
height: 100%;
}
.thofi-submit-lead {
font-size: 18px;
color: #eee6ff;
}
.thofi-submit-steps {
display: grid;
grid-template-columns: repeat(2, minmax(0,1fr));
gap: 12px;
margin: 24px 0;
}
.thofi-submit-steps div {
padding: 15px;
border-radius: 18px;
background: rgba(0,0,0,.28);
border: 1px solid rgba(255,255,255,.10);
}
.thofi-submit-steps strong {
display: inline-flex;
width: 30px;
height: 30px;
align-items: center;
justify-content: center;
border-radius: 50%;
margin-right: 8px;
background: linear-gradient(135deg,#8b5cf6,#06b6d4);
color: #fff;
}
.thofi-submit-steps span {
color: #f5ecff;
font-weight: 800;
}
.thofi-requirements {
padding: 18px;
border-radius: 22px;
background: rgba(134,239,172,.08);
border: 1px solid rgba(134,239,172,.18);
}
.thofi-requirements h3 {
margin-bottom: 10px;
}
.thofi-requirements ul {
margin: 0;
padding-left: 20px;
color: #d8c7ff;
}
.thofi-requirements li {
margin: 8px 0;
}
.thofi-submit-form-card .wpcf7-submit {
width: 100%;
margin-top: 6px;
padding: 15px 20px;
border-radius: 16px;
font-size: 16px;
letter-spacing: 0;
color: #fff;
background: linear-gradient(135deg, #8b5cf6, #06b6d4);
box-shadow: 0 14px 28px rgba(6,182,212,0.25);
}
.thofi-volume {
display: flex;
flex-direction: column;
gap: 5px;
color: #d8c7ff;
font-size: 11px;
font-weight: 800;
text-transform: uppercase;
letter-spacing: .08em;
}
.thofi-volume input {
width: 120px;
accent-color: #06b6d4;
}
@media (max-width: 900px) {
.thofi-submit-grid {
grid-template-columns: 1fr;
}
}
@media (max-width: 760px) {
.thofi-submit-steps {
grid-template-columns: 1fr;
}
.thofi-volume {
display: none;
}
} .thofi-live-page {
padding-top: 42px;
}
.thofi-live-hero {
position: relative;
display: grid;
grid-template-columns: minmax(280px, 430px) minmax(0, 1fr);
gap: 44px;
align-items: center;
min-height: 72vh;
padding: 54px;
border-radius: 38px;
background:
radial-gradient(circle at 18% 24%, rgba(139,92,246,.38), transparent 34%),
radial-gradient(circle at 86% 18%, rgba(6,182,212,.24), transparent 32%),
linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
border: 1px solid rgba(255,255,255,.14);
box-shadow: 0 28px 80px rgba(0,0,0,.35);
overflow: hidden;
}
.thofi-live-cover-stage {
position: relative;
display: flex;
justify-content: center;
align-items: center;
}
.thofi-live-cover {
position: relative;
z-index: 2;
width: min(100%, 420px);
aspect-ratio: 1 / 1;
object-fit: cover;
border-radius: 34px;
border: 1px solid rgba(255,255,255,.18);
box-shadow: 0 26px 70px rgba(0,0,0,.48), 0 0 70px rgba(6,182,212,.18);
background: rgba(0,0,0,.28);
}
.thofi-live-pulse-ring {
position: absolute;
width: 92%;
aspect-ratio: 1 / 1;
border-radius: 50%;
background: radial-gradient(circle, rgba(6,182,212,.24), transparent 62%);
filter: blur(4px);
animation: thofiPulse 2.8s ease-in-out infinite;
}
@keyframes thofiPulse {
0%, 100% { transform: scale(.94); opacity: .55; }
50% { transform: scale(1.05); opacity: 1; }
}
.thofi-live-status {
position: absolute;
z-index: 3;
left: 26px;
top: 26px;
display: inline-flex;
align-items: center;
gap: 8px;
padding: 10px 14px;
border-radius: 999px;
background: rgba(0,0,0,.58);
border: 1px solid rgba(134,239,172,.30);
color: #86efac;
font-weight: 900;
letter-spacing: .08em;
backdrop-filter: blur(14px);
}
.thofi-live-status span {
width: 9px;
height: 9px;
border-radius: 50%;
background: #22c55e;
box-shadow: 0 0 16px #22c55e;
}
.thofi-live-info h1 {
font-size: clamp(46px, 6vw, 86px);
line-height: .95;
margin: 18px 0 18px;
}
.thofi-live-kicker {
max-width: 720px;
color: #eee6ff;
font-size: clamp(20px, 2.4vw, 30px);
line-height: 1.28;
font-weight: 800;
}
.thofi-live-songbox {
margin: 28px 0;
padding: 24px;
border-radius: 28px;
background: rgba(0,0,0,.32);
border: 1px solid rgba(255,255,255,.12);
}
.thofi-live-songbox small {
color: #86efac;
font-weight: 900;
letter-spacing: .12em;
}
.thofi-live-songbox h2 {
margin: 8px 0 6px;
font-size: clamp(30px, 4vw, 52px);
}
.thofi-live-songbox p {
margin: 0;
color: #d8c7ff;
font-size: 22px;
}
.thofi-live-extra {
display: flex;
flex-wrap: wrap;
gap: 10px;
margin-top: 18px;
}
.thofi-live-extra span {
padding: 9px 12px;
border-radius: 999px;
background: rgba(255,255,255,.08);
border: 1px solid rgba(255,255,255,.10);
color: #f5ecff;
font-size: 13px;
font-weight: 800;
}
.thofi-live-controls {
display: flex;
flex-wrap: wrap;
gap: 14px;
align-items: center;
}
.thofi-live-main-btn {
border: 0;
cursor: pointer;
padding: 18px 30px;
border-radius: 999px;
color: #fff;
font-size: 18px;
font-weight: 950;
background: linear-gradient(135deg, #8b5cf6, #06b6d4);
box-shadow: 0 0 34px rgba(6,182,212,.36), 0 20px 40px rgba(139,92,246,.28);
}
.thofi-live-note {
max-width: 680px;
margin-top: 18px;
color: #bdaee0;
}
.thofi-live-grid {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 22px;
}
@media (max-width: 980px) {
.thofi-live-hero {
grid-template-columns: 1fr;
padding: 34px;
}
.thofi-live-cover {
max-width: 340px;
}
}
@media (max-width: 760px) {
.thofi-live-page {
padding-top: 20px;
}
.thofi-live-hero {
padding: 24px;
border-radius: 28px;
gap: 26px;
min-height: auto;
}
.thofi-live-songbox {
padding: 18px;
}
.thofi-live-songbox p {
font-size: 17px;
}
.thofi-live-grid {
grid-template-columns: 1fr;
}
} .thofi-history-section {
margin-top: 42px;
}
.thofi-history-grid {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 18px;
}
.thofi-history-grid-compact {
grid-template-columns: repeat(5, minmax(0, 1fr));
}
.thofi-history-card {
display: grid;
grid-template-columns: 86px minmax(0, 1fr);
gap: 14px;
align-items: center;
padding: 14px;
border-radius: 22px;
background: rgba(255,255,255,.07);
border: 1px solid rgba(255,255,255,.12);
box-shadow: 0 14px 34px rgba(0,0,0,.22);
}
.thofi-history-grid-compact .thofi-history-card {
grid-template-columns: 1fr;
align-items: start;
}
.thofi-history-cover {
width: 86px;
height: 86px;
object-fit: cover;
border-radius: 18px;
border: 1px solid rgba(255,255,255,.14);
background: rgba(0,0,0,.25);
}
.thofi-history-grid-compact .thofi-history-cover {
width: 100%;
height: auto;
aspect-ratio: 1 / 1;
}
.thofi-history-meta span {
display: inline-block;
margin-bottom: 6px;
color: #86efac;
font-size: 12px;
font-weight: 900;
letter-spacing: .08em;
text-transform: uppercase;
}
.thofi-history-meta strong {
display: block;
color: #fff;
font-size: 18px;
line-height: 1.18;
}
.thofi-history-meta p {
margin: 6px 0 0;
color: #d8c7ff;
font-size: 14px;
}
.thofi-history-empty {
grid-column: 1 / -1;
padding: 22px;
border-radius: 22px;
background: rgba(255,255,255,.06);
border: 1px solid rgba(255,255,255,.10);
color: #d8c7ff;
}
@media (max-width: 1100px) {
.thofi-history-grid-compact {
grid-template-columns: repeat(3, minmax(0, 1fr));
}
}
@media (max-width: 760px) {
.thofi-history-grid,
.thofi-history-grid-compact {
grid-template-columns: 1fr;
}
.thofi-history-card,
.thofi-history-grid-compact .thofi-history-card {
grid-template-columns: 76px minmax(0, 1fr);
}
.thofi-history-cover,
.thofi-history-grid-compact .thofi-history-cover {
width: 76px;
height: 76px;
}
} .thofi-pro-detail {
overflow: hidden;
}
.thofi-song-hero-pro,
.thofi-artist-hero-pro {
display: grid;
grid-template-columns: minmax(220px, 360px) minmax(0, 1fr);
gap: 34px;
align-items: center;
margin-top: 22px;
padding: 28px;
border-radius: 30px;
background: linear-gradient(135deg, rgba(255,255,255,.09), rgba(255,255,255,.035));
border: 1px solid rgba(255,255,255,.12);
}
.thofi-song-cover-wrap {
display: flex;
justify-content: center;
}
.thofi-song-detail-cover,
.thofi-detail-image {
width: 230px;
height: 230px;
max-width: 230px;
aspect-ratio: 1 / 1;
object-fit: cover;
border-radius: 22px;
border: 1px solid rgba(255,255,255,.16);
box-shadow: 0 24px 70px rgba(0,0,0,.42);
}
.thofi-song-cover-placeholder-large {
display: grid;
place-items: center;
font-size: 78px;
background: radial-gradient(circle at 30% 20%, rgba(167,139,250,.35), rgba(0,0,0,.28));
}
.thofi-live-chip,
.thofi-mini-label {
display: inline-flex;
align-items: center;
gap: 8px;
margin-bottom: 10px;
padding: 6px 10px;
border-radius: 999px;
color: #86efac;
background: rgba(34,197,94,.12);
border: 1px solid rgba(34,197,94,.28);
font-size: 12px;
font-weight: 900;
letter-spacing: .08em;
text-transform: uppercase;
}
.thofi-song-hero-content h1,
.thofi-artist-hero-content h1 {
margin: 0 0 10px;
font-size: clamp(34px, 5vw, 66px);
line-height: .95;
}
.thofi-song-artist-line,
.thofi-artist-tagline {
font-size: 20px;
color: #d8c7ff;
margin: 0 0 18px;
}
.thofi-song-artist-line a {
color: #fff;
font-weight: 900;
text-decoration: none;
}
.thofi-stat-row {
display: flex;
flex-wrap: wrap;
gap: 12px;
margin: 22px 0;
}
.thofi-stat-row span {
min-width: 130px;
padding: 14px 16px;
border-radius: 18px;
background: rgba(255,255,255,.07);
border: 1px solid rgba(255,255,255,.11);
color: #fff;
}
.thofi-stat-row strong {
display: block;
margin-bottom: 4px;
color: #c4b5fd;
font-size: 12px;
text-transform: uppercase;
letter-spacing: .08em;
}
.thofi-stream-buttons,
.thofi-preview-actions {
display: flex;
flex-wrap: wrap;
gap: 10px;
}
.thofi-native-preview {
padding: 18px;
border-radius: 22px;
background: rgba(0,0,0,.18);
border: 1px solid rgba(255,255,255,.10);
}
.thofi-native-preview audio {
width: 100%;
margin: 8px 0 12px;
}
.thofi-preview-note {
margin: 12px 0 0;
color: #facc15;
font-size: 13px;
line-height: 1.5;
}
.thofi-story-box,
.thofi-related-section {
margin-top: 28px;
padding: 26px;
border-radius: 28px;
background: rgba(255,255,255,.055);
border: 1px solid rgba(255,255,255,.10);
} .thofi-related-section .thofi-latest-grid {
grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
gap: 16px;
}
.thofi-related-section .thofi-mini-song-card {
display: grid;
grid-template-columns: 92px minmax(0, 1fr);
gap: 16px;
align-items: center;
padding: 14px;
}
.thofi-related-section .thofi-mini-song-card > a {
display: block;
width: 92px;
}
.thofi-related-section .thofi-mini-cover,
.thofi-related-section .thofi-song-cover-placeholder {
width: 92px;
height: 92px;
min-width: 92px;
aspect-ratio: 1 / 1;
object-fit: cover;
border-radius: 18px;
}
.thofi-related-section .thofi-mini-content {
padding: 0;
}
.thofi-related-section .thofi-mini-content h3 {
margin: 0 0 10px;
font-size: 20px;
line-height: 1.15;
}
.thofi-pro-song-card {
align-items: stretch;
}
.thofi-pro-song-card .thofi-mini-cover {
width: 100%;
min-height: 170px;
object-fit: cover;
}
.thofi-mini-content small {
display: inline-block;
margin: 4px 0 14px;
color: #c4b5fd;
}
.thofi-song-cover-placeholder {
display: grid;
place-items: center;
background: radial-gradient(circle at 30% 20%, rgba(167,139,250,.30), rgba(0,0,0,.25));
min-height: 120px;
}
@media (max-width: 820px) {
.thofi-song-hero-pro,
.thofi-artist-hero-pro {
grid-template-columns: 1fr;
padding: 18px;
}
.thofi-song-detail-cover,
.thofi-detail-image {
max-width: 230px;
margin-left: auto;
margin-right: auto;
}
.thofi-stat-row span {
width: 100%;
}
} .thofi-preview-button {
cursor: pointer;
border: 0;
}
.thofi-preview-button.playing {
filter: brightness(1.12);
box-shadow: 0 0 0 2px rgba(255,255,255,0.12), 0 0 24px rgba(255,255,255,0.12);
} body.thofi-page-loading main {
opacity: 0.55;
transition: opacity 0.18s ease;
} .thofi-cf7-grid {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 16px;
}
.thofi-cf7-full,
.thofi-cf7-grid .wpcf7-submit {
grid-column: 1 / -1;
}
.wpcf7 select,
.wpcf7 input[type="file"] {
width: 100%;
padding: 14px 15px;
border-radius: 14px;
border: 1px solid rgba(255,255,255,0.18);
background: rgba(0,0,0,0.32);
color: #ffffff;
font-size: 15px;
outline: none;
}
.wpcf7 select:focus,
.wpcf7 input[type="file"]:focus {
border-color: rgba(6,182,212,0.75);
box-shadow: 0 0 0 3px rgba(6,182,212,0.12);
}
.thofi-form-hint,
.thofi-optional {
display: block;
margin-top: 7px;
color: rgba(255,255,255,0.62);
font-size: 12px;
font-weight: 600;
}
.thofi-rights-box {
padding: 14px 15px;
border-radius: 16px;
background: rgba(255,255,255,0.055);
border: 1px solid rgba(255,255,255,0.13);
}
@media (max-width: 720px) {
.thofi-cf7-grid {
grid-template-columns: 1fr;
}
} .thofi-publication-note {
background: rgba(255,255,255,0.06);
border: 1px solid rgba(255,255,255,0.14);
border-radius: 16px;
padding: 14px 16px;
color: rgba(255,255,255,0.9);
}
.thofi-azuracast-song-card .thofi-mini-label {
background: rgba(255, 0, 102, 0.14);
color: #fff;
} .thofi-submit-page { padding-top: 72px; }
.thofi-submit-page .thofi-section-headline { margin-bottom: 28px; } .thofi-artist-hero-pro {
grid-template-columns: 260px minmax(0, 1fr);
}
.thofi-artist-hero-pro .thofi-detail-image,
.thofi-artist-hero-pro .thofi-detail-avatar {
width: 230px !important;
height: 230px !important;
max-width: 230px !important;
aspect-ratio: 1 / 1;
object-fit: cover;
border-radius: 22px;
}
@media (max-width: 820px) {
.thofi-artist-hero-pro {
grid-template-columns: 1fr;
}
.thofi-artist-hero-pro .thofi-detail-image,
.thofi-artist-hero-pro .thofi-detail-avatar {
margin: 0 auto;
}
} .thofi-artist-hero-content h1{
font-size: clamp(32px, 4vw, 52px) !important;
line-height: 1.05 !important;
margin-bottom: 12px !important;
}
.thofi-artist-hero-content + div h2,
.thofi-artist-songs h2,
.thofi-section-headline h2{
font-size: clamp(26px, 3vw, 38px) !important;
line-height: 1.15 !important;
margin-bottom: 18px !important;
word-break: normal !important;
overflow-wrap: normal !important;
} .thofi-artist-detail,
.thofi-pro-detail,
.thofi-artist-hero-pro{
overflow:visible !important;
height:auto !important;
min-height:unset !important;
max-height:none !important;
position:relative !important;
}
.thofi-artist-hero-pro{
display:grid !important;
grid-template-columns:minmax(260px,360px) minmax(0,1fr) !important;
}
@media (min-width:821px){
.thofi-artist-detail{
display:block !important;
}
} @media (max-width: 820px){
body.single-thofi_artist .thofi-artist-detail,
body.single-thofi_artist .thofi-pro-detail{
overflow: visible !important;
width: 100% !important;
max-width: 100% !important;
}
body.single-thofi_artist .thofi-artist-hero-pro{
display: flex !important;
flex-direction: column !important;
grid-template-columns: 1fr !important;
width: 100% !important;
max-width: 100% !important;
height: auto !important;
min-height: 0 !important;
overflow: visible !important;
box-sizing: border-box !important;
}
body.single-thofi_artist .thofi-artist-hero-pro > *,
body.single-thofi_artist .thofi-artist-detail > *,
body.single-thofi_artist .thofi-pro-detail > *{
max-width: 100% !important;
box-sizing: border-box !important;
}
body.single-thofi_artist .thofi-artist-image,
body.single-thofi_artist .thofi-artist-photo,
body.single-thofi_artist .artist-image,
body.single-thofi_artist .artist-photo{
width: 100% !important;
max-width: 100% !important;
margin-left: auto !important;
margin-right: auto !important;
}
} .thofi-song-single-page .thofi-stat-row > span {
width: 230px;
min-width: 230px;
padding: 18px;
border-radius: 24px;
display: grid;
grid-template-columns: 1fr 1fr;
grid-template-rows: auto 74px;
gap: 12px;
align-items: center;
justify-items: center;
box-sizing: border-box;
}
.thofi-song-single-page .thofi-stat-row > span > strong {
grid-column: 1 / -1;
width: 100%;
margin: 0;
text-align: center;
font-size: 15px;
line-height: 1.1;
letter-spacing: .12em;
}
.thofi-song-single-page .thofi-stat-row > span .thofi-like-total,
.thofi-song-single-page .thofi-stat-row > span .thofi-like-btn {
width: 74px;
height: 74px;
min-width: 74px;
padding: 0;
margin: 0;
border-radius: 18px;
display: flex;
align-items: center;
justify-content: center;
box-sizing: border-box;
line-height: 1;
text-align: center;
text-decoration: none;
}
.thofi-song-single-page .thofi-stat-row > span .thofi-like-total {
font-size: 30px;
font-weight: 800;
color: #fff;
background: rgba(255,255,255,.07);
border: 1px solid rgba(255,255,255,.11);
}
.thofi-song-single-page .thofi-stat-row > span .thofi-like-btn {
font-size: 30px;
background: rgba(255,255,255,.07);
border: 1px solid rgba(255,255,255,.11);
}
.thofi-song-single-page .thofi-stat-row > span .thofi-like-btn.liked {
cursor: default;
}
@media (max-width: 820px) {
.thofi-song-single-page .thofi-stat-row > span {
width: 230px;
max-width: 100%;
}
.thofi-song-single-page .thofi-stat-row > span .thofi-like-total,
.thofi-song-single-page .thofi-stat-row > span .thofi-like-btn {
width: 74px;
min-width: 74px;
}
}  .thofi-song-cover,
.thofi-featured-cover,
.thofi-mini-cover,
.thofi-trending-cover,
.thofi-song-detail-cover,
.thofi-song-cover-small,
.thofi-song-cover-placeholder,
.thofi-song-cover-placeholder-large,
.thofi-related-section .thofi-mini-cover,
.thofi-related-section .thofi-song-cover-placeholder,
.thofi-pro-song-card .thofi-mini-cover,
.thofi-artist-image,
.thofi-detail-image,
.thofi-artist-avatar-large,
.thofi-detail-avatar,
.thofi-focus-artist-image,
.thofi-focus-artist-avatar,
.thofi-player-cover-img,
.thofi-player-cover,
.thofi-nowplaying-cover,
.thofi-history-cover,
.thofi-live-cover {
aspect-ratio: 1 / 1 !important;
object-fit: cover !important;
display: block;
box-sizing: border-box;
overflow: hidden;
} .thofi-song-detail-cover,
.thofi-detail-image,
.thofi-detail-avatar,
.thofi-song-cover-placeholder-large {
width: 230px !important;
height: 230px !important;
max-width: 230px !important;
min-width: 230px !important;
border-radius: 22px;
} .thofi-song-cover-small,
.thofi-related-section .thofi-mini-cover,
.thofi-related-section .thofi-song-cover-placeholder {
width: 92px !important;
height: 92px !important;
max-width: 92px !important;
min-width: 92px !important;
border-radius: 18px;
} .thofi-song-cover,
.thofi-featured-cover,
.thofi-mini-cover,
.thofi-trending-cover,
.thofi-pro-song-card .thofi-mini-cover {
width: 100% !important;
height: auto !important;
min-height: 0 !important;
} .thofi-artist-image,
.thofi-artist-avatar-large {
width: 72px !important;
height: 72px !important;
max-width: 72px !important;
min-width: 72px !important;
border-radius: 16px;
} .thofi-focus-artist-image,
.thofi-focus-artist-avatar {
width: 120px !important;
height: 120px !important;
max-width: 120px !important;
min-width: 120px !important;
border-radius: 28px;
} .thofi-history-cover {
width: 86px !important;
height: 86px !important;
max-width: 86px !important;
min-width: 86px !important;
} .thofi-nowplaying-cover,
.thofi-live-cover {
width: 100% !important;
height: auto !important;
min-height: 0 !important;
} .thofi-player-cover-img,
.thofi-player-cover {
width: 82px !important;
height: 82px !important;
max-width: 82px !important;
min-width: 82px !important;
border-radius: 22px;
} .thofi-song-card,
.thofi-mini-song-card,
.thofi-featured-song-card,
.thofi-trending-card,
.thofi-pro-song-card,
.thofi-related-section .thofi-mini-song-card {
overflow: hidden;
} .thofi-spotify-embed,
.thofi-preview-player,
.thofi-native-preview,
.thofi-story-box,
.thofi-related-section,
.thofi-pro-detail,
.thofi-card {
max-width: 100%;
box-sizing: border-box;
}
.thofi-spotify-embed iframe,
.thofi-preview-player iframe,
iframe {
max-width: 100% !important;
box-sizing: border-box;
} @media (max-width: 900px) {
html,
body {
max-width: 100%;
overflow-x: hidden;
}
.thofi-wrap,
.thofi-card,
.thofi-pro-detail,
.thofi-song-hero-pro,
.thofi-artist-hero-pro,
.thofi-story-box,
.thofi-related-section,
.thofi-spotify-embed,
.thofi-preview-player,
.thofi-native-preview {
width: 100% !important;
max-width: 100% !important;
box-sizing: border-box !important;
}
.thofi-song-detail-cover,
.thofi-detail-image,
.thofi-detail-avatar,
.thofi-song-cover-placeholder-large {
width: 230px !important;
height: 230px !important;
max-width: 230px !important;
min-width: 230px !important;
margin-left: auto;
margin-right: auto;
}
.thofi-player-cover-img,
.thofi-player-cover {
width: 58px !important;
height: 58px !important;
max-width: 58px !important;
min-width: 58px !important;
border-radius: 16px;
}
.thofi-song-grid,
.thofi-song-grid-compact,
.thofi-latest-grid,
.thofi-related-section .thofi-latest-grid,
.thofi-artist-grid,
.thofi-artist-grid-cards {
grid-template-columns: 1fr !important;
}
} @media (max-width: 520px) {
.thofi-song-detail-cover,
.thofi-detail-image,
.thofi-detail-avatar,
.thofi-song-cover-placeholder-large {
width: 210px !important;
height: 210px !important;
max-width: 210px !important;
min-width: 210px !important;
}
.thofi-song-cover-small,
.thofi-related-section .thofi-mini-cover,
.thofi-related-section .thofi-song-cover-placeholder {
width: 82px !important;
height: 82px !important;
max-width: 82px !important;
min-width: 82px !important;
}
.thofi-history-cover {
width: 76px !important;
height: 76px !important;
max-width: 76px !important;
min-width: 76px !important;
}
} .thofi-plattenkueche {
color: #fff5e6;
background: #130b07;
overflow: hidden;
}
.opk-hero {
position: relative;
min-height: 760px;
display: flex;
align-items: center;
justify-content: center;
padding: 120px 18px 80px;
isolation: isolate;
}
.opk-hero-bg {
position: absolute;
inset: 0;
z-index: -2;
background-image:
linear-gradient(180deg, rgba(18,8,3,.35), rgba(18,8,3,.93)),
radial-gradient(circle at 22% 28%, rgba(255,168,72,.36), transparent 34%),
radial-gradient(circle at 78% 18%, rgba(255,218,150,.20), transparent 30%),
radial-gradient(circle at 50% 78%, rgba(95,42,14,.70), transparent 45%),
url(//thofi65.de/wp-content/themes/thofi-ai-radio-wordpress-theme/assets/ollis-plattenkueche-bg.jpg);
background-size: cover;
background-position: center;
filter: saturate(1.06);
}
.opk-hero::after {
content: '';
position: absolute;
inset: 0;
z-index: -1;
background:
linear-gradient(90deg, rgba(0,0,0,.52), transparent 30%, rgba(0,0,0,.46)),
repeating-linear-gradient(0deg, rgba(255,255,255,.025) 0 1px, transparent 1px 5px);
pointer-events: none;
}
.opk-hero-inner {
width: min(1060px, 100%);
text-align: center;
}
.opk-kicker {
margin: 0 0 12px;
font-size: 12px;
font-weight: 800;
letter-spacing: .22em;
text-transform: uppercase;
color: #ffd28a;
}
.opk-hero h1 {
margin: 0;
font-size: clamp(38px, 8vw, 92px);
line-height: .95;
letter-spacing: .03em;
text-shadow: 0 12px 45px rgba(0,0,0,.65);
}
.opk-subtitle {
max-width: 840px;
margin: 26px auto 0;
font-size: clamp(18px, 2.2vw, 26px);
line-height: 1.42;
color: rgba(255,245,230,.92);
}
.opk-player-card {
width: min(720px, 100%);
margin: 44px auto 0;
display: grid;
grid-template-columns: 138px 1fr;
gap: 22px;
align-items: center;
padding: 24px;
border-radius: 32px;
background: rgba(46,23,10,.42);
border: 1px solid rgba(255,221,163,.22);
box-shadow: 0 24px 70px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.13);
backdrop-filter: blur(14px);
text-align: left;
}
.opk-vinyl {
width: 132px;
height: 132px;
border-radius: 50%;
background: repeating-radial-gradient(circle, #17110e 0 5px, #070504 6px 10px);
display: grid;
place-items: center;
box-shadow: 0 18px 45px rgba(0,0,0,.42);
}
.opk-vinyl span {
width: 44px;
height: 44px;
border-radius: 50%;
background: radial-gradient(circle, #3a1409 0 8px, #d29b45 9px 100%);
}
.opk-player-main strong,
.opk-player-main small,
.opk-player-label { display: block; }
.opk-player-label { color: #ffd28a; font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: .14em; margin-bottom: 6px; }
.opk-player-main strong { font-size: clamp(21px, 3vw, 34px); line-height: 1.1; }
.opk-player-main small { color: rgba(255,245,230,.78); margin-top: 7px; font-size: 15px; }
.opk-player-controls { display: flex; align-items: center; gap: 14px; margin-top: 18px; }
.opk-play-btn {
width: 58px;
height: 58px;
border-radius: 50%;
border: 1px solid rgba(255,231,190,.5);
background: rgba(255,210,138,.22);
color: #fff5e6;
font-size: 22px;
cursor: pointer;
}
.opk-player-note { color: rgba(255,245,230,.82); }
.opk-section {
width: min(1120px, calc(100% - 32px));
margin: 0 auto;
padding: 76px 0;
}
.opk-section-head { text-align: center; margin-bottom: 30px; }
.opk-section h2 { margin: 0; font-size: clamp(30px, 5vw, 58px); line-height: 1.05; }
.opk-section-head > p:last-child { color: rgba(255,245,230,.75); }
.opk-now-grid {
display: grid;
grid-template-columns: minmax(220px, 360px) 1fr;
gap: 30px;
align-items: center;
padding: 26px;
border-radius: 34px;
background: linear-gradient(135deg, rgba(75,34,13,.78), rgba(32,15,8,.88));
border: 1px solid rgba(255,221,163,.18);
box-shadow: 0 22px 65px rgba(0,0,0,.32);
}
.opk-cover-frame img {
width: 100%;
aspect-ratio: 1 / 1;
object-fit: cover;
border-radius: 26px;
box-shadow: 0 18px 55px rgba(0,0,0,.42);
}
.opk-now-info h3 { margin: 0; font-size: clamp(30px, 5vw, 62px); line-height: 1.02; }
.opk-now-info p { margin: 14px 0 28px; font-size: clamp(18px, 2.4vw, 28px); color: rgba(255,245,230,.78); }
.opk-progress { height: 12px; border-radius: 999px; background: rgba(255,255,255,.16); overflow: hidden; }
.opk-progress span { display: block; width: 0; height: 100%; border-radius: inherit; background: linear-gradient(90deg, #ffd28a, #fff1c7); transition: width .4s ease; }
.opk-time { display: flex; justify-content: space-between; color: rgba(255,245,230,.7); font-size: 13px; margin-top: 8px; }
.opk-history-card,
.opk-about-card,
.opk-community-card {
margin-top: 26px;
padding: 28px;
border-radius: 30px;
background: rgba(255,255,255,.07);
border: 1px solid rgba(255,221,163,.16);
box-shadow: 0 18px 55px rgba(0,0,0,.23);
backdrop-filter: blur(10px);
}
.opk-history-card h3 { margin: 0 0 18px; font-size: 24px; }
.opk-history-list { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 12px; }
.opk-history-row { display: grid; grid-template-columns: 58px 1fr; gap: 12px; align-items: center; padding: 10px; border-radius: 18px; background: rgba(0,0,0,.18); }
.opk-history-row img { width: 58px; height: 58px; object-fit: cover; border-radius: 13px; }
.opk-history-row strong,
.opk-history-row span { display: block; }
.opk-history-row strong { line-height: 1.15; }
.opk-history-row span { color: rgba(255,245,230,.7); font-size: 13px; margin-top: 4px; }
.opk-about { width: 100%; max-width: none; background: radial-gradient(circle at 50% 20%, rgba(255,168,72,.20), transparent 44%); }
.opk-about-card { width: min(860px, calc(100% - 32px)); margin: 0 auto; text-align: center; padding: clamp(34px, 6vw, 76px); }
.opk-about-card p { font-size: clamp(18px, 2.2vw, 26px); line-height: 1.45; color: rgba(255,245,230,.9); }
.opk-filter { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 18px; margin-bottom: 26px; }
.opk-filter label { color: #ffd28a; font-weight: 800; font-size: 13px; letter-spacing: .08em; text-transform: uppercase; }
.opk-filter input { width: 100%; margin-top: 8px; padding: 15px 16px; border-radius: 16px; border: 1px solid rgba(255,221,163,.22); background: rgba(0,0,0,.22); color: #fff5e6; outline: none; }
.opk-song-wall { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 18px; }
.opk-song-tile { min-width: 0; border-radius: 24px; overflow: hidden; background: rgba(255,255,255,.07); border: 1px solid rgba(255,221,163,.14); transition: transform .22s ease, box-shadow .22s ease; }
.opk-song-tile:hover { transform: translateY(-4px); box-shadow: 0 18px 44px rgba(0,0,0,.32); }
.opk-song-tile img { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; display: block; }
.opk-song-tile div { padding: 14px; }
.opk-song-tile strong,
.opk-song-tile span { display: block; }
.opk-song-tile strong { line-height: 1.16; }
.opk-song-tile span { color: rgba(255,245,230,.72); font-size: 14px; margin-top: 6px; }
.opk-empty { grid-column: 1 / -1; padding: 24px; border-radius: 20px; background: rgba(0,0,0,.20); color: rgba(255,245,230,.75); text-align: center; }
.opk-community { padding-top: 20px; }
.opk-community-card { margin: 0 auto; width: min(760px, 100%); text-align: center; font-size: clamp(22px, 3vw, 36px); line-height: 1.24; }
@media (max-width: 900px) {
.opk-hero { min-height: 680px; padding-top: 90px; }
.opk-now-grid { grid-template-columns: 1fr; }
.opk-cover-frame { max-width: 360px; margin: 0 auto; width: 100%; }
.opk-history-list { grid-template-columns: 1fr; }
.opk-song-wall { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 600px) {
.opk-player-card { grid-template-columns: 1fr; text-align: center; justify-items: center; padding: 20px; }
.opk-player-controls { justify-content: center; }
.opk-filter { grid-template-columns: 1fr; }
.opk-song-wall { grid-template-columns: 1fr; }
.opk-section { width: min(100% - 22px, 1120px); padding: 54px 0; }
.opk-now-grid, .opk-history-card, .opk-about-card, .opk-community-card { border-radius: 24px; padding: 20px; }
} .thofi-song-single-page .thofi-song-hero-pro{
grid-template-columns:260px minmax(0,1fr) !important;
}
.thofi-song-single-page .thofi-song-hero-content h1{
margin:0 0 12px !important;
font-size:clamp(22px,2.1vw,28px) !important;
line-height:1.05 !important;
max-width:620px;
}
.thofi-song-single-page .thofi-stat-row{
display:flex !important;
gap:14px !important;
flex-wrap:nowrap !important;
}
.thofi-song-single-page .thofi-stat-row > span{
width:220px !important;
min-width:220px !important;
min-height:160px !important;
padding:18px !important;
border-radius:24px !important;
display:flex !important;
flex-direction:column !important;
justify-content:flex-start !important;
align-items:center !important;
}
.thofi-song-single-page .thofi-stat-row > span > strong{
margin-bottom:18px !important;
font-size:14px !important;
}
.thofi-song-single-page .thofi-like-total,
.thofi-song-single-page .thofi-like-btn{
width:58px !important;
height:58px !important;
min-width:58px !important;
border-radius:16px !important;
font-size:22px !important;
}
.thofi-song-single-page .thofi-like-total{
font-weight:700 !important;
}
.thofi-song-single-page .thofi-stat-row > span:has(.thofi-like-total){
display:grid !important;
grid-template-columns:58px 58px !important;
grid-template-rows:auto 58px !important;
justify-content:center !important;
column-gap:12px !important;
row-gap:16px !important;
}
.thofi-song-single-page .thofi-stat-row > span:has(.thofi-like-total)>strong{
grid-column:1/-1 !important;
}
@media(max-width:820px){
.thofi-song-single-page .thofi-stat-row{
flex-wrap:wrap !important;
}
.thofi-song-single-page .thofi-stat-row>span{
width:220px !important;
}
}