.material { font-family: "Material Symbols Outlined"; font-weight: normal; font-style: normal; font-size: 24px; line-height: 1; letter-spacing: normal; text-transform: none; display: inline-block; white-space: nowrap; word-wrap: normal; direction: ltr; -webkit-font-feature-settings: "liga"; -webkit-font-smoothing: antialiased; }
button .material { vertical-align: middle; }
.material--300 { font-weight: 300; }
.material--300 { font-variation-settings: "FILL" 0, "wght" 300, "GRAD" 0, "opsz" 24; }
.material--filled { font-variation-settings: "FILL" 1, "wght" 400, "GRAD" 0, "opsz" 24; }
/*Boilerplate*/
:root {
	--btn-hover: var(--c-accent-2);
	--highlight-color: var(--c-accent);
	--font-size: 16px;
}
body { font-family: "Roboto", Arial, sans-serif; background: var(--radial-gradient), linear-gradient(180deg, var(--c-bg-2), var(--c-bg)); color: var(--c-text); font-size: var(--font-size); margin: 0; padding: 0; }
body * { -webkit-appearance: none; -moz-appearance: none; appearance: none; box-sizing: border-box; }
* { scrollbar-width: thin !important; scrollbar-color: transparent transparent !important; }
*:hover { scrollbar-color: var(--c-border) transparent !important; }
*::-webkit-scrollbar { width: 8px !important; height: 8px !important; }
*::-webkit-scrollbar-track { background: transparent !important; }
*::-webkit-scrollbar-thumb { background: transparent !important; border-radius: var(--r-pill) !important; }
*:hover::-webkit-scrollbar-thumb { background: var(--c-border) !important; }
input[type="text"] { border: 1px solid var(--c-border); background: var(--c-bg-3); color: var(--c-text); outline: none; }
input[type="text"]:focus { border-color: var(--c-accent-glow); box-shadow: var(--ring-accent); }
select { border: 1px solid var(--c-border); padding-right: 20px; border-radius: var(--r-1); background: var(--c-bg-3); color: var(--c-text); outline: none; }
select:focus { border-color: var(--c-accent-glow); box-shadow: var(--ring-accent); }
#loader { top: 0; left: 0; position: fixed; z-index: 100; width: 100vw; height: 100dvh; display: none; }
#loader__circle, .tpf__loaderCircle { height: 40px; width: 40px; border-radius: 50%; border: 4px solid rgba(255, 255, 255, 0); border-top-color: var(--c-accent); border-right-color: var(--c-accent); animation: circle-spin 4s infinite linear; position: absolute; left: calc(50% - 20px); top: calc(50% - 20px); }
#loader__bg { width: 100%; height: 100%; opacity: 0.55; background: rgba(0, 0, 0, 0.55); backdrop-filter: blur(8px); }
@keyframes circle-spin {
	0% { transform: rotate(0deg); border-top-color: var(--c-accent); border-right-color: var(--c-accent); }
	50% { border-top-color: var(--c-accent-glow); border-right-color: var(--c-accent-glow); }
	100% { transform: rotate(720deg); border-top-color: var(--c-accent); border-right-color: var(--c-accent); }
}
.material-icons { -webkit-touch-callout: none; -webkit-user-select: none; -khtml-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; }
input[type="checkbox"] { padding: 0; width: 20px; height: 20px; border: 1px solid var(--c-border); vertical-align: middle; text-align: center; outline: none; background: var(--c-bg-3); color: var(--c-text); border-radius: 6px; }
input[type="checkbox"]:checked { border-color: var(--c-accent-glow); color: var(--c-text-strong); background: var(--c-accent-glow-2); }
input[type="checkbox"]:checked:after { content: "\2713"; }
button, input, select, textarea { font-family: Roboto; }
button.button { -webkit-touch-callout: none; -webkit-user-select: none; -khtml-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; background: var(--c-panel-2); border: 1px solid var(--c-border); display: inline-block; cursor: pointer; color: var(--c-text-strong); font-size: 13px; padding: 6px 10px; text-decoration: none; text-shadow: none; margin: 0 2px; border-radius: 10px; transition: transform 0.12s ease, background 0.12s ease, border-color 0.12s ease, box-shadow 0.12s ease; }
button.button:hover { background: var(--c-panel); border-color: rgba(170, 220, 255, 0.22); box-shadow: 0 0 0 3px rgba(170, 220, 255, 0.1); transform: translateY(-1px); }
button.button:active { transform: translateY(0); box-shadow: none; }
input.text-input, textarea.text-input { background: transparent; padding: 6px 0; border: 0; outline: none; border-bottom: 1px solid var(--c-border); font-size: 16px; font-weight: normal; color: var(--c-text); }
input.text-input:focus, textarea.text-input:focus { border-color: var(--c-accent-glow); box-shadow: 0 3px 0 -2px var(--c-accent-glow); }
i.material-icons, span.material-icons { cursor: pointer; color: var(--c-text-dim); }
i.material-icons:hover, span.material-icons:hover { color: var(--c-text-strong); }
#lbar { display: none; background-color: transparent; height: 5px; width: 100%; top: 0; position: absolute; z-index: 10; }
#lbar.show { display: block !important; }
#lbar__cont { padding: 0; border-radius: 0; }
#lbar__inner { border-radius: 0; height: 5px; background-color: var(--c-accent); }
.mButton { outline: none; border: 1px solid var(--c-border); cursor: pointer; font-weight: 950; box-sizing: border-box; padding: 10px 14px; margin: 0 8px 0 0; position: relative; background: var(--c-panel-2); color: var(--c-text-strong); font-family: inherit; box-shadow: none; border-radius: 14px; letter-spacing: 0.08em; text-transform: uppercase; font-size: 12px; transition: transform 0.12s ease, background 0.12s ease, opacity 0.12s ease, border-color 0.12s ease, box-shadow 0.12s ease; }
.mButton:hover { background: var(--c-panel); transform: translateY(-1px); border-color: rgba(170, 220, 255, 0.22); box-shadow: 0 0 0 3px rgba(170, 220, 255, 0.1); }
.mButton:active { transform: translateY(0); box-shadow: none; }
.mButton--flat { background: transparent; color: var(--c-text); border-radius: 14px; box-shadow: none; border: 1px solid var(--c-border); padding: 10px 14px; }
.mButton--flat:hover { background: var(--c-hover); border-color: rgba(170, 220, 255, 0.22); }
button.mButton--light:not(.mButton--flat) { background: rgba(170, 220, 255, 0.16); color: var(--c-text-strong); border-color: rgba(170, 220, 255, 0.22); }
.mButton--flat.mButton--animated:not(:active) { animation-name: button-press; animation-duration: 0.4s; animation-timing-function: ease-in-out; }
.mButton:not(.mButton--flat)::after { position: absolute; content: ""; height: 100%; width: 100%; top: 0; left: 0; pointer-events: none; background-image: radial-gradient(circle at center, rgba(255, 255, 255, 0.22) 0%, rgba(255, 255, 255, 0.22) 10%, transparent 11%, transparent 100%); background-size: 1% 1%; background-position: center; background-repeat: no-repeat; background-color: transparent; transition: 1s opacity ease, 0.5s background-size ease-in 0.3s; opacity: 0; border-radius: 14px; }
.mButton:not(.mButton--flat):active::after { background-size: 1000% 1000%; transition: 0.2s background-size ease-out, 0s opacity ease-in; opacity: 0.45; }
.prompt { position: fixed; width: 520px; box-sizing: border-box; left: 50%; transform: translateX(-50%) translateY(8px) scale(0.985); top: 110px; box-shadow: var(--shadow-1); background: color-mix(in srgb, var(--c-bg-3) 72%, transparent); border: 1px solid var(--c-border); backdrop-filter: blur(14px); z-index: 110; opacity: 0; pointer-events: none; transition: opacity 0.18s ease, transform 0.18s ease; border-radius: var(--r-3); }
@media (max-width: 600px) {
	.prompt { width: calc(100vw - 24px); left: 12px; transform: translateY(8px) scale(0.985); top: 90px; }
}
.prompt__header { background: none; padding: 18px 18px 10px; color: var(--c-text-strong) !important; font-size: 18px; font-weight: 950; letter-spacing: -0.01em; text-align: left; border-bottom: 1px solid var(--c-border); }
.prompt__background { z-index: 108; position: fixed; width: 100vw; height: 100dvh; top: 0; left: 0; background: rgba(0, 0, 0, 0.62); opacity: 0; transition: opacity 0.18s ease; }
.prompt__background--showing { opacity: 1; }
.prompt__ok { display: flex; align-items: center; }
.prompt.prompt--showing { opacity: 1; transform: translateX(-50%) translateY(0) scale(1); pointer-events: auto; }
@media (max-width: 600px) {
	.prompt.prompt--showing { transform: translateY(0) scale(1); }
}
.prompt__content { padding: 16px 18px 18px; }
.prompt__msg { padding: 0; margin: 0 0 12px; font-weight: 600; line-height: 1.6; max-height: 46dvh; overflow-y: auto; font-size: 14px; color: var(--c-text-muted); }
.prompt__msg .prompt__link { color: var(--c-accent); text-decoration: none; }
.prompt__msg .prompt__link:hover { color: var(--c-accent-2); text-decoration: underline; }
.prompt__buttons { text-align: right; margin-top: 12px; display: flex; justify-content: flex-end; gap: 10px; align-items: center; }
.prompt__buttons span:last-child, .prompt__buttons button:last-child { margin-right: 0; }
.prompt__buttons *:focus { color: var(--c-text-strong) !important; }
.prompt__ta { height: 160px; font-size: 14px; font-family: inherit; resize: none; width: 100%; box-sizing: border-box; padding: 12px; background: rgba(255, 255, 255, 0.05); border: 1px solid var(--c-border); border-radius: var(--r-2); color: var(--c-text-strong); outline: none; }
.prompt__ta:focus { border-color: var(--c-accent-glow); box-shadow: var(--ring-accent); }
.prompt__input[type="text"] { color: var(--c-text-strong); padding: 11px 12px; border: 1px solid var(--c-border); width: 100%; box-sizing: border-box; border-radius: var(--r-2); background: rgba(255, 255, 255, 0.05); outline: none; }
.prompt__input[type="text"]:focus { border-color: var(--c-accent-glow); box-shadow: var(--ring-accent); }
.prompt__toast { position: fixed; left: 50%; top: 50px; transform: translateX(-50%); z-index: 999999; padding: 10px 14px; border-radius: var(--r-2); background: var(--c-accent); color: var(--c-text-strong); font-size: 14px; opacity: 0; transition: opacity 0.15s ease; box-shadow: var(--shadow-2); }
.prompt__toast--showing { opacity: 1; }
h1 { color: var(--c-text-strong); font-family: Roboto; font-weight: 900; margin: 0; font-size: 28px; }
@keyframes button-press {
	50% { border-radius: 0; background-color: rgba(170, 220, 255, 0.14); }
}
.pattern { display: inline-block; width: 55px; height: 50px; background-image: var(--patterns-sprite); background-color: var(--c-text); vertical-align: bottom; }
.pattern__convergence { background-color: var(--c-text); background-position-x: -158px; background-position-y: -52px; }
.pattern__divergence { background-color: var(--c-text); background-position-x: -158px; background-position-y: -156px; }
.pattern__cyclicality { background-color: var(--c-text); background-position-x: -158px; background-position-y: -104px; }
.pattern__redirection { background-color: var(--c-text); background-position-x: -158px; background-position-y: -208px; }
.pattern__reduction { background-color: var(--c-text); background-position-x: -158px; background-position-y: -260px; }
.pattern__acceleration { background-color: var(--c-text); background-position-x: -158px; background-position-y: 0px; }
.pattern__convergence.pattern--active { background-color: #6fd04a; }
.pattern__divergence.pattern--active { background-color: #ee4bb6; }
.pattern__cyclicality.pattern--active { background-color: #6c46d6; }
.pattern__redirection.pattern--active { background-color: #00a2a5; }
.pattern__reduction.pattern--active { background-color: #ff6914; }
.pattern__acceleration.pattern--active { background-color: #00a2f6; }
.patternColor { display: inline-block; width: 55px; height: 60px; vertical-align: bottom; }
.patternColor__convergence { background-image: url("https://cdn.trendhunterstatic.com/icons/pt/updated/patterns_opp_convergence-lime.png"); background-size: cover; background-repeat: no-repeat; }
.patternColor__divergence { background-image: url("https://cdn.trendhunterstatic.com/icons/pt/updated/patterns_opp_divergence-magenta.png"); background-size: cover; background-repeat: no-repeat; }
.patternColor__cyclicality { background-image: url("https://cdn.trendhunterstatic.com/icons/pt/updated/patterns_opp_cyclicality-plum.png"); background-size: cover; background-repeat: no-repeat; }
.patternColor__redirection { background-image: url("https://cdn.trendhunterstatic.com/icons/pt/updated/patterns_opp_redirection-teal.png"); background-size: cover; background-repeat: no-repeat; }
.patternColor__reduction { background-image: url("https://cdn.trendhunterstatic.com/icons/pt/updated/patterns_opp_reduction-orange.png"); background-size: cover; background-repeat: no-repeat; }
.patternColor__acceleration { background-image: url("https://cdn.trendhunterstatic.com/icons/pt/updated/patterns_opp_acceleration-blue.png"); background-size: cover; background-repeat: no-repeat; }
.mt { display: inline-block; vertical-align: bottom; width: 55px; height: 50px; background-size: cover; background-repeat: no-repeat; }
.mt__title { text-transform: uppercase; color: var(--c-text-strong); font-size: 12px; font-weight: 500; }
.mt__cont { vertical-align: middle; display: inline-block; }
.mt__artificial-intelligence { background-image: url("https://cdn.trendhunterstatic.com/trendreport/webreport/m50/artificial-intelligence-50.png"); }
.mt__prosumerism { background-image: url("https://cdn.trendhunterstatic.com/trendreport/webreport/m50/prosumerism-50.png"); }
.mt__catalyzation { background-image: url("https://cdn.trendhunterstatic.com/trendreport/webreport/m50/catalyzation-50.png"); }
.mt__nostalgia { background-image: url("https://cdn.trendhunterstatic.com/trendreport/webreport/m50/nostalgia-50.png"); }
.mt__naturality { background-image: url("https://cdn.trendhunterstatic.com/trendreport/webreport/m50/naturality-50.png"); }
.mt__youthfulness { background-image: url("https://cdn.trendhunterstatic.com/trendreport/webreport/m50/youthfulness-50.png"); }
.mt__instant-entrepreneurship { background-image: url("https://cdn.trendhunterstatic.com/trendreport/webreport/m50/instant-entrepreneurship-50.png"); }
.mt__simplicity { background-image: url("https://cdn.trendhunterstatic.com/trendreport/webreport/m50/simplicity-50.png"); }
.mt__curation { background-image: url("https://cdn.trendhunterstatic.com/trendreport/webreport/m50/curation-50.png"); }
.mt__tribalism { background-image: url("https://cdn.trendhunterstatic.com/trendreport/webreport/m50/tribalism-50.png"); }
.mt__experience { background-image: url("https://cdn.trendhunterstatic.com/trendreport/webreport/m50/experience-50.png"); }
.mt__gamification { background-image: url("https://cdn.trendhunterstatic.com/trendreport/webreport/m50/gamification-50.png"); }
.mt__multisensation { background-image: url("https://cdn.trendhunterstatic.com/trendreport/webreport/m50/multisensation-50.png"); }
.mt__hybridization { background-image: url("https://cdn.trendhunterstatic.com/trendreport/webreport/m50/hybridization-50.png"); }
.mt__co-creation { background-image: url("https://cdn.trendhunterstatic.com/trendreport/webreport/m50/co-creation-50.png"); }
.mt__authenticity { background-image: url("https://cdn.trendhunterstatic.com/trendreport/webreport/m50/authenticity-50.png"); }
.mt__many-to-many { background-image: url("https://cdn.trendhunterstatic.com/trendreport/webreport/m50/many-to-many-50.png"); }
.mt__personalization { background-image: url("https://cdn.trendhunterstatic.com/trendreport/webreport/m50/personalization-50.png"); }
/* .age{display:inline-block;vertical-align:bottom; width:50px; height:50px; background-size:cover; background-repeat:no-repeat;}
.age__0_2{background-image:url('https://cdn.trendhunterstatic.com/demographicspng/newlight/Demographic_White_01.png');}
.age__under_12{background-image:url('https://cdn.trendhunterstatic.com/demographicspng/newlight/Demographic_White_02.png');}
.age__12_18{background-image:url('https://cdn.trendhunterstatic.com/demographicspng/newlight/Demographic_White_03.png');}
.age__18_35{background-image:url('https://cdn.trendhunterstatic.com/demographicspng/newlight/Demographic_White_04.png');}
.age__35_55{background-image:url('https://cdn.trendhunterstatic.com/demographicspng/newlight/Demographic_White_05.png');}
.age__over_55{background-image:url('https://cdn.trendhunterstatic.com/demographicspng/newlight/Demographic_White_06.png');}

.region{display:inline-block; width:55px;height:50px;background-image:url('https://cdn.trendhunterstatic.com/sprites/regions-sprite-thgpt.png'); background-color:transparent;vertical-align:bottom; }
.region__africa{}
.region__asia{}
.region__europe{}
.region__north_america{}
.region__south_america{} */
.tpf__pList { display: flex; flex-flow: column; }
.tpf__pListItem { border: 1px solid black; font-size: var(--font-size); padding: 5px; width: 100%; display: block; text-decoration: none; font-weight: 500; color: inherit; margin-bottom: 5px; cursor: pointer; display: flex; flex-flow: row; justify-content: space-between; }
.tpf__pListItem:last-child { margin-bottom: 0px; }
.tpf__pListItem:hover { color: white; background-color: black; }
.tgt__textLink { color: inherit; font-size: var(--font-size); }
.tgt__textLink:hover { text-decoration: underline; }
.thgpt__pop.thgpt__pop--pmt {
	.thgpt__popSubTitle {
		display: flex; text-align: left; align-items: center; margin-top: 14px;
		span { width: 100%; font-size: 18px; }
	}
	.pattern, .mt { margin-right: 15px; }
	iframe { width: 100%; margin: 15px 0; }
	.thgpt__popBody {
		white-space: normal;
		label { font-size: 18px; font-weight: 600; margin-bottom: 15px; display: block; }
	}
	.tgta__related {
		font-size: 14px; font-weight: 400; display: flex; margin-bottom: 25px; align-items: center;
		.rel__cont {
			width: 100%; display: flex; flex-direction: column;
			.rel__title { font-size: 16px; }
		}
	}
}
.material.item--islocked { font-size: 17px; }
.cardRowRefreshImg .item--islocked { font-size: 14px; }
:root {
	--r-1: 6px;
	--r-2: 12px;
	--r-3: 18px;
	--r-pill: 999px;
	--s-1: 6px;
	--s-2: 10px;
	--s-3: 14px;
	--s-4: 18px;
	--s-5: 25px;
	--c-bg: #050b12;
	--c-bg-2: #07121d;
	--c-bg-3: #091a28;
	--c-panel: #0b2333;
	--c-panel-2: #0f2d41;
	--c-text: rgba(236, 248, 255, 0.86);
	--c-text-strong: rgba(246, 253, 255, 0.96);
	--c-text-muted: rgba(198, 226, 240, 0.64);
	--c-text-dim: rgba(150, 190, 210, 0.38);
	--c-accent: #ff8a3a;
	--c-accent-2: #e6782e;
	--c-accent-glow: rgba(255, 138, 58, 0.18);
	--c-accent-glow-2: rgba(255, 138, 58, 0.08);
	--c-error: #b91c1c;
	--c-error-glow: rgba(255, 100, 80, 0.3);
	--c-error-shadow: rgba(185, 28, 28, 0.45);
	--c-border: rgba(170, 220, 255, 0.14);
	--c-hover: rgba(170, 220, 255, 0.1);
	--c-focus: rgba(130, 210, 255, 0.42);
	--c-border-2: rgba(255, 255, 255, 0.1);
	/* ---- effects ---- */ --shadow-1: 0 22px 70px rgba(0, 0, 0, 0.55);
	--shadow-2: 0 0 22px rgba(0, 0, 0, 0.7);
	--shadow-accent: inset 0 0 0 1px var(--c-accent-glow);
	--ring-accent: 0 0 0 3px var(--c-accent-glow);
	/* ---- atmosphere ---- */ --radial-gradient: radial-gradient(1200px 700px at 50% 8%, rgba(210, 245, 255, 0.08), rgba(0, 0, 0, 0) 60%), radial-gradient(900px 520px at 78% 0%, rgba(90, 200, 255, 0.16), rgba(0, 0, 0, 0) 55%), radial-gradient(900px 700px at 18% 88%, rgba(120, 230, 255, 0.08), rgba(0, 0, 0, 0) 62%);
	/* ---- layout constants ---- */ --sidebar-w: 280px;
	--sidebar-w-collapsed: 84px;
	--header-h: 64px;
	--panel-h: calc(100% - 2 * (var(--s-5)));
	/* ---- Images ---- */ --logo-url: url("https://cdn.trendhunterstatic.com/icons/ai-icon.png"); --horizon-logo: url("https://cdn.trendhunterstatic.com/logos/horizon/Horizon_Logo_White_NoTH.png"); --horizon-logo-with-th: url("https://cdn.trendhunterstatic.com/logos/horizon/Horizon_Logo_White.png");
	--demo-sprite: url("https://cdn.trendhunterstatic.com/sprites/demographics-sprite.png");
	--regions-sprite: url("https://cdn.trendhunterstatic.com/sprites/regions-sprite.png");
	--patterns-sprite: url("https://cdn.trendhunterstatic.com/sprites/megatrends-patterns-inverted-sprite.png");
}
/* BLUE GLASS */
body.theme--blue-glass { --c-bg: #050b12; --c-bg-2: #07121d; --c-bg-3: #091a28; --c-panel: #0b2333; --c-panel-2: #0f2d41; --c-text: rgba(236, 248, 255, 0.86); --c-text-strong: rgba(246, 253, 255, 0.96); --c-text-muted: rgba(198, 226, 240, 0.64); --c-text-dim: rgba(150, 190, 210, 0.38); --c-accent: #ff8a3a; --c-accent-2: #e6782e; --c-accent-glow: rgba(255, 138, 58, 0.18); --c-accent-glow-2: rgba(255, 138, 58, 0.08); --c-border: rgba(170, 220, 255, 0.14); --c-hover: rgba(170, 220, 255, 0.1); --c-focus: rgba(130, 210, 255, 0.42); --shadow-1: 0 22px 70px rgba(0, 0, 0, 0.55); --shadow-2: 0 0 4px rgba(0, 0, 0, 0.7); --shadow-accent: inset 0 0 0 1px var(--c-accent-glow); --ring-accent: 0 0 0 3px var(--c-accent-glow); --radial-gradient: radial-gradient(1200px 700px at 50% 8%, rgba(210, 245, 255, 0.08), rgba(0, 0, 0, 0) 60%), radial-gradient(900px 520px at 78% 0%, rgba(90, 200, 255, 0.16), rgba(0, 0, 0, 0) 55%), radial-gradient(900px 700px at 18% 88%, rgba(120, 230, 255, 0.08), rgba(0, 0, 0, 0) 62%); --demo-sprite: url("https://cdn.trendhunterstatic.com/sprites/demographics-sprite-thgpt-blueglass.png"); --regions-sprite: url("https://cdn.trendhunterstatic.com/sprites/regions-sprite-thgpt-blueglass.png?_t=1772742027185"); --patterns-sprite: url("https://cdn.trendhunterstatic.com/sprites/megatrends-patterns-sprite-thgpt-blueglass.png?_t=1772553481695"); }
/* GRAPHITE + ORANGE */
body.theme--graphite-orange { --c-bg: #06070a; --c-bg-2: #090b10; --c-bg-3: #0d1016; --c-panel: #0f131a; --c-panel-2: #141a24; --c-text: rgba(245, 247, 250, 0.86); --c-text-strong: rgba(255, 255, 255, 0.96); --c-text-muted: rgba(210, 218, 230, 0.62); --c-text-dim: rgba(170, 182, 200, 0.34); --c-accent: #ff8a3a; --c-accent-2: #e6782e; --c-accent-glow: rgba(255, 138, 58, 0.16); --c-accent-glow-2: rgba(255, 138, 58, 0.07); --c-border: rgba(255, 255, 255, 0.1); --c-hover: rgba(255, 255, 255, 0.06); --c-focus: rgba(255, 138, 58, 0.44); --shadow-1: 0 20px 60px rgba(0, 0, 0, 0.6); --shadow-2: 0 0 4px rgba(0, 0, 0, 0.76); --shadow-accent: inset 0 0 0 1px var(--c-accent-glow); --ring-accent: 0 0 0 3px var(--c-accent-glow); --radial-gradient: radial-gradient(1200px 700px at 50% 8%, rgba(255, 255, 255, 0.04), rgba(0, 0, 0, 0) 60%), radial-gradient(900px 520px at 78% 0%, var(--c-accent-glow), rgba(0, 0, 0, 0) 55%), radial-gradient(900px 700px at 18% 88%, rgba(255, 255, 255, 0.03), rgba(0, 0, 0, 0) 62%); --demo-sprite: url("https://cdn.trendhunterstatic.com/sprites/demographics-sprite-thgpt-graphite.png"); --regions-sprite: url("https://cdn.trendhunterstatic.com/sprites/regions-sprite-thgpt-graphite.png?_t=1772742027185"); --patterns-sprite: url("https://cdn.trendhunterstatic.com/sprites/megatrends-patterns-sprite-thgpt-graphite.png?_t=1772555978913"); }
/* MIDNIGHT TEAL */
body.theme--midnight-teal { --c-bg: #040c10; --c-bg-2: #06161b; --c-bg-3: #07242a; --c-panel: #082b31; --c-panel-2: #0b3640; --c-text: rgba(232, 252, 255, 0.86); --c-text-strong: rgba(247, 254, 255, 0.96); --c-text-muted: rgba(190, 234, 242, 0.64); --c-text-dim: rgba(140, 200, 210, 0.38); --c-accent: #ff8a3a; --c-accent-2: #e6782e; --c-accent-glow: rgba(255, 138, 58, 0.18); --c-accent-glow-2: rgba(255, 138, 58, 0.08); --c-border: rgba(160, 235, 245, 0.16); --c-hover: rgba(160, 235, 245, 0.11); --c-focus: rgba(120, 230, 255, 0.44); --shadow-1: 0 22px 70px rgba(0, 0, 0, 0.55); --shadow-2: 0 0 4px rgba(0, 0, 0, 0.7); --shadow-accent: inset 0 0 0 1px var(--c-accent-glow); --ring-accent: 0 0 0 3px var(--c-accent-glow); --radial-gradient: radial-gradient(1200px 700px at 50% 8%, rgba(200, 255, 250, 0.09), rgba(0, 0, 0, 0) 60%), radial-gradient(900px 520px at 78% 0%, rgba(90, 230, 255, 0.15), rgba(0, 0, 0, 0) 55%), radial-gradient(900px 700px at 18% 88%, rgba(120, 255, 220, 0.08), rgba(0, 0, 0, 0) 62%); --demo-sprite: url("https://cdn.trendhunterstatic.com/sprites/demographics-sprite-thgpt-midnightteal.png"); --regions-sprite: url("https://cdn.trendhunterstatic.com/sprites/regions-sprite-thgpt-midnightteal.png?_t=1772742027185"); --patterns-sprite: url("https://cdn.trendhunterstatic.com/sprites/megatrends-patterns-sprite-thgpt-midnightteal.png?_t=1772561217920"); }
/* LIGHT GLASS */
body.theme--light-glass { --c-bg: #f4f7fb; --c-bg-2: #eef3f9; --c-bg-3: #e7eef7; --c-panel: rgba(255, 255, 255, 0.7); --c-panel-2: rgba(255, 255, 255, 0.82); --c-text: rgba(10, 18, 28, 0.86); --c-text-strong: rgba(10, 18, 28, 0.94); --c-text-muted: rgba(10, 18, 28, 0.6); --c-text-dim: rgba(10, 18, 28, 0.38); --c-accent: #ff7a2a; --c-accent-2: #e46c22; --c-accent-glow: rgba(255, 122, 42, 0.22); --c-accent-glow-2: rgba(255, 122, 42, 0.12); --c-border: rgba(12, 24, 40, 0.14); --c-hover: rgba(12, 24, 40, 0.06); --c-focus: rgba(255, 122, 42, 0.4); --shadow-1: 0 22px 70px rgba(0, 0, 0, 0.2); --shadow-2: 0 0 4px rgba(0, 0, 0, 0.12); --shadow-accent: inset 0 0 0 1px var(--c-accent-glow); --ring-accent: 0 0 0 3px var(--c-accent-glow); --radial-gradient: radial-gradient(1200px 700px at 50% 8%, rgba(0, 120, 255, 0.08), rgba(0, 0, 0, 0) 60%), radial-gradient(900px 520px at 78% 0%, rgba(255, 122, 42, 0.1), rgba(0, 0, 0, 0) 55%), radial-gradient(900px 700px at 18% 88%, rgba(0, 160, 255, 0.07), rgba(0, 0, 0, 0) 62%); --logo-url: url("https://cdn.trendhunterstatic.com/icons/ai-icon-black.png"); --horizon-logo: url("https://cdn.trendhunterstatic.com/logos/horizon/Horizon_Logo_Black_NoTH.png"); --horizon-logo-with-th: url("https://cdn.trendhunterstatic.com/logos/horizon/Horizon_Logo_Black.png"); --demo-sprite: url("https://cdn.trendhunterstatic.com/sprites/demographics-sprite-thgpt-lightglass.png"); --regions-sprite: url("https://cdn.trendhunterstatic.com/sprites/regions-sprite-thgpt-lightglass.png?_t=1772742027185"); --patterns-sprite: url("https://cdn.trendhunterstatic.com/sprites/megatrends-patterns-sprite-thgpt-lightglass.png?_t=1772555860309"); }
/* SUNSET PURPLE */
body.theme--sunset-purple { --c-bg: #070612; --c-bg-2: #0b0820; --c-bg-3: #120b2d; --c-panel: #17113a; --c-panel-2: #1e1849; --c-text: rgba(248, 244, 255, 0.86); --c-text-strong: rgba(255, 252, 255, 0.96); --c-text-muted: rgba(222, 210, 242, 0.64); --c-text-dim: rgba(190, 170, 220, 0.38); --c-accent: #ff7a2a; --c-accent-2: #e46c22; --c-accent-glow: rgba(255, 122, 42, 0.18); --c-accent-glow-2: rgba(255, 122, 42, 0.08); --c-border: rgba(210, 185, 255, 0.14); --c-hover: rgba(210, 185, 255, 0.1); --c-focus: rgba(170, 120, 255, 0.42); --shadow-1: 0 22px 70px rgba(0, 0, 0, 0.58); --shadow-2: 0 0 22px rgba(0, 0, 0, 0.72); --shadow-accent: inset 0 0 0 1px var(--c-accent-glow); --ring-accent: 0 0 0 3px var(--c-accent-glow); --radial-gradient: radial-gradient(1200px 700px at 50% 8%, rgba(245, 220, 255, 0.09), rgba(0, 0, 0, 0) 60%), radial-gradient(900px 520px at 78% 0%, rgba(180, 120, 255, 0.16), rgba(0, 0, 0, 0) 55%), radial-gradient(900px 700px at 18% 88%, rgba(255, 170, 220, 0.08), rgba(0, 0, 0, 0) 62%); }
/* ARCTIC MINT */
body.theme--arctic-mint { --c-bg: #050f10; --c-bg-2: #061a1b; --c-bg-3: #082526; --c-panel: #0a2f30; --c-panel-2: #0d3b3c; --c-text: rgba(236, 255, 252, 0.86); --c-text-strong: rgba(246, 255, 254, 0.96); --c-text-muted: rgba(198, 242, 236, 0.64); --c-text-dim: rgba(150, 210, 200, 0.38); --c-accent: #ff7a2a; --c-accent-2: #e46c22; --c-accent-glow: rgba(255, 122, 42, 0.18); --c-accent-glow-2: rgba(255, 122, 42, 0.08); --c-border: rgba(160, 245, 230, 0.15); --c-hover: rgba(160, 245, 230, 0.1); --c-focus: rgba(120, 255, 230, 0.42); --shadow-1: 0 22px 70px rgba(0, 0, 0, 0.55); --shadow-2: 0 0 22px rgba(0, 0, 0, 0.7); --shadow-accent: inset 0 0 0 1px var(--c-accent-glow); --ring-accent: 0 0 0 3px var(--c-accent-glow); --radial-gradient: radial-gradient(1200px 700px at 50% 8%, rgba(210, 255, 248, 0.09), rgba(0, 0, 0, 0) 60%), radial-gradient(900px 520px at 78% 0%, rgba(120, 255, 230, 0.15), rgba(0, 0, 0, 0) 55%), radial-gradient(900px 700px at 18% 88%, rgba(180, 255, 240, 0.08), rgba(0, 0, 0, 0) 62%); }
/* ROSE SMOKE */
body.theme--rose-smoke { --c-bg: #11060a; --c-bg-2: #1a0a10; --c-bg-3: #250f18; --c-panel: #2d141f; --c-panel-2: #3a1b29; --c-text: rgba(255, 242, 248, 0.86); --c-text-strong: rgba(255, 250, 252, 0.96); --c-text-muted: rgba(245, 205, 222, 0.64); --c-text-dim: rgba(220, 165, 190, 0.38); --c-accent: #ff7a2a; --c-accent-2: #e46c22; --c-accent-glow: rgba(255, 122, 42, 0.18); --c-accent-glow-2: rgba(255, 122, 42, 0.08); --c-border: rgba(255, 190, 215, 0.14); --c-hover: rgba(255, 190, 215, 0.1); --c-focus: rgba(255, 140, 180, 0.42); --shadow-1: 0 22px 70px rgba(0, 0, 0, 0.58); --shadow-2: 0 0 22px rgba(0, 0, 0, 0.72); --shadow-accent: inset 0 0 0 1px var(--c-accent-glow); --ring-accent: 0 0 0 3px var(--c-accent-glow); --radial-gradient: radial-gradient(1200px 700px at 50% 8%, rgba(255, 220, 235, 0.09), rgba(0, 0, 0, 0) 60%), radial-gradient(900px 520px at 78% 0%, rgba(255, 150, 190, 0.15), rgba(0, 0, 0, 0) 55%), radial-gradient(900px 700px at 18% 88%, rgba(255, 190, 215, 0.08), rgba(0, 0, 0, 0) 62%); }
/* DESERT SAND */
body.theme--desert-sand { --c-bg: #fbf3e6; --c-bg-2: #f6ecdc; --c-bg-3: #efe2ce; --c-panel: rgba(255, 255, 255, 0.72); --c-panel-2: rgba(255, 255, 255, 0.84); --c-text: rgba(28, 18, 10, 0.86); --c-text-strong: rgba(28, 18, 10, 0.94); --c-text-muted: rgba(28, 18, 10, 0.6); --c-text-dim: rgba(28, 18, 10, 0.38); --c-accent: #ff7a2a; --c-accent-2: #e46c22; --c-accent-glow: rgba(255, 122, 42, 0.22); --c-accent-glow-2: rgba(255, 122, 42, 0.12); --c-border: rgba(60, 35, 15, 0.14); --c-hover: rgba(60, 35, 15, 0.06); --c-focus: rgba(255, 122, 42, 0.4); --shadow-1: 0 22px 70px rgba(0, 0, 0, 0.18); --shadow-2: 0 0 4px rgba(0, 0, 0, 0.12); --shadow-accent: inset 0 0 0 1px var(--c-accent-glow); --ring-accent: 0 0 0 3px var(--c-accent-glow); --radial-gradient: radial-gradient(1200px 700px at 50% 8%, rgba(255, 200, 120, 0.1), rgba(0, 0, 0, 0) 60%), radial-gradient(900px 520px at 78% 0%, rgba(255, 122, 42, 0.1), rgba(0, 0, 0, 0) 55%), radial-gradient(900px 700px at 18% 88%, rgba(255, 180, 120, 0.07), rgba(0, 0, 0, 0) 62%); --logo-url: url("https://cdn.trendhunterstatic.com/icons/ai-icon-black.png"); }
.u-hidden { display: none !important; }
/* ===== Rotating Border ===== */
@property --angle {
	syntax: "<angle>";
	initial-value: 0deg;
	inherits: false;
}
.borderRotate { position: relative; }
.borderRotate::after, .borderRotate::before { content: ""; position: absolute; height: 100%; width: 100%; background: conic-gradient(from var(--angle), var(--c-accent), var(--c-accent-glow), var(--c-focus), var(--c-focus), var(--c-accent)); top: 50%; left: 50%; translate: -50% -50%; z-index: -1; padding: 3px; border-radius: 24px; animation: 3s borderSpin linear infinite; }
.borderRotate::before { filter: blur(0.5rem); opacity: 0.5; }
@keyframes borderSpin {
	from { --angle: 0deg; }
	to { --angle: 360deg; }
}
/* ===== layout utilities ===== */
.stack { display: flex; flex-direction: column; }
.row { display: flex; flex-direction: row; align-items: center; }
.wrap { flex-wrap: wrap; }
.gap-1 { gap: var(--s-1); }
.gap-2 { gap: var(--s-2); }
.gap-3 { gap: var(--s-3); }
.gap-4 { gap: var(--s-4); }
.gap-5 { gap: var(--s-5); }
.gradient { background: radial-gradient(140% 160% at 50% -20%, rgba(255, 255, 255, 0.05) 0%, var(--c-panel-2) 28%, var(--c-panel) 72%); }
.gradient-2 { background: linear-gradient(180deg, var(--c-bg-3), var(--c-bg-2)); }
.gradient-3 { background: linear-gradient(180deg, var(--c-bg-3), var(--c-bg)); }
.background-1 { background: var(--c-bg-3); }
.center { align-items: center; justify-content: center; }
.between { justify-content: space-between; }
.grow { flex: 1 1 auto; min-width: 0; }
.scroll { overflow: auto; }
.noScrollBar::-webkit-scrollbar { display: none; }
.scroll { overflow-y: auto; overflow-x: hidden; min-height: 0; min-width: 0; scrollbar-width: none; }
.scroll::-webkit-scrollbar { width: 0; height: 0; }
.scroll:hover { scrollbar-width: thin; }
.scroll:hover::-webkit-scrollbar { width: 8px; }
.scroll:hover::-webkit-scrollbar-thumb { background: var(--c-border); border-radius: var(--r-pill); }
.scroll:hover::-webkit-scrollbar-track { background: transparent; }
/* ===== spacing utilities ===== */
.p-1 { padding: var(--s-1); }
.p-2 { padding: var(--s-2); }
.p-3 { padding: var(--s-3); }
.p-4 { padding: var(--s-4); }
.p-5 { padding: var(--s-5); }
.px-5 { padding-left: var(--s-5); padding-right: var(--s-5); }
.m-2 { margin: var(--s-2); }
.m-3 { margin: var(--s-3); }
.m-4 { margin: var(--s-4); }
.m-5 { margin: var(--s-5); }
.round-1 { border-radius: var(--r-1); }
.round-2 { border-radius: var(--r-2); }
.round-3 { border-radius: var(--r-3); }
.round-pill { border-radius: var(--r-pill); }
.border-1 { border: 1px solid var(--c-border); }
/* ===== text utilities ===== */
.t-strong { color: var(--c-text-strong); }
.t-muted { color: var(--c-text-muted); }
.t-dim { color: var(--c-text-dim); }
.t-accent { color: var(--c-accent); }
/* ===== transition ===== */
.transition { transition: width 200ms ease, margin-left 200ms ease, left 200ms ease, padding 200ms ease; }
.transition-2 { transition: transform 160ms ease, background 160ms ease, border-color 160ms ease, box-shadow 140ms ease; }
/* Print PDF */
.thgptPrintSection--right { break-before: page; page-break-before: always; }
@media print {
	@page { margin: 0; }
	html, body, #thgptPrintRoot, #thgptPrintRoot * { -webkit-print-color-adjust: exact; print-color-adjust: exact; }
	#thgptPrintRoot .thgptPrintTabPage { break-before: page; page-break-before: always; }
	#thgptPrintRoot .thgptPrintTabPage:first-child { break-before: auto; page-break-before: auto; }
	#thgptPrintRoot .u-hidden { display: block !important; }
	#thgptPrintRoot .cardsScroll { overflow: visible !important; height: auto !important; max-height: none !important; }
	#thgptPrintRoot .msg, #thgptPrintRoot .cardsCol, #thgptPrintRoot .sectionHeader { padding: var(--s-5); }
	#thgptPrintRoot .huntChip, #thgptPrintRoot .pill, #thgptPrintRoot .cardRowActions, #thgptPrintRoot .refreshProducts, #thgptPrintRoot .refreshCampaigns, #thgptPrintRoot .exploreFurther { display: none !important; }
	#thgptPrintRoot .cardsCol .cardRow::after { display: none !important; }
	#thgptPrintRoot .cardsCol { gap: 0; }
	#thgptPrintRoot .cardRow { margin-bottom: 14px; }
	#thgptPrintRoot .tabInfo { display: none !important; opacity: 0 !important; }
}
/* General */
.tg__testing { position: absolute; right: 0; top: 0; padding: 5px; font-size: var(--font-size); z-index: 100; color: var(--c-text); background: var(--c-accent-2); }
* { box-sizing: border-box; min-width: 0; }
body { font-size: 16px; background: var(--radial-gradient), linear-gradient(180deg, var(--c-bg-2), var(--c-bg)); }
p { margin: 0; }
a { text-decoration: none; }
.tg, .app, .main { min-height: 100dvh; color: var(--c-text); }
.main { height: 100dvh; display: flex; flex-flow: row; padding: 10px; }
.content { height: 100%; width: 100%; }
.section { margin-top: 20px; }
.page { padding: 0 var(--s-5); border-radius: var(--r-3); padding-bottom: calc(var(--s-5) / 2); }
.right { flex-grow: 1; margin-left: calc(245px + 2 * var(--s-5)); margin-top: calc(50px + 2 * var(--s-5)); margin-bottom: calc(var(--s-5) - 10px); }
body[data-panel="topic"] .right { margin-top: calc(var(--s-5) - 10px); }
.cont { margin: 0 calc(var(--s-5) - 10px) 0 var(--s-5); height: calc(100dvh - 2 * var(--s-5) - 85px); }
.hubHeader { align-items: flex-start; padding: calc(var(--s-5) / 2) 0; padding-bottom: 0; }
.hubHeaderLeft { flex: 1 1 auto; min-width: 0; }
.hubTitle { font-size: 34px; font-weight: 850; color: var(--c-text); letter-spacing: 0.005em; }
.hubSub { margin-top: 6px; color: var(--c-text-muted); font-size: 14px; }
.pill { border-radius: var(--r-pill); border: 1px solid var(--c-border); background: var(--c-bg-3); backdrop-filter: blur(10px); }
.pill:hover { transform: translateY(-1px); border-color: var(--c-focus); background: var(--c-hover); box-shadow: var(--ring-accent); }
.btn { font-size: 15px; font-weight: 300; padding: 12px 18px; appearance: none; box-sizing: border-box; font-family: "Roboto"; cursor: pointer; outline-color: var(--c-accent); transition: color 0.2s ease-in-out, background-color 0.2s ease-in-out, border-color 0.2s ease-in-out, box-shadow 0.2s ease-in-out; display: flex; align-items: center; letter-spacing: 0.02em; border-radius: var(--r-2); background: var(--c-panel-2); border: 1px solid var(--c-border); color: var(--c-text-strong); gap: 5px; }
.btn .material { font-size: 18px; display: block; flex: 0 0 auto; }
.btn:hover { background: var(--c-panel); border-color: var(--c-border); box-shadow: var(--shadow-2), var(--shadow-accent); }
.btn:focus-visible { box-shadow: var(--ring-accent); border-color: var(--c-accent-glow); }
.btn.btn--ghost { background: transparent; border-color: var(--c-border); color: var(--c-text); }
.btn.btn--ghost:hover { background: var(--c-hover); border-color: var(--c-focus); box-shadow: var(--ring-accent); }
.btn.btn--danger { border-color: rgba(219, 68, 55, 0.35); color: rgba(255, 140, 140, 0.92); background: rgba(219, 68, 55, 0.08); }
.btn.btn--danger:hover { box-shadow: 0 0 0 3px rgba(219, 68, 55, 0.14); background: rgba(219, 68, 55, 0.18); color: var(--c-text-strong); }
.is-active { background: var(--c-accent-glow-2) !important; border-color: var(--c-accent-2) !important; box-shadow: var(--ring-accent), var(--shadow-2) !important; }
/* Sidebar */
.sidebar { position: fixed; top: var(--s-5); left: var(--s-5); width: var(--sidebar-w); height: var(--panel-h); display: flex; flex-direction: column; min-height: 0; }
.sidebar .logoRow { margin-bottom: var(--s-2); overflow: hidden; }
.logoIcon { width: 45px; height: 45px; display: grid; place-items: center; background-image: var(--logo-url); background-size: 40px 40px; background-position: center; background-repeat: no-repeat; }
.logoRow .logoText { display: block; font-weight: 700; letter-spacing: 0.08em; font-size: 18px; color: var(--c-text); opacity: 0.9; white-space: nowrap; }
.sidebar .navItems { flex-grow: 1; min-height: 0; overflow: auto; }
.navItems .navTop { flex-grow: 1; padding-bottom: 10px; }
.navItem { border-radius: var(--r-2); padding: var(--s-2); margin: 2px 0; transition: background 160ms ease, transform 160ms ease; font-size: var(--font-size); color: var(--c-text-strong); font-weight: 400; text-decoration: none; cursor: pointer; }
.navItem:hover, .navItem--active, .sideItem:hover { background: var(--c-hover); }
.navItem.navItem--active { background: var(--c-accent-glow-2); box-shadow: var(--shadow-accent); }
.navItem .navItemIcon { opacity: 0.9; }
.navItem .navItemText { margin-left: 5px; flex-grow: 1; }
.sideItem { padding: 8px 10px; color: var(--c-text); }
.sideItem:hover, .sideSectionLink:hover { background: var(--c-hover); color: var(--c-text); }
.sideItem:focus-visible { outline: 2px solid var(--c-focus); outline-offset: 2px; }
.sideItemLabel { font-size: 13px; font-weight: 700; color: inherit; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sideItemCount { flex: 0 0 auto; font-size: 12px; font-weight: 900; color: var(--c-text-strong); padding: 2px 8px; background: var(--c-accent-glow-2); border: 1px solid var(--c-accent-glow); }
.sideSection { margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--c-border); }
.sideSectionHdr { margin: 0 4px 10px; }
.sideSectionTitle { font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--c-text-muted); font-weight: 800; }
.sideSectionLink { font-size: 11px; color: var(--c-text-muted); font-weight: 800; text-decoration: none; padding: 6px 8px; }
.sideList { max-height: 220px; }
.sideList::-webkit-scrollbar { width: 8px; }
.sideList::-webkit-scrollbar-thumb { background: var(--c-border); border-radius: var(--r-pill); }
.sideList::-webkit-scrollbar-track { background: transparent; }
.tgt__navSubItem { font-size: 13px; padding: 10px 10px 10px 20px; white-space: nowrap; width: 100%; overflow: hidden; text-overflow: ellipsis; color: var(--c-text-strong); cursor: pointer; }
.tgt__navSubItem:last-child { margin-bottom: 10px; }
.navItemCont--activeHunts { margin-bottom: 8px; }
.activeHuntsLbl { font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--c-text-muted); font-weight: 800; padding: 6px 10px 6px; border-top: 1px solid var(--c-border); }
.activeHuntItem { display: flex; align-items: center; gap: 8px; padding: 8px 10px; border-radius: var(--r-2); cursor: pointer; transition: background 160ms ease; color: var(--c-text); font-size: 13px; font-weight: 400; margin-bottom: 2px; }
.activeHuntItem:hover { background: var(--c-hover); }
.activeHuntItem.navItem--active { background: var(--c-accent-glow-2); box-shadow: var(--shadow-accent); }
.activeHuntItemIcon { font-size: 18px; color: var(--c-accent); flex-shrink: 0; }
.activeHuntItemText { flex: 1 1 auto; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.activeHuntItemClose { font-size: 16px; cursor: pointer; opacity: 0; flex-shrink: 0; transition: opacity 160ms ease, color 160ms ease; }
.activeHuntItem:hover .activeHuntItemClose { opacity: 0.5; }
.activeHuntItemClose:hover { opacity: 1 !important; color: var(--c-accent); }
.sidebarCollapseBtn, .splitCollapseBtn { position: absolute; top: 7px; right: -14px; width: 24px; height: 24px; border-radius: var(--r-pill); border: 1px solid var(--c-accent-glow); background: linear-gradient(180deg, var(--c-accent), var(--c-accent-2)); color: var(--c-text-strong); display: grid; place-items: center; cursor: pointer; transition: transform 160ms ease, box-shadow 160ms ease, filter 160ms ease; z-index: 5; }
.splitExpandBtn { position: absolute; top: 7px; left: -14px; width: 24px; height: 24px; border-radius: var(--r-pill); border: 1px solid var(--c-accent-glow); background: linear-gradient(180deg, var(--c-accent), var(--c-accent-2)); color: var(--c-text-strong); display: grid; place-items: center; cursor: pointer; transition: transform 160ms ease, box-shadow 160ms ease, filter 160ms ease; z-index: 5; }
.sidebarCollapseBtn:hover, .splitCollapseBtn:hover, .splitExpandBtn:hover { transform: translateY(-1px); filter: saturate(1.05); }
.sidebarCollapseBtn:active, .splitCollapseBtn:active, .splitExpandBtn:active { transform: translateY(0px); }
.sidebarCollapseBtn:focus-visible, .splitCollapseBtn:focus-visible, .splitExpandBtn:focus-visible { outline: 0; box-shadow: var(--ring-accent); }
.sidebarCollapseIcon { font-size: 20px; line-height: 1; }
/* Sidebar Bottom Notification Card */
.sidebarFooter { padding-top: 12px; }
.sidebarNotif { position: relative; }
.sidebarNotifInner { padding: 18px 16px; border-radius: 24px; background: linear-gradient(180deg, var(--c-bg-3), var(--c-bg-2)); backdrop-filter: blur(14px); display: flex; flex-direction: column; align-items: center; justify-content: center; }
.sidebarNotifTitle { font-weight: 600; font-size: 18px; color: var(--c-text-strong); }
.sidebarNotifDesc { opacity: 0.75; font-size: 14px; line-height: 1.35; color: var(--c-text); text-align: center; }
.sidebarNotifTitle + .sidebarNotifDesc { margin-top: 14px; }
.sidebarNotifInner .sidebarNotifDesc:last-of-type { margin-bottom: 14px; }
/* Sidebar Collapse */
.sidebar--showing { width: var(--sidebar-w-collapsed); padding: var(--s-2); }
.sidebar--showing .logoText, .sidebar--showing .navItemText, .sidebar--showing .tgt__navSubLbl, .sidebar--showing .sideSectionLink, .sidebar--showing .tg__navItemSub, .sidebar--showing .sideList .sideItemLabel, .sidebar--showing .activeHuntItemText, .sidebar--showing .activeHuntItemClose, .sidebar--showing .sidebarFooter { display: none !important; }
.sidebar--showing .sideSectionTitle, .sidebar--showing .activeHuntsLbl { text-align: center; letter-spacing: normal; }
.sidebar--showing .navItem { position: relative; justify-content: center; padding: 10px 8px; }
.sidebar--showing .navItemIcon { margin-right: 0 !important; }
.sidebar--showing .sideSection .sideItem, .sidebar--showing .sideSectionHdr, .sidebar--showing .activeHuntItem { justify-content: center; }
.sidebar--showing ~ .header { left: calc(108px + var(--s-5)); }
.sidebar--showing ~ .right { margin-left: calc(73px + var(--s-5)); }
.sidebar--showing .sidebarCollapseBtn { right: -14px; }
.sidebar--showing .sidebarCollapseIcon { transform: rotate(180deg); }
.sidebar--showing .sidebarLogo { height: auto; width: 100%; max-height: 2rem; object-fit: contain; margin: var(--s-2) 0; }
.sidebar--showing .sideItem { position: relative; }
.sidebarTooltip { position: fixed; left: 0; top: 0; padding: 8px 10px; border-radius: var(--r-2); background: var(--c-panel-2); border: 1px solid var(--c-border); color: var(--c-text-strong); font-size: 12px; font-weight: 900; letter-spacing: 0.02em; white-space: nowrap; box-shadow: var(--shadow-2); backdrop-filter: blur(10px); pointer-events: none; opacity: 0; transform: translateX(0); transition: opacity 120ms ease, transform 120ms ease; z-index: 999999; }
.sidebarTooltip.is-showing { opacity: 1; transform: translateX(6px); }
/* Mobile Sidebar */
.sidebar--mobile { display: none; }
.sidebar--mobile .sidebarMenu { position: absolute; top: 15px; left: 15px; cursor: pointer; border-radius: 50%; padding: 4px; }
.sidebar--mobile .sidebarMenu:hover { background: var(--c-hover); }
.sidebar--mobile .navItems { display: none; position: absolute; top: 50px; z-index: 999999; background: var(--c-bg-2); padding: 18px; border-radius: 12px; }
/* Headerbar */
.header { position: fixed; top: var(--s-5); left: calc(280px + 2 * (var(--s-5))); right: var(--s-5); height: var(--header-h); z-index: 2; padding: 0; backdrop-filter: blur(12px); display: none; }
body:not([data-panel="hunt"]):not([data-panel="topic"]):not([data-panel="upgrade"]) .header { display: block; }
.headerInner { height: 100%; display: grid; grid-template-columns: 1fr auto; padding: 0 var(--s-2); }
.headerCenter { width: 100%; }
.headerRight { justify-content: end; }
.headerLink { text-decoration: none; font-size: 13px; font-weight: 600; }
.headerLink:hover, .helpBtn:hover, .avatarBtn:hover, .menuItem:hover { background: var(--c-hover); }
.helpBtn { border: none; background: transparent; color: var(--c-text-dim); cursor: pointer; }
.avatarBtn { background: var(--c-bg-3); padding: 2px 4px 2px 2px; cursor: pointer; }
.avatar { width: 40px; height: 40px; overflow: hidden; display: block; }
.avatarImg { width: 100%; height: 100%; object-fit: cover; display: block; }
.chev { font-size: 20px; opacity: 0.8; }
.menu { position: fixed; min-width: 200px; background: var(--c-bg-3); box-shadow: var(--shadow-2); display: none; z-index: 1000; }
.menu.is-open { display: block; }
.menuItem { display: block; width: 100%; color: var(--c-text); text-decoration: none; font-weight: 600; font-size: 13px; background: transparent; border: 0; text-align: left; cursor: pointer; }
.menuItem--btn { appearance: none; }
.search { width: 100%; margin: 0 auto; position: relative; padding: 10px 36px 10px 14px; background: var(--c-bg-3); border: 1px solid var(--c-border); }
.search:focus-within { box-shadow: var(--ring-accent); }
.searchIcon { font-size: 24px; cursor: pointer; position: absolute; right: 10px; }
.searchIcon:hover { background: var(--c-hover); border-radius: var(--r-pill); }
.searchInput { width: 100%; background: transparent; border: 0; outline: 0; color: var(--c-text); font-size: 14px; }
.searchInput::placeholder { color: var(--c-text-muted); }
.searchInput--stop { pointer-events: none; }
body[data-panel="settings"] .search { display: none; }
.trendSpotter { width: 200px; }
.trendSpotter:hover { background: var(--c-hover); border-radius: var(--r-2); }
/* Hunt Page */
body[data-panel="hunt"] .right { margin-top: calc(var(--s-5) / 2); }
body[data-panel="hunt"] .content { overflow: auto; }
body[data-panel="hunt"] .huntChip { padding: 0 !important; }
.hunt { position: relative; }
.huntCenter { position: relative; z-index: 1; min-height: calc(100dvh - 2 * var(--s-5) - 85px); padding: 70px 18px 40px; }
.huntBrand { margin-top: 10px; }
.huntLogo { height: clamp(3.5rem, 8vw, 7.8125rem); width: auto; display: block; content: var(--horizon-logo-with-th); }
.sidebarLogo { height: 3rem; width: auto; display: block; content: var(--horizon-logo); }
.huntSearchWrap, .huntPop { width: min(720px, 92%); }
.huntPop { display: grid; grid-template-rows: 0fr; opacity: 0; transition: grid-template-rows 0.3s ease, opacity 0.25s ease; overflow: hidden; }
.huntPop.is-open { grid-template-rows: 1fr; opacity: 1; }
.huntPop > * { overflow: hidden; }
.huntChip { padding: 12px 22px; color: var(--c-text); font-weight: 850; cursor: pointer; position: relative; }
.huntChipInner { background: var(--c-bg-3); padding: 12px 22px; border-radius: var(--r-pill); position: relative; }
.huntInfo { position: absolute; top: -9px; right: -11px; width: 18px; height: 18px; display: flex; align-items: center; justify-content: center; font-size: var(--s-2); font-weight: 800; line-height: 1; color: var(--c-accent); opacity: 0; transition: opacity 0.15s ease, color 0.15s ease, border-color 0.15s ease; }
.huntChip:hover .huntInfo { opacity: 1; color: var(--c-accent); border-color: var(--c-focus); }
.roleCards { display: grid; grid-template-columns: repeat(5, 1fr); align-items: stretch; padding: 5px; }
.roleCard { position: relative; background: var(--c-bg-2); padding: 14px 12px 12px; min-height: 92px; cursor: pointer; border: 1px solid var(--c-border); }
.roleCard:hover { transform: translateY(-1px); background: var(--c-bg-3); border-color: var(--c-accent-glow); box-shadow: var(--ring-accent); }
.roleIcon { width: 34px; height: 34px; display: grid; place-items: center; background: var(--c-bg-2); color: var(--c-text); margin-bottom: 8px; border: 1px solid var(--c-border); }
.roleIcon .material { font-size: 20px; }
.roleLbl { font-size: 12px; font-weight: 900; color: var(--c-text-muted); letter-spacing: 0.02em; text-align: center; }
.roleCard.is-active .roleLbl { color: var(--c-text); }
.huntRecList, .huntRecHead { width: min(860px, 92%); }
.huntRecHead { margin-top: 14px; }
.huntRecLabel { font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--c-text-muted); font-weight: 900; }
.huntRefresh { width: 25px; height: 25px; display: grid; place-items: center; cursor: pointer; color: var(--c-text); }
.huntRefresh .material { font-size: 18px; }
.huntRec { width: 100%; padding: 14px 18px; text-align: left; color: var(--c-text); font-weight: 700; cursor: pointer; border: 1px solid var(--c-border); }
.huntRec:hover { transform: translateY(-1px); background: var(--c-hover); }
.huntRec--loading { animation: thgptPulse 1.2s ease-in-out infinite; opacity: 0.65; pointer-events: none; }
.huntBtn { width: min(450px, 65%); height: 0; padding: 0; border: 1px solid var(--c-accent-2); background: var(--c-accent); cursor: pointer; opacity: 0; overflow: hidden; transition: height 0.3s ease, opacity 0.25s ease, padding 0.3s ease; }
.huntBtn.is-open { height: 40px; opacity: 1; }
.huntBtn:hover { background: var(--c-accent-2); }
.huntInfoPop { color: var(--c-text); }
.huntInfoHead { display: flex; align-items: flex-start; justify-content: space-between; gap: var(--s-4); margin-bottom: var(--s-4); }
.huntInfoTitle { font-size: 20px; font-weight: 900; letter-spacing: 0.2px; color: var(--c-text-strong); line-height: 1.2; }
.huntInfoSub { display: inline-block; margin-left: 8px; font-size: 14px; font-weight: 750; color: var(--c-text-muted); opacity: 0.9; }
.huntInfoBody { display: grid; gap: var(--s-4); }
.huntInfoSection { padding: var(--s-3) var(--s-4); border: 1px solid rgba(170, 220, 255, 0.1); border-radius: var(--r-2); background: linear-gradient(var(--c-bg-3), var(--c-bg-2)); }
.huntInfoLabel { font-size: 12px; font-weight: 900; letter-spacing: 0.12em; text-transform: uppercase; color: var(--c-text-dim); margin-bottom: 8px; }
.huntInfoText { font-size: 15px; line-height: 1.5; color: var(--c-text); margin-bottom: var(--s-4); }
.huntInfoQuote { font-size: 15px; line-height: 1.5; color: var(--c-text-strong); padding-left: 14px; border-left: 3px solid var(--c-accent-glow); opacity: 0.95; }
.huntInfoList { margin: 10px 0 0 18px; padding: 0; display: grid; gap: 8px; color: var(--c-text); font-size: 15px; }
.huntInfoList li { line-height: 1.4; color: var(--c-text); }
.huntInfoNote { margin-top: var(--s-2); padding: var(--s-3) var(--s-4); border-radius: var(--r-2); background: var(--c-accent-glow-2); border: 1px solid var(--c-accent-glow); color: var(--c-text-strong); font-size: 14px; line-height: 1.5; }
.huntInfoPop::-webkit-scrollbar { width: 10px; }
.huntInfoPop::-webkit-scrollbar-thumb { background: rgba(170, 220, 255, 0.14); border-radius: 999px; border: 2px solid rgba(0, 0, 0, 0); }
.huntInfoPop::-webkit-scrollbar-track { background: transparent; }
.tabInfoPop .pop__content { max-width: 500px; }
/* History Page */
.history a, .history a:visited, .history a:hover { color: inherit; }
.history a *, .historyCard * { text-decoration: none; }
.group { padding: 10px 12px; }
.historyCard { display: block; padding: 18px 18px 16px; border: 1px solid var(--c-border); background: var(--c-bg-3); }
.historyCardMain { overflow: auto; }
.group:hover, .historyCard:hover { transform: translateY(-1px); border-color: var(--c-border-2); background: var(--c-bg-2); box-shadow: var(--shadow-2); }
.sectionHeader { align-items: flex-end; margin: 0 0 12px; padding-bottom: 12px; border-bottom: 1px solid var(--c-border); }
.sectionTitle { font-size: 18px; color: var(--c-text-strong); font-weight: 800; letter-spacing: -0.25px; }
.sectionSubtle { color: var(--c-text-muted); font-weight: 600; font-size: 13px; margin-left: 8px; opacity: 0.7; }
.sectionList > a { display: block; }
details.section > summary .material::before { font-family: "Material Symbols Outlined"; font-size: 22px; content: "keyboard_arrow_up"; cursor: pointer; }
details.section[open] > summary .material::before { content: "keyboard_arrow_down"; }
.groupSummary { cursor: pointer; user-select: none; list-style: none; padding: 12px 6px; color: var(--c-text-strong); font-weight: 900; letter-spacing: -0.15px; font-size: 14px; }
.group summary::-webkit-details-marker { display: none; }
.groupCount { font-size: 12px; color: var(--c-text-muted); border: 1px solid var(--c-accent-glow); padding: 5px 10px; background: var(--c-accent-glow-2); }
.historyIcon { opacity: 0.95; flex: 0 0 auto; margin-top: 2px; width: 22px; height: 22px; display: inline-flex; align-items: center; justify-content: center; color: var(--c-accent); }
.historyCardTop { border-bottom: 1px solid var(--c-border); }
.historyCardRow { padding-bottom: 14px; }
.historyCardTitle { color: var(--c-text-strong); font-size: 16px; line-height: 1.35; min-width: 0; font-weight: 800; letter-spacing: -0.2px; flex-wrap: nowrap; }
.historyCardPrompt { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 760px; color: var(--c-text-strong); }
.historyCardBrand { color: var(--c-text-muted); white-space: nowrap; flex: 0 0 auto; font-weight: 700; opacity: 0.75; margin-left: 6px; overflow: hidden; text-overflow: ellipsis; max-width: 260px; }
.historyCardActions { flex: 0 0 auto; min-height: 20px; padding: 5px 15px; font-weight: 900; letter-spacing: 0.3px; text-transform: uppercase; font-size: 12px; white-space: nowrap; }
.favoriteHistory { border-color: var(--c-accent); background: var(--c-accent-glow); box-shadow: var(--shadow-2); color: var(--c-text); }
.deleteHistory { background: transparent; color: var(--c-text); }
.favoriteHistory, .deleteHistory { font-size: 14px; padding: 2px 10px; border: 1px solid var(--c-border); }
.favoriteHistory:hover, .deleteHistory:hover { border-color: var(--c-border-2); background: var(--c-hover); box-shadow: var(--ring-accent); }
.favoriteHistory:hover { border-color: var(--c-accent-2); background: var(--c-accent-glow-2); }
.deleteAllHistory { white-space: nowrap; letter-spacing: 0; justify-content: center; }
.historyMetaRow { margin-top: 12px; }
.historyDate { font-size: 12px; color: var(--c-text-muted); white-space: nowrap; }
.historyChips { row-gap: 10px; column-gap: 10px; min-width: 0; }
.historyChip { display: inline-flex; align-items: center; font-size: 12px; color: var(--c-text); background: var(--c-bg-3); padding: 7px 12px; white-space: nowrap; border: 1px solid var(--c-border); }
.historyChip b { color: var(--c-text); font-weight: 900; margin-left: 8px; }
.historyChip--muted { color: var(--c-text-muted); border-color: var(--c-border); background: var(--c-bg-3); max-width: 560px; overflow: hidden; text-overflow: ellipsis; }
/* Saved Search Page */
.ideasPage { width: 100%; margin: 0 auto; position: relative; }
.projectsStrip { padding: 0; padding-bottom: calc(var(--s-5) / 2); border-bottom: 1px solid var(--c-border); margin-bottom: var(--s-5); }
.projectsStripRow { margin-top: 10px; }
.projectsStripBtns { justify-content: flex-end; flex-shrink: 0; }
.shareStripLbl { color: var(--c-text-muted); font-size: 13px; font-weight: 700; }
.shareStripUrl { color: var(--c-text-muted); font-size: 13px; background: var(--c-bg-3); border: 1px solid var(--c-border); padding: 8px 10px; width: calc(100% - 150px); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; cursor: pointer; }
.projTabs { margin-top: 14px; gap: 22px; padding: 0 0 10px; border-bottom: 1px solid var(--c-border); scrollbar-width: thin; flex-wrap: nowrap; scrollbar-color: var(--c-border) transparent; }
.projTabs::-webkit-scrollbar { height: 0px; }
.projTabs::-webkit-scrollbar-thumb { background: var(--c-border) !important; border-radius: var(--r-pill); }
.projTabs::-webkit-scrollbar-track { background: transparent; }
.projTabs::-webkit-scrollbar-corner { background: transparent; }
.projTab { position: relative; display: inline-flex; align-items: center; text-decoration: none; color: var(--c-text); font-weight: 850; font-size: 14px; padding: 6px 2px; white-space: nowrap; flex: 0 0 auto; }
.projTab:hover { color: var(--c-text-muted); }
.projTab.is-active { background: transparent !important; color: var(--c-text-strong); box-shadow: none !important; }
.projTab.is-active:after { content: ""; position: absolute; left: 0; right: 0; bottom: -2px; height: 3px; border-radius: 3px; background: var(--c-accent); }
.projPill { display: inline-flex; align-items: center; justify-content: center; min-width: 26px; height: 22px; padding: 0 10px; background: var(--c-accent-glow-2); border: 1px solid var(--c-accent-glow); color: var(--c-text-strong); font-size: 12px; }
.ideasHeader { margin-top: 16px; align-items: center; }
.ideasTitle { font-size: 18px; font-weight: 850; color: var(--c-text); }
.ideasActions .btn { margin-bottom: calc(var(--s-5) / 2); }
.cards { margin-top: 14px; width: 100%; max-width: 100%; display: flex; flex-flow: row wrap; gap: var(--s-5); align-items: stretch; }
.cards > .card { flex: 0 0 calc(33.333% - (var(--s-5) * 2 / 3)); max-width: 500px; }
.card { overflow: hidden; background: var(--c-bg-3); border: 1px solid var(--c-border); min-height: 420px; position: relative; }
.card:hover { border-color: var(--c-border-2); box-shadow: var(--shadow-2); transform: translateY(-1px); }
.card::after { content: ""; position: absolute; top: 12px; right: 12px; width: 22px; height: 22px; border-radius: var(--r-2); background: var(--c-bg-2); border: 2px solid var(--c-text-muted); opacity: 0.25; transition: opacity 140ms ease, transform 140ms ease, background 140ms ease, border-color 140ms ease, box-shadow 140ms ease; }
.card--selected { border-color: var(--c-accent) !important; box-shadow: var(--shadow-2), var(--ring-accent); }
.card--selected::after { opacity: 1; background: var(--c-accent-2); border-color: var(--c-border); box-shadow: var(--ring-accent), var(--shadow-2); transform: scale(1.06); }
.card--selected::before { content: "✓"; position: absolute; top: 14px; right: 14px; width: 22px; height: 22px; display: flex; align-items: center; justify-content: center; color: var(--c-text-strong); font-weight: 900; font-size: 14px; line-height: 1; text-shadow: var(--shadow-2); z-index: 5; pointer-events: none; }
.cardMedia { height: 180px; overflow: hidden; background: var(--c-bg-3); position: relative; }
.cardImg { width: 100%; height: 100%; object-fit: cover; display: block; border-radius: var(--r-2); }
.cardBody { color: var(--c-text); padding: 14px 16px; min-height: 0; }
.cardTitle { margin: 0 0 10px; font-weight: 850; font-size: 18px; line-height: 1.15; color: var(--c-text); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.cardDesc { color: var(--c-text); font-size: 14px; line-height: 1.55; }
.cardDesc p { margin: 0 0 10px; }
.cardDesc ul { margin: 10px 0 0; padding-left: 18px; }
.cardDesc li { margin: 6px 0; }
.cardDesc strong { color: var(--c-text); }
.cardActions { margin-top: auto; border-top: 1px solid var(--c-border); padding: 12px 14px 14px; justify-content: flex-end; }
.cardActions .btn, .cardRowActions .btn { appearance: none; border-radius: var(--r-pill); padding: 8px 12px; font-weight: 850; font-size: 13px; letter-spacing: 0.02em; cursor: pointer; }
.empty { margin-top: calc(var(--s-5) / 2); }
.empty > div { border-radius: var(--r-3); background: var(--c-bg-3); border: 1px solid var(--c-border); padding: 18px; }
.emptyTitle { font-size: 16px; font-weight: 850; color: var(--c-text); }
.emptySub { margin-top: 6px; font-size: 13px; color: var(--c-text-muted); }
.cardTitleEdit { color: var(--c-text); width: 100%; padding: 8px 10px; border: 1px solid var(--c-text-dim) !important; border-radius: var(--r-1); font: inherit; font-weight: 600; outline: 0; margin-bottom: 8px; background: transparent; }
.cardDescEdit { color: var(--c-text); min-height: 92px; padding: 10px; border: 1px solid var(--c-text-dim); border-radius: var(--r-1); background: transparent; outline: 0; line-height: 1.35; overflow: auto; }
.cardTitleEdit:focus, .cardDescEdit:focus { border-color: var(--c-accent-glow) !important; box-shadow: none !important; }
.cardTitleEdit::placeholder, .cardDescEdit::placeholder { color: var(--c-text); }
/* Main Page */
.split { display: grid; grid-template-columns: 1.25fr 0.85fr; gap: 18px; padding: calc(var(--s-5) / 2) var(--s-5); height: 100%; max-width: 1440px; margin: 0 auto; transition: grid-template-columns 250ms ease-in-out; }
.split--resizing { transition: none; }
.reader { height: 100%; padding: 2px; overflow-y: auto; -webkit-overflow-scrolling: touch; }
.readerStream { flex: 1; padding-right: 8px; margin: calc(var(--s-5) / 2); }
.readerCats { margin-top: 0; padding: 0 0 calc(var(--s-5) / 2); display: flex; gap: 12px; flex-wrap: nowrap; overflow-x: auto; overflow-y: hidden; width: 100%; padding-top: 2px; }
.readerCats .huntChip { white-space: nowrap; flex: 0 0 auto; box-shadow: none !important; padding: 8px 12px; font-size: 12px; }
.readerCats__downloadWrap { margin-left: auto; order: 999; flex-shrink: 0; position: relative; background: var(--c-bg-3); border-radius: var(--r-pill); margin-right: 2px; }
.readerCats__downloadWrap::after, .readerCats__downloadWrap::before { content: ""; position: absolute; height: 100%; width: 100%; background: conic-gradient(from var(--angle), var(--c-accent), var(--c-accent-glow), var(--c-focus), var(--c-focus), var(--c-accent)); top: 50%; left: 50%; translate: -50% -50%; z-index: -1; padding: 2px; border-radius: var(--r-pill); animation: 3s borderSpin linear infinite; }
.readerCats__downloadWrap::before { opacity: 0.5; }
.readerCats__download.is-disabled { opacity: 0.4; pointer-events: none; cursor: default; }
/* Report generating banner — fixed top-center, styled like .prompt__toast */
.reportGenerating { position: fixed; top: 50px; left: 50%; transform: translateX(-50%); z-index: 999999; display: flex; align-items: center; gap: 8px; padding: 10px 14px; border-radius: var(--r-2); background: var(--c-accent); color: var(--c-text-strong); font-size: 14px; box-shadow: var(--shadow-2); white-space: nowrap; }
.readerFollow { padding: 5px; }
.readerFollow .pill.is-locked { position: relative; filter: blur(3px); pointer-events: none; user-select: none; border: 1px solid var(--c-border); background: linear-gradient(180deg, var(--c-panel-2), var(--c-panel)); }
.followBtn { padding: 10px 14px; color: var(--c-text); font-weight: 850; font-size: 12px; border: none; cursor: pointer; background: var(--c-panel-2); }
.followBtn::before { content: "question_exchange"; font-family: "Material Symbols Outlined"; font-size: 16px; vertical-align: middle; margin-right: 6px; font-weight: normal; }
.msg { max-width: 65%; }
.msg--ai { align-self: flex-start; text-align: left; max-width: calc(100% - calc(var(--s-5) / 2)); }
.msg--user { align-self: flex-end; opacity: 0.62; filter: saturate(0.9); text-align: right; }
.readerTop { justify-content: flex-end; color: rgba(255, 255, 255, 0.55); font-size: 12px; }
.msg--ai .readerTop { justify-content: flex-start; }
.msg--user .readerTop { justify-content: flex-end; }
.readerTop .huntChip { padding: 2px 10px !important; font-size: 10px; cursor: default; box-shadow: none !important; }
.readerTop .huntChip[data-type] { cursor: pointer; }
.readerTop .pill:hover { transform: none !important; }
.readerMeta { color: var(--c-text); }
.iconMini { appearance: none; background: var(--c-bg-3); color: var(--c-text); padding: 6px 10px; cursor: pointer; }
.iconMini:hover { background: var(--c-hover); border-color: var(--c-focus); }
.downloadOptions { padding: 0; border: none; }
.downloadOptions:hover { color: var(--c-accent); background: none; }
.readerTitle { margin: 0; font-size: 22px; line-height: 1.15; letter-spacing: -0.2px; font-weight: 900; color: var(--c-text-strong); }
.readerSearch { margin-top: 0; padding: 12px 14px; backdrop-filter: blur(14px); position: sticky; bottom: 0; z-index: 5; border-top: 1px solid var(--c-border); }
.addIconWrap { position: absolute; left: 5px; border-radius: 50%; display: flex; align-items: center; justify-content: center; background: var(--c-bg-3); }
/* .addIconWrap::after,.addIconWrap::before{content:'';position:absolute;height:100%;width:100%;background:conic-gradient(from var(--angle), var(--c-accent),var(--c-accent-glow),var(--c-focus),var(--c-focus),var(--c-accent));top:50%;left:50%;translate:-50% -50%;z-index:-1;padding:2px;border-radius:50%;animation:3s borderSpin linear infinite;}
  .addIconWrap::before{opacity:0.5;} */
.addIcon { cursor: pointer; border-radius: 50%; }
.addIcon:hover { background-color: var(--c-hover); }
.readerSearch .searchInput { margin-left: calc(var(--s-5) + 8px); }
.readerBody { overflow: visible; color: var(--c-text); font-size: 14px; line-height: 1.75; }
.readerBody p { margin: 0 0 14px; }
.readerBody p:last-child { margin-bottom: 0; }
.readerBody .citation, .readerBody a { color: var(--c-accent-2); font-weight: 600; }
.readerBody a:hover { text-decoration: underline; }
.loadingHdr { margin-bottom: 12px; color: var(--c-text); font-weight: 800; font-size: 13px; margin-top: 10px; }
.dot { width: 6px; height: 6px; border-radius: 99px; background: var(--c-text-muted); display: inline-block; animation: thgptDot 900ms infinite ease-in-out; }
.dot:nth-child(2) { animation-delay: 120ms; }
.dot:nth-child(3) { animation-delay: 240ms; }
.popover { position: fixed; z-index: 999999; display: none; max-width: calc(100vw - 16px); }
.popoverInner { background: var(--c-bg-3); border: 1px solid var(--c-border); border-radius: var(--r-2); padding: 6px; box-shadow: var(--shadow-2); min-width: 220px; max-width: 280px; }
.popoverItem { display: flex; align-items: center; gap: 5px; width: 100%; text-align: left; background: transparent; border: 0; color: var(--c-text-strong); padding: 8px 10px; border-radius: 10px; cursor: pointer; font-weight: 700; font-size: 14px; line-height: 1.15; white-space: nowrap; }
.popoverItem:hover { background: var(--c-hover); }
.popoverItem.is-active { background: var(--c-accent-glow-2); box-shadow: var(--shadow-accent); }
.popoverItem.is-disabled { opacity: 0.4; cursor: not-allowed; pointer-events: none; }
.popoverLoading { display: flex; align-items: center; gap: 6px; padding: 6px 10px; font-size: 12px; color: var(--c-text-dim); font-weight: 500; }
.popoverSpinner { font-size: 16px; animation: circle-spin 2s infinite linear; }
.popoverList { padding-top: 5px; }
.popoverBack { background: transparent; border: 0; color: var(--c-text-dim); cursor: pointer; padding: 4px 6px; border-radius: 8px; font-size: 14px; line-height: 1; }
.popoverBack:hover { background: var(--c-hover); color: var(--c-text-strong); }
.list { height: calc(100% - 2px); padding: 14px; -webkit-overflow-scrolling: touch; position: relative; }
.splitDragHandle { position: absolute; top: 40px; left: -5px; width: 10px; height: calc(100% - 40px); cursor: col-resize; z-index: 10; }
.splitDragHandle::after { content: ""; position: absolute; top: 10%; left: 50%; transform: translateX(-50%); width: 2px; height: 80%; border-radius: 2px; background: transparent; transition: background 0.15s ease; }
.splitDragHandle:hover::after, .split--resizing .splitDragHandle::after { background: var(--c-accent-glow); }
.split--resizing { user-select: none; cursor: col-resize; }
.tabs { width: 100%; flex-wrap: nowrap; min-width: 0; padding-top: 5px; padding-left: 2px; padding-right: 2px; padding-bottom: 2px; overflow-x: auto; overflow-y: hidden; -webkit-overflow-scrolling: touch; position: relative; scrollbar-width: thin; scrollbar-color: transparent transparent; }
.tabs::-webkit-scrollbar { height: 4px; }
.tabs::-webkit-scrollbar-track { background: transparent; }
.tabs::-webkit-scrollbar-thumb { background: transparent; border-radius: 4px; }
.tabs--hovered { scrollbar-color: var(--c-border, rgba(170, 220, 255, 0.4)) rgba(0, 0, 0, 0.1); }
.tabs--hovered::-webkit-scrollbar-track { background: transparent; }
.tabs--hovered::-webkit-scrollbar-thumb { background: var(--c-border); border-radius: var(--r-pill); }
.tab { padding: 8px 14px; color: var(--c-text); font-weight: 900; font-size: 12px; border: none; cursor: pointer; white-space: nowrap; flex: 0 0 auto; }
.tabInfo { position: absolute; top: -8px; right: -11px; width: 18px; height: 18px; display: flex; align-items: center; justify-content: center; font-size: var(--s-2); font-weight: 800; line-height: 1; color: var(--c-accent); opacity: 0; transition: opacity 0.15s ease, color 0.15s ease, border-color 0.15s ease; }
.tab:hover .tabInfo { opacity: 1; }
.tab.is-active { background: var(--c-accent-glow-2); border: 1px solid var(--c-accent-glow); box-shadow: var(--ring-accent) !important; }
.cardsScroll { padding: 2px 0; max-height: calc(100dvh - 160px); height: 100%; overflow-y: auto; -webkit-overflow-scrolling: touch; }
.cardsCol, .cardsCol .productCards, .cardsCol .campaignCards { font-size: 14px; margin-bottom: -14px; }
.takeawaysH2 { font-size: 22px; font-weight: 700; margin: 0; letter-spacing: 0.2px; }
.takeawaysCardList .cardRowDesc { -webkit-line-clamp: none; font-size: 14px; }
.mdTail { margin-top: 8px; opacity: 0.6; font-size: 12px; white-space: pre-wrap; }
.mdTail:empty { display: none; margin-top: 0; }
.cardsCol[data-type="insights"] .cardRowImg .thgpt__tlSquare { height: 50%; }
.cardsCol[data-type="takeaways"], .cardsCol[data-type="megatrends"] { gap: 0; }
.cardsCol[data-type="takeaways"] .cardRow { display: flex; padding: 0 14px; width: 100%; cursor: default; }
.cardsCol[data-type="takeaways"] .cardRowMain { justify-content: space-evenly; width: 100%; }
.cardsCol[data-type="takeaways"] .sk--line, .cardsCol[data-type="megatrends"] .sk--line { height: 50px; }
.cardsCol[data-type="megatrends"] .cardRow { grid-template-columns: 1fr; }
.cardsCol[data-type="megatrends"] .cardRowMain { display: flex; align-items: center; gap: 14px; width: 100%; justify-content: flex-start; flex-direction: row; padding: 12px 14px 12px 14px; }
.cardsCol[data-type="megatrends"] .mt__cont { width: calc(100% - 55px); }
.cardsCol[data-type="megatrends"] .cardRowTitle { margin-bottom: 5px; }
.cardsCol[data-type="megatrends"] .cardRowImg { width: 90px; height: 90px; min-height: 90px; }
.cardsCol[data-type="product-gen"] .exploreFurther, .cardsCol[data-type="campaign-gen"] .exploreFurther { margin-top: 14px; }
.cardsCol[data-type="product-gen"] .cardRowImg, .cardsCol[data-type="campaign-gen"] .cardRowImg { min-height: 255px; max-height: 265px; }
.cardsCol[data-type="product-gen"] .cardRowTitle, .cardsCol[data-type="campaign-gen"] .cardRowTitle { font-size: 18px; }
.cardsCol[data-type="product-gen"] .cardRowDesc, .cardsCol[data-type="campaign-gen"] .cardRowDesc { font-size: 15px; }
.exploreFurtherWrap { width: 100%; }
.exploreFurther { justify-content: center; }
.refreshProducts, .refreshCampaigns, .exploreFurther { cursor: pointer; width: 100%; text-transform: uppercase; }
.productCards .cardRow, .campaignCards .cardRow { grid-template-columns: 1fr; padding: 14px; }
.productCards .cardRowDesc, .campaignCards .cardRowDesc { -webkit-line-clamp: none; }
.productCards .cardRowImg, .campaignCards .cardRowImg { position: relative; border-radius: var(--r-2); overflow: hidden; background: var(--c-bg-3); }
.productCards .cardRowmg { max-height: 250px; }
.cardRow { display: grid; grid-template-columns: 168px 1fr; gap: 14px; background: var(--c-panel-2); border: 1px solid var(--c-border); border-radius: var(--r-3); overflow: hidden; }
.cardRow:not(.cardRow--skeleton):hover { border-color: var(--c-accent-2); box-shadow: 0 0 0 2px var(--c-accent-glow); cursor: pointer; }
.cardRowImg { min-height: 155px; max-height: 165px; }
.cardRowImg img { width: 100%; height: 100%; object-fit: cover; display: block; }
.cardRowImg--loaded:not(.sk)::after, .cards .cardMedia::after { content: "expand_content"; position: absolute; right: 5px; bottom: 5px; opacity: 0; font-family: "Material Symbols Outlined"; font-size: 16px; line-height: 1; color: var(--c-text); width: 24px; height: 24px; display: grid; place-items: center; background: var(--c-bg); border-radius: var(--r-2); backdrop-filter: blur(6px); pointer-events: none; cursor: pointer; }
.cardRow:not(.sk):hover .cardRowImg--loaded::after, .card:hover .cardMedia::after { opacity: 1; }
.cardRowMain { padding: 12px 14px 12px 0; min-width: 0; display: flex; flex-direction: column; gap: calc(var(--s-3) / 2); }
.cardRowTitle { margin: 0; font-size: 16px; font-weight: 900; color: var(--c-text-strong); letter-spacing: -0.15px; line-height: 1.2; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.cardRowDesc { margin: 0; color: var(--c-text-muted); font-size: 13px; line-height: 1.55; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.cardRowDescText { display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2; overflow: hidden; }
.cardRowFooter { margin-top: auto; display: flex; align-items: center; justify-content: space-between; gap: 10px; position: relative; }
.cardRowIcons { display: flex; color: var(--c-text-dim); }
.cardRowIco { width: 50px; display: grid; place-items: center; }
.cardRowIco img { width: 100%; height: 100%; opacity: 0.35; }
.cardRowIco.cardRowIco--selected img { opacity: 1; }
.cardRowActions { margin-top: auto; border-top: 1px solid var(--c-border); padding-top: 12px; justify-content: flex-end; }
.cardRowScore { display: flex; align-items: center; gap: 10px; width: 100%; }
.cardRowFooter { margin-top: auto; display: flex; align-items: center; justify-content: space-between; gap: 12px; padding-top: 12px; }
.cardRowScore { display: flex; align-items: center; gap: 10px; min-width: 0; flex: 1 1 auto; }
.cardRowScore .material { font-size: 16px; cursor: pointer; color: var(--c-text); }
.cardRowFooter .cardRowScore .material { font-size: 14px; }
.cardRowBar { width: 100%; max-width: 260px; height: 8px; border-radius: var(--r-pill); background: var(--c-border); overflow: hidden; border: 1px solid var(--c-border); }
.cardRowBarFill { display: block; height: 100%; width: 0%; background: linear-gradient(90deg, var(--c-accent), var(--c-accent-glow)); border-radius: var(--r-pill); }
.cardRowTen { font-size: 12px; font-weight: 900; color: var(--c-text-muted); white-space: nowrap; }
.cardRowActions { display: flex; align-items: center; gap: 8px; flex: 0 0 auto; }
.cardRowSave { border-radius: var(--r-pill); padding: 8px 12px; font-weight: 950; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; }
.cardRowSave[aria-pressed="true"] { background: var(--c-accent-glow-2); border-color: var(--c-accent-glow); color: var(--c-text-strong); box-shadow: var(--shadow-accent); }
.cardRowReasons { margin: 8px 0 0; padding: 0; list-style: none; color: var(--c-text-muted); font-size: 13px; line-height: 1.55; }
.cardRowReasons li { margin: 0; padding-left: 14px; position: relative; }
.cardRowReasons li::before { content: "•"; position: absolute; left: 0; top: 0; opacity: 0.7; }
.cardRowReasonsHeader { margin: 8px 0 4px; font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--c-text-muted); opacity: 0.8; }
.cardRowReasonLine { margin-bottom: 5px; padding-left: 14px; position: relative; color: var(--c-text-muted); font-size: 13px; line-height: 1.55; }
.cardRowReasonLine::before { content: "•"; position: absolute; left: 0; top: 0; opacity: 0.7; }
.cardRow.is-locked { position: relative; overflow: hidden; border: 1px solid var(--c-border); border-radius: var(--r-3); background: linear-gradient(180deg, rgba(11, 35, 51, 0.22), rgba(7, 18, 29, 0.18)); box-shadow: var(--shadow-2); }
.cardRow.is-locked .cardRowMain { filter: blur(10px); opacity: 0.52; pointer-events: none; user-select: none; transform: scale(1.01); }
.cardRowLockOverlay { position: absolute; inset: 0; padding: var(--s-3); display: flex; align-items: center; justify-content: center; background: radial-gradient(900px 180px at 70% 0%, var(--c-accent-glow-2), rgba(0, 0, 0, 0) 55%), linear-gradient(180deg, rgba(5, 11, 18, 0), rgba(5, 11, 18, 0.18)); }
.cardRowLockBox { display: inline-flex; align-items: center; gap: var(--s-2); padding: 8px 10px; border-radius: var(--r-pill); background: linear-gradient(180deg, var(--c-panel-2), var(--c-panel)); border: 1px solid var(--c-border); backdrop-filter: blur(12px); box-shadow: var(--shadow-2); }
.cardRowLockBox .lockTitle { font-weight: 800; color: var(--c-text-strong); letter-spacing: 0.2px; display: inline-flex; align-items: center; gap: 8px; }
.cardRowLockBox .lockTitle::before { content: ""; width: 10px; height: 10px; border-radius: var(--r-pill); background: var(--c-accent); box-shadow: 0 0 0 4px var(--c-accent-glow); }
.cardRowLockBox .lockDesc { display: none; }
.cardRowLockBox .lockBtn { border: 1px solid var(--c-accent-glow); background: linear-gradient(180deg, var(--c-accent-glow), var(--c-accent-glow-2)); color: var(--c-text-strong); border-radius: var(--r-pill); padding: 8px 12px; font-weight: 900; cursor: pointer; box-shadow: var(--shadow-accent); line-height: 1; }
.cardRowLockBox .lockBtn:hover { border-color: var(--c-accent-2); background: linear-gradient(180deg, var(--c-accent-glow), var(--c-accent-glow-2)); }
.cardRowLockBox .lockBtn:active { transform: translateY(1px); }
.cardRowLockBox .lockBtn:focus { outline: none; box-shadow: var(--ring-accent), var(--shadow-accent); }
.cardBar { width: 65%; height: 8px; border-radius: var(--r-pill); background: var(--c-bg-3); overflow: hidden; border: 1px solid var(--c-border); }
.cardBar span { display: block; height: 100%; background: linear-gradient(90deg, var(--c-accent), var(--c-accent-2)); border-radius: var(--r-pill); }
.thgpt__tlSquare { width: 50%; height: 50%; display: inline-block; vertical-align: top; }
.thgpt__tlSquare:last-child:nth-child(3) { width: 100%; }
.thgpt__tlSquare img { width: 100%; height: 100%; object-fit: cover; }
.cardRowImg--loaded { position: relative; transition: max-height 0.18s ease; }
.cardRowImg--loaded.isExpanded, .cardMedia.isExpanded { max-height: 520px !important; }
/* pick what you want */
.cardRowImg--loaded.isExpanded img, .cardMedia.isExpanded img { object-fit: contain; background: var(--c-bg-3); }
.list--showing { width: var(--s-5); }
.split:has(.list--showing) { grid-template-columns: 4fr 0.1fr; }
.split:has(.list--showing) .splitCollapseBtn { left: -14px; }
.list--showing .tabs, .list--showing .iconMini, .list--showing .cardsScroll { display: none; }
.split:has(.list--expanded) { grid-template-columns: 0.1fr 4fr; }
.split:has(.list--expanded) .reader { opacity: 0; }
.split:has(.list--expanded) .splitCollapseBtn { display: none; }
.split:has(.list--expanded) .splitDragHandle { display: none; }
.split:has(.list--showing) .splitExpandBtn { display: none; }
.split:has(.list--expanded) .cardsCol, .split:has(.list--expanded) .productCards, .split:has(.list--expanded) .campaignCards, .split:has(.list--expanded) .takeawaysCards { flex-flow: row wrap; width: 100%; }
.split:has(.list--expanded) .cardRow { width: calc(50% - 7px); }
.split:has(.list--expanded) .takeawaysCards section { width: calc(50% - 9px); }
.split:has(.list--expanded) .takeawaysCards section .cardRow { width: 100%; height: 115px; }
.split:has(.list--expanded) .cardsCol[data-type="takeaways"] .cardRowMain { justify-content: flex-start; }
.cardsCol[data-type="product-gen"] .cardRowMain, .cardsCol[data-type="campaign-gen"] .cardRowMain { gap: var(--s-3); padding: 12px 0 0 0; }
.cardsCol[data-type="product-gen"] .cardRow, .cardsCol[data-type="campaign-gen"] .cardRow { gap: 5px; position: relative; }
.cardsCol[data-type="product-gen"] .cardRow:not(.card--saved):not(.is-locked)::after, .cardsCol[data-type="campaign-gen"] .cardRow:not(.card--saved):not(.is-locked)::after { content: ""; position: absolute; top: 17px; right: 17px; width: 22px; height: 22px; border-radius: var(--r-2); background: var(--c-bg-2); border: 2px solid var(--c-text-muted); opacity: 0.25; transition: opacity 140ms ease, transform 140ms ease, background 140ms ease, border-color 140ms ease, box-shadow 140ms ease; }
.cardRow.card--selected::before { top: 20px; right: 20px; }
.cardsCol[data-type="product-gen"] .cardRow:hover, .cardsCol[data-type="campaign-gen"] .cardRow:hover { border-color: var(--c-accent-2); box-shadow: 0 0 0 2px var(--c-accent-glow); cursor: pointer; }
.cardsCol[data-type="product-gen"] .cardRowBar, .cardsCol[data-type="campaign-gen"] .cardRowBar { height: 12px; max-width: 100%; }
.cardsCol[data-type="product-gen"] .cardRowTen, .cardsCol[data-type="campaign-gen"] .cardRowTen { font-size: 16px; }
/* Inline Article Pill */
.sourceRow { margin: var(--s-3) 0 var(--s-5); display: flex; gap: var(--s-3); align-items: center; flex-wrap: wrap; }
.sourceLabel { color: var(--c-text-muted); font-weight: 600; letter-spacing: 0.2px; }
.sourcePills { display: flex; gap: var(--s-2); flex-wrap: wrap; }
.articlePill { display: flex; align-items: center; gap: var(--s-2); padding: 3px 5px; border-radius: var(--r-pill); border: 1px solid var(--c-border); background: var(--c-accent-glow-2); box-shadow: var(--shadow-accent); text-decoration: none; max-width: 420px; position: relative; transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease; }
.articlePill:hover { background: var(--c-hover); border-color: var(--c-focus); text-decoration: none !important; }
.articlePill:focus-visible { outline: none; box-shadow: var(--shadow-accent), var(--ring-accent); }
.pillImg { width: 28px; height: 28px; border-radius: var(--r-pill); object-fit: cover; flex: 0 0 auto; background: var(--c-panel-2); }
.pillImg--ph { display: inline-block; background: var(--c-panel-2); }
.pillText { display: flex; align-items: baseline; gap: var(--s-2); min-width: 0; font-size: 13px; }
.pillNum { color: var(--c-text); font-weight: 700; position: absolute; top: -9px; right: -2px; text-shadow: 0 1px 0 rgba(0, 0, 0, 0.35); font-size: 10px; }
.pillTitle { color: var(--c-text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 340px; }
a.citeNum { color: var(--c-accent); font-weight: 700; text-decoration: none; }
/* Skeleton */
.cardsCol.is-loading { pointer-events: none; }
.cardRow--skeleton .sk { display: block; background: var(--c-bg-3); border-radius: 10px; position: relative; overflow: hidden; border: 1px solid var(--c-border); }
.cardRow--skeleton .sk::after { content: ""; position: absolute; inset: 0; transform: translateX(-120%); background: linear-gradient(90deg, transparent, rgba(170, 220, 255, 0.16), transparent); animation: thgptShimmer 1.2s infinite; }
.cardRow--skeleton .cardRowImg { height: 155px; }
.cardRow--skeleton .sk--img { width: 100%; height: 100%; border-radius: 12px; }
.cardRow--skeleton .sk--title { height: 16px; width: 70%; margin-bottom: 10px; }
.cardRow--skeleton .sk--line { height: 12px; width: 95%; margin-bottom: 8px; }
.cardRow--skeleton .sk--line2 { width: 82%; }
.cardRow--skeleton .sk--footer { height: 28px; width: 100%; border-radius: 12px; }
.takeawayCards .sk--line, .productCards .sk--line, .campaignCards .sk--line { height: 50px; }
/* History skeleton loading */
.historyCard--sk { pointer-events: none; position: relative; overflow: hidden; }
.historyCard--sk::after { content: ""; position: absolute; inset: 0; transform: translateX(-120%); background: linear-gradient(90deg, transparent, rgba(170, 220, 255, 0.16), transparent); animation: thgptShimmer 1.2s infinite; }
.historyCard--sk:hover { transform: none; box-shadow: none; }
.historyCard--sk .sk { display: block; border-radius: 8px; background: var(--c-bg-2); }
.historyCard--sk .sk--icon { width: 22px; height: 22px; border-radius: 6px; flex: 0 0 auto; }
.historyCard--sk .sk--prompt { height: 16px; width: 220px; }
.historyCard--sk .sk--prompt-long { width: 340px; }
.historyCard--sk .sk--prompt-short { width: 160px; }
.historyCard--sk .sk--btn { height: 28px; width: 56px; border-radius: 999px; }
.historyCard--sk .sk--chip { height: 32px; width: 120px; border-radius: 999px; }
.historyCard--sk .sk--chip-wide { width: 170px; }
.historyCard--sk .sk--date { height: 12px; width: 80px; flex: 0 0 auto; }
/* Popup Article */
.pop__cont { position: fixed; top: 0; left: 0; width: 100vw; height: 100dvh; display: flex; flex-flow: row; justify-content: center; align-items: center; z-index: 100000; opacity: 1; visibility: visible; transition: opacity 0.18s ease, visibility 0.18s ease; }
.pop__bg { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.55); opacity: 1; transition: opacity 0.18s ease; }
.pop__cont .ig__iframe { width: 100%; height: 600px; border: 0; }
.pop__inner { position: relative; transform: translateY(0) scale(1); opacity: 1; transition: transform 0.18s ease, opacity 0.18s ease; }
.pop__closeIcon { position: absolute; top: 7px; right: 10px; cursor: pointer; padding: 5px; z-index: 2; }
.pop__closeIcon:hover { background: var(--c-hover); box-shadow: 0 0 0 2px var(--c-accent-glow); border-radius: 50%; }
.pop__closeTutorial { display: flex; align-items: center; }
.pop__closeTutorial:hover { border-radius: var(--r-2) !important; }
.thgpt__popNav--prev { position: absolute; top: 12px; right: 50px; border: none; background: var(--c-bg-3); outline: none; color: var(--c-text-strong); border-radius: var(--r-pill); padding: 0px 10px; z-index: 2; cursor: pointer; display: flex; align-items: center; gap: 5px; font-size: 15px; border: 1px solid var(--c-border); }
.thgpt__popNav--prev:hover { background: var(--c-hover); box-shadow: 0 0 0 2px var(--c-accent-glow); }
.pop__content { max-height: 90dvh; overflow-y: auto; padding: 35px; position: relative; width: min(900px, calc(100vw - 70px)); padding: calc(var(--s-5) * 1.5); background: var(--c-bg); border: 1px solid var(--c-border); border-radius: 22px; box-shadow: 0 28px 120px rgba(0, 0, 0, 0.75); backdrop-filter: blur(18px); }
.pop__content::-webkit-scrollbar { display: none; }
.pop__cont.is-closing { opacity: 0; visibility: hidden; }
.pop__cont.is-closing .pop__bg { opacity: 0; }
.pop__cont.is-closing .pop__inner { transform: translateY(8px) scale(0.985); opacity: 0; }
@media (prefers-reduced-motion: reduce) {
	.pop__cont, .pop__bg, .pop__inner { transition: none; }
}
.pop--tutorial .pop__bg { backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); }
.thgpt__pop { width: 100%; }
.thgpt__popHead { margin-bottom: 14px; }
.thgpt__popTitle { font-size: 32px; line-height: 1.12; font-weight: 980; letter-spacing: -0.02em; margin: 0; color: var(--c-text-strong); }
.thgpt__popSubTitle { margin-top: 8px; font-size: 18px; line-height: 1.45; font-weight: 850; color: var(--c-text-muted); }
.thgpt__popByline { margin-top: 10px; display: flex; align-items: center; gap: 10px; color: var(--c-text-dim); font-size: 14px; font-weight: 850; }
.thgpt__popDot { opacity: 0.55; }
.thgpt__popRefs { margin-top: 8px; font-size: 14px; color: var(--c-text-muted); display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.thgpt__popRefsLbl { font-weight: 950; color: var(--c-text-muted); }
.thgpt__popRefSep { opacity: 0.5; padding: 0 4px; }
.thgpt__popRefLink { color: var(--c-text-strong); text-decoration: none; border-bottom: 1px solid var(--c-border); padding-bottom: 1px; }
.thgpt__popRefLink:hover { border-bottom-color: var(--c-focus); }
.thgpt__popMedia { margin: 16px 0 18px; border-radius: 20px; overflow: hidden; background: var(--c-bg-3); border: 1px solid var(--c-border); max-height: 350px; display: flex; align-items: center; justify-content: center; }
.thgpt__popMedia--insight { height: 350px; display: inline-block; }
.thgpt__popImg { width: 100%; height: 100%; max-height: 46dvh; object-fit: cover; display: block; }
.thgpt__popBody { margin-top: 10px; font-size: 15px; line-height: 1.68; color: var(--c-text); white-space: pre-line; }
.thgpt__popBody b { color: var(--c-text-strong); }
.thgpt__popAI { margin-top: 18px; padding: 16px; border-radius: 18px; background: var(--c-bg-3); border: 1px solid var(--c-border); color: var(--c-text); font-size: 13px; line-height: 1.65; }
.thgpt__popAI .tgta__aiText, .thgpt__popAI .aiText { margin: 0; }
.thgpt__popAI .tpt__aSecCont { padding: 0; background: none; border: none; }
.thgpt__popAI .tpt__aSec:first-child { margin-bottom: var(--s-5); }
.thgpt__popAI .tpt__aSecHeading { font-size: 13px; font-weight: 900; letter-spacing: 0.14em; text-transform: uppercase; color: var(--c-text-dim); margin: 0 0 14px 0; }
.thgpt__popAI .tpt__aSecItems { display: flex; flex-direction: column; gap: 12px; }
.thgpt__popAI .tpt__aItem { padding: 0; background: none; border: none; }
.thgpt__popAI .tpt__aItemText { font-size: 14px; line-height: 1.65; color: var(--c-text); }
.thgpt__popAI .tpt__aItemTitle { font-weight: 900; color: var(--c-text-strong); }
.thgpt__popAI .tpt__aSec + .tpt__aSec { padding-top: var(--s-5); border-top: 1px solid var(--c-border); }
.thgpt__popMeta .tha__scoreBarLbl { font-size: 18px; font-weight: 400; text-align: right; width: 85px; line-height: 1; display: inline-block; vertical-align: middle; color: var(--c-text-muted); }
.thgpt__popMeta .tha__scoreCont { display: flex; flex-flow: row wrap; align-items: center; margin-bottom: 35px; margin-bottom: var(--aspace); }
.thgpt__popMeta .tha__scoreBars { width: 100%; display: inline-flex; flex-flow: column; justify-content: space-between; height: 100%; padding: 5px calc(var(--s-3) / 2); }
.thgpt__popMeta .tha__scoreLbl { font-size: 20px; font-weight: 300; color: var(--c-text-strong); }
.thgpt__popMeta .tha__scoreBar { width: calc(100% - 85px); display: inline-block; vertical-align: middle; padding-left: 15px; }
.thgpt__popMeta .tha__scorePart { height: 10px; display: inline-block; vertical-align: top; }
.thgpt__popMeta .tha__scorePart--filled { background: var(--c-accent); }
.thgpt__popMeta .tha__scorePart--empty { background: linear-gradient(to right, transparent 50%, var(--c-accent-glow) 50%); background-size: 4px 1px, 100% 0px; height: 10px; }
.thgpt__popMeta .demo__genderBox { display: inline-block; width: 14px; height: 15px; vertical-align: top; background: var(--demo-sprite); background-color: var(--c-text-dim); }
.thgpt__popMeta .demo__genderBox.demo__genderBox--on { background-color: var(--c-accent) !important; }
.thgpt__popMeta .demo__male { background-position-x: -15px; background-position-y: -48px; }
.thgpt__popMeta .demo__female { background-position-x: 1px; background-position-y: -48px; }
.thgpt__popMeta .demo__ageGender { display: inline-block; vertical-align: middle; margin-right: 10px; }
.thgpt__popMeta .demo__ageBox { display: inline-block; vertical-align: bottom; height: 46px; background: var(--demo-sprite); background-color: var(--c-text-dim); }
.thgpt__popMeta .demo__ageBox.demo__ageBox--on { background-color: var(--c-accent) !important; }
.thgpt__popMeta .demo__baby { width: 16px; background-position-x: 0px; background-position-y: 0px; }
.thgpt__popMeta .demo__child { width: 12px; background-position-x: -17px; background-position-y: 0px; }
.thgpt__popMeta .demo__kid { width: 20px; background-position-x: -29px; background-position-y: 0px; }
.thgpt__popMeta .demo__youngAdult { width: 23px; background-position-x: -49px; background-position-y: 0px; }
.thgpt__popMeta .demo__middleAge { width: 22px; background-position-x: -72px; background-position-y: 0px; }
.thgpt__popMeta .demo__senior { width: 20px; background-position-x: -94px; background-position-y: 0px; }
.thgpt__popMeta .demo__map { width: 120px; height: 79px; display: inline-block; background-image: var(--regions-sprite); vertical-align: middle; margin-right: 0px; background-color: var(--c-accent) !important; }
.thgpt__popMeta .tha__demoLeft, .thgpt__popMeta .tha__demoRight { display: inline-block; vertical-align: middle; width: 50%; }
.thgpt__popMeta .tha__demoBox { width: 250px; }
.thgpt__popLinkRow { margin-top: 18px; padding-top: 14px; border-top: 1px solid var(--c-border); }
.thgpt__popLink { color: var(--c-text-strong); font-weight: 950; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; text-decoration: none; display: inline-flex; align-items: center; gap: 8px; }
.thgpt__popLink:hover { text-decoration: underline; text-underline-offset: 4px; }
.thgpt__popMeta { margin-top: 18px; display: flex; gap: 16px; }
.thgpt__popScoreBox { width: 110px; height: 110px; border-radius: 18px; background: var(--c-bg-3); border: 1px solid var(--c-border); display: flex; align-items: center; justify-content: center; font-weight: 980; font-size: 26px; color: var(--c-text-strong); }
.thgpt__popScore { min-width: 0; width: 50%; display: flex; align-items: center; }
.thgpt__popDemo { grid-column: 1 / -1; margin-top: 10px; }
.thgpt__popPMT { margin-top: 18px; display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.thgpt__popPMTItem { padding: 14px; border-radius: 18px; background: var(--c-bg-3); border: 1px solid var(--c-border); }
.thgpt__popPMTTitle, .thgpt__popRelLbl { font-weight: 950; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--c-text-muted); margin-bottom: 10px; }
.thgpt__popRelLbl { margin-top: 18px; }
.thgpt__popRel { margin-top: 18px; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.thgpt__popRelItem { display: grid; grid-template-columns: 84px 1fr; gap: 12px; padding: 12px; border-radius: 18px; background: var(--c-bg-3); border: 1px solid var(--c-border); text-decoration: none; color: var(--c-text-strong); }
.thgpt__popRelItem:hover { background: var(--c-hover); }
.thgpt__popRelImg { width: 84px; height: 84px; border-radius: 14px; overflow: hidden; background: var(--c-bg-2); border: 1px solid var(--c-border); }
.thgpt__popRelImgEl { width: 100%; height: 100%; object-fit: cover; display: block; }
.thgpt__popRelText { min-width: 0; }
.thgpt__popRelT1 { font-weight: 950; font-size: 13px; line-height: 1.2; color: var(--c-text-strong); }
.thgpt__popRelT2 { margin-top: 4px; font-weight: 850; font-size: 12px; color: var(--c-text-muted); line-height: 1.2; }
.thgpt__popRelBar { grid-column: 1 / -1; height: 8px; border-radius: var(--r-pill); overflow: hidden; background: var(--c-bg-2); display: flex; border: 1px solid var(--c-border); }
.thgpt__popRelBarPart { height: 100%; }
.thgpt__popRelBarPart--filled { background: var(--c-accent); }
.thgpt__popRelBarPart--empty { background: var(--c-accent-glow); }
.thgpt__popBtn { margin-top: 18px; border: none; border-radius: 16px; padding: 12px 14px; cursor: pointer; background: var(--c-panel-2); border: 1px solid var(--c-border); color: var(--c-text-strong); display: inline-flex; align-items: center; gap: 10px; }
.thgpt__popBtn:hover { background: var(--c-panel); }
.thgpt__popBtnLbl { font-weight: 950; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; }
/* Tutorial popup */
.thgpt__tutorialPop { width: 100%; text-align: center; height: 75dvh; display: flex; flex-direction: column; justify-content: space-between; }
.thgpt__popTutorialHead { margin-bottom: 22px; }
.thgpt__tutorialTitle { font-size: 36px; line-height: 1.1; font-weight: 980; letter-spacing: -0.02em; color: var(--c-text-strong); }
.thgpt__tutorialSubTitle { font-size: 15px; line-height: 1.6; color: var(--c-text-muted); font-weight: 400; max-width: 75%; margin: 0 auto; margin-top: 10px; }
.thgpt__tutorialSubTitle ul { margin: 0; width: fit-content; }
.thgpt__tutorialSubTitle ul li { text-align: left; }
.thgpt__tutorialSubTitle--left { text-align: left; }
/* Carousel track + slides */
.thgpt__popTutorialBody { border-radius: 16px; overflow: hidden; border: 1px solid var(--c-border); }
.thgpt__carTrack { position: relative; }
.thgpt__carSlide { display: none; animation: thgpt__carFadeIn 0.2s ease; }
.thgpt__carSlide--active { display: block; }
@keyframes thgpt__carFadeIn {
	from { opacity: 0; }
	to { opacity: 1; }
}
/* Video area */
.thgpt__carVideo { width: 100%; aspect-ratio: 16/9; background: var(--c-bg-2); overflow: hidden; position: relative; }
.thgpt__carVideoEl { width: 100%; height: 100%; object-fit: cover; display: block; }
.thgpt__carVideoPlaceholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; }
.thgpt__carPlayIcon { font-size: 56px !important; color: var(--c-text-dim); opacity: 0.3; }
/* Nav bar */
.thgpt__popCarouselNav { display: flex; align-items: center; justify-content: center; gap: 16px; margin-top: 20px; }
.thgpt__carDots { display: flex; align-items: center; gap: 10px; }
.thgpt__carDot { width: 13px; height: 13px; border-radius: 50%; background: transparent; border: 2px solid rgba(170, 220, 255, 0.35); cursor: pointer; padding: 0; transition: background 0.2s, border-color 0.2s; flex-shrink: 0; }
.thgpt__carDot--active { background: var(--c-accent); border-color: var(--c-accent); }
.thgpt__carPrev, .thgpt__carNext { border: none; background: var(--c-accent); border-radius: 50%; width: 40px; height: 40px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; cursor: pointer; color: var(--c-text-strong); transition: background 0.15s, box-shadow 0.15s; outline: none; }
.thgpt__carPrev:hover:not(:disabled), .thgpt__carNext:hover:not(:disabled) { background: var(--c-accent-2); box-shadow: 0 0 0 4px var(--c-accent-glow); }
.thgpt__carPrev:disabled, .thgpt__carNext:disabled { opacity: 0.35; cursor: default; }
.thgpt__carPrev .material, .thgpt__carNext .material { font-size: 26px; }
/* Settings Page */
.settingsPage { width: 100%; margin: 0 auto; position: relative; }
.settingsGrid { display: grid; grid-template-columns: 1.2fr 0.8fr; gap: var(--s-5); margin-top: var(--s-5); }
.settingsGrid .is-full { grid-column: 1 / -1; }
@media (max-width: 1100px) {
	.settingsGrid { grid-template-columns: 1fr; }
}
.settingsCard { border: 1px solid var(--c-border); border-radius: var(--r-3); background: linear-gradient(180deg, var(--c-bg-3), var(--c-bg-2)); padding: 18px; box-shadow: var(--shadow-2); }
.settingsCardHead { padding-bottom: 14px; border-bottom: 1px solid var(--c-border); margin-bottom: 14px; }
.settingsKicker { font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--c-text-muted); font-weight: 900; }
.settingsCardTitle { font-size: 18px; color: var(--c-text-strong); font-weight: 900; letter-spacing: -0.2px; }
.settingsCardSub { font-size: 13px; line-height: 1.55; color: var(--c-text-muted); max-width: 560px; }
.settingsCardSub strong { color: var(--c-accent-2); }
.settingsBadge { padding: 8px 12px; font-size: 12px; color: var(--c-text); background: rgba(255, 255, 255, 0.04); border: 1px solid var(--c-border); }
.settingsHint { font-size: 13px; line-height: 1.5; }
.settingsFoot { margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--c-border); }
/* Theme picker */
.themeGrid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--s-2); margin-top: var(--s-2); }
@media (max-width: 700px) {
	.themeGrid { grid-template-columns: 1fr; }
}
.themeOption { cursor: pointer; display: block; }
.themeRadio { position: absolute; opacity: 0; pointer-events: none; }
.themeOptionInner { display: flex; height: 100%; border: 1px solid var(--c-border); border-radius: var(--r-3); background: color-mix(in srgb, var(--c-panel) 35%, transparent); padding: 12px; transition: transform 160ms ease, background 160ms ease, border-color 160ms ease, box-shadow 140ms ease; }
.themeOption:hover .themeOptionInner { transform: translateY(-1px); background: color-mix(in srgb, var(--c-panel-2) 45%, transparent); border-color: color-mix(in srgb, var(--c-border) 55%, var(--c-text-dim)); box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-hover) 90%, transparent); }
.themeRadio:checked + .themeOptionInner { border-color: var(--c-accent); box-shadow: var(--ring-accent), var(--shadow-2); background: color-mix(in srgb, var(--c-accent-glow-2) 55%, var(--c-panel-2)); }
.themeOptionTop { display: flex; gap: 12px; align-items: center; }
.themeSwatch { width: 44px; height: 44px; border-radius: 14px; border: 1px solid color-mix(in srgb, var(--c-border) 65%, transparent); box-shadow: inset 0 1px 0 color-mix(in srgb, var(--c-text-dim) 50%, transparent); }
.themeSwatch--blue { background: radial-gradient(120% 120% at 20% 0%, rgba(120, 230, 255, 0.22), rgba(0, 0, 0, 0) 60%), linear-gradient(180deg, #0f2d41, #07121d); }
.themeSwatch--graphite { background: radial-gradient(120% 120% at 20% 0%, var(--c-border-2), rgba(0, 0, 0, 0) 60%), linear-gradient(180deg, #141a24, #06070a); }
.themeSwatch--teal { background: radial-gradient(120% 120% at 20% 0%, rgba(90, 200, 255, 0.22), rgba(0, 0, 0, 0) 60%), linear-gradient(180deg, #11384d, #071a24); }
.themeSwatch--light { background: radial-gradient(120% 120% at 20% 0%, rgba(120, 230, 255, 0.18), rgba(0, 0, 0, 0) 60%), linear-gradient(180deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.04)); }
.themeSwatch--purple { background: radial-gradient(120% 120% at 20% 0%, rgba(180, 120, 255, 0.22), rgba(0, 0, 0, 0) 60%), linear-gradient(180deg, #1e1849, #0b0820); }
.themeSwatch--mint { background: radial-gradient(120% 120% at 20% 0%, rgba(120, 255, 230, 0.2), rgba(0, 0, 0, 0) 60%), linear-gradient(180deg, #0d3b3c, #061a1b); }
.themeSwatch--rose { background: radial-gradient(120% 120% at 20% 0%, rgba(255, 150, 190, 0.2), rgba(0, 0, 0, 0) 60%), linear-gradient(180deg, #3a1b29, #1a0a10); }
.themeSwatch--sand { background: radial-gradient(120% 120% at 20% 0%, rgba(255, 200, 120, 0.22), rgba(0, 0, 0, 0) 60%), linear-gradient(180deg, rgba(255, 255, 255, 0.78), #f6ecdc); }
.themeName { font-size: 14px; font-weight: 900; color: var(--c-text-strong); letter-spacing: -0.15px; }
.themeDesc { font-size: 12px; line-height: 1.45; color: var(--c-text-muted); }
.themeMini { margin-top: 12px; border-radius: 16px; border: 1px solid color-mix(in srgb, var(--c-border) 65%, transparent); background: color-mix(in srgb, var(--c-bg-2) 65%, transparent); overflow: hidden; }
.themeMiniBar { height: 10px; background: linear-gradient(90deg, color-mix(in srgb, var(--c-text-dim) 22%, transparent), color-mix(in srgb, var(--c-text-dim) 10%, transparent)); }
.themeMiniRow { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; padding: 10px; }
.themeMiniCard { height: 28px; border-radius: var(--r-2); background: color-mix(in srgb, var(--c-panel-2) 55%, transparent); border: 1px solid color-mix(in srgb, var(--c-border) 65%, transparent); }
/* Collab list */
.collabList { display: flex; flex-direction: column; gap: 10px; margin-top: 14px; }
.collabRow { display: flex; align-items: center; justify-content: space-between; gap: var(--s-3); padding: var(--s-3); border: 1px solid var(--c-border); border-radius: var(--r-3); background: color-mix(in srgb, var(--c-panel) 35%, transparent); transition: transform 160ms ease, background 160ms ease, border-color 160ms ease, box-shadow 140ms ease; }
.collabRow:hover { transform: translateY(-1px); background: color-mix(in srgb, var(--c-panel-2) 45%, transparent); border-color: color-mix(in srgb, var(--c-border) 55%, var(--c-text-dim)); box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-hover) 90%, transparent); }
.collabLeft { display: flex; align-items: center; gap: var(--s-3); min-width: 0; }
.collabAvatar { width: 42px; height: 42px; border-radius: 14px; display: grid; place-items: center; font-weight: 950; color: var(--c-text-strong); background: linear-gradient(180deg, var(--c-panel-2), var(--c-bg-2)); border: 1px solid color-mix(in srgb, var(--c-border) 65%, transparent); }
.collabMeta { min-width: 0; }
/* Theme pager */
.themePager { display: grid; grid-template-columns: auto 1fr auto; gap: var(--s-3); align-items: center; margin-top: 14px; }
.themeNav { min-width: 44px; justify-content: center; }
.themeViewport { position: relative; min-width: 0; }
.themePage { display: none; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.themePage.themePage--active { display: grid; }
@media (max-width: 700px) {
	.themePage { grid-template-columns: 1fr; }
}
.themeDots { display: flex; justify-content: center; gap: 8px; margin-top: 12px; }
.themeDot { width: 8px; height: 8px; border-radius: var(--r-pill); border: 1px solid var(--c-border); background: transparent; cursor: pointer; opacity: 0.7; }
.themeDot:hover { opacity: 1; background: var(--c-hover); }
.themeDot.is-active { background: var(--c-accent-glow); border-color: var(--c-accent); opacity: 1; }
.settingsCardTitle--sm { font-size: 14px; }
.settingsList { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.settingsListItem { display: flex; align-items: flex-start; gap: 10px; font-size: 13px; line-height: 1.55; color: var(--c-text); }
.settingsListIcon { width: 18px; height: 18px; border-radius: 10px; display: grid; place-items: center; flex: 0 0 auto; margin-top: 2px; background: color-mix(in srgb, var(--c-hover) 75%, transparent); border: 1px solid color-mix(in srgb, var(--c-border) 85%, transparent); color: var(--c-accent); box-shadow: inset 0 1px 0 color-mix(in srgb, var(--c-text-dim) 35%, transparent); }
.settingsBtnPrimary { appearance: none; border: 1px solid var(--c-accent); background: linear-gradient(180deg, color-mix(in srgb, var(--c-accent) 18%, transparent), color-mix(in srgb, var(--c-accent-2) 12%, transparent)); color: var(--c-text-strong); padding: 10px 12px; border-radius: var(--r-2); font-weight: 950; letter-spacing: -0.15px; cursor: pointer; box-shadow: var(--shadow-accent), var(--shadow-2); transition: transform 160ms ease, box-shadow 140ms ease, border-color 160ms ease, background 160ms ease; white-space: nowrap; }
.settingsBtnPrimary:hover { transform: translateY(-1px); box-shadow: var(--ring-accent), var(--shadow-2); border-color: color-mix(in srgb, var(--c-accent) 92%, var(--c-text-strong)); }
.settingsBtnPrimary:active { transform: translateY(0); }
.settingsToggleRow { padding: 12px; }
.settingsLink { font-size: 13px; color: color-mix(in srgb, var(--c-text-muted) 90%, var(--c-text-strong)); text-decoration: none; font-weight: 900; cursor: pointer; }
.settingsLink:hover { color: var(--c-text-strong); text-decoration: underline; }
.toggle { position: relative; display: inline-flex; align-items: center; }
.toggle input { position: absolute; opacity: 0; pointer-events: none; }
.toggleUI { width: 44px; height: 26px; border-radius: var(--r-pill); background: color-mix(in srgb, var(--c-hover) 80%, transparent); border: 1px solid var(--c-border); box-shadow: inset 0 1px 0 color-mix(in srgb, var(--c-text-dim) 35%, transparent); position: relative; transition: background 160ms ease, border-color 160ms ease, box-shadow 160ms ease; }
.toggleUI:after { content: ""; width: 20px; height: 20px; border-radius: var(--r-pill); background: var(--c-text-strong); position: absolute; top: 2px; left: 2px; box-shadow: 0 8px 18px rgba(0, 0, 0, 0.35); transition: transform 160ms ease; }
.toggle input:checked + .toggleUI { background: color-mix(in srgb, var(--c-accent-glow) 75%, transparent); border-color: color-mix(in srgb, var(--c-focus) 80%, transparent); box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-accent-glow-2) 90%, transparent), inset 0 1px 0 color-mix(in srgb, var(--c-text-dim) 35%, transparent); }
.toggle input:checked + .toggleUI:after { transform: translateX(18px); }
.settingsBadge--trial { background: color-mix(in srgb, var(--c-accent-glow) 65%, transparent); border: 1px solid var(--c-accent); color: var(--c-text-strong); font-weight: 900; box-shadow: var(--shadow-accent); }
.settingsInput { width: 100%; padding: 10px 12px; border-radius: var(--r-2); border: 1px solid var(--c-border); background: color-mix(in srgb, var(--c-panel-2) 60%, transparent); color: var(--c-text-strong); font-size: 14px; outline: none; transition: border-color 160ms ease, box-shadow 140ms ease; }
.settingsInput:focus { border-color: var(--c-focus); box-shadow: var(--ring-accent); }
.settingsBtnSecondary { appearance: none; border: 1px solid var(--c-border); background: color-mix(in srgb, var(--c-panel) 35%, transparent); color: var(--c-text); padding: 10px 12px; border-radius: var(--r-2); font-weight: 900; cursor: pointer; transition: transform 160ms ease, background 160ms ease, border-color 160ms ease; }
.settingsBtnSecondary:hover { transform: translateY(-1px); background: color-mix(in srgb, var(--c-panel-2) 45%, transparent); border-color: color-mix(in srgb, var(--c-border) 55%, var(--c-text-dim)); }
.settingsInput::placeholder { color: var(--c-text-muted); }
.brandLogoPreview { width: 100%; height: 125px; object-fit: contain; }
.settingsSelect { width: 100%; padding: 10px 12px; border-radius: var(--r-2); border: 1px solid var(--c-border); background: color-mix(in srgb, var(--c-panel-2) 60%, transparent); color: var(--c-text-strong); font-size: 13px; outline: none; transition: border-color 160ms ease, box-shadow 140ms ease; }
.settingsSelect:focus { border-color: var(--c-focus); box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-focus) 35%, transparent); }
.settingsChipGrid { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 8px; }
.settingsChip { appearance: none; border: 1px solid var(--c-border); background: color-mix(in srgb, var(--c-panel) 35%, transparent); color: var(--c-text); padding: 8px 10px; border-radius: var(--r-pill); font-weight: 900; font-size: 12px; cursor: pointer; transition: transform 160ms ease, background 160ms ease, border-color 160ms ease, box-shadow 140ms ease; }
.settingsChip:hover { transform: translateY(-1px); background: color-mix(in srgb, var(--c-panel-2) 45%, transparent); border-color: color-mix(in srgb, var(--c-border) 55%, var(--c-text-dim)); box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-hover) 90%, transparent); }
.settingsChip.is-active { border-color: var(--c-accent); background: color-mix(in srgb, var(--c-accent-glow-2) 55%, var(--c-panel-2)); box-shadow: var(--ring-accent); }
/* Upgrade Page */
body[data-panel="upgrade"] .right { margin-top: 0; margin-bottom: 0; }
.upgrade { display: flex; align-items: center; height: 100%; }
.upgradePage { max-width: 1180px; margin: 0 auto; padding: calc(var(--s-5) / 2) 0 var(--s-5); }
.upgradeTop { padding: calc(var(--s-5) / 2) 0 var(--s-5); }
.upgradeKicker { display: inline-flex; align-items: center; gap: 10px; padding: 8px 12px; font-size: 12px; font-weight: 900; letter-spacing: 0.08em; text-transform: uppercase; color: var(--c-text-muted); border-color: color-mix(in srgb, var(--c-border) 80%, transparent); background: color-mix(in srgb, var(--c-bg-3) 85%, transparent); }
.upgradeKickerDot { width: 10px; height: 10px; border-radius: 999px; background: radial-gradient(circle at 30% 30%, var(--c-text-dim), rgba(255, 255, 255, 0) 55%), linear-gradient(180deg, var(--c-accent), var(--c-accent-2)); box-shadow: 0 0 0 3px var(--c-accent-glow-2), 0 0 18px var(--c-accent-glow); }
.upgradeHead { margin-top: 16px; display: flex; align-items: flex-start; justify-content: space-between; gap: var(--s-5); }
.upgradeTitle { margin: 0; font-size: 44px; line-height: 1.05; font-weight: 980; letter-spacing: -0.02em; color: var(--c-text-strong); }
.upgradeToggle { display: inline-flex; gap: 6px; padding: 6px; border-color: color-mix(in srgb, var(--c-border) 85%, transparent); background: color-mix(in srgb, var(--c-bg-3) 85%, transparent); }
.upgradeToggleBtn { border: 1px solid transparent; background: transparent; color: var(--c-text-muted); font-weight: 900; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; padding: 10px 14px; border-radius: var(--r-pill); cursor: pointer; transition: transform 160ms ease, background 160ms ease, border-color 160ms ease, box-shadow 140ms ease, color 160ms ease; display: inline-flex; align-items: center; gap: 8px; }
.upgradeToggleBtn:hover { background: var(--c-hover); border-color: var(--c-focus); box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-hover) 80%, transparent); transform: translateY(-1px); color: var(--c-text); }
.upgradeToggleBtn.is-active { background: linear-gradient(180deg, var(--c-accent), var(--c-accent-2)); border-color: var(--c-accent-glow); color: var(--c-text-strong); box-shadow: var(--ring-accent), var(--shadow-2); }
.upgradeDeal { padding: 4px 8px; border-radius: var(--r-pill); background: rgba(0, 0, 0, 0.25); border: 1px solid var(--c-border-2); color: var(--c-text-strong); font-weight: 950; letter-spacing: 0.06em; font-size: 11px; }
.upgradeGrid { margin-top: 18px; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--s-5); align-items: stretch; }
.plan { position: relative; border-radius: 24px; border: 1px solid var(--c-border); }
.plan:hover { transform: translateY(-1px); border-color: color-mix(in srgb, var(--c-focus) 55%, var(--c-border)); box-shadow: var(--ring-accent); }
.planInner { position: relative; min-height: 560px; border-radius: 24px; background: linear-gradient(180deg, var(--c-bg-3), var(--c-bg-2)); padding: 30px; backdrop-filter: blur(14px); height: 100%; }
.planTop { position: relative; display: flex; align-items: center; gap: 12px; margin-bottom: var(--s-5); }
.planGlyph { width: 34px; height: 34px; border-radius: 14px; background-image: var(--logo-url); background-size: 34px 34px; background-position: center; background-repeat: no-repeat; }
.planMeta { min-width: 0; }
.planName { font-size: 22px; font-weight: 950; letter-spacing: -0.02em; color: var(--c-text-strong); }
.planTag { margin-top: 4px; font-size: 13px; font-weight: 700; opacity: 0.9; }
.planTag--pop { display: inline-flex; align-items: center; gap: 8px; color: var(--c-text-muted); font-size: 12px; font-weight: 950; letter-spacing: 0.08em; text-transform: uppercase; }
.planTag--pop::before { content: ""; width: 8px; height: 8px; border-radius: 999px; background: var(--c-accent); box-shadow: 0 0 0 3px var(--c-accent-glow-2), 0 0 16px var(--c-accent-glow); }
.planCurrentBadge { position: absolute; top: 16px; right: 16px; font-size: 11px; font-weight: 800; letter-spacing: 0.06em; text-transform: uppercase; color: var(--c-accent); background: color-mix(in srgb, var(--c-accent) 12%, transparent); border: 1px solid color-mix(in srgb, var(--c-accent) 30%, transparent); border-radius: 999px; padding: 3px 10px; white-space: nowrap; }
.planBestFor { color: var(--c-text-muted); margin-bottom: var(--s-5); font-size: 14px; line-height: 1.5; }
.planPriceRow { position: relative; margin-top: 10px; display: flex; align-items: baseline; gap: 10px; }
.planPrice { font-size: 44px; line-height: 1; font-weight: 980; letter-spacing: -0.03em; color: var(--c-text-strong); }
.planUnit { font-size: 13px; font-weight: 800; }
.planDivider { position: relative; margin: 18px 0; border-top: 1px solid var(--c-border); opacity: 0.9; }
.planCta { width: 100%; justify-content: center; border-radius: var(--r-pill); padding: 12px 16px; font-weight: 950; letter-spacing: 0.08em; text-transform: uppercase; font-size: 12px; margin: var(--s-5) 0; }
.planCta--primary { background: linear-gradient(180deg, var(--c-accent), var(--c-accent-2)); border-color: var(--c-accent-glow); box-shadow: var(--shadow-accent); transition: color 0.2s ease-in-out, border-color 0.2s ease-in-out, box-shadow 0.2s ease-in-out; }
.planCta--primary:hover { filter: saturate(1.02); box-shadow: var(--ring-accent); background: var(--c-accent-2); }
.planSection { position: relative; margin-top: var(--s-5); }
.planSectionTitle { font-size: 12px; font-weight: 950; letter-spacing: 0.1em; text-transform: uppercase; color: var(--c-text-muted); margin-bottom: 12px; }
.planList { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; color: var(--c-text-muted); font-size: 13px; line-height: 1.45; }
.planList li { display: flex; align-items: flex-start; gap: 10px; }
.planCheck, .planUnCheck { width: 18px; height: 18px; border-radius: 8px; flex: 0 0 auto; margin-top: 1px; border: 1px solid color-mix(in srgb, var(--c-border) 85%, transparent); background: color-mix(in srgb, var(--c-bg-3) 80%, transparent); position: relative; box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05); }
.planCheck::after { content: ""; position: absolute; left: 5px; top: 4px; width: 7px; height: 4px; border-left: 2px solid var(--c-accent); border-bottom: 2px solid var(--c-accent); transform: rotate(-45deg); opacity: 0.85; }
.plan--featured .planPrice { letter-spacing: -0.02em; }
.plan--featured .planList { color: color-mix(in srgb, var(--c-text) 85%, var(--c-text-muted)); }
/* Service Error Banner */
.tgs__serviceError { position: fixed; top: 0; left: 0; right: 0; z-index: 9999; display: flex; align-items: center; justify-content: center; gap: 10px; padding: 10px 18px; background: color-mix(in srgb, var(--c-error) 85%, var(--c-bg)); border-bottom: 1px solid var(--c-error-glow); color: var(--c-text-strong); font-size: 13px; font-weight: 700; text-align: center; box-shadow: 0 2px 14px var(--c-error-shadow); }
.tgs__serviceErrorIcon { flex: 0 0 auto; font-size: 18px; opacity: 0.9; }
.tgs__serviceErrorText { line-height: 1.45; }
.tgs__serviceErrorClose { position: absolute; right: 18px; top: 50%; transform: translateY(-50%); appearance: none; background: none; border: none; color: var(--c-text-strong); cursor: pointer; font-size: 20px; line-height: 1; opacity: 0.7; padding: 4px; transition: opacity 0.14s ease; }
.tgs__serviceErrorClose:hover { opacity: 1; }
/* Usage Banner (Trial) */
.tgs__usageBanner { position: absolute; top: 5px; left: 50%; transform: translateX(-50%); z-index: 99; display: none; align-items: center; gap: 10px; padding: 8px 40px 8px 14px; background: var(--c-bg-3); border: 1px solid var(--c-border); border-radius: var(--r-pill); color: var(--c-text); font-size: 13px; width: fit-content; max-width: calc(100% - 24px); overflow: hidden; }
body[data-panel="hunt"] .tgs__usageBanner, body[data-panel="topic"] .tgs__usageBanner { display: flex; }
.tgs__usageBannerIcon { flex: 0 0 auto; font-size: 16px; color: var(--c-accent); }
.tgs__usageBannerText { flex: 1 1 auto; min-width: 0; line-height: 1; color: var(--c-text-muted); font-size: 13px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.tgs__usageBannerText strong { color: var(--c-text-strong); font-weight: 800; }
.tgs__usageBar { width: 120px; height: 5px; background: var(--c-border); border-radius: var(--r-pill); overflow: hidden; flex: 0 0 auto; }
.tgs__usageBarFill { height: 100%; background: linear-gradient(90deg, var(--c-accent), var(--c-accent-2)); border-radius: var(--r-pill); transition: width 0.3s ease; }
.tgs__usageBannerCta { flex: 0 0 auto; appearance: none; background: linear-gradient(180deg, var(--c-accent), var(--c-accent-2)); border: 1px solid var(--c-accent-glow); border-radius: var(--r-pill); color: var(--c-text-strong); cursor: pointer; font-size: 12px; font-weight: 900; letter-spacing: 0.06em; padding: 5px 12px; box-shadow: var(--shadow-accent); transition: filter 0.14s ease, box-shadow 0.14s ease; white-space: nowrap; text-decoration: none; }
.tgs__usageBannerCta:hover { filter: saturate(1.05); box-shadow: var(--ring-accent); }
.tgs__usageBannerClose { position: absolute; right: 10px; top: 50%; transform: translateY(-50%); appearance: none; background: none; border: none; color: var(--c-text-dim); cursor: pointer; font-size: 18px; line-height: 1; padding: 2px; transition: color 0.14s ease; }
.tgs__usageBannerClose:hover { color: var(--c-text-strong); }
/* Feedback Banner */
.tgs__feedbackBanner { position: fixed; bottom: 0; left: 0; right: 0; z-index: 9998; display: flex; align-items: center; gap: 12px; padding: 12px 52px 12px 22px; background: linear-gradient(180deg, var(--c-panel-2), var(--c-panel)); border-top: 1px solid var(--c-border); backdrop-filter: blur(14px); color: var(--c-text); font-size: 15px; box-shadow: 0 -4px 24px rgba(0, 0, 0, 0.35); }
.tgs__feedbackBannerIcon { flex: 0 0 auto; font-size: 18px; color: var(--c-accent); opacity: 0.85; }
.tgs__feedbackBannerText { flex: 1; line-height: 1.45; color: var(--c-text-muted); }
.tgs__feedbackBannerText strong { color: var(--c-text-strong); font-weight: 800; }
.tgs__feedbackBannerSep { margin: 0 10px; color: var(--c-text-dim); }
.tgs__feedbackBannerCta { flex: 0 0 auto; appearance: none; background: linear-gradient(180deg, var(--c-accent), var(--c-accent-2)); border: 1px solid var(--c-accent-glow); border-radius: var(--r-pill); color: var(--c-text-strong); cursor: pointer; font-size: 14px; font-weight: 900; letter-spacing: 0.06em; padding: 7px 14px; box-shadow: var(--shadow-accent); transition: filter 0.14s ease, box-shadow 0.14s ease; white-space: nowrap; }
.tgs__feedbackBannerCta:hover { filter: saturate(1.05); box-shadow: var(--ring-accent); }
.tgs__feedbackBannerClose { position: absolute; right: 14px; top: 50%; transform: translateY(-50%); appearance: none; background: none; border: none; color: var(--c-text-dim); cursor: pointer; font-size: 20px; line-height: 1; padding: 4px; transition: color 0.14s ease; }
.tgs__feedbackBannerClose:hover { color: var(--c-text-strong); }
/* RESPONSIVE  */
@media (max-width: 1300px) {
	.cardRowIcons { display: none; }
}
@media (max-width: 1200px) {
	.upgradeGrid { grid-template-columns: 1fr; }
	.upgrade { height: auto; }
	.plan { min-height: auto; }
}
@media (max-width: 1100px) {
	.cards > .card { flex-basis: calc(50% - (25px / 2)); max-width: calc(50% - (25px / 2)); }
}
@media (max-width: 1050px) {
	.tgs__usageBar { display: none; }
}
@media (max-width: 980px) {
	.cardRowIcons { display: flex; }
	.splitDragHandle { cursor: default; pointer-events: none; }
	.roleCards { grid-template-columns: repeat(2, 1fr); }
	.sidebar { transform: none; width: 84px; padding: 18px 10px; }
	.header { left: 119px; }
	.logoText, .navItemText, .navSubLbl, .navItemList, .navItemSub, .sideSectionLink, .sideSectionTitleInner, .sideList .sideItemLabel { display: none !important; }
	.navItem { padding: 10px 8px; }
	.navItemIcon { margin-right: 0 !important; }
	.sideSection .sideItem, .sideSection .sideSectionHdr, .navItem, .sideSection .activeHuntItem { justify-content: center; }
	.right { margin-left: 84px; margin-top: calc(50px + 2 * var(--s-4)); }
	.split { grid-template-columns: 1fr; height: auto; }
	.reader, .list { height: auto; min-height: 420px; }
	.msg { max-width: 92%; }
	.sidebarNotif { display: none; }
	.sideSectionTitle, .activeHuntsLbl { text-align: center; letter-spacing: normal; }
	.sidebarCollapseBtn { display: none; }
	.readerStream { max-height: 50dvh; overflow-y: auto; }
	.sidebarCollapseBtn, .splitCollapseBtn, .splitExpandBtn { display: none; }
	.split:has(.list--expanded) .cardRow { width: 100%; }
}
@media (max-width: 860px) {
	.pop__content { width: calc(100vw - 24px); padding: 18px; border-radius: 18px; }
	.pop__closeIcon { z-index: 99999; }
	.thgpt__popMeta { flex-wrap: wrap; }
	.thgpt__popScoreBox { width: 100%; height: 72px; border-radius: 16px; }
	.thgpt__popScore { width: 100%; }
	.thgpt__popDemo { width: 100%; }
	.thgpt__popDemo .tha__demoBox { display: flex; gap: 14px; margin: 0 auto; }
	.thgpt__popDemo .tha__demoLeft, .thgpt__popDemo .tha__demoRight { width: 100%; }
	.thgpt__popPMT { grid-template-columns: 1fr; }
	.thgpt__popRel { grid-template-columns: 1fr; }
	.projectsStrip { flex-direction: column; }
}
@media (max-width: 820px) {
	.upgradeHead { flex-direction: column; align-items: flex-start; }
	.upgradeTitle { font-size: 38px; }
	.historyDate { display: none; }
}
@media (max-width: 680px) {
	.cards { gap: 16px; }
	.cards > .card { flex-basis: 100%; max-width: 100%; }
	.shareStripUrl { max-width: 400px; }
	.historyCardRow { flex-direction: column; align-items: baseline; }
	.historyCardActions { padding: 0; }
	.historyCardPrompt { max-width: 200px; }
	.settingsBadge { display: none; }
	.tgs__serviceError { padding: 10px 44px 10px 14px; font-size: 12px; }
	.tgs__serviceErrorIcon { display: none; }
	.tgs__serviceErrorClose { right: 10px; }
	.sideSectionTitle, .activeHuntsLbl { text-align: left; letter-spacing: 0.14em; }
	.sideSection .sideSectionHdr { justify-content: start; }
}
@media (max-width: 650px) {
	.sidebar { display: none; }
	.header { left: calc(var(--s-5) + 10px); margin-top: var(--s-3); }
	.right { margin-left: 0; margin-top: calc(50px + 2 * var(--s-5)); }
	.huntBrand { flex-direction: column; }
	.sidebar--mobile { display: block; }
	.logoText, .navItemText, .navSubLbl, .navItemList, .navItemSub, .sideSectionTitleInner, .sideList .sideItemLabel { display: flex !important; }
	.settingsFoot { flex-direction: column; }
	.settingsFoot .row { flex-direction: column; align-items: start; }
	.settingsFoot .settingsBtnPrimary { margin: 0 auto; }
	.upgradeKicker { display: none; }
	.sidebar--showing ~ .right { margin-left: 0; }
	.sidebar--showing ~ .header { left: calc(var(--s-5) + 10px); }
	.reader { position: relative; z-index: 0; }
	.thgpt__tutorialPop { height: auto; max-height: 75dvh; }
	.pop__closeTutorial { font-size: 0; }
	.thgpt__tutorialSubTitle { display: none; }
}
@media (max-width: 550px) {
	.artInfo { display: none; }
	.tgs__feedbackBannerWrap { display: none; }
	.huntLogo { margin: 0 auto; }
	.header .searchInput::placeholder { color: transparent; }
	.historyMetaRow { display: none; }
	.header .search { display: none; }
	.headerLink .material { display: none; }
	.ideasPage { overflow: auto; }
	#addIconPopover { max-height: 60dvh; overflow-y: auto; }
	.hubHeader { flex-wrap: wrap; }
}
@media (max-width: 475px) {
	.cardRowIcons { display: none; }
	.cardRow { grid-template-columns: 115px 1fr; }
}
@keyframes thgptPulse {
	0% { opacity: 0.45; }
	50% { opacity: 0.85; }
	100% { opacity: 0.45; }
}
@keyframes thgptShimmer {
	0% { transform: translateX(-120%); }
	100% { transform: translateX(120%); }
}
@keyframes thgptDot {
	0%, 80%, 100% { transform: translateY(0); opacity: 0.45; }
	40% { transform: translateY(-3px); opacity: 1; }
}
