/*
 * CycleSave Core Styles v2.0
 * Modern design system for CycleSave marketing site.
 * Compatible with Twenty Twenty-Five block theme.
 */

/* ═══════════════════════════════════════════════════════
   DESIGN TOKENS
   ═══════════════════════════════════════════════════════ */
:root {
	/* Brand — CycleSave Teal/Green (replaces purple; variable names kept for compatibility) */
	--cc-purple:        #0D7C66;   /* CycleSave primary teal */
	--cc-purple-dark:   #096B58;   /* CycleSave primary dark */
	--cc-purple-xdark:  #053D31;   /* deep teal for hero backgrounds */
	--cc-purple-light:  #e6f5f1;   /* CycleSave primary light */
	--cc-purple-xlight: #f0faf7;   /* CycleSave primary 50 */

	/* Accent Gold — CycleSave gold (replaces amber; variable names kept) */
	--cc-amber:         #E5A530;   /* CycleSave gold */
	--cc-amber-dark:    #C68B1A;   /* darker gold */
	--cc-amber-light:   #FFF8E1;   /* CycleSave gold light */

	/* Supporting colours */
	--cc-green:         #50A659;   /* CycleSave admin green / success */
	--cc-green-light:   #e6f5f1;
	--cc-blue:          #3B82F6;
	--cc-blue-light:    #DBEAFE;
	--cc-red:           #DC3545;   /* CycleSave red */

	/* Neutral (identical to CycleSave) */
	--cc-dark:          #0A1A14;   /* deep teal-black for dark sections */
	--cc-text:          #1A1A2E;
	--cc-text-muted:    #6B7280;
	--cc-border:        #E5E7EB;
	--cc-bg:            #F9FAFB;
	--cc-white:         #FFFFFF;

	/* Gradients — teal direction */
	--cc-gradient:       linear-gradient(135deg, #053D31 0%, #096B58 55%, #0D7C66 100%);
	--cc-gradient-hero:  linear-gradient(150deg, #0A1A14 0%, #0B3D32 50%, #0D5C4A 100%);
	--cc-gradient-soft:  linear-gradient(135deg, #f0faf7 0%, #e6f5f1 100%);

	/* Shape */
	--cc-radius:    12px;
	--cc-radius-sm: 8px;
	--cc-radius-lg: 20px;
	--cc-radius-xl: 28px;

	/* Shadows */
	--cc-shadow:        0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.05);
	--cc-shadow-md:     0 4px 12px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);
	--cc-shadow-lg:     0 20px 40px rgba(0,0,0,.10), 0 8px 16px rgba(0,0,0,.06);
	--cc-shadow-purple: 0 8px 32px rgba(13,124,102,.22);  /* teal glow */
	--cc-shadow-amber:  0 8px 32px rgba(229,165,48,.28);  /* gold glow */
}

/* ═══════════════════════════════════════════════════════
   BASE TYPOGRAPHY
   ═══════════════════════════════════════════════════════ */
html, body {
	font-family: 'Manrope', 'Inter', system-ui, -apple-system, sans-serif;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
	font-feature-settings: "ss01","ss02","cv01","cv02","cv03";
}

h1, h2, h3, h4, h5, h6,
.wp-block-heading {
	font-family: 'Manrope', 'Inter', system-ui, sans-serif;
	letter-spacing: -0.02em;
	-webkit-font-smoothing: antialiased;
}

html { scroll-behavior: smooth; }


/* ═══════════════════════════════════════════════════════
   HERO — SPLIT LAYOUT
   ═══════════════════════════════════════════════════════ */
.cccore-hero {
	overflow: hidden;
	position: relative;
}

.cccore-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(ellipse 80% 60% at 70% 50%, rgba(13,124,102,.15) 0%, transparent 70%);
	pointer-events: none;
}

.cccore-hero h1 {
	line-height: 1.08;
	letter-spacing: -0.03em;
	font-weight: 800;
}

.cccore-hero p {
	max-width: 600px;
	line-height: 1.7;
}

/* Hero split layout */
.cc-hero-split {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 48px;
	align-items: center;
}

@media (max-width: 900px) {
	.cc-hero-split {
		grid-template-columns: 1fr;
		gap: 40px;
	}
}

/* Floating product screenshot in hero */
.cc-hero-screenshot {
	position: relative;
	perspective: 1000px;
}

.cc-hero-screenshot img {
	border-radius: var(--cc-radius-lg);
	box-shadow: var(--cc-shadow-lg), 0 0 0 1px rgba(255,255,255,.1);
	transform: perspective(1200px) rotateY(-8deg) rotateX(4deg);
	width: 100%;
	height: auto;
}

.cc-hero-screenshot::before {
	content: '';
	position: absolute;
	inset: -20px;
	background: var(--cc-gradient);
	opacity: 0.1;
	border-radius: 28px;
	filter: blur(32px);
	z-index: -1;
}

/* Stat strip */
.cc-stat-strip {
	display: flex;
	gap: 32px;
	flex-wrap: wrap;
	align-items: center;
}

.cc-stat-strip .cc-stat-item {
	display: flex;
	flex-direction: column;
}

.cc-stat-item-value {
	font-size: 1.5rem;
	font-weight: 800;
	color: var(--cc-white);
	letter-spacing: -0.02em;
	line-height: 1;
}

.cc-stat-item-label {
	font-size: 0.8rem;
	color: rgba(255,255,255,.65);
	margin-top: 2px;
}

/* Trust badges in hero */
.cc-trust-badges {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	align-items: center;
}

.cc-trust-badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 0.82rem;
	font-weight: 600;
	color: rgba(255,255,255,.75);
}

.cc-trust-badge::before {
	content: '✓';
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 18px;
	height: 18px;
	background: rgba(255,255,255,.15);
	border-radius: 50%;
	font-size: 10px;
	color: #fff;
	flex-shrink: 0;
}

/* Amber CTA button override */
.wp-block-button.is-style-cc-amber .wp-block-button__link,
.cc-btn-amber {
	background: var(--cc-amber) !important;
	color: #1A1A2E !important;
	font-weight: 700;
}

.wp-block-button.is-style-cc-amber .wp-block-button__link:hover {
	background: var(--cc-amber-dark) !important;
	box-shadow: var(--cc-shadow-amber);
	transform: translateY(-1px);
}

/* ═══════════════════════════════════════════════════════
   SECTION LABELS
   ═══════════════════════════════════════════════════════ */
.cc-section-label {
	display: flex;
	width: fit-content;
	margin-left: auto;
	margin-right: auto;
	align-items: center;
	gap: 6px;
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--cc-purple);
	background: var(--cc-purple-xlight);
	padding: 5px 14px;
	border-radius: 100px;
	border: 1px solid var(--cc-purple-light);
}

.cc-section-label-hero {
    align-items: flex-start!important;
    justify-content: flex-start!important;
    margin-left: 0px;
    margin-right: 0px;
}


/* ═══════════════════════════════════════════════════════
   FEATURE CARDS
   ═══════════════════════════════════════════════════════ */
.cccore-feature-card {
	transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
	border-radius: var(--cc-radius-lg);
	border: 1px solid var(--cc-border);
	background: var(--cc-white);
}

.cccore-feature-card:hover {
	transform: translateY(-6px);
	box-shadow: var(--cc-shadow-md), 0 0 0 2px var(--cc-purple-light);
	border-color: var(--cc-purple-light);
}

/* Feature icon wrapper */
.cc-feature-icon {
	width: 52px;
	height: 52px;
	border-radius: 14px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.5rem;
	background: var(--cc-gradient-soft);
	margin-bottom: 16px;
	transition: transform 0.2s ease;
}

.cccore-feature-card:hover .cc-feature-icon {
	transform: scale(1.1) rotate(-3deg);
}

/* ═══════════════════════════════════════════════════════
   HOW-IT-WORKS
   ═══════════════════════════════════════════════════════ */
.cccore-step-number {
	font-weight: 800;
	line-height: 1;
	background: var(--cc-gradient);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	font-size: 3rem;
	display: block;
	margin-bottom: 12px;
}

/* ═══════════════════════════════════════════════════════
   PRICING CARDS
   ═══════════════════════════════════════════════════════ */
.cccore-pricing-card {
	transition: transform 0.22s ease, box-shadow 0.22s ease;
	border-radius: var(--cc-radius-lg);
	overflow: hidden;
	position: relative;
}

.cccore-pricing-card:hover {
	transform: translateY(-6px);
	box-shadow: var(--cc-shadow-lg);
}

.cccore-pricing-featured {
	box-shadow: var(--cc-shadow-purple);
}

.cccore-pricing-featured:hover {
	box-shadow: 0 24px 60px rgba(91,33,182,.22), 0 8px 20px rgba(91,33,182,.12);
}

