/* ============================================
   Terminal Theme - Dark terminal-inspired blog
   ============================================ */

/* -- CSS Custom Properties -- */
:root {
  --term-bg: #1a1e24;
  --term-bg-alt: #21262d;
  --term-bg-card: #282c34;
  --term-border: rgba(139, 148, 158, 0.2);
  --term-text: #c9d1d9;
  --term-text-dim: #8b949e;
  --term-green: #3fb950;
  --term-amber: #d29922;
  --term-blue: #58a6ff;
  --term-red: #f85149;
  --term-pink: #db61a2;
  --term-cyan: #56d4dd;
  --term-white: #f0f6fc;
  --term-font: 'JetBrains Mono', 'Fira Code', 'Source Code Pro', 'Cascadia Code', 'Consolas', monospace;
  --term-font-body: 'Inter', 'Source Sans Pro', -apple-system, sans-serif;
  --term-radius: 6px;
  --term-glow: 0 0 10px rgba(63, 185, 80, 0.15);
}

/* -- Base Overrides -- */
html {
  font-size: 14px !important;
}

body, body.left-sidebar, body.right-sidebar {
  background: var(--term-bg) !important;
  color: var(--term-text) !important;
  font-family: var(--term-font-body) !important;
  line-height: 1.7 !important;
}

/* -- Use full screen width -- */
.container {
  width: 100% !important;
  max-width: 1400px !important;
  min-width: 0 !important;
  padding-left: 2em !important;
  padding-right: 2em !important;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--term-font) !important;
  color: var(--term-green) !important;
  letter-spacing: -0.02em;
}

h2 a, h3 a {
  color: var(--term-green) !important;
  text-decoration: none !important;
}

h2 a:hover, h3 a:hover {
  color: var(--term-cyan) !important;
  text-shadow: var(--term-glow);
}

a {
  color: var(--term-blue) !important;
  text-decoration: none !important;
  transition: color 0.2s ease, text-shadow 0.2s ease !important;
}

a:hover {
  color: var(--term-green) !important;
  text-shadow: 0 0 8px rgba(63, 185, 80, 0.3);
}

p, li, span, div {
  color: var(--term-text);
}

strong, b {
  color: var(--term-white);
}

em, i {
  color: var(--term-text-dim);
}

hr {
  border-color: var(--term-border) !important;
}

/* -- Header -- */
#header-wrapper {
  background: var(--term-bg-alt) !important;
  border-bottom: 1px solid var(--term-border) !important;
  box-shadow: none !important;
  padding: 1.5em 0 !important;
}

#header-wrapper .inner {
  background: none !important;
}

#header {
  background: none !important;
}

#logo {
  font-family: var(--term-font) !important;
  letter-spacing: -0.02em;
}

#logo a {
  color: var(--term-green) !important;
  text-shadow: var(--term-glow) !important;
}

#logo a:before {
  content: "~/";
  color: var(--term-text-dim);
  font-weight: 300;
}

#header > p {
  color: var(--term-text-dim) !important;
  font-family: var(--term-font) !important;
  font-size: 0.85em !important;
}

/* -- Navigation -- */
#nav {
  font-family: var(--term-font) !important;
}

#nav ul {
  background: none !important;
}

#nav > ul > li > a,
#nav > ul > li > span {
  color: var(--term-text-dim) !important;
  text-transform: none !important;
  font-size: 0.85em !important;
  letter-spacing: 0 !important;
  padding: 0.5em 1em !important;
  border-radius: var(--term-radius) !important;
  transition: all 0.2s ease !important;
}

#nav > ul > li > a:hover,
#nav > ul > li > a.current {
  color: var(--term-green) !important;
  background: rgba(63, 185, 80, 0.1) !important;
}

/* Dropdown menus */
#nav ul ul,
.dropotron {
  background: var(--term-bg-card) !important;
  border: 1px solid var(--term-border) !important;
  border-radius: var(--term-radius) !important;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4) !important;
  padding: 0.5em 0 !important;
}

