/*!
Theme Name: Code Pirate
Theme URI: https://codepirate.cc
Author: Code Pirate
Description: Dark hacker-terminal child theme for Blocksy. Phosphor green, Press Start 2P headlines, scanline overlay, glitch FX — built for the Code Pirate VS Code extension website.
Version: 1.0.2
Template: blocksy
Text Domain: code-pirate
*/

/* ============================================================
   DESIGN TOKENS
   ============================================================ */

:root {
  --cp-black:         #0a0a0a;
  --cp-black-mid:     #111111;
  --cp-black-card:    #141414;
  --cp-green:         #00ff41;
  --cp-green-dim:     #00cc33;
  --cp-green-dark:    #004d13;
  --cp-green-glow:    rgba(0, 255, 65, 0.15);
  --cp-green-glow-sm: rgba(0, 255, 65, 0.08);
  --cp-text:          #d4f5d4;
  --cp-text-muted:    #6b9e6b;
  --cp-border:        rgba(0, 255, 65, 0.12);
  --cp-border-hover:  rgba(0, 255, 65, 0.45);

  /* Override Blocksy palette slots */
  --theme-palette-color-1: #00ff41;
  --theme-palette-color-2: #00cc33;
  --theme-palette-color-3: #d4f5d4;
  --theme-palette-color-4: #6b9e6b;
  --theme-palette-color-5: #1a2a1a;
  --theme-palette-color-6: #141414;
  --theme-palette-color-7: #111111;
  --theme-palette-color-8: #0a0a0a;
}

/* ============================================================
   GLOBAL BASE
   ============================================================ */

html,
body {
  background-color: var(--cp-black) !important;
  color: var(--cp-text) !important;
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 15px;
  line-height: 1.75;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Background glitch overlay — injected via wp_body_open as a dedicated div
   (avoids body::before conflict with scanline body::after and Blocksy) */
.cp-bg-glitch-overlay {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9998;
  opacity: 0;
  animation: cp-bg-glitch 11s infinite;
}

@keyframes cp-bg-glitch {
  0%, 84%, 100% {
    opacity: 0;
    clip-path: none;
    background: transparent;
    transform: none;
  }
  85% {
    opacity: 1;
    background: rgba(0, 255, 65, 0.09);
    clip-path: polygon(0 12%, 100% 12%, 100% 16%, 0 16%);
    transform: translateX(-3px);
  }
  86% {
    opacity: 0;
    clip-path: none;
    transform: none;
  }
  87% {
    opacity: 1;
    background: rgba(255, 0, 60, 0.08);
    clip-path: polygon(0 48%, 100% 48%, 100% 53%, 0 53%);
    transform: translateX(4px);
  }
  88% {
    opacity: 0;
    clip-path: none;
    transform: none;
  }
  89% {
    opacity: 1;
    background: rgba(0, 225, 255, 0.07);
    clip-path: polygon(0 71%, 100% 71%, 100% 75%, 0 75%);
    transform: translateX(-2px);
  }
  90% {
    opacity: 0;
    clip-path: none;
    transform: none;
  }
}

/* Scanline overlay — sits above everything, never intercepts clicks */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  background: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 3px,
    rgba(0, 0, 0, 0.09) 3px,
    rgba(0, 0, 0, 0.09) 4px
  );
  pointer-events: none;
  z-index: 10000;
  opacity: 0.55;
}

/* Selection */
::selection {
  background: var(--cp-green);
  color: #000000;
}

