/*!
Theme Name: GetToTheCloud
Theme URI: https://www.gettothe.cloud
Author: Alex ter Neuzen
Author URI: https://www.gettothe.cloud
Description: A clean, news-style WordPress theme for long-form technical writing — Azure, Bicep, PowerShell, hybrid cloud. Built around the "Category | Topic – Modifier" title cadence, a generous reading column, AI-cover-friendly post cards, navy social footer, and a code-block treatment that reads well at length. Originally designed for gettothe.cloud.
Version: 1.1.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: gettothecloud
Tags: blog, technology, news, two-columns, right-sidebar, custom-menu, custom-logo, featured-images, threaded-comments, translation-ready
*/

/* =====================================================================
   GetToTheCloud — Tokens
   ===================================================================== */
@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600;700&family=IBM+Plex+Serif:ital,wght@0,400;0,500;1,400&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root {
  --gttc-azure-50:#EAF4FF; --gttc-azure-100:#D2E7FF; --gttc-azure-200:#A5CEFF;
  --gttc-azure-300:#6DAEFF; --gttc-azure-400:#3D93FF; --gttc-azure-500:#1F8FFF;
  --gttc-azure-600:#0B5FD8; --gttc-azure-700:#0747A6; --gttc-azure-800:#053478; --gttc-azure-900:#032455;

  --gttc-navy-50:#F6F8FB; --gttc-navy-100:#EEF2F7; --gttc-navy-200:#DBE2EC;
  --gttc-navy-300:#B7C4D5; --gttc-navy-400:#8EA0B8; --gttc-navy-500:#5B7290;
  --gttc-navy-600:#2E5984; --gttc-navy-700:#20446F; --gttc-navy-800:#163459; --gttc-navy-900:#0E2A47;

  --gttc-paper:#FFFFFF; --gttc-paper-tint:#F8FAFC;
  --gttc-divider:#E4EAF1;

  --gttc-success:#1F8A5B; --gttc-warn:#C8870F; --gttc-danger:#C8351D;

  --gttc-tag-azure:#1F8FFF; --gttc-tag-powershell:#2671C8; --gttc-tag-bicep:#6B4FE0;
  --gttc-tag-devops:#0E7AB6; --gttc-tag-onprem:#4B5B6F; --gttc-tag-news:#C8351D;
  --gttc-tag-code:#20446F; --gttc-tag-tool:#6B4FE0; --gttc-tag-avd:#0747A6;

  --color-bg: var(--gttc-paper);
  --color-bg-tint: var(--gttc-navy-50);
  --color-fg: var(--gttc-navy-900);
  --color-fg-muted: var(--gttc-navy-600);
  --color-fg-subtle: var(--gttc-navy-500);
  --color-link: var(--gttc-azure-600);
  --color-link-hover: var(--gttc-azure-700);
  --color-border: var(--gttc-divider);
  --color-border-strong: var(--gttc-navy-200);
  --color-primary: var(--gttc-azure-500);

  --font-sans: 'IBM Plex Sans', 'Segoe UI', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-serif: 'IBM Plex Serif', Georgia, serif;
  --font-mono: 'JetBrains Mono', 'Cascadia Code', 'SFMono-Regular', Consolas, monospace;

  --radius-sm:4px; --radius-md:6px; --radius-lg:10px; --radius-pill:999px;

  --shadow-1: 0 1px 2px rgba(14,42,71,0.06);
  --shadow-2: 0 2px 6px rgba(14,42,71,0.08), 0 1px 2px rgba(14,42,71,0.04);
  --shadow-3: 0 8px 20px rgba(14,42,71,0.10), 0 2px 6px rgba(14,42,71,0.06);
  --shadow-4: 0 18px 40px rgba(14,42,71,0.14), 0 4px 10px rgba(14,42,71,0.08);
  --shadow-focus: 0 0 0 3px rgba(31,143,255,0.32);

  --ease-out: cubic-bezier(0.22,0.61,0.36,1);
  --dur-fast: 120ms; --dur-base: 200ms; --dur-slow: 320ms;

  --container-feed: 1180px;
  --container-narrow: 760px;
}

