/* =========================================================
   TubeSignal — Main Stylesheet
   Design system: warm red + white, editorial YouTube-tool SaaS
   ========================================================= */

:root{
	/* Brand */
	--ts-red: #E11D2E;
	--ts-red-dark: #B3121F;
	--ts-red-light: #FF5A4E;
	--ts-warm-bg: #FFF3F0;
	--ts-warm-bg-2: #FFEAE4;
	--ts-circle: #FFB199;
	--ts-circle-2: #FFD9CF;

	/* Neutrals */
	--ts-ink: #1A1210;
	--ts-body: #5B534F;
	--ts-line: #EFE6E2;
	--ts-white: #FFFFFF;
	--ts-surface: #FFFFFF;
	--ts-dark-bg: #1A0E0C;
	--ts-dark-surface: #241412;

	/* Type */
	--font-display: 'Sora', 'Inter', sans-serif;
	--font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;

	/* Radii / shadow */
	--radius-sm: 10px;
	--radius-md: 16px;
	--radius-lg: 24px;
	--radius-pill: 999px;
	--shadow-sm: 0 2px 8px rgba(26,18,16,.06);
	--shadow-md: 0 12px 32px rgba(26,18,16,.08);
	--shadow-lg: 0 24px 60px rgba(225,29,46,.14);

	--container: 1220px;
	--transition: .25s cubic-bezier(.4,0,.2,1);
}

/* =========================================================
   Reset
   ========================================================= */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
	margin:0;
	font-family:var(--font-body);
	color:var(--ts-body);
	background:var(--ts-white);
	font-size:16px;
	line-height:1.65;
	-webkit-font-smoothing:antialiased;
	overflow-x:hidden;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4{ font-family:var(--font-display); color:var(--ts-ink); line-height:1.15; margin:0 0 .5em; font-weight:700; letter-spacing:-.01em; }
h1{ font-size:clamp(2.4rem,5vw,3.6rem); font-weight:800; }
h2{ font-size:clamp(1.8rem,3.4vw,2.5rem); }
h3{ font-size:1.25rem; }
p{ margin:0 0 1em; }
.container{ max-width:var(--container); margin:0 auto; padding:0 24px; }

:focus-visible{ outline:3px solid var(--ts-red-light); outline-offset:2px; }
@media (prefers-reduced-motion: reduce){ *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; } }