/* Scrollbar */
::-webkit-scrollbar               { width: 6px; height: 6px; }
::-webkit-scrollbar-track         { background: var(--cp-black); }
::-webkit-scrollbar-thumb         { background: var(--cp-green-dark); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover   { background: var(--cp-green-dim); }

/* ============================================================
   TYPOGRAPHY
   ============================================================ */

h1, h2, h3, h4, h5, h6,
.wp-block-heading {
  font-family: 'Press Start 2P', monospace !important;
  color: var(--cp-green) !important;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  line-height: 1.5;
}

h1 { font-size: clamp(18px, 4vw, 36px) !important; }
h2 { font-size: clamp(14px, 3vw, 28px) !important; }
h3 { font-size: clamp(11px, 2.5vw, 20px) !important; }
h4 { font-size: clamp(10px, 2vw,  16px) !important; }
h5, h6 { font-size: 10px !important; }

p, li, td, th, label, span, div {
  font-family: 'JetBrains Mono', monospace !important;
}

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

a:hover {
  color: #ffffff !important;
  text-shadow: 0 0 8px var(--cp-green-glow);
}

strong, b {
  color: var(--cp-green);
  font-weight: 700;
}

/* Code / pre */
code,
pre,
.wp-block-code,
.wp-block-preformatted {
  font-family: 'JetBrains Mono', monospace !important;
  background: #0d1a0d !important;
  color: var(--cp-green) !important;
  border: 1px solid var(--cp-border) !important;
  border-radius: 3px;
}

pre,
.wp-block-code {
  padding: 1.5em !important;
  overflow-x: auto;
  position: relative;
}

/* Fake terminal prompt prefix on pre blocks */
pre::before,
.wp-block-code::before {
  content: '$ ';
  color: var(--cp-green-dim);
  opacity: 0.6;
}

/* Blockquote */
blockquote,
.wp-block-quote {
  border-left: 3px solid var(--cp-green) !important;
  background: var(--cp-black-card) !important;
  padding: 1em 1.5em !important;
  color: var(--cp-text-muted) !important;
  font-style: italic;
  margin: 1.5em 0;
}

.wp-block-quote p {
  font-size: 1.1em !important;
}

/* ============================================================
   HEADER & NAVIGATION
   ============================================================ */

.ct-header,
.site-header,
header[data-id="header"],
[data-id="header"] {
  background: rgba(10, 10, 10, 0.96) !important;
  border-bottom: 1px solid var(--cp-border) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.ct-site-title a,
.site-title a {
  font-family: 'Press Start 2P', monospace !important;
  color: var(--cp-green) !important;
  font-size: 11px !important;
  letter-spacing: 0.12em;
  text-shadow: 0 0 12px rgba(0, 255, 65, 0.4);
}

/* Desktop nav links */
.ct-menu a,
.main-navigation a,
[data-id="menu"] a,
nav a {
  font-family: 'JetBrains Mono', monospace !important;
  color: var(--cp-text-muted) !important;
  font-size: 12px !important;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: color 0.2s, text-shadow 0.2s;
}

.ct-menu a:hover,
.main-navigation a:hover,
nav a:hover {
  color: var(--cp-green) !important;
  text-shadow: 0 0 8px rgba(0, 255, 65, 0.5) !important;
}

.ct-menu .current-menu-item > a,
.main-navigation .current-menu-item > a {
  color: var(--cp-green) !important;
}

/* Mobile hamburger */
.ct-toggle-dropdown-mobile,
.menu-toggle {
  color: var(--cp-green) !important;
  border-color: var(--cp-green) !important;
}

/* ============================================================
   BUTTONS & CTAs
   ============================================================ */

.wp-block-button__link,
.ct-button,
.button,
a.button,
input[type="submit"],
button:not(.menu-toggle):not(.search-submit) {
  font-family: 'Press Start 2P', monospace !important;
  font-size: 10px !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--cp-green) !important;
  background: transparent !important;
  border: 2px solid var(--cp-green) !important;
  border-radius: 2px !important;
  padding: 14px 28px !important;
  cursor: pointer;
  transition: all 0.25s ease !important;
  text-shadow: none !important;
  box-shadow: inset 0 0 0 0 var(--cp-green) !important;
}

.wp-block-button__link:hover,
.ct-button:hover,
.button:hover,
a.button:hover,
input[type="submit"]:hover,
button:not(.menu-toggle):not(.search-submit):hover {
  color: #000000 !important;
  background: var(--cp-green) !important;
  box-shadow: 0 0 20px var(--cp-green-glow), 0 0 40px rgba(0, 255, 65, 0.1) !important;
}

/* Filled (primary download) buttons */
.wp-block-button.is-style-fill .wp-block-button__link,
.cp-btn-primary {
  background: var(--cp-green) !important;
  color: #000000 !important;
  box-shadow: 0 0 16px var(--cp-green-glow) !important;
}

.wp-block-button.is-style-fill .wp-block-button__link:hover,
.cp-btn-primary:hover {
  box-shadow: 0 0 30px var(--cp-green-glow), 0 0 60px rgba(0, 255, 65, 0.15) !important;
}

/* ============================================================
   LAYOUT SECTIONS
   ============================================================ */

main,
#main,
.site-main,
.site-content,
.wp-block-group,
.ct-section,
section {
  background-color: transparent !important;
}

/* Feature/info cards */
.wp-block-column,
.ct-card {
  background: var(--cp-black-card) !important;
  border: 1px solid var(--cp-border) !important;
  border-radius: 3px !important;
  transition: border-color 0.3s, box-shadow 0.3s;
}

.wp-block-column:hover,
.ct-card:hover {
  border-color: var(--cp-border-hover) !important;
  box-shadow: 0 0 24px var(--cp-green-glow) !important;
}

/* Terminal ">" prefix on feature card headings */
.wp-block-column h3::before,
.wp-block-column h4::before,
.ct-card h3::before {
  content: '> ';
  color: var(--cp-green-dim);
  opacity: 0.65;
}

/* Full-width dark band sections */
.wp-block-cover,
.wp-block-group.alignfull {
  background-color: var(--cp-black) !important;
}

/* Alternate section tint */
.wp-block-group.has-global-padding:nth-of-type(even) {
  background-color: var(--cp-black-mid) !important;
}

/* ============================================================
   HERO SECTION
   ============================================================ */

.ct-hero,
.wp-block-cover:first-of-type,
.hero-section {
  background: var(--cp-black) !important;
  min-height: 88vh !important;
  position: relative;
  overflow: hidden;
}

/* Pixel grid overlay on hero */
.ct-hero::before,
.wp-block-cover:first-of-type::before,
.hero-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(0, 255, 65, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 255, 65, 0.03) 1px, transparent 1px);
  background-size: 44px 44px;
  pointer-events: none;
  z-index: 0;
}

/* ============================================================
   GLITCH ANIMATION (add class="cp-glitch" data-text="YOUR TEXT")
   ============================================================ */

@keyframes cp-glitch {
  0%   { clip-path: inset(20% 0 60% 0); transform: translate(-4px, 0); }
  10%  { clip-path: inset(70% 0 5% 0);  transform: translate(4px, 0); }
  20%  { clip-path: inset(40% 0 40% 0); transform: translate(-2px, 0); }
  30%  { clip-path: inset(10% 0 80% 0); transform: translate(2px, 0); }
  40%  { clip-path: inset(60% 0 20% 0); transform: translate(-4px, 0); }
  50%  { clip-path: inset(80% 0 5% 0);  transform: translate(0, 0); }
  60%  { clip-path: inset(30% 0 50% 0); transform: translate(4px, 0); }
  70%  { clip-path: inset(5% 0 85% 0);  transform: translate(-2px, 0); }
  80%  { clip-path: inset(50% 0 30% 0); transform: translate(2px, 0); }
  90%  { clip-path: inset(15% 0 70% 0); transform: translate(-4px, 0); }
  100% { clip-path: inset(20% 0 60% 0); transform: translate(4px, 0); }
}

.cp-glitch {
  position: relative;
  display: inline-block;
  color: var(--cp-green) !important;
}

.cp-glitch::before,
.cp-glitch::after {
  content: attr(data-text);
  position: absolute;
  inset: 0;
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  text-transform: inherit;
  letter-spacing: inherit;
  white-space: nowrap;
}

.cp-glitch::before {
  color: #ff003c;
  animation: cp-glitch 3.5s infinite linear alternate-reverse;
  opacity: 0.5;
}

