@charset "UTF-8";

/* =========================================
   CSS変数によるテーマ設定（RPG酒場風に修正）
========================================= */

/* 1. モダンテーマ（デフォルト）: クリーン＆鮮やかな青 (変更なし) */
:root {
    --bg-main: #f0fdfa;       /* 背景色: ミントホワイト */
    --text-main: #0f172a;     /* 文字色: 濃いネイビー */
    --card-bg: #ffffff;       /* カード背景: 白 */
    --border-color: #007bff;  /* 枠線色: 鮮やかなエレクトリックブルー */
    --border-width: 2px;
    --border-radius: 1rem;
    --shadow-base: 0 10px 15px -3px rgba(0, 123, 255, 0.15); /* 青みがかった影 */
    --shadow-hover: 0 20px 25px -5px rgba(0, 123, 255, 0.25);
    --transform-hover: translateY(-6px);
    --font-base: ui-sans-serif, system-ui, sans-serif;
    
    /* アクセントカラー */
    --badge-bg: #007bff;      /* 鮮やかなエレクトリックブルー */
    --badge-text: #ffffff;
    --title-border: #007bff;  /* 鮮やかな青の下線 */
    --header-bg: rgba(255, 255, 255, 0.9);
    --btn-bg: #ff4500;        /* 鮮やかなオレンジレッド */
    --btn-text: #ffffff;

    /* コード: VS Code Dark+ / bash ターミナル風（モダン・レトロ共通のエディタ調） */
    --vsc-editor-bg: #1e1e1e;
    --vsc-editor-fg: #d4d4d4;
    --vsc-titlebar-bg: #252526;
    --vsc-titlebar-fg: #cccccc;
    --vsc-border-outer: #3c3c3c;
    --vsc-accent-left: #3794ff;
    --vsc-terminal-prompt: #23d18b;
    --vsc-terminal-fg: #cccccc;
    --vsc-keyword: #569cd6;
    --vsc-string: #ce9178;
    --vsc-panel-shadow: 0 10px 28px rgba(0, 0, 0, 0.42), inset 0 1px 0 rgba(255, 255, 255, 0.04);

    /* 本文中インライン code（黒背景は使わず淡色のみ。黒背景はコードブロックのみ） */
    --prose-inline-code-bg: rgba(15, 23, 42, 0.06);
    --prose-inline-code-border: rgba(15, 23, 42, 0.13);
}

/* 2. レトロテーマ起動時: ダークグレー + くっきりアクセント */
body.theme-retro {
    --bg-main: #d1d5db;       /* 背景色: やや濃いグレー */
    --text-main: #111827;     /* 文字色: 黒寄りの濃グレー */
    --card-bg: #e5e7eb;       /* カード背景: 背景より少し明るいグレー */
    --border-color: #334155;  /* 枠線色: かっちりしたスレート */
    --border-width: 4px;
    --border-radius: 12px;
    --shadow-base: 0 8px 18px rgba(15, 23, 42, 0.25);
    --shadow-hover: 0 14px 24px rgba(15, 23, 42, 0.3);
    --transform-hover: translateY(-4px);
    --font-base: 'DotGothic16', sans-serif;
    
    /* アクセントカラー: くっきりしたサイバー寄り */
    --badge-bg: #7dd3fc;      /* 明るいシアン */
    --badge-text: #0f172a;
    --title-border: #0ea5e9;  /* はっきりしたスカイブルー */
    --header-bg: rgba(209, 213, 219, 0.95);
    --btn-bg: #22d3ee;        /* シアン */
    --btn-text: #0f172a;

    /* レトロ時もコード枠は同系を維持（カードとのコントラストで浮く） */
    --vsc-editor-bg: #181818;
    --vsc-titlebar-bg: #202020;

    --prose-inline-code-bg: rgba(17, 24, 39, 0.09);
    --prose-inline-code-border: rgba(51, 65, 85, 0.28);
}

