/* ============================================================================ Stegasoo - Main Stylesheet ============================================================================ */ /* ---------------------------------------------------------------------------- CSS Variables ---------------------------------------------------------------------------- */ :root { --gradient-start: #667eea; --gradient-end: #764ba2; --bg-dark-1: #1a1a2e; --bg-dark-2: #16213e; --bg-dark-3: #0f3460; --text-muted: rgba(255, 255, 255, 0.5); --border-light: rgba(255, 255, 255, 0.1); --overlay-dark: rgba(0, 0, 0, 0.3); --overlay-light: rgba(255, 255, 255, 0.05); } /* ---------------------------------------------------------------------------- Base Styles ---------------------------------------------------------------------------- */ body { min-height: 100vh; background: linear-gradient(135deg, var(--bg-dark-1) 0%, var(--bg-dark-2) 50%, var(--bg-dark-3) 100%); } /* ---------------------------------------------------------------------------- Navigation ---------------------------------------------------------------------------- */ .navbar { background: var(--overlay-dark) !important; backdrop-filter: blur(10px); } /* ---------------------------------------------------------------------------- Cards ---------------------------------------------------------------------------- */ .card { background: var(--overlay-light); backdrop-filter: blur(10px); border: 1px solid var(--border-light); } .card-header { background: linear-gradient(135deg, var(--gradient-start), var(--gradient-end)); border-bottom: none; } .card-link .card-header.text-center { padding-top: 0.5rem !important; padding-bottom: 0.5rem !important; height: 4.5rem; /* Fixed height to match original */ display: flex; align-items: center; justify-content: center; } .feature-card { transition: transform 0.3s ease, box-shadow 0.3s ease; } .feature-card:hover { transform: translateY(-5px); box-shadow: 0 10px 40px rgba(102, 126, 234, 0.2); } /* ---------------------------------------------------------------------------- Buttons ---------------------------------------------------------------------------- */ .btn-primary { background: linear-gradient(135deg, var(--gradient-start), var(--gradient-end)); border: none; } .btn-primary:hover { background: linear-gradient(135deg, var(--gradient-end), var(--gradient-start)); transform: translateY(-2px); box-shadow: 0 5px 20px rgba(102, 126, 234, 0.4); } /* ---------------------------------------------------------------------------- Forms ---------------------------------------------------------------------------- */ .form-control, .form-select { background: var(--overlay-light); border: 1px solid var(--border-light); color: #fff; } .form-control:focus, .form-select:focus { background: rgba(255, 255, 255, 0.1); border-color: var(--gradient-start); box-shadow: 0 0 0 0.25rem rgba(102, 126, 234, 0.25); color: #fff; } .form-control::placeholder { color: var(--text-muted); } /* Fix dropdown options for dark theme */ .form-select option { background: var(--bg-dark-1); color: #fff; } /* ---------------------------------------------------------------------------- Hero & Icons ---------------------------------------------------------------------------- */ .hero-icon { font-size: 4rem; background: linear-gradient(135deg, var(--gradient-start), var(--gradient-end)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; } /* ---------------------------------------------------------------------------- Phrase Display ---------------------------------------------------------------------------- */ .phrase-display { font-family: 'Courier New', monospace; font-size: 1rem; background: var(--overlay-dark); padding: 0.5rem 0.75rem; border-radius: 0.5rem; border-left: 4px solid var(--gradient-start); display: inline-block; line-height: 1.6; word-spacing: 0.3rem; } /* ---------------------------------------------------------------------------- PIN Display ---------------------------------------------------------------------------- */ .pin-display { font-family: 'Courier New', monospace; font-size: 3rem; font-weight: bold; letter-spacing: 0.75rem; background: linear-gradient(135deg, #fef08a, #fcd34d, #fb923c); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; display: inline-block; line-height: 1; } .pin-container { background: var(--overlay-dark); border: 1px solid var(--border-light); border-radius: 0.75rem; padding: 1.5rem 2rem; display: inline-block; } /* ---------------------------------------------------------------------------- Story Cards (Memory Aid) ---------------------------------------------------------------------------- */ .story-word { color: #ff6b6b; font-weight: bold; text-transform: uppercase; } .story-card { background: rgba(0, 0, 0, 0.2); border-left: 3px solid var(--gradient-start); padding: 1rem; margin-bottom: 0.75rem; border-radius: 0.5rem; font-size: 0.95rem; line-height: 1.6; } .story-card .day-label { font-weight: bold; color: var(--gradient-start); margin-bottom: 0.5rem; } /* ---------------------------------------------------------------------------- Alert / Message Display ---------------------------------------------------------------------------- */ .alert-message { background: var(--overlay-dark); border: 1px solid var(--border-light); border-radius: 0.5rem; padding: 1.5rem; white-space: pre-wrap; font-family: 'Courier New', monospace; } /* ---------------------------------------------------------------------------- Drop Zone (Drag & Drop File Upload) ---------------------------------------------------------------------------- */ .drop-zone { position: relative; border: 2px dashed rgba(255, 255, 255, 0.2); border-radius: 0.5rem; padding: 1.5rem; text-align: center; transition: all 0.2s ease; } .drop-zone.drag-over { border-color: var(--gradient-start); background: rgba(102, 126, 234, 0.1); } .drop-zone input[type="file"] { position: absolute; inset: 0; opacity: 0; cursor: pointer; } .drop-zone-label { pointer-events: none; } .drop-zone-preview { max-height: 120px; border-radius: 0.375rem; margin-top: 0.75rem; } /* ---------------------------------------------------------------------------- Footer ---------------------------------------------------------------------------- */ footer { background: rgba(0, 0, 0, 0.2); } /* ---------------------------------------------------------------------------- Custom Alert Variants ---------------------------------------------------------------------------- */ .alert-success-bright { background: rgba(34, 197, 94, 0.2); border-color: #22c55e; color: #4ade80; } /* ---------------------------------------------------------------------------- Utility Classes ---------------------------------------------------------------------------- */ .bg-dark-subtle { background: rgba(0, 0, 0, 0.2); } .status-box { background: rgba(0, 0, 0, 0.2); padding: 1rem; border-radius: 0.5rem; } .result-icon { font-size: 4rem; } .footer-icon { vertical-align: text-bottom; } /* ---------------------------------------------------------------------------- Card Stuff Icons ---------------------------------------------------------------------------- */ .action-card { transition: transform 0.2s ease, box-shadow 0.2s ease; } .action-card:hover { transform: translateY(-5px); box-shadow: 0 10px 20px rgba(0,0,0,0.1) !important; } .feature-card { border-radius: 10px; overflow: hidden; } /* Ensure buttons are easily tappable on mobile */ @media (max-width: 768px) { .btn-lg { padding: 1rem 1.5rem; font-size: 1.1rem; } .card { margin-bottom: 1rem; } } /* ---------------------------------------------------------------------------- Dramatic Gold Glow Hover Effect ---------------------------------------------------------------------------- */ .embossed-icon { color: #f8f8f8 !important; text-shadow: /* Subtle emboss only by default */ 0 0.5px 0 rgba(255, 255, 255, 0.4), /* Soft top highlight */ 0 -0.5px 0 rgba(0, 0, 0, 0.15), /* Very soft bottom shadow */ 0 1px 2px rgba(0, 0, 0, 0.1); /* Minimal drop shadow */ position: relative; display: inline-block; transition: all 0.3s ease; font-size: 3.5rem !important; line-height: 1; padding: 10px 0; } .card-link:hover .embossed-icon { color: #ffffff !important; text-shadow: /* GOLD GLOW LAYERS - Only on hover */ 0 0 10px rgba(255, 215, 0, 0.5), /* Soft inner glow */ 0 0 20px rgba(255, 215, 0, 0.3), /* Medium glow */ 0 0 30px rgba(255, 215, 0, 0.2), /* Outer glow */ 0 0 40px rgba(255, 215, 0, 0.1), /* Far outer glow */ /* Enhanced emboss on hover */ 0 1px 0 rgba(255, 255, 255, 0.8), /* Bright top highlight */ 0 -1px 0 rgba(0, 0, 0, 0.25), /* Deeper bottom shadow */ 0 2px 4px rgba(0, 0, 0, 0.15), /* Soft drop shadow */ /* Gold accent shadows */ 0 1px 2px rgba(255, 215, 0, 0.3), /* Gold highlight layer */ 0 -1px 1px rgba(255, 215, 0, 0.15); /* Gold shadow layer */ filter: drop-shadow(0 0 8px rgba(255, 215, 0, 0.25)); transform: scale(1.02); /* Slight grow on hover */ } /* Card header adjustments for dramatic effect */ .card-link .card-header.text-center { padding-top: 1.25rem !important; padding-bottom: 1.25rem !important; min-height: 6.5rem; display: flex; align-items: center; justify-content: center; position: relative; transition: all 0.3s ease; } /* Enhance the gradient on hover for dramatic effect */ .card-link:hover .card-header.text-center { background: linear-gradient(135deg, var(--gradient-start) 0%, #5a67d8 20%, var(--gradient-end) 80%, #8a2be2 100%); box-shadow: inset 0 0 20px rgba(255, 215, 0, 0.1); } /* Mobile adjustments */ @media (max-width: 768px) { .embossed-icon { font-size: 2.8rem !important; padding: 8px 0; } .card-link:hover .embossed-icon { transform: scale(1.01); } .card-link .card-header.text-center { padding-top: 1rem !important; padding-bottom: 1rem !important; min-height: 5.5rem; } } /* ---------------------------------------------------------------------------- Card Links ---------------------------------------------------------------------------- */ .card-link { text-decoration: none; color: inherit; display: block; height: 100%; } .card-link:hover { color: inherit; } /* Optional: Add a slight scale effect to the entire card on hover */ .card-link .feature-card { transition: transform 0.3s ease, box-shadow 0.3s ease; } .card-link:hover .feature-card { transform: translateY(-5px); box-shadow: 0 10px 40px rgba(102, 126, 234, 0.3); }