/* ==========================================================================
   TikTok service page (templates/page-tiktok.html)
   ========================================================================== */

.cs-tt-hero {
	background: var(--wp--preset--color--cream, #f7efe1);
	padding: clamp(56px, 7vw, 96px) clamp(20px, 4vw, 64px);
}
.cs-tt-hero__inner {
	max-width: 1440px; margin: 0 auto;
	display: grid; grid-template-columns: 1.1fr 1fr;
	gap: clamp(32px, 5vw, 64px); align-items: center;
}
.cs-tt-hero__left { min-width: 0; }
.cs-tt-hero__heading {
	font-family: var(--wp--preset--font-family--sans, "Inter", sans-serif);
	font-weight: 700; font-size: clamp(44px, 6.5vw, 96px);
	line-height: 0.94; letter-spacing: -0.034em;
	color: var(--wp--preset--color--navy, #15264d);
	margin: 22px 0 20px; text-wrap: balance;
}
.cs-tt-hero__orange { color: var(--wp--preset--color--orange, #f79018); }
.cs-tt-hero__lede {
	font-size: clamp(16px, 1.3vw, 19px); line-height: 1.55;
	color: #2a2f3a; max-width: 600px; margin: 0 0 28px;
}
.cs-tt-hero__ctas { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 24px; }
.cs-tt-hero__trust {
	display: flex; flex-wrap: wrap; gap: 14px 22px;
	font-family: var(--wp--preset--font-family--mono, "JetBrains Mono", monospace);
	font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: #6b7280;
}
.cs-tt-hero__card {
	background: #fff; border-radius: 24px; padding: 28px 28px 24px;
	box-shadow: 0 1px 2px rgba(0,0,0,.04), 0 18px 50px rgba(20, 30, 60, 0.10);
	position: relative; overflow: hidden;
}
.cs-tt-hero__card::after {
	content: ""; position: absolute; right: -80px; top: -80px;
	width: 220px; height: 220px; border-radius: 999px;
	background: radial-gradient(closest-side, rgba(247,144,24,0.14), transparent);
	pointer-events: none;
}
.cs-tt-hero__card-head {
	display: flex; justify-content: space-between; align-items: center;
	font-family: var(--wp--preset--font-family--mono, "JetBrains Mono", monospace);
	font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
	color: #6b7280; margin-bottom: 18px;
}
.cs-tt-hero__card-pulse { color: var(--wp--preset--color--orange, #f79018); font-weight: 600; }
.cs-tt-hero__card-rows {
	display: flex; flex-direction: column; gap: 14px;
	border-top: 1px solid rgba(20, 30, 60, 0.08); padding-top: 18px;
}
.cs-tt-hero__card-row {
	display: flex; justify-content: space-between; align-items: baseline; gap: 16px;
	font-size: 14px; color: #2a2f3a;
}
.cs-tt-hero__card-row strong {
	font-feature-settings: "tnum" 1; font-weight: 700;
	color: var(--wp--preset--color--navy, #15264d); font-size: 17px;
}
.cs-tt-hero__card-foot {
	margin-top: 18px; padding-top: 16px;
	border-top: 1px solid rgba(20, 30, 60, 0.08);
	font-size: 13px; color: #6b7280; font-style: italic;
}

.cs-tt-problem { background: #fff; padding: clamp(64px, 7vw, 112px) clamp(20px, 4vw, 64px); }
.cs-tt-problem__inner { max-width: 1440px; margin: 0 auto; }
.cs-tt-problem__head { max-width: 860px; margin-bottom: 48px; }
.cs-tt-problem__h2 {
	font-weight: 700; font-size: clamp(36px, 4.4vw, 64px);
	color: var(--wp--preset--color--navy, #15264d);
	margin: 18px 0 16px; letter-spacing: -0.025em; line-height: 1.04; text-wrap: balance;
}
.cs-tt-problem__lede { font-size: 17px; color: #6b7280; line-height: 1.6; max-width: 720px; }
.cs-tt-problem__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.cs-tt-problem__card {
	background: var(--wp--preset--color--cream, #f7efe1);
	border-radius: 20px; padding: 32px;
	box-shadow: 0 1px 2px rgba(0,0,0,.04), 0 12px 36px rgba(20,30,60,.04);
}
.cs-tt-problem__num {
	font-family: var(--wp--preset--font-family--mono, "JetBrains Mono", monospace);
	font-size: 11px; letter-spacing: 0.16em;
	color: var(--wp--preset--color--orange-ink, #c5630a); margin-bottom: 14px;
}
.cs-tt-problem__title {
	font-size: 22px; font-weight: 700; line-height: 1.2;
	color: var(--wp--preset--color--navy, #15264d);
	margin-bottom: 12px; letter-spacing: -0.4px;
}
.cs-tt-problem__desc { font-size: 15px; color: #2a2f3a; line-height: 1.6; }

.cs-tt-services {
	background: var(--wp--preset--color--cream, #f7efe1);
	padding: clamp(64px, 7vw, 112px) clamp(20px, 4vw, 64px);
}
.cs-tt-services__inner { max-width: 1440px; margin: 0 auto; }
.cs-tt-services__head { max-width: 900px; margin-bottom: 56px; }
.cs-tt-services__h2 {
	font-weight: 700; font-size: clamp(36px, 4.4vw, 64px);
	color: var(--wp--preset--color--navy, #15264d);
	margin: 18px 0 16px; letter-spacing: -0.025em; line-height: 1.04; text-wrap: balance;
}
.cs-tt-services__lede { font-size: 17px; color: #6b7280; line-height: 1.6; max-width: 760px; }
.cs-tt-services__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.cs-tt-services__card {
	background: #fff; border-radius: 24px; padding: 32px;
	box-shadow: 0 1px 2px rgba(0,0,0,.04), 0 14px 40px rgba(20,30,60,.06);
	display: flex; flex-direction: column; position: relative;
}
.cs-tt-services__card--accent {
	background: linear-gradient(180deg, #fff 0%, var(--wp--preset--color--orange-soft, #fde2c1) 100%);
	border: 1px solid rgba(247, 144, 24, 0.25);
}
.cs-tt-services__num {
	font-family: var(--wp--preset--font-family--mono, "JetBrains Mono", monospace);
	font-size: 11px; letter-spacing: 0.16em;
	color: var(--wp--preset--color--orange-ink, #c5630a); margin-bottom: 14px;
}
.cs-tt-services__title {
	font-size: 22px; font-weight: 700; line-height: 1.2;
	color: var(--wp--preset--color--navy, #15264d);
	margin-bottom: 12px; letter-spacing: -0.4px;
}
.cs-tt-services__desc { font-size: 15px; color: #2a2f3a; line-height: 1.6; margin-bottom: 18px; }
.cs-tt-services__list {
	margin: 0; padding: 0; list-style: none;
	font-size: 14px; color: #2a2f3a; line-height: 1.5;
	border-top: 1px solid rgba(20, 30, 60, 0.08); padding-top: 16px;
}
.cs-tt-services__list li { position: relative; padding-left: 18px; margin-bottom: 8px; }
.cs-tt-services__list li:last-child { margin-bottom: 0; }
.cs-tt-services__list li::before {
	content: "→"; position: absolute; left: 0; top: 0;
	color: var(--wp--preset--color--orange, #f79018); font-weight: 600;
}
.cs-tt-services__badge {
	position: absolute; top: 18px; right: 18px;
	font-family: var(--wp--preset--font-family--mono, "JetBrains Mono", monospace);
	font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase;
	color: var(--wp--preset--color--orange-ink, #c5630a);
	background: #fff; padding: 5px 10px; border-radius: 999px;
	box-shadow: 0 2px 8px rgba(247, 144, 24, 0.18);
}

.cs-tt-flywheel {
	background: var(--wp--preset--color--navy-deep, #0c1a3c); color: #fff;
	padding: clamp(64px, 7vw, 112px) clamp(20px, 4vw, 64px);
	position: relative; overflow: hidden;
}
.cs-tt-flywheel::before {
	content: ""; position: absolute; top: -200px; right: -200px;
	width: 600px; height: 600px; border-radius: 999px;
	background: radial-gradient(closest-side, rgba(247, 144, 24, 0.12), transparent);
	pointer-events: none;
}
.cs-tt-flywheel__inner { max-width: 1440px; margin: 0 auto; position: relative; }
.cs-tt-flywheel__head { max-width: 860px; margin-bottom: 56px; }
.cs-tt-flywheel__h2 {
	font-weight: 700; font-size: clamp(36px, 4.4vw, 64px);
	color: #fff; margin: 18px 0 16px;
	letter-spacing: -0.025em; line-height: 1.04;
}
.cs-tt-flywheel__lede {
	font-size: 17px; color: rgba(255, 255, 255, 0.75);
	line-height: 1.6; max-width: 760px;
}
.cs-tt-flywheel__steps {
	display: grid;
	grid-template-columns: 1fr auto 1fr auto 1fr auto 1fr;
	gap: 16px; align-items: stretch;
}
.cs-tt-flywheel__step {
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 18px; padding: 24px;
	display: flex; flex-direction: column; gap: 10px;
}
.cs-tt-flywheel__step-num {
	font-family: var(--wp--preset--font-family--mono, "JetBrains Mono", monospace);
	font-size: 12px; letter-spacing: 0.16em;
	color: var(--wp--preset--color--orange, #f79018); font-weight: 700;
}
.cs-tt-flywheel__step-title {
	font-size: 18px; font-weight: 700; color: #fff;
	line-height: 1.2; letter-spacing: -0.3px;
}
.cs-tt-flywheel__step-desc {
	font-size: 14px; color: rgba(255, 255, 255, 0.72); line-height: 1.55;
}
.cs-tt-flywheel__arrow {
	display: flex; align-items: center; justify-content: center;
	font-size: 24px; color: var(--wp--preset--color--orange, #f79018); font-weight: 700;
}

.cs-tt-stats {
	background: var(--wp--preset--color--cream, #f7efe1);
	padding: clamp(48px, 6vw, 80px) clamp(20px, 4vw, 64px);
}
.cs-tt-stats__inner {
	max-width: 1440px; margin: 0 auto;
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
}
.cs-tt-stat {
	background: #fff; border-radius: 20px; padding: 32px 28px;
	box-shadow: 0 1px 2px rgba(0,0,0,.04), 0 12px 36px rgba(20,30,60,.04);
}
.cs-tt-stat__value {
	font-family: var(--wp--preset--font-family--sans, "Inter", sans-serif);
	font-feature-settings: "tnum" 1; font-weight: 700;
	font-size: clamp(36px, 4vw, 56px); line-height: 1;
	color: var(--wp--preset--color--navy, #15264d);
	margin-bottom: 10px; letter-spacing: -0.02em;
}
.cs-tt-stat__label { font-size: 13px; color: #6b7280; line-height: 1.4; }

.cs-tt-plan { background: #fff; padding: clamp(64px, 7vw, 112px) clamp(20px, 4vw, 64px); }
.cs-tt-plan__inner { max-width: 1440px; margin: 0 auto; }
.cs-tt-plan__head { max-width: 860px; margin-bottom: 56px; }
.cs-tt-plan__h2 {
	font-weight: 700; font-size: clamp(36px, 4.4vw, 64px);
	color: var(--wp--preset--color--navy, #15264d);
	margin: 18px 0 16px; letter-spacing: -0.025em; line-height: 1.04;
}
.cs-tt-plan__lede { font-size: 17px; color: #6b7280; line-height: 1.6; max-width: 760px; }
.cs-tt-plan__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.cs-tt-plan__phase {
	background: var(--wp--preset--color--cream, #f7efe1);
	border-radius: 20px; padding: 32px;
	border-top: 4px solid var(--wp--preset--color--orange, #f79018);
}
.cs-tt-plan__phase-when {
	font-family: var(--wp--preset--font-family--mono, "JetBrains Mono", monospace);
	font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
	color: var(--wp--preset--color--orange-ink, #c5630a); margin-bottom: 8px;
}
.cs-tt-plan__phase-title {
	font-size: 22px; font-weight: 700; color: var(--wp--preset--color--navy, #15264d);
	margin-bottom: 18px; line-height: 1.2; letter-spacing: -0.4px;
}
.cs-tt-plan__phase-list {
	margin: 0; padding: 0; list-style: none;
	font-size: 14px; color: #2a2f3a; line-height: 1.55;
}
.cs-tt-plan__phase-list li { position: relative; padding-left: 22px; margin-bottom: 10px; }
.cs-tt-plan__phase-list li::before {
	content: "✓"; position: absolute; left: 0; top: 0;
	color: var(--wp--preset--color--orange, #f79018); font-weight: 700;
}

.cs-tt-fit {
	background: var(--wp--preset--color--cream, #f7efe1);
	padding: clamp(64px, 7vw, 112px) clamp(20px, 4vw, 64px);
}
.cs-tt-fit__inner { max-width: 1280px; margin: 0 auto; }
.cs-tt-fit__head { max-width: 860px; margin-bottom: 48px; }
.cs-tt-fit__h2 {
	font-weight: 700; font-size: clamp(36px, 4.4vw, 64px);
	color: var(--wp--preset--color--navy, #15264d);
	margin: 18px 0 0; letter-spacing: -0.025em; line-height: 1.04;
}
.cs-tt-fit__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.cs-tt-fit__col {
	background: #fff; border-radius: 24px; padding: 36px;
	box-shadow: 0 1px 2px rgba(0,0,0,.04), 0 12px 36px rgba(20,30,60,.05);
}
.cs-tt-fit__col--yes { border-top: 4px solid var(--wp--preset--color--orange, #f79018); }
.cs-tt-fit__col--no  { border-top: 4px solid #aab2c0; }
.cs-tt-fit__col-head {
	font-family: var(--wp--preset--font-family--mono, "JetBrains Mono", monospace);
	font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
	margin-bottom: 18px;
}
.cs-tt-fit__col--yes .cs-tt-fit__col-head { color: var(--wp--preset--color--orange-ink, #c5630a); }
.cs-tt-fit__col--no  .cs-tt-fit__col-head { color: #6b7280; }
.cs-tt-fit__list {
	margin: 0; padding: 0; list-style: none;
	font-size: 15px; color: #2a2f3a; line-height: 1.55;
}
.cs-tt-fit__list li { padding: 14px 0; border-top: 1px solid rgba(20,30,60,0.06); }
.cs-tt-fit__list li:first-child { border-top: none; padding-top: 0; }

.cs-tt-faq { background: #fff; padding: clamp(64px, 7vw, 112px) clamp(20px, 4vw, 64px); }
.cs-tt-faq__inner { max-width: 1080px; margin: 0 auto; }
.cs-tt-faq__head { max-width: 720px; margin-bottom: 40px; }
.cs-tt-faq__h2 {
	font-weight: 700; font-size: clamp(32px, 3.8vw, 56px);
	color: var(--wp--preset--color--navy, #15264d);
	margin: 18px 0 0; letter-spacing: -0.025em; line-height: 1.06;
}
.cs-tt-faq__list { display: flex; flex-direction: column; }
.cs-tt-faq__item { border-top: 1px solid rgba(20, 30, 60, 0.10); padding: 22px 0; }
.cs-tt-faq__item[open] .cs-tt-faq__q::after { transform: rotate(45deg); }
.cs-tt-faq__q {
	cursor: pointer; list-style: none;
	font-size: 19px; font-weight: 600; line-height: 1.3;
	color: var(--wp--preset--color--navy, #15264d);
	letter-spacing: -0.3px;
	display: flex; justify-content: space-between; align-items: center; gap: 24px;
}
.cs-tt-faq__q::-webkit-details-marker { display: none; }
.cs-tt-faq__q::after {
	content: "+"; flex-shrink: 0;
	font-size: 24px; font-weight: 400;
	color: var(--wp--preset--color--orange, #f79018);
	transition: transform 200ms ease;
	width: 28px; height: 28px;
	display: flex; align-items: center; justify-content: center;
}
.cs-tt-faq__a { font-size: 16px; color: #2a2f3a; line-height: 1.65; margin-top: 14px; max-width: 800px; }

.cs-nav__hot {
	position: relative;
	color: var(--wp--preset--color--orange, #f79018) !important;
}
.cs-nav__hot::after {
	content: "NEW"; position: absolute;
	top: -10px; right: -22px;
	font-family: var(--wp--preset--font-family--mono, "JetBrains Mono", monospace);
	font-size: 8px; font-weight: 700; letter-spacing: 0.1em;
	background: var(--wp--preset--color--orange, #f79018);
	color: var(--wp--preset--color--navy, #15264d);
	padding: 2px 5px; border-radius: 3px;
}

@media (max-width: 900px) {
	.cs-tt-hero__inner { grid-template-columns: 1fr; }
	.cs-tt-hero__card { max-width: 480px; }
	.cs-tt-problem__grid,
	.cs-tt-services__grid,
	.cs-tt-plan__grid { grid-template-columns: 1fr; }
	.cs-tt-stats__inner { grid-template-columns: 1fr 1fr; }
	.cs-tt-fit__grid { grid-template-columns: 1fr; }
	.cs-tt-flywheel__steps { grid-template-columns: 1fr; }
	.cs-tt-flywheel__arrow { transform: rotate(90deg); padding: 4px 0; }
}
@media (max-width: 480px) {
	.cs-tt-stats__inner { grid-template-columns: 1fr; }
}


/* === fix-25 (cs-tiktok.css overrides) === Append-only fixes that need to win
 * over the base rules in this same file. The cs-tt-hero base CSS sets the
 * lede / card-row text to #2a2f3a (dark gray) and uses cs-hero-bg__veil
 * with a fade-to-cream gradient that hides the lede. These overrides
 * fix both. */
.cs-tt-hero__lede {
    color: var(--wp--preset--color--cloud, #dfe4ee) !important;
    max-width: none !important;
    opacity: 1 !important;
    font-size: clamp(15px, 1.05vw, 17px) !important;
    line-height: 1.45 !important;
    margin: 0 0 14px !important;
}
.cs-tt-hero__card-row {
    color: rgba(255, 255, 255, 0.84) !important;
}
.cs-tt-hero__card-row strong {
    color: #ffffff !important;
}
.cs-tt-hero__card-head {
    color: rgba(255, 255, 255, 0.6) !important;
}
.cs-tt-hero__card {
    background: rgba(12, 20, 36, 0.85) !important;
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    align-self: start !important;
    height: auto !important;
    padding: 18px 22px !important;
}
.cs-tt-hero__card-rows {
    border-top-color: rgba(255, 255, 255, 0.08) !important;
}
.cs-tt-hero__inner {
    align-items: start !important;
}
.cs-tt-hero {
    min-height: auto !important;
    padding-block: clamp(40px, 5vw, 64px) !important;
}
.cs-tt-hero__trust {
    color: rgba(255, 255, 255, 0.85) !important;
}
.cs-tt-hero__trust strong { color: #ffffff !important; }

/* Nullify the cream fade-to-bottom veil on marketplace LP heroes — it was
 * eating the lede text. */
.cs-tt-hero .cs-hero-bg__veil {
    background: transparent !important;
    background-image: none !important;
}