/* スキルバッジの個別色設定（レトロモード用、はっきり配色） */
body.theme-retro #skills .custom-badge {
    background-color: var(--badge-bg);
}
body.theme-retro #skills .custom-badge:nth-child(2) {
    background-color: #67e8f9; /* シアン */
}
body.theme-retro #skills .custom-badge:nth-child(3) {
    background-color: #93c5fd; /* ブルー */
}
body.theme-retro #skills .custom-badge:nth-child(4n) {
    background-color: #38bdf8; /* 濃いシアン */
    color: #0f172a;
}

/* =========================================
   カスタムクラス
========================================= */

html { 
    scroll-behavior: smooth; 
    scroll-padding-top: 5rem;
}

body {
    background-color: var(--bg-main);
    color: var(--text-main);
    font-family: var(--font-base);
    transition: background-color 0.4s, color 0.4s;
}

/* 画像の切り替えロジック */
.img-retro { display: none; }
body.theme-retro .img-modern { display: none; }
body.theme-retro .img-retro { display: block; }

/* ドット絵未設定のカード: レトロモードでもモダン画像を表示 */
body.theme-retro .thumb-retro-pending .img-modern {
    display: block !important;
}

/* 共通パーツデザイン */
.custom-header {
    background-color: var(--header-bg);
    border-bottom: var(--border-width) solid var(--border-color);
    backdrop-filter: blur(8px);
    transition: background-color 0.4s;
}

.custom-card {
    background-color: var(--card-bg);
    border: var(--border-width) solid var(--border-color);
    border-radius: var(--border-radius);
    box-shadow: var(--shadow-base);
    transition: all 0.2s ease-in-out;
}
.custom-card.is-hoverable:hover {
    box-shadow: var(--shadow-hover);
    transform: var(--transform-hover);
}

.custom-border-b { border-bottom: var(--border-width) solid var(--border-color); }

.custom-badge {
    background-color: var(--badge-bg);
    color: var(--badge-text);
    border: var(--border-width) solid var(--border-color);
    border-radius: calc(var(--border-radius) / 2);
    padding: 0.3rem 1.2rem;
    font-weight: bold;
    font-size: 0.9rem;
    box-shadow: var(--shadow-base);
    letter-spacing: 0.05em;
}

.custom-title {
    border-bottom: calc(var(--border-width) * 2) solid var(--title-border);
    padding-bottom: 0.5rem;
    display: inline-block;
}

.custom-btn {
    background-color: var(--btn-bg);
    color: var(--btn-text);
    border: var(--border-width) solid var(--border-color);
    border-radius: 9999px;
    box-shadow: var(--shadow-base);
    transition: all 0.2s;
    cursor: pointer;
}
body.theme-retro .custom-btn {
    border-radius: 9999px;
}
.custom-btn:active {
    box-shadow: var(--shadow-hover);
    transform: var(--transform-hover);
}

/* 訪問者カウンタ（Moe Counter SVG） */
#visitor-counter {
    min-height: 0;
    line-height: 1;
}

.visitor-counter-img {
    height: 40px;
    width: auto;
    max-width: 100%;
    object-fit: contain;
    display: block;
}

body.theme-retro .visitor-counter-img {
    image-rendering: pixelated;
    image-rendering: crisp-edges;
}

/* プロフィール画像の隠しゲーム導線 */
.profile-secret-box {
    position: relative;
    overflow: hidden;
}

.profile-slide-layer {
    position: absolute;
    inset: 0;
    z-index: 2;
    touch-action: none;
    user-select: none;
    -webkit-user-select: none;
    cursor: grab;
    transition: transform 0.22s ease-out;
    will-change: transform;
}

.profile-slide-layer img {
    pointer-events: none;
    -webkit-user-drag: none;
}

.profile-slide-layer.is-dragging {
    cursor: grabbing;
    transition: none;
}

