@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;600;700;900&display=swap');

/* --- GLASSMORPHISM & ALAPOK --- */
:root {
    --glass-bg: rgba(255, 255, 255, 0.65);
    --glass-border: rgba(255, 255, 255, 0.4);
    --glass-shadow: 0 8px 32px 0 rgba(31, 38, 135, 0.15);
}
.dark :root {
    --glass-bg: rgba(30, 30, 30, 0.6);
    --glass-border: rgba(255, 255, 255, 0.1);
}

body { -webkit-tap-highlight-color: transparent; } /* Mobilon ne villogjon érintéskor */

/* Üveghatás javítása mobilon */
.glass-panel {
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    box-shadow: var(--glass-shadow);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px); /* Safari support */
    transition: transform 0.2s ease;
}

/* --- IPHONE/SAFARI 3D FLIP FIX --- */
.perspective-1000 { perspective: 1000px; }
.transform-style-3d { transform-style: preserve-3d; }

.flip-card-inner {
    position: relative;
    width: 100%;
    height: 100%;
    transition: transform 0.6s cubic-bezier(0.4, 0.2, 0.2, 1);
    transform-style: preserve-3d;
}
.flip-card-inner.flipped { transform: rotateY(180deg); }

/* FONTOS: Ez javítja a villogást iPhone-on */
.card-face {
    position: absolute; /* Ez a kulcs, hogy ne essen szét */
    inset: 0;           /* Teljes kitöltés */
    width: 100%; 
    height: 100%;
    -webkit-backface-visibility: hidden; 
    backface-visibility: hidden;
    border-radius: 1.5rem;
    overflow: hidden;
    transform: translate3d(0,0,0); /* Hardveres gyorsítás */
}

/* A hátlapot előre elforgatjuk */
.card-back-visible {
    transform: rotateY(180deg);
}

