.gg-button{min-height:42px;display:inline-flex;align-items:center;justify-content:center;padding:0 18px;border:1px solid var(--gg-border-strong);border-radius:999px;background:var(--gg-surface);color:var(--gg-text);font-weight:700}
.gg-button--primary{background:var(--gg-accent);border-color:var(--gg-accent);color:var(--gg-on-accent)}
.gg-small-btn{height:32px;padding:0 12px;border:1px solid var(--gg-border);border-radius:999px;background:var(--gg-surface);color:var(--gg-muted)}
.gg-hero{position:relative;overflow:hidden;border-radius:calc(var(--gg-radius) + 10px);background:var(--gg-player);box-shadow:var(--gg-runtime-shadow)}
.gg-hero__track{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none}
.gg-hero__track::-webkit-scrollbar{display:none}
.gg-hero__slide{position:relative;min-width:100%;height:430px;scroll-snap-align:start;overflow:hidden}
.gg-hero__media,.gg-hero__media img{position:absolute;inset:0;width:100%;height:100%}
.gg-hero__media img{object-fit:cover;filter:saturate(.96)}
.gg-hero__slide:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.74),rgba(0,0,0,.22) 55%,rgba(0,0,0,.08))}
.gg-hero__content{position:relative;z-index:1;max-width:560px;height:100%;display:flex;flex-direction:column;justify-content:center;padding:42px;color:#fff}
.gg-hero__eyebrow,.gg-page-hero__eyebrow,.gg-detail__eyebrow,.gg-player__eyebrow{margin:0 0 8px;color:var(--gg-accent);font-weight:800}
.gg-hero__eyebrow{color:#fff}
.gg-hero h1{margin:0;font-size:42px;line-height:1.1}
.gg-hero__meta{display:flex;flex-wrap:wrap;gap:10px;margin:14px 0;color:rgba(255,255,255,.82)}
.gg-hero__meta span{padding:2px 9px;border:1px solid rgba(255,255,255,.22);border-radius:999px;background:rgba(255,255,255,.1)}
.gg-hero__desc{max-height:54px;margin:0 0 22px;overflow:hidden;color:rgba(255,255,255,.78)}
.gg-hero__actions{display:flex;gap:10px}
.gg-hero__dots{position:absolute;left:42px;bottom:24px;z-index:3;display:flex;gap:8px}
.gg-hero__dots button{width:8px;height:8px;padding:0;border:0;border-radius:50%;background:rgba(255,255,255,.42)}
.gg-hero__dots button.is-active{width:22px;border-radius:999px;background:#fff}
.gg-notice{height:46px;margin-top:18px;display:flex;align-items:center;gap:12px;padding:0 16px;border:1px solid var(--gg-border);border-radius:var(--gg-radius);background:var(--gg-surface);overflow:hidden}
.gg-notice__label{font-weight:800;color:var(--gg-accent);white-space:nowrap}
.gg-notice__marquee{min-width:0;overflow:hidden;white-space:nowrap;color:var(--gg-muted)}
.gg-notice__marquee span{display:inline-block;animation:gg-marquee 20s linear infinite}
@keyframes gg-marquee{from{transform:translateX(40%)}to{transform:translateX(-100%)}}
.gg-section{margin-top:30px}
.gg-section-head{display:flex;align-items:end;justify-content:space-between;gap:18px;margin-bottom:16px}
.gg-section-head__title{margin:0;font-size:24px;line-height:1.25}
.gg-section-head__desc{margin:5px 0 0;color:var(--gg-muted)}
.gg-section-head__more{color:var(--gg-accent);font-weight:700;white-space:nowrap}
.gg-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:18px}
.gg-card{min-width:0}
.gg-card__poster{position:relative;display:block;aspect-ratio:2/3;border-radius:var(--gg-radius);overflow:hidden;background:var(--gg-surface-2);border:1px solid var(--gg-border)}
.gg-card__poster img{width:100%;height:100%;object-fit:cover;transition:transform .25s ease}
.gg-card:hover .gg-card__poster img{transform:scale(1.04)}
.gg-card__badge{position:absolute;right:8px;top:8px;max-width:calc(100% - 16px);padding:3px 8px;border-radius:999px;background:rgba(0,0,0,.58);color:#fff;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gg-card__play{position:absolute;left:10px;bottom:10px;width:32px;height:32px;border-radius:50%;background:rgba(0,0,0,.52)}
.gg-card__play:after{content:"";position:absolute;left:13px;top:9px;border-left:10px solid #fff;border-top:7px solid transparent;border-bottom:7px solid transparent}
.gg-card__title{margin:9px 0 2px;font-size:15px;line-height:1.35;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gg-card__meta{display:flex;gap:7px;margin:0;color:var(--gg-muted);font-size:13px;overflow:hidden;white-space:nowrap}
.gg-page{display:flex;justify-content:center;flex-wrap:wrap;gap:8px;margin-top:28px}
.gg-page__item{min-width:38px;height:38px;display:grid;place-items:center;padding:0 12px;border:1px solid var(--gg-border);border-radius:999px;background:var(--gg-surface);color:var(--gg-muted)}
.gg-page__item.is-active{background:var(--gg-accent);border-color:var(--gg-accent);color:var(--gg-on-accent)}
.gg-ad{margin-top:24px;border-radius:var(--gg-radius);overflow:hidden;background:var(--gg-surface);border:1px solid var(--gg-border)}
.gg-popup[hidden]{display:none}
.gg-popup{position:fixed;inset:0;z-index:90;display:grid;place-items:center;padding:20px}
.gg-popup__mask{position:absolute;inset:0;background:rgba(0,0,0,.48)}
.gg-popup__panel{position:relative;width:min(480px,100%);overflow:hidden;border-radius:calc(var(--gg-radius) + 8px);background:var(--gg-surface);border:1px solid var(--gg-border);box-shadow:0 24px 70px rgba(0,0,0,.28)}
.gg-popup__close{position:absolute;right:12px;top:12px;z-index:1;width:34px;height:34px;border:0;border-radius:50%;background:rgba(0,0,0,.46);color:#fff;font-size:22px;line-height:1}
.gg-popup__image{display:block;width:100%;max-height:260px;object-fit:cover;background:var(--gg-surface-2)}
.gg-popup__body{padding:20px}
.gg-popup__body h2{margin:0 0 8px;font-size:22px}
.gg-popup__body p{margin:0;color:var(--gg-muted);line-height:1.75}
@media (max-width:1080px){.gg-grid{grid-template-columns:repeat(5,minmax(0,1fr))}}
@media (max-width:860px){.gg-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.gg-hero__slide{height:360px}.gg-hero h1{font-size:34px}}
@media (max-width:620px){
    .gg-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
    .gg-hero{width:auto;margin:0;border-radius:calc(var(--gg-radius) + 4px);box-shadow:var(--gg-runtime-shadow)}
    .gg-hero__slide{height:320px;min-height:0}
    .gg-hero__slide:after{background:linear-gradient(180deg,rgba(0,0,0,.08),rgba(0,0,0,.3) 40%,rgba(0,0,0,.86) 100%)}
    .gg-hero__media img{object-fit:cover}
    .gg-hero__content{justify-content:flex-end;padding:0 16px 52px}
    .gg-hero__eyebrow{display:none}
    .gg-hero h1{font-size:26px;text-shadow:0 2px 14px rgba(0,0,0,.35)}
    .gg-hero__meta{gap:6px;margin:9px 0}
    .gg-hero__meta span{padding:3px 8px;border:0;background:rgba(0,0,0,.58);font-weight:800;color:#fff;font-size:12px}
    .gg-hero__desc{display:-webkit-box;max-height:42px;margin-bottom:12px;-webkit-line-clamp:2;-webkit-box-orient:vertical;color:rgba(255,255,255,.78);font-size:13px;line-height:1.6}
    .gg-hero__actions .gg-button{min-width:108px;min-height:42px;height:42px;padding:0 14px;border:0;background:rgba(255,255,255,.92);color:#08080d}
    .gg-hero__actions .gg-button+.gg-button{background:rgba(0,0,0,.62);color:#fff}
    .gg-hero__dots{left:16px;bottom:18px}
    .gg-section-head__title{font-size:21px}
}
@media (max-width:390px){.gg-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.gg-hero__slide{height:290px}.gg-hero h1{font-size:24px}}