.cp-glitch::after {
  color: #00d4ff;
  animation: cp-glitch 2.8s infinite linear alternate;
  opacity: 0.35;
}

/* ============================================================
   TYPEWRITER CURSOR (add class="cp-typewriter")
   ============================================================ */

@keyframes cp-cursor-blink {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0; }
}

.cp-typewriter::after {
  content: '_';
  display: inline-block;
  animation: cp-cursor-blink 1s step-end infinite;
  color: var(--cp-green);
  margin-left: 3px;
}

/* ============================================================
   FOOTER
   ============================================================ */

.ct-footer,
.site-footer,
footer {
  background: #050505 !important;
  border-top: 1px solid var(--cp-border) !important;
  color: var(--cp-text-muted) !important;
}

.ct-footer a,
.site-footer a,
footer a {
  color: var(--cp-text-muted) !important;
  transition: color 0.2s;
}

.ct-footer a:hover,
.site-footer a:hover,
footer a:hover {
  color: var(--cp-green) !important;
}

.ct-footer p,
.site-footer p,
footer p {
  font-size: 11px !important;
  letter-spacing: 0.06em;
  color: var(--cp-text-muted) !important;
}

/* ============================================================
   DOCS / CONTENT PAGES
   ============================================================ */

.entry-title {
  font-family: 'Press Start 2P', monospace !important;
  color: var(--cp-green) !important;
}

.entry-content {
  color: var(--cp-text);
  max-width: 860px;
}

/* Tables */
table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px !important;
  margin: 1.5em 0;
}

th {
  background: var(--cp-black-card) !important;
  color: var(--cp-green) !important;
  border: 1px solid var(--cp-border) !important;
  padding: 10px 14px !important;
  text-transform: uppercase;
  font-size: 10px !important;
  letter-spacing: 0.1em;
  font-family: 'Press Start 2P', monospace !important;
}

td {
  background: transparent !important;
  color: var(--cp-text) !important;
  border: 1px solid var(--cp-border) !important;
  padding: 10px 14px !important;
}

tr:hover td {
  background: var(--cp-green-glow-sm) !important;
}

/* ============================================================
   PRICING / DOWNLOAD SECTION
   ============================================================ */

.cp-pricing-card {
  background: var(--cp-black-card);
  border: 1px solid var(--cp-border);
  border-radius: 3px;
  padding: 2.5em 2em;
  text-align: center;
  transition: all 0.3s;
}

.cp-pricing-card.featured {
  border-color: var(--cp-green);
  box-shadow: 0 0 30px var(--cp-green-glow);
}

.cp-pricing-card:hover {
  box-shadow: 0 0 25px var(--cp-green-glow);
  border-color: var(--cp-border-hover);
}

.cp-price {
  font-family: 'Press Start 2P', monospace !important;
  font-size: 28px;
  color: var(--cp-green);
  margin: 0.5em 0;
  display: block;
}

.cp-price-label {
  font-size: 11px;
  color: var(--cp-text-muted);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

/* ============================================================
   FORMS
   ============================================================ */

input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
textarea,
select {
  background: var(--cp-black-card) !important;
  color: var(--cp-text) !important;
  border: 1px solid var(--cp-border) !important;
  border-radius: 2px !important;
  font-family: 'JetBrains Mono', monospace !important;
  padding: 10px 14px !important;
  transition: border-color 0.2s, box-shadow 0.2s;
  font-size: 13px !important;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
textarea:focus,
select:focus {
  border-color: var(--cp-green) !important;
  box-shadow: 0 0 10px var(--cp-green-glow) !important;
  outline: none !important;
}

/* ============================================================
   UTILITY CLASSES
   ============================================================ */

/* Terminal prompt prefix */
.cp-prompt::before {
  content: '$ ';
  color: var(--cp-green);
  font-family: 'JetBrains Mono', monospace;
}

/* Status badge (FREE / PRO) */
.cp-badge {
  display: inline-block;
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--cp-green);
  border: 1px solid var(--cp-green);
  padding: 3px 10px;
  border-radius: 2px;
  background: var(--cp-green-glow-sm);
}

.cp-badge.pro {
  color: #000000;
  background: var(--cp-green);
  border-color: var(--cp-green);
}

/* Color helpers */
.cp-green  { color: var(--cp-green) !important; }
.cp-muted  { color: var(--cp-text-muted) !important; }
.cp-glow   { text-shadow: 0 0 10px var(--cp-green-glow) !important; }

/* Skull / pirate divider */
.cp-divider {
  text-align: center;
  color: var(--cp-green-dark);
  font-size: 24px;
  letter-spacing: 0.5em;
  margin: 2em 0;
  opacity: 0.6;
}

.cp-divider::before,
.cp-divider::after {
  content: '─── ';
  font-size: 14px;
  vertical-align: middle;
  letter-spacing: 0;
}

/* ============================================================
   FULL-WIDTH LAYOUT — page-fullwidth.php template + global fixes
   ============================================================ */

/* Full-width page template wrappers */
.cp-fullwidth-wrap,
.cp-fullwidth-content {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box;
}

/* Kill every container width constraint globally */
:root {
  --theme-container-edge-spacing: 98vw !important;
  --theme-narrow-container-max-width: 1900px !important;
  --theme-normal-container-max-width: 1900px !important;
}

/* Blocksy header rows — expand to full width */
.ct-header,
.ct-header > div,
[data-row],
[data-row] > div,
[data-header] .ct-container,
[data-header] .ct-container-narrow,
[data-header] .ct-container-fluid {
  max-width: 100% !important;
  width: 100% !important;
}

/* Belt-and-suspenders: hide sidebar in case it ever renders */
.ct-sidebar,
#sidebar,
aside.widget-area,
[data-sidebar] > aside {
  display: none !important;
}

/* If data-sidebar attribute is still present, collapse it */
[data-sidebar],
[data-sidebar="right"],
[data-sidebar="left"] {
  --grid-template-columns: 100% !important;
  grid-template-columns: 100% !important;
  display: block !important;
}

/* Main content always full width */
.ct-container > article,
.ct-container-full > article,
[data-content] > article,
article.type-page,
article.type-post {
  width: 100% !important;
  max-width: 100% !important;
}

/* Blocksy container — let it use full width */
.ct-container,
.ct-container-full {
  max-width: var(--theme-normal-container-max-width, 1280px) !important;
  width: 100% !important;
}

/* Inner prose content readable width, but blocks go full-width */
.entry-content > *:not(.alignfull):not(.alignwide):not(.wp-block-cover):not(.wp-block-group) {
  max-width: 900px;
}

/* ============================================================
   MOBILE
   ============================================================ */

@media (max-width: 768px) {
  h1 { font-size: 16px !important; }
  h2 { font-size: 13px !important; }
  h3 { font-size: 11px !important; }
  h4, h5, h6 { font-size: 10px !important; }

  body::after { opacity: 0.3; }

  .wp-block-button__link,
  .ct-button,
  .button {
    padding: 12px 18px !important;
    font-size: 9px !important;
  }
}

/* ============================================================
   HOMEPAGE — SHARED LAYOUT
   ============================================================ */

.cp-section-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
  box-sizing: border-box;
}

