@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;600;700&display=swap');
*{margin:0;padding:0;box-sizing:border-box}
:root{--primary:#E91E63;--secondary:#9C27B0;--accent:#00BCD4;--dark:#1A1A2E;--light:#FFF0F5;--card:#FFFFFF;--text:#333333;--gray:#f5f5f5}
html{scroll-behavior:smooth}
body{font-family:'Noto Sans JP',sans-serif;color:var(--text);background:var(--light);line-height:1.7}
a{text-decoration:none;color:inherit;transition:.3s}
img{max-width:100%;height:auto}
.container{max-width:1200px;margin:0 auto;padding:0 20px}
/* Header */
header{background:var(--dark);padding:15px 0;position:sticky;top:0;z-index:1000}
header .container{display:flex;justify-content:space-between;align-items:center}
.logo{font-size:1.8rem;font-weight:700;color:var(--primary)}
.logo span{color:var(--accent)}
nav ul{display:flex;list-style:none;gap:30px}
nav ul li a{color:#fff;font-weight:500;position:relative}
nav ul li a:hover{color:var(--primary)}
nav ul li a::after{content:'';position:absolute;bottom:-5px;left:0;width:0;height:2px;background:var(--primary);transition:.3s}
nav ul li a:hover::after{width:100%}
.hamburger{display:none;flex-direction:column;cursor:pointer;gap:5px}
.hamburger span{width:25px;height:3px;background:#fff;transition:.3s}
/* Hero */
.hero{background:linear-gradient(135deg,var(--dark) 0%,var(--secondary) 100%);color:#fff;padding:100px 0;text-align:center}
.hero h1{font-size:3rem;margin-bottom:20px}
.hero p{font-size:1.3rem;opacity:.9;max-width:600px;margin:0 auto 30px}
.btn{display:inline-block;background:var(--primary);color:#fff;padding:15px 40px;border-radius:50px;font-weight:600;transition:.3s}
.btn:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(233,30,99,.4)}
/* Sections */
section{padding:80px 0}
.section-title{text-align:center;font-size:2.5rem;margin-bottom:50px;color:var(--dark)}
.section-title span{color:var(--primary)}
/* Cards */
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px}
.card{background:var(--card);border-radius:20px;overflow:hidden;box-shadow:0 5px 20px rgba(0,0,0,.08);transition:.3s}
.card:hover{transform:translateY(-10px);box-shadow:0 15px 40px rgba(0,0,0,.12)}
.card-img{height:200px;background:linear-gradient(135deg,var(--primary),var(--secondary));display:flex;align-items:center;justify-content:center;font-size:4rem}
.card-body{padding:25px}
.card-body h3{font-size:1.3rem;margin-bottom:10px;color:var(--dark)}
.card-body p{color:#666;margin-bottom:15px;font-size:.95rem}
.card-tags{display:flex;gap:10px;flex-wrap:wrap}
.tag{background:var(--light);color:var(--primary);padding:5px 15px;border-radius:20px;font-size:.8rem;font-weight:500}
/* Stats */
.stats{background:var(--dark);padding:60px 0}
.stats .container{display:flex;justify-content:space-around;flex-wrap:wrap;gap:30px}
.stat{text-align:center;color:#fff}
.stat h2{font-size:3rem;color:var(--primary)}
.stat p{opacity:.8}
/* Newsletter */
.newsletter{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;text-align:center;padding:80px 0}
.newsletter h2{font-size:2rem;margin-bottom:20px}
.newsletter form{display:flex;max-width:500px;margin:30px auto;gap:10px}
.newsletter input{flex:1;padding:15px 20px;border:none;border-radius:50px;font-size:1rem}
.newsletter button{background:var(--dark);color:#fff;padding:15px 30px;border:none;border-radius:50px;cursor:pointer;font-weight:600;transition:.3s}
.newsletter button:hover{transform:scale(1.05)}
/* Article */
.article-card{display:flex;gap:20px;background:var(--card);border-radius:15px;overflow:hidden;margin-bottom:20px;transition:.3s}
.article-card:hover{transform:translateX(10px)}
.article-card img{width:250px;object-fit:cover}
.article-content{padding:20px}
.article-content h3{font-size:1.3rem;margin-bottom:10px;color:var(--dark)}
.article-meta{font-size:.85rem;color:#888;margin-bottom:10px}
/* Footer */
footer{background:var(--dark);color:#fff;padding:60px 0 20px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-about h3{font-size:1.8rem;color:var(--primary);margin-bottom:15px}
.footer-about p{opacity:.7;line-height:1.8}
.footer-links h4{color:var(--accent);margin-bottom:20px}
.footer-links ul{list-style:none}
.footer-links li{margin-bottom:10px}
.footer-links a{opacity:.7;transition:.3s}
.footer-links a:hover{opacity:1;color:var(--primary)}
.footer-bottom{text-align:center;padding-top:20px;border-top:1px solid rgba(255,255,255,.1);opacity:.6}
/* Games Filter */
.filter-bar{display:flex;gap:15px;flex-wrap:wrap;margin-bottom:40px;justify-content:center}
.filter-btn{padding:10px 25px;background:var(--card);border:2px solid var(--primary);color:var(--primary);border-radius:30px;cursor:pointer;font-weight:500;transition:.3s}
.filter-btn:hover,.filter-btn.active{background:var(--primary);color:#fff}
.search-box{display:flex;justify-content:center;margin-bottom:40px}
.search-box input{width:100%;max-width:400px;padding:15px 25px;border:2px solid var(--primary);border-radius:50px;font-size:1rem;border-radius:50px 0 0 50px}
.search-box button{background:var(--primary);color:#fff;padding:15px 30px;border:none;cursor:pointer;border-radius:0 50px 50px 0}
/* Game Page */
.game-header{background:linear-gradient(135deg,var(--dark),var(--secondary));color:#fff;padding:60px 0;text-align:center}
.game-container{max-width:900px;margin:0 auto;padding:40px 20px}
.game-area{background:var(--card);border-radius:20px;padding:40px;text-align:center;margin-bottom:30px;min-height:400px;display:flex;flex-direction:column;align-items:center;justify-content:center}
.game-score{font-size:2rem;font-weight:700;color:var(--primary);margin-bottom:20px}
.game-timer{font-size:1.5rem;color:var(--accent);margin-bottom:20px}
.game-btn{background:var(--primary);color:#fff;padding:15px 40px;border:none;border-radius:50px;font-size:1.1rem;cursor:pointer;transition:.3s;margin:10px}
.game-btn:hover{transform:scale(1.05);box-shadow:0 10px 25px rgba(233,30,99,.3)}
.game-btn:disabled{opacity:.5;cursor:not-allowed}
.difficulty{display:flex;gap:10px;justify-content:center;margin-bottom:20px}
.diff-btn{padding:8px 20px;border:2px solid var(--primary);background:#fff;color:var(--primary);border-radius:20px;cursor:pointer;transition:.3s}
.diff-btn:hover,.diff-btn.active{background:var(--primary);color:#fff}
.related-games{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-top:40px}
.related-game{background:var(--light);padding:20px;border-radius:15px;text-align:center;transition:.3s}
.related-game:hover{transform:scale(1.05)}
.related-game a{color:var(--primary);font-weight:600}
/* Animations */
@keyframes fadeIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.fade-in{animation:fadeIn .6s ease-out}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
.pulse{animation:pulse 2s infinite}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-10px)}75%{transform:translateX(10px)}}
.shake{animation:shake .5s}
/* FAQ */
.faq-item{background:var(--card);margin-bottom:15px;border-radius:15px;overflow:hidden}
.faq-question{padding:20px 25px;font-weight:600;cursor:pointer;display:flex;justify-content:space-between;align-items:center;background:var(--card)}
.faq-question:hover{background:var(--light)}
.faq-answer{padding:0 25px;max-height:0;overflow:hidden;transition:.3s}
.faq-item.active .faq-answer{max-height:500px;padding:20px 25px}
/* Contact Form */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px}
.form-group{margin-bottom:25px}
.form-group label{display:block;margin-bottom:8px;font-weight:500}
.form-group input,.form-group textarea{width:100%;padding:15px;border:2px solid #eee;border-radius:10px;font-size:1rem;font-family:inherit;transition:.3s}
.form-group input:focus,.form-group textarea:focus{border-color:var(--primary);outline:none}
/* Mobile */
@media(max-width:768px){
    .hamburger{display:flex}
    nav ul{position:absolute;top:100%;left:0;right:0;background:var(--dark);flex-direction:column;padding:20px;gap:15px;display:none}
    nav ul.active{display:flex}
    .hero h1{font-size:2rem}
    .footer-grid{grid-template-columns:1fr}
    .contact-grid{grid-template-columns:1fr}
    .article-card{flex-direction:column}
    .article-card img{width:100%;height:200px}
}
