/* a CSS placeholder for a purple/indigo grid hacker theme with frosted glass */ /* Design tokens */ :root{ --bg: #2a0f4b; /* deep purple base */ --grid: rgba(0, 255, 200, 0.25); /* teal/green accent grid */ --card: rgba(255,255,255,.92); --card-border: rgba(0,0,0,.15); --text: #0b0b0b; --muted: #2a2a2a; --shadow: 0 8px 28px rgba(0,0,0,.28); --radius: 14px; } * { box-sizing: border-box; } html, body { height: 100%; } html { font-family: Inter, ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial; } body { margin: 0; color: var(--text); background: linear-gradient(135deg, rgba(42,15,75,.95), rgba(12,5,50,.95) 60%), var(--bg); /* cyan grid pattern overlay on purple base */ background-image: linear-gradient(to right, rgba(0,255,200,.25) 1px, transparent 1px), linear-gradient(to bottom, rgba(0,255,200,.25) 1px, transparent 1px); background-size: 20px 20px; min-height: 100vh; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; position: relative; overflow-x: hidden; } body::before{ content:""; position: fixed; inset: 0; background: radial-gradient(circle at 25% 15%, rgba(0,255,200,.15), transparent 40%), radial-gradient(circle at 75% 60%, rgba(255,0,170,.15), transparent 40%); mix-blend-mode: overlay; pointer-events: none; z-index: 0; filter: saturate(1.05); } header, main, footer { position: relative; z-index: 1; } /* Header */ header { text-align: center; padding: 1rem; } header h2 { margin: 0; font-size: .95rem; color: #e5e5ff; opacity: .95; } /* Main area */ main { padding: 0 1rem; } /* Hero section - mobile-first; two-column on larger screens */ .hero { display: grid; grid-template-columns: 1fr; gap: 1.6rem; align-items: center; justify-items: center; padding: 1.3rem; } /* Frosted glass text card */ .hero-copy { text-align: center; padding: 1.75rem; border-radius: var(--radius); max-width: 760px; background: rgba(255,255,255,.92); border: 1px solid rgba(0,0,0,.12); backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); box-shadow: var(--shadow); } .hero-copy h1 { font-size: clamp(1.9rem, 4vw, 2.6rem); margin: 0 0 .5rem; color: #0a0a0a; } .subhead { font-size: 1rem; color: #0e2a2a; margin-bottom: 1.25rem; } .cta { display: inline-block; padding: 1rem 1.8rem; font-weight: 700; font-size: 1.05rem; color: #041016; text-decoration: none; border-radius: 999px; background: linear-gradient(135deg, #2affd0 0%, #0bd6e3 60%, #0b8a9f 100%); border: 1px solid rgba(0,0,0,.15); box-shadow: 0 6px 20px rgba(0, 210, 200, .6); transition: transform .15s ease, box-shadow .15s ease; } .cta:hover { transform: translateY(-1px); box-shadow: 0 14px 26px rgba(0,210,200,.8); } .cta:focus-visible { outline: 3px solid #e6fff0; outline-offset: 3px; } /* Centerpiece image */ .hero-media { display: flex; justify-content: center; width: 100%; } .hero-media img { width: min(680px, 92%); height: auto; border-radius: 12px; box-shadow: 0 20px 40px rgba(0,0,0,.45); image-rendering: crisp-edges; } /* Footer */ footer { text-align: center; padding: 1rem; font-size: 0.92rem; } footer .advertisements a { color: #6af0ff; text-decoration: none; border-bottom: 1px dotted rgba(106,240,208,.5); } footer .advertisements a:hover { text-decoration: underline; } footer .gratitude { margin-top: .5rem; color: #e6fffb; } /* Desktop two-column layout: text left, image right */ @media (min-width: 860px) { .hero { grid-template-columns: 1.15fr 0.85fr; gap: 2rem; padding: 2rem; } .hero-copy { text-align: left; padding: 2rem; } .hero-copy h1 { font-size: 2.4rem; } .hero-media { align-self: center; } .hero-media img { width: 100%; max-width: 740px; } }