/* Overlay for background image readability */ #bg-overlay { position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(30, 30, 46, 0.8), rgba(30, 30, 46, 0.95)); z-index: 0; pointer-events: none; } #content-layer { position: relative; z-index: 10; display: flex; flex-direction: column; height: 100%; width: 100%; } /* Top Header */ .header-panel { padding: max(env(safe-area-inset-top), 16px) 20px 20px 20px; text-align: center; background: linear-gradient(to bottom, var(--surface-color), transparent); flex-shrink: 0; } /* Main Clicker Area */ .clicker-area { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; position: relative; } .main-button { width: 45vmin; height: 45vmin; max-width: 250px; max-height: 250px; background: var(--surface-color); border: 4px solid var(--accent-color); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 4rem; color: var(--accent-color); box-shadow: 0 0 30px rgba(203, 166, 247, 0.2), inset 0 0 20px rgba(0,0,0,0.5); transition: transform 0.1s cubic-bezier(0.175, 0.885, 0.32, 1.275), box-shadow 0.2s, border-color 0.2s; cursor: pointer; touch-action: manipulation; position: relative; z-index: 20; } .main-button:active { transform: scale(0.92); box-shadow: 0 0 10px rgba(203, 166, 247, 0.4), inset 0 0 30px rgba(0,0,0,0.8); border-color: var(--accent-hover); color: var(--accent-hover); } .main-button::after { content: ''; position: absolute; inset: -10px; border-radius: 50%; border: 2px dashed var(--accent-color); opacity: 0.3; animation: spin 20s linear infinite; pointer-events: none; } @keyframes spin { 100% { transform: rotate(360deg); } } /* Upgrades List */ .upgrades-panel { flex-shrink: 0; height: 45%; background: rgba(49, 50, 68, 0.8); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); border-top: 1px solid rgba(255,255,255,0.1); display: flex; flex-direction: column; border-top-left-radius: 24px; border-top-right-radius: 24px; overflow: hidden; box-shadow: 0 -5px 20px rgba(0,0,0,0.3); } .upgrades-header { padding: 16px; text-align: center; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; font-size: 0.9rem; color: var(--text-secondary); border-bottom: 1px solid rgba(255,255,255,0.05); background: rgba(0,0,0,0.2); flex-shrink: 0; } .upgrades-list { flex: 1; overflow-y: auto; padding: 12px; display: flex; flex-direction: column; gap: 12px; padding-bottom: max(env(safe-area-inset-bottom), 24px); } .upgrade-card { display: flex; align-items: center; background: rgba(0,0,0,0.2); border: 1px solid rgba(255,255,255,0.05); border-radius: 16px; padding: 12px; transition: all 0.2s ease; touch-action: manipulation; } .upgrade-card.affordable { background: rgba(203, 166, 247, 0.1); border-color: rgba(203, 166, 247, 0.3); cursor: pointer; } .upgrade-card.affordable:active { transform: scale(0.98); background: rgba(203, 166, 247, 0.2); } .upgrade-card.locked { opacity: 0.5; filter: grayscale(1); } .upgrade-icon { width: 48px; height: 48px; border-radius: 12px; background-color: var(--surface-color); background-size: cover; background-position: center; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; color: var(--accent-color); margin-right: 16px; flex-shrink: 0; box-shadow: inset 0 0 10px rgba(0,0,0,0.5); } .upgrade-info { flex: 1; } .upgrade-title { font-weight: 700; font-size: 1rem; margin-bottom: 2px; display: flex; align-items: center; gap: 6px; } .upgrade-effect { font-size: 0.8rem; color: var(--text-secondary); } .upgrade-cost { font-weight: 700; display: flex; align-items: center; gap: 6px; font-size: 1.1rem; } .affordable .upgrade-cost { color: var(--success-color); } .locked .upgrade-cost { color: var(--danger-color); } /* Floating Text Effects */ .float-text { position: absolute; color: var(--accent-color); font-weight: bold; font-size: 1.5rem; pointer-events: none; user-select: none; z-index: 100; text-shadow: 0 2px 5px rgba(0,0,0,0.5); animation: floatUp 1s ease-out forwards; } @keyframes floatUp { 0% { transform: translateY(0) scale(1); opacity: 1; } 100% { transform: translateY(-100px) scale(1.5); opacity: 0; } } /* Notifications */ #notification-container { position: fixed; top: 20px; left: 50%; transform: translateX(-50%); z-index: 1000; display: flex; flex-direction: column; gap: 10px; pointer-events: none; width: 90%; max-width: 400px; } .notification { background: var(--surface-color); color: white; padding: 12px 20px; border-radius: 12px; border-left: 4px solid var(--accent-color); box-shadow: 0 4px 15px rgba(0,0,0,0.3); display: flex; align-items: center; gap: 10px; animation: slideDown 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards, fadeOut 0.3s ease 2.7s forwards; font-weight: 600; font-size: 0.95rem; } @keyframes slideDown { from { transform: translateY(-50px); opacity: 0; } to { transform: translateY(0); opacity: 1; } } @keyframes fadeOut { from { opacity: 1; } to { opacity: 0; } } .stat-box { background: rgba(0,0,0,0.3); border-radius: 12px; padding: 10px 20px; display: inline-block; border: 1px solid rgba(255,255,255,0.05); } .pulse-text { animation: pulseColor 2s infinite; } @keyframes pulseColor { 0%, 100% { color: var(--text-primary); } 50% { color: var(--accent-color); } } .restore-btn { background: var(--accent-color); color: var(--bg-color); padding: 8px 16px; border-radius: 8px; font-weight: 800; margin-top: 10px; display: inline-block; cursor: pointer; box-shadow: 0 4px 10px rgba(203, 166, 247, 0.3); transition: transform 0.1s; text-transform: uppercase; font-size: 0.8rem; letter-spacing: 1px; } .restore-btn:active { transform: scale(0.95); } /* Success Screen Overlay */ #success-screen { position: absolute; inset: 0; background: rgba(30, 30, 46, 0.95); z-index: 5000; display: flex; flex-direction: column; align-items: center; justify-content: center; visibility: hidden; opacity: 0; pointer-events: none; transition: opacity 0.5s ease, visibility 0.5s; padding: 20px; text-align: center; } #success-screen.visible { visibility: visible; opacity: 1; pointer-events: auto; } .success-icon { font-size: 5rem; color: var(--success-color); margin-bottom: 20px; animation: floatUpDown 3s ease-in-out infinite; filter: drop-shadow(0 0 20px rgba(166, 227, 161, 0.5)); } @keyframes floatUpDown { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-15px); } }