:root{
  --bg:#0b0b0b;
  --card:#111;
  --muted:#9a9a9a;
  --accent:#e50914;
  --glass: rgba(255,255,255,0.04);
  --radius:10px;
  --header-height:72px;
  font-size:16px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: 'Montserrat', system-ui, sans-serif;
  background: linear-gradient(180deg,#050505 0%, #0f0f12 100%);
  color:#fff;
  padding-top:var(--header-height);
}
.site-header{display:flex;justify-content:space-between;align-items:center;padding:18px 40px;position:fixed;width:100%;z-index:40;top:0;left:0;background:linear-gradient(180deg,rgba(0,0,0,0.6),transparent);backdrop-filter: blur(4px)}
.logo{font-weight:700;color:var(--accent);font-size:20px}
.nav{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.search{padding:8px 12px;border-radius:6px;border:none;background:var(--glass);color:#fff;min-width:200px}

/* Estiliza especificamente selects com a classe .search para melhorar contraste */
select.search{
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.02));
  border:1px solid rgba(255,255,255,0.04);
  color: #fff;
  padding-right:34px; /* espaço para o ícone de seta */
  min-width:200px;
}
select.search:focus{outline:2px solid rgba(229,9,20,0.12);outline-offset:2px}
select.search option{background:#0d0d0d;color:#fff}
/* esconder seta nativa no IE/Edge older */
select.search::-ms-expand{display:none}
.profile{padding:6px 10px;background:transparent;color:var(--muted)}

/* Hamburger button (mobile) */
.hamburger{display:none;background:transparent;border:1px solid rgba(255,255,255,0.06);color:#fff;padding:8px 10px;border-radius:8px;font-size:20px;cursor:pointer}
.hamburger:active{transform:scale(.98)}

/* Mobile nav: hidden by default on small screens, shown when body.mobile-open */
@media (max-width:800px){
  .nav{display:none}
  .hamburger{display:inline-flex}
  body.mobile-open .nav{display:flex;position:fixed;left:0;right:0;top:var(--header-height);background:linear-gradient(180deg,rgba(10,10,10,0.98),#070707);padding:16px;flex-direction:column;gap:12px;z-index:50}
  body.mobile-open .nav .search{width:100%}
}

.hero{height:56vh;min-height:320px;position:relative;display:flex;align-items:flex-end;padding:clamp(20px,4vw,56px) clamp(16px,3.5vw,60px) 40px;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:blur(6px) brightness(0.5);transform:scale(1.05);transition:transform .8s ease}
.hero-content{position:relative;z-index:5;max-width:720px}
.title{font-size:clamp(22px,4vw,40px);margin:0 0 12px}
.hero-content p{color:var(--muted);margin:0 0 18px}
.hero-actions .btn{padding:12px 18px;border-radius:6px;border:none;margin-right:10px;font-weight:600;cursor:pointer}
.btn.play{background:var(--accent);color:#fff}
.btn.info{background:transparent;border:1px solid rgba(255,255,255,0.12);color:#fff}

.row{padding:26px 56px}
.row h2{margin:0 0 12px;font-size:20px}
.carousel{display:flex;gap:12px;overflow-x:auto;padding-bottom:6px;scroll-snap-type:x mandatory}
.carousel::-webkit-scrollbar{height:10px}
.carousel::-webkit-scrollbar-thumb{background:#222;border-radius:10px}
.card{width:clamp(140px,18vw,200px);flex:0 0 auto;background:var(--card);border-radius:8px;overflow:hidden;scroll-snap-align:start;cursor:pointer;transform:translateZ(0);transition:transform .18s cubic-bezier(.2,.9,.2,1), box-shadow .25s ease;position:relative}
.card img{width:100%;height:110px;object-fit:cover;display:block}
.card .meta{padding:10px}
.card .title{font-size:14px;margin:0 0 6px}
.card .sub{color:var(--muted);font-size:13px}
.card:hover{transform:translateY(-8px) scale(1.03);box-shadow:0 10px 30px rgba(0,0,0,0.6)}

/* 3D tilt support */
.carousel{perspective:1200px}
.card{transform-style:preserve-3d;will-change:transform}

/* carousel controls */
.carousel-wrap{position:relative}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,0.6);border:1px solid rgba(255,255,255,0.06);color:#fff;padding:8px 12px;border-radius:8px;cursor:pointer;z-index:10}
.carousel-btn.left{left:6px}
.carousel-btn.right{right:6px}
.carousel-btn:active{transform:translateY(-50%) scale(.98)}

.grid-section{padding:26px 56px}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}

.modal{position:fixed;inset:0;background:rgba(0,0,0,0.6);display:none;align-items:center;justify-content:center;z-index:60}
.modal[aria-hidden="false"]{display:flex}
.modal-panel{background:linear-gradient(180deg,#0d0d0d,#070707);border-radius:12px;padding:20px;max-width:900px;width:94%;box-shadow:0 30px 80px rgba(0,0,0,0.7);position:relative}
.modal-panel .close{position:absolute;right:12px;top:10px;background:rgba(255,255,255,0.03);border:none;color:#fff;font-size:20px;width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;cursor:pointer;transition:transform .12s ease, background .12s ease, box-shadow .12s ease;box-shadow:0 6px 18px rgba(0,0,0,0.45);backdrop-filter:blur(6px)}
.modal-panel .close:hover{transform:scale(1.04);background:rgba(255,255,255,0.06)}
.modal-panel .close:focus{outline:2px solid rgba(229,9,20,0.25);outline-offset:2px;box-shadow:0 8px 22px rgba(229,9,20,0.01)}
.modal-panel.fullscreen .close{right:18px;top:12px;background:rgba(0,0,0,0.01);width:44px;height:44px}
.modal-body{display:flex;gap:18px}
.modal-body img{width:320px;height:180px;object-fit:cover;border-radius:8px}
.modal-body .info{flex:1}
.modal-body .info h3{margin:0 0 8px}
.modal-body .info p{color:var(--muted)}

/* confirmation UI inside modal when user attempts to close */
.modal-close-confirm{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:linear-gradient(180deg,#0d0d0d,#090909);padding:16px;border-radius:10px;border:1px solid rgba(255,255,255,0.06);z-index:80;min-width:260px;box-shadow:0 12px 40px rgba(0,0,0,0.6)}
.modal-close-confirm p{margin:0 0 12px;color:var(--muted);text-align:center}
.modal-close-confirm .confirm-actions{display:flex;gap:10px;justify-content:center}
.modal-close-confirm .btn{padding:8px 12px;border-radius:8px;border:none;cursor:pointer}
.modal-close-confirm .btn.secondary{background:transparent;border:1px solid rgba(255,255,255,0.06);color:#fff}
.modal-close-confirm .btn.primary{background:var(--accent);color:#fff}

/* play button overlay on cards */
.card-play{position:absolute;right:8px;top:8px;background:rgba(0,0,0,0.55);border:none;color:#fff;padding:8px 10px;border-radius:8px;cursor:pointer;font-size:14px;z-index:20}

/* Fullscreen iframe modal */
.modal-panel.fullscreen{width:100%;max-width:100%;height:100%;border-radius:0;padding:0;box-shadow:none}
.modal-panel.fullscreen .close{right:12px;top:8px;background:rgba(0,0,0,0.45);padding:6px;border-radius:6px}
.modal-iframe{width:100%;height:100%;border:0;display:block}
.modal-iframe-container{width:100%;height:100%;display:block;padding:0}

/* entrance animation */
.modal-panel.fullscreen{transform:translateY(6vh) scale(.98);opacity:0;transition:transform .5s cubic-bezier(.2,.9,.25,1), opacity .3s ease}
.modal-panel.fullscreen.open{transform:translateY(0) scale(1);opacity:1}

/* lock scroll and subtle dim when modal open */
body.modal-open{overflow:hidden}

/* iframe spinner */
.iframe-spinner{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:30}
.iframe-spinner .spinner-dot{width:48px;height:48px;border-radius:50%;border:4px solid rgba(255,255,255,0.08);border-top-color:var(--accent);animation:spin 1s linear infinite}
.iframe-spinner.hide{opacity:0;transition:opacity .25s ease}
.modal-iframe{transition:opacity .35s ease}

@keyframes spin{to{transform:rotate(360deg)}}

/* more dramatic entrance and visual flair */
@keyframes modalPop {
  0%{transform:translateY(8vh) scale(.88) rotateX(10deg);opacity:0}
  60%{transform:translateY(-2vh) scale(1.04) rotateX(0);opacity:1}
  85%{transform:translateY(1vh) scale(.99)}
  100%{transform:translateY(0) scale(1)}
}

.modal-panel.fullscreen.open{animation:modalPop .7s cubic-bezier(.2,.9,.25,1) both}

/* animated glow ring */
.modal-panel.fullscreen::before{
  content:'';position:absolute;inset:-6px;border-radius:6px;background:linear-gradient(90deg, rgba(229,9,20,0.01), rgba(255,200,50,0.12));filter:blur(12px);opacity:0;transition:opacity .35s ease;pointer-events:none}
.modal-panel.fullscreen.open::before{opacity:1}

/* particle burst */
.particle-emitter{position:absolute;left:0;top:0;width:100%;height:100%;pointer-events:none;overflow:visible;z-index:40}
.particle-emitter span{position:absolute;width:10px;height:10px;border-radius:50%;opacity:1;transform-origin:center center;will-change:transform,opacity}
@keyframes particleBurst{to{transform:translate(var(--tx), var(--ty)) scale(.7);opacity:0}}


.site-footer{padding:20px 56px;color:var(--muted);font-size:13px}

@media (max-width:800px){
  :root{ --header-height:64px }
  .hero{padding:40px 16px}
  .title{font-size:26px}
  .card{width:clamp(120px,30vw,160px)}
  .modal-body{flex-direction:column}
  .modal-body img{width:100%;height:220px}
  .search{min-width:0;width:100%}
  .nav{gap:8px}
  .profile{display:none}
}

/* subtle entrance animations */
.carousel .card{opacity:0;transform:translateY(20px);animation:fadeUp .5s forwards}
.carousel .card:nth-child(1){animation-delay:.05s}
.carousel .card:nth-child(2){animation-delay:.09s}
.carousel .card:nth-child(3){animation-delay:.13s}
.carousel .card:nth-child(4){animation-delay:.17s}

@keyframes fadeUp{to{opacity:1;transform:none}}
