/* ------------------------------- Allgemein ------------------------------- */
body{font-family:sans-serif;background:#f7f7f7;margin:0;padding:0;}
.container{padding:20px;}
.hidden{display:none!important;}

/* ------------------------------- Navigation ------------------------------- */
.nav{background:#333;color:#fff;padding:10px 20px;display:flex;justify-content:space-between;align-items:center;gap:12px;}
.nav a{color:#fff;text-decoration:none;}
.nav strong{font-weight:700;white-space:nowrap;}
.left{display:flex;align-items:center;gap:14px;}
.nav-links{display:flex;flex-wrap:wrap;gap:12px;}
.right{display:flex;align-items:center;gap:12px;}
.nav-toggle{display:none;width:40px;height:40px;background:transparent;border:0;padding:0;cursor:pointer;position:relative;}
.nav-toggle span{position:absolute;left:8px;right:8px;height:2px;background:#fff;transition:transform .2s ease,top .2s ease,opacity .2s ease;}
.nav-toggle span:nth-child(1){top:12px;}
.nav-toggle span:nth-child(2){top:19px;}
.nav-toggle span:nth-child(3){top:26px;}
@media(max-width:640px){.nav-toggle{display:block;}.nav{flex-wrap:wrap;align-items:flex-start;}.left{width:100%;flex-direction:column;align-items:flex-start;}.nav-links{display:none;width:100%;flex-direction:column;gap:8px;padding-top:6px;}.nav--open .nav-links{display:flex;}.right{width:100%;justify-content:space-between;}.nav--open .nav-toggle span:nth-child(1){top:19px;transform:rotate(45deg);}.nav--open .nav-toggle span:nth-child(2){opacity:0;}.nav--open .nav-toggle span:nth-child(3){top:19px;transform:rotate(-45deg);}}

/* ------------------------------- Karten-Grid ------------------------------- */
.card-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:24px;margin-top:24px;}

/* ------------------------------- Einzelne Karte ------------------------------- */
.card-item{background:#fff;border-radius:10px;padding:8px;width:100%;box-shadow:0 2px 6px rgba(0,0,0,0.08);transition:transform .15s ease,box-shadow .15s ease;text-align:center;display:flex;flex-direction:column;justify-content:space-between;height:100%;position:relative;}
.card-item:hover{transform:translateY(-2px);box-shadow:0 4px 10px rgba(0,0,0,0.15);}
.card-item img{width:100%;height:auto;max-height:340px;object-fit:contain;margin-bottom:6px;border-radius:6px;}
@media(min-width:1921px){.card-item img{max-height:500px;}}
.card-info{font-size:.9em;color:#333;line-height:1.4em;margin-top:4px;}

/* ------------------------------- Owned-Karten leicht ausgrauen ------------------------------- */
.card-item.owned::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,0.55);border-radius:10px;pointer-events:none;z-index:1;transition:background .3s ease;}
.card-item.no-overlay::after{display:none!important;}

/* ------------------------------- Herz-Icon ------------------------------- */
.card-favorite{position:absolute;top:8px;right:8px;width:24px;height:24px;cursor:pointer;z-index:2;opacity:0;transition:opacity .25s ease,transform .25s ease;transform:scale(.9);}
.card-favorite::before{content:'';display:block;width:100%;height:100%;background-image:url('img/heart.svg');background-repeat:no-repeat;background-position:center;background-size:contain;}
.card-favorite.fav::before{background-image:url('img/heart_full.svg');animation:pulse .3s ease;}
.card-item:hover .card-favorite{opacity:1;transform:scale(1);}

/* ------------------------------- Stern-Icon ------------------------------- */
.card-star{position:absolute;top:8px;right:8px;width:24px;height:24px;cursor:pointer;z-index:2;background-image:url('img/star.svg');background-repeat:no-repeat;background-size:contain;opacity:0;visibility:hidden;transition:opacity .25s ease,transform .25s ease;transform:scale(.9);}
.card-star.starred{background-image:url('img/star_full.svg');animation:pulse .3s ease;}
.card-item:hover .card-star{opacity:1;visibility:visible;transform:scale(1);}

/* ------------------------------- Lupe-Icon ------------------------------- */
.card-zoom{position:absolute;top:8px;left:8px;width:24px;height:24px;cursor:pointer;z-index:2;opacity:0;transition:opacity .25s ease,transform .25s ease;transform:scale(.9);background-image:url('img/zoom-in.svg');background-repeat:no-repeat;background-position:center;background-size:contain;}
.card-item:hover .card-zoom{opacity:1;transform:scale(1);}

/* ------------------------------- Lightbox für Lupe ------------------------------- */
#lightbox,.zoom-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.8);display:none;justify-content:center;align-items:center;z-index:9999;}
#lightbox img,.zoom-modal img{max-width:90%;max-height:90%;border-radius:12px;box-shadow:0 0 25px rgba(255,255,255,0.2);cursor:pointer;animation:fadeIn .3s ease-out;}

/* ------------------------------- Set-Übersicht (sets.php) ------------------------------- */
.set-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-top:20px;}
.set-card{background-color:#fff;border-radius:10px;padding:14px;text-align:center;display:flex;flex-direction:column;justify-content:space-between;box-shadow:0 2px 8px rgba(0,0,0,0.07);transition:transform .2s ease,box-shadow .2s ease;}
.set-card:hover{transform:translateY(-3px);box-shadow:0 6px 12px rgba(0,0,0,0.12);}
.set-card img{width:auto;height:100px;margin:0 auto 10px auto;object-fit:contain;max-width:100%;}
.set-card h4{margin:8px 0 4px 0;font-size:1.1em;color:#222;}
.set-card p{font-size:.95em;color:#555;margin:4px 0;}
.progress-bar{background:#eee;border-radius:4px;overflow:hidden;height:10px;margin:6px 0;}
.progress-bar>div{background:#4caf50;height:100%;}

/* ------------------------------- Buttons ------------------------------- */
.btn{display:inline-block;background:#4caf50;color:#fff;padding:6px 12px;border-radius:4px;text-decoration:none;font-size:.9em;margin-top:auto;}
.btn:hover{background:#388e3c;}

/* ------------------------------- Pokedex-Grid ------------------------------- */
.pokedex-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:24px;margin-bottom:40px;align-items:start;justify-items:center;}
.pokedex-entry{width:140px;height:180px;display:flex;flex-direction:column;align-items:center;text-align:center;text-decoration:none;color:#000;padding:10px;background:#fff;border-radius:8px;box-shadow:0 2px 6px rgba(0,0,0,0.08);transition:transform .15s ease,box-shadow .15s ease;box-sizing:border-box;}
.pokedex-entry:hover{transform:translateY(-4px);box-shadow:0 4px 12px rgba(0,0,0,0.15);}
.pokedex-entry img{width:96px;height:96px;object-fit:contain;margin-bottom:8px;flex-shrink:0;}
.pokedex-entry .name{font-size:.85em;line-height:1.3em;color:#333;height:2.6em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}

/* ------------------------------- Landing-Page ------------------------------- */
.landing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px;margin-top:30px;}
.landing-box{background:#fff;border-radius:12px;padding:30px 20px;box-shadow:0 4px 12px rgba(0,0,0,0.06);text-align:center;transition:transform .2s ease,box-shadow .2s ease;text-decoration:none;color:inherit;}
.landing-box:hover{transform:translateY(-4px);box-shadow:0 6px 16px rgba(0,0,0,0.12);}
.landing-box h3{font-size:1.5em;margin-bottom:10px;}
.landing-box p{font-size:1em;color:#555;}
.landing-box.danger{background-color:#fcebea;color:#c0392b;}

/* ------------------------------- Responsive ------------------------------- */
@media(max-width:1400px){.card-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:900px){.card-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:600px){.card-grid{grid-template-columns:repeat(3,1fr);}}

/* ------------------------------- Fancy Animationen für Karten ------------------------------- */
@keyframes pulse{0%{transform:scale(1);}50%{transform:scale(1.3);}100%{transform:scale(1);}}
@keyframes fadeIn{from{opacity:0;transform:scale(.9);}to{opacity:1;transform:scale(1);}}

/* ------------------------------- Login-Seite ------------------------------- */
.login-body{background:linear-gradient(135deg,#e0f7e9,#f0f0f0);font-family:sans-serif;display:flex;justify-content:center;align-items:center;height:100vh;margin:0;}
.login-container{background:#fff;padding:30px 40px;border-radius:12px;box-shadow:0 4px 20px rgba(0,0,0,0.1);width:100%;max-width:400px;text-align:center;animation:fadeInDown .6s ease;}
.login-container h2{margin-bottom:20px;color:#222;}
.login-error{color:#e11d48;margin-bottom:15px;font-weight:bold;}
.login-form{display:flex;flex-direction:column;gap:15px;}
.login-form label{font-size:.95em;color:#333;text-align:left;display:flex;flex-direction:column;gap:5px;}
.login-form input{padding:10px;border:1px solid #ccc;border-radius:6px;font-size:1em;transition:border-color .2s ease;}
.login-form input:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 2px rgba(76,175,80,0.2);}
.login-form button{background:#4caf50;color:#fff;padding:10px;border:none;border-radius:6px;font-size:1em;cursor:pointer;transition:background .3s ease;}
.login-form button:hover{background:#388e3c;}
@keyframes fadeInDown{from{opacity:0;transform:translateY(-30px);}to{opacity:1;transform:translateY(0);}}

/* ------------------------------- Icons (Remove / Geschenk / RH-Badge) ------------------------------- */
.card-remove{position:absolute;top:40px;left:8px;width:24px;height:24px;background-image:url('img/trash.svg');background-size:contain;background-repeat:no-repeat;cursor:pointer;opacity:0;transition:opacity .2s ease;z-index:2;}
.card-item:hover .card-remove{opacity:1;}
.card-gift{position:absolute;top:42px;left:8px;width:22px;height:22px;background:url('img/giftbox.svg') no-repeat center/contain;cursor:pointer;opacity:0;transition:opacity .2s;}
.card-gift.wish{background-image:url('img/giftbox_full.svg');}
.card-item:hover .card-gift{opacity:1;}
.card-rh{position:absolute;top:42px;right:8px;width:22px;height:22px;background:url('img/rh_empty.svg') no-repeat center/contain;cursor:pointer;opacity:0;transition:opacity .2s;}
.card-rh.rh-owned{background-image:url('img/rh_full.svg');}
.card-item:hover .card-rh{opacity:1;}

/* ------------------------------- Wants-Ansicht ------------------------------- */
.wants-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;}
.want-item{display:flex;gap:10px;padding:12px;background:#f8f8f8;border-radius:8px;box-shadow:0 0 5px rgba(0,0,0,0.1);}
.want-item img{width:100px;height:auto;border-radius:4px;}
.want-info{flex:1;font-size:14px;}
.username{color:#007bff;font-weight:bold;}
.have-card-btn{margin-top:6px;background:#28a745;color:#fff;border:none;padding:6px 10px;border-radius:4px;cursor:pointer;}

/* ------------------------------- Zusätzliche Label ------------------------------- */
.info-label{color:#007bff;}
.sort-bar{margin:10px 0 20px;display:flex;align-items:center;gap:10px;}
.sort-bar label{font-weight:bold;}

/* ------------------------------- Leaderboard & Preview ------------------------------- */
.leaderboard-section{margin-bottom:40px;}
.leaderboard-table{width:100%;border-collapse:collapse;margin-bottom:20px;background:#fff;box-shadow:0 2px 8px rgba(0,0,0,0.05);border-radius:8px;overflow:hidden;}
.leaderboard-table th,.leaderboard-table td{padding:12px 16px;text-align:left;}
.leaderboard-table th{background:#eee;font-weight:bold;}
.leaderboard-table tr:nth-child(even){background:#f9f9f9;}
.leaderboard-table tr:hover{background:#f0f8ff;}
.ranking-card{background:#fff;border-radius:12px;padding:20px;margin-bottom:40px;box-shadow:0 2px 10px rgba(0,0,0,0.05);}
.ranking-card h2{font-size:20px;margin-bottom:15px;}
.ranking-table{width:100%;border-collapse:collapse;}
.ranking-table th,.ranking-table td{padding:10px 14px;text-align:left;border-bottom:1px solid #ddd;}
.ranking-table th{background-color:#f5f5f5;font-weight:bold;}
.ranking-table tr:hover{background-color:#f0f8ff;}
.card-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;margin-top:20px;}
.card-preview-item{background:#fff;border-radius:8px;box-shadow:0 2px 6px rgba(0,0,0,0.05);padding:8px;text-align:center;}
.card-preview-item img{max-width:100%;border-radius:6px;height:auto;}
.card-preview-info{font-size:14px;margin-top:6px;}
.hidden{display:none;}
.card-tooltip-box{position:absolute;z-index:9999;background:#fff;border:1px solid #ccc;padding:10px;box-shadow:0 2px 8px rgba(0,0,0,0.2);border-radius:6px;pointer-events:none;max-width:200px;}
.card-tooltip-box img{max-width:100%;margin-bottom:5px;}
.leaderboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:24px;margin-bottom:40px;}
.ranking-card{display:flex;flex-direction:column;justify-content:flex-start;}
.user-link{color:#222;font-weight:600;text-decoration:none;transition:all .2s ease;}
.user-link:hover{color:#444;text-decoration:underline;}

/* ------------------------------- Badges ------------------------------- */
.badge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;}
.badge-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.06);padding:16px;transition:transform .1s ease,box-shadow .1s ease;}
.badge-card.is-earned{border:1px solid #b6f2c0;}
.badge-card.is-locked{opacity:.6;}
.badge-card:hover{transform:translateY(-2px);box-shadow:0 6px 14px rgba(0,0,0,.08);}
.badge-top{display:flex;align-items:center;gap:8px;margin-bottom:6px;}
.badge-icon{font-size:20px;}
.badge-title{font-weight:700;}
.badge-desc{font-size:14px;color:#555;min-height:38px;}
.badge-status{font-size:12px;margin-top:8px;background:#f5f5f5;border-radius:10px;padding:4px 8px;display:inline-block;}
.is-earned .badge-status{background:#d7f8de;color:#0c7a3b;}
.badge-section{margin:26px 0;}
.badge-section-title{display:flex;align-items:center;gap:10px;font-weight:800;font-size:18px;margin:6px 0 12px;padding-left:10px;border-left:4px solid #e5e7eb;}
.badge-section-icon{font-size:18px;opacity:.8;}

/* ===== Grundlayout (Swipe-View) ===== */
body{background:#f8f9fb;color:#111;font-family:system-ui,sans-serif;}
.wrap{max-width:480px;margin:20px auto;padding:0 12px;}
h1{font-size:24px;font-weight:700;margin-bottom:16px;}

/* ===== Kartenstapel ===== */
.swiper{position:relative;width:100%;max-width:780px;margin:0 auto;height:520px;}
.card{position:absolute;inset:0;margin:0;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 22px rgba(17,24,39,0.08);overflow:hidden;transform:translate(0,0) rotate(0deg);transition:transform .18s ease;will-change:transform;}
.card--animate{transition:transform .18s ease,opacity .18s ease;}
.card.next{pointer-events:none;}
.card.current{z-index:2;}

/* ===== Bildbereich ===== */
.card__image{display:flex;align-items:center;justify-content:center;background:#f1f3f6;height:360px;border-bottom:1px solid #eee;}
.card__image img{max-height:340px;border-radius:8px;}

/* ===== Meta ===== */
.card__meta{padding:10px 14px 14px;font-size:14px;line-height:1.4;}
.card__meta strong{display:block;font-size:16px;margin-bottom:4px;}
.card__meta .prices{margin-top:6px;font-size:13px;color:#666;}

/* ===== Swipe-Badges ===== */
.badge{position:absolute;top:12px;padding:8px 12px;border:3px solid;font-weight:bold;border-radius:8px;opacity:0;background:#fff;}
.badge-like{left:12px;border-color:#2ecc71;color:#27ae60;}
.badge-skip{right:12px;border-color:#e74c3c;color:#c0392b;}

/* ===== Tinder-Style Buttons ===== */
.cta{display:flex;justify-content:center;gap:32px;margin-top:20px;}
.swipe-btn{width:64px;height:64px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(0,0,0,0.15);transition:transform .15s ease;}
.swipe-btn:active{transform:scale(.9);}
.swipe-btn.skip{background:#ff4d4f;color:#fff;font-size:28px;font-weight:bold;}
.swipe-btn.like{background:#2ecc71;color:#fff;font-size:28px;font-weight:bold;}

/* ===== Status ===== */
.msg{text-align:center;margin-top:10px;font-size:14px;color:#555;}

/* -------- Mobile (Swipe-View) -------- */
@media(max-width:640px){.wrap{max-width:100%;margin:12px auto;padding:0 10px;}h1{margin:8px 0 10px;font-size:22px;}body.swiper-lock{overflow:hidden;}.swiper{max-width:100%;height:calc(100svh-350px);margin:0 auto;}.card{height:100%;}.card__image{height:calc(100%-110px);background:#f5f7fa;}.card__image img{max-height:100%;max-width:96%;}.card__meta{padding:10px 12px 12px;font-size:13.5px;}.card__meta strong{font-size:15px;}.cta{position:fixed;left:0;right:0;bottom:56px;margin:0;gap:32px;justify-content:center;pointer-events:none;}.cta .swipe-btn{pointer-events:auto;width:68px;height:68px;font-size:30px;}}
