/* mkmpi.top - French Quirky Games */
:root{--primary:#E11D48;--primary-dark:#be123c;--accent:#06B6D4;--accent-dark:#0891b2;--bg:#0f172a;--bg2:#1e293b;--card:#334155;--text:#f1f5f9;--text-dim:#94a3b8;--success:#22c55e;--danger:#ef4444;--warning:#f59e0b}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:none;border-radius:8px;padding:10px 20px;font-size:1rem;transition:all .2s}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-dark);transform:translateY(-2px)}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:var(--accent-dark);transform:translateY(-2px)}
.btn-outline{background:transparent;border:2px solid var(--accent);color:var(--accent)}
.btn-outline:hover{background:var(--accent);color:#fff}

/* Header */
header{background:var(--bg2);padding:1rem 2rem;position:sticky;top:0;z-index:100;border-bottom:2px solid var(--primary)}
nav{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;flex-wrap:wrap}
.logo{font-size:1.8rem;font-weight:800;color:var(--primary);text-shadow:0 0 20px rgba(225,29,72,.4)}
.logo span{color:var(--accent)}
.nav-links{display:flex;gap:1.5rem;list-style:none}
.nav-links a{color:var(--text);font-weight:500;transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--primary);text-decoration:none}
.menu-toggle{display:none;background:none;border:none;color:var(--text);font-size:1.5rem}

/* Hero */
.hero{text-align:center;padding:4rem 2rem;background:linear-gradient(135deg,var(--bg) 0%,var(--bg2) 100%)}
.hero h1{font-size:2.8rem;margin-bottom:1rem;text-shadow:0 0 30px rgba(225,29,72,.3)}
.hero h1 span{color:var(--primary)}
.hero p{font-size:1.2rem;color:var(--text-dim);max-width:600px;margin:0 auto 2rem}
.hero-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.hero-btns button{padding:14px 32px;font-size:1.1rem}

/* Sections */
.section{padding:3rem 2rem;max-width:1200px;margin:0 auto}
.section-title{font-size:2rem;text-align:center;margin-bottom:2rem;color:var(--text)}
.section-title span{color:var(--primary)}

/* Grid */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}
.card{background:var(--card);border-radius:12px;overflow:hidden;transition:transform .3s,box-shadow .3s;border:1px solid rgba(255,255,255,.05)}
.card:hover{transform:translateY(-5px);box-shadow:0 10px 30px rgba(225,29,72,.2)}
.card-img{height:160px;background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);display:flex;align-items:center;justify-content:center;font-size:3rem}
.card-body{padding:1.2rem}
.card-body h3{font-size:1.1rem;margin-bottom:.5rem;color:var(--text)}
.card-body p{color:var(--text-dim);font-size:.9rem;margin-bottom:1rem}
.card-badge{display:inline-block;padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:600}
.badge-new{background:var(--primary);color:#fff}
.badge-hot{background:var(--accent);color:#fff}
.badge-fun{background:var(--success);color:#fff}

/* Game Container */
.game-container{max-width:800px;margin:2rem auto;padding:2rem;background:var(--card);border-radius:16px;text-align:center}
.game-container h2{color:var(--primary);margin-bottom:1rem}
.game-area{min-height:300px;background:var(--bg);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin:1.5rem 0;overflow:hidden;position:relative}
.game-stats{display:flex;justify-content:center;gap:2rem;margin:1rem 0;font-size:1.1rem}
.game-stats span{color:var(--accent);font-weight:700}
.game-controls{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:1.5rem}
.game-over{color:var(--primary);font-size:2rem;font-weight:800;margin:1rem 0}

/* Specific game styles */
.mole-hole{width:80px;height:80px;background:var(--bg2);border-radius:50%;display:inline-flex;align-items:flex-end;justify-content:center;overflow:hidden;cursor:pointer;margin:10px;position:relative}
.mole{width:60px;height:60px;background:#8B4513;border-radius:50%;position:absolute;bottom:-60px;transition:bottom .1s;display:flex;align-items:center;justify-content:center;font-size:2rem}
.mole.active{bottom:0}
.mole.bonked{background:#666}

.color-btn{width:150px;height:150px;border-radius:20px;border:4px solid #fff;cursor:pointer;transition:transform .1s}
.color-btn:hover{transform:scale(1.05)}

.balloon{width:60px;height:80px;background:linear-gradient(to top,var(--primary),#ff6b8a);border-radius:50% 50% 50% 50% / 60% 60% 40% 40%;display:inline-block;margin:5px;cursor:pointer;animation:float 2s infinite ease-in-out;position:relative}
.balloon::after{content:'';position:absolute;bottom:-15px;left:50%;transform:translateX(-50%);border-left:8px solid transparent;border-right:8px solid transparent;border-top:15px solid var(--primary)}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-20px)}}

.falling-item{position:absolute;font-size:2rem;cursor:pointer;transition:transform .05s}
.falling-item:hover{transform:scale(1.2)}

.fruit{position:absolute;font-size:2.5rem;cursor:pointer;user-select:none}
.slice-effect{position:absolute;pointer-events:none;font-size:2rem;opacity:1;transition:all .5s}

.memory-card{width:80px;height:80px;background:var(--bg2);border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:2.5rem;transition:transform .3s,background .3s}
.memory-card.flipped{background:var(--card);transform:rotateY(180deg)}
.memory-card.matched{background:var(--success);opacity:.5;cursor:default}

.sudoku-cell{width:50px;height:50px;border:1px solid var(--text-dim);display:flex;align-items:center;justify-content:center;font-size:1.3rem;font-weight:700;cursor:pointer;background:#fff;color:#000;transition:background .2s}
.sudoku-cell:hover{background:#e0f2fe}
.sudoku-cell.selected{background:var(--accent);color:#fff}
.sudoku-cell.fixed{background:#ddd;color:#000}
.sudoku-cell.error{background:var(--danger);color:#fff}
.sudoku-cell:nth-child(3n){border-right:3px solid var(--primary)}
.sudoku-grid{display:grid;grid-template-columns:repeat(4,50px);gap:0;border:3px solid var(--primary);margin:0 auto}

/* Footer */
footer{background:var(--bg2);padding:2rem;text-align:center;border-top:2px solid var(--primary);margin-top:3rem}
footer p{color:var(--text-dim)}
footer a{color:var(--accent)}

/* Responsive */
@media(max-width:768px){
.nav-links{display:none;flex-direction:column;width:100%;padding:1rem 0;gap:.5rem}
.nav-links.open{display:flex}
.menu-toggle{display:block}
.hero h1{font-size:2rem}
.grid{grid-template-columns:1fr}
.game-stats{flex-direction:column;gap:.5rem}
.sudoku-cell{width:40px;height:40px;font-size:1rem}
.sudoku-grid{grid-template-columns:repeat(4,40px)}
}

/* Animations */
@keyframes pop{0%{transform:scale(1)}50%{transform:scale(1.3)}100%{transform:scale(1)}}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-15px)}}
.animate-pop{animation:pop .3s}
.animate-shake{animation:shake .3s}
.animate-bounce{animation:bounce .5s}

/* Snake game canvas */
#snakeCanvas,#tetrisCanvas,#pongCanvas,#flappyCanvas,#spaceCanvas,#breakoutCanvas{border:3px solid var(--primary);border-radius:8px;background:#000;max-width:100%}

/* Word search */
.word-search-grid{display:grid;gap:2px;margin:1rem auto;font-family:monospace}
.word-search-cell{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg2);border-radius:4px;font-weight:700;font-size:1rem;cursor:pointer;transition:all .2s}
.word-search-cell:hover{background:var(--accent)}
.word-search-cell.selected{background:var(--primary)}
.word-search-cell.found{background:var(--success)}

/* Sliding puzzle */
.sliding-tile{width:80px;height:80px;background:var(--accent);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:700;cursor:pointer;transition:all .15s}
.sliding-tile:hover{background:var(--primary)}
.sliding-tile.empty{background:var(--bg2);cursor:default}
.sliding-grid{display:grid;grid-template-columns:repeat(4,80px);gap:4px;margin:1rem auto}

/* Quiz */
.quiz-question{background:var(--bg2);padding:1.5rem;border-radius:12px;margin-bottom:1rem;font-size:1.1rem}
.quiz-option{display:block;width:100%;padding:12px;margin:8px 0;background:var(--card);border:2px solid transparent;border-radius:8px;text-align:left;color:var(--text);transition:all .2s}
.quiz-option:hover{border-color:var(--accent)}
.quiz-option.correct{background:var(--success);border-color:var(--success)}
.quiz-option.wrong{background:var(--danger);border-color:var(--danger)}

/* Hangman */
.hangman-display{font-size:4rem;letter-spacing:.5rem;text-align:center;margin:1rem 0}

/* 2048 */
.game-2048{display:grid;grid-template-columns:repeat(4,80px);gap:8px;margin:1rem auto}
.tile-2048{width:80px;height:80px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700}
.tile-2{background:#eee;color:#000}.tile-4{background:#eee;color:#000}.tile-8{background:#f67c5f;color:#fff}.tile-16{background:#f67c5f;color:#fff}.tile-32{background:#f65e3b;color:#fff}.tile-64{background:#edcf72;color:#fff}.tile-128{background:#edcf72;font-size:1.2rem}.tile-256{background:#edcc61}.tile-512{background:#edc53f}.tile-1024{background:#edc53f;font-size:1rem}.tile-2048{background:#edc22e;color:#fff}

/* Dress up */
.dressup-canvas{border:2px dashed var(--text-dim);border-radius:12px;min-height:400px;display:flex;flex-direction:column;align-items:center;padding:1rem}
.dressup-item{width:60px;height:60px;background:var(--bg2);border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:2rem;border:2px solid transparent;transition:all .2s}
.dressup-item:hover{border-color:var(--accent);transform:scale(1.1)}
.dressup-item.selected{border-color:var(--primary);background:var(--primary)}

/* Pet */
.pet-display{font-size:8rem;text-align:center;margin:1rem 0}
.pet-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.pet-stats{background:var(--bg2);padding:1rem;border-radius:12px;margin:1rem auto;max-width:300px}

/* Pizza builder */
.pizza-base{width:200px;height:200px;background:#f4d03f;border-radius:50%;position:relative;margin:1rem auto;box-shadow:0 4px 15px rgba(0,0,0,.3)}
.topping{position:absolute;font-size:1.5rem;cursor:pointer}
.pizza-toppings{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin:1rem 0}
.pizza-topping-btn{padding:8px 16px;background:var(--bg2);border-radius:20px;font-size:1.5rem;cursor:pointer;border:2px solid transparent;transition:all .2s}
.pizza-topping-btn:hover{border-color:var(--accent)}
.pizza-topping-btn.selected{border-color:var(--primary);background:var(--primary)}

/* Burger stacker */
.burger-stack{width:150px;min-height:300px;margin:0 auto;display:flex;flex-direction:column-reverse;align-items:center}
.burger-layer{width:120px;height:30px;margin:2px 0;position:relative}
.burger-bun-top{background:#d4811a;border-radius:60px 60px 5px 5px;height:35px}
.burger-patty{background:#6b3e1a;border-radius:10px;height:25px}
.burger-cheese{background:#f7dc6f;height:10px;margin:-2px 0;width:130px}
.burger-lettuce{background:#27ae60;border-radius:5px;height:15px;width:135px}
.burger-tomato{background:#e74c3c;height:12px;border-radius:5px;width:125px}
.burger-bun-bottom{background:#d4811a;border-radius:5px 5px 40px 40px;height:25px}

/* Cookie decorator */
.cookie-canvas{width:250px;height:250px;background:#f4d03f;border-radius:50%;margin:1rem auto;position:relative;cursor:crosshair}
.cookie-deco{position:absolute;font-size:1.5rem;cursor:pointer}

/* Doodle Jump */
#doodleCanvas{background:linear-gradient(to bottom,#87CEEB 0%,#87CEEB 80%,#228B22 80%)}

/* Forms */
.form-group{margin-bottom:1rem}
.form-group label{display:block;margin-bottom:.5rem;font-weight:500}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px;border-radius:8px;border:2px solid var(--card);background:var(--bg2);color:var(--text);font-size:1rem}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent)}

/* Article */
.article-content{background:var(--card);padding:2rem;border-radius:12px;max-width:800px;margin:2rem auto}
.article-content h2{color:var(--primary);margin:1.5rem 0 1rem}
.article-content h3{color:var(--accent);margin:1.2rem 0 .8rem}
.article-content p{margin-bottom:1rem;line-height:1.8}
.article-content ul,.article-content ol{margin:1rem 0 1rem 1.5rem}
.article-content li{margin-bottom:.5rem}
.article-content blockquote{border-left:4px solid var(--primary);padding-left:1rem;margin:1rem 0;font-style:italic;color:var(--text-dim)}

/* Toast/Notification */
.toast{position:fixed;bottom:20px;right:20px;padding:15px 25px;background:var(--card);border-left:4px solid var(--accent);border-radius:8px;color:var(--text);font-weight:500;transform:translateY(100px);opacity:0;transition:all .3s;z-index:1000}
.toast.show{transform:translateY(0);opacity:1}
.toast.success{border-color:var(--success)}
.toast.error{border-color:var(--danger)}

/* Modal */
.modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.8);z-index:200;align-items:center;justify-content:center}
.modal.active{display:flex}
.modal-content{background:var(--card);padding:2rem;border-radius:16px;max-width:500px;width:90%;text-align:center}
.modal-actions{display:flex;gap:1rem;justify-content:center;margin-top:1.5rem}

/* Score table */
.score-table{width:100%;border-collapse:collapse;margin:1rem 0}
.score-table th,.score-table td{padding:10px;border-bottom:1px solid var(--bg2);text-align:left}
.score-table th{background:var(--bg2);color:var(--primary)}
.score-table tr:hover{background:rgba(6,182,212,.1)}

/* Homepage overrides - missing from CSS */
.navbar{background:var(--bg2);padding:1rem 2rem;position:sticky;top:0;z-index:100;border-bottom:2px solid var(--primary)}
.nav-container{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap}
.navbar .logo{font-size:1.8rem;font-weight:800;color:var(--primary);text-shadow:0 0 20px rgba(225,29,72,.4)}
.navbar .logo span{color:var(--accent)}
.navbar .nav-links{display:flex;gap:1.5rem;list-style:none;align-items:center}
.navbar .nav-links a{color:var(--text);font-weight:500;transition:color .2s}
.navbar .nav-links a:hover,.navbar .nav-links a.active{color:var(--primary);text-decoration:none}
.hamburger{display:none;background:none;border:none;color:var(--text);font-size:1.5rem;cursor:pointer}
.hamburger span{display:block;width:25px;height:3px;background:var(--text);margin:5px 0;border-radius:2px}
.hero-content{position:relative;z-index:1}
.hero .tagline{font-size:1.3rem;color:var(--text-dim);margin-bottom:2rem}
.hero-stats{display:flex;gap:2rem;justify-content:center;flex-wrap:wrap;margin-top:2rem}
.stat-item{text-align:center}
.stat-number{display:block;font-size:2rem;font-weight:800;color:var(--primary)}
.stat-label{color:var(--text-dim);font-size:.9rem}
.games-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-top:1.5rem}
.game-card{background:var(--card);border-radius:12px;overflow:hidden;transition:transform .3s,box-shadow .3s;border:1px solid rgba(255,255,255,.05);display:block;color:var(--text);text-decoration:none}
.game-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px rgba(225,29,72,.2);text-decoration:none}
.game-card img{width:100%;height:180px;object-fit:cover}
.game-card-content{padding:1rem}
.game-card-content h3{font-size:1.1rem;margin-bottom:.5rem;color:var(--text)}
.game-card-content p{color:var(--text-dim);font-size:.9rem;margin-bottom:.8rem}
.game-card-meta{display:flex;justify-content:space-between;align-items:center;font-size:.85rem}
.category-tag{background:var(--primary);color:#fff;padding:3px 8px;border-radius:10px;font-size:.75rem}
.article-card{background:var(--card);border-radius:12px;overflow:hidden;transition:transform .3s,box-shadow .3s;border:1px solid rgba(255,255,255,.05);display:block;color:var(--text);text-decoration:none}
.article-card:hover{transform:translateY(-3px);box-shadow:0 8px 25px rgba(6,182,212,.15);text-decoration:none}
.article-card img{width:100%;height:160px;object-fit:cover}
.article-card-content{padding:1rem}
.article-card-content h3{font-size:1rem;margin-bottom:.5rem;color:var(--text);line-height:1.4}
.article-card-content p{color:var(--text-dim);font-size:.85rem}
.article-meta{color:var(--text-dim);font-size:.8rem;display:flex;gap:1rem;margin-top:.5rem}
.read-time{color:var(--accent)}
.section-subtitle{text-align:center;color:var(--text-dim);margin-top:-1.2rem;margin-bottom:1.5rem;font-size:1rem}
.newsletter{background:var(--card);padding:2.5rem;border-radius:16px;text-align:center;margin:2rem auto;max-width:600px}
.newsletter h2{margin-bottom:.5rem}
.newsletter p{color:var(--text-dim);margin-bottom:1.5rem;font-size:.95rem}
.newsletter-form{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap}
.newsletter-form input{flex:1;min-width:200px;padding:12px 16px;border-radius:8px;border:2px solid var(--text-dim);background:var(--bg);color:var(--text);font-size:1rem}
.newsletter-form input:focus{outline:none;border-color:var(--accent)}
.newsletter-form button{padding:12px 24px;background:var(--primary);color:#fff;border-radius:8px;font-weight:600;cursor:pointer;border:none;transition:background .2s}
.newsletter-form button:hover{background:var(--primary-dark)}
.btn-secondary{display:inline-block;padding:12px 24px;background:var(--bg2);color:var(--text);border-radius:8px;font-weight:600;transition:all .2s;border:2px solid var(--text-dim)}
.btn-secondary:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
@media(max-width:768px){
  .hamburger{display:block}
  .navbar .nav-links{display:none;flex-direction:column;width:100%;padding:1rem 0;gap:.5rem}
  .navbar .nav-links.open{display:flex}
  .games-grid{grid-template-columns:1fr}
  .hero-stats{flex-direction:column;gap:1rem}
}
