GNU/_PAGE/work/work.php
<?php require_once '/home/www/GNU/_PAGE/head.php'; ?>
<!DOCTYPE html>
<html lang="ko">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>AI MANUAL - 시스템 관제 센터</title>
    <!-- 웹 폰트 및 아이콘 로드 -->
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css">
    <link href="https://fonts.googleapis.com/css2?family=Orbitron:wght@400;700;900&family=Noto+Sans+KR:wght@300;400;700&family=JetBrains+Mono:wght@400;700&display=swap" rel="stylesheet">
    
    <style>
        /* 변수 설정 */
        :root {
            --aim-neon-green: #00ff88;
            --aim-neon-blue: #00d2ff;
            --aim-gold: #f1c40f;
            --aim-bg-deep: #050505;
            --aim-card-bg: rgba(13, 17, 23, 0.7);
            --aim-border-glow: rgba(0, 255, 136, 0.3);
            --aim-border-line: rgba(255, 255, 255, 0.08);
        }

        /* [구조 유지] 전체 배경 스타일 */
        body { 
            background-color: var(--aim-bg-deep); 
            color: #e1e1e1; 
            font-family: 'Noto Sans KR', sans-serif; 
            margin: 0; 
            padding: 0; 
            display: flex; 
            flex-direction: column; 
            align-items: center; 
            min-height: 100vh;
            overflow-x: hidden;
            background-image: radial-gradient(circle at 50% 0%, #1a1f35 0%, #050505 100%);
        }

        /* 로딩 시퀀스 */
        #aim-system-loader { 
            position: fixed; top: 0; left: 0; width: 100%; height: 100%; 
            background: #000; display: flex; flex-direction: column; 
            justify-content: center; align-items: center; z-index: 99999; 
            transition: opacity 0.6s cubic-bezier(0.4, 0, 0.2, 1); 
        }
        .aim-quantum-spinner { 
            width: 60px; height: 60px; 
            border: 2px solid rgba(0, 255, 136, 0.1); 
            border-top: 2px solid var(--aim-neon-green); 
            border-radius: 50%; 
            animation: aim-spin 1s cubic-bezier(0.5, 0, 0.5, 1) infinite; 
            margin-bottom: 20px; 
            box-shadow: 0 0 15px var(--aim-neon-green);
        }
        @keyframes aim-spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }
        
        .aim-main-content-wrap { 
            opacity: 0; 
            transform: translateY(30px); 
            transition: all 0.8s cubic-bezier(0.2, 1, 0.3, 1); 
            width: 100%; 
            max-width: 100%; 
            padding: 80px 50px; 
            box-sizing: border-box; 
        }
        .aim-main-content-wrap.aim-is-active { opacity: 1; transform: translateY(0); }

        .aim-header-banner { 
            border-bottom: 1px solid var(--aim-border-line); 
            padding-bottom: 40px; 
            margin-bottom: 60px; 
            text-align: center; 
            width: 100%; 
        }
        .aim-header-banner h1 { 
            font-family: 'Orbitron', sans-serif; 
            color: var(--aim-neon-green); 
            font-size: 3.5rem; 
            margin: 0; 
            letter-spacing: 12px;
            text-shadow: 0 0 20px rgba(0, 255, 136, 0.4);
            font-weight: 900;
        }
        .aim-header-banner p { 
            font-family: 'JetBrains Mono', monospace; 
            color: #555; 
            font-size: 1rem; 
            margin-top: 15px; 
            text-transform: uppercase;
            letter-spacing: 3px;
        }

        .aim-manual-grid { 
            display: grid; 
            grid-template-columns: repeat(3, 1fr); 
            gap: 30px; 
            width: 100%; 
        }

        .aim-nav-card { 
            background: var(--aim-card-bg); 
            backdrop-filter: blur(20px);
            border: 1px solid var(--aim-border-line); 
            padding: 45px 35px; 
            border-radius: 24px; 
            text-decoration: none; 
            transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275); 
            display: flex; 
            flex-direction: column; 
            gap: 20px; 
            position: relative;
            overflow: hidden;
            box-shadow: 0 10px 30px rgba(0,0,0,0.3);
            cursor: pointer;
        }
        
        .aim-nav-card::after {
            content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 2px;
            background: linear-gradient(90deg, transparent, var(--aim-neon-green), transparent);
            opacity: 0; transition: opacity 0.3s;
        }

        .aim-nav-card:hover { 
            border-color: var(--aim-neon-green); 
            background: rgba(30, 30, 45, 0.85);
            transform: translateY(-15px); 
            box-shadow: 0 30px 60px rgba(0, 0, 0, 0.7), 0 0 20px rgba(0, 255, 136, 0.1);
        }
        .aim-nav-card:hover::after { opacity: 1; }

        .aim-nav-card h2 { 
            margin: 0; 
            color: #fff; 
            font-family: 'Orbitron', sans-serif;
            font-size: 1.6rem;
            display: flex;
            align-items: center;
            gap: 15px;
        }
        .aim-nav-card h2 i { color: var(--aim-gold); transition: all 0.3s; }
        .aim-nav-card:hover h2 i { transform: rotate(-10deg) scale(1.15); color: var(--aim-neon-green); text-shadow: 0 0 10px var(--aim-neon-green); }

        .aim-nav-card p { 
            margin: 0; 
            color: #94a3b8; 
            line-height: 1.7; 
            font-size: 0.95rem;
            font-weight: 300;
        }

        .aim-source-tag { 
            font-family: 'JetBrains Mono', monospace;
            font-size: 0.75rem; 
            color: var(--aim-neon-blue); 
            background: rgba(0, 210, 255, 0.08); 
            padding: 6px 12px; 
            border-radius: 8px; 
            align-self: flex-start; 
            border: 1px solid rgba(0, 210, 255, 0.15);
            font-weight: 600;
            display: flex;
            align-items: center;
            gap: 8px;
        }

        /* 팝업 모달 스타일 */
        .aim-modal-overlay {
            position: fixed; top: 0; left: 0; width: 100%; height: 100%;
            background: rgba(0, 0, 0, 0.85);
            backdrop-filter: blur(10px);
            z-index: 100000;
            display: none;
            justify-content: center;
            align-items: center;
        }
        .aim-modal-content {
            background: #0d1117;
            border: 1px solid var(--aim-neon-blue);
            width: 90%; max-width: 800px;
            border-radius: 20px;
            padding: 40px;
            position: relative;
            box-shadow: 0 0 50px rgba(0, 210, 255, 0.2);
            animation: aim-modal-up 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
        }
        @keyframes aim-modal-up { from { opacity: 0; transform: translateY(50px); } to { opacity: 1; transform: translateY(0); } }

        .aim-modal-close {
            position: absolute; top: 20px; right: 20px;
            color: #666; font-size: 1.5rem; cursor: pointer; transition: 0.2s;
        }
        .aim-modal-close:hover { color: var(--aim-neon-green); }

        .aim-modal-title {
            font-family: 'Orbitron', sans-serif;
            font-size: 1.5rem; color: var(--aim-neon-blue);
            margin-bottom: 25px; border-bottom: 1px solid #222; padding-bottom: 15px;
        }
        .aim-code-block {
            background: #050505; border: 1px solid #222;
            padding: 20px; border-radius: 10px; font-family: 'JetBrains Mono', monospace;
            font-size: 0.9rem; line-height: 1.8; color: #aaa;
            margin-bottom: 15px; position: relative;
        }
        .aim-code-keyword { color: var(--aim-neon-green); }
        .aim-code-path { color: var(--aim-neon-blue); }

        /* 복사 버튼 스타일 */
        .aim-copy-trigger {
            position: absolute; top: 15px; right: 15px;
            background: #111; color: #555; border: 1px solid #333;
            padding: 4px 10px; font-size: 10px; border-radius: 4px;
            cursor: pointer; transition: 0.2s; font-family: 'Orbitron', sans-serif;
        }
        .aim-copy-trigger:hover { background: var(--aim-neon-green); color: #000; border-color: var(--aim-neon-green); }

        .aim-ai-link-btn {
            display: flex; align-items: center; justify-content: space-between;
            background: rgba(255, 255, 255, 0.03);
            border: 1px solid #333; padding: 20px 30px; border-radius: 12px;
            margin-bottom: 12px; text-decoration: none; transition: 0.3s;
        }
        .aim-ai-link-btn:hover {
            background: rgba(0, 210, 255, 0.1); border-color: var(--aim-neon-blue);
            transform: translateX(10px);
        }
        .aim-ai-link-btn span { font-family: 'Orbitron', sans-serif; color: #fff; font-weight: bold; }
        .aim-ai-link-btn i { color: var(--aim-neon-blue); }

        /* 반응형 대응 */
        @media (max-width: 1200px) {
            .aim-manual-grid { grid-template-columns: repeat(2, 1fr); }
        }
        @media (max-width: 800px) {
            .aim-manual-grid { grid-template-columns: 1fr; }
            .aim-main-content-wrap { padding: 40px 20px; }
            .aim-header-banner h1 { font-size: 2.2rem; letter-spacing: 4px; }
        }
    </style>
</head>
<body>
    <!-- 로딩 화면 -->
    <div id="aim-system-loader">
        <div class="aim-quantum-spinner"></div>
        <div style="color:var(--aim-neon-green); font-family: 'Orbitron'; letter-spacing:5px; font-size: 0.85rem; font-weight: 700;">PROTOCOL_INITIALIZING...</div>
    </div>

    <!-- 메인 컨텐츠 -->
    <div class="aim-main-content-wrap" id="aim-main-container">
        <div class="aim-header-banner">
            <h1>WORK OLD BOY</h1>
            <p>Terminal Core & Database Command Protocol</p>
        </div>

        <div class="aim-manual-grid">
            <!-- 블록 1: Server Information -->
            <div class="aim-nav-card" onclick="aimShowModal('server')">
                <div class="aim-source-tag"><i class="fa-solid fa-code-branch"></i> Server Information</div>
                <h2><i class="fa-solid fa-server"></i> Server Basic Info</h2>
                <p>사이트의 기본정보 및 필수 환경 설정을 확인합니다.<br>DB 연결 정보, 핸들러 설정, 그누보드 연동 데이터 및 데몬 시스템의 물리적 경로 프로토콜 및 작업 시 필요한 정보를 관제합니다.</p>
            </div>

            <!-- 블록 2: AI Work -->
            <div class="aim-nav-card" onclick="aimShowModal('ai')">
                <div class="aim-source-tag"><i class="fa-solid fa-code-branch"></i> AI Work</div>
                <h2><i class="fa-solid fa-brain"></i> AI Self-employment</h2>
                <p>효율적인 코딩 및 관제를 위한 AI 연동 허브입니다. ChatGPT, Gemini 및 Google AI Studio로 즉시 연결되어 인공지능 보조 프로토콜을 수행합니다.</p>
            </div>

            <!-- 블록 3: About Oldboy (Directory Manual) -->
            <a href="<?php echo G5_URL; ?>/_PAGE/library/manual_ai/directory_structure.php" class="aim-nav-card" target="_blank">
                <div class="aim-source-tag"><i class="fa-solid fa-code-branch"></i> About Oldboy</div>
                <h2><i class="fa-solid fa-folder-tree"></i> Directory Manual</h2>
                <p>전체 서버 파일 시스템의 계층 구조를 시각화합니다. AI 연동 작업 시 필요한 각 노드의 절대 경로를 즉시 확인하고 복사하여 작업 효율을 극대화합니다.</p>
            </a>

            <!-- 블록 4: About Maria (Database Manual) -->
            <a href="<?php echo G5_URL; ?>/_PAGE/library/manual_ai/db_structure.php" class="aim-nav-card" target="_blank">
                <div class="aim-source-tag"><i class="fa-solid fa-microchip"></i> About Maria</div>
                <h2><i class="fa-solid fa-database"></i> Database Manual</h2>
                <p>upbit_data 클러스터의 실시간 데이터 스키마 설계도입니다. 테이블 인덱스 무결성과 컬럼별 상세 주석 데이터를 분석하여 정밀한 쿼리 설계를 지원합니다.</p>
            </a>

            <!-- 블록 5: Directory Tree -->
            <a href="<?php echo G5_URL; ?>/_PAGE/structure/directory/directory_tree.php" class="aim-nav-card" target="_blank">
                <div class="aim-source-tag"><i class="fa-solid fa-microchip"></i>  Directory Tree</div>
                <h2><i class="fa-solid fa-network-wired"></i> Site Servers</h2>
                <p>사이트 서버 구조를 모니터링 탐색합니다. 트리형 구조를 통해 각 디렉토리의 물리적 위치와 권한 상태를 직관적으로 파악합니다.</p>
            </a>

            <!-- 블록 6: SQL Tree -->
            <a href="<?php echo G5_URL; ?>/_PAGE/structure/mysql/SQL_tree.php" class="aim-nav-card" target="_blank">
                <div class="aim-source-tag"><i class="fa-solid fa-microchip"></i> SQL Tree</div>
                <h2><i class="fa-solid fa-table-list"></i> Maria DB</h2>
                <p>Maria DB SQL 구조를 트리형 계층으로 모니터링합니다. 테이블 간의 관계와 스키마 설계 흐름을 시각적으로 탐색합니다.</p>
            </a>

            <!-- 블록 7: Data Back -->
            <a href="<?php echo G5_URL; ?>" class="aim-nav-card" target="_blank">
                <div class="aim-source-tag"><i class="fa-solid fa-microchip"></i> SQL_tree.php</div>
                <h2><i class="fa-solid fa-floppy-disk"></i> Data Back</h2>
                <p>Data Back : 각종 데이터 백업 프로토콜입니다. 게시판(BOARD), 원천 데이터(DATA), DB 클러스터 및 핵심 소스 파일을 보존합니다.</p>
            </a>
        </div>
    </div>

    <!-- 서버 정보 팝업 모달 -->
    <div id="aim-modal-server" class="aim-modal-overlay" onclick="aimCloseModal('server')">
        <div class="aim-modal-content" onclick="event.stopPropagation()">
            <i class="fa-solid fa-xmark aim-modal-close" onclick="aimCloseModal('server')"></i>
            <div class="aim-modal-title">SERVER CONFIGURATION LOG</div>
            
            <div class="aim-code-block">
                <button class="aim-copy-trigger" onclick="aimCopyToClipboard('/home/www/DB/db_upbit.php\n$db_upbit = $pdo;', this)">COPY</button>
                <span class="aim-code-keyword"># 업비트 DB 정보 파일 경로</span><br>
                PATH: <span class="aim-code-path">/home/www/DB/db_upbit.php</span><br>
                HANDLER: <span class="aim-code-keyword">$db_upbit = $pdo;</span> <span style="color:#555;">// ★ UPBIT 전용 DB 핸들러</span>
            </div>

            <div class="aim-code-block">
                <button class="aim-copy-trigger" onclick="aimCopyToClipboard('/home/www/DB/db_gnu.php\nreturn $pdo_gnu;', this)">COPY</button>
                <span class="aim-code-keyword"># 그누보드 DB 정보 파일 경로</span><br>
                PATH: <span class="aim-code-path">/home/www/DB/db_gnu.php</span><br>
                HANDLER: <span class="aim-code-keyword">return $pdo_gnu;</span>
            </div>

            <div class="aim-code-block">
                <button class="aim-copy-trigger" onclick="aimCopyToClipboard('/home/www/DB/key_upbit_trade.php\n$UPBIT_ACCESS_KEY / $UPBIT_SECRET_KEY', this)">COPY</button>
                <span class="aim-code-keyword"># 업비트 개인 키 경로</span><br>
                PATH: <span class="aim-code-path">/home/www/DB/key_upbit_trade.php</span><br>
                KEYS: <span class="aim-code-keyword">$UPBIT_ACCESS_KEY / $UPBIT_SECRET_KEY</span>
            </div>
        </div>
    </div>

    <!-- AI 작업 팝업 모달 -->
    <div id="aim-modal-ai" class="aim-modal-overlay" onclick="aimCloseModal('ai')">
        <div class="aim-modal-content" onclick="event.stopPropagation()">
            <i class="fa-solid fa-xmark aim-modal-close" onclick="aimCloseModal('ai')"></i>
            <div class="aim-modal-title">AI ASSISTANT HUB</div>
            
            <a href="https://chat.openai.com" target="_blank" class="aim-ai-link-btn">
                <span><i class="fa-solid fa-bolt-lightning mr-3"></i> OPEN AI : CHATGPT</span>
                <i class="fa-solid fa-chevron-right"></i>
            </a>

            <a href="https://gemini.google.com" target="_blank" class="aim-ai-link-btn">
                <span><i class="fa-solid fa-wand-magic-sparkles mr-3"></i> GOOGLE : GEMINI</span>
                <i class="fa-solid fa-chevron-right"></i>
            </a>

            <a href="https://aistudio.google.com/" target="_blank" class="aim-ai-link-btn">
                <span><i class="fa-solid fa-code mr-3"></i> GOOGLE : AI STUDIO</span>
                <i class="fa-solid fa-chevron-right"></i>
            </a>
        </div>
    </div>

    <script>
        // 팝업 열기 함수
        function aimShowModal(type) {
            document.getElementById('aim-modal-' + type).style.display = 'flex';
        }

        // 팝업 닫기 함수
        function aimCloseModal(type) {
            document.getElementById('aim-modal-' + type).style.display = 'none';
        }

        // 클립보드 복사 함수
        function aimCopyToClipboard(text, btn) {
            navigator.clipboard.writeText(text).then(() => {
                const originalText = btn.innerHTML;
                btn.innerHTML = '<i class="fa-solid fa-check"></i> COPIED';
                btn.style.backgroundColor = 'var(--aim-neon-green)';
                btn.style.color = '#000';
                setTimeout(() => {
                    btn.innerHTML = originalText;
                    btn.style.backgroundColor = '';
                    btn.style.color = '';
                }, 1500);
            }).catch(err => {
                console.error('복사 실패:', err);
            });
        }

        window.addEventListener('load', () => {
            const loader = document.getElementById('aim-system-loader');
            const container = document.getElementById('aim-main-container');
            
            setTimeout(() => {
                loader.style.opacity = '0';
                setTimeout(() => { 
                    loader.style.display = 'none'; 
                    container.classList.add('aim-is-active'); 
                }, 600);
            }, 800);
        });

        // ESC 키로 팝업 닫기
        window.addEventListener('keydown', (e) => {
            if (e.key === 'Escape') {
                aimCloseModal('server');
                aimCloseModal('ai');
            }
        });
    </script>
</body>
</html>
<?php require_once '/home/www/GNU/_PAGE/tail.php'; ?>