.dropotron li a,
#nav ul ul li a {
  color: var(--term-text) !important;
  font-family: var(--term-font) !important;
  font-size: 0.8em !important;
  padding: 0.5em 1.2em !important;
  border: none !important;
  border-bottom: none !important;
}

.dropotron li a:hover,
#nav ul ul li a:hover {
  background: rgba(63, 185, 80, 0.1) !important;
  color: var(--term-green) !important;
}

.dropotron.level-0 {
  border-top: 2px solid var(--term-green) !important;
  margin-top: 0.5em !important;
}

.dropotron.level-0:before {
  border-bottom-color: var(--term-green) !important;
}

/* -- Main Content Area -- */
#main-wrapper {
  background: var(--term-bg) !important;
  border: none !important;
  box-shadow: none !important;
}

#main {
  background: none !important;
}

.container {
  background: none !important;
}

/* -- Article / Post Cards -- */
article.box, .box {
  background: var(--term-bg-card) !important;
  border: 1px solid var(--term-border) !important;
  border-radius: var(--term-radius) !important;
  box-shadow: none !important;
  padding: 2em !important;
  color: var(--term-text) !important;
}

article.box.post header,
article.box header {
  border-bottom: 1px solid var(--term-border);
  padding-bottom: 1em;
  margin-bottom: 1em;
}

article.box.post-excerpt {
  border-top: none !important;
  margin-bottom: 1.5em !important;
}

article.box.post-excerpt + article.box.post-excerpt {
  margin-top: 0;
}

/* Post metadata / info line */
.info {
  color: var(--term-text-dim) !important;
  font-family: var(--term-font) !important;
  font-size: 0.8em !important;
  padding: 0.5em 0 !important;
  border-bottom: 1px solid var(--term-border) !important;
  margin-bottom: 1em !important;
}

.info .stats {
  float: right;
}

.info .stats li a {
  color: var(--term-text-dim) !important;
}

.info .stats li a:hover {
  color: var(--term-green) !important;
}

/* Blog body content */
.BlogBody {
  color: var(--term-text) !important;
  line-height: 1.8 !important;
}

.BlogBody h2, .BlogBody h3, .BlogBody h4 {
  margin-top: 1.5em;
}

.BlogBody code,
code {
  background: var(--term-bg) !important;
  color: var(--term-amber) !important;
  font-family: var(--term-font) !important;
  padding: 0.15em 0.4em !important;
  border-radius: 3px !important;
  font-size: 0.9em !important;
  border: 1px solid var(--term-border) !important;
}

.BlogBody pre,
pre {
  background: var(--term-bg) !important;
  border: 1px solid var(--term-border) !important;
  border-radius: var(--term-radius) !important;
  padding: 1.2em !important;
  overflow-x: auto !important;
  color: var(--term-text) !important;
  font-family: var(--term-font) !important;
  font-size: 0.85em !important;
  line-height: 1.6 !important;
}

.BlogBody pre code,
pre code {
  background: none !important;
  border: none !important;
  padding: 0 !important;
  color: var(--term-text) !important;
}

.BlogBody blockquote,
blockquote {
  border-left: 3px solid var(--term-green) !important;
  background: rgba(63, 185, 80, 0.05) !important;
  padding: 1em 1.5em !important;
  margin: 1em 0 !important;
  border-radius: 0 var(--term-radius) var(--term-radius) 0 !important;
  color: var(--term-text-dim) !important;
}

/* Images */
.image.featured img,
#content img {
  border-radius: var(--term-radius) !important;
  border: 1px solid var(--term-border) !important;
}

/* -- Tags -- */
.term-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5em;
  align-items: center;
  padding: 1em 0;
  border-top: 1px solid var(--term-border);
  margin-top: 1.5em;
}

.term-tags .term-tag-label {
  color: var(--term-text-dim);
  font-family: var(--term-font);
  font-size: 0.8em;
  margin-right: 0.3em;
}

