/* ---
AISUCKS.IO | Immersive Interface v6.5
--- */
:root {
    --bg: #000000; --text: rgba(230, 230, 255, 0.85); --text-strong: #FFFFFF; --text-soft: rgba(230, 230, 255, 0.4); --line: rgba(230, 230, 255, 0.15); --glow: #FFFFFF; --accent-soft: rgba(255, 255, 255, 0.07); --card-bg: rgba(15, 15, 20, 0.5); --submit-text: #000000;
}
body.theme-light {
    --bg: #F9F9FD; --text: #4A4A6A; --text-strong: #1A1A3A; --text-soft: rgba(74, 74, 106, 0.5); --line: rgba(74, 74, 106, 0.1); --glow: #1A1A3A; --accent-soft: rgba(26, 26, 58, 0.05); --card-bg: rgba(255, 255, 255, 0.7); --submit-text: #F9F9FD;
}
* { margin: 0; padding: 0; box-sizing: border-box; user-select: none; }
body { font-family: 'Inter', sans-serif; background: var(--bg); color: var(--text); -webkit-font-smoothing: antialiased; transition: background-color 0.6s ease, color 0.6s ease; cursor: none; }
a, button, input, textarea, .radio-label { cursor: auto; }

#top-left-info { position: fixed; top: 24px; left: 24px; font-family: 'IBM Plex Mono', monospace; color: var(--text-soft); font-size: 0.875rem; z-index: 200; line-height: 1.5; pointer-events: none; }
#tagline { color: var(--text-strong); font-weight: 700; }
#terminal-log { position: fixed; bottom: 20px; left: 20px; width: 350px; height: 150px; font-family: 'IBM Plex Mono', monospace; color: var(--text-soft); font-size: 0.75rem; line-height: 1.6; overflow-y: auto; opacity: 0; transition: opacity 0.5s ease; z-index: 50; scrollbar-width: none; }
#terminal-log::-webkit-scrollbar { display: none; }
#terminal-log.active { opacity: 1; }
#terminal-log .log-entry { opacity: 0; animation: fadeIn 0.5s forwards; }
#scan-report, #shadow-report { font-family: 'IBM Plex Mono', monospace; white-space: pre-wrap; line-height: 2; text-align: center; padding: 6rem 2rem; opacity: 0; transform: translateY(40px); transition: opacity 0.8s ease, transform 0.8s ease; display: none; }
#scan-report.visible, #shadow-report.visible { display: block; opacity: 1; transform: translateY(0); }
#decode-button, #consultation-button { color: var(--glow); text-decoration: none; border: 1px solid var(--glow); padding: 0.75rem 1.5rem; pointer-events: auto; display: inline-block; transition: all 0.3s ease; font-family: 'IBM Plex Mono', monospace; font-size: 1rem; font-weight: 700; background-color: transparent; }
#decode-button:hover, #decode-button:disabled, #consultation-button:hover { background: var(--glow); color: var(--bg); }
#decode-button:disabled { opacity: 0.5; }
.metric-interpretation { color: var(--text-soft); font-size: 0.875rem; margin-left: 1rem; }
#narrative-closure { margin-top: 3rem; line-height: 2.5; color: var(--text-strong); }
#report-actions, #consultation-cta { margin-top: 3rem; display: flex; justify-content: center; align-items: center; gap: 1.5rem; flex-wrap: wrap; }
.cursor { position: fixed; width: 24px; height: 24px; border: 1px solid var(--text-soft); border-radius: 50%; pointer-events: none; z-index: 9999; transform: translate(-50%, -50%); transition: transform 0.15s ease-out, border-color 0.6s ease, background-color 0.2s ease; mix-blend-mode: difference; }
.cursor.active { transform: translate(-50%, -50%) scale(0.5); background-color: var(--text-strong); }
.cursor.hover-link { transform: translate(-50%, -50%) scale(1.6); }
#progress-bar { position: fixed; top: 0; left: 0; height: 2px; width: 0%; background: var(--glow); z-index: 101; transition: width 0.1s linear; }
.top-nav { position: fixed; top: 24px; right: 24px; display: flex; justify-content: flex-end; align-items: center; z-index: 100; gap: 1.5rem; }

.nav-link { pointer-events: auto; font-family: 'IBM Plex Mono', monospace; color: var(--text-strong); text-decoration: none; font-weight: 700; font-size: 1rem; letter-spacing: 1px; transition: all 0.2s ease-in-out; }
.nav-link:hover { transform: scale(1.05); letter-spacing: 0.05em; color: var(--text-soft); }

