/* ===== GLOBAL ===== */
*{margin:0;padding:0;box-sizing:border-box}
:root{
    --red:#cc0000;--dark-red:#8b0000;--gold:#ffd700;
    --black:#0a0a0a;--dark:#1a1a1a;--darker:#111;
    --text:#e0e0e0;--muted:#999;
}
body{font-family:Georgia,serif;background:var(--black);color:var(--text);line-height:1.7}
a{color:var(--gold);text-decoration:none;transition:color .2s}
a:hover{color:#fff;text-decoration:underline}

/* ===== NAVBAR ===== */
.navbar{
    position:fixed;top:0;left:0;right:0;z-index:1000;
    background:rgba(10,10,10,.9);backdrop-filter:blur(10px);
    border-bottom:2px solid var(--dark-red);transition:all .3s;
}
.navbar.scrolled{background:rgba(10,10,10,.98);box-shadow:0 4px 20px rgba(0,0,0,.5)}
.nav-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:.8rem 2rem}
.nav-brand{color:var(--red);font-weight:900;font-size:1.2rem;text-transform:uppercase;letter-spacing:2px;text-decoration:none}
.nav-brand:hover{color:var(--gold);text-decoration:none}
.nav-links{display:flex;list-style:none;gap:.5rem;align-items:center}
.nav-links a{color:var(--text);font-size:.9rem;padding:.5rem .8rem;border-radius:3px;text-decoration:none;transition:all .2s}
.nav-links a:hover{color:var(--gold);background:rgba(204,0,0,.15);text-decoration:none}
.nav-chat-btn{background:var(--red) !important;color:#fff !important;font-weight:700;border-radius:4px !important;padding:.5rem 1rem !important}
.nav-chat-btn:hover{background:var(--dark-red) !important}
.nav-toggle{display:none;background:none;border:none;color:var(--text);font-size:1.5rem;cursor:pointer}

/* ===== NAV DROPDOWNS ===== */
.nav-dropdown{position:relative}
.nav-dropdown>a{display:flex;align-items:center;gap:.3rem}
.nav-dropdown>a::after{content:'▾';font-size:.7rem;opacity:.6}
.nav-dropdown-menu{
    display:none;position:absolute;top:100%;left:0;min-width:220px;
    background:var(--dark);border:1px solid rgba(204,0,0,.3);border-radius:4px;
    box-shadow:0 8px 30px rgba(0,0,0,.6);padding:.5rem 0;z-index:1001;
}
.nav-dropdown:hover .nav-dropdown-menu{display:block}
.nav-dropdown-menu a{display:block;padding:.5rem 1.2rem;font-size:.85rem;white-space:nowrap}
.nav-dropdown-menu a:hover{background:rgba(204,0,0,.15)}

/* ===== SEARCH OVERLAY ===== */
.search-btn{background:none;border:none;color:var(--muted);font-size:1.1rem;cursor:pointer;padding:.5rem;transition:color .2s}
.search-btn:hover{color:var(--gold)}
.search-overlay{
    display:none;position:fixed;inset:0;z-index:2000;
    background:rgba(10,10,10,.95);backdrop-filter:blur(10px);
    padding:2rem;overflow-y:auto;
}
.search-overlay.open{display:flex;flex-direction:column;align-items:center;padding-top:15vh}
.search-overlay-close{position:absolute;top:1rem;right:2rem;background:none;border:none;color:var(--muted);font-size:2rem;cursor:pointer}
.search-overlay-close:hover{color:var(--gold)}
.search-box{
    width:100%;max-width:600px;display:flex;gap:0;
    border:2px solid var(--red);border-radius:6px;overflow:hidden;margin-bottom:2rem;
}
.search-box input{
    flex:1;background:var(--dark);border:none;color:var(--text);
    padding:1rem 1.5rem;font-size:1.2rem;font-family:Georgia,serif;outline:none;
}
.search-box input::placeholder{color:#666}
.search-results{width:100%;max-width:600px}
.search-result{
    display:block;padding:1rem 1.5rem;border-bottom:1px solid rgba(204,0,0,.15);
    color:var(--text);text-decoration:none;transition:all .2s;
}
.search-result:hover{background:rgba(204,0,0,.1);color:var(--gold);text-decoration:none}
.search-result h4{color:var(--gold);font-size:1rem;margin-bottom:.3rem}
.search-result p{color:var(--muted);font-size:.85rem}
.search-empty{color:var(--muted);text-align:center;padding:2rem;font-style:italic}
.search-ai{margin-top:1rem;padding:1rem 1.5rem;background:rgba(204,0,0,.08);border:1px solid rgba(204,0,0,.3);border-radius:8px;color:var(--text)}
.search-ai .search-ai-title{color:var(--gold);font-weight:700;font-size:.9rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:.5rem}
.search-ai .search-ai-body{font-size:.9rem;line-height:1.6;color:var(--text)}
.search-ai .search-ai-loading{color:var(--muted);font-style:italic}
.search-empty{color:var(--muted);text-align:center;padding:2rem;font-style:italic}

@media(max-width:900px){
    .nav-toggle{display:block}
    .nav-links{
        display:none;flex-direction:column;position:absolute;top:100%;left:0;right:0;
        background:var(--dark);border-bottom:2px solid var(--red);padding:1rem;gap:.3rem;
    }
    .nav-links.active{display:flex}
    .nav-links a{padding:.8rem 1rem;font-size:1rem}
    .nav-dropdown-menu{position:static;display:none;box-shadow:none;border:none;padding-left:1rem}
    .nav-dropdown.open .nav-dropdown-menu{display:block}
    .nav-dropdown>a::after{content:'▸'}
    .nav-dropdown.open>a::after{content:'▾'}
}

/* ===== HERO ===== */
.hero{
    min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;
    text-align:center;padding:6rem 2rem 4rem;position:relative;overflow:hidden;
    background:linear-gradient(135deg,var(--black) 0%,#1a0000 50%,var(--black) 100%);
    border-bottom:4px solid var(--red);
}
.hero-content{position:relative;z-index:1}
.hero-particles{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero-particles canvas{width:100%;height:100%}
.emblem{font-size:5rem;margin-bottom:1rem;animation:pulse 3s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}
h1{font-size:clamp(2rem,5vw,3.5rem);color:var(--red);text-transform:uppercase;letter-spacing:3px;font-weight:900;margin-bottom:.5rem}
.subtitle{font-size:clamp(1rem,2.5vw,1.4rem);color:var(--gold);font-style:italic;margin-bottom:2rem;letter-spacing:2px}
.tagline{font-size:1.2rem;max-width:700px;margin:0 auto 3rem;color:#ccc}
.hero-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ===== BUTTONS ===== */
.btn{display:inline-block;padding:.9rem 2.5rem;font-size:1.1rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;border-radius:4px;text-decoration:none;transition:all .3s;cursor:pointer}
.btn:hover{text-decoration:none}
.btn-primary{background:var(--red);color:#fff;border:2px solid var(--gold)}
.btn-primary:hover{background:var(--dark-red);transform:translateY(-2px);color:#fff}
.btn-outline{background:transparent;color:var(--gold);border:2px solid var(--gold)}
.btn-outline:hover{background:var(--gold);color:var(--black);transform:translateY(-2px)}
.btn-secondary{background:var(--dark);color:var(--gold);border:2px solid rgba(204,0,0,.4)}
.btn-secondary:hover{background:rgba(204,0,0,.2);border-color:var(--red);transform:translateY(-2px)}

/* ===== NOTICE ===== */
.notice-section{max-width:900px;margin:0 auto;padding:2rem}
.notice{padding:2rem;background:rgba(204,0,0,.12);border:2px solid var(--red);border-radius:6px}
.notice h3{color:var(--gold);margin-bottom:1rem;font-size:1.3rem}
.notice p{font-size:1.05rem;margin-bottom:.8rem;color:#ddd}

/* ===== SECTIONS ===== */
.section{max-width:900px;margin:0 auto;padding:4rem 2rem}
.section h2{color:var(--red);font-size:2rem;margin-bottom:1.5rem;border-left:4px solid var(--gold);padding-left:1rem}
.section h3{color:var(--gold);margin:1.5rem 0 .8rem;font-size:1.2rem}
.section p{margin-bottom:1.5rem;font-size:1.1rem}
.section-inner{max-width:1000px;margin:0 auto;padding:0 2rem}
.section-inner h2{color:var(--red);font-size:2rem;margin-bottom:1.5rem;border-left:4px solid var(--gold);padding-left:1rem}

/* ===== PRINCIPLES ===== */
.principles{background:var(--dark);padding:4rem 2rem;border-top:2px solid var(--dark-red);border-bottom:2px solid var(--dark-red)}
.pg{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;max-width:1000px;margin:0 auto}
.pr{padding:2rem;background:rgba(204,0,0,.08);border:1px solid rgba(204,0,0,.3);border-radius:4px;transition:transform .2s,border-color .2s}
.pr:hover{transform:translateY(-3px);border-color:var(--red)}
.pr h3{color:var(--gold);margin-bottom:.8rem;font-size:1.2rem}

/* ===== QUOTES ===== */
.quote{font-style:italic;color:var(--gold);text-align:center;padding:3rem 2rem;font-size:1.3rem;max-width:800px;margin:0 auto}
.quote cite{display:block;margin-top:1rem;color:var(--muted);font-size:1rem}

/* ===== STATS SECTION ===== */
.stats-section{
    background:var(--dark);padding:4rem 2rem;
    border-top:2px solid var(--dark-red);border-bottom:2px solid var(--dark-red);
}
.stats-grid{
    max-width:1000px;margin:0 auto;display:grid;
    grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;text-align:center;
}
.stat-item{padding:2rem 1rem}
.stat-number{
    font-size:3rem;font-weight:900;color:var(--red);
    font-variant-numeric:tabular-nums;
}
.stat-label{color:var(--gold);font-size:1rem;margin-top:.5rem;text-transform:uppercase;letter-spacing:1px}
.stat-desc{color:var(--muted);font-size:.85rem;margin-top:.3rem}

/* ===== CHATBOT PROMO ===== */
.chatbot-promo{
    background:linear-gradient(135deg,#1a0000 0%,var(--dark) 50%,#0a0a1a 100%);
    border-top:2px solid var(--dark-red);border-bottom:2px solid var(--dark-red);
    padding:4rem 2rem;
}
.chatbot-promo-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.chatbot-promo-text h2{color:var(--red);font-size:2rem;margin-bottom:1rem}
.chatbot-promo-text p{font-size:1.1rem;margin-bottom:2rem;color:#ccc}
.chat-preview-window{
    background:var(--black);border:1px solid rgba(204,0,0,.4);border-radius:8px;overflow:hidden;
    box-shadow:0 10px 40px rgba(0,0,0,.5);
}
.chat-preview-header{background:var(--dark-red);color:#fff;padding:.8rem 1.2rem;font-weight:700;font-size:.95rem}
.chat-preview-msg{padding:.8rem 1.2rem;font-size:.9rem;border-bottom:1px solid rgba(255,255,255,.05)}
.chat-preview-msg.bot{color:var(--gold);background:rgba(204,0,0,.05)}
.chat-preview-msg.user{color:#ccc;background:rgba(255,255,255,.03)}
@media(max-width:768px){.chatbot-promo-inner{grid-template-columns:1fr}}

/* ===== RESOURCE LIST ===== */
.resource-list{list-style:none;display:flex;flex-direction:column;gap:.8rem}
.resource-list li a{
    display:block;padding:1rem 1.5rem;background:rgba(204,0,0,.06);border:1px solid rgba(204,0,0,.2);
    border-radius:4px;color:var(--text);font-size:1.05rem;transition:all .2s;
}
.resource-list li a:hover{background:rgba(204,0,0,.15);border-color:var(--red);color:var(--gold);text-decoration:none;transform:translateX(5px)}

/* ===== CTA ===== */
.cta{text-align:center;padding:4rem 2rem;background:linear-gradient(to bottom,var(--black),#1a0000)}
.cta h2{color:var(--red);margin-bottom:1rem;font-size:2rem}
.cta p{margin-bottom:2rem;font-size:1.1rem;color:#ccc}

/* ===== FOOTER ===== */
footer{text-align:center;padding:3rem 2rem;background:var(--black);border-top:2px solid var(--dark-red)}
.footer-inner{max-width:900px;margin:0 auto}
.footer-links{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap;margin-bottom:1.5rem}
.footer-links a{color:var(--muted);font-size:.9rem}
.footer-links a:hover{color:var(--gold)}
footer p{color:#666;margin-bottom:.3rem}
.footer-slogan{color:var(--red);font-style:italic;font-weight:700;margin-top:.5rem}

/* ===== PAGE LAYOUTS (subpages) ===== */
.page-hero{
    padding:8rem 2rem 3rem;text-align:center;
    background:linear-gradient(135deg,var(--black) 0%,#1a0000 50%,var(--black) 100%);
    border-bottom:4px solid var(--red);
}
.page-hero .emblem{font-size:4rem;margin-bottom:1rem}
.page-hero h1{font-size:clamp(1.8rem,4vw,2.8rem);color:var(--red);text-transform:uppercase;letter-spacing:2px;font-weight:900;margin-bottom:1rem}
.page-hero .subtitle{color:var(--gold);font-style:italic;font-size:1.2rem;max-width:700px;margin:0 auto}
.divider{border:0;border-top:2px solid var(--dark-red);margin:0}

/* ===== CARDS GRID (for theory/reading) ===== */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}
.card{padding:2rem;background:rgba(204,0,0,.08);border:1px solid rgba(204,0,0,.3);border-radius:4px;transition:transform .2s,border-color .2s}
.card:hover{transform:translateY(-3px);border-color:var(--red)}
.card h3{color:var(--gold);margin-bottom:.8rem;font-size:1.2rem}
.card p{color:#ccc;font-size:1rem}
.card .card-tag{display:inline-block;background:var(--dark-red);color:#fff;font-size:.75rem;padding:.2rem .6rem;border-radius:3px;margin-bottom:.8rem;text-transform:uppercase;letter-spacing:1px}

/* ===== READING LIST ===== */
.book-list{list-style:none;display:flex;flex-direction:column;gap:1rem}
.book-item{padding:1.5rem;background:rgba(204,0,0,.06);border:1px solid rgba(204,0,0,.2);border-radius:4px;transition:all .2s}
.book-item:hover{border-color:var(--red);background:rgba(204,0,0,.1)}
.book-item h3{color:var(--gold);font-size:1.1rem;margin-bottom:.3rem}
.book-item .book-author{color:var(--red);font-size:.95rem;font-style:italic;margin-bottom:.5rem}
.book-item p{color:#ccc;font-size:.95rem}

/* ===== CHAT PAGE ===== */
.chat-container{
    max-width:900px;margin:0 auto;padding:2rem;min-height:calc(100vh - 200px);
    display:flex;flex-direction:column;
}
.chat-header{text-align:center;margin-bottom:2rem}
.chat-header h2{color:var(--red);font-size:1.8rem;margin-bottom:.5rem}
.chat-header p{color:var(--muted);font-size:1rem}
.chat-messages{
    flex:1;overflow-y:auto;padding:1rem;background:var(--darker);
    border:1px solid rgba(204,0,0,.3);border-radius:8px 8px 0 0;
    min-height:400px;max-height:60vh;
}
.chat-msg{margin-bottom:1rem;padding:1rem 1.2rem;border-radius:6px;font-size:1rem;line-height:1.6;animation:fadeIn .3s}
@keyframes fadeIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}
.chat-msg.bot{background:rgba(204,0,0,.1);border-left:3px solid var(--red);color:var(--text)}
.chat-msg.user{background:rgba(255,215,0,.08);border-left:3px solid var(--gold);color:#fff}
.chat-msg.system{background:rgba(255,255,255,.03);color:var(--muted);font-style:italic;font-size:.9rem;text-align:center;border-left:none}
.chat-msg .sender{font-weight:700;font-size:.85rem;margin-bottom:.3rem;text-transform:uppercase;letter-spacing:1px}
.chat-msg.bot .sender{color:var(--red)}
.chat-msg.user .sender{color:var(--gold)}
.chat-input-area{display:flex;gap:0;border:1px solid rgba(204,0,0,.3);border-top:none;border-radius:0 0 8px 8px;overflow:hidden}
.chat-input{
    flex:1;background:var(--dark);border:none;color:var(--text);
    padding:1rem 1.2rem;font-size:1rem;font-family:Georgia,serif;outline:none;
    resize:none;overflow-y:auto;
}
.chat-input::placeholder{color:#666}
.chat-send{
    background:var(--red);color:#fff;border:none;padding:1rem 2rem;
    font-size:1rem;font-weight:700;cursor:pointer;font-family:Georgia,serif;
    text-transform:uppercase;letter-spacing:1px;transition:background .2s;
}
.chat-send:hover{background:var(--dark-red)}
.chat-send:disabled{opacity:.5;cursor:not-allowed}
.chat-suggestions{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1rem}
.chat-suggestion{
    background:rgba(204,0,0,.08);border:1px solid rgba(204,0,0,.3);color:var(--text);
    padding:.6rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;
    font-family:Georgia,serif;transition:all .2s;
}
.chat-suggestion:hover{background:rgba(204,0,0,.2);border-color:var(--red);color:var(--gold)}
.chat-disclaimer{text-align:center;margin-top:1rem;color:#666;font-size:.8rem}
.chat-info-bar{display:flex;justify-content:space-between;padding:.5rem 1rem;background:rgba(204,0,0,.05);border:1px solid rgba(204,0,0,.15);border-radius:4px;margin-top:.8rem;font-size:.75rem;color:var(--muted);font-variant-numeric:tabular-nums}
.typing-indicator{color:var(--muted);font-style:italic;padding:.5rem 1.2rem;font-size:.9rem}

/* ===== CHAT CONTROLS ===== */
.chat-controls{display:flex;align-items:center;gap:1rem;justify-content:center;margin-top:.8rem}
.chat-control-btn{
    background:rgba(204,0,0,.15);border:1px solid rgba(204,0,0,.3);color:var(--muted);
    padding:.4rem 1rem;border-radius:4px;cursor:pointer;font-size:.8rem;font-family:Georgia,serif;
    transition:all .2s;
}
.chat-control-btn:hover{background:rgba(204,0,0,.3);color:var(--text);border-color:var(--red)}
.chat-status{color:var(--muted);font-size:.8rem;font-style:italic}
.chat-status.active{color:var(--gold);animation:statusPulse 1.5s ease-in-out infinite}
@keyframes statusPulse{0%,100%{opacity:1}50%{opacity:.5}}

/* ===== STREAMING CURSOR ===== */
.streaming-cursor{
    display:inline-block;width:8px;height:1.1em;background:var(--red);
    margin-left:2px;vertical-align:text-bottom;
    animation:blink .6s step-end infinite;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}

/* ===== MODEL SELECTOR ===== */
.model-selector{
    display:flex;align-items:center;gap:.5rem;
}
.model-selector select{
    background:var(--dark);border:1px solid rgba(204,0,0,.3);color:var(--text);
    padding:.3rem .6rem;border-radius:4px;font-size:.8rem;font-family:Georgia,serif;
    cursor:pointer;outline:none;
}
.model-selector select:focus{border-color:var(--red)}
.model-selector label{color:var(--muted);font-size:.8rem}

/* ===== PLEDGE LIST ===== */
.pledge-list{
    list-style:none;counter-reset:pledge;display:flex;flex-direction:column;gap:1rem;
    margin:2rem 0;padding:0;
}
.pledge-list li{
    counter-increment:pledge;padding:1.2rem 1.5rem 1.2rem 4rem;
    background:rgba(204,0,0,.06);border:1px solid rgba(204,0,0,.2);
    border-radius:4px;font-size:1.05rem;position:relative;transition:all .2s;
}
.pledge-list li::before{
    content:counter(pledge);position:absolute;left:0;top:0;bottom:0;width:3rem;
    display:flex;align-items:center;justify-content:center;
    background:var(--dark-red);color:var(--gold);font-weight:900;font-size:1.2rem;
    border-radius:4px 0 0 4px;
}
.pledge-list li:hover{border-color:var(--red);background:rgba(204,0,0,.1);transform:translateX(3px)}

/* ===== TIMELINE ===== */
.timeline{position:relative;max-width:800px;margin:0 auto;padding:2rem 0}
.timeline::before{
    content:'';position:absolute;left:50%;top:0;bottom:0;width:3px;
    background:linear-gradient(to bottom,var(--red),var(--gold),var(--red));
    transform:translateX(-50%);
}
.timeline-item{
    position:relative;padding:1.5rem 0;display:flex;align-items:flex-start;
}
.timeline-item:nth-child(odd){flex-direction:row-reverse;text-align:right}
.timeline-item:nth-child(odd) .timeline-content{margin-left:0;margin-right:calc(50% + 2rem)}
.timeline-item:nth-child(even) .timeline-content{margin-left:calc(50% + 2rem)}
.timeline-dot{
    position:absolute;left:50%;transform:translateX(-50%);
    width:16px;height:16px;background:var(--red);border:3px solid var(--gold);
    border-radius:50%;z-index:1;
}
.timeline-content{
    padding:1.5rem;background:rgba(204,0,0,.08);border:1px solid rgba(204,0,0,.3);
    border-radius:6px;transition:all .3s;width:calc(50% - 2rem);
}
.timeline-content:hover{border-color:var(--red);background:rgba(204,0,0,.15)}
.timeline-content h3{color:var(--gold);font-size:1.1rem;margin-bottom:.3rem}
.timeline-content .timeline-year{
    color:var(--red);font-weight:900;font-size:1.3rem;margin-bottom:.5rem;
    text-transform:uppercase;letter-spacing:2px;
}
.timeline-content p{color:#ccc;font-size:.95rem}

@media(max-width:768px){
    .timeline::before{left:20px}
    .timeline-dot{left:20px}
    .timeline-item,.timeline-item:nth-child(odd){flex-direction:row;text-align:left}
    .timeline-item:nth-child(odd) .timeline-content,
    .timeline-item:nth-child(even) .timeline-content{
        margin-left:50px;margin-right:0;width:calc(100% - 50px);
    }
}

/* ===== FAQ / STUDY GUIDE ===== */
.faq-item{
    margin-bottom:1rem;background:rgba(204,0,0,.06);border:1px solid rgba(204,0,0,.2);
    border-radius:6px;overflow:hidden;transition:border-color .2s;
}
.faq-item:hover{border-color:var(--red)}
.faq-question{
    display:flex;justify-content:space-between;align-items:center;
    padding:1.2rem 1.5rem;cursor:pointer;color:var(--gold);font-size:1.1rem;
    font-weight:700;transition:background .2s;user-select:none;
}
.faq-question:hover{background:rgba(204,0,0,.1)}
.faq-question .faq-icon{
    color:var(--red);font-size:1.5rem;font-weight:900;transition:transform .3s;
    flex-shrink:0;margin-left:1rem;
}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-answer{
    max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s ease;
    padding:0 1.5rem;color:#ccc;font-size:1rem;line-height:1.7;
}
.faq-item.open .faq-answer{max-height:600px;padding:0 1.5rem 1.5rem}
.faq-answer p{margin-bottom:1rem}

/* ===== STUDY PATH ===== */
.study-path{display:flex;flex-direction:column;gap:1.5rem;position:relative}
.study-step{
    display:flex;gap:1.5rem;align-items:flex-start;padding:1.5rem;
    background:rgba(204,0,0,.06);border:1px solid rgba(204,0,0,.2);
    border-radius:6px;transition:all .2s;
}
.study-step:hover{border-color:var(--red);background:rgba(204,0,0,.1)}
.study-step-num{
    flex-shrink:0;width:3rem;height:3rem;
    background:var(--dark-red);color:var(--gold);border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-weight:900;font-size:1.3rem;
}
.study-step-content h3{color:var(--gold);font-size:1.1rem;margin-bottom:.3rem}
.study-step-content p{color:#ccc;font-size:.95rem;margin-bottom:.5rem}
.study-step-content .step-links{display:flex;gap:.8rem;flex-wrap:wrap}
.study-step-content .step-links a{
    font-size:.85rem;color:var(--text);background:rgba(204,0,0,.15);
    padding:.3rem .8rem;border-radius:3px;border:1px solid rgba(204,0,0,.3);
    transition:all .2s;
}
.study-step-content .step-links a:hover{
    background:rgba(204,0,0,.3);border-color:var(--red);color:var(--gold);text-decoration:none;
}

/* ===== SCROLL ANIMATIONS ===== */
.section,.principles,.quote,.chatbot-promo,.cta,.notice-section,.stats-section{
    opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease;
}
.section.visible,.principles.visible,.quote.visible,.chatbot-promo.visible,.cta.visible,.notice-section.visible,.stats-section.visible{
    opacity:1;transform:translateY(0);
}

/* ===== ENHANCED MOBILE ===== */
@media(max-width:600px){
    .hero{padding:5rem 1rem 3rem}
    .hero-buttons{flex-direction:column;align-items:center}
    .btn{width:100%;max-width:300px;text-align:center}
    .section{padding:2.5rem 1rem}
    .quote{padding:2rem 1rem;font-size:1.1rem}
    .chat-container{padding:1rem}
    .chat-messages{min-height:300px;max-height:50vh}
    .chat-suggestions{gap:.5rem}
    .chat-suggestion{font-size:.8rem;padding:.5rem .8rem}
    .pg{grid-template-columns:1fr}
    .cards-grid{grid-template-columns:1fr}
    .resource-list li a{font-size:.95rem;padding:.8rem 1rem}
    .pledge-list li{padding:1rem 1rem 1rem 3.5rem;font-size:.95rem}
    .pledge-list li::before{width:2.5rem;font-size:1rem}
    .stats-grid{grid-template-columns:1fr 1fr}
    .stat-number{font-size:2.2rem}
}

/* ===== BACK TO TOP ===== */
.back-to-top{
    position:fixed;bottom:24px;left:24px;z-index:999;width:44px;height:44px;
    border-radius:50%;background:var(--dark-red);border:2px solid rgba(255,215,0,.3);
    color:var(--gold);font-size:20px;cursor:pointer;opacity:0;pointer-events:none;
    transition:all .3s;display:flex;align-items:center;justify-content:center;
    box-shadow:0 4px 12px rgba(0,0,0,.5);
}
.back-to-top.show{opacity:1;pointer-events:auto}
.back-to-top:hover{background:var(--red);border-color:var(--gold);transform:translateY(-2px)}

/* ===== ROTATING QUOTES ===== */
.rotating-quotes{position:relative;min-height:120px;overflow:hidden}
.rotating-quotes .quote-slide{
    position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
    opacity:0;transition:opacity 1s ease;
}
.rotating-quotes .quote-slide.active{opacity:1}

/* ===== SMOOTH SCROLL ===== */
html{scroll-behavior:smooth}

/* ===== SELECTION ===== */
::selection{background:var(--red);color:#fff}

/* ===== HEADING ENHANCEMENTS ===== */
h1,h2{text-shadow:0 2px 8px rgba(204,0,0,.3)}
.section h2::after{content:'';display:block;width:60px;height:2px;background:var(--gold);margin-top:.5rem;opacity:.6}

/* ===== LINK UNDERLINE EFFECT ===== */
.section p a{
    text-decoration:none;border-bottom:1px solid rgba(255,215,0,.3);
    transition:border-color .2s,color .2s;
}
.section p a:hover{border-bottom-color:var(--gold)}

/* ===== CARD HOVER GLOW ===== */
.card:hover,.pr:hover{box-shadow:0 4px 20px rgba(204,0,0,.15)}

/* ===== FOCUS STYLES (accessibility) ===== */
a:focus-visible,.btn:focus-visible,button:focus-visible,select:focus-visible,input:focus-visible,textarea:focus-visible{
    outline:2px solid var(--gold);outline-offset:2px;
}

/* ===== PRINT STYLES ===== */
@media print{
    .navbar,.back-to-top,.cw-btn,.cw-popup,.chat-widget-container{display:none !important}
    body{background:#fff;color:#000}
    .section,.principles{opacity:1;transform:none}
    a{color:#000;text-decoration:underline}
}