.term-tags a {
  display: inline-block;
  background: rgba(88, 166, 255, 0.12) !important;
  color: var(--term-blue) !important;
  font-family: var(--term-font) !important;
  font-size: 0.75em !important;
  padding: 0.3em 0.7em !important;
  border-radius: 3px !important;
  transition: all 0.2s ease !important;
  border: 1px solid rgba(88, 166, 255, 0.2) !important;
}

.term-tags a:hover {
  background: rgba(63, 185, 80, 0.15) !important;
  color: var(--term-green) !important;
  border-color: rgba(63, 185, 80, 0.3) !important;
}

/* -- Categories (folder style) -- */
ul.CategoryList {
  list-style: none !important;
  padding: 0 !important;
}

ul.CategoryList > li {
  margin-bottom: 0 !important;
  padding: 0.8em 1em !important;
  border-bottom: 1px solid var(--term-border) !important;
  transition: background 0.2s ease;
}

ul.CategoryList > li:last-child {
  border-bottom: none !important;
}

ul.CategoryList > li:hover {
  background: rgba(63, 185, 80, 0.05);
}

ul.CategoryList > li > a {
  font-family: var(--term-font) !important;
  font-size: 1.1em !important;
  font-weight: 600 !important;
  color: var(--term-green) !important;
  text-decoration: none !important;
}

ul.CategoryList > li > a:before {
  content: "\f07b  ";
  font-family: FontAwesome !important;
  color: var(--term-amber);
  margin-right: 0.3em;
}

ul.CategoryList > li > a:hover {
  color: var(--term-cyan) !important;
}

ul.CategoryList .cat-count {
  color: var(--term-text-dim);
  font-family: var(--term-font);
  font-size: 0.75em;
  display: block;
  margin-top: 0.2em;
  padding-left: 1.9em;
}

/* -- Sidebar -- */
#sidebar .box {
  background: var(--term-bg-card) !important;
  border: 1px solid var(--term-border) !important;
  border-radius: var(--term-radius) !important;
  margin-bottom: 1.5em !important;
}

#sidebar .box .inner {
  background: none !important;
  box-shadow: none !important;
}

#sidebar .box header h3,
#sidebar .box h3 {
  font-family: var(--term-font) !important;
  color: var(--term-green) !important;
  font-size: 0.9em !important;
}

#sidebar .box header h3:before,
#sidebar .box h3:before {
  color: var(--term-amber) !important;
}

/* Search box */
.box.search input[type="text"],
input[type="text"],
input[type="email"],
input[type="password"],
textarea,
select {
  background: var(--term-bg) !important;
  border: 1px solid var(--term-border) !important;
  border-radius: var(--term-radius) !important;
  color: var(--term-text) !important;
  font-family: var(--term-font) !important;
  padding: 0.6em 1em !important;
  transition: border-color 0.2s ease !important;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
textarea:focus {
  border-color: var(--term-green) !important;
  outline: none !important;
  box-shadow: 0 0 0 2px rgba(63, 185, 80, 0.15) !important;
}

/* -- Buttons -- */
.button, button,
input[type="submit"],
input[type="button"],
a.button {
  background: rgba(63, 185, 80, 0.15) !important;
  color: var(--term-green) !important;
  border: 1px solid rgba(63, 185, 80, 0.3) !important;
  border-radius: var(--term-radius) !important;
  font-family: var(--term-font) !important;
  font-size: 0.85em !important;
  padding: 0.6em 1.5em !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  text-shadow: none !important;
  box-shadow: none !important;
  background-image: none !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

.button:hover, button:hover,
input[type="submit"]:hover,
a.button:hover {
  background: rgba(63, 185, 80, 0.25) !important;
  color: var(--term-white) !important;
  border-color: var(--term-green) !important;
  box-shadow: var(--term-glow) !important;
}

a.button.morelink,
a.button.prevlink,
a.button.nextlink {
  background: rgba(88, 166, 255, 0.1) !important;
  color: var(--term-blue) !important;
  border-color: rgba(88, 166, 255, 0.25) !important;
  background-image: none !important;
}

a.button.morelink:hover,
a.button.prevlink:hover,
a.button.nextlink:hover {
  background: rgba(88, 166, 255, 0.2) !important;
  color: var(--term-white) !important;
  border-color: var(--term-blue) !important;
}

.button.alt {
  background: rgba(210, 153, 34, 0.12) !important;
  color: var(--term-amber) !important;
  border-color: rgba(210, 153, 34, 0.3) !important;
}

.button.alt:hover {
  background: rgba(210, 153, 34, 0.22) !important;
  color: var(--term-white) !important;
  border-color: var(--term-amber) !important;
}

a.button.active {
  box-shadow: 0 0 8px rgba(63, 185, 80, 0.4) !important;
  background: rgba(63, 185, 80, 0.25) !important;
  border-color: var(--term-green) !important;
}

/* -- Pagination -- */
.pagination .button {
  min-width: 2.75em;
}

/* -- Features / Home Cards -- */
#features-wrapper {
  background: var(--term-bg-alt) !important;
  border-top: 1px solid var(--term-border) !important;
  border-bottom: 1px solid var(--term-border) !important;
}

#features-wrapper .inner {
  background: none !important;
}

