/* =====================================================================
   home.css — gaya KHUSUS homepage. Hanya dimuat di index.php.
   ===================================================================== */

/* ---------- 1. HERO ---------- */
.hero {
    position: relative; min-height: 100svh;
    display: flex; align-items: flex-end;
    padding-bottom: clamp(3rem, 10vh, 8rem);
    overflow: hidden;
}
.hero__media { position: absolute; inset: 0; z-index: -1; }
.hero__img {
    width: 100%; height: 120%; object-fit: cover;
    transform: scale(1.08); will-change: transform;
    animation: heroDrift 18s ease-in-out infinite alternate;
}
@keyframes heroDrift { to { transform: scale(1.16) translateY(-3%); } }
.hero__veil {
    position: absolute; inset: 0;
    background:
        radial-gradient(120% 90% at 30% 100%, color-mix(in srgb, var(--accent) 35%, transparent), transparent 60%),
        linear-gradient(180deg, color-mix(in srgb, var(--ink-900) 55%, transparent) 0%, transparent 30%, var(--ink-900) 96%);
}

.hero__title {
    font-size: var(--step-2xl); font-weight: 500;
    margin: .4rem 0 1rem; letter-spacing: -.01em;
}
.hero__title span { display: block; }
.hero__cn { font-family: var(--font-cn); color: var(--gold-soft); font-size: .42em; letter-spacing: .1em; margin-top: .2em; }
.hero__tagline {
    font-family: var(--font-display); font-style: italic;
    font-size: var(--step-lg); color: var(--text-on-ink);
    max-width: 30ch; margin-bottom: 2rem;
}
.hero__actions { display: flex; gap: 1rem; flex-wrap: wrap; }

.hero__scroll {
    position: absolute; bottom: 1.6rem; left: 50%; transform: translateX(-50%);
    font-size: var(--step-xs); letter-spacing: .3em; text-transform: uppercase;
    color: var(--text-on-ink-dim); display: flex; flex-direction: column; align-items: center; gap: .6rem;
}
.hero__scroll span { width: 1px; height: 38px; background: linear-gradient(var(--gold), transparent); animation: scrollPulse 2s var(--ease) infinite; }
@keyframes scrollPulse { 0%, 100% { opacity: .3; transform: scaleY(.6); } 50% { opacity: 1; transform: scaleY(1); } }

/* ---------- 2. TRENDING ---------- */
.trending { padding-top: clamp(4rem, 12vh, 9rem); }
.trending__head { margin-bottom: 3rem; }
.trending__head h2 { font-size: var(--step-xl); margin-top: .6rem; max-width: 18ch; }
.trending__grid {
    display: grid; gap: clamp(1.2rem, 3vw, 2rem);
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.card {
    --accent: var(--cinnabar);
    display: block; border-radius: var(--radius); overflow: hidden;
    background: var(--ink-800);
    transition: transform .5s var(--ease-out), box-shadow .5s var(--ease);
    transform-style: preserve-3d; will-change: transform;
}
.card:hover { box-shadow: 0 30px 60px -30px color-mix(in srgb, var(--accent) 60%, black); }
.card__media { position: relative; aspect-ratio: 3/4; overflow: hidden; }
.card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s var(--ease-out); }
.card:hover .card__media img { transform: scale(1.08); }
.card__rating {
    position: absolute; top: .8rem; left: .8rem;
    font-family: var(--font-display); font-size: 1.1rem; font-weight: 600;
    color: var(--ink-900); background: var(--gold-soft);
    padding: .15em .6em; border-radius: 100px;
    box-shadow: 0 4px 14px -4px rgba(0,0,0,.5);
}
.card__body { padding: 1.1rem 1.2rem 1.4rem; transform: translateZ(30px); }
.card__cn { font-family: var(--font-cn); color: var(--accent); font-size: 1rem; }
.card__title { font-size: var(--step-md); margin: .15rem 0 .3rem; }
.card__meta { font-size: var(--step-xs); color: var(--text-on-ink-dim); letter-spacing: .03em; }

/* ---------- 3. GENRE ---------- */
.genre { padding-top: clamp(5rem, 14vh, 10rem); }
.genre__intro { max-width: 60ch; margin-bottom: 3.5rem; }
.genre__intro h2 { font-size: var(--step-xl); margin: .6rem 0 1rem; }
.genre__lead { color: var(--text-on-ink-dim); font-size: var(--step-md); }

.genre__rows { display: flex; flex-direction: column; }
.genre-row {
    display: grid; align-items: center; gap: 1.5rem;
    grid-template-columns: auto auto 1fr 2.2fr auto;
    padding: 1.8rem 0;
    border-top: 1px solid color-mix(in srgb, var(--paper) 12%, transparent);
    transition: padding-left .45s var(--ease), background .45s var(--ease);
}
.genre__rows .genre-row:last-child { border-bottom: 1px solid color-mix(in srgb, var(--paper) 12%, transparent); }
.genre-row:hover { padding-left: 1.4rem; background: linear-gradient(90deg, color-mix(in srgb, var(--cinnabar) 12%, transparent), transparent 70%); }
.genre-row__num { font-family: var(--font-display); font-size: 1.1rem; color: var(--gold); }
.genre-row__cn { font-family: var(--font-cn); font-size: 2rem; color: var(--text-on-ink); }
.genre-row__name { font-family: var(--font-display); font-size: var(--step-lg); }
.genre-row__desc { color: var(--text-on-ink-dim); font-size: var(--step-sm); }
.genre-row__arrow { font-size: 1.4rem; color: var(--gold); transition: transform .4s var(--ease-out); }
.genre-row:hover .genre-row__arrow { transform: translateX(8px); }

@media (max-width: 760px) {
    .genre-row { grid-template-columns: auto 1fr auto; gap: 1rem 1.2rem; }
    .genre-row__cn { grid-row: span 2; }
    .genre-row__desc { grid-column: 2 / 4; }
}

/* ---------- 4. SPOTLIGHT ---------- */
.spotlight {
    --accent: var(--cinnabar);
    display: grid; grid-template-columns: 1.1fr 1fr; align-items: center; gap: clamp(2rem, 5vw, 5rem);
    width: var(--shell); margin: clamp(5rem, 14vh, 10rem) auto 0;
}
.spotlight__img { border-radius: var(--radius); overflow: hidden; position: relative; aspect-ratio: 4/3; }
.spotlight__img::after { content: ""; position: absolute; inset: 0; box-shadow: inset 0 0 120px -20px color-mix(in srgb, var(--accent) 70%, transparent); }
.spotlight__img img { width: 100%; height: 100%; object-fit: cover; }
.spotlight__title { font-size: var(--step-xl); margin: .6rem 0 .2rem; }
.spotlight__cn { font-family: var(--font-cn); color: var(--accent); font-size: var(--step-lg); }
.spotlight__quote { font-family: var(--font-display); font-style: italic; font-size: var(--step-lg); color: var(--gold-soft); margin: 1.4rem 0; line-height: 1.3; }
.spotlight__body { color: var(--text-on-ink-dim); margin-bottom: 2rem; }

@media (max-width: 820px) {
    .spotlight { grid-template-columns: 1fr; }
}