/* =====================================================================
   Reset & base
   ===================================================================== */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0; padding: 0;
  background: var(--color-bg);
  color: var(--color-fg);
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img, svg, video { max-width: 100%; display: block; }
a { color: var(--color-link); text-decoration: underline; text-underline-offset: 2px; text-decoration-thickness: 1px; transition: color var(--dur-fast) var(--ease-out); }
a:hover { color: var(--color-link-hover); text-decoration-thickness: 2px; }
:focus-visible { outline: none; box-shadow: var(--shadow-focus); border-radius: var(--radius-sm); }
.screen-reader-text { position: absolute; left: -10000px; top: auto; width: 1px; height: 1px; overflow: hidden; }
.skip-link { position: absolute; left: -10000px; top: 0; background: var(--gttc-navy-900); color: #fff; padding: 8px 14px; }
.skip-link:focus { left: 8px; top: 8px; z-index: 1000; }

.gttc-container { max-width: var(--container-feed); margin: 0 auto; padding: 0 24px; }
.gttc-row { display: flex; align-items: center; gap: 12px; }
.gttc-stack { display: flex; flex-direction: column; }

/* =====================================================================
   Header
   ===================================================================== */
.gttc-header { background: #fff; border-bottom: 1px solid var(--color-border); }
.gttc-header__strip {
  padding: 8px 0;
  border-bottom: 1px solid var(--color-border);
  font-size: 12px;
  color: var(--color-fg-muted);
}
.gttc-header__strip .gttc-row { justify-content: space-between; flex-wrap: wrap; gap: 8px; }
.gttc-header__logo {
  padding: 28px 24px 18px;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  text-align: center;
}
.gttc-header__logo .custom-logo,
.gttc-header__logo .gttc-logo-img { height: 64px; width: auto; }
.gttc-header__logo a { text-decoration: none; }
.gttc-sitetitle {
  font-family: var(--font-sans); font-weight: 700;
  font-size: 32px; letter-spacing: -0.01em; color: var(--gttc-navy-900); margin: 0;
}
.gttc-sitetitle .gttc-azure { color: var(--gttc-azure-500); }
.gttc-tagline {
  font-family: var(--font-serif); font-style: italic;
  color: var(--color-fg-muted); font-size: 14px; margin: 0;
}
.gttc-nav { background: #fff; border-top: 1px solid var(--color-border); padding: 6px 0; position: relative; }
.gttc-nav__inner { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; }
.gttc-nav__list, .gttc-nav__list ul { list-style: none; padding: 0; margin: 0; }
.gttc-nav__list { display: flex; gap: 24px; flex-wrap: wrap; }
.gttc-nav__list > li { position: relative; }
.gttc-nav__list a {
  font-weight: 600; font-size: 14px;
  color: var(--gttc-navy-700);
  text-decoration: none;
  padding: 10px 0;
  display: inline-block;
  position: relative;
}
.gttc-nav__list a:hover { color: var(--gttc-azure-500); }
.gttc-nav__list .current-menu-item > a,
.gttc-nav__list .current_page_item > a,
.gttc-nav__list .current-menu-parent > a { color: var(--gttc-azure-500); }
.gttc-nav__list .current-menu-item > a::after,
.gttc-nav__list .current_page_item > a::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: 0; height: 2px;
  background: var(--gttc-azure-500); border-radius: 1px;
}
.gttc-nav__list ul.sub-menu {
  position: absolute; top: 100%; left: 0;
  background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-md);
  min-width: 200px; padding: 6px 0; box-shadow: var(--shadow-3);
  opacity: 0; visibility: hidden; transition: opacity 120ms var(--ease-out);
  z-index: 50;
}
.gttc-nav__list li:hover > ul.sub-menu,
.gttc-nav__list li:focus-within > ul.sub-menu { opacity: 1; visibility: visible; }
.gttc-nav__list ul.sub-menu a { display: block; padding: 8px 14px; }
.gttc-nav__search {
  display: flex; align-items: center; gap: 8px;
  background: var(--gttc-navy-50);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 6px 10px;
  color: var(--gttc-navy-500);
  min-width: 220px;
}
.gttc-nav__search input {
  border: 0; outline: 0; background: transparent;
  font-family: inherit; font-size: 13px; color: var(--gttc-navy-900); width: 100%;
}
.gttc-nav__search input::placeholder { color: var(--gttc-navy-400); }
.gttc-socials { display: inline-flex; gap: 10px; color: var(--gttc-navy-500); }
.gttc-socials a { color: inherit; display: inline-flex; transition: color var(--dur-fast) var(--ease-out); }
.gttc-socials a:hover { color: var(--gttc-azure-500); }

.gttc-menu-toggle {
  display: none;
  background: transparent; border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 6px 12px; font-size: 13px; font-weight: 600;
  color: var(--gttc-navy-700); cursor: pointer;
}
@media (max-width: 720px) {
  .gttc-nav__list { display: none; width: 100%; flex-direction: column; gap: 0; }
  .gttc-nav__list.is-open { display: flex; }
  .gttc-nav__list a { padding: 10px 0; display: block; border-bottom: 1px solid var(--color-border); }
  .gttc-menu-toggle { display: inline-block; }
  .gttc-nav__search { min-width: 0; flex: 1; }
}

/* =====================================================================
   Page chrome
   ===================================================================== */
.gttc-page { padding: 32px 0 64px; }
.gttc-page__title {
  font-size: 32px; font-weight: 700; letter-spacing: -0.01em;
  margin: 0 0 4px 0; color: var(--color-fg);
}
.gttc-page__lede { margin: 0 0 28px 0; color: var(--color-fg-muted); font-size: 16px; }
.gttc-breadcrumb { color: var(--gttc-navy-500); font-size: 13px; margin-bottom: 6px; }
.gttc-breadcrumb a { color: inherit; text-decoration: none; }
.gttc-breadcrumb a:hover { color: var(--gttc-azure-500); }

.gttc-feed { display: grid; grid-template-columns: 1fr 320px; gap: 40px; align-items: start; }
.gttc-feed--no-sidebar { grid-template-columns: 1fr; max-width: 1080px; margin: 0 auto; }
@media (max-width: 960px) { .gttc-feed { grid-template-columns: 1fr; } }
.gttc-feed__list { display: flex; flex-direction: column; gap: 28px; min-width: 0; align-items: stretch; }
.gttc-feed--no-sidebar .gttc-feed__list { align-items: center; }
.gttc-feed--no-sidebar .gttc-feed__list > .gttc-card { width: 100%; max-width: 1080px; }
.gttc-feed__grid {
  display: flex;
  flex-wrap: wrap;
  gap: 28px;
  justify-content: center;
  width: 100%;
}
.gttc-feed__grid > .gttc-card {
  flex: 1 1 340px;
  min-width: 0;
  max-width: 520px;
}

/* =====================================================================
   Post card
   ===================================================================== */
.gttc-card {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-2);
  transition: box-shadow var(--dur-base) var(--ease-out);
  display: flex; flex-direction: column;
}
.gttc-card:hover { box-shadow: var(--shadow-3); }
.gttc-card:hover .gttc-cover__img { transform: scale(1.02); }
.gttc-card__body { padding: 16px 18px 18px; display: flex; flex-direction: column; gap: 10px; }
.gttc-card__title { margin: 0; font-size: 18px; font-weight: 600; line-height: 1.3; color: var(--gttc-navy-900); text-wrap: balance; }
.gttc-card__title a { color: inherit; text-decoration: none; }
.gttc-card__title a:hover { color: var(--gttc-azure-600); }
.gttc-card__title--lg { font-size: 26px; line-height: 1.2; letter-spacing: -0.01em; }
.gttc-card__excerpt { margin: 0; color: var(--gttc-navy-700); font-size: 14px; line-height: 1.55; }
.gttc-card__excerpt--clamp { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.gttc-readmore { color: var(--gttc-azure-600); font-weight: 600; font-size: 13px; text-decoration: none; align-self: flex-start; }
.gttc-readmore:hover { color: var(--gttc-azure-700); }
.gttc-readmore::after { content: ' →'; }

.gttc-card--featured .gttc-cover { aspect-ratio: 21/9; }
.gttc-card--featured .gttc-card__body { padding: 22px 26px 26px; gap: 14px; }

/* Cover */
.gttc-cover { position: relative; aspect-ratio: 3/2; overflow: hidden; background: linear-gradient(135deg, #163459, #0B5FD8 60%, #3D93FF); margin: 0; }
.gttc-cover__img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-slow) var(--ease-out); }
.gttc-cover__noise { position: absolute; inset: 0; background:
  radial-gradient(ellipse at 30% 40%, rgba(255,255,255,0.18), transparent 55%),
  radial-gradient(ellipse at 75% 70%, rgba(255,255,255,0.10), transparent 55%);
  mix-blend-mode: screen; pointer-events: none; }
.gttc-cover__label {
  position: absolute; left: 14px; bottom: 12px;
  font-family: var(--font-mono); font-size: 11px;
  color: rgba(255,255,255,0.85);
  text-shadow: 0 1px 2px rgba(0,0,0,0.4);
  max-width: 90%;
}

/* Chips */
.gttc-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.gttc-chip {
  border: 1px solid transparent;
  border-radius: var(--radius-pill);
  font-weight: 600;
  letter-spacing: 0.02em;
  padding: 2px 9px;
  font-size: 11px;
  text-decoration: none;
  display: inline-flex; align-items: center;
  background: rgba(31,143,255,0.10); color: var(--gttc-azure-600); border-color: rgba(31,143,255,0.25);
  transition: background var(--dur-fast) var(--ease-out);
}
.gttc-chip:hover { background: rgba(31,143,255,0.18); }
.gttc-chip--lg { padding: 4px 12px; font-size: 12px; }
.gttc-chip--azure-local { background: rgba(11,95,216,0.10); color: var(--gttc-azure-700); border-color: rgba(11,95,216,0.25); }
.gttc-chip--powershell { background: rgba(38,113,200,0.10); color: var(--gttc-tag-powershell); border-color: rgba(38,113,200,0.25); }
.gttc-chip--bicep      { background: rgba(107,79,224,0.10); color: var(--gttc-tag-bicep); border-color: rgba(107,79,224,0.25); }
.gttc-chip--devops     { background: rgba(14,122,182,0.10); color: var(--gttc-tag-devops); border-color: rgba(14,122,182,0.25); }
.gttc-chip--avd        { background: rgba(7,71,166,0.10);  color: var(--gttc-tag-avd); border-color: rgba(7,71,166,0.25); }
.gttc-chip--onprem     { background: rgba(75,91,111,0.10); color: var(--gttc-tag-onprem); border-color: rgba(75,91,111,0.25); }
.gttc-chip--news       { background: rgba(200,53,29,0.10); color: var(--gttc-tag-news); border-color: rgba(200,53,29,0.25); }
.gttc-chip--code       { background: rgba(32,68,111,0.10); color: var(--gttc-tag-code); border-color: rgba(32,68,111,0.25); }
.gttc-chip--tool       { background: rgba(107,79,224,0.10); color: var(--gttc-tag-tool); border-color: rgba(107,79,224,0.25); }

/* Byline */
.gttc-byline { display: flex; align-items: center; gap: 8px; color: var(--gttc-navy-500); font-size: 12px; flex-wrap: wrap; }
.gttc-byline a { color: var(--gttc-navy-700); text-decoration: none; }
.gttc-byline a:hover { color: var(--gttc-azure-600); }
.gttc-byline__dot { color: var(--gttc-navy-300); }
.gttc-byline__time { display: inline-flex; align-items: center; gap: 5px; }
.gttc-avatar {
  display: inline-flex; align-items: center; justify-content: center;
  width: 22px; height: 22px; border-radius: var(--radius-pill);
  background: linear-gradient(135deg, var(--gttc-azure-600), var(--gttc-azure-500));
  color: #fff; font-weight: 700; font-size: 10px; flex-shrink: 0; overflow: hidden;
}
.gttc-avatar img { width: 100%; height: 100%; object-fit: cover; }
.gttc-avatar--lg { width: 44px; height: 44px; font-size: 16px; }
.gttc-byline--lg { font-size: 13px; }
.gttc-byline--lg .gttc-avatar { width: 36px; height: 36px; font-size: 14px; }

/* =====================================================================
   Sidebar
   ===================================================================== */
.gttc-sidebar { display: flex; flex-direction: column; gap: 22px; min-width: 0; position: sticky; top: 16px; }
.gttc-widget {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 16px 18px;
}
.gttc-widget__title, .widget .widget-title, .widget h2 {
  font-size: 11px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--gttc-navy-500);
  margin: 0 0 12px 0; padding-bottom: 10px; border-bottom: 1px solid var(--color-border);
}
.gttc-widget ul, .widget ul { list-style: none; padding: 0; margin: 0; }
.gttc-widget li, .widget li {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 0; border-bottom: 1px solid var(--color-border);
  font-size: 14px; color: var(--gttc-navy-700);
}
.gttc-widget li:last-child, .widget li:last-child { border-bottom: 0; }
.gttc-widget li a, .widget li a { color: inherit; text-decoration: none; }
.gttc-widget li a:hover, .widget li a:hover { color: var(--gttc-azure-500); }
.gttc-widget .post-count, .widget .count { font-family: var(--font-mono); font-size: 12px; color: var(--gttc-navy-500); }
.gttc-widget--cta { background: var(--gttc-navy-50); }