#features header h2 {
  color: var(--term-green) !important;
}

section.feature.card {
  background: var(--term-bg-card) !important;
  border: 1px solid var(--term-border) !important;
  border-radius: var(--term-radius) !important;
  padding: 0 !important;
  overflow: hidden;
  transition: border-color 0.3s ease, box-shadow 0.3s ease !important;
  cursor: pointer;
}

section.feature.card:hover {
  border-color: var(--term-green) !important;
  box-shadow: var(--term-glow) !important;
}

section.feature.card header {
  padding: 1em 1.2em 0 !important;
}

section.feature.card p {
  padding: 0 1.2em !important;
  color: var(--term-text-dim) !important;
  font-size: 0.9em !important;
}

section.feature.card .image.featured {
  margin: 0 !important;
  border-radius: 0 !important;
}

section.feature.card .image.featured img {
  border-radius: 0 !important;
  border: none !important;
  border-bottom: 1px solid var(--term-border) !important;
  width: 100%;
}

/* -- Banner -- */
#banner-wrapper {
  border-bottom: 1px solid var(--term-border) !important;
}

#banner-wrapper .inner {
  background-color: var(--term-bg-alt) !important;
  background-blend-mode: overlay !important;
}

#banner {
  font-family: var(--term-font) !important;
}

/* -- Footer -- */
#footer-wrapper {
  background: var(--term-bg-alt) !important;
  border-top: 1px solid var(--term-border) !important;
  color: var(--term-text-dim) !important;
}

#footer-wrapper .inner {
  background: none !important;
  box-shadow: none !important;
}

#footer {
  background: none !important;
}

#footer header h2 {
  color: var(--term-text) !important;
}

#footer header h2 strong {
  color: var(--term-green) !important;
}

/* Copyright */
#copyright {
  border-top: 1px solid var(--term-border) !important;
  background: none !important;
}

#copyright li {
  color: var(--term-text-dim) !important;
  font-family: var(--term-font) !important;
  font-size: 0.75em !important;
  border-left-color: var(--term-border) !important;
}

#copyright a {
  color: var(--term-text-dim) !important;
}

#copyright a:hover {
  color: var(--term-green) !important;
}

/* -- Calendar Widget -- */
.box.calendar .inner {
  background-color: var(--term-bg) !important;
  box-shadow: none !important;
  border: 1px solid var(--term-border) !important;
  border-radius: var(--term-radius) !important;
}

.box.calendar caption {
  color: var(--term-green) !important;
  font-family: var(--term-font) !important;
}

.box.calendar th {
  color: var(--term-amber) !important;
  border-top-color: var(--term-border) !important;
  box-shadow: none !important;
}

