/**
 * PlayFully Welcome/Splash Page Styles
 * Large screens (1650px and above)
 * View-specific overrides only
 */

@import "core/global_L.css";
@import "core/global_prelog_L.css";
@import "core/fonts.css";

/* ================================ */
/* Hero Section                     */
/* ================================ */

.sectionHero {
    height: auto;
}

/* ================================ */
/* Contrast Shield                  */
/* ================================ */

.divContrastShield {
    background: radial-gradient(
        ellipse 50% 75% at 50% 60%,
        rgba(0, 0, 0, 0.8) 0%,
        rgba(0, 0, 0, 0.7) 30%,
        rgba(0, 0, 0, 0.2) 60%,
        rgba(0, 0, 0, 0) 100%
    );
}

/* Cinematic vignette overlay */
.divContrastShield::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: radial-gradient(
        ellipse 80% 80% at 50% 50%,
        transparent 50%,
        rgba(0, 0, 0, 0.4) 100%
    );
    pointer-events: none;
}

/* ================================ */
/* Center Content Block             */
/* ================================ */

.mainHeroContent {
    padding: 0 60px;
}

/* Brand Mark */
.divHeroBrand {
    gap: 2px;
    margin-bottom: 30px;
}

/* Logo icon (large) */
.imgHeroPlayFullyLogoIcon {
    width: 160px;
    height: 160px;
    filter: drop-shadow(0 0 20px rgba(255, 131, 0, 0.5));
    animation: logoPulse 1.5s ease-in-out;
    animation-delay: 3.2s;
    animation-iteration-count: 1;
}

@keyframes logoPulse {
    0%, 100% {
        filter: drop-shadow(0 0 20px rgba(255, 131, 0, 0.4));
    }
    50% {
        filter: drop-shadow(0 0 55px rgba(255, 131, 0, 0.9));
    }
}

.canHover .divHeroBrand:hover .imgHeroPlayFullyLogoIcon {
    filter: drop-shadow(0 0 35px rgba(255, 131, 0, 0.9));
}

.spnHeroLogoText {
    font-size: 70px;
    text-shadow: 
        0 0 15px rgba(255, 131, 0, 0.5),
        0 0 30px rgba(255, 131, 0, 0.25);
    padding-bottom: 4px;
    transition: text-shadow 0.5s ease-in-out;
}

/* ================================ */
/* Headline                         */
/* ================================ */

.h1HeroHeadline {
    font-family: Rubik_SemiBold;
    font-size: 38px;
    line-height: 1.5;
    color: var(--c7);
    margin: 0 0 40px 0;
    max-width: 800px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    text-align: center;
    gap: 0 10px;
}

/* Each word in headline */
.spnHeadWord {
    display: inline-block;
    opacity: 0;
    transform: translateY(20px);
    animation: wordReveal 0.5s ease-out forwards;
}

/* Different font sizes for emphasis */
.spnHeadWordMedium {
    font-size: 24px;
    line-height: 1.3;
}
.spnHeadWordLight {
    font-size: 20px;
    line-height: 1.3;
}

/* Staggered delays for each word */
#spnHeadWord1 { animation-delay: 0.3s; }
#spnHeadWord2 { animation-delay: 0.45s; }
#spnHeadWord3 { animation-delay: 0.95s; }
#spnHeadWord4 { animation-delay: 1.45s; }
#spnHeadWord5 { animation-delay: 1.6s; }
#spnHeadWord6 { animation-delay: 1.75s; }

/* Line break after "Game" - centered layout */
#spnHeadWord3 {
    flex-basis: 100%;
}

/* Word reveal animation */
@keyframes wordReveal {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Flash/glow pulse on "Game" */
.spnHeadWordFlash {
    animation: 
        wordReveal 0.5s ease-out 0.45s forwards,
        powerUpFlash 0.6s ease-out 0.65s forwards;
}

@keyframes powerUpFlash {
    0% {
        color: var(--c7);
        text-shadow: none;
    }
    30% {
        color: var(--pf_orange);
        text-shadow: 
            0 0 20px rgba(255, 131, 0, 0.9),
            0 0 40px rgba(255, 131, 0, 0.6),
            0 0 60px rgba(255, 131, 0, 0.4);
    }
    100% {
        color: var(--c7);
        text-shadow: 
            0 0 8px rgba(255, 131, 0, 0.3),
            0 0 15px rgba(255, 131, 0, 0.15);
    }
}

/* Subheadline */
.pHeroSubheadline {
    font-family: Rubik_Regular;
    font-size: 18px;
    line-height: 1.6;
    color: var(--c7);
    max-width: 100%; width: 100%;
    text-align: left;
    animation: fadeInUp 0.8s ease-out 2.2s both;
}
#pHeroSubheadline2 {
    text-align: right;
}
.pHeroSubheadline:nth-of-type(2) {
    margin-bottom: 100px;
    animation: fadeInUp 0.8s ease-out 2.35s both;
}