.cp-section-title {
  font-family: 'Press Start 2P', monospace !important;
  font-size: clamp(14px, 2.5vw, 26px) !important;
  color: var(--cp-green) !important;
  text-align: center;
  margin: 0 0 16px;
  line-height: 1.6;
}

.cp-section-sub {
  text-align: center;
  color: var(--cp-text-muted);
  font-size: 13px;
  margin: 0 0 60px;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

/* ============================================================
   HOMEPAGE — HERO
   ============================================================ */

.cp-hero {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: var(--cp-black);
  border-bottom: 1px solid var(--cp-border);
  position: relative;
  overflow: hidden;
  padding: 80px 0;
}

/* Constrain + pad all direct Gutenberg children of the hero */
.cp-hero > * {
  width: 100%;
  max-width: 1200px;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 40px;
  padding-right: 40px;
  box-sizing: border-box;
  position: relative;
  z-index: 1;
}

/* Skull & crossbones watermark — sits behind hero content */
.cp-hero::after {
  content: '';
  position: absolute;
  right: 3%;
  top: 50%;
  transform: translateY(-50%);
  width: min(480px, 38vw);
  height: min(480px, 38vw);
  background-image: url('/pirate2.png');
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  opacity: 0.055;
  filter: invert(1) sepia(1) saturate(6) hue-rotate(85deg);
  pointer-events: none;
  z-index: 0;
}

/* Subtle radial glow behind hero */
.cp-hero::before {
  content: '';
  position: absolute;
  top: -20%;
  left: 50%;
  transform: translateX(-50%);
  width: 80vw;
  height: 80vw;
  background: radial-gradient(ellipse at center, rgba(0,255,65,0.05) 0%, transparent 65%);
  pointer-events: none;
}

.cp-hero__inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 120px 40px 80px;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 24px;
  position: relative;
  z-index: 1;
}

.cp-hero__eyebrow {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: var(--cp-green-dim);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 6px;
}

.cp-blink {
  animation: cp-blink-anim 1.1s step-end infinite;
  color: var(--cp-green);
  font-size: 14px;
  line-height: 1;
}

@keyframes cp-blink-anim {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0; }
}

/* Eyebrow typewriter: text types in from left, cursor blinks at end */
.cp-eyebrow-text {
  display: inline-block;
  overflow: hidden;
  white-space: nowrap;
  width: 0;
  vertical-align: bottom;
  animation: cp-eyebrow-type 2.4s steps(30, end) 0.5s forwards;
}

@keyframes cp-eyebrow-type {
  from { width: 0; }
  to   { width: 38ch; }
}

.cp-hero__headline {
  font-family: 'Press Start 2P', monospace !important;
  font-size: clamp(28px, 6vw, 72px) !important;
  color: var(--cp-green) !important;
  line-height: 1.25 !important;
  letter-spacing: 0.04em;
  margin: 0 !important;
  text-shadow: 0 0 30px rgba(0,255,65,0.35), 0 0 60px rgba(0,255,65,0.15);
}

.cp-hero__tagline {
  font-family: 'JetBrains Mono', monospace;
  font-size: clamp(13px, 2vw, 18px);
  color: var(--cp-text);
  margin: 0;
  border-right: 2px solid var(--cp-green);
  white-space: nowrap;
  overflow: hidden;
  width: 100%;
  max-width: 520px;
  animation: cp-type 2.8s steps(48, end) both, cp-cursor-blink 0.75s step-end infinite;
}

@keyframes cp-type {
  from { max-width: 0; }
  to   { max-width: 520px; }
}

@keyframes cp-cursor-blink {
  0%, 100% { border-color: var(--cp-green); }
  50%      { border-color: transparent; }
}

.cp-hero__sub {
  font-size: 13px;
  color: var(--cp-text-muted);
  line-height: 1.9;
  margin: 0;
  max-width: 560px;
}

.cp-hero__zero {
  font-family: 'JetBrains Mono', monospace;
  font-size: clamp(13px, 1.6vw, 18px);
  color: var(--cp-green);
  font-weight: 700;
  letter-spacing: 0.06em;
  margin: 0;
  max-width: 560px;
  text-shadow: 0 0 20px rgba(0,255,65,0.3);
}

.cp-hero__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-top: 8px;
}

/* Terminal mockup */
.cp-hero__terminal {
  width: 100%;
  max-width: 520px;
  margin-top: 16px;
}

.cp-terminal {
  background: #0d1a0d;
  border: 1px solid var(--cp-border);
  border-radius: 6px;
  overflow: hidden;
  box-shadow: 0 0 40px rgba(0,255,65,0.08);
}