/* --- KÁRTYA SZÍNEK --- */
.bg-card-start { background: linear-gradient(135deg, #2d3436, #000000); }
.bg-card-bronz { background: linear-gradient(135deg, #d35400, #a04000); }
.bg-card-ezust { background: linear-gradient(135deg, #bdc3c7, #2c3e50); color:#111; }
.bg-card-arany { background: linear-gradient(135deg, #f1c40f, #b7950b); color:#111; }

.tier-chip {
    padding: 4px 12px;
    border-radius: 99px;
    background: rgba(255,255,255,0.2);
    border: 1px solid rgba(255,255,255,0.3);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 1px;
    text-transform: uppercase;
}

/* --- SCROLLBAR ELREJTÉSE (App-like feel) --- */
::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(0,0,0,0.1); border-radius: 4px; }

/* --- VIP ROADMAP --- */
.vip-roadmap { position: relative; padding: 30px 0 10px; margin-top: 60px; }
.vip-roadmap .road-line { position:absolute; left:0; right:0; top:38px; height:4px; border-radius:99px; background:#e5e7eb; z-index: 0; }
.dark .vip-roadmap .road-line { background:#374151; }
.vip-roadmap .road-car { position:absolute; top:22px; transform: translateX(-50%); transition: left 0.8s ease-in-out; z-index: 10; }
.vip-roadmap .road-car .car-dot { width:32px; height:32px; border-radius:50%; background:#d63031; border: 3px solid #fff; box-shadow: 0 4px 10px rgba(214,48,49,0.4); display:flex; align-items:center; justify-content:center; color:white; font-size: 12px; }

.roadmap-stop { position:absolute; top:34px; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; z-index: 5; }
.roadmap-stop .stop-icon { width:12px; height:12px; border-radius:50%; background:#9ca3af; margin-bottom: 8px; border: 2px solid #fff; }
.roadmap-stop.reached .stop-icon { background: #10b981; border-color: #fff; transform: scale(1.2); }
.stop-label { opacity: 0; font-size: 10px; font-weight: bold; transition: opacity 0.3s; position: absolute; top: 15px; width: max-content; text-align: center; }
.roadmap-stop.reached .stop-label { opacity: 1; color: #10b981; }

/* ANIMÁCIÓK */
@keyframes fadeIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
.animate-fade-in { animation: fadeIn 0.4s ease-out forwards; }

/* --- BANKKÁRTYA CHIP --- */
.card-chip {
    width: 45px; height: 34px;
    background: linear-gradient(135deg, #d4af37 0%, #f9eac3 50%, #c5a028 100%);
    border-radius: 6px;
    position: relative;
    box-shadow: inset 0 1px 3px rgba(0,0,0,0.4);
    border: 1px solid #b89523;
}
/* A chip vonalkái */
.card-chip::before {
    content: ''; position: absolute; top: 0; left: 50%; width: 1px; height: 100%;
    background: rgba(0,0,0,0.3); transform: translateX(-50%);
}
.card-chip::after {
    content: ''; position: absolute; top: 50%; left: 0; width: 100%; height: 1px;
    background: rgba(0,0,0,0.3); transform: translateY(-50%);
}
.chip-inner-rect {
    position: absolute; top: 25%; left: 25%; width: 50%; height: 50%;
    border: 1px solid rgba(0,0,0,0.3); border-radius: 4px;
}

* --- JAVÍTOTT PROGRESS BAR (Lépcsőzetes címkék) --- */
.vip-roadmap { position: relative; margin-top: 50px; margin-bottom: 40px; height: 50px; }
.vip-roadmap .road-line { position:absolute; left:0; right:0; top:0; height:6px; border-radius:99px; background:#e5e7eb; z-index: 0; }
.dark .vip-roadmap .road-line { background:#374151; }

.vip-roadmap .road-car { 
    position:absolute; top:-16px; transform: translateX(-50%); transition: left 0.8s ease-in-out; z-index: 10; 
    width: 38px; height: 38px; display: flex; align-items: center; justify-content: center;
}
.vip-roadmap .road-car .car-dot { 
    width:100%; height:100%; border-radius:50%; background:#d63031; border: 3px solid #fff; 
    box-shadow: 0 4px 10px rgba(214,48,49,0.4); color:white; font-size: 14px; display:flex; align-items:center; justify-content:center;
}

.roadmap-stop { 
    position:absolute; top:-6px; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; z-index: 5; 
    width: 80px;
}
.roadmap-stop .stop-icon { 
    width:18px; height:18px; border-radius:50%; background:#9ca3af; border: 3px solid #fff; z-index: 6;
    margin-bottom: 8px; box-shadow: 0 2px 5px rgba(0,0,0,0.1);
}
.roadmap-stop.reached .stop-icon { background: #10b981; transform: scale(1.1); }

/* Címke alap */
.roadmap-stop .stop-label { 
    text-align: center; font-size: 10px; line-height: 1.2; color: #6b7280; font-weight: 700;
    width: 100%;
}
.roadmap-stop.reached .stop-label { color: #10b981; }

/* TRÜKK: Minden második címkét lejjebb tolunk, hogy elférjenek */
.roadmap-stop:nth-child(odd) .stop-label { margin-top: 5px; } 
.roadmap-stop:nth-child(even) .stop-label { margin-top: 25px; position: relative; }
/* Vonal a lenti címkékhez */
.roadmap-stop:nth-child(even) .stop-label::before {
    content: ''; position: absolute; top: -15px; left: 50%; width: 1px; height: 15px; background: #d1d5db;
}

/* --- TOOLTIP (Ajánlói infóhoz) --- */
.tooltip-trigger:hover + .tooltip-content { display: block; opacity: 1; transform: translateY(0); }
.tooltip-content {
    display: none; opacity: 0; transform: translateY(10px); transition: all 0.2s;
    position: absolute; bottom: 100%; right: 0; width: 260px;
    background: #1f2937; color: #fff; padding: 12px; border-radius: 12px;
    font-size: 11px; z-index: 50; box-shadow: 0 10px 30px rgba(0,0,0,0.3);
    line-height: 1.5; pointer-events: none;
}