/* ================================ */
/* CTA Buttons                      */
/* ================================ */

.divHeroCTA {
    display: flex;
    flex-direction: row;
    gap: 24px;
    justify-content: center;
    align-items: center;
    animation: fadeInUp 0.8s ease-out 0.6s both;
}

/* Primary CTA Button */
.btnHeroPrimary.custBtnCont {
    height: 56px;
    border-radius: 28px;
    background: var(--pf_orange);
    border: 2px solid var(--pf_orange);
    transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.btnHeroPrimary .custBtnA,
.btnHeroPrimary .custBtnSpn {
    display: flex;
    font-family: Rubik_Medium, sans-serif;
    height: 100%; min-height: 100%;
    padding: 0 42px;
    font-size: 17px;
    line-height: 56px;
    color: var(--c0) !important;
    text-decoration: none;
}

.canHover .btnHeroPrimary.custBtnCont:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 30px rgba(255, 131, 0, 0.45);
    background: var(--pf_orange);
    border-color: var(--pf_orange);
}

.btnHeroPrimary.custBtnCont:focus {
    outline: 2px solid var(--c7);
    outline-offset: 3px;
}

.btnHeroPrimary.custBtnCont:active {
    transform: translateY(0);
}

/* Secondary CTA Button */
.btnHeroSecondary.custBtnCont {
    height: 56px;
    border-radius: 28px;
    background: transparent;
    border: 2px solid var(--c4);
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}

.btnHeroSecondary .custBtnA,
.btnHeroSecondary .custBtnSpn {
    display: flex;
    justify-content: center;
    height: 100%; min-height: 100%;
    padding: 0 42px;
    font-family: Rubik_Medium, sans-serif;
    font-size: 17px;
    line-height: 56px;
    color: var(--c7);
    text-decoration: none;
}

.canHover .btnHeroSecondary.custBtnCont:hover {
    transform: translateY(-3px);
    border-color: var(--c7);
    background: rgba(255, 255, 255, 0.08);
    box-shadow: 0 10px 30px rgba(255, 255, 255, 0.12);
}

.btnHeroSecondary.custBtnCont:focus {
    outline: 2px solid var(--pf_orange);
    outline-offset: 3px;
}

.btnHeroSecondary.custBtnCont:active {
    transform: translateY(0);
}

/* ================================ */
/* Footer                           */
/* ================================ */

#footerHeroPillars {
    display: none;
}

/* ================================ */
/* Copyright Notice - Welcome       */
/* ================================ */

#divWelcomeCopyNoticeContainer {
    position: relative;
    display: block;
    z-index: 15;
    text-align: center;
    pointer-events: none;
}

.divWelcomeCopyNoticeLine {
    line-height: 1.5;
}

.spnWelcomeCopyNoticeText.tpgCaptionInfo {
    color: var(--c9);
}

/* ================================ */
/* Dialog Container                 */
/* ================================ */

.divWelcomeDialogsMasterContainer {
    display: none;
}

/* ================================ */
/* Pillars Section                  */
/* ================================ */

.sectionPillars {
    position: relative;
    width: 100%;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 60px 60px 140px 60px;
    box-sizing: border-box;
    z-index: 10;
}

.divPillarsContainer {
    display: flex;
    flex-direction: column;
    gap: 30px;
    max-width: 900px;
    width: 100%;
}

/* Individual Pillar Card */
.artPillar {
    display: grid;
    gap: 40px;
    align-items: center;
    padding: 2em 3em 2em 3em;
    background: rgba(0, 0, 0, 0.30);
    border-radius: 30px;
    box-shadow: 0 0 80px 40px rgba(255, 131, 0, 0.1);
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}
#artPillar1, #artPillar3 {
    grid-template-columns: 1fr 300px;
}
#artPillar2 {
    grid-template-columns: 300px 1fr;
}


/* Visible state (triggered by JS) */
.artPillar.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* Stagger delays */
.artPillar[data-pillar="1"].is-visible {
    transition-delay: 200ms;
}
.artPillar[data-pillar="2"].is-visible {
    transition-delay: 500ms;
}
.artPillar[data-pillar="3"].is-visible {
    transition-delay: 700ms;
}

/* Text-first layout (text left, visual right) */
.artPillar--textFirst {
    grid-template-areas: "text visual";
}
.artPillar--textFirst .divPillarText {
    grid-area: text;
}
.artPillar--textFirst .divPillarVisual {
    grid-area: visual;
}

/* Visual-first layout (visual left, text right) */
.artPillar--visualFirst {
    grid-template-areas: "visual text";
}
.artPillar--visualFirst .divPillarText {
    grid-area: text;
}
.artPillar--visualFirst .divPillarVisual {
    grid-area: visual;
}