.cp-terminal__bar {
  background: #1a1a1a;
  padding: 10px 16px;
  display: flex;
  align-items: center;
  gap: 8px;
  border-bottom: 1px solid var(--cp-border);
}

.cp-terminal__dot {
  width: 11px;
  height: 11px;
  border-radius: 50%;
  flex-shrink: 0;
}
.cp-terminal__dot--red    { background: #ff5f57; }
.cp-terminal__dot--yellow { background: #ffbd2e; }
.cp-terminal__dot--green  { background: #28c940; }

.cp-terminal__title {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: var(--cp-text-muted);
  margin-left: auto;
  margin-right: auto;
  letter-spacing: 0.05em;
}

.cp-terminal__body {
  padding: 20px 20px 24px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.cp-terminal__line {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.cp-terminal__prompt { color: var(--cp-green); }
.cp-terminal__cmd    { color: var(--cp-text); }
.cp-terminal__ok     { color: var(--cp-green); }
.cp-terminal__cursor {
  color: var(--cp-green);
  animation: cp-blink-anim 1s step-end infinite;
}

.cp-terminal__line--output {
  color: var(--cp-text-muted);
  padding-left: 20px;
}

/* ============================================================
   HOMEPAGE — BUTTON SYSTEM
   ============================================================ */

.cp-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: 'Press Start 2P', monospace;
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none !important;
  padding: 16px 28px;
  border-radius: 3px;
  cursor: pointer;
  transition: all 0.2s ease;
  line-height: 1;
  border: none;
  box-sizing: border-box;
}

.cp-btn--primary {
  background: var(--cp-green);
  color: #000 !important;
  box-shadow: 0 0 20px rgba(0,255,65,0.25);
}
.cp-btn--primary:hover {
  background: #fff;
  color: #000 !important;
  box-shadow: 0 0 35px rgba(0,255,65,0.5);
  transform: translateY(-2px);
}

.cp-btn--ghost {
  background: transparent;
  color: var(--cp-green) !important;
  border: 1px solid var(--cp-border-hover);
}
.cp-btn--ghost:hover {
  background: var(--cp-green-glow);
  border-color: var(--cp-green);
  color: var(--cp-green) !important;
}
.cp-btn--ghost[disabled] {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}

.cp-btn--lg {
  font-size: 12px;
  padding: 20px 40px;
}

.cp-btn--full {
  width: 100%;
  justify-content: center;
}

.cp-btn__icon {
  font-size: 16px;
  line-height: 1;
}

/* Gutenberg wraps button text in <a class="wp-block-button__link">.
   The global button rule gives it green text — invisible on a green bg.
   Override for primary button wrappers to enforce black text on green. */
.cp-btn--primary .wp-block-button__link,
.cp-btn--primary > a {
  color: #000000 !important;
  background: var(--cp-green) !important;
  border-color: var(--cp-green) !important;
  box-shadow: 0 0 20px rgba(0,255,65,0.25) !important;
}
.cp-btn--primary .wp-block-button__link:hover,
.cp-btn--primary > a:hover {
  color: #000000 !important;
  background: #ffffff !important;
  border-color: #ffffff !important;
  box-shadow: 0 0 35px rgba(0,255,65,0.5) !important;
}

/* ============================================================
   HOMEPAGE — HOOK STRIP
   ============================================================ */

.cp-hook {
  background: var(--cp-black-mid);
  border-top: 1px solid var(--cp-border);
  border-bottom: 2px solid rgba(0,255,65,0.18);
  box-shadow: 0 2px 20px rgba(0,255,65,0.06);
  padding: 80px 0;
}

.cp-hook__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
  text-align: center;
}

.cp-hook__quote {
  font-family: 'Press Start 2P', monospace;
  font-size: clamp(12px, 2.5vw, 22px);
  color: var(--cp-green);
  line-height: 1.7;
  margin: 0 0 36px;
  text-shadow: 0 0 20px rgba(0,255,65,0.2);
}

.cp-hook__source {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: var(--cp-text-muted);
  margin: -16px 0 28px;
  letter-spacing: 0.06em;
}

.cp-hook__source a {
  color: var(--cp-green);
  text-decoration: none;
  opacity: 0.6;
  transition: opacity 0.2s ease;
}

.cp-hook__source a:hover {
  opacity: 1;
  text-decoration: underline;
}

.cp-hook__pills {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
}

.cp-pill {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: var(--cp-green);
  background: var(--cp-green-glow-sm);
  border: 1px solid var(--cp-border);
  padding: 6px 16px;
  border-radius: 2px;
  letter-spacing: 0.08em;
}

/* ============================================================
   HOMEPAGE — FEATURES GRID
   ============================================================ */

.cp-features {
  background: var(--cp-black);
  padding: 130px 0;
  border-bottom: 2px solid rgba(0,255,65,0.18);
  box-shadow: 0 2px 20px rgba(0,255,65,0.06);
}

.cp-features__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 0;
}

.cp-card {
  background: var(--cp-black-card);
  border: 1px solid var(--cp-border);
  border-radius: 4px;
  padding: 32px;
  transition: border-color 0.25s, box-shadow 0.25s;
}

.cp-card:hover {
  border-color: var(--cp-border-hover);
  box-shadow: 0 0 24px rgba(0,255,65,0.07);
}

.cp-card__icon {
  font-size: 28px;
  margin-bottom: 20px;
  line-height: 1;
}

.cp-card__title {
  font-family: 'Press Start 2P', monospace !important;
  font-size: 10px !important;
  color: var(--cp-green) !important;
  margin: 0 0 16px !important;
  line-height: 1.7 !important;
  text-transform: uppercase;
}

.cp-card__body {
  font-size: 12px;
  color: var(--cp-text-muted);
  line-height: 1.85;
  margin: 0;
}

.cp-card__body code {
  font-size: 11px;
  padding: 1px 5px;
  border-radius: 2px;
}

/* ============================================================
   HOMEPAGE — PROVIDERS STRIP
   ============================================================ */

.cp-providers {
  background: var(--cp-black-mid);
  padding: 80px 0;
  border-bottom: 1px solid var(--cp-border);
}

.cp-providers .cp-section-title {
  margin-bottom: 32px;
}

.cp-providers__label {
  font-size: 11px;
  color: var(--cp-text-muted);
  text-align: center;
  margin: 0 0 20px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.cp-providers__list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0;
}

.cp-provider {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  color: var(--cp-text-muted);
  padding: 0 14px;
  transition: color 0.2s;
}

.cp-provider:hover { color: var(--cp-green); }

.cp-provider__sep {
  color: var(--cp-border-hover);
  font-size: 14px;
}

/* ============================================================
   HOMEPAGE — HOW IT WORKS
   ============================================================ */

.cp-how {
  background: var(--cp-black);
  padding: 130px 0;
  border-bottom: 2px solid rgba(0,255,65,0.18);
  box-shadow: 0 2px 20px rgba(0,255,65,0.06);
}

.cp-steps {
  display: flex;
  align-items: flex-start;
  gap: 0;
  margin-top: 60px;
}

.cp-step {
  flex: 1;
  padding: 32px;
  background: var(--cp-black-card);
  border: 1px solid var(--cp-border);
  border-radius: 4px;
}

.cp-step__connector {
  color: var(--cp-green-dim);
  font-size: 20px;
  padding: 0 12px;
  flex-shrink: 0;
  margin-top: 60px;
  opacity: 0.5;
}

.cp-step__num {
  font-family: 'Press Start 2P', monospace;
  font-size: 28px;
  color: var(--cp-green);
  opacity: 0.25;
  margin-bottom: 20px;
  line-height: 1;
}

.cp-step__title {
  font-family: 'Press Start 2P', monospace !important;
  font-size: 10px !important;
  color: var(--cp-green) !important;
  margin: 0 0 16px !important;
  line-height: 1.7 !important;
}

.cp-step__body {
  font-size: 12px;
  color: var(--cp-text-muted);
  line-height: 1.85;
  margin: 0 0 20px;
}

.cp-step__body code {
  font-size: 11px;
  padding: 1px 5px;
}

.cp-step__cta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: var(--cp-green) !important;
  letter-spacing: 0.05em;
  text-decoration: none;
  display: inline-block;
}

.cp-step__cta--kbd {
  color: var(--cp-text-muted) !important;
}

kbd {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  background: #1a1a1a;
  border: 1px solid var(--cp-border);
  padding: 2px 7px;
  border-radius: 3px;
  color: var(--cp-text);
}

/* ============================================================
   HOMEPAGE — PRICING
   ============================================================ */

.cp-pricing {
  background: var(--cp-black-mid);
  padding: 130px 0;
  border-bottom: 2px solid rgba(0,255,65,0.18);
  box-shadow: 0 2px 20px rgba(0,255,65,0.06);
}

.cp-pricing__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  max-width: 800px;
  margin: 0 auto;
}