.secret-game-btn {
    position: absolute;
    left: 50%;
    bottom: 0.35rem;
    transform: translateX(-50%);
    z-index: 1;
    width: 3.4rem;
    height: 3.4rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border: var(--border-width) solid var(--border-color);
    border-radius: 9999px;
    background-color: var(--btn-bg);
    color: var(--btn-text);
    font-size: 1.7rem;
    font-weight: 700;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.18s ease-in-out;
    box-shadow: var(--shadow-base);
    text-decoration: none;
}

.secret-game-btn.is-revealed {
    opacity: 1;
    pointer-events: auto;
}

/* =========================================
   コード表示（サイト共通・テーマ変数に追従）
========================================= */

/* 等幅はドットフォントを継承しない（可読性のため） */
pre.code-block,
pre.code-block code {
    font-family: ui-monospace, "Cascadia Mono", "Cascadia Code", "Segoe UI Mono",
        "Ubuntu Mono", "Noto Sans Mono", Menlo, Consolas, monospace;
}

figure.code-sample {
    margin: 0;
    overflow: hidden;
    border-radius: calc(var(--border-radius) * 0.7);
    border: 1px solid var(--vsc-border-outer);
    box-shadow: var(--vsc-panel-shadow);
}

.code-sample-label {
    font-family: ui-monospace, "Cascadia Mono", "Cascadia Code", "Segoe UI Mono", Menlo,
        Consolas, monospace;
    display: block;
    width: 100%;
    max-width: 100%;
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    line-height: 1.4;
    margin: 0;
    padding: 0.42rem 1rem;
    box-sizing: border-box;
    color: var(--vsc-titlebar-fg);
    background: linear-gradient(180deg, #2d2d2d 0%, var(--vsc-titlebar-bg) 100%);
    border-bottom: 1px solid #1b1b1b;
    box-shadow: inset 0 -1px 0 rgba(55, 148, 255, 0.35);
}

.code-sample[data-lang="bash"] .code-sample-label {
    color: var(--vsc-terminal-prompt);
    text-shadow: 0 0 12px rgba(35, 209, 139, 0.25);
}

.code-sample[data-lang="yaml"] .code-sample-label {
    color: var(--vsc-string);
}

.code-sample[data-lang="powershell"] .code-sample-label {
    color: var(--vsc-keyword);
}

pre.code-block {
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    margin: 0;
    padding: 1rem 1.15rem;
    font-size: 0.8125rem;
    line-height: 1.65;
    tab-size: 4;
    -moz-tab-size: 4;
    color: var(--vsc-editor-fg);
    background-color: var(--vsc-editor-bg);
    border: none;
    border-left: 3px solid var(--vsc-accent-left);
    border-radius: 0;
    box-shadow: none;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

/* Highlight.js 適用後: テーマの背景・着色を優先し、枠だけ pre が持つ */
pre.code-block:has(code.hljs) {
    background-color: transparent;
    padding: 0;
    color: unset;
}

pre.code-block code.hljs {
    border-radius: 0 !important;
    margin: 0;
    padding: 1rem 1.15rem !important;
    font-weight: 400;
}

.code-sample[data-lang="bash"] pre.code-block code:not(.hljs) {
    color: var(--vsc-terminal-fg);
}

pre.code-block code:not(.hljs) {
    display: block;
    padding: 0;
    margin: 0;
    font-size: inherit;
    font-weight: 500;
    line-height: inherit;
    color: inherit;
    background: none;
    border: none;
    border-radius: 0;
    white-space: pre;
    word-break: normal;
    overflow-wrap: normal;
}

/* 本文中インライン code（暗い背景はコードブロックのみ） */
article .code-inline {
    font-family: ui-monospace, "Cascadia Mono", "Segoe UI Mono", Menlo, Consolas, monospace;
    font-size: 0.9em;
    font-weight: 600;
    padding: 0.12em 0.45em;
    color: var(--text-main);
    background-color: var(--prose-inline-code-bg);
    border: 1px solid var(--prose-inline-code-border);
    border-radius: calc(var(--border-radius) / 4);
    white-space: pre-wrap;
    overflow-wrap: anywhere;
    word-break: break-word;
    max-width: 100%;
    vertical-align: baseline;
}