/**
 * FILE: frontend/css/styles.css
 * HYBRID AESTHETIC: Premium Editorial Newspaper + Clinical Forensics. Zero Inline Styles. Fluid Geometry Retained. Zero Rounded Corners.
 * LAST MODIFICATION: 2026-06-12
 */

:root {
    --paper: #fff1e5;
    --ink: #1a1a1a;
    --accent: #e31b23;
    --border: #d8c8b8;
    --white: #ffffff;
    
    --spacing-sm: clamp(0.5rem, 1vw, 1rem);
    --spacing-md: clamp(1rem, 2vw, 2rem);
    --spacing-lg: clamp(2rem, 4vw, 4rem);
    --spacing-xl: clamp(4rem, 8vw, 8rem);
    
    --text-xs: clamp(0.7rem, 0.8vw, 0.85rem);
    --text-base: clamp(1rem, 1.2vw, 1.15rem);
    --text-lg: clamp(1.2rem, 1.5vw, 1.5rem);
    --text-xl: clamp(2rem, 3vw, 2.5rem);
    --text-xxl: clamp(3rem, 6vw, 5rem);

    --bg-canvas: #f2efe9;    
    --bg-paper: #f9f8f6;     
    --ink-primary: #1c1d1a;  
    --ink-secondary: #5a5c54;
    --accent-red: #c92a2a;   
    --accent-hover: #a12222;
    --border-color: #dcd7ce; 
}

/* ==========================================================================
   RESET & TYPOGRAPHY
   ========================================================================== */
* { margin: 0; padding: 0; box-sizing: border-box; }

@font-face { font-family: 'Libre Baskerville'; font-style: normal; font-weight: 400; font-display: swap; src: url('../fonts/libre-baskerville-v24-latin-regular.woff2') format('woff2'); }
@font-face { font-family: 'Libre Baskerville'; font-style: italic; font-weight: 400; font-display: swap; src: url('../fonts/libre-baskerville-v24-latin-italic.woff2') format('woff2'); }
@font-face { font-family: 'Libre Baskerville'; font-style: normal; font-weight: 700; font-display: swap; src: url('../fonts/libre-baskerville-v24-latin-700.woff2') format('woff2'); }
@font-face { font-family: 'Oswald'; font-style: normal; font-weight: 400; font-display: swap; src: url('../fonts/oswald-v57-latin-regular.woff2') format('woff2'); }
@font-face { font-family: 'Oswald'; font-style: normal; font-weight: 700; font-display: swap; src: url('../fonts/oswald-v57-latin-700.woff2') format('woff2'); }
@font-face { font-family: 'JetBrains Mono'; font-style: normal; font-weight: 400; font-display: swap; src: url('../fonts/jetbrains-mono-v24-latin-regular.woff2') format('woff2'); }
@font-face { font-family: 'JetBrains Mono'; font-style: normal; font-weight: 700; font-display: swap; src: url('../fonts/jetbrains-mono-v24-latin-700.woff2') format('woff2'); }

body { 
    background-color: var(--bg-canvas); 
    color: var(--ink-primary); 
    font-family: 'Inter', sans-serif;
    line-height: 1.6;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    width: 100%;
}

h1, h2, h3, h4, h5, h6, p, span, div, .mono, .oswald { overflow-wrap: break-word; word-wrap: break-word; }
.serif-heading { font-family: 'Playfair Display', serif; }
.brand-heading { font-family: 'Oswald', sans-serif; text-transform: uppercase; letter-spacing: -1px; }
.sans-bold { font-family: 'Inter', sans-serif; font-weight: 800; }
.mono, .mono-text { font-family: 'JetBrains Mono', monospace; text-transform: uppercase; }
.oswald { font-family: 'Oswald', sans-serif; text-transform: uppercase; line-height: 1.1; }
.text-accent { color: var(--accent-red); }
.text-secondary { color: var(--ink-secondary); }
.text-center { text-align: center; }
.input-uppercase { text-transform: uppercase !important; }
.input-lowercase { text-transform: lowercase !important; }

/* SPACING UTILITIES */
.mt-md { margin-top: var(--spacing-md); }
.mt-sm { margin-top: var(--spacing-sm); }
.mt-xl { margin-top: var(--spacing-xl); }
.mt-auto { margin-top: auto; }

/* ==========================================================================
   CLINICAL BUTTONS (Formerly Brutalist)
   ========================================================================== */