.cp-pricing__grid--3 {
  grid-template-columns: repeat(3, 1fr);
  max-width: 1100px;
}

.cp-pricing__card {
  background: var(--cp-black-card);
  border: 1px solid var(--cp-border);
  border-radius: 4px;
  padding: 40px;
  position: relative;
}

.cp-pricing__card--pro {
  border-color: var(--cp-border-hover);
  box-shadow: 0 0 30px rgba(0,255,65,0.06);
}

.cp-pricing__card--lifetime {
  border-color: var(--cp-green);
  box-shadow: 0 0 40px rgba(0,255,65,0.12);
  position: relative;
}

.cp-pricing__badge {
  position: absolute;
  top: -14px;
  right: 24px;
  background: var(--cp-green);
  color: #000;
  font-family: 'Press Start 2P', monospace;
  font-size: 11px;
  padding: 6px 16px;
  border-radius: 2px;
  letter-spacing: 0.08em;
}

.cp-pricing__tier {
  font-family: 'Press Start 2P', monospace;
  font-size: 11px;
  color: var(--cp-green);
  margin-bottom: 16px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.cp-pricing__price {
  font-family: 'Press Start 2P', monospace;
  font-size: 28px;
  color: #fff;
  margin-bottom: 32px;
  line-height: 1;
}

.cp-pricing__period {
  font-size: 12px;
  color: var(--cp-text-muted);
}

.cp-pricing__features {
  list-style: none;
  padding: 0;
  margin: 0 0 32px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.cp-pricing__features li {
  font-size: 12px;
  color: var(--cp-text-muted);
  line-height: 1.5;
}

.cp-pricing__feature--muted {
  color: var(--cp-border-hover) !important;
  font-style: italic;
}

.cp-pricing__note {
  font-size: 11px;
  color: var(--cp-text-muted);
  line-height: 1.7;
  margin: 0 0 24px;
  padding: 10px 14px;
  border-left: 2px solid var(--cp-green-dark);
  background: rgba(0,255,65,0.03);
}

/* Lifetime cap warning */
.cp-lifetime-cap {
  margin-bottom: 20px;
  padding: 8px 12px;
  background: rgba(0,255,65,0.05);
  border: 1px solid rgba(0,255,65,0.2);
  border-radius: 2px;
}

.cp-lifetime-cap__label {
  font-size: 10px;
  color: var(--cp-green-dim);
  letter-spacing: 0.05em;
}

/* Email capture form on lifetime card */
.cp-email-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 12px;
}

.cp-email-form__input {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  background: #0a0a0a;
  border: 1px solid var(--cp-border);
  color: var(--cp-text);
  padding: 12px 16px;
  border-radius: 3px;
  outline: none;
  width: 100%;
  box-sizing: border-box;
  transition: border-color 0.2s;
}

.cp-email-form__input:focus {
  border-color: var(--cp-green);
  box-shadow: 0 0 10px rgba(0,255,65,0.1);
}

.cp-email-form__input::placeholder {
  color: var(--cp-text-muted);
  opacity: 0.5;
}

.cp-email-form__fine {
  font-size: 10px !important;
  color: var(--cp-text-muted) !important;
  text-align: center;
  margin: 0 !important;
  letter-spacing: 0.05em;
}

/* ============================================================
   HOMEPAGE — CTA BANNER
   ============================================================ */

.cp-cta-banner {
  background: var(--cp-black);
  padding: 120px 0;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.cp-cta-banner::before {
  content: '';
  position: absolute;
  bottom: -30%;
  left: 50%;
  transform: translateX(-50%);
  width: 70vw;
  height: 70vw;
  background: radial-gradient(ellipse at center, rgba(0,255,65,0.04) 0%, transparent 65%);
  pointer-events: none;
}

.cp-cta-banner__inner {
  position: relative;
  z-index: 1;
}

.cp-cta-banner__headline {
  font-family: 'Press Start 2P', monospace !important;
  font-size: clamp(16px, 3vw, 32px) !important;
  color: var(--cp-green) !important;
  line-height: 1.8 !important;
  margin: 0 0 40px !important;
  text-shadow: 0 0 30px rgba(0,255,65,0.25);
}

.cp-cta-banner__fine {
  margin-top: 24px;
  font-size: 11px;
  color: var(--cp-text-muted);
  letter-spacing: 0.08em;
}

/* ============================================================
   GLITCH EFFECT
   ============================================================ */

.cp-glitch {
  position: relative;
}

.cp-glitch::before,
.cp-glitch::after {
  content: attr(data-text);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  font-family: inherit;
  font-size: inherit;
  color: inherit;
  line-height: inherit;
}

.cp-glitch::before {
  color: #ff003c;
  animation: cp-glitch-1 3.5s infinite linear;
  clip-path: polygon(0 15%, 100% 15%, 100% 35%, 0 35%);
  transform: translateX(-3px);
  opacity: 0.8;
}

.cp-glitch::after {
  color: #00ffe1;
  animation: cp-glitch-2 3.5s infinite linear;
  clip-path: polygon(0 60%, 100% 60%, 100% 80%, 0 80%);
  transform: translateX(3px);
  opacity: 0.8;
}

@keyframes cp-glitch-1 {
  0%, 90%, 100%  { transform: translateX(-3px); opacity: 0; }
  91%            { transform: translateX(-5px) skewX(-5deg); opacity: 0.8; }
  93%            { transform: translateX(5px)  skewX(5deg);  opacity: 0.8; }
  95%            { transform: translateX(-3px); opacity: 0.8; }
  97%            { transform: translateX(0);    opacity: 0; }
}

@keyframes cp-glitch-2 {
  0%, 88%, 100%  { transform: translateX(3px);  opacity: 0; }
  89%            { transform: translateX(6px)  skewX(3deg);  opacity: 0.8; }
  91%            { transform: translateX(-4px) skewX(-3deg); opacity: 0.8; }
  93%            { transform: translateX(3px);  opacity: 0.8; }
  96%            { transform: translateX(0);    opacity: 0; }
}

/* ============================================================
   HOMEPAGE — RESPONSIVE
   ============================================================ */

@media (max-width: 900px) {
  .cp-features__grid {
    grid-template-columns: 1fr 1fr;
  }

  .cp-steps {
    flex-direction: column;
    gap: 16px;
  }

  .cp-step__connector {
    margin-top: 0;
    transform: rotate(90deg);
    align-self: center;
  }

  .cp-pricing__grid,
  .cp-pricing__grid--3 {
    grid-template-columns: 1fr;
    max-width: 440px;
  }
}

@media (max-width: 600px) {
  .cp-hero__inner,
  .cp-section-inner,
  .cp-hook__inner {
    padding-left: 20px;
    padding-right: 20px;
  }

  .cp-hero__headline {
    font-size: clamp(22px, 8vw, 40px) !important;
  }

  .cp-hero__tagline {
    white-space: normal;
    border-right: none;
    animation: none;
    max-width: 100%;
  }

  .cp-features__grid {
    grid-template-columns: 1fr;
  }

  .cp-hero__ctas {
    flex-direction: column;
  }

  .cp-btn--full,
  .cp-hero__ctas .cp-btn {
    width: 100%;
    justify-content: center;
  }

  .cp-providers__list {
    gap: 8px;
  }
}


/* ============================================================
   INNER PAGES — HERO HEADER
   (Privacy, Terms, Docs)
   ============================================================ */

.cp-inner-hero {
  background: var(--cp-black);
  padding: 100px 0 60px;
  border-bottom: 1px solid rgba(0,255,65,0.15);
  position: relative;
  overflow: hidden;
}

.cp-inner-hero__headline {
  font-family: 'Press Start 2P', monospace !important;
  font-size: clamp(22px, 5vw, 52px) !important;
  color: var(--cp-green) !important;
  margin: 0 0 24px !important;
  line-height: 1.3 !important;
}

.cp-inner-hero__sub {
  font-size: clamp(14px, 1.8vw, 17px);
  color: var(--cp-text-muted);
  line-height: 1.8;
  max-width: 680px;
  margin: 0 0 20px;
}

.cp-inner-hero__meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: rgba(0,255,65,0.45);
  letter-spacing: 0.08em;
  margin: 0;
}


/* ============================================================
   INNER PAGES — PROSE SECTION
   ============================================================ */

.cp-prose-section {
  background: var(--cp-black);
  padding: 80px 0 100px;
}

.cp-prose-inner {
  max-width: 800px;
  margin: 0 auto;
  padding: 0 40px;
  box-sizing: border-box;
}

.cp-prose-block {
  margin-bottom: 48px;
}

.cp-prose-block--highlight {
  border-left: 3px solid var(--cp-green);
  padding: 20px 24px;
  background: rgba(0,255,65,0.04);
  border-radius: 0 2px 2px 0;
}

.cp-prose-block--highlight p {
  margin: 0;
  font-size: 15px;
  line-height: 1.8;
  color: var(--cp-text);
}

.cp-prose-heading {
  font-family: 'Press Start 2P', monospace;
  font-size: clamp(11px, 1.4vw, 14px);
  color: var(--cp-green);
  margin: 56px 0 20px;
  line-height: 1.6;
  letter-spacing: 0.05em;
  padding-top: 56px;
  border-top: 1px solid rgba(0,255,65,0.12);
}

.cp-prose-heading:first-child,
.cp-prose-heading.cp-docs-section-anchor:first-of-type {
  margin-top: 0;
  padding-top: 0;
  border-top: none;
}

.cp-prose-subheading {
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px;
  color: var(--cp-green);
  font-weight: 700;
  margin: 36px 0 12px;
  letter-spacing: 0.06em;
}

.cp-prose-body {
  margin-bottom: 8px;
}

.cp-prose-body p,
.cp-prose-body li {
  font-size: 15px;
  line-height: 1.85;
  color: var(--cp-text);
  margin-bottom: 12px;
}

.cp-prose-body ul,
.cp-prose-body ol {
  padding-left: 24px;
  margin: 12px 0 20px;
}

.cp-prose-body li {
  margin-bottom: 8px;
}

.cp-prose-body a {
  color: var(--cp-green);
  text-decoration: none;
  border-bottom: 1px solid rgba(0,255,65,0.3);
  transition: border-color 0.2s ease, color 0.2s ease;
}

.cp-prose-body a:hover {
  color: #fff;
  border-color: rgba(255,255,255,0.5);
}

.cp-prose-body code {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  background: rgba(0,255,65,0.08);
  color: var(--cp-green);
  padding: 2px 6px;
  border-radius: 2px;
  border: 1px solid rgba(0,255,65,0.15);
}

.cp-prose-body strong {
  color: var(--cp-text);
  font-weight: 700;
}


/* ============================================================
   DOCS — TABLE OF CONTENTS
   ============================================================ */

.cp-docs-toc {
  margin-top: 32px;
  border: 1px solid rgba(0,255,65,0.2);
  padding: 20px 24px;
  border-radius: 2px;
  background: rgba(0,255,65,0.03);
  display: inline-block;
  max-width: 100%;
}

.cp-docs-toc__label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  color: rgba(0,255,65,0.5);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin: 0 0 12px;
}

