/* =====================================================================
   KD – Homepage Tool Panel (BriefBuilder mockup) — v1.4.3
   Interaktywne demo z klikalnymi zakładkami. Ciemny motyw (granat/grafit),
   akcent #fb761d. Wszystko scoped pod .kd-tool. Orientacja pozioma.
   v1.4.0: oryginalne logotypy silników (Google/OpenAI/Claude/Gemini/Perplexity),
   zakładki SERP + Treść (scraped), UJEDNOLICONE ODSTĘPY przez zmienne
   --kd-gap / --kd-pad (jeden rytm we wszystkich zakładkach).
   ===================================================================== */

.kd-tool {
	/* paleta (dopasowana do realnego produktu — ciemny granat) */
	--kd-primary: #fb761d;
	--kd-primary-soft: rgba(251, 118, 29, .14);
	--kd-bg: #0c0f1a;
	--kd-card: #161b2b;
	--kd-card-2: #1b2133;
	--kd-line: #283047;
	--kd-line-soft: #232a3e;
	--kd-text: #eef1f8;
	--kd-text-soft: #aab2c8;
	--kd-text-mute: #7e879f;
	--kd-accent: #2dd4bf;     /* teal — jak w realnym UI */
	--kd-up: #34d399;
	--kd-radius: 14px;

	/* === RYTM ODSTĘPÓW (jeden źródłowy zestaw dla wszystkich zakładek) === */
	--kd-gap: 14px;        /* odstęp między kartami / sekcjami w widoku */
	--kd-gap-sm: 8px;      /* odstęp między elementami listy w karcie */
	--kd-pad: 16px;        /* padding wnętrza karty */
	--kd-pad-sm: 11px;     /* padding mniejszych elementów (linki, pozycje listy) */
	--kd-stage-pad: 16px;  /* padding sceny / scrolla wokół kart */

	width: 100%;
	max-width: 1320px;
	margin: 0 auto;
	box-sizing: border-box;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Inter, Arial, sans-serif;
	color: var(--kd-text);
	-webkit-font-smoothing: antialiased;
}
.kd-tool *,
.kd-tool *::before,
.kd-tool *::after { box-sizing: border-box; }

/* --- GLOBALNY GUARD IKON: żadne SVG nie może się rozdąć --- */
.kd-tool svg,
.kd-tool .kd-tool__ic {
	width: 16px;
	height: 16px;
	flex: 0 0 auto;
	display: inline-block;
	vertical-align: middle;
}
.kd-tool .kd-tool__ic--sm { width: 13px; height: 13px; }
.kd-tool .kd-tool__ic--check { width: 14px; height: 14px; }

/* =========================== OKNO =========================== */
.kd-tool__window {
	position: relative;
	display: flex;
	flex-direction: column;
	width: 100%;
	aspect-ratio: 16 / 10;
	background: var(--kd-bg);
	border: 1px solid var(--kd-line);
	border-radius: 18px;
	overflow: hidden;
	box-shadow: 0 30px 70px -25px rgba(0, 0, 0, .7), 0 0 0 1px rgba(255, 255, 255, .02) inset;
}

