/* ============================================
   AGIRAPOP! — Site Público
   Identidade: Vinho/Bordô + Bronze + Azul-Marinho
   ============================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
img,svg{display:block;max-width:100%}
button{background:none;border:none;cursor:pointer;font:inherit;color:inherit}
a{color:inherit;text-decoration:none}
ul{list-style:none}

:root{
    --black:#0B0B0B;
    --black-soft:#1A1A1A;
    --black-deep:#050505;
    --red:#6B0F1A;
    --red-bright:#8B1825;
    --red-deep:#4A0810;
    --logo-red:#E63946;
    --bronze:#A07840;
    --bronze-bright:#C49560;
    --bronze-deep:#6B4F26;
    --navy:#1E2C4F;
    --navy-bright:#2A3D6B;
    --navy-deep:#0F1729;
    --cream:#F5F2EC;
    --cream-warm:#FAF6EC;
    --cream-soft:#E8E5DD;
    --gray-300:#C7C2B6;
    --gray-500:#7C7870;
    --gray-700:#3A3834;

    --font-display:'Bebas Neue',Impact,sans-serif;
    --font-pop:'Bangers',cursive;
    --font-noble:'Cinzel',serif;
    --font-body:'Inter',-apple-system,sans-serif;

    --container:1320px;
    --header-h:92px;
    --easing:cubic-bezier(0.65,0,0.35,1);
    --easing-out:cubic-bezier(0.16,1,0.3,1);
    --easing-bounce:cubic-bezier(0.68,-0.55,0.265,1.55);
}

body{
    font-family:var(--font-body);
    background:var(--cream-warm);
    color:var(--black);
    overflow-x:hidden;
    line-height:1.5;
    -webkit-font-smoothing:antialiased;
}

/* ====== SCROLL PROGRESS ====== */
.scroll-progress{
    position:fixed;top:0;left:0;height:4px;
    background:linear-gradient(90deg,var(--red),var(--bronze-bright),var(--red));
    z-index:9999;transition:width .15s ease;
    box-shadow:0 0 10px rgba(107,15,26,.6);
}

/* ====== INTRO LOADER ====== */
.intro{
    position:fixed;inset:0;background:var(--black);z-index:9999;
    display:flex;align-items:center;justify-content:center;
    transition:opacity .8s var(--easing);
}
.intro.exit{opacity:0;pointer-events:none}
.intro-logo{animation:logoIntro 1.4s var(--easing-bounce)}
@keyframes logoIntro{
    0%{opacity:0;transform:scale(0.5) rotate(-10deg)}
    60%{transform:scale(1.1) rotate(3deg)}
    100%{opacity:1;transform:scale(1) rotate(0)}
}
.intro-logo svg{width:340px;height:auto}

/* ====== HEADER ====== */
.header{
    position:fixed;top:0;left:0;right:0;height:var(--header-h);z-index:100;
    background:var(--black);border-bottom:3px solid var(--red);
    transform:translateY(-100%);transition:.6s var(--easing) .6s;
}
.header.visible{transform:translateY(0)}
.header-container{
    max-width:var(--container);margin:0 auto;height:100%;padding:0 1.5rem;
    display:flex;align-items:center;justify-content:space-between;gap:2rem;
}
.brand{display:flex;align-items:center;gap:.6rem}
.brand-logo{height:64px;width:auto}
.nav{display:flex;gap:.4rem;flex:1;justify-content:center}
.nav a{
    font-family:var(--font-display);font-size:1.1rem;color:var(--cream);
    padding:.6rem 1rem;letter-spacing:.06em;transition:.25s;border-radius:6px;position:relative;
}
.nav a:hover{color:var(--bronze-bright);background:rgba(196,149,96,.1)}
.nav a.active{color:var(--bronze-bright)}
.nav a.active::after{
    content:'';position:absolute;bottom:-4px;left:50%;transform:translateX(-50%);
    width:24px;height:3px;background:var(--red);border-radius:2px;
}
.header-right{display:flex;align-items:center;gap:.8rem}
.cart-btn{
    display:flex;align-items:center;gap:.5rem;padding:.7rem 1.3rem;
    background:var(--red);color:var(--cream);border-radius:100px;
    font-family:var(--font-display);font-size:1rem;letter-spacing:.08em;
    transition:.25s var(--easing);border:2px solid var(--red);
}
.cart-btn:hover{
    background:var(--bronze);color:var(--cream);border-color:var(--bronze-bright);
    transform:translateY(-2px) scale(1.03);
}