/* Pillar Text Block */
.divPillarText {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* Pillar Title */
.h2PillarTitle {
    font-family: Rubik_SemiBold, sans-serif;
    font-size: 32px;
    line-height: 1.3;
    color: var(--c7);
    margin: 0;
}

.spnPillarTitleRegular {
    color: var(--c7);
}

.spnPillarTitleEmphasis {
    color: var(--pf_orange);
}

/* Pillar Primary Line */
.pPillarPrimary {
    font-family: Rubik_Regular, sans-serif;
    font-size: 18px;
    line-height: 1.6;
    color: var(--c7);
    margin: 0;
}

/* Pillar Secondary Line */
.pPillarSecondary {
    font-family: Rubik_Regular, sans-serif;
    font-size: 15px;
    line-height: 1.5;
    color: var(--c9);
    margin: 0;
}

/* Emphasis within pillar text */
.spnPillarEmphasis {
    color: var(--pf_orange);
}

/* Pillar Visual Block */
.divPillarVisual {
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
}

.imgPillarPlaceholder {
    width: 100%;
    max-width: 200px;
    height: auto;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-radius: 16px;
}

/* ================================ */
/* Pillars CTA Buttons              */
/* ================================ */

.divPillarsCTA {
    display: flex;
    flex-direction: row;
    gap: 20px;
    justify-content: center;
    align-items: center;
    margin-top: 50px;
}

/* Primary CTA Button (reusing hero styles) */
.btnPillarsPrimary.custBtnCont {
    height: 56px;
    border-radius: 28px;
    background: var(--pf_orange);
    border: 2px solid var(--pf_orange);
    transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.btnPillarsPrimary .custBtnA,
.btnPillarsPrimary .custBtnSpn {
    display: flex;
    font-family: Rubik_Medium, sans-serif;
    height: 100%; min-height: 100%;
    padding: 0 40px;
    font-size: 17px;
    line-height: 56px;
    color: var(--c0) !important;
    text-decoration: none;
}

.canHover .btnPillarsPrimary.custBtnCont:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(255, 131, 0, 0.4);
    background: var(--pf_orange);
    border-color: var(--pf_orange);
}

.btnPillarsPrimary.custBtnCont:focus {
    outline: 2px solid var(--c7);
    outline-offset: 3px;
}

.btnPillarsPrimary.custBtnCont:active {
    transform: translateY(0);
}

/* Secondary CTA Button (reusing hero styles) */
.btnPillarsSecondary.custBtnCont {
    height: 56px;
    border-radius: 28px;
    background: transparent;
    border: 2px solid var(--c4);
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}

.btnPillarsSecondary .custBtnA,
.btnPillarsSecondary .custBtnSpn {
    display: flex;
    justify-content: center;
    height: 100%; min-height: 100%;
    padding: 0 40px;
    font-family: Rubik_Medium, sans-serif;
    font-size: 17px;
    line-height: 56px;
    color: var(--c7);
    text-decoration: none;
}

.canHover .btnPillarsSecondary.custBtnCont:hover {
    transform: translateY(-2px);
    border-color: var(--c7);
    background: rgba(255, 255, 255, 0.08);
    box-shadow: 0 8px 24px rgba(255, 255, 255, 0.1);
}

.btnPillarsSecondary.custBtnCont:focus {
    outline: 2px solid var(--pf_orange);
    outline-offset: 3px;
}

.btnPillarsSecondary.custBtnCont:active {
    transform: translateY(0);
}

/* ================================ */
/* Reduced Motion Support           */
/* ================================ */

@media (prefers-reduced-motion: reduce) {
    /* Particles handled by JS - static particles created instead */
    
    .btnHeroPrimary.custBtnCont,
    .btnHeroSecondary.custBtnCont,
    .btnPillarsPrimary.custBtnCont,
    .btnPillarsSecondary.custBtnCont {
        transition: none;
    }
    
    .canHover .btnHeroPrimary.custBtnCont:hover,
    .canHover .btnHeroSecondary.custBtnCont:hover,
    .canHover .btnPillarsPrimary.custBtnCont:hover,
    .canHover .btnPillarsSecondary.custBtnCont:hover {
        transform: none;
    }
    
    /* Pillars - instant visibility, no animation */
    .artPillar {
        opacity: 1;
        transform: none;
        transition: none;
    }
}

/* Body class for reduced motion (JS fallback) */
body.reduced-motion .btnHeroPrimary.custBtnCont,
body.reduced-motion .btnHeroSecondary.custBtnCont,
body.reduced-motion .btnPillarsPrimary.custBtnCont,
body.reduced-motion .btnPillarsSecondary.custBtnCont {
    transition: none;
}

body.reduced-motion .canHover .btnHeroPrimary.custBtnCont:hover,
body.reduced-motion .canHover .btnHeroSecondary.custBtnCont:hover,
body.reduced-motion .canHover .btnPillarsPrimary.custBtnCont:hover,
body.reduced-motion .canHover .btnPillarsSecondary.custBtnCont:hover {
    transform: none;
}

body.reduced-motion .artPillar {
    opacity: 1;
    transform: none;
    transition: none;
}