.container { max-width: 900px; margin: 0 auto; padding: 20vh 24px; }
.manifesto { min-height: 80vh; display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; }
.brand-title { font-family: 'IBM Plex Mono', monospace; font-size: 1rem; font-weight: 700; color: var(--glow); letter-spacing: 0.2em; text-transform: uppercase; margin-bottom: 3rem; }
.manifesto p { font-family: 'IBM Plex Mono', monospace; font-size: clamp(1.2rem, 3vw, 2rem); line-height: 1.7; margin-bottom: 2.5rem; max-width: 50ch; color: var(--text-strong); }
#scan, #offers { padding-top: 5rem; transition: opacity 0.5s ease-out; }
#roast-form { width: 100%; position: relative; min-height: 400px; }
.form-group { opacity: 0; visibility: hidden; position: absolute; width: 100%; transition: opacity 0.4s ease-in-out; }
.form-group.active { opacity: 1; visibility: visible; position: relative; animation: slideInUp 0.5s ease-out; }
.form-group label { display: block; font-size: clamp(1.25rem, 3vw, 1.75rem); margin-bottom: 2.5rem; line-height: 1.5; color: var(--text-strong); }
input[type="text"], input[type="email"], textarea { background-color: transparent; color: var(--text); font-family: 'Inter', sans-serif; font-size: 1.125rem; border: 1px solid var(--line); border-radius: 8px; padding: 1rem; width: 100%; transition: border-color 0.3s ease; pointer-events: auto; }
input[type="text"]:focus, input[type="email"]:focus, textarea:focus { outline: none; border-color: var(--glow); }
textarea { min-height: 150px; resize: vertical; }
.radio-group { display: flex; flex-direction: column; gap: 1rem; }
.radio-label { display: flex; align-items: center; font-size: 1.125rem; color: var(--text); padding: 1rem; border: 1px solid var(--line); border-radius: 8px; transition: border-color 0.3s, background-color 0.3s; pointer-events: auto; }
.radio-label:hover { border-color: var(--text-soft); }
.radio-label input[type="radio"] { opacity: 0; width: 0; height: 0; }
.radio-custom { width: 1em; height: 1em; border: 1px solid var(--text-soft); border-radius: 50%; margin-right: 1rem; flex-shrink: 0; transition: border-color 0.3s, background-color 0.3s; }
.radio-label input[type="radio"]:checked ~ .radio-custom { background-color: var(--glow); border-color: var(--glow); }
.radio-label input[type="radio"]:checked ~ span { color: var(--text-strong); }
.form-navigation { margin-top: 3rem; display: flex; justify-content: space-between; align-items: center; font-family: 'IBM Plex Mono', monospace; font-size: 1rem; color: var(--text-soft); min-height: 40px; }
.form-meta { display: flex; gap: 1.5rem; }
.nav-button, .submit-button { pointer-events: auto; background-color: transparent; color: var(--text-strong); font-family: 'IBM Plex Mono', monospace; font-size: 1rem; font-weight: 700; padding: 0.75rem 1.5rem; border: 1px solid var(--line); border-radius: 999px; transition: all 0.3s ease; }
.nav-button:hover { border-color: var(--text-strong); background-color: var(--accent-soft); }
.submit-button { background-color: var(--glow); border-color: var(--glow); color: var(--submit-text); }
.submit-button:hover { transform: scale(1.05); }
.footer { text-align: center; padding: 4rem 0 2rem 0; margin-top: 5rem; border-top: 1px solid var(--line); }
.footer p { font-size: 0.875rem; color: var(--text-soft); line-height: 1.6; max-width: 45ch; margin: 0 auto; }
#theme-switcher { position: fixed; bottom: 24px; right: 24px; width: 48px; height: 48px; background: var(--card-bg); border: 1px solid var(--line); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 20px; color: var(--text-soft); z-index: 300; transition: all 0.5s ease; pointer-events: auto; }
#theme-switcher:hover { border-color: var(--text); color: var(--text); transform: scale(1.1) rotate(-180deg); }

.response-box { border: 1px solid var(--line); border-radius: 8px; padding: 2rem; background: var(--card-bg); margin-top: 2rem; }
.response-box pre { white-space: pre-wrap; font-family: 'IBM Plex Mono', monospace; font-size: 0.9rem; line-height: 1.6; color: var(--text); margin: 0; }

/* --- Styles for Offers Section --- */
.offer-card {
    background-color: transparent;
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 2.5rem 2rem;
    display: flex;
    flex-direction: column;
    text-align: left;
    min-height: 480px;
    transition: border-color 0.3s ease, transform 0.3s ease;
    position: relative;
}
.offer-card:hover {
    transform: translateY(-5px);
    border-color: var(--text-soft);
}
.tier-name {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--text-strong);
    margin-bottom: 0.75rem;
}
.tier-price {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 1.125rem;
    color: var(--text);
    margin-bottom: 1rem;
}
.micro-tagline {
    font-family: 'Inter', sans-serif;
    font-style: italic;
    font-size: 0.8rem;
    color: var(--text-soft);
    margin-bottom: 2rem;
}
.tier-desc {
    color: var(--text);
    line-height: 1.8;
    flex-grow: 1;
    margin-bottom: 2.5rem;
    list-style-type: '- ';
    list-style-position: outside;
    padding-left: 1rem;
}
.tier-desc li {
    padding-left: 0.5rem;
    margin-bottom: 0.75rem;
}
.stripe-button-container {
    margin-top: auto;
    width: 100%;
    display: flex;
    justify-content: center;
}
.offer-button {
    pointer-events: auto;
    text-align: center;
    text-decoration: none;
    background-color: transparent;
    color: var(--text-strong);
    font-family: 'IBM Plex Mono', monospace;
    font-size: 1rem;
    font-weight: 700;
    padding: 0.875rem 1.5rem;
    border: 1px solid transparent; /* Border is initially transparent */
    border-radius: 8px;
    transition: all 0.3s ease;
    margin-top: auto;
}
.offer-button:hover {
    background-color: var(--accent-soft);
    border-color: var(--line); /* Border appears on hover */
    color: var(--text-strong);
}

@keyframes slideInUp { from { transform: translateY(30px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
@keyframes fadeIn { to { opacity: 1; } }
@media (hover: none) { .cursor { display: none; } * { cursor: auto; } }

@media (max-width: 768px) {
    .container { padding: 15vh 16px; }
    #top-left-info { 
        left: 16px; 
        top: 16px; 
        right: auto;
        max-width: 50%;
    }
    .top-nav { 
        padding: 16px;
        left: auto;
        right: 16px;
    }
    #terminal-log { display: none; }
}