/* Featured card gradient header band */
.cc-pricing-band {
	background: var(--cc-gradient);
	padding: 10px 20px;
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.cc-pricing-band-label {
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(255,255,255,.9);
}

.cc-pricing-band-badge {
	font-size: 0.7rem;
	font-weight: 700;
	background: rgba(255,255,255,.2);
	color: #fff;
	padding: 3px 10px;
	border-radius: 100px;
	letter-spacing: 0.05em;
}

/* Pricing list */
.cccore-pricing-card .wp-block-list {
	list-style: none;
	padding-left: 0 !important;
}

.cccore-pricing-card .wp-block-list li {
	padding-left: 0;
	margin-bottom: 0.55em;
	display: flex;
	align-items: flex-start;
	gap: 8px;
}

.cccore-pricing-card .wp-block-list li::before {
	content: '✓';
	color: var(--cc-green);
	font-weight: 700;
	flex-shrink: 0;
	margin-top: 1px;
}

/* ═══════════════════════════════════════════════════════
   TESTIMONIAL CARDS
   ═══════════════════════════════════════════════════════ */
.cccore-testimonial-card {
	transition: transform 0.22s ease, box-shadow 0.22s ease;
	border-radius: var(--cc-radius-lg);
	position: relative;
}

.cccore-testimonial-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--cc-shadow-md);
}

/* Big opening quote mark */
.cc-quote-mark {
	font-size: 5rem;
	line-height: 0.8;
	color: var(--cc-purple-light);
	font-family: Georgia, serif;
	display: block;
	margin-bottom: -8px;
	user-select: none;
}

/* Star ratings */
.cc-stars {
	color: var(--cc-amber);
	letter-spacing: 2px;
	font-size: 0.9rem;
}

/* Testimonial author avatar */
.cc-avatar {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	overflow: hidden;
	flex-shrink: 0;
}

.cc-avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* ═══════════════════════════════════════════════════════
   CTA SECTION
   ═══════════════════════════════════════════════════════ */
.cccore-cta-section {
	position: relative;
	overflow: hidden;
}

.cccore-cta-section::before {
	content: '';
	position: absolute;
	top: -80px;
	left: -80px;
	width: 360px;
	height: 360px;
	background: radial-gradient(circle, rgba(13,124,102,.25) 0%, transparent 70%);
	pointer-events: none;
}

.cccore-cta-section::after {
	content: '';
	position: absolute;
	bottom: -80px;
	right: -80px;
	width: 300px;
	height: 300px;
	background: radial-gradient(circle, rgba(229,165,48,.15) 0%, transparent 70%);
	pointer-events: none;
}

/* ═══════════════════════════════════════════════════════
   BADGES
   ═══════════════════════════════════════════════════════ */
