@charset "UTF-8";
.wpcf7 .screen-reader-response {
position: absolute;
overflow: hidden;
clip: rect(1px, 1px, 1px, 1px);
clip-path: inset(50%);
height: 1px;
width: 1px;
margin: -1px;
padding: 0;
border: 0;
word-wrap: normal !important;
}
.wpcf7 .hidden-fields-container {
display: none;
}
.wpcf7 form .wpcf7-response-output {
margin: 2em 0.5em 1em;
padding: 0.2em 1em;
border: 2px solid #00a0d2; }
.wpcf7 form.init .wpcf7-response-output,
.wpcf7 form.resetting .wpcf7-response-output,
.wpcf7 form.submitting .wpcf7-response-output {
display: none;
}
.wpcf7 form.sent .wpcf7-response-output {
border-color: #46b450; }
.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output {
border-color: #dc3232; }
.wpcf7 form.spam .wpcf7-response-output {
border-color: #f56e28; }
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output {
border-color: #ffb900; }
.wpcf7-form-control-wrap {
position: relative;
}
.wpcf7-not-valid-tip {
color: #dc3232; font-size: 1em;
font-weight: normal;
display: block;
}
.use-floating-validation-tip .wpcf7-not-valid-tip {
position: relative;
top: -2ex;
left: 1em;
z-index: 100;
border: 1px solid #dc3232;
background: #fff;
padding: .2em .8em;
width: 24em;
}
.wpcf7-list-item {
display: inline-block;
margin: 0 0 0 1em;
}
.wpcf7-list-item-label::before,
.wpcf7-list-item-label::after {
content: " ";
}
.wpcf7-spinner {
visibility: hidden;
display: inline-block;
background-color: #23282d; opacity: 0.75;
width: 24px;
height: 24px;
border: none;
border-radius: 100%;
padding: 0;
margin: 0 24px;
position: relative;
}
form.submitting .wpcf7-spinner {
visibility: visible;
}
.wpcf7-spinner::before {
content: '';
position: absolute;
background-color: #fbfbfc; top: 4px;
left: 4px;
width: 6px;
height: 6px;
border: none;
border-radius: 100%;
transform-origin: 8px 8px;
animation-name: spin;
animation-duration: 1000ms;
animation-timing-function: linear;
animation-iteration-count: infinite;
}
@media (prefers-reduced-motion: reduce) {
.wpcf7-spinner::before {
animation-name: blink;
animation-duration: 2000ms;
}
}
@keyframes spin {
from {
transform: rotate(0deg);
}
to {
transform: rotate(360deg);
}
}
@keyframes blink {
from {
opacity: 0;
}
50% {
opacity: 1;
}
to {
opacity: 0;
}
}
.wpcf7 [inert] {
opacity: 0.5;
}
.wpcf7 input[type="file"] {
cursor: pointer;
}
.wpcf7 input[type="file"]:disabled {
cursor: default;
}
.wpcf7 .wpcf7-submit:disabled {
cursor: not-allowed;
}
.wpcf7 input[type="url"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"] {
direction: ltr;
}
.wpcf7-reflection > output {
display: list-item;
list-style: none;
}
.wpcf7-reflection > output[hidden] {
display: none;
}
  :root {
--vscode-blue: #4DA3FF;
--vscode-yellow: #FFD166;
--bg-white: #ffffff;
--bg-light: #f8f9fa;
--bg-dark: #0f172a;
--text-main: #1e1e1e;
--text-gray: #6a737d;
--border-color: #e1e4e8;
--container-width: 1100px;
--header-height: 70px; --sql-bg: #1e1e1e;
--sql-keyword: #569cd6;
--sql-string: #ce9178;
--sql-func: #dcdcaa;
--sql-comment: #6a9955;
--sql-line: #858585;
}
* {
box-sizing: border-box;
margin: 0;
padding: 0;
}
body {
font-family: 'Noto Sans JP', sans-serif;
color: var(--text-main);
background-color: var(--bg-white);
line-height: 1.7;
background-image: radial-gradient(var(--border-color) 1px, transparent 1px);
background-size: 24px 24px;
scroll-behavior: smooth; } .sr-only {
position: absolute;
width: 1px;
height: 1px;
padding: 0;
margin: -1px;
overflow: hidden;
clip: rect(0, 0, 0, 0);
white-space: nowrap;
border: 0;
}
a {
text-decoration: none;
color: inherit;
transition: 0.3s;
}
ul {
list-style: none;
}
img {
max-width: 100%;
display: block;
}
.container {
max-width: var(--container-width);
margin: 0 auto;
}
.mono {
font-family: 'JetBrains Mono', monospace;
} .site-header {
background: var(--bg-white);
opacity: 0.9;
backdrop-filter: blur(10px);
border-bottom: 1px solid var(--border-color);
position: sticky;
top: 0;
z-index: 100;
height: var(--header-height);
}
.header-inner {
display: flex;
justify-content: space-between;
align-items: center;
height: var(--header-height);
}
.logo-text {
font-size: 1.5rem;
font-weight: 700;
font-family: 'JetBrains Mono', monospace;
}
.logo-text span.blue { color: var(--vscode-blue); }
.logo-text span.yellow { color: var(--vscode-yellow); }
.logo-text span.gray { color: var(--text-gray); opacity: 0.4; }
.site-desc {
font-size: 10px;
color: var(--text-gray);
display: block;
margin-top: -4px;
}
.nav-list {
display: flex;
align-items: center;
gap: 24px;
font-size: 14px;
font-weight: 700;
list-style: none;
font-family: 'JetBrains Mono', monospace;
}
.nav-list a:hover {
color: var(--vscode-blue);
}
.nav-hamburger {
display: none;
text-align: center;
}
.nav-sp {
display: none;
}
.icon-x {
width: 1.25rem;
height: 1.25rem;
display: block;
}
.btn-contact a {
background: var(--vscode-blue);
color: #fff !important;
padding: 8px 20px;
border-radius: 6px;
}
.btn-contact a:hover {
opacity: 0.7;
} html, body {
overflow-x: clip;
} .menu-trigger {
display: none; position: relative;
width: 30px;
height: 24px;
background: none;
border: none;
cursor: pointer;
z-index: 200;
}
.menu-trigger span {
display: block;
position: absolute;
left: 0;
width: 100%;
height: 2px;
background-color: var(--text-main);
transition: all 0.4s;
}
.menu-trigger span:nth-child(1) { top: 0; }
.menu-trigger span:nth-child(2) { top: 11px; }
.menu-trigger span:nth-child(3) { bottom: 0; } .is-active .menu-trigger span:nth-child(1) {
transform: translateY(11px) rotate(-45deg);
}
.is-active .menu-trigger span:nth-child(2) {
opacity: 0;
}
.is-active .menu-trigger span:nth-child(3) {
transform: translateY(-11px) rotate(45deg);
} .hero-banner {
position: relative;
background: var(--bg-dark);
border-radius: 20px;
overflow: hidden;
aspect-ratio: 16 / 7;
display: flex;
align-items: center;
box-shadow: 0 20px 40px rgba(0,0,0,0.15);
}
.hero-img {
position: absolute;
inset: 0;
width: 100%;
height: 100%;
object-fit: cover;
opacity: 0.5;
transition: 0.3s;
}
.hero-banner:hover .hero-img {
transform: scale(1.05);
}
.hero-content {
position: relative;
z-index: 1;
padding: 0 60px;
color: #fff;
max-width: 800px;
}
.hero-label {
color: var(--vscode-blue);
font-size: 14px;
font-weight: 700;
letter-spacing: 0.1em;
margin-bottom: 8px;
display: block;
}
.hero-title {
font-family: 'Noto Sans JP', sans-serif;
font-size: clamp(1.8rem, 5vw, 3rem);
line-height: 1.2;
margin-bottom: 20px;
}
.hero-title::before {
content: "";
}
.hero-title span {
color: var(--vscode-yellow);
}
.hero-btn {
background: var(--vscode-blue);
color: #fff;
padding: 12px 32px;
border-radius: 8px;
font-weight: 700;
display: inline-block;
}
.hero-btn:hover {
opacity: 0.7;
} section {
padding-top: 40px;
} section:nth-child(1) {
padding-top: 20px;
} section:last-child {
padding-bottom: 100px;
}
h2.comment-text {
font-size: 1.5rem;
font-family: 'JetBrains Mono', monospace;
}
.section-header {
display: flex;
justify-content: space-between;
align-items: flex-end;
margin-bottom: 40px;
border-bottom: 2px solid var(--border-color);
padding-bottom: 10px;
}
.view-all {
font-size: 12px;
font-weight: 700;
color: var(--vscode-blue);
}
.view-all:hover {
text-decoration: underline;
}
h2.comment-text::before {
content: "\002F\002F  ";
color: var(--vscode-blue);
} .post-grid {
display: grid;
gap: 30px;
}
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.card {
background: var(--bg-white);
border: 1px solid var(--border-color);
border-radius: 12px;
overflow: hidden;
transition: 0.3s;
}
.card a {
display: block;
height: 100%;
}
.card:hover {
transform: translateY(-5px);
box-shadow: 0 10px 20px rgba(0,0,0,0.05);
}
.card-img {
width: 100%;
aspect-ratio: 16 / 9;
object-fit: cover;
}
.card-body {
padding: 20px;
}
.card-tag {
background: #f1f8ff;
color: var(--vscode-blue);
font-size: 11px;
font-weight: 700;
padding: 2px 8px;
border-radius: 4px;
}
.card-title {
font-size: 1.1rem;
font-weight: 700;
margin-bottom: 10px;
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
overflow: hidden;
}
.card-date {
font-size: 11px;
color: var(--text-gray);
font-family: 'JetBrains Mono', monospace;
} #blog {
margin-top: 40px;
padding-bottom: 40px;
background: var(--bg-light);
border-top: 1px solid var(--border-color);
border-bottom: 1px solid var(--border-color);
} .works-card .card-img {
aspect-ratio: 16 / 9;
}
.works-card .card-title {
font-size: 1.4rem;
} #about {
margin-top: 40px;
padding-bottom: 40px;
background: var(--bg-dark);
color: #fff;
}
#about .wp-block-group__inner-container {
margin: 0 auto;
}
.about-section {
color: #fff;
padding: 60px;
display: flex;
align-items: center;
gap: 60px;
}
#about .wp-block-columns {
display: grid;
grid-template-columns: 240px 1fr;
gap: 60px;
max-width: 56rem;
}
#about .wp-block-column:nth-child(1) {
display: flex;
align-items: center;
}
#about figure {
position: relative;
flex-shrink: 0;
}
#about figure::after {
content: "";
position: absolute;
inset: 10px -10px -10px 10px;
border: 2px solid var(--vscode-blue);
border-radius: 20px;
z-index: 0;
max-width: 240px;
}
#about img {
width: 240px;
height: 240px;
border-radius: 20px;
object-fit: cover;
position: relative;
z-index: 1;
background: #1e293b;
}
#about h2 {
font-family: 'JetBrains Mono', monospace;
font-size: 1.5rem;
font-weight: 700;
margin-bottom: 20px;
}
#about h2::before {
content: "\002F\002F  ";
color: var(--vscode-blue);
}
#about h3 {
color: var(--vscode-yellow);
font-size: 1.2rem;
font-weight: 700;
margin-bottom: 15px;
}
#about p {
color: var(--text-gray);
margin-bottom: 30px;
}
#about a {
border: 1px solid var(--text-gray);
border-radius: 0.25rem;
padding: 0.25rem 1rem;
color: #fff;
display: inline-block;
margin-right: 10px;
}
#about a:hover {
background-color: var(--text-gray);
} #contact {
text-align: center;
padding-top: 100px;;
}
#contact h2 {
font-size: 3rem;
margin-bottom: 20px;
}
#contact h2::before {
content: "";
}
.contact-btn {
background: var(--vscode-blue);
color: #fff;
padding: 16px 48px;
border-radius: 12px;
font-size: 1.2rem;
font-weight: 700;
display: inline-block;
box-shadow: 0 10px 20px rgba(77, 163, 255, 0.3);
}
.contact-btn:hover {
opacity: 0.7;
}
.link-arrow::after {
content: " \2192";
}
#contact p {
margin-bottom: 20px;
}  .breadcrumb { padding: 20px 0 0; font-size: 12px; color: var(--text-gray); }
.breadcrumb-list { display: flex; flex-wrap: wrap; }
.breadcrumb-item + .breadcrumb-item::before { content: ">"; margin: 0 10px; color: var(--text-gray); font-size: 10px; }
.breadcrumb-item a:hover { color: var(--vscode-blue); }
.breadcrumb-item.current { color: var(--text-main); font-weight: 700; } .archive-header {
padding: 40px 0;
background: var(--bg-light);
border-bottom: 1px solid var(--border-color);
margin-bottom: 50px;
}
.archive-title { color: var(--vscode-blue); font-size: 2.5rem; margin-bottom: 15px; letter-spacing: -0.02em; font-family: 'JetBrains Mono', monospace; }
.archive-category .archive-title::before { content: "\002F"; color: var(--text-gray); opacity: 0.4; margin-right: 5px; font-weight: 400; }
.archive-description { color: var(--text-gray); font-size: 0.95rem; max-width: 700px; }
.archive-tag .archive-title::before { content: "\0040"; color: var(--text-gray); opacity: 0.4; margin-right: 5px; font-weight: 400; }
.archive-title.category-title { color: var(--vscode-yellow);} .archive-container {
display: grid;
grid-template-columns: 1fr 320px; gap: 60px;
margin-bottom: 100px;
} .archive-list { display: flex; flex-direction: column; gap: 40px; }
.horizontal-card {
display: flex; gap: 24px;
background: var(--bg-white);
border: 1px solid transparent; border-radius: 8px;
padding: 0;
transition: transform 0.3s, box-shadow 0.3s;
}
.card-thumb {
flex-shrink: 0; width: 260px; aspect-ratio: 16 / 9;
border-radius: 8px; overflow: hidden; border: 1px solid var(--border-color);
}
.card-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s; }
.horizontal-card:hover .card-thumb img { transform: scale(1.05); }
.horizontal-card .card-body { flex-grow: 1; padding: 5px 0; display: flex; flex-direction: column; }
.tag-wrap { margin-bottom: 10px; }
.card-tag {
background: #f1f8ff; color: var(--vscode-blue);
font-size: 11px; font-weight: 700; padding: 3px 8px;
border-radius: 4px; display: inline-block; margin-right: 5px;
}
.horizontal-card .card-title { font-size: 1.4rem; font-weight: 700; margin-bottom: 10px; line-height: 1.4; min-height: 2.8em; }
.horizontal-card .card-excerpt { font-size: 0.9rem; color: var(--text-gray); margin-bottom: auto; line-height: 1.6; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; min-height: 4.8em; }
.horizontal-card .card-meta { margin-top: 15px; font-size: 12px; color: var(--text-gray); display: flex; align-items: center; gap: 10px; } .pagination { display: flex; justify-content: center; gap: 8px; margin-top: 60px; }
.page-numbers {
width: 40px; height: 40px; display: flex; align-items: center; justify-content: center;
border: 1px solid var(--border-color); border-radius: 6px; font-size: 14px;
transition: 0.3s;
}
.page-numbers:hover, .page-numbers.current {
background: var(--vscode-blue); color: #fff; border-color: var(--vscode-blue);
} .sidebar { display: flex; flex-direction: column; gap: 50px; }
.widget-title {
font-size: 14px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em;
margin-bottom: 20px; padding-bottom: 8px; border-bottom: 2px solid var(--text-main);
display: flex; align-items: center;
}
.widget-title::before { content: ""; width: 8px; height: 8px; background: var(--vscode-blue); margin-right: 10px; } .search-form { display: flex; border: 1px solid var(--border-color); border-radius: 6px; overflow: hidden; }
.search-form input { font-family: 'JetBrains Mono', monospace; border: none; padding: 12px; flex-grow: 1; outline: none; font-size: 14px; }
.search-form button { font-family: 'JetBrains Mono', monospace;  background: var(--vscode-blue); color: #fff; border: none; padding: 0 15px; cursor: pointer; font-weight: 700; margin: 0; }
.search-form button:hover { opacity: 0.7; } .mini-post-list { display: flex; flex-direction: column; gap: 15px; }
.mini-post-item { display: flex; gap: 12px; align-items: flex-start; }
.mini-post-thumb { width: 70px; height: 70px; border-radius: 6px; object-fit: cover; flex-shrink: 0; border: 1px solid var(--border-color); }
.mini-post-title { font-size: 13px; font-weight: 700; line-height: 1.5; }
.mini-post-item:hover .mini-post-title { color: var(--vscode-blue); } .category-list li { display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid var(--border-color); }
.category-list a { padding: 12px 0; font-size: 14px; width: 85%; }
.category-list a:hover { color: var(--vscode-blue); padding-left: 5px; } .cat-count { background: var(--bg-light); padding: 2px 8px; border-radius: 10px; font-size: 11px; color: var(--text-gray); } .profile-widget { text-align: center; background: var(--bg-white); border: 1px solid var(--border-color); padding: 30px 20px; border-radius: 12px; }
.profile-icon { display: inline; width: 120px; height: 120px; border-radius: 50%; margin-bottom: 15px; border: 2px solid var(--border-color); padding: 2px; }
.profile-name { font-weight: 700; font-size: 1.1rem; margin-bottom: 5px; }
.profile-desc { font-size: 13px; color: var(--text-gray); line-height: 1.6; margin-bottom: 20px; }
.profile-link { font-size: 12px; color: var(--vscode-blue); font-weight: 700; letter-spacing: 0.05em; }
.profile-link:hover { text-decoration: underline; } .sidebar-contact-btn {
display: flex; justify-content: center; align-items: center; gap: 10px;
width: 100%; padding: 16px; background: var(--vscode-blue);
color: #fff; border-radius: 8px; font-weight: 700; font-size: 14px;
box-shadow: 0 4px 15px rgba(77, 163, 255, 0.3); transition: 0.3s;
}
.sidebar-contact-btn:hover { opacity: 0.7; } .single-layout main {
min-width: 0;
}
.single-layout {
display: grid;
grid-template-columns: 1fr 320px;
gap: 60px;
margin-bottom: 100px;
}
.post-header { margin-bottom: 40px; }
.post-category { 
color: var(--vscode-yellow); font-weight: 700; font-size: 1.4rem; 
margin-top: 10px; display: inline-block;
}
.post-title { font-size: 2.2rem; line-height: 1.3; margin-bottom: 20px; letter-spacing: -0.02em; font-weight: 700; }
.post-title::before { content: "# "; color: var(--text-gray); opacity: 0.4; font-family: 'JetBrains Mono'; font-weight: 400; margin-right: 0.2em; }
.post-meta { display: flex; flex-wrap: wrap; align-items: center; gap: 20px; font-size: 13px; color: var(--text-gray); }
.post-meta time span { font-weight: 700; color: var(--text-main); margin-right: 5px; }
.post-thumbnail { 
margin-bottom: 50px; border-radius: 12px; overflow: hidden; 
border: 1px solid var(--border-color);
}
.post-thumbnail img { height: auto; width: 100%; } .post-content { font-size: 16px; color: var(--text-main); } .post-content h2, .post-content h3, .post-content h4 {
scroll-margin-top: calc(var(--header-height) - 30px);
} .post-content h2 { 
font-size: 1.6rem; margin: 60px 0 20px; padding-bottom: 10px; 
border-bottom: 2px solid var(--border-color); font-weight: 700;
}
.post-content h2::before { content: "## "; color: var(--vscode-blue); font-family: 'JetBrains Mono'; font-weight: 400; margin-right: 0.3em; }
.post-content h3 { font-size: 1.3rem; margin: 40px 0 15px; font-weight: 700; }
.post-content h3::before { content: "### "; color: var(--vscode-yellow); font-family: 'JetBrains Mono'; font-weight: 400; margin-right: 0.3em; }
.post-content h4 { font-size: 1.1rem; margin: 30px 0 10px; font-weight: 700; }
.post-content p { margin-bottom: 1.8em; } .post-content p a:not([class]) {
color: var(--vscode-blue); text-decoration: underline; text-underline-offset: 3px;
text-decoration-color: rgba(77, 163, 255, 0.4); font-weight: 700; transition: all 0.2s;
}
.post-content p a:not([class]):hover,
.post-content li a:not([class]):hover {
text-decoration-color: var(--vscode-blue); background: rgba(77, 163, 255, 0.1); border-radius: 2px;
} .post-content ul { margin-bottom: 1.8em; padding-left: 0.5em; list-style: none; }
.post-content ul li { position: relative; padding-left: 1.5em; margin-bottom: 0.5em; }
.post-content ul li::before { 
content: "-"; position: absolute; left: 0; 
color: var(--vscode-blue); font-family: 'JetBrains Mono'; font-weight: 700;
} .post-content ol { margin-bottom: 1.8em; padding-left: 1.5em; counter-reset: opti-counter; list-style: none; }
.post-content ol li { position: relative; padding-left: 2em; margin-bottom: 1em; counter-increment: opti-counter; }
.post-content ol li::before {
content: counter(opti-counter) ".";
position: absolute; left: 0; top: 0;
color: var(--vscode-blue); font-family: 'JetBrains Mono'; font-weight: 700;
font-size: 0.9em;
} .post-content figure { margin: 40px 0; }
.post-content figure img { border-radius: 8px; border: 1px solid var(--border-color); }
.post-content figcaption {
margin-top: 12px; text-align: center; font-size: 13px; color: var(--text-gray);
font-family: 'JetBrains Mono', monospace; display: flex; align-items: center; justify-content: center; gap: 8px;
}
.post-content figcaption::before { content: "["; color: var(--vscode-blue); }
.post-content figcaption::after { content: "]"; color: var(--vscode-blue); } .post-content code { background: var(--bg-light); padding: 2px 6px; 
border-radius: 4px; font-family: 'JetBrains Mono'; font-size: 0.9em;
color: #d946ef;
}
.post-content pre { margin-bottom: 30px;
border-radius: 8px;
overflow: hidden; } .post-content pre code.hljs {
padding: 20px;
font-family: 'JetBrains Mono';
font-size: 14px;
line-height: 1.6;
background: #1e1e1e; } .post-content blockquote {
border-left: 4px solid var(--vscode-blue); background: var(--bg-light);
padding: 20px; margin: 0 0 30px; color: var(--text-gray); font-style: italic;
} .post-content table {
width: 100%; border-collapse: collapse; margin-bottom: 30px; font-size: 0.95em;
}
.post-content th, .post-content td { border: 1px solid var(--border-color); padding: 12px; }
.post-content th { background: var(--bg-light); font-weight: 700; text-align: left; } .post-content input[type="text"],
.post-content input[type="email"],
.post-content textarea {
width: 100%;
padding: 15px;
margin-bottom: 20px;
border: 1px solid var(--border-color);
border-radius: 6px;
font-family: inherit;
font-size: 16px;
background: var(--bg-light);
transition: 0.3s;
}
.post-content input:focus,
.post-content textarea:focus {
outline: none;
border-color: var(--vscode-blue);
background: #fff;
box-shadow: 0 0 0 3px rgba(77, 163, 255, 0.1);
}
.post-content label {
display: block;
margin-bottom: 8px;
font-weight: 700;
font-size: 14px;
}
.post-content span.required {
color: #ef4444;
margin-left: 4px;
}
.post-content button, 
.post-content input[type="submit"] {
display: inline-block; background: var(--vscode-blue); color: #fff;
padding: 12px 40px; border-radius: 6px; font-weight: 700; text-decoration: none;
border: none; cursor: pointer; transition: 0.3s; font-size: 16px;
}
.post-content button:hover,
.post-content input[type="submit"]:hover { opacity: 0.7; }
.wp-block-search__label { width: auto; }
.wp-block-table thead { border: 1px solid var(--border-color); }  .opti-toc {
background-color: var(--bg-light);
border: 1px solid var(--border-color);
border-radius: 8px; padding: 25px; margin: 0 0 40px 0;
}
.opti-toc__title {
font-size: 14px; font-weight: 700; margin-bottom: 15px;
font-family: 'JetBrains Mono', monospace; display: flex; align-items: center; color: var(--text-main);
}
.opti-toc__title::before { content: ":: "; color: var(--vscode-blue); margin-right: 5px; }
.opti-toc__list { list-style: none !important; padding: 0 !important; margin: 0 !important; }
.opti-toc__list li { list-style: none !important; padding-left: 0 !important; margin-bottom: 8px !important; font-size: 14px; }
.opti-toc__list li::before { content: none !important; }
.opti-toc__list > li > a { font-weight: 700; text-decoration: none; }
.opti-toc__list > li > a:hover { opacity: 0.8; }
.opti-toc__list ul { list-style: none !important; padding-left: 20px !important; margin: 5px 0 !important; }
.opti-toc__list ul li { margin-bottom: 5px !important; font-size: 13px; }
.opti-toc__list ul li::before { content: "-" !important; position: static !important; margin-right: 5px; color: var(--text-gray); } .opti-link-card {
display: flex; gap: 20px; align-items: center; border: 1px solid var(--border-color);
border-radius: 8px; padding: 15px; margin: 30px 0; background: #fff; text-decoration: none;
transition: 0.3s;
}
.opti-link-card:hover { border-color: var(--vscode-blue); transform: translateY(-2px); }
.opti-link-card__thumb {
width: 120px; aspect-ratio: 16/9; object-fit: cover;
border-radius: 4px; background: var(--bg-light); flex-shrink: 0;
}
.opti-link-card__body { flex-grow: 1; }
.opti-link-card__title { font-weight: 700; font-size: 1rem; margin-bottom: 5px; color: var(--text-main); }
.opti-link-card__meta { font-size: 12px; color: var(--text-gray); display: flex; align-items: center; gap: 5px; }
.opti-link-card__meta::before { content: "🔗"; font-size: 10px; } .opti-btn {
display: inline-block; background: var(--vscode-blue); color: #fff !important;
padding: 12px 30px; border-radius: 6px; font-weight: 700; text-decoration: none;
margin: 20px 0; transition: 0.3s;
}
.opti-btn:hover { opacity: 0.7; } .post-tags { margin: 60px 0 40px; padding-top: 20px; border-top: 1px solid var(--border-color); }
.card-tag {
background: #f1f8ff; color: var(--vscode-blue); font-size: 12px; font-weight: 700;
padding: 4px 12px; border-radius: 4px; display: inline-block; margin-right: 8px; text-decoration: none;
}
.card-tag::before { content: "@"; opacity: 0.6; margin-right: 2px; }
.related-section {
margin-top: 60px; padding: 25px; background-color: var(--bg-light);
border-radius: 12px; border: 1px solid var(--border-color);
}
.related-title { font-size: 1.1rem; margin-bottom: 20px; display: flex; align-items: center; }
.related-title::before {
content: "SEE ALSO"; font-family: 'JetBrains Mono'; font-size: 12px;
background: var(--vscode-yellow); color: var(--bg-dark);
padding: 2px 8px; margin-right: 15px; border-radius: 4px; font-weight: 700;
}
.related-list { display: flex; flex-direction: column; gap: 12px; }
.related-item { display: flex; align-items: baseline; gap: 10px; font-size: 15px; font-weight: 700; }
.related-item::before { content: "\2192"; color: var(--vscode-blue); font-family: 'JetBrains Mono'; }
.related-item a:hover { color: var(--vscode-blue); text-decoration: underline; }
.post-nav { display: flex; justify-content: space-between; gap: 20px; margin-top: 40px; padding-top: 40px; border-top: 1px solid var(--border-color); }
.nav-link { 
flex: 1; font-size: 14px; font-weight: 700; text-decoration: none; padding: 20px;
}
.nav-link.prev span::before { content: "\003C "; }
.nav-link span { display: block; font-size: 11px; color: var(--text-gray); margin-bottom: 8px; }
.nav-link.next { text-align: right; }
.nav-link.next span::after { content: " \003E"; } .page-layout {
max-width: 800px;
margin: 60px auto 100px;
}
.page-title { font-size: 2.5rem; line-height: 1.3; margin-bottom: 20px; letter-spacing: -0.02em; font-weight: 700; text-align: center; }
.page-title::before { content: "# "; color: var(--text-gray); opacity: 0.4; font-family: 'JetBrains Mono'; font-weight: 400; } .error-header { text-align: center; }
.error-code {
font-size: 8rem;
font-weight: 700;
line-height: 1;
color: var(--bg-dark);
margin-bottom: 20px;
letter-spacing: -5px;
text-shadow: 4px 4px 0 var(--border-color);
}
.error-title {
font-size: 1.5rem;
margin-bottom: 20px;
font-weight: 700;
}
.error-content { text-align: center; }
.error-message {
color: var(--text-gray);
margin-bottom: 40px;
} .error-search {
width: 100%;
max-width: 400px;
margin: 0 auto;
} footer {
background: var(--bg-light);
border-top: 1px solid var(--border-color);
padding: 60px 0 30px;
}
.footer-grid {
display: grid;
grid-template-columns: 2fr 1fr 1fr;
gap: 40px;
margin-bottom: 60px;
}
.footer-logo {
font-size: 1.8rem;
font-weight: 700;
margin-bottom: 10px;
}
.footer-info p {
font-size: 13px;
color: var(--text-gray);
max-width: 300px;
}
.footer-nav { 
font-family: 'JetBrains Mono', monospace;
}
.footer-nav h4 {
color: var(--vscode-blue);
margin-bottom: 20px;
}
.footer-nav ul li {
margin-bottom: 10px;
font-size: 14px;
}
.copyright {
text-align: center;
font-size: 11px;
color: var(--text-gray);
padding-top: 30px;
border-top: 1px solid var(--border-color);
font-family: 'JetBrains Mono', monospace;
} .breadcrumb { padding: 20px 0 0; font-size: 12px; color: var(--text-gray); }
.breadcrumb-list { display: flex; flex-wrap: wrap; }
.breadcrumb-item + .breadcrumb-item::before { content: ">"; margin: 0 10px; color: var(--border-color); font-size: 10px; }
.breadcrumb-item a:hover { color: var(--vscode-blue); }
.archive-header {
padding: 60px 0;
background: var(--bg-light);
border-bottom: 1px solid var(--border-color);
margin-bottom: 50px;
} .sql-console {
background: var(--sql-bg);
border-radius: 8px;
box-shadow: 0 10px 30px rgba(0,0,0,0.15);
overflow: hidden;
font-family: 'JetBrains Mono', monospace;
border: 1px solid #333;
}
.sql-header {
background: #252526;
padding: 8px 15px;
display: flex;
align-items: center;
gap: 8px;
border-bottom: 1px solid #333;
}
.sql-dots { display: flex; gap: 6px; }
.sql-dot { width: 10px; height: 10px; border-radius: 50%; background: #5f5f5f; }
.sql-tab { color: #ccc; font-size: 12px; margin-left: 10px; }
.sql-body {
padding: 20px;
color: #d4d4d4;
font-size: 1.1rem;
line-height: 1.6;
position: relative;
}
.sql-body::before {
content: "1\A 2\A 3\A 4";
white-space: pre;
position: absolute; left: 15px; top: 20px;
color: var(--sql-line); text-align: right; opacity: 0.5; font-size: 0.9em; line-height: 1.8;
}
.sql-code { padding-left: 30px; display: block; }
.kwd { color: var(--sql-keyword); font-weight: 700; }
.str { color: var(--sql-string); }
.func { color: var(--sql-func); }
.cmt { color: var(--sql-comment); font-size: 0.9em; display: block; margin-top: 5px; }
.cursor {
display: inline-block; width: 8px; height: 1.2em; background: #fff;
vertical-align: text-bottom; animation: blink 1s step-end infinite; margin-left: 2px;
}
@keyframes blink { 50% { opacity: 0; } } .not-found {
text-align: center;
padding: 80px 40px;
background: var(--bg-light);
border-radius: 8px;
border: 2px dashed var(--border-color);
margin-bottom: 60px;
}
.not-found-icon {
font-size: 1.2rem;
font-weight: 700;
color: var(--vscode-yellow);
background: #2d2d2d;
display: inline-block;
padding: 8px 16px;
border-radius: 4px;
margin-bottom: 25px;
}
.not-found-title {
font-size: 2rem;
font-weight: 700;
margin-bottom: 15px;
color: var(--text-main);
letter-spacing: -0.02em;
}
.not-found-text {
color: var(--text-gray);
margin-bottom: 40px;
line-height: 1.8;
} @media (max-width: 992px) {
.grid-3 { grid-template-columns: repeat(2, 1fr); }
.container { padding-right: 20px; padding-left: 20px; }
.hero-banner { aspect-ratio: 16 / 9; }
.hero-content { padding: 0 40px; }
.about-section { flex-direction: column; padding: 40px; }
.hidden { display: none; }
.archive-container, .single-layout { grid-template-columns: 1fr; gap: 60px; }
.sidebar { max-width: 600px; margin: 0 auto; width: 100%; }
}
@media (max-width: 768px) {
.grid-3, .grid-2 { grid-template-columns: 1fr; }
.nav-hamburger { display: block; font-size: 1.7rem; }
.footer-grid { grid-template-columns: 1fr; }
.hero-title { font-size: 1.2rem; }
.contact-cta h2 { font-size: 2rem; }
.logo-text { font-size: 1.3rem; }
.hero-btn { padding: 5px 12px; }
.about-links { justify-content: center; }
#contact h2 { font-size: 1.3rem; }
.menu-trigger {
display: block; }
.post-title { font-size: 1.3rem; }
.site-nav {
position: fixed;
top: 0;
right: -100%; width: 70%;
height: 100vh;
background: rgba(255, 255, 255, 0.98);
padding-top: 100px;
transition: all 0.5s;
z-index: 150;
} .is-active .site-nav {
right: 0;
visibility: visible;
opacity: 1;
}
.nav-list {
flex-direction: column;
gap: 40px !important;
}
.nav-list a {
font-size: 1.5rem;
font-family:'JetBrains Mono', monospace;
} body.is-active {
overflow: hidden;
}
.archive-header {
padding: 20px 0;
margin-bottom: 30px;
}
.archive-title {
font-size: 1.4rem;
}
.horizontal-card {
border-radius: 12px;
border: 1px solid var(--border-color);
overflow: hidden;
flex-direction: column;
gap: 0;
}
.horizontal-card .card-thumb {
border-radius: 0;
width: 100%; aspect-ratio: 16/9;
border: none;
}
.horizontal-card .card-title {
font-size: 1.1rem;
min-height: auto;
}
.horizontal-card .card-excerpt{
min-height: auto;
}
.horizontal-card .card-body {
padding: 20px;
}
.post-content h2 {
font-size: 1.2rem;
}
.post-content h3 {
font-size: 1.1rem;
}
.page-title{
font-size: 1.4rem;
}
#about .wp-block-columns {
flex-direction: column;
gap: 30px;
grid-template-columns: none;
}
#about .wp-block-column:nth-child(1) {
margin: 0 auto;
}
.archive-container main {
max-width: 100%;
overflow: hidden;
}
} pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}.hljs{background:#1e1e1e;color:#dcdcdc}.hljs-keyword,.hljs-literal,.hljs-name,.hljs-symbol{color:#569cd6}.hljs-link{color:#569cd6;text-decoration:underline}.hljs-built_in,.hljs-type{color:#4ec9b0}.hljs-class,.hljs-number{color:#b8d7a3}.hljs-meta .hljs-string,.hljs-string{color:#d69d85}.hljs-regexp,.hljs-template-tag{color:#9a5334}.hljs-formula,.hljs-function,.hljs-params,.hljs-subst,.hljs-title{color:#dcdcdc}.hljs-comment,.hljs-quote{color:#57a64a;font-style:italic}.hljs-doctag{color:#608b4e}.hljs-meta,.hljs-meta .hljs-keyword,.hljs-tag{color:#9b9b9b}.hljs-template-variable,.hljs-variable{color:#bd63c5}.hljs-attr,.hljs-attribute{color:#9cdcfe}.hljs-section{color:gold}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}.hljs-bullet,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id,.hljs-selector-pseudo,.hljs-selector-tag{color:#d7ba7d}.hljs-addition{background-color:#144212;display:inline-block;width:100%}.hljs-deletion{background-color:#600;display:inline-block;width:100%}  @font-face {
font-display: swap; font-family: 'JetBrains Mono';
font-style: normal;
font-weight: 400;
src: url(//opticode-lab.com/wp-content/themes/opticode-lab/assets/fonts/jetbrains-mono-v24-latin-regular.woff2) format('woff2'); } @font-face {
font-display: swap; font-family: 'Noto Sans JP';
font-style: normal;
font-weight: 400;
src: url(//opticode-lab.com/wp-content/themes/opticode-lab/assets/fonts/noto-sans-jp-v56-latin-regular.woff2) format('woff2'); }@keyframes pchppFlash{20%{opacity:1}50%{opacity:0}80%{opacity:1}}.pochipp-box{position:relative;display:grid;grid-gap:0 24px;grid-template-areas:"areaImg areaBody" "areaBtns areaBtns";grid-template-rows:auto auto;grid-template-columns:100px 1fr;max-width:960px;padding:24px!important;color:#353535;font-size:16px;background:#fff;box-shadow:0 1px 8px -4px rgba(0,0,0,.2),0 0 0 1px rgba(0,0,0,.02)}body:not(#__) .pochipp-box{margin:2em auto}.pochipp-box .pochipp-box__logo{position:absolute;right:3px;bottom:4px;display:flex;align-items:center;justify-content:center;opacity:.2}.pochipp-box .pochipp-box__logo img{display:block;width:12px;height:12px;margin:0!important}.pochipp-box .pochipp-box__logo span{display:block;font-size:10px;line-height:1;transform:scale(.8)}.pochipp-box__image{grid-area:areaImg;margin:0;padding:0}.pochipp-box__image a{display:block;width:100%;text-decoration:none!important}.pochipp-box__image img{display:block;width:100%;height:auto;max-height:160px;-o-object-fit:contain;object-fit:contain}.pochipp-box__body{grid-area:areaBody;margin:0;padding:0}.pochipp-box__title{margin:0 0 8px;font-weight:700;line-height:1.6}.pochipp-box__title a{display:block;width:100%;color:inherit!important;text-decoration:none!important}.pochipp-box__info{margin:4px 0 0;font-size:12px;line-height:1.5;opacity:.75}.pochipp-box__price{margin:4px 0 0;font-size:13px;line-height:1.5}.pochipp-box__price span{font-size:10px;opacity:.75}.pochipp-box__review{display:flex;margin-top:4px}.pochipp-box__review a{display:flex;align-items:center;text-decoration:none!important}.pochipp-box__review img+span{margin-left:4px}.pochipp-box__review span{font-size:12px;color:#599ba3!important}.pochipp-box__review span.dashicons{display:flex;align-items:center;font-size:16px}.pochipp-box .pochipp-box__btns{position:relative;left:-4px;display:flex;flex-wrap:wrap;grid-area:areaBtns;align-items:flex-end;width:calc(100% + 8px);margin:12px 0 0;padding:0}.pochipp-box__btnwrap span{width:100%}.pochipp-box .pochipp-box__btnwrap{min-width:-moz-max-content;min-width:max-content;padding:4px}.pochipp-box__btnwrap.-on-sale{order:-1}.pochipp-box .pochipp-box__btn{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;margin:0!important;padding:12px;font-size:1em;line-height:1;letter-spacing:.5px;text-align:center;text-decoration:none!important}.pochipp-box .pochipp-box__btn:hover{opacity:.8}.pochipp-box .pochipp-box__btn img{position:absolute;display:block;width:1px;height:1px;visibility:hidden;opacity:0}.pochipp-box .pochipp-box__btn span{font-size:inherit;line-height:1}.pochipp-box .pochipp-box__saleInfo{font-size:12px;line-height:1;text-align:center}.pochipp-box__saleInfo.-top{margin-bottom:4px;font-weight:700}[data-sale-effect=flash] .pochipp-box__saleInfo{animation:1.5s linear 0s infinite pchppFlash}.pochipp-box__btnwrap.-amazon .pochipp-box__saleInfo{color:var(--pchpp-color-amazon)}.pochipp-box__btnwrap.-rakuten .pochipp-box__saleInfo{color:var(--pchpp-color-rakuten)}.pochipp-box__btnwrap.-yahoo .pochipp-box__saleInfo{color:var(--pchpp-color-yahoo)}.pochipp-box__btnwrap.-mercari .pochipp-box__saleInfo{color:var(--pchpp-color-mercari)}.pochipp-box__btnwrap.-custom .pochipp-box__saleInfo{color:var(--pchpp-color-custom)}.pochipp-box__btnwrap.-custom_2 .pochipp-box__saleInfo{color:var(--pchpp-color-custom-2)}.pochipp-box__price[data-disp-price=off]{display:none}.pochipp-box[data-btn-radius=off]{border-radius:1px}.pochipp-box[data-btn-radius=off] .pochipp-box__btn,.pochipp-box[data-btn-radius=off] .pochipp-box__image img,.pochipp-box[data-btn-radius=off] .pochipp-box__saleInfo{border-radius:1px}.pochipp-box[data-btn-radius=on]{border-radius:4px}.pochipp-box[data-btn-radius=on] .pochipp-box__image img{border-radius:4px}.pochipp-box[data-btn-radius=on] .pochipp-box__btn,.pochipp-box[data-btn-radius=on] .pochipp-box__saleInfo{border-radius:40px}.pochipp-box[data-btn-style=dflt] .pochipp-box__btn{position:relative;overflow:hidden;color:#fff!important;background-color:#3c3c3c;box-shadow:0 1px 4px -1px rgba(0,0,0,.2)}.pochipp-box[data-btn-style=dflt] .pochipp-box__btn::before{position:absolute;top:0;left:0;display:block;width:100%;height:100%;background:linear-gradient(175deg,#fff,transparent 50%,transparent 70%,#555);opacity:.1;content:""}.pochipp-box[data-btn-style=dflt] .-amazon>.pochipp-box__btn{background:var(--pchpp-color-amazon)}.pochipp-box[data-btn-style=dflt] .-rakuten>.pochipp-box__btn{background:var(--pchpp-color-rakuten)}.pochipp-box[data-btn-style=dflt] .-yahoo>.pochipp-box__btn{background:var(--pchpp-color-yahoo)}.pochipp-box[data-btn-style=dflt] .-mercari>.pochipp-box__btn{background:var(--pchpp-color-mercari)}.pochipp-box[data-btn-style=dflt] .-custom>.pochipp-box__btn{background:var(--pchpp-color-custom)}.pochipp-box[data-btn-style=dflt] .-custom_2>.pochipp-box__btn{background:var(--pchpp-color-custom-2)}.pochipp-box[data-btn-style=outline] .pochipp-box__btn{background:0 0!important;box-shadow:inset 0 0 0 1px currentColor,0 1px 4px -1px rgba(0,0,0,.2)}.pochipp-box[data-btn-style=outline] .-amazon>.pochipp-box__btn{color:var(--pchpp-color-amazon)}.pochipp-box[data-btn-style=outline] .-rakuten>.pochipp-box__btn{color:var(--pchpp-color-rakuten)}.pochipp-box[data-btn-style=outline] .-yahoo>.pochipp-box__btn{color:var(--pchpp-color-yahoo)}.pochipp-box[data-btn-style=outline] .-custom>.pochipp-box__btn{color:var(--pchpp-color-custom)}.pochipp-box[data-btn-style=outline] .-custom_2>.pochipp-box__btn{color:var(--pchpp-color-custom-2)}.pochipp-box[data-img=r]{grid-template-areas:"areaBody areaImg" "areaBtns areaBtns";grid-template-columns:1fr 100px}.pochipp-inline__btnwrap{display:inline-flex;margin:.5em .5em}.pochipp-inline__btnwrap>.pochipp-inline__btn{display:inline-block;width:var(--pchpp-inline-width,auto);padding:.75em 1.5em;overflow:hidden;color:var(--pchpp-inline-txt-color,inherit);font-size:1em;line-height:1.5;text-align:center;text-decoration:none!important;background-color:var(--pchpp-inline-bg-color,none);border-radius:var(--pchpp-inline-radius,0);box-shadow:var(--pchpp-inline-shadow,none)}.pochipp-inline__btnwrap>.pochipp-inline__btn:hover{opacity:.8}.position-fixed{position:fixed}@media screen and (min-width:600px){.pochipp-box.is-vrtcl{display:block;max-width:400px}.pochipp-box.is-vrtcl .pochipp-box__btns .pochipp-box__btnwrap{flex-basis:100%;min-width:100%;max-width:100%}.pochipp-box.is-vrtcl .pochipp-box__image{margin-bottom:16px}.pochipp-box.is-vrtcl .pochipp-box__image img{width:40%;max-width:120px;margin:0 auto}}@media screen and (min-width:1000px){.pochipp-box[data-lyt-pc=dflt]{grid-template-areas:"areaImg areaBody" "areaImg areaBtns"}.pochipp-box[data-lyt-pc=dflt][data-img=r]{grid-template-areas:"areaBody areaImg" "areaBtns areaImg"}.pochipp-box[data-lyt-pc=big]{grid-template-columns:120px 1fr}.pochipp-box[data-lyt-pc=big][data-img=r]{grid-template-columns:1fr 120px}.pochipp-box[data-lyt-pc=big] .pochipp-box__btns{margin-top:20px}.pochipp-box[data-lyt-pc=imgbig]{grid-template-areas:"areaImg areaBody" "areaImg areaBtns";grid-template-columns:140px 1fr}}@media screen and (min-width:1100px){[data-maxclmn-pc=fit]>.pochipp-box__btnwrap{flex:1;max-width:50%;font-size:15px}[data-maxclmn-pc="3"]>.pochipp-box__btnwrap{flex:0 0 33.3%;font-size:15px}[data-maxclmn-pc="2"]>.pochipp-box__btnwrap{flex-basis:50%;max-width:50%}}@media screen and (max-width:1099px){.pochipp-box__btnwrap{flex-basis:50%;min-width:50%!important;max-width:50%}}@media screen and (max-width:599px){.pochipp-box{grid-gap:0 16px;grid-template-columns:25% 1fr;width:88%;box-sizing:border-box;font-size:13px}.pochipp-box__price{font-size:12px}[data-maxclmn-mb="1"]>.pochipp-box__btnwrap{flex-basis:100%;max-width:100%;font-size:15px}[data-maxclmn-mb="2"]>.pochipp-box__btnwrap{font-size:13px}[data-maxclmn-mb="2"]>.pochipp-box__btnwrap.-on-sale{flex-basis:100%;max-width:100%}.pochipp-box .pochipp-box__btn{padding:12px 10px}[data-maxclmn-mb="2"]>.-long-text:not(.-on-sale) .pochipp-box__btn{font-size:12px;line-height:13px;letter-spacing:0;white-space:nowrap}.pochipp-box .pochipp-box__saleInfo{font-size:11px}.pochipp-box[data-img=r]{grid-template-columns:1fr 25%}.pochipp-box[data-lyt-mb=vrtcl]{display:block;font-size:14px}.pochipp-box[data-lyt-mb=vrtcl] .pochipp-box__image{width:100%;margin-bottom:16px}.pochipp-box[data-lyt-mb=vrtcl] .pochipp-box__image img{width:60%;max-width:120px;margin:0 auto}.pochipp-box[data-lyt-mb=vrtcl] .pochipp-box__body{width:100%;padding:0}}@media screen and (max-width:360px){.pochipp-box{width:100%;box-sizing:border-box;padding:16px!important;font-size:14px}}