.screen-reader-text{ position:absolute; left:-9999px; }
.skip-link{ position:fixed; top:-100px; left:12px; background:var(--ts-red); color:#fff; padding:10px 16px; border-radius:var(--radius-sm); z-index:9999; transition:top .2s; }
.skip-link:focus{ top:12px; left:12px; position:fixed; }

/* =========================================================
   Buttons
   ========================================================= */
.btn{
	display:inline-flex; align-items:center; justify-content:center; gap:8px;
	padding:13px 26px; border-radius:var(--radius-pill); font-weight:700; font-size:.95rem;
	border:2px solid transparent; transition:transform var(--transition), box-shadow var(--transition), background var(--transition), color var(--transition);
	white-space:nowrap;
}
.btn:active{ transform:scale(.97); }
.btn-primary{ background:linear-gradient(135deg,var(--ts-red),var(--ts-red-dark)); color:#fff; box-shadow:0 10px 24px rgba(225,29,46,.28); }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 16px 32px rgba(225,29,46,.36); }
.btn-ghost{ background:#fff; color:var(--ts-ink); border-color:var(--ts-line); }
.btn-ghost:hover{ border-color:var(--ts-red); color:var(--ts-red); transform:translateY(-2px); }
.btn-outline{ background:transparent; border-color:var(--ts-red); color:var(--ts-red); }
.btn-outline:hover{ background:var(--ts-red); color:#fff; }
.btn-lg{ padding:16px 32px; font-size:1.02rem; }
.btn-sm{ padding:9px 18px; font-size:.85rem; }

/* =========================================================
   Header
   ========================================================= */
.site-header{ position:sticky; top:0; z-index:500; background:rgba(255,255,255,.85); backdrop-filter:blur(10px); border-bottom:1px solid var(--ts-line); }
.site-header__inner{ display:flex; align-items:center; justify-content:space-between; gap:24px; height:76px; }
.site-branding, .site-logo-text{ display:flex; align-items:center; gap:10px; font-family:var(--font-display); font-weight:800; font-size:1.25rem; color:var(--ts-ink); }
.custom-logo{ max-height:44px; width:auto; }
.nav-menu{ display:flex; align-items:center; gap:30px; }
.nav-menu a{ font-weight:600; font-size:.95rem; color:var(--ts-ink); position:relative; padding:4px 0; }
.nav-menu a::after{ content:""; position:absolute; left:0; right:0; bottom:-2px; height:2px; background:var(--ts-red); transform:scaleX(0); transition:transform var(--transition); }
.nav-menu a:hover::after{ transform:scaleX(1); }
.site-header__actions{ display:flex; align-items:center; gap:14px; }
.theme-toggle{ width:38px; height:38px; border-radius:50%; border:1px solid var(--ts-line); background:#fff; display:flex; align-items:center; justify-content:center; color:var(--ts-ink); }
.theme-toggle .icon-moon{ display:none; }
.menu-toggle{ display:none; flex-direction:column; gap:5px; width:38px; height:38px; border:none; background:transparent; align-items:center; justify-content:center; }
.menu-toggle span{ width:22px; height:2px; background:var(--ts-ink); border-radius:2px; transition:var(--transition); }

.ts-breadcrumbs{ background:var(--ts-warm-bg); border-bottom:1px solid var(--ts-line); }
.ts-breadcrumbs ol{ display:flex; flex-wrap:wrap; gap:6px; padding:12px 0; font-size:.85rem; }
.ts-breadcrumbs li:not(:last-child)::after{ content:"/"; margin-left:8px; color:var(--ts-body); opacity:.5; }
.ts-breadcrumbs a{ color:var(--ts-red); font-weight:600; }
.ts-breadcrumbs li[aria-current]{ color:var(--ts-body); }

/* =========================================================
   Eyebrow / shared type
   ========================================================= */
.eyebrow{ display:inline-flex; align-items:center; gap:8px; font-size:.8rem; font-weight:700; letter-spacing:.04em; text-transform:uppercase; padding:7px 14px; border-radius:var(--radius-pill); background:rgba(255,255,255,.5); color:var(--ts-red-dark); margin-bottom:16px; }
.eyebrow--dark{ background:var(--ts-warm-bg-2); }
.pulse-dot{ width:8px; height:8px; border-radius:50%; background:var(--ts-red); position:relative; }
.pulse-dot::after{ content:""; position:absolute; inset:0; border-radius:50%; background:var(--ts-red); animation:pulse 1.8s infinite; }
@keyframes pulse{ 0%{ transform:scale(1); opacity:.7;} 100%{ transform:scale(2.6); opacity:0;} }

.text-gradient{ background:linear-gradient(135deg,var(--ts-red),var(--ts-red-light)); -webkit-background-clip:text; background-clip:text; color:transparent; }

.section{ position:relative; padding:96px 0; overflow:hidden; }
.section--warm{ background:var(--ts-warm-bg); }
.section--tint{ background:#FBF9F8; }
.section--dark{ background:linear-gradient(135deg,var(--ts-ink),#341613); color:#fff; }
.section--dark .stat-item__label{ color:rgba(255,255,255,.65); }
.section--cta{ background:linear-gradient(135deg,var(--ts-red-dark),var(--ts-red)); color:#fff; }

.section-head{ max-width:640px; margin:0 auto 56px; text-align:center; }
.section-head--row{ display:flex; align-items:flex-end; justify-content:space-between; text-align:left; max-width:none; margin-bottom:40px; gap:20px; flex-wrap:wrap; }
.section-head h2{ margin-bottom:12px; }
.section-head__sub{ color:var(--ts-body); font-size:1.05rem; }
.section-head--row .section-head__sub{ margin:8px 0 0; }

/* Decorative warm blobs used behind visuals on tinted sections */
.section__blob{ position:absolute; width:520px; height:520px; border-radius:50%; filter:blur(70px); opacity:.55; z-index:0; pointer-events:none; }
.section__blob--right{ background:var(--ts-circle); top:-120px; right:-160px; }
.section__blob--left{ background:var(--ts-circle-2); top:-100px; left:-160px; }

/* =========================================================
   HERO
   ========================================================= */
.hero{ position:relative; padding:76px 0 100px; overflow:hidden; background:linear-gradient(180deg,#FFF8F6 0%, #fff 70%); }
.hero__blob{ position:absolute; border-radius:50%; filter:blur(90px); z-index:0; }
.hero__blob--1{ width:600px; height:600px; background:var(--ts-circle); opacity:.45; top:-220px; right:-180px; animation:float 9s ease-in-out infinite; }
.hero__blob--2{ width:380px; height:380px; background:var(--ts-circle-2); opacity:.5; bottom:-160px; left:-140px; animation:float 11s ease-in-out infinite reverse; }
@keyframes float{ 0%,100%{ transform:translateY(0);} 50%{ transform:translateY(26px);} }

.hero__inner{ position:relative; z-index:1; display:grid; grid-template-columns:1.05fr .95fr; gap:56px; align-items:center; }
.hero__title{ margin-bottom:20px; }
.hero__subtitle{ font-size:1.12rem; max-width:520px; }
.hero__ctas{ display:flex; gap:16px; flex-wrap:wrap; margin:28px 0 30px; }
.hero__trust{ display:flex; align-items:center; gap:14px; font-size:.92rem; color:var(--ts-body); }
.hero__trust strong{ color:var(--ts-ink); }
.avatar-stack{ display:flex; }
.avatar-stack span{ width:32px; height:32px; border-radius:50%; border:2.5px solid #fff; margin-left:-10px; background:linear-gradient(135deg,var(--ts-red),var(--ts-red-light)); }
.avatar-stack span:first-child{ margin-left:0; }

.hero__visual{ position:relative; height:460px; }
.dash-card{ position:absolute; inset:20px 10px 60px 10px; background:#fff; border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); border:1px solid var(--ts-line); overflow:hidden; animation:fadeUp .8s ease both; }
.dash-card__head{ display:flex; align-items:center; gap:8px; padding:16px 20px; border-bottom:1px solid var(--ts-line); }
.dot{ width:9px; height:9px; border-radius:50%; }
.dot--red{ background:#F87171; } .dot--yellow{ background:#FBBF24; } .dot--green{ background:#34D399; }
.dash-card__title{ margin-left:8px; font-weight:700; font-size:.85rem; color:var(--ts-ink); }
.dash-card__body{ padding:26px; display:flex; align-items:flex-end; gap:26px; }
.dash-bars{ display:flex; align-items:flex-end; gap:8px; height:150px; flex:1; }
.dash-bars span{ flex:1; height:var(--h); background:linear-gradient(180deg,var(--ts-red-light),var(--ts-red)); border-radius:6px 6px 0 0; }
.dash-ring{ position:relative; width:88px; height:88px; flex-shrink:0; }
.dash-ring svg{ width:100%; height:100%; transform:rotate(-90deg); }
.ring-bg{ fill:none; stroke:var(--ts-warm-bg-2); stroke-width:8; }
.ring-fg{ fill:none; stroke:var(--ts-red); stroke-width:8; stroke-linecap:round; stroke-dasharray:214; stroke-dashoffset:28; }
.dash-ring__num{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-weight:800; font-family:var(--font-display); color:var(--ts-ink); }

.float-card{ position:absolute; display:flex; align-items:center; gap:10px; background:#fff; border-radius:var(--radius-md); box-shadow:var(--shadow-md); padding:12px 16px; border:1px solid var(--ts-line); animation:floatCard 5s ease-in-out infinite; }
.float-card__icon{ width:32px; height:32px; border-radius:50%; background:var(--ts-warm-bg); color:var(--ts-red); display:flex; align-items:center; justify-content:center; font-weight:800; }
.float-card strong{ display:block; color:var(--ts-ink); font-size:.9rem; }
.float-card small{ color:var(--ts-body); font-size:.75rem; }
.float-card--1{ top:10px; left:-20px; animation-delay:.4s; }
.float-card--2{ bottom:20px; right:-10px; animation-delay:1.1s; }
@keyframes floatCard{ 0%,100%{ transform:translateY(0);} 50%{ transform:translateY(-10px);} }
@keyframes fadeUp{ from{ opacity:0; transform:translateY(24px);} to{ opacity:1; transform:translateY(0);} }

/* =========================================================
   Split row (article spotlight + tool showcase)
   ========================================================= */
.split-row{ position:relative; z-index:1; display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.split-row__text h2, .split-row__text h3{ margin-bottom:16px; }
.split-row__text p{ font-size:1.05rem; }
.split-row__media{ position:relative; display:flex; align-items:center; justify-content:center; }
.media-circle{ position:absolute; width:340px; height:340px; border-radius:50%; background:radial-gradient(circle at 35% 30%, var(--ts-circle), var(--ts-circle-2) 70%); filter:blur(6px); z-index:0; opacity:.9; }
.media-circle--sm{ width:280px; height:280px; }
.media-image{ position:relative; z-index:1; border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); border:6px solid #fff; }
.media-placeholder{ position:relative; z-index:1; width:100%; max-width:420px; aspect-ratio:4/3; border-radius:var(--radius-lg); background:#fff; border:1px solid var(--ts-line); box-shadow:var(--shadow-md); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; color:var(--ts-red); }
.media-placeholder span{ font-weight:700; color:var(--ts-ink); font-size:.9rem; }

.tool-row{ position:relative; padding:64px 0; overflow:hidden; }
.tool-row--warm{ background:var(--ts-warm-bg); }
.tool-row--reverse .split-row{ direction:rtl; }
.tool-row--reverse .split-row > *{ direction:ltr; }
.tool-index{ font-family:var(--font-display); font-weight:800; font-size:.85rem; color:var(--ts-circle); letter-spacing:.05em; display:block; margin-bottom:6px; }
.check-list{ display:flex; flex-direction:column; gap:10px; margin:20px 0 28px; }
.check-list li{ display:flex; align-items:center; gap:10px; font-size:.95rem; color:var(--ts-ink); }
.check-list svg{ flex-shrink:0; color:var(--ts-red); background:var(--ts-warm-bg-2); border-radius:50%; padding:3px; box-sizing:content-box; }

.tool-mock{ position:relative; z-index:1; width:100%; max-width:440px; background:#fff; border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); border:1px solid var(--ts-line); overflow:hidden; }
.tool-mock__head{ display:flex; gap:8px; padding:14px 18px; border-bottom:1px solid var(--ts-line); }
.tool-mock__body{ padding:24px; }
.tool-mock__input{ height:40px; border-radius:var(--radius-sm); background:var(--ts-warm-bg); border:1.5px dashed var(--ts-circle); margin-bottom:18px; }
.tool-mock__line{ height:10px; border-radius:6px; background:var(--ts-line); margin-bottom:10px; }
.tool-mock__line:nth-child(3){ background:linear-gradient(90deg,var(--ts-red-light),var(--ts-circle-2)); }
.tool-mock__chip-row{ display:flex; gap:8px; margin-top:16px; }
.tool-mock__chip{ height:26px; width:70px; border-radius:var(--radius-pill); background:var(--ts-warm-bg-2); border:1px solid var(--ts-circle); }

/* =========================================================
   Feature grid (Why Choose)
   ========================================================= */
.feature-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.feature-card{ background:#fff; border:1px solid var(--ts-line); border-radius:var(--radius-lg); padding:32px; transition:transform var(--transition), box-shadow var(--transition); }
.feature-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:transparent; }
.feature-card__icon{ display:block; width:52px; height:52px; border-radius:16px; margin-bottom:18px; background:var(--ts-warm-bg); position:relative; }
.feature-card__icon::after{ content:""; position:absolute; inset:15px; background:var(--ts-red); mask-size:contain; mask-repeat:no-repeat; mask-position:center; -webkit-mask-size:contain; -webkit-mask-repeat:no-repeat; -webkit-mask-position:center; }
.feature-card__icon--gift::after{ mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M20 12v9H4v-9M2 7h20v5H2V7Zm10 14V7M12 7C10 2 5 4 6 7s6 0 6 0Zm0 0c2-5 7-3 6 0s-6 0-6 0Z'/%3E%3C/svg%3E"); -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M20 12v9H4v-9M2 7h20v5H2V7Zm10 14V7M12 7C10 2 5 4 6 7s6 0 6 0Zm0 0c2-5 7-3 6 0s-6 0-6 0Z'/%3E%3C/svg%3E"); }
.feature-card__icon--zap::after{ mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M13 2 3 14h8l-1 8 10-12h-8l1-8Z'/%3E%3C/svg%3E"); -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M13 2 3 14h8l-1 8 10-12h-8l1-8Z'/%3E%3C/svg%3E"); }
.feature-card__icon--unlock::after{ mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Crect x='3' y='11' width='18' height='11' rx='2'/%3E%3Cpath d='M7 11V7a5 5 0 0 1 9.9-1'/%3E%3C/svg%3E"); -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Crect x='3' y='11' width='18' height='11' rx='2'/%3E%3Cpath d='M7 11V7a5 5 0 0 1 9.9-1'/%3E%3C/svg%3E"); }
.feature-card__icon--device::after{ mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Crect x='6' y='2' width='12' height='20' rx='2'/%3E%3Cpath d='M11 18h2'/%3E%3C/svg%3E"); -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Crect x='6' y='2' width='12' height='20' rx='2'/%3E%3Cpath d='M11 18h2'/%3E%3C/svg%3E"); }
.feature-card__icon--spark::after{ mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M12 3v4M12 17v4M3 12h4M17 12h4M5.6 5.6l2.8 2.8M15.6 15.6l2.8 2.8M18.4 5.6l-2.8 2.8M8.4 15.6l-2.8 2.8'/%3E%3C/svg%3E"); -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M12 3v4M12 17v4M3 12h4M17 12h4M5.6 5.6l2.8 2.8M15.6 15.6l2.8 2.8M18.4 5.6l-2.8 2.8M8.4 15.6l-2.8 2.8'/%3E%3C/svg%3E"); }
.feature-card__icon--shield::after{ mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M12 22s8-4 8-10V5l-8-3-8 3v7c0 6 8 10 8 10Z'/%3E%3C/svg%3E"); -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M12 22s8-4 8-10V5l-8-3-8 3v7c0 6 8 10 8 10Z'/%3E%3C/svg%3E"); }

/* =========================================================
   Stats
   ========================================================= */
.stats-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; text-align:center; }
.stat-item__num{ display:block; font-family:var(--font-display); font-size:clamp(2rem,4vw,3rem); font-weight:800; color:#fff; margin-bottom:6px; }
.stat-item__label{ font-size:.9rem; }

/* =========================================================
   Testimonials
   ========================================================= */
.testimonial-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.testimonial-card{ background:#fff; border:1px solid var(--ts-line); border-radius:var(--radius-lg); padding:30px; box-shadow:var(--shadow-sm); }
.testimonial-card__stars{ color:var(--ts-red); letter-spacing:2px; margin-bottom:14px; }
.testimonial-card__person{ display:flex; align-items:center; gap:12px; margin-top:20px; }
.avatar-dot{ width:38px; height:38px; border-radius:50%; background:linear-gradient(135deg,var(--ts-red),var(--ts-circle)); flex-shrink:0; }
.testimonial-card__person small{ color:var(--ts-body); display:block; font-size:.8rem; }

/* =========================================================
   Blog grid
   ========================================================= */
.blog-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.blog-card{ display:block; background:#fff; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--ts-line); transition:transform var(--transition), box-shadow var(--transition); }
.blog-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); }
.blog-card__media{ aspect-ratio:16/10; overflow:hidden; background:var(--ts-warm-bg); }
.blog-card__media img{ width:100%; height:100%; object-fit:cover; }
.blog-card__placeholder{ width:100%; height:100%; background:linear-gradient(135deg,var(--ts-warm-bg),var(--ts-warm-bg-2)); }
.blog-card__body{ padding:22px; }
.blog-card__cat{ font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:.04em; color:var(--ts-red); }
.blog-card h3{ font-size:1.05rem; margin:8px 0; }
.blog-card p{ font-size:.9rem; margin:0; color:var(--ts-body); }

/* =========================================================
   FAQ accordion
   ========================================================= */
.faq-layout{ display:grid; grid-template-columns:.8fr 1.2fr; gap:56px; }
.faq-layout__head p a{ color:var(--ts-red); font-weight:700; }
.faq-item{ border-bottom:1px solid var(--ts-line); }
.faq-item__q{ width:100%; display:flex; align-items:center; justify-content:space-between; gap:16px; background:none; border:none; padding:20px 0; text-align:left; font-weight:700; font-size:1.02rem; color:var(--ts-ink); }
.faq-item__icon{ flex-shrink:0; width:28px; height:28px; border-radius:50%; background:var(--ts-warm-bg); color:var(--ts-red); display:flex; align-items:center; justify-content:center; font-size:1.1rem; transition:transform var(--transition); }
.faq-item__q[aria-expanded="true"] .faq-item__icon{ transform:rotate(45deg); }
.faq-item__a{ max-height:0; overflow:hidden; transition:max-height .3s ease; }
.faq-item__a p{ padding:0 0 20px; color:var(--ts-body); }

/* =========================================================
   Newsletter / CTA box
   ========================================================= */
.newsletter-form{ display:flex; gap:10px; }
.newsletter-form input{ flex:1; padding:12px 16px; border-radius:var(--radius-pill); border:1px solid var(--ts-line); font-family:inherit; }
.footer-newsletter .newsletter-form{ flex-direction:column; }
.cta-box{ position:relative; z-index:1; text-align:center; max-width:640px; margin:0 auto; }
.cta-box h2{ color:#fff; }
.cta-box p{ color:rgba(255,255,255,.85); margin-bottom:28px; }
.newsletter-form--lg{ max-width:460px; margin:0 auto; }
.newsletter-form--lg input{ background:rgba(255,255,255,.92); border:none; }

/* =========================================================
   Footer
   ========================================================= */
.site-footer{ background:var(--ts-ink); color:rgba(255,255,255,.7); padding:70px 0 0; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr 1.3fr; gap:32px; padding-bottom:50px; border-bottom:1px solid rgba(255,255,255,.1); }
.footer-brand .site-logo-text{ color:#fff; }
.footer-tagline{ font-size:.9rem; margin:14px 0 18px; }
.footer-social{ display:flex; gap:10px; }
.footer-social a{ width:36px; height:36px; border-radius:50%; background:rgba(255,255,255,.08); display:flex; align-items:center; justify-content:center; transition:background var(--transition); }
.footer-social a:hover{ background:var(--ts-red); }
.widget-title{ color:#fff; font-size:.9rem; text-transform:uppercase; letter-spacing:.04em; margin-bottom:16px; }
.footer-menu{ display:flex; flex-direction:column; gap:10px; }
.footer-menu a{ font-size:.9rem; transition:color var(--transition); }
.footer-menu a:hover{ color:#fff; }
.footer-newsletter p{ font-size:.88rem; margin-bottom:14px; }
.footer-newsletter input{ background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.15); color:#fff; }
.footer-newsletter input::placeholder{ color:rgba(255,255,255,.5); }
.footer-bottom{ display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; padding:24px 0; font-size:.82rem; }
.footer-disclaimer{ max-width:520px; text-align:right; opacity:.7; }

/* =========================================================
   Generic page/content templates (blog, pages, tools archive)
   ========================================================= */
.page-hero{ padding:64px 0 40px; background:var(--ts-warm-bg); text-align:center; }
.page-hero h1{ margin-bottom:12px; }
.page-hero p{ max-width:600px; margin:0 auto; font-size:1.05rem; }

.content-layout{ display:grid; grid-template-columns:1fr 340px; gap:56px; padding:64px 0; align-items:start; }
.content-layout.no-sidebar{ grid-template-columns:1fr; max-width:800px; margin:0 auto; }
.entry-content{ font-size:1.05rem; }
.entry-content h2{ margin-top:1.6em; }
.entry-content h3{ margin-top:1.3em; }
.entry-content p{ margin-bottom:1.3em; }
.entry-content img{ border-radius:var(--radius-md); margin:1.6em 0; }
.entry-content ul, .entry-content ol{ margin:0 0 1.3em; padding-left:1.4em; list-style:revert; }
.entry-content blockquote{ border-left:4px solid var(--ts-red); background:var(--ts-warm-bg); padding:18px 24px; border-radius:0 var(--radius-md) var(--radius-md) 0; font-style:italic; margin:1.6em 0; }
.entry-content a{ color:var(--ts-red); text-decoration:underline; }
.entry-content table{ width:100%; border-collapse:collapse; margin:1.6em 0; }
.entry-content table th, .entry-content table td{ border:1px solid var(--ts-line); padding:10px 14px; }

.post-meta{ display:flex; flex-wrap:wrap; gap:16px; align-items:center; font-size:.88rem; color:var(--ts-body); margin-bottom:24px; }
.post-meta span{ display:inline-flex; align-items:center; gap:6px; }

.toc{ background:var(--ts-warm-bg); border-radius:var(--radius-md); padding:22px 26px; margin:0 0 32px; }
.toc h2{ font-size:1rem; margin-bottom:12px; }
.toc ul{ display:flex; flex-direction:column; gap:8px; padding-left:0; list-style:none; }
.toc a{ color:var(--ts-red-dark); font-weight:600; font-size:.92rem; }

.share-row{ display:flex; align-items:center; gap:10px; margin:30px 0; }
.share-row a{ width:38px; height:38px; border-radius:50%; background:var(--ts-warm-bg); display:flex; align-items:center; justify-content:center; color:var(--ts-red); }

.author-box{ display:flex; gap:18px; align-items:flex-start; background:var(--ts-warm-bg); border-radius:var(--radius-lg); padding:26px; margin:36px 0; }
.author-box img{ border-radius:50%; width:64px; height:64px; }
.author-box h3{ margin-bottom:6px; font-size:1rem; }

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

.sidebar .widget{ background:#fff; border:1px solid var(--ts-line); border-radius:var(--radius-md); padding:22px; margin-bottom:22px; }

.post-list{ display:flex; flex-direction:column; gap:32px; }
.post-list article{ display:grid; grid-template-columns:240px 1fr; gap:26px; }
.post-list .entry-thumb{ border-radius:var(--radius-md); overflow:hidden; aspect-ratio:4/3; background:var(--ts-warm-bg); }
.post-list .entry-thumb img{ width:100%; height:100%; object-fit:cover; }

.pagination{ display:flex; justify-content:center; gap:10px; padding-top:20px; }
.pagination .page-numbers{ min-width:40px; height:40px; display:inline-flex; align-items:center; justify-content:center; border-radius:50%; border:1px solid var(--ts-line); font-weight:700; }
.pagination .page-numbers.current{ background:var(--ts-red); border-color:var(--ts-red); color:#fff; }

.search-form-wrap{ max-width:520px; margin:0 auto 20px; display:flex; gap:10px; }
.search-form-wrap input{ flex:1; padding:14px 18px; border-radius:var(--radius-pill); border:1px solid var(--ts-line); }

.error-404{ text-align:center; padding:110px 0; }
.error-404__code{ font-family:var(--font-display); font-size:clamp(4rem,12vw,8rem); font-weight:800; color:var(--ts-red); line-height:1; margin-bottom:10px; }

.tools-archive-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; padding:60px 0 90px; }
.tool-card{ background:#fff; border:1px solid var(--ts-line); border-radius:var(--radius-lg); padding:28px; transition:transform var(--transition), box-shadow var(--transition); }
.tool-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); }
.tool-card__icon{ width:48px; height:48px; border-radius:14px; background:var(--ts-warm-bg); color:var(--ts-red); display:flex; align-items:center; justify-content:center; margin-bottom:16px; font-weight:800; }
.tool-card h3{ font-size:1.05rem; margin-bottom:8px; }
.tool-card p{ font-size:.9rem; margin-bottom:16px; }

.category-filter{ display:flex; flex-wrap:wrap; gap:10px; padding:30px 0 0; }
.category-filter a{ padding:8px 16px; border-radius:var(--radius-pill); border:1px solid var(--ts-line); font-size:.85rem; font-weight:600; }
.category-filter a.active, .category-filter a:hover{ background:var(--ts-red); border-color:var(--ts-red); color:#fff; }

/* Single tool page layout */
.tool-hero{ padding:70px 0 50px; background:var(--ts-warm-bg); position:relative; overflow:hidden; }
.tool-interface{ background:#fff; border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); border:1px solid var(--ts-line); padding:36px; margin:-30px auto 60px; max-width:800px; position:relative; z-index:2; }
.tool-interface input, .tool-interface textarea{ width:100%; padding:14px 16px; border-radius:var(--radius-sm); border:1.5px solid var(--ts-line); font-family:inherit; margin-bottom:14px; }
.tool-steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.tool-steps__item{ text-align:center; }
.tool-steps__num{ width:44px; height:44px; border-radius:50%; background:var(--ts-red); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:800; margin:0 auto 14px; }

/* =========================================================
   Dark mode
   ========================================================= */
body.dark-mode{ background:var(--ts-dark-bg); color:rgba(255,255,255,.75); }
body.dark-mode h1, body.dark-mode h2, body.dark-mode h3, body.dark-mode h4{ color:#fff; }
body.dark-mode .site-header{ background:rgba(26,14,12,.85); border-color:rgba(255,255,255,.08); }
body.dark-mode .site-branding, body.dark-mode .site-logo-text, body.dark-mode .nav-menu a{ color:#fff; }
body.dark-mode .theme-toggle{ background:var(--ts-dark-surface); border-color:rgba(255,255,255,.15); color:#fff; }
body.dark-mode .theme-toggle .icon-sun{ display:none; }
body.dark-mode .theme-toggle .icon-moon{ display:block; }
body.dark-mode .hero{ background:linear-gradient(180deg,#241412 0%, var(--ts-dark-bg) 70%); }
body.dark-mode .section--warm, body.dark-mode .tool-row--warm, body.dark-mode .section--tint{ background:var(--ts-dark-surface); }
body.dark-mode .dash-card, body.dark-mode .float-card, body.dark-mode .feature-card, body.dark-mode .testimonial-card, body.dark-mode .blog-card, body.dark-mode .tool-mock, body.dark-mode .tool-card, body.dark-mode .media-placeholder, body.dark-mode .tool-interface, body.dark-mode .sidebar .widget{
	background:var(--ts-dark-surface); border-color:rgba(255,255,255,.08); color:rgba(255,255,255,.75);
}
body.dark-mode .btn-ghost{ background:var(--ts-dark-surface); color:#fff; border-color:rgba(255,255,255,.15); }
body.dark-mode .eyebrow--dark{ background:rgba(255,255,255,.08); color:var(--ts-red-light); }
body.dark-mode .ts-breadcrumbs{ background:var(--ts-dark-surface); border-color:rgba(255,255,255,.08); }
body.dark-mode .faq-item{ border-color:rgba(255,255,255,.08); }
body.dark-mode .footer-newsletter input{ background:rgba(255,255,255,.06); }

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:1080px){
	.hero__inner{ grid-template-columns:1fr; }
	.hero__visual{ height:380px; order:-1; }
	.split-row{ grid-template-columns:1fr; gap:40px; }
	.tool-row--reverse .split-row{ direction:ltr; }
	.tool-row--reverse .split-row__media{ order:-1; }
	.feature-grid, .testimonial-grid, .blog-grid, .related-grid, .tools-archive-grid{ grid-template-columns:repeat(2,1fr); }
	.stats-grid{ grid-template-columns:repeat(2,1fr); gap:36px; }
	.footer-grid{ grid-template-columns:1fr 1fr; }
	.content-layout{ grid-template-columns:1fr; }
	.faq-layout{ grid-template-columns:1fr; gap:24px; }
}
@media (max-width:820px){
	.nav-menu{ position:fixed; top:76px; left:0; right:0; bottom:0; background:#fff; flex-direction:column; align-items:flex-start; padding:30px 24px; gap:22px; transform:translateX(-100%); transition:transform var(--transition); overflow-y:auto; }
	.nav-menu.is-open{ transform:translateX(0); }
	.menu-toggle{ display:flex; }
	.menu-toggle.is-open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
	.menu-toggle.is-open span:nth-child(2){ opacity:0; }
	.menu-toggle.is-open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
	.site-header__cta{ display:none; }
	body.dark-mode .nav-menu{ background:var(--ts-dark-bg); }
}
@media (max-width:680px){
	.section{ padding:64px 0; }
	.feature-grid, .testimonial-grid, .blog-grid, .related-grid, .tools-archive-grid{ grid-template-columns:1fr; }
	.stats-grid{ grid-template-columns:1fr 1fr; }
	.footer-grid{ grid-template-columns:1fr; }
	.footer-bottom{ flex-direction:column; }
	.footer-disclaimer{ text-align:left; }
	.post-list article{ grid-template-columns:1fr; }
	.section-head--row{ flex-direction:column; align-items:flex-start; }
	.tool-steps{ grid-template-columns:1fr; }
	.newsletter-form{ flex-direction:column; }
}