.cc-badge {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 3px 10px;
	border-radius: 100px;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.cc-badge-free        { background: var(--cc-green-light);  color: #065F46; }
.cc-badge-premium     { background: var(--cc-purple-light); color: var(--cc-purple-dark); }
.cc-badge-integration { background: var(--cc-blue-light);   color: #1E40AF; }
.cc-badge-theme       { background: var(--cc-amber-light);  color: #92400E; }
.cc-badge-new         { background: #FEE2E2;                 color: #991B1B; }

/* ═══════════════════════════════════════════════════════
   ADDON CARDS (Marketplace)
   ═══════════════════════════════════════════════════════ */
.cc-addon-card {
	background: var(--cc-white);
	border: 1px solid var(--cc-border);
	border-radius: var(--cc-radius-lg);
	overflow: hidden;
	transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
	display: flex;
	flex-direction: column;
}

.cc-addon-card:hover {
	transform: translateY(-5px);
	box-shadow: var(--cc-shadow-md), 0 0 0 2px var(--cc-purple-light);
	border-color: var(--cc-purple-light);
}

.cc-addon-card-thumb {
	position: relative;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: var(--cc-bg);
}

.cc-addon-card-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s ease;
}

.cc-addon-card:hover .cc-addon-card-thumb img {
	transform: scale(1.04);
}

.cc-addon-card-body {
	padding: 20px;
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.cc-addon-card-meta {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
}

.cc-addon-card-title {
	font-size: 1rem;
	font-weight: 700;
	color: var(--cc-text);
	line-height: 1.35;
	margin: 0;
}

.cc-addon-card-desc {
	font-size: 0.875rem;
	color: var(--cc-text-muted);
	line-height: 1.6;
	flex: 1;
}

.cc-addon-card-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 14px 20px;
	border-top: 1px solid var(--cc-border);
	background: var(--cc-bg);
}

.cc-addon-price {
	font-weight: 700;
	font-size: 0.875rem;
	color: var(--cc-text);
}

.cc-addon-price.is-free {
	color: var(--cc-green);
}

/* Addon grid */
.cc-addons-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}

@media (max-width: 900px) {
	.cc-addons-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
	.cc-addons-grid { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════
   BLOG CARDS
   ═══════════════════════════════════════════════════════ */
.cc-blog-card {
	background: var(--cc-white);
	border: 1px solid var(--cc-border);
	border-radius: var(--cc-radius-lg);
	overflow: hidden;
	transition: transform 0.22s ease, box-shadow 0.22s ease;
	display: flex;
	flex-direction: column;
}

.cc-blog-card:hover {
	transform: translateY(-5px);
	box-shadow: var(--cc-shadow-md);
}

.cc-blog-card-thumb {
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: var(--cc-bg);
}

.cc-blog-card-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s ease;
}

.cc-blog-card:hover .cc-blog-card-thumb img {
	transform: scale(1.04);
}

.cc-blog-card-body {
	padding: 20px;
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.cc-blog-card-category {
	display: inline-flex;
	align-items: center;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--cc-purple);
	text-decoration: none;
}

.cc-blog-card-title {
	font-size: 1rem;
	font-weight: 700;
	color: var(--cc-text);
	line-height: 1.35;
	margin: 0;
	text-decoration: none;
	display: block;
	transition: color 0.15s;
}

.cc-blog-card-title:hover,
.cc-blog-card:hover .cc-blog-card-title {
	color: var(--cc-purple);
}

.cc-blog-card-excerpt {
	font-size: 0.875rem;
	color: var(--cc-text-muted);
	line-height: 1.65;
	flex: 1;
}

.cc-blog-card-meta {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 0.78rem;
	color: var(--cc-text-muted);
	margin-top: auto;
	padding-top: 12px;
	border-top: 1px solid var(--cc-border);
}

.cc-blog-card-meta span { display: flex; align-items: center; gap: 4px; }

/* Featured blog card (first post, full-width) */
.cc-blog-featured {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0;
	background: var(--cc-white);
	border: 1px solid var(--cc-border);
	border-radius: var(--cc-radius-xl);
	overflow: hidden;
	box-shadow: var(--cc-shadow);
}

.cc-blog-featured:hover {
	box-shadow: var(--cc-shadow-md);
}

.cc-blog-featured .cc-blog-card-thumb {
	aspect-ratio: auto;
	height: 100%;
	min-height: 300px;
}

.cc-blog-featured .cc-blog-card-body {
	padding: 36px;
	justify-content: center;
}

.cc-blog-featured .cc-blog-card-title {
	font-size: 1.4rem;
	line-height: 1.3;
}

@media (max-width: 768px) {
	.cc-blog-featured { grid-template-columns: 1fr; }
	.cc-blog-featured .cc-blog-card-thumb { min-height: 200px; }
}

/* Blog grid below featured */
.cc-blog-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}

@media (max-width: 900px) {
	.cc-blog-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
	.cc-blog-grid { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════
   SINGLE POST — 3-COLUMN LAYOUT
   ═══════════════════════════════════════════════════════ */

/* Ensure the single-post <main> breaks out of root padding / constrained layout */
body.single-post .wp-site-blocks {
	padding-left: 0 !important;
	padding-right: 0 !important;
}

.cc-single-3col {
	display: grid;
	grid-template-columns: 140px 1fr 220px;
	gap: 48px;
	align-items: start;
}

/* Left metadata sidebar */
.cc-meta-sidebar {
	position: sticky;
	top: 96px;
}

.admin-bar .cc-meta-sidebar {
	top: 128px;
}

.cc-meta-label {
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--cc-text-muted);
	margin: 0 0 6px;
	line-height: 1;
}

.cc-meta-value {
	font-size: 0.875rem;
	color: var(--cc-text);
	margin: 0;
}

.cc-reading-time {
	font-size: 0.875rem;
	color: var(--cc-text);
	display: block;
}

/* Tags in left sidebar as pill badges */
.cc-meta-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.cc-meta-tags a {
	display: inline-block;
	padding: 3px 10px;
	border: 1px solid var(--cc-border);
	border-radius: 100px;
	font-size: 0.78rem;
	font-weight: 600;
	color: var(--cc-text);
	text-decoration: none;
	transition: background 0.15s, border-color 0.15s, color 0.15s;
}

.cc-meta-tags a:hover {
	background: var(--cc-purple-xlight);
	border-color: var(--cc-purple);
	color: var(--cc-purple);
}

/* Right sidebar column */
.cc-single-sidebar-col {
	position: sticky;
	top: 96px;
}

.admin-bar .cc-single-sidebar-col {
	top: 128px;
}

/* Center content column */
.cc-single-content-col {
	min-width: 0;
}

/* Featured image banner */
.cc-single-banner-image img {
	width: 100%;
	max-height: 420px;
	object-fit: cover;
}

/* ── Sidebar widgets (shared) ──────────────────────────── */

/* Simple search input (no button, just input) */
.cc-sidebar-search-simple {
	display: block;
}

.cc-sidebar-search-input {
	width: 100%;
	padding: 8px 12px;
	font-size: 0.875rem;
	line-height: 1.4;
	border: 1px solid var(--cc-border);
	border-radius: 6px;
	background: var(--cc-bg);
	color: var(--cc-text);
	outline: none;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
	box-sizing: border-box;
}

.cc-sidebar-search-input:focus {
	border-color: var(--cc-purple);
	box-shadow: 0 0 0 3px rgba(13, 124, 102, 0.12);
}

.cc-sidebar-search-input::placeholder {
	color: var(--cc-text-muted);
}

/* Tag pills in sidebar */
.cc-tag-pills {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.cc-tag-pill {
	display: inline-block;
	padding: 4px 12px;
	border: 1px solid var(--cc-border);
	border-radius: 100px;
	font-size: 0.78rem;
	font-weight: 600;
	color: var(--cc-text);
	text-decoration: none;
	transition: background 0.15s, border-color 0.15s, color 0.15s;
	line-height: 1.4;
}

.cc-tag-pill:hover {
	background: var(--cc-purple-xlight);
	border-color: var(--cc-purple);
	color: var(--cc-purple);
}

/* Recent posts list (titles only) */
.cc-recent-posts-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0;
}

.cc-recent-posts-list li {
	padding: 8px 0;
	border-bottom: 1px solid var(--cc-border);
}

.cc-recent-posts-list li:last-child {
	border-bottom: none;
}

.cc-recent-posts-list a {
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--cc-text);
	text-decoration: none;
	line-height: 1.4;
	transition: color 0.15s;
}

.cc-recent-posts-list a:hover {
	color: var(--cc-purple);
}

/* Category count badge */
.cc-sidebar-categories .count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 24px;
	height: 20px;
	padding: 0 6px;
	border-radius: 6px;
	background: var(--cc-purple-xlight);
	color: var(--cc-purple);
	font-size: 0.72rem;
	font-weight: 700;
	margin-left: auto;
}

/* Responsive — 3-column layout */
@media (max-width: 1024px) {
	.cc-single-3col {
		grid-template-columns: 1fr 220px;
		gap: 40px;
	}
	.cc-meta-sidebar {
		display: none;
	}
}

@media (max-width: 768px) {
	.cc-single-3col {
		grid-template-columns: 1fr;
		gap: 32px;
	}
	.cc-single-sidebar-col {
		position: static;
	}
}

/* ═══════════════════════════════════════════════════════
   DOCUMENTATION SIDEBAR
   ═══════════════════════════════════════════════════════ */
.cccore-docs-sidebar {
	position: sticky;
	top: 96px;
}

.admin-bar .cccore-docs-sidebar {
	top: 128px;
}

/* Docs search input */
.cc-docs-search {
	margin-bottom: 20px;
}

.cc-docs-search-input {
	width: 100%;
	padding: 8px 12px;
	font-size: 0.875rem;
	line-height: 1.4;
	border: 1px solid var(--cc-border);
	border-radius: 6px;
	background: var(--cc-bg-offset, #f9fafb);
	color: var(--cc-text);
	outline: none;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.cc-docs-search-input:focus {
	border-color: var(--cc-purple);
	box-shadow: 0 0 0 3px rgba(13, 124, 102, 0.12);
}

.cc-docs-search-input::placeholder {
	color: var(--cc-text-muted);
}

.cccore-docs-nav {
	list-style: none;
	padding-left: 0 !important;
}

.cccore-docs-nav li {
	margin-top: 0 !important;
}

.cccore-docs-nav a {
	text-decoration: none;
	color: var(--cc-text-muted);
	transition: color 0.15s ease, border-color 0.15s ease, padding-left 0.15s ease;
	display: block;
	padding: 7px 0 7px 14px;
	border-left: 2px solid transparent;
	font-size: 0.875rem;
	line-height: 1.4;
}

.cccore-docs-nav a:hover,
.cccore-docs-nav a:focus,
.cccore-docs-nav a.is-active {
	color: var(--cc-purple);
	border-left-color: var(--cc-purple);
	padding-left: 18px;
}

.cccore-docs-nav .cc-nav-section-title {
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--cc-text);
	padding: 14px 0 6px 14px;
	margin-top: 4px;
}

.cccore-docs-nav .cc-nav-section-title:first-child {
	padding-top: 0;
}

/* Docs sidebar mobile toggle — hidden on desktop */
.cc-docs-sidebar-toggle {
	display: none;
}

/* Doc article content */
.cccore-docs-content h2 {
	scroll-margin-top: 110px;
}

.cccore-docs-content h2:not(:first-child) {
	margin-top: 3rem;
	padding-top: 2rem;
	border-top: 1px solid var(--cc-border);
}

.cccore-docs-content pre {
	background: var(--cc-dark);
	color: #e2e8f0;
	border-radius: var(--cc-radius);
	padding: 20px;
	overflow-x: auto;
	font-size: 0.875rem;
	line-height: 1.6;
}

.cccore-docs-content code {
	font-size: 0.875em;
	background: var(--cc-purple-xlight);
	color: var(--cc-purple-dark);
	padding: 2px 6px;
	border-radius: 4px;
}

.cccore-docs-content pre code {
	background: none;
	color: inherit;
	padding: 0;
	font-size: inherit;
	border-radius: 0;
}

/* Doc header — breadcrumb + title */
.cc-doc-header {
	margin-bottom: 2rem;
	padding-bottom: 1.5rem;
	border-bottom: 1px solid var(--cc-border);
}

.cc-doc-title {
	font-size: clamp(1.6rem, 4vw, 2.2rem);
	font-weight: 800;
	letter-spacing: -0.03em;
	line-height: 1.15;
	color: var(--cc-text);
	margin: 12px 0 0;
}

/* Paragraphs */
.cccore-docs-content p {
	font-size: 1rem;
	line-height: 1.8;
	color: var(--cc-text);
	margin-top: 0;
	margin-bottom: 1.25rem;
}

/* Headings */
.cccore-docs-content h3 {
	font-size: 1.15rem;
	font-weight: 700;
	letter-spacing: -0.01em;
	color: var(--cc-text);
	margin-top: 2rem;
	margin-bottom: 0.75rem;
}

.cccore-docs-content h4 {
	font-size: 1rem;
	font-weight: 700;
	color: var(--cc-text);
	margin-top: 1.5rem;
	margin-bottom: 0.5rem;
}

/* Lists */
.cccore-docs-content ul,
.cccore-docs-content ol {
	margin: 0 0 1.5rem 0;
	padding-left: 1.5rem;
	line-height: 1.8;
	color: var(--cc-text);
}

.cccore-docs-content li {
	margin-bottom: 0.4rem;
	font-size: 1rem;
}

.cccore-docs-content li::marker {
	color: var(--cc-purple);
}

.cccore-docs-content ul ul,
.cccore-docs-content ol ol,
.cccore-docs-content ul ol,
.cccore-docs-content ol ul {
	margin-top: 0.4rem;
	margin-bottom: 0;
}

/* Tables */
.cccore-docs-content table {
	width: 100%;
	border-collapse: collapse;
	margin: 1.5rem 0;
	font-size: 0.92rem;
	line-height: 1.6;
	border-radius: var(--cc-radius);
	overflow: hidden;
	border: 1px solid var(--cc-border);
}

.cccore-docs-content thead th {
	background: var(--cc-purple-xlight);
	color: var(--cc-text);
	font-weight: 700;
	font-size: 0.82rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	padding: 12px 16px;
	text-align: left;
	border-bottom: 2px solid var(--cc-purple-light);
}

.cccore-docs-content td {
	padding: 12px 16px;
	border-bottom: 1px solid var(--cc-border);
	vertical-align: top;
}

.cccore-docs-content tbody tr:last-child td {
	border-bottom: none;
}

.cccore-docs-content tbody tr:hover {
	background: var(--cc-purple-xlight);
}

/* Blockquotes / callouts */
.cccore-docs-content blockquote {
	margin: 1.5rem 0;
	padding: 16px 20px;
	border-left: 4px solid var(--cc-purple);
	background: var(--cc-purple-xlight);
	border-radius: 0 var(--cc-radius-sm) var(--cc-radius-sm) 0;
	color: var(--cc-text);
	font-size: 0.95rem;
	line-height: 1.7;
}

.cccore-docs-content blockquote p:last-child {
	margin-bottom: 0;
}

/* Images */
.cccore-docs-content img {
	max-width: 100%;
	height: auto;
	border-radius: var(--cc-radius);
	border: 1px solid var(--cc-border);
	margin: 1.5rem 0;
}

/* Strong / emphasis */
.cccore-docs-content strong {
	font-weight: 700;
	color: var(--cc-text);
}

/* Links */
.cccore-docs-content a {
	color: var(--cc-purple);
	text-decoration: underline;
	text-underline-offset: 2px;
	transition: color 0.15s;
}

.cccore-docs-content a:hover {
	color: var(--cc-purple-dark);
}

/* Horizontal rule */
.cccore-docs-content hr {
	border: none;
	border-top: 1px solid var(--cc-border);
	margin: 2rem 0;
}

/* Figure / wp-block-table wrapper */
.cccore-docs-content figure {
	margin: 1.5rem 0;
}

.cccore-docs-content figcaption {
	font-size: 0.82rem;
	color: var(--cc-text-muted);
	text-align: center;
	margin-top: 8px;
}

/* Responsive */
@media (max-width: 768px) {
	.cccore-docs-content table {
		display: block;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}
	.cc-doc-nav {
		grid-template-columns: 1fr;
	}
}

/* Breadcrumb */
.cc-doc-breadcrumb {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 0.82rem;
	color: var(--cc-text-muted);
	flex-wrap: wrap;
}

.cc-doc-breadcrumb a {
	color: var(--cc-text-muted);
	text-decoration: none;
	transition: color 0.15s;
}

.cc-doc-breadcrumb a:hover { color: var(--cc-purple); }

.cc-doc-breadcrumb-sep {
	color: var(--cc-border);
	font-size: 0.7rem;
}

/* Was this helpful? */
.cc-doc-feedback {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 20px 24px;
	background: var(--cc-purple-xlight);
	border: 1px solid var(--cc-purple-light);
	border-radius: var(--cc-radius);
	font-size: 0.875rem;
	color: var(--cc-text);
	margin-top: 48px;
}

.cc-doc-feedback strong { color: var(--cc-text); font-weight: 700; }

.cc-feedback-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 14px;
	border-radius: var(--cc-radius-sm);
	border: 1px solid var(--cc-purple-light);
	background: var(--cc-white);
	color: var(--cc-purple);
	font-size: 0.82rem;
	font-weight: 600;
	cursor: pointer;
	transition: background 0.15s, border-color 0.15s;
	text-decoration: none;
}

.cc-feedback-btn:hover {
	background: var(--cc-purple);
	color: #fff;
	border-color: var(--cc-purple);
}

/* Prev / Next doc nav */
.cc-doc-nav {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
	margin-top: 48px;
}

.cc-doc-nav-card {
	display: flex;
	flex-direction: column;
	gap: 4px;
	padding: 16px 20px;
	border: 1px solid var(--cc-border);
	border-radius: var(--cc-radius);
	text-decoration: none;
	color: var(--cc-text);
	transition: border-color 0.15s, background 0.15s;
}

.cc-doc-nav-card:hover {
	border-color: var(--cc-purple);
	background: var(--cc-purple-xlight);
}

.cc-doc-nav-card.is-next { text-align: right; }

.cc-doc-nav-dir {
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--cc-text-muted);
}

.cc-doc-nav-title {
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--cc-purple);
}