/* =========================== CHROME =========================== */
.kd-tool__chrome {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 9px 14px;
	background: #0a0d16;
	border-bottom: 1px solid var(--kd-line-soft);
	flex: 0 0 auto;
}
.kd-tool__dots { display: flex; gap: 6px; }
.kd-tool__dot { width: 11px; height: 11px; border-radius: 50%; }
.kd-tool__dot--r { background: #ff5f57; }
.kd-tool__dot--y { background: #febc2e; }
.kd-tool__dot--g { background: #28c840; }
.kd-tool__chrome-nav { display: flex; gap: 6px; color: var(--kd-text-mute); }
.kd-tool__chrome-nav svg { width: 14px; height: 14px; }
.kd-tool__address {
	flex: 1 1 auto;
	display: flex;
	align-items: center;
	gap: 7px;
	min-width: 0;
	padding: 6px 12px;
	border: 1px solid var(--kd-line-soft);
	border-radius: 8px;
	background: #0e1320;
}
.kd-tool__address-lock { color: var(--kd-up); display: flex; }
.kd-tool__address-lock svg { width: 12px; height: 12px; }
.kd-tool__address-url {
	font-size: 12px;
	color: var(--kd-text-soft);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* =========================== TOPBAR =========================== */
/* Jeden wiersz, wspólna oś pionowa (center), logo+tytuł lewo, badge prawo.
   Tytuł (crumb) dostaje margin-right:auto i pcha badge do prawej krawędzi.
   min-width:0 + ellipsis chronią przed ściśnięciem i nachodzeniem. */
.kd-tool__topbar {
	display: flex;
	align-items: center;
	gap: 14px;
	min-height: 46px;
	padding: 8px 18px;
	background: linear-gradient(180deg, #131829, #0e1220);
	border-bottom: 1px solid var(--kd-line-soft);
	flex: 0 0 auto;
}
.kd-tool__logo {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	flex: 0 0 auto;
	font-weight: 700;
	font-size: 14px;
	line-height: 1.2;
	color: var(--kd-text);
	white-space: nowrap;
}
.kd-tool__logo svg { color: var(--kd-primary); width: 17px; height: 17px; }
.kd-tool__crumb {
	display: flex;
	flex-direction: column;
	justify-content: center;
	flex: 1 1 auto;
	min-width: 0;
	line-height: 1.3;
	margin-right: auto;
}
.kd-tool__crumb b { display: block; font-size: 13px; color: var(--kd-text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.kd-tool__crumb-meta { font-size: 11px; color: var(--kd-text-mute); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.kd-tool__topbadge {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	flex: 0 0 auto;
	font-size: 11.5px;
	font-weight: 600;
	line-height: 1.2;
	color: var(--kd-up);
	background: rgba(52, 211, 153, .12);
	border: 1px solid rgba(52, 211, 153, .28);
	padding: 5px 11px;
	border-radius: 999px;
	white-space: nowrap;
}
.kd-tool__topbadge svg { color: var(--kd-up); }

/* =========================== TABS =========================== */
.kd-tool__tabs {
	display: flex;
	gap: 6px;
	padding: 10px 14px 0;
	background: #0c1019;
	border-bottom: 1px solid var(--kd-line-soft);
	flex: 0 0 auto;
	overflow-x: auto;
	scrollbar-width: none;
}
.kd-tool__tabs::-webkit-scrollbar { display: none; }
.kd-tool__tab {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	padding: 9px 16px;
	margin-bottom: -1px;
	border: 1px solid transparent;
	border-bottom: none;
	border-radius: 10px 10px 0 0;
	background: transparent;
	color: var(--kd-text-mute);
	font: inherit;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	white-space: nowrap;
	transition: color .18s, background .18s, border-color .18s;
}
.kd-tool__tab svg { width: 15px; height: 15px; }
.kd-tool__tab:hover { color: var(--kd-text-soft); background: rgba(255, 255, 255, .03); }
.kd-tool__tab:focus-visible { outline: 2px solid var(--kd-primary); outline-offset: 2px; }
.kd-tool__tab.is-active {
	color: var(--kd-text);
	background: var(--kd-bg);
	border-color: var(--kd-line);
	border-bottom: 1px solid var(--kd-bg);
}
.kd-tool__tab.is-active svg { color: var(--kd-primary); }
.kd-tool__tab-short { display: none; }

/* =========================== HAMBURGER + MENU (mobile) =========================== */
/* Domyślnie (desktop ≥768px): hamburger i menu ukryte, zwykły rząd zakładek. */
.kd-tool__tabsbar { position: relative; flex: 0 0 auto; }
.kd-tool__burger { display: none; }
.kd-tool__menu { display: none; }

/* =========================== STAGE / PANELS =========================== */
.kd-tool__stage {
	position: relative;
	flex: 1 1 auto;
	min-height: 0;
	background: var(--kd-bg);
}
.kd-tool__panel {
	position: absolute;
	inset: 0;
	opacity: 0;
	visibility: hidden;
	transition: opacity .22s ease;
}
.kd-tool__panel.is-active { opacity: 1; visibility: visible; }
/* sterujemy widocznością klasą .is-active, nie atrybutem [hidden] (JS go usuwa) */
.kd-tool__panel[hidden] { display: block; }

.kd-tool__scroll {
	position: absolute;
	inset: 0;
	overflow-y: auto;
	overflow-x: hidden;
	padding: var(--kd-stage-pad);
	display: flex;
	flex-direction: column;
	gap: var(--kd-gap);
	scrollbar-width: thin;
	scrollbar-color: var(--kd-line) transparent;
}
.kd-tool__scroll::-webkit-scrollbar { width: 8px; }
.kd-tool__scroll::-webkit-scrollbar-thumb { background: var(--kd-line); border-radius: 99px; }
.kd-tool__scroll::-webkit-scrollbar-track { background: transparent; }

/* =========================== LAYOUT GRID =========================== */
.kd-tool__grid {
	display: grid;
	grid-template-columns: 1.55fr 1fr;
	gap: var(--kd-gap);
	align-items: start;
}
.kd-tool__col { display: flex; flex-direction: column; gap: var(--kd-gap); min-width: 0; }

/* =========================== CARD =========================== */
.kd-tool__card {
	background: var(--kd-card);
	border: 1px solid var(--kd-line-soft);
	border-radius: var(--kd-radius);
	padding: var(--kd-pad);
	min-width: 0;            /* karta nie rozpycha siatki na wąskim ekranie */
	overflow-wrap: anywhere; /* długie frazy/URL-e łamią się, nie wychodzą poza ramkę */
}
.kd-tool__card--accent { border-left: 3px solid var(--kd-primary); }
.kd-tool__card-title {
	display: flex;
	align-items: center;
	gap: 8px;
	margin: 0 0 4px;
	font-size: 14px;
	font-weight: 700;
	color: var(--kd-text);
}
.kd-tool__card-title svg { color: var(--kd-primary); width: 17px; height: 17px; }
.kd-tool__card-sub {
	display: block;
	font-size: 11.5px;
	color: var(--kd-text-mute);
	margin-bottom: var(--kd-gap);
}
.kd-tool__eyebrow--gap { margin-top: var(--kd-gap); }
.kd-tool__eyebrow {
	display: block;
	font-size: 10.5px;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--kd-text-mute);
	margin-bottom: 6px;
}
.kd-tool__query { margin: 0; font-size: 19px; font-weight: 700; color: var(--kd-text); line-height: 1.3; }
.kd-tool__summary { margin: 0; font-size: 13px; line-height: 1.6; color: var(--kd-text-soft); }
.kd-tool__summary b { color: var(--kd-text); font-weight: 700; }

/* --- Suggested headings --- */
.kd-tool__head-h1 {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 10px 12px;
	background: var(--kd-primary-soft);
	border: 1px solid rgba(251, 118, 29, .3);
	border-radius: 10px;
	font-size: 13.5px;
	font-weight: 700;
	color: var(--kd-text);
	line-height: 1.4;
	margin-bottom: var(--kd-gap-sm);
}
.kd-tool__head-sec {
	border: 1px solid var(--kd-line-soft);
	border-radius: 10px;
	overflow: hidden;
	margin-bottom: var(--kd-gap-sm);
}
.kd-tool__head-h2 {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 9px 12px;
	background: rgba(45, 212, 191, .06);
	font-size: 13px;
	font-weight: 600;
	color: var(--kd-text);
	line-height: 1.4;
}
.kd-tool__head-h3 {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 7px 12px 7px 26px;
	border-top: 1px solid var(--kd-line-soft);
	background: rgba(255, 255, 255, .015);
	font-size: 12.5px;
	color: var(--kd-text-soft);
	line-height: 1.4;
}
.kd-tool__lvl {
	flex: 0 0 auto;
	font-size: 10px;
	font-weight: 800;
	padding: 2px 6px;
	border-radius: 6px;
	line-height: 1.4;
}
.kd-tool__lvl--h1 { background: var(--kd-primary); color: #1a1206; }
.kd-tool__lvl--h2 { background: rgba(45, 212, 191, .18); color: var(--kd-accent); border: 1px solid rgba(45, 212, 191, .4); }
.kd-tool__lvl--h3 { background: rgba(96, 165, 250, .14); color: #93c5fd; border: 1px solid rgba(96, 165, 250, .3); }
.kd-tool__headfoot {
	display: flex;
	gap: 8px;
	margin-top: 12px;
	padding-top: 12px;
	border-top: 1px solid var(--kd-line-soft);
}
.kd-tool__chip {
	font-size: 11px;
	font-weight: 600;
	color: var(--kd-text-soft);
	background: var(--kd-card-2);
	border: 1px solid var(--kd-line-soft);
	padding: 3px 10px;
	border-radius: 999px;
}

/* --- Stat grid --- */
.kd-tool__statgrid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--kd-gap-sm); }
.kd-tool__stat {
	background: var(--kd-card-2);
	border: 1px solid var(--kd-line-soft);
	border-radius: 10px;
	padding: 12px;
	text-align: center;
}
.kd-tool__stat-num { display: block; font-size: 24px; font-weight: 800; color: var(--kd-primary); line-height: 1; }
.kd-tool__stat-cap { display: block; font-size: 10.5px; color: var(--kd-text-mute); margin-top: 5px; }

/* === RESET CENTROWANIA: sekcja hero ma text-align:center, który przeciekał do
      treści panelu (tytuły SERP, dokument Treści itd.). Domyślnie wszystko do lewej;
      celowe centrowanie (kafelki stat, donut) ma własne, bardziej specyficzne reguły. === */
.kd-tool__viewport,
.kd-tool__serp, .kd-tool__serp-title, .kd-tool__serp-url, .kd-tool__serp-desc,
.kd-tool__sc-doc, .kd-tool__sc-doc h1, .kd-tool__sc-doc h2, .kd-tool__sc-doc h3,
.kd-tool__sc-doc h4, .kd-tool__sc-doc p, .kd-tool__sc-doc li, .kd-tool__sc-body,
.kd-tool__paa, .kd-tool__paa-item, .kd-tool__links, .kd-tool__src-answer,
.kd-tool__chatcard, .kd-tool__chatcard * { text-align: left; }

/* --- AIO / GEO --- */
/* AIO Summary ZAWSZE do lewej (nagłówki, tekst, Key Points) — żadnego centrowania. */
.kd-tool__card--accent,
.kd-tool__card--accent .kd-tool__summary,
.kd-tool__card--accent .kd-tool__eyebrow,
.kd-tool__card--accent .kd-tool__keypoints,
.kd-tool__card--accent .kd-tool__keypoints li,
.kd-tool__card--accent .kd-tool__aio-note { text-align: left; }
.kd-tool__aio-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 12px; }
.kd-tool__aio-head .kd-tool__card-title { margin: 0; }
.kd-tool__pill-badge {
	font-size: 10.5px;
	font-weight: 700;
	color: var(--kd-primary);
	background: var(--kd-primary-soft);
	border: 1px solid rgba(251, 118, 29, .3);
	padding: 3px 9px;
	border-radius: 999px;
}
.kd-tool__keypoints { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--kd-gap-sm); }
.kd-tool__keypoints li {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	font-size: 13px;
	line-height: 1.5;
	color: var(--kd-text-soft);
}
.kd-tool__kp-num {
	flex: 0 0 auto;
	width: 20px;
	height: 20px;
	border-radius: 6px;
	background: var(--kd-primary-soft);
	color: var(--kd-primary);
	font-size: 11px;
	font-weight: 800;
	display: flex;
	align-items: center;
	justify-content: center;
}
.kd-tool__aio-note {
	margin: 14px 0 0;
	padding-top: 12px;
	border-top: 1px solid var(--kd-line-soft);
	font-size: 11.5px;
	line-height: 1.55;
	color: var(--kd-text-mute);
}
.kd-tool__aio-note svg { color: var(--kd-primary); width: 13px; height: 13px; }
.kd-tool__aio-note b { color: var(--kd-text-soft); }

/* --- Bars --- */
.kd-tool__bars { display: flex; flex-direction: column; gap: var(--kd-gap-sm); }
.kd-tool__bar-row { display: grid; grid-template-columns: 96px 1fr 62px; align-items: center; gap: 10px; }
.kd-tool__bar-label { font-size: 12px; color: var(--kd-text-soft); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.kd-tool__bar-track { height: 8px; border-radius: 99px; background: var(--kd-card-2); overflow: hidden; }
.kd-tool__bar-fill {
	display: block;
	height: 100%;
	width: var(--kd-w, 0%);
	border-radius: 99px;
	background: linear-gradient(90deg, var(--kd-primary), #ffa45c);
	transition: width .8s cubic-bezier(.22, 1, .36, 1);
}
.kd-tool__bar-fill--mute { background: linear-gradient(90deg, #4a5474, #6b7596); }
.kd-tool__bar-val { font-size: 11.5px; color: var(--kd-text-mute); text-align: right; white-space: nowrap; }

/* --- Insights --- */
.kd-tool__insights { display: grid; grid-template-columns: 1fr 1fr; gap: var(--kd-gap); }
.kd-tool__insight { display: flex; flex-direction: column; gap: var(--kd-gap-sm); }
.kd-tool__insight-tag {
	align-self: flex-start;
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-size: 11px;
	font-weight: 600;
	color: var(--kd-accent);
	background: rgba(45, 212, 191, .1);
	border: 1px solid rgba(45, 212, 191, .26);
	padding: 3px 9px;
	border-radius: 999px;
}
.kd-tool__insight-tag svg { width: 12px; height: 12px; color: var(--kd-accent); }

/* --- Sources / Links --- */
.kd-tool__srctabs { display: flex; gap: var(--kd-gap-sm); margin: 0 0 var(--kd-gap); flex-wrap: wrap; }
.kd-tool__srctab {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	font: inherit;
	font-size: 12px;
	font-weight: 600;
	color: var(--kd-text-mute);
	background: var(--kd-card-2);
	border: 1px solid var(--kd-line-soft);
	padding: 6px 13px 6px 9px;
	border-radius: 999px;
	cursor: pointer;
	transition: color .16s, background .16s, border-color .16s;
}
.kd-tool__srctab:hover { color: var(--kd-text-soft); }
.kd-tool__srctab:focus-visible { outline: 2px solid var(--kd-primary); outline-offset: 2px; }
.kd-tool__srctab.is-active { color: #1a1206; background: var(--kd-primary); border-color: var(--kd-primary); }
/* w aktywnej pigułce logo na ciemnym tle — wymuś czytelny ciemny kolor logotypu */
.kd-tool__srctab.is-active .kd-tool__brandico { background: rgba(26, 18, 6, .14); }
.kd-tool__srctab.is-active .kd-tool__brandico svg { color: #1a1206; }
.kd-tool__links-title {
	display: flex;
	align-items: center;
	gap: 7px;
	margin: 0 0 10px;
	font-size: 12px;
	font-weight: 700;
	color: var(--kd-text-soft);
}
.kd-tool__links-title svg { color: var(--kd-primary); width: 14px; height: 14px; }
.kd-tool__links { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--kd-gap-sm); }
.kd-tool__link {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: var(--kd-pad-sm);
	background: var(--kd-card-2);
	border: 1px solid var(--kd-line-soft);
	border-radius: 10px;
	transition: border-color .16s;
}
.kd-tool__link:hover { border-color: rgba(251, 118, 29, .4); }
.kd-tool__link-no {
	flex: 0 0 auto;
	width: 20px;
	height: 20px;
	border-radius: 6px;
	background: rgba(255, 255, 255, .05);
	color: var(--kd-text-mute);
	font-size: 11px;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
}
.kd-tool__link-check {
	flex: 0 0 auto;
	width: 18px;
	height: 18px;
	border-radius: 50%;
	background: rgba(52, 211, 153, .15);
	color: var(--kd-up);
	display: flex;
	align-items: center;
	justify-content: center;
}
.kd-tool__link-check svg { width: 11px; height: 11px; color: var(--kd-up); }
.kd-tool__link-body { display: flex; flex-direction: column; min-width: 0; line-height: 1.35; }
.kd-tool__link-title { font-size: 12.5px; font-weight: 600; color: var(--kd-text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.kd-tool__link-url {
	display: flex;
	align-items: center;
	gap: 5px;
	font-size: 11px;
	color: #6ea8fe;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.kd-tool__link-url svg { width: 10px; height: 10px; color: var(--kd-text-mute); }

/* --- Pod-zakładki Źródeł: panele treści (SERP / ChatGPT / AIO) --- */
/* Widocznością steruje JS klasą .is-active + atrybutem [hidden]. */
.kd-tool__srcpanel { display: none; }
.kd-tool__srcpanel.is-active { display: block; }
.kd-tool__srcpanel[hidden] { display: none; }
.kd-tool__src-prompt {
	display: flex;
	align-items: center;
	gap: 9px;
	margin-bottom: var(--kd-gap-sm);
	padding: var(--kd-pad-sm);
	background: var(--kd-card-2);
	border: 1px solid var(--kd-line-soft);
	border-radius: 10px;
	font-size: 12px;
	font-weight: 600;
	color: var(--kd-text-soft);
}
.kd-tool__src-prompt > span { min-width: 0; line-height: 1.4; }
.kd-tool__src-answer {
	margin-bottom: var(--kd-gap);
	padding: var(--kd-pad-sm);
	background: rgba(255, 255, 255, .015);
	border: 1px solid var(--kd-line-soft);
	border-radius: 10px;
}
.kd-tool__src-answer p { margin: 0 0 9px; font-size: 12.5px; line-height: 1.6; color: var(--kd-text-soft); }
.kd-tool__src-answer p:last-child { margin-bottom: 0; }
.kd-tool__src-answer b { color: var(--kd-text); font-weight: 700; }
.kd-tool__src-ul { list-style: none; margin: 0 0 9px; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.kd-tool__src-ul li {
	position: relative;
	padding-left: 16px;
	font-size: 12.5px;
	line-height: 1.55;
	color: var(--kd-text-soft);
}
.kd-tool__src-ul li::before {
	content: "";
	position: absolute;
	left: 2px;
	top: 8px;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: var(--kd-primary);
}
.kd-tool__src-ul b { color: var(--kd-text); font-weight: 700; }
.kd-tool__src-note {
	margin: var(--kd-gap-sm) 0 0;
	display: flex;
	align-items: center;
	gap: 7px;
	font-size: 11.5px;
	line-height: 1.5;
	color: var(--kd-text-mute);
}
.kd-tool__src-note b { color: var(--kd-text-soft); font-weight: 700; }
/* logo w link-check pod-zakładek ChatGPT/AIO (zamiast checkmarka) */
.kd-tool__link-check .kd-tool__brandico { width: 18px; height: 18px; border-radius: 50%; background: transparent; border: none; }
.kd-tool__link-check .kd-tool__brandico .kd-tool__brandsvg { width: 11px; height: 11px; }

/* --- PAA --- */
.kd-tool__paa { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--kd-gap-sm); }
.kd-tool__paa-item {
	display: flex;
	align-items: center;
	gap: 9px;
	min-width: 0;
	padding: var(--kd-pad-sm);
	background: var(--kd-card-2);
	border: 1px solid var(--kd-line-soft);
	border-radius: 10px;
	font-size: 12.5px;
	color: var(--kd-text-soft);
}
.kd-tool__paa-item svg { flex: 0 0 auto; color: var(--kd-text-mute); width: 13px; height: 13px; }
.kd-tool__paa-q { min-width: 0; overflow-wrap: anywhere; }

/* =========================== CTA =========================== */
.kd-tool__cta {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 11px 18px;
	background: linear-gradient(180deg, #131829, #0d111d);
	border-top: 1px solid var(--kd-line);
	flex: 0 0 auto;
	transition: transform .3s ease, opacity .3s ease;
}
.kd-tool__cta.is-dismissed {
	transform: translateY(110%);
	opacity: 0;
	height: 0;
	padding: 0;
	margin: 0;
	overflow: hidden;
	pointer-events: none;
}
.kd-tool__cta-text { display: flex; flex-direction: column; line-height: 1.35; margin-right: auto; min-width: 0; }
.kd-tool__cta-text b { font-size: 13.5px; color: var(--kd-text); }
.kd-tool__cta-text span { font-size: 12px; color: var(--kd-text-mute); }
.kd-tool__cta-btn {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	padding: 9px 18px;
	background: var(--kd-primary);
	color: #1a1206 !important;
	font-size: 13px;
	font-weight: 700;
	text-decoration: none;
	border-radius: 10px;
	white-space: nowrap;
	transition: filter .16s, transform .16s;
}
.kd-tool__cta-btn:hover { filter: brightness(1.08); transform: translateY(-1px); }
.kd-tool__cta-btn svg { width: 15px; height: 15px; color: #1a1206; }
.kd-tool__cta-dismiss {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font: inherit;
	font-size: 12px;
	font-weight: 600;
	color: var(--kd-text-mute);
	background: transparent;
	border: 1px solid var(--kd-line);
	padding: 8px 13px;
	border-radius: 10px;
	cursor: pointer;
	white-space: nowrap;
	transition: color .16s, border-color .16s;
}
.kd-tool__cta-dismiss:hover { color: var(--kd-text-soft); border-color: var(--kd-text-mute); }
.kd-tool__cta-dismiss:focus-visible { outline: 2px solid var(--kd-primary); outline-offset: 2px; }
.kd-tool__cta-dismiss svg { width: 12px; height: 12px; }

/* =========================== ORYGINALNE LOGOTYPY SILNIKÓW =========================== */
/* Globalny guard SVG nadaje 16px; tu dajemy sztywny rozmiar i brandowy kolor.
   Logotypy są jednobarwne (fill=currentColor) — kolor steruje .kd-tool__brand--*. */
.kd-tool__brandsvg { width: 15px; height: 15px; flex: 0 0 auto; }

/* nagi logotyp w okrągłej/zaokrąglonej pigułce (czytelność w ciemnym motywie) */
.kd-tool__brandico {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	flex: 0 0 auto;
	border-radius: 7px;
	background: rgba(255, 255, 255, .07);
	border: 1px solid var(--kd-line-soft);
}
.kd-tool__brandico .kd-tool__brandsvg { width: 14px; height: 14px; }

/* logotyp + etykieta tekstowa (pigułka źródła / silnika) */
.kd-tool__brand {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 4px 11px 4px 7px;
	border-radius: 999px;
	background: var(--kd-card-2);
	border: 1px solid var(--kd-line-soft);
	font-size: 11.5px;
	font-weight: 600;
	color: var(--kd-text-soft);
	white-space: nowrap;
}
.kd-tool__brand .kd-tool__brandsvg { width: 15px; height: 15px; }

/* brandowe kolory logotypów (czytelne na ciemnym tle) */
.kd-tool__brand--google .kd-tool__brandsvg     { color: #4285f4; }
.kd-tool__brand--openai .kd-tool__brandsvg     { color: #e6e9f2; }
.kd-tool__brand--claude .kd-tool__brandsvg     { color: #d97757; }
.kd-tool__brand--gemini .kd-tool__brandsvg     { color: #8e7bff; }
.kd-tool__brand--perplexity .kd-tool__brandsvg { color: #20b8cd; }

/* rząd pigułek silników (np. w Chat Summary na zakładce Brief) */
.kd-tool__brandrow { display: flex; flex-wrap: wrap; gap: var(--kd-gap-sm); margin-bottom: var(--kd-gap); }

/* lista Chat Summary per silnik (GEO/AIO) */
.kd-tool__chatlist { display: flex; flex-direction: column; gap: var(--kd-gap-sm); }
.kd-tool__chatitem {
	display: flex;
	flex-direction: column;
	gap: 7px;
	padding: var(--kd-pad-sm);
	background: var(--kd-card-2);
	border: 1px solid var(--kd-line-soft);
	border-radius: 10px;
}
.kd-tool__chatitem .kd-tool__brand { align-self: flex-start; }

/* bar-label z logotypem (pokrycie tematu wg źródła) */
.kd-tool__bar-label { display: flex; align-items: center; gap: 6px; }
.kd-tool__bar-label .kd-tool__brandico { width: 19px; height: 19px; border-radius: 6px; }
.kd-tool__bar-label .kd-tool__brandico .kd-tool__brandsvg { width: 11px; height: 11px; }

/* =========================== SERP CLASSIC (lista wyników) =========================== */
.kd-tool__serp { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--kd-gap-sm); }
.kd-tool__serp-item {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	padding: var(--kd-pad-sm);
	background: var(--kd-card-2);
	border: 1px solid var(--kd-line-soft);
	border-radius: 10px;
	transition: border-color .16s;
}
.kd-tool__serp-item:hover { border-color: rgba(251, 118, 29, .4); }
.kd-tool__serp-pos {
	flex: 0 0 auto;
	width: 24px;
	height: 24px;
	border-radius: 7px;
	background: var(--kd-primary-soft);
	color: var(--kd-primary);
	font-size: 12px;
	font-weight: 800;
	display: flex;
	align-items: center;
	justify-content: center;
}
.kd-tool__serp-body { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.kd-tool__serp-title { font-size: 13.5px; font-weight: 600; color: #8ab4f8; line-height: 1.35; }
.kd-tool__serp-url {
	display: flex;
	align-items: center;
	gap: 5px;
	font-size: 11.5px;
	color: var(--kd-up);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.kd-tool__serp-url svg { width: 10px; height: 10px; color: var(--kd-text-mute); }
.kd-tool__serp-desc { font-size: 12.5px; line-height: 1.5; color: var(--kd-text-soft); }
/* data publikacji w stylu Google: szary prefiks przed snippetem */
.kd-tool__serp-date { color: var(--kd-text-mute); }
.kd-tool__serp-desc .kd-tool__serp-date::after { content: " — "; }
/* znacznik wideo (YouTube) */
.kd-tool__serp-item--video .kd-tool__serp-pos {
	background: rgba(255, 95, 87, .14);
	color: #ff7a73;
}
.kd-tool__serp-vidtag {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	align-self: flex-start;
	margin-top: 2px;
	font-size: 10.5px;
	font-weight: 700;
	color: #ff7a73;
	background: rgba(255, 95, 87, .1);
	border: 1px solid rgba(255, 95, 87, .26);
	padding: 2px 8px;
	border-radius: 999px;
}
.kd-tool__serp-vidtag svg { width: 11px; height: 11px; color: #ff7a73; }

/* =========================== TREŚĆ (SCRAPED CONTENT) =========================== */
.kd-tool__sc {
	display: grid;
	grid-template-columns: 220px minmax(0, 1fr);   /* minmax(0,..) -> prawa kolumna nie rozpycha siatki */
	gap: var(--kd-gap);
	align-items: start;
}
.kd-tool__sc-list {
	display: flex;
	flex-direction: column;
	gap: var(--kd-gap-sm);
	min-width: 0;
	max-width: 100%;
	box-sizing: border-box;
	padding: var(--kd-pad);
	background: var(--kd-card);
	border: 1px solid var(--kd-line-soft);
	border-radius: var(--kd-radius);
	overflow: hidden;        /* sidebar trzyma boxy w ryzach (desktop) */
}
.kd-tool__sc-list .kd-tool__eyebrow { margin-bottom: 2px; }
.kd-tool__sc-src {
	display: flex;
	align-items: center;
	gap: 10px;
	width: 100%;
	min-width: 0;            /* pozwala dziecku (srcmeta) realnie się skurczyć -> ellipsis działa */
	max-width: 100%;
	box-sizing: border-box;
	padding: 9px 10px;
	background: transparent;
	border: 1px solid var(--kd-line-soft);
	border-radius: 10px;
	cursor: pointer;
	text-align: left;
	font: inherit;
	overflow: hidden;        /* żaden tekst nie wyjdzie poza ramkę boxa */
	transition: border-color .16s, background .16s;
}
.kd-tool__sc-src:hover { border-color: rgba(251, 118, 29, .35); }
.kd-tool__sc-src:focus-visible { outline: 2px solid var(--kd-primary); outline-offset: 2px; }
.kd-tool__sc-src.is-active { border-color: var(--kd-primary); background: var(--kd-primary-soft); }
.kd-tool__sc-fav {
	flex: 0 0 auto;
	width: 26px;
	height: 26px;
	border-radius: 7px;
	background: var(--kd-card-2);
	border: 1px solid var(--kd-line-soft);
	display: flex;
	align-items: center;
	justify-content: center;
}
.kd-tool__sc-fav svg { color: var(--kd-text-mute); width: 14px; height: 14px; }
.kd-tool__sc-src.is-active .kd-tool__sc-fav svg { color: var(--kd-primary); }
.kd-tool__sc-srcmeta { display: flex; flex-direction: column; flex: 1 1 auto; min-width: 0; max-width: 100%; line-height: 1.3; }
.kd-tool__sc-srctitle { max-width: 100%; font-size: 12px; font-weight: 600; color: var(--kd-text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.kd-tool__sc-srcdom { max-width: 100%; font-size: 10.5px; color: var(--kd-text-mute); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* prawa kolumna: kontener wszystkich dokumentów (tylko aktywny widoczny) */
.kd-tool__sc-docwrap { min-width: 0; }
.kd-tool__sc-doc {
	background: var(--kd-card);
	border: 1px solid var(--kd-line-soft);
	border-radius: var(--kd-radius);
	padding: var(--kd-pad);
	min-width: 0;
	display: none;
}
.kd-tool__sc-doc.is-active { display: block; }
.kd-tool__sc-doc[hidden] { display: none; }
.kd-tool__sc-head { padding-bottom: var(--kd-gap); border-bottom: 1px solid var(--kd-line-soft); margin-bottom: var(--kd-gap); }
.kd-tool__sc-title { display: flex; align-items: flex-start; gap: 8px; margin: 0 0 7px; font-size: 14.5px; font-weight: 700; color: var(--kd-text); line-height: 1.35; }
.kd-tool__sc-title svg { color: var(--kd-primary); width: 17px; height: 17px; margin-top: 1px; }
.kd-tool__sc-url {
	display: flex;
	align-items: center;
	gap: 5px;
	font-size: 12px;
	color: var(--kd-up);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	margin-bottom: 9px;
}
.kd-tool__sc-url svg { width: 11px; height: 11px; color: var(--kd-text-mute); }
.kd-tool__sc-meta { display: flex; flex-wrap: wrap; gap: 7px; }
.kd-tool__sc-tag {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-size: 10.5px;
	font-weight: 600;
	color: var(--kd-text-mute);
	background: var(--kd-card-2);
	border: 1px solid var(--kd-line-soft);
	padding: 3px 9px;
	border-radius: 999px;
}
.kd-tool__sc-tag svg { width: 11px; height: 11px; color: var(--kd-text-mute); }
.kd-tool__sc-content { display: flex; flex-direction: column; }
.kd-tool__sc-content .kd-tool__sc-h {
	margin: var(--kd-gap) 0 6px;
	font-size: 13px;
	font-weight: 700;
	color: var(--kd-text);
}
.kd-tool__sc-content .kd-tool__sc-h:first-child { margin-top: 0; }
.kd-tool__sc-content p { margin: 0; font-size: 12.5px; line-height: 1.6; color: var(--kd-text-soft); }
.kd-tool__sc-content p b { color: var(--kd-text); font-weight: 700; }

/* =========================== TABLET =========================== */
@media (max-width: 980px) {
	.kd-tool__grid { grid-template-columns: 1fr; }
	.kd-tool__insights { grid-template-columns: 1fr; }
	.kd-tool__sc { grid-template-columns: 180px 1fr; }
	.kd-tool__window { aspect-ratio: 16 / 11; }
}

/* =========================== MOBILE (≤767px) — HAMBURGER =========================== */
@media (max-width: 767px) {
	/* zacieśniamy WSPÓLNY rytm odstępów — wszystkie zakładki kurczą się równo */
	.kd-tool { --kd-gap: 10px; --kd-gap-sm: 7px; --kd-pad: 13px; --kd-pad-sm: 10px; --kd-stage-pad: 12px; }
	/* MOBILE: WYSOKA ramka (wygodny kafelek, nie pasek). Treść scrolluje się w środku.
	   Brak aspect-ratio = brak wymuszonej proporcji, która robiła panel za niskim. */
	.kd-tool__window { aspect-ratio: auto; height: clamp(540px, 80vh, 700px); border-radius: 14px; }
	.kd-tool__chrome { padding: 7px 10px; gap: 8px; }
	.kd-tool__chrome-nav { display: none; }
	.kd-tool__address { padding: 5px 10px; }
	.kd-tool__topbar { min-height: 42px; padding: 7px 12px; gap: 9px; }
	.kd-tool__topbadge { display: none; }

	/* CHOWAMY poziomy rząd zakładek, POKAZUJEMY hamburger z etykietą aktywnego widoku */
	.kd-tool__tabsbar {
		padding: 8px 10px;
		background: #0c1019;
		border-bottom: 1px solid var(--kd-line-soft);
	}
	.kd-tool__tabs { display: none; }
	.kd-tool__burger {
		display: flex;
		align-items: center;
		gap: 9px;
		width: 100%;
		min-height: 44px;
		padding: 9px 12px;
		border: 1px solid var(--kd-line);
		border-radius: 10px;
		background: var(--kd-bg);
		color: var(--kd-text);
		font: inherit;
		font-size: 13.5px;
		font-weight: 700;
		cursor: pointer;
		text-align: left;
		transition: border-color .16s, background .16s;
	}
	.kd-tool__burger:hover { border-color: var(--kd-text-mute); }
	.kd-tool__burger:focus-visible { outline: 2px solid var(--kd-primary); outline-offset: 2px; }
	.kd-tool__burger-ic { display: inline-flex; flex: 0 0 auto; color: var(--kd-primary); }
	.kd-tool__burger-ic svg { color: var(--kd-primary); }
	.kd-tool__burger-label { flex: 1 1 auto; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
	.kd-tool__burger-chev { display: inline-flex; flex: 0 0 auto; color: var(--kd-text-mute); transition: transform .18s ease; }
	.kd-tool__burger[aria-expanded="true"] .kd-tool__burger-chev { transform: rotate(180deg); }

	/* rozwijane menu (dropdown) — 6 pozycji = te same widoki */
	.kd-tool__menu {
		display: block;
		position: absolute;
		left: 10px;
		right: 10px;
		top: calc(100% - 4px);
		z-index: 30;
		margin: 0;
		padding: 6px;
		list-style: none;
		background: var(--kd-card);
		border: 1px solid var(--kd-line);
		border-radius: 12px;
		box-shadow: 0 18px 40px -12px rgba(0, 0, 0, .8);
		max-height: 60vh;
		overflow-y: auto;
		scrollbar-width: thin;
	}
	.kd-tool__menu[hidden] { display: none; }
	.kd-tool__menuitem {
		display: flex;
		align-items: center;
		gap: 11px;
		width: 100%;
		min-height: 44px;
		padding: 10px 12px;
		border: 1px solid transparent;
		border-radius: 9px;
		background: transparent;
		color: var(--kd-text-soft);
		font: inherit;
		font-size: 13.5px;
		font-weight: 600;
		cursor: pointer;
		text-align: left;
		transition: color .16s, background .16s;
	}
	.kd-tool__menuitem svg { width: 16px; height: 16px; flex: 0 0 auto; color: var(--kd-text-mute); }
	.kd-tool__menuitem:hover { background: rgba(255, 255, 255, .04); color: var(--kd-text); }
	.kd-tool__menuitem:focus-visible { outline: 2px solid var(--kd-primary); outline-offset: -2px; }
	.kd-tool__menuitem.is-active {
		color: var(--kd-text);
		background: var(--kd-primary-soft);
		border-color: rgba(251, 118, 29, .3);
	}
	.kd-tool__menuitem.is-active svg { color: var(--kd-primary); }

	.kd-tool__statgrid { grid-template-columns: 1fr 1fr; }
	.kd-tool__bar-row { grid-template-columns: 88px minmax(0, 1fr) 48px; gap: 7px; }
	.kd-tool__query { font-size: 16px; word-break: break-word; }
	/* anti-overflow: na wąskim ekranie nic nie może być szersze niż kolumna */
	.kd-tool__brandrow { gap: 6px; }
	.kd-tool__brand { white-space: normal; }
	.kd-tool__serp-item { gap: 9px; }
	/* SERP + scraped: kolumna na mobile */
	.kd-tool__sc { grid-template-columns: 1fr; }
	.kd-tool__sc-list { flex-direction: row; flex-wrap: nowrap; overflow-x: auto; overflow-y: hidden; scrollbar-width: none; max-width: 100%; -webkit-overflow-scrolling: touch; }
	.kd-tool__sc-list::-webkit-scrollbar { display: none; }
	.kd-tool__sc-list .kd-tool__eyebrow { display: none; }
	/* na mobile boxy są stałej szerokości w poziomym pasku — tekst nadal ucinany ellipsis */
	.kd-tool__sc-src { flex: 0 0 auto; width: auto; min-width: 160px; max-width: 72vw; min-height: 44px; }
	/* pod-zakładki Źródeł: zwijalne w wiersz + dotykowe cele ≥40px */
	.kd-tool__srctabs { flex-wrap: wrap; gap: 7px; }
	.kd-tool__srctab { min-height: 40px; padding: 8px 14px 8px 10px; }
	.kd-tool__paa-item { min-height: 40px; }
	.kd-tool__cta { flex-wrap: wrap; gap: 10px; padding: 10px 12px; }
	.kd-tool__cta-text { flex: 1 1 100%; }
	.kd-tool__cta-btn, .kd-tool__cta-dismiss { flex: 1 1 auto; justify-content: center; min-height: 40px; }
}

/* =========================== REDUCED MOTION =========================== */
@media (prefers-reduced-motion: reduce) {
	.kd-tool *,
	.kd-tool *::before,
	.kd-tool *::after {
		transition: none !important;
		animation: none !important;
	}
}