/* ====== HERO ====== */
.hero{
    position:relative;padding:calc(var(--header-h) + 2rem) 1.5rem 0;
    background:var(--black);color:var(--cream);overflow:hidden;
}
.hero::before{
    content:'';position:absolute;inset:0;
    background-image:radial-gradient(circle,rgba(160,120,64,.07) 2px,transparent 2px);
    background-size:24px 24px;
}
.hero::after{
    content:'';position:absolute;top:-20%;right:-10%;width:60%;height:80%;
    background:radial-gradient(circle,rgba(30,44,79,.4) 0%,transparent 60%);
    pointer-events:none;
}
.hero-container{
    max-width:var(--container);margin:0 auto;
    display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;
    min-height:calc(100vh - var(--header-h));padding:3rem 0 5rem;
    position:relative;z-index:2;
}
.hero-text{position:relative}
.hero-flag{
    display:inline-flex;align-items:center;gap:.6rem;
    background:var(--navy);color:var(--cream);padding:.5rem 1.2rem;
    border-radius:100px;font-family:var(--font-display);font-size:.95rem;
    letter-spacing:.1em;margin-bottom:1.5rem;
    border:2px solid var(--bronze);box-shadow:4px 4px 0 var(--red);
    transform:rotate(-2deg);
    opacity:0;animation:popIn .6s var(--easing-bounce) 1.4s forwards;
}
@keyframes popIn{
    from{opacity:0;transform:rotate(-2deg) scale(0.8)}
    to{opacity:1;transform:rotate(-2deg) scale(1)}
}
.hero-flag::before{
    content:'';width:8px;height:8px;background:var(--bronze-bright);
    border:1px solid var(--cream);border-radius:50%;
}
.hero-title{
    font-family:var(--font-display);font-size:clamp(3.5rem,8vw,7rem);
    line-height:.85;letter-spacing:.005em;margin-bottom:1.2rem;color:var(--cream);
    text-shadow:6px 6px 0 var(--red),12px 12px 0 var(--bronze);
}
.hero-title span{
    display:block;opacity:0;transform:translateY(40px);
    animation:slideUp .8s var(--easing-out) forwards;
}
.hero-title span:nth-child(1){animation-delay:1.6s}
.hero-title span:nth-child(2){animation-delay:1.75s;color:var(--bronze-bright);text-shadow:6px 6px 0 var(--red),12px 12px 0 var(--cream)}
.hero-title span:nth-child(3){animation-delay:1.9s}
@keyframes slideUp{to{opacity:1;transform:translateY(0)}}
.hero-desc{
    font-size:1.1rem;line-height:1.6;color:var(--gray-300);
    max-width:480px;margin:1.5rem 0 2rem;
    opacity:0;animation:fadeIn 1s 2.2s forwards;
}
@keyframes fadeIn{to{opacity:1}}
.hero-desc strong{color:var(--bronze-bright)}
.hero-cta{
    display:flex;gap:1rem;align-items:center;flex-wrap:wrap;
    opacity:0;animation:fadeIn 1s 2.5s forwards;
}

.btn-pop{
    display:inline-flex;align-items:center;gap:.7rem;
    padding:1.1rem 2rem;background:var(--red);color:var(--cream);border-radius:100px;
    font-family:var(--font-display);font-size:1.2rem;letter-spacing:.08em;
    border:3px solid var(--black);box-shadow:5px 5px 0 var(--bronze);
    transition:.2s var(--easing);cursor:pointer;
}
.hero .btn-pop{box-shadow:5px 5px 0 var(--bronze),5px 5px 0 1px var(--cream)}
.btn-pop:hover{transform:translate(-2px,-2px);box-shadow:7px 7px 0 var(--bronze)}
.hero .btn-pop:hover{box-shadow:7px 7px 0 var(--bronze),7px 7px 0 1px var(--cream)}
.btn-pop:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--bronze)}
.btn-pop svg{width:18px;height:14px}

.btn-link{
    color:var(--bronze-bright);font-family:var(--font-display);font-size:1rem;
    letter-spacing:.05em;border-bottom:2px solid var(--bronze-bright);padding:.4rem 0;transition:.2s;
}
.btn-link:hover{color:var(--cream);border-color:var(--cream)}