/* TOC sidebar */
.cc-doc-toc {
	position: sticky;
	top: 96px;
	font-size: 0.82rem;
}

.admin-bar .cc-doc-toc { top: 128px; }

.cc-doc-toc-title {
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--cc-text-muted);
	margin-bottom: 10px;
}

.cc-doc-toc a {
	display: block;
	color: var(--cc-text-muted);
	text-decoration: none;
	padding: 5px 0 5px 12px;
	border-left: 2px solid transparent;
	transition: color 0.15s, border-color 0.15s;
	line-height: 1.4;
}

.cc-doc-toc a:hover,
.cc-doc-toc a.is-active {
	color: var(--cc-purple);
	border-left-color: var(--cc-purple);
}

/* ═══════════════════════════════════════════════════════
   ADDON SINGLE — Screenshot Gallery & Steps
   ═══════════════════════════════════════════════════════ */
.cc-screenshot-gallery {
	display: flex;
	gap: 16px;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	padding-bottom: 8px;
	scrollbar-width: thin;
	scrollbar-color: var(--cc-purple-light) transparent;
}

.cc-screenshot-gallery::-webkit-scrollbar { height: 4px; }
.cc-screenshot-gallery::-webkit-scrollbar-track { background: transparent; }
.cc-screenshot-gallery::-webkit-scrollbar-thumb { background: var(--cc-purple-light); border-radius: 2px; }

.cc-screenshot-item {
	flex-shrink: 0;
	width: 80%;
	max-width: 700px;
	scroll-snap-align: start;
	border-radius: var(--cc-radius);
	overflow: hidden;
	box-shadow: var(--cc-shadow-md);
}

.cc-screenshot-item img {
	width: 100%;
	height: auto;
	display: block;
}

/* Integration steps timeline */
.cc-steps-timeline {
	list-style: none;
	padding: 0;
	margin: 0;
	position: relative;
}

.cc-steps-timeline::before {
	content: '';
	position: absolute;
	left: 20px;
	top: 28px;
	bottom: 28px;
	width: 2px;
	background: linear-gradient(to bottom, var(--cc-purple), var(--cc-purple-light));
	z-index: 0;
}

.cc-step-item {
	display: flex;
	gap: 20px;
	position: relative;
	padding-bottom: 32px;
}

.cc-step-item:last-child { padding-bottom: 0; }

.cc-step-number {
	width: 42px;
	height: 42px;
	border-radius: 50%;
	background: var(--cc-gradient);
	color: #fff;
	font-size: 0.9rem;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	position: relative;
	z-index: 1;
	box-shadow: 0 0 0 4px #fff, 0 0 0 6px var(--cc-purple-light);
}

.cc-step-content {
	padding-top: 8px;
}

.cc-step-title {
	font-weight: 700;
	color: var(--cc-text);
	margin-bottom: 6px;
	font-size: 1rem;
}

.cc-step-desc {
	color: var(--cc-text-muted);
	font-size: 0.875rem;
	line-height: 1.65;
}

/* Addon meta info chips */
.cc-addon-meta-chips {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.cc-meta-chip {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 12px;
	background: var(--cc-bg);
	border: 1px solid var(--cc-border);
	border-radius: var(--cc-radius-sm);
	font-size: 0.82rem;
	color: var(--cc-text);
}

.cc-meta-chip strong { color: var(--cc-text); font-weight: 600; }
.cc-meta-chip .cc-chip-label { color: var(--cc-text-muted); font-size: 0.75rem; }

/* ═══════════════════════════════════════════════════════
   FEATURES PAGE — ALTERNATING SECTIONS
   ═══════════════════════════════════════════════════════ */
.cc-feature-section {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 64px;
	align-items: center;
}

.cc-feature-section.is-reversed {
	direction: rtl;
}

.cc-feature-section.is-reversed > * {
	direction: ltr;
}

@media (max-width: 900px) {
	.cc-feature-section,
	.cc-feature-section.is-reversed {
		grid-template-columns: 1fr;
		direction: ltr;
		gap: 32px;
	}
}

.cc-feature-screenshot {
	border-radius: var(--cc-radius-lg);
	overflow: hidden;
	box-shadow: var(--cc-shadow-lg);
	position: relative;
}

.cc-feature-screenshot img {
	width: 100%;
	height: auto;
	display: block;
}

/* ═══════════════════════════════════════════════════════
   PRICING FAQ
   ═══════════════════════════════════════════════════════ */
.cc-faq-item {
	border-bottom: 1px solid var(--cc-border);
	padding: 20px 0;
}

.cc-faq-item:first-child { border-top: 1px solid var(--cc-border); }

.cc-faq-question {
	font-weight: 700;
	font-size: 1rem;
	color: var(--cc-text);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	list-style: none;
}

.cc-faq-question::after {
	content: '+';
	font-size: 1.4rem;
	color: var(--cc-purple);
	flex-shrink: 0;
	font-weight: 300;
	transition: transform 0.2s ease;
}

details[open] .cc-faq-question::after {
	content: '−';
}

.cc-faq-answer {
	padding-top: 12px;
	font-size: 0.9375rem;
	color: var(--cc-text-muted);
	line-height: 1.7;
}

/* ═══════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════ */
.cccore-footer a {
	transition: color 0.15s ease, opacity 0.15s ease;
}

.cccore-footer a:hover {
	color: var(--wp--preset--color--accent-2, #e6f5f1) !important;
	opacity: 1;
}

/* Social icons row */
.cc-social-icons {
	display: flex;
	gap: 12px;
	align-items: center;
}

.cc-social-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	border-radius: 8px;
	background: rgba(255,255,255,.1);
	color: rgba(255,255,255,.7);
	text-decoration: none;
	font-size: 0.9rem;
	transition: background 0.15s, color 0.15s;
}

.cc-social-icon:hover {
	background: var(--cc-purple);
	color: #fff;
}

/* ═══════════════════════════════════════════════════════
   BUTTON OVERRIDES
   ═══════════════════════════════════════════════════════ */
.wp-block-button__link {
	font-family: 'Manrope', 'Inter', system-ui, sans-serif;
	font-weight: 600;
	-webkit-font-smoothing: antialiased;
	transition: background-color 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease !important;
}

.wp-block-button.is-style-fill .wp-block-button__link:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(91, 33, 182, 0.28);
}

.wp-block-button.is-style-outline .wp-block-button__link {
	transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.15s ease !important;
}