.brutalist-button {
    display: inline-block;
    background: var(--ink-primary);
    color: var(--paper);
    font-family: 'JetBrains Mono', monospace; 
    font-weight: 700;
    text-transform: uppercase;
    border: 1px solid var(--ink-primary);
    padding: var(--spacing-md) var(--spacing-lg);
    font-size: var(--text-base);
    letter-spacing: 1px;
    cursor: pointer;
    transition: all 0.2s ease;
    text-align: center;
    width: 100%;
    border-radius: 0;
}
.brutalist-button:hover { 
    background: var(--accent-red); 
    color: var(--white); 
    border-color: var(--accent-red); 
}
.brutalist-button.inverse { 
    background: transparent; 
    color: var(--ink-primary); 
    border: 1px solid var(--ink-primary);
}
.brutalist-button.inverse:hover { 
    background: var(--ink-primary); 
    color: var(--white); 
}

/* ==========================================================================
   NEWSPAPER LAYOUT & COMPONENTS
   ========================================================================== */
.container { max-width: 1400px; margin: 0 auto; padding: 0 1rem; }

/* --- TICKER --- */
.ticker-wrapper {
    background: var(--ink-primary);
    color: #fff;
    padding: 8px 0;
    overflow: hidden;
    white-space: nowrap;
    font-size: 11px;
    font-family: 'JetBrains Mono', monospace;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    position: sticky;
    top: 0;
    z-index: 3000;
}
.ticker-content { display: inline-block; animation: ticker 250s linear infinite; }
.ticker-item { margin-right: 40px; }
.ticker-item::after { content: '///'; margin-left: 40px; color: var(--accent-red); }
@keyframes ticker { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

/* --- MASTHEAD --- */
.masthead { border-bottom: 1px solid var(--ink-primary); padding: 2rem 0; margin-bottom: 3rem; text-align: center; }
.masthead-meta { display: flex; justify-content: space-between; align-items: center; font-family: 'JetBrains Mono', monospace; font-size: 11px; text-transform: uppercase; color: var(--ink-secondary); border-bottom: 1px solid var(--border-color); padding-bottom: 0.5rem; margin-bottom: 1.5rem; }
.masthead-title { font-size: clamp(3rem, 7vw, 6rem); font-weight: 800; line-height: 0.9; letter-spacing: -1px; }

/* --- EDITORIAL GRID (ABOVE FOLD) --- */
.editorial-grid { display: grid; grid-template-columns: minmax(0, 1fr) 250px; gap: 3rem; align-items: start; position: relative; }
.editorial-grid::after { content: ''; position: absolute; top: 0; bottom: 0; right: calc(250px + 1.5rem); width: 1px; background-color: var(--border-color); }
@media (max-width: 992px) { .editorial-grid { grid-template-columns: 1fr; gap: 2rem; } .editorial-grid::after { display: none; } }

.label { display: inline-block; width: max-content; font-family: 'JetBrains Mono', monospace; font-size: 10px; text-transform: uppercase; letter-spacing: 1px; color: var(--accent-red); border: 1px solid var(--accent-red); padding: 3px 8px; margin-bottom: 1rem; }
.label-dark { color: var(--ink-primary); border-color: var(--ink-primary); }

.article-title { font-size: clamp(2.5rem, 4vw, 4rem); line-height: 1.1; margin-bottom: 1.5rem; font-weight: 700; letter-spacing: -0.5px; padding:0;}
.article-hero-img { width: 100%; height: auto; aspect-ratio: 16 / 9 / 1; object-fit: cover; border: 1px solid var(--border-color); margin-bottom: 2rem; filter: grayscale(100%) contrast(110%); }
.article-lead { font-size: 1.35rem; color: var(--ink-primary); margin-bottom: 2rem; line-height: 1.4; border-left: 2px solid var(--accent-red); padding-left: 1.5rem; }
.article-body p { margin-bottom: 1.5rem; font-size: 1.1rem; }

.action-module { background-color: transparent; border: 1px solid var(--ink-primary); padding: 2.5rem 1.5rem; margin-bottom: 2rem; }
.action-module-title { font-size: 1.5rem; margin-bottom: 1rem; line-height: 1.2; }
.action-module-desc { font-size: 0.9rem; margin-bottom: 1.5rem; color: var(--ink-secondary); }
.btn-primary { display: inline-block; width: 100%; padding: 16px; background-color: var(--accent-red); color: #fff; border: none; font-family: 'JetBrains Mono', monospace; font-weight: 700; font-size: 14px; text-transform: uppercase; letter-spacing: 1px; cursor: pointer; text-align: center; transition: background-color 0.2s; }
.btn-primary:hover { background-color: var(--ink-primary); }
.form-footnote { margin-top: 1.5rem; font-size: 0.8rem; color: var(--ink-secondary); text-align: center; font-family: 'JetBrains Mono', monospace; text-transform: uppercase; }

/* --- CLASSIFIEDS Base --- */
.sidebar-classifieds { display: flex; flex-direction: column; gap: 1.5rem; padding-top: 1rem; border-top: 1px dashed var(--border-color); }
.news-category-block { background-color: var(--ink-primary); color: var(--bg-paper); text-transform: uppercase; font-family: 'Inter', sans-serif; font-weight: 800; text-align: center; padding: 4px 0; margin: 0 0 10px 0; font-size: 15px; break-inside: avoid; page-break-inside: avoid; }
.news-ad { break-inside: avoid; page-break-inside: avoid; margin-bottom: 15px; font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif; font-size: 12px; line-height: 1.15; text-align: justify; color: var(--ink-primary); border-top: 1px solid #ccc; padding-top: 6px; }
.news-ad:first-child { border-top: none; padding-top: 0; }
.news-ad-title { font-weight: bold; text-transform: uppercase; margin-bottom: 2px; font-size: 12px; text-align: left; }
.news-ad-stars { text-align: center; margin: 4px 0; letter-spacing: 2px; font-size: 10px; }
.news-ad-premium { border: 1px solid var(--ink-primary); padding: 8px; margin-bottom: 15px; background: #fff; }
.news-ad-premium .news-ad-title { font-size: 14px; text-align: center; margin-bottom: 6px; }

/* --- OTHER SECTIONS --- */
.standalone-video { margin: 4rem 0; border-top: 1px solid var(--border-color); border-bottom: 1px solid var(--border-color); padding: 2rem 0; }
.yt-wrapper { max-width: 1200px; margin: 0 auto; }
.yt-video-container { width: 100%; aspect-ratio: 16 / 9; background-color: var(--ink-primary); position: relative; cursor: pointer; overflow: hidden; border: 1px solid var(--border-color); transition: opacity 0.2s; }
.yt-video-container:hover { opacity: 0.9; }
.yt-thumbnail { width: 100%; height: 100%; background-size: cover; background-position: center; opacity: 0.85; transition: opacity 0.3s; filter: grayscale(100%);}
.yt-video-container:hover .yt-thumbnail { opacity: 1; }
.yt-caption { width: 100%; text-align: center; margin: 1rem auto; }
.yt-play-btn { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); background: var(--accent-red); color: white; width: 60px; height: 60px; display: flex; align-items: center; justify-content: center; font-size: 24px; border-radius: 0; padding-left: 5px; }

.banner-img { margin:-2rem auto; width: 100%; max-width:800px; height:auto; border: 1px dashed var(--ink-secondary);}
.banner-div { margin:0 auto; width: 100%; text-align:center;}

.pain-section { margin-top: 5rem; border-top: 1px solid var(--border-color); padding-top: 3rem; display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: center; }
.pain-image img { width:100%; max-width:680px; filter: grayscale(100%); border: 1px solid var(--border-color); }
.pain-image-placeholder { background-color: var(--ink-primary); color: var(--bg-canvas); display: flex; align-items: center; justify-content: center; min-height: 400px; font-family: 'JetBrains Mono', monospace; text-align: center; padding: 2rem; border: 1px solid var(--border-color); }
.pain-text-wrapper { display: flex; flex-direction: column; justify-content: center; }
.pain-title { font-size: 2.2rem; line-height: 1.1; margin-bottom: 1rem; }
.pain-desc { font-size: 1.1rem; margin-bottom: 1.5rem; color: var(--ink-secondary); }
.pain-emphasis { font-size: 1.1rem; font-weight: 500; }
@media (max-width: 992px) { 
    .pain-section { grid-template-columns: 1fr; } 
    .pain-image-placeholder { min-height: 250px; }
}

.classifieds-section { margin-top: 5rem; border-top: 2px solid var(--ink-primary); padding-top: 2rem; }
.classifieds-header { text-align: center; border-bottom: 1px solid var(--border-color); padding-bottom: 1rem; margin-bottom: 2rem; }
.classifieds-title { font-size: 3rem; margin: 0; line-height: 1; }
.classifieds-subtitle { color: var(--ink-secondary); font-size: 0.85rem; letter-spacing: 2px; display: block; margin-top: 0.5rem; }
.newspaper-columns { column-width: 240px; column-gap: 20px; column-rule: 1px solid var(--border-color); }

.tools-section { margin-top: 5rem; padding-top: 3rem; border-top: 1px solid var(--border-color); }
.tools-section-title { font-size: 2rem; margin-bottom: 0.5rem; }
.tools-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1px; background-color: var(--border-color); border: 1px solid var(--border-color); margin-top: 2rem; }
.tool-card { background-color: var(--bg-canvas); padding: 2rem; display: flex; flex-direction: column; transition: background-color 0.2s; }
.tool-card:hover { background-color: var(--bg-paper); }
.tool-title { font-size: 1.25rem; margin-bottom: 0.5rem; font-weight: 600; }
.tool-desc { color: var(--ink-secondary); font-size: 0.95rem; flex-grow: 1; margin-bottom: 1.5rem; }
.tool-btn { align-self: flex-start; background: transparent; border: 1px solid var(--ink-primary); color: var(--ink-primary); padding: 8px 16px; font-family: 'JetBrains Mono', monospace; font-size: 12px; text-transform: uppercase; cursor: pointer; transition: all 0.2s; }
.tool-btn:hover { background: var(--ink-primary); color: var(--bg-canvas); }

footer { margin-top: 6rem; padding: 2rem 0; border-top: 1px solid var(--border-color); text-align: center; font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--ink-secondary); text-transform: uppercase; }

/* ==========================================================================
   MODALS (Standard Setup)
   ========================================================================== */
.main-site { transition: filter 0.5s ease, opacity 0.5s ease; min-height: 100vh; }
.main-site.blurred { opacity: 0.15; filter: blur(8px); pointer-events: none; user-select: none; }

.modal-overlay {
    position: fixed; inset: 0; background: rgba(0,0,0,0.95);
    backdrop-filter: blur(4px); z-index: 4000; display: flex;
    align-items: flex-start; justify-content: center; padding: 5vh 5vw;
    overflow-y: auto; overflow-x: hidden; opacity: 0; visibility: hidden; transition: opacity 0.3s ease;
}
.modal-overlay.active { opacity: 1; visibility: visible; }

.modal-container {
    background: var(--bg-paper); width: 100%; max-width: 1200px;
    height: auto; min-height: min-content; display: flex; flex-direction: column;
    position: relative; margin: auto; flex-shrink: 0;
    border: 1px solid var(--ink-primary);
}

.modal-header {
    display: flex; justify-content: space-between; align-items: center;
    padding: 1rem 1.5rem; border-bottom: 1px solid var(--border-color);
    background: var(--bg-canvas);
}
.modal-title-text { font-weight: 700; font-size: 14px; margin: 0; }
.modal-close { background: transparent; border: none; font-family: 'JetBrains Mono', monospace; font-size: 12px; cursor: pointer; text-transform: uppercase; color: var(--ink-secondary); }
.modal-close:hover { color: var(--accent-red); }

/* ==========================================================================
   CASE STUDY MODAL
   ========================================================================== */
.full-viewport-modal { padding: 0 !important; display: block !important; overflow: hidden !important; }
.full-viewport-modal .modal-container { width: 100vw; max-width: 100vw; height: 100vh; min-height: 100vh; margin: 0; border: none; overflow-y: auto; overflow-x: hidden; -webkit-overflow-scrolling: touch; }
.modal-header-black { background: var(--ink-primary); color: var(--bg-paper); padding: 1rem 2rem; display: flex; justify-content: space-between; align-items: center; position: sticky; top: 0; z-index: 100; border-bottom: 1px solid #333; }
.modal-header-black h3 { margin: 0; font-size: 1.2rem; letter-spacing: 1px; }
.modal-header-black .modal-close { background: transparent; color: var(--bg-paper); border: 1px solid var(--bg-paper); padding: 6px 16px; font-size: 12px; transition: all 0.2s; cursor: pointer; }
.modal-header-black .modal-close:hover { background: var(--bg-paper); color: var(--ink-primary); }

.modal-content-wrapper { max-width: 1200px; margin: 0 auto; padding: 4rem 1rem; width: 100%; padding-bottom: 120px; }
.case-study-header-wrap { margin-bottom: 4rem; }
.case-study-header-wrap .article-title { font-size: clamp(3rem, 6vw, 4.5rem); max-width: 1200px; margin: 0 auto; line-height: 1.05; }
.modal-hero-gate { margin-bottom: 3rem; background: var(--ink-primary); }
.modal-hero-img-gate { width: 100%; height: auto; aspect-ratio: 16 / 9 / 1; object-fit: cover; display: block; border-bottom: 2px solid var(--accent-red); filter: grayscale(100%) contrast(110%); }

.modal-article-body { max-width: 800px; margin: 0 auto; }
.modal-article-body .article-lead { font-size: 1.35rem; color: var(--ink-primary); margin-bottom: 2.5rem; line-height: 1.5; border-left: 2px solid var(--accent-red); padding-left: 1.5rem; }
.case-study-symptoms-box { background: transparent; padding: 2rem; border: 1px solid var(--border-color); margin-bottom: 2.5rem; }
.case-study-symptoms-title { font-size: 1rem; text-transform: uppercase; letter-spacing: 2px; color: var(--accent-red); margin-bottom: 1rem; border-bottom: 1px solid var(--border-color); padding-bottom: 0.5rem; }
.modal-mini-story { font-family: 'Inter', sans-serif; font-size: 1.15rem; line-height: 1.8; color: var(--ink-secondary); margin-bottom:2rem;}

.video-wrapper { margin-top: 5rem; border-top: 1px solid var(--border-color); padding:0; }
.modal-vsl-section { margin-top: 4rem; display: none; }
.vsl-frame { width: 100%; aspect-ratio: 16/9; background: #000; border: 1px solid var(--ink-primary); margin-top: var(--spacing-sm); transition: aspect-ratio 0.3s ease; }
#modal-remark-content {width: 100%;margin: 2rem auto;text-align:center;display:block;}
.modal-classifieds-wrapper{ margin-top: 5rem; border-top: 1px solid var(--border-color); padding-top: 3rem; }
.classifieds-title-small { font-size: 2rem; text-align: center; margin-bottom: 2rem; }
.modal-newspaper-columns .strict-bordered-ad { border: 1px solid var(--border-color) !important; padding: 1.5rem !important; margin-bottom: 1.5rem !important; background: transparent; break-inside: avoid; page-break-inside: avoid; }

/* ==========================================================================
   BLUEPRINT MODAL (Lead Capture)
   ========================================================================== */
.blueprint-cta-box { border-top: 1px solid var(--border-color); padding-top: 3rem; margin-top: 4rem; }
.blueprint-pitch { font-size: 1.15rem; line-height: 1.6; color: var(--ink-primary); }
.clean-form-layout { width: 100%; display: flex; flex-direction: column; align-items: center; }
.clean-input-wrapper { display: flex; width: 100%; position: relative; }
.clean-input { margin-bottom: 0 !important; border: 1px solid var(--ink-primary); box-shadow: none !important; padding-right: 60px !important; }
.clean-input:focus { border-color: var(--accent-red); outline: none; }
.clean-btn { position: absolute; right: 0; top: 0; bottom: 0; background: var(--ink-primary); color: #fff; border: 1px solid var(--ink-primary); width: 50px; display: flex; justify-content: center; align-items: center; cursor: pointer; transition: background 0.2s; padding: 0; margin: 0; }
.clean-btn:hover { background: var(--accent-red); border-color: var(--accent-red); }
.clean-btn svg { fill: currentColor; }
@keyframes spin { 100% { transform: rotate(360deg); } }
.turnstile-popover { width: 100%; display: flex; justify-content: center; margin-top: 15px; }

/* ==========================================================================
   DIAGNOSTIC FUNNEL (The Refined Clinical Vibe)
   ========================================================================== */
.diagnostic-funnel { 
    background: transparent; 
    padding: var(--spacing-lg); 
    margin-bottom: var(--spacing-xl); 
    max-width: 800px; 
    margin-left: auto; 
    margin-right: auto; 
}
.diag-step { display: none; animation: fadeIn 0.4s ease; }
.diag-step.active { display: block; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }

.diag-options-grid { 
    display: grid; 
    grid-template-columns: 1fr 1fr; 
    gap: var(--spacing-sm); 
    margin-top: var(--spacing-md); 
}
@media (max-width: 600px) { .diag-options-grid { grid-template-columns: 1fr; } }

.diag-modal-container { max-width: 800px !important; padding: 0 !important; border: 1px solid var(--ink-primary); }
.diag-modal-header { background: var(--bg-paper); border-bottom: 1px solid var(--ink-primary); color: var(--ink-primary); padding: var(--spacing-sm) var(--spacing-md); display: flex; justify-content: space-between; align-items: center; }
.diag-modal-title { margin: 0; color: var(--ink-primary); font-size: 1.1rem; letter-spacing: 1px; }
.diag-modal-close { position: static !important; border: none !important; color: var(--ink-secondary); padding: 5px 10px; }
.diag-modal-close:hover { color: var(--accent-red); }
.diag-funnel-override { border: none !important; box-shadow: none !important; margin-bottom: 0 !important; }

.diag-step-counter { margin-bottom: var(--spacing-md); color: var(--ink-secondary); font-size: 0.85rem; letter-spacing: 1px; }
.diag-step-title { font-size: var(--text-lg); font-family: 'Inter', sans-serif; font-weight: 500; letter-spacing: -0.5px; text-transform: none; }
.diag-mb-sm { margin-bottom: var(--spacing-sm); }
.diag-mb-md { margin-bottom: var(--spacing-md); }

/* Option Buttons as Clinical Data Rows */
.diag-opt {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    gap: 8px; /* Handles the vertical spacing between [ ] and text */
    padding: var(--spacing-sm) var(--spacing-md);
    background: transparent;
    color: var(--ink-primary);
    border: 1px solid var(--border-color);
    font-family: 'JetBrains Mono', monospace;
    text-transform: none;
    font-weight: 500;
}
.diag-opt:hover {
    background: var(--bg-paper);
    border-color: var(--ink-primary);
    color: var(--ink-primary);
}
.diag-opt::before {
    content: '[ ]';
    font-family: 'JetBrains Mono', monospace;
    color: var(--ink-secondary);
    margin-right: 0; /* Resetting the old inline margin */
    transition: color 0.2s;
}
.diag-opt:hover::before {
    content: '[X]';
    color: var(--accent-red);
}

.diag-audio-wrapper { background: transparent; border: 1px solid var(--border-color); padding: var(--spacing-md); margin-top: var(--spacing-sm); }
.diag-audio-controls { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.diag-btn-audio { display: inline-flex; align-items: center; justify-content: center; gap: 10px; background: var(--bg-paper); color: var(--ink-primary); border-color: var(--ink-primary); width: auto; font-size: 0.85rem;}
.diag-btn-audio:hover { background: var(--ink-primary); color: var(--white); }
.diag-btn-audio.recording { animation: pulse 1.5s infinite; background: var(--accent-red); color: var(--white); border-color: var(--accent-red); }

@keyframes pulse {
    0% { opacity: 1; }
    50% { opacity: 0.6; }
    100% { opacity: 1; }
}

.diag-btn-stop { width: auto !important; padding: var(--spacing-sm) var(--spacing-md) !important; font-size: 0.85rem;}
.diag-audio-status-text { color: var(--accent-red); font-size: 0.85rem; }
.diag-audio-canvas { width: 100%; background: var(--ink-primary); border: 1px solid var(--ink-primary); margin-top: 15px; }
.diag-audio-player { width: 100%; margin-top: 15px; border: 1px solid var(--border-color); border-radius: 0; }
.diag-audio-player::-webkit-media-controls-enclosure { border-radius: 0; background-color: var(--bg-paper); }

.diag-error-text { color: var(--accent-red); font-size: 0.85rem; }
.diag-turnstile { width: 100% !important; max-width: 100% !important; margin: 5px 0 15px 0 !important; padding: 0 !important; }
.diag-btn-submit { background: var(--ink-primary) !important; border-color: var(--ink-primary) !important; color: var(--white) !important; }
.diag-btn-submit:hover { background: var(--accent-red) !important; border-color: var(--accent-red) !important; }
.diag-response-box { margin-top: 15px; padding: 15px; font-size: 14px; transition: all 0.3s ease; border: 1px solid transparent; }

.form-input {
    width: 100%; max-width: 100%; padding: var(--spacing-md); background: transparent;
    border: 1px solid var(--border-color); font-family: 'Inter', sans-serif;
    font-size: var(--text-base); margin-bottom: var(--spacing-md); color: var(--ink-primary);
    border-radius: 0; outline: none; box-sizing: border-box; transition: border-color 0.2s;
}
.form-input:focus { outline: none; border-color: var(--ink-primary); }

.cf-turnstile { width: 100%; display: flex; justify-content: center; align-items: center; margin-top: 5px; }
@media (max-width: 380px) { .cf-turnstile { transform: scale(0.85); transform-origin: center center; } }

@media (max-width: 768px) {
    article img, .yt-video-container, .modal-hero-gate, .vsl-frame {
        margin-left: -1rem !important;
        margin-right: -1rem !important;
        width: calc(100% + 2rem) !important;
        border-left: none !important;
        border-right: none !important;
        border-radius: 0 !important;
    }
    .video-wrapper { margin-top: 2rem; border-top: 0px solid var(--ink-primary); padding:0; }
}

/* ==========================================================================
   SHARED CLINICAL FUNNEL STYLES (subscribe.php & qualify.php)
   ========================================================================== */
.subscribe-page, .qualify-page {
    background-color: var(--bg-canvas);
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.clinical-container {
    max-width: 800px;
    margin: var(--spacing-xl) auto auto auto;
    flex-grow: 1;
}

.clinical-header {
    border-bottom: 1px solid var(--ink-primary);
    margin-bottom: var(--spacing-lg);
    padding-bottom: var(--spacing-md);
    text-align: center;
}

/* Specific fix to prevent the H1 from breaking words on mobile */
.consent-title {
    font-size: clamp(2rem, 5vw, 3rem);
    letter-spacing: -1px;
    color: var(--ink-primary);
    margin: 0;
}

.clinical-subtitle {
    margin-top: 10px;
    color: var(--ink-secondary);
    font-weight: bold;
    letter-spacing: 1px;
    font-size: 0.85rem;
}

.clinical-card {
    background: transparent;
    border: 1px solid var(--border-color);
    padding: var(--spacing-lg);
}

/* Hard constraint specifically for the Qualify Wizard so inputs don't stretch to 800px */
.qualify-card {
    max-width: 600px;
    margin: 0 auto;
    background: var(--bg-paper);
}

.clinical-lead {
    margin-bottom: var(--spacing-md);
    font-family: 'Inter', sans-serif;
    font-size: 1.05rem;
    line-height: 1.6;
    color: var(--ink-primary);
}

.clinical-form {
    display: flex;
    flex-direction: column;
}

.clinical-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-md);
}
@media (max-width: 600px) {
    .clinical-grid { grid-template-columns: 1fr; }
}

.input-group {
    display: flex;
    flex-direction: column;
}

.clinical-input {
    margin-bottom: 0; 
    font-family: 'Inter', sans-serif; 
    font-size: 0.95rem;
    padding: 12px;
}

.input-readonly {
    background-color: var(--bg-canvas);
    color: var(--ink-secondary);
    cursor: not-allowed;
    border-color: var(--border-color);
}
.input-readonly:focus {
    border-color: var(--border-color); 
}

/* ==========================================================================
   SCROLLABLE TERMS LOGIC (subscribe.php)
   ========================================================================== */
.terms-label {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 5px;
    color: var(--ink-primary);
}
.terms-label span {
    color: var(--accent-red);
    font-size: 0.75rem;
    animation: bounceDown 2s infinite;
}

@keyframes bounceDown {
    0%, 20%, 50%, 80%, 100% { transform: translateY(0); }
    40% { transform: translateY(-5px); }
    60% { transform: translateY(-3px); }
}

.terms-container {
    width: 100%;
    height: 250px;
    overflow-y: scroll;
    background: var(--bg-paper);
    border: 1px solid var(--ink-primary);
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-md);
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.8rem;
    line-height: 1.6;
    color: var(--ink-primary);
    box-shadow: inset 0 2px 10px rgba(0,0,0,0.05); 
}

.terms-container::-webkit-scrollbar { width: 12px; }
.terms-container::-webkit-scrollbar-track { background: var(--bg-canvas); border-left: 1px solid var(--border-color); }
.terms-container::-webkit-scrollbar-thumb { background: var(--ink-secondary); border: 2px solid var(--bg-canvas); }
.terms-container::-webkit-scrollbar-thumb:hover { background: var(--ink-primary); }

.audit-notice {
    font-size: 0.8rem;
    margin-bottom: var(--spacing-md);
    color: var(--ink-secondary);
    line-height: 1.5;
}

/* ==========================================================================
   WIZARD COMPONENT LOGIC (qualify.php)
   ========================================================================== */
.wizard-title {
    font-size: var(--text-lg);
    margin-bottom: var(--spacing-sm);
    color: var(--ink-primary);
}

.wizard-desc {
    margin-bottom: var(--spacing-md);
    color: var(--ink-secondary);
    font-family: 'Inter', sans-serif;
    line-height: 1.6;
}

.wizard-input-group {
    display: flex;
    flex-direction: column;
    margin-bottom: var(--spacing-md);
}

.qualify-radio-label {
    display: flex;
    align-items: center;
    padding: 15px;
    border: 1px solid var(--border-color);
    cursor: pointer;
    font-family: 'Inter', sans-serif;
    font-weight: 500;
    font-size: 0.95rem;
    transition: all 0.2s ease;
    margin-bottom: 10px;
    color: var(--ink-primary);
    background: transparent;
}

.qualify-radio-label:hover {
    background: var(--white);
    border-color: var(--ink-primary);
}

/* FIX FOR DARK MODE WHITE-ON-WHITE ISSUE */
.qualify-radio-label.selected {
    background-color: var(--ink-primary) !important;
    color: #ffffff !important; 
    border-color: var(--ink-primary) !important;
}

.qualify-radio-input {
    margin-right: 15px;
    accent-color: var(--ink-primary);
}

.wizard-back-btn {
    margin-top: 15px;
    background: transparent;
    border: none;
    text-decoration: underline;
    cursor: pointer;
    color: var(--ink-secondary);
    font-size: 0.85rem;
    transition: color 0.2s;
    display: block; 
}
.wizard-back-btn:hover { color: var(--accent-red); }

.wizard-loading, .wizard-success {
    text-align: center;
    padding: var(--spacing-lg);
}

.wizard-loading h3 { font-size: var(--text-xl); color: var(--ink-primary); letter-spacing: 1px; animation: wizardPulse 1.5s infinite; }
.wizard-loading p { margin-top: 15px; color: var(--accent-red); }

@keyframes wizardPulse {
    0% { opacity: 1; }
    50% { opacity: 0.5; color: var(--accent-red); }
    100% { opacity: 1; }
}

.wizard-success h3 { font-size: var(--text-xl); color: #15803d; letter-spacing: 1px; }
.wizard-success p { margin-top: 15px; color: var(--ink-secondary); line-height: 1.6; }

.wizard-cta-box { display: flex; flex-direction: column; gap: 15px; max-width: 400px; margin: 30px auto 0; }
.wizard-btn-link { text-decoration: none; padding: 15px; letter-spacing: 1px; }

.whatsapp-btn { background-color: #25D366 !important; border-color: #25D366 !important; color: #ffffff !important; }
.whatsapp-btn:hover { background-color: #128C7E !important; border-color: #128C7E !important; }

/* Button States */
.accept-btn { transition: all 0.3s ease; }
.accept-btn:disabled { background: var(--bg-canvas); color: var(--ink-secondary); border-color: var(--border-color); cursor: not-allowed; opacity: 0.7; }
.accept-btn.unlocked { background-color: var(--accent-red) !important; color: #ffffff !important; border-color: var(--accent-red) !important; }
.accept-btn.unlocked:hover { background-color: var(--ink-primary) !important; border-color: var(--ink-primary) !important; }

.clinical-footer {
    margin-top: var(--spacing-xl);
    padding: var(--spacing-md);
    text-align: center;
    font-size: 0.75rem;
    color: var(--ink-secondary);
}

.alert-error { color: var(--accent-red); border: 1px solid var(--accent-red); padding: var(--spacing-sm) var(--spacing-md); margin-bottom: var(--spacing-md); font-size: 0.9rem; }
.alert-success { color: #15803d; border: 1px solid #15803d; padding: var(--spacing-md); margin-bottom: var(--spacing-md); background: #f0fdf4; font-size: 1.1rem; letter-spacing: 0.5px; }