:root{--toastify-color-light: #fff;--toastify-color-dark: #121212;--toastify-color-info: #3498db;--toastify-color-success: #07bc0c;--toastify-color-warning: #f1c40f;--toastify-color-error: #e74c3c;--toastify-color-transparent: rgba(255, 255, 255, .7);--toastify-icon-color-info: var(--toastify-color-info);--toastify-icon-color-success: var(--toastify-color-success);--toastify-icon-color-warning: var(--toastify-color-warning);--toastify-icon-color-error: var(--toastify-color-error);--toastify-toast-width: 320px;--toastify-toast-background: #fff;--toastify-toast-min-height: 64px;--toastify-toast-max-height: 800px;--toastify-font-family: sans-serif;--toastify-z-index: 9999;--toastify-text-color-light: #757575;--toastify-text-color-dark: #fff;--toastify-text-color-info: #fff;--toastify-text-color-success: #fff;--toastify-text-color-warning: #fff;--toastify-text-color-error: #fff;--toastify-spinner-color: #616161;--toastify-spinner-color-empty-area: #e0e0e0;--toastify-color-progress-light: linear-gradient( to right, #4cd964, #5ac8fa, #007aff, #34aadc, #5856d6, #ff2d55 );--toastify-color-progress-dark: #bb86fc;--toastify-color-progress-info: var(--toastify-color-info);--toastify-color-progress-success: var(--toastify-color-success);--toastify-color-progress-warning: var(--toastify-color-warning);--toastify-color-progress-error: var(--toastify-color-error)}.Toastify__toast-container{z-index:var(--toastify-z-index);-webkit-transform:translate3d(0,0,var(--toastify-z-index));position:fixed;padding:4px;width:var(--toastify-toast-width);box-sizing:border-box;color:#fff}.Toastify__toast-container--top-left{top:1em;left:1em}.Toastify__toast-container--top-center{top:1em;left:50%;transform:translate(-50%)}.Toastify__toast-container--top-right{top:1em;right:1em}.Toastify__toast-container--bottom-left{bottom:1em;left:1em}.Toastify__toast-container--bottom-center{bottom:1em;left:50%;transform:translate(-50%)}.Toastify__toast-container--bottom-right{bottom:1em;right:1em}@media only screen and (max-width : 480px){.Toastify__toast-container{width:100vw;padding:0;left:0;margin:0}.Toastify__toast-container--top-left,.Toastify__toast-container--top-center,.Toastify__toast-container--top-right{top:0;transform:translate(0)}.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-right{bottom:0;transform:translate(0)}.Toastify__toast-container--rtl{right:0;left:initial}}.Toastify__toast{position:relative;min-height:var(--toastify-toast-min-height);box-sizing:border-box;margin-bottom:1rem;padding:8px;border-radius:4px;box-shadow:0 1px 10px #0000001a,0 2px 15px #0000000d;display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between;max-height:var(--toastify-toast-max-height);overflow:hidden;font-family:var(--toastify-font-family);cursor:default;direction:ltr;z-index:0}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-body{margin:auto 0;-ms-flex:1 1 auto;flex:1 1 auto;padding:6px;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}.Toastify__toast-body>div:last-child{word-break:break-word;-ms-flex:1;flex:1}.Toastify__toast-icon{-webkit-margin-end:10px;margin-inline-end:10px;width:20px;-ms-flex-negative:0;flex-shrink:0;display:-ms-flexbox;display:flex}.Toastify--animate{animation-fill-mode:both;animation-duration:.7s}.Toastify--animate-icon{animation-fill-mode:both;animation-duration:.3s}@media only screen and (max-width : 480px){.Toastify__toast{margin-bottom:0;border-radius:0}}.Toastify__toast-theme--dark{background:var(--toastify-color-dark);color:var(--toastify-text-color-dark)}.Toastify__toast-theme--light,.Toastify__toast-theme--colored.Toastify__toast--default{background:var(--toastify-color-light);color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{color:var(--toastify-text-color-info);background:var(--toastify-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{color:var(--toastify-text-color-success);background:var(--toastify-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{color:var(--toastify-text-color-warning);background:var(--toastify-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{color:var(--toastify-text-color-error);background:var(--toastify-color-error)}.Toastify__progress-bar-theme--light{background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error{background:var(--toastify-color-transparent)}.Toastify__close-button{color:#fff;background:transparent;outline:none;border:none;padding:0;cursor:pointer;opacity:.7;transition:.3s ease;-ms-flex-item-align:start;align-self:flex-start}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;height:16px;width:14px}.Toastify__close-button:hover,.Toastify__close-button:focus{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{position:absolute;bottom:0;left:0;width:100%;height:5px;z-index:var(--toastify-z-index);opacity:.7;transform-origin:left}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{right:0;left:initial;transform-origin:right}.Toastify__spinner{width:20px;height:20px;box-sizing:border-box;border:2px solid;border-radius:100%;border-color:var(--toastify-spinner-color-empty-area);border-right-color:var(--toastify-spinner-color);animation:Toastify__spin .65s linear infinite}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,0,0)}to{opacity:0;transform:translate3d(2000px,0,0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,0,0)}to{opacity:0;transform:translate3d(-2000px,0,0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,-10px,0)}40%,45%{opacity:1;transform:translate3d(0,20px,0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,10px,0)}40%,45%{opacity:1;transform:translate3d(0,-20px,0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--top-left,.Toastify__bounce-enter--bottom-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--top-right,.Toastify__bounce-enter--bottom-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--top-left,.Toastify__bounce-exit--bottom-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--top-right,.Toastify__bounce-exit--bottom-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{transform:perspective(400px) rotateX(90deg);animation-timing-function:ease-in;opacity:0}40%{transform:perspective(400px) rotateX(-20deg);animation-timing-function:ease-in}60%{transform:perspective(400px) rotateX(10deg);opacity:1}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:perspective(400px)}30%{transform:perspective(400px) rotateX(-20deg);opacity:1}to{transform:perspective(400px) rotateX(90deg);opacity:0}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideOutRight{0%{transform:translateZ(0)}to{visibility:hidden;transform:translate3d(110%,0,0)}}@keyframes Toastify__slideOutLeft{0%{transform:translateZ(0)}to{visibility:hidden;transform:translate3d(-110%,0,0)}}@keyframes Toastify__slideOutDown{0%{transform:translateZ(0)}to{visibility:hidden;transform:translate3d(0,500px,0)}}@keyframes Toastify__slideOutUp{0%{transform:translateZ(0)}to{visibility:hidden;transform:translate3d(0,-500px,0)}}.Toastify__slide-enter--top-left,.Toastify__slide-enter--bottom-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--top-right,.Toastify__slide-enter--bottom-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--top-left,.Toastify__slide-exit--bottom-left{animation-name:Toastify__slideOutLeft}.Toastify__slide-exit--top-right,.Toastify__slide-exit--bottom-right{animation-name:Toastify__slideOutRight}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown}@keyframes Toastify__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.navbar{background:#0f172af2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1rem 0;position:sticky;top:0;z-index:1000;box-shadow:0 4px 6px #0000004d}.navbar-container{display:flex;justify-content:space-between;align-items:center}.navbar-logo{font-size:1.5rem;font-weight:700;color:var(--text-primary);text-decoration:none;display:flex;align-items:center;gap:.5rem;transition:transform .3s ease}.navbar-logo:hover{transform:scale(1.05)}.logo-icon{font-size:2rem}.navbar-menu{display:flex;align-items:center;gap:1.5rem}.navbar-link{color:var(--text-secondary);text-decoration:none;font-weight:500;transition:color .3s ease;padding:.5rem 1rem;border-radius:6px}.navbar-link:hover{color:var(--primary-color);background:#6366f11a}.navbar-link-admin{background:linear-gradient(135deg,var(--secondary-color),#db2777);color:#fff;padding:.5rem 1rem}.navbar-link-admin:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ec489966}.navbar-user{display:flex;align-items:center;gap:1rem}.navbar-username{color:var(--text-primary);font-weight:600}.btn-sm{padding:8px 16px;font-size:14px}@media (max-width: 768px){.navbar-menu{gap:.75rem}.navbar-link{padding:.4rem .6rem;font-size:.9rem}.navbar-username{display:none}.logo-icon{font-size:1.5rem}.navbar-logo{font-size:1.2rem}}.rom-card{background:var(--bg-dark-secondary);border-radius:12px;overflow:hidden;transition:all .3s ease;cursor:pointer}.rom-card:hover{transform:translateY(-8px);box-shadow:0 12px 24px #6366f14d}.rom-card-link{text-decoration:none;color:inherit;display:block}.rom-card-image-wrapper{position:relative;width:100%;padding-top:75%;overflow:hidden}.rom-card-image{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.rom-card:hover .rom-card-image{transform:scale(1.1)}.rom-card-overlay{position:absolute;top:0;left:0;right:0;padding:12px;background:linear-gradient(180deg,rgba(0,0,0,.7) 0%,transparent 100%)}.rom-card-category{display:inline-block;background:var(--primary-color);color:#fff;padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:600}.rom-card-content{padding:16px}.rom-card-title{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin-bottom:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rom-card-description{font-size:.9rem;color:var(--text-secondary);margin-bottom:12px;min-height:40px;line-height:1.4}.rom-card-stats{display:flex;gap:16px;padding-top:12px;border-top:1px solid var(--bg-dark-tertiary)}.rom-stat{display:flex;align-items:center;gap:6px;color:var(--text-secondary);font-size:.85rem}.rom-stat-icon{font-size:1rem}.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);background:#0009;color:#fff;border:none;width:36px;height:36px;border-radius:50%;font-size:1.5rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .3s ease;z-index:10}.rom-card:hover .carousel-btn{opacity:1}.carousel-btn:hover{background:#000c;transform:translateY(-50%) scale(1.1)}.carousel-btn-prev{left:12px}.carousel-btn-next{right:12px}.carousel-indicators{position:absolute;bottom:12px;left:50%;transform:translate(-50%);display:flex;gap:6px;z-index:10}.carousel-indicator{width:8px;height:8px;border-radius:50%;background:#ffffff80;transition:all .3s ease;cursor:pointer}.carousel-indicator.active{width:24px;border-radius:4px;background:var(--primary-color)}.rom-card-pending{opacity:.85}.rom-card-badge{position:absolute;top:12px;right:12px;padding:6px 12px;border-radius:20px;font-size:.75rem;font-weight:600;z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.rom-card-badge.pending{background:#fbbf24e6;color:#1f2937}.rom-card-availability{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}.availability-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:600}.availability-badge.online{background:#10b98133;color:#10b981;border:1px solid rgba(16,185,129,.3)}.availability-badge.download{background:#3b82f633;color:#3b82f6;border:1px solid rgba(59,130,246,.3)}.availability-badge.pending{background:#fbbf2433;color:#fbbf24;border:1px solid rgba(251,191,36,.3)}.availability-badge.unavailable{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3)}@media (max-width: 768px){.rom-card-title{font-size:1rem}.rom-card-description{font-size:.85rem}}.hero{background:linear-gradient(135deg,#667eea,#764ba2);padding:80px 0;margin-bottom:60px;text-align:center}.hero-title{font-size:3rem;font-weight:900;margin-bottom:20px;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.hero-subtitle{font-size:1.3rem;color:#ffffffe6;margin-bottom:40px;max-width:700px;margin-left:auto;margin-right:auto}.search-form{display:flex;max-width:600px;margin:0 auto;gap:12px}.search-input{flex:1}.categories-filter{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;justify-content:center}.availability-filter{display:flex;gap:12px;margin-bottom:40px;flex-wrap:wrap;justify-content:center}.filter-btn{padding:10px 20px;background:var(--bg-dark-secondary);color:var(--text-secondary);border:2px solid transparent;border-radius:20px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .3s ease}.filter-btn:hover{background:var(--bg-dark-tertiary);transform:translateY(-2px)}.filter-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#ffffff4d;box-shadow:0 4px 15px #667eea66}.category-btn{padding:12px 24px;background:var(--bg-dark-secondary);color:var(--text-secondary);border:2px solid transparent;border-radius:25px;font-weight:600;cursor:pointer;transition:all .3s ease}.category-btn:hover{background:var(--bg-dark-tertiary);color:var(--text-primary)}.category-btn.active{background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));color:#fff;border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 6px 12px #6366f14d}.roms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;margin-bottom:40px}.no-results{text-align:center;padding:60px 20px;color:var(--text-secondary)}.no-results h3{font-size:1.5rem;margin-bottom:12px;color:var(--text-primary)}.pagination{display:flex;justify-content:center;align-items:center;gap:20px;margin:40px 0}.pagination-info{color:var(--text-secondary);font-weight:600}.pagination .btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.hero{padding:60px 0}.hero-title{font-size:2rem}.hero-subtitle{font-size:1.1rem}.search-form{flex-direction:column}.roms-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.categories-filter{gap:8px}.category-btn{padding:10px 18px;font-size:.9rem}}.auth-page{min-height:calc(100vh - 80px);display:flex;align-items:center;justify-content:center;padding:40px 20px;background:var(--bg-dark);color:var(--text-primary)}.auth-container{width:100%;max-width:450px}.auth-card{background:var(--bg-dark-secondary);border-radius:16px;padding:40px;box-shadow:0 10px 30px #00000080}.auth-title{font-size:2rem;font-weight:900;text-align:center;margin-bottom:8px;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:32px}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-weight:600;color:var(--text-primary);font-size:.9rem}.btn-block{width:100%;margin-top:12px}.auth-footer{text-align:center;margin-top:24px;color:var(--text-secondary)}.auth-link{color:var(--primary-color);font-weight:600;text-decoration:none;transition:color .3s ease}.auth-link:hover{color:var(--primary-dark);text-decoration:underline}@media (max-width: 768px){.auth-card{padding:30px 24px}.auth-title{font-size:1.75rem}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000bf;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s ease}.modal-content{background:#fff;border-radius:12px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d;animation:slideUp .3s ease}.facebook-share-modal .modal-header{padding:20px;border-bottom:1px solid #e5e5e5;display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#1877f2,#0e5ac7);color:#fff;border-radius:12px 12px 0 0}.facebook-share-modal .modal-header h2{margin:0;font-size:1.5rem;font-weight:600}.modal-close{background:transparent;border:none;font-size:2rem;color:#fff;cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.modal-close:hover:not(:disabled){background:#fff3}.modal-close:disabled{opacity:.5;cursor:not-allowed}.modal-body{padding:30px 20px}.share-game-preview{display:flex;justify-content:center;margin-bottom:20px;border-radius:8px;overflow:hidden;box-shadow:0 4px 12px #0000001a}.share-game-preview img{max-width:200px;height:auto;display:block;border-radius:8px}.share-icon{display:flex;justify-content:center;margin-bottom:20px}.share-message{text-align:center;font-size:1.1rem;color:#333;margin-bottom:24px;line-height:1.6}.share-message strong{color:#1877f2;font-weight:600}.share-preview{background:#f7f9fa;border-radius:8px;padding:16px;margin-top:20px}.preview-label{font-size:.9rem;color:#666;margin-bottom:10px;font-weight:500}.preview-box{background:#fff;border:1px solid #e5e5e5;border-radius:6px;padding:12px;font-size:.95rem;color:#444;font-style:italic;line-height:1.5}.sdk-loading{text-align:center;padding:10px;background:#fff3cd;border-radius:6px;margin-top:15px}.sdk-loading small{color:#856404}.share-info{margin-top:20px;padding:15px;background:#fff3cd;border-left:4px solid #ffc107;border-radius:6px}.share-info p{margin:0;color:#856404;font-size:.9rem;line-height:1.5}.confirmation-message{padding:30px 20px;text-align:center}.confirmation-message p{margin:0;line-height:1.6}.modal-footer{padding:20px;border-top:1px solid #e5e5e5;display:flex;gap:12px;justify-content:flex-end}.btn{padding:12px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-secondary{background:#e5e5e5;color:#333}.btn-secondary:hover:not(:disabled){background:#d0d0d0}.btn-facebook{background:linear-gradient(135deg,#1877f2,#0e5ac7);color:#fff;box-shadow:0 4px 12px #1877f24d}.btn-facebook:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #1877f266}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 768px){.modal-content{width:95%;max-height:95vh}.facebook-share-modal .modal-header h2{font-size:1.25rem}.share-message{font-size:1rem}.modal-footer{flex-direction:column}.btn{width:100%}}.comments-section{margin-top:40px;padding:30px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.comments-section h3{margin:0 0 24px;font-size:1.5rem;color:#333;font-weight:600}.login-prompt{text-align:center;padding:40px 20px;background:#f7f9fa;border-radius:8px;color:#666}.comment-form{margin-bottom:30px}.comment-input-group{display:flex;flex-direction:column;gap:12px}.comment-input-group textarea{width:100%;padding:14px;border:2px solid #e5e5e5;border-radius:8px;font-size:1rem;font-family:inherit;resize:vertical;transition:border-color .3s}.comment-input-group textarea:focus{outline:none;border-color:#6c5ce7}.comment-input-group textarea:disabled{background:#f5f5f5;cursor:not-allowed}.comment-form-footer{display:flex;justify-content:space-between;align-items:center}.char-counter{font-size:.85rem;color:#999}.btn{padding:10px 20px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.btn-primary{background:linear-gradient(135deg,#6c5ce7,#5846c7);color:#fff;box-shadow:0 4px 12px #6c5ce74d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #6c5ce766}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.comments-loading{text-align:center;padding:40px 20px;color:#666}.spinner{width:40px;height:40px;margin:0 auto 16px;border:4px solid #f3f3f3;border-top:4px solid #6c5ce7;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.no-comments{text-align:center;padding:40px 20px;background:#f7f9fa;border-radius:8px;color:#666}.comments-list{display:flex;flex-direction:column;gap:20px}.comment-item{padding:20px;background:#f7f9fa;border-radius:10px;border-left:4px solid #6c5ce7;transition:all .3s}.comment-item:hover{background:#f0f2f5;box-shadow:0 2px 8px #0000000d}.comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.comment-author{display:flex;align-items:center;gap:8px}.author-icon{font-size:1.2rem}.author-name{font-weight:600;color:#333;font-size:1rem}.comment-meta{display:flex;align-items:center;gap:12px}.comment-date{font-size:.85rem;color:#999}.comment-delete{background:transparent;border:none;cursor:pointer;font-size:1.1rem;padding:4px 8px;border-radius:4px;transition:all .2s}.comment-delete:hover{background:#ff00001a}.comment-body p{margin:0;color:#555;line-height:1.6;white-space:pre-wrap;word-wrap:break-word}.comments-pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:24px;padding-top:24px;border-top:1px solid #e5e5e5}.btn-pagination{background:#f0f0f0;color:#333;padding:8px 16px;font-size:.9rem}.btn-pagination:hover:not(:disabled){background:#e0e0e0}.btn-pagination:disabled{opacity:.4;cursor:not-allowed}.pagination-info{font-size:.9rem;color:#666;font-weight:500}@media (max-width: 768px){.comments-section{padding:20px 16px}.comments-section h3{font-size:1.25rem}.comment-header{flex-direction:column;align-items:flex-start;gap:8px}.comment-meta{width:100%;justify-content:space-between}.comments-pagination{flex-wrap:wrap}.btn-pagination{flex:1;min-width:120px}}.rom-details{padding:40px 0;min-height:calc(100vh - 80px);background:var(--bg-dark);color:var(--text-primary)}.back-link{display:inline-block;color:var(--primary-color);text-decoration:none;font-weight:600;margin-bottom:30px;transition:transform .3s ease}.back-link:hover{transform:translate(-5px)}.rom-details-content{display:grid;grid-template-columns:1fr 1.5fr;gap:40px;margin-top:20px}.rom-details-image-section{display:flex;flex-direction:column;gap:16px}.rom-details-image-main{border-radius:16px;overflow:hidden;box-shadow:0 10px 30px #00000080;background:var(--bg-dark-secondary)}.rom-details-main-img{width:100%;height:auto;display:block}.rom-details-image-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:12px}.gallery-thumb{border-radius:8px;overflow:hidden;cursor:pointer;border:3px solid transparent;transition:all .3s ease;aspect-ratio:4/3}.gallery-thumb img{width:100%;height:100%;object-fit:cover;display:block}.gallery-thumb:hover{border-color:var(--primary-color);transform:translateY(-3px);box-shadow:0 4px 12px #6366f166}.gallery-thumb.active{border-color:var(--primary-color);box-shadow:0 0 0 2px var(--bg-dark),0 0 0 5px var(--primary-color)}.rom-details-image{border-radius:16px;overflow:hidden;box-shadow:0 10px 30px #00000080}.rom-details-image img{width:100%;height:auto;display:block}.rom-details-info{display:flex;flex-direction:column;gap:24px;background:#fff;padding:32px;border-radius:16px;box-shadow:0 4px 20px #0000001a}.rom-category-badge{display:inline-block;background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));color:#fff;padding:8px 20px;border-radius:25px;font-weight:700;font-size:.9rem;width:fit-content}.rom-details-title{font-size:2.5rem;font-weight:900;color:#1a1a1a;line-height:1.2}.rom-details-stats{display:flex;gap:30px;padding:20px 0;border-top:2px solid #e5e7eb;border-bottom:2px solid #e5e7eb}.stat-item{display:flex;flex-direction:column;align-items:center;gap:4px}.stat-icon{font-size:1.5rem}.stat-value{font-size:1.3rem;font-weight:700;color:#1a1a1a}.stat-label{font-size:.85rem;color:#6b7280}.rom-details-description{background:#fff;padding:32px;border-radius:16px;box-shadow:0 4px 20px #0000001a}.rom-details-description h3{font-size:1.3rem;margin-bottom:12px;color:#1a1a1a}.rom-details-description p{color:#374151;line-height:1.8;font-size:1.05rem}.rom-details-actions{display:flex;gap:16px;flex-wrap:wrap}.btn-lg{padding:16px 32px;font-size:1.1rem}.btn-favorite{padding:16px 24px;font-size:1.5rem;background:var(--bg-dark-tertiary);border:2px solid transparent}.btn-favorite.active{border-color:var(--secondary-color);animation:pulse .5s ease}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@media (max-width: 968px){.rom-details-content{grid-template-columns:1fr;gap:30px}.rom-details-title{font-size:2rem}.rom-details-stats{gap:20px}.rom-details-actions{flex-direction:column}.rom-details-actions .btn{width:100%}}.rom-details-actions .btn:disabled{opacity:.5;cursor:not-allowed;background:#6b7280}.rom-details-actions .btn:disabled:hover{transform:none;box-shadow:none}.rom-pending-notice{margin-top:20px;padding:16px;background:#fbbf241a;border:2px solid rgba(251,191,36,.3);border-radius:12px;color:#fbbf24;font-size:.95rem;text-align:center}.rom-pending-notice p{margin:0;display:flex;align-items:center;justify-content:center;gap:8px}.rom-info-notice{margin-top:20px;padding:16px;background:#3b82f61a;border:2px solid rgba(59,130,246,.3);border-radius:12px;color:#3b82f6;font-size:.95rem;text-align:center}.rom-info-notice p{margin:0;display:flex;align-items:center;justify-content:center;gap:8px}.rom-unavailable-notice{margin-top:20px;padding:16px;background:#ef44441a;border:2px solid rgba(239,68,68,.3);border-radius:12px;color:#ef4444;font-size:.95rem;text-align:center}.rom-unavailable-notice p{margin:0;display:flex;align-items:center;justify-content:center;gap:8px}.comments-warning-modal{max-width:600px}.comments-warning-modal .modal-header{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;padding:20px;border-radius:12px 12px 0 0;display:flex;justify-content:space-between;align-items:center}.comments-warning-modal .modal-header h2{margin:0;font-size:1.5rem;font-weight:600}.comments-warning-modal .modal-body{padding:24px}.warning-message{font-size:1.1rem;color:#555;margin-bottom:20px;line-height:1.6}.pending-roms-list{display:flex;flex-direction:column;gap:16px;max-height:400px;overflow-y:auto}.pending-rom-item{display:flex;gap:16px;padding:16px;background:#f7f9fa;border-radius:8px;align-items:center;border:2px solid #e5e5e5;transition:all .3s}.pending-rom-item:hover{border-color:#f59e0b;box-shadow:0 4px 12px #f59e0b33}.pending-rom-item img{width:80px;height:80px;object-fit:cover;border-radius:8px}.pending-rom-info{flex:1;display:flex;flex-direction:column;gap:8px}.pending-rom-info h4{margin:0;color:#333;font-size:1rem}.btn-small{padding:8px 16px;font-size:.9rem;align-self:flex-start}.comments-warning-modal .modal-footer{padding:16px 24px;border-top:1px solid #e5e5e5;display:flex;justify-content:flex-end}@media (max-width: 768px){.pending-rom-item{flex-direction:column;text-align:center}.pending-rom-item img{width:100%;height:150px}.pending-rom-info{align-items:center}.btn-small{align-self:center}}.player-page{min-height:calc(100vh - 80px);background:var(--bg-dark);padding:20px 0}.player-header{background:var(--bg-dark-secondary);padding:20px;margin-bottom:20px;display:flex;align-items:center;gap:20px;box-shadow:0 2px 8px #0000004d}.player-title{font-size:1.5rem;font-weight:700;flex:1}.player-info{display:flex;gap:12px}.player-category{background:var(--primary-color);color:#fff;padding:6px 16px;border-radius:20px;font-size:.85rem;font-weight:600}.player-container{display:grid;grid-template-columns:1fr 350px;gap:20px;max-width:1600px;margin:0 auto;padding:0 20px}.emulator-wrapper{background:#000;border-radius:12px;overflow:hidden;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 40px #0009}.emulator-placeholder{padding:40px;color:var(--text-primary);text-align:left;max-width:800px}.emulator-info h2{color:var(--primary-color);margin-bottom:20px}.emulator-instructions{background:var(--bg-dark-secondary);padding:20px;border-radius:8px;margin:20px 0}.emulator-instructions ol{margin-left:20px;line-height:2}.emulator-instructions a{color:var(--primary-color);text-decoration:none}.emulator-instructions a:hover{text-decoration:underline}.emulator-instructions code{background:var(--bg-dark-tertiary);padding:2px 8px;border-radius:4px;font-family:Courier New,monospace}.rom-info-box{background:var(--bg-dark-secondary);padding:20px;border-radius:8px;margin:20px 0;border-left:4px solid var(--primary-color)}.rom-info-box h3{margin-bottom:12px;color:var(--primary-color)}.rom-info-box p{margin:8px 0;line-height:1.6}.rom-info-box code{background:var(--bg-dark-tertiary);padding:2px 8px;border-radius:4px;font-size:.85rem;word-break:break-all}.controls-info{background:var(--bg-dark-secondary);padding:20px;border-radius:8px;margin-top:20px}.controls-info h3{margin-bottom:16px;color:var(--secondary-color)}.controls-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.control-item{display:flex;justify-content:space-between;align-items:center;background:var(--bg-dark-tertiary);padding:10px 16px;border-radius:6px}.control-key{background:var(--bg-dark);padding:4px 12px;border-radius:4px;font-family:Courier New,monospace;font-weight:700;border:2px solid var(--primary-color);color:var(--primary-color)}.control-action{color:var(--text-secondary);font-size:.9rem}.player-sidebar{background:var(--bg-dark-secondary);padding:24px;border-radius:12px;height:fit-content}.player-sidebar h3{font-size:1.2rem;margin-bottom:12px;color:var(--text-primary)}.player-sidebar p{color:var(--text-secondary);line-height:1.6;margin-bottom:20px}.player-stats{display:flex;flex-direction:column;gap:12px;padding-top:20px;border-top:2px solid var(--bg-dark-tertiary)}.player-stats .stat{display:flex;align-items:center;gap:12px;color:var(--text-secondary)}.player-stats .stat-icon{font-size:1.2rem}@media (max-width: 1200px){.player-container{grid-template-columns:1fr}.emulator-wrapper{min-height:500px}}@media (max-width: 768px){.player-header{flex-wrap:wrap}.player-title{font-size:1.2rem;width:100%}.emulator-placeholder{padding:20px}.controls-grid{grid-template-columns:1fr}}.profile-page{padding:40px 0;min-height:calc(100vh - 80px);background:var(--bg-dark);color:var(--text-primary)}.profile-header{display:flex;align-items:center;gap:24px;padding:40px;background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));border-radius:16px;margin-bottom:40px;box-shadow:0 10px 30px #6366f14d}.profile-avatar{width:100px;height:100px;border-radius:50%;background:#fff;color:var(--primary-color);display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:900;box-shadow:0 4px 12px #0003}.profile-info{flex:1}.profile-name{font-size:2rem;font-weight:900;margin-bottom:8px;color:#fff}.profile-email{font-size:1.1rem;color:#ffffffe6;margin-bottom:12px}.profile-badge{display:inline-block;background:var(--secondary-color);color:#fff;padding:6px 16px;border-radius:20px;font-size:.85rem;font-weight:700}.profile-tabs{display:flex;gap:12px;margin-bottom:30px;border-bottom:2px solid var(--bg-dark-tertiary)}.profile-tab{padding:16px 32px;background:transparent;border:none;color:var(--text-secondary);font-size:1.1rem;font-weight:600;cursor:pointer;border-bottom:3px solid transparent;transition:all .3s ease}.profile-tab:hover{color:var(--text-primary);background:#6366f11a}.profile-tab.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.profile-content{min-height:400px}.profile-section{animation:fadeIn .5s ease}.section-title{font-size:1.8rem;font-weight:700;margin-bottom:30px;color:var(--text-primary)}.empty-state{text-align:center;padding:80px 20px;background:var(--bg-dark-secondary);border-radius:12px;border:2px dashed var(--bg-dark-tertiary)}.empty-state p{font-size:1.2rem;color:var(--text-secondary);margin-bottom:24px}@media (max-width: 768px){.profile-header{flex-direction:column;text-align:center;padding:30px 20px}.profile-avatar{width:80px;height:80px;font-size:2.5rem}.profile-name{font-size:1.5rem}.profile-tabs{flex-wrap:wrap}.profile-tab{padding:12px 24px;font-size:1rem}.section-title{font-size:1.5rem}}.roms-management{animation:fadeIn .5s ease}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.roms-table-container{background:var(--bg-dark-secondary);border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0000004d}.roms-table{width:100%;border-collapse:collapse}.roms-table thead{background:var(--bg-dark-tertiary)}.roms-table th{padding:16px;text-align:left;font-weight:700;color:var(--text-primary);border-bottom:2px solid var(--bg-dark)}.roms-table td{padding:16px;color:var(--text-secondary);border-bottom:1px solid var(--bg-dark-tertiary)}.roms-table tbody tr:hover{background:var(--bg-dark-tertiary)}.rom-thumbnail{width:80px;height:60px;object-fit:cover;border-radius:6px}.rom-title-cell{font-weight:600;color:var(--text-primary)}.category-badge{display:inline-block;background:var(--primary-color);color:#fff;padding:4px 12px;border-radius:12px;font-size:.8rem;font-weight:600}.action-buttons{display:flex;gap:8px}.btn-icon{background:transparent;border:none;font-size:1.3rem;cursor:pointer;padding:6px;border-radius:6px;transition:all .3s ease}.btn-icon:hover{background:var(--bg-dark-tertiary);transform:scale(1.1)}.btn-delete:hover{background:#ef444433}.empty-table{text-align:center;padding:60px 20px;color:var(--text-secondary)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;animation:fadeIn .3s ease}.modal-content{background:var(--bg-dark-secondary);border-radius:12px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:2px solid var(--bg-dark-tertiary)}.modal-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.modal-close{background:transparent;border:none;font-size:2rem;color:var(--text-secondary);cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .3s ease}.modal-close:hover{background:var(--bg-dark-tertiary);color:var(--text-primary)}.rom-form{padding:24px}.rom-form .form-group{margin-bottom:20px}.textarea{resize:vertical;font-family:inherit}.file-input{padding:10px;cursor:pointer}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:24px;border-top:2px solid var(--bg-dark-tertiary)}.selected-images-info{margin-top:12px;padding:12px;background:var(--bg-dark-tertiary);border-radius:8px}.selected-images-info>p{font-size:.9rem;color:var(--text-secondary);margin-bottom:12px;font-weight:500}.current-images-section{margin-bottom:16px;padding:12px;background:#6366f11a;border:1px solid var(--primary-color);border-radius:8px}.current-images-label{font-size:.9rem;color:var(--primary-color);margin-bottom:12px;font-weight:600}.current-rom-info{margin-bottom:12px;padding:10px;background:#6366f11a;border-left:3px solid var(--primary-color);border-radius:4px}.current-rom-label{font-size:.85rem;color:var(--text-secondary);margin:0}.current-rom-label code{background:var(--bg-dark-tertiary);padding:2px 6px;border-radius:3px;color:var(--primary-color);font-size:.8rem}.images-replace-note{font-size:.8rem;color:#f59e0b;margin-top:8px;margin-bottom:0;font-style:italic}.image-preview-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.image-preview-item{display:flex;flex-direction:column;gap:6px;background:var(--bg-dark-secondary);padding:8px;border-radius:6px;border:1px solid var(--bg-dark-tertiary)}.image-preview-item.current{border-color:var(--primary-color);background:#6366f10d}.image-preview-thumb{width:100%;height:80px;object-fit:cover;border-radius:4px}.image-preview-item span{font-size:.75rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 968px){.admin-header{flex-direction:column;align-items:flex-start;gap:16px}.roms-table-container{overflow-x:auto}.roms-table{min-width:800px}.modal-content{max-height:95vh}}.stats-page{animation:fadeIn .5s ease}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px;margin-bottom:40px}.stat-card{background:var(--bg-dark-secondary);padding:24px;border-radius:12px;display:flex;align-items:center;gap:20px;box-shadow:0 4px 12px #0000004d;transition:transform .3s ease}.stat-card:hover{transform:translateY(-4px)}.stat-card-primary{border-left:4px solid var(--primary-color)}.stat-card-success{border-left:4px solid var(--success)}.stat-card-warning{border-left:4px solid var(--warning)}.stat-icon{font-size:3rem}.stat-value{font-size:2.5rem;font-weight:900;color:var(--text-primary);margin-bottom:4px}.stat-label{color:var(--text-secondary);font-size:.9rem;font-weight:600}.stats-sections{display:grid;grid-template-columns:1fr 1fr;gap:30px}.stats-section{background:var(--bg-dark-secondary);padding:24px;border-radius:12px}.section-title{font-size:1.3rem;font-weight:700;margin-bottom:20px;color:var(--text-primary)}.category-stats-list{display:flex;flex-direction:column;gap:16px}.category-stat-item{background:var(--bg-dark-tertiary);padding:20px;border-radius:8px}.category-stat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.category-stat-header h3{font-size:1.1rem;color:var(--text-primary)}.category-stat-badge{background:var(--primary-color);color:#fff;padding:4px 12px;border-radius:12px;font-size:.8rem;font-weight:700}.category-stat-metrics{display:flex;gap:24px}.metric{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:.9rem}.metric-icon{font-size:1.2rem}.metric-value{font-weight:700;color:var(--text-primary)}.recent-roms-list{display:flex;flex-direction:column;gap:12px}.recent-rom-item{background:var(--bg-dark-tertiary);padding:16px;border-radius:8px;display:flex;justify-content:space-between;align-items:center}.recent-rom-info h4{font-size:1rem;color:var(--text-primary);margin-bottom:4px}.recent-rom-category{font-size:.8rem;color:var(--text-secondary)}.recent-rom-stats{display:flex;gap:16px;color:var(--text-secondary);font-size:.9rem}.empty-message{text-align:center;color:var(--text-secondary);padding:40px 20px}@media (max-width: 968px){.stats-sections,.stats-grid{grid-template-columns:1fr}}.scraper-manager{padding:2rem;max-width:1400px;margin:0 auto}.scraper-header{text-align:center;margin-bottom:2rem}.scraper-header h1{font-size:2.5rem;margin-bottom:.5rem;color:#2c3e50}.scraper-header p{color:#7f8c8d;font-size:1.1rem}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.panel-header h2{margin:0}.panel-actions{display:flex;gap:.75rem;flex-wrap:wrap}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;text-align:center;transition:transform .2s}.stat-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.stat-card.highlight{border:2px solid #f39c12;background:linear-gradient(135deg,#fff9e6,#fff)}.stat-card h3{font-size:2.5rem;margin:0;color:#3498db;font-weight:700}.stat-card.highlight h3{color:#f39c12}.stat-card p{margin:.5rem 0 0;color:#7f8c8d;font-size:.9rem;text-transform:uppercase;letter-spacing:1px}.scraper-tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:2px solid #ecf0f1;overflow-x:auto}.scraper-tabs button{padding:1rem 1.5rem;border:none;background:transparent;color:#7f8c8d;font-size:1rem;font-weight:500;cursor:pointer;border-bottom:3px solid transparent;transition:all .3s;white-space:nowrap}.scraper-tabs button:hover{color:#3498db;background:#3498db0d}.scraper-tabs button.active{color:#3498db;border-bottom-color:#3498db;font-weight:600}.tab-content{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a}.tab-panel h2{color:#2c3e50;margin-bottom:1.5rem;font-size:1.8rem}.scraping-form{max-width:600px;margin:2rem auto}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#2c3e50}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:2px solid #ecf0f1;border-radius:8px;font-size:1rem;transition:border-color .3s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3498db}.form-group small{display:block;margin-top:.5rem;color:#95a5a6;font-size:.85rem}.btn-primary,.btn-secondary,.btn-success,.btn-danger,.btn-warning,.btn-link{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;display:inline-block;text-decoration:none;text-align:center}.btn-primary{background:#3498db;color:#fff}.btn-primary:hover:not(:disabled){background:#2980b9;transform:translateY(-2px)}.btn-secondary{background:#95a5a6;color:#fff}.btn-secondary:hover{background:#7f8c8d}.btn-success{background:#27ae60;color:#fff}.btn-success:hover:not(:disabled){background:#229954;transform:translateY(-2px)}.btn-danger{background:#e74c3c;color:#fff}.btn-danger:hover{background:#c0392b}.btn-warning{background:#f39c12;color:#fff}.btn-warning:hover:not(:disabled){background:#e67e22;transform:translateY(-2px)}.btn-link{background:#3498db;color:#fff;padding:.5rem 1rem;font-size:.9rem;margin:.25rem}.btn-link:hover{background:#2980b9}button:disabled{opacity:.6;cursor:not-allowed}.scraping-result{background:#d5f4e6;border:2px solid #27ae60;padding:1.5rem;border-radius:8px;margin-top:2rem;text-align:center}.scraping-result h3{color:#27ae60;margin-bottom:1rem}.scraping-result button{margin-top:1rem}.scraping-info{background:#ecf0f1;padding:1.5rem;border-radius:8px;margin-top:2rem}.scraping-info h3{color:#34495e;margin-bottom:1rem}.scraping-info ol{padding-left:1.5rem}.scraping-info li{margin-bottom:.75rem;line-height:1.6;color:#555}.jobs-list{display:grid;gap:1.5rem}.job-card{background:#f8f9fa;border:2px solid #ecf0f1;padding:1.5rem;border-radius:12px;transition:all .3s}.job-card:hover{border-color:#3498db;box-shadow:0 4px 12px #3498db26}.job-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.job-header h3{margin:0;color:#2c3e50;font-size:1.3rem}.job-info p{margin:.5rem 0;color:#555}.job-progress{margin:1rem 0}.progress-bar{width:100%;height:8px;background:#ecf0f1;border-radius:4px;overflow:hidden;margin-top:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,#3498db,#2ecc71);transition:width .3s}.job-stats{display:flex;gap:1rem;margin-top:1rem}.stat-success,.stat-error{padding:.4rem .8rem;border-radius:6px;font-weight:600;font-size:.9rem}.stat-success{background:#d5f4e6;color:#27ae60}.stat-error{background:#fadbd8;color:#e74c3c}.job-actions{display:flex;gap:1rem;margin-top:1.5rem;flex-wrap:wrap}.badge{padding:.4rem .8rem;border-radius:6px;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-success{background:#d5f4e6;color:#27ae60}.badge-warning{background:#fff3cd;color:#f39c12}.badge-danger{background:#fadbd8;color:#e74c3c}.badge-secondary{background:#ecf0f1;color:#7f8c8d}.badge-info{background:#d6eaf8;color:#3498db}.pending-info{background:#fff3cd;border-left:4px solid #f39c12;padding:1rem;margin-bottom:2rem;border-radius:4px}.pending-info p{margin:0;color:#856404}.pending-roms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.pending-rom-card{background:#fff;border:2px solid #ecf0f1;border-radius:12px;overflow:hidden;transition:all .3s}.pending-rom-card:hover{border-color:#f39c12;box-shadow:0 4px 16px #f39c1233}.rom-image-preview{width:100%;height:200px;background:#ecf0f1;display:flex;align-items:center;justify-content:center;overflow:hidden}.rom-image-preview img{width:100%;height:100%;object-fit:cover}.no-image{color:#95a5a6;font-size:1.2rem}.rom-info{padding:1.5rem}.rom-info h3{margin:0 0 .5rem;color:#2c3e50;font-size:1.2rem;line-height:1.4}.rom-category{color:#7f8c8d;font-size:.9rem;margin:.5rem 0}.rom-details{margin:1rem 0;padding:1rem;background:#f8f9fa;border-radius:8px}.rom-details p{margin:.5rem 0;font-size:.9rem;color:#555}.rom-links,.rom-links-modal{display:flex;flex-direction:column;gap:.5rem;margin:1rem 0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;overflow-y:auto}.modal-content{background:#fff;border-radius:12px;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d}.modal-content.small{max-width:600px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:2px solid #ecf0f1}.modal-header h2{margin:0;color:#2c3e50;font-size:1.5rem}.btn-close{background:#e74c3c;color:#fff;border:none;width:36px;height:36px;border-radius:50%;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s}.btn-close:hover{background:#c0392b;transform:rotate(90deg)}.modal-body{padding:1.5rem}.items-list{max-height:500px;overflow-y:auto;margin-top:1rem}.item-card{display:flex;gap:1rem;padding:1rem;border:1px solid #ecf0f1;border-radius:8px;margin-bottom:1rem;background:#f8f9fa}.item-image{flex-shrink:0;width:100px;height:100px;background:#ecf0f1;border-radius:8px;overflow:hidden}.item-image img{width:100%;height:100%;object-fit:cover}.item-info{flex:1}.item-info h4{margin:0 0 .5rem;color:#2c3e50;font-size:1rem}.item-url{font-size:.8rem;color:#95a5a6;word-break:break-all;margin:.5rem 0}.rom-id{font-weight:600;color:#27ae60;font-size:.9rem;margin:.5rem 0}.error-text{color:#e74c3c;font-size:.85rem;margin:.5rem 0}.error-message{background:#fadbd8;color:#e74c3c;padding:.75rem;border-radius:6px;margin-top:1rem;font-size:.9rem}.loading{text-align:center;padding:3rem;color:#7f8c8d;font-size:1.2rem}.empty-state{text-align:center;padding:3rem;color:#95a5a6}.empty-state p{font-size:1.2rem}.job-detail-info{background:#f8f9fa;padding:1rem;border-radius:8px;margin-bottom:1.5rem}.job-detail-info p{margin:.5rem 0;color:#555}@media (max-width: 768px){.scraper-manager{padding:1rem}.scraper-header h1{font-size:2rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.stat-card h3{font-size:2rem}.scraper-tabs{flex-wrap:wrap}.scraper-tabs button{padding:.75rem 1rem;font-size:.9rem}.tab-content{padding:1rem}.scraping-form{margin:1rem 0}.pending-roms-grid{grid-template-columns:1fr}.item-card{flex-direction:column}.item-image{width:100%;height:150px}.modal-content{max-height:95vh}.modal-header,.modal-body{padding:1rem}.job-actions{flex-direction:column}.job-actions button{width:100%}}.items-list::-webkit-scrollbar,.modal-body::-webkit-scrollbar{width:8px}.items-list::-webkit-scrollbar-track,.modal-body::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.items-list::-webkit-scrollbar-thumb,.modal-body::-webkit-scrollbar-thumb{background:#bdc3c7;border-radius:4px}.items-list::-webkit-scrollbar-thumb:hover,.modal-body::-webkit-scrollbar-thumb:hover{background:#95a5a6}.file-input{width:100%;padding:.75rem;border:2px dashed #3498db;border-radius:8px;background:#f8f9fa;cursor:pointer;transition:all .3s}.file-input:hover{border-color:#2980b9;background:#ecf0f1}.file-info{background:#e8f5e9;border:1px solid #4caf50;padding:.75rem;border-radius:6px;margin-top:.5rem}.file-info p{margin:.25rem 0;color:#2e7d32}.upload-progress{margin-top:1rem}.upload-progress .progress-bar{width:100%;height:20px;background:#ecf0f1;border-radius:10px;overflow:hidden;margin-bottom:.5rem}.upload-progress .progress-fill{height:100%;background:linear-gradient(90deg,#3498db,#2ecc71);transition:width .3s;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.85rem}.upload-progress p{text-align:center;color:#3498db;font-weight:600;margin:0}.item-card-detailed{background:#fff;border:2px solid #ecf0f1;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;transition:all .3s}.item-card-detailed:hover{border-color:#3498db;box-shadow:0 4px 12px #3498db26}.item-header{display:flex;gap:1.5rem;margin-bottom:1rem;align-items:flex-start}.item-title-section{flex:1}.item-title-section h4{margin:0 0 .75rem;color:#2c3e50;font-size:1.3rem;line-height:1.4}.item-title-section .badge{margin-right:.5rem;margin-bottom:.5rem;display:inline-block}.item-title-section .rom-id{display:inline-block;margin-left:.5rem}.item-scraped-data{background:#f8f9fa;border-radius:8px;padding:1.25rem;margin-top:1rem}.item-scraped-data h5{margin:0 0 1rem;color:#2c3e50;font-size:1.1rem;font-weight:600;border-bottom:2px solid #ecf0f1;padding-bottom:.5rem}.scraped-details{display:grid;gap:.75rem}.detail-row{display:flex;align-items:flex-start;padding:.75rem;background:#fff;border-radius:6px;border-left:3px solid #3498db}.detail-row.full-width{grid-column:1 / -1}.detail-label{font-weight:600;color:#2c3e50;min-width:140px;flex-shrink:0;font-size:.95rem}.detail-value{color:#555;flex:1;font-size:.95rem}.detail-link{color:#3498db;text-decoration:none;font-weight:500;transition:color .2s}.detail-link:hover{color:#2980b9;text-decoration:underline}.link-small{color:#27ae60;text-decoration:none;font-weight:600;font-size:.9rem;transition:color .2s}.link-small:hover{color:#229954;text-decoration:underline}.success-text{color:#27ae60;font-weight:600}.warning-text{color:#f39c12;font-weight:600}.error-text{color:#e74c3c;font-weight:600}.description-preview{margin-top:.5rem}.description-preview summary{cursor:pointer;color:#3498db;font-weight:600;padding:.5rem;background:#fff;border-radius:6px;transition:all .2s;-webkit-user-select:none;user-select:none}.description-preview summary:hover{background:#ecf0f1;color:#2980b9}.description-content{margin-top:1rem;padding:1rem;background:#fff;border-radius:6px;border:1px solid #ecf0f1;max-height:300px;overflow-y:auto;line-height:1.6;color:#555}.description-content p{margin:.5rem 0}.description-content strong{color:#2c3e50}.item-pending-info{background:#fff3cd;border-left:4px solid #f39c12;padding:1rem;border-radius:6px;margin-top:1rem}.item-pending-info p{margin:0;color:#856404;font-weight:500}.item-error{background:#fadbd8;border-left:4px solid #e74c3c;padding:1rem;border-radius:6px;margin-top:1rem;color:#c0392b}.item-error strong{font-weight:600}@media (max-width: 768px){.item-header{flex-direction:column}.detail-row{flex-direction:column;gap:.5rem}.detail-label{min-width:auto}.item-card-detailed,.item-scraped-data{padding:1rem}}.admin-dashboard{display:grid;grid-template-columns:250px 1fr;min-height:calc(100vh - 80px);background:var(--bg-dark)}.admin-sidebar{background:var(--bg-dark-secondary);border-right:2px solid var(--bg-dark-tertiary)}.admin-sidebar-header{padding:24px;border-bottom:2px solid var(--bg-dark-tertiary)}.admin-sidebar-header h2{font-size:1.3rem;font-weight:700;color:var(--text-primary)}.admin-nav{padding:16px;display:flex;flex-direction:column;gap:8px}.admin-nav-link{padding:14px 16px;color:var(--text-secondary);text-decoration:none;border-radius:8px;font-weight:600;transition:all .3s ease;display:flex;align-items:center;gap:12px}.admin-nav-link:hover{background:var(--bg-dark-tertiary);color:var(--text-primary)}.admin-nav-link.active{background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));color:#fff;box-shadow:0 4px 12px #6366f14d}.admin-content{padding:40px;overflow-y:auto}.admin-header{margin-bottom:40px}.admin-title{font-size:2rem;font-weight:900;margin-bottom:8px;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.admin-subtitle{color:var(--text-secondary);font-size:1.1rem}@media (max-width: 968px){.admin-dashboard{grid-template-columns:1fr}.admin-sidebar{position:sticky;top:0;z-index:100}.admin-nav{flex-direction:row;overflow-x:auto}.admin-content{padding:20px}}.rom-details-description,.player-sidebar,.rom-card-description{line-height:1.6;background:transparent}.rom-details-description p,.player-sidebar p{margin:.8em 0;color:#374151;line-height:1.7;background:transparent}.rom-details-description p:first-of-type,.player-sidebar p:first-of-type{margin-top:0}.rom-details-description h3,.player-sidebar h3{color:#1a1a1a;font-size:1.2em;margin:1.5em 0 .8em;font-weight:600;background:transparent}.rom-details-description h3:first-child,.player-sidebar h3:first-child{margin-top:0}.rom-details-description strong,.player-sidebar strong{color:#111827;font-weight:600}.rom-details-description ul,.player-sidebar ul{margin:1em 0;padding-left:1.5em;list-style-type:disc}.rom-details-description li,.player-sidebar li{margin:.5em 0;color:#374151}.rom-details-description strong:has(+emoji),.player-sidebar strong:has(+emoji){display:inline-block;padding:.2em .5em;background:#6366f11a;border-radius:4px;border-left:3px solid #6366f1}.rom-card-description{font-size:.9em;color:#b0b0b0;line-height:1.5}.rom-card-description p,.rom-card-description strong,.rom-card-description ul,.rom-card-description li{margin:0;padding:0;list-style:none;display:inline}@media (max-width: 768px){.rom-details-description p,.player-sidebar p{font-size:.95em}.rom-details-description h3,.player-sidebar h3{font-size:1.1em}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #6366f1;--primary-dark: #4f46e5;--secondary-color: #ec4899;--bg-dark: #0f172a;--bg-dark-secondary: #1e293b;--bg-dark-tertiary: #334155;--text-primary: #f8fafc;--text-secondary: #cbd5e1;--success: #10b981;--error: #ef4444;--warning: #f59e0b}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,var(--bg-dark) 0%,#1e1e3f 100%);color:var(--text-primary);min-height:100vh;line-height:1.6}#root{min-height:100vh}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--bg-dark-secondary)}::-webkit-scrollbar-thumb{background:var(--primary-color);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--primary-dark)}.container{max-width:1400px;margin:0 auto;padding:0 20px}.btn{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:8px;text-decoration:none}.btn-primary{background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 20px #6366f14d}.btn-secondary{background:var(--bg-dark-tertiary);color:var(--text-primary)}.btn-secondary:hover{background:var(--bg-dark-secondary)}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover{background:#dc2626}.card{background:var(--bg-dark-secondary);border-radius:12px;padding:24px;box-shadow:0 4px 6px #0000004d;transition:transform .3s ease,box-shadow .3s ease}.card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #00000080}.input{width:100%;padding:12px 16px;background:var(--bg-dark-tertiary);border:2px solid transparent;border-radius:8px;color:var(--text-primary);font-size:16px;transition:all .3s ease}.input:focus{outline:none;border-color:var(--primary-color);background:var(--bg-dark-secondary)}.input::placeholder{color:var(--text-secondary)}.loading{display:flex;justify-content:center;align-items:center;min-height:200px}.spinner{width:50px;height:50px;border:4px solid var(--bg-dark-tertiary);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-message{background:#ef44441a;border:1px solid var(--error);color:var(--error);padding:12px 16px;border-radius:8px;margin:16px 0}.success-message{background:#10b9811a;border:1px solid var(--success);color:var(--success);padding:12px 16px;border-radius:8px;margin:16px 0}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .5s ease-out}@media (max-width: 768px){.container{padding:0 16px}.btn{padding:10px 20px;font-size:14px}.card{padding:16px}}