.wp-block-button.is-style-outline .wp-block-button__link:hover {
	background-color: var(--wp--preset--color--accent-1, #0D7C66);
	color: #fff;
	transform: translateY(-2px);
}

/* Large pill buttons */
.wp-block-button.is-style-cc-pill .wp-block-button__link {
	border-radius: 100px !important;
	padding-left: 28px !important;
	padding-right: 28px !important;
}

/* ═══════════════════════════════════════════════════════
   FOCUS & ACCESSIBILITY
   ═══════════════════════════════════════════════════════ */
.wp-block-button__link:focus-visible,
a:focus-visible {
	outline: 2px solid var(--cc-purple);
	outline-offset: 3px;
}

/* ═══════════════════════════════════════════════════════
   TUTORIAL CARDS (existing, refined)
   ═══════════════════════════════════════════════════════ */
.cccore-tutorial-card {
	transition: transform 0.22s ease, box-shadow 0.22s ease;
	border-radius: var(--cc-radius-lg);
	border: 1px solid var(--cc-border);
	overflow: hidden;
}

.cccore-tutorial-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--cc-shadow-md);
	border-color: var(--cc-purple-light);
}

.cccore-tutorial-card a {
	font-weight: 700;
	text-decoration: none;
}

.cccore-tutorial-card a:hover { color: var(--cc-purple); }