.gttc-recent { display: flex; flex-direction: column; gap: 12px; }
.gttc-recent__item { display: flex; gap: 10px; align-items: flex-start; padding: 0; border: 0; }
.gttc-recent__item:not(:last-child) { padding-bottom: 12px; border-bottom: 1px solid var(--color-border); }
.gttc-recent__thumb {
  width: 60px; height: 60px; border-radius: var(--radius-md); flex-shrink: 0;
  background: linear-gradient(135deg, var(--gttc-navy-800), var(--gttc-azure-500));
  background-size: cover; background-position: center;
}
.gttc-recent__title { font-size: 13px; font-weight: 600; line-height: 1.35; color: var(--gttc-navy-900); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.gttc-recent__title a { color: inherit; text-decoration: none; }
.gttc-recent__item:hover .gttc-recent__title { color: var(--gttc-azure-600); }
.gttc-recent__date { font-size: 11px; color: var(--gttc-navy-500); margin-top: 4px; }

/* Default WP widget overrides */
.widget select { width: 100%; padding: 8px 10px; border: 1px solid var(--color-border); border-radius: var(--radius-md); font-family: inherit; font-size: 14px; background: #fff; }
.widget_calendar table { width: 100%; border-collapse: collapse; font-size: 13px; }
.widget_calendar caption { font-weight: 600; color: var(--gttc-navy-700); padding-bottom: 6px; }
.widget_calendar th, .widget_calendar td { padding: 4px; text-align: center; color: var(--gttc-navy-700); border: 0; }
.widget_calendar tbody td { border-bottom: 0; }
.widget_tag_cloud a { display: inline-block; margin: 0 4px 6px 0; padding: 3px 10px; background: var(--gttc-navy-50); color: var(--gttc-navy-700); border-radius: var(--radius-pill); font-size: 12px !important; text-decoration: none; border: 1px solid var(--color-border); }
.widget_tag_cloud a:hover { background: var(--gttc-azure-50); color: var(--gttc-azure-700); border-color: var(--gttc-azure-200); }

.gttc-search { display: flex; align-items: center; gap: 8px; border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 8px 10px; color: var(--gttc-navy-500); }
.gttc-search input[type=search] { border: 0; outline: 0; flex: 1; font-family: inherit; font-size: 13px; color: var(--gttc-navy-900); background: transparent; min-width: 0; }
.gttc-search button { border: 0; background: transparent; color: var(--gttc-navy-500); cursor: pointer; padding: 2px; }

/* =====================================================================
   Single post
   ===================================================================== */
.gttc-article { background: #fff; }
.gttc-article__cover { width: 100%; margin: 0 0 24px; }
.gttc-article__cover .gttc-cover {
  aspect-ratio: auto;
  min-height: 0;
  max-height: none;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--gttc-navy-100);
}
.gttc-article__cover .gttc-cover__img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
}
/* When there is no real featured image, render the gradient fallback at a fixed aspect. */
.gttc-article__cover .gttc-cover:not(:has(.gttc-cover__img)) {
  aspect-ratio: 3 / 2;
  min-height: 240px;
  background: linear-gradient(135deg, #163459, #0B5FD8 60%, #3D93FF);
}
.gttc-article__inner { max-width: var(--container-narrow); margin: 0 auto; padding: 28px 24px 56px; }
.gttc-article__title { font-size: 40px; font-weight: 700; line-height: 1.15; letter-spacing: -0.02em; color: var(--color-fg); text-wrap: balance; margin: 18px 0 14px; }
@media (max-width: 600px) { .gttc-article__title { font-size: 30px; } }
.gttc-back { background: transparent; border: 0; color: var(--gttc-navy-500); font-family: inherit; font-size: 13px; font-weight: 600; padding: 0; text-decoration: none; }
.gttc-back:hover { color: var(--gttc-azure-500); }
.gttc-rule { border: 0; border-top: 1px solid var(--color-border); margin: 22px 0; }

/* Prose */
.gttc-prose, .entry-content { font-family: var(--font-sans); font-size: 16px; line-height: 1.75; color: var(--color-fg); word-wrap: break-word; }
.gttc-prose > * + *, .entry-content > * + * { margin-top: 18px; }
.gttc-prose h1, .entry-content h1 { font-size: 32px; font-weight: 700; margin: 40px 0 12px; line-height: 1.2; letter-spacing: -0.02em; }
.gttc-prose h2, .entry-content h2 { font-size: 26px; font-weight: 700; margin: 36px 0 12px; line-height: 1.25; letter-spacing: -0.01em; }
.gttc-prose h3, .entry-content h3 { font-size: 20px; font-weight: 600; margin: 28px 0 10px; }
.gttc-prose h4, .entry-content h4 { font-size: 17px; font-weight: 600; margin: 24px 0 8px; }
.gttc-prose ul, .gttc-prose ol, .entry-content ul, .entry-content ol { padding-left: 22px; }
.gttc-prose li, .entry-content li { margin-bottom: 4px; }
.gttc-prose blockquote, .entry-content blockquote {
  border-left: 3px solid var(--gttc-azure-500);
  background: var(--gttc-azure-50);
  padding: 14px 18px; margin: 22px 0; border-radius: 0 var(--radius-md) var(--radius-md) 0;
  font-family: var(--font-serif); font-style: italic; color: var(--gttc-navy-800);
}
.gttc-prose blockquote p, .entry-content blockquote p { margin: 0; }
.gttc-prose code, .entry-content code {
  font-family: var(--font-mono); font-size: 0.9em;
  background: var(--gttc-navy-50); color: var(--gttc-navy-900);
  padding: 2px 6px; border-radius: var(--radius-sm); border: 1px solid var(--color-border);
}
.gttc-prose pre, .entry-content pre {
  margin: 22px 0; background: var(--gttc-navy-900); color: #E6ECF5;
  padding: 18px 20px; border-radius: var(--radius-md);
  font-family: var(--font-mono); font-size: 13.5px; line-height: 1.6;
  overflow: auto; border: 1px solid var(--gttc-navy-800);
}
.gttc-prose pre code, .entry-content pre code { background: transparent; border: 0; padding: 0; color: inherit; font-size: inherit; }
.gttc-prose img, .entry-content img { border-radius: var(--radius-md); }
.gttc-prose table, .entry-content table { width: 100%; border-collapse: collapse; margin: 22px 0; font-size: 14px; }
.gttc-prose th, .entry-content th { background: var(--gttc-navy-50); padding: 10px 12px; text-align: left; font-weight: 600; border-bottom: 1px solid var(--color-border); }
.gttc-prose td, .entry-content td { padding: 10px 12px; border-bottom: 1px solid var(--color-border); }

/* WP alignment helpers */
.alignleft  { float: left; margin: 0 24px 18px 0; max-width: 50%; }
.alignright { float: right; margin: 0 0 18px 24px; max-width: 50%; }
.aligncenter { display: block; margin: 18px auto; }
.alignwide  { margin-left: calc(50% - 50vw + 12px); margin-right: calc(50% - 50vw + 12px); max-width: 100vw; }
.alignfull  { margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); max-width: 100vw; }
.wp-caption { max-width: 100%; }
.wp-caption-text, .gallery-caption { font-size: 13px; color: var(--gttc-navy-500); text-align: center; margin-top: 6px; }
.sticky .gttc-card { border-color: var(--gttc-azure-300); }
.bypostauthor { /* no-op */ }

/* Callouts (helper class for custom blocks) */
.gttc-callout { margin: 22px 0; padding: 14px 16px; border-left: 3px solid var(--gttc-azure-500); background: var(--gttc-azure-50); border-radius: 0 var(--radius-md) var(--radius-md) 0; color: var(--color-fg); }
.gttc-callout strong { color: var(--gttc-azure-700); margin-right: 4px; }
.gttc-callout--warn { border-color: var(--gttc-warn); background: #FBF6E8; }
.gttc-callout--warn strong { color: #8A5A06; }
.gttc-callout--success { border-color: var(--gttc-success); background: #EDF7F1; }
.gttc-callout--success strong { color: #0F6B44; }

/* Post nav + tags + share */
.gttc-postnav { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 24px; }
@media (max-width: 600px) { .gttc-postnav { grid-template-columns: 1fr; } }
.gttc-postnav__side {
  text-align: left; background: #fff;
  border: 1px solid var(--color-border); border-radius: var(--radius-md);
  padding: 16px 18px; text-decoration: none; display: block;
  transition: box-shadow var(--dur-base) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
}
.gttc-postnav__side:hover { border-color: var(--gttc-azure-300); box-shadow: var(--shadow-2); }
.gttc-postnav__side--right { text-align: right; }
.gttc-postnav__eyebrow { font-size: 11px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gttc-navy-500); margin-bottom: 6px; }
.gttc-postnav__title { font-size: 15px; font-weight: 600; color: var(--gttc-navy-900); }

.gttc-tags { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; margin: 24px 0 0; color: var(--gttc-navy-500); font-size: 13px; }

/* Related */
.gttc-related { margin: 56px 0 0; }
.gttc-related__head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 18px; border-bottom: 1px solid var(--color-border); padding-bottom: 10px; }
.gttc-related__eyebrow { font-size: 18px; font-weight: 700; color: var(--color-fg); }
.gttc-related__head a { color: var(--gttc-azure-600); text-decoration: none; font-size: 13px; font-weight: 600; }
.gttc-related__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
@media (max-width: 900px) { .gttc-related__grid { grid-template-columns: 1fr; } }

/* Comments */
.gttc-comments { margin-top: 48px; padding-top: 32px; border-top: 1px solid var(--color-border); }
.gttc-comments__title { font-size: 22px; font-weight: 700; margin: 0 0 18px; color: var(--color-fg); }
.gttc-comments .comment-list { list-style: none; padding: 0; margin: 0; }
.gttc-comments .comment-list li { padding: 14px 0; border-bottom: 1px solid var(--color-border); }
.gttc-comments .comment-meta { font-size: 13px; color: var(--gttc-navy-500); margin-bottom: 6px; }
.gttc-comments .comment-author { color: var(--gttc-navy-700); font-weight: 600; }
.gttc-comments .comment-form { margin-top: 24px; display: flex; flex-direction: column; gap: 12px; }
.gttc-comments .comment-form input[type=text], .gttc-comments .comment-form input[type=email], .gttc-comments .comment-form input[type=url], .gttc-comments .comment-form textarea {
  width: 100%; padding: 10px 12px; border: 1px solid var(--color-border); border-radius: var(--radius-md);
  font-family: inherit; font-size: 14px; color: var(--gttc-navy-900); background: #fff;
}
.gttc-comments .comment-form textarea { min-height: 120px; resize: vertical; }
.gttc-comments .submit, .gttc-button {
  background: var(--gttc-azure-500); color: #fff; border: 0;
  padding: 10px 22px; border-radius: var(--radius-md);
  font-family: inherit; font-weight: 600; font-size: 14px;
  cursor: pointer; align-self: flex-start; text-decoration: none;
  transition: background var(--dur-fast) var(--ease-out);
}
.gttc-comments .submit:hover, .gttc-button:hover { background: var(--gttc-azure-600); }

/* Pagination */
.gttc-pagination, .nav-links { display: flex; gap: 6px; align-items: center; justify-content: center; margin-top: 36px; flex-wrap: wrap; }
.gttc-pagination a, .gttc-pagination span, .nav-links a, .nav-links .current {
  background: #fff; border: 1px solid var(--color-border);
  padding: 6px 12px; border-radius: var(--radius-md);
  font-size: 13px; color: var(--gttc-navy-700); text-decoration: none;
}
.gttc-pagination a:hover, .nav-links a:hover { background: var(--gttc-navy-50); color: var(--gttc-azure-600); }
.gttc-pagination .current, .nav-links .current { background: var(--gttc-azure-500); border-color: var(--gttc-azure-500); color: #fff; font-weight: 600; }

/* =====================================================================
   Footer
   ===================================================================== */
.gttc-footer { background: var(--gttc-navy-900); color: #E6ECF5; margin-top: 72px; padding: 56px 0 28px; }
.gttc-footer a { color: var(--gttc-azure-300); }
.gttc-footer a:hover { color: var(--gttc-azure-100); }
.gttc-footer__cta { display: grid; grid-template-columns: 1.2fr 1fr; gap: 40px; }
@media (max-width: 720px) { .gttc-footer__cta { grid-template-columns: 1fr; } }
.gttc-footer__eyebrow { color: var(--gttc-azure-300); font-size: 12px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 8px; }
.gttc-footer__title { font-size: 26px; font-weight: 700; margin: 0 0 12px; color: #fff; letter-spacing: -0.01em; line-height: 1.2; }
.gttc-footer__lede { font-size: 15px; line-height: 1.6; color: #B7C4D5; margin: 0; max-width: 460px; }
.gttc-footer__channels { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 10px 24px; font-size: 14px; color: #DBE2EC; }
.gttc-footer__channels li { padding: 0; border: 0; color: inherit; }
.gttc-footer__channels a { color: inherit; text-decoration: none; }
.gttc-footer__channels a:hover { color: var(--gttc-azure-300); }
.gttc-footer__bio { display: flex; gap: 14px; align-items: flex-start; margin-top: 44px; padding-top: 28px; border-top: 1px solid rgba(255,255,255,0.08); }
.gttc-footer__bio p { margin: 4px 0 0; color: #B7C4D5; font-size: 14px; line-height: 1.55; max-width: 640px; }
.gttc-footer__name { color: #fff; font-weight: 700; font-size: 16px; }
.gttc-footer__legal { margin-top: 28px; color: #8EA0B8; font-size: 12px; display: flex; gap: 10px; flex-wrap: wrap; }
.gttc-footer__legal a { color: inherit; }

/* =====================================================================
   Author page
   ===================================================================== */
.gttc-author {
  display: grid;
  grid-template-columns: 168px 1fr;
  gap: 32px;
  align-items: start;
  background: linear-gradient(180deg, var(--gttc-navy-50) 0%, #fff 100%);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 32px 36px;
  margin-bottom: 36px;
  position: relative;
  overflow: hidden;
}
.gttc-author::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px;
  background: linear-gradient(90deg, var(--gttc-azure-500), var(--gttc-azure-700));
}
@media (max-width: 720px) {
  .gttc-author { grid-template-columns: 1fr; text-align: center; padding: 28px 22px; }
}
.gttc-author__avatar {
  width: 168px; height: 168px;
  border-radius: var(--radius-pill);
  background: linear-gradient(135deg, var(--gttc-azure-600), var(--gttc-azure-500));
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  box-shadow: var(--shadow-3);
  border: 4px solid #fff;
  flex-shrink: 0;
}
.gttc-author__avatar img, .gttc-author__avatar-img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.gttc-author__initial { color: #fff; font-size: 64px; font-weight: 700; }
@media (max-width: 720px) { .gttc-author__avatar { margin: 0 auto; } }

.gttc-author__meta { min-width: 0; }
.gttc-author__eyebrow { color: var(--gttc-azure-600); margin: 0 0 6px; }
.gttc-eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.gttc-author__name {
  font-family: var(--font-sans);
  font-size: 36px;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.15;
  color: var(--color-fg);
  margin: 0 0 6px;
}
.gttc-author__role {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 16px;
  color: var(--color-fg-muted);
  margin: 0 0 16px;
}
.gttc-author__bio {
  color: var(--gttc-navy-700);
  font-size: 15px;
  line-height: 1.7;
  max-width: 640px;
  margin-bottom: 20px;
}
.gttc-author__bio p { margin: 0 0 10px; }
.gttc-author__bio p:last-child { margin: 0; }

.gttc-author__stats {
  display: flex; flex-wrap: wrap; gap: 28px;
  padding: 14px 0;
  margin-bottom: 18px;
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
}
@media (max-width: 720px) { .gttc-author__stats { justify-content: center; gap: 20px; } }
.gttc-stat__value {
  font-family: var(--font-sans);
  font-size: 20px;
  font-weight: 700;
  color: var(--gttc-navy-900);
  letter-spacing: -0.01em;
}
.gttc-stat__label {
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gttc-navy-500);
  margin-top: 2px;
}

.gttc-author__socials {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-wrap: wrap; gap: 8px;
}
@media (max-width: 720px) { .gttc-author__socials { justify-content: center; } }
.gttc-author__socials li { padding: 0; border: 0; }
.gttc-author__socials a {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  background: #fff;
  font-size: 13px;
  font-weight: 500;
  color: var(--gttc-navy-700);
  text-decoration: none;
  transition: border-color var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out);
}
.gttc-author__socials a:hover {
  border-color: var(--gttc-azure-300);
  background: var(--gttc-azure-50);
  color: var(--gttc-azure-700);
}

.gttc-section-title {
  font-family: var(--font-sans);
  font-size: 20px;
  font-weight: 700;
  color: var(--color-fg);
  margin: 0 0 18px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--color-border);
  letter-spacing: -0.01em;
}

/* =====================================================================
   Reading-time + entry meta
   ===================================================================== */
.gttc-entry-meta { display: flex; flex-wrap: wrap; gap: 14px; color: var(--gttc-navy-500); font-size: 13px; margin: 8px 0 0; align-items: center; }
.gttc-entry-meta__item { display: inline-flex; gap: 5px; align-items: center; }

/* Gutenberg block fallbacks */
.wp-block-image figcaption { font-size: 13px; color: var(--gttc-navy-500); text-align: center; }
.wp-block-quote, .wp-block-pullquote { border-left: 3px solid var(--gttc-azure-500); padding: 14px 18px; background: var(--gttc-azure-50); border-radius: 0 var(--radius-md) var(--radius-md) 0; }
.wp-block-code, .wp-block-preformatted { background: var(--gttc-navy-900); color: #E6ECF5; padding: 18px 20px; border-radius: var(--radius-md); font-family: var(--font-mono); font-size: 13.5px; }
.wp-block-button__link { background: var(--gttc-azure-500); color: #fff; border-radius: var(--radius-md); padding: 10px 22px; font-weight: 600; }
.wp-block-button__link:hover { background: var(--gttc-azure-600); }

/* Print */
@media print {
  .gttc-header, .gttc-footer, .gttc-sidebar, .gttc-related, .gttc-postnav, .gttc-back, .gttc-comments { display: none !important; }
  body { font-size: 12pt; }
}