.hero-stats{
    display:flex;gap:2rem;margin-top:3rem;
    opacity:0;animation:fadeIn 1s 2.8s forwards;
}
.hero-stat{flex:1}
.hero-stat-num{font-family:var(--font-display);font-size:2.2rem;line-height:1;color:var(--bronze-bright)}
.hero-stat-label{
    font-size:.7rem;color:var(--gray-500);text-transform:uppercase;
    letter-spacing:.1em;font-weight:600;margin-top:.3rem;
}

/* ====== CAIXA FUNKO HERO ====== */
.hero-box-wrap{
    position:relative;display:flex;align-items:center;justify-content:center;
    opacity:0;transform:translateY(40px);
    animation:boxIn 1.2s var(--easing-out) 1.6s forwards;
}
@keyframes boxIn{to{opacity:1;transform:translateY(0)}}

.funko-box{
    position:relative;width:340px;height:480px;
    background:var(--black);border:4px solid var(--cream);border-radius:6px;
    box-shadow:14px 14px 0 var(--red),28px 28px 0 var(--bronze);
    transform:rotate(-3deg);transition:.4s var(--easing);cursor:pointer;
}
.funko-box:hover{transform:rotate(-3deg) scale(1.03) translateY(-6px)}
.funko-box::before{
    content:'';position:absolute;inset:8px;
    background-image:radial-gradient(circle,rgba(160,120,64,.12) 1.5px,transparent 1.5px);
    background-size:14px 14px;pointer-events:none;
}
.funko-box-top{
    position:absolute;top:14px;left:14px;right:14px;
    display:flex;align-items:center;justify-content:space-between;z-index:3;
}
.funko-box-logo{
    background:var(--cream);color:var(--logo-red);
    font-family:var(--font-display);font-size:1.3rem;padding:.3rem .8rem;
    border:2px solid var(--black);border-radius:4px;letter-spacing:.05em;
    box-shadow:3px 3px 0 var(--black);transform:rotate(-3deg);line-height:1;
}
.funko-box-num{
    background:var(--bronze);color:var(--cream);
    font-family:var(--font-display);font-size:.95rem;padding:.4rem .7rem;
    border:2px solid var(--black);border-radius:4px;line-height:1;box-shadow:3px 3px 0 var(--black);
}
.funko-box-window{
    position:absolute;top:78px;left:24px;right:24px;bottom:130px;
    background:radial-gradient(circle at 50% 65%,#3a3a3a 0%,#0f0f0f 80%);
    border:3px solid var(--bronze);border-radius:4px;overflow:hidden;
    box-shadow:inset 0 0 30px rgba(0,0,0,.8);z-index:2;
}
.funko-box-window::before{
    content:'';position:absolute;top:0;left:0;width:60%;height:35%;
    background:linear-gradient(135deg,rgba(255,255,255,.15) 0%,transparent 80%);pointer-events:none;
}
.funko-box-window::after{
    content:'';position:absolute;inset:0;
    background-image:radial-gradient(circle,rgba(160,120,64,.06) 1px,transparent 1px);
    background-size:10px 10px;pointer-events:none;
}
.funko-character{
    position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
    font-size:11rem;line-height:1;
    filter:drop-shadow(0 12px 24px rgba(0,0,0,.6));transition:.4s var(--easing);
}
.funko-box:hover .funko-character{transform:scale(1.05)}

.funko-box-stamp{
    position:absolute;top:90px;right:-22px;
    background:var(--red);color:var(--cream);
    font-family:var(--font-display);font-size:.75rem;padding:.4rem .9rem;
    border:2px solid var(--cream);border-radius:4px;transform:rotate(8deg);
    box-shadow:2px 2px 0 var(--black);letter-spacing:.05em;z-index:4;line-height:1;
}
.funko-box-name{
    position:absolute;bottom:50px;left:24px;right:24px;text-align:center;z-index:3;
}
.funko-box-name-tag{
    display:inline-block;font-family:var(--font-body);font-size:.6rem;
    color:var(--bronze-bright);letter-spacing:.18em;text-transform:uppercase;
    font-weight:700;margin-bottom:.4rem;
}
.funko-box-name h3{
    font-family:var(--font-display);font-size:2rem;line-height:.85;
    color:var(--cream);letter-spacing:.02em;text-shadow:3px 3px 0 var(--red);
}
.funko-box-name h3 small{
    display:block;font-size:.85rem;color:var(--bronze-bright);
    margin-top:.3rem;text-shadow:2px 2px 0 var(--black);
}
.placa-agira{
    position:absolute;bottom:14px;left:14px;right:14px;
    background:linear-gradient(180deg,var(--navy-bright) 0%,var(--navy) 50%,var(--navy-deep) 100%);
    border:2px solid var(--bronze);border-radius:4px;padding:.5rem .6rem;
    text-align:center;z-index:3;box-shadow:inset 0 0 8px rgba(0,0,0,.5),0 2px 0 rgba(0,0,0,.3);
}
.placa-agira-title{
    font-family:var(--font-noble);font-size:.85rem;color:var(--cream);
    font-weight:900;letter-spacing:.15em;line-height:1;
    text-shadow:1px 1px 2px rgba(0,0,0,.8);
}
.placa-agira-sub{
    display:block;font-family:var(--font-body);font-size:.55rem;
    color:var(--bronze-bright);letter-spacing:.15em;text-transform:uppercase;
    margin-top:.2rem;font-weight:600;
}

/* ====== TAGLINE BAR ====== */
.tagline-bar{
    background:var(--red);color:var(--cream);padding:1.4rem 0;overflow:hidden;
    border-top:4px solid var(--black);border-bottom:4px solid var(--black);
    position:relative;z-index:5;
}
.tagline-track{
    display:flex;gap:3rem;white-space:nowrap;
    animation:scroll-x 35s linear infinite;
    font-family:var(--font-display);font-size:1.6rem;letter-spacing:.05em;
}
.tagline-item{display:flex;align-items:center;gap:3rem}
.tagline-item::after{content:'★';color:var(--bronze-bright);font-size:1.2rem}
.tagline-item strong{color:var(--bronze-bright)}
@keyframes scroll-x{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ====== SEÇÕES BASE ====== */
.section{padding:6rem 1.5rem;position:relative}
.section-cream{background:var(--cream-warm)}
.section-dark{background:var(--black);color:var(--cream);position:relative}
.section-dark::before{
    content:'';position:absolute;inset:0;
    background-image:radial-gradient(circle,rgba(160,120,64,.06) 2px,transparent 2px);
    background-size:30px 30px;pointer-events:none;
}
.section-navy{
    background:linear-gradient(180deg,var(--navy-deep) 0%,var(--navy) 50%,var(--navy-deep) 100%);
    color:var(--cream);position:relative;
}
.section-navy::before{
    content:'';position:absolute;inset:0;
    background-image:radial-gradient(circle,rgba(196,149,96,.08) 2px,transparent 2px);
    background-size:30px 30px;pointer-events:none;
}
.section-container{max-width:var(--container);margin:0 auto;position:relative;z-index:2}

.section-head{margin-bottom:4rem;text-align:center;position:relative}
.section-head-tag{
    display:inline-block;background:var(--bronze);color:var(--cream);
    font-family:var(--font-display);font-size:.95rem;padding:.4rem 1.2rem;
    border:3px solid var(--black);border-radius:100px;box-shadow:3px 3px 0 var(--black);
    margin-bottom:1.2rem;letter-spacing:.08em;transform:rotate(-2deg);
}
.section-dark .section-head-tag,.section-navy .section-head-tag{
    background:var(--red);color:var(--cream);border-color:var(--cream);
    box-shadow:3px 3px 0 var(--bronze);
}
.section-title{
    font-family:var(--font-display);font-size:clamp(3rem,6vw,5.5rem);
    line-height:.9;color:var(--black);letter-spacing:.01em;
    text-shadow:5px 5px 0 var(--red);
}
.section-dark .section-title,.section-navy .section-title{
    color:var(--cream);text-shadow:5px 5px 0 var(--red),10px 10px 0 var(--bronze);
}
.section-title em{font-style:normal;color:var(--red);text-shadow:5px 5px 0 var(--bronze)}
.section-dark .section-title em,.section-navy .section-title em{
    color:var(--bronze-bright);text-shadow:5px 5px 0 var(--red);
}
.section-sub{
    font-size:1.05rem;color:var(--gray-500);margin-top:1.2rem;
    max-width:560px;margin-left:auto;margin-right:auto;
}
.section-dark .section-sub,.section-navy .section-sub{color:var(--gray-300)}