/* Difficulty badges */
.cc-difficulty-beginner    { background: var(--cc-green-light); color: #065F46; }
.cc-difficulty-intermediate { background: var(--cc-amber-light); color: #92400E; }
.cc-difficulty-advanced    { background: #FEE2E2; color: #991B1B; }

/* ═══════════════════════════════════════════════════════
   NO-BULLET LIST UTILITY
   ═══════════════════════════════════════════════════════ */
.is-style-no-bullets {
	list-style: none;
	padding-left: 0 !important;
}

.is-style-no-bullets li {
	margin-top: 0 !important;
}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════ */
@media (max-width: 781px) {
	.cccore-pricing-card,
	.cccore-feature-card,
	.cccore-testimonial-card,
	.cccore-tutorial-card {
		margin-bottom: var(--wp--preset--spacing--30);
	}

	.cccore-hero h1 {
		font-size: clamp(1.75rem, 7vw, 3.5rem) !important;
	}

	.cccore-hero .wp-block-buttons {
		flex-direction: column;
		align-items: stretch;
	}

	.cccore-hero .wp-block-button {
		width: 100%;
	}

	.cccore-docs-sidebar-col {
		flex-basis: 100% !important;
	}

	.cccore-docs-sidebar,
	.cc-doc-toc {
		position: static;
	}

	/* Docs sidebar mobile toggle */
	.cc-docs-sidebar-toggle {
		display: flex;
		align-items: center;
		gap: 8px;
		width: 100%;
		padding: 12px 16px;
		border: 1px solid var(--cc-border);
		border-radius: var(--cc-radius-sm);
		background: var(--cc-white);
		color: var(--cc-text);
		font-size: 0.9rem;
		font-weight: 600;
		cursor: pointer;
		transition: background 0.15s ease, border-color 0.15s ease;
	}

	.cc-docs-sidebar-toggle:hover,
	.cc-docs-sidebar-toggle:focus-visible {
		background: var(--cc-purple-xlight);
		border-color: var(--cc-purple);
		outline: none;
	}

	.cc-docs-sidebar-toggle-icon {
		flex-shrink: 0;
		transition: transform 0.2s ease;
	}

	.cc-docs-sidebar-toggle[aria-expanded="true"] .cc-docs-sidebar-toggle-icon {
		transform: rotate(90deg);
	}

	/* Collapsible panel */
	.cc-docs-sidebar-panel {
		max-height: 0;
		overflow: hidden;
		transition: max-height 0.3s ease;
	}

	.cc-docs-sidebar-panel.is-open {
		max-height: 2000px;
	}

	.cc-docs-sidebar-panel .cc-docs-search {
		margin-top: 16px;
	}

	.cc-doc-nav { grid-template-columns: 1fr; }

	.cc-steps-timeline::before { display: none; }

	.cc-screenshot-item { width: 90%; }

	.cc-stat-strip { gap: 20px; }
}

/* ═══════════════════════════════════════════════════════
   AUTH PAGES — Login & Register split layout
   ═══════════════════════════════════════════════════════ */

/* Full-screen two-column shell */
.cc-auth-layout {
	display: flex;
	min-height: 100vh;
	width: 100%;
}

/* Left — brand panel */
.cc-auth-brand {
	flex: 0 0 44%;
	background: var(--cc-gradient);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 60px 48px;
}

.cc-auth-brand-inner {
	max-width: 380px;
	width: 100%;
}

/* Right — form panel */
.cc-auth-form-panel {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--cc-bg);
	padding: 60px 40px;
}

/* White card that contains the form */
.cc-auth-card {
	background: var(--cc-white);
	border: 1px solid var(--cc-border);
	border-radius: var(--cc-radius-xl);
	padding: 40px;
	width: 100%;
	max-width: 440px;
	box-shadow: var(--cc-shadow-md);
}

/* ProfilePress form body — strip out PP default styles */
.cc-auth-form-body .pp-form-wrapper,
.cc-auth-form-body .pp-form-field-wrap {
	padding: 0 !important;
	margin: 0 0 16px !important;
	box-shadow: none !important;
	border: none !important;
	background: transparent !important;
}

.cc-auth-form-body input[type="text"],
.cc-auth-form-body input[type="email"],
.cc-auth-form-body input[type="password"] {
	width: 100%;
	padding: 11px 14px;
	border: 1px solid var(--cc-border);
	border-radius: var(--cc-radius-sm);
	font-size: 0.9375rem;
	color: var(--cc-text);
	background: var(--cc-white);
	transition: border-color 0.15s, box-shadow 0.15s;
	box-sizing: border-box;
}

.cc-auth-form-body input[type="text"]:focus,
.cc-auth-form-body input[type="email"]:focus,
.cc-auth-form-body input[type="password"]:focus {
	outline: none;
	border-color: var(--cc-purple);
	box-shadow: 0 0 0 3px rgba(13, 124, 102, 0.12);
}

.cc-auth-form-body input[type="submit"],
.cc-auth-form-body button[type="submit"] {
	width: 100%;
	padding: 13px;
	background: var(--cc-purple);
	color: #fff;
	border: none;
	border-radius: var(--cc-radius-sm);
	font-size: 0.9375rem;
	font-weight: 700;
	cursor: pointer;
	transition: background 0.15s, transform 0.1s;
}

.cc-auth-form-body input[type="submit"]:hover,
.cc-auth-form-body button[type="submit"]:hover {
	background: var(--cc-purple-dark);
	transform: translateY(-1px);
}

/* Stack on mobile */
@media (max-width: 768px) {
	.cc-auth-layout {
		flex-direction: column;
	}

	.cc-auth-brand {
		flex: none;
		padding: 48px 24px;
	}

	.cc-auth-form-panel {
		padding: 40px 20px;
	}

	.cc-auth-card {
		padding: 28px 20px;
	}
}

/* ═══════════════════════════════════════════════════════
   BLOG QUERY LOOP — real post grid with wp:query
   ═══════════════════════════════════════════════════════ */

/* blog-grid pattern — secondary 3-col query loop */
.cc-blog-grid.wp-block-post-template {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	list-style: none;
	padding: 0;
	margin: 0;
}

@media (max-width: 900px) {
	.cc-blog-grid.wp-block-post-template { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
	.cc-blog-grid.wp-block-post-template { grid-template-columns: 1fr; }
}

/* blog-grid pattern — featured post: make the block figure fill the grid cell */
.cc-blog-featured > .wp-block-post-featured-image,
.cc-blog-featured > figure.wp-block-post-featured-image {
	height: 100%;
	min-height: 300px;
	aspect-ratio: auto;
	overflow: hidden;
	margin: 0;
}

.cc-blog-featured > .wp-block-post-featured-image img,
.cc-blog-featured > figure.wp-block-post-featured-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* cc-archive-grid.wp-block-post-template — category/tag archive 2-col grid */
.cc-archive-grid.wp-block-post-template {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 24px;
	list-style: none;
	padding: 0;
	margin: 0;
}

@media (max-width: 700px) {
	.cc-archive-grid.wp-block-post-template { grid-template-columns: 1fr; }
}

/* Tag cloud */
.cc-tag-cloud.wp-block-tag-cloud {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.cc-tag-cloud.wp-block-tag-cloud a {
	display: inline-block;
	padding: 4px 10px;
	background: var(--cc-purple-xlight);
	border: 1px solid var(--cc-purple-light);
	border-radius: 100px;
	font-size: 0.78rem !important;
	font-weight: 600;
	color: var(--cc-purple);
	text-decoration: none;
	transition: background 0.15s, color 0.15s;
}

.cc-tag-cloud.wp-block-tag-cloud a:hover {
	background: var(--cc-purple);
	color: #fff;
	border-color: var(--cc-purple);
}

/* Sidebar search */
.cc-sidebar-search.wp-block-search__button-inside .wp-block-search__inside-wrapper {
	border: 1px solid var(--cc-border);
	border-radius: var(--cc-radius-sm);
	overflow: hidden;
	display: flex;
	align-items: center;
	background: var(--cc-white);
	transition: border-color 0.15s, box-shadow 0.15s;
}

.cc-sidebar-search.wp-block-search__button-inside .wp-block-search__inside-wrapper:focus-within {
	border-color: var(--cc-purple);
	box-shadow: 0 0 0 3px rgba(13,124,102,0.12);
}

.cc-sidebar-search .wp-block-search__input {
	border: none !important;
	box-shadow: none !important;
	padding: 10px 12px !important;
	font-size: 0.875rem !important;
	flex: 1;
	background: transparent;
	color: var(--cc-text);
}

.cc-sidebar-search .wp-block-search__button {
	background: var(--cc-purple) !important;
	color: #fff !important;
	border: none !important;
	padding: 10px 14px !important;
	font-size: 0.82rem !important;
	font-weight: 600 !important;
	cursor: pointer;
	white-space: nowrap;
	border-radius: 0 !important;
	transition: background 0.15s;
}

.cc-sidebar-search .wp-block-search__button:hover {
	background: var(--cc-purple-dark) !important;
}

/* Addon type terms styled as badges inside card meta */
.cc-addon-card-meta.wp-block-post-terms a.wp-block-post-terms__item {
	display: inline-flex;
	align-items: center;
	padding: 3px 9px;
	border-radius: 100px;
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	text-decoration: none;
	background: var(--cc-purple-xlight);
	color: var(--cc-purple-dark);
	transition: opacity 0.15s;
}

.cc-addon-card-meta.wp-block-post-terms .wp-block-post-terms__separator {
	display: none;
}

/* cc-blog-grid-query.wp-block-post-template — blog-page.html archive query */
.cc-blog-grid-query.wp-block-post-template {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	list-style: none;
	padding: 0;
	margin: 0;
}

@media (max-width: 900px) {
	.cc-blog-grid-query.wp-block-post-template { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
	.cc-blog-grid-query.wp-block-post-template { grid-template-columns: 1fr; }
}

/* Pagination */
.cc-pagination.wp-block-query-pagination {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	flex-wrap: wrap;
}

.cc-pagination .wp-block-query-pagination-numbers a,
.cc-pagination .wp-block-query-pagination-numbers span,
.cc-pagination .wp-block-query-pagination-previous,
.cc-pagination .wp-block-query-pagination-next {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 12px;
	border: 1px solid var(--cc-border);
	border-radius: var(--cc-radius-sm);
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--cc-text);
	text-decoration: none;
	transition: background 0.15s, border-color 0.15s, color 0.15s;
}

.cc-pagination .wp-block-query-pagination-numbers a:hover,
.cc-pagination .wp-block-query-pagination-previous:hover,
.cc-pagination .wp-block-query-pagination-next:hover {
	background: var(--cc-purple-xlight);
	border-color: var(--cc-purple);
	color: var(--cc-purple);
}

.cc-pagination .wp-block-query-pagination-numbers .current {
	background: var(--cc-purple);
	border-color: var(--cc-purple);
	color: #fff;
}

/* ═══════════════════════════════════════════════════════
   SINGLE POST — featured image + sidebar
   ═══════════════════════════════════════════════════════ */

.cc-single-featured-image img {
	width: 100%;
	max-height: 500px;
	object-fit: cover;
	border-radius: 16px;
	display: block;
}

.cc-post-sidebar-col .cc-post-sidebar {
	position: sticky;
	top: 96px;
	display: flex;
	flex-direction: column;
	gap: 24px;
}

.admin-bar .cc-post-sidebar-col .cc-post-sidebar {
	top: 128px;
}

.cc-sidebar-widget {
	background: var(--cc-white);
	border: 1px solid var(--cc-border);
	border-radius: var(--cc-radius-lg);
	padding: 24px;
	margin-top: 10px;
	margin-bottom: 10px;
}

.cc-sidebar-ad {
	border: none;
	padding: 0;
	background: transparent;
}

.cc-sidebar-widget-title {
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--cc-text-muted);
	margin: 0 0 14px;
}

.cc-sidebar-categories.wp-block-categories {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.cc-sidebar-categories.wp-block-categories li {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 7px 10px;
	border-radius: var(--cc-radius-sm);
	transition: background 0.15s;
}

.cc-sidebar-categories.wp-block-categories li a {
	flex: 1;
	font-size: 0.875rem;
	color: var(--cc-text);
	text-decoration: none;
	transition: color 0.15s;
}

.cc-sidebar-categories.wp-block-categories li .count {
	font-size: 0.78rem;
	color: var(--cc-text-muted);
	margin-left: 6px;
}

.cc-sidebar-categories.wp-block-categories li:hover {
	background: var(--cc-purple-xlight);
}

.cc-sidebar-categories.wp-block-categories li:hover a {
	color: var(--cc-purple);
}

.cc-sidebar-categories.wp-block-categories li a:hover {
	background: var(--cc-purple-xlight);
	color: var(--cc-purple);
}

/* Recent posts mini-cards */
.cc-recent-post {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px 0;
	border-bottom: 1px solid var(--cc-border);
}

.cc-recent-post:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.cc-recent-post-thumb.wp-block-post-featured-image,
.cc-recent-post .wp-block-post-featured-image {
	width: 72px !important;
	height: 72px !important;
	min-width: 72px;
	flex-shrink: 0;
	overflow: hidden;
	border-radius: 10px;
	display: block;
}

.cc-recent-post-thumb.wp-block-post-featured-image a,
.cc-recent-post .wp-block-post-featured-image a {
	display: block;
	width: 100%;
	height: 100%;
}

.cc-recent-post-thumb.wp-block-post-featured-image img,
.cc-recent-post .wp-block-post-featured-image img {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover;
	display: block;
}

.cc-post-content {
	font-size: 1.0625rem;
	line-height: 1.8;
	color: var(--cc-text);
}

.cc-tag-list .wp-block-post-terms__item {
	display: inline-block;
	padding: 3px 10px;
	background: var(--cc-purple-xlight);
	border: 1px solid var(--cc-purple-light);
	border-radius: 100px;
	font-size: 0.78rem;
	font-weight: 600;
	color: var(--cc-purple);
	text-decoration: none;
	margin: 2px;
}

@media (max-width: 900px) {
	.cc-post-sidebar-col { display: none; }
}

/* ═══════════════════════════════════════════════════════
   SUPPORT PAGE — tab system
   ═══════════════════════════════════════════════════════ */

.cc-support-tabs {
	max-width: 860px;
	margin: 0 auto;
}

.cc-support-tab-nav {
	display: flex;
	align-items: stretch;
	background: var(--cc-bg);
	border: 1px solid var(--cc-border);
	border-radius: var(--cc-radius-lg);
	padding: 4px;
	gap: 4px;
	margin-bottom: 32px;
}

.cc-support-tab-btn {
	flex: 1;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 7px;
	padding: 11px 16px;
	border: none;
	border-radius: 10px;
	background: transparent;
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--cc-text-muted);
	cursor: pointer;
	text-decoration: none;
	transition: background 0.15s, color 0.15s, box-shadow 0.15s;
	white-space: nowrap;
}

.cc-support-tab-btn:hover {
	background: var(--cc-white);
	color: var(--cc-text);
}

.cc-support-tab-btn.active {
	background: var(--cc-white);
	color: var(--cc-purple);
	box-shadow: var(--cc-shadow);
}

.cc-support-tab-panel { display: none; }
.cc-support-tab-panel.active { display: block; }

.cc-support-panel-inner {
	background: var(--cc-white);
	border: 1px solid var(--cc-border);
	border-radius: var(--cc-radius-xl);
	padding: 48px;
}

.cc-support-panel-title {
	font-size: 1.4rem;
	font-weight: 800;
	letter-spacing: -0.02em;
	color: var(--cc-text);
	margin: 0 0 10px;
}

.cc-support-panel-desc {
	font-size: 0.9375rem;
	color: var(--cc-text-muted);
	line-height: 1.7;
	margin: 0 0 32px;
}

.cc-support-form {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.cc-support-form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}

.cc-support-form-field {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.cc-support-form-field label {
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--cc-text);
}

.cc-support-form-field input,
.cc-support-form-field select,
.cc-support-form-field textarea {
	padding: 11px 14px;
	border: 1px solid var(--cc-border);
	border-radius: var(--cc-radius-sm);
	font-size: 0.9375rem;
	color: var(--cc-text);
	background: var(--cc-white);
	font-family: inherit;
	transition: border-color 0.15s, box-shadow 0.15s;
	resize: vertical;
}

.cc-support-form-field input:focus,
.cc-support-form-field select:focus,
.cc-support-form-field textarea:focus {
	outline: none;
	border-color: var(--cc-purple);
	box-shadow: 0 0 0 3px rgba(13, 124, 102, 0.12);
}

.cc-support-submit {
	align-self: flex-start;
	padding: 13px 28px;
	background: var(--cc-purple);
	color: #fff;
	border: none;
	border-radius: var(--cc-radius-sm);
	font-size: 0.9375rem;
	font-weight: 700;
	font-family: inherit;
	cursor: pointer;
	transition: background 0.15s, transform 0.1s;
}

.cc-support-submit:hover {
	background: var(--cc-purple-dark);
	transform: translateY(-1px);
}

@media (max-width: 640px) {
	.cc-support-form-row    { grid-template-columns: 1fr; }
	.cc-support-panel-inner { padding: 28px 20px; }
	.cc-support-tab-btn     { font-size: 0.82rem; padding: 10px; gap: 4px; }
}

/* ═══════════════════════════════════════════════════════
   SINGLE ADDON PAGE
   ═══════════════════════════════════════════════════════ */

/* Post content area — proper typography */
.cc-addon-content h2,
.cc-addon-content h3 {
	letter-spacing: -0.02em;
	font-weight: 700;
	margin-top: 2rem;
	margin-bottom: 0.75rem;
}
.cc-addon-content h2 { font-size: 1.4rem; }
.cc-addon-content h3 { font-size: 1.1rem; color: var(--cc-text); }
.cc-addon-content p  { line-height: 1.75; color: #374151; margin-bottom: 1rem; }
.cc-addon-content ul,
.cc-addon-content ol {
	padding-left: 1.25rem;
	margin-bottom: 1.25rem;
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.cc-addon-content li { line-height: 1.65; color: #374151; font-size: 0.95rem; }
.cc-addon-content a  { color: var(--cc-purple); text-decoration: underline; }

/* Addon hero */
.cc-addon-hero .cc-doc-breadcrumb a { color: rgba(255,255,255,0.45); text-decoration: none; }
.cc-addon-hero .cc-doc-breadcrumb a:hover { color: rgba(255,255,255,0.7); }

/* Sidebar sticky wrapper */
.cc-addon-sidebar-col {
	position: relative;
}
.cc-addon-info-sidebar {
	position: sticky;
	top: 80px;
}

/* Info card */
.cc-addon-info-card {
	background: #fff;
	border: 1px solid var(--cc-border);
	border-radius: var(--cc-radius);
	padding: 20px;
}

/* Definition list */
.cc-addon-info-dl {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin: 0;
}
.cc-addon-info-row {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: 12px;
	padding: 8px 0;
	border-bottom: 1px solid #F3F4F6;
}
.cc-addon-info-row:last-child { border-bottom: none; }
.cc-addon-info-row dt {
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--cc-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	flex-shrink: 0;
}
.cc-addon-info-row dd {
	font-size: 0.875rem;
	color: var(--cc-text);
	font-weight: 500;
	text-align: right;
	margin: 0;
}

/* Integration steps */
.cc-addon-steps {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 16px;
	counter-reset: steps;
}
.cc-addon-step {
	display: flex;
	gap: 12px;
	align-items: flex-start;
}
.cc-addon-step-num {
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: var(--cc-purple-light);
	color: var(--cc-purple);
	font-size: 0.75rem;
	font-weight: 800;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	margin-top: 1px;
}

@media (max-width: 768px) {
	.cc-addon-sidebar-col { order: -1; }
	.cc-addon-info-sidebar { position: static; margin-bottom: 32px; }
}

/* ═══════════════════════════════════════════════════════
   ROADMAP PAGE
   ═══════════════════════════════════════════════════════ */

/* Status legend badges */
.cc-rm-badge {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 4px 10px;
	border-radius: 100px;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.03em;
}
.cc-rm-badge--released   { background: #e6f5f1; color: #096B58; }
.cc-rm-badge--progress   { background: #FFF8E1; color: #C68B1A; }
.cc-rm-badge--planned    { background: #f0faf7; color: #0D7C66; border: 1px solid #b8e0d8; }
.cc-rm-badge--considering{ background: #f3f4f6; color: #6B7280; border: 1px solid #d1d5db; }

/* Section header */
.cc-rm-section-header {
	display: flex;
	gap: 20px;
	align-items: flex-start;
	margin-bottom: 40px;
}
.cc-rm-section-line {
	width: 4px;
	min-height: 80px;
	border-radius: 4px;
	flex-shrink: 0;
}
.cc-rm-section-line--released   { background: #0D7C66; }
.cc-rm-section-line--progress   { background: #E5A530; }
.cc-rm-section-line--planned    { background: #b8e0d8; }
.cc-rm-section-line--considering{ background: #d1d5db; }

/* Feature card grid */
.cc-rm-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
}
@media (max-width: 900px) { .cc-rm-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 600px) { .cc-rm-grid { grid-template-columns: 1fr; } }

/* Feature card */
.cc-rm-card {
	display: flex;
	gap: 14px;
	padding: 20px;
	border-radius: var(--cc-radius);
	border: 1px solid var(--cc-border);
	background: #fff;
	transition: box-shadow 0.15s, transform 0.15s;
}
.cc-rm-card:hover {
	box-shadow: var(--cc-shadow-md);
	transform: translateY(-2px);
}
.cc-rm-card--released   { border-left: 3px solid #0D7C66; }
.cc-rm-card--progress   { border-left: 3px solid #E5A530; }
.cc-rm-card--planned    { border-left: 3px solid #b8e0d8; }
.cc-rm-card--considering{ border-left: 3px solid #d1d5db; opacity: 0.85; }

.cc-rm-card-icon {
	width: 36px;
	height: 36px;
	border-radius: 9px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.1rem;
	flex-shrink: 0;
}
.cc-rm-card-title {
	font-size: 0.9375rem;
	font-weight: 700;
	color: var(--cc-text);
	margin: 0;
}
.cc-rm-card-desc {
	font-size: 0.825rem;
	color: var(--cc-text-muted);
	line-height: 1.6;
	margin: 0;
}
.cc-rm-card-desc code {
	font-size: 0.775rem;
	background: #f3f4f6;
	padding: 1px 5px;
	border-radius: 4px;
	font-family: ui-monospace, monospace;
}

/* Tier pill */
.cc-rm-tier {
	display: inline-block;
	font-size: 0.7rem;
	font-weight: 700;
	padding: 2px 7px;
	border-radius: 100px;
	letter-spacing: 0.03em;
	flex-shrink: 0;
}
.cc-rm-tier--free { background: #e6f5f1; color: #096B58; }
.cc-rm-tier--pro  { background: #FFF8E1; color: #C68B1A; }

/* ═══════════════════════════════════════════════════════
   CHANGELOG PAGE
   ═══════════════════════════════════════════════════════ */

/* Two-column layout */
.cc-cl-layout {
	display: grid;
	grid-template-columns: 1fr 300px;
	gap: 48px;
	align-items: start;
}
@media (max-width: 900px) {
	.cc-cl-layout { grid-template-columns: 1fr; }
	.cc-cl-sidebar { order: -1; }
}

/* Timeline entries */
.cc-cl-main {
	position: relative;
}
.cc-cl-main::before {
	content: '';
	position: absolute;
	left: 9px;
	top: 20px;
	bottom: 0;
	width: 2px;
	background: linear-gradient(to bottom, var(--cc-purple), var(--cc-border));
}

.cc-cl-entry {
	display: flex;
	gap: 24px;
	padding-bottom: 48px;
	position: relative;
}
.cc-cl-entry:last-child { padding-bottom: 0; }
.cc-cl-entry--beta .cc-cl-entry-dot { background: #d1d5db; }
.cc-cl-entry--beta .cc-cl-entry-body { opacity: 0.8; }

.cc-cl-entry-dot {
	width: 20px;
	height: 20px;
	border-radius: 50%;
	background: var(--cc-purple);
	border: 3px solid #fff;
	box-shadow: 0 0 0 2px var(--cc-purple);
	flex-shrink: 0;
	margin-top: 4px;
}

.cc-cl-entry-body {
	flex: 1;
}

.cc-cl-entry-header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 16px;
	margin-bottom: 20px;
	padding-bottom: 16px;
	border-bottom: 1px solid var(--cc-border);
}

.cc-cl-version {
	font-size: 1.3rem;
	font-weight: 800;
	letter-spacing: -0.02em;
	color: var(--cc-text);
	margin: 0 0 4px;
	display: flex;
	align-items: center;
	gap: 8px;
}
.cc-cl-date {
	font-size: 0.8rem;
	color: var(--cc-text-muted);
	margin: 0;
}

.cc-cl-edition {
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 700;
	padding: 2px 8px;
	border-radius: 100px;
}
.cc-cl-edition--free { background: #e6f5f1; color: #096B58; }
.cc-cl-edition--pro  { background: #FFF8E1; color: #C68B1A; }
.cc-cl-edition--beta { background: #f3f4f6; color: #6B7280; }

.cc-cl-download {
	font-size: 0.8rem;
	font-weight: 600;
	color: var(--cc-purple);
	text-decoration: none;
	white-space: nowrap;
	padding: 6px 14px;
	border: 1px solid var(--cc-purple-light);
	border-radius: 100px;
	transition: background 0.15s;
}
.cc-cl-download:hover { background: var(--cc-purple-xlight); }

/* Change list */
.cc-cl-items {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.cc-cl-items li {
	font-size: 0.9rem;
	color: #374151;
	line-height: 1.6;
	display: flex;
	gap: 8px;
	align-items: flex-start;
}
.cc-cl-items code {
	font-size: 0.8rem;
	background: #f3f4f6;
	padding: 1px 5px;
	border-radius: 4px;
	font-family: ui-monospace, monospace;
}

/* Change type tags */
.cc-cl-tag {
	display: inline-block;
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	padding: 2px 7px;
	border-radius: 4px;
	flex-shrink: 0;
	margin-top: 2px;
}
.cc-cl-tag--new      { background: #e6f5f1; color: #096B58; }
.cc-cl-tag--improved { background: #eff6ff; color: #1d4ed8; }
.cc-cl-tag--fixed    { background: #fef3c7; color: #92400e; }
.cc-cl-tag--breaking { background: #fee2e2; color: #991b1b; }

/* Sidebar */
.cc-cl-sidebar-inner {
	position: sticky;
	top: 80px;
}

.cc-cl-nav-card {
	background: #fff;
	border: 1px solid var(--cc-border);
	border-radius: var(--cc-radius);
	padding: 20px;
}
.cc-cl-nav-title {
	font-size: 0.8rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--cc-text-muted);
	margin: 0 0 14px;
}
.cc-cl-nav {
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.cc-cl-nav-link {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 8px 10px;
	border-radius: 8px;
	text-decoration: none;
	transition: background 0.1s;
}
.cc-cl-nav-link:hover { background: var(--cc-purple-xlight); }
.cc-cl-nav-ver {
	font-size: 0.875rem;
	font-weight: 700;
	color: var(--cc-text);
}
.cc-cl-nav-date {
	font-size: 0.75rem;
	color: var(--cc-text-muted);
	margin-left: auto;
}
.cc-cl-sidebar-cta {
	border-radius: var(--cc-radius);
	padding: 24px 20px;
	margin-top: 16px;
}

/* ═══════════════════════════════════════════════════════
   STATIC ADDON DETAIL PAGE  (.cc-sa-*)
   Paste the generated HTML into a Custom HTML block on each addon post.
   ═══════════════════════════════════════════════════════ */

.cc-sa-wrap { font-family: 'Manrope','Inter',system-ui,sans-serif; -webkit-font-smoothing: antialiased; }

/* ── Hero ─────────────────────────── */
.cc-sa-hero { background: #0A1A14; padding: 52px 24px 48px; }
.cc-sa-hero-inner { max-width: 900px; margin: 0 auto; }

.cc-sa-breadcrumb { font-size: 0.8rem; color: rgba(255,255,255,.4); margin: 0 0 20px; }
.cc-sa-breadcrumb a { color: rgba(255,255,255,.4); text-decoration: none; }
.cc-sa-breadcrumb a:hover { color: rgba(255,255,255,.7); text-decoration: underline; }

.cc-sa-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 18px; align-items: center; }
.cc-sa-chip {
	display: inline-flex; align-items: center; gap: 5px;
	padding: 4px 10px; border-radius: 20px;
	font-size: 0.7rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; line-height: 1.4;
}
.cc-sa-chip-type { background: rgba(13,124,102,.25); color: #6EE7B7; }
.cc-sa-chip-free { background: rgba(16,185,129,.2); color: #6EE7B7; border: 1px solid rgba(16,185,129,.3); }
.cc-sa-chip-pro  { background: rgba(229,165,48,.2);  color: #FCD34D; border: 1px solid rgba(229,165,48,.3); }
.cc-sa-chip-meta { background: rgba(255,255,255,.08); color: rgba(255,255,255,.55); }
.cc-sa-chip-new  { background: rgba(220,38,38,.2);   color: #FCA5A5; border: 1px solid rgba(220,38,38,.3); }

.cc-sa-title {
	font-size: clamp(1.75rem,3.5vw,2.75rem); font-weight: 800;
	letter-spacing: -0.03em; line-height: 1.1; color: #fff; margin: 0 0 16px;
}
.cc-sa-desc { font-size: 1.05rem; line-height: 1.75; color: rgba(255,255,255,.65); margin: 0; max-width: 680px; }

/* ── Body layout ─────────────────────── */
.cc-sa-body { max-width: 1100px; margin: 0 auto; padding: 52px 24px 72px; display: flex; gap: 48px; align-items: flex-start; }
.cc-sa-main { flex: 0 0 calc(65% - 24px); min-width: 0; }
.cc-sa-side { flex: 1; min-width: 0; }

.cc-sa-section { margin-bottom: 44px; }
.cc-sa-section:last-child { margin-bottom: 0; }
.cc-sa-section-title {
	font-size: 1.15rem; font-weight: 700; letter-spacing: -0.02em; color: var(--cc-text);
	margin: 0 0 20px; padding-bottom: 12px; border-bottom: 2px solid var(--cc-border);
}

/* ── Features grid ───────────────────── */
.cc-sa-features { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.cc-sa-feature {
	background: var(--cc-bg); border: 1px solid var(--cc-border);
	border-radius: var(--cc-radius); padding: 16px 18px;
	transition: border-color .15s, box-shadow .15s;
}
.cc-sa-feature:hover { border-color: var(--cc-purple-light); box-shadow: var(--cc-shadow-md); }
.cc-sa-feature-icon { font-size: 1.3rem; margin-bottom: 8px; display: block; }
.cc-sa-feature-title { font-size: .875rem; font-weight: 700; color: var(--cc-text); margin: 0 0 4px; }
.cc-sa-feature-desc  { font-size: .82rem; color: var(--cc-text-muted); line-height: 1.6; margin: 0; }

/* ── Sidebar ──────────────────────────── */
.cc-sa-info-sticky { position: sticky; top: 80px; display: flex; flex-direction: column; gap: 14px; }
.cc-sa-info-card { background: #fff; border: 1px solid var(--cc-border); border-radius: var(--cc-radius); overflow: hidden; }
.cc-sa-info-head {
	background: var(--cc-gradient-soft); padding: 14px 20px;
	border-bottom: 1px solid var(--cc-border);
	display: flex; align-items: center; justify-content: space-between;
}
.cc-sa-info-head-label { font-size: .75rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--cc-text-muted); margin: 0; }
.cc-sa-info-rows { padding: 0 20px; }
.cc-sa-info-row {
	display: flex; justify-content: space-between; align-items: center;
	padding: 10px 0; border-bottom: 1px solid #F3F4F6; font-size: .875rem; gap: 12px;
}
.cc-sa-info-row:last-child { border-bottom: none; }
.cc-sa-info-row dt { font-size: .8rem; font-weight: 600; color: var(--cc-text-muted); text-transform: uppercase; letter-spacing: .04em; flex-shrink: 0; }
.cc-sa-info-row dd { font-size: .875rem; color: var(--cc-text); font-weight: 500; text-align: right; margin: 0; }

/* ── CTA box ─────────────────────────── */
.cc-sa-cta { background: var(--cc-gradient); border-radius: var(--cc-radius); padding: 22px 20px; text-align: center; }
.cc-sa-cta.cc-sa-cta-free { background: linear-gradient(135deg,#065F46,#0D7C66); }
.cc-sa-cta-title { font-size: 1rem; font-weight: 700; color: #fff; margin: 0 0 6px; }
.cc-sa-cta-sub   { font-size: .82rem; color: rgba(255,255,255,.75); margin: 0 0 16px; }
.cc-sa-cta-btn {
	display: inline-block; background: #fff; color: var(--cc-purple-dark);
	padding: 10px 22px; border-radius: 8px; font-size: .875rem; font-weight: 700;
	text-decoration: none; transition: opacity .15s;
}
.cc-sa-cta-btn:hover { opacity: .9; color: var(--cc-purple-dark); }

/* ── Support links ────────────────────── */
.cc-sa-support { display: flex; flex-direction: column; gap: 6px; }
.cc-sa-support-link {
	display: flex; align-items: center; gap: 8px; padding: 10px 14px;
	background: #fff; border: 1px solid var(--cc-border); border-radius: var(--cc-radius-sm);
	font-size: .82rem; font-weight: 600; color: var(--cc-text); text-decoration: none;
	transition: border-color .15s, color .15s;
}
.cc-sa-support-link:hover { border-color: var(--cc-purple); color: var(--cc-purple); }

/* ── Coming-soon notice ──────────────── */
.cc-sa-notice {
	display: flex; align-items: flex-start; gap: 12px;
	background: #FFF8E1; border: 1px solid #FEE08B; border-left: 4px solid var(--cc-amber);
	border-radius: var(--cc-radius-sm); padding: 14px 18px; margin-bottom: 32px;
	font-size: .875rem; color: #78350F; line-height: 1.6;
}
.cc-sa-notice strong { font-weight: 700; }

/* ── Responsive ──────────────────────── */
@media (max-width: 900px) {
	.cc-sa-body { flex-direction: column; padding: 32px 20px 48px; }
	.cc-sa-main, .cc-sa-side { flex: none; width: 100%; }
	.cc-sa-side { order: -1; }
	.cc-sa-info-sticky { position: static; }
	.cc-sa-features { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
	.cc-sa-hero { padding: 36px 20px 32px; }
}

@media (max-width: 768px) {
    .row-hide-mobile {
        display: none !important;
    }
}
/* ═══════════════════════════════════════════════════════
   SECTION SPACING — prevent double margins between alignfull groups
   ═══════════════════════════════════════════════════════ */
.wp-block-group.alignfull + .wp-block-group.alignfull {
	margin-top: 0;
}

/* ═══════════════════════════════════════════════════════
   SEARCH RESULTS
   ═══════════════════════════════════════════════════════ */
.cc-search-result-card {
	transition: box-shadow 0.2s ease, border-color 0.2s ease;
}
.cc-search-result-card:hover {
	border-color: #0D7C66 !important;
	box-shadow: 0 2px 8px rgba(13, 124, 102, 0.10);
}