.cp-docs-toc__links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
}

.cp-docs-toc__link {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  color: var(--cp-green);
  text-decoration: none;
  opacity: 0.7;
  transition: opacity 0.2s ease;
}

.cp-docs-toc__link:hover {
  opacity: 1;
  text-decoration: underline;
}


/* ============================================================
   DOCS — COMMAND BLOCKS
   ============================================================ */

.cp-docs-command {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  background: rgba(0,255,65,0.05);
  border: 1px solid rgba(0,255,65,0.2);
  border-left: 3px solid var(--cp-green);
  padding: 14px 18px;
  border-radius: 0 2px 2px 0;
  margin: 16px 0 20px;
  color: var(--cp-text);
  line-height: 1.7;
}

.cp-docs-command__label {
  display: block;
  font-size: 10px;
  color: rgba(0,255,65,0.5);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 6px;
}

.cp-docs-command code {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  background: rgba(0,255,65,0.1);
  color: var(--cp-green);
  padding: 1px 5px;
  border-radius: 2px;
}


/* ============================================================
   DOCS — DOWNLOAD CTA INLINE
   ============================================================ */

.cp-docs-download-cta {
  display: flex;
  align-items: center;
  gap: 20px;
  margin: 24px 0 48px;
  flex-wrap: wrap;
}