.box.calendar td {
  color: var(--term-text-dim) !important;
  border-top-color: var(--term-border) !important;
  box-shadow: none !important;
}

.box.calendar td a {
  color: var(--term-blue) !important;
}

.box.calendar td a:hover {
  background-color: rgba(63, 185, 80, 0.15) !important;
  color: var(--term-green) !important;
}

.box.calendar td.today a,
.box.calendar td.today > span {
  background-color: var(--term-green) !important;
  background-image: none !important;
  color: var(--term-bg) !important;
  box-shadow: 0 0 8px rgba(63, 185, 80, 0.4) !important;
}

/* -- Comments -- */
li.CommentListItem {
  border-bottom: 1px solid var(--term-border) !important;
  padding: 1em !important;
}

.CommentText {
  color: var(--term-text) !important;
}

.CommentHeader {
  color: var(--term-text-dim) !important;
  font-family: var(--term-font) !important;
  font-size: 0.8em !important;
}

/* -- Tables -- */
#content tr > th {
  background: var(--term-bg-alt) !important;
  color: var(--term-green) !important;
  font-family: var(--term-font) !important;
  border-bottom: 1px solid var(--term-border) !important;
}

#content tr:nth-child(even) {
  background: rgba(33, 38, 45, 0.5) !important;
}

#content tr:last-child {
  border-bottom-color: var(--term-border) !important;
}

#content td, #content th {
  padding: 0.5em 0.8em !important;
  border: 1px solid var(--term-border) !important;
}

/* -- Search Results -- */
ul.SearchResults > li > a:not(.button) {
  color: var(--term-green) !important;
  font-family: var(--term-font) !important;
}

/* -- Prompt cursor blink for header -- */
@keyframes blink {
  0%, 100% { opacity: 1; }
  50% { opacity: 0; }
}

#header > p:after {
  content: "_";
  color: var(--term-green);
  animation: blink 1s step-end infinite;
  margin-left: 2px;
}

/* -- Terminal prompt prefix on articles -- */
article.box.post > header > h2:before,
article.box.post-excerpt > header > h2:before {
  content: "> ";
  color: var(--term-amber);
  font-weight: 300;
}

/* -- Scrollbar styling -- */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: var(--term-bg);
}

::-webkit-scrollbar-thumb {
  background: var(--term-border);
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--term-text-dim);
}

/* -- Selection color -- */
::selection {
  background: rgba(63, 185, 80, 0.3);
  color: var(--term-white);
}

/* -- Mobile nav overrides -- */
@media screen and (max-width: 736px) {
  #nav {
    background: var(--term-bg-card) !important;
    border: 1px solid var(--term-border) !important;
  }

  #nav a {
    border-bottom-color: var(--term-border) !important;
  }

  #navButton .toggle {
    background: var(--term-bg-card) !important;
    border: 1px solid var(--term-border) !important;
    color: var(--term-text) !important;
  }

  #navButton .toggle:before {
    color: var(--term-green) !important;
  }
}

/* -- Misc overrides to kill old theme backgrounds -- */
#page-wrapper {
  background: var(--term-bg) !important;
}

.text-style1 .inner {
  background: none !important;
  box-shadow: none !important;
}

section.box {
  background: var(--term-bg-card) !important;
}

/* Remove old background images/patterns */
body:before,
#header-wrapper:before,
#main-wrapper:before,
#footer-wrapper:before,
#features-wrapper:before,
#banner-wrapper:before {
  background-image: none !important;
}

/* Home Cards override */
div.HomeCard {
  background: none !important;
}

h3.HomeCardTitle {
  font-family: var(--term-font) !important;
  color: var(--term-white) !important;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.8) !important;
}

p.HomeCardBlank {
  background-color: var(--term-bg-alt) !important;
  border: 1px solid var(--term-border) !important;
  border-radius: var(--term-radius) !important;
}

/* Star ratings */
.CommentStarsInput i,
.CommentStars i {
  color: var(--term-amber) !important;
}
