/* Google Fonts */ @import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;600&display=swap'); :root { --bg-color: #0f172a; --card-bg: #1e293b; --text-color: #f1f5f9; --accent-color: #3b82f6; --accent-hover: #2563eb; --gradient-1: linear-gradient(135deg, #3b82f6 0%, #8b5cf6 100%); --glass-bg: rgba(30, 41, 59, 0.7); --border-color: rgba(255, 255, 255, 0.1); --container-max: 960px; } * { margin: 0; padding: 0; box-sizing: border-box; font-family: 'Outfit', sans-serif; } body { background-color: var(--bg-color); color: var(--text-color); min-height: 100vh; display: flex; flex-direction: column; align-items: center; padding: 2rem; } h1 { font-size: 2rem; font-weight: 600; margin-bottom: 2rem; text-align: center; background: var(--gradient-1); -webkit-background-clip: text; -webkit-text-fill-color: transparent; } .container { width: 100%; max-width: var(--container-max); display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 2rem; } /* Service Cards (Index) */ .card { background: var(--card-bg); padding: 2rem; border-radius: 1rem; border: 1px solid var(--border-color); transition: transform 0.3s ease, box-shadow 0.3s ease; text-decoration: none; color: inherit; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; } .card:hover { transform: translateY(-5px); box-shadow: 0 10px 20px rgba(0, 0, 0, 0.3); border-color: var(--accent-color); } .card h2 { font-size: 1.5rem; margin-bottom: 0.5rem; } .card p { color: #94a3b8; font-size: 0.9rem; } /* Forms & Service Pages */ .service-container { background: var(--card-bg); padding: 3rem; border-radius: 1rem; box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); width: 100%; max-width: 600px; border: 1px solid var(--border-color); } .service-title { margin-bottom: 1.5rem; text-align: center; } label { display: block; margin-bottom: 0.5rem; color: #cbd5e1; } input[type="text"], input[type="file"], textarea { width: 100%; padding: 0.75rem; margin-bottom: 1.5rem; background: var(--bg-color); border: 1px solid var(--border-color); border-radius: 0.5rem; color: var(--text-color); font-size: 1rem; } input[type="file"]::file-selector-button { background: var(--card-bg); color: var(--text-color); padding: 0.5rem 1rem; border: 1px solid var(--border-color); border-radius: 0.3rem; cursor: pointer; margin-right: 1rem; } button { width: 100%; padding: 0.6rem; background: var(--gradient-1); color: white; border: none; border-radius: 0.5rem; font-size: 0.98rem; font-weight: 600; cursor: pointer; transition: filter 0.18s ease; } button:hover { filter: brightness(1.1); } .result-box { margin-top: 2rem; padding: 1rem; background: rgba(59, 130, 246, 0.06); border: 1px solid rgba(59,130,246,0.12); border-radius: 0.5rem; text-align: center; } .back-link { display: block; margin-top: 1.5rem; text-align: center; color: var(--accent-color); text-decoration: none; } .back-link:hover { text-decoration: underline; } audio { width: 100%; margin-top: 10px; } /* Make images responsive and add subtle rounding */ img { max-width: 100%; height: auto; display: block; border-radius: 0.5rem; } /* Improve focus styles for accessibility */ input[type="text"], input[type="file"], textarea { transition: box-shadow 0.15s ease, border-color 0.15s ease; } input[type="text"]:focus, input[type="file"]:focus, textarea:focus { outline: none; box-shadow: 0 0 0 4px rgba(59,130,246,0.08); border-color: var(--accent-color); }