.cp-docs-download-cta__note {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: var(--cp-text-muted);
  letter-spacing: 0.05em;
}


/* ============================================================
   DOCS — TABLES
   ============================================================ */

.cp-docs-table-wrap {
  overflow-x: auto;
  margin: 16px 0 24px;
  border: 1px solid rgba(0,255,65,0.15);
  border-radius: 2px;
}

.cp-docs-table {
  width: 100%;
  border-collapse: collapse;
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
}

.cp-docs-table th {
  background: rgba(0,255,65,0.08);
  color: var(--cp-green);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 12px 16px;
  text-align: left;
  border-bottom: 1px solid rgba(0,255,65,0.2);
}

.cp-docs-table td {
  padding: 12px 16px;
  color: var(--cp-text);
  border-bottom: 1px solid rgba(0,255,65,0.07);
  vertical-align: top;
  line-height: 1.6;
}

.cp-docs-table tr:last-child td {
  border-bottom: none;
}

.cp-docs-table tr:hover td {
  background: rgba(0,255,65,0.03);
}

.cp-docs-table td a {
  color: var(--cp-green);
  text-decoration: none;
}

.cp-docs-table td a:hover {
  text-decoration: underline;
}

.cp-docs-table td code {
  font-size: 11px;
  background: rgba(0,255,65,0.08);
  color: var(--cp-green);
  padding: 1px 5px;
  border-radius: 2px;
}


/* ============================================================
   INNER PAGES — BOTTOM CTA
   ============================================================ */

.cp-inner-cta {
  background: var(--cp-black-mid);
  padding: 80px 0;
  border-top: 1px solid rgba(0,255,65,0.15);
  text-align: center;
}


/* ============================================================
   INNER PAGES — RESPONSIVE
   ============================================================ */

@media (max-width: 768px) {
  .cp-inner-hero {
    padding: 60px 0 40px;
  }

  .cp-prose-inner {
    padding: 0 20px;
  }

  .cp-docs-toc__links {
    flex-direction: column;
    gap: 8px;
  }

  .cp-docs-download-cta {
    flex-direction: column;
    align-items: flex-start;
  }

  .cp-docs-table {
    font-size: 11px;
  }

  .cp-docs-table th,
  .cp-docs-table td {
    padding: 10px 12px;
  }
}
