/* ===================================
   COMPONENTS — Cards, Buttons, Forms, Feeds
   =================================== */

/* --- Buttons --- */
.btn {
    display:inline-flex; align-items:center; justify-content:center; gap:var(--space-sm);
    padding:14px 32px; font-family:var(--font-body); font-size:0.9rem; font-weight:600;
    text-transform:uppercase; letter-spacing:1.5px; border:none; border-radius:var(--radius-full);
    cursor:pointer; transition:all var(--transition-normal); text-decoration:none;
    position:relative; overflow:hidden;
}
.btn-primary { background:var(--gradient-flame); color:white; box-shadow:0 4px 15px rgba(255,106,0,0.3); }
.btn-primary:hover { box-shadow:0 6px 25px rgba(255,106,0,0.5), 0 0 40px rgba(255,60,0,0.2), 0 0 60px rgba(255,106,0,0.1); transform:translateY(-2px); color:white; }
.btn-secondary { background:transparent; color:var(--accent); border:2px solid var(--accent); }
.btn-secondary:hover { background:rgba(255,106,0,0.1); box-shadow:0 0 20px rgba(255,106,0,0.3), 0 0 40px rgba(255,60,0,0.1); transform:translateY(-2px); color:var(--accent); border-color:rgba(255,140,0,0.8); }
.btn-gold { background:linear-gradient(135deg,#FFD700,#FF8C00); color:#000; font-weight:700; }
.btn-gold:hover { box-shadow:0 6px 25px rgba(255,215,0,0.4), 0 0 40px rgba(255,215,0,0.2), 0 0 60px rgba(255,140,0,0.1); transform:translateY(-2px); color:#000; }
.btn::after {
    content:''; position:absolute; top:-50%; left:-50%; width:200%; height:200%;
    background:linear-gradient(transparent,rgba(255,255,255,0.1),transparent);
    transform:rotate(45deg); transition:var(--transition-slow); opacity:0;
}
.btn:hover::after { opacity:1; transform:rotate(45deg) translate(50%,50%); }

/* --- Cards --- */
.card {
    background:var(--bg-card); border:1px solid rgba(255,106,0,0.25);
    border-radius:var(--radius-lg); padding:var(--space-lg);
    transition:all var(--transition-normal); position:relative; overflow:hidden;
    animation: neonPulse 4s ease-in-out infinite;
}
.card::before {
    content:''; position:absolute; inset:0;
    background:linear-gradient(135deg,rgba(255,106,0,0.05),transparent);
    opacity:0; transition:opacity var(--transition-normal);
}
.card:hover { border-color:rgba(255,140,0,0.7); transform:translateY(-5px); box-shadow:0 10px 40px rgba(255,106,0,0.2), 0 0 25px rgba(255,106,0,0.3), inset 0 0 12px rgba(255,106,0,0.05); animation: neonPulseIntense 2s ease-in-out infinite; }
.card:hover::before { opacity:1; }
.card-image { width:100%; height:200px; object-fit:cover; border-radius:var(--radius-md); margin-bottom:var(--space-md); }
.card-title { font-family:var(--font-heading); font-size:1.2rem; margin-bottom:var(--space-sm); color:#FF6A00; text-shadow: 0 0 5px rgba(255,106,0,0.4), 0 0 10px rgba(255,60,0,0.2); }
.card-description { color:var(--text-muted); font-size:0.9rem; margin-bottom:var(--space-md); }

/* --- Album Grid --- */
.album-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:var(--space-lg); }
.album-card {
    background:var(--bg-card); border:1px solid rgba(255,106,0,0.25);
    border-radius:var(--radius-lg); overflow:hidden; transition:all var(--transition-normal);
    cursor:pointer; text-decoration:none; display:block;
    animation: neonPulse 4s ease-in-out infinite;
}
.album-card:hover {
    border-color:rgba(255,140,0,0.8); transform:translateY(-8px) scale(1.02);
    box-shadow:0 15px 50px rgba(255,106,0,0.3), 0 0 35px rgba(255,106,0,0.35), 0 0 60px rgba(255,60,0,0.1);
    animation: neonPulseIntense 2s ease-in-out infinite;
}
.album-card-image {
    width:100%; height:200px; object-fit:cover;
    background:linear-gradient(135deg,rgba(255,106,0,0.2),rgba(255,60,0,0.1));
    display:flex; align-items:center; justify-content:center;
}
.album-card-image .album-icon { font-size:3rem; filter:drop-shadow(0 0 15px rgba(255,106,0,0.5)); }
.album-card-body { padding:var(--space-lg); }
.album-card-title { font-family:var(--font-heading); font-size:1.1rem; color:#FF6A00; margin-bottom:var(--space-sm); text-shadow: 0 0 5px rgba(255,106,0,0.4), 0 0 10px rgba(255,60,0,0.2); }
.album-card-subtitle { color:var(--text-muted); font-size:0.85rem; margin-bottom:var(--space-md); }

/* --- Feed Section --- */
.feed-section {
    background:var(--bg-card); border:1px solid rgba(255,106,0,0.25);
    border-radius:var(--radius-lg); padding:var(--space-xl); position:relative; overflow:hidden;
    animation: neonPulse 4s ease-in-out infinite;
}
.feed-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:var(--space-lg); }
.feed-title { display:flex; align-items:center; gap:var(--space-sm); font-family:'Orbitron', sans-serif; font-size:1.2rem; color:#FF6A00; text-shadow: 0 0 5px rgba(255,106,0,0.4), 0 0 10px rgba(255,60,0,0.2); letter-spacing:1px; }
.feed-icon { width:32px; height:32px; fill:var(--accent); }
.feed-embed { width:100%; border-radius:var(--radius-md); overflow:hidden; position:relative; }
.feed-embed iframe { width:100%; border:none; border-radius:var(--radius-md); }

/* --- Forms --- */
.form-group { margin-bottom:var(--space-lg); }
.form-label {
    display:block; font-size:0.85rem; font-weight:600; color:var(--text-secondary);
    margin-bottom:var(--space-sm); text-transform:uppercase; letter-spacing:1px;
}
.form-input, .form-textarea, .form-select {
    width:100%; padding:14px 18px; background:rgba(255,255,255,0.05);
    border:1px solid rgba(255,106,0,0.2); border-radius:var(--radius-md);
    color:var(--text-primary); font-family:var(--font-body); font-size:1rem;
    transition:var(--transition-fast); outline:none;
}
.form-input:focus, .form-textarea:focus, .form-select:focus {
    border-color:rgba(255,140,0,0.7); box-shadow:0 0 20px rgba(255,106,0,0.3), 0 0 40px rgba(255,60,0,0.1), inset 0 0 8px rgba(255,106,0,0.05);
    background:rgba(255,255,255,0.08);
    animation: neonPulseIntense 2s ease-in-out infinite;
}
.form-textarea { resize:vertical; min-height:120px; }
.form-input::placeholder, .form-textarea::placeholder { color:var(--text-muted); }

/* --- Link Cards --- */
.link-card {
    display:flex; align-items:center; gap:var(--space-lg);
    padding:var(--space-lg) var(--space-xl); background:var(--bg-card);
    border:1px solid rgba(255,106,0,0.25); border-radius:var(--radius-lg);
    text-decoration:none; transition:all var(--transition-normal); position:relative; overflow:hidden;
    animation: neonPulse 4s ease-in-out infinite;
}
.link-card::before {
    content:''; position:absolute; left:0; top:0; bottom:0; width:4px;
    background:var(--gradient-flame); box-shadow:0 0 10px rgba(255,106,0,0.5);
}
.link-card:hover { border-color:rgba(255,140,0,0.7); transform:translateX(5px); box-shadow:0 5px 30px rgba(255,106,0,0.25), 0 0 20px rgba(255,106,0,0.3); animation: neonPulseIntense 2s ease-in-out infinite; }
.link-card-icon {
    width:48px; height:48px; display:flex; align-items:center; justify-content:center;
    border-radius:var(--radius-md); background:rgba(255,106,0,0.1); color:var(--accent); flex-shrink:0;
}
.link-card-icon svg { width:24px; height:24px; fill:currentColor; }
.link-card-content { flex:1; }
.link-card-title { font-family:var(--font-heading); font-size:1.1rem; color:#FF6A00; margin-bottom:4px; text-shadow: 0 0 5px rgba(255,106,0,0.3); }
.link-card-url { font-size:0.8rem; color:var(--text-muted); }
.link-card-arrow { color:var(--accent); font-size:1.2rem; transition:transform var(--transition-fast); }
.link-card:hover .link-card-arrow { transform:translateX(5px); }

/* --- Comment Bubbles --- */
.comment-bubble {
    background:var(--bg-card); border:1px solid rgba(255,106,0,0.25);
    border-radius:var(--radius-lg); padding:var(--space-lg); margin-bottom:var(--space-md);
    position:relative; transition:var(--transition-fast);
    animation: neonPulse 4s ease-in-out infinite;
}
.comment-bubble:hover { border-color:rgba(255,140,0,0.6); box-shadow:0 0 25px rgba(255,106,0,0.25), 0 0 15px rgba(255,106,0,0.2); animation: neonPulseIntense 2.5s ease-in-out infinite; }
.comment-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:var(--space-sm); }
.comment-author { font-weight:600; color:var(--accent); font-size:0.95rem; }
.comment-time { font-size:0.75rem; color:var(--text-muted); }
.comment-text { color:var(--text-secondary); font-size:0.95rem; line-height:1.6; }
.comment-delete {
    background:none; border:none; color:var(--text-muted); cursor:pointer;
    font-size:0.8rem; transition:var(--transition-fast); padding:4px 8px; border-radius:var(--radius-sm);
}
.comment-delete:hover { color:var(--fire); background:rgba(255,60,0,0.1); }

/* --- Tip Jar --- */
.tip-amounts { display:flex; gap:var(--space-md); flex-wrap:wrap; justify-content:center; margin-bottom:var(--space-xl); }
.tip-amount {
    padding:var(--space-md) var(--space-xl); background:var(--bg-card);
    border:2px solid rgba(255,106,0,0.3); border-radius:var(--radius-lg);
    color:var(--gold); font-family:var(--font-heading); font-size:1.3rem;
    cursor:pointer; transition:all var(--transition-normal); min-width:100px; text-align:center;
}
.tip-amount:hover, .tip-amount.selected {
    border-color:var(--gold); background:rgba(255,215,0,0.1);
    box-shadow:0 0 25px rgba(255,215,0,0.2); transform:translateY(-3px);
}
.tip-custom-input {
    padding:var(--space-md) var(--space-lg); background:var(--bg-card);
    border:2px solid rgba(255,106,0,0.3); border-radius:var(--radius-lg);
    color:var(--gold); font-family:var(--font-heading); font-size:1.3rem;
    width:150px; text-align:center; outline:none;
}
.tip-custom-input:focus { border-color:var(--gold); box-shadow:0 0 15px rgba(255,215,0,0.2); }

/* --- Blog Cards --- */
.blog-grid { display:grid; gap:var(--space-lg); }
.blog-card {
    background:var(--bg-card); border:1px solid rgba(255,106,0,0.25);
    border-radius:var(--radius-lg); padding:var(--space-xl);
    transition:all var(--transition-normal); cursor:pointer; text-decoration:none; display:block;
    animation: neonPulse 4s ease-in-out infinite;
}
.blog-card:hover { border-color:rgba(255,140,0,0.7); transform:translateY(-3px); box-shadow:0 10px 40px rgba(255,106,0,0.2), 0 0 20px rgba(255,106,0,0.3); animation: neonPulseIntense 2s ease-in-out infinite; }
.blog-card-date { font-size:0.8rem; color:var(--accent); text-transform:uppercase; letter-spacing:1px; margin-bottom:var(--space-sm); }
.blog-card-title { font-family:var(--font-heading); font-size:1.4rem; color:#FF6A00; margin-bottom:var(--space-sm); text-shadow: 0 0 5px rgba(255,106,0,0.4), 0 0 10px rgba(255,60,0,0.2); }
.blog-card-excerpt { color:var(--text-muted); font-size:0.95rem; line-height:1.6; }

/* --- Auth Modal --- */
.auth-modal-overlay {
    position:fixed; inset:0; background:rgba(0,0,0,0.8); backdrop-filter:blur(10px);
    z-index:2000; display:none; align-items:center; justify-content:center;
}
.auth-modal-overlay.active { display:flex; }
.auth-modal {
    background:var(--bg-card); border:1px solid rgba(255,106,0,0.4);
    border-radius:var(--radius-xl); padding:var(--space-xl); max-width:420px; width:90%;
    position:relative; animation:scaleIn 0.3s ease, neonPulseIntense 3s ease-in-out 0.3s infinite;
    box-shadow:0 20px 60px rgba(0,0,0,0.5), 0 0 40px rgba(255,106,0,0.15), 0 0 80px rgba(255,60,0,0.05);
}
.auth-modal-close {
    position:absolute; top:var(--space-md); right:var(--space-md);
    background:none; border:none; color:var(--text-muted); font-size:1.5rem;
    cursor:pointer; transition:var(--transition-fast); width:36px; height:36px;
    display:flex; align-items:center; justify-content:center; border-radius:50%;
}
.auth-modal-close:hover { color:var(--accent); background:rgba(255,106,0,0.1); }
.auth-modal-title { font-family:'Orbitron', sans-serif; font-size:1.3rem; text-align:center; margin-bottom:var(--space-lg); color:#FF6A00; text-shadow: 0 0 7px #FF6A00, 0 0 15px rgba(255,106,0,0.5); letter-spacing:2px; }
.auth-toggle { text-align:center; margin-top:var(--space-lg); color:var(--text-muted); font-size:0.9rem; }
.auth-toggle a { color:var(--accent); cursor:pointer; font-weight:600; }

/* --- Video Grid --- */
.video-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(350px,1fr)); gap:var(--space-lg); }
.video-card {
    border-radius:var(--radius-lg); overflow:hidden; background:var(--bg-card);
    border:1px solid rgba(255,106,0,0.25); transition:all var(--transition-normal);
    animation: neonPulse 4s ease-in-out infinite;
}
.video-card:hover { border-color:rgba(255,140,0,0.7); box-shadow:0 10px 40px rgba(255,106,0,0.2), 0 0 25px rgba(255,106,0,0.3); transform:translateY(-5px); animation: neonPulseIntense 2s ease-in-out infinite; }
.video-card iframe { width:100%; aspect-ratio:16/9; display:block; border:none; }
.video-card-info { padding:var(--space-md); }
.video-card-title { font-size:0.95rem; color:var(--text-primary); font-weight:500; }

/* --- Page Headers --- */
.page-header { text-align:center; padding:var(--space-2xl) 0; position:relative; }
.page-header-title {
    font-family: 'Orbitron', sans-serif;
    font-size: clamp(1.8rem, 5vw, 3rem);
    font-weight: 800;
    color: #FF6A00;
    letter-spacing: 3px;
    text-transform: uppercase;
    margin-bottom: var(--space-sm);
    text-shadow:
        0 0 7px #FF6A00,
        0 0 15px #FF6A00,
        0 0 30px #FF3C00,
        0 0 50px #FF3C00,
        0 0 80px rgba(255,60,0,0.4),
        0 0 120px rgba(255,60,0,0.2);
    animation: neonTextPulse 3s ease-in-out infinite;
}
.page-header-subtitle {
    color: var(--text-muted);
    font-size: 1.1rem;
    letter-spacing: 3px;
    text-transform: uppercase;
    font-family: var(--font-body);
    font-weight: 300;
}

/* --- Toast --- */
.toast {
    position:fixed; bottom:30px; right:30px; padding:var(--space-md) var(--space-xl);
    background:var(--bg-card); border:1px solid var(--accent); border-radius:var(--radius-md);
    color:var(--text-primary); font-size:0.9rem; z-index:3000;
    animation:slideInRight 0.3s ease;
    box-shadow:0 10px 30px rgba(0,0,0,0.3), 0 0 15px rgba(255,106,0,0.2);
}
.toast.success { border-color:#4CAF50; }
.toast.error { border-color:var(--fire); }

/* --- Auth Gate --- */
.auth-gate {
    text-align:center; padding:var(--space-2xl);
    display:flex; flex-direction:column; align-items:center; gap:var(--space-lg);
}
.auth-gate-icon { font-size:4rem; animation:fireFlicker 2s ease-in-out infinite; }
.auth-gate-title {
    font-family: 'Orbitron', sans-serif;
    font-size: 1.5rem;
    color: #FF6A00;
    text-shadow: 0 0 7px #FF6A00, 0 0 15px #FF6A00, 0 0 30px rgba(255,60,0,0.4);
    letter-spacing: 2px;
}
.auth-gate-text { color:var(--text-muted); max-width:400px; }
