/*
Theme Name: AuHunter
Theme URI: https://auhunter.com
Author: AuHunter
Author URI: https://auhunter.com
Description: Maison of indicators dedicated to the metal — เว็บไซต์ทางการของ AuHunter Gold Trading Suite ออกแบบเฉพาะสำหรับ XAUUSD
Version: 3.5.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: Proprietary
Text Domain: auhunter
Tags: dark, gold, custom-colors, custom-menu, featured-images
*/

:root {
  --color-bg-base: #0a0806;
  --color-bg-elevated: #0f0c08;
  --color-surface: #15110a;
  --color-surface-2: #1c1810;
  --color-hairline: #2a2218;
  --color-hairline-bright: #3d3221;
  --color-gold: #c9a961;
  --color-gold-bright: #e5c478;
  --color-gold-deep: #8a6d3a;
  --color-gold-faint: rgba(201, 169, 97, 0.08);
  --color-cream: #ebe2c8;
  --color-cream-2: #c5b896;
  --color-muted: #8c8166;
  --color-faint: #4a4334;
  --color-bull: #6ba373;
  --color-bear: #b85450;
  --font-display-en: 'Fraunces', 'Trirong', serif;
  --font-display-th: 'Trirong', 'Fraunces', serif;
  --font-body: 'IBM Plex Sans Thai', system-ui, -apple-system, sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
  --space-1: 4px; --space-2: 8px; --space-3: 12px; --space-4: 16px;
  --space-5: 20px; --space-6: 24px; --space-8: 32px; --space-10: 40px;
  --space-12: 48px; --space-16: 64px; --space-20: 80px;
  --space-24: 100px; --space-32: 140px;
  --border-radius-sm: 2px;
  --border-radius-md: 4px;
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --duration-fast: 0.2s;
  --duration-base: 0.3s;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  background: var(--color-bg-base);
  color: var(--color-cream);
  font-family: var(--font-body);
  font-weight: 300;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}
body::before {
  content: ''; position: fixed; inset: 0;
  background:
    radial-gradient(ellipse at 12% 8%, rgba(201, 169, 97, 0.04) 0%, transparent 50%),
    radial-gradient(ellipse at 88% 92%, rgba(201, 169, 97, 0.03) 0%, transparent 50%);
  pointer-events: none; z-index: 0;
}
::selection { background: var(--color-gold); color: var(--color-bg-base); }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
img { max-width: 100%; display: block; height: auto; }

/* WP-specific */
.alignnone { margin: 0; }
.aligncenter { display: block; margin: 0 auto; }
.alignleft { float: left; margin-right: 1em; }
.alignright { float: right; margin-left: 1em; }
.screen-reader-text { border: 0; clip: rect(1px, 1px, 1px, 1px); height: 1px; width: 1px; overflow: hidden; position: absolute !important; }

.container { max-width: 1320px; margin: 0 auto; padding: 0 40px; position: relative; z-index: 1; }
.container-narrow { max-width: 980px; margin: 0 auto; padding: 0 40px; position: relative; z-index: 1; }
.container-wide { max-width: 1480px; margin: 0 auto; padding: 0 40px; position: relative; z-index: 1; }

/* Crest */
.crest {
  width: 36px; height: 36px;
  border: 1px solid var(--color-gold);
  border-radius: 50%;
  display: grid; place-items: center;
  color: var(--color-gold);
  font-family: var(--font-display-en);
  font-style: italic; font-weight: 300; font-size: 14px;
  flex-shrink: 0; position: relative;
}
.crest::before { content: ''; position: absolute; inset: 3px; border: 0.5px solid var(--color-gold-deep); border-radius: 50%; }
.crest.sm { width: 28px; height: 28px; font-size: 11px; }
.crest.md { width: 48px; height: 48px; font-size: 18px; }
.crest.md::before { inset: 4px; }
.crest.lg { width: 56px; height: 56px; font-size: 22px; }
.crest.lg::before { inset: 4px; }
.crest.xl { width: 96px; height: 96px; font-size: 36px; }
.crest.xl::before { inset: 6px; }

.brand-name { font-family: var(--font-display-en); font-weight: 400; font-size: 19px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--color-cream); }
.brand-name.lg { font-size: 26px; letter-spacing: 0.26em; }

/* ════════════════════════════════════════════════════════════
   Nav · v1.38.0 · 2-row editorial layout
   ════════════════════════════════════════════════════════════ */

.site-nav { position: sticky; top: 0; z-index: 100; backdrop-filter: blur(20px) saturate(120%); -webkit-backdrop-filter: blur(20px) saturate(120%); background: rgba(10, 8, 6, 0.92); border-bottom: 1px solid var(--color-hairline); }

/* ─── Row 1 · Utility bar ─── */
.nav-utility { border-bottom: 1px solid var(--color-hairline); }
.nav-utility-inner { display: flex; align-items: center; justify-content: space-between; height: 64px; gap: 20px; }
.nav-brand { display: flex; align-items: center; gap: 14px; text-decoration: none; flex-shrink: 0; }
.nav-utility-right { display: flex; align-items: center; gap: 20px; }
.nav-cta { padding: 9px 18px; font-size: 12px; letter-spacing: 0.06em; }

/* ─── Hamburger · mobile only ─── */
.nav-hamburger { display: none; background: none; border: 0; padding: 10px; cursor: pointer; align-items: center; justify-content: center; flex-direction: column; gap: 5px; z-index: 210; position: relative; }
.nav-hamburger span { display: block; width: 22px; height: 1.5px; background: var(--color-gold); transition: transform var(--duration-base), opacity var(--duration-base); }
body.nav-open .nav-hamburger span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
body.nav-open .nav-hamburger span:nth-child(2) { opacity: 0; }
body.nav-open .nav-hamburger span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* ─── Row 2 · Main nav menu ─── */
.nav-main { background: transparent; }
.nav-main-inner { display: flex; align-items: center; justify-content: center; height: 50px; }
.nav-links { display: flex; gap: 32px; list-style: none; margin: 0; padding: 0; align-items: center; }
.nav-links a { color: var(--color-cream-2); font-size: 13px; font-weight: 300; letter-spacing: 0.02em; transition: color var(--duration-fast); position: relative; display: inline-block; padding: 6px 0; white-space: nowrap; text-decoration: none; }
.nav-links a::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 1px; background: var(--color-gold); transform: scaleX(0); transform-origin: left; transition: transform var(--duration-base); }
.nav-links a:hover { color: var(--color-gold); }
.nav-links a:hover::after,
.nav-links li.current-menu-item a::after,
.nav-links li.current_page_item a::after,
.nav-links li.current-menu-ancestor a::after,
.nav-links li.current_page_ancestor a::after { transform: scaleX(1); }
.nav-links li.current-menu-item a,
.nav-links li.current_page_item a,
.nav-links li.current-menu-ancestor a,
.nav-links li.current_page_ancestor a { color: var(--color-gold); }

/* ─── Desktop dropdown (depth-2 submenu) ─── */
.nav-links li.menu-item-has-children { position: relative; }
.nav-links li.menu-item-has-children > a { padding-right: 16px; }
.nav-links li.menu-item-has-children > a::after {
  content: '\25BE';            /* ▾ caret · replaces underline for parents */
  position: absolute; right: 0; top: 50%; left: auto; bottom: auto;
  width: auto; height: auto; background: none;
  transform: translateY(-50%) scaleX(1);
  font-size: 9px; color: var(--color-faint);
  transition: color var(--duration-fast), transform var(--duration-fast);
}
.nav-links li.menu-item-has-children:hover > a,
.nav-links li.menu-item-has-children:focus-within > a { color: var(--color-gold); }
.nav-links li.menu-item-has-children:hover > a::after,
.nav-links li.menu-item-has-children:focus-within > a::after { color: var(--color-gold); transform: translateY(-50%) rotate(180deg); }
.nav-links .sub-menu {
  position: absolute; top: 100%; left: 50%;
  transform: translateX(-50%) translateY(8px);
  min-width: 210px; list-style: none; margin: 0; padding: 8px 0;
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-hairline-bright); border-radius: 6px;
  box-shadow: 0 14px 44px rgba(0,0,0,0.5);
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity var(--duration-fast), transform var(--duration-fast), visibility 0s var(--duration-fast);
  z-index: 300;
}
.nav-links li.menu-item-has-children:hover > .sub-menu,
.nav-links li.menu-item-has-children:focus-within > .sub-menu {
  opacity: 1; visibility: visible; pointer-events: auto;
  transform: translateX(-50%) translateY(0);
  transition: opacity var(--duration-fast), transform var(--duration-fast);
}
.nav-links .sub-menu li { width: 100%; }
.nav-links .sub-menu a { display: block; padding: 9px 20px; white-space: nowrap; font-size: 13px; }
.nav-links .sub-menu a::after { display: none; }
.nav-links .sub-menu a:hover,
.nav-links .sub-menu li.current-menu-item a,
.nav-links .sub-menu li.current_page_item a { color: var(--color-gold); background: var(--color-surface); }

/* ─── Lang toggle ─── */
.lang-toggle { display: flex; gap: 6px; align-items: center; font-family: var(--font-mono); font-size: 11px; color: var(--color-faint); letter-spacing: 0.1em; }
.lang-toggle .active { color: var(--color-gold); }
.lang-toggle .sep { color: var(--color-hairline-bright); }

/* ═══════════════════════════════════════
   Mobile drawer · slides in from right
   ═══════════════════════════════════════ */
.nav-drawer { position: fixed; top: 0; right: 0; bottom: 0; width: min(320px, 88vw); background: linear-gradient(180deg, #1c1810 0%, #15110a 100%); border-left: 2px solid var(--color-gold); z-index: 250; transform: translateX(100%); transition: transform var(--duration-base) ease-out; overflow-y: auto; box-shadow: -20px 0 60px rgba(0,0,0,0.6); }
body.nav-open .nav-drawer { transform: translateX(0); }
.nav-drawer-inner { padding: 88px 28px 40px; min-height: 100%; display: flex; flex-direction: column; gap: 24px; }
.nav-drawer-links { display: flex; flex-direction: column; gap: 0; list-style: none; margin: 0; padding: 0; width: 100%; }
.nav-drawer-links li { width: 100%; border-bottom: 1px solid var(--color-hairline-bright); }
.nav-drawer-links a { display: block; padding: 16px 4px; color: var(--color-cream); font-family: var(--font-display-th); font-size: 15px; text-decoration: none; transition: color var(--duration-fast); line-height: 1.4; word-break: break-word; overflow-wrap: anywhere; }
.nav-drawer-links a:hover,
.nav-drawer-links li.current-menu-item a,
.nav-drawer-links li.current_page_item a { color: var(--color-gold-bright); }
/* ─── Drawer accordion (depth-2 submenu) ─── */
.nav-drawer-links li.menu-item-has-children > a { display: flex; align-items: center; justify-content: space-between; }
.nav-drawer-links li.menu-item-has-children > a::after { content: '\25BE'; font-size: 11px; color: var(--color-faint); transition: transform var(--duration-fast); margin-left: 12px; }
.nav-drawer-links li.menu-item-has-children.open > a::after { transform: rotate(180deg); color: var(--color-gold); }
.nav-drawer-links .sub-menu { list-style: none; margin: 0; padding: 0; max-height: 0; overflow: hidden; transition: max-height var(--duration-base) ease; }
.nav-drawer-links li.menu-item-has-children.open > .sub-menu { max-height: 600px; }
.nav-drawer-links .sub-menu li { width: 100%; border-bottom: none; border-top: 1px solid var(--color-hairline); }
.nav-drawer-links .sub-menu li:first-child { border-top: 1px solid var(--color-hairline-bright); }
.nav-drawer-links .sub-menu a { padding: 13px 4px 13px 20px; font-size: 14px; color: var(--color-cream-2); }
.nav-drawer-divider { display: none; }
.nav-drawer-extras { display: flex; flex-direction: column; gap: 16px; padding: 12px 0 0; border-top: 1px solid var(--color-gold-deep); margin-top: 12px; }
.nav-drawer-cta { width: 100%; text-align: center; }
.nav-drawer-extras .lang-toggle { justify-content: center; padding: 8px; font-size: 12px; }

/* WP Admin Bar adjustments · push drawer top to account for admin bar */
body.admin-bar .nav-drawer-inner { padding-top: 120px; }  /* 88px + 32px admin bar */
@media (max-width: 782px) {
	body.admin-bar .nav-drawer-inner { padding-top: 134px; }  /* 88px + 46px mobile admin bar */
}

/* Mobile backdrop overlay · sibling of header, outside stacking context */
.nav-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,0.75); z-index: 240; opacity: 0; visibility: hidden; transition: opacity var(--duration-base), visibility 0s var(--duration-base); }
body.nav-open .nav-backdrop { opacity: 1; visibility: visible; transition: opacity var(--duration-base); }
body.nav-open { overflow: hidden; }

/* ═══════════════════════════════════════
   Responsive breakpoints
   ═══════════════════════════════════════ */

/* Tablet · 768-1024px · slight condensation */
@media (max-width: 1024px) {
	.nav-utility-inner { height: 60px; }
	.nav-main-inner { min-height: 46px; height: auto; overflow: visible; padding: 4px 0; }
	.nav-links { gap: 22px; padding: 0 16px; flex-wrap: wrap; justify-content: center; row-gap: 2px; }
	.nav-links a { font-size: 12.5px; }
	.lang-toggle { font-size: 10px; }
	.nav-cta { padding: 8px 14px; font-size: 11.5px; letter-spacing: 0.04em; }
}

/* Mobile · ≤768px · hide utility-right + main nav, show hamburger */
@media (max-width: 768px) {
	.nav-utility-inner { height: 60px; }
	.nav-utility-right { display: none; }
	.nav-main { display: none; }
	.nav-hamburger { display: inline-flex; }
	.brand-name { font-size: 16px; letter-spacing: 0.18em; }
	.crest { width: 32px; height: 32px; font-size: 12px; }

	/* IMPORTANT · disable backdrop-filter on mobile · breaks stacking context with fixed children */
	.site-nav { backdrop-filter: none; -webkit-backdrop-filter: none; background: rgba(10, 8, 6, 0.96); }
	body.nav-open .site-nav { z-index: 260; background: rgba(10, 8, 6, 1); }
	body.nav-open .nav-hamburger { z-index: 270; }
}

/* Small mobile · ≤380px · tighter */
@media (max-width: 380px) {
	.nav-utility-inner { height: 56px; }
	.nav-brand { gap: 10px; }
	.brand-name { font-size: 14px; letter-spacing: 0.16em; }
	.crest { width: 28px; height: 28px; font-size: 11px; }
}

/* Buttons */
.btn-gold { background: var(--color-gold); color: var(--color-bg-base); padding: 13px 24px; font-family: var(--font-body); font-weight: 500; font-size: 13px; letter-spacing: 0.04em; border: 1px solid var(--color-gold); border-radius: var(--border-radius-sm); transition: all var(--duration-fast); display: inline-block; text-align: center; }
.btn-gold:hover { background: var(--color-gold-bright); border-color: var(--color-gold-bright); transform: translateY(-1px); }
.nav-cta-line { background: transparent; color: #3ad17f; border-color: #1f9d57; }
.nav-cta-line:hover { background: #06c755; color: #fff; border-color: #06c755; transform: translateY(-1px); }
.btn-ghost { background: transparent; color: var(--color-cream); padding: 13px 24px; font-family: var(--font-body); font-weight: 400; font-size: 13px; letter-spacing: 0.04em; border: 1px solid var(--color-hairline-bright); border-radius: var(--border-radius-sm); transition: all var(--duration-fast); display: inline-block; text-align: center; }
.btn-ghost:hover { border-color: var(--color-gold); color: var(--color-gold); }
.btn-text { background: transparent; color: var(--color-gold); padding: 13px 0; font-family: var(--font-body); font-weight: 400; font-size: 13px; letter-spacing: 0.04em; border: 0; display: inline-flex; align-items: center; gap: 6px; transition: gap var(--duration-fast); }
.btn-text:hover { gap: 10px; }

/* Badges */
.badge { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; padding: 6px 12px; border-radius: var(--border-radius-sm); }
.badge-gold { background: var(--color-gold); color: var(--color-bg-base); }
.badge-outline { background: transparent; color: var(--color-gold); border: 1px solid var(--color-gold-deep); }
.badge-bull { background: rgba(107, 163, 115, 0.12); color: var(--color-bull); border: 1px solid rgba(107, 163, 115, 0.3); }
.badge-bear { background: rgba(184, 84, 80, 0.12); color: var(--color-bear); border: 1px solid rgba(184, 84, 80, 0.3); }
.badge-muted { background: var(--color-bg-elevated); color: var(--color-muted); border: 1px solid var(--color-hairline); }

/* Stats */
.stat-row { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--color-hairline); border-bottom: 1px solid var(--color-hairline); padding: 24px 0; }
.stat { padding: 0 16px; border-right: 1px solid var(--color-hairline); }
.stat:first-child { padding-left: 0; }
.stat:last-child { border-right: 0; padding-right: 0; }
.stat-num { font-family: var(--font-display-en); font-weight: 300; font-size: 42px; color: var(--color-gold); line-height: 1; margin-bottom: 8px; letter-spacing: -0.02em; }
.stat-num em { font-style: italic; }
.stat-label { font-family: var(--font-mono); font-size: 10px; color: var(--color-muted); text-transform: uppercase; letter-spacing: 0.18em; }

/* Section */
.sec { padding: 100px 0; scroll-margin-top: 100px; }
.sec + .sec { border-top: 1px solid var(--color-hairline); }
.sec.alt { background: var(--color-bg-elevated); border-top: 1px solid var(--color-hairline); border-bottom: 1px solid var(--color-hairline); }
.sec-mark { display: flex; align-items: baseline; gap: 16px; margin-bottom: 24px; font-family: var(--font-mono); font-size: 11px; color: var(--color-gold); letter-spacing: 0.24em; text-transform: uppercase; }
.sec-mark .num { font-family: var(--font-display-en); font-style: italic; font-size: 22px; font-weight: 300; letter-spacing: 0; }
.sec-mark .rule { flex: 0 0 50px; height: 1px; background: var(--color-gold-deep); }
.sec-head { display: grid; grid-template-columns: 1fr 1.2fr; gap: 80px; margin-bottom: 64px; align-items: end; }
.sec-title { font-family: var(--font-display-th); font-weight: 300; font-size: clamp(40px, 5vw, 64px); line-height: 1; letter-spacing: -0.025em; color: var(--color-cream); }
.sec-title em { font-family: var(--font-display-en); font-style: italic; color: var(--color-gold); font-weight: 200; }
.sec-desc { font-size: 17px; color: var(--color-cream-2); line-height: 1.75; font-weight: 300; max-width: 580px; }
.sec-desc strong { color: var(--color-cream); font-weight: 400; }

/* Hero */
.hero { padding: 90px 0 40px; position: relative; overflow: hidden; }
.hero-meta { display: flex; justify-content: space-between; align-items: center; padding-bottom: 36px; border-bottom: 1px solid var(--color-hairline); margin-bottom: 60px; font-family: var(--font-mono); font-size: 11px; color: var(--color-muted); letter-spacing: 0.18em; text-transform: uppercase; }
.hero-meta .vol { color: var(--color-gold); }
.hero-meta .center { flex: 1; text-align: center; font-family: var(--font-display-en); font-style: italic; font-weight: 300; font-size: 14px; text-transform: none; letter-spacing: 0.02em; color: var(--color-cream-2); }
.hero-eyebrow { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--color-gold); margin-bottom: 18px; }
.hero-title { font-family: var(--font-display-th); font-weight: 300; font-size: clamp(34px, 4.4vw, 66px); line-height: 1.08; letter-spacing: -0.025em; color: var(--color-cream); margin-bottom: 22px; }
.hero-title em { font-family: var(--font-display-en); font-style: italic; font-weight: 200; color: var(--color-gold); }
.hero-body { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; margin-top: 60px; align-items: start; }
.hero-sub { font-size: 19px; line-height: 1.65; color: var(--color-cream-2); font-weight: 300; max-width: 540px; margin-bottom: 36px; }
.hero-sub strong { color: var(--color-cream); font-weight: 400; }
.hero-cta { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 48px; }
.hero-stats { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--color-hairline); padding-top: 28px; }
.hero-stat { padding-right: 20px; border-right: 1px solid var(--color-hairline); }
.hero-stat:last-child { border-right: 0; }
.hero-stat:not(:first-child) { padding-left: 20px; }
.hero-stat .stat-num { font-family: var(--font-display-en); font-weight: 300; font-size: 44px; color: var(--color-gold); line-height: 1; margin-bottom: 8px; letter-spacing: -0.02em; }

/* Frame card */
.frame-card { background: linear-gradient(180deg, var(--color-surface) 0%, var(--color-bg-elevated) 100%); border: 1px solid var(--color-hairline-bright); border-radius: var(--border-radius-md); padding: 28px; position: relative; box-shadow: 0 40px 100px -30px rgba(0, 0, 0, 0.7), 0 0 0 1px rgba(201, 169, 97, 0.06) inset; }
.frame-corner { position: absolute; width: 12px; height: 12px; border-color: var(--color-gold); z-index: 2; }
.frame-corner.tl { top: -1px; left: -1px; border-top: 1px solid; border-left: 1px solid; }
.frame-corner.tr { top: -1px; right: -1px; border-top: 1px solid; border-right: 1px solid; }
.frame-corner.bl { bottom: -1px; left: -1px; border-bottom: 1px solid; border-left: 1px solid; }
.frame-corner.br { bottom: -1px; right: -1px; border-bottom: 1px solid; border-right: 1px solid; }
.chart-head { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 22px; padding-bottom: 18px; border-bottom: 1px solid var(--color-hairline); }
.chart-symbol { font-family: var(--font-mono); font-size: 13px; font-weight: 500; color: var(--color-cream); letter-spacing: 0.08em; }
.chart-symbol .tf { color: var(--color-muted); margin-left: 8px; font-weight: 400; }
.chart-status { font-family: var(--font-mono); font-size: 10px; color: var(--color-muted); letter-spacing: 0.14em; margin-top: 6px; display: flex; align-items: center; gap: 6px; }
.chart-price { font-family: var(--font-display-en); font-size: 30px; font-weight: 300; color: var(--color-gold); line-height: 1; letter-spacing: -0.01em; }
.chart-price .decimal { opacity: 0.5; }
.chart-change { font-family: var(--font-mono); font-size: 11px; color: var(--color-bull); margin-top: 6px; text-align: right; letter-spacing: 0.06em; }
.illus-tag { font-family: var(--font-mono); font-size: 9px; line-height: 1; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-gold); border: 1px solid var(--color-hairline-bright); border-radius: 3px; padding: 2px 5px; }
.chart-sample-note { font-family: var(--font-mono); font-size: 10px; color: var(--color-muted); margin-top: 6px; text-align: right; letter-spacing: 0.06em; }
.chart-svg { width: 100%; height: 240px; display: block; }
.chart-meta { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin-top: 18px; padding-top: 16px; border-top: 1px solid var(--color-hairline); }
.meta-pill { font-family: var(--font-mono); font-size: 10px; color: var(--color-cream-2); display: flex; align-items: center; gap: 6px; letter-spacing: 0.06em; }
.meta-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--color-gold); }
.meta-dot.bull { background: var(--color-bull); }
.live-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--color-bull); display: inline-block; box-shadow: 0 0 8px rgba(107, 163, 115, 0.6); animation: pulseDot 2s ease-in-out infinite; }
@keyframes pulseDot { 0%, 100% { opacity: 1; transform: scale(1); } 50% { opacity: 0.5; transform: scale(0.85); } }

/* Manifesto */
.manifesto { padding: 140px 0; position: relative; background: var(--color-bg-elevated); border-top: 1px solid var(--color-hairline); border-bottom: 1px solid var(--color-hairline); }
.manifesto-inner { max-width: 980px; margin: 0 auto; text-align: center; }
.manifesto-mark { font-family: var(--font-display-en); font-size: 80px; color: var(--color-gold); line-height: 0.4; margin-bottom: 32px; font-weight: 300; font-style: italic; }
.manifesto-text { font-family: var(--font-display-th); font-size: clamp(28px, 3.6vw, 48px); font-weight: 300; line-height: 1.35; color: var(--color-cream); letter-spacing: -0.01em; margin-bottom: 36px; }
.manifesto-text em { font-family: var(--font-display-en); font-style: italic; font-weight: 400; color: var(--color-gold); }
.manifesto-attr { font-family: var(--font-mono); font-size: 11px; color: var(--color-muted); letter-spacing: 0.22em; text-transform: uppercase; }
.manifesto-attr span { color: var(--color-gold); }

/* Featured grid */
.featured-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--color-hairline); border-top: 1px solid var(--color-hairline); border-bottom: 1px solid var(--color-hairline); }
.feat-card { background: var(--color-bg-base); padding: 56px 48px; transition: background var(--duration-base); cursor: default; position: relative; min-height: 380px; display: block; color: inherit; }
.feat-card:hover { background: var(--color-surface); }
.feat-num { font-family: var(--font-display-en); font-style: italic; font-size: 14px; color: var(--color-gold); letter-spacing: 0.05em; margin-bottom: 32px; font-weight: 300; }
.feat-name { font-family: var(--font-display-en); font-size: 38px; font-weight: 300; margin-bottom: 6px; color: var(--color-cream); line-height: 1.05; letter-spacing: -0.015em; }
.feat-name em { font-style: italic; color: var(--color-gold); font-weight: 200; }
.feat-tag { font-family: var(--font-mono); font-size: 10px; color: var(--color-muted); text-transform: uppercase; letter-spacing: 0.18em; margin-bottom: 24px; margin-top: 8px; }
.feat-desc { color: var(--color-cream-2); font-size: 15px; line-height: 1.75; margin-bottom: 28px; font-weight: 300; max-width: 460px; }
.feat-features { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.feat-features li { font-size: 12px; color: var(--color-cream-2); padding-left: 22px; position: relative; font-family: var(--font-mono); font-weight: 400; letter-spacing: 0.04em; }
.feat-features li::before { content: ''; position: absolute; left: 0; top: 9px; width: 12px; height: 1px; background: var(--color-gold); }
.feat-arrow { position: absolute; top: 56px; right: 48px; color: var(--color-faint); font-family: var(--font-mono); font-size: 24px; font-weight: 300; transition: all var(--duration-base) ease; }
.feat-card:hover .feat-arrow { color: var(--color-gold); transform: translate(4px, -4px); }

/* Suite grid */
.suite-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--color-hairline); border: 1px solid var(--color-hairline); }
.suite-tile { background: var(--color-bg-base); padding: 32px 28px; min-height: 150px; display: flex; flex-direction: column; justify-content: space-between; position: relative; transition: background var(--duration-base); color: inherit; }
.suite-tile.ready { background: var(--color-surface); }
.suite-tile.ready:hover { background: var(--color-surface-2); }
.suite-tile.coming:hover { background: var(--color-bg-elevated); }
.suite-num { font-family: var(--font-display-en); font-style: italic; font-weight: 300; font-size: 13px; color: var(--color-faint); letter-spacing: 0.02em; }
.suite-tile.ready .suite-num { color: var(--color-gold-deep); }
.suite-name { font-family: var(--font-display-en); font-size: 22px; font-weight: 300; color: var(--color-cream-2); line-height: 1.15; margin-top: 14px; letter-spacing: -0.01em; }
.suite-tile.ready .suite-name { color: var(--color-gold); font-style: italic; font-weight: 300; }
.suite-tile.coming .suite-name { color: var(--color-muted); }
.suite-status { font-family: var(--font-mono); font-size: 9px; text-transform: uppercase; letter-spacing: 0.2em; margin-top: auto; display: flex; align-items: center; gap: 6px; }
.status-ready { color: var(--color-bull); }
.status-soon { color: var(--color-faint); }
.status-dot { width: 5px; height: 5px; border-radius: 50%; }
.status-ready .status-dot { background: var(--color-bull); box-shadow: 0 0 6px rgba(107, 163, 115, 0.5); }
.status-soon .status-dot { background: var(--color-faint); }

/* Method grid */
.method-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 100px 120px; }
.method-item { border-top: 1px solid var(--color-gold-deep); padding-top: 32px; position: relative; }
.method-item::before { content: ''; position: absolute; top: -1px; left: 0; width: 40px; height: 1px; background: var(--color-gold); }
.method-num { font-family: var(--font-display-en); font-style: italic; font-size: 16px; color: var(--color-gold); margin-bottom: 16px; font-weight: 300; letter-spacing: 0.05em; }
.method-title { font-family: var(--font-display-th); font-size: 32px; font-weight: 400; color: var(--color-cream); margin-bottom: 18px; line-height: 1.15; letter-spacing: -0.01em; }
.method-title em { font-family: var(--font-display-en); font-style: italic; color: var(--color-gold); font-weight: 200; }
.method-desc { color: var(--color-cream-2); font-size: 15px; line-height: 1.75; font-weight: 300; }

/* Pricing */
.tiers-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--color-hairline); border: 1px solid var(--color-hairline); }
.tier { background: var(--color-bg-base); padding: 56px 44px; position: relative; display: flex; flex-direction: column; }
.tier.featured { background: var(--color-surface); }
.tier.featured::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, transparent, var(--color-gold), transparent); }
.tier-tag { position: absolute; top: 0; left: 50%; transform: translate(-50%, -50%); background: var(--color-gold); color: var(--color-bg-base); font-family: var(--font-mono); font-size: 9px; font-weight: 500; letter-spacing: 0.22em; text-transform: uppercase; padding: 7px 14px; border-radius: 1px; }
.tier-name { font-family: var(--font-display-en); font-style: italic; font-weight: 300; font-size: 26px; color: var(--color-gold); margin-bottom: 8px; }
.tier-sub { font-size: 12px; color: var(--color-muted); margin-bottom: 36px; font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.16em; }
.tier-amount { font-family: var(--font-display-en); font-weight: 200; font-size: 72px; line-height: 1; color: var(--color-cream); margin-bottom: 6px; letter-spacing: -0.04em; }
.tier-amount .currency { font-family: var(--font-display-en); font-style: italic; font-size: 22px; color: var(--color-gold); margin-right: 6px; vertical-align: top; margin-top: 12px; display: inline-block; font-weight: 300; }
.tier-period { font-family: var(--font-mono); font-size: 11px; color: var(--color-faint); margin-bottom: 36px; letter-spacing: 0.12em; text-transform: uppercase; border-bottom: 1px solid var(--color-hairline); padding-bottom: 28px; }
.tier-features { list-style: none; display: flex; flex-direction: column; gap: 14px; margin-bottom: 40px; flex: 1; }
.tier-features li { font-size: 14px; color: var(--color-cream); padding-left: 26px; position: relative; font-weight: 300; line-height: 1.55; }
.tier-features li::before { content: '✓'; position: absolute; left: 0; top: 0; color: var(--color-gold); font-family: var(--font-mono); font-size: 14px; }
.tier-features li.muted { color: var(--color-faint); }
.tier-features li.muted::before { content: '−'; color: var(--color-faint); }
.tier-features li strong { color: var(--color-cream); font-weight: 400; }
.tier-cta { width: 100%; text-align: center; padding: 14px; }

/* FAQ */
.faq-list { border-top: 1px solid var(--color-hairline); }
.faq-item { border-bottom: 1px solid var(--color-hairline); padding: 28px 0; cursor: pointer; }
.faq-q { display: flex; justify-content: space-between; align-items: baseline; gap: 24px; }
.faq-num { font-family: var(--font-display-en); font-style: italic; color: var(--color-gold); font-size: 14px; font-weight: 300; flex: 0 0 36px; }
.faq-q-text { font-family: var(--font-display-th); font-size: 20px; font-weight: 400; color: var(--color-cream); flex: 1; line-height: 1.3; }
.faq-toggle { font-family: var(--font-display-en); color: var(--color-gold); font-size: 24px; font-weight: 200; line-height: 1; transition: transform var(--duration-base); font-style: italic; }
.faq-item.open .faq-toggle { transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height var(--duration-base) ease, margin-top var(--duration-base) ease, opacity var(--duration-base); color: var(--color-cream-2); font-size: 15px; line-height: 1.75; font-weight: 300; padding-left: 36px; opacity: 0; }
.faq-item.open .faq-a { max-height: 320px; margin-top: 18px; opacity: 1; }

/* CTA banner */
.cta-banner { background: var(--color-surface); border-top: 1px solid var(--color-gold-deep); border-bottom: 1px solid var(--color-gold-deep); padding: 120px 0; text-align: center; position: relative; overflow: hidden; }
.cta-banner::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 50% 50%, rgba(201, 169, 97, 0.08) 0%, transparent 60%); pointer-events: none; }
.cta-mark { font-family: var(--font-display-en); font-style: italic; color: var(--color-gold); font-size: 14px; letter-spacing: 0.3em; text-transform: uppercase; margin-bottom: 28px; position: relative; z-index: 1; }
.cta-headline { font-family: var(--font-display-th); font-size: clamp(48px, 7vw, 96px); font-weight: 300; line-height: 1; margin-bottom: 28px; letter-spacing: -0.025em; position: relative; z-index: 1; }
.cta-headline em { font-family: var(--font-display-en); font-style: italic; color: var(--color-gold); font-weight: 200; }
.cta-sub { color: var(--color-cream-2); font-size: 18px; margin-bottom: 48px; font-weight: 300; position: relative; z-index: 1; }
.cta-actions { display: flex; gap: 14px; justify-content: center; position: relative; z-index: 1; flex-wrap: wrap; }

/* Footer */
.site-footer { background: var(--color-bg-base); padding: 80px 0 40px; border-top: 1px solid var(--color-hairline); }
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 60px; margin-bottom: 60px; }
.footer-brand-block { display: flex; flex-direction: column; gap: 20px; }
.footer-tagline { color: var(--color-cream-2); font-size: 14px; line-height: 1.7; max-width: 360px; font-weight: 300; }
.footer-col h4 { font-family: var(--font-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.22em; color: var(--color-gold); margin-bottom: 20px; font-weight: 500; }
.footer-col ul { list-style: none; }
.footer-col li { margin-bottom: 12px; }
.footer-col a { color: var(--color-cream-2); font-size: 13px; font-weight: 300; transition: color var(--duration-fast); }
.footer-col a:hover { color: var(--color-gold); }
.footer-bottom { padding-top: 36px; border-top: 1px solid var(--color-hairline); display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 10px; color: var(--color-faint); letter-spacing: 0.18em; text-transform: uppercase; }

/* Product page */
.breadcrumb { border-bottom: 1px solid var(--color-hairline); padding: 18px 0; font-family: var(--font-mono); font-size: 11px; color: var(--color-muted); letter-spacing: 0.16em; text-transform: uppercase; }
.breadcrumb a { color: var(--color-cream-2); transition: color var(--duration-fast); }
.breadcrumb a:hover { color: var(--color-gold); }
.breadcrumb .sep { color: var(--color-faint); margin: 0 14px; }
.breadcrumb .current { color: var(--color-gold); }
.product-hero { padding: 64px 0 80px; }
.product-hero-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 64px; align-items: start; }
.product-eyebrow { font-family: var(--font-mono); font-size: 11px; color: var(--color-gold); letter-spacing: 0.3em; text-transform: uppercase; margin-bottom: 24px; display: flex; align-items: center; gap: 14px; }
.product-eyebrow::before { content: ''; width: 32px; height: 1px; background: var(--color-gold); }
.product-eyebrow .num { font-family: var(--font-display-en); font-style: italic; font-size: 18px; font-weight: 300; letter-spacing: 0; color: var(--color-gold); }
.product-title { font-family: var(--font-display-en); font-weight: 200; font-size: clamp(56px, 8vw, 112px); line-height: 0.95; letter-spacing: -0.035em; color: var(--color-cream); margin-bottom: 14px; }
.product-brand-kicker { display: block; font-family: var(--font-mono); font-size: 13px; font-weight: 400; letter-spacing: 0.32em; text-transform: uppercase; color: var(--color-gold); margin-bottom: 14px; opacity: 0.85; }
.product-title em { font-family: var(--font-display-en); font-style: italic; color: var(--color-gold); font-weight: 200; }
.product-subtitle { font-family: var(--font-display-th); font-size: 24px; font-weight: 300; color: var(--color-cream-2); margin-bottom: 28px; letter-spacing: -0.005em; line-height: 1.4; }
.status-row { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 32px; }
.product-desc { font-size: 17px; color: var(--color-cream-2); line-height: 1.75; font-weight: 300; max-width: 560px; margin-bottom: 36px; }
.product-desc strong { color: var(--color-cream); font-weight: 400; }
.product-cta { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 48px; }
.product-stats { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--color-hairline); border-bottom: 1px solid var(--color-hairline); padding: 24px 0; }

/* Page content */
.page-content { padding: 80px 0; }
.page-content h1, .page-content h2, .page-content h3 { font-family: var(--font-display-th); font-weight: 400; color: var(--color-cream); margin: 32px 0 16px; line-height: 1.2; letter-spacing: -0.01em; }
.page-content h1 { font-size: 48px; }
.page-content h2 { font-size: 32px; color: var(--color-gold); }
.page-content h3 { font-size: 22px; }
.page-content p { color: var(--color-cream-2); font-size: 16px; line-height: 1.75; font-weight: 300; margin-bottom: 16px; }
.page-content a { color: var(--color-gold); text-decoration: underline; text-underline-offset: 4px; }
.page-content ul, .page-content ol { color: var(--color-cream-2); font-size: 16px; line-height: 1.75; font-weight: 300; margin: 16px 0 16px 24px; }
.page-content li { margin-bottom: 8px; }

/* The Hunter's Pact (IB Partnership) */
.pact-section { background: var(--color-bg-elevated); border-top: 1px solid var(--color-hairline); border-bottom: 1px solid var(--color-hairline); }
.pact-card { padding: 64px 56px; max-width: 1100px; margin: 0 auto; }
.pact-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 56px; margin-bottom: 56px; }
.pact-step { position: relative; }
.pact-step + .pact-step { padding-left: 56px; border-left: 1px solid var(--color-hairline); }
.pact-step-num { font-family: var(--font-display-en); font-style: italic; font-size: 16px; color: var(--color-gold); margin-bottom: 16px; font-weight: 300; letter-spacing: 0.05em; }
.pact-step-title { font-family: var(--font-display-th); font-size: 24px; font-weight: 400; color: var(--color-cream); margin-bottom: 14px; line-height: 1.2; letter-spacing: -0.01em; }
.pact-step-title em { font-family: var(--font-display-en); font-style: italic; color: var(--color-gold); font-weight: 200; }
.pact-step-desc { color: var(--color-cream-2); font-size: 14px; line-height: 1.7; font-weight: 300; }
.pact-step-desc strong { color: var(--color-cream); font-weight: 400; }
.pact-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; padding-top: 48px; border-top: 1px solid var(--color-hairline); }
.pact-col-mark { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; margin-bottom: 24px; font-weight: 500; }
.pact-col-mark-good { color: var(--color-gold); }
.pact-col-mark-warn { color: var(--color-cream-2); }
.pact-conditions { list-style: none; display: flex; flex-direction: column; gap: 14px; }
.pact-conditions li { font-size: 14px; color: var(--color-cream-2); padding-left: 26px; position: relative; font-weight: 300; line-height: 1.55; }
.pact-conditions li::before { content: '→'; position: absolute; left: 0; top: 0; color: var(--color-gold-deep); font-family: var(--font-mono); font-size: 14px; }
.pact-conditions li strong { color: var(--color-cream); font-weight: 400; }
.pact-cta { text-align: center; margin-top: 48px; padding-top: 40px; border-top: 1px solid var(--color-hairline); }
.pact-cta-note { margin-top: 18px; font-family: var(--font-mono); font-size: 11px; color: var(--color-muted); letter-spacing: 0.16em; text-transform: uppercase; }

/* TradingView Live Chart — full-width section */
.tv-live-sec { padding: 60px 0 80px; border-top: 1px solid var(--color-hairline); }
.tv-live-wrap { padding: 24px; }
.tv-live-frame { width: 100%; height: 640px; margin-top: 16px; border-radius: var(--border-radius-sm); overflow: hidden; background: var(--color-bg-base); }
.tv-live-frame iframe { width: 100% !important; height: 100% !important; border: 0; display: block; }
@media (max-width: 980px) {
  .tv-live-frame { height: 480px; }
  .tv-live-sec { padding: 40px 0 60px; }
  .tv-live-wrap { padding: 16px; }
}

/* Product Gallery */
.product-hero-image { padding: 20px; }
.product-hero-image .hero-image { width: 100%; height: auto; border-radius: var(--border-radius-sm); display: block; margin-top: 12px; }
.product-gallery-sec { padding: 60px 0; }
.product-gallery { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.gallery-item-link { display: block; width: 100%; padding: 0; cursor: pointer; position: relative; overflow: hidden; border: 1px solid var(--color-hairline-bright); border-radius: var(--border-radius-md); background: var(--color-surface); transition: border-color var(--duration-base), transform var(--duration-base); font: inherit; }
.gallery-item-link:hover { border-color: var(--color-gold-deep); transform: translateY(-2px); }
.gallery-item-link img { width: 100%; height: auto; display: block; }
.gallery-item-link::after { content: '⛶'; position: absolute; top: 12px; right: 14px; color: var(--color-gold); font-family: var(--font-mono); font-size: 15px; opacity: 0; transition: opacity var(--duration-fast); background: rgba(10,8,6,0.7); width: 30px; height: 30px; display: grid; place-items: center; border-radius: 50%; }
.gallery-item-link:hover::after { opacity: 1; }

/* v1.56.2 · Lightbox overlay */
.auh-lightbox { position: fixed; inset: 0; z-index: 9999; background: rgba(8,6,4,0.94); display: none; align-items: center; justify-content: center; padding: 40px; cursor: zoom-out; backdrop-filter: blur(4px); }
.auh-lightbox.is-open { display: flex; animation: auhLbFade 220ms ease; }
@keyframes auhLbFade { from { opacity: 0; } to { opacity: 1; } }
.auh-lightbox-img { max-width: 96vw; max-height: 90vh; width: auto; height: auto; border-radius: var(--border-radius-md); box-shadow: 0 24px 80px rgba(0,0,0,0.6); border: 1px solid rgba(229,180,80,0.25); cursor: default; }
.auh-lightbox-close { position: absolute; top: 22px; right: 28px; width: 46px; height: 46px; border-radius: 50%; background: rgba(255,255,255,0.06); border: 1px solid rgba(229,180,80,0.3); color: var(--color-gold); font-size: 28px; line-height: 1; cursor: pointer; display: grid; place-items: center; transition: background 180ms ease, transform 180ms ease; }
.auh-lightbox-close:hover { background: rgba(229,180,80,0.18); transform: scale(1.08); }
@media (max-width: 720px) { .auh-lightbox { padding: 20px; } .auh-lightbox-close { top: 14px; right: 16px; width: 40px; height: 40px; font-size: 24px; } }

/* Video Embed (responsive 16:9) */
.video-sec { padding: 80px 0; }
.video-embed { position: relative; width: 100%; padding-bottom: 56.25%; height: 0; overflow: hidden; border: 1px solid var(--color-hairline-bright); border-radius: var(--border-radius-md); background: var(--color-surface); }
.video-embed iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: 0; }

/* ═══ FOOTER LEGAL ═══ */
.footer-legal { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.footer-legal a { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-muted); text-decoration: none; transition: color var(--duration-fast); }
.footer-legal a:hover { color: var(--color-gold); }
.footer-legal .footer-sep { color: var(--color-faint); font-family: var(--font-mono); font-size: 10px; }
.footer-legal span:last-child { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-muted); }

/* ═══ PAGE CONTENT TYPOGRAPHY (Privacy / Terms / Glossary / Tutorial) ═══ */
.page-content { font-family: var(--font-body); font-weight: 300; color: var(--color-cream-2); font-size: 16px; line-height: 1.85; }
.page-content h2 { font-family: var(--font-display-en); font-weight: 300; font-size: 32px; color: var(--color-cream); margin: 56px 0 20px; letter-spacing: -0.01em; line-height: 1.3; }
.page-content h2:first-of-type { margin-top: 0; }
.page-content h3 { font-family: var(--font-display-th); font-weight: 400; font-size: 22px; color: var(--color-cream); margin: 36px 0 14px; line-height: 1.4; }
.page-content h3:first-child { margin-top: 0; }
.page-content p { margin: 14px 0; }
.page-content ul, .page-content ol { margin: 16px 0; padding-left: 24px; }
.page-content ul li, .page-content ol li { margin: 8px 0; color: var(--color-cream-2); }
.page-content ul li::marker { color: var(--color-gold); }
.page-content strong { color: var(--color-cream); font-weight: 500; }
.page-content code { font-family: var(--font-mono); background: var(--color-bg-base); padding: 2px 6px; border-radius: 3px; font-size: 0.92em; color: var(--color-gold); }
.page-content a { color: var(--color-gold); text-decoration: none; border-bottom: 1px solid var(--color-gold-deep); transition: color var(--duration-fast); }
.page-content a:hover { color: var(--color-gold-bright); border-color: var(--color-gold-bright); }

/* Glossary section blocks */
.page-content h3[id] { scroll-margin-top: 100px; padding-top: 8px; }
.page-content h3[id]::before { content: ''; display: inline-block; width: 12px; height: 1px; background: var(--color-gold); vertical-align: middle; margin-right: 12px; }

/* btn-text — used for small inline links */
.btn-text { display: inline-block; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-gold); text-decoration: none; border-bottom: 1px solid var(--color-gold-deep); padding-bottom: 2px; transition: color var(--duration-fast); }
.btn-text:hover { color: var(--color-gold-bright); border-color: var(--color-gold-bright); }

/* ═══════════════════════════════════════════════════════════════
   AUHUNTER JOURNAL · APP SHELL (v1.48 SaaS layout)
   Sidebar + main content · hides main site header for journal pages
   ═══════════════════════════════════════════════════════════════ */

.aj-app-page .site-nav,
.aj-app-page header.site-nav,
.aj-app-page > header.site-nav { display: none !important; }
.aj-app-page { padding-top: 0 !important; background: var(--color-bg-base); }
body.aj-app-page { padding-top: 0 !important; }
.aj-app-page main.aj-app-main + footer,
.aj-app-page .site-footer { margin-left: 240px; background: var(--color-bg-base); }
@media (max-width: 900px) {
	.aj-app-page .site-footer,
	.aj-app-page main.aj-app-main + footer { margin-left: 0; }
}

/* WP admin bar offset (when logged in admin sees toolbar) */
.admin-bar .aj-sidebar { top: 32px; height: calc(100vh - 32px); }
@media screen and (max-width: 782px) {
	.admin-bar .aj-sidebar { top: 46px; height: calc(100vh - 46px); }
}

/* ─ Sidebar ─ */
.aj-sidebar {
	position: fixed; left: 0; top: 0; width: 240px; height: 100vh;
	background: linear-gradient(180deg, #1a1610 0%, #14110d 100%);
	border-right: 1px solid var(--color-hairline);
	display: flex; flex-direction: column;
	overflow-y: auto; overflow-x: hidden;
	z-index: 50;
	transition: left var(--duration-base);
}
.aj-sidebar::-webkit-scrollbar { width: 4px; }
.aj-sidebar::-webkit-scrollbar-track { background: transparent; }
.aj-sidebar::-webkit-scrollbar-thumb { background: var(--color-hairline-bright); border-radius: 2px; }

.aj-sidebar-head { display: flex; align-items: flex-start; justify-content: space-between; padding: 22px 20px 16px; }
.aj-sidebar-brand { display: flex; align-items: center; gap: 10px; }
.aj-brand-mark { flex-shrink: 0; }
.aj-brand-text { display: flex; flex-direction: column; gap: 1px; }
.aj-brand-name { font-family: var(--font-display-en); font-size: 18px; color: var(--color-cream); letter-spacing: 0.01em; line-height: 1.1; }
.aj-brand-tag { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.22em; color: var(--color-muted); }
.aj-sidebar-close { display: none; background: transparent; border: none; color: var(--color-cream-2); font-size: 18px; cursor: pointer; padding: 4px 8px; }

.aj-sidebar-lang { display: flex; gap: 4px; padding: 0 20px 16px; }
.aj-lang-pill {
	flex: 1; padding: 7px 0; background: transparent;
	border: 1px solid var(--color-hairline-bright);
	color: var(--color-cream-2);
	font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.16em;
	border-radius: var(--border-radius-sm); cursor: pointer;
	transition: all var(--duration-fast);
}
.aj-lang-pill:hover { border-color: var(--color-gold); color: var(--color-gold); }
.aj-lang-pill.active { background: linear-gradient(180deg, #e5c478 0%, #c9a961 100%); border-color: var(--color-gold-bright); color: var(--color-bg-base); font-weight: 600; }

.aj-sidebar-nav { padding: 8px 12px; display: flex; flex-direction: column; gap: 2px; flex: 1; }
.aj-side-link {
	display: flex; align-items: center; gap: 11px;
	padding: 9px 12px;
	color: var(--color-cream-2);
	text-decoration: none;
	font-family: var(--font-body); font-size: 13px;
	border-radius: var(--border-radius-sm);
	transition: all var(--duration-fast);
}
.aj-side-link:hover { background: rgba(201,169,97,0.06); color: var(--color-gold); }
.aj-side-link.active { background: rgba(201,169,97,0.12); color: var(--color-gold); border-left: 2px solid var(--color-gold); padding-left: 10px; }
.aj-side-link svg { flex-shrink: 0; opacity: 0.8; }
.aj-side-link.active svg { opacity: 1; }

.aj-sidebar-mini { margin: 12px 16px 0; padding: 14px 14px 12px; background: rgba(0,0,0,0.25); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); }
.aj-mini-title { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--color-muted); margin: 0 0 10px; font-weight: 500; }
.aj-mini-row { display: flex; justify-content: space-between; align-items: center; padding: 4px 0; font-size: 11px; }
.aj-mini-label { color: var(--color-cream-2); }
.aj-mini-val { font-family: var(--font-display-en); font-size: 14px; color: var(--color-cream); font-weight: 400; }
.aj-mini-val.pos { color: var(--color-bull); }
.aj-mini-val.neg { color: var(--color-bear); }

.aj-sidebar-foot { padding: 16px 16px 18px; display: flex; flex-direction: column; gap: 2px; }
.aj-side-foot-link { padding: 7px 8px; color: var(--color-muted); font-size: 11px; font-family: var(--font-mono); letter-spacing: 0.06em; text-decoration: none; border-radius: var(--border-radius-sm); transition: all var(--duration-fast); }
.aj-side-foot-link:hover { color: var(--color-gold); background: rgba(201,169,97,0.04); }
.aj-side-logout:hover { color: var(--color-bear); background: rgba(184,84,80,0.04); }

/* Hamburger button (mobile only) · z-index above WP admin bar */
.aj-mobile-menu-btn {
	display: none; position: fixed; top: 14px; left: 14px; z-index: 100001;
	width: 42px; height: 42px; padding: 0;
	background: var(--color-surface); border: 1px solid var(--color-gold-deep);
	color: var(--color-gold); border-radius: var(--border-radius-sm);
	cursor: pointer; box-shadow: 0 4px 16px rgba(0,0,0,0.5);
	align-items: center; justify-content: center;
	transition: all var(--duration-fast);
}
.aj-mobile-menu-btn:hover { background: var(--color-gold); color: var(--color-bg-base); border-color: var(--color-gold-bright); }
.aj-mobile-menu-btn svg { display: block; }

/* Push button below admin bar */
.admin-bar .aj-mobile-menu-btn { top: 46px; }
@media screen and (max-width: 782px) {
	.admin-bar .aj-mobile-menu-btn { top: 58px; }
}

.aj-sidebar-backdrop { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.55); z-index: 99; }
.aj-sidebar-backdrop.open { display: block; }

/* ─ Main content area ─ */
.aj-app-main {
	margin-left: 240px;
	padding: 28px 36px 60px;
	min-height: 100vh;
	background: var(--color-bg-base);
}

.aj-app-topbar { display: flex; align-items: flex-start; justify-content: space-between; gap: 20px; padding-bottom: 20px; border-bottom: 1px solid var(--color-hairline); margin-bottom: 22px; }
.aj-topbar-greeting { flex: 1; }
.aj-app-eyebrow { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 6px; }
.aj-app-hello { font-family: var(--font-display-th); font-size: 26px; font-weight: 300; color: var(--color-cream); margin: 0 0 6px; letter-spacing: 0.01em; }
.aj-app-subtitle { font-size: 13px; color: var(--color-cream-2); margin: 0; line-height: 1.5; }
.aj-topbar-actions { display: flex; align-items: center; gap: 10px; flex-shrink: 0; padding-top: 4px; }

/* ─ Filter pills ─ */
.aj-filter-pills { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; padding: 14px 16px; margin-bottom: 18px; background: var(--color-surface); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); }
.aj-filter-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-muted); margin-right: 4px; }
.aj-pill { padding: 5px 12px; background: rgba(201,169,97,0.08); border: 1px solid var(--color-gold-deep); color: var(--color-gold); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; border-radius: 999px; }
.aj-pill-active { background: rgba(201,169,97,0.12); border-color: var(--color-gold); }
.aj-pill-meta { font-family: var(--font-mono); font-size: 10px; color: var(--color-muted); margin-left: 4px; }

/* ─ Big stat cards ─ */
.aj-stats-grid-l { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 12px; margin-bottom: 22px; }
.aj-stat-l {
	background: var(--color-surface);
	border: 1px solid var(--color-hairline);
	border-radius: var(--border-radius-sm);
	padding: 18px 20px;
	display: flex; flex-direction: column; gap: 4px;
	transition: border-color var(--duration-fast);
}
.aj-stat-l:hover { border-color: var(--color-hairline-bright); }
.aj-stat-l-label { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 4px; }
.aj-stat-l-value { font-family: var(--font-display-en); font-size: 32px; font-weight: 300; color: var(--color-cream); line-height: 1.1; letter-spacing: -0.01em; }
.aj-stat-l-unit { font-size: 14px; color: var(--color-muted); font-weight: 400; margin-left: 2px; }
.aj-stat-l-sub { font-size: 11px; color: var(--color-muted); margin-top: 2px; line-height: 1.4; }
.aj-stat-l-value.aj-stat-pos { color: var(--color-bull); }
.aj-stat-l-value.aj-stat-neg { color: var(--color-bear); }
.aj-stat-pos { color: var(--color-bull); }
.aj-stat-neg { color: var(--color-bear); }

/* ─ Dashboard row · Equity wide + Donut ─ */
.aj-dash-row { display: grid; grid-template-columns: 2fr 1fr; gap: 16px; margin-bottom: 22px; }
.aj-equity-wide { padding: 20px 24px; }
.aj-equity-chart { padding: 8px 0; }
.aj-equity-chart canvas { width: 100%; height: auto; max-height: 220px; display: block; }
.aj-equity-stats { display: flex; justify-content: space-between; gap: 12px; padding-top: 14px; border-top: 1px solid var(--color-hairline); margin-top: 8px; }
.aj-eq-stat { flex: 1; }
.aj-eq-stat-label { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 4px; }
.aj-eq-stat-val { font-family: var(--font-display-en); font-size: 17px; color: var(--color-cream); font-weight: 400; }

/* ─ Donut card ─ */
.aj-donut-card { padding: 20px 22px; display: flex; flex-direction: column; }
.aj-donut-wrap { display: flex; justify-content: center; align-items: center; padding: 8px 0 12px; }
.aj-donut-svg { width: 100%; max-width: 180px; height: auto; }
.aj-donut-legend { display: flex; flex-direction: column; gap: 8px; padding-top: 14px; border-top: 1px solid var(--color-hairline); }
.aj-legend-row { display: flex; align-items: center; gap: 8px; font-size: 12px; }
.aj-legend-dot { width: 9px; height: 9px; border-radius: 2px; flex-shrink: 0; }
.aj-legend-label { flex: 1; color: var(--color-cream-2); }
.aj-legend-val { font-family: var(--font-display-en); color: var(--color-cream); font-size: 15px; font-weight: 400; }

/* ─ Per-broker breakdown cards ─ */
.aj-broker-summary-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 12px; margin-bottom: 22px; }
.aj-broker-sum-card { padding: 18px 22px; }
.aj-bsum-head { display: flex; align-items: center; gap: 12px; padding-bottom: 14px; border-bottom: 1px solid var(--color-hairline); margin-bottom: 14px; }
.aj-bsum-logo { width: 36px; height: 36px; flex-shrink: 0; }
.aj-bsum-logo .aj-broker-logo-letter { width: 36px; height: 36px; font-size: 13px; }
.aj-bsum-logo img { width: 36px; height: 36px; object-fit: contain; }
.aj-bsum-name { flex: 1; min-width: 0; }
.aj-bsum-broker { font-family: var(--font-display-th); font-size: 16px; color: var(--color-cream); line-height: 1.1; }
.aj-bsum-accounts { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; color: var(--color-muted); margin-top: 2px; }
.aj-bsum-stats { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; }
.aj-bsum-stat { padding: 6px 0; }
.aj-bsum-stat-label { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 4px; }
.aj-bsum-stat-val { font-family: var(--font-display-en); font-size: 18px; color: var(--color-cream); font-weight: 400; }

/* ─ Section heading inside app ─ */
.aj-app-main .aj-section-head { margin-bottom: 12px; padding-bottom: 8px; }

/* ─ Mobile ─ */
@media (max-width: 1000px) {
	.aj-dash-row { grid-template-columns: 1fr; }
}
@media (max-width: 900px) {
	.aj-mobile-menu-btn { display: flex !important; }
	.aj-sidebar { left: -280px; width: 280px; z-index: 100000; }
	.aj-sidebar.open { left: 0; }
	.aj-sidebar-close { display: block; }
	.aj-app-main { margin-left: 0; padding: 76px 18px 50px; }
	.aj-app-topbar { flex-direction: column; align-items: flex-start; gap: 8px; }
	.aj-app-hello { font-size: 22px; }
	.aj-stats-grid-l { grid-template-columns: 1fr 1fr; }
	.aj-broker-summary-grid { grid-template-columns: 1fr; }
}

/* Admin bar pushes content down */
.admin-bar.aj-app-page .aj-app-main { padding-top: 110px; }
@media (max-width: 782px) {
	.admin-bar.aj-app-page .aj-app-main { padding-top: 120px; }
}
@media (max-width: 480px) {
	.aj-stats-grid-l { grid-template-columns: 1fr; }
	.aj-stat-l-value { font-size: 28px; }
}

/* ═══════════════════════════════════════════════════════════════
   AUHUNTER JOURNAL · MEMBER APP STYLES
   Login + Dashboard · Dark gold luxury aesthetic
   ═══════════════════════════════════════════════════════════════ */

.aj-app-sec, .aj-login-sec { padding: 40px 0 80px; min-height: 70vh; }

.aj-login-wrap { max-width: 480px; margin: 0 auto; padding: 0 20px; }

.aj-lang-switcher { display: flex; align-items: center; justify-content: center; gap: 8px; margin-bottom: 24px; }
.aj-lang-btn { background: transparent; border: 0; color: var(--color-muted); font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; cursor: pointer; padding: 6px 10px; transition: color var(--duration-fast); }
.aj-lang-btn:hover { color: var(--color-cream); }
.aj-lang-btn.active { color: var(--color-gold); }
.aj-lang-sep { color: var(--color-hairline-bright); }

.aj-login-card { padding: 40px 36px 32px; text-align: center; }
.aj-login-brand { margin-bottom: 20px; }
.aj-login-brand svg { display: block; margin: 0 auto; }
.aj-login-title { font-family: var(--font-display-th); font-size: 26px; font-weight: 400; color: var(--color-cream); margin: 0 0 8px; letter-spacing: 0.01em; }
.aj-login-sub { font-size: 13px; color: var(--color-muted); margin: 0 0 28px; line-height: 1.6; }

.aj-login-social { display: flex; flex-direction: column; gap: 10px; margin-bottom: 24px; }
.aj-social-btn { display: flex; align-items: center; justify-content: center; gap: 10px; padding: 12px 16px; background: transparent; border: 1px solid var(--color-hairline-bright); color: var(--color-cream); font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.06em; cursor: pointer; transition: all var(--duration-base); border-radius: var(--border-radius-sm); }
.aj-social-btn:hover:not(:disabled) { border-color: var(--color-gold); background: rgba(201,169,97,0.04); color: var(--color-gold-bright); }
.aj-social-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.aj-social-warning { font-size: 10px; color: var(--color-muted); font-style: italic; margin-top: 4px; padding: 8px; background: rgba(184,84,80,0.06); border-radius: var(--border-radius-sm); border-left: 2px solid var(--color-bear); text-align: left; }

.aj-login-divider { position: relative; text-align: center; margin: 20px 0; }
.aj-login-divider::before { content: ''; position: absolute; top: 50%; left: 0; right: 0; height: 1px; background: var(--color-hairline); }
.aj-login-divider span { position: relative; display: inline-block; padding: 0 16px; background: var(--color-surface); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.2em; color: var(--color-muted); text-transform: uppercase; }

.aj-login-form { text-align: left; margin-bottom: 18px; }
.aj-field { margin-bottom: 14px; }
.aj-field label { display: block; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 6px; }
.aj-field input { width: 100%; padding: 11px 14px; background: var(--color-bg-base); border: 1px solid var(--color-hairline-bright); border-radius: var(--border-radius-sm); color: var(--color-cream); font-family: var(--font-body); font-size: 14px; transition: border-color var(--duration-base); }
.aj-field input:focus { outline: 0; border-color: var(--color-gold); }

.aj-login-submit { width: 100%; padding: 13px; background: linear-gradient(180deg, #e5c478 0%, #c9a961 100%); color: var(--color-bg-base); border: 0; border-radius: var(--border-radius-sm); font-family: var(--font-mono); font-size: 12px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; cursor: pointer; transition: all var(--duration-base); }
.aj-login-submit:hover { background: linear-gradient(180deg, #ecd089 0%, #d6b46e 100%); transform: translateY(-1px); }

.aj-login-links { display: flex; justify-content: center; gap: 8px; align-items: center; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.04em; margin-bottom: 24px; }
.aj-login-links a { color: var(--color-cream-2); text-decoration: none; }
.aj-login-links a:hover { color: var(--color-gold); }
.aj-link-sep { color: var(--color-hairline-bright); }

.aj-login-disclaimer { font-size: 10px; color: var(--color-muted); line-height: 1.6; padding-top: 18px; border-top: 1px solid var(--color-hairline); }

.container-wide { max-width: 1100px; margin: 0 auto; padding: 0 20px; }

.aj-app-header { display: flex; justify-content: space-between; align-items: flex-start; padding-bottom: 18px; border-bottom: 1px solid var(--color-hairline); margin-bottom: 24px; flex-wrap: wrap; gap: 16px; }
.aj-app-eyebrow { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--color-gold); margin-bottom: 6px; }
.aj-app-hello { font-family: var(--font-display-th); font-size: 26px; font-weight: 400; color: var(--color-cream); margin: 0; letter-spacing: 0.01em; }
.aj-app-header-actions { display: flex; gap: 14px; align-items: center; }

.aj-tier-badge { font-family: var(--font-mono); font-size: 10px; padding: 4px 10px; border-radius: 999px; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600; }
.aj-tier-free      { background: rgba(150,150,150,0.10); color: var(--color-cream-2); border: 1px solid var(--color-hairline-bright); }
.aj-tier-member    { background: rgba(201,169,97,0.10); color: var(--color-gold); border: 1px solid var(--color-gold-deep); }
.aj-tier-ib_member { background: linear-gradient(180deg, #e5c478 0%, #c9a961 100%); color: var(--color-bg-base); }

.aj-app-nav { display: flex; gap: 6px; padding: 8px; background: var(--color-surface); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); margin-bottom: 24px; overflow-x: auto; flex-wrap: wrap; }
.aj-nav-item { padding: 8px 14px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; color: var(--color-cream-2); text-decoration: none; border-radius: var(--border-radius-sm); white-space: nowrap; transition: all var(--duration-base); }
.aj-nav-item:hover { background: rgba(201,169,97,0.06); color: var(--color-gold); }
.aj-nav-item.active { background: rgba(201,169,97,0.12); color: var(--color-gold); border: 1px solid var(--color-gold-deep); }
.aj-nav-ib { color: var(--color-gold); }
.aj-nav-logout { margin-left: auto; color: var(--color-muted); }

.aj-empty-state { padding: 60px 40px; text-align: center; max-width: 640px; margin: 0 auto; }
.aj-empty-icon { margin-bottom: 24px; }
.aj-empty-icon svg { display: block; margin: 0 auto; }
.aj-empty-title { font-family: var(--font-display-th); font-size: 24px; font-weight: 400; color: var(--color-cream); margin: 0 0 12px; }
.aj-empty-sub { font-size: 14px; color: var(--color-muted); margin: 0 0 28px; line-height: 1.6; }
.aj-empty-actions { margin-bottom: 36px; }
.aj-btn-primary { display: inline-block; padding: 14px 28px; background: linear-gradient(180deg, #e5c478 0%, #c9a961 100%); color: var(--color-bg-base); text-decoration: none; border-radius: var(--border-radius-sm); font-family: var(--font-mono); font-size: 12px; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; transition: all var(--duration-base); }
.aj-btn-primary:hover { transform: translateY(-1px); box-shadow: 0 8px 24px rgba(201,169,97,0.25); }

.aj-empty-steps { display: flex; justify-content: center; gap: 32px; padding-top: 28px; border-top: 1px solid var(--color-hairline); flex-wrap: wrap; }
.aj-step { display: flex; flex-direction: column; align-items: center; gap: 6px; opacity: 0.4; }
.aj-step-current { opacity: 1; }
.aj-step-done    { opacity: 0.7; }
.aj-step-done .aj-step-num { background: var(--color-gold); color: var(--color-bg-base); }
.aj-step-num { width: 36px; height: 36px; border-radius: 50%; border: 1px solid var(--color-gold-deep); display: flex; align-items: center; justify-content: center; font-family: var(--font-mono); font-size: 12px; color: var(--color-gold); font-weight: 600; }
.aj-step-current .aj-step-num { border-color: var(--color-gold); background: rgba(201,169,97,0.10); }
.aj-step-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; color: var(--color-cream-2); }

.aj-stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-bottom: 20px; }
.aj-stat-card { background: var(--color-surface); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); padding: 16px 18px; }
.aj-stat-label { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 6px; }
.aj-stat-value { font-family: var(--font-display-en); font-weight: 300; font-size: 24px; color: var(--color-cream); letter-spacing: -0.01em; }
.aj-stat-value.aj-stat-pos { color: var(--color-bull); }
.aj-stat-value.aj-stat-neg { color: var(--color-bear); }

.aj-card { padding: 24px 28px; margin-bottom: 20px; }
.aj-card-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; padding-bottom: 12px; border-bottom: 1px solid var(--color-hairline); }
.aj-card-head h3 { font-family: var(--font-display-th); font-size: 16px; font-weight: 400; color: var(--color-cream); margin: 0; letter-spacing: 0.04em; }
.aj-card-meta { font-family: var(--font-mono); font-size: 11px; color: var(--color-muted); }
.aj-card-link { font-family: var(--font-mono); font-size: 11px; color: var(--color-gold); text-decoration: none; letter-spacing: 0.08em; }
.aj-card-link:hover { color: var(--color-gold-bright); }

.aj-equity-chart { padding: 8px 0; }
.aj-equity-chart canvas { width: 100%; height: 180px; display: block; }

.aj-trades-list { display: flex; flex-direction: column; gap: 2px; }
.aj-trade-row { display: grid; grid-template-columns: 100px 1fr 60px 60px 100px 60px; gap: 12px; align-items: center; padding: 12px 14px; background: var(--color-bg-base); border-radius: var(--border-radius-sm); font-size: 13px; }
.aj-trade-time { font-family: var(--font-mono); font-size: 11px; color: var(--color-muted); }
.aj-trade-symbol { color: var(--color-cream); }
.aj-trade-dir { font-family: var(--font-mono); font-size: 11px; font-weight: 600; letter-spacing: 0.08em; }
.aj-trade-dir-buy  { color: var(--color-bull); }
.aj-trade-dir-sell { color: var(--color-bear); }
.aj-trade-lot { color: var(--color-cream-2); font-family: var(--font-mono); }
.aj-trade-pnl { font-family: var(--font-mono); font-weight: 600; text-align: right; }
.aj-trade-pnl-pos { color: var(--color-bull); }
.aj-trade-pnl-neg { color: var(--color-bear); }
.aj-trade-badge { font-family: var(--font-mono); font-size: 9px; padding: 3px 8px; border-radius: 999px; letter-spacing: 0.1em; text-align: center; text-transform: uppercase; }
.aj-trade-badge-win  { background: rgba(95,168,79,0.12);  color: var(--color-bull); }
.aj-trade-badge-loss { background: rgba(184,84,80,0.12);  color: var(--color-bear); }
.aj-trade-badge-be   { background: rgba(150,150,150,0.10); color: var(--color-cream-2); }
.aj-trade-badge-pending { background: rgba(250,204,21,0.10); color: #facc15; }

.aj-fab { position: fixed; bottom: 24px; right: 24px; display: flex; align-items: center; gap: 8px; padding: 14px 20px; background: linear-gradient(180deg, #e5c478 0%, #c9a961 100%); color: var(--color-bg-base); border-radius: 999px; text-decoration: none; font-family: var(--font-mono); font-size: 11px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; box-shadow: 0 8px 24px rgba(0,0,0,0.5), 0 0 0 1px rgba(229,196,120,0.4); transition: all var(--duration-base); z-index: 90; }
.aj-fab:hover { transform: translateY(-2px); box-shadow: 0 12px 28px rgba(0,0,0,0.6), 0 0 0 1px rgba(229,196,120,0.6); color: var(--color-bg-base); }

.aj-disclaimer-footer { font-size: 11px; color: var(--color-muted); text-align: center; max-width: 720px; margin: 40px auto 0; line-height: 1.7; padding: 16px; border-top: 1px solid var(--color-hairline); }

@media (max-width: 980px) {
	.aj-stats-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
	.aj-app-sec, .aj-login-sec { padding: 24px 0 60px; }
	.aj-login-card { padding: 28px 22px 24px; }
	.aj-app-header { flex-direction: column; }
	.aj-app-nav { gap: 4px; padding: 6px; }
	.aj-nav-item { padding: 6px 10px; font-size: 10px; }
	.aj-empty-state { padding: 36px 20px; }
	.aj-empty-steps { gap: 16px; }
	.aj-trade-row { grid-template-columns: 1fr auto; }
	.aj-fab { bottom: 16px; right: 16px; padding: 12px 16px; font-size: 10px; }
	.aj-card { padding: 18px 20px; }
}

/* ═══════════════════════════════════════════════════════════════
   AUHUNTER JOURNAL · BROKERS PAGE
   ═══════════════════════════════════════════════════════════════ */

.aj-app-subtitle { font-size: 13px; color: var(--color-muted); margin: 6px 0 0; }

.aj-section-head { display: flex; justify-content: space-between; align-items: center; margin: 20px 0 16px; flex-wrap: wrap; gap: 12px; }
.aj-section-title { font-family: var(--font-display-th); font-size: 16px; font-weight: 400; color: var(--color-cream); margin: 0; letter-spacing: 0.04em; }
.aj-section-meta { font-family: var(--font-mono); font-size: 12px; color: var(--color-muted); margin-right: 14px; }
.aj-section-meta strong { color: var(--color-gold); font-weight: 600; }
.aj-section-actions { display: flex; align-items: center; }

.aj-btn-sm { padding: 8px 16px; font-size: 11px; letter-spacing: 0.12em; }

/* ═══ Account grid ═══ */
.aj-accounts-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 16px; margin-bottom: 28px; }
.aj-account-card { padding: 20px 22px; transition: all var(--duration-base); }
.aj-account-card:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,0.4); }

.aj-account-head { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 14px; padding-bottom: 14px; border-bottom: 1px solid var(--color-hairline); }
.aj-broker-logo { width: 40px; height: 40px; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-family: var(--font-display-en); font-size: 20px; font-weight: 700; flex-shrink: 0; overflow: hidden; }
.aj-broker-logo-img { background: #fff; padding: 2px; }
.aj-broker-logo img { width: 100%; height: 100%; object-fit: contain; display: block; }
.aj-account-info { flex: 1; min-width: 0; }
.aj-account-broker { font-family: var(--font-display-th); font-size: 15px; color: var(--color-cream); font-weight: 500; }
.aj-account-nickname { font-size: 12px; color: var(--color-muted); margin-top: 2px; }

.aj-acctype-badge { font-family: var(--font-mono); font-size: 8px; padding: 4px 8px; border-radius: 999px; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 600; white-space: nowrap; }
.aj-acctype-personal     { background: rgba(150,150,150,0.10); color: var(--color-cream-2); border: 1px solid var(--color-hairline-bright); }
.aj-acctype-pending_ib   { background: rgba(250,204,21,0.10); color: #facc15; border: 1px solid #facc1555; }
.aj-acctype-via_auhunter { background: linear-gradient(180deg, #e5c478 0%, #c9a961 100%); color: var(--color-bg-base); }
.aj-acctype-rejected     { background: rgba(184,84,80,0.10); color: var(--color-bear); border: 1px solid #b8545055; }
.aj-acctype-closed       { background: rgba(80,80,80,0.10); color: var(--color-muted); }

.aj-account-body { display: flex; flex-direction: column; gap: 8px; }
.aj-account-row { display: flex; justify-content: space-between; font-size: 12px; }
.aj-account-label { color: var(--color-muted); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; }
.aj-account-val { color: var(--color-cream); font-weight: 500; }
.aj-account-val.aj-account-mono { font-family: var(--font-mono); color: var(--color-gold); }
.aj-account-trades-row { margin-top: 6px; padding-top: 8px; border-top: 1px dashed var(--color-hairline); }
.aj-account-trades-row strong { color: var(--color-gold); font-family: var(--font-mono); }

.aj-account-notes { margin-top: 12px; padding: 10px 12px; background: rgba(0,0,0,0.3); border-left: 2px solid var(--color-gold-deep); border-radius: var(--border-radius-sm); font-size: 11px; color: var(--color-cream-2); font-style: italic; line-height: 1.5; }

.aj-account-actions { display: flex; gap: 8px; margin-top: 14px; padding-top: 12px; border-top: 1px solid var(--color-hairline); }
.aj-btn-ghost { flex: 1; padding: 8px 12px; background: transparent; border: 1px solid var(--color-hairline-bright); color: var(--color-cream-2); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; border-radius: var(--border-radius-sm); cursor: pointer; transition: all var(--duration-base); }
.aj-btn-ghost:hover { border-color: var(--color-gold); color: var(--color-gold); background: rgba(201,169,97,0.04); }
.aj-btn-ghost.aj-btn-danger:hover { border-color: var(--color-bear); color: var(--color-bear); background: rgba(184,84,80,0.06); }

/* ═══ IB CTA card ═══ */
.aj-ib-card { padding: 32px 36px; margin-top: 24px; background: linear-gradient(180deg, #2a2118 0%, #1d1812 100%); }
.aj-ib-head { text-align: center; margin-bottom: 24px; }
.aj-ib-badge { display: inline-block; font-family: var(--font-display-th); font-size: 18px; color: var(--color-gold-bright); font-weight: 500; letter-spacing: 0.02em; margin-bottom: 8px; }
.aj-ib-sub { font-size: 13px; color: var(--color-cream-2); margin: 0; line-height: 1.6; }

.aj-ib-benefits { background: rgba(0,0,0,0.25); padding: 18px 22px; border-radius: var(--border-radius-sm); border: 1px solid var(--color-hairline); margin-bottom: 22px; }
.aj-ib-benefits-title { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-gold); margin-bottom: 12px; }
.aj-ib-benefit-list { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px 18px; }
.aj-ib-benefit-list li { font-size: 12px; color: var(--color-cream); line-height: 1.5; }

.aj-ib-brokers { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 12px; margin-bottom: 20px; }
.aj-ib-broker-btn { display: flex; align-items: center; gap: 12px; padding: 16px 18px; background: rgba(0,0,0,0.35); border: 1px solid var(--color-hairline-bright); border-radius: var(--border-radius-sm); text-decoration: none; transition: all var(--duration-base); }
.aj-ib-broker-btn:hover { border-color: var(--color-gold); background: rgba(201,169,97,0.05); transform: translateX(2px); }
.aj-ib-broker-logo { width: 36px; height: 36px; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-family: var(--font-display-en); font-size: 18px; font-weight: 700; flex-shrink: 0; overflow: hidden; }
.aj-ib-broker-logo-img { background: #fff; padding: 2px; }
.aj-ib-broker-logo img { width: 100%; height: 100%; object-fit: contain; display: block; }
.aj-ib-broker-text { flex: 1; min-width: 0; }
.aj-ib-broker-name { display: block; font-family: var(--font-display-th); font-size: 13px; color: var(--color-cream); font-weight: 500; line-height: 1.3; }
.aj-ib-broker-tag { display: block; font-size: 10px; color: var(--color-muted); margin-top: 2px; line-height: 1.4; }
.aj-ib-broker-arrow { color: var(--color-gold); font-size: 18px; font-family: var(--font-display-en); }

.aj-ib-disclaimer { font-size: 10px; color: var(--color-muted); text-align: center; line-height: 1.7; padding-top: 16px; border-top: 1px solid var(--color-hairline); }

/* ════════════════════════════════════════════════════════════
   IB MEMBERSHIP PAGE (template-app-ib.php)
   ════════════════════════════════════════════════════════════ */

/* ─── Hero (tier + usage) ─── */
.aj-ibp-hero { padding: 28px 32px; margin-bottom: 24px; background: linear-gradient(180deg, #221b13 0%, #1a140e 100%); }
.aj-ibp-hero-grid { display: grid; grid-template-columns: minmax(0, 280px) 1fr; gap: 36px; align-items: center; }

.aj-ibp-tier-block { border-right: 1px solid var(--color-hairline); padding-right: 32px; }
.aj-ibp-tier-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 8px; }
.aj-ibp-tier-name { font-family: var(--font-display-en); font-size: 32px; font-weight: 600; letter-spacing: 0.04em; line-height: 1; margin-bottom: 8px; }
.aj-ibp-tier-name.aj-ibp-tier-free { color: var(--color-cream-2); }
.aj-ibp-tier-name.aj-ibp-tier-member { color: var(--color-gold); }
.aj-ibp-tier-name.aj-ibp-tier-ib_member { background: linear-gradient(180deg, #e5c478 0%, #c9a961 100%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.aj-ibp-crown { font-size: 24px; color: var(--color-gold-bright); margin-right: 4px; -webkit-text-fill-color: var(--color-gold-bright); }
.aj-ibp-tier-sub { font-size: 12px; color: var(--color-cream-2); margin: 0 0 18px; line-height: 1.6; }
.aj-ibp-upgrade-btn { display: inline-flex; align-items: center; gap: 8px; padding: 11px 18px; font-size: 11px; }
.aj-ibp-arrow { font-family: var(--font-display-en); }

.aj-ibp-usage-block { display: flex; flex-direction: column; gap: 14px; }
.aj-ibp-usage-title { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-gold); margin-bottom: 4px; }
.aj-ibp-usage-row { display: flex; flex-direction: column; gap: 6px; }
.aj-ibp-usage-head { display: flex; justify-content: space-between; align-items: baseline; }
.aj-ibp-usage-label { font-size: 12px; color: var(--color-cream-2); }
.aj-ibp-usage-val { font-family: var(--font-mono); font-size: 11px; color: var(--color-cream); letter-spacing: 0.04em; }
.aj-ibp-usage-val strong { color: var(--color-gold); font-weight: 600; font-size: 13px; }
.aj-ibp-bar { width: 100%; height: 4px; background: rgba(0,0,0,0.4); border-radius: 999px; overflow: hidden; border: 1px solid var(--color-hairline); }
.aj-ibp-bar-fill { height: 100%; background: linear-gradient(90deg, #c9a961 0%, #e5c478 100%); border-radius: 999px; transition: width var(--duration-base); }
.aj-ibp-bar-fill.warn { background: linear-gradient(90deg, #d97757 0%, #e88c5f 100%); }
.aj-ibp-bar-unlimited .aj-ibp-bar-fill { width: 100%; background: linear-gradient(90deg, #c9a961 0%, #e5c478 50%, #c9a961 100%); opacity: 0.5; }
.aj-ibp-warn { font-size: 11px; color: var(--color-bear); padding: 8px 10px; background: rgba(217,119,87,0.08); border: 1px solid rgba(217,119,87,0.25); border-radius: var(--border-radius-sm); margin-top: 4px; }

/* ─── Verified / pending account cards ─── */
.aj-ibp-acc-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 12px; margin-bottom: 28px; }
.aj-ibp-acc-card { padding: 16px 18px; display: flex; align-items: center; gap: 14px; }
.aj-ibp-acc-verified { border-color: var(--color-gold-deep); background: linear-gradient(180deg, rgba(201,169,97,0.06) 0%, transparent 100%); }
.aj-ibp-acc-pending { border-color: rgba(217,119,87,0.3); }
.aj-ibp-acc-logo { width: 38px; height: 38px; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-family: var(--font-display-en); font-size: 17px; font-weight: 700; flex-shrink: 0; overflow: hidden; }
.aj-ibp-acc-logo-img { background: #fff; padding: 2px; }
.aj-ibp-acc-logo img { width: 100%; height: 100%; object-fit: contain; display: block; }
.aj-ibp-acc-body { flex: 1; min-width: 0; }
.aj-ibp-acc-broker { font-family: var(--font-display-th); font-size: 13px; color: var(--color-cream); font-weight: 500; line-height: 1.3; }
.aj-ibp-acc-num { font-family: var(--font-mono); font-size: 11px; color: var(--color-cream-2); letter-spacing: 0.04em; margin-top: 2px; }
.aj-ibp-acc-meta { font-size: 10px; color: var(--color-muted); margin-top: 4px; }
.aj-ibp-acc-status { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; padding: 4px 10px; border-radius: 999px; flex-shrink: 0; font-weight: 600; }
.aj-ibp-acc-status-ok { background: rgba(94,162,121,0.12); color: var(--color-bull); border: 1px solid rgba(94,162,121,0.3); }
.aj-ibp-acc-status-pending { background: rgba(217,119,87,0.10); color: var(--color-bear); border: 1px solid rgba(217,119,87,0.3); }

/* ─── Submit-for-review form ─── */
.aj-ibp-submit-card { padding: 24px 28px; margin-bottom: 28px; }
.aj-ibp-submit-head { margin-bottom: 16px; }
.aj-ibp-submit-title-row { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.aj-ibp-submit-title { font-family: var(--font-display-th); font-size: 16px; font-weight: 500; color: var(--color-cream); margin: 0; letter-spacing: 0.01em; }
.aj-ibp-submit-sub { font-size: 12px; color: var(--color-cream-2); margin: 0; line-height: 1.6; }
.aj-ibp-submit-form { display: grid; grid-template-columns: 1fr auto; gap: 12px; align-items: end; }
.aj-ibp-submit-form .aj-field { margin: 0; }
.aj-ibp-submit-btn { padding: 12px 22px; white-space: nowrap; font-size: 11px; }
.aj-ibp-submit-msg { grid-column: 1 / -1; padding: 10px 14px; border-radius: var(--border-radius-sm); font-size: 12px; line-height: 1.5; }
.aj-ibp-submit-msg.ok { background: rgba(94,162,121,0.08); color: var(--color-bull); border: 1px solid rgba(94,162,121,0.25); }
.aj-ibp-submit-msg.err { background: rgba(217,119,87,0.08); color: var(--color-bear); border: 1px solid rgba(217,119,87,0.25); }

/* ─── Comparison table ─── */
.aj-ibp-compare-wrap { overflow-x: auto; margin-bottom: 28px; border: 1px solid var(--color-hairline); border-radius: var(--border-radius-md); background: var(--color-surface); }
.aj-ibp-compare { width: 100%; min-width: 640px; border-collapse: collapse; }
.aj-ibp-compare thead th { padding: 22px 18px 18px; text-align: center; background: linear-gradient(180deg, #1a1510 0%, #14110c 100%); border-bottom: 1px solid var(--color-hairline); position: relative; vertical-align: top; }
.aj-ibp-compare-feat { text-align: left !important; font-family: var(--font-mono); font-size: 10px; color: var(--color-muted); letter-spacing: 0.16em; text-transform: uppercase; width: 44%; }
.aj-ibp-compare-col { width: 28%; }
.aj-ibp-compare-col.is-current { background: linear-gradient(180deg, #221b13 0%, #1a140e 100%) !important; }
.aj-ibp-compare-col-best { background: linear-gradient(180deg, rgba(201,169,97,0.10) 0%, rgba(201,169,97,0.02) 100%) !important; }
.aj-ibp-compare-col-best.is-current { background: linear-gradient(180deg, rgba(201,169,97,0.18) 0%, rgba(201,169,97,0.05) 100%) !important; }
.aj-ibp-compare-name { font-family: var(--font-display-en); font-size: 14px; font-weight: 600; color: var(--color-cream); letter-spacing: 0.06em; margin-bottom: 4px; }
.aj-ibp-compare-col-best .aj-ibp-compare-name { color: var(--color-gold-bright); }
.aj-ibp-compare-sub { font-size: 10px; color: var(--color-muted); line-height: 1.5; font-weight: 400; }
.aj-ibp-compare-badge { display: inline-block; font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; padding: 3px 8px; border-radius: 999px; background: var(--color-gold-deep); color: var(--color-cream); margin-top: 8px; font-weight: 600; }
.aj-ibp-compare tbody td { padding: 14px 18px; border-bottom: 1px solid var(--color-hairline); text-align: center; font-size: 12px; color: var(--color-cream); }
.aj-ibp-compare tbody tr:last-child td { border-bottom: 0; }
.aj-ibp-compare tbody td.aj-ibp-compare-feat { text-align: left !important; font-family: var(--font-display-th); font-size: 12px; color: var(--color-cream-2); letter-spacing: 0; text-transform: none; font-weight: 400; }
.aj-ibp-compare-cell-best { background: rgba(201,169,97,0.04); }
.aj-ibp-check { color: var(--color-bull); font-size: 16px; font-weight: 600; }
.aj-ibp-check-gold { color: var(--color-gold-bright); }
.aj-ibp-dash { color: var(--color-muted); font-size: 14px; }
.aj-ibp-val { font-family: var(--font-mono); font-size: 11px; color: var(--color-cream); letter-spacing: 0.04em; }
.aj-ibp-val-gold { color: var(--color-gold-bright); font-weight: 600; }

/* ─── Steps (How it works) ─── */
.aj-ibp-steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 12px; margin-bottom: 28px; }
.aj-ibp-step { padding: 20px 22px; display: flex; gap: 16px; align-items: flex-start; }
.aj-ibp-step-num { font-family: var(--font-display-en); font-size: 22px; font-weight: 200; color: var(--color-gold); letter-spacing: 0.04em; line-height: 1; flex-shrink: 0; opacity: 0.7; }
.aj-ibp-step-body { flex: 1; min-width: 0; }
.aj-ibp-step-title { font-family: var(--font-display-th); font-size: 14px; font-weight: 500; color: var(--color-cream); margin: 0 0 6px; letter-spacing: 0.01em; line-height: 1.3; }
.aj-ibp-step-sub { font-size: 12px; color: var(--color-cream-2); margin: 0; line-height: 1.6; }

/* ─── CTA card ─── */
.aj-ibp-cta-card { padding: 32px 36px; margin-bottom: 28px; background: linear-gradient(180deg, #2a2118 0%, #1d1812 100%); }
.aj-ibp-cta-head { text-align: center; margin-bottom: 22px; }
.aj-ibp-cta-title { font-family: var(--font-display-th); font-size: 20px; font-weight: 500; color: var(--color-gold-bright); margin: 0 0 6px; letter-spacing: 0.02em; }
.aj-ibp-cta-sub { font-size: 13px; color: var(--color-cream-2); margin: 0; line-height: 1.6; }

/* ─── FAQ ─── */
.aj-ibp-faq { display: flex; flex-direction: column; gap: 8px; margin-bottom: 28px; }
.aj-ibp-faq-item { background: var(--color-surface); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); overflow: hidden; transition: border-color var(--duration-base); }
.aj-ibp-faq-item[open] { border-color: var(--color-gold-deep); }
.aj-ibp-faq-q { display: flex; justify-content: space-between; align-items: center; padding: 16px 22px; font-family: var(--font-display-th); font-size: 14px; font-weight: 500; color: var(--color-cream); cursor: pointer; list-style: none; letter-spacing: 0.01em; gap: 16px; }
.aj-ibp-faq-q::-webkit-details-marker { display: none; }
.aj-ibp-faq-q:hover { color: var(--color-gold-bright); }
.aj-ibp-faq-icon { font-family: var(--font-display-en); font-weight: 200; font-size: 20px; color: var(--color-gold); flex-shrink: 0; transition: transform var(--duration-base); }
.aj-ibp-faq-item[open] .aj-ibp-faq-icon { transform: rotate(45deg); }
.aj-ibp-faq-a { padding: 0 22px 18px; font-size: 12px; color: var(--color-cream-2); line-height: 1.7; border-top: 1px solid var(--color-hairline); padding-top: 14px; margin: 0; }

/* ─── Login polish ─── */
.aj-login-values { list-style: none; padding: 0; margin: 0 0 26px; display: flex; flex-direction: column; gap: 6px; text-align: left; }
.aj-login-values li { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--color-cream-2); }
.aj-login-check { color: var(--color-gold); font-weight: 600; font-size: 13px; }
.aj-login-error { background: rgba(217,119,87,0.10); border: 1px solid rgba(217,119,87,0.30); color: var(--color-bear); padding: 10px 14px; border-radius: var(--border-radius-sm); font-size: 12px; line-height: 1.5; margin-bottom: 14px; text-align: left; }
.aj-login-form-row { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin: 0 0 16px; flex-wrap: wrap; }
.aj-login-remember { display: inline-flex; align-items: center; gap: 6px; font-size: 11px; color: var(--color-cream-2); cursor: pointer; user-select: none; }
.aj-login-remember input { accent-color: var(--color-gold); width: 13px; height: 13px; margin: 0; cursor: pointer; }
.aj-login-forgot-link { font-family: var(--font-mono); font-size: 11px; color: var(--color-cream-2); text-decoration: none; letter-spacing: 0.02em; }
.aj-login-forgot-link:hover { color: var(--color-gold); }
.aj-login-oauth-hint { font-family: var(--font-mono); font-size: 10px; color: var(--color-muted); text-align: center; padding: 10px 0 6px; letter-spacing: 0.04em; }

/* ════════════════════════════════════════════════════════════
   CALENDAR PAGE (template-app-calendar.php)
   ════════════════════════════════════════════════════════════ */

/* ─── Month control bar ─── */
.aj-cal-control { display: flex; justify-content: space-between; align-items: center; gap: 16px; padding: 14px 18px; background: var(--color-surface); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); margin-bottom: 18px; }
.aj-cal-nav-btn { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.10em; color: var(--color-cream-2); padding: 8px 14px; border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); text-decoration: none; transition: all var(--duration-base); background: rgba(0,0,0,0.2); }
.aj-cal-nav-btn:hover { color: var(--color-gold); border-color: var(--color-gold-deep); }
.aj-cal-month-label { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; justify-content: center; }
.aj-cal-month-name { font-family: var(--font-display-th); font-size: 22px; font-weight: 400; color: var(--color-cream); letter-spacing: 0.02em; }
.aj-cal-month-year { font-family: var(--font-display-en); font-size: 18px; font-weight: 300; color: var(--color-gold); letter-spacing: 0.06em; }
.aj-cal-today-link { font-family: var(--font-mono); font-size: 10px; color: var(--color-cream-2); text-decoration: none; padding: 3px 8px; border: 1px solid var(--color-hairline); border-radius: 999px; letter-spacing: 0.06em; transition: all var(--duration-base); }
.aj-cal-today-link:hover { color: var(--color-gold); border-color: var(--color-gold-deep); }

/* ─── Summary cards ─── */
.aj-cal-summary { display: grid; grid-template-columns: repeat(6, 1fr); gap: 12px; margin-bottom: 18px; }
@media (max-width: 1100px) { .aj-cal-summary { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 600px)  { .aj-cal-summary { grid-template-columns: repeat(2, 1fr); } }
.aj-cal-sum-sub { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.06em; color: var(--color-muted); margin-top: 4px; line-height: 1.3; }
.aj-cal-sum-val.pos { color: var(--color-bull); }
.aj-cal-sum-val.neg { color: var(--color-bear); }
.aj-cal-sum-card { padding: 16px 20px; }
.aj-cal-sum-card.is-pos { border-color: rgba(94,162,121,0.25); }
.aj-cal-sum-card.is-neg { border-color: rgba(217,119,87,0.25); }
.aj-cal-sum-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 8px; }
.aj-cal-sum-val { font-family: var(--font-display-en); font-size: 22px; font-weight: 300; color: var(--color-cream); letter-spacing: 0.02em; line-height: 1; }
.aj-cal-sum-val.pos { color: var(--color-bull); }
.aj-cal-sum-val.neg { color: var(--color-bear); }

/* ─── Grid wrapper ─── */
.aj-cal-grid-wrap { padding: 4px 4px 4px; margin-bottom: 22px; position: relative; }
.aj-cal-dow-row { display: grid; grid-template-columns: repeat(7, 1fr); padding: 14px 4px 10px; border-bottom: 1px solid var(--color-hairline); }
.aj-cal-dow { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--color-muted); text-align: center; padding: 4px 0; }
.aj-cal-dow.is-weekend { color: var(--color-cream-2); opacity: 0.6; }

.aj-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; padding: 6px; }

.aj-cal-cell { display: flex; flex-direction: column; gap: 4px; min-height: 72px; padding: 8px 10px; border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); background: rgba(0,0,0,0.15); text-decoration: none; color: var(--color-cream); transition: all var(--duration-base); position: relative; overflow: hidden; }
.aj-cal-cell:not(.aj-cal-cell-blank):not(.is-future) { cursor: default; }
a.aj-cal-cell:hover { transform: translateY(-1px); border-color: var(--color-gold-deep); box-shadow: 0 4px 12px rgba(0,0,0,0.25); }
.aj-cal-cell-blank { border: 0; background: transparent; min-height: 0; }
.aj-cal-cell.is-future { opacity: 0.32; background: transparent; }
.aj-cal-cell.is-weekend:not(.is-pos):not(.is-neg):not(.is-be) { background: rgba(0,0,0,0.25); }
.aj-cal-cell.is-empty .aj-cal-cell-num { color: var(--color-muted); }
.aj-cal-cell.is-today { border-color: var(--color-gold); box-shadow: inset 0 0 0 1px var(--color-gold-deep); }
.aj-cal-cell.is-pos { background: linear-gradient(180deg, rgba(94,162,121,0.18) 0%, rgba(94,162,121,0.06) 100%); border-color: rgba(94,162,121,0.35); }
.aj-cal-cell.is-neg { background: linear-gradient(180deg, rgba(217,119,87,0.18) 0%, rgba(217,119,87,0.06) 100%); border-color: rgba(217,119,87,0.35); }
.aj-cal-cell.is-be  { background: rgba(150,150,150,0.10); }

.aj-cal-cell-head { display: flex; justify-content: space-between; align-items: center; }
.aj-cal-cell-num { font-family: var(--font-mono); font-size: 12px; font-weight: 500; color: var(--color-cream); letter-spacing: 0.02em; }
.aj-cal-cell-today { color: var(--color-gold-bright); font-size: 8px; line-height: 1; }
.aj-cal-cell-pnl { font-family: var(--font-display-en); font-size: 14px; font-weight: 600; letter-spacing: 0.02em; line-height: 1.1; margin-top: 2px; }
.aj-cal-cell-pnl.pos { color: var(--color-bull); }
.aj-cal-cell-pnl.neg { color: var(--color-bear); }
.aj-cal-cell-pnl.be { color: var(--color-cream-2); }
.aj-cal-cell-count { font-family: var(--font-mono); font-size: 9px; color: var(--color-muted); letter-spacing: 0.08em; margin-top: auto; }
.aj-cal-cell-meta { display: flex; align-items: baseline; justify-content: space-between; gap: 4px; margin-top: auto; font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.06em; line-height: 1.2; }
.aj-cal-cell-meta .aj-cal-cell-count { margin-top: 0; }
.aj-cal-cell-wl { display: inline-flex; align-items: baseline; gap: 2px; opacity: 0.95; }
.aj-cal-cell-wl .wl-w { color: var(--color-bull); font-weight: 600; }
.aj-cal-cell-wl .wl-l { color: var(--color-bear); font-weight: 600; }
.aj-cal-cell-wl .wl-sep { color: var(--color-muted); }
.aj-cal-cell-streak { font-size: 10px; line-height: 1; margin-left: auto; opacity: 0.85; }
.aj-cal-cell.is-streak-win  { box-shadow: inset 0 0 0 1.5px rgba(60,156,109,0.45); }
.aj-cal-cell.is-streak-loss { box-shadow: inset 0 0 0 1.5px rgba(217,119,87,0.45); }
.aj-cal-cell.is-streak-win:hover  { box-shadow: inset 0 0 0 1.5px rgba(60,156,109,0.65), 0 0 14px rgba(60,156,109,0.20); }
.aj-cal-cell.is-streak-loss:hover { box-shadow: inset 0 0 0 1.5px rgba(217,119,87,0.65), 0 0 14px rgba(217,119,87,0.20); }

/* ════════════════════════════════════════════════════════════
   v1.29 · Calendar month picker
   ════════════════════════════════════════════════════════════ */

.aj-cal-month-label { position: relative; }
.aj-cal-picker-btn { display: inline-flex; align-items: center; gap: 8px; padding: 8px 16px; background: rgba(201,169,97,0.04); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); cursor: pointer; transition: all var(--duration-base); font-family: inherit; color: var(--color-cream); }
.aj-cal-picker-btn:hover { background: rgba(201,169,97,0.10); border-color: var(--color-gold-bright); }
.aj-cal-picker-btn .aj-cal-month-name { font-family: var(--font-display-th); font-size: 22px; font-weight: 500; color: var(--color-cream); }
.aj-cal-picker-btn .aj-cal-month-year { font-family: var(--font-display-en); font-size: 18px; font-weight: 400; color: var(--color-gold-bright); margin-left: 4px; }
.aj-cal-picker-caret { font-size: 12px; color: var(--color-gold-bright); margin-left: 4px; opacity: 0.7; transition: transform var(--duration-base); }
.aj-cal-picker-btn[aria-expanded="true"] .aj-cal-picker-caret { transform: rotate(180deg); }

.aj-cal-picker { position: absolute; top: calc(100% + 8px); left: 50%; transform: translateX(-50%) translateY(-6px); width: 320px; max-width: 90vw; padding: 16px; background: #1a1410; border: 1px solid var(--color-gold-deep); border-radius: var(--border-radius); box-shadow: 0 20px 40px rgba(0,0,0,0.50), 0 0 30px rgba(201,169,97,0.08); z-index: 100; opacity: 0; pointer-events: none; transition: opacity var(--duration-base), transform var(--duration-base); }
.aj-cal-picker.is-open { opacity: 1; pointer-events: auto; transform: translateX(-50%) translateY(0); }

.aj-cal-picker-yr { display: flex; align-items: center; justify-content: space-between; padding: 4px 4px 12px; border-bottom: 1px solid var(--color-hairline); margin-bottom: 12px; }
.aj-cal-pyr-nav { width: 32px; height: 32px; background: rgba(255,255,255,0.04); border: 1px solid var(--color-hairline); border-radius: 6px; color: var(--color-cream-2); cursor: pointer; font-size: 14px; transition: all var(--duration-base); }
.aj-cal-pyr-nav:hover { background: rgba(201,169,97,0.10); border-color: var(--color-gold-bright); color: var(--color-gold-bright); }
.aj-cal-pyr-label { font-family: var(--font-display-en); font-size: 18px; font-weight: 500; color: var(--color-gold-bright); letter-spacing: 0.04em; }

.aj-cal-picker-mons { display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px; }
.aj-cal-pmon { padding: 10px 8px; background: rgba(255,255,255,0.03); border: 1px solid var(--color-hairline); border-radius: 6px; color: var(--color-cream-2); font-family: inherit; font-size: 12px; cursor: pointer; transition: all var(--duration-base); }
.aj-cal-pmon:hover { background: rgba(201,169,97,0.10); border-color: var(--color-gold-bright); color: var(--color-gold-bright); }
.aj-cal-pmon.is-today { border-color: rgba(60,156,109,0.50); color: #6dd49b; }
.aj-cal-pmon.is-active { background: var(--color-gold-bright); border-color: var(--color-gold-bright); color: #1a1410; font-weight: 600; }
.aj-cal-pmon.is-active.is-today { background: #6dd49b; border-color: #6dd49b; color: #0a1a12; }

/* ════════════════════════════════════════════════════════════
   v1.30 · Analytics · Period chips + Equity curve + Expectancy + Time of Day
   ════════════════════════════════════════════════════════════ */

/* Period chips · `<a>` variant for page-reload navigation (different from History's button-based chips) */
.aj-ana-period-chips { margin-top: 0; }
.aj-ana-period-chips .aj-period-chip { text-decoration: none; display: inline-block; }
.aj-period-info { margin-left: auto; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-muted); padding-left: 8px; }

/* Equity curve card */
.aj-eq-card { padding: 24px 26px; margin-bottom: 24px; }
.aj-eq-header { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-bottom: 18px; padding-bottom: 14px; border-bottom: 1px solid var(--color-hairline); }
.aj-eq-final { display: flex; align-items: baseline; gap: 10px; }
.aj-eq-final-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-muted); }
.aj-eq-final-val { font-family: var(--font-display-en); font-size: 28px; font-weight: 500; letter-spacing: 0.02em; }
.aj-eq-final-val.aj-stat-pos { color: var(--color-bull); }
.aj-eq-final-val.aj-stat-neg { color: var(--color-bear); }
.aj-eq-extremes { display: flex; gap: 18px; flex-wrap: wrap; }
.aj-eq-ext { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; color: var(--color-muted); display: inline-flex; align-items: center; gap: 4px; }
.aj-eq-ext strong { color: var(--color-cream); font-weight: 600; font-size: 12px; letter-spacing: 0.04em; margin-left: 2px; }
.aj-eq-peak strong { color: #6dd49b; }
.aj-eq-trough strong { color: #d97757; }

.aj-eq-chart { position: relative; width: 100%; height: 240px; margin: 8px 0; }
.aj-eq-svg { width: 100%; height: 100%; display: block; }

.aj-eq-axis { display: flex; justify-content: space-between; padding-top: 10px; margin-top: 6px; border-top: 1px dashed rgba(255,255,255,0.08); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; color: var(--color-muted); }
.aj-eq-axis-mid { color: var(--color-gold-bright); }

/* Expectancy grid · 6 cards */
.aj-expect-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 12px; margin-bottom: 24px; }
.aj-expect-card { padding: 16px 18px; min-width: 0; position: relative; }
.aj-expect-hero { background: linear-gradient(135deg, rgba(201,169,97,0.08) 0%, rgba(201,169,97,0.02) 100%); border-color: rgba(201,169,97,0.30); }
.aj-expect-label { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 8px; line-height: 1.3; }
.aj-expect-val { font-family: var(--font-display-en); font-size: 22px; font-weight: 500; letter-spacing: 0.01em; line-height: 1.1; word-break: break-word; }
.aj-expect-hero .aj-expect-val { font-size: 26px; }
.aj-expect-sub { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.06em; color: var(--color-muted); margin-top: 6px; line-height: 1.4; }

@media (max-width: 1200px) { .aj-expect-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 700px)  { .aj-expect-grid { grid-template-columns: repeat(2, 1fr); } }

/* Time of Day heatmap · 24 cells in 6×4 grid */
.aj-tod-card { padding: 22px 24px; margin-bottom: 24px; }
.aj-tod-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 6px; }
.aj-tod-cell { padding: 12px 8px; border: 1px solid var(--color-hairline); border-radius: 6px; text-align: center; min-height: 78px; display: flex; flex-direction: column; justify-content: center; gap: 4px; transition: transform var(--duration-base), border-color var(--duration-base); }
.aj-tod-cell:hover { border-color: var(--color-gold-bright); transform: translateY(-2px); }
.aj-tod-cell.is-empty { opacity: 0.45; }
.aj-tod-cell.is-empty:hover { transform: none; border-color: var(--color-hairline); }
.aj-tod-hour { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.06em; color: var(--color-cream-2); font-weight: 500; }
.aj-tod-pnl { font-family: var(--font-display-en); font-size: 13px; font-weight: 600; line-height: 1.1; }
.aj-tod-pnl.pos { color: var(--color-bull); }
.aj-tod-pnl.neg { color: var(--color-bear); }
.aj-tod-pnl.is-muted { color: var(--color-muted); font-weight: 400; }
.aj-tod-meta { font-family: var(--font-mono); font-size: 9px; color: var(--color-muted); letter-spacing: 0.04em; }
.aj-tod-insight { margin-top: 16px; }

@media (max-width: 900px) { .aj-tod-grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 600px) { .aj-tod-grid { grid-template-columns: repeat(3, 1fr); } .aj-tod-cell { min-height: 64px; padding: 8px 4px; } }

/* ════════════════════════════════════════════════════════════
   v1.31 · GOLD Membership page · Benefits + Final CTA + Gold hero
   ════════════════════════════════════════════════════════════ */

/* Benefits showcase · 4 cards · emotional pre-comparison */
.aj-ibp-benefits { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-bottom: 28px; }
.aj-ibp-benefit-card { padding: 22px 22px 24px; position: relative; display: flex; flex-direction: column; gap: 10px; transition: transform var(--duration-base), border-color var(--duration-base); }
.aj-ibp-benefit-card:hover { transform: translateY(-3px); }
.aj-ibp-benefit-highlight { background: linear-gradient(135deg, rgba(201,169,97,0.10) 0%, rgba(201,169,97,0.02) 100%); border-color: rgba(201,169,97,0.40); }
.aj-ibp-benefit-icon { width: 48px; height: 48px; display: flex; align-items: center; justify-content: center; background: rgba(201,169,97,0.08); border: 1px solid rgba(201,169,97,0.30); border-radius: 12px; margin-bottom: 6px; }
.aj-ibp-benefit-title { font-family: var(--font-display-th); font-size: 17px; font-weight: 500; color: var(--color-cream); letter-spacing: 0.01em; line-height: 1.3; }
.aj-ibp-benefit-sub { font-size: 12.5px; color: var(--color-cream-2); line-height: 1.6; flex: 1; }
.aj-ibp-benefit-badge { display: inline-block; align-self: flex-start; padding: 3px 10px; background: rgba(201,169,97,0.10); border: 1px solid rgba(201,169,97,0.30); border-radius: 999px; font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.10em; text-transform: uppercase; color: var(--color-gold-bright); margin-top: 4px; }
.aj-ibp-benefit-badge-hot { background: rgba(60,156,109,0.10); border-color: rgba(60,156,109,0.40); color: #6dd49b; }

@media (max-width: 1200px) { .aj-ibp-benefits { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .aj-ibp-benefits { grid-template-columns: 1fr; } }

/* GOLD hero celebration · for GOLD users */
.aj-ibp-hero-gold { background: linear-gradient(135deg, rgba(201,169,97,0.10) 0%, rgba(201,169,97,0.02) 100%); border-color: rgba(201,169,97,0.45); padding: 32px 36px; }
.aj-ibp-gold-celebrate { display: grid; grid-template-columns: 90px 1fr 300px; align-items: center; gap: 28px; }
.aj-ibp-gold-crown { font-size: 72px; line-height: 1; color: var(--color-gold-bright); text-shadow: 0 0 30px rgba(201,169,97,0.40); text-align: center; }
.aj-ibp-gold-greeting { min-width: 0; }
.aj-ibp-gold-eyebrow { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-gold-bright); margin-bottom: 8px; }
.aj-ibp-gold-title { font-family: var(--font-display-th); font-size: 26px; font-weight: 500; color: var(--color-cream); margin: 0 0 6px; line-height: 1.2; }
.aj-ibp-gold-sub { font-size: 13.5px; color: var(--color-cream-2); margin: 0; line-height: 1.6; }
.aj-ibp-gold-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; padding-left: 24px; border-left: 1px solid rgba(201,169,97,0.30); }
.aj-ibp-gold-stat { text-align: center; padding: 8px 4px; }
.aj-ibp-gold-stat-val { font-family: var(--font-display-en); font-size: 22px; font-weight: 500; color: var(--color-gold-bright); line-height: 1; }
.aj-ibp-gold-stat-label { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.10em; text-transform: uppercase; color: var(--color-muted); margin-top: 6px; }

@media (max-width: 980px) {
	.aj-ibp-gold-celebrate { grid-template-columns: 1fr; gap: 18px; }
	.aj-ibp-gold-stats { padding-left: 0; border-left: none; padding-top: 18px; border-top: 1px solid rgba(201,169,97,0.20); }
}

/* Final CTA card · after FAQ · close the loop */
.aj-ibp-final-cta { margin-top: 32px; padding: 36px 32px; text-align: center; background: linear-gradient(135deg, rgba(201,169,97,0.08) 0%, rgba(201,169,97,0.02) 100%); border-color: rgba(201,169,97,0.40); }
.aj-ibp-final-cta-gold { background: linear-gradient(135deg, rgba(60,156,109,0.06) 0%, rgba(201,169,97,0.03) 100%); border-color: rgba(60,156,109,0.30); }
.aj-ibp-final-cta-icon { font-size: 40px; color: var(--color-gold-bright); margin-bottom: 8px; text-shadow: 0 0 20px rgba(201,169,97,0.40); }
.aj-ibp-final-cta-gold .aj-ibp-final-cta-icon { color: #6dd49b; text-shadow: 0 0 20px rgba(60,156,109,0.40); }
.aj-ibp-final-cta-title { font-family: var(--font-display-th); font-size: 24px; font-weight: 500; color: var(--color-cream); margin: 0 0 10px; line-height: 1.3; }
.aj-ibp-final-cta-sub { font-size: 14px; color: var(--color-cream-2); margin: 0 auto 24px; line-height: 1.6; max-width: 580px; }

.aj-ibp-final-cta-brokers { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; margin-bottom: 18px; }
.aj-ibp-final-cta-broker { display: inline-flex; align-items: center; gap: 10px; padding: 12px 20px; background: rgba(0,0,0,0.30); border: 1px solid var(--color-gold-deep); border-radius: var(--border-radius-sm); color: var(--color-cream); text-decoration: none; font-family: inherit; transition: all var(--duration-base); }
.aj-ibp-final-cta-broker:hover { background: rgba(201,169,97,0.10); border-color: var(--color-gold-bright); transform: translateY(-2px); }
.aj-ibp-final-cta-logo { width: 24px; height: 24px; object-fit: contain; }
.aj-ibp-final-cta-broker-name { font-size: 14px; font-weight: 500; letter-spacing: 0.02em; }
.aj-ibp-final-cta-arrow { font-size: 14px; color: var(--color-gold-bright); margin-left: 4px; }

.aj-ibp-final-cta-alt { font-size: 12px; color: var(--color-muted); margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--color-hairline); }
.aj-ibp-final-cta-alt-link { color: var(--color-gold-bright); text-decoration: none; font-weight: 500; margin-left: 6px; }
.aj-ibp-final-cta-alt-link:hover { text-decoration: underline; }

/* ════════════════════════════════════════════════════════════
   v1.32 · Over-limit account UI (FREE tier with extra accounts)
   ════════════════════════════════════════════════════════════ */

/* Banner shown above accounts grid */
.aj-overlimit-banner { display: flex; align-items: center; gap: 14px; padding: 14px 18px; margin-bottom: 16px; background: rgba(184,84,80,0.06); border: 1px solid rgba(184,84,80,0.25); border-radius: var(--border-radius-sm); }
.aj-overlimit-icon { font-size: 22px; color: #d97757; line-height: 1; }
.aj-overlimit-body { flex: 1; min-width: 0; }
.aj-overlimit-title { font-family: var(--font-display-th); font-size: 14px; font-weight: 500; color: var(--color-cream); margin-bottom: 4px; }
.aj-overlimit-sub { font-size: 12px; color: var(--color-cream-2); line-height: 1.5; }
.aj-overlimit-cta { padding: 8px 16px; background: rgba(201,169,97,0.10); border: 1px solid var(--color-gold-deep); border-radius: var(--border-radius-sm); color: var(--color-gold-bright); text-decoration: none; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; transition: all var(--duration-base); white-space: nowrap; }
.aj-overlimit-cta:hover { background: var(--color-gold-bright); color: #1a1410; }

/* Over-limit account card · faded with ribbon */
.aj-account-card.is-over-limit { opacity: 0.65; position: relative; }
.aj-account-card.is-over-limit:hover { opacity: 0.85; }
.aj-account-card.is-over-limit::after { content: ''; position: absolute; inset: 0; background: repeating-linear-gradient(45deg, transparent 0, transparent 12px, rgba(184,84,80,0.03) 12px, rgba(184,84,80,0.03) 13px); pointer-events: none; border-radius: inherit; }
.aj-over-limit-ribbon { position: absolute; top: 12px; right: -8px; padding: 4px 14px 4px 12px; background: rgba(184,84,80,0.20); border: 1px solid rgba(184,84,80,0.45); border-right: none; border-radius: 4px 0 0 4px; font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; color: #f0a085; z-index: 2; }

/* ════════════════════════════════════════════════════════════
   v1.34 · Profile page
   ════════════════════════════════════════════════════════════ */

/* Profile hero · avatar + name + meta */
.aj-profile-hero { padding: 28px 32px; }
.aj-profile-hero-grid { display: grid; grid-template-columns: 90px 1fr; gap: 24px; align-items: center; }
.aj-profile-avatar { width: 90px; height: 90px; border-radius: 50%; background: linear-gradient(135deg, var(--color-gold-bright) 0%, var(--color-gold-deep) 100%); display: flex; align-items: center; justify-content: center; font-family: var(--font-display-en); font-size: 38px; font-weight: 500; color: #1a1410; box-shadow: 0 0 30px rgba(201,169,97,0.25); }
.aj-profile-info { min-width: 0; }
.aj-profile-name-row { display: flex; align-items: center; gap: 12px; margin-bottom: 4px; flex-wrap: wrap; }
.aj-profile-name { font-family: var(--font-display-th); font-size: 28px; font-weight: 500; color: var(--color-cream); margin: 0; line-height: 1.2; }
.aj-profile-edit-btn { font-size: 11px; padding: 5px 12px; }
.aj-profile-email { font-family: var(--font-mono); font-size: 12px; color: var(--color-cream-2); margin-bottom: 10px; }
.aj-profile-meta { font-size: 12px; color: var(--color-muted); }
.aj-profile-meta strong { color: var(--color-cream-2); font-weight: 500; }

.aj-profile-edit-form { display: flex; gap: 8px; align-items: center; margin-top: 16px; flex-wrap: wrap; padding-top: 16px; border-top: 1px solid var(--color-hairline); }
.aj-profile-edit-form input { flex: 1; min-width: 200px; padding: 10px 14px; background: rgba(0,0,0,0.30); border: 1px solid var(--color-gold-deep); border-radius: var(--border-radius-sm); color: var(--color-cream); font-family: inherit; font-size: 14px; }
.aj-profile-edit-form input:focus { outline: none; border-color: var(--color-gold-bright); }

.aj-profile-form-msg { font-size: 11px; padding: 4px 10px; border-radius: 999px; }
.aj-profile-form-msg.is-ok { color: #6dd49b; background: rgba(60,156,109,0.10); border: 1px solid rgba(60,156,109,0.30); }
.aj-profile-form-msg.is-err { color: #f0a085; background: rgba(184,84,80,0.10); border: 1px solid rgba(184,84,80,0.30); }

/* Stats overview · 4 cards */
.aj-profile-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 16px; }
.aj-profile-stat { padding: 20px 18px; text-align: center; }
.aj-profile-stat-val { font-family: var(--font-display-en); font-size: 32px; font-weight: 500; color: var(--color-cream); line-height: 1; margin-bottom: 8px; }
.aj-profile-stat-val.aj-profile-stat-gold { color: var(--color-gold-bright); }
.aj-profile-stat-label { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-muted); }

.aj-profile-trade-range { display: flex; gap: 24px; padding: 12px 18px; margin-bottom: 24px; background: rgba(0,0,0,0.20); border-radius: var(--border-radius-sm); font-size: 12px; color: var(--color-cream-2); flex-wrap: wrap; }
.aj-profile-range-key { color: var(--color-muted); }
.aj-profile-trade-range strong { color: var(--color-cream); font-weight: 500; }

@media (max-width: 980px) { .aj-profile-stats { grid-template-columns: repeat(2, 1fr); } }

/* Preferences grid */
.aj-profile-prefs { padding: 24px 26px; }
.aj-profile-prefs-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px 20px; }
.aj-profile-prefs-grid .aj-field { margin: 0; }
.aj-profile-prefs-submit { grid-column: 1 / -1; display: flex; align-items: center; gap: 14px; padding-top: 12px; border-top: 1px solid var(--color-hairline); flex-wrap: wrap; }

@media (max-width: 700px) { .aj-profile-prefs-grid { grid-template-columns: 1fr; } }

/* Security · change password */
.aj-profile-security { padding: 24px 26px; }
.aj-profile-security-head { margin-bottom: 20px; padding-bottom: 16px; border-bottom: 1px solid var(--color-hairline); }
.aj-profile-security-title { font-family: var(--font-display-th); font-size: 16px; font-weight: 500; color: var(--color-cream); margin: 0 0 4px; }
.aj-profile-security-sub { font-size: 12px; color: var(--color-cream-2); margin: 0; }
.aj-profile-pw-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px 20px; }
.aj-profile-pw-grid .aj-field { margin: 0; }
.aj-profile-pw-submit { grid-column: 1 / -1; display: flex; align-items: center; gap: 14px; padding-top: 12px; border-top: 1px solid var(--color-hairline); flex-wrap: wrap; }

@media (max-width: 900px) { .aj-profile-pw-grid { grid-template-columns: 1fr; } }

/* v1.34.2 · OAuth-only user banner + set-first-password layout */
.aj-profile-oauth-banner { display: flex; align-items: flex-start; gap: 14px; padding: 14px 18px; margin-bottom: 20px; background: rgba(66,133,244,0.06); border: 1px solid rgba(66,133,244,0.25); border-radius: var(--border-radius-sm); }
.aj-profile-oauth-icon { width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: 50%; flex-shrink: 0; color: var(--color-gold-bright); font-size: 16px; }
.aj-profile-oauth-body { flex: 1; min-width: 0; }
.aj-profile-oauth-title { font-family: var(--font-display-th); font-size: 14px; font-weight: 500; color: var(--color-cream); margin-bottom: 4px; }
.aj-profile-oauth-sub { font-size: 12px; color: var(--color-cream-2); line-height: 1.6; }

.aj-profile-pw-grid-2col { grid-template-columns: repeat(2, 1fr) !important; }
@media (max-width: 700px) { .aj-profile-pw-grid-2col { grid-template-columns: 1fr !important; } }

/* v1.34.4 · Activity log section */
.aj-profile-activity { padding: 22px 26px; }
.aj-profile-activity-list { display: flex; flex-direction: column; gap: 14px; margin-bottom: 20px; }
.aj-profile-activity-item { display: flex; gap: 14px; align-items: flex-start; padding: 10px 0; border-bottom: 1px solid var(--color-hairline); }
.aj-profile-activity-item:last-child { border-bottom: 0; }
.aj-profile-activity-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--color-muted); margin-top: 6px; flex-shrink: 0; }
.aj-profile-activity-item.is-current .aj-profile-activity-dot { background: #6dd49b; box-shadow: 0 0 8px rgba(60,156,109,0.40); animation: aj-pulse 2s ease-in-out infinite; }
.aj-profile-activity-dot-gold { background: var(--color-gold-bright) !important; }
@keyframes aj-pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.5; } }
.aj-profile-activity-body { flex: 1; min-width: 0; }
.aj-profile-activity-action { font-size: 13.5px; color: var(--color-cream); font-weight: 500; margin-bottom: 3px; }
.aj-profile-activity-meta { font-family: var(--font-mono); font-size: 11px; color: var(--color-muted); }
.aj-profile-activity-tag { display: inline-block; padding: 2px 8px; background: rgba(60,156,109,0.12); border: 1px solid rgba(60,156,109,0.30); border-radius: 999px; font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.10em; color: #6dd49b; margin-left: 4px; }

.aj-profile-activity-actions { display: flex; align-items: center; gap: 14px; padding-top: 16px; border-top: 1px solid var(--color-hairline); flex-wrap: wrap; }
.aj-btn-warn { color: #f0a085; border-color: rgba(184,84,80,0.45); }
.aj-btn-warn:hover { background: rgba(184,84,80,0.10); border-color: #f0a085; }
.aj-profile-activity-hint { font-size: 11px; color: var(--color-muted); margin: 10px 0 0; line-height: 1.6; }

/* ════════════════════════════════════════════════════════════
   v1.35 · Rewards page · /journal-rewards/
   ════════════════════════════════════════════════════════════ */

/* Hero · 4 status stats */
.aj-rw-hero { padding: 26px 30px; margin-bottom: 24px; }
.aj-rw-hero-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.aj-rw-stat { padding: 6px 4px; border-left: 1px solid var(--color-hairline); padding-left: 18px; }
.aj-rw-stat:first-child { border-left: 0; padding-left: 0; }
.aj-rw-stat-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 8px; }
.aj-rw-stat-val { font-family: var(--font-display-en); font-size: 30px; font-weight: 500; color: var(--color-cream); line-height: 1; margin-bottom: 6px; }
.aj-rw-stat-credit .aj-rw-stat-val { color: var(--color-gold-bright); text-shadow: 0 0 16px rgba(201,169,97,0.30); }
.aj-rw-stat-sub { font-size: 11px; color: var(--color-cream-2); }

@media (max-width: 980px) { .aj-rw-hero-grid { grid-template-columns: repeat(2, 1fr); } .aj-rw-stat { border-left: 0; padding-left: 0; } }

/* Welcome bonus card · locked vs ready */
.aj-rw-welcome-card { display: grid; grid-template-columns: 64px 1fr auto; gap: 20px; align-items: center; padding: 22px 26px; margin-bottom: 24px; }
.aj-rw-welcome-icon { width: 64px; height: 64px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 32px; background: rgba(201,169,97,0.10); border: 1px solid rgba(201,169,97,0.30); }
.aj-rw-welcome-locked .aj-rw-welcome-icon { opacity: 0.6; }
.aj-rw-welcome-ready .aj-rw-welcome-icon { background: linear-gradient(135deg, rgba(201,169,97,0.20) 0%, rgba(201,169,97,0.05) 100%); box-shadow: 0 0 20px rgba(201,169,97,0.20); }
.aj-rw-welcome-title { font-family: var(--font-display-th); font-size: 18px; font-weight: 500; color: var(--color-cream); margin: 0 0 4px; }
.aj-rw-welcome-sub { font-size: 12.5px; color: var(--color-cream-2); margin: 0; line-height: 1.6; }

@media (max-width: 700px) { .aj-rw-welcome-card { grid-template-columns: 1fr; text-align: center; } }

/* Active quests · cards */
.aj-rw-quests { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; margin-bottom: 24px; }
.aj-rw-quest { padding: 22px 24px; position: relative; }
.aj-rw-quest-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; margin-bottom: 14px; }
.aj-rw-quest-head > div { display: flex; align-items: center; gap: 10px; min-width: 0; }
.aj-rw-quest-icon { font-size: 20px; }
.aj-rw-quest-title { font-family: var(--font-display-th); font-size: 15px; font-weight: 500; color: var(--color-cream); margin: 0; }
.aj-rw-quest-status { padding: 3px 10px; border-radius: 999px; font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.10em; text-transform: uppercase; white-space: nowrap; flex-shrink: 0; }
.aj-rw-quest-status-tracking { background: rgba(201,169,97,0.10); border: 1px solid rgba(201,169,97,0.30); color: var(--color-gold-bright); }
.aj-rw-quest-status-eligible { background: rgba(60,156,109,0.10); border: 1px solid rgba(60,156,109,0.30); color: #6dd49b; }
.aj-rw-quest-status-approved { background: rgba(60,156,109,0.15); border: 1px solid rgba(60,156,109,0.40); color: #6dd49b; }
.aj-rw-quest-status-paid { background: rgba(60,156,109,0.20); border: 1px solid #6dd49b; color: #6dd49b; }
.aj-rw-quest-status-rejected { background: rgba(184,84,80,0.10); border: 1px solid rgba(184,84,80,0.30); color: #f0a085; }
.aj-rw-quest-status-expired { background: rgba(120,120,120,0.10); border: 1px solid rgba(120,120,120,0.30); color: var(--color-muted); }

.aj-rw-quest-amount { font-family: var(--font-display-en); font-size: 28px; font-weight: 500; color: var(--color-gold-bright); line-height: 1; margin-bottom: 6px; }
.aj-rw-quest-desc { font-size: 12px; color: var(--color-cream-2); margin-bottom: 16px; line-height: 1.6; }

.aj-rw-progress-row { margin-bottom: 12px; }
.aj-rw-progress-bar { height: 8px; background: rgba(0,0,0,0.40); border: 1px solid var(--color-hairline); border-radius: 999px; overflow: hidden; margin-bottom: 6px; }
.aj-rw-progress-fill { height: 100%; background: linear-gradient(90deg, var(--color-gold-deep) 0%, var(--color-gold-bright) 100%); transition: width var(--duration-base); }
.aj-rw-progress-bar.is-complete .aj-rw-progress-fill { background: linear-gradient(90deg, #3c9c6d 0%, #6dd49b 100%); }
.aj-rw-progress-label { font-family: var(--font-mono); font-size: 11px; color: var(--color-cream-2); display: flex; justify-content: space-between; }
.aj-rw-progress-pct { color: var(--color-gold-bright); font-weight: 600; }

.aj-rw-quest-meta { font-size: 11px; color: var(--color-muted); padding-top: 10px; border-top: 1px solid var(--color-hairline); }

@media (max-width: 900px) { .aj-rw-quests { grid-template-columns: 1fr; } }

/* Referral card */
.aj-rw-referral { padding: 26px 30px; margin-bottom: 24px; }
.aj-rw-referral-promo { display: grid; grid-template-columns: 1fr auto 1fr; gap: 24px; align-items: center; margin-bottom: 8px; padding: 8px 0 22px; }
.aj-rw-referral-promo-side { text-align: center; }
.aj-rw-referral-icon-circle { width: 56px; height: 56px; margin: 0 auto 10px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 28px; background: linear-gradient(135deg, rgba(201,169,97,0.20) 0%, rgba(201,169,97,0.05) 100%); border: 1px solid var(--color-gold-deep); }
.aj-rw-referral-promo-amount { font-family: var(--font-display-en); font-size: 32px; font-weight: 500; color: var(--color-gold-bright); line-height: 1; margin-bottom: 4px; }
.aj-rw-referral-promo-label { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-cream-2); }
.aj-rw-referral-promo-plus { font-family: var(--font-display-en); font-size: 30px; color: var(--color-muted); font-weight: 300; }
.aj-rw-referral-tagline { text-align: center; font-size: 13px; color: var(--color-cream-2); margin: 0 0 24px; padding-bottom: 22px; border-bottom: 1px solid var(--color-hairline); line-height: 1.6; }

.aj-rw-link-block, .aj-rw-share-block { margin-bottom: 20px; }
.aj-rw-link-label { display: block; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 8px; }
.aj-rw-link-row { display: flex; gap: 10px; }
.aj-rw-link-input { flex: 1; padding: 12px 16px; background: rgba(0,0,0,0.40); border: 1px solid var(--color-gold-deep); border-radius: var(--border-radius-sm); color: var(--color-gold-bright); font-family: var(--font-mono); font-size: 13px; cursor: pointer; }
.aj-rw-link-input:focus { outline: none; border-color: var(--color-gold-bright); }
.aj-rw-link-code { font-family: var(--font-mono); font-size: 11px; color: var(--color-muted); margin-top: 8px; }
.aj-rw-link-code code { color: var(--color-gold-bright); padding: 2px 8px; background: rgba(201,169,97,0.08); border-radius: 4px; }

.aj-rw-share-input { width: 100%; padding: 12px 16px; background: rgba(0,0,0,0.30); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); color: var(--color-cream); font-family: inherit; font-size: 12.5px; line-height: 1.7; resize: vertical; }
.aj-rw-share-input:focus { outline: none; border-color: var(--color-gold-deep); }
.aj-rw-share-actions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; }

.aj-rw-ref-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-top: 24px; padding-top: 22px; border-top: 1px solid var(--color-hairline); }
.aj-rw-ref-stat { text-align: center; padding: 10px 6px; background: rgba(0,0,0,0.20); border-radius: var(--border-radius-sm); }
.aj-rw-ref-stat-val { font-family: var(--font-display-en); font-size: 22px; font-weight: 500; color: var(--color-cream); margin-bottom: 4px; }
.aj-rw-ref-stat-gold .aj-rw-ref-stat-val { color: var(--color-gold-bright); }
.aj-rw-ref-stat-label { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-muted); }

@media (max-width: 700px) { .aj-rw-ref-stats { grid-template-columns: repeat(2, 1fr); } }

/* History table */
.aj-rw-history-card { padding: 0; overflow: hidden; margin-bottom: 24px; }
.aj-rw-history-table { width: 100%; border-collapse: collapse; font-size: 12.5px; }
.aj-rw-history-table thead th { background: rgba(0,0,0,0.30); padding: 12px 16px; text-align: left; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.10em; text-transform: uppercase; color: var(--color-muted); border-bottom: 1px solid var(--color-gold-deep); }
.aj-rw-history-table tbody td { padding: 14px 16px; border-bottom: 1px solid var(--color-hairline); color: var(--color-cream-2); }
.aj-rw-history-table tbody tr:last-child td { border-bottom: 0; }
.aj-rw-history-table tbody tr:hover { background: rgba(255,255,255,0.02); }
.aj-rw-amt { font-family: var(--font-mono); color: var(--color-gold-bright) !important; font-weight: 600; }
.aj-rw-num { font-family: var(--font-mono); }
.aj-rw-dt { font-family: var(--font-mono); font-size: 11px; color: var(--color-muted) !important; }
.aj-rw-method { display: inline-block; padding: 2px 8px; background: rgba(201,169,97,0.08); border: 1px solid rgba(201,169,97,0.20); border-radius: 999px; font-family: var(--font-mono); font-size: 10px; color: var(--color-gold-bright); text-transform: uppercase; }

.aj-rw-status-pill { display: inline-block; padding: 3px 10px; border-radius: 999px; font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.10em; text-transform: uppercase; }
.aj-rw-status-tracking { background: rgba(201,169,97,0.10); border: 1px solid rgba(201,169,97,0.30); color: var(--color-gold-bright); }
.aj-rw-status-eligible { background: rgba(60,156,109,0.10); border: 1px solid rgba(60,156,109,0.30); color: #6dd49b; }
.aj-rw-status-approved { background: rgba(60,156,109,0.15); border: 1px solid rgba(60,156,109,0.40); color: #6dd49b; }
.aj-rw-status-paid { background: rgba(60,156,109,0.20); border: 1px solid #6dd49b; color: #6dd49b; font-weight: 600; }
.aj-rw-status-rejected { background: rgba(184,84,80,0.10); border: 1px solid rgba(184,84,80,0.30); color: #f0a085; }
.aj-rw-status-expired { background: rgba(120,120,120,0.10); border: 1px solid rgba(120,120,120,0.30); color: var(--color-muted); }

/* Terms list */
.aj-rw-terms { padding: 20px 26px; background: rgba(0,0,0,0.20); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-md); margin-bottom: 24px; }
.aj-rw-terms ul { list-style: none; padding: 0; margin: 0; }
.aj-rw-terms li { padding: 8px 0 8px 22px; border-bottom: 1px solid var(--color-hairline); font-size: 12.5px; color: var(--color-cream-2); line-height: 1.6; position: relative; }
.aj-rw-terms li:last-child { border-bottom: 0; }
.aj-rw-terms li::before { content: '✓'; position: absolute; left: 0; top: 8px; color: var(--color-gold-bright); font-weight: 600; }
.aj-rw-terms strong { color: var(--color-gold-bright); font-weight: 600; }

/* v1.35.1 · Welcome card · expanded with steps + broker buttons */
.aj-rw-welcome-card { display: block !important; }
.aj-rw-welcome-head { display: flex; gap: 18px; align-items: center; margin-bottom: 20px; }
.aj-rw-welcome-head .aj-rw-welcome-icon { flex-shrink: 0; }
.aj-rw-welcome-head .aj-rw-welcome-body { flex: 1; min-width: 0; }
.aj-rw-welcome-head .aj-rw-welcome-title { white-space: normal; word-break: normal; }

/* Mini steps · 4 horizontal */
.aj-rw-steps-mini { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin: 18px 0; }
.aj-rw-step-mini { display: flex; gap: 8px; align-items: flex-start; padding: 10px 12px; background: rgba(0,0,0,0.20); border-radius: var(--border-radius-sm); font-size: 11.5px; color: var(--color-cream-2); line-height: 1.5; min-width: 0; word-break: break-word; }
.aj-rw-step-num { display: inline-flex; align-items: center; justify-content: center; width: 22px; height: 22px; min-width: 22px; border-radius: 50%; background: rgba(201,169,97,0.15); border: 1px solid var(--color-gold-deep); color: var(--color-gold-bright); font-family: var(--font-mono); font-size: 11px; font-weight: 600; flex-shrink: 0; }

@media (max-width: 980px) { .aj-rw-steps-mini { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .aj-rw-steps-mini { grid-template-columns: 1fr; } }

/* Broker buttons in welcome card */
.aj-rw-broker-btns { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 18px; }
.aj-rw-broker-btn { display: flex; align-items: center; gap: 12px; padding: 14px 18px; background: rgba(0,0,0,0.30); border: 1px solid var(--color-gold-deep); border-radius: var(--border-radius-sm); color: var(--color-cream); text-decoration: none; flex: 1 1 200px; transition: all var(--duration-base); min-width: 0; }
.aj-rw-broker-btn:hover { background: rgba(201,169,97,0.10); border-color: var(--color-gold-bright); transform: translateY(-2px); }
.aj-rw-broker-logo { width: 32px; height: 32px; object-fit: contain; flex-shrink: 0; }
.aj-rw-broker-info { flex: 1; min-width: 0; }
.aj-rw-broker-name { font-family: var(--font-display-th); font-size: 14px; font-weight: 500; color: var(--color-cream); margin-bottom: 2px; word-break: break-word; }
.aj-rw-broker-tag { font-size: 10.5px; color: var(--color-cream-2); line-height: 1.3; word-break: break-word; }
.aj-rw-broker-arrow { font-size: 16px; color: var(--color-gold-bright); flex-shrink: 0; }
.aj-rw-broker-note { margin-top: 14px; padding: 10px 14px; background: rgba(201,169,97,0.06); border-radius: var(--border-radius-sm); font-size: 11px; color: var(--color-cream-2); border-left: 2px solid var(--color-gold-deep); word-break: break-word; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.aj-rw-broker-note code { color: var(--color-gold-bright); padding: 2px 8px; background: rgba(201,169,97,0.10); border-radius: 3px; font-family: var(--font-mono); white-space: nowrap; }

/* Membership tier card */
.aj-profile-tier-card { display: grid; grid-template-columns: 64px 1fr 32px; gap: 20px; align-items: center; padding: 22px 26px; background: var(--color-card-bg); border: 1px solid var(--color-card-border); border-radius: var(--border-radius-md); text-decoration: none; color: inherit; transition: all var(--duration-base); margin-bottom: 24px; }
.aj-profile-tier-card:hover { border-color: var(--color-gold-bright); transform: translateY(-2px); }
.aj-profile-tier-icon { width: 64px; height: 64px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 32px; background: rgba(201,169,97,0.08); border: 1px solid rgba(201,169,97,0.30); color: var(--color-gold-bright); }
.aj-profile-tier-ib_member .aj-profile-tier-icon { background: linear-gradient(135deg, rgba(201,169,97,0.20) 0%, rgba(201,169,97,0.05) 100%); border-color: var(--color-gold-bright); box-shadow: 0 0 20px rgba(201,169,97,0.20); }
.aj-profile-tier-name { font-family: var(--font-display-en); font-size: 22px; font-weight: 500; color: var(--color-gold-bright); letter-spacing: 0.04em; margin-bottom: 4px; }
.aj-profile-tier-sub { font-size: 12.5px; color: var(--color-cream-2); line-height: 1.5; }
.aj-profile-tier-arrow { font-size: 24px; color: var(--color-gold-bright); text-align: center; }

.aj-cal-picker-foot { margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--color-hairline); text-align: center; }
.aj-cal-picker-today { padding: 6px 16px; background: transparent; border: 1px solid var(--color-hairline); border-radius: 999px; color: var(--color-cream-2); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; cursor: pointer; transition: all var(--duration-base); }
.aj-cal-picker-today:hover { background: rgba(201,169,97,0.10); border-color: var(--color-gold-bright); color: var(--color-gold-bright); }

@media (max-width: 600px) {
	.aj-cal-picker { width: 280px; padding: 12px; }
	.aj-cal-picker-btn .aj-cal-month-name { font-size: 18px; }
	.aj-cal-picker-btn .aj-cal-month-year { font-size: 16px; }
}

.aj-cal-empty-overlay { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); padding: 14px 22px; background: rgba(20,17,12,0.92); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); font-size: 12px; color: var(--color-cream-2); text-align: center; max-width: 90%; pointer-events: none; line-height: 1.6; }

/* ─── Best / worst day ─── */
.aj-cal-extremes { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; margin-bottom: 22px; }
.aj-cal-ext-card { padding: 18px 22px; }
.aj-cal-ext-card.is-best  { border-color: rgba(94,162,121,0.30); background: linear-gradient(180deg, rgba(94,162,121,0.06) 0%, transparent 100%); }
.aj-cal-ext-card.is-worst { border-color: rgba(217,119,87,0.30); background: linear-gradient(180deg, rgba(217,119,87,0.06) 0%, transparent 100%); }
.aj-cal-ext-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 6px; }
.aj-cal-ext-date { font-family: var(--font-display-th); font-size: 14px; color: var(--color-cream); margin-bottom: 4px; }
.aj-cal-ext-val { font-family: var(--font-display-en); font-size: 20px; font-weight: 600; letter-spacing: 0.02em; line-height: 1; }
.aj-cal-ext-val.pos { color: var(--color-bull); }
.aj-cal-ext-val.neg { color: var(--color-bear); }
.aj-cal-ext-empty { font-family: var(--font-display-th); font-size: 13px; color: var(--color-muted); margin-bottom: 6px; line-height: 1.5; font-style: italic; }
.aj-cal-ext-zero { color: var(--color-cream-2); opacity: 0.5; }

/* Date filter banner on /journal-trades/ (from calendar links) */
.aj-date-banner { display: flex; align-items: center; gap: 12px; padding: 10px 16px; margin-bottom: 14px; background: linear-gradient(90deg, rgba(201,169,97,0.10) 0%, rgba(201,169,97,0.03) 100%); border: 1px solid var(--color-gold-deep); border-radius: var(--border-radius-sm); font-size: 12px; color: var(--color-cream); flex-wrap: wrap; }
.aj-date-banner-icon { font-size: 14px; }
.aj-date-banner-text { flex: 1; color: var(--color-cream-2); }
.aj-date-banner-text strong { color: var(--color-gold-bright); font-family: var(--font-display-en); font-weight: 600; letter-spacing: 0.02em; margin-left: 4px; }
.aj-date-banner-clear { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.10em; color: var(--color-cream-2); text-decoration: none; padding: 4px 10px; border: 1px solid var(--color-hairline); border-radius: 999px; transition: all var(--duration-base); }
.aj-date-banner-clear:hover { color: var(--color-gold); border-color: var(--color-gold-deep); }

/* ════════════════════════════════════════════════════════════
   TIER LIMIT MODAL · injected via auh_journal_render_app_shell
   ════════════════════════════════════════════════════════════ */
.aj-limit-modal-backdrop { z-index: 250; }
.aj-limit-modal { max-width: 460px; padding: 0; position: relative; }
.aj-limit-modal .aj-modal-close { position: absolute; top: 14px; right: 14px; background: transparent; border: 0; color: var(--color-muted); font-size: 18px; cursor: pointer; padding: 4px 8px; border-radius: var(--border-radius-sm); transition: color var(--duration-base); z-index: 2; }
.aj-limit-modal .aj-modal-close:hover { color: var(--color-bear); }
.aj-limit-modal-body { padding: 32px 32px 24px; text-align: center; }
.aj-limit-icon { width: 64px; height: 64px; margin: 0 auto 16px; display: flex; align-items: center; justify-content: center; background: rgba(201,169,97,0.10); border: 1px solid var(--color-gold-deep); border-radius: 50%; }
.aj-limit-title { font-family: var(--font-display-th); font-size: 20px; font-weight: 500; color: var(--color-cream); margin: 0 0 10px; letter-spacing: 0.01em; }
.aj-limit-sub { font-size: 13px; color: var(--color-cream-2); margin: 0 0 22px; line-height: 1.6; }
.aj-limit-sub strong { color: var(--color-gold-bright); font-family: var(--font-display-en); font-size: 16px; font-weight: 600; letter-spacing: 0.02em; margin: 0 2px; }
.aj-limit-current { display: inline-block; padding: 4px 12px; background: rgba(217,119,87,0.08); border: 1px solid rgba(217,119,87,0.25); border-radius: 999px; }
.aj-limit-perks { background: rgba(0,0,0,0.30); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); padding: 16px 18px; margin-bottom: 22px; text-align: left; }
.aj-limit-perks-title { font-family: var(--font-display-th); font-size: 13px; font-weight: 500; color: var(--color-gold-bright); margin-bottom: 10px; letter-spacing: 0.01em; }
.aj-limit-perks-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.aj-limit-perks-list li { font-size: 12px; color: var(--color-cream-2); line-height: 1.5; }
.aj-limit-actions { display: flex; gap: 10px; margin-bottom: 16px; }
.aj-limit-actions .aj-btn-ghost { flex: 0 0 auto; padding: 12px 20px; font-size: 11px; }
.aj-limit-actions .aj-btn-primary { flex: 1; padding: 12px 20px; font-size: 11px; text-decoration: none; display: inline-flex; align-items: center; justify-content: center; gap: 6px; }
.aj-limit-foot { font-size: 10px; color: var(--color-muted); line-height: 1.6; margin: 0; padding-top: 14px; border-top: 1px solid var(--color-hairline); }

/* ─── Proactive usage banner on Add Trade + Brokers (≥80%) ─── */
.aj-usage-banner { display: flex; align-items: center; gap: 12px; padding: 12px 18px; margin-bottom: 18px; background: rgba(217,119,87,0.08); border: 1px solid rgba(217,119,87,0.30); border-radius: var(--border-radius-sm); flex-wrap: wrap; }
.aj-usage-banner.is-warn { background: rgba(217,119,87,0.10); border-color: rgba(217,119,87,0.40); }
.aj-usage-banner.is-info { background: rgba(201,169,97,0.05); border-color: var(--color-gold-deep); }
.aj-usage-banner-icon { font-size: 16px; flex-shrink: 0; }
.aj-usage-banner-text { flex: 1; font-size: 12px; color: var(--color-cream); line-height: 1.5; min-width: 0; }
.aj-usage-banner-text strong { color: var(--color-gold-bright); font-family: var(--font-display-en); font-weight: 600; letter-spacing: 0.02em; }
.aj-usage-banner-cta { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.10em; text-transform: uppercase; color: var(--color-cream); text-decoration: none; padding: 6px 12px; border: 1px solid var(--color-gold-deep); border-radius: 999px; transition: all var(--duration-base); background: linear-gradient(180deg, #e5c478 0%, #c9a961 100%); color: var(--color-bg-base); font-weight: 600; flex-shrink: 0; }
.aj-usage-banner-cta:hover { transform: translateY(-1px); box-shadow: 0 4px 12px rgba(201,169,97,0.25); }

/* ─── "Other" broker option + custom name input ─── */
.aj-broker-option-other { border-top: 1px solid var(--color-hairline) !important; margin-top: 4px; padding-top: 10px !important; }
.aj-broker-option-other .aj-broker-opt-name { color: var(--color-cream-2); font-style: italic; }
.aj-broker-option-other:hover .aj-broker-opt-name { color: var(--color-gold-bright); }
.aj-acc-custom-broker { animation: aj-fade-in 0.2s ease-out; }
.aj-acc-custom-broker .aj-field-hint { font-size: 11px; color: var(--color-muted); margin: 6px 0 0; line-height: 1.5; }
@keyframes aj-fade-in { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: translateY(0); } }

/* Inline message in account modal · replaces alert() */
.aj-modal-msg { padding: 10px 14px; margin-top: 14px; border-radius: var(--border-radius-sm); font-size: 12px; line-height: 1.5; border: 1px solid var(--color-hairline); background: rgba(0,0,0,0.20); color: var(--color-cream-2); }
.aj-modal-msg.success { background: rgba(94,162,121,0.10); color: var(--color-bull); border-color: rgba(94,162,121,0.30); }
.aj-modal-msg.error   { background: rgba(217,119,87,0.10); color: var(--color-bear); border-color: rgba(217,119,87,0.30); }

/* ════════════════════════════════════════════════════════════
   SCREENSHOT UPLOAD · GOLD-only · Add Trade form
   ════════════════════════════════════════════════════════════ */
.aj-shots-block { background: rgba(0,0,0,0.20); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); padding: 18px 20px; margin-top: 20px; }
.aj-shots-block.is-locked { opacity: 0.65; }
.aj-shots-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; gap: 12px; flex-wrap: wrap; }
.aj-shots-title { font-family: var(--font-display-th); font-size: 13px; font-weight: 500; color: var(--color-cream); letter-spacing: 0.01em; }
.aj-shots-lock { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.10em; text-transform: uppercase; color: var(--color-bg-base); background: linear-gradient(180deg, #e5c478 0%, #c9a961 100%); padding: 6px 12px; border-radius: 999px; text-decoration: none; font-weight: 600; transition: transform var(--duration-base); }
.aj-shots-lock:hover { transform: translateY(-1px); }
.aj-shots-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 640px) { .aj-shots-grid { grid-template-columns: 1fr; } }
.aj-shot-slot { display: flex; flex-direction: column; gap: 6px; }
.aj-shot-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.10em; text-transform: uppercase; color: var(--color-muted); }
.aj-shot-drop { position: relative; background: rgba(0,0,0,0.40); border: 1px dashed var(--color-hairline); border-radius: var(--border-radius-sm); min-height: 140px; transition: all var(--duration-base); overflow: hidden; }
.aj-shot-drop:hover { border-color: var(--color-gold-deep); background: rgba(0,0,0,0.30); }
.aj-shots-block.is-locked .aj-shot-drop:hover { border-color: var(--color-hairline); background: rgba(0,0,0,0.40); cursor: not-allowed; }
.aj-shot-input { position: absolute; inset: 0; opacity: 0; cursor: pointer; z-index: 1; }
.aj-shot-input:disabled { cursor: not-allowed; }
.aj-shot-empty { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px; padding: 24px 14px; min-height: 140px; color: var(--color-muted); text-align: center; }
.aj-shot-empty svg { color: var(--color-muted); margin-bottom: 4px; }
.aj-shot-empty span { font-size: 12px; color: var(--color-cream-2); }
.aj-shot-empty small { font-size: 10px; color: var(--color-muted); }
.aj-shot-preview { position: relative; }
.aj-shot-img { display: block; width: 100%; height: auto; max-height: 280px; object-fit: contain; background: #000; }
.aj-shot-remove { position: absolute; top: 8px; right: 8px; width: 28px; height: 28px; border-radius: 50%; background: rgba(0,0,0,0.75); border: 1px solid rgba(255,255,255,0.20); color: #fff; cursor: pointer; font-size: 13px; display: flex; align-items: center; justify-content: center; transition: all var(--duration-base); z-index: 2; }
.aj-shot-remove:hover { background: var(--color-bear); border-color: var(--color-bear); }
.aj-shot-progress { display: flex; align-items: center; justify-content: center; min-height: 140px; font-family: var(--font-mono); font-size: 16px; color: var(--color-gold-bright); letter-spacing: 0.04em; }
.aj-shot-progress span::after { content: ''; display: inline-block; margin-left: 6px; animation: aj-pulse 1s ease-in-out infinite; }
@keyframes aj-pulse { 0%, 100% { opacity: 0.4; } 50% { opacity: 1; } }

/* ─── Screenshots inline in trade history ─── */
.aj-trade-shots-inline { display: flex; gap: 8px; margin-top: 6px; }
.aj-trade-shots-inline img { width: 56px; height: 40px; object-fit: cover; border-radius: 4px; border: 1px solid var(--color-hairline); cursor: pointer; transition: transform var(--duration-base), border-color var(--duration-base); }
.aj-trade-shots-inline img:hover { transform: scale(1.06); border-color: var(--color-gold); }

/* ─── Lightbox ─── */
.aj-lightbox { position: fixed; inset: 0; background: rgba(0,0,0,0.92); display: none; align-items: center; justify-content: center; z-index: 9999; padding: 30px; cursor: zoom-out; }
.aj-lightbox.is-open { display: flex; }
.aj-lightbox img { max-width: 100%; max-height: 100%; object-fit: contain; }
.aj-lightbox-close { position: absolute; top: 20px; right: 20px; width: 40px; height: 40px; border-radius: 50%; background: rgba(255,255,255,0.10); border: 1px solid rgba(255,255,255,0.20); color: #fff; cursor: pointer; font-size: 16px; }
.aj-lightbox-close:hover { background: rgba(255,255,255,0.20); }

/* ─── Export PDF button + modal (Analytics) ─── */
.aj-export-pdf-btn, .aj-export-pdf-lock { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.10em; text-transform: uppercase; padding: 8px 14px; border-radius: 999px; cursor: pointer; transition: all var(--duration-base); display: inline-flex; align-items: center; gap: 6px; }
.aj-export-pdf-btn { background: transparent; color: var(--color-cream); border: 1px solid var(--color-gold-deep); }
.aj-export-pdf-btn:hover { background: var(--color-gold-deep); color: var(--color-bg-base); }
.aj-export-pdf-lock { background: transparent; color: var(--color-muted); border: 1px solid var(--color-hairline); text-decoration: none; }
.aj-export-pdf-lock:hover { color: var(--color-cream); border-color: var(--color-gold-deep); }
.aj-export-modal { max-width: 500px; position: relative; }
.aj-export-modal .aj-modal-close { position: absolute; top: 14px; right: 14px; background: transparent; border: 0; color: var(--color-muted); font-size: 18px; cursor: pointer; padding: 4px 8px; border-radius: var(--border-radius-sm); transition: color var(--duration-base); z-index: 2; }
.aj-export-modal .aj-modal-close:hover { color: var(--color-bear); }

/* ════════════════════════════════════════════════════════════
   FLATPICKR · dark + gold theme override (journal pages)
   ════════════════════════════════════════════════════════════ */
.flatpickr-calendar { background: #1a1612 !important; border: 1px solid var(--color-gold-deep) !important; box-shadow: 0 8px 32px rgba(0,0,0,0.6); border-radius: var(--border-radius-sm); font-family: var(--font-display-th); }
.flatpickr-calendar::before, .flatpickr-calendar::after { border-bottom-color: var(--color-gold-deep) !important; }
.flatpickr-months { background: #14110d !important; padding: 10px 0 8px !important; border-bottom: 1px solid var(--color-gold-deep) !important; }
.flatpickr-month { background: transparent !important; color: var(--color-gold-bright) !important; }
.flatpickr-current-month { padding: 4px 0 2px !important; font-size: 15px !important; font-weight: 500 !important; display: flex; align-items: center; justify-content: center; gap: 4px; }
.flatpickr-current-month .flatpickr-monthDropdown-months { display: inline-block !important; background: transparent !important; border: 0 !important; color: var(--color-gold-bright) !important; font-family: var(--font-display-th) !important; font-size: 15px !important; font-weight: 600 !important; cursor: pointer; padding: 4px 8px !important; border-radius: 4px; transition: background var(--duration-base); appearance: none; -webkit-appearance: none; -moz-appearance: none; }
.flatpickr-current-month .flatpickr-monthDropdown-months:hover { background: rgba(201,169,97,0.15) !important; }
.flatpickr-current-month .flatpickr-monthDropdown-months option { background: #1a1612 !important; color: var(--color-cream) !important; font-weight: 400 !important; padding: 6px 10px; }
.flatpickr-current-month input.cur-year { background: transparent !important; border: 0 !important; color: var(--color-gold-bright) !important; font-family: var(--font-display-en) !important; font-size: 15px !important; font-weight: 600 !important; letter-spacing: 0.02em !important; padding: 4px 6px !important; cursor: pointer; }
.flatpickr-current-month input.cur-year:hover { background: rgba(201,169,97,0.10) !important; }
.flatpickr-prev-month, .flatpickr-next-month { color: var(--color-gold-bright) !important; fill: var(--color-gold-bright) !important; padding: 8px 12px !important; }
.flatpickr-prev-month:hover, .flatpickr-next-month:hover { color: var(--color-cream) !important; fill: var(--color-cream) !important; background: rgba(201,169,97,0.10) !important; border-radius: 4px; }
.flatpickr-prev-month svg, .flatpickr-next-month svg { fill: currentColor !important; }
.flatpickr-weekdays { background: transparent; padding: 4px 0; }
span.flatpickr-weekday { background: transparent !important; color: var(--color-muted) !important; font-family: var(--font-mono) !important; font-size: 10px !important; letter-spacing: 0.06em !important; text-transform: uppercase; font-weight: 500; }
.flatpickr-days { padding: 2px 4px; }
.flatpickr-day { color: var(--color-cream) !important; border-radius: 4px !important; border: 1px solid transparent !important; font-weight: 400; }
.flatpickr-day:hover, .flatpickr-day:focus { background: rgba(201,169,97,0.15) !important; border-color: var(--color-gold-deep) !important; color: var(--color-cream) !important; }
.flatpickr-day.today { border-color: var(--color-gold-deep) !important; color: var(--color-gold-bright) !important; font-weight: 600; }
.flatpickr-day.today:hover { background: var(--color-gold-deep) !important; color: var(--color-bg-base) !important; }
.flatpickr-day.selected, .flatpickr-day.selected:hover, .flatpickr-day.startRange, .flatpickr-day.endRange { background: linear-gradient(180deg, #e5c478 0%, #c9a961 100%) !important; border-color: var(--color-gold-deep) !important; color: var(--color-bg-base) !important; font-weight: 600 !important; }
.flatpickr-day.prevMonthDay, .flatpickr-day.nextMonthDay { color: var(--color-muted) !important; opacity: 0.45; }
.flatpickr-day.flatpickr-disabled { color: var(--color-muted) !important; opacity: 0.30; }
.flatpickr-time { border-top: 1px solid var(--color-gold-deep) !important; background: #14110d !important; height: 44px !important; }
.flatpickr-time .numInputWrapper, .flatpickr-time .flatpickr-time-separator, .flatpickr-time input { color: var(--color-gold-bright) !important; background: transparent !important; font-family: var(--font-display-en) !important; font-size: 16px !important; font-weight: 600 !important; }
.flatpickr-time input:hover, .flatpickr-time input:focus { background: rgba(201,169,97,0.10) !important; }
.flatpickr-time .flatpickr-time-separator { color: var(--color-gold-bright) !important; font-weight: 600; }
.flatpickr-time .numInputWrapper:hover { background: rgba(201,169,97,0.05) !important; }
.numInputWrapper span { border-color: var(--color-hairline) !important; }
.numInputWrapper span:hover { background: rgba(201,169,97,0.20) !important; }
.numInputWrapper span.arrowUp::after { border-bottom-color: var(--color-cream) !important; }
.numInputWrapper span.arrowDown::after { border-top-color: var(--color-cream) !important; }
.flatpickr-input { cursor: pointer; }

/* ════════════════════════════════════════════════════════════
   DASHBOARD · interactive filters + Best/Worst/Streak/Today
   ════════════════════════════════════════════════════════════ */
.aj-dash-filters { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; padding: 14px 18px; background: rgba(0,0,0,0.18); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); margin: 0 0 22px; }
.aj-chip-row { display: inline-flex; gap: 6px; }
.aj-pill-clickable { background: transparent; border: 1px solid var(--color-hairline); color: var(--color-cream-2); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.10em; text-transform: uppercase; padding: 6px 12px; border-radius: 999px; cursor: pointer; transition: all var(--duration-base); }
.aj-pill-clickable:hover { color: var(--color-cream); border-color: var(--color-gold-deep); }
.aj-pill-clickable.aj-pill-active { background: var(--color-gold-deep); color: var(--color-bg-base); border-color: var(--color-gold-deep); font-weight: 600; }
.aj-pill-select { background: transparent; border: 1px solid var(--color-hairline); color: var(--color-cream); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; padding: 6px 28px 6px 12px; border-radius: 999px; cursor: pointer; appearance: none; -webkit-appearance: none; background-image: linear-gradient(45deg, transparent 50%, var(--color-cream-2) 50%), linear-gradient(135deg, var(--color-cream-2) 50%, transparent 50%); background-position: calc(100% - 14px) 50%, calc(100% - 9px) 50%; background-size: 5px 5px, 5px 5px; background-repeat: no-repeat; }
.aj-pill-select:hover { border-color: var(--color-gold-deep); }
.aj-pill-select option { background: #1a1612; color: var(--color-cream); }
.aj-pill-streak { font-family: var(--font-display-th); font-size: 12px; padding: 4px 10px; border-radius: 999px; }
.aj-streak-win  { background: rgba(60,156,109,0.15); color: #6dd49b; border: 1px solid rgba(60,156,109,0.30); }
.aj-streak-loss { background: rgba(217,119,87,0.15); color: #e8a386; border: 1px solid rgba(217,119,87,0.30); }

/* Today P&L badge */
.aj-today-pnl { display: inline-flex; align-items: center; gap: 8px; padding: 6px 14px; border-radius: 999px; border: 1px solid var(--color-hairline); background: rgba(0,0,0,0.18); font-family: var(--font-mono); font-size: 11px; }
.aj-today-pnl-label { color: var(--color-muted); letter-spacing: 0.10em; text-transform: uppercase; font-size: 9px; }
.aj-today-pnl-val { font-weight: 600; letter-spacing: 0.02em; }
.aj-today-pos { border-color: rgba(60,156,109,0.40); }
.aj-today-pos .aj-today-pnl-val { color: #6dd49b; }
.aj-today-neg { border-color: rgba(217,119,87,0.40); }
.aj-today-neg .aj-today-pnl-val { color: #e8a386; }

/* Best / Worst trade cards */
.aj-extremes-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin: 0 0 26px; }
@media (max-width: 640px) { .aj-extremes-row { grid-template-columns: 1fr; } }
.aj-extreme-card { display: flex; align-items: center; gap: 16px; padding: 18px 22px; background: rgba(0,0,0,0.20); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); position: relative; }
.aj-extreme-best  { border-left: 3px solid #3c9c6d; }
.aj-extreme-worst { border-left: 3px solid var(--color-bear); }
.aj-extreme-icon { font-size: 28px; width: 48px; height: 48px; display: flex; align-items: center; justify-content: center; background: rgba(0,0,0,0.30); border-radius: 50%; border: 1px solid var(--color-hairline); }
.aj-extreme-body { flex: 1; min-width: 0; }
.aj-extreme-label { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 4px; }
.aj-extreme-val { font-family: var(--font-display-en); font-size: 22px; font-weight: 500; letter-spacing: 0.01em; line-height: 1; margin-bottom: 4px; }
.aj-extreme-val.pos { color: #6dd49b; }
.aj-extreme-val.neg { color: #e8a386; }
.aj-extreme-meta { font-size: 11px; color: var(--color-cream-2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ─── Coach Layer · behavioral insights ─── */
.aj-coach-section { margin: 0 0 26px; }
.aj-coach-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 12px; padding: 0 4px; }
.aj-coach-title { font-family: var(--font-display-th); font-size: 14px; font-weight: 500; color: var(--color-cream); margin: 0; display: inline-flex; align-items: center; gap: 6px; letter-spacing: 0.01em; }
.aj-coach-glyph { font-size: 16px; }
.aj-coach-count { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.10em; text-transform: uppercase; color: var(--color-muted); }
.aj-coach-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(360px, 1fr)); gap: 12px; }
.aj-coach-card { display: flex; gap: 14px; align-items: flex-start; padding: 14px 18px; background: rgba(0,0,0,0.22); border: 1px solid var(--color-hairline); border-left-width: 3px; border-radius: var(--border-radius-sm); transition: background var(--duration-base); }
.aj-coach-card:hover { background: rgba(0,0,0,0.30); }
.aj-coach-critical { border-left-color: var(--color-bear); }
.aj-coach-warning  { border-left-color: #d4a23e; }
.aj-coach-insight  { border-left-color: var(--color-bull); }
.aj-coach-icon { font-size: 22px; line-height: 1; width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; background: rgba(0,0,0,0.30); border-radius: 50%; border: 1px solid var(--color-hairline); }
.aj-coach-critical .aj-coach-icon { border-color: rgba(217,119,87,0.30); }
.aj-coach-warning  .aj-coach-icon { border-color: rgba(212,162,62,0.30); }
.aj-coach-insight  .aj-coach-icon { border-color: rgba(60,156,109,0.30); }
.aj-coach-body { flex: 1; min-width: 0; }
.aj-coach-card-title { font-family: var(--font-display-th); font-size: 13px; font-weight: 500; color: var(--color-cream); margin-bottom: 4px; line-height: 1.35; }
.aj-coach-msg { font-size: 11px; color: var(--color-cream-2); line-height: 1.5; }

/* ─── Top Mistakes panel ─── */
.aj-mistakes-section { margin: 0 0 26px; }
.aj-mistakes-card { padding: 20px 24px; background: rgba(0,0,0,0.20); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); position: relative; }
.aj-mistakes-list { display: flex; flex-direction: column; gap: 10px; }
.aj-mistake-row { display: grid; grid-template-columns: 200px 1fr 32px; align-items: center; gap: 14px; }
@media (max-width: 640px) { .aj-mistake-row { grid-template-columns: 140px 1fr 28px; gap: 8px; } }
.aj-mistake-name { font-family: var(--font-display-th); font-size: 12px; color: var(--color-cream); }
.aj-mistake-bar-wrap { height: 6px; background: rgba(255,255,255,0.04); border-radius: 999px; overflow: hidden; }
.aj-mistake-bar { height: 100%; background: linear-gradient(90deg, #d4a23e 0%, var(--color-bear) 100%); border-radius: 999px; transition: width 0.4s ease-out; }
.aj-mistake-count { font-family: var(--font-mono); font-size: 12px; color: var(--color-cream-2); text-align: right; font-weight: 500; }

/* ─── Recent trades second-line meta ─── */
.aj-trade-row { display: flex !important; flex-direction: column !important; gap: 4px; padding: 12px 14px; align-items: stretch !important; }
.aj-trade-row-main { display: grid; grid-template-columns: 100px 1fr 60px 60px 100px 60px; gap: 12px; align-items: center; font-size: 13px; width: 100%; box-sizing: border-box; }
@media (max-width: 768px) { .aj-trade-row-main { grid-template-columns: 1fr auto; } }
.aj-trade-meta-line { padding-left: 4px; font-size: 10px; color: var(--color-muted); display: flex; gap: 8px; flex-wrap: wrap; }
.aj-trade-meta-strat { color: var(--color-cream-2); }
.aj-trade-meta-mistake { color: var(--color-bear); opacity: 0.85; }

/* ─── Equity stat hint icon ─── */
.aj-eq-stat-hint { display: inline-block; margin-left: 4px; color: var(--color-muted); font-size: 11px; cursor: help; opacity: 0.6; transition: opacity var(--duration-base); }
.aj-eq-stat-hint:hover { opacity: 1; color: var(--color-gold-bright); }

/* ════════════════════════════════════════════════════════════
   APP FOOTER · compact · journal pages only
   ════════════════════════════════════════════════════════════ */
.site-footer-app { background: rgba(0,0,0,0.30); border-top: 1px solid var(--color-hairline); padding: 20px 0; margin-top: 40px; }
.site-footer-app .container { max-width: 1400px; margin: 0 auto; padding: 0 24px; }
.aj-app-foot-row { display: flex; align-items: center; gap: 24px; flex-wrap: wrap; padding-bottom: 14px; border-bottom: 1px solid var(--color-hairline); }
.aj-app-foot-brand { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.aj-app-foot-name { font-family: var(--font-display-en); font-size: 14px; font-weight: 500; color: var(--color-cream); }
.aj-app-foot-tag { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-muted); }
.aj-app-foot-disclaim { flex: 1; min-width: 280px; font-size: 10px; line-height: 1.5; color: var(--color-muted); }
.aj-app-foot-links { display: flex; gap: 6px; align-items: center; font-size: 10px; font-family: var(--font-mono); letter-spacing: 0.05em; text-transform: uppercase; flex-shrink: 0; }
.aj-app-foot-links a { color: var(--color-cream-2); text-decoration: none; transition: color var(--duration-base); }
.aj-app-foot-links a:hover { color: var(--color-gold-bright); }
.aj-app-foot-links span { color: var(--color-muted); }
.aj-app-foot-copy { margin-top: 12px; text-align: center; font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.10em; color: var(--color-muted); }

/* ════════════════════════════════════════════════════════════
   BROKERS PAGE · pending banner + stats + rights panels
   ════════════════════════════════════════════════════════════ */
.aj-pending-banner { display: flex; gap: 16px; align-items: flex-start; background: linear-gradient(135deg, rgba(212,162,62,0.10) 0%, rgba(212,162,62,0.04) 100%); border: 1px solid rgba(212,162,62,0.30); border-left: 3px solid #d4a23e; border-radius: var(--border-radius-sm); padding: 16px 20px; margin: 0 0 22px; }
.aj-pending-icon { font-size: 22px; line-height: 1; }
.aj-pending-body { flex: 1; }
.aj-pending-title { font-family: var(--font-display-th); font-size: 13px; font-weight: 500; color: var(--color-cream); margin-bottom: 4px; }
.aj-pending-sub { display: flex; gap: 6px; flex-wrap: wrap; margin: 4px 0 6px; }
.aj-pending-tag { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.04em; color: #e5c478; background: rgba(212,162,62,0.10); border: 1px solid rgba(212,162,62,0.25); padding: 2px 8px; border-radius: 999px; }
.aj-pending-eta { font-size: 11px; color: var(--color-cream-2); }

/* ─── Per-account stats panel ─── */
.aj-account-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; padding: 14px; margin: 14px 0 0; background: rgba(0,0,0,0.25); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); }
.aj-acc-stat { text-align: center; }
.aj-acc-stat-key { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 4px; }
.aj-acc-stat-val { font-family: var(--font-display-en); font-size: 16px; font-weight: 500; color: var(--color-cream); letter-spacing: 0.01em; }
.aj-acc-stat-val.pos { color: #6dd49b; }
.aj-acc-stat-val.neg { color: #e8a386; }
.aj-account-stats-empty { grid-template-columns: 1fr; text-align: center; padding: 18px 14px; }
.aj-acc-stat-empty { font-size: 11px; color: var(--color-muted); font-style: italic; }

/* ─── Rights / benefits panel ─── */
.aj-account-rights { margin-top: 14px; padding: 14px 16px; border-radius: var(--border-radius-sm); border: 1px solid var(--color-hairline); background: rgba(0,0,0,0.18); }
.aj-rights-gold     { border-color: rgba(201,169,97,0.30); background: linear-gradient(135deg, rgba(201,169,97,0.06) 0%, rgba(0,0,0,0.25) 100%); }
.aj-rights-pending  { border-color: rgba(212,162,62,0.30); }
.aj-rights-rejected { border-color: rgba(217,119,87,0.30); }
.aj-rights-head { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.aj-rights-glyph { font-size: 14px; }
.aj-rights-title { font-family: var(--font-display-th); font-size: 12px; font-weight: 500; color: var(--color-cream); letter-spacing: 0.01em; }
.aj-rights-gold .aj-rights-title { color: var(--color-gold-bright); }
.aj-rights-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 5px; }
.aj-rights-list li { font-size: 11px; color: var(--color-cream-2); line-height: 1.5; }
.aj-rights-gold .aj-rights-list li { color: var(--color-cream); }
.aj-rights-list-locked li { color: var(--color-muted); opacity: 0.7; }

/* ─── Rebate-only mode (user already GOLD) ─── */
.aj-rights-title-rebate { color: var(--color-gold-bright); }
.aj-rights-list-rebate li { display: flex; align-items: baseline; gap: 6px; flex-wrap: wrap; }
.aj-rights-list-rebate li small { color: var(--color-muted); font-size: 10px; font-style: italic; opacity: 0.85; }
.aj-rights-list-rebate li.aj-right-new { color: var(--color-gold-bright); font-weight: 500; }
.aj-rights-list-rebate li.aj-right-new::before { content: ''; }
.aj-rights-list-rebate li.aj-right-already { color: var(--color-cream-2); opacity: 0.75; }
.aj-rights-list-rebate li.aj-right-already small { color: #6dd49b; opacity: 0.7; }

/* ─── Rebate badge (on Personal account card) ─── */
.aj-rebate-badge { display: flex; gap: 12px; align-items: flex-start; background: linear-gradient(135deg, rgba(201,169,97,0.10) 0%, rgba(201,169,97,0.03) 100%); border: 1px solid rgba(201,169,97,0.25); border-left: 3px solid var(--color-gold-bright); border-radius: var(--border-radius-sm); padding: 10px 12px; margin: 10px 0 12px; }
.aj-rebate-badge-upsell { background: linear-gradient(135deg, rgba(60,156,109,0.08) 0%, rgba(201,169,97,0.03) 100%); border-color: rgba(60,156,109,0.20); border-left-color: #6dd49b; }
.aj-rebate-icon { font-size: 18px; line-height: 1.2; flex-shrink: 0; }
.aj-rebate-text { flex: 1; min-width: 0; }
.aj-rebate-amount { font-family: var(--font-display-en); font-size: 14px; font-weight: 500; color: var(--color-cream); letter-spacing: 0.01em; }
.aj-rebate-badge .aj-rebate-amount { color: var(--color-gold-bright); }
.aj-rebate-badge-upsell .aj-rebate-amount { color: #6dd49b; }
.aj-rebate-note { font-size: 10px; color: var(--color-muted); margin-top: 3px; line-height: 1.4; }

/* ─── Rebate comparison table (on /journal-ib/ page) ─── */
.aj-rebate-table-card { padding: 24px 28px; margin-bottom: 28px; }
.aj-rebate-table-wrap { overflow-x: auto; margin: 0 -4px; padding: 0 4px; }
.aj-rebate-table { width: 100%; border-collapse: separate; border-spacing: 0; font-size: 13px; min-width: 580px; }
.aj-rebate-table thead th { text-align: left; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.10em; text-transform: uppercase; color: var(--color-muted); font-weight: 500; padding: 0 14px 12px; border-bottom: 1px solid var(--color-hairline); }
.aj-rebate-table tbody td { padding: 14px; border-bottom: 1px solid rgba(255,255,255,0.04); color: var(--color-cream-2); vertical-align: middle; }
.aj-rebate-table tbody tr:last-child td { border-bottom: 0; }
.aj-rebate-table tbody tr:hover td { background: rgba(201,169,97,0.04); }
.aj-rebate-broker-cell { display: flex; align-items: center; gap: 10px; font-family: var(--font-display-en); font-size: 14px; color: var(--color-cream); }
.aj-rebate-logo { width: 36px; height: 36px; border-radius: 6px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-weight: 600; font-size: 14px; }
.aj-rebate-logo.aj-rebate-logo-img { overflow: hidden; background: rgba(255,255,255,0.02); }
.aj-rebate-logo.aj-rebate-logo-img img { width: 100%; height: 100%; object-fit: contain; padding: 2px; box-sizing: border-box; }
.aj-rebate-amount-cell { font-family: var(--font-display-en); font-weight: 500; color: var(--color-gold-bright); font-size: 14px; letter-spacing: 0.02em; }
.aj-rebate-types-cell { font-family: var(--font-mono); font-size: 11px; color: var(--color-cream-2); }
.aj-rebate-notes-cell { font-size: 12px; color: var(--color-muted); }
.aj-rebate-disclaimer { margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--color-hairline); font-size: 10px; line-height: 1.7; color: var(--color-muted); font-style: italic; }

/* ════════════════════════════════════════════════════════════
   /journal-rebates/ page · dedicated rebate hub
   ════════════════════════════════════════════════════════════ */

/* Shortcut card on /journal-ib/ */
.aj-rebate-shortcut { display: flex; align-items: center; gap: 16px; padding: 18px 22px; background: linear-gradient(135deg, rgba(201,169,97,0.08) 0%, rgba(201,169,97,0.02) 100%); border: 1px solid rgba(201,169,97,0.25); border-left: 3px solid var(--color-gold-bright); border-radius: var(--border-radius-sm); text-decoration: none; margin-bottom: 28px; transition: transform var(--duration-base), border-color var(--duration-base); }
.aj-rebate-shortcut:hover { transform: translateX(2px); border-left-color: #e5c478; }
.aj-rebate-shortcut-icon { font-size: 24px; flex-shrink: 0; }
.aj-rebate-shortcut-text { flex: 1; }
.aj-rebate-shortcut-title { font-family: var(--font-display-th); font-size: 14px; font-weight: 500; color: var(--color-cream); margin-bottom: 3px; }
.aj-rebate-shortcut-sub { font-size: 11px; color: var(--color-cream-2); line-height: 1.5; }
.aj-rebate-shortcut-arrow { font-family: var(--font-display-en); font-size: 18px; color: var(--color-gold-bright); flex-shrink: 0; transition: transform var(--duration-base); }
.aj-rebate-shortcut:hover .aj-rebate-shortcut-arrow { transform: translateX(4px); }

/* Status row at top of Rebates page */
.aj-rebate-status-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 14px; margin: 0 0 28px; }
.aj-rebate-status-card { padding: 16px 18px; background: rgba(0,0,0,0.25); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); }
.aj-rebate-status-key { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.10em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 8px; }
.aj-rebate-status-val { font-family: var(--font-display-en); font-size: 22px; font-weight: 500; color: var(--color-cream); letter-spacing: 0.01em; }
.aj-rebate-status-val .aj-stat-pos { color: var(--color-gold-bright); }
.aj-rebate-status-val .aj-stat-neutral { color: var(--color-cream-2); }

/* How-it-works 4-step grid */
.aj-rebate-howit-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; margin-bottom: 32px; }
.aj-rebate-howit-card { position: relative; padding: 20px; background: rgba(0,0,0,0.20); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); transition: border-color var(--duration-base); }
.aj-rebate-howit-card:hover { border-color: rgba(201,169,97,0.30); }
.aj-rebate-howit-num { position: absolute; top: 14px; right: 16px; font-family: var(--font-display-en); font-size: 32px; font-weight: 300; color: rgba(201,169,97,0.20); letter-spacing: -0.02em; }
.aj-rebate-howit-title { font-family: var(--font-display-th); font-size: 14px; font-weight: 500; color: var(--color-cream); margin: 0 32px 8px 0; line-height: 1.4; }
.aj-rebate-howit-text { font-size: 11px; color: var(--color-cream-2); line-height: 1.6; }

/* Sign up button in table CTA column */
.aj-rebate-cta-col { width: 100px; text-align: right; }
.aj-rebate-cta-cell { text-align: right; }
.aj-rebate-signup-btn { display: inline-block; padding: 6px 12px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-gold-bright); border: 1px solid rgba(201,169,97,0.30); border-radius: 999px; text-decoration: none; transition: all var(--duration-base); }
.aj-rebate-signup-btn:hover { background: rgba(201,169,97,0.10); border-color: var(--color-gold-bright); }

/* Bottom contextual CTA block */
.aj-rebate-cta-block { padding: 32px; margin: 24px 0 32px; text-align: center; background: linear-gradient(135deg, rgba(201,169,97,0.06) 0%, rgba(0,0,0,0.30) 100%); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); }
.aj-rebate-cta-title { font-family: var(--font-display-th); font-size: 18px; font-weight: 500; color: var(--color-cream); margin: 0 0 10px; }
.aj-rebate-cta-text { font-size: 13px; color: var(--color-cream-2); line-height: 1.6; max-width: 560px; margin: 0 auto 18px; }

/* FAQ details/summary */
.aj-rebate-faq { display: flex; flex-direction: column; gap: 8px; margin-bottom: 32px; }
.aj-rebate-faq-item { background: rgba(0,0,0,0.20); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); overflow: hidden; transition: border-color var(--duration-base); }
.aj-rebate-faq-item[open] { border-color: rgba(201,169,97,0.25); }
.aj-rebate-faq-item summary { padding: 14px 20px; cursor: pointer; font-family: var(--font-display-th); font-size: 13px; font-weight: 500; color: var(--color-cream); list-style: none; position: relative; padding-right: 44px; }
.aj-rebate-faq-item summary::-webkit-details-marker { display: none; }
.aj-rebate-faq-item summary::after { content: '+'; position: absolute; right: 20px; top: 50%; transform: translateY(-50%); font-size: 18px; color: var(--color-gold-bright); transition: transform var(--duration-base); }
.aj-rebate-faq-item[open] summary::after { content: '−'; }
.aj-rebate-faq-item summary:hover { background: rgba(255,255,255,0.02); }
.aj-rebate-faq-body { padding: 0 20px 16px; font-size: 12px; color: var(--color-cream-2); line-height: 1.7; }

/* ════════════════════════════════════════════════════════════
   ADD TRADE · v1.25 additions
   ════════════════════════════════════════════════════════════ */

/* Risk % stat · amber tier for 1-2% range */
.aj-preview-stat-value.aj-stat-amber { color: #d4a23e; }

/* Custom symbol input · appears when OTHER selected */
.aj-symbol-custom-input { margin-top: 8px; width: 100%; padding: 10px 12px; background: rgba(0,0,0,0.30); border: 1px solid var(--color-gold-deep); border-radius: var(--border-radius-sm); color: var(--color-cream); font-family: var(--font-mono); font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase; transition: border-color var(--duration-base); box-sizing: border-box; }
.aj-symbol-custom-input:focus { outline: none; border-color: var(--color-gold-bright); }
.aj-symbol-custom-input::placeholder { color: var(--color-muted); text-transform: none; letter-spacing: normal; }

/* R:R preset buttons under TP */
.aj-rr-presets { display: flex; align-items: center; gap: 6px; margin-top: 8px; flex-wrap: wrap; }
.aj-rr-presets-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-muted); margin-right: 4px; }
.aj-rr-preset { padding: 5px 12px; background: rgba(255,255,255,0.03); border: 1px solid var(--color-hairline); border-radius: 999px; color: var(--color-cream-2); font-family: var(--font-mono); font-size: 11px; font-weight: 500; cursor: pointer; transition: all var(--duration-base); }
.aj-rr-preset:hover { background: rgba(201,169,97,0.10); border-color: var(--color-gold-bright); color: var(--color-gold-bright); }
.aj-rr-preset:active { transform: scale(0.96); }

/* ════════════════════════════════════════════════════════════
   v1.26 · 2-column Add Trade layout (desktop wide)
   ════════════════════════════════════════════════════════════ */

.aj-add-trade-layout { display: flex; flex-direction: column; gap: 18px; margin-bottom: 24px; }
.aj-add-trade-main { display: flex; flex-direction: column; gap: 18px; min-width: 0; }
.aj-add-trade-side { display: flex; flex-direction: column; gap: 18px; min-width: 0; }

@media (min-width: 1200px) {
	.aj-add-trade-layout {
		display: grid;
		grid-template-columns: minmax(0, 1fr) 380px;
		gap: 22px;
		align-items: start;
	}
	.aj-add-trade-side {
		position: sticky;
		top: 24px;
		max-height: calc(100vh - 48px);
		overflow-y: auto;
		overflow-x: hidden;
		padding-right: 4px;
		scrollbar-width: thin;
		scrollbar-color: var(--color-gold-deep) transparent;
	}
	.aj-add-trade-side::-webkit-scrollbar { width: 6px; }
	.aj-add-trade-side::-webkit-scrollbar-track { background: transparent; }
	.aj-add-trade-side::-webkit-scrollbar-thumb { background: rgba(201,169,97,0.30); border-radius: 999px; }
}

/* ─── Sidebar card head shared style (preview + screenshots) ─── */
.aj-side-head { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; padding-bottom: 12px; border-bottom: 1px solid var(--color-hairline); }
.aj-side-glyph { font-size: 18px; line-height: 1; }
.aj-side-title { font-family: var(--font-display-th); font-size: 14px; font-weight: 500; color: var(--color-cream); margin: 0; letter-spacing: 0.01em; flex: 1; }
.aj-side-live { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.14em; color: #6dd49b; padding: 3px 8px; background: rgba(60,156,109,0.10); border: 1px solid rgba(60,156,109,0.30); border-radius: 999px; }

/* ─── Preview card · sidebar variant (compact 1-col stat layout) ─── */
.aj-preview-side { padding: 20px 22px; }
.aj-preview-side .aj-preview-summary { display: flex; align-items: center; gap: 10px; padding: 12px 14px; background: rgba(201,169,97,0.06); border: 1px solid rgba(201,169,97,0.20); border-radius: var(--border-radius-sm); margin-bottom: 14px; font-size: 13px; }
.aj-preview-side .aj-preview-symbol { font-family: var(--font-display-en); font-weight: 500; color: var(--color-cream); font-size: 14px; }
.aj-preview-side .aj-preview-stats { display: flex; flex-direction: column; grid-template-columns: none; gap: 6px; margin-bottom: 14px; }
.aj-preview-side .aj-preview-stat { display: flex; align-items: baseline; justify-content: space-between; padding: 10px 14px; background: rgba(0,0,0,0.25); border: 1px solid var(--color-hairline); border-radius: 6px; text-align: left; }
.aj-preview-side .aj-preview-stat-label { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 0; flex: 1; }
.aj-preview-side .aj-preview-stat-value { font-family: var(--font-display-en); font-size: 14px; font-weight: 500; }
.aj-preview-side .aj-preview-result { margin-top: 6px; padding: 12px 14px; }

/* Side warnings · stack neatly */
.aj-preview-side .aj-preview-warnings { margin-top: 10px; display: flex; flex-direction: column; gap: 6px; }

/* ─── Screenshots card · sidebar variant ─── */
.aj-shots-side { padding: 20px 22px; }
.aj-shots-side .aj-shots-block.is-locked { opacity: 0.6; }
.aj-shots-side .aj-shots-grid { display: flex; flex-direction: column; gap: 14px; }
.aj-shots-side .aj-shot-slot { width: 100%; }
.aj-shots-side .aj-shot-drop { min-height: 130px; }
.aj-shots-side .aj-shots-lock { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; color: var(--color-gold-bright); padding: 2px 10px; background: rgba(201,169,97,0.08); border: 1px solid rgba(201,169,97,0.30); border-radius: 999px; text-decoration: none; }
.aj-shots-side .aj-shots-lock:hover { background: rgba(201,169,97,0.15); }

/* ════════════════════════════════════════════════════════════
   v1.27 · History page · Period chips + Summary + Sortable
   ════════════════════════════════════════════════════════════ */

/* Period chips row */
.aj-period-chips { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 14px; padding: 12px 16px; background: rgba(0,0,0,0.20); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); }
.aj-period-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-muted); margin-right: 6px; }
.aj-period-chip { padding: 6px 14px; background: rgba(255,255,255,0.03); border: 1px solid var(--color-hairline); border-radius: 999px; color: var(--color-cream-2); font-family: var(--font-mono); font-size: 11px; font-weight: 500; cursor: pointer; transition: all var(--duration-base); letter-spacing: 0.04em; }
.aj-period-chip:hover { background: rgba(201,169,97,0.10); border-color: var(--color-gold-bright); color: var(--color-gold-bright); }
.aj-period-chip.is-active { background: var(--color-gold-bright); border-color: var(--color-gold-bright); color: #1a1410; font-weight: 600; }

/* Filtered summary card · 6-stat grid */
.aj-history-summary { display: grid; grid-template-columns: repeat(6, 1fr); gap: 8px; margin-bottom: 18px; padding: 16px 18px; background: rgba(201,169,97,0.04); border: 1px solid rgba(201,169,97,0.20); border-radius: var(--border-radius-sm); }
.aj-hs-stat { padding: 10px 12px; background: rgba(0,0,0,0.30); border: 1px solid var(--color-hairline); border-radius: 6px; min-width: 0; }
.aj-hs-key { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 6px; }
.aj-hs-val { font-family: var(--font-display-en); font-size: 16px; font-weight: 500; color: var(--color-cream); line-height: 1.2; word-break: break-word; }
.aj-hs-sub { font-family: var(--font-mono); font-size: 10px; color: var(--color-muted); margin-top: 2px; letter-spacing: 0.04em; }
.aj-hs-val.aj-stat-pos { color: #6dd49b; }
.aj-hs-val.aj-stat-neg { color: #d97757; }

@media (max-width: 1100px) { .aj-history-summary { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 600px)  { .aj-history-summary { grid-template-columns: repeat(2, 1fr); } }

/* Sortable column headers */
.aj-th-sortable { cursor: pointer; user-select: none; transition: color var(--duration-base); }
.aj-th-sortable:hover { color: var(--color-gold-bright); }
.aj-th-sortable.is-sorted { color: var(--color-gold-bright); }
.aj-sort-ind { font-size: 9px; margin-left: 4px; opacity: 0.8; }
.aj-rights-msg { font-size: 11px; color: var(--color-cream-2); line-height: 1.6; }
.aj-rights-msg small { color: var(--color-muted); font-size: 10px; }
.aj-rights-cta { display: inline-block; margin-top: 10px; padding: 8px 14px; background: linear-gradient(180deg, #e5c478 0%, #c9a961 100%); color: var(--color-bg-base); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.10em; text-transform: uppercase; font-weight: 600; text-decoration: none; border-radius: 999px; transition: transform var(--duration-base); }
.aj-rights-cta:hover { transform: translateY(-1px); }

/* ─── Rights actions (verify button + secondary link) ─── */
.aj-rights-actions { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-top: 12px; }
.aj-rights-info-link { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; color: var(--color-cream-2); text-decoration: none; transition: color var(--duration-base); }
.aj-rights-info-link:hover { color: var(--color-gold-bright); }

/* ─── Verify modal ─── */
.aj-verify-modal { max-width: 480px; text-align: left; position: relative; }
.aj-verify-modal .aj-modal-close { position: absolute; top: 14px; right: 14px; background: transparent; border: 0; color: var(--color-muted); font-size: 18px; cursor: pointer; padding: 4px 8px; border-radius: var(--border-radius-sm); transition: color var(--duration-base); z-index: 2; }
.aj-verify-modal .aj-modal-close:hover { color: var(--color-bear); }
.aj-ibp-submit-msg { padding: 10px 14px; border-radius: var(--border-radius-sm); font-size: 12px; line-height: 1.5; }
.aj-ibp-submit-msg.ok  { background: rgba(60,156,109,0.10); color: #6dd49b; border: 1px solid rgba(60,156,109,0.30); }
.aj-ibp-submit-msg.err { background: rgba(217,119,87,0.10); color: #e8a386; border: 1px solid rgba(217,119,87,0.30); }

/* ─── Account actions row with View Trades link ─── */
.aj-account-actions { display: flex; gap: 8px; margin-top: 14px; flex-wrap: wrap; }
.aj-acc-history-link { flex: 0 0 auto; }
.aj-account-actions .aj-edit-account, .aj-account-actions .aj-delete-account { flex: 1 1 auto; }

/* ─── Mobile (IB page + login) ─── */
@media (max-width: 720px) {
	.aj-ibp-hero { padding: 22px 20px; }
	.aj-ibp-hero-grid { grid-template-columns: 1fr; gap: 22px; }
	.aj-ibp-tier-block { border-right: 0; border-bottom: 1px solid var(--color-hairline); padding-right: 0; padding-bottom: 22px; }
	.aj-ibp-tier-name { font-size: 26px; }
	.aj-ibp-submit-form { grid-template-columns: 1fr; }
	.aj-ibp-submit-btn { width: 100%; }
	.aj-ibp-submit-card { padding: 20px 18px; }
	.aj-ibp-cta-card { padding: 22px 18px; }
	.aj-ibp-step { padding: 16px 18px; }
	.aj-ibp-faq-q { padding: 14px 18px; font-size: 13px; }
	.aj-ibp-faq-a { padding: 12px 18px 16px; }
	.aj-login-form-row { gap: 8px; }

	/* Calendar mobile */
	.aj-cal-control { flex-direction: column; gap: 10px; padding: 14px; }
	.aj-cal-month-name { font-size: 18px; }
	.aj-cal-month-year { font-size: 16px; }
	.aj-cal-summary { grid-template-columns: repeat(2, 1fr); }
	.aj-cal-sum-card { padding: 12px 14px; }
	.aj-cal-sum-val { font-size: 18px; }
	.aj-cal-dow { font-size: 9px; letter-spacing: 0.08em; }
	.aj-cal-grid { gap: 3px; padding: 4px; }
	.aj-cal-cell { min-height: 64px; padding: 5px 6px; gap: 2px; border-radius: 6px; }
	.aj-cal-cell-num { font-size: 11px; }
	.aj-cal-cell-pnl { font-size: 11px; }
	.aj-cal-cell-count { font-size: 8px; letter-spacing: 0.04em; }
	.aj-cal-extremes { grid-template-columns: 1fr; }
	.aj-cal-ext-card { padding: 14px 18px; }
}

/* ═══ Modal ═══ */
.aj-modal-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,0.7); backdrop-filter: blur(4px); z-index: 200; display: flex; align-items: center; justify-content: center; padding: 20px; overflow-y: auto; }
.aj-modal { max-width: 580px; width: 100%; padding: 0; margin: auto; }
.aj-modal-head { padding: 22px 28px 16px; border-bottom: 1px solid var(--color-hairline); display: flex; justify-content: space-between; align-items: center; }
.aj-modal-title { font-family: var(--font-display-th); font-size: 18px; font-weight: 400; color: var(--color-cream); margin: 0; letter-spacing: 0.02em; }
.aj-modal-close { background: transparent; border: 0; color: var(--color-muted); font-size: 20px; cursor: pointer; padding: 4px 8px; border-radius: var(--border-radius-sm); transition: color var(--duration-base); }
.aj-modal-close:hover { color: var(--color-bear); }
.aj-modal-body { padding: 22px 28px 28px; }
.aj-modal-actions { display: flex; gap: 10px; margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--color-hairline); }
.aj-modal-actions .aj-btn-ghost { flex: 0 0 auto; padding: 12px 22px; font-size: 12px; }
.aj-modal-actions .aj-btn-primary { flex: 1; padding: 12px 22px; font-size: 12px; }

.aj-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.aj-field-row.cols-3 { grid-template-columns: 1fr 1fr 1fr; }
.aj-req { color: var(--color-gold); }

.aj-field select,
.aj-field textarea { width: 100%; padding: 11px 14px; background: var(--color-bg-base); border: 1px solid var(--color-hairline-bright); border-radius: var(--border-radius-sm); color: var(--color-cream); font-family: var(--font-body); font-size: 14px; transition: border-color var(--duration-base); }
.aj-field select:focus,
.aj-field textarea:focus { outline: 0; border-color: var(--color-gold); }
.aj-field textarea { resize: vertical; min-height: 60px; font-family: var(--font-body); line-height: 1.5; }

/* ═══ Custom Broker Dropdown (with logos) ═══ */
.aj-native-select { position: absolute; opacity: 0; pointer-events: none; height: 0; width: 0; }
.aj-broker-select { position: relative; }
.aj-broker-select-trigger {
	display: flex; align-items: center; justify-content: space-between; gap: 10px;
	width: 100%; padding: 10px 14px;
	background: var(--color-bg-base);
	border: 1px solid var(--color-hairline-bright);
	border-radius: var(--border-radius-sm);
	color: var(--color-cream); font-family: var(--font-body); font-size: 14px;
	cursor: pointer; text-align: left;
	transition: border-color var(--duration-base);
}
.aj-broker-select-trigger:hover,
.aj-broker-select-trigger:focus { outline: 0; border-color: var(--color-gold); }
.aj-broker-select.open .aj-broker-select-trigger { border-color: var(--color-gold); border-bottom-left-radius: 0; border-bottom-right-radius: 0; }

.aj-broker-select-display { display: flex; align-items: center; gap: 10px; flex: 1; min-width: 0; }
.aj-broker-placeholder { color: var(--color-muted); }
.aj-broker-arrow { color: var(--color-muted); font-size: 12px; transition: transform var(--duration-base); }
.aj-broker-select.open .aj-broker-arrow { transform: rotate(180deg); color: var(--color-gold); }

.aj-broker-select-panel {
	position: absolute; top: 100%; left: 0; right: 0; z-index: 100;
	max-height: 280px; overflow-y: auto;
	background: var(--color-surface);
	border: 1px solid var(--color-gold); border-top: 0;
	border-radius: 0 0 var(--border-radius-sm) var(--border-radius-sm);
	box-shadow: 0 8px 24px rgba(0,0,0,0.5);
}
.aj-broker-option {
	display: flex; align-items: center; gap: 10px; width: 100%;
	padding: 11px 14px;
	background: transparent; border: 0; cursor: pointer; text-align: left;
	color: var(--color-cream); font-family: var(--font-body); font-size: 14px;
	transition: background var(--duration-fast), color var(--duration-fast);
}
.aj-broker-option:hover,
.aj-broker-option:focus { outline: 0; background: rgba(201,169,97,0.08); color: var(--color-gold-bright); }
.aj-broker-option + .aj-broker-option { border-top: 1px solid var(--color-hairline); }

.aj-broker-opt-logo { width: 26px; height: 26px; border-radius: 6px; display: flex; align-items: center; justify-content: center; font-family: var(--font-display-en); font-size: 13px; font-weight: 700; flex-shrink: 0; overflow: hidden; }
.aj-broker-opt-logo-img { background: #fff; padding: 1px; }
.aj-broker-opt-logo img { width: 100%; height: 100%; object-fit: contain; display: block; }
.aj-broker-opt-name { font-weight: 500; }

/* Display logo (shown in trigger when option selected) */
.aj-broker-display-logo { width: 22px; height: 22px; border-radius: 5px; display: inline-flex; align-items: center; justify-content: center; font-family: var(--font-display-en); font-size: 11px; font-weight: 700; flex-shrink: 0; overflow: hidden; }
.aj-broker-display-logo-img { background: #fff; padding: 1px; }
.aj-broker-display-logo img { width: 100%; height: 100%; object-fit: contain; display: block; }

/* ═══════════════════════════════════════════════════════════════
   AUHUNTER JOURNAL · ADD TRADE PAGE
   ═══════════════════════════════════════════════════════════════ */

.aj-trade-form { display: flex; flex-direction: column; gap: 18px; }
.aj-trade-card { padding: 22px 26px; }
.aj-trade-card .aj-card-head h3 { font-size: 14px; letter-spacing: 0.04em; }

/* Direction toggle · BUY / SELL */
.aj-direction-toggle { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.aj-dir-btn {
	padding: 14px 18px;
	background: var(--color-bg-base);
	border: 1px solid var(--color-hairline-bright);
	color: var(--color-cream-2);
	font-family: var(--font-mono);
	font-size: 13px; font-weight: 600; letter-spacing: 0.12em;
	border-radius: var(--border-radius-sm);
	cursor: pointer;
	transition: all var(--duration-base);
}
.aj-dir-btn:hover { border-color: var(--color-gold); }
.aj-dir-btn.aj-dir-buy.active { background: rgba(95,168,79,0.12); border-color: var(--color-bull); color: var(--color-bull); }
.aj-dir-btn.aj-dir-sell.active { background: rgba(184,84,80,0.12); border-color: var(--color-bear); color: var(--color-bear); }

/* Quick lot chips */
.aj-quick-chips { display: flex; gap: 6px; margin-top: 8px; flex-wrap: wrap; }
.aj-quick-chip {
	padding: 6px 12px;
	background: transparent;
	border: 1px solid var(--color-hairline);
	color: var(--color-muted);
	font-family: var(--font-mono); font-size: 11px;
	border-radius: 999px;
	cursor: pointer;
	transition: all var(--duration-fast);
}
.aj-quick-chip:hover { border-color: var(--color-gold); color: var(--color-gold); background: rgba(201,169,97,0.04); }

/* ═══ Preview card (live calc) ═══ */
.aj-preview-card { background: linear-gradient(180deg, #28221a 0%, #1d1812 100%); border-color: var(--color-gold-deep); }

.aj-preview-summary { display: flex; align-items: center; gap: 14px; padding-bottom: 14px; border-bottom: 1px solid var(--color-hairline); margin-bottom: 16px; flex-wrap: wrap; }
.aj-preview-symbol { font-family: var(--font-display-th); font-size: 18px; color: var(--color-cream); }
.aj-preview-dir { font-family: var(--font-mono); font-size: 12px; font-weight: 700; letter-spacing: 0.1em; padding: 4px 10px; border-radius: 999px; }
.aj-preview-dir-buy { background: rgba(95,168,79,0.12); color: var(--color-bull); }
.aj-preview-dir-sell { background: rgba(184,84,80,0.12); color: var(--color-bear); }
.aj-preview-lot { font-family: var(--font-mono); font-size: 13px; color: var(--color-muted); }
.aj-preview-lot span { color: var(--color-gold); font-weight: 600; }

.aj-preview-stats { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; margin-bottom: 16px; }
@media (max-width: 980px) { .aj-preview-stats { grid-template-columns: repeat(3, 1fr); } }
.aj-preview-stat { padding: 10px 14px; background: rgba(0,0,0,0.25); border-radius: var(--border-radius-sm); border: 1px solid var(--color-hairline); }
.aj-preview-stat-label { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 4px; }
.aj-preview-stat-value { font-family: var(--font-display-en); font-size: 18px; font-weight: 400; color: var(--color-cream); }

.aj-preview-result { display: flex; align-items: center; gap: 10px; padding: 14px 18px; background: rgba(0,0,0,0.3); border-radius: var(--border-radius-sm); border: 1px solid var(--color-hairline); margin-bottom: 12px; }
.aj-preview-result.result-win  { background: rgba(95,168,79,0.10); border-color: rgba(95,168,79,0.4); }
.aj-preview-result.result-loss { background: rgba(184,84,80,0.10); border-color: rgba(184,84,80,0.4); }
.aj-preview-result.result-be   { background: rgba(150,150,150,0.08); border-color: var(--color-hairline-bright); }
.aj-result-icon { font-size: 22px; line-height: 1; }
.aj-result-text { font-family: var(--font-mono); font-size: 13px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; }
.result-win  .aj-result-text { color: var(--color-bull); }
.result-loss .aj-result-text { color: var(--color-bear); }
.result-be   .aj-result-text { color: var(--color-cream-2); }
.result-open .aj-result-text { color: var(--color-muted); }

.aj-preview-warnings { display: flex; flex-direction: column; gap: 6px; }
.aj-warning { padding: 8px 12px; background: rgba(184,84,80,0.08); border-left: 2px solid var(--color-bear); border-radius: var(--border-radius-sm); font-size: 11px; color: var(--color-bear); line-height: 1.5; }
.aj-warning.aj-warning-yellow { background: rgba(250,204,21,0.06); border-left-color: #facc15; color: #facc15; }

/* ═══ Chips (strategy + mistakes) ═══ */
.aj-chip-group { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 4px; }
.aj-chip {
	padding: 7px 13px;
	background: transparent;
	border: 1px solid var(--color-hairline-bright);
	color: var(--color-cream-2);
	font-family: var(--font-body); font-size: 12px;
	border-radius: 999px;
	cursor: pointer;
	transition: all var(--duration-fast);
}
.aj-chip:hover { border-color: var(--color-gold); color: var(--color-gold); background: rgba(201,169,97,0.04); }
.aj-chip.active { background: linear-gradient(180deg, #e5c478 0%, #c9a961 100%); border-color: var(--color-gold-bright); color: var(--color-bg-base); font-weight: 600; }
.aj-chip-none { font-style: italic; opacity: 0.85; }
.aj-chip-none.active { background: rgba(95,168,79,0.18); border-color: var(--color-bull); color: var(--color-bull); }

/* ═══ Emotion buttons ═══ */
.aj-emo-group { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin-top: 4px; }
.aj-emo-btn {
	display: flex; flex-direction: column; align-items: center; gap: 4px;
	padding: 12px 8px;
	background: var(--color-bg-base);
	border: 1px solid var(--color-hairline-bright);
	border-radius: var(--border-radius-sm);
	cursor: pointer;
	transition: all var(--duration-fast);
}
.aj-emo-btn:hover { border-color: var(--color-gold); background: rgba(201,169,97,0.04); }
.aj-emo-btn.active { border-color: var(--color-gold); background: rgba(201,169,97,0.12); }
.aj-emo-icon { font-size: 24px; line-height: 1; }
.aj-emo-label { font-size: 11px; color: var(--color-cream-2); font-family: var(--font-body); }
.aj-emo-btn.active .aj-emo-label { color: var(--color-gold); }

/* ═══ Submit bar ═══ */
.aj-trade-submit-bar { display: flex; gap: 10px; align-items: center; padding: 16px 0; flex-wrap: wrap; }
.aj-trade-submit-bar .aj-btn-ghost { padding: 13px 22px; font-size: 12px; }
.aj-trade-submit-bar .aj-btn-primary { padding: 13px 22px; font-size: 12px; flex: 1; min-width: 200px; }
.aj-trade-submit-bar .aj-btn-primary.aj-btn-secondary { flex: 0 0 auto; background: transparent; border: 1px solid var(--color-gold); color: var(--color-gold); box-shadow: none; }
.aj-trade-submit-bar .aj-btn-primary.aj-btn-secondary:hover { background: rgba(201,169,97,0.06); }

.aj-trade-msg { padding: 14px 18px; border-radius: var(--border-radius-sm); margin-top: 12px; font-size: 13px; }
.aj-trade-msg.success { background: rgba(95,168,79,0.10); border: 1px solid var(--color-bull); color: var(--color-bull); }
.aj-trade-msg.error   { background: rgba(184,84,80,0.10); border: 1px solid var(--color-bear); color: var(--color-bear); }

/* ═══════════════════════════════════════════════════════════════
   AUHUNTER JOURNAL · TRADE HISTORY PAGE (v1.49)
   ═══════════════════════════════════════════════════════════════ */

.aj-history-filters { padding: 18px 20px; margin-bottom: 16px; }
.aj-filter-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 10px; margin-bottom: 12px; }
.aj-filter-field { display: flex; flex-direction: column; gap: 4px; }
.aj-filter-field label { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--color-muted); }
.aj-filter-field select, .aj-filter-field input[type="search"] {
	background: var(--color-bg-base); border: 1px solid var(--color-hairline-bright);
	color: var(--color-cream); padding: 8px 10px; border-radius: var(--border-radius-sm);
	font-family: var(--font-body); font-size: 12px; transition: border-color var(--duration-fast);
}
.aj-filter-field select:focus, .aj-filter-field input[type="search"]:focus { outline: none; border-color: var(--color-gold); }
.aj-filter-search { grid-column: span 2; }

.aj-filter-actions { display: flex; align-items: center; gap: 10px; padding-top: 12px; border-top: 1px solid var(--color-hairline); flex-wrap: wrap; }
.aj-filter-actions .aj-btn-ghost { padding: 7px 14px; font-size: 11px; }
.aj-filter-count { margin-left: auto; font-family: var(--font-mono); font-size: 11px; color: var(--color-muted); letter-spacing: 0.06em; }

/* Table */
.aj-history-table-card { padding: 0; overflow: hidden; }
.aj-history-table-wrap { overflow-x: auto; }
.aj-history-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.aj-history-table thead { background: rgba(0,0,0,0.25); border-bottom: 1px solid var(--color-hairline); }
.aj-history-table th {
	padding: 13px 14px; text-align: left;
	font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase;
	color: var(--color-muted); font-weight: 500; white-space: nowrap;
}
.aj-history-table .aj-th-center { text-align: center; }
.aj-history-table .aj-th-right { text-align: right; }
.aj-history-table tbody tr { border-bottom: 1px solid var(--color-hairline); transition: background var(--duration-fast); }
.aj-history-table tbody tr:hover { background: rgba(201,169,97,0.04); }
.aj-history-table tbody tr:last-child { border-bottom: none; }
.aj-history-table td {
	padding: 12px 14px;
	color: var(--color-cream-2);
	white-space: nowrap;
	vertical-align: middle;
}
.aj-tbl-date { display: flex; flex-direction: column; gap: 1px; }
.aj-tbl-date-day { font-family: var(--font-mono); font-size: 11px; color: var(--color-cream); }
.aj-tbl-date-time { font-family: var(--font-mono); font-size: 9px; color: var(--color-muted); }
.aj-tbl-account { display: flex; align-items: center; gap: 8px; }
.aj-tbl-broker-logo { width: 22px !important; height: 22px !important; flex-shrink: 0; }
.aj-tbl-broker-logo .aj-broker-logo-letter { width: 22px; height: 22px; font-size: 9px; }
.aj-tbl-broker-logo img { width: 22px; height: 22px; object-fit: contain; }
.aj-tbl-acc-text { display: flex; flex-direction: column; gap: 0; }
.aj-tbl-acc-name { font-size: 11px; color: var(--color-cream); }
.aj-tbl-acc-num { font-family: var(--font-mono); font-size: 9px; color: var(--color-muted); }
.aj-tbl-symbol { font-family: var(--font-mono); font-size: 11px; color: var(--color-cream); }
.aj-tbl-dir { text-align: center; font-family: var(--font-mono); font-size: 10px; font-weight: 700; letter-spacing: 0.08em; }
.aj-tbl-dir-buy { color: var(--color-bull); }
.aj-tbl-dir-sell { color: var(--color-bear); }
.aj-tbl-lot, .aj-tbl-rr { text-align: right; font-family: var(--font-display-en); font-size: 13px; color: var(--color-cream); }
.aj-tbl-result { text-align: center; }
.aj-tbl-result .aj-trade-badge { font-size: 9px; padding: 2px 8px; }
.aj-tbl-pnl { text-align: right; font-family: var(--font-display-en); font-size: 14px; font-weight: 500; }
.aj-tbl-pnl.pos { color: var(--color-bull); }
.aj-tbl-pnl.neg { color: var(--color-bear); }
.aj-tbl-strategy { font-size: 11px; color: var(--color-cream-2); }
.aj-tbl-actions { text-align: right; }
.aj-tbl-act-btn { background: transparent; border: 1px solid var(--color-hairline-bright); color: var(--color-cream-2); padding: 5px 8px; border-radius: var(--border-radius-sm); cursor: pointer; transition: all var(--duration-fast); margin-left: 4px; font-size: 12px; text-decoration: none; display: inline-block; }
.aj-tbl-act-btn:hover { border-color: var(--color-gold); color: var(--color-gold); }
.aj-tbl-act-btn.aj-tbl-act-del:hover { border-color: var(--color-bear); color: var(--color-bear); }
.aj-tcm-actions { display: flex; gap: 6px; }
.aj-tcm-actions .aj-tbl-act-btn { font-size: 11px; }

/* Mobile cards (alternate view) */
.aj-history-cards { display: none; padding: 12px; flex-direction: column; gap: 10px; }
.aj-trade-card-m {
	background: var(--color-bg-base); border: 1px solid var(--color-hairline);
	border-radius: var(--border-radius-sm); padding: 14px 16px;
	display: flex; flex-direction: column; gap: 10px;
}
.aj-tcm-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }
.aj-tcm-left { display: flex; flex-direction: column; gap: 2px; }
.aj-tcm-symbol { font-family: var(--font-mono); font-size: 13px; color: var(--color-cream); font-weight: 600; letter-spacing: 0.04em; }
.aj-tcm-meta { font-family: var(--font-mono); font-size: 10px; color: var(--color-muted); }
.aj-tcm-pnl { font-family: var(--font-display-en); font-size: 18px; font-weight: 500; text-align: right; }
.aj-tcm-pnl.pos { color: var(--color-bull); }
.aj-tcm-pnl.neg { color: var(--color-bear); }
.aj-tcm-row { display: flex; justify-content: space-between; align-items: center; padding-top: 8px; border-top: 1px solid var(--color-hairline); font-size: 11px; }
.aj-tcm-row-label { color: var(--color-muted); font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; }
.aj-tcm-row-val { color: var(--color-cream); }
.aj-tcm-foot { display: flex; justify-content: space-between; align-items: center; padding-top: 8px; border-top: 1px solid var(--color-hairline); }

/* Pagination */
.aj-pagination { display: flex; align-items: center; justify-content: center; gap: 16px; padding: 18px; border-top: 1px solid var(--color-hairline); }
.aj-pg-btn {
	background: transparent; border: 1px solid var(--color-hairline-bright);
	color: var(--color-cream-2); padding: 7px 14px; border-radius: var(--border-radius-sm);
	cursor: pointer; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.06em;
	transition: all var(--duration-fast);
}
.aj-pg-btn:hover:not(:disabled) { border-color: var(--color-gold); color: var(--color-gold); }
.aj-pg-btn:disabled { opacity: 0.3; cursor: not-allowed; }
.aj-pg-info { font-family: var(--font-mono); font-size: 11px; color: var(--color-muted); letter-spacing: 0.06em; }

/* Delete modal */
.aj-modal-small { max-width: 440px; }
.aj-del-warning { font-size: 13px; color: var(--color-cream); line-height: 1.6; margin-bottom: 14px; }
.aj-del-preview { background: rgba(184,84,80,0.06); border-left: 2px solid var(--color-bear); padding: 12px 14px; margin-bottom: 18px; font-size: 12px; color: var(--color-cream-2); border-radius: 0 var(--border-radius-sm) var(--border-radius-sm) 0; line-height: 1.6; }
.aj-btn-danger {
	background: var(--color-bear); color: #fff; padding: 11px 22px;
	font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
	border: 1px solid var(--color-bear); border-radius: var(--border-radius-sm); cursor: pointer;
	transition: all var(--duration-fast); font-weight: 500;
}
.aj-btn-danger:hover { background: #a94a47; border-color: #a94a47; }

/* Empty state for history */
.aj-history-table-card .aj-empty-state { padding: 60px 20px; }

/* Mobile responsive for history */
@media (max-width: 900px) {
	.aj-history-table-wrap { display: none; }
	.aj-history-cards { display: flex; }
	.aj-filter-search { grid-column: span 1; }
	.aj-filter-row { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
	.aj-filter-row { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════════
   AUHUNTER JOURNAL · ANALYTICS PAGE (v1.51)
   ═══════════════════════════════════════════════════════════════ */

.aj-ana-meta { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 14px; }
.aj-ana-sec-head { margin-top: 28px; margin-bottom: 14px; }
.aj-ana-sec-head .aj-section-title { font-size: 18px; }
.aj-section-sub { font-size: 12px; color: var(--color-cream-2); margin: 4px 0 0; line-height: 1.5; }
.aj-ana-empty { padding: 30px 20px; text-align: center; color: var(--color-muted); font-style: italic; font-size: 13px; }

/* Insight box (golden tip) */
.aj-insight-box {
	background: linear-gradient(180deg, rgba(201,169,97,0.10) 0%, rgba(201,169,97,0.04) 100%);
	border: 1px solid var(--color-gold-deep); border-left-width: 3px;
	padding: 12px 16px; margin: 12px 0 22px;
	font-size: 13px; color: var(--color-cream); line-height: 1.6; border-radius: var(--border-radius-sm);
}
.aj-insight-box strong { color: var(--color-gold); }

/* Strategy table */
.aj-ana-table-wrap { overflow-x: auto; padding: 0; }
.aj-ana-table { width: 100%; }
.aj-ana-table tbody tr:hover { background: rgba(201,169,97,0.04); }
.aj-ana-table td { font-size: 13px; padding: 14px 14px; }
.aj-ana-table .aj-tbl-pnl { font-size: 15px; }

/* Mistake cards 4-grid */
.aj-mistake-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 12px; margin-bottom: 8px; }
.aj-mistake-card {
	padding: 20px 22px;
	display: flex; flex-direction: column; gap: 8px;
	background: var(--color-surface);
	border: 1px solid var(--color-hairline);
	transition: border-color var(--duration-fast);
}
.aj-mistake-card:hover { border-color: var(--color-hairline-bright); }
.aj-mistake-card.aj-mistake-good { background: linear-gradient(180deg, rgba(95,168,79,0.06) 0%, var(--color-surface) 100%); }
.aj-mistake-card.aj-mistake-empty { opacity: 0.5; }
.aj-mistake-icon { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; border-radius: 8px; }
.aj-mistake-icon.aj-icon-good { background: rgba(95,168,79,0.12); color: var(--color-bull); }
.aj-mistake-icon.aj-icon-bad  { background: rgba(184,84,80,0.10); color: var(--color-bear); }
.aj-mistake-label { font-size: 12px; color: var(--color-cream-2); line-height: 1.3; }
.aj-mistake-value { font-family: var(--font-display-en); font-size: 30px; font-weight: 400; color: var(--color-cream); line-height: 1; letter-spacing: -0.01em; }
.aj-mistake-unit { font-size: 14px; color: var(--color-muted); margin-left: 4px; font-weight: 300; }
.aj-mistake-sub { font-size: 10px; color: var(--color-muted); font-family: var(--font-mono); letter-spacing: 0.06em; margin-top: 2px; }

/* Direction split */
.aj-dir-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 8px; }
.aj-dir-card { padding: 22px 26px; }
.aj-dir-buy { border-left: 3px solid var(--color-bull); }
.aj-dir-sell { border-left: 3px solid var(--color-bear); }
.aj-dir-header { display: flex; justify-content: space-between; align-items: baseline; padding-bottom: 14px; border-bottom: 1px solid var(--color-hairline); margin-bottom: 14px; }
.aj-dir-label { font-family: var(--font-mono); font-size: 14px; font-weight: 700; letter-spacing: 0.16em; }
.aj-dir-buy .aj-dir-label { color: var(--color-bull); }
.aj-dir-sell .aj-dir-label { color: var(--color-bear); }
.aj-dir-count { font-family: var(--font-mono); font-size: 11px; color: var(--color-muted); }
.aj-dir-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.aj-dir-stat-label { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 4px; }
.aj-dir-stat-val { font-family: var(--font-display-en); font-size: 18px; color: var(--color-cream); font-weight: 400; }

/* Emotion analysis */
.aj-emo-analysis { padding: 20px 24px; }
.aj-emo-row { display: grid; grid-template-columns: 200px 1fr 160px; gap: 14px; align-items: center; padding: 10px 0; border-bottom: 1px solid var(--color-hairline); }
.aj-emo-row:last-child { border-bottom: none; }
.aj-emo-row-left { display: flex; align-items: center; gap: 10px; }
.aj-emo-row-icon { font-size: 22px; line-height: 1; }
.aj-emo-row-label { font-size: 13px; color: var(--color-cream); flex: 1; }
.aj-emo-row-count { font-family: var(--font-mono); font-size: 10px; color: var(--color-muted); letter-spacing: 0.06em; }
.aj-emo-row-bar { width: 100%; }
.aj-emo-bar-track { height: 8px; background: rgba(255,255,255,0.04); border-radius: 4px; overflow: hidden; }
.aj-emo-bar-fill { height: 100%; transition: width var(--duration-base); }
.aj-emo-bar-pos { background: linear-gradient(90deg, #5fa84f 0%, #7ec76e 100%); }
.aj-emo-bar-neg { background: linear-gradient(90deg, #b85450 0%, #d06a66 100%); }
.aj-emo-bar-fill:not(.aj-emo-bar-pos):not(.aj-emo-bar-neg) { background: linear-gradient(90deg, #b8946a 0%, #c9a961 100%); }
.aj-emo-row-stats { display: flex; flex-direction: column; align-items: flex-end; gap: 2px; }
.aj-emo-wr { font-family: var(--font-mono); font-size: 11px; font-weight: 600; letter-spacing: 0.06em; }
.aj-emo-pnl { font-family: var(--font-display-en); font-size: 14px; font-weight: 400; }

/* Day of Week heatmap */
.aj-dow-grid { padding: 20px 24px; display: grid; grid-template-columns: repeat(7, 1fr); gap: 8px; }
.aj-dow-cell { padding: 14px 8px; border-radius: var(--border-radius-sm); text-align: center; transition: transform var(--duration-fast); border: 1px solid var(--color-hairline); }
.aj-dow-cell:hover { transform: translateY(-2px); }
.aj-dow-day { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 6px; }
.aj-dow-pnl { font-family: var(--font-display-en); font-size: 16px; color: var(--color-cream); font-weight: 400; line-height: 1.2; }
.aj-dow-pnl.pos { color: var(--color-bull); }
.aj-dow-pnl.neg { color: var(--color-bear); }
.aj-dow-meta { font-family: var(--font-mono); font-size: 9px; color: var(--color-muted); margin-top: 4px; letter-spacing: 0.06em; }

/* Monthly bars */
.aj-month-card { padding: 24px 28px; }
.aj-month-bars { display: flex; align-items: stretch; gap: 12px; height: 220px; overflow-x: auto; padding: 10px 0 14px; }
.aj-month-col { flex: 1; min-width: 80px; display: flex; flex-direction: column; align-items: center; gap: 6px; }
.aj-month-bar-wrap { flex: 1; width: 60%; max-width: 50px; position: relative; }
.aj-month-zero-line { position: absolute; left: -8px; right: -8px; top: 50%; height: 1px; background: var(--color-hairline-bright); }
.aj-month-bar { position: absolute; left: 0; right: 0; border-radius: 2px 2px 0 0; min-height: 4px; transition: height var(--duration-base); }
.aj-month-bar-pos { background: linear-gradient(180deg, #7ec76e 0%, #5fa84f 100%); }
.aj-month-bar-neg { background: linear-gradient(0deg, #d06a66 0%, #b85450 100%); border-radius: 0 0 2px 2px; }
.aj-month-bar-val { position: absolute; left: 50%; transform: translateX(-50%); font-family: var(--font-mono); font-size: 9px; color: var(--color-cream); white-space: nowrap; letter-spacing: 0.04em; }
.aj-month-bar-pos .aj-month-bar-val { top: -16px; }
.aj-month-bar-neg .aj-month-bar-val { bottom: -16px; }
.aj-month-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; color: var(--color-cream-2); text-transform: uppercase; }
.aj-month-trades { font-family: var(--font-mono); font-size: 9px; color: var(--color-muted); }

/* Mobile responsive for analytics */
@media (max-width: 900px) {
	.aj-dir-grid { grid-template-columns: 1fr; }
	.aj-dow-grid { grid-template-columns: repeat(7, 1fr); padding: 14px; gap: 4px; }
	.aj-dow-cell { padding: 10px 4px; }
	.aj-dow-pnl { font-size: 13px; }
	.aj-emo-row { grid-template-columns: 140px 1fr; gap: 10px; }
	.aj-emo-row-stats { grid-column: 1 / -1; flex-direction: row; justify-content: space-between; padding-top: 6px; border-top: 1px dashed var(--color-hairline); }
	.aj-month-card { padding: 16px; }
}
@media (max-width: 480px) {
	.aj-dow-grid { grid-template-columns: repeat(4, 1fr); }
	.aj-mistake-grid { grid-template-columns: 1fr 1fr; }
}

/* ═══ Mobile ═══ */
@media (max-width: 768px) {
	.aj-accounts-grid { grid-template-columns: 1fr; }
	.aj-section-head { flex-direction: column; align-items: flex-start; }
	.aj-section-actions { width: 100%; justify-content: space-between; }
	.aj-ib-benefit-list { grid-template-columns: 1fr; }
	.aj-ib-card { padding: 22px 20px; }
	.aj-field-row { grid-template-columns: 1fr; }
	.aj-modal-body { padding: 18px 20px 24px; }
	.aj-modal-head { padding: 18px 20px 14px; }
	.aj-modal-actions { flex-direction: column; }
	.aj-modal-actions .aj-btn-ghost,
	.aj-modal-actions .aj-btn-primary { width: 100%; }
	.aj-preview-stats { grid-template-columns: repeat(2, 1fr); }
	.aj-emo-group { grid-template-columns: repeat(4, 1fr); }
	.aj-trade-card { padding: 18px 18px; }
	.aj-trade-submit-bar { flex-direction: column; }
	.aj-trade-submit-bar .aj-btn-ghost,
	.aj-trade-submit-bar .aj-btn-primary { width: 100%; min-width: 0; }
}
@media (max-width: 420px) {
	.aj-emo-group { grid-template-columns: repeat(2, 1fr); }
	.aj-preview-summary { gap: 8px; }
	.aj-preview-symbol { font-size: 16px; }
}

/* ═══ LOT CALCULATOR PAGE · v2 (clean, points-based, risk presets) ═══ */
/* ═══════════════════════════════════════════════════
   TIER S · GOD-MODE FEATURES
   Tooltips · Risk Meter · Mini Chart · Mobile FAB
   ═══════════════════════════════════════════════════ */

/* Tooltip · info icon ⓘ with hover/tap popup */
.lot-info {
  display: inline-flex; align-items: center; justify-content: center;
  width: 14px; height: 14px;
  border-radius: 50%;
  border: 1px solid var(--color-gold-deep);
  background: transparent;
  color: var(--color-gold);
  font-size: 8px; font-weight: 600;
  cursor: help;
  position: relative;
  margin-left: 4px;
  vertical-align: middle;
  transition: all var(--duration-fast);
  font-family: var(--font-mono);
  text-transform: none;
  letter-spacing: 0;
}
.lot-info:hover { background: var(--color-gold); color: var(--color-bg-base); transform: scale(1.1); }
.lot-info::before {
  content: attr(data-tip);
  position: absolute;
  bottom: calc(100% + 10px); left: 50%;
  transform: translateX(-50%);
  width: max-content; max-width: 260px;
  padding: 10px 14px;
  background: linear-gradient(180deg, #28221a 0%, #1d1812 100%);
  border: 1px solid var(--color-gold);
  border-radius: 4px;
  font-size: 11px;
  font-family: var(--font-body);
  font-weight: 400;
  color: var(--color-cream);
  line-height: 1.55;
  white-space: normal;
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity 0.2s, visibility 0.2s, transform 0.2s;
  z-index: 100;
  letter-spacing: 0.01em;
  text-align: left;
  box-shadow: 0 8px 24px rgba(0,0,0,0.5), 0 0 0 1px rgba(201,169,97,0.15) inset;
}
.lot-info::after {
  content: ''; position: absolute;
  bottom: calc(100% + 4px); left: 50%;
  transform: translateX(-50%);
  width: 0; height: 0;
  border: 6px solid transparent;
  border-top-color: var(--color-gold);
  opacity: 0; visibility: hidden;
  transition: opacity 0.2s, visibility 0.2s;
  z-index: 100;
}
.lot-info:hover::before, .lot-info:hover::after,
.lot-info:focus::before, .lot-info:focus::after,
.lot-info.tip-open::before, .lot-info.tip-open::after {
  opacity: 1; visibility: visible;
}

/* Risk Meter · visual gauge */
.lot-risk-meter { margin: 16px 0 10px; }
.lot-risk-meter-zones {
  display: flex; justify-content: space-between;
  font-family: var(--font-mono); font-size: 8px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--color-muted);
  margin-bottom: 6px;
}
.lot-risk-meter-zones .zone.safe { color: #5fa84f; }
.lot-risk-meter-zones .zone.caution { color: #e5c478; }
.lot-risk-meter-zones .zone.danger { color: #d97757; }
.lot-risk-meter-zones .zone.extreme { color: #b85450; }

.lot-risk-meter-track {
  position: relative;
  height: 8px;
  background: linear-gradient(90deg,
    #5fa84f 0%, #5fa84f 20%,
    #e5c478 25%, #e5c478 45%,
    #d97757 50%, #d97757 75%,
    #b85450 80%, #b85450 100%);
  border-radius: 4px;
  overflow: hidden;
  border: 1px solid var(--color-hairline);
}
.lot-risk-meter-fill {
  position: absolute;
  top: 0; left: 0;
  height: 100%;
  background: rgba(0,0,0,0.55);
  transition: width 0.4s var(--ease-out);
  border-right: 1px solid rgba(255,255,255,0.3);
}
.lot-risk-meter-marker {
  position: absolute;
  top: -3px;
  width: 3px;
  height: 14px;
  background: var(--color-cream);
  border-radius: 1px;
  box-shadow: 0 0 8px rgba(245,236,211,0.7);
  transition: left 0.4s var(--ease-out);
  transform: translateX(-50%);
}

.lot-risk-meter-labels {
  display: flex; justify-content: space-between;
  font-family: var(--font-mono); font-size: 9px;
  color: var(--color-muted);
  margin-top: 4px;
  letter-spacing: 0.04em;
}

/* Compound Growth Mini Chart */
.lot-cg-chart {
  margin: 18px 0 4px;
  padding: 16px 14px 10px;
  background: rgba(10,8,6,0.4);
  border: 1px solid var(--color-hairline);
  border-radius: 4px;
}
.lot-cg-chart svg {
  width: 100%; height: 140px;
  display: block;
}
.lot-cg-chart path {
  transition: d 0.4s var(--ease-out);
}
.lot-cg-chart-legend {
  display: flex; justify-content: center; align-items: center;
  flex-wrap: wrap;
  gap: 12px; margin-top: 8px;
  font-family: var(--font-mono); font-size: 9px;
  letter-spacing: 0.1em;
  color: var(--color-cream-2);
}
.cg-legend-item { display: inline-flex; align-items: center; gap: 5px; }
.cg-legend-item .dot {
  width: 8px; height: 2px;
  border-radius: 1px;
}
.cg-legend-axis { color: var(--color-muted); font-style: italic; }

/* Mobile FAB · floating button to scroll back to calculator */
.lot-fab {
  position: fixed;
  bottom: 24px; right: 24px;
  display: none;
  align-items: center;
  gap: 8px;
  padding: 12px 18px;
  background: linear-gradient(135deg, #e5c478 0%, #c9a961 100%);
  color: #0a0806;
  border: 0;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  cursor: pointer;
  box-shadow: 0 8px 24px rgba(0,0,0,0.5), 0 0 0 1px rgba(229,196,120,0.4);
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.3s, transform 0.3s;
  z-index: 90;
}
.lot-fab.visible { opacity: 1; transform: translateY(0); }
.lot-fab:hover { transform: translateY(-2px); box-shadow: 0 12px 28px rgba(0,0,0,0.6), 0 0 0 1px rgba(229,196,120,0.6); }
.lot-fab svg { stroke-width: 2; }
.lot-fab-text { letter-spacing: 0.14em; }

@media (max-width: 768px) {
  .lot-fab { display: flex; bottom: 20px; right: 16px; padding: 10px 16px; }
}

@media (max-width: 540px) {
  .lot-info::before { max-width: 220px; font-size: 10px; padding: 8px 12px; }
  .lot-risk-meter-zones { font-size: 7px; }
  .lot-risk-meter-labels { font-size: 8px; }
  .lot-cg-chart { padding: 12px 10px 8px; }
  .lot-cg-chart svg { height: 110px; }
  .lot-cg-chart-legend { font-size: 8px; gap: 8px; }
  .lot-fab { font-size: 10px; padding: 9px 14px; }
  .lot-fab-text { display: none; }
  .lot-fab svg { width: 22px; height: 22px; }
}

.lot-calc-section { padding-top: 24px; }

/* Section label · "TOOL" indicator above calculator · makes it visually distinct */
.lot-calc-label { display: flex; align-items: center; justify-content: center; gap: 14px; max-width: 560px; margin: 0 auto 18px; }
.lot-calc-label-dot { width: 4px; height: 4px; background: #c9a961; border-radius: 50%; box-shadow: 0 0 12px rgba(201,169,97,0.6); }
.lot-calc-label-text { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase; color: #c9a961; font-weight: 600; }

.lot-calc-single { padding: 40px 40px 36px; position: relative; max-width: 560px; margin: 0 auto; }

/* PROMINENT calculator card · clearly distinct from other content cards · this is THE action zone */
.lot-calc-single.frame-card {
  background: linear-gradient(180deg, #28221a 0%, #1d1812 100%);
  border: 1px solid #c9a961;
  box-shadow:
    0 0 0 1px rgba(201, 169, 97, 0.20) inset,
    0 50px 120px -30px rgba(0, 0, 0, 0.85),
    0 0 80px -20px rgba(201, 169, 97, 0.18);
}
.lot-calc-single.frame-card .frame-corner {
  background: #c9a961;
  width: 14px;
  height: 14px;
}

/* Quick Scenarios · pre-fill ตามสไตล์ */
.lot-scenarios { margin-bottom: 28px; padding-bottom: 24px; border-bottom: 1px solid var(--color-hairline); }
.lot-scenarios-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; color: var(--color-gold); text-transform: uppercase; margin-bottom: 10px; text-align: center; }
.lot-scenarios-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; }
.lot-scenario { display: flex; flex-direction: column; align-items: center; gap: 3px; padding: 12px 8px; background: var(--color-bg-base); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); cursor: pointer; transition: all var(--duration-base); font-family: inherit; text-align: center; }
.lot-scenario:hover { border-color: var(--color-gold); background: rgba(201, 169, 97, 0.06); transform: translateY(-1px); }
.lot-scenario.active { border-color: var(--color-gold); background: rgba(201, 169, 97, 0.10); }
.lot-scenario-tf { font-family: var(--font-display-en); font-weight: 300; font-size: 20px; color: var(--color-gold); line-height: 1; letter-spacing: -0.02em; }
.lot-scenario-name { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-cream); }
.lot-scenario-desc { font-family: var(--font-mono); font-size: 8px; letter-spacing: 0.06em; color: var(--color-muted); margin-top: 1px; }

.lot-field { margin-bottom: 20px; display: flex; flex-direction: column; gap: 6px; }
.lot-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.lot-field label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--color-muted); font-weight: 500; }
.lot-field input, .lot-field select {
  width: 100%; padding: 13px 14px; background: var(--color-bg-base); color: var(--color-cream);
  border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm);
  font-size: 17px; font-family: var(--font-mono); transition: border-color var(--duration-base);
}
.lot-field input:focus, .lot-field select:focus { outline: none; border-color: var(--color-gold); }
.lot-field input::placeholder { color: var(--color-faint); }
.lot-hint { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.04em; color: var(--color-muted); }

/* Risk Preset Buttons */
.lot-risk-presets { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; }
.lot-risk-btn { display: flex; flex-direction: column; align-items: center; gap: 4px; padding: 14px 8px; background: var(--color-bg-base); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); cursor: pointer; transition: all var(--duration-base); font-family: inherit; }
.lot-risk-btn:hover { border-color: var(--color-gold-deep); background: rgba(201, 169, 97, 0.04); }
.lot-risk-btn.active { border-color: var(--color-gold); background: rgba(201, 169, 97, 0.10); }
.lot-risk-emoji { font-size: 18px; line-height: 1; }
.lot-risk-pct { font-family: var(--font-display-en); font-weight: 300; font-size: 22px; color: var(--color-gold-bright); line-height: 1; }
.lot-risk-btn.active .lot-risk-pct { color: var(--color-gold); }
.lot-risk-name { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-cream-2); }

/* Result block */
.lot-result-block { margin-top: 32px; padding-top: 32px; border-top: 1px solid var(--color-hairline); }
.lot-main-result { text-align: center; padding: 8px 16px 24px; border-bottom: 1px solid var(--color-hairline); margin-bottom: 24px; }
.lot-main-label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 14px; }
.lot-main-num { font-family: var(--font-display-en); font-weight: 200; font-size: clamp(80px, 16vw, 128px); line-height: 1; color: var(--color-gold); letter-spacing: -0.04em; }
.lot-main-num.empty { color: var(--color-faint); }
.lot-main-unit { font-family: var(--font-mono); font-size: 13px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--color-cream-2); margin-top: 8px; }

.lot-summary { display: flex; flex-direction: column; }
.lot-summary-row { display: flex; justify-content: space-between; align-items: baseline; padding: 12px 0; border-bottom: 1px solid var(--color-hairline); }
.lot-summary-row:last-child { border-bottom: none; }
.lot-summary-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-muted); }
.lot-summary-val { font-family: var(--font-display-en); font-weight: 300; font-size: 24px; line-height: 1; color: var(--color-cream); letter-spacing: -0.02em; margin-left: auto; }
.lot-summary-val.positive { color: var(--color-bull); }
.lot-summary-val.negative { color: var(--color-bear); }
.lot-summary-row small { font-family: var(--font-mono); font-size: 10px; color: var(--color-cream-2); margin-left: 12px; min-width: 90px; text-align: right; }

.lot-warnings { margin-top: 20px; }
.lot-warning { padding: 10px 14px; background: rgba(184, 84, 80, 0.08); border-left: 3px solid var(--color-bear); color: var(--color-bear); font-size: 13px; margin-bottom: 8px; border-radius: 2px; font-family: var(--font-body-th); }
.lot-warning.info { background: rgba(201, 169, 97, 0.08); border-left-color: var(--color-gold); color: var(--color-gold-bright); }

/* Spread field — gold border emphasis */
.lot-spread-field input { border-color: var(--color-gold-deep); }
.lot-spread-field input:focus { border-color: var(--color-gold); }

/* Risk preset chips */
.lot-presets { display: flex; gap: 6px; flex-wrap: wrap; margin: 8px 0 4px; }
.lot-preset { padding: 6px 14px; background: var(--color-bg-base); color: var(--color-cream-2); border: 1px solid var(--color-hairline); border-radius: 100px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.06em; cursor: pointer; transition: all var(--duration-base); }
.lot-preset:hover { border-color: var(--color-gold-deep); color: var(--color-cream); }
.lot-preset.active { background: var(--color-gold); color: var(--color-bg-base); border-color: var(--color-gold); font-weight: 600; }

/* Mode Tabs · เลือกแบบคำนวณ */
.lot-mode-tabs { display: grid; grid-template-columns: 1fr 1fr; gap: 0; margin: 20px 0 24px; border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); padding: 4px; background: var(--color-bg-base); }
.lot-mode-tab { padding: 12px 10px; background: transparent; color: var(--color-cream-2); border: none; cursor: pointer; border-radius: 3px; transition: all var(--duration-base); display: flex; flex-direction: column; gap: 4px; align-items: center; text-align: center; font-family: inherit; }
.lot-mode-tab:hover { color: var(--color-cream); background: rgba(201, 169, 97, 0.04); }
.lot-mode-tab.active { background: rgba(201, 169, 97, 0.12); color: var(--color-cream); }
.lot-mode-tab.active .lot-mode-tab-text { color: var(--color-gold-bright); }
.lot-mode-tab-text { font-size: 13px; font-weight: 500; letter-spacing: 0.02em; }
.lot-mode-tab-desc { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.10em; color: var(--color-muted); text-transform: uppercase; }
.lot-mode-tab.active .lot-mode-tab-desc { color: var(--color-cream-2); }

/* Direction Badge (Price mode auto-detect) */
.lot-direction-badge { display: flex; align-items: center; gap: 10px; padding: 12px 16px; background: rgba(107, 163, 115, 0.08); border: 1px solid var(--color-bull); border-radius: var(--border-radius-sm); margin-bottom: 18px; font-family: var(--font-mono); }
.lot-direction-badge.sell { background: rgba(184, 84, 80, 0.08); border-color: var(--color-bear); }
.lot-direction-badge.invalid { background: rgba(140, 129, 102, 0.08); border-color: var(--color-muted); }
.lot-dir-icon { font-size: 14px; }
.lot-dir-text { font-size: 12px; letter-spacing: 0.16em; color: var(--color-bull); font-weight: 600; }
.lot-direction-badge.sell .lot-dir-text { color: var(--color-bear); }
.lot-direction-badge.invalid .lot-dir-text { color: var(--color-muted); }
.lot-dir-info { margin-left: auto; font-size: 10px; color: var(--color-cream-2); letter-spacing: 0.04em; }

/* Result · Real P&L row (gold accent) */
.lot-summary-row.lot-summary-real { background: rgba(201, 169, 97, 0.04); margin: 0 -8px; padding-left: 8px; padding-right: 8px; }
.lot-summary-val.gold { color: var(--color-gold-bright); }

/* Drawdown Projection section */
.lot-dd-section { margin-top: 24px; padding-top: 8px; }
.lot-dd-head { display: flex; align-items: center; gap: 12px; margin-bottom: 8px; }
.lot-dd-head-line { flex: 1; height: 1px; background: var(--color-hairline); }
.lot-dd-head-text { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; color: var(--color-gold); text-transform: uppercase; }
.lot-dd-row { display: flex; align-items: center; padding: 9px 0; border-bottom: 1px solid var(--color-hairline); font-size: 12px; }
.lot-dd-row:last-child { border-bottom: none; }
.lot-dd-icon { font-size: 13px; margin-right: 10px; width: 18px; text-align: center; }
.lot-dd-label { color: var(--color-cream-2); flex: 1; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.04em; }
.lot-dd-loss { font-family: var(--font-display-en); font-weight: 300; color: var(--color-bear); font-size: 16px; min-width: 80px; text-align: right; margin-right: 12px; letter-spacing: -0.01em; }
.lot-dd-remain { font-family: var(--font-mono); font-size: 10px; min-width: 130px; text-align: right; color: var(--color-cream); }
.lot-dd-remain.warn { color: var(--color-gold-bright); }
.lot-dd-remain.bad { color: var(--color-bear); }

/* Compound Growth section · mirrors Drawdown */
.lot-cg-section { margin-top: 24px; padding-top: 8px; }
.lot-cg-head { display: flex; align-items: center; gap: 12px; margin-bottom: 8px; }
.lot-cg-head-line { flex: 1; height: 1px; background: var(--color-hairline); }
.lot-cg-head-text { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; color: var(--color-bull); text-transform: uppercase; }
.lot-cg-row { display: flex; align-items: center; padding: 9px 0; border-bottom: 1px solid var(--color-hairline); font-size: 12px; }
.lot-cg-row:last-of-type { border-bottom: none; }
.lot-cg-icon { font-size: 13px; margin-right: 10px; width: 18px; text-align: center; }
.lot-cg-label { color: var(--color-cream-2); flex: 1; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.04em; }
.lot-cg-gain { font-family: var(--font-display-en); font-weight: 300; color: var(--color-bull); font-size: 16px; min-width: 80px; text-align: right; margin-right: 12px; letter-spacing: -0.01em; }
.lot-cg-gain.negative { color: var(--color-bear); }
.lot-cg-final { font-family: var(--font-mono); font-size: 10px; min-width: 130px; text-align: right; color: var(--color-cream); }
.lot-cg-final.negative { color: var(--color-bear); }
.lot-cg-note { margin: 12px 0 0; font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.04em; color: var(--color-muted); text-align: center; font-style: italic; line-height: 1.7; }
.lot-cg-note strong { font-style: normal; color: var(--color-cream-2); font-weight: 600; letter-spacing: 0.06em; }

/* Action row · Copy + MT5 side-by-side */
/* Primary Copy Lot button · big, shows actual lot value */
.lot-action-row { display: block; margin-top: 24px; }
.lot-copy-btn {
  width: 100%;
  padding: 18px 24px;
  background: linear-gradient(180deg, #e5c478 0%, #c9a961 100%);
  color: var(--color-bg-base);
  border: none;
  border-radius: var(--border-radius-sm);
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all var(--duration-base);
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  margin-top: 0;
  box-shadow: 0 8px 24px rgba(201,169,97,0.18);
}
.lot-copy-icon { font-size: 16px; }
.lot-copy-main { font-weight: 600; }
.lot-copy-val {
  font-family: var(--font-display-en);
  font-size: 20px;
  font-weight: 300;
  letter-spacing: -0.02em;
  text-transform: none;
  padding-left: 14px;
  border-left: 1px solid rgba(10,8,6,0.25);
}
.lot-copy-btn:hover:not(:disabled) { background: linear-gradient(180deg, #ecd089 0%, #d6b46e 100%); transform: translateY(-1px); box-shadow: 0 12px 28px rgba(201,169,97,0.3); }
.lot-copy-btn:disabled { background: var(--color-hairline); color: var(--color-muted); cursor: not-allowed; box-shadow: none; }
.lot-copy-btn:disabled .lot-copy-val { display: none; }
.lot-copy-btn.copied { background: var(--color-bull); color: var(--color-bg-base); }

/* Hide old mt5-btn styles (removed in v1.40) */
.lot-mt5-btn, .lot-copy-all { display: none !important; }

/* Reset link (subtle) */
.lot-reset-link { display: block; width: 100%; padding: 10px; background: transparent; color: var(--color-muted); border: none; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; cursor: pointer; transition: color var(--duration-base); margin-top: 8px; }
.lot-reset-link:hover { color: var(--color-cream); }

/* LocalStorage memory note */
.lot-memory-note { text-align: center; margin: 14px 0 0; padding: 8px 12px; background: rgba(107, 163, 115, 0.06); border-left: 2px solid var(--color-bull); border-radius: 2px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; color: var(--color-bull); }

/* Formula section */
.lot-formula { padding: 36px 40px; max-width: 720px; margin: 32px auto 0; position: relative; }
.lot-formula-step { display: flex; gap: 20px; padding: 16px 0; border-bottom: 1px solid var(--color-hairline); }
.lot-formula-step:last-child { border-bottom: none; }
.lot-formula-num { font-family: var(--font-display-en); font-weight: 200; font-size: 36px; line-height: 1; color: var(--color-gold); flex-shrink: 0; width: 44px; text-align: center; }
.lot-formula-text { flex: 1; color: var(--color-cream-2); line-height: 1.7; }
.lot-formula-text strong { color: var(--color-cream); }
.lot-formula-text code { background: var(--color-bg-base); padding: 2px 8px; border-radius: 3px; color: var(--color-gold); font-size: 0.9em; }
.lot-formula-text small { color: var(--color-muted); font-size: 13px; }

/* CTA */
.lot-cta { padding: 48px 40px; text-align: center; max-width: 720px; margin: 0 auto; position: relative; }

/* Intro paragraph (below hero) */
.lot-intro { text-align: center; max-width: 720px; margin: 0 auto 8px; padding: 18px 24px; background: rgba(201, 169, 97, 0.04); border-left: 2px solid var(--color-gold-deep); border-radius: 2px; color: var(--color-cream-2); font-size: 14px; line-height: 1.85; letter-spacing: 0.01em; }
.lot-intro strong { color: var(--color-cream); font-weight: 500; }
.lot-intro a { color: var(--color-gold-bright); text-decoration: underline; text-decoration-color: rgba(201,169,97,0.3); }
.lot-intro a:hover { color: var(--color-gold); text-decoration-color: var(--color-gold); }

/* Asset Specs Strip · clearly indicates Gold-only */
.lot-asset-specs { display: flex; justify-content: center; align-items: stretch; max-width: 760px; margin: 0 auto 24px; padding: 18px 24px; background: linear-gradient(180deg, rgba(201,169,97,0.06) 0%, rgba(201,169,97,0.02) 100%); border-top: 1px solid var(--color-gold-deep); border-bottom: 1px solid var(--color-gold-deep); position: relative; }
.asset-spec { flex: 1; text-align: center; padding: 0 12px; }
.asset-spec-label { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-cream-2); margin-bottom: 6px; opacity: 0.8; }
.asset-spec-value { font-family: var(--font-display-en); font-weight: 300; font-size: 22px; color: var(--color-gold-bright); letter-spacing: -0.01em; line-height: 1; margin-bottom: 4px; }
.asset-spec-sub { font-family: var(--font-mono); font-size: 9px; color: var(--color-muted); letter-spacing: 0.08em; font-style: italic; }
.asset-spec-divider { width: 1px; background: linear-gradient(180deg, transparent 0%, var(--color-hairline) 30%, var(--color-hairline) 70%, transparent 100%); margin: 4px 0; }

/* Quick Answer (TL;DR card) */
.lot-quickanswer-sec { padding-top: 0; }
.lot-quickanswer { padding: 28px 36px; max-width: 720px; margin: 0 auto; position: relative; }
.quickanswer-tag { display: inline-block; padding: 4px 10px; background: var(--color-gold); color: var(--color-bg-base); font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.18em; text-transform: uppercase; border-radius: 2px; margin-bottom: 14px; font-weight: 600; }
.quickanswer-q { font-family: var(--font-display-en); font-weight: 300; font-size: 22px; color: var(--color-cream); margin: 0 0 12px; letter-spacing: -0.01em; }
.quickanswer-a { color: var(--color-cream-2); font-size: 15px; line-height: 1.8; margin: 0; }
.quickanswer-a strong { color: var(--color-cream); font-weight: 500; }
.quickanswer-a a { color: var(--color-gold-bright); text-decoration: underline; text-decoration-color: rgba(201,169,97,0.3); }
.quickanswer-a a:hover { color: var(--color-gold); }

/* How To Use · 4 steps */
.lot-howto-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; max-width: 920px; margin: 32px auto 0; }
.lot-howto-step { background: var(--color-bg-base); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); padding: 24px 18px; text-align: center; transition: all var(--duration-base); }
.lot-howto-step:hover { border-color: var(--color-gold-deep); }
.lot-howto-num { font-family: var(--font-display-en); font-weight: 200; font-size: 48px; color: var(--color-gold); line-height: 1; margin-bottom: 12px; letter-spacing: -0.04em; }
.lot-howto-title { font-family: var(--font-display-en); font-weight: 300; font-size: 17px; color: var(--color-cream); margin: 0 0 8px; }
.lot-howto-text { font-size: 13px; line-height: 1.6; color: var(--color-cream-2); margin: 0; }
.lot-howto-text a { color: var(--color-gold-bright); text-decoration: underline; text-decoration-color: rgba(201,169,97,0.3); }
.lot-howto-text a:hover { color: var(--color-gold); }

/* Features Showcase Grid */
.lot-features-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; max-width: 1020px; margin: 32px auto 0; }
.lot-feature { padding: 26px 24px 22px; position: relative; }
.feature-num { font-family: var(--font-display-en); font-weight: 200; font-size: 32px; color: var(--color-gold); letter-spacing: -0.04em; line-height: 1; margin-bottom: 10px; opacity: 0.85; }
.feature-title { font-family: var(--font-display-en); font-weight: 300; font-size: 19px; color: var(--color-cream); margin: 0 0 10px; letter-spacing: -0.01em; }
.lot-feature p.feature-text { font-size: 13px; line-height: 1.75; color: var(--color-cream-2); margin: 0; }
.lot-feature p.feature-text strong { color: var(--color-gold-bright); font-weight: 500; }

/* Extra small features bar */
.lot-features-extra { margin: 32px auto 0; max-width: 720px; text-align: center; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.10em; color: var(--color-cream-2); padding: 14px 20px; background: rgba(201, 169, 97, 0.04); border-top: 1px solid var(--color-hairline); border-bottom: 1px solid var(--color-hairline); display: flex; justify-content: center; align-items: center; gap: 10px; flex-wrap: wrap; }
.extra-item { white-space: nowrap; }
.extra-sep { color: var(--color-faint); }

/* Methodology Grid */
.lot-method-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; max-width: 920px; margin: 32px auto 0; }
.lot-method-item { padding: 24px 24px 22px; position: relative; }
.lot-method-title { font-family: var(--font-display-en); font-weight: 300; font-size: 18px; color: var(--color-gold-bright); margin: 0 0 10px; letter-spacing: -0.01em; }
.lot-method-item p { font-size: 13px; line-height: 1.75; color: var(--color-cream-2); margin: 0; }
.lot-method-item p strong { color: var(--color-cream); font-weight: 500; }

/* Trust Footer */
.lot-trust-sec { padding: 32px 0; border-top: 1px solid var(--color-hairline); border-bottom: 1px solid var(--color-hairline); }
.lot-trust-bar { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; max-width: 920px; margin: 0 auto 16px; padding: 0 16px; }
.trust-author { display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; }
.trust-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--color-muted); }
.trust-brand { font-family: var(--font-display-en); font-weight: 300; font-size: 18px; color: var(--color-gold); letter-spacing: -0.01em; }
.trust-desc { font-size: 12px; color: var(--color-cream-2); font-style: italic; }
.trust-meta { display: flex; align-items: center; gap: 10px; font-family: var(--font-mono); font-size: 11px; color: var(--color-muted); letter-spacing: 0.04em; }
.trust-sep { color: var(--color-faint); }
.trust-version { color: var(--color-gold-deep); }
.lot-disclaimer { max-width: 760px; margin: 0 auto; padding: 14px 18px; background: rgba(184, 84, 80, 0.05); border-left: 2px solid var(--color-bear); border-radius: 2px; font-size: 12px; line-height: 1.7; color: var(--color-cream-2); }
.lot-disclaimer strong { color: var(--color-cream); }

/* FAQ accordion (native details/summary) */
.lot-faq { padding: 32px 40px; max-width: 760px; margin: 0 auto; position: relative; }
.lot-faq-item { padding: 18px 0; border-bottom: 1px solid var(--color-hairline); }
.lot-faq-item:last-child { border-bottom: none; }
.lot-faq-item summary { cursor: pointer; padding: 0 32px 0 0; position: relative; font-size: 16px; line-height: 1.5; color: var(--color-cream); font-weight: 500; list-style: none; transition: color var(--duration-base); }
.lot-faq-item summary::-webkit-details-marker { display: none; }
.lot-faq-item summary::after { content: '+'; position: absolute; right: 0; top: 50%; transform: translateY(-50%); font-family: var(--font-display-en); font-size: 24px; font-weight: 200; color: var(--color-gold); transition: transform var(--duration-base); }
.lot-faq-item[open] summary::after { content: '−'; }
.lot-faq-item summary:hover { color: var(--color-gold-bright); }
.lot-faq-item p { margin: 14px 0 4px; color: var(--color-cream-2); font-size: 14px; line-height: 1.8; padding-right: 32px; }
.lot-faq-item p strong { color: var(--color-cream); font-weight: 500; }
.lot-faq-item p a { color: var(--color-gold-bright); text-decoration: underline; text-decoration-color: rgba(201,169,97,0.3); }
.lot-faq-item p a:hover { color: var(--color-gold); }

@media (max-width: 880px) {
  .lot-howto-grid { grid-template-columns: 1fr 1fr; }
  .lot-method-grid { grid-template-columns: 1fr; }
  .lot-compare-table { font-size: 11px; }
  .lot-compare-table th, .lot-compare-table td { padding: 10px 6px; }
}

@media (max-width: 540px) {
  .lot-intro { padding: 14px 16px; font-size: 13px; }
  .lot-asset-specs { padding: 14px 8px; gap: 2px; flex-wrap: wrap; }
  .asset-spec { padding: 8px 4px; min-width: 0; flex: 1 1 calc(50% - 4px); }
  .asset-spec-divider { display: none; }
  .asset-spec-label { font-size: 8px; letter-spacing: 0.12em; }
  .asset-spec-value { font-size: 16px; }
  .asset-spec-sub { font-size: 8px; }
  .lot-features-grid { grid-template-columns: 1fr; gap: 12px; }
  .lot-feature { padding: 20px 18px; }
  .feature-num { font-size: 26px; }
  .feature-title { font-size: 17px; }
  .lot-quickanswer { padding: 22px 22px; }
  .quickanswer-q { font-size: 18px; }
  .quickanswer-a { font-size: 14px; }
  .lot-howto-grid { grid-template-columns: 1fr; gap: 10px; }
  .lot-howto-step { padding: 18px 16px; }
  .lot-howto-num { font-size: 36px; }
  .lot-method-item { padding: 18px 18px; }
  .lot-method-title { font-size: 16px; }
  .lot-faq { padding: 20px 18px; }
  .lot-faq-item summary { font-size: 14px; padding-right: 28px; }
  .lot-faq-item p { font-size: 13px; padding-right: 0; }
  .lot-trust-bar { flex-direction: column; align-items: flex-start; }
  .lot-disclaimer { font-size: 11px; padding: 12px 14px; }
}

@media (max-width: 540px) {
  .lot-calc-single { padding: 24px 20px; }
  .lot-field-row { grid-template-columns: 1fr; gap: 0; }
  .lot-scenarios-grid { grid-template-columns: 1fr 1fr 1fr; gap: 6px; }
  .lot-scenario { padding: 10px 4px; }
  .lot-scenario-tf { font-size: 16px; }
  .lot-scenario-name { font-size: 9px; }
  .lot-scenario-desc { font-size: 7px; }
  .lot-summary-val { font-size: 20px; }
  .lot-summary-row small { min-width: 70px; font-size: 9px; }
  .lot-action-row { grid-template-columns: 1fr; gap: 8px; }
  .lot-cg-final, .lot-dd-remain { min-width: 100px; font-size: 9px; }
  .lot-formula { padding: 24px 20px; }
  .lot-formula-step { gap: 14px; }
  .lot-formula-num { font-size: 28px; width: 36px; }
}

/* ═══ SIGNAL PAGE — TF TABS (M1 / M5 / M15) ═══ */
.auhunter-live-indicator { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--color-muted); display: flex; align-items: center; justify-content: center; gap: 10px; }
.auhunter-live-indicator .live-dot { display: inline-block; width: 6px; height: 6px; background: var(--color-bull); border-radius: 50%; }
.auhunter-live-indicator .pulse { animation: pulse 2s infinite; }
.auhunter-live-indicator.refreshing { opacity: 0.6; }
.ts-tabs { display: flex; gap: 0; justify-content: center; margin: 0 auto 40px; max-width: 760px; border-bottom: 1px solid var(--color-hairline); }
.ts-tab { flex: 1; background: transparent; border: none; border-bottom: 2px solid transparent; padding: 18px 16px 20px; cursor: pointer; color: var(--color-cream-2); transition: all var(--duration-base); margin-bottom: -1px; font-family: inherit; text-align: center; }
.ts-tab:hover { color: var(--color-cream); background: rgba(201, 169, 97, 0.03); }
.ts-tab.active { border-bottom-color: var(--color-gold); color: var(--color-cream); }
.ts-tab-num { font-family: var(--font-display-en); font-weight: 300; font-size: 28px; line-height: 1; letter-spacing: -0.02em; color: var(--color-gold); margin-bottom: 4px; }
.ts-tab-name { font-family: var(--font-display-en); font-style: italic; font-weight: 300; font-size: 14px; color: var(--color-cream-2); letter-spacing: 0.01em; margin-bottom: 6px; }
.ts-tab.active .ts-tab-name { color: var(--color-cream); }
.ts-tab-stat { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-muted); }
.ts-panel { display: none; animation: fadeIn 0.3s ease; }
.ts-panel.active { display: block; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }

@media (max-width: 600px) {
  .ts-tab { padding: 14px 10px 16px; }
  .ts-tab-num { font-size: 22px; }
  .ts-tab-name { font-size: 12px; }
  .ts-tab-stat { font-size: 9px; letter-spacing: 0.10em; }
}

/* ═══ SIGNAL PAGE — TIME-SERIES STATS (7 days · 8 weeks · 12 months) ═══ */
.timeseries-section { max-width: 1280px; margin: 0 auto 56px; }
.timeseries-section:last-of-type { margin-bottom: 32px; }
.timeseries-head { text-align: center; margin-bottom: 24px; }
.timeseries-title { font-family: var(--font-display-th); font-weight: 400; font-size: 22px; color: var(--color-cream); margin: 0 0 6px; letter-spacing: -0.01em; }
.timeseries-title em { font-family: var(--font-display-en); font-style: italic; color: var(--color-gold); font-weight: 300; }
.timeseries-sub { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--color-muted); margin: 0; }

.timeseries-grid { display: grid; gap: 8px; padding: 4px; }
.timeseries-grid.periods-5 { grid-template-columns: repeat(5, 1fr); max-width: 1100px; margin: 0 auto; }
.ts-period-card { min-height: 170px; padding: 22px 14px 18px; }

.timeseries-cell {
  background: var(--color-bg-base);
  border: 1px solid var(--color-hairline);
  border-radius: var(--border-radius-sm);
  padding: 16px 8px 14px;
  text-align: center;
  transition: border-color var(--duration-base), background var(--duration-base);
  min-height: 130px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.timeseries-cell:hover { border-color: var(--color-hairline-bright); background: var(--color-surface); }
.timeseries-cell.today { border-color: var(--color-gold-deep); background: linear-gradient(180deg, rgba(201, 169, 97, 0.06) 0%, transparent 60%); }
.timeseries-cell.future { opacity: 0.35; }

.ts-label { font-family: var(--font-mono); font-size: 10px; color: var(--color-muted); letter-spacing: 0.08em; line-height: 1.4; margin-bottom: 10px; position: relative; }
.ts-name { display: block; color: var(--color-cream-2); font-weight: 500; text-transform: uppercase; letter-spacing: 0.12em; font-size: 11px; }
.ts-date { display: block; color: var(--color-muted); font-size: 9px; margin-top: 2px; }
.ts-dot { display: inline-block; width: 5px; height: 5px; background: var(--color-bull); border-radius: 50%; position: absolute; top: 0; right: 4px; animation: pulse 2s infinite; }

.ts-wr { font-family: var(--font-display-en); font-weight: 300; font-size: 28px; line-height: 1; color: var(--color-cream); letter-spacing: -0.02em; margin: 4px 0 8px; }
.ts-wr em { font-style: italic; font-size: 0.5em; color: var(--color-gold); margin-left: 1px; font-weight: 300; vertical-align: super; }
.ts-trades { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-cream-2); margin-bottom: 4px; }
.ts-split { font-family: var(--font-mono); font-size: 11px; display: flex; align-items: center; justify-content: center; gap: 4px; }
.ts-w { color: var(--color-bull); font-weight: 500; }
.ts-l { color: var(--color-bear); font-weight: 500; }
.ts-sep { color: var(--color-faint); }
.ts-empty { font-family: var(--font-mono); font-size: 18px; color: var(--color-faint); padding: 16px 0; }

/* Points per cell — color-coded P&L */
.ts-points { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.04em; margin-top: 6px; padding-top: 6px; border-top: 1px solid var(--color-hairline); font-weight: 600; }
.ts-points small { font-weight: 400; opacity: 0.6; font-size: 0.8em; letter-spacing: 0.06em; }
.ts-points.positive { color: var(--color-bull); }
.ts-points.negative { color: var(--color-bear); }

/* Market-closed notice (weekend) on Today card */
.ts-closed { font-size: 30px; line-height: 1; margin: 10px 0 6px; opacity: 0.85; }
.ts-closed-text { font-family: var(--font-display-th); font-size: 16px; color: var(--color-cream-2); line-height: 1.4; }
.ts-closed-text small { display: block; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-muted); margin-top: 4px; }

/* 30-Day Stats Calendar (per TF) */
.ts-calendar { max-width: 720px; margin: 40px auto 0; }
.ts-cal-head { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-muted); text-align: center; margin-bottom: 16px; }
.ts-cal-head strong { color: var(--color-gold); font-weight: 600; }
.ts-cal-nav { display: flex; align-items: center; justify-content: center; gap: 16px; margin-bottom: 18px; }
.ts-cal-title { font-family: var(--font-display-th); font-size: 16px; color: var(--color-cream); min-width: 150px; text-align: center; letter-spacing: 0.01em; }
.ts-cal-prev, .ts-cal-next { width: 34px; height: 34px; border-radius: 9px; border: 1px solid var(--color-hairline); background: rgba(255,255,255,0.02); color: var(--color-cream-2); font-size: 18px; line-height: 1; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: border-color var(--duration-base), color var(--duration-base); }
.ts-cal-prev:hover:not(:disabled), .ts-cal-next:hover:not(:disabled) { border-color: var(--color-gold); color: var(--color-gold); }
.ts-cal-prev:disabled, .ts-cal-next:disabled { opacity: 0.22; cursor: default; }
.ts-cal-cell.is-future { background: none; border-color: var(--color-hairline); opacity: 0.4; }
.ts-cal-cell.is-future .ts-cal-date { color: var(--color-faint); }
.ts-cal-cell.is-today { box-shadow: inset 0 0 0 1.5px var(--color-gold); }
.ts-cal-weekdays { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; margin-bottom: 6px; }
.ts-cal-weekdays span { text-align: center; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; color: var(--color-faint); }
.ts-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; }
.ts-cal-cell { min-height: 78px; padding: 8px 4px; overflow: hidden; border-radius: 7px; border: 1px solid var(--color-hairline); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px; background: rgba(255,255,255,0.012); transition: transform var(--duration-base), border-color var(--duration-base); cursor: default; }
.ts-cal-cell:not(.is-pad):hover { transform: translateY(-2px); border-color: var(--color-hairline-bright); }
.ts-cal-cell.is-pad { border: none; background: none; }
.ts-cal-date { font-family: var(--font-mono); font-size: 13px; color: var(--color-cream-2); line-height: 1; }
.ts-cal-pts { font-family: var(--font-mono); font-size: 13px; font-weight: 600; line-height: 1.05; letter-spacing: 0.01em; }
.ts-cal-cell.is-profit { background: rgba(107, 163, 115, 0.14); border-color: rgba(107, 163, 115, 0.35); }
.ts-cal-cell.is-profit .ts-cal-pts { color: var(--color-bull); }
.ts-cal-cell.is-loss { background: rgba(184, 84, 80, 0.13); border-color: rgba(184, 84, 80, 0.32); }
.ts-cal-cell.is-loss .ts-cal-pts { color: var(--color-bear); }
.ts-cal-cell.is-flat .ts-cal-date { color: var(--color-faint); }
.ts-cal-cell.is-closed { background: rgba(255,255,255,0.02); border-style: dashed; }
.ts-cal-cell.is-closed .ts-cal-date { color: var(--color-faint); opacity: 0.6; }
.ts-cal-cell.is-empty { background: rgba(255,255,255,0.006); border-color: var(--color-hairline); }
.ts-cal-cell.is-empty .ts-cal-date { color: var(--color-faint); opacity: 0.4; }
.ts-cal-pts i { font-style: normal; font-size: 9px; font-weight: 400; color: var(--color-faint); margin-left: 2px; letter-spacing: 0; }
.ts-cal-wl { font-family: var(--font-mono); font-size: 10px; line-height: 1; letter-spacing: 0.01em; color: var(--color-muted); white-space: nowrap; }
.ts-cal-wl b { font-weight: 600; }
.ts-cal-wl b.w { color: var(--color-bull); }
.ts-cal-wl b.l { color: var(--color-bear); }
.ts-cal-cell.is-profit .ts-cal-wl,
.ts-cal-cell.is-loss .ts-cal-wl { color: var(--color-muted); }
.ts-cal-note { text-align: center; margin-top: 8px; font-family: var(--font-mono); font-size: 9px; line-height: 1.5; color: var(--color-faint); letter-spacing: 0.02em; }
.ts-cal-dash { font-family: var(--font-mono); font-size: 10px; line-height: 1; color: var(--color-faint); opacity: 0.35; }
.ts-cal-legend { display: flex; justify-content: center; gap: 18px; align-items: center; margin-top: 16px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; color: var(--color-muted); text-transform: uppercase; }
.ts-cal-legend .lg { display: inline-block; width: 11px; height: 11px; border-radius: 3px; margin-right: 6px; vertical-align: middle; border: 1px solid var(--color-hairline); }
.ts-cal-legend .lg.is-profit { background: rgba(107, 163, 115, 0.4); }
.ts-cal-legend .lg.is-loss { background: rgba(184, 84, 80, 0.4); }
.ts-cal-legend .lg.is-closed { background: rgba(255,255,255,0.04); border-style: dashed; }
.ts-cal-legend .lg.is-empty { background: rgba(255,255,255,0.01); border-color: var(--color-hairline); }
.ts-cal-empty { text-align: center; font-family: var(--font-mono); font-size: 12px; color: var(--color-muted); padding: 28px 16px; border: 1px dashed var(--color-hairline); border-radius: 10px; }
@media (max-width: 560px) {
  .ts-cal-cell { min-height: 62px; padding: 6px 2px; gap: 3px; }
  .ts-cal-pts { font-size: 11px; }
  .ts-cal-pts i { display: none; }
  .ts-cal-wl { font-size: 8px; letter-spacing: -0.2px; }
  .ts-cal-date { font-size: 11px; }
  .ts-cal-grid, .ts-cal-weekdays { gap: 4px; }
}

/* Dual Points Band (current month + 12-month total) */
.stats-points-dual { margin-top: 40px; padding: 36px 24px; background: linear-gradient(180deg, rgba(201, 169, 97, 0.05) 0%, transparent 100%); border-top: 1px solid var(--color-hairline-bright); border-bottom: 1px solid var(--color-hairline-bright); display: grid; grid-template-columns: 1fr auto 1fr; gap: 32px; align-items: center; max-width: 1100px; margin-left: auto; margin-right: auto; }
.stats-points-side { text-align: center; }
.stats-points-divider { width: 1px; height: 80px; background: var(--color-hairline-bright); }

/* Single-band fallback (legacy) */
.stats-points-band { margin-top: 32px; padding: 32px 24px; background: linear-gradient(180deg, rgba(201, 169, 97, 0.04) 0%, transparent 100%); border-top: 1px solid var(--color-hairline-bright); border-bottom: 1px solid var(--color-hairline-bright); text-align: center; }

.stats-points-label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 12px; }
.stats-points-num { font-family: var(--font-display-en); font-weight: 200; font-size: clamp(40px, 6.5vw, 72px); line-height: 1; letter-spacing: -0.03em; display: inline-block; color: var(--color-gold); }
.stats-points-num.positive { color: var(--color-gold); }
.stats-points-num.negative { color: var(--color-bear); }
.stats-points-unit { display: inline-block; margin-left: 10px; font-family: var(--font-mono); font-size: 13px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-cream-2); vertical-align: middle; }

@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }

/* Responsive: periods grid wraps gracefully */
@media (max-width: 900px) {
  .timeseries-grid.periods-5 { grid-template-columns: repeat(3, 1fr); }
  .ts-wr { font-size: 24px; }
  .ts-period-card { min-height: 150px; padding: 16px 8px 14px; }
  .stats-points-dual { grid-template-columns: 1fr; gap: 24px; }
  .stats-points-divider { width: 60px; height: 1px; margin: 0 auto; }
}
@media (max-width: 540px) {
  .timeseries-grid.periods-5 { grid-template-columns: repeat(2, 1fr); }
}

/* ═══ SIGNAL PAGE — TRUST INDICATORS ═══ */
.trust-sec { padding: 64px 0 40px; }
.trust-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 56px; max-width: 1100px; margin: 0 auto; }
.trust-item { text-align: center; padding: 0 12px; }
.trust-mark { font-family: var(--font-display-en); font-size: 14px; color: var(--color-gold); margin-bottom: 20px; letter-spacing: 0.16em; opacity: 0.8; }
.trust-mark em { font-style: italic; font-weight: 300; }
.trust-title { font-family: var(--font-display-th); font-weight: 400; font-size: 24px; color: var(--color-cream); margin-bottom: 16px; line-height: 1.35; }
.trust-title em { font-family: var(--font-display-en); font-style: italic; color: var(--color-gold); font-weight: 300; }
.trust-desc { font-family: var(--font-body); font-size: 14px; font-weight: 300; color: var(--color-cream-2); line-height: 1.75; }
.trust-desc strong { color: var(--color-cream); font-weight: 500; }

@media (max-width: 980px) {
  .trust-grid { grid-template-columns: 1fr; gap: 40px; }
}

/* ═══ SIGNAL PAGE — 3 CHANNELS GRID ═══ */
.channels-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; max-width: 1280px; margin: 0 auto; }
.channel-card { padding: 36px 28px 28px; position: relative; display: flex; flex-direction: column; transition: transform var(--duration-base), border-color var(--duration-base); }
.channel-card:hover { transform: translateY(-4px); }
.channel-card.featured { border-color: var(--color-gold-deep); background: linear-gradient(180deg, rgba(201, 169, 97, 0.03) 0%, transparent 60%); }
.channel-tag { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 24px; }
.channel-tag.featured { color: var(--color-gold); }
.channel-num { font-family: var(--font-display-en); font-weight: 200; font-size: 88px; line-height: 0.9; letter-spacing: -0.03em; color: var(--color-cream); margin-bottom: 4px; }
.channel-num em { font-style: italic; color: var(--color-gold); font-weight: 300; }
.channel-name { font-family: var(--font-display-en); font-weight: 300; font-style: italic; font-size: 28px; color: var(--color-cream-2); margin-bottom: 16px; letter-spacing: -0.01em; }
.channel-desc { font-family: var(--font-body); font-size: 14px; font-weight: 300; color: var(--color-cream-2); line-height: 1.7; margin-bottom: 28px; min-height: 60px; }
.channel-specs { list-style: none; padding: 0; margin: 0 0 32px; border-top: 1px solid var(--color-hairline); }
.channel-specs li { display: flex; justify-content: space-between; align-items: baseline; padding: 12px 0; border-bottom: 1px solid var(--color-hairline); font-size: 13px; }
.channel-specs li span { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-muted); }
.channel-specs li strong { font-family: var(--font-mono); color: var(--color-cream); font-weight: 500; font-size: 12px; letter-spacing: 0.04em; }
.channel-cta { margin-top: auto; text-align: center; }
.channel-cta .btn-gold { width: 100%; justify-content: center; display: block; }
.channel-handle { margin-top: 14px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; color: var(--color-muted); }

@media (max-width: 980px) {
  .channels-grid { grid-template-columns: 1fr; gap: 20px; }
  .channel-num { font-size: 72px; }
  .channel-desc { min-height: auto; }
}

/* ═══ SIGNAL PAGE — ALERT TYPES GRID ═══ */
.alert-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; margin-top: 48px; }
.alert-item { padding: 28px 24px; border-top: 1px solid var(--color-hairline-bright); }
.alert-num { font-family: var(--font-display-en); font-weight: 300; font-size: 14px; color: var(--color-gold); letter-spacing: 0.12em; margin-bottom: 16px; }
.alert-num em { font-style: italic; }
.alert-title { font-family: var(--font-display-th); font-weight: 400; font-size: 18px; color: var(--color-cream); margin-bottom: 12px; line-height: 1.3; }
.alert-title em { font-family: var(--font-display-en); font-style: italic; color: var(--color-gold); font-weight: 300; }
.alert-desc { font-family: var(--font-body); font-size: 13px; font-weight: 300; color: var(--color-cream-2); line-height: 1.7; }

@media (max-width: 1200px) {
  .alert-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .alert-grid { grid-template-columns: 1fr; }
}

/* ═══ NEWSLETTER SUBSCRIBE ═══ */
.subscribe-block { max-width: 560px; margin: 0 auto; text-align: center; }
.subscribe-block.subscribe-inline { max-width: 100%; text-align: left; }
.subscribe-head { margin-bottom: 24px; }
.subscribe-title { font-family: var(--font-display-th); font-weight: 400; font-size: 22px; color: var(--color-cream); margin-bottom: 6px; line-height: 1.3; }
.subscribe-sub { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-muted); }
.auhunter-subscribe-form { display: flex; gap: 8px; align-items: stretch; }
.subscribe-block.subscribe-inline .auhunter-subscribe-form { max-width: 480px; }
.auhunter-subscribe-form input[type="email"] {
  flex: 1; padding: 14px 16px;
  background: var(--color-bg-base);
  border: 1px solid var(--color-hairline-bright);
  color: var(--color-cream);
  font-family: var(--font-body); font-size: 14px; font-weight: 300;
  border-radius: var(--border-radius-sm);
  transition: border-color var(--duration-fast);
  outline: none;
}
.auhunter-subscribe-form input[type="email"]::placeholder { color: var(--color-muted); }
.auhunter-subscribe-form input[type="email"]:focus { border-color: var(--color-gold); }
.auhunter-subscribe-form button {
  background: var(--color-gold); color: var(--color-bg-base);
  padding: 14px 22px;
  font-family: var(--font-body); font-weight: 500; font-size: 13px;
  letter-spacing: 0.04em;
  border: 1px solid var(--color-gold);
  border-radius: var(--border-radius-sm);
  transition: all var(--duration-fast);
  white-space: nowrap; cursor: pointer;
  position: relative;
}
.auhunter-subscribe-form button:hover:not(:disabled) { background: var(--color-gold-bright); border-color: var(--color-gold-bright); }
.auhunter-subscribe-form button:disabled { opacity: 0.7; cursor: wait; }
.auhunter-subscribe-form button.loading .btn-label { opacity: 0.4; }
.auhunter-subscribe-form button.loading .btn-spinner { display: inline-block; }
.btn-spinner { display: none; position: absolute; top: 50%; left: 50%; width: 14px; height: 14px; border: 2px solid currentColor; border-top-color: transparent; border-radius: 50%; transform: translate(-50%, -50%); animation: spin 0.6s linear infinite; }
@keyframes spin { to { transform: translate(-50%, -50%) rotate(360deg); } }
.subscribe-status { margin-top: 14px; min-height: 18px; font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.04em; }
.subscribe-status.success { color: var(--color-bull); }
.subscribe-status.error { color: var(--color-bear); }
.subscribe-note { margin-top: 12px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-faint); }

/* Subscribe section variants */
.subscribe-section { padding: 80px 0; border-top: 1px solid var(--color-hairline); border-bottom: 1px solid var(--color-hairline); background: var(--color-bg-elevated); }
.subscribe-section .subscribe-title { font-size: 32px; }
.subscribe-section .subscribe-sub { font-size: 13px; margin-bottom: 8px; }

/* Footer newsletter */
.footer-newsletter { padding: 48px 0; border-bottom: 1px solid var(--color-hairline); margin-bottom: 48px; }
.footer-newsletter .subscribe-block { max-width: 720px; }

@media (max-width: 980px) {
  .auhunter-subscribe-form { flex-direction: column; }
  .auhunter-subscribe-form button { width: 100%; }
}

/* ═══ BETA MODE STYLES ═══ */
.btn-gold.btn-lg, .btn-ghost.btn-lg { padding: 18px 36px; font-size: 14px; letter-spacing: 0.06em; }

.beta-badge { display: inline-flex; align-items: center; gap: 10px; margin: 28px 0 32px; padding: 8px 16px; border: 1px solid var(--color-gold-deep); border-radius: 999px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--color-gold); background: rgba(201, 169, 97, 0.06); }
.beta-badge .live-dot { background: var(--color-gold); box-shadow: 0 0 8px rgba(201, 169, 97, 0.6); }

.beta-progress-wrap { max-width: 560px; margin: 56px auto 0; padding: 28px 32px; background: var(--color-surface); border: 1px solid var(--color-hairline-bright); border-radius: var(--border-radius-md); }
.beta-progress-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 16px; }
.beta-progress-label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--color-muted); }
.beta-progress-stat { font-family: var(--font-display-en); font-weight: 300; font-size: 32px; color: var(--color-cream); letter-spacing: -0.02em; }
.beta-progress-stat em { font-style: italic; color: var(--color-gold); font-weight: 200; }
.beta-progress-bar { width: 100%; height: 8px; background: var(--color-hairline); border-radius: 999px; overflow: hidden; position: relative; }
.beta-progress-fill { height: 100%; background: linear-gradient(90deg, var(--color-gold-deep) 0%, var(--color-gold) 60%, var(--color-gold-bright) 100%); border-radius: 999px; box-shadow: 0 0 16px rgba(201, 169, 97, 0.4); transition: width 1.2s var(--ease-out); }
.beta-progress-foot { display: flex; justify-content: space-between; margin-top: 14px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-muted); }
.beta-progress-foot span:last-child { color: var(--color-gold); }

/* Future pricing — faded tiers */
.future-pricing-sec .tiers-faded { opacity: 0.72; filter: saturate(0.6); }
.future-pricing-sec .tier .tier-amount { color: var(--color-cream-2); }
.future-pricing-sec .tier .tier-amount::after { content: ''; display: block; height: 2px; background: var(--color-faint); margin-top: -32px; margin-bottom: 14px; transform: rotate(-4deg); transform-origin: left; opacity: 0; }
.future-pricing-sec .tier .tier-name { color: var(--color-cream-2); font-style: italic; }
.future-pricing-sec .tier .tier-features li { color: var(--color-cream-2); }
.future-pricing-sec .tier .tier-features li::before { color: var(--color-gold-deep); }
.future-pricing-sec .tier.featured { background: var(--color-bg-elevated); }
.future-pricing-sec .tier.featured::before { opacity: 0.5; }
.future-pricing-sec .tier-tag { background: var(--color-gold-deep); color: var(--color-cream); }

/* Animations */
@keyframes fadeUp { from { opacity: 0; transform: translateY(24px); } to { opacity: 1; transform: translateY(0); } }
.hero-meta { animation: fadeUp 1s var(--ease-out) 0.1s backwards; }
.hero-title { animation: fadeUp 1.2s var(--ease-out) 0.25s backwards; }
.hero-body > div:first-child > * { animation: fadeUp 1s var(--ease-out) backwards; }
.hero-sub { animation-delay: 0.5s; }
.hero-cta { animation-delay: 0.65s; }
.hero-stats { animation-delay: 0.8s; }
.frame-card { animation: fadeUp 1.2s var(--ease-out) 0.7s backwards; }

/* Responsive */
@media (max-width: 980px) {
  /* Legacy nav rules removed in v1.38.0 · see new nav CSS at top */

  .hero-body, .product-hero-grid { grid-template-columns: 1fr; gap: 60px; }
  .sec-head { grid-template-columns: 1fr; gap: 28px; }
  .featured-grid, .tiers-grid, .method-grid, .footer-grid { grid-template-columns: 1fr; }
  .suite-grid { grid-template-columns: repeat(2, 1fr); }
  .hero-stats { grid-template-columns: repeat(2, 1fr); gap: 24px; }
  .hero-stat { border-right: 0; padding: 0; }
  .product-stats { grid-template-columns: repeat(2, 1fr); gap: 16px; padding: 16px 0; }
  .stat { border-right: 0; padding: 8px 0; }
  .sec { padding: 80px 0; }
  .manifesto, .cta-banner { padding: 90px 0; }
  .hero { padding: 60px 0 40px; }
  .container, .container-narrow, .container-wide { padding: 0 24px; }
  .feat-card { padding: 40px 32px; min-height: 320px; }
  .tier { padding: 44px 32px; }
  .pact-card { padding: 40px 28px; }
  .pact-steps { grid-template-columns: 1fr; gap: 40px; }
  .pact-step + .pact-step { padding-left: 0; padding-top: 40px; border-left: 0; border-top: 1px solid var(--color-hairline); }
  .pact-cols { grid-template-columns: 1fr; gap: 40px; }
  .product-gallery { grid-template-columns: 1fr; gap: 16px; }

  /* Lot Calc · responsive grids */
  .lot-features-grid { grid-template-columns: 1fr 1fr; gap: 14px; }
}

/* ════════════════════════════════════════════════════════════
   v1.36 · Market & News page · /market/
   ════════════════════════════════════════════════════════════ */

.market-hero { padding: 60px 0 32px; text-align: center; position: relative; }
.market-hero-eyebrow { display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; color: var(--color-gold-bright); margin-bottom: 18px; text-transform: uppercase; }
.market-live-dot { width: 8px; height: 8px; border-radius: 50%; background: #6dd49b; box-shadow: 0 0 12px rgba(109,212,155,0.60); animation: market-pulse 1.8s ease-in-out infinite; }
@keyframes market-pulse { 0%, 100% { opacity: 1; transform: scale(1); } 50% { opacity: 0.6; transform: scale(1.2); } }
.market-hero-title { font-family: var(--font-display-th); font-size: clamp(28px, 4vw, 44px); font-weight: 500; color: var(--color-cream); margin: 0 0 14px; line-height: 1.2; }
.market-hero-sub { font-size: 15px; color: var(--color-cream-2); max-width: 780px; margin: 0 auto; line-height: 1.7; }

.market-main { padding: 32px 0; }
.market-grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: 22px; }
.market-col-side { display: flex; flex-direction: column; gap: 22px; }

.market-card { padding: 0; background: var(--color-bg-elevated); border: 1px solid var(--color-gold-deep); border-radius: var(--border-radius-md); position: relative; overflow: hidden; }
.market-card-head { display: flex; justify-content: space-between; align-items: center; padding: 18px 22px 14px; border-bottom: 1px solid var(--color-hairline); flex-wrap: wrap; gap: 8px; }
.market-card-title { font-family: var(--font-display-th); font-size: 16px; font-weight: 500; color: var(--color-cream); margin: 0; display: flex; align-items: center; gap: 8px; }
.market-card-icon { font-size: 18px; }
.market-card-meta { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.10em; text-transform: uppercase; color: var(--color-muted); }
.market-widget-wrap { padding: 4px 8px 8px; }
.market-widget-wrap .tradingview-widget-container { min-height: 200px; }

@media (max-width: 980px) {
  .market-grid { grid-template-columns: 1fr; }
}

.market-stories, .market-heatmap, .market-note, .market-cta { padding: 32px 0; }
.market-section-head { margin-bottom: 22px; text-align: center; }
.market-section-title { font-family: var(--font-display-th); font-size: 24px; font-weight: 500; color: var(--color-cream); margin: 0 0 6px; }
.market-section-sub { font-size: 13px; color: var(--color-cream-2); margin: 0; }

.market-note-card { padding: 32px 36px; }
.market-note-title { font-family: var(--font-display-th); font-size: 20px; font-weight: 500; color: var(--color-gold-bright); margin: 0 0 24px; text-align: center; }
.market-note-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 24px; }
.market-note-item { padding: 16px 18px; background: rgba(0,0,0,0.30); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); }
.market-note-event { font-family: var(--font-display-th); font-size: 14px; font-weight: 500; color: var(--color-cream); margin-bottom: 6px; }
.market-note-impact { font-size: 11.5px; color: var(--color-cream-2); line-height: 1.6; }
.market-note-footer { padding: 14px 20px; background: rgba(201,169,97,0.06); border-left: 3px solid var(--color-gold-deep); border-radius: var(--border-radius-sm); font-size: 13px; color: var(--color-cream-2); margin: 0; line-height: 1.7; }
.market-note-footer strong { color: var(--color-gold-bright); font-weight: 500; }

@media (max-width: 780px) {
  .market-note-grid { grid-template-columns: 1fr; }
  .market-note-card { padding: 24px 20px; }
}

.market-cta-card { padding: 40px 36px; text-align: center; }
.market-cta-title { font-family: var(--font-display-th); font-size: 26px; font-weight: 500; color: var(--color-cream); margin: 0 0 8px; }
.market-cta-sub { font-size: 14px; color: var(--color-cream-2); margin: 0 0 20px; }
.market-cta-buttons { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* v1.40.0 · CTA benefit bullets */
.market-cta-benefits { list-style: none; padding: 0; margin: 0 auto 24px; display: inline-flex; flex-direction: column; gap: 8px; text-align: left; }
.market-cta-benefits li { font-size: 13px; color: var(--color-cream-2); font-family: var(--font-display-th); letter-spacing: 0.01em; }
@media (max-width: 700px) {
	.market-cta-benefits { font-size: 12.5px; text-align: center; align-items: flex-start; padding-left: 8px; }
}

/* ════════════════════════════════════════════════════════════
   v1.40.0 · Hero sources subline · secondary info under main subline
   ════════════════════════════════════════════════════════════ */
.market-hero-sources { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.08em; color: var(--color-muted); margin: 14px auto 0; max-width: 720px; text-transform: uppercase; }
@media (max-width: 700px) {
	.market-hero-sources { font-size: 9.5px; letter-spacing: 0.06em; padding: 0 14px; }
}

/* ════════════════════════════════════════════════════════════
   v1.40.2 · Hero CTA buttons · immediate conversion path
   ════════════════════════════════════════════════════════════ */
.market-hero-ctas { display: flex; gap: 14px; justify-content: center; margin-top: 24px; flex-wrap: wrap; }
.market-hero-cta {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	padding: 12px 22px;
	border-radius: var(--border-radius-sm);
	text-decoration: none;
	transition: all var(--duration-base);
	border: 1px solid transparent;
	min-width: 280px;
	text-align: left;
}
.market-hero-cta-icon { font-size: 22px; line-height: 1; flex-shrink: 0; }
.market-hero-cta-text { display: flex; flex-direction: column; gap: 2px; flex: 1; }
.market-hero-cta-label { font-family: var(--font-display-th); font-size: 14.5px; font-weight: 500; letter-spacing: 0.01em; }
.market-hero-cta-sub { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.04em; opacity: 0.80; }

.market-hero-cta-primary {
	background: linear-gradient(135deg, var(--color-gold-deep) 0%, var(--color-gold-bright) 100%);
	color: #1a1208;
	border-color: var(--color-gold-bright);
	box-shadow: 0 4px 16px rgba(229,196,120,0.25);
}
.market-hero-cta-primary:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(229,196,120,0.40);
}
.market-hero-cta-primary .market-hero-cta-sub { color: #2a1f0e; }

.market-hero-cta-ghost {
	background: rgba(0,0,0,0.30);
	color: var(--color-cream);
	border-color: var(--color-gold-deep);
}
.market-hero-cta-ghost:hover {
	border-color: var(--color-gold-bright);
	background: rgba(229,196,120,0.08);
	transform: translateY(-2px);
}
.market-hero-cta-ghost .market-hero-cta-sub { color: var(--color-muted); }

@media (max-width: 700px) {
	.market-hero-ctas { flex-direction: column; gap: 10px; padding: 0 16px; margin-top: 20px; }
	.market-hero-cta { width: 100%; min-width: 0; padding: 11px 16px; }
	.market-hero-cta-label { font-size: 13.5px; }
	.market-hero-cta-sub { font-size: 9.5px; }
}

/* ════════════════════════════════════════════════════════════
   v1.40.0 · Market Brief · auto-derived today summary · 3 cards
   ════════════════════════════════════════════════════════════ */
.market-brief { padding: 16px 0 8px; }
.market-brief-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.market-brief-card {
	padding: 16px 18px;
	background: rgba(0,0,0,0.30);
	border: 1px solid var(--color-hairline);
	border-radius: var(--border-radius-sm);
	border-left: 3px solid var(--color-gold-deep);
	transition: border-left-color var(--duration-base);
}
.market-brief-card:hover { border-left-color: var(--color-gold-bright); }
.market-brief-label {
	font-family: var(--font-mono);
	font-size: 10px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--color-muted);
	margin-bottom: 8px;
}
.market-brief-value {
	font-family: var(--font-display-en);
	font-size: 18px;
	color: var(--color-cream);
	letter-spacing: 0.01em;
	margin-bottom: 6px;
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
}
.market-brief-high { color: #d65a52; font-weight: 700; }
.market-brief-med  { color: #d9963d; font-weight: 700; }
.market-brief-low  { color: #c9a961; font-weight: 600; }
.market-brief-quiet { color: var(--color-muted); font-size: 14px; }
.market-brief-session { color: var(--color-gold-bright); }
.market-brief-pips { color: var(--color-gold-bright); font-weight: 600; font-family: var(--font-mono); font-size: 17px; letter-spacing: 0.02em; }
.market-brief-sub { font-family: var(--font-display-th); font-size: 11.5px; color: var(--color-cream-2); line-height: 1.5; }
.market-brief-sub strong { color: var(--color-gold-bright); font-family: var(--font-mono); }

@media (max-width: 900px) {
	.market-brief-grid { grid-template-columns: 1fr; gap: 10px; }
	.market-brief-card { padding: 14px 16px; }
}

/* v1.40.1 · "(ทุกสกุล)" scope note in Events card */
.market-brief-scope { font-size: 10px; color: var(--color-muted); font-weight: 400; letter-spacing: 0.04em; margin-left: 4px; }

/* ════════════════════════════════════════════════════════════
   v1.40.1 · Trading Sessions overlay bar · 24h band with NOW marker
   ════════════════════════════════════════════════════════════ */
.market-sessions { padding: 4px 0 20px; }
.market-sessions-card {
	padding: 18px 22px 22px;
	background: rgba(0,0,0,0.30);
	border: 1px solid var(--color-hairline);
	border-radius: var(--border-radius-sm);
}
.market-sessions-head { display: flex; align-items: baseline; gap: 14px; margin-bottom: 14px; flex-wrap: wrap; }
.market-sessions-title { font-family: var(--font-display-th); font-size: 15px; font-weight: 500; color: var(--color-cream); }
.market-sessions-sub { font-size: 11.5px; color: var(--color-cream-2); }

.market-sessions-axis {
	display: grid;
	grid-template-columns: repeat(13, 1fr);
	font-family: var(--font-mono);
	font-size: 9.5px;
	color: var(--color-muted);
	letter-spacing: 0.08em;
	padding: 0 0 6px;
}
.market-sessions-axis span { text-align: center; }
.market-sessions-axis span:first-child { text-align: left; }
.market-sessions-axis span:last-child { text-align: right; }

.market-sessions-track {
	position: relative;
	height: 86px;
	background: linear-gradient(180deg, rgba(0,0,0,0.40) 0%, rgba(0,0,0,0.20) 100%);
	border: 1px solid var(--color-hairline);
	border-radius: var(--border-radius-sm);
	overflow: hidden;
}
.market-sessions-band {
	position: absolute;
	height: 22px;
	display: flex;
	align-items: center;
	padding: 0 10px;
	font-family: var(--font-mono);
	font-size: 9.5px;
	letter-spacing: 0.08em;
	color: var(--color-cream);
	border-radius: 2px;
	overflow: hidden;
	white-space: nowrap;
}
.market-sessions-band-label { font-weight: 600; }

.market-sessions-band-tokyo  { top: 8px;  background: rgba(229,148,77,0.20); border: 1px solid rgba(229,148,77,0.45); }
.market-sessions-band-london { top: 33px; background: rgba(120,162,201,0.20); border: 1px solid rgba(120,162,201,0.45); }
.market-sessions-band-ny     { top: 58px; background: rgba(168,123,191,0.20); border: 1px solid rgba(168,123,191,0.45); }

/* Overlap zone · London + NY · highlight for gold volatility */
.market-sessions-overlap {
	position: absolute;
	top: 0;
	bottom: 0;
	background: linear-gradient(180deg, rgba(229,196,120,0.12) 0%, rgba(229,196,120,0.04) 100%);
	border-left: 1px dashed rgba(229,196,120,0.40);
	border-right: 1px dashed rgba(229,196,120,0.40);
	pointer-events: none;
}

/* NOW marker · vertical gold line + pill label */
.market-sessions-now {
	position: absolute;
	top: -4px;
	bottom: -4px;
	width: 0;
	border-left: 2px solid var(--color-gold-bright);
	box-shadow: 0 0 8px rgba(229,196,120,0.50);
	z-index: 5;
	pointer-events: none;
	transition: left var(--duration-base);
}
.market-sessions-now-label {
	position: absolute;
	top: -22px;
	left: 50%;
	transform: translateX(-50%);
	white-space: nowrap;
	font-family: var(--font-mono);
	font-size: 9px;
	letter-spacing: 0.08em;
	color: #000;
	background: var(--color-gold-bright);
	padding: 3px 8px;
	border-radius: 999px;
	font-weight: 700;
}

.market-sessions-legend { display: flex; gap: 18px; margin-top: 14px; flex-wrap: wrap; font-size: 11px; color: var(--color-cream-2); }
.market-sessions-legend-item { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-display-th); }
.market-sessions-legend .dot { width: 8px; height: 8px; border-radius: 2px; display: inline-block; }
.market-sessions-legend .dot-tokyo  { background: rgba(229,148,77,0.60); }
.market-sessions-legend .dot-london { background: rgba(120,162,201,0.60); }
.market-sessions-legend .dot-ny     { background: rgba(168,123,191,0.60); }

@media (max-width: 700px) {
	.market-sessions-card { padding: 14px 14px 16px; }
	.market-sessions-head { gap: 6px; margin-bottom: 10px; }
	.market-sessions-title { font-size: 14px; }
	.market-sessions-sub { font-size: 10.5px; }
	.market-sessions-axis { font-size: 8.5px; }
	.market-sessions-track { height: 80px; }
	.market-sessions-band { height: 18px; padding: 0 6px; font-size: 8.5px; }
	.market-sessions-band-tokyo  { top: 6px; }
	.market-sessions-band-london { top: 28px; }
	.market-sessions-band-ny     { top: 50px; }
	.market-sessions-band-label { font-size: 8.5px; }
	.market-sessions-now-label { font-size: 8.5px; padding: 2px 6px; top: -20px; }
	.market-sessions-legend { gap: 10px; font-size: 10.5px; margin-top: 10px; }
}

/* ════════════════════════════════════════════════════════════
   v1.40.1 · Date range filter chips
   ════════════════════════════════════════════════════════════ */
.market-cal-daterange {
	padding: 5px 12px;
	background: rgba(0,0,0,0.30);
	border: 1px solid var(--color-hairline);
	border-radius: var(--border-radius-sm);
	color: var(--color-cream-2);
	font-size: 12px;
	font-family: var(--font-display-th);
	letter-spacing: 0.01em;
	cursor: pointer;
	transition: all var(--duration-base);
}
.market-cal-daterange:hover { color: var(--color-gold-bright); border-color: var(--color-gold-deep); }
.market-cal-daterange.is-active { background: rgba(201,169,97,0.18); border-color: var(--color-gold-bright); color: var(--color-gold-bright); }

/* v1.40.2 · positioning bullets · "why AuHunter" preamble above grid */
.market-helps-why {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 10px 24px;
	margin-bottom: 28px;
	padding: 18px 22px;
	background: linear-gradient(180deg, rgba(229,196,120,0.05) 0%, rgba(0,0,0,0.20) 100%);
	border: 1px solid var(--color-hairline);
	border-left: 3px solid var(--color-gold-bright);
	border-radius: var(--border-radius-sm);
}
.market-helps-why-item { font-family: var(--font-display-th); font-size: 13.5px; color: var(--color-cream-2); line-height: 1.6; }
.market-helps-why-item strong { color: var(--color-gold-bright); }
@media (max-width: 700px) {
	.market-helps-why { grid-template-columns: 1fr; padding: 14px 16px; gap: 8px; }
	.market-helps-why-item { font-size: 12.5px; }
}

/* v1.40.2 · Inline mini disclaimer near CTA */
.market-cta-mini-disclaimer {
	margin: 18px 0 0;
	font-size: 11px;
	color: var(--color-muted);
	font-family: var(--font-display-th);
	letter-spacing: 0.01em;
	line-height: 1.5;
}

/* v1.40.2 · Mobile spacing polish · breathing room between sections */
@media (max-width: 700px) {
	.market-section-title { font-size: 19px !important; letter-spacing: 0.005em; }
	.market-section-sub { font-size: 12px !important; }
	.market-helps,
	.market-stories,
	.market-heatmap,
	.market-faq,
	.market-cta { padding-top: 28px !important; padding-bottom: 28px !important; }
	.market-helps-card { padding: 16px 14px; }
}

/* ════════════════════════════════════════════════════════════
   v1.40.0 · "AuHunter ช่วยอะไร" · transparency · IB disclosure
   ════════════════════════════════════════════════════════════ */
.market-helps { padding: 40px 0; }
.market-helps-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.market-helps-card {
	padding: 22px 20px;
	background: rgba(0,0,0,0.30);
	border: 1px solid var(--color-hairline);
	border-radius: var(--border-radius-sm);
	transition: transform var(--duration-base), border-color var(--duration-base);
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.market-helps-card:hover { transform: translateY(-3px); border-color: var(--color-gold-deep); }
.market-helps-card-highlight {
	border-color: var(--color-gold-deep);
	background: linear-gradient(180deg, rgba(229,196,120,0.06) 0%, rgba(0,0,0,0.30) 100%);
}
.market-helps-icon { font-size: 28px; line-height: 1; }
.market-helps-title { font-family: var(--font-display-th); font-size: 16px; font-weight: 500; color: var(--color-cream); }
.market-helps-text { font-size: 13px; color: var(--color-cream-2); line-height: 1.6; flex: 1; }
.market-helps-text strong { color: var(--color-gold-bright); }
.market-helps-link {
	display: inline-block;
	margin-top: 6px;
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: 0.05em;
	color: var(--color-gold-bright);
	text-decoration: none;
	border-bottom: 1px solid var(--color-gold-deep);
	padding-bottom: 2px;
	align-self: flex-start;
}
.market-helps-link:hover { color: var(--color-cream); border-color: var(--color-gold-bright); }

.market-helps-disclosure {
	margin-top: 24px;
	padding: 14px 18px;
	background: rgba(0,0,0,0.25);
	border: 1px solid var(--color-hairline);
	border-left: 3px solid var(--color-gold-bright);
	border-radius: var(--border-radius-sm);
	font-size: 12px;
	color: var(--color-cream-2);
	line-height: 1.7;
}
.market-helps-disclosure strong { color: var(--color-gold-bright); font-family: var(--font-mono); letter-spacing: 0.04em; }

@media (max-width: 900px) {
	.market-helps-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
}
@media (max-width: 600px) {
	.market-helps-grid { grid-template-columns: 1fr; }
	.market-helps-card { padding: 18px 16px; }
}

/* ════════════════════════════════════════════════════════════
   v1.40.0 · Risk Disclaimer · ad-safe · regulator-friendly
   ════════════════════════════════════════════════════════════ */
.market-disclaimer { padding: 8px 0 24px; }
.market-disclaimer-box {
	display: flex;
	gap: 14px;
	padding: 16px 20px;
	background: rgba(184,84,80,0.06);
	border: 1px solid rgba(184,84,80,0.30);
	border-radius: var(--border-radius-sm);
	align-items: flex-start;
}
.market-disclaimer-icon { font-size: 22px; line-height: 1.2; flex-shrink: 0; }
.market-disclaimer-text { font-size: 12px; color: var(--color-cream-2); line-height: 1.75; font-family: var(--font-display-th); }
.market-disclaimer-text strong { color: #d6837e; }

@media (max-width: 700px) {
	.market-disclaimer-box { padding: 14px 16px; gap: 10px; }
	.market-disclaimer-icon { font-size: 18px; }
	.market-disclaimer-text { font-size: 11.5px; line-height: 1.7; }
}

/* ════════════════════════════════════════════════════════════
   v1.40.0 · "NOW" marker · horizontal line in calendar at current time
   ════════════════════════════════════════════════════════════ */
.market-cal-now-marker { background: transparent; }
.market-cal-now-marker-cell {
	padding: 0 !important;
	border: none !important;
	background: transparent !important;
	display: flex !important;
	align-items: center !important;
	gap: 10px;
	height: 18px;
}
.market-cal-now-marker-line {
	flex: 1;
	height: 1px;
	background: linear-gradient(90deg, transparent 0%, var(--color-gold-bright) 30%, var(--color-gold-bright) 70%, transparent 100%);
	opacity: 0.7;
}
.market-cal-now-marker-label {
	font-family: var(--font-mono);
	font-size: 10px;
	letter-spacing: 0.10em;
	color: var(--color-gold-bright);
	text-transform: uppercase;
	padding: 2px 10px;
	background: rgba(229,196,120,0.10);
	border: 1px solid var(--color-gold-deep);
	border-radius: 999px;
	flex-shrink: 0;
}

/* On mobile (table → block layout), the marker row needs explicit block display */
@media (max-width: 900px) {
	.market-cal-now-marker { display: block; padding: 6px 0; }
	.market-cal-now-marker-cell { display: flex !important; padding: 0 14px !important; height: 22px; }
}

/* ════════════════════════════════════════════════════════════
   v1.40.0 · Past event styling · clearer than just opacity
   ════════════════════════════════════════════════════════════ */
.market-cal-event.is-past { opacity: 0.50; }
.market-cal-event.is-past .market-cal-event-title { text-decoration: line-through; text-decoration-color: rgba(255,255,255,0.30); text-decoration-thickness: 1px; }
.market-cal-event.is-past:hover { opacity: 0.85; }
.market-cal-event.is-past:hover .market-cal-event-title { text-decoration-color: rgba(255,255,255,0.50); }

/* ════════════════════════════════════════════════════════════
   v1.36.1 · Market · Impact Guide · FF-style colored boxes
   ════════════════════════════════════════════════════════════ */

.market-impact-guide { padding: 32px 0; }

.impact-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 24px; }

.impact-box { padding: 20px 22px; position: relative; transition: transform var(--duration-base); }
.impact-box:hover { transform: translateY(-3px); }

.impact-box-head { display: flex; align-items: center; gap: 14px; margin-bottom: 16px; padding-bottom: 14px; border-bottom: 1px solid var(--color-hairline); }

/* ForexFactory-style folder icon · CSS-only */
.impact-folder { width: 32px; height: 26px; border-radius: 2px 2px 4px 4px; position: relative; flex-shrink: 0; }
.impact-folder::before { content: ''; position: absolute; top: -5px; left: 4px; width: 12px; height: 6px; border-radius: 2px 2px 0 0; }
.impact-folder::after { content: ''; position: absolute; inset: 0; border-radius: 2px 2px 4px 4px; background: linear-gradient(180deg, rgba(255,255,255,0.15) 0%, transparent 30%); }

.impact-folder-red { background: #c0392b; }
.impact-folder-red::before { background: #a83229; }
.impact-folder-orange { background: #e67e22; }
.impact-folder-orange::before { background: #c96a1c; }
.impact-folder-yellow { background: #f1c40f; }
.impact-folder-yellow::before { background: #d4ac0d; }
.impact-folder-gray { background: #95a5a6; }
.impact-folder-gray::before { background: #7f8c8d; }

.impact-level { font-family: var(--font-mono); font-size: 14px; font-weight: 600; letter-spacing: 0.10em; color: var(--color-cream); }
.impact-color-name { font-family: var(--font-display-th); font-size: 12px; color: var(--color-cream-2); margin-top: 2px; }

.impact-red    { border-color: rgba(192, 57, 43, 0.50); }
.impact-orange { border-color: rgba(230, 126, 34, 0.50); }
.impact-yellow { border-color: rgba(241, 196, 15, 0.50); }
.impact-gray   { border-color: rgba(149, 165, 166, 0.50); }

.impact-red    .impact-level { color: #ff6b5a; }
.impact-orange .impact-level { color: #f4a458; }
.impact-yellow .impact-level { color: #f5d547; }
.impact-gray   .impact-level { color: #bdc3c7; }

.impact-pips { font-size: 13px; color: var(--color-cream); margin-bottom: 8px; line-height: 1.5; }
.impact-pips strong { color: var(--color-gold-bright); font-weight: 600; }

.impact-warning { font-size: 11px; color: var(--color-cream-2); margin-bottom: 14px; padding: 6px 10px; background: rgba(0,0,0,0.25); border-radius: var(--border-radius-sm); border-left: 2px solid var(--color-gold-deep); }

.impact-events { list-style: none; padding: 0; margin: 0; }
.impact-events li { padding: 5px 0; font-size: 12px; color: var(--color-cream-2); border-bottom: 1px solid var(--color-hairline); }
.impact-events li:last-child { border-bottom: 0; }

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

/* Tips Table */
.impact-tips-card { padding: 26px 30px; }
.impact-tips-title { font-family: var(--font-display-th); font-size: 18px; font-weight: 500; color: var(--color-gold-bright); margin: 0 0 16px; text-align: center; }
.impact-tips-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.impact-tips-table thead th { padding: 10px 14px; text-align: left; background: rgba(0,0,0,0.30); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.10em; text-transform: uppercase; color: var(--color-muted); border-bottom: 1px solid var(--color-gold-deep); }
.impact-tips-table tbody td { padding: 12px 14px; border-bottom: 1px solid var(--color-hairline); color: var(--color-cream-2); line-height: 1.6; }
.impact-tips-table tbody tr:last-child td { border-bottom: 0; }
.impact-tips-table tbody tr:hover { background: rgba(255,255,255,0.02); }
.impact-tips-table tbody td:first-child { color: var(--color-cream); font-weight: 500; white-space: nowrap; }

.impact-tips-footer { margin: 18px 0 0; padding: 14px 18px; background: rgba(201,169,97,0.06); border-left: 3px solid var(--color-gold-deep); border-radius: var(--border-radius-sm); font-size: 13px; color: var(--color-cream-2); line-height: 1.7; }
.impact-tips-footer strong { color: var(--color-gold-bright); font-weight: 500; }

@media (max-width: 700px) {
  .impact-tips-card { padding: 20px 16px; }
  .impact-tips-table { font-size: 12px; }
  .impact-tips-table tbody td { padding: 10px 8px; }
}

/* ════════════════════════════════════════════════════════════
   v1.36.2 · Custom Economic Calendar · FF data + colored folders
   ════════════════════════════════════════════════════════════ */

.market-cal-controls { padding: 14px 18px; border-bottom: 1px solid var(--color-hairline); display: flex; flex-direction: column; gap: 12px; }
.market-cal-tabs { display: flex; gap: 6px; }
.market-cal-tab { padding: 7px 16px; background: rgba(0,0,0,0.30); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); color: var(--color-cream-2); font-family: var(--font-display-th); font-size: 12.5px; text-decoration: none; transition: all var(--duration-base); }
.market-cal-tab:hover { color: var(--color-gold-bright); border-color: var(--color-gold-deep); }
.market-cal-tab.is-active { background: rgba(201,169,97,0.18); border-color: var(--color-gold-bright); color: var(--color-gold-bright); }

.market-cal-filters { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.market-cal-filter-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-muted); margin-right: 4px; }
.market-cal-filter { padding: 5px 12px; background: rgba(0,0,0,0.30); border: 1px solid var(--color-hairline); border-radius: 999px; color: var(--color-cream-2); font-size: 11.5px; cursor: pointer; transition: all var(--duration-base); display: inline-flex; align-items: center; gap: 4px; }
.market-cal-filter:hover { border-color: var(--color-gold-deep); color: var(--color-cream); }
.market-cal-filter.is-active { background: rgba(201,169,97,0.15); border-color: var(--color-gold-bright); color: var(--color-gold-bright); }

.market-cal-scroll { overflow-x: auto; }
.market-cal-table { width: 100%; border-collapse: collapse; font-size: 12.5px; min-width: 720px; }
.market-cal-table thead th { padding: 11px 10px; text-align: left; background: rgba(0,0,0,0.30); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.10em; text-transform: uppercase; color: var(--color-muted); border-bottom: 1px solid var(--color-gold-deep); white-space: nowrap; font-weight: 500; }
.market-cal-table thead th.col-num { text-align: right; }
.market-cal-table thead th.col-impact { text-align: center; width: 60px; }
.market-cal-table thead th.col-time { width: 70px; }
.market-cal-table thead th.col-cur { width: 80px; }

.market-cal-date-row td { padding: 12px 14px; background: linear-gradient(90deg, rgba(201,169,97,0.10) 0%, rgba(201,169,97,0.02) 100%); font-family: var(--font-display-th); font-size: 13.5px; font-weight: 500; color: var(--color-gold-bright); border-top: 1px solid var(--color-gold-deep); border-bottom: 1px solid var(--color-hairline); letter-spacing: 0.02em; }
.market-cal-date-row.is-today td { background: linear-gradient(90deg, rgba(229,196,120,0.20) 0%, rgba(229,196,120,0.05) 100%); }
.market-cal-date-row.is-today strong { color: #fff; padding: 2px 8px; background: var(--color-gold-bright); color: #000 !important; border-radius: 4px; font-size: 11px; margin-left: 6px; }

.market-cal-event td { padding: 10px 10px; border-bottom: 1px solid var(--color-hairline); color: var(--color-cream-2); vertical-align: middle; }
.market-cal-event:hover td { background: rgba(255,255,255,0.025); }
.market-cal-event.is-past td { opacity: 0.55; }

.market-cal-time { font-family: var(--font-mono); color: var(--color-cream) !important; white-space: nowrap; font-size: 12px; }
.market-cal-cur { font-family: var(--font-mono); font-size: 11.5px; font-weight: 500; color: var(--color-cream) !important; white-space: nowrap; letter-spacing: 0.05em; }
.market-cal-flag { font-size: 14px; margin-right: 4px; }

.market-cal-impact { text-align: center; }
.market-cal-impact .impact-folder { display: inline-block; width: 22px; height: 18px; }

.market-cal-event-name { color: var(--color-cream) !important; font-size: 12.5px; line-height: 1.4; }
.market-cal-num { text-align: right; font-family: var(--font-mono); font-size: 11.5px; white-space: nowrap; }
.market-cal-prev { color: var(--color-muted) !important; }
.market-cal-actual { color: var(--color-gold-bright) !important; font-weight: 600; }

.market-cal-footer { padding: 12px 18px; border-top: 1px solid var(--color-hairline); display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 10px; color: var(--color-muted); letter-spacing: 0.05em; flex-wrap: wrap; gap: 8px; }
.market-cal-error { padding: 30px 24px; text-align: center; color: var(--color-cream-2); }
.market-cal-error p { font-size: 14px; margin: 0 0 8px; }
.market-cal-error small { display: block; color: var(--color-muted); font-family: var(--font-mono); font-size: 11px; line-height: 1.6; }

/* ════════════════════════════════════════════════════════════
   v1.39.0 · Signal indicator + click-to-expand detail panel
   ════════════════════════════════════════════════════════════ */

/* Make event row clickable */
.market-cal-event { cursor: pointer; transition: background var(--duration-base); }
.market-cal-event:focus-visible { outline: 2px solid var(--color-gold-bright); outline-offset: -2px; }
.market-cal-event.is-expanded { background: rgba(201,169,97,0.06); }
.market-cal-event.is-expanded .market-cal-expand { transform: rotate(180deg); color: var(--color-gold-bright); }

/* Expand chevron · in event name cell */
.market-cal-event-title { display: inline; }
.market-cal-expand {
	display: inline-block;
	margin-left: 6px;
	font-size: 10px;
	color: var(--color-muted);
	transition: transform var(--duration-base), color var(--duration-base);
	vertical-align: 1px;
}
.market-cal-event:hover .market-cal-expand { color: var(--color-gold-deep); }

/* Signal arrow next to time · only visible when event released */
.market-cal-signal {
	display: inline-block;
	margin-left: 5px;
	font-size: 9px;
	font-weight: 700;
	letter-spacing: -0.02em;
	vertical-align: 1px;
}
.market-cal-signal-beat     { color: var(--color-bull); }
.market-cal-signal-miss     { color: var(--color-bear); }
.market-cal-signal-met      { color: var(--color-gold-bright); }
.market-cal-signal-released { color: var(--color-cream-2); }

/* Actual cell · color based on signal (desktop view) */
.market-cal-actual-beat     { color: var(--color-bull) !important; font-weight: 700; }
.market-cal-actual-miss     { color: var(--color-bear) !important; font-weight: 700; }
.market-cal-actual-met      { color: var(--color-gold-bright) !important; font-weight: 700; }
.market-cal-actual-released { color: var(--color-cream) !important; font-weight: 600; }
.market-cal-actual-pending  { color: var(--color-muted) !important; }

/* ─── Detail panel · expanded row content ─── */
/* v1.39.1 · [hidden] must beat any display:block override (mobile rule sets display:block) */
.market-cal-detail[hidden] { display: none !important; }
.market-cal-detail { background: rgba(0,0,0,0.30); border-bottom: 1px solid var(--color-gold-deep); }
.market-cal-detail-cell { padding: 0; }
.market-cal-detail-inner { padding: 18px 22px; display: flex; flex-direction: column; gap: 14px; }

.market-cal-detail-head { display: flex; flex-direction: column; gap: 4px; }
.market-cal-detail-title { font-family: var(--font-display-en); font-size: 16px; color: var(--color-cream); display: flex; align-items: center; gap: 8px; letter-spacing: 0.01em; }
.market-cal-detail-flag { font-size: 18px; line-height: 1; }
.market-cal-detail-meta { font-family: var(--font-mono); font-size: 11px; color: var(--color-muted); letter-spacing: 0.04em; }
.market-cal-detail-meta .market-cal-detail-impact-high     { color: #d65a52; font-weight: 600; }
.market-cal-detail-meta .market-cal-detail-impact-medium   { color: #d9963d; font-weight: 600; }
.market-cal-detail-meta .market-cal-detail-impact-low      { color: #c9a961; font-weight: 600; }
.market-cal-detail-meta .market-cal-detail-impact-holiday  { color: var(--color-muted); }

/* 3-column stat grid · Forecast | Previous | Actual */
.market-cal-detail-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.market-cal-stat {
	padding: 12px 10px;
	background: rgba(0,0,0,0.35);
	border: 1px solid var(--color-hairline);
	border-radius: var(--border-radius-sm);
	text-align: center;
}
.market-cal-stat-label {
	font-family: var(--font-mono);
	font-size: 9px;
	letter-spacing: 0.10em;
	text-transform: uppercase;
	color: var(--color-muted);
	margin-bottom: 5px;
}
.market-cal-stat-val { font-family: var(--font-mono); font-size: 16px; font-weight: 600; color: var(--color-cream); letter-spacing: 0.02em; }
.market-cal-stat-glyph { font-size: 13px; margin-left: 3px; vertical-align: 1px; }
.market-cal-stat-pending { color: var(--color-muted); font-size: 15px; }

/* Stat actual · colored by signal */
.market-cal-stat-actual-beat     { background: rgba(107,163,115,0.10); border-color: var(--color-bull); }
.market-cal-stat-actual-beat     .market-cal-stat-val,
.market-cal-stat-actual-beat     .market-cal-stat-glyph { color: var(--color-bull); }
.market-cal-stat-actual-miss     { background: rgba(184,84,80,0.10); border-color: var(--color-bear); }
.market-cal-stat-actual-miss     .market-cal-stat-val,
.market-cal-stat-actual-miss     .market-cal-stat-glyph { color: var(--color-bear); }
.market-cal-stat-actual-met      { background: rgba(201,169,97,0.10); border-color: var(--color-gold-bright); }
.market-cal-stat-actual-met      .market-cal-stat-val { color: var(--color-gold-bright); }
.market-cal-stat-actual-released { border-color: var(--color-gold-deep); }
.market-cal-stat-actual-pending  { background: rgba(255,255,255,0.02); }

/* Verdict line · "BEAT · Actual +2.0 เทียบ Forecast" */
.market-cal-detail-verdict {
	padding: 10px 14px;
	border-radius: var(--border-radius-sm);
	font-family: var(--font-display-th);
	font-size: 13px;
	letter-spacing: 0.01em;
}
.market-cal-detail-verdict strong { font-weight: 700; margin-right: 4px; }
.market-cal-detail-verdict-beat     { background: rgba(107,163,115,0.10); color: var(--color-bull); border-left: 3px solid var(--color-bull); }
.market-cal-detail-verdict-miss     { background: rgba(184,84,80,0.10); color: var(--color-bear); border-left: 3px solid var(--color-bear); }
.market-cal-detail-verdict-met      { background: rgba(201,169,97,0.10); color: var(--color-gold-bright); border-left: 3px solid var(--color-gold-bright); }
.market-cal-detail-verdict-released { background: rgba(255,255,255,0.03); color: var(--color-cream-2); border-left: 3px solid var(--color-cream-2); }
.market-cal-detail-verdict-pending  { background: rgba(255,255,255,0.02); color: var(--color-cream-2); border-left: 3px solid var(--color-gold-deep); }

/* XAUUSD impact line */
.market-cal-detail-impact {
	display: flex; align-items: center; gap: 10px;
	padding: 10px 14px;
	background: rgba(229,196,120,0.05);
	border: 1px solid var(--color-gold-deep);
	border-radius: var(--border-radius-sm);
	font-family: var(--font-display-th);
	font-size: 12.5px;
	color: var(--color-cream-2);
	line-height: 1.5;
}
.market-cal-detail-impact .impact-folder { width: 16px; height: 13px; flex-shrink: 0; }
.market-cal-detail-impact strong { color: var(--color-gold-bright); }

/* Actions row · Google News link */
.market-cal-detail-actions { display: flex; justify-content: flex-end; }
.market-cal-detail-link {
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: 0.05em;
	color: var(--color-gold-bright);
	text-decoration: none;
	padding: 6px 12px;
	border: 1px solid var(--color-gold-deep);
	border-radius: 999px;
	transition: all var(--duration-base);
}
.market-cal-detail-link:hover { background: rgba(229,196,120,0.10); border-color: var(--color-gold-bright); }

/* ─── Tablet · 901-1024px · hide Star + Forecast + Previous · keep Actual ─── */
@media (max-width: 1024px) and (min-width: 901px) {
	.market-cal-table { min-width: 0; }
	.market-cal-event td:nth-child(1),
	.market-cal-event td:nth-child(6),
	.market-cal-event td:nth-child(7),
	.market-cal-table thead th:nth-child(1),
	.market-cal-table thead th:nth-child(6),
	.market-cal-table thead th:nth-child(7) { display: none; }
	.market-cal-event td { padding: 9px 6px; }
}

/* ─── Mobile · ≤900px · ForexFactory-style grid layout ─── */
/* v1.38.6 · Convert table → CSS Grid on mobile · eliminates ALL table-layout:fixed conflicts
   (th-vs-td width hijack, hidden-cells-taking-space, mid-word break, header overlap) */
@media (max-width: 900px) {
	.market-cal-scroll { overflow-x: visible; }
	.market-cal-table { display: block; min-width: 0; width: 100%; font-size: 12px; border-collapse: separate; }

	/* Hide thead entirely on mobile · ForexFactory style */
	.market-cal-table thead { display: none !important; }
	.market-cal-table tbody { display: block; width: 100%; }

	/* Date row · full-width banner */
	.market-cal-date-row { display: block; }
	.market-cal-date-row td { display: block; padding: 11px 14px; font-size: 13px; }

	/* Event row · 4-col grid: time | cur | impact | event-name */
	.market-cal-event {
		display: grid;
		grid-template-columns: 52px 62px 36px 1fr;
		align-items: center;
		border-bottom: 1px solid var(--color-hairline);
	}
	.market-cal-event:hover { background: rgba(255,255,255,0.025); }
	.market-cal-event.is-past { opacity: 0.55; }

	/* Hide unused cells · star (1), forecast (6), previous (7), actual (8)
	   With grid: display:none removes from layout entirely · zero residual space */
	.market-cal-event td:nth-child(1),
	.market-cal-event td:nth-child(6),
	.market-cal-event td:nth-child(7),
	.market-cal-event td:nth-child(8) { display: none !important; }

	/* Visible cells · flex inside for vertical centering */
	.market-cal-event td {
		display: flex;
		align-items: center;
		padding: 11px 4px;
		border-bottom: none;
		min-width: 0;
		color: var(--color-cream-2);
		vertical-align: middle;
	}

	.market-cal-time {
		font-family: var(--font-mono);
		font-size: 11.5px;
		white-space: nowrap;
		color: var(--color-cream) !important;
	}
	.market-cal-cur {
		font-family: var(--font-mono);
		font-size: 10.5px;
		color: var(--color-cream) !important;
		padding-left: 4px;
		white-space: nowrap;
		letter-spacing: 0.03em;
	}
	.market-cal-cur .market-cal-flag { font-size: 13px; margin-right: 3px; }
	.market-cal-impact { justify-content: center; padding: 11px 0; }
	.market-cal-impact .impact-folder { width: 18px; height: 14px; }
	.market-cal-event-name {
		font-size: 12px;
		line-height: 1.4;
		color: var(--color-cream) !important;
		word-break: keep-all;
		overflow-wrap: break-word;
		padding-left: 8px;
		padding-right: 6px;
		display: block;
	}
	.market-cal-date-row.is-today strong { font-size: 10px; padding: 1px 6px; }

	/* v1.39.0 · detail row · block layout on mobile (parent table is display:block) */
	.market-cal-detail { display: block; width: 100%; }
	.market-cal-detail-cell { display: block; padding: 0; }
	.market-cal-detail-inner { padding: 14px 14px 16px; gap: 12px; }
	.market-cal-detail-title { font-size: 14.5px; }
	.market-cal-detail-flag { font-size: 16px; }
	.market-cal-detail-meta { font-size: 10.5px; }
	.market-cal-detail-stats { gap: 6px; }
	.market-cal-stat { padding: 10px 6px; }
	.market-cal-stat-label { font-size: 8.5px; margin-bottom: 4px; }
	.market-cal-stat-val { font-size: 14px; }
	.market-cal-stat-glyph { font-size: 11px; }
	.market-cal-detail-verdict { font-size: 12px; padding: 9px 12px; }
	.market-cal-detail-impact { font-size: 11.5px; padding: 9px 12px; }
	.market-cal-detail-link { font-size: 10.5px; padding: 5px 10px; }

	/* Compact: hide expand chevron on mobile (whole row clickable so chevron is redundant) */
	.market-cal-expand { font-size: 9px; margin-left: 4px; }
}

/* ─── Very small · ≤380px · tighter grid ─── */
@media (max-width: 380px) {
	.market-cal-event { grid-template-columns: 46px 54px 30px 1fr; }
	.market-cal-event td { padding: 10px 3px; }
	.market-cal-time { font-size: 11px; }
	.market-cal-cur { font-size: 10px; padding-left: 2px; }
	.market-cal-cur .market-cal-flag { font-size: 12px; }
	.market-cal-impact .impact-folder { width: 16px; height: 13px; }
	.market-cal-event-name { font-size: 11.5px; padding-left: 6px; }
}

/* Folder icons inside filter buttons · smaller */
.market-cal-filter .impact-folder { transform: scale(0.85); }

/* ════════════════════════════════════════════════════════════
   v1.36.3 · Currency filter pills · multi-select
   ════════════════════════════════════════════════════════════ */

.market-cur-pill { padding: 5px 11px; background: rgba(0,0,0,0.30); border: 1px solid var(--color-hairline); border-radius: 999px; color: var(--color-cream-2); font-size: 11.5px; font-family: var(--font-mono); letter-spacing: 0.04em; cursor: pointer; transition: all var(--duration-base); display: inline-flex; align-items: center; gap: 4px; }
.market-cur-pill:hover { border-color: var(--color-gold-deep); color: var(--color-cream); }
.market-cur-pill.is-active { background: rgba(201,169,97,0.15); border-color: var(--color-gold-bright); color: var(--color-gold-bright); }

/* Quick preset button · highlighted slightly more */
.market-cal-cur-quick { padding: 5px 12px; background: rgba(229,196,120,0.06); border: 1px solid var(--color-gold-deep); border-radius: 999px; color: var(--color-gold-bright); font-size: 11.5px; cursor: pointer; transition: all var(--duration-base); display: inline-flex; align-items: center; gap: 4px; margin-left: 8px; }
.market-cal-cur-quick:hover { background: rgba(229,196,120,0.15); border-color: var(--color-gold-bright); }

/* ════════════════════════════════════════════════════════════
   v1.36.4 · Timezone selector dropdown
   ════════════════════════════════════════════════════════════ */

.market-cal-toprow { display: flex; justify-content: space-between; align-items: center; gap: 12px; flex-wrap: wrap; }
.market-cal-tz-wrap { display: flex; align-items: center; gap: 8px; }
.market-cal-tz-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-muted); }
.market-cal-tz-select { padding: 6px 28px 6px 12px; background: rgba(0,0,0,0.40); border: 1px solid var(--color-gold-deep); border-radius: var(--border-radius-sm); color: var(--color-gold-bright); font-size: 12px; font-family: inherit; cursor: pointer; appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='%23c9a961' stroke-width='1.5' fill='none' stroke-linecap='round'/></svg>"); background-repeat: no-repeat; background-position: right 10px center; transition: all var(--duration-base); }
.market-cal-tz-select:hover { border-color: var(--color-gold-bright); background-color: rgba(201,169,97,0.10); }
.market-cal-tz-select:focus { outline: none; border-color: var(--color-gold-bright); box-shadow: 0 0 0 2px rgba(201,169,97,0.15); }
.market-cal-tz-select option { background: var(--color-bg-elevated); color: var(--color-cream); }

@media (max-width: 700px) {
	.market-cal-toprow { flex-direction: column; align-items: stretch; }
	.market-cal-tz-wrap { justify-content: flex-end; }
	.market-cal-tz-select { width: 100%; max-width: 280px; }
}

/* ════════════════════════════════════════════════════════════
   v1.36.6 · Countdown banner + Search + Bookmarks
   ════════════════════════════════════════════════════════════ */

/* Countdown banner */
.market-countdown { padding: 8px 0 24px; }
.market-countdown-card { display: flex; justify-content: space-between; align-items: center; padding: 22px 30px; gap: 24px; transition: all var(--duration-base); }
.market-countdown.is-soon .market-countdown-card { border-color: var(--color-gold-bright); box-shadow: 0 0 24px rgba(229,196,120,0.15); }
.market-countdown.is-imminent .market-countdown-card { border-color: var(--color-bear); animation: countdown-pulse 1.4s ease-in-out infinite; }
@keyframes countdown-pulse { 0%, 100% { box-shadow: 0 0 20px rgba(184,84,80,0.25); } 50% { box-shadow: 0 0 32px rgba(184,84,80,0.50); } }

.market-countdown-left { flex: 1; min-width: 0; }
.market-countdown-eyebrow { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; color: var(--color-bear); text-transform: uppercase; margin-bottom: 8px; display: flex; align-items: center; gap: 8px; }
.market-countdown-event { font-family: var(--font-display-th); font-size: 20px; font-weight: 500; color: var(--color-cream); margin-bottom: 6px; line-height: 1.2; }
.market-countdown-meta { display: flex; gap: 18px; font-size: 13px; color: var(--color-cream-2); flex-wrap: wrap; }
.market-countdown-flag { font-family: var(--font-mono); font-weight: 500; }
.market-countdown-time { font-family: var(--font-display-th); }

.market-countdown-right { text-align: right; flex-shrink: 0; }
.market-countdown-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; color: var(--color-muted); text-transform: uppercase; margin-bottom: 4px; }
.market-countdown-timer { font-family: var(--font-mono); font-size: 28px; font-weight: 600; color: var(--color-gold-bright); letter-spacing: 0.04em; line-height: 1; }
.market-countdown.is-soon .market-countdown-timer { color: var(--color-gold-bright); }
.market-countdown.is-imminent .market-countdown-timer { color: var(--color-bear); }

@media (max-width: 700px) {
	.market-countdown-card { flex-direction: column; align-items: stretch; text-align: center; gap: 14px; padding: 20px 18px; }
	.market-countdown-right { text-align: center; }
	.market-countdown-meta { justify-content: center; }
	.market-countdown-event { font-size: 17px; }
	.market-countdown-timer { font-size: 24px; }
}

/* Search + Bookmark row */
.market-cal-searchrow { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; padding-top: 8px; border-top: 1px solid var(--color-hairline); }
.market-cal-search { flex: 1; min-width: 220px; position: relative; display: flex; align-items: center; }
.market-cal-search-icon { position: absolute; left: 12px; font-size: 13px; color: var(--color-muted); pointer-events: none; }
.market-cal-search-input { flex: 1; padding: 8px 36px 8px 36px; background: rgba(0,0,0,0.40); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); color: var(--color-cream); font-size: 12.5px; font-family: inherit; transition: border-color var(--duration-base); }
.market-cal-search-input::placeholder { color: var(--color-muted); }
.market-cal-search-input:focus { outline: none; border-color: var(--color-gold-deep); }
.market-cal-search-clear { position: absolute; right: 10px; padding: 4px 8px; background: transparent; border: 0; color: var(--color-muted); cursor: pointer; font-size: 12px; }
.market-cal-search-clear:hover { color: var(--color-gold-bright); }

.market-cal-bookmark-btn { padding: 8px 14px; background: rgba(0,0,0,0.30); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); color: var(--color-cream-2); font-size: 12px; cursor: pointer; transition: all var(--duration-base); display: flex; align-items: center; gap: 6px; }
.market-cal-bookmark-btn:hover { border-color: var(--color-gold-deep); color: var(--color-cream); }
.market-cal-bookmark-btn.is-active { background: rgba(229,196,120,0.15); border-color: var(--color-gold-bright); color: var(--color-gold-bright); }
.market-cal-bookmark-btn.is-active .aj-star { color: var(--color-gold-bright); }
.market-cal-bookmark-count { padding: 1px 7px; background: rgba(0,0,0,0.40); border-radius: 999px; font-family: var(--font-mono); font-size: 10px; }
.market-cal-bookmark-btn.is-active .market-cal-bookmark-count { background: rgba(0,0,0,0.50); color: var(--color-gold-bright); }
.aj-star { font-size: 14px; }

/* Star button in table row */
.market-cal-table thead th.col-star { width: 30px; padding: 11px 6px; }
.market-cal-star { width: 30px; padding: 8px 6px; text-align: center; }
.aj-star-btn { background: transparent; border: 0; color: var(--color-muted); font-size: 16px; cursor: pointer; padding: 4px; transition: color var(--duration-base); line-height: 1; }
.aj-star-btn:hover { color: var(--color-gold-bright); }
.aj-star-btn.is-active { color: var(--color-gold-bright); }

@media (max-width: 700px) {
	.market-cal-table thead th.col-star,
	.market-cal-event td.market-cal-star { padding: 6px 3px; }
	.aj-star-btn { font-size: 14px; }
	.market-cal-searchrow { flex-direction: column; align-items: stretch; }
	.market-cal-search { min-width: 0; }
	.market-cal-bookmark-btn { justify-content: center; }
}

/* ════════════════════════════════════════════════════════════
   v1.36.7 · Week range display (replace tabs)
   ════════════════════════════════════════════════════════════ */

.market-cal-weekrange { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.market-cal-weekrange-label { font-family: var(--font-display-th); font-size: 14px; font-weight: 500; color: var(--color-gold-bright); }
.market-cal-weekrange-dates { font-family: var(--font-mono); font-size: 12px; color: var(--color-cream-2); padding: 4px 12px; background: rgba(0,0,0,0.30); border: 1px solid var(--color-hairline); border-radius: 999px; letter-spacing: 0.04em; }

/* Hide tabs since we removed them · backward compat */
.market-cal-tabs { display: none; }

/* ════════════════════════════════════════════════════════════
   v1.36.8 · FAQ section + USD default state
   ════════════════════════════════════════════════════════════ */

.market-faq { padding: 40px 0; }
.market-faq-list { max-width: 880px; margin: 0 auto; display: flex; flex-direction: column; gap: 10px; }

.market-faq-item { background: var(--color-bg-elevated); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-md); overflow: hidden; transition: border-color var(--duration-base); }
.market-faq-item[open] { border-color: var(--color-gold-deep); }
.market-faq-item:hover { border-color: var(--color-gold-deep); }

.market-faq-q { padding: 16px 22px; font-family: var(--font-display-th); font-size: 15px; font-weight: 500; color: var(--color-cream); cursor: pointer; user-select: none; position: relative; padding-right: 50px; transition: color var(--duration-base); list-style: none; }
.market-faq-q::-webkit-details-marker { display: none; }
.market-faq-q::after { content: '+'; position: absolute; right: 22px; top: 50%; transform: translateY(-50%); width: 24px; height: 24px; border-radius: 50%; background: rgba(201,169,97,0.10); border: 1px solid var(--color-gold-deep); color: var(--color-gold-bright); display: flex; align-items: center; justify-content: center; font-family: var(--font-mono); font-size: 16px; line-height: 1; transition: transform var(--duration-base); }
.market-faq-item[open] .market-faq-q::after { content: '−'; transform: translateY(-50%) rotate(180deg); }
.market-faq-q:hover { color: var(--color-gold-bright); }

.market-faq-a { padding: 0 22px 18px; font-size: 13.5px; color: var(--color-cream-2); line-height: 1.8; border-top: 1px solid var(--color-hairline); padding-top: 14px; }
.market-faq-a strong { color: var(--color-gold-bright); font-weight: 500; }
.market-faq-a a { color: var(--color-gold-bright); border-bottom: 1px solid var(--color-gold-deep); }
.market-faq-a a:hover { color: var(--color-cream); }
.market-faq-a ul, .market-faq-a ol { margin: 8px 0 0; }
.market-faq-a li { margin-bottom: 4px; }

@media (max-width: 700px) {
	.market-faq-q { font-size: 14px; padding: 14px 18px; padding-right: 48px; }
	.market-faq-q::after { right: 16px; width: 22px; height: 22px; }
	.market-faq-a { padding: 12px 18px 16px; font-size: 12.5px; }
}

/* ════════════════════════════════════════════════════════════
   v1.41.0 · BROKER REVIEWS · archive + single
   ════════════════════════════════════════════════════════════ */

/* ───── Hero · shared archive + single ───── */
.brokers-hero,
.broker-hero { padding: 60px 0 30px; background: linear-gradient(180deg, rgba(229,196,120,0.04) 0%, transparent 100%); }
.brokers-hero { text-align: center; }
.brokers-hero-eyebrow { display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; color: var(--color-gold-bright); margin-bottom: 18px; text-transform: uppercase; }
.brokers-hero-title { font-family: var(--font-display-th); font-size: 38px; font-weight: 500; color: var(--color-cream); margin: 0 0 14px; letter-spacing: 0.005em; }
.brokers-hero-sub { font-size: 15px; color: var(--color-cream-2); max-width: 720px; margin: 0 auto; line-height: 1.7; }
.brokers-hero-sources { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.08em; color: var(--color-muted); margin: 14px auto 0; text-transform: uppercase; }

@media (max-width: 700px) {
	.brokers-hero,
	.broker-hero { padding: 40px 0 20px; }
	.brokers-hero-title { font-size: 26px; }
	.brokers-hero-sub { font-size: 13px; padding: 0 14px; }
	.brokers-hero-sources { font-size: 9.5px; padding: 0 14px; }
}

/* ───── Archive · main content ───── */
.brokers-main { padding: 24px 0 40px; }
.brokers-empty { padding: 60px 24px; text-align: center; color: var(--color-cream-2); }

.brokers-filters { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 26px; justify-content: center; }
.brokers-filter {
	padding: 7px 16px;
	background: rgba(0,0,0,0.30);
	border: 1px solid var(--color-hairline);
	border-radius: 999px;
	color: var(--color-cream-2);
	font-family: var(--font-display-th);
	font-size: 13px;
	cursor: pointer;
	transition: all var(--duration-base);
}
.brokers-filter:hover { color: var(--color-gold-bright); border-color: var(--color-gold-deep); }
.brokers-filter.is-active { background: rgba(201,169,97,0.18); border-color: var(--color-gold-bright); color: var(--color-gold-bright); }

/* ───── Comparison table (desktop) ───── */
.brokers-table-wrap { overflow-x: auto; margin-bottom: 32px; background: rgba(0,0,0,0.20); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); }
.brokers-table { width: 100%; border-collapse: collapse; min-width: 920px; }
.brokers-table thead th {
	padding: 14px 12px;
	background: rgba(0,0,0,0.30);
	font-family: var(--font-mono);
	font-size: 10px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--color-muted);
	border-bottom: 1px solid var(--color-gold-deep);
	font-weight: 500;
	text-align: left;
	white-space: nowrap;
}
.brokers-table tbody tr { border-bottom: 1px solid var(--color-hairline); transition: background var(--duration-base); }
.brokers-table tbody tr:hover { background: rgba(229,196,120,0.04); }
.brokers-table td { padding: 14px 12px; color: var(--color-cream-2); font-size: 13px; vertical-align: middle; }
.brokers-table td small { font-size: 10px; color: var(--color-muted); }

.bt-col-logo { width: 56px; }
.bt-col-cta  { text-align: right; }

.brokers-tlogo { width: 44px; height: 44px; border-radius: 8px; font-size: 18px; font-weight: 700; display: flex; align-items: center; justify-content: center; }
.brokers-tlogo img { width: 100%; height: 100%; object-fit: cover; border-radius: 8px; }

.brokers-table-name { color: var(--color-cream) !important; font-weight: 600; text-decoration: none; font-size: 15px; display: inline-flex; align-items: center; gap: 6px; }
.brokers-table-name:hover { color: var(--color-gold-bright) !important; }
.brokers-verified-tag { display: inline-flex; width: 18px; height: 18px; align-items: center; justify-content: center; background: var(--color-bull); color: #fff; border-radius: 50%; font-size: 11px; font-weight: 700; }
.brokers-table-tag { font-size: 11px; color: var(--color-muted); margin-top: 2px; font-family: var(--font-display-th); }
.brokers-table-checked { font-size: 10px; color: var(--color-faint); margin-top: 4px; font-family: var(--font-mono); letter-spacing: 0.02em; }

.brokers-score-num { font-family: var(--font-mono); font-size: 16px; font-weight: 700; color: var(--color-gold-bright); margin-right: 4px; }
.brokers-score-stars { color: var(--color-gold-deep); font-size: 12px; letter-spacing: -1px; }
.brokers-score-pending { color: var(--color-muted); font-family: var(--font-mono); }

.brokers-rebate-pill { display: inline-block; padding: 4px 10px; background: rgba(107,163,115,0.12); color: var(--color-bull); border: 1px solid rgba(107,163,115,0.30); border-radius: 999px; font-family: var(--font-mono); font-size: 11.5px; font-weight: 600; }
.brokers-rebate-pill small { font-size: 9px; color: var(--color-bull); opacity: 0.7; margin-left: 2px; }

.brokers-table-cta { display: inline-block; padding: 7px 14px; background: rgba(229,196,120,0.10); border: 1px solid var(--color-gold-deep); border-radius: var(--border-radius-sm); color: var(--color-gold-bright); text-decoration: none; font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.04em; transition: all var(--duration-base); }
.brokers-table-cta:hover { background: var(--color-gold-bright); color: #1a1208; border-color: var(--color-gold-bright); }

/* ───── Card grid (mobile + supplemental) ───── */
.brokers-cards { display: none; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 14px; }
.brokers-card {
	display: block;
	padding: 18px;
	background: rgba(0,0,0,0.30);
	border: 1px solid var(--color-hairline);
	border-radius: var(--border-radius-sm);
	text-decoration: none;
	transition: all var(--duration-base);
}
.brokers-card:hover { border-color: var(--color-gold-deep); transform: translateY(-2px); }
.brokers-card-head { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; padding-right: 76px; }
.brokers-clogo { width: 44px; height: 44px; border-radius: 8px; font-size: 18px; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.brokers-clogo img { width: 100%; height: 100%; object-fit: cover; border-radius: 8px; }
.brokers-card-name { flex: 1; font-family: var(--font-display-en); font-size: 17px; font-weight: 600; color: var(--color-cream); display: flex; align-items: center; gap: 6px; }
.brokers-card-score { font-family: var(--font-mono); font-size: 13px; color: var(--color-gold-bright); font-weight: 600; }
.brokers-card-tagline { font-size: 12px; color: var(--color-muted); margin-bottom: 12px; font-family: var(--font-display-th); }
.brokers-card-specs { display: flex; gap: 12px; flex-wrap: wrap; font-family: var(--font-mono); font-size: 10.5px; color: var(--color-cream-2); padding: 8px 0; border-top: 1px solid var(--color-hairline); border-bottom: 1px solid var(--color-hairline); }
.brokers-card-pros { list-style: none; padding: 12px 0 8px; margin: 0; }
.brokers-card-pros li { font-size: 12px; color: var(--color-cream-2); margin-bottom: 4px; font-family: var(--font-display-th); }
.brokers-card-cta { font-family: var(--font-mono); font-size: 11px; color: var(--color-gold-bright); letter-spacing: 0.04em; text-align: right; padding-top: 8px; }
.brokers-card-checked { font-family: var(--font-mono); font-size: 10px; color: var(--color-faint); letter-spacing: 0.03em; margin-top: 10px; padding-top: 8px; border-top: 1px solid var(--color-hairline); }

/* ═══════════════════════════════════════
   v1.64.0 · Compare Brokers
   ═══════════════════════════════════════ */
/* Toggle pill (injected into row CTA cell + card corner) */
.aj-cmp-toggle { display: inline-flex; align-items: center; gap: 5px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.04em; color: var(--color-cream-2); background: var(--color-surface); border: 1px solid var(--color-hairline-bright); border-radius: 999px; padding: 4px 10px; cursor: pointer; transition: all var(--duration-fast); white-space: nowrap; }
.aj-cmp-toggle:hover { border-color: var(--color-gold-deep); color: var(--color-gold-bright); }
.aj-cmp-toggle .aj-cmp-tbox { display: inline-flex; align-items: center; justify-content: center; width: 14px; height: 14px; border-radius: 50%; background: var(--color-bg-base); border: 1px solid var(--color-hairline-bright); font-size: 10px; line-height: 1; }
.aj-cmp-toggle.is-on { background: rgba(201,169,97,0.14); border-color: var(--color-gold); color: var(--color-gold-bright); }
.aj-cmp-toggle.is-on .aj-cmp-tbox { background: var(--color-gold); border-color: var(--color-gold); color: var(--color-bg-base); }
.aj-cmp-toggle.is-card { position: absolute; top: 16px; right: 16px; z-index: 3; padding: 3px 9px; font-size: 9.5px; }
.brokers-card { position: relative; }
.bt-col-cta .aj-cmp-toggle { margin-bottom: 6px; }
.brokers-table-row.aj-cmp-picked,
.brokers-card.aj-cmp-picked { outline: 1px solid var(--color-gold-deep); outline-offset: -1px; background: rgba(201,169,97,0.05); }

/* Sticky compare bar */
.aj-cmp-bar { position: fixed; left: 0; right: 0; bottom: 0; z-index: 240; background: linear-gradient(180deg, rgba(15,12,8,0.96), rgba(10,8,6,0.99)); border-top: 1px solid var(--color-gold-deep); backdrop-filter: blur(8px); box-shadow: 0 -10px 40px rgba(0,0,0,0.5); padding: 12px 0; }
.aj-cmp-bar-flash { animation: ajCmpFlash 0.4s ease; }
@keyframes ajCmpFlash { 0%,100% { border-top-color: var(--color-gold-deep); } 50% { border-top-color: var(--color-bear); } }
.aj-cmp-bar-inner { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.aj-cmp-bar-label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; color: var(--color-muted); text-transform: uppercase; white-space: nowrap; }
.aj-cmp-bar-label strong { color: var(--color-gold-bright); }
.aj-cmp-chips { display: flex; gap: 8px; flex-wrap: wrap; flex: 1; min-width: 120px; }
.aj-cmp-chip { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-display-th); font-size: 13px; color: var(--color-cream); background: var(--color-surface); border: 1px solid var(--color-hairline-bright); border-radius: 6px; padding: 5px 6px 5px 12px; }
.aj-cmp-chip button { background: none; border: none; color: var(--color-muted); cursor: pointer; font-size: 12px; padding: 2px 4px; line-height: 1; }
.aj-cmp-chip button:hover { color: var(--color-bear); }
.aj-cmp-bar-actions { display: flex; gap: 10px; align-items: center; }
.aj-cmp-clear { background: none; border: none; color: var(--color-muted); font-family: var(--font-mono); font-size: 11px; cursor: pointer; letter-spacing: 0.04em; }
.aj-cmp-clear:hover { color: var(--color-cream); }
.aj-cmp-go { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.06em; color: var(--color-bg-base); background: var(--color-gold); border: none; border-radius: 6px; padding: 9px 18px; cursor: pointer; font-weight: 600; transition: all var(--duration-fast); }
.aj-cmp-go:hover:not(:disabled) { background: var(--color-gold-bright); }
.aj-cmp-go:disabled { opacity: 0.35; cursor: not-allowed; }
body.aj-cmp-bar-open { padding-bottom: 76px; }

/* Compare modal */
.aj-cmp-modal { position: fixed; inset: 0; z-index: 300; display: flex; align-items: center; justify-content: center; padding: 24px; }
.aj-cmp-modal[hidden], .aj-cmp-bar[hidden] { display: none !important; }
body.admin-bar .aj-cmp-modal { top: 46px; }
@media screen and (min-width: 783px) { body.admin-bar .aj-cmp-modal { top: 32px; } }
.aj-cmp-modal-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0.78); }
.aj-cmp-modal-panel { position: relative; z-index: 1; width: min(960px, 100%); max-height: 88vh; display: flex; flex-direction: column; background: var(--color-bg-elevated); border: 1px solid var(--color-gold-deep); border-radius: var(--border-radius-md); box-shadow: 0 30px 90px rgba(0,0,0,0.6); overflow: hidden; }
.aj-cmp-modal-head { display: flex; align-items: center; justify-content: space-between; padding: 18px 22px; border-bottom: 1px solid var(--color-hairline); }
.aj-cmp-modal-head h3 { margin: 0; font-family: var(--font-display-th); font-size: 19px; color: var(--color-cream); }
.aj-cmp-modal-x { background: none; border: 1px solid var(--color-hairline-bright); color: var(--color-cream-2); width: 32px; height: 32px; border-radius: 6px; cursor: pointer; font-size: 14px; transition: all var(--duration-fast); }
.aj-cmp-modal-x:hover { border-color: var(--color-bear); color: var(--color-bear); }
.aj-cmp-table-wrap { overflow: auto; flex: 1; }
.aj-cmp-modal-note { padding: 12px 22px; border-top: 1px solid var(--color-hairline); font-size: 11px; color: var(--color-faint); line-height: 1.6; }
body.aj-cmp-modal-open { overflow: hidden; }

/* Compare table */
.aj-cmp-table { border-collapse: collapse; width: 100%; min-width: 480px; }
.aj-cmp-table th, .aj-cmp-table td { padding: 12px 14px; text-align: center; border-bottom: 1px solid var(--color-hairline); font-size: 13px; color: var(--color-cream-2); vertical-align: middle; }
.aj-cmp-table .aj-cmp-rl { text-align: left; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.03em; color: var(--color-muted); white-space: nowrap; position: sticky; left: 0; background: var(--color-bg-elevated); z-index: 2; }
.aj-cmp-table thead th { position: sticky; top: 0; z-index: 4; }
.aj-cmp-table .aj-cmp-corner { position: sticky; left: 0; top: 0; background: var(--color-bg-elevated); z-index: 6; }
.aj-cmp-bhead { background: var(--color-surface); border-bottom: 1px solid var(--color-hairline-bright); min-width: 150px; }
.aj-cmp-logo-img { width: 34px; height: 34px; object-fit: contain; border-radius: 6px; display: block; margin: 0 auto 6px; }
.aj-cmp-logo-letter { display: inline-flex; align-items: center; justify-content: center; width: 34px; height: 34px; border-radius: 6px; color: #0a0806; font-family: var(--font-display-en); font-weight: 700; margin-bottom: 6px; }
.aj-cmp-bname { font-family: var(--font-display-en); font-size: 14px; font-weight: 600; color: var(--color-cream); }
.aj-cmp-vtag { color: var(--color-gold-bright); font-size: 11px; }
.aj-cmp-bscore { font-family: var(--font-mono); font-size: 12px; color: var(--color-gold-bright); margin-top: 3px; }
.aj-cmp-row-hl td { background: rgba(201,169,97,0.06); color: var(--color-gold-bright); font-weight: 600; }
.aj-cmp-row-hl .aj-cmp-rl { color: var(--color-gold-bright); background: var(--color-bg-elevated); }
.aj-sf { font-size: 15px; font-weight: 700; }
.aj-sf.yes { color: var(--color-bull); }
.aj-sf.no { color: var(--color-bear); opacity: 0.7; }
.aj-sf.partial { color: var(--color-gold-bright); }
.aj-cmp-table small { color: var(--color-muted); font-size: 10px; }
.aj-cmp-foot td { padding-top: 16px; }
.aj-cmp-cta { display: block; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.03em; padding: 9px 10px; border: 1px solid var(--color-hairline-bright); border-radius: 6px; color: var(--color-cream); text-decoration: none; transition: all var(--duration-fast); }
.aj-cmp-cta:hover { border-color: var(--color-gold-deep); }
.aj-cmp-cta.gold { background: var(--color-gold); border-color: var(--color-gold); color: #0a0806; font-weight: 600; }
.aj-cmp-cta.gold:hover { background: var(--color-gold-bright); }
.aj-cmp-review { display: block; font-family: var(--font-mono); font-size: 10px; color: var(--color-muted); text-decoration: none; margin-top: 8px; }
.aj-cmp-review:hover { color: var(--color-gold-bright); }
/* Compact comparison on tablet/mobile · prevents column cutoff */
@media (max-width: 820px) {
	.aj-cmp-table th, .aj-cmp-table td { padding: 9px 8px; font-size: 11.5px; }
	.aj-cmp-bhead { min-width: 118px; }
	.aj-cmp-table .aj-cmp-rl { font-size: 10px; max-width: 96px; white-space: normal; line-height: 1.35; }
	.aj-cmp-table { min-width: 0; }
	.aj-cmp-bname { font-size: 12.5px; }
	.aj-cmp-logo-img, .aj-cmp-logo-letter { width: 28px; height: 28px; }
}
@media (max-width: 600px) {
	.aj-cmp-modal { padding: 0; }
	.aj-cmp-modal-panel { width: 100%; max-height: 100vh; height: 100vh; max-height: 100dvh; height: 100dvh; border-radius: 0; border: none; }
	body.admin-bar .aj-cmp-modal-panel { height: calc(100dvh - 46px); max-height: calc(100dvh - 46px); }
	.aj-cmp-modal-head { padding: 14px 16px; }
	.aj-cmp-modal-head h3 { font-size: 16px; }
	.aj-cmp-bar-inner { gap: 10px; }
	.aj-cmp-bar-label { width: 100%; }
}
@media (max-width: 480px) {
	.aj-cmp-bhead { min-width: 104px; }
	.aj-cmp-table .aj-cmp-rl { max-width: 80px; }
}

@media (max-width: 900px) {
	.brokers-table-wrap { display: none; }
	.brokers-cards { display: grid; }
}

/* ───── Trust + FAQ ───── */
.brokers-trust { padding: 30px 0; }
.brokers-trust-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.brokers-trust-card { padding: 20px; background: rgba(0,0,0,0.25); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); }
.brokers-trust-icon { font-size: 26px; margin-bottom: 8px; }
.brokers-trust-title { font-family: var(--font-display-th); font-size: 15px; font-weight: 500; color: var(--color-cream); margin-bottom: 6px; }
.brokers-trust-text { font-size: 12.5px; color: var(--color-cream-2); line-height: 1.7; }
.brokers-trust-text strong { color: var(--color-gold-bright); }

@media (max-width: 900px) {
	.brokers-trust-grid { grid-template-columns: 1fr; }
}

.brokers-faq { padding: 30px 0; }

/* ════════════════════════════════════════════════════════════
   SINGLE BROKER REVIEW
   ════════════════════════════════════════════════════════════ */

.broker-hero-grid { display: grid; grid-template-columns: 1fr auto; gap: 24px; align-items: center; margin-bottom: 32px; }
.broker-hero-left { display: flex; gap: 20px; align-items: center; }
.broker-hero-logo { width: 80px; height: 80px; border-radius: 14px; font-size: 32px; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.broker-hero-logo img { width: 100%; height: 100%; object-fit: cover; border-radius: 14px; }
.broker-hero-meta { flex: 1; }
.broker-hero-eyebrow { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; color: var(--color-gold-bright); margin-bottom: 8px; text-transform: uppercase; display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.broker-hero-partner { background: rgba(107,163,115,0.15); color: var(--color-bull); padding: 2px 10px; border-radius: 999px; border: 1px solid rgba(107,163,115,0.30); font-size: 10px; letter-spacing: 0.06em; }
.broker-hero-title { font-family: var(--font-display-en); font-size: 38px; font-weight: 600; color: var(--color-cream); margin: 0 0 8px; letter-spacing: 0; }
.broker-hero-tagline { font-family: var(--font-display-th); font-size: 14.5px; color: var(--color-cream-2); margin: 0 0 12px; line-height: 1.6; }
.broker-hero-score { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-mono); }
.broker-hero-score .broker-score-num { font-size: 22px; font-weight: 700; color: var(--color-gold-bright); }
.broker-hero-score .broker-score-stars { font-size: 16px; color: var(--color-gold-deep); letter-spacing: -1px; }
.broker-hero-score .broker-score-label { font-size: 10.5px; color: var(--color-muted); letter-spacing: 0.06em; }

.broker-hero-cta-wrap { display: flex; flex-direction: column; gap: 8px; align-items: flex-end; }
.broker-hero-cta { display: inline-block; padding: 14px 28px; background: linear-gradient(135deg, var(--color-gold-deep) 0%, var(--color-gold-bright) 100%); color: #1a1208; font-family: var(--font-display-th); font-size: 15px; font-weight: 600; text-decoration: none; border-radius: var(--border-radius-sm); transition: all var(--duration-base); box-shadow: 0 4px 16px rgba(229,196,120,0.25); white-space: nowrap; }
.broker-hero-cta:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(229,196,120,0.40); }
.broker-hero-cta-ghost { font-family: var(--font-mono); font-size: 11.5px; color: var(--color-gold-bright); text-decoration: none; letter-spacing: 0.04em; }
.broker-hero-cta-ghost:hover { color: var(--color-cream); }

/* Quick stats row */
.broker-quickstats { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 10px; }
.broker-qs-item { padding: 12px 14px; background: rgba(0,0,0,0.30); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); }
.broker-qs-rebate { border-color: var(--color-gold-deep); background: linear-gradient(135deg, rgba(229,196,120,0.08) 0%, rgba(0,0,0,0.30) 100%); }
.broker-qs-label { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.10em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 4px; }
.broker-qs-val { font-family: var(--font-mono); font-size: 15px; font-weight: 600; color: var(--color-cream); letter-spacing: 0.01em; }
.broker-qs-val small { font-size: 11px; color: var(--color-muted); font-weight: 400; }
.broker-qs-rebate .broker-qs-val { color: var(--color-gold-bright); }

@media (max-width: 800px) {
	.broker-hero-grid { grid-template-columns: 1fr; gap: 18px; }
	.broker-hero-left { flex-direction: column; align-items: flex-start; gap: 14px; }
	.broker-hero-logo { width: 64px; height: 64px; font-size: 26px; }
	.broker-hero-title { font-size: 28px; }
	.broker-hero-cta-wrap { align-items: stretch; }
	.broker-hero-cta { text-align: center; }
}

/* Sections */
.broker-section { padding: 32px 0; }
.broker-section-title { font-family: var(--font-display-th); font-size: 22px; font-weight: 500; color: var(--color-cream); margin: 0 0 16px; letter-spacing: 0.005em; }

/* Pros / Cons grid */
.broker-proscons-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.broker-pros, .broker-cons { padding: 22px 24px; border-radius: var(--border-radius-sm); border: 1px solid var(--color-hairline); }
.broker-pros { background: linear-gradient(180deg, rgba(107,163,115,0.06) 0%, rgba(0,0,0,0.30) 100%); border-left: 3px solid var(--color-bull); }
.broker-cons { background: linear-gradient(180deg, rgba(184,84,80,0.06) 0%, rgba(0,0,0,0.30) 100%); border-left: 3px solid var(--color-bear); }
.broker-pc-title { font-family: var(--font-display-th); font-size: 18px; font-weight: 500; color: var(--color-cream); margin: 0 0 12px; }
.broker-pros .broker-pc-title { color: var(--color-bull); }
.broker-cons .broker-pc-title { color: var(--color-bear); }
.broker-pc-list { list-style: none; padding: 0; margin: 0; }
.broker-pc-list li { font-family: var(--font-display-th); font-size: 13.5px; color: var(--color-cream-2); line-height: 1.6; padding: 6px 0; border-bottom: 1px dashed var(--color-hairline); }
.broker-pc-list li:last-child { border-bottom: none; }

@media (max-width: 700px) {
	.broker-proscons-grid { grid-template-columns: 1fr; }
}

/* Verdict body */
.broker-verdict-body { padding: 24px 26px; background: rgba(0,0,0,0.25); border: 1px solid var(--color-hairline); border-left: 3px solid var(--color-gold-bright); border-radius: var(--border-radius-sm); }
.broker-verdict-body p { font-family: var(--font-display-th); font-size: 14.5px; color: var(--color-cream-2); line-height: 1.85; margin: 0 0 14px; }
.broker-verdict-body p:last-child { margin-bottom: 0; }
.broker-verdict-body strong { color: var(--color-gold-bright); font-weight: 500; }

/* Rebate detail card */
.broker-rebate-card { display: flex; gap: 20px; padding: 24px 26px; background: linear-gradient(135deg, rgba(229,196,120,0.08) 0%, rgba(0,0,0,0.30) 100%); border: 1px solid var(--color-gold-deep); border-radius: var(--border-radius-sm); align-items: flex-start; }
.broker-rebate-icon { font-size: 38px; flex-shrink: 0; }
.broker-rebate-body { flex: 1; }
.broker-rebate-amount { font-family: var(--font-mono); font-size: 24px; font-weight: 700; color: var(--color-gold-bright); margin: 4px 0 8px; letter-spacing: 0.02em; }
.broker-rebate-meta { font-size: 13px; color: var(--color-cream-2); margin-bottom: 6px; }
.broker-rebate-meta strong { color: var(--color-cream); }
.broker-rebate-notes { font-size: 12.5px; color: var(--color-muted); margin-bottom: 10px; line-height: 1.6; }
.broker-rebate-disc { font-size: 12px; color: var(--color-cream-2); line-height: 1.7; margin: 8px 0 0; padding: 10px 14px; background: rgba(0,0,0,0.30); border-radius: var(--border-radius-sm); }
.broker-rebate-disc strong { color: var(--color-gold-bright); }

@media (max-width: 700px) {
	.broker-rebate-card { flex-direction: column; gap: 10px; }
	.broker-rebate-icon { font-size: 30px; }
	.broker-rebate-amount { font-size: 20px; }
}

/* Details grid · platforms / deposits / best-for / regulation */
.broker-details-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 14px; }
.broker-detail-card { padding: 16px 18px; background: rgba(0,0,0,0.25); border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); }
.broker-detail-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 10px; }
.broker-detail-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.broker-tag { padding: 4px 10px; background: rgba(255,255,255,0.04); border: 1px solid var(--color-hairline); border-radius: 999px; font-family: var(--font-mono); font-size: 11px; color: var(--color-cream); }
.broker-tag-bf { background: rgba(229,196,120,0.08); border-color: var(--color-gold-deep); color: var(--color-gold-bright); }
.broker-tag-reg { background: rgba(107,163,115,0.08); border-color: rgba(107,163,115,0.30); color: var(--color-bull); }

/* Final CTA */
.broker-final-card { padding: 36px 32px; text-align: center; }
.broker-final-title { font-family: var(--font-display-th); font-size: 24px; font-weight: 500; color: var(--color-cream); margin: 0 0 8px; }
.broker-final-sub { font-size: 14px; color: var(--color-cream-2); margin: 0 0 18px; line-height: 1.6; }
.broker-final-sub strong { color: var(--color-gold-bright); }
.broker-final-buttons { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-bottom: 16px; }

/* Sticky mobile CTA bar */
.broker-sticky-cta {
	display: none;
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 100;
	padding: 14px 16px;
	background: linear-gradient(135deg, var(--color-gold-deep) 0%, var(--color-gold-bright) 100%);
	color: #1a1208;
	font-family: var(--font-display-th);
	font-size: 14px;
	font-weight: 600;
	text-align: center;
	text-decoration: none;
	box-shadow: 0 -4px 20px rgba(0,0,0,0.50);
}
@media (max-width: 700px) {
	.broker-sticky-cta { display: block; }
	body { padding-bottom: 60px; }
}

/* ════════════════════════════════════════════════════════════
   v1.42.0 · Last-updated badge · Score breakdown · Trader Safety Box
   ════════════════════════════════════════════════════════════ */

/* ── Last-updated badge (hero) ───────────────────────────────── */
.broker-hero-updated {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-top: 10px;
	padding: 5px 12px;
	background: rgba(107,163,115,0.10);
	border: 1px solid rgba(107,163,115,0.30);
	border-radius: 999px;
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: 0.04em;
	color: var(--color-cream-2);
}
.broker-hero-updated strong { color: var(--color-bull); font-weight: 600; }

/* ── Score Breakdown · 4 sub-scores ─────────────────────────── */
.broker-breakdown-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 14px;
}
.broker-bd-card {
	padding: 16px 18px;
	background: rgba(0,0,0,0.30);
	border: 1px solid var(--color-hairline);
	border-radius: var(--border-radius-sm);
	transition: border-color var(--duration-base);
}
.broker-bd-head {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 10px;
}
.broker-bd-icon { font-size: 18px; }
.broker-bd-label {
	flex: 1;
	font-family: var(--font-display-th);
	font-size: 14px;
	font-weight: 500;
	color: var(--color-cream);
}
.broker-bd-val {
	font-family: var(--font-mono);
	font-size: 18px;
	font-weight: 700;
}
.broker-bd-bar-wrap {
	height: 6px;
	background: rgba(255,255,255,0.05);
	border-radius: 3px;
	overflow: hidden;
	margin-bottom: 8px;
}
.broker-bd-bar {
	height: 100%;
	background: var(--color-gold-bright);
	border-radius: 3px;
	transition: width var(--duration-base);
}
.broker-bd-desc {
	font-size: 11.5px;
	color: var(--color-muted);
	font-family: var(--font-display-th);
	letter-spacing: 0.005em;
}

/* Tone variants */
.broker-bd-excellent { border-color: rgba(107,163,115,0.40); }
.broker-bd-excellent .broker-bd-val { color: var(--color-bull); }
.broker-bd-excellent .broker-bd-bar { background: linear-gradient(90deg, var(--color-bull) 0%, #8dc296 100%); }

.broker-bd-good .broker-bd-val { color: var(--color-gold-bright); }
.broker-bd-good .broker-bd-bar { background: var(--color-gold-bright); }

.broker-bd-fair { border-color: rgba(229,180,80,0.30); }
.broker-bd-fair .broker-bd-val { color: #e5b450; }
.broker-bd-fair .broker-bd-bar { background: #e5b450; }

.broker-bd-weak { border-color: rgba(184,84,80,0.40); }
.broker-bd-weak .broker-bd-val { color: var(--color-bear); }
.broker-bd-weak .broker-bd-bar { background: var(--color-bear); }

/* ── Trader Safety Box · 4 yes/no flags ─────────────────────── */
.broker-safety-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 12px;
}
.broker-safety-card {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 14px 18px;
	background: rgba(0,0,0,0.30);
	border: 1px solid var(--color-hairline);
	border-left: 3px solid var(--color-hairline);
	border-radius: var(--border-radius-sm);
}
.broker-safety-icon { font-size: 24px; flex-shrink: 0; }
.broker-safety-body { flex: 1; min-width: 0; }
.broker-safety-label {
	font-family: var(--font-display-th);
	font-size: 13.5px;
	font-weight: 500;
	color: var(--color-cream);
	margin-bottom: 2px;
}
.broker-safety-meta {
	font-size: 11.5px;
	color: var(--color-muted);
	font-family: var(--font-display-th);
}
.broker-safety-status {
	flex-shrink: 0;
	padding: 4px 10px;
	border-radius: 999px;
	font-family: var(--font-mono);
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.03em;
}

/* Status variants */
.broker-safety-card.safety-yes { border-left-color: var(--color-bull); background: linear-gradient(90deg, rgba(107,163,115,0.04) 0%, rgba(0,0,0,0.30) 100%); }
.broker-safety-card.safety-yes .broker-safety-status { background: rgba(107,163,115,0.18); color: var(--color-bull); border: 1px solid rgba(107,163,115,0.30); }

.broker-safety-card.safety-no { border-left-color: var(--color-bear); background: linear-gradient(90deg, rgba(184,84,80,0.04) 0%, rgba(0,0,0,0.30) 100%); }
.broker-safety-card.safety-no .broker-safety-status { background: rgba(184,84,80,0.18); color: var(--color-bear); border: 1px solid rgba(184,84,80,0.30); }

.broker-safety-card.safety-partial { border-left-color: #e5b450; background: linear-gradient(90deg, rgba(229,180,80,0.04) 0%, rgba(0,0,0,0.30) 100%); }
.broker-safety-card.safety-partial .broker-safety-status { background: rgba(229,180,80,0.18); color: #e5b450; border: 1px solid rgba(229,180,80,0.30); }

@media (max-width: 700px) {
	.broker-safety-card { padding: 12px 14px; gap: 10px; }
	.broker-safety-icon { font-size: 20px; }
	.broker-safety-label { font-size: 13px; }
	.broker-safety-meta { font-size: 11px; }
	.broker-bd-card { padding: 14px 16px; }
}

/* ════════════════════════════════════════════════════════════
   v1.43.0 · Breadcrumbs + Similar brokers section
   ════════════════════════════════════════════════════════════ */

/* ── Breadcrumbs ─────────────────────────────────────────────── */
.auh-breadcrumbs {
	padding: 14px 0;
	border-bottom: 1px solid var(--color-hairline);
	background: rgba(0,0,0,0.20);
}
.auh-bc-list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0;
	margin: 0;
	padding: 0;
	list-style: none;
	font-family: var(--font-mono);
	font-size: 11.5px;
	letter-spacing: 0.04em;
}
.auh-bc-item {
	display: inline-flex;
	align-items: center;
}
.auh-bc-item a {
	color: var(--color-muted);
	text-decoration: none;
	transition: color var(--duration-base);
}
.auh-bc-item a:hover { color: var(--color-gold-bright); }
.auh-bc-item.is-current span { color: var(--color-cream); font-weight: 500; }
.auh-bc-sep {
	margin: 0 10px;
	color: var(--color-gold-deep);
	font-size: 13px;
	line-height: 1;
}

@media (max-width: 700px) {
	.auh-breadcrumbs { padding: 11px 0; }
	.auh-bc-list { font-size: 10.5px; }
	.auh-bc-sep { margin: 0 7px; }
}

/* ── Similar brokers section ─────────────────────────────────── */
.broker-similar-sub {
	font-family: var(--font-display-th);
	font-size: 13px;
	color: var(--color-cream-2);
	margin: 0 0 18px;
}

.broker-similar-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 14px;
}

.broker-similar-card {
	display: flex;
	flex-direction: column;
	padding: 18px 20px;
	background: rgba(0,0,0,0.30);
	border: 1px solid var(--color-hairline);
	border-radius: var(--border-radius-sm);
	text-decoration: none;
	transition: all var(--duration-base);
}
.broker-similar-card:hover {
	border-color: var(--color-gold-deep);
	transform: translateY(-3px);
	box-shadow: 0 8px 24px rgba(0,0,0,0.30);
}

.broker-similar-head {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 8px;
}
.broker-similar-logo {
	width: 40px;
	height: 40px;
	border-radius: 8px;
	font-size: 15px;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.broker-similar-logo img { width: 100%; height: 100%; object-fit: cover; border-radius: 8px; }
.broker-similar-name {
	flex: 1;
	font-family: var(--font-display-en);
	font-size: 16px;
	font-weight: 600;
	color: var(--color-cream);
	display: flex;
	align-items: center;
	gap: 6px;
}
.broker-similar-score {
	font-family: var(--font-mono);
	font-size: 12.5px;
	font-weight: 600;
	color: var(--color-gold-bright);
}

.broker-similar-tag {
	font-family: var(--font-display-th);
	font-size: 12px;
	color: var(--color-muted);
	line-height: 1.5;
	margin-bottom: 12px;
	min-height: 36px;
}

.broker-similar-specs {
	display: flex;
	gap: 12px;
	padding: 10px 0;
	border-top: 1px solid var(--color-hairline);
	border-bottom: 1px solid var(--color-hairline);
	margin-bottom: 10px;
}
.broker-similar-spec {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.bs-label {
	font-family: var(--font-mono);
	font-size: 9.5px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--color-muted);
}
.bs-val {
	font-family: var(--font-mono);
	font-size: 12.5px;
	font-weight: 600;
	color: var(--color-cream);
}
.broker-similar-spec-rebate .bs-val { color: var(--color-gold-bright); }

.broker-similar-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 5px;
	margin-bottom: 12px;
}
.broker-similar-bf {
	padding: 3px 8px;
	background: rgba(229,196,120,0.08);
	border: 1px solid var(--color-gold-deep);
	border-radius: 999px;
	font-family: var(--font-mono);
	font-size: 10px;
	color: var(--color-gold-bright);
	letter-spacing: 0.02em;
}

.broker-similar-cta {
	margin-top: auto;
	font-family: var(--font-mono);
	font-size: 11.5px;
	color: var(--color-gold-bright);
	letter-spacing: 0.04em;
	text-align: right;
	padding-top: 4px;
}

@media (max-width: 700px) {
	.broker-similar-card { padding: 14px 16px; }
	.broker-similar-name { font-size: 15px; }
	.broker-similar-tag { font-size: 11.5px; min-height: 0; }
	.broker-similar-specs { gap: 8px; }
	.bs-val { font-size: 11.5px; }
}

/* ════════════════════════════════════════════════════════════
   v1.44.0 · Style cards · Methodology · Pending · CTA upgrades
   ════════════════════════════════════════════════════════════ */

/* ── Choose by trading style · 6-card grid ─────────────────── */
.brokers-style { padding: 30px 0 10px; }
.brokers-style-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 14px;
}
.brokers-style-card {
	padding: 18px 20px;
	background: rgba(0,0,0,0.30);
	border: 1px solid var(--color-hairline);
	border-radius: var(--border-radius-sm);
	transition: border-color var(--duration-base);
}
.brokers-style-card:hover { border-color: var(--color-gold-deep); }
.brokers-style-head {
	display: flex;
	gap: 12px;
	align-items: flex-start;
	margin-bottom: 14px;
	padding-bottom: 12px;
	border-bottom: 1px solid var(--color-hairline);
}
.brokers-style-icon { font-size: 26px; line-height: 1; flex-shrink: 0; }
.brokers-style-title {
	font-family: var(--font-display-th);
	font-size: 16px;
	font-weight: 600;
	color: var(--color-cream);
	margin-bottom: 2px;
}
.brokers-style-desc {
	font-family: var(--font-display-th);
	font-size: 11.5px;
	color: var(--color-muted);
	line-height: 1.5;
}
.brokers-style-list { list-style: none; padding: 0; margin: 0; }
.brokers-style-list li { margin-bottom: 6px; }
.brokers-style-list li:last-child { margin-bottom: 0; }
.brokers-style-item {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 8px 10px;
	background: rgba(0,0,0,0.25);
	border: 1px solid transparent;
	border-radius: var(--border-radius-sm);
	text-decoration: none;
	transition: all var(--duration-base);
}
.brokers-style-item:hover {
	background: rgba(229,196,120,0.06);
	border-color: var(--color-gold-deep);
}
.brokers-style-logo {
	width: 28px; height: 28px;
	border-radius: 6px;
	font-size: 12px;
	font-weight: 700;
	display: flex; align-items: center; justify-content: center;
	flex-shrink: 0;
}
.brokers-style-logo img { width: 100%; height: 100%; object-fit: cover; border-radius: 6px; }
.brokers-style-name {
	flex: 1;
	font-family: var(--font-display-en);
	font-size: 13.5px;
	font-weight: 600;
	color: var(--color-cream);
}
.brokers-style-score {
	font-family: var(--font-mono);
	font-size: 11px;
	color: var(--color-gold-bright);
	font-weight: 600;
}

/* ── Pending brokers section · subtle "coming soon" feel ───── */
.brokers-pending {
	margin-top: 28px;
	padding: 20px 22px;
	background: rgba(0,0,0,0.20);
	border: 1px dashed var(--color-hairline);
	border-radius: var(--border-radius-sm);
}
.brokers-pending-head {
	display: flex;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
	margin-bottom: 14px;
}
.brokers-pending-tag {
	font-family: var(--font-mono);
	font-size: 10.5px;
	letter-spacing: 0.08em;
	padding: 4px 10px;
	background: rgba(229,180,80,0.10);
	color: #e5b450;
	border: 1px solid rgba(229,180,80,0.30);
	border-radius: 999px;
	text-transform: uppercase;
}
.brokers-pending-meta {
	font-family: var(--font-display-th);
	font-size: 12px;
	color: var(--color-muted);
}
.brokers-pending-list {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 8px;
}
.brokers-pending-card {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 12px;
	background: rgba(0,0,0,0.25);
	border: 1px solid var(--color-hairline);
	border-radius: var(--border-radius-sm);
	text-decoration: none;
	opacity: 0.75;
	transition: opacity var(--duration-base);
}
.brokers-pending-card:hover { opacity: 1; border-color: var(--color-gold-deep); }
.brokers-pending-logo {
	width: 32px; height: 32px;
	border-radius: 6px;
	font-size: 13px;
	font-weight: 700;
	display: flex; align-items: center; justify-content: center;
	flex-shrink: 0;
}
.brokers-pending-logo img { width: 100%; height: 100%; object-fit: cover; border-radius: 6px; }
.brokers-pending-body { flex: 1; min-width: 0; }
.brokers-pending-name {
	font-family: var(--font-display-en);
	font-size: 14px;
	color: var(--color-cream);
	font-weight: 600;
	display: flex; align-items: center; gap: 6px;
}
.brokers-pending-tagline {
	font-size: 11px;
	color: var(--color-muted);
	margin-top: 2px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.brokers-pending-cta {
	font-family: var(--font-mono);
	font-size: 11px;
	color: var(--color-gold-bright);
	letter-spacing: 0.04em;
}

/* ── Methodology section ────────────────────────────────────── */
.brokers-methodology {
	padding: 36px 0;
	background: linear-gradient(180deg, rgba(229,196,120,0.03) 0%, transparent 100%);
	border-top: 1px solid var(--color-hairline);
	border-bottom: 1px solid var(--color-hairline);
}
.brokers-method-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 14px;
	margin-bottom: 22px;
}
.brokers-method-card {
	position: relative;
	padding: 22px 22px 20px;
	background: rgba(0,0,0,0.30);
	border: 1px solid var(--color-hairline);
	border-radius: var(--border-radius-sm);
}
.brokers-method-num {
	position: absolute;
	top: 16px;
	right: 18px;
	font-family: var(--font-mono);
	font-size: 26px;
	font-weight: 700;
	color: var(--color-gold-deep);
	opacity: 0.50;
}
.brokers-method-icon { font-size: 28px; line-height: 1; margin-bottom: 10px; }
.brokers-method-title {
	font-family: var(--font-display-th);
	font-size: 15.5px;
	font-weight: 600;
	color: var(--color-cream);
	margin: 0 0 8px;
}
.brokers-method-text {
	font-family: var(--font-display-th);
	font-size: 12.5px;
	color: var(--color-cream-2);
	line-height: 1.7;
	margin: 0;
}
.brokers-method-note {
	padding: 14px 18px;
	background: rgba(0,0,0,0.25);
	border-left: 3px solid var(--color-gold-deep);
	border-radius: var(--border-radius-sm);
	font-family: var(--font-display-th);
	font-size: 12.5px;
	color: var(--color-cream-2);
	line-height: 1.7;
}
.brokers-method-note strong { color: var(--color-gold-bright); }

/* ── Verified Partner info icon · single broker hero ───────── */
.broker-hero-partner { cursor: help; }
.broker-hero-partner-info {
	display: inline-flex;
	width: 14px; height: 14px;
	align-items: center; justify-content: center;
	background: rgba(107,163,115,0.25);
	border-radius: 50%;
	font-size: 9px;
	margin-left: 2px;
	font-style: normal;
}

/* ── Rebate conditions disclaimer ──────────────────────────── */
.broker-rebate-conditions {
	margin-top: 10px;
	padding: 10px 14px;
	background: rgba(229,180,80,0.06);
	border: 1px solid rgba(229,180,80,0.25);
	border-radius: var(--border-radius-sm);
	font-family: var(--font-display-th);
	font-size: 12px;
	color: var(--color-cream-2);
	line-height: 1.7;
}
.broker-rebate-conditions strong { color: #e5b450; }

/* ── Final CTA benefit bullets ─────────────────────────────── */
.broker-final-benefits {
	list-style: none;
	padding: 0;
	margin: 0 auto 22px;
	max-width: 520px;
	text-align: left;
	font-family: var(--font-display-th);
}
.broker-final-benefits li {
	font-size: 13.5px;
	color: var(--color-cream-2);
	padding: 5px 0;
	border-bottom: 1px dashed var(--color-hairline);
	line-height: 1.6;
}
.broker-final-benefits li:last-child { border-bottom: none; }
.broker-final-benefits strong { color: var(--color-gold-bright); }

/* ── LINE / admin contact button · sage green ──────────────── */
.btn-line {
	display: inline-block;
	padding: 12px 22px;
	background: #06C755;
	color: #fff;
	font-family: var(--font-display-th);
	font-size: 14px;
	font-weight: 600;
	text-decoration: none;
	border-radius: var(--border-radius-sm);
	transition: all var(--duration-base);
	border: 1px solid #06C755;
}
.btn-line:hover {
	background: #05a847;
	border-color: #05a847;
	transform: translateY(-2px);
	box-shadow: 0 4px 14px rgba(6,199,85,0.30);
}

/* ── Income disclosure box · transparency ──────────────────── */
.broker-income-disclosure {
	display: flex;
	gap: 16px;
	margin-top: 24px;
	padding: 18px 22px;
	background: rgba(0,0,0,0.20);
	border: 1px solid var(--color-hairline);
	border-left: 3px solid var(--color-bull);
	border-radius: var(--border-radius-sm);
}
.broker-income-icon { font-size: 24px; line-height: 1; flex-shrink: 0; }
.broker-income-body { flex: 1; }
.broker-income-title {
	font-family: var(--font-display-th);
	font-size: 14px;
	font-weight: 600;
	color: var(--color-bull);
	margin: 0 0 6px;
}
.broker-income-body p {
	font-family: var(--font-display-th);
	font-size: 12.5px;
	color: var(--color-cream-2);
	line-height: 1.7;
	margin: 0;
}
.broker-income-body strong { color: var(--color-gold-bright); }
.broker-income-body a {
	color: var(--color-gold-bright);
	border-bottom: 1px solid var(--color-gold-deep);
	text-decoration: none;
}
.broker-income-body a:hover { color: var(--color-cream); }

@media (max-width: 700px) {
	.brokers-style-card { padding: 14px 16px; }
	.brokers-method-card { padding: 18px 16px 16px; }
	.brokers-method-num { font-size: 22px; top: 12px; right: 14px; }
	.broker-income-disclosure { flex-direction: column; gap: 8px; padding: 14px 16px; }
	.broker-final-buttons { flex-direction: column; }
	.broker-final-buttons a { width: 100%; text-align: center; }
}

/* ════════════════════════════════════════════════════════════
   v1.45.0 · Non-verified broker mode · honest informational
   ════════════════════════════════════════════════════════════ */

/* Hero NO-IB notice */
.broker-hero-noib {
	font-family: var(--font-display-th);
	font-size: 11px;
	color: var(--color-muted);
	margin-top: 6px;
	padding: 4px 10px;
	background: rgba(0,0,0,0.30);
	border: 1px dashed var(--color-hairline);
	border-radius: 999px;
	text-align: center;
}

/* Final CTA · info mode (non-verified) · neutral tone vs verified gold */
.broker-final-benefits-info li {
	color: var(--color-cream-2);
}
.broker-final-benefits-info strong {
	color: var(--color-cream);
}
.broker-final-benefits-info a {
	color: var(--color-gold-bright);
	text-decoration: none;
	border-bottom: 1px solid var(--color-gold-deep);
}

/* Large ghost button · non-verified primary CTA */
.btn-ghost-large {
	padding: 14px 28px;
	font-size: 15px;
	border: 2px solid var(--color-hairline);
}
.btn-ghost-large:hover {
	border-color: var(--color-gold-deep);
	background: rgba(229,196,120,0.04);
	transform: translateY(-2px);
}

/* ════════════════════════════════════════════════════════════
   v1.47.0 · Legal disclaimer · opinion privilege + verification
   ════════════════════════════════════════════════════════════ */
.broker-legal-disclaimer {
	display: flex;
	gap: 18px;
	padding: 22px 26px;
	background: linear-gradient(180deg, rgba(229,180,80,0.04) 0%, rgba(0,0,0,0.30) 100%);
	border: 1px solid rgba(229,180,80,0.25);
	border-radius: var(--border-radius-sm);
}
.broker-legal-icon {
	font-size: 30px;
	line-height: 1;
	flex-shrink: 0;
	margin-top: 2px;
}
.broker-legal-body { flex: 1; }
.broker-legal-title {
	font-family: var(--font-display-th);
	font-size: 16px;
	font-weight: 600;
	color: #e5b450;
	margin: 0 0 12px;
}
.broker-legal-body p {
	font-family: var(--font-display-th);
	font-size: 12.5px;
	color: var(--color-cream-2);
	line-height: 1.75;
	margin: 0 0 10px;
}
.broker-legal-body p:last-child { margin-bottom: 0; }
.broker-legal-body strong { color: var(--color-cream); }
.broker-legal-body a {
	color: var(--color-gold-bright);
	text-decoration: none;
	border-bottom: 1px solid var(--color-gold-deep);
}
.broker-legal-body a:hover { color: var(--color-cream); border-color: var(--color-cream); }

@media (max-width: 700px) {
	.broker-legal-disclaimer { flex-direction: column; gap: 10px; padding: 18px 18px; }
	.broker-legal-icon { font-size: 24px; }
	.broker-legal-body p { font-size: 12px; }
}

/* ════════════════════════════════════════════════════════════
   v1.48.0 · Min deposit note · Rebate-pending pill
   ════════════════════════════════════════════════════════════ */

/* Quick stats note · hint text below value */
.broker-qs-note {
	font-family: var(--font-display-th);
	font-size: 10.5px;
	color: var(--color-muted);
	margin-top: 6px;
	line-height: 1.5;
	border-top: 1px dashed var(--color-hairline);
	padding-top: 6px;
}

/* "ดูเงื่อนไข" placeholder when no fixed min */
.broker-qs-val-text {
	font-family: var(--font-display-th);
	font-size: 13px;
	font-weight: 600;
	color: var(--color-cream-2);
	font-style: italic;
}

/* Rebate "สอบถาม" pill · gentle CTA instead of dash */
.brokers-rebate-pending {
	display: inline-block;
	padding: 3px 10px;
	background: rgba(229,180,80,0.08);
	color: #b89a5e;
	border: 1px dashed rgba(229,180,80,0.30);
	border-radius: 999px;
	font-family: var(--font-display-th);
	font-size: 11px;
	cursor: help;
	transition: all var(--duration-base);
}
.brokers-rebate-pending:hover {
	background: rgba(229,180,80,0.14);
	color: #e5b450;
	border-color: rgba(229,180,80,0.50);
}

/* ════════════════════════════════════════════════════════════
   v1.50.0 · Archive table cell note tooltip
   ════════════════════════════════════════════════════════════ */
.bt-val {
	font-family: var(--font-mono);
	font-weight: 600;
}
.bt-val-text {
	font-family: var(--font-display-th);
	font-size: 12px;
	font-style: italic;
	color: var(--color-cream-2);
}
.bt-cell-note {
	display: inline-flex;
	width: 14px; height: 14px;
	align-items: center;
	justify-content: center;
	margin-left: 4px;
	background: rgba(229,180,80,0.15);
	color: #e5b450;
	border-radius: 50%;
	font-size: 9px;
	cursor: help;
	transition: all var(--duration-base);
}
.bt-cell-note:hover {
	background: rgba(229,180,80,0.30);
}

/* ════════════════════════════════════════════════════════════
   v1.50.5 · ForexFactory direct link · for real-time actual verification
   ════════════════════════════════════════════════════════════ */
.market-cal-detail-link-ff {
	background: rgba(229,180,80,0.10) !important;
	border-color: rgba(229,180,80,0.40) !important;
	color: #e5b450 !important;
}
.market-cal-detail-link-ff:hover {
	background: rgba(229,180,80,0.20) !important;
	color: #fff !important;
}

/* Feed delay notice · above calendar table */
.market-cal-delay-notice {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 14px;
	margin: 0 0 12px;
	background: linear-gradient(180deg, rgba(229,180,80,0.04) 0%, rgba(0,0,0,0.20) 100%);
	border: 1px solid rgba(229,180,80,0.20);
	border-left: 3px solid rgba(229,180,80,0.50);
	border-radius: var(--border-radius-sm);
	font-family: var(--font-display-th);
	font-size: 12px;
	color: var(--color-cream-2);
	line-height: 1.6;
}
.market-cal-delay-icon {
	font-size: 18px;
	line-height: 1;
	flex-shrink: 0;
}
.market-cal-delay-text strong { color: var(--color-cream); }
.market-cal-delay-text a {
	color: #e5b450;
	text-decoration: underline;
	text-underline-offset: 2px;
}
.market-cal-delay-text a:hover { color: #fff; }

/* ════════════════════════════════════════════════════════════
   v1.51.0 · Calendar view switcher (AuHunter vs LIVE TradingView)
   ════════════════════════════════════════════════════════════ */
.market-cal-viewtabs {
	display: flex;
	gap: 4px;
	border-bottom: 0.5px solid rgba(229,180,80,0.15);
	margin: 0 0 14px;
	padding: 0;
	overflow-x: auto;
	scrollbar-width: none;
}
.market-cal-viewtabs::-webkit-scrollbar { display: none; }

.market-cal-viewtab {
	background: transparent;
	border: 0;
	color: var(--color-cream-3, #8a8780);
	cursor: pointer;
	padding: 12px 18px;
	font-family: var(--font-display-th);
	font-weight: 500;
	font-size: 13px;
	display: flex;
	align-items: center;
	gap: 10px;
	border-bottom: 2px solid transparent;
	margin-bottom: -0.5px;
	transition: color 180ms ease, border-color 180ms ease;
	flex-shrink: 0;
}
.market-cal-viewtab:hover { color: var(--color-cream, #e8e5dd); }
.market-cal-viewtab.is-active {
	color: #e5b450;
	border-bottom-color: #e5b450;
}
.market-cal-viewtab-icon {
	font-size: 16px;
	line-height: 1;
}
.market-cal-viewtab-dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: #e24b4a;
	box-shadow: 0 0 0 4px rgba(226,75,74,0.20);
	flex-shrink: 0;
	animation: auh-live-pulse 1.6s infinite;
}
@keyframes auh-live-pulse {
	0%, 100% { box-shadow: 0 0 0 4px rgba(226,75,74,0.20); }
	50%      { box-shadow: 0 0 0 7px rgba(226,75,74,0.05); }
}
.market-cal-viewtab-text {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 1px;
	line-height: 1.2;
}
.market-cal-viewtab-label {
	font-size: 13px;
	font-weight: 600;
}
.market-cal-viewtab-sub {
	font-size: 10px;
	color: var(--color-cream-3, #8a8780);
	font-weight: 400;
	letter-spacing: 0.2px;
}
.market-cal-viewtab.is-active .market-cal-viewtab-sub { color: rgba(229,180,80,0.65); }

.market-cal-viewpane[hidden] { display: none; }
.market-cal-viewpane.is-active { display: block; }

/* LIVE pane info banner */
.market-cal-live-info {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	padding: 12px 16px;
	margin: 0 0 12px;
	background: linear-gradient(180deg, rgba(226,75,74,0.06) 0%, rgba(0,0,0,0.20) 100%);
	border: 1px solid rgba(226,75,74,0.20);
	border-left: 3px solid #e24b4a;
	border-radius: var(--border-radius-sm);
	font-family: var(--font-display-th);
	color: var(--color-cream-2);
	line-height: 1.6;
}
.market-cal-live-dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: #e24b4a;
	box-shadow: 0 0 0 4px rgba(226,75,74,0.20);
	flex-shrink: 0;
	margin-top: 6px;
	animation: auh-live-pulse 1.6s infinite;
}
.market-cal-live-text { font-size: 13px; }
.market-cal-live-text strong { color: var(--color-cream); }
.market-cal-live-text small {
	display: block;
	margin-top: 4px;
	font-size: 11px;
	color: var(--color-cream-3);
}
.market-cal-live-widget {
	min-height: 540px;
}

/* Hint banner when there are no_data events · show in AuHunter view */
.market-cal-live-hint {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 10px 16px;
	margin: 12px 0 0;
	background: rgba(226,75,74,0.06);
	border: 0.5px dashed rgba(226,75,74,0.30);
	border-radius: var(--border-radius-sm);
	font-family: var(--font-display-th);
	font-size: 12px;
	color: var(--color-cream-2);
	cursor: pointer;
	transition: background 180ms ease;
}
.market-cal-live-hint:hover { background: rgba(226,75,74,0.12); }
.market-cal-live-hint strong { color: #e24b4a; }
.market-cal-live-hint .market-cal-live-hint-cta {
	color: #e5b450;
	font-weight: 600;
	text-decoration: underline;
	text-underline-offset: 2px;
}

/* Mobile · stack tab text vertically · keep readable */
@media (max-width: 640px) {
	.market-cal-viewtab { padding: 10px 12px; gap: 8px; }
	.market-cal-viewtab-label { font-size: 12px; }
	.market-cal-viewtab-sub { font-size: 9px; }
	.market-cal-live-widget { min-height: 480px; }
}

/* ════════════════════════════════════════════════════════════
   v1.52.0 · Minimal "news at a glance" calendar
   ════════════════════════════════════════════════════════════ */

/* Top row · week range + timezone */
.cal-mini-toprow {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin: 0 0 12px;
	flex-wrap: wrap;
}
.cal-mini-weekrange {
	font-family: var(--font-display-th);
	font-size: 13px;
	color: var(--color-cream-2);
	font-weight: 500;
}
.cal-mini-tz-select {
	background: rgba(0,0,0,0.30);
	border: 0.5px solid rgba(229,180,80,0.20);
	color: var(--color-cream-2);
	font-family: var(--font-display-th);
	font-size: 12px;
	padding: 6px 10px;
	border-radius: var(--border-radius-sm);
	cursor: pointer;
	transition: border-color 180ms ease;
}
.cal-mini-tz-select:hover, .cal-mini-tz-select:focus { border-color: rgba(229,180,80,0.50); outline: 0; }

/* Filter chips */
.cal-mini-chips {
	display: flex;
	gap: 8px;
	margin: 0 0 16px;
	overflow-x: auto;
	scrollbar-width: none;
	padding-bottom: 4px;
}
.cal-mini-chips::-webkit-scrollbar { display: none; }
.cal-mini-chip {
	background: transparent;
	border: 0.5px solid rgba(255,255,255,0.10);
	color: var(--color-cream-3);
	cursor: pointer;
	padding: 7px 14px;
	font-family: var(--font-display-th);
	font-size: 12px;
	font-weight: 500;
	border-radius: 14px;
	white-space: nowrap;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	transition: all 180ms ease;
	flex-shrink: 0;
}
.cal-mini-chip:hover { border-color: rgba(229,180,80,0.40); color: var(--color-cream); }
.cal-mini-chip.is-active {
	background: rgba(229,180,80,0.15);
	border-color: #e5b450;
	color: #e5b450;
}
.cal-mini-chip-high .cal-mini-chip-dot {
	width: 8px;
	height: 8px;
	border-radius: 2px;
	background: #c92020;
	display: inline-block;
}
.cal-mini-chip-high.is-active { background: rgba(201,32,32,0.15); border-color: #c92020; color: #ff7777; }

/* Day header */
.cal-mini-day {
	padding: 14px 16px 8px;
	font-family: var(--font-display-th);
	font-size: 13px;
	color: #e5b450;
	font-weight: 500;
	display: flex;
	align-items: center;
	gap: 10px;
	border-bottom: 0.5px solid rgba(229,180,80,0.10);
	background: rgba(229,180,80,0.02);
}
.cal-mini-tag {
	font-size: 10px;
	padding: 3px 9px;
	border-radius: 8px;
	font-weight: 600;
	letter-spacing: 0.5px;
}
.cal-mini-tag-today { background: rgba(229,180,80,0.25); color: #e5b450; }
.cal-mini-tag-tomorrow { background: rgba(151,196,89,0.15); color: #97c459; }

/* Event row · the whole row is a clickable link */
.cal-mini-row {
	display: grid;
	grid-template-columns: 64px 80px 28px 1fr 24px;
	gap: 14px;
	padding: 13px 16px;
	align-items: center;
	border-bottom: 0.5px solid #1a1a1a;
	cursor: pointer;
	transition: background 180ms ease;
	text-decoration: none;
	color: inherit;
}
.cal-mini-row:hover {
	background: rgba(229,180,80,0.04);
	text-decoration: none;
}
.cal-mini-row.is-high {
	border-left: 2px solid #c92020;
	padding-left: 14px;
	background: rgba(201,32,32,0.03);
}
.cal-mini-row.is-high:hover { background: rgba(201,32,32,0.07); }
.cal-mini-row.is-past {
	opacity: 0.45;
	background: rgba(255,255,255,0.012);
}
.cal-mini-row.is-past:hover { opacity: 0.85; }
.cal-mini-row.is-past .cal-mini-time { text-decoration: line-through; text-decoration-thickness: 1px; text-decoration-color: rgba(255,255,255,0.30); }
.cal-mini-row.is-past .cal-mini-arrow {
	color: #4a7c2e;
	font-weight: 600;
}
.cal-mini-row.is-past.is-high { opacity: 0.55; }  /* HIGH past events slightly more visible */
.cal-mini-row.is-past.is-high:hover { opacity: 0.95; }

.cal-mini-time {
	font-family: var(--font-mono);
	font-size: 13px;
	color: var(--color-cream);
	font-weight: 500;
}
.cal-mini-cur {
	font-family: var(--font-mono);
	font-size: 12px;
	color: var(--color-cream-2);
	letter-spacing: 0.3px;
}
.cal-mini-impact {
	display: block;
	margin: 0 auto;
}
.cal-mini-name {
	font-family: var(--font-display-th);
	font-size: 13px;
	color: var(--color-cream);
	line-height: 1.35;
}
.cal-mini-row.is-high .cal-mini-name { font-weight: 600; color: #fff; }
.cal-mini-arrow {
	color: #666;
	font-size: 14px;
	font-family: var(--font-mono);
	transition: color 180ms ease, transform 180ms ease;
	text-align: center;
}
.cal-mini-row:hover .cal-mini-arrow {
	color: #e5b450;
	transform: translateX(2px);
}

/* Filtered out · hidden via JS */
.cal-mini-row[hidden], .cal-mini-day[hidden] { display: none; }

/* Legend / footer */
.cal-mini-legend {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	padding: 14px 16px;
	border-top: 0.5px solid #1a1a1a;
	background: rgba(0,0,0,0.20);
	font-family: var(--font-display-th);
	font-size: 11px;
	color: var(--color-cream-3);
	flex-wrap: wrap;
}
.cal-mini-legend-keys {
	display: flex;
	align-items: center;
	gap: 16px;
}
.cal-mini-legend-keys span {
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.cal-mini-legend-folder {
	width: 14px !important;
	height: 11px !important;
}
.cal-mini-legend-meta a { color: #e5b450; text-decoration: underline; }

/* Error state */
.cal-mini-error {
	padding: 30px 20px;
	text-align: center;
	font-family: var(--font-display-th);
	color: var(--color-cream-2);
}
.cal-mini-error p { margin: 0 0 6px; font-size: 14px; }
.cal-mini-error small { font-size: 12px; color: var(--color-cream-3); }

/* Mobile */
@media (max-width: 640px) {
	.cal-mini-row {
		grid-template-columns: 52px 40px 22px 1fr 18px;
		gap: 10px;
		padding: 12px 12px;
	}
	.cal-mini-time { font-size: 12px; }
	.cal-mini-cur { font-size: 10px; }
	.cal-mini-name { font-size: 12px; }
	.cal-mini-day { padding: 12px 12px 6px; font-size: 12px; }
	.cal-mini-toprow { flex-direction: column; align-items: stretch; }
	.cal-mini-legend { flex-direction: column; align-items: flex-start; gap: 8px; }
}

/* v1.52.1 · Currency filter chips · 2nd row */
.cal-mini-chips-cur {
	border-top: 0.5px solid rgba(255,255,255,0.05);
	padding-top: 12px;
	margin-top: -8px;
	align-items: center;
}
.cal-mini-chips-label {
	font-family: var(--font-display-th);
	font-size: 11px;
	color: var(--color-cream-3);
	letter-spacing: 0.3px;
	flex-shrink: 0;
	margin-right: 4px;
}
.cal-mini-chip-gold {
	background: linear-gradient( 180deg, rgba(229,180,80,0.10) 0%, rgba(229,180,80,0.05) 100% );
	border-color: rgba(229,180,80,0.35) !important;
	color: #e5b450 !important;
	font-weight: 600;
}
.cal-mini-chip-gold.is-active {
	background: rgba(229,180,80,0.22) !important;
	border-color: #e5b450 !important;
	color: #e5b450 !important;
	box-shadow: 0 0 0 1px rgba(229,180,80,0.25);
}
.cal-mini-chip-gold-icon {
	font-size: 13px;
	line-height: 1;
}

/* v1.52.3 · Next upcoming event marker · ▶ green play icon · subtle pulse */
.cal-mini-row.is-next {
	background: linear-gradient( 90deg, rgba(151,196,89,0.06) 0%, rgba(151,196,89,0.02) 60%, transparent 100% );
	position: relative;
}
.cal-mini-row.is-next::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 3px;
	background: linear-gradient( 180deg, #97c459 0%, #5a8a32 100% );
	box-shadow: 0 0 6px rgba(151,196,89,0.40);
}
.cal-mini-row.is-next .cal-mini-time {
	color: #c9e09a;
	font-weight: 600;
}
.cal-mini-next-icon {
	display: inline-block;
	color: #97c459;
	font-size: 10px;
	margin-right: 6px;
	animation: auh-next-pulse 1.6s ease-in-out infinite;
	transform: translateY(-1px);
}
@keyframes auh-next-pulse {
	0%, 100% { opacity: 1; transform: translateY(-1px) scale(1); }
	50%      { opacity: 0.55; transform: translateY(-1px) scale(0.92); }
}
/* When is-next combines with is-high · keep red border priority + green icon */
.cal-mini-row.is-next.is-high::before {
	background: linear-gradient( 180deg, #c92020 0%, #97c459 100% );
}
.cal-mini-row.is-next:hover { background: rgba(151,196,89,0.10); }

/* v1.52.4 · Stale data notice (when last_good fallback in use) */
.cal-mini-stale-notice {
	padding: 10px 16px;
	margin-bottom: 12px;
	background: rgba(229,180,80,0.06);
	border: 0.5px solid rgba(229,180,80,0.20);
	border-radius: var(--border-radius-sm);
	font-family: var(--font-display-th);
	font-size: 12px;
	color: var(--color-cream-2);
	line-height: 1.5;
}
.cal-mini-stale-notice strong { color: #e5b450; }

/* ════════════════════════════════════════════════════════════
   v1.52.5 · Mobile fix · prevent calendar card overflow on narrow screens
   ════════════════════════════════════════════════════════════ */
.market-col-main, .market-card {
	min-width: 0;
	max-width: 100%;
}
.cal-mini-chips, .cal-mini-list, .cal-mini-toprow, .cal-mini-legend {
	max-width: 100%;
	min-width: 0;
}
.cal-mini-row {
	min-width: 0;
}
.cal-mini-name {
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

@media (max-width: 640px) {
	/* More compact chips on mobile */
	.cal-mini-chip {
		padding: 6px 11px;
		font-size: 11px;
		gap: 4px;
	}
	.cal-mini-chip-gold {
		padding: 6px 9px;
	}
	.cal-mini-chips-label {
		font-size: 10px;
		margin-right: 2px;
	}

	/* v1.52.6 · Shrink the folder icon on mobile to prevent overlap with name */
	.cal-mini-impact.impact-folder {
		width: 22px !important;
		height: 18px !important;
	}
	.cal-mini-impact.impact-folder::before {
		width: 8px !important;
		height: 4px !important;
		top: -3px !important;
		left: 3px !important;
	}

	/* Narrower row columns on mobile · impact column = 26px (fits 22px folder + breathing room) */
	.cal-mini-row {
		grid-template-columns: 48px 40px 26px 1fr 16px !important;
		gap: 8px !important;
		padding: 11px 10px !important;
	}
	.cal-mini-time { font-size: 12px; }
	.cal-mini-cur { font-size: 10px; }
	.cal-mini-name { font-size: 12px; }
	.cal-mini-next-icon { font-size: 9px; margin-right: 3px; }

	/* Toprow stacks vertically · TZ select fits */
	.cal-mini-toprow {
		flex-direction: column;
		align-items: stretch;
		gap: 8px;
	}
	.cal-mini-tz-select { width: 100%; }

	/* Legend stacks · less cramped */
	.cal-mini-legend {
		flex-direction: column;
		align-items: flex-start;
		gap: 8px;
		font-size: 10px;
	}

	/* Calendar card · slightly less padding on mobile */
	.market-col-main .market-card {
		padding: 14px 12px;
	}
}

/* Extra-narrow phones (≤380px) · ultra compact */
@media (max-width: 380px) {
	.cal-mini-impact.impact-folder {
		width: 18px !important;
		height: 14px !important;
	}
	.cal-mini-impact.impact-folder::before {
		width: 7px !important;
		height: 3px !important;
		top: -2px !important;
		left: 2px !important;
	}
	.cal-mini-row {
		grid-template-columns: 44px 32px 22px 1fr 14px !important;
		gap: 6px !important;
		padding: 10px 8px !important;
	}
	.cal-mini-cur {
		font-size: 9px;
		letter-spacing: 0;
	}
}

/* v1.53.0 · Safety-revised copy · data note under calendar */
.cal-mini-data-note {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	padding: 10px 14px;
	margin: 0 0 8px;
	background: rgba(229,180,80,0.04);
	border: 0.5px solid rgba(229,180,80,0.15);
	border-radius: var(--border-radius-sm);
	font-family: var(--font-display-th);
	font-size: 11px;
	color: var(--color-cream-3);
	line-height: 1.5;
}
.cal-mini-data-note-icon { flex-shrink: 0; }

/* v1.53.1 · Market Brief · Next HIGH event countdown card */
.market-brief-card-next {
	border-left: 2px solid rgba(229,180,80,0.40);
}
.market-brief-next-title {
	font-size: 14px !important;
	line-height: 1.4;
	color: var(--color-cream) !important;
	overflow: hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}
.market-brief-next-countdown {
	color: #e5b450;
	font-weight: 600;
}

/* ════════════════════════════════════════════════════════════
   v1.53.2 · "How to use this page in 30s" · onboarding card
   ════════════════════════════════════════════════════════════ */
.market-howto {
	padding: 16px 0 8px;
}
.market-howto-card {
	background: linear-gradient( 180deg, rgba(229,180,80,0.05) 0%, rgba(229,180,80,0.01) 100% );
	border: 0.5px solid rgba(229,180,80,0.25);
	border-radius: var(--border-radius-md);
	padding: 0;
	overflow: hidden;
}
.market-howto-summary {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 14px 18px;
	cursor: pointer;
	list-style: none;
	user-select: none;
	font-family: var(--font-display-th);
	transition: background 180ms ease;
}
.market-howto-summary::-webkit-details-marker { display: none; }
.market-howto-summary:hover { background: rgba(229,180,80,0.04); }
.market-howto-icon {
	font-size: 18px;
	line-height: 1;
}
.market-howto-title {
	flex: 1;
	font-size: 15px;
	font-weight: 600;
	color: #e5b450;
	letter-spacing: 0.2px;
}
.market-howto-toggle {
	width: 0;
	height: 0;
	border-left: 5px solid transparent;
	border-right: 5px solid transparent;
	border-top: 6px solid #e5b450;
	transition: transform 220ms ease;
}
.market-howto-card[open] .market-howto-toggle { transform: rotate(180deg); }

.market-howto-steps {
	list-style: none;
	margin: 0;
	padding: 4px 18px 14px;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.market-howto-steps li {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	padding: 8px 12px;
	background: rgba(0,0,0,0.20);
	border: 0.5px solid rgba(255,255,255,0.05);
	border-radius: var(--border-radius-sm);
	transition: background 180ms ease;
}
.market-howto-steps li:hover { background: rgba(0,0,0,0.30); }
.market-howto-step-num {
	flex-shrink: 0;
	width: 24px;
	height: 24px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(229,180,80,0.20);
	color: #e5b450;
	border-radius: 50%;
	font-family: var(--font-mono);
	font-size: 12px;
	font-weight: 700;
}
.market-howto-step-text {
	flex: 1;
	font-family: var(--font-display-th);
	font-size: 13px;
	line-height: 1.55;
	color: var(--color-cream-2);
}
.market-howto-step-text strong { color: var(--color-cream); }
.market-howto-step-text a {
	color: #e5b450;
	text-decoration: underline;
	text-underline-offset: 2px;
}
.market-howto-step-text a:hover { color: #fff; }

.market-howto-disclaimer {
	margin: 4px 18px 14px;
	padding: 8px 12px;
	background: rgba(255,255,255,0.02);
	border-left: 2px solid rgba(229,180,80,0.30);
	border-radius: 4px;
	font-family: var(--font-display-th);
	font-size: 11px;
	color: var(--color-cream-3);
	line-height: 1.5;
}

/* Mobile · slightly tighter spacing */
@media (max-width: 640px) {
	.market-howto-summary { padding: 12px 14px; }
	.market-howto-title { font-size: 14px; }
	.market-howto-steps { padding: 4px 14px 12px; }
	.market-howto-steps li { padding: 8px 10px; gap: 10px; }
	.market-howto-step-num { width: 22px; height: 22px; font-size: 11px; }
	.market-howto-step-text { font-size: 12px; }
	.market-howto-disclaimer { margin: 4px 14px 12px; font-size: 10px; }
}

/* ════════════════════════════════════════════════════════════
   v1.53.3 · Reviewer feedback polish · CTA · mobile calendar · FAB
   ════════════════════════════════════════════════════════════ */

/* Mobile calendar · improve row legibility · larger touch targets */
@media (max-width: 640px) {
	/* Chips · 38px tap target (Apple/Google guideline 36-44) */
	.cal-mini-chip {
		min-height: 38px;
		padding: 9px 13px !important;
		font-size: 11.5px !important;
	}
	.cal-mini-chip-gold { padding: 9px 11px !important; }

	/* Rows · taller + better line-height · easier to scan & tap */
	.cal-mini-row {
		padding: 13px 12px !important;
		min-height: 48px;  /* Apple HIG minimum */
	}
	.cal-mini-name {
		line-height: 1.45 !important;
	}
	.cal-mini-time {
		line-height: 1.4;
		font-weight: 600;  /* clearer time anchor */
	}

	/* Day header · more breathing room */
	.cal-mini-day {
		padding: 16px 12px 10px !important;
	}

	/* Date filter chips (row 1) · same tap target */
	.cal-mini-chips:not(.cal-mini-chips-cur) .cal-mini-chip {
		min-height: 38px;
	}
}

/* ────────────────────────────────────────────
   v1.53.3 · Floating "ดูข่าววันนี้" button · mobile only
   ──────────────────────────────────────────── */
.market-fab-calendar {
	position: fixed;
	bottom: 20px;
	right: 16px;
	z-index: 90;
	display: none;
	align-items: center;
	gap: 8px;
	padding: 12px 18px;
	background: linear-gradient( 180deg, #e5b450 0%, #c79532 100% );
	color: #0a0a0a;
	border-radius: 26px;
	font-family: var(--font-display-th);
	font-weight: 700;
	font-size: 13px;
	text-decoration: none;
	box-shadow: 0 6px 24px rgba(0,0,0,0.45), 0 0 0 0.5px rgba(229,180,80,0.50);
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 280ms ease, transform 280ms ease;
	pointer-events: none;
}
.market-fab-calendar:hover { text-decoration: none; color: #0a0a0a; }
.market-fab-calendar.is-visible:not(.is-hidden) {
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}
.market-fab-calendar.is-hidden {
	opacity: 0;
	transform: translateY(20px) scale(0.9);
	pointer-events: none;
}
.market-fab-icon {
	font-size: 16px;
	line-height: 1;
}

/* Show only on mobile · desktop has hero CTA already */
@media (max-width: 768px) {
	.market-fab-calendar { display: inline-flex; }
}
@media (max-width: 380px) {
	.market-fab-calendar { padding: 11px 15px; font-size: 12px; }
	.market-fab-label { font-size: 12px; }
}

/* v1.54.1 · Yoast Premium breadcrumb styling · match our theme */
.auh-breadcrumbs-yoast {
	background: transparent;
	padding: 12px 0 4px;
	font-family: var(--font-display-th);
	font-size: 12px;
	color: var(--color-cream-3);
}
.auh-breadcrumbs-yoast a {
	color: var(--color-cream-2);
	text-decoration: none;
	transition: color 180ms ease;
}
.auh-breadcrumbs-yoast a:hover {
	color: #e5b450;
}
.auh-breadcrumbs-yoast .breadcrumb_last,
.auh-breadcrumbs-yoast span[aria-current="page"] {
	color: #e5b450;
	font-weight: 500;
}

/* v1.54.3 · Optional SEO intro section · renders WP editor content */
.market-intro {
	padding: 8px 0 16px;
}
.market-intro-content {
	max-width: 880px;
	margin: 0 auto;
	font-family: var(--font-display-th);
	font-size: 14px;
	line-height: 1.75;
	color: var(--color-cream-2);
}
.market-intro-content h2 {
	font-size: 17px;
	color: var(--color-cream);
	margin: 18px 0 8px;
	font-weight: 600;
	letter-spacing: 0.2px;
}
.market-intro-content h3 {
	font-size: 15px;
	color: var(--color-cream);
	margin: 14px 0 6px;
	font-weight: 600;
}
.market-intro-content p {
	margin: 0 0 12px;
}
.market-intro-content a {
	color: #e5b450;
	text-decoration: underline;
	text-underline-offset: 2px;
}
.market-intro-content a:hover { color: #fff; }
.market-intro-content ul, .market-intro-content ol {
	margin: 0 0 12px;
	padding-left: 22px;
}
.market-intro-content li { margin-bottom: 4px; }
.market-intro-content strong { color: var(--color-cream); }

@media (max-width: 640px) {
	.market-intro-content { font-size: 13px; line-height: 1.65; }
	.market-intro-content h2 { font-size: 15px; }
}

/* ════════════════════════════════════════════════════════════
   v1.55.2 · Single indicator · Key Features section
   ════════════════════════════════════════════════════════════ */
.product-features-sec {
	background: var(--color-background, #0a0a0a);
}
.product-features-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 20px;
	max-width: 900px;
	margin: 0 auto;
}
.product-feature-card {
	position: relative;
	padding: 28px 30px;
	background: linear-gradient( 180deg, rgba(229,180,80,0.04) 0%, rgba(229,180,80,0.01) 100% );
	border: 0.5px solid rgba(229,180,80,0.18);
	border-radius: var(--border-radius-md, 8px);
	display: flex;
	align-items: flex-start;
	gap: 18px;
	transition: border-color 220ms ease, transform 220ms ease;
}
.product-feature-card:hover {
	border-color: rgba(229,180,80,0.40);
	transform: translateY(-2px);
}
.product-feature-num {
	flex-shrink: 0;
	font-family: var(--font-display, Georgia, serif);
	font-size: 26px;
	font-style: italic;
	color: var(--color-gold, #e5b450);
	line-height: 1;
	opacity: 0.6;
}
.product-feature-text {
	font-family: var(--font-display-th, sans-serif);
	font-size: 15px;
	line-height: 1.55;
	color: var(--color-cream, #e8e5dd);
	padding-top: 4px;
}

@media (max-width: 720px) {
	.product-features-grid {
		grid-template-columns: 1fr;
		gap: 14px;
	}
	.product-feature-card {
		padding: 22px 22px;
		gap: 14px;
	}
	.product-feature-num { font-size: 22px; }
	.product-feature-text { font-size: 14px; }
}

/* ════════════════════════════════════════════════════════════
   v1.56.0 · Single indicator · Deep Features · How-to · FAQ
   ════════════════════════════════════════════════════════════ */

/* Deep Features · numbered list with title + desc */
.product-deep-list {
	max-width: 820px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: 28px;
}
.product-deep-item {
	display: flex;
	gap: 22px;
	align-items: flex-start;
	padding-bottom: 28px;
	border-bottom: 0.5px solid rgba(229,180,80,0.12);
}
.product-deep-item:last-child { border-bottom: 0; padding-bottom: 0; }
.product-deep-num {
	flex-shrink: 0;
	font-family: var(--font-display, Georgia, serif);
	font-size: 32px;
	font-style: italic;
	color: var(--color-gold, #e5b450);
	line-height: 1;
	opacity: 0.5;
	min-width: 48px;
}
.product-deep-title {
	font-family: var(--font-display-th, sans-serif);
	font-size: 18px;
	font-weight: 600;
	color: var(--color-cream, #fff);
	margin: 0 0 8px;
	line-height: 1.4;
}
.product-deep-desc {
	font-family: var(--font-display-th, sans-serif);
	font-size: 14.5px;
	line-height: 1.7;
	color: var(--color-cream-2, #c9c4b8);
	margin: 0;
}

/* How-to · numbered steps */
.product-howto-list {
	max-width: 760px;
	margin: 0 auto;
	padding: 0;
	list-style: none;
	counter-reset: howto;
}
.product-howto-step {
	display: flex;
	gap: 20px;
	align-items: flex-start;
	margin-bottom: 24px;
	position: relative;
}
.product-howto-step:not(:last-child)::after {
	content: '';
	position: absolute;
	left: 19px;
	top: 44px;
	bottom: -24px;
	width: 1px;
	background: linear-gradient( 180deg, rgba(229,180,80,0.30), transparent );
}
.product-howto-marker {
	flex-shrink: 0;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: rgba(229,180,80,0.12);
	border: 0.5px solid rgba(229,180,80,0.40);
	color: var(--color-gold, #e5b450);
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--font-mono, monospace);
	font-size: 15px;
	font-weight: 700;
	z-index: 1;
}
.product-howto-title {
	font-family: var(--font-display-th, sans-serif);
	font-size: 17px;
	font-weight: 600;
	color: var(--color-cream, #fff);
	margin: 6px 0 6px;
	line-height: 1.4;
}
.product-howto-desc {
	font-family: var(--font-display-th, sans-serif);
	font-size: 14px;
	line-height: 1.7;
	color: var(--color-cream-2, #c9c4b8);
	margin: 0;
}

/* FAQ · accordion */
.product-faq-list {
	max-width: 760px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.product-faq-item {
	background: rgba(255,255,255,0.02);
	border: 0.5px solid rgba(229,180,80,0.15);
	border-radius: var(--border-radius-md, 8px);
	overflow: hidden;
	transition: border-color 200ms ease;
}
.product-faq-item[open] { border-color: rgba(229,180,80,0.35); }
.product-faq-q {
	padding: 18px 22px;
	cursor: pointer;
	font-family: var(--font-display-th, sans-serif);
	font-size: 15.5px;
	font-weight: 600;
	color: var(--color-cream, #fff);
	list-style: none;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	transition: color 180ms ease;
}
.product-faq-q::-webkit-details-marker { display: none; }
.product-faq-q::after {
	content: '+';
	font-size: 22px;
	color: var(--color-gold, #e5b450);
	flex-shrink: 0;
	transition: transform 220ms ease;
	line-height: 1;
}
.product-faq-item[open] .product-faq-q::after { transform: rotate(45deg); }
.product-faq-q:hover { color: var(--color-gold, #e5b450); }
.product-faq-a {
	padding: 0 22px 20px;
	font-family: var(--font-display-th, sans-serif);
	font-size: 14.5px;
	line-height: 1.75;
	color: var(--color-cream-2, #c9c4b8);
}

@media (max-width: 720px) {
	.product-deep-num { font-size: 26px; min-width: 38px; }
	.product-deep-title { font-size: 16px; }
	.product-deep-item { gap: 16px; }
	.product-howto-step { gap: 14px; }
	.product-howto-marker { width: 34px; height: 34px; font-size: 13px; }
	.product-howto-step:not(:last-child)::after { left: 16px; top: 38px; }
	.product-faq-q { font-size: 14.5px; padding: 16px 18px; }
	.product-faq-a { padding: 0 18px 18px; font-size: 14px; }
}

/* ════════════════════════════════════════════════════════════
   v1.58.0 · Cross-sell + Risk Disclaimer
   ════════════════════════════════════════════════════════════ */

/* Cross-sell grid */
.product-crosssell-sec { padding: 80px 0; }
.crosssell-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 18px;
	max-width: 980px;
	margin: 0 auto;
}
.crosssell-card {
	display: flex;
	flex-direction: column;
	padding: 26px 24px;
	background: rgba(255,255,255,0.02);
	border: 0.5px solid rgba(229,180,80,0.16);
	border-radius: var(--border-radius-md, 8px);
	text-decoration: none;
	transition: border-color 220ms ease, transform 220ms ease, background 220ms ease;
}
.crosssell-card:hover {
	border-color: rgba(229,180,80,0.45);
	transform: translateY(-3px);
	background: rgba(229,180,80,0.04);
}
.crosssell-card-tag {
	font-family: var(--font-mono, monospace);
	font-size: 10px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--color-gold, #e5b450);
	margin-bottom: 12px;
	opacity: 0.85;
}
.crosssell-card-name {
	font-family: var(--font-display-en, Georgia, serif);
	font-size: 20px;
	font-weight: 300;
	color: var(--color-cream, #fff);
	margin-bottom: 10px;
	line-height: 1.25;
}
.crosssell-card-line {
	font-family: var(--font-display-th, sans-serif);
	font-size: 13.5px;
	line-height: 1.6;
	color: var(--color-cream-2, #c9c4b8);
	margin-bottom: 16px;
	flex-grow: 1;
}
.crosssell-card-arrow {
	font-family: var(--font-mono, monospace);
	font-size: 12px;
	color: var(--color-gold, #e5b450);
	letter-spacing: 0.05em;
	transition: transform 200ms ease;
}
.crosssell-card:hover .crosssell-card-arrow { transform: translateX(4px); }

/* Risk Disclaimer */
.product-disclaimer-sec { padding: 20px 0 80px; }
.product-disclaimer {
	max-width: 860px;
	margin: 0 auto;
	display: flex;
	gap: 18px;
	align-items: flex-start;
	padding: 26px 30px;
	background: rgba(255,255,255,0.015);
	border: 0.5px solid rgba(229,180,80,0.14);
	border-left: 2px solid rgba(229,180,80,0.4);
	border-radius: var(--border-radius-md, 8px);
}
.product-disclaimer-icon {
	flex-shrink: 0;
	font-size: 20px;
	color: var(--color-gold, #e5b450);
	line-height: 1.5;
	opacity: 0.8;
}
.product-disclaimer-title {
	font-family: var(--font-display-th, sans-serif);
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.04em;
	color: var(--color-cream-2, #c9c4b8);
	margin: 0 0 8px;
	text-transform: none;
}
.product-disclaimer-text {
	font-family: var(--font-display-th, sans-serif);
	font-size: 12.5px;
	line-height: 1.75;
	color: var(--color-cream-3, #8f8b80);
	margin: 0;
}
.product-disclaimer-text strong { color: var(--color-cream-2, #c9c4b8); font-weight: 600; }

@media (max-width: 860px) {
	.crosssell-grid { grid-template-columns: 1fr; gap: 14px; }
	.product-disclaimer { flex-direction: column; gap: 12px; padding: 22px 22px; }
}

/* v1.58.1 · Footer trademark notice */
.footer-trademark {
	max-width: 900px;
	margin: 20px auto 0;
	padding-top: 18px;
	border-top: 0.5px solid rgba(255,255,255,0.06);
	font-family: var(--font-display-th, sans-serif);
	font-size: 11px;
	line-height: 1.7;
	color: rgba(180,175,165,0.45);
	text-align: center;
}

/* ════════════════════════════════════════════════════════════
   v1.59.0 · Hero right column · quick spec panel (fills whitespace)
   ════════════════════════════════════════════════════════════ */
.product-hero-right { display: flex; flex-direction: column; gap: 24px; }
.product-hero-specs {
	display: flex;
	flex-direction: column;
	padding: 6px 4px;
}
.hero-spec-row {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: 16px;
	padding: 13px 4px;
	border-bottom: 0.5px solid rgba(229,180,80,0.12);
}
.hero-spec-row:last-child { border-bottom: 0; }
.hero-spec-label {
	font-family: var(--font-mono, monospace);
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--color-cream-3, #8f8b80);
}
.hero-spec-value {
	font-family: var(--font-display-th, sans-serif);
	font-size: 14px;
	font-weight: 500;
	color: var(--color-cream, #e8e5dd);
	text-align: right;
}
@media (max-width: 960px) {
	.product-hero-specs { margin-top: 4px; }
	.hero-spec-row { padding: 12px 2px; }
}

/* ════════════════════════════════════════════════════════════
   v1.60.0 · Trade Journal · public landing (guest)
   ════════════════════════════════════════════════════════════ */
.aj-public-hero { padding: 56px 0 52px; }
.aj-public-eyebrow {
	font-family: var(--font-mono, monospace);
	font-size: 11px; letter-spacing: 0.32em; text-transform: uppercase;
	color: var(--color-gold, #e5b450); margin-bottom: 28px; opacity: 0.85;
}
.aj-public-title {
	font-family: var(--font-display-en, Georgia, serif);
	font-weight: 200; font-size: clamp(40px, 6.5vw, 76px); line-height: 1.02;
	letter-spacing: -0.03em; color: var(--color-cream, #fff); margin-bottom: 24px;
}
.aj-public-title em { font-style: italic; color: var(--color-gold, #e5b450); }
.aj-public-sub {
	font-family: var(--font-display-th, sans-serif);
	font-size: 17px; line-height: 1.7; font-weight: 300;
	color: var(--color-cream-2, #c9c4b8); max-width: 600px; margin: 0 auto 36px;
}
.aj-public-cta { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.aj-public-preview { padding: 72px 0 88px; }
.aj-public-grid {
	display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px;
	max-width: 900px; margin: 0 auto;
}
.aj-public-card { position: relative; padding: 32px 30px; }
.aj-public-card-icon { font-size: 28px; margin-bottom: 16px; }
.aj-public-card h3 {
	font-family: var(--font-display-th, sans-serif);
	font-size: 18px; font-weight: 600; color: var(--color-cream, #fff); margin: 0 0 10px;
}
.aj-public-card p {
	font-family: var(--font-display-th, sans-serif);
	font-size: 14px; line-height: 1.65; color: var(--color-cream-2, #c9c4b8); margin: 0;
}
.aj-public-note {
	text-align: center; margin-top: 24px;
	font-family: var(--font-display-th, sans-serif);
	font-size: 13px; color: var(--color-cream-3, #8f8b80);
}
@media (max-width: 760px) {
	.aj-public-grid { grid-template-columns: 1fr; }
	.aj-public-cta { flex-direction: column; align-items: stretch; }
	.aj-public-sub { font-size: 16px; }
	.aj-public-card p { font-size: 15px; line-height: 1.7; }
	.market-faq-q { font-size: 15.5px; }
	.market-faq-a { font-size: 14.5px; line-height: 1.85; }
}

/* v1.60.3 · Logout confirmation banner on journal landing */
.aj-logout-confirm {
	display: inline-block;
	margin-bottom: 28px;
	padding: 11px 22px;
	border-radius: 999px;
	background: rgba(107,163,115,0.12);
	border: 0.5px solid rgba(107,163,115,0.4);
	font-family: var(--font-display-th, sans-serif);
	font-size: 14px;
	color: #8fce97;
}

/* v1.61.1 · Market · live GMT+7 last-updated indicator */
.market-updated {
	display: inline-flex;
	align-items: center;
	gap: 9px;
	margin: 18px 0 0;
	padding: 7px 16px;
	border-radius: 999px;
	background: rgba(107,163,115,0.08);
	border: 0.5px solid rgba(107,163,115,0.28);
	font-family: var(--font-mono, monospace);
	font-size: 12px;
	letter-spacing: 0.04em;
	color: var(--color-cream-2, #c9c4b8);
}
.market-updated #market-updated-time { color: var(--color-cream, #fff); font-weight: 600; }
.market-updated-dot {
	width: 7px; height: 7px; border-radius: 50%;
	background: #6ba373;
	box-shadow: 0 0 0 0 rgba(107,163,115,0.5);
	animation: auhPulseDot 2s infinite;
}
@keyframes auhPulseDot {
	0%   { box-shadow: 0 0 0 0 rgba(107,163,115,0.5); }
	70%  { box-shadow: 0 0 0 7px rgba(107,163,115,0); }
	100% { box-shadow: 0 0 0 0 rgba(107,163,115,0); }
}

/* v1.61.1 · Signal · "how to read stats" honest explainer */
.sig-explain-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 18px;
	max-width: 820px;
	margin: 0 auto;
}
.sig-explain-card { position: relative; padding: 28px 26px; }
.sig-explain-icon { font-size: 26px; margin-bottom: 14px; }
.sig-explain-card h3 {
	font-family: var(--font-display-th, sans-serif);
	font-size: 17px; font-weight: 600; color: var(--color-cream, #fff); margin: 0 0 10px;
}
.sig-explain-card p {
	font-family: var(--font-display-th, sans-serif);
	font-size: 14px; line-height: 1.7; color: var(--color-cream-2, #c9c4b8); margin: 0;
}
.sig-explain-card p strong { color: var(--color-cream, #fff); font-weight: 600; }
.sig-explain-note {
	max-width: 820px;
	margin: 28px auto 0;
	padding: 18px 24px;
	border-radius: var(--border-radius-sm, 8px);
	background: rgba(229,180,80,0.06);
	border: 0.5px solid rgba(229,180,80,0.25);
	font-family: var(--font-display-th, sans-serif);
	font-size: 14px; line-height: 1.75; color: var(--color-cream-2, #c9c4b8); text-align: center;
}
.sig-explain-note strong { color: var(--color-gold, #e5b450); }
@media (max-width: 720px) {
	.sig-explain-grid { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════════════════════════════
   v1.62.0 · Indicators archive · grouped by status + badges
   ════════════════════════════════════════════════════════════ */
/* Hero count strip */
.suite-count-strip {
	display: inline-flex; align-items: center; gap: 14px;
	margin-top: 28px; padding: 9px 22px;
	border-radius: 999px;
	border: 0.5px solid rgba(229,180,80,0.22);
	background: rgba(229,180,80,0.05);
	font-family: var(--font-mono, monospace); font-size: 12px;
	letter-spacing: 0.1em; color: var(--color-cream-2, #c9c4b8);
}
.suite-count-item strong { color: var(--color-gold, #e5b450); font-weight: 700; }
.suite-count-sep { color: var(--color-faint, #555); }

/* Group header */
.suite-group { padding-top: 56px; padding-bottom: 8px; }
.suite-group-head { margin-bottom: 36px; }
.suite-group-title {
	font-family: var(--font-display-en, Georgia, serif);
	font-weight: 200; font-size: clamp(30px, 4vw, 46px);
	color: var(--color-cream, #fff); margin: 12px 0 8px; letter-spacing: -0.02em;
}
.suite-group-desc {
	font-family: var(--font-display-th, sans-serif);
	font-size: 15px; line-height: 1.6; font-weight: 300;
	color: var(--color-cream-2, #c9c4b8); max-width: 600px; margin: 0;
}

/* Tag line on tile */
.suite-tag {
	font-family: var(--font-mono, monospace); font-size: 10px;
	letter-spacing: 0.14em; text-transform: uppercase;
	color: var(--color-muted, #8f8b80); margin-top: 6px;
}

/* Beta tile + badge */
.suite-tile.beta { background: var(--color-surface, #1a1814); }
.suite-tile.beta:hover { background: var(--color-surface-2, #221f1a); }

/* Locked (not-yet-ready) tiles — non-clickable, no hover affordance */
.suite-tile.is-locked { cursor: default; }
.suite-tile.coming.is-locked:hover { background: var(--color-bg-base); }
.suite-tile.beta.is-locked:hover { background: var(--color-surface, #1a1814); }
.suite-tile.beta .suite-num { color: #d4a13c; }
.suite-tile.beta .suite-name { color: #e8c879; font-weight: 400; }
.status-beta { color: #e0a93f; }
.status-beta .status-dot { background: #e0a93f; box-shadow: 0 0 6px rgba(224,169,63,0.5); animation: auhPulseDot 2s infinite; }

/* ════════════════════════════════════════════════════════════
   v1.62.1 · Roadmap page
   ════════════════════════════════════════════════════════════ */
/* Legend */
.rm-legend { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.rm-legend-item { display: flex; align-items: flex-start; gap: 11px; }
.rm-legend-item strong { display: block; font-family: var(--font-display-th, sans-serif); font-size: 15px; color: var(--color-cream, #fff); }
.rm-legend-item span { display: block; font-family: var(--font-display-th, sans-serif); font-size: 12.5px; color: var(--color-cream-3, #8f8b80); line-height: 1.5; margin-top: 2px; }
.rm-legend-dot { width: 11px; height: 11px; border-radius: 50%; flex-shrink: 0; margin-top: 4px; }
.rm-st-ready   { background: var(--color-bull, #6ba373); box-shadow: 0 0 7px rgba(107,163,115,0.5); }
.rm-st-testing { background: #e0a93f; box-shadow: 0 0 7px rgba(224,169,63,0.5); }
.rm-st-dev     { background: #5b9bd5; box-shadow: 0 0 7px rgba(91,155,213,0.5); }
.rm-st-planned { background: var(--color-faint, #555); }

/* Timeline */
.rm-timeline { position: relative; padding-left: 8px; }
.rm-phase { display: grid; grid-template-columns: 40px 1fr; gap: 0; position: relative; padding-bottom: 36px; }
.rm-phase:last-child { padding-bottom: 0; }
.rm-phase-marker { position: relative; display: flex; justify-content: center; }
.rm-phase-marker::before { content: ''; position: absolute; top: 16px; bottom: -36px; left: 50%; width: 1px; background: rgba(229,180,80,0.18); transform: translateX(-50%); }
.rm-phase:last-child .rm-phase-marker::before { display: none; }
.rm-phase-dot { width: 14px; height: 14px; border-radius: 50%; margin-top: 4px; position: relative; z-index: 2; border: 2px solid var(--color-bg-base, #14110d); }
.rm-phase-done .rm-phase-dot   { background: var(--color-bull, #6ba373); box-shadow: 0 0 8px rgba(107,163,115,0.5); }
.rm-phase-active .rm-phase-dot { background: var(--color-gold, #e5b450); box-shadow: 0 0 10px rgba(229,180,80,0.6); animation: auhPulseDot 2s infinite; }
.rm-phase-planned .rm-phase-dot{ background: var(--color-faint, #555); }
.rm-phase-body { padding-left: 16px; padding-top: 0; }
.rm-phase-head { display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap; }
.rm-phase-name { font-family: var(--font-mono, monospace); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--color-gold, #e5b450); }
.rm-phase-period { font-family: var(--font-mono, monospace); font-size: 11px; letter-spacing: 0.1em; color: var(--color-cream-3, #8f8b80); }
.rm-phase-active .rm-phase-period { color: var(--color-gold, #e5b450); }
.rm-phase-title { font-family: var(--font-display-th, sans-serif); font-size: 20px; font-weight: 600; color: var(--color-cream, #fff); margin: 8px 0 14px; }
.rm-phase-list { list-style: none; padding: 0; margin: 0; }
.rm-phase-list li { font-family: var(--font-display-th, sans-serif); font-size: 14.5px; line-height: 1.5; color: var(--color-cream-2, #c9c4b8); padding: 5px 0 5px 20px; position: relative; }
.rm-phase-list li::before { content: '—'; position: absolute; left: 0; color: var(--color-gold-deep, #b8893c); }
.rm-phase-done .rm-phase-list li::before { content: '✓'; color: var(--color-bull, #6ba373); }

/* Indicator status columns */
.rm-ind-cols { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 28px; max-width: 1000px; margin: 0 auto; }
.rm-ind-col-head { font-family: var(--font-mono, monospace); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-cream, #fff); padding-bottom: 14px; margin-bottom: 6px; border-bottom: 0.5px solid rgba(229,180,80,0.15); display: flex; align-items: center; gap: 9px; }
.rm-ind-row { display: block; padding: 12px 14px; margin-top: 8px; border-radius: var(--border-radius-sm, 8px); background: var(--color-surface, #1a1814); border: 0.5px solid transparent; transition: background var(--duration-base, .2s); color: inherit; text-decoration: none; }
.rm-ind-ready:hover, .rm-ind-testing:hover { background: var(--color-surface-2, #221f1a); border-color: rgba(229,180,80,0.2); }
.rm-ind-name { display: block; font-family: var(--font-display-th, sans-serif); font-size: 15px; font-weight: 500; color: var(--color-cream, #fff); }
.rm-ind-ready .rm-ind-name { color: var(--color-gold, #e5b450); }
.rm-ind-planned { opacity: 0.62; }
.rm-ind-planned .rm-ind-name { color: var(--color-cream-2, #c9c4b8); font-weight: 400; }
.rm-ind-tag { display: block; font-family: var(--font-mono, monospace); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--color-muted, #8f8b80); margin-top: 3px; }

@media (max-width: 760px) {
	.rm-legend { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
	.rm-legend { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════════════════════════════
   v1.62.2 · Changelog page
   ════════════════════════════════════════════════════════════ */
.cl-list { max-width: 720px; margin: 0 auto; }
.cl-entry {
	padding: 28px 0 26px;
	border-bottom: 0.5px solid rgba(229,180,80,0.12);
}
.cl-entry:first-child { padding-top: 0; }
.cl-entry:last-child { border-bottom: 0; }
.cl-entry-head {
	display: flex; align-items: baseline; justify-content: space-between;
	gap: 16px; flex-wrap: wrap; margin-bottom: 16px;
}
.cl-entry-title {
	font-family: var(--font-display-th, sans-serif);
	font-size: 19px; font-weight: 600; color: var(--color-cream, #fff);
	display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap;
}
.cl-entry-title a { color: var(--color-gold, #e5b450); text-decoration: none; }
.cl-entry-title a:hover { text-decoration: underline; }
.cl-version {
	font-family: var(--font-mono, monospace); font-size: 11px;
	letter-spacing: 0.1em; color: var(--color-cream-3, #8f8b80);
	padding: 2px 9px; border: 0.5px solid rgba(229,180,80,0.25); border-radius: 999px;
}
.cl-date {
	font-family: var(--font-mono, monospace); font-size: 12px;
	letter-spacing: 0.06em; color: var(--color-cream-3, #8f8b80);
}
.cl-changes { list-style: none; padding: 0; margin: 0; }
.cl-changes li {
	display: flex; align-items: flex-start; gap: 12px;
	padding: 7px 0;
}
.cl-badge {
	flex-shrink: 0; margin-top: 1px;
	font-family: var(--font-mono, monospace); font-size: 10px;
	letter-spacing: 0.08em; text-transform: uppercase;
	padding: 3px 10px; border-radius: 999px; min-width: 58px; text-align: center;
}
.cl-new     { background: rgba(107,163,115,0.14); color: #8fce97; border: 0.5px solid rgba(107,163,115,0.35); }
.cl-fix     { background: rgba(214,110,110,0.14); color: #e08f8f; border: 0.5px solid rgba(214,110,110,0.35); }
.cl-improve { background: rgba(229,180,80,0.12); color: var(--color-gold, #e5b450); border: 0.5px solid rgba(229,180,80,0.3); }
.cl-text {
	font-family: var(--font-display-th, sans-serif); font-size: 15px;
	line-height: 1.6; color: var(--color-cream-2, #c9c4b8);
}
@media (max-width: 600px) {
	.cl-badge { min-width: 50px; font-size: 9px; }
	.cl-text { font-size: 14px; }
}

/* ════════════════════════════════════════════════════════════
   v1.62.4 · Getting Started + Use Case page
   ════════════════════════════════════════════════════════════ */
/* 6-step onboarding */
.gs-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.gs-step {
	position: relative; display: flex; gap: 16px;
	padding: 26px 24px;
	background: var(--color-surface, #1a1814);
	border-radius: var(--border-radius-sm, 8px);
	border: 0.5px solid rgba(229,180,80,0.1);
	transition: border-color var(--duration-base, .2s), background var(--duration-base, .2s);
}
.gs-step:hover { border-color: rgba(229,180,80,0.28); background: var(--color-surface-2, #221f1a); }
.gs-step-num {
	flex-shrink: 0; width: 34px; height: 34px; border-radius: 50%;
	display: flex; align-items: center; justify-content: center;
	font-family: var(--font-display-en, Georgia, serif); font-size: 16px; font-style: italic;
	color: var(--color-gold, #e5b450);
	border: 1px solid rgba(229,180,80,0.4);
}
.gs-step-icon { font-size: 24px; margin-bottom: 8px; }
.gs-step-title { font-family: var(--font-display-th, sans-serif); font-size: 17px; font-weight: 600; color: var(--color-cream, #fff); margin: 0 0 8px; }
.gs-step-desc { font-family: var(--font-display-th, sans-serif); font-size: 14px; line-height: 1.6; color: var(--color-cream-2, #c9c4b8); margin: 0 0 14px; }
.gs-step-link { font-family: var(--font-mono, monospace); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--color-gold, #e5b450); text-decoration: none; }
.gs-step-link:hover { text-decoration: underline; }

/* Use-case vertical flow */
.gs-flow { position: relative; padding-left: 6px; }
.gs-flow-step { display: grid; grid-template-columns: 44px 1fr; gap: 16px; position: relative; padding-bottom: 26px; }
.gs-flow-step:last-child { padding-bottom: 0; }
.gs-flow-num {
	flex-shrink: 0; width: 38px; height: 38px; border-radius: 50%;
	display: flex; align-items: center; justify-content: center;
	font-family: var(--font-display-en, Georgia, serif); font-size: 16px; font-style: italic;
	color: var(--color-bg-base, #14110d); background: var(--color-gold, #e5b450);
	position: relative; z-index: 2;
}
.gs-flow-step::before {
	content: ''; position: absolute; left: 19px; top: 38px; bottom: -0px; width: 1px;
	background: rgba(229,180,80,0.2);
}
.gs-flow-step:last-child::before { display: none; }
.gs-flow-title { font-family: var(--font-display-th, sans-serif); font-size: 17px; font-weight: 600; color: var(--color-cream, #fff); margin: 6px 0 6px; }
.gs-flow-desc { font-family: var(--font-display-th, sans-serif); font-size: 14.5px; line-height: 1.6; color: var(--color-cream-2, #c9c4b8); margin: 0; }
.gs-flow-note {
	margin-top: 32px; padding: 18px 24px;
	border-radius: var(--border-radius-sm, 8px);
	background: rgba(229,180,80,0.06); border: 0.5px solid rgba(229,180,80,0.22);
	font-family: var(--font-display-th, sans-serif); font-size: 14.5px; line-height: 1.7;
	color: var(--color-cream-2, #c9c4b8);
}
.gs-flow-note strong { color: var(--color-gold, #e5b450); }

/* Next-step cards */
.gs-next { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; max-width: 720px; margin: 0 auto; }
.gs-next-card { position: relative; padding: 30px 28px; text-align: left; color: inherit; text-decoration: none; transition: background var(--duration-base, .2s); }
.gs-next-card:hover { background: var(--color-surface-2, #221f1a); }
.gs-next-icon { font-size: 28px; margin-bottom: 14px; }
.gs-next-card h3 { font-family: var(--font-display-th, sans-serif); font-size: 18px; font-weight: 600; color: var(--color-cream, #fff); margin: 0 0 8px; }
.gs-next-card p { font-family: var(--font-display-th, sans-serif); font-size: 14px; line-height: 1.6; color: var(--color-cream-2, #c9c4b8); margin: 0; }

@media (max-width: 900px) { .gs-steps { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) {
	.gs-steps { grid-template-columns: 1fr; }
	.gs-next { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════════════════════════════
   v1.62.5 · How to Choose Indicator page
   ════════════════════════════════════════════════════════════ */
.hc-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 20px; }
.hc-card {
	padding: 30px 28px;
	background: var(--color-surface, #1a1814);
	border-radius: var(--border-radius-sm, 8px);
	border: 0.5px solid rgba(229,180,80,0.1);
	transition: border-color var(--duration-base, .2s);
}
.hc-card:hover { border-color: rgba(229,180,80,0.25); }
.hc-card-icon { font-size: 30px; margin-bottom: 14px; }
.hc-card-title { font-family: var(--font-display-th, sans-serif); font-size: 19px; font-weight: 600; color: var(--color-cream, #fff); margin: 0 0 8px; }
.hc-card-desc { font-family: var(--font-display-th, sans-serif); font-size: 14px; line-height: 1.6; color: var(--color-cream-2, #c9c4b8); margin: 0 0 18px; }
.hc-pills { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 18px; }
.hc-pill {
	display: inline-flex; align-items: center; gap: 7px;
	font-family: var(--font-display-th, sans-serif); font-size: 13px; font-weight: 500;
	padding: 7px 14px; border-radius: 999px; text-decoration: none; line-height: 1;
}
.hc-pill-ready  { background: rgba(107,163,115,0.12); color: #8fce97; border: 0.5px solid rgba(107,163,115,0.35); }
.hc-pill-ready:hover { background: rgba(107,163,115,0.2); }
.hc-pill-tool   { background: rgba(229,180,80,0.12); color: var(--color-gold, #e5b450); border: 0.5px solid rgba(229,180,80,0.32); }
.hc-pill-tool:hover { background: rgba(229,180,80,0.2); }
.hc-pill-coming { background: rgba(255,255,255,0.04); color: var(--color-cream-3, #8f8b80); border: 0.5px solid rgba(255,255,255,0.08); }
.hc-dot { width: 6px; height: 6px; border-radius: 50%; background: #6ba373; box-shadow: 0 0 6px rgba(107,163,115,0.6); }
.hc-card-why {
	font-family: var(--font-display-th, sans-serif); font-size: 13px; line-height: 1.6;
	color: var(--color-cream-3, #8f8b80); margin: 0; padding-top: 14px;
	border-top: 0.5px solid rgba(229,180,80,0.1);
}
.hc-card-why span { color: var(--color-gold, #e5b450); font-weight: 600; }
.hc-legend-note {
	text-align: center; margin-top: 40px;
	font-family: var(--font-display-th, sans-serif); font-size: 13px;
	color: var(--color-cream-3, #8f8b80); line-height: 2.2;
}
.hc-legend-note a { color: var(--color-gold, #e5b450); }

/* v1.65.0 · Indicator Finder Quiz */
.hc-quiz { padding: 36px 32px; }
.hc-quiz-mark { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--color-gold); margin-bottom: 12px; text-align: center; }
.hc-quiz-title { font-family: var(--font-display-th); font-size: clamp(24px, 4vw, 34px); color: var(--color-cream); margin: 0 0 28px; text-align: center; }
.hc-quiz-title em { color: var(--color-gold-bright); font-style: normal; }
.hc-quiz-q { margin-bottom: 22px; }
.hc-quiz-qlabel { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.04em; color: var(--color-cream-2); margin-bottom: 12px; }
.hc-quiz-opts { display: flex; flex-wrap: wrap; gap: 10px; }
.hc-quiz-opt { font-family: var(--font-display-th); font-size: 14px; color: var(--color-cream-2); background: var(--color-surface); border: 1px solid var(--color-hairline-bright); border-radius: 8px; padding: 10px 16px; cursor: pointer; transition: all var(--duration-fast); }
.hc-quiz-opt:hover { border-color: var(--color-gold-deep); color: var(--color-cream); }
.hc-quiz-opt.is-on { background: rgba(201,169,97,0.14); border-color: var(--color-gold); color: var(--color-gold-bright); }
.hc-quiz-result { margin-top: 26px; padding-top: 26px; border-top: 1px solid var(--color-hairline); text-align: center; }
.hc-quiz-result[hidden] { display: none !important; }
.hc-quiz-result-label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 10px; }
.hc-quiz-result-group { font-family: var(--font-display-th); font-size: 23px; color: var(--color-gold-bright); font-weight: 600; margin-bottom: 8px; }
.hc-quiz-result-note { font-size: 13px; color: var(--color-muted); margin-bottom: 18px; font-family: var(--font-display-th); line-height: 1.6; }
.hc-card { scroll-margin-top: 90px; }
.hc-card-highlight { border-color: var(--color-gold) !important; animation: hcPulse 2.6s ease; }
@keyframes hcPulse {
	0%   { box-shadow: 0 0 0 1px var(--color-gold), 0 0 0 rgba(201,169,97,0.0); }
	25%  { box-shadow: 0 0 0 1px var(--color-gold), 0 0 34px rgba(201,169,97,0.38); }
	100% { box-shadow: 0 0 0 1px var(--color-gold), 0 12px 40px rgba(201,169,97,0.12); }
}

/* v1.67.0 · Quick goal comparison table */
.hc-goal-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); }
.hc-goal-table { width: 100%; border-collapse: collapse; min-width: 760px; font-family: var(--font-display-th); }
.hc-goal-table th { text-align: left; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--color-gold); padding: 14px 16px; background: var(--color-surface); border-bottom: 1px solid var(--color-hairline-bright); white-space: nowrap; }
.hc-goal-table td { padding: 16px; font-size: 14px; color: var(--color-cream-2); border-bottom: 1px solid var(--color-hairline); line-height: 1.55; vertical-align: top; }
.hc-goal-table tr:last-child td { border-bottom: none; }
.hc-goal-table tbody tr:hover td { background: rgba(201,169,97,0.04); }
.hc-goal-name { color: var(--color-cream) !important; font-weight: 600; font-size: 15px !important; }
.hc-diff { display: inline-block; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.04em; padding: 3px 11px; border-radius: 999px; border: 1px solid; white-space: nowrap; }
.hc-diff-easy { color: var(--color-bull); border-color: rgba(107,163,115,0.4); background: rgba(107,163,115,0.10); }
.hc-diff-mid  { color: var(--color-gold-bright); border-color: rgba(201,169,97,0.4); background: rgba(201,169,97,0.10); }
.hc-diff-hard { color: var(--color-bear); border-color: rgba(184,84,80,0.45); background: rgba(184,84,80,0.10); }
.hc-goal-warn { display: flex; gap: 12px; align-items: flex-start; margin-top: 22px; padding: 16px 18px; background: rgba(201,169,97,0.06); border: 1px solid rgba(201,169,97,0.25); border-radius: var(--border-radius-sm); }
.hc-goal-warn-icon { flex-shrink: 0; font-size: 15px; line-height: 1.7; }
.hc-goal-warn p { margin: 0; font-family: var(--font-display-th); font-size: 13px; line-height: 1.7; color: var(--color-cream-3, #8f8b80); }
@media (max-width: 720px) {
	.hc-goal-wrap { overflow-x: visible; border: none; border-radius: 0; }
	.hc-goal-table { min-width: 0; }
	.hc-goal-table thead { display: none; }
	.hc-goal-table tr { display: block; border: 1px solid var(--color-hairline); border-radius: var(--border-radius-sm); margin-bottom: 14px; background: rgba(0,0,0,0.30); }
	.hc-goal-table td { display: flex; justify-content: space-between; gap: 16px; align-items: flex-start; border-bottom: 1px solid var(--color-hairline); padding: 11px 14px; text-align: right; }
	.hc-goal-table tr td:last-child { border-bottom: none; }
	.hc-goal-table td::before { content: attr(data-label); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--color-muted); flex-shrink: 0; text-align: left; padding-top: 2px; }
	.hc-goal-table td.hc-goal-name::before { color: var(--color-gold); }
}

/* ═══════════════════════════════════════
   v1.69.0 · Journal UI mockup demo (guest landing)
   ═══════════════════════════════════════ */
.aj-demo-note { font-family: var(--font-display-th); font-size: 13px; color: var(--color-muted); margin: 0 auto 28px; max-width: 520px; }
.aj-demo-tabs { display: flex; justify-content: center; flex-wrap: wrap; gap: 8px; margin-bottom: 18px; }
.aj-demo-tab { font-family: var(--font-display-th); font-size: 13px; color: var(--color-cream-2); background: var(--color-surface); border: 1px solid var(--color-hairline-bright); border-radius: 999px; padding: 8px 16px; cursor: pointer; transition: all var(--duration-fast); }
.aj-demo-tab:hover { border-color: var(--color-gold-deep); color: var(--color-cream); }
.aj-demo-tab.is-on { background: rgba(201,169,97,0.14); border-color: var(--color-gold); color: var(--color-gold-bright); }
.aj-demo-frame { max-width: 760px; margin: 0 auto; border: 1px solid var(--color-hairline-bright); border-radius: 12px; overflow: hidden; background: var(--color-bg-base, #0c0a08); box-shadow: 0 24px 70px rgba(0,0,0,0.5); }
.aj-demo-bar { display: flex; align-items: center; gap: 8px; padding: 11px 14px; background: var(--color-surface); border-bottom: 1px solid var(--color-hairline); }
.aj-demo-dot { width: 11px; height: 11px; border-radius: 50%; flex-shrink: 0; }
.aj-demo-dot.r { background: #e0625e; } .aj-demo-dot.y { background: #e0b04e; } .aj-demo-dot.g { background: #6bb36f; }
.aj-demo-urlbar { flex: 1; margin-left: 8px; font-family: var(--font-mono); font-size: 11px; color: var(--color-muted); background: var(--color-bg-base, #0c0a08); border: 1px solid var(--color-hairline); border-radius: 6px; padding: 5px 12px; text-align: center; }
.aj-demo-badge { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-gold-bright); border: 1px solid rgba(201,169,97,0.4); background: rgba(201,169,97,0.10); border-radius: 999px; padding: 3px 9px; flex-shrink: 0; }
.aj-demo-screen { padding: 20px; min-height: 340px; }
.aj-demo-panel { display: none; }
.aj-demo-panel.is-on { display: block; animation: ajDemoFade 0.3s ease; }
@keyframes ajDemoFade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
.aj-demo-block-head { display: flex; justify-content: space-between; align-items: center; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--color-cream-2); margin-bottom: 12px; }
.aj-demo-chip { font-family: var(--font-mono); font-size: 11px; padding: 2px 9px; border-radius: 999px; }
.aj-demo-chip.up { color: var(--color-bull); background: rgba(107,163,115,0.12); border: 1px solid rgba(107,163,115,0.3); }
/* dashboard */
.aj-demo-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-bottom: 22px; }
.aj-demo-stat { background: var(--color-surface); border: 1px solid var(--color-hairline); border-radius: 10px; padding: 14px 12px; display: flex; flex-direction: column; gap: 6px; }
.aj-demo-stat-l { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--color-muted); }
.aj-demo-stat-v { font-family: var(--font-display-en); font-size: 22px; font-weight: 600; color: var(--color-cream); }
.aj-demo-stat-v small { font-size: 11px; color: var(--color-muted); font-weight: 400; }
.aj-demo-stat-v.up { color: var(--color-bull); } .aj-demo-stat-v.down { color: var(--color-bear); }
.aj-demo-equity { margin-bottom: 22px; }
.aj-demo-svg { width: 100%; height: 130px; display: block; background: rgba(0,0,0,0.20); border: 1px solid var(--color-hairline); border-radius: 10px; }
.aj-demo-recent { }
.aj-demo-streak { font-family: var(--font-display-th); font-size: 11px; color: var(--color-gold-bright); }
.aj-demo-trow { display: flex; align-items: center; gap: 12px; padding: 11px 4px; border-bottom: 1px solid var(--color-hairline); font-family: var(--font-mono); font-size: 12px; }
.aj-demo-trow:last-child { border-bottom: none; }
.aj-demo-tdir { font-weight: 600; font-size: 10px; padding: 3px 8px; border-radius: 5px; letter-spacing: 0.04em; }
.aj-demo-tdir.buy { color: var(--color-bull); background: rgba(107,163,115,0.14); }
.aj-demo-tdir.sell { color: var(--color-bear); background: rgba(184,84,80,0.14); }
.aj-demo-tsym { color: var(--color-cream); font-weight: 600; }
.aj-demo-tdate { color: var(--color-muted); }
.aj-demo-trr { color: var(--color-cream-2); margin-left: auto; }
.aj-demo-tpnl { font-weight: 600; min-width: 72px; text-align: right; }
.aj-demo-tpnl.up { color: var(--color-bull); } .aj-demo-tpnl.down { color: var(--color-bear); }
/* calendar */
.aj-demo-cal-dow { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; margin-bottom: 6px; }
.aj-demo-cal-dow span { text-align: center; font-family: var(--font-mono); font-size: 10px; color: var(--color-muted); }
.aj-demo-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; }
.aj-demo-cal-cell { aspect-ratio: 1 / 1; border: 1px solid var(--color-hairline); border-radius: 7px; padding: 5px; display: flex; flex-direction: column; justify-content: space-between; background: rgba(0,0,0,0.18); }
.aj-demo-cal-d { font-family: var(--font-mono); font-size: 10px; color: var(--color-muted); }
.aj-demo-cal-p { font-family: var(--font-mono); font-size: 10px; font-weight: 600; text-align: right; }
.aj-demo-cal-cell.win { border-color: rgba(107,163,115,0.4); background: rgba(107,163,115,0.10); }
.aj-demo-cal-cell.win .aj-demo-cal-p { color: var(--color-bull); }
.aj-demo-cal-cell.loss { border-color: rgba(184,84,80,0.4); background: rgba(184,84,80,0.10); }
.aj-demo-cal-cell.loss .aj-demo-cal-p { color: var(--color-bear); }
/* add trade */
.aj-demo-form { display: flex; flex-direction: column; gap: 14px; max-width: 520px; margin: 0 auto; }
.aj-demo-frow { display: flex; align-items: center; justify-content: space-between; gap: 14px; }
.aj-demo-flabel { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--color-muted); }
.aj-demo-fchip { font-family: var(--font-mono); font-size: 13px; padding: 6px 14px; border-radius: 7px; background: var(--color-surface); border: 1px solid var(--color-hairline-bright); color: var(--color-cream); }
.aj-demo-fchip.gold { color: var(--color-gold-bright); border-color: rgba(201,169,97,0.4); background: rgba(201,169,97,0.10); }
.aj-demo-fseg { display: inline-flex; border: 1px solid var(--color-hairline-bright); border-radius: 7px; overflow: hidden; font-family: var(--font-mono); font-size: 12px; }
.aj-demo-fseg span { padding: 7px 18px; color: var(--color-muted); }
.aj-demo-fseg .on.buy { background: rgba(107,163,115,0.16); color: var(--color-bull); font-weight: 600; }
.aj-demo-fgrid3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.aj-demo-finput { background: var(--color-surface); border: 1px solid var(--color-hairline); border-radius: 8px; padding: 10px 12px; display: flex; flex-direction: column; gap: 5px; }
.aj-demo-finput span { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--color-muted); }
.aj-demo-finput b { font-family: var(--font-display-en); font-size: 16px; color: var(--color-cream); font-weight: 600; }
.aj-demo-fval { font-family: var(--font-display-en); font-size: 16px; color: var(--color-cream); font-weight: 600; }
.aj-demo-fprev { display: flex; justify-content: space-around; gap: 12px; padding: 14px; background: rgba(201,169,97,0.06); border: 1px solid rgba(201,169,97,0.22); border-radius: 10px; }
.aj-demo-fprev span { display: flex; flex-direction: column; align-items: center; gap: 4px; }
.aj-demo-fprev i { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--color-muted); font-style: normal; }
.aj-demo-fprev b { font-family: var(--font-display-en); font-size: 16px; color: var(--color-cream); font-weight: 600; }
.aj-demo-fprev b.up { color: var(--color-bull); }
.aj-demo-cta { display: flex; justify-content: center; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
@media (max-width: 600px) {
	.aj-demo-screen { padding: 14px; }
	.aj-demo-stats { grid-template-columns: repeat(2, 1fr); }
	.aj-demo-stat-v { font-size: 19px; }
	.aj-demo-trow { gap: 8px; font-size: 11px; flex-wrap: wrap; }
	.aj-demo-trr { margin-left: 0; }
	.aj-demo-tpnl { min-width: 0; margin-left: auto; }
	.aj-demo-fgrid3 { grid-template-columns: 1fr; }
	.aj-demo-cal-d { font-size: 9px; } .aj-demo-cal-p { font-size: 9px; }
}
.aj-demo-shot { display: block; width: 100%; height: auto; border-radius: 8px; border: 1px solid var(--color-hairline); }
.aj-demo-shot { cursor: zoom-in; transition: opacity var(--duration-fast); }
.aj-demo-shot:hover { opacity: 0.92; }
.aj-demo-lb { position: fixed; inset: 0; z-index: 99999; display: none; align-items: center; justify-content: center; background: rgba(0,0,0,0.90); padding: 24px; cursor: zoom-out; }
.aj-demo-lb.is-open { display: flex; animation: ajDemoFade 0.2s ease; }
.aj-demo-lb-img { max-width: 96vw; max-height: 92vh; border-radius: 8px; border: 1px solid var(--color-hairline-bright); box-shadow: 0 20px 80px rgba(0,0,0,0.7); }
.aj-demo-lb-close { position: absolute; top: 18px; right: 22px; width: 42px; height: 42px; border-radius: 50%; background: var(--color-surface); border: 1px solid var(--color-hairline-bright); color: var(--color-cream); font-size: 18px; line-height: 1; cursor: pointer; transition: all var(--duration-fast); }
.aj-demo-lb-close:hover { border-color: var(--color-gold); color: var(--color-gold-bright); }

/* v1.72.0 · pain hook + trust row (journal landing) */
.aj-pain { padding: 60px 0; }
.aj-pain-h2 { font-size: clamp(26px, 3.4vw, 40px); line-height: 1.28; text-wrap: balance; max-width: 720px; margin: 0 auto 18px; }
.aj-pain-qs { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; }
.aj-pain-qs span { font-family: var(--font-display-th); font-size: 14px; color: var(--color-cream-2); background: var(--color-surface); border: 1px solid var(--color-hairline); border-radius: 999px; padding: 10px 18px; }
.aj-trust { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; max-width: 760px; margin: 40px auto 0; }
.aj-trust-item { text-align: center; padding: 20px 16px; border: 1px solid var(--color-hairline); border-radius: 12px; background: rgba(0,0,0,0.20); display: flex; flex-direction: column; gap: 6px; }
.aj-trust-i { font-size: 24px; }
.aj-trust-item b { font-family: var(--font-display-th); font-size: 15px; color: var(--color-cream); font-weight: 600; }
.aj-trust-item span:last-child { font-family: var(--font-display-th); font-size: 12.5px; color: var(--color-muted); line-height: 1.5; }
@media (max-width: 600px) {
	.aj-trust { grid-template-columns: 1fr; gap: 12px; }
	.aj-trust-item { flex-direction: row; align-items: center; gap: 14px; text-align: left; padding: 14px 16px; }
	.aj-trust-i { font-size: 22px; }
	.aj-pain-qs span { font-size: 13.5px; }
}

/* ═══════════════════════════════════════
   v1.75.0 · Journal Demo (interactive · /journal-demo/)
   ═══════════════════════════════════════ */
.ajd-hero { padding: 56px 0 32px; }
.ajd-eyebrow { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-gold); margin-bottom: 14px; }
.ajd-title { font-family: var(--font-display-th); font-weight: 300; font-size: clamp(34px, 5vw, 56px); line-height: 1.05; color: var(--color-cream); margin: 0 0 14px; }
.ajd-title em { font-family: var(--font-display-en); font-style: italic; color: var(--color-gold); font-weight: 200; }
.ajd-sub { font-family: var(--font-display-th); font-size: 16px; line-height: 1.7; color: var(--color-cream-2); max-width: 560px; margin: 0 auto 18px; }
.ajd-warn { display: inline-block; font-family: var(--font-display-th); font-size: 12.5px; color: var(--color-cream-3, #8f8b80); background: rgba(201,169,97,0.06); border: 1px solid rgba(201,169,97,0.22); border-radius: 999px; padding: 8px 18px; }
.ajd-grid { display: grid; grid-template-columns: 1fr 340px; gap: 24px; align-items: start; }
.ajd-main, .ajd-side { display: flex; flex-direction: column; gap: 20px; }
.ajd-side { position: sticky; top: 90px; }
.ajd-block-head { display: flex; justify-content: space-between; align-items: center; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--color-cream-2); margin-bottom: 12px; }
.ajd-chip { font-family: var(--font-mono); font-size: 11px; padding: 2px 10px; border-radius: 999px; }
.ajd-chip.up { color: var(--color-bull); background: rgba(107,163,115,0.12); border: 1px solid rgba(107,163,115,0.3); }
.ajd-chip.down { color: var(--color-bear); background: rgba(184,84,80,0.12); border: 1px solid rgba(184,84,80,0.3); }
/* stats */
.ajd-stats { display: grid; grid-template-columns: repeat(5, 1fr); gap: 10px; }
.ajd-stat { background: var(--color-surface); border: 1px solid var(--color-hairline); border-radius: 10px; padding: 14px 12px; display: flex; flex-direction: column; gap: 6px; }
.ajd-stat-l { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--color-muted); }
.ajd-stat-v { font-family: var(--font-display-en); font-size: 22px; font-weight: 600; color: var(--color-cream); line-height: 1; }
.ajd-stat-v.up { color: var(--color-bull); } .ajd-stat-v.down { color: var(--color-bear); }
/* equity */
.ajd-equity { background: var(--color-surface); border: 1px solid var(--color-hairline); border-radius: 12px; padding: 18px; }
.ajd-eq-svg { width: 100%; height: 150px; display: block; }
/* trades */
.ajd-trades { background: var(--color-surface); border: 1px solid var(--color-hairline); border-radius: 12px; padding: 18px; }
.ajd-reset { font-family: var(--font-display-th); font-size: 11px; color: var(--color-cream-2); background: transparent; border: 1px solid var(--color-hairline-bright); border-radius: 999px; padding: 4px 12px; cursor: pointer; transition: all var(--duration-fast); }
.ajd-reset:hover { border-color: var(--color-gold); color: var(--color-gold-bright); }
.ajd-empty { font-family: var(--font-display-th); font-size: 13px; color: var(--color-muted); text-align: center; padding: 24px 0; }
.ajd-trow { display: flex; align-items: center; gap: 12px; padding: 11px 4px; border-bottom: 1px solid var(--color-hairline); font-family: var(--font-mono); font-size: 12px; }
.ajd-trow:last-child { border-bottom: none; }
.ajd-tdir { font-weight: 600; font-size: 10px; padding: 3px 8px; border-radius: 5px; letter-spacing: 0.04em; }
.ajd-tdir.buy { color: var(--color-bull); background: rgba(107,163,115,0.14); }
.ajd-tdir.sell { color: var(--color-bear); background: rgba(184,84,80,0.14); }
.ajd-tsym { color: var(--color-cream); font-weight: 600; }
.ajd-tentry { color: var(--color-muted); }
.ajd-trr { color: var(--color-cream-2); margin-left: auto; }
.ajd-tpnl { font-weight: 600; min-width: 78px; text-align: right; }
.ajd-tpnl.up { color: var(--color-bull); } .ajd-tpnl.down { color: var(--color-bear); }
.ajd-del { width: 24px; height: 24px; border-radius: 6px; border: 1px solid var(--color-hairline); background: transparent; color: var(--color-muted); cursor: pointer; font-size: 11px; line-height: 1; transition: all var(--duration-fast); flex-shrink: 0; }
.ajd-del:hover { border-color: var(--color-bear); color: var(--color-bear); }
/* form */
.ajd-form-card { background: var(--color-surface); border: 1px solid var(--color-hairline-bright); border-radius: 14px; padding: 22px; display: flex; flex-direction: column; gap: 14px; }
.ajd-form-head { font-family: var(--font-display-th); font-size: 17px; font-weight: 600; color: var(--color-cream); }
.ajd-fieldrow { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.ajd-flabel { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--color-muted); }
.ajd-field { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.ajd-field > span { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--color-muted); }
.ajd-field input { width: 130px; font-family: var(--font-display-en); font-size: 15px; color: var(--color-cream); background: var(--color-bg-base, #0c0a08); border: 1px solid var(--color-hairline-bright); border-radius: 8px; padding: 8px 12px; text-align: right; }
.ajd-field input:focus { outline: none; border-color: var(--color-gold); }
.ajd-seg { display: inline-flex; border: 1px solid var(--color-hairline-bright); border-radius: 8px; overflow: hidden; }
.ajd-seg button { font-family: var(--font-mono); font-size: 12px; padding: 7px 14px; color: var(--color-muted); background: transparent; border: none; cursor: pointer; transition: all var(--duration-fast); }
.ajd-seg.sm button { font-family: var(--font-display-th); font-size: 12px; padding: 7px 12px; }
.ajd-seg button.on { background: rgba(201,169,97,0.14); color: var(--color-gold-bright); font-weight: 600; }
.ajd-seg button[data-dir="BUY"].on { background: rgba(107,163,115,0.16); color: var(--color-bull); }
.ajd-seg button[data-dir="SELL"].on { background: rgba(184,84,80,0.16); color: var(--color-bear); }
.ajd-prev { display: flex; justify-content: space-between; gap: 8px; padding: 12px; background: rgba(201,169,97,0.06); border: 1px solid rgba(201,169,97,0.20); border-radius: 10px; }
.ajd-prev span { display: flex; flex-direction: column; align-items: center; gap: 3px; font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.03em; text-transform: uppercase; color: var(--color-muted); }
.ajd-prev b { font-family: var(--font-display-en); font-size: 14px; color: var(--color-cream); }
.ajd-err { font-family: var(--font-display-th); font-size: 12.5px; color: var(--color-bear); background: rgba(184,84,80,0.10); border: 1px solid rgba(184,84,80,0.3); border-radius: 8px; padding: 8px 12px; }
.ajd-err[hidden] { display: none !important; }
.ajd-add { width: 100%; }
.ajd-cta { width: 100%; text-align: center; }
.ajd-cta-note { font-family: var(--font-display-th); font-size: 12px; line-height: 1.6; color: var(--color-muted); text-align: center; margin: 0; }
@media (max-width: 880px) {
	.ajd-grid { grid-template-columns: 1fr; }
	.ajd-side { position: static; }
	.ajd-stats { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 520px) {
	.ajd-stats { grid-template-columns: repeat(2, 1fr); }
	.ajd-trow { gap: 8px; font-size: 11px; flex-wrap: wrap; }
	.ajd-trr { margin-left: 0; }
	.ajd-field input { width: 110px; }
}
.ajd-feat-link { display: block; text-align: center; font-family: var(--font-display-th); font-size: 13px; color: var(--color-gold); text-decoration: none; padding: 4px; transition: color var(--duration-fast); }
.ajd-feat-link:hover { color: var(--color-gold-bright); }

/* ═══════════════════════════════════════
   v1.78.0 · Glossary (data-driven · search + filter)
   ═══════════════════════════════════════ */
.gloss-controls { margin-bottom: 28px; }
.gloss-search { width: 100%; font-family: var(--font-display-th); font-size: 15px; color: var(--color-cream); background: var(--color-surface); border: 1px solid var(--color-hairline-bright); border-radius: 10px; padding: 13px 18px; margin-bottom: 16px; box-sizing: border-box; }
.gloss-search:focus { outline: none; border-color: var(--color-gold); }
.gloss-search::placeholder { color: var(--color-muted); }
.gloss-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.gloss-chip { font-family: var(--font-display-th); font-size: 13px; color: var(--color-cream-2); background: var(--color-surface); border: 1px solid var(--color-hairline-bright); border-radius: 999px; padding: 7px 14px; cursor: pointer; transition: all var(--duration-fast); }
.gloss-chip span { color: var(--color-muted); font-size: 11px; }
.gloss-chip:hover { border-color: var(--color-gold-deep); color: var(--color-cream); }
.gloss-chip.is-on { background: rgba(201,169,97,0.14); border-color: var(--color-gold); color: var(--color-gold-bright); }
.gloss-chip.is-on span { color: var(--color-gold); }
.gloss-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(420px, 1fr)); gap: 16px; align-items: start; }
.gloss-item { background: var(--color-surface); border: 1px solid var(--color-hairline); border-radius: 12px; padding: 20px 22px; }
.gloss-cat-tag { display: inline-block; font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--color-gold); background: rgba(201,169,97,0.08); border: 1px solid rgba(201,169,97,0.2); border-radius: 999px; padding: 2px 9px; margin-bottom: 10px; }
.gloss-term { font-family: var(--font-display-th); font-size: 18px; color: var(--color-cream); margin: 0 0 8px; scroll-margin-top: 90px; }
.gloss-def { font-family: var(--font-display-th); font-size: 14px; line-height: 1.65; color: var(--color-cream-3, #8f8b80); }
.gloss-def p { margin: 0 0 8px; }
.gloss-def p:last-child { margin-bottom: 0; }
.gloss-def strong { color: var(--color-cream-2); }
.gloss-def ul { margin: 8px 0 0; padding-left: 18px; }
.gloss-def li { margin-bottom: 4px; }
.gloss-link { display: inline-block; margin-top: 12px; font-family: var(--font-display-th); font-size: 13px; color: var(--color-gold); text-decoration: none; }
.gloss-link:hover { color: var(--color-gold-bright); }
.gloss-empty { text-align: center; font-family: var(--font-display-th); font-size: 15px; color: var(--color-muted); padding: 48px 0; }
.gloss-empty[hidden] { display: none !important; }
@media (max-width: 720px) {
	.gloss-grid { grid-template-columns: 1fr; }
}
.gloss-th { font-family: var(--font-display-th); font-size: 0.72em; font-weight: 400; color: var(--color-muted); white-space: nowrap; }

/* ════════════════════════════════════════════════════════════
   LEARN GOLD · pillar education page (เทรดทองคืออะไร)
   ════════════════════════════════════════════════════════════ */
.lg-hero { padding-top: 56px; text-align: center; }
.lg-eyebrow { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-gold); margin-bottom: 14px; }
.lg-h1 { font-family: var(--font-display-th); font-size: clamp(32px, 6vw, 52px); color: var(--color-cream); line-height: 1.12; margin: 0 0 22px; }
.lg-lead { font-size: 17px; line-height: 1.8; color: var(--color-cream-2); max-width: 720px; margin: 0 auto; }
.lg-lead strong { color: var(--color-cream); }
.lg-meta { font-family: var(--font-mono); font-size: 12px; color: var(--color-muted); letter-spacing: 0.04em; margin-bottom: 22px; }
.lg-tldr { max-width: 720px; margin: 30px auto 0; text-align: left; border: 1px solid rgba(196,160,82,0.28); border-radius: 14px; padding: 22px 26px; background: rgba(196,160,82,0.05); }
.lg-tldr-h { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-gold); margin-bottom: 14px; }
.lg-tldr ul { list-style: none; margin: 0; padding: 0; }
.lg-tldr li { font-size: 15px; line-height: 1.7; color: var(--color-cream-2); padding-left: 22px; position: relative; margin-bottom: 9px; }
.lg-tldr li:last-child { margin-bottom: 0; }
.lg-tldr li::before { content: "→"; position: absolute; left: 0; color: var(--color-gold); }
.lg-tldr li strong { color: var(--color-cream); }
.lg-lead em, .lg-prose em { color: var(--color-gold-bright); font-style: normal; }
.lg-toc { display: flex; flex-wrap: wrap; gap: 9px; justify-content: center; margin-top: 36px; }
.lg-toc a { font-family: var(--font-mono); font-size: 12px; color: var(--color-muted); border: 1px solid var(--color-hairline); border-radius: 999px; padding: 7px 14px; transition: color var(--duration-base), border-color var(--duration-base); }
.lg-toc a:hover { color: var(--color-gold); border-color: var(--color-gold); }
.lg-alt { background: rgba(255,255,255,0.015); }
.lg-prose h2 { font-family: var(--font-display-th); font-size: clamp(24px, 4vw, 34px); color: var(--color-cream); margin: 0 0 22px; }
.lg-prose p { font-size: 16px; line-height: 1.85; color: var(--color-cream-2); margin: 0 0 18px; }
.lg-prose p strong { color: var(--color-cream); }
.lg-prose a { color: var(--color-gold); border-bottom: 1px solid rgba(196,160,82,0.3); transition: color var(--duration-base); }
.lg-prose a:hover { color: var(--color-gold-bright); border-color: var(--color-gold-bright); }
.lg-note { font-size: 14px !important; color: var(--color-muted) !important; }
/* Comparison table */
.lg-table-wrap { overflow-x: auto; margin: 8px 0 18px; border: 1px solid var(--color-hairline); border-radius: 12px; }
.lg-table { width: 100%; border-collapse: collapse; font-size: 15px; min-width: 480px; }
.lg-table th, .lg-table td { text-align: left; padding: 13px 18px; border-bottom: 1px solid var(--color-hairline); color: var(--color-cream-2); }
.lg-table thead th { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.05em; text-transform: uppercase; color: var(--color-gold); }
.lg-table td:first-child { color: var(--color-muted); }
.lg-table tbody tr:last-child td { border-bottom: none; }
.lg-table tbody tr:hover td { background: rgba(255,255,255,0.015); }
/* Inline SVG figures */
.lg-figure { margin: 8px 0 26px; border: 1px solid var(--color-hairline); border-radius: 14px; padding: 16px; background: rgba(255,255,255,0.012); }
.lg-figure svg { display: block; width: 100%; height: auto; }
.lg-figure figcaption { text-align: center; font-family: var(--font-mono); font-size: 12px; color: var(--color-muted); margin-top: 12px; letter-spacing: 0.03em; }
/* Buy/Sell cards */
.lg-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin: 8px 0 22px; }
.lg-card { border: 1px solid var(--color-hairline); border-radius: 12px; padding: 20px; background: rgba(255,255,255,0.012); }
.lg-card-h { font-family: var(--font-mono); font-size: 13px; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 8px; }
.lg-card p { font-size: 14px !important; margin: 0 !important; }
.lg-card-bull { border-color: rgba(107,163,115,0.4); } .lg-card-bull .lg-card-h { color: var(--color-bull); }
.lg-card-bear { border-color: rgba(184,84,80,0.4); } .lg-card-bear .lg-card-h { color: var(--color-bear); }
/* Steps */
.lg-steps { list-style: none; counter-reset: none; padding: 0; margin: 0; display: grid; gap: 16px; }
.lg-steps li { border-left: 2px solid var(--color-gold); padding: 4px 0 4px 20px; }
.lg-step-h { font-family: var(--font-display-th); font-size: 18px; color: var(--color-cream); margin-bottom: 6px; }
.lg-steps p { font-size: 15px !important; margin: 0 !important; }
/* Terms dl */
.lg-terms { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 28px; margin: 0 0 18px; }
.lg-terms > div { border-bottom: 1px solid var(--color-hairline); padding-bottom: 12px; }
.lg-terms dt { font-family: var(--font-mono); font-size: 14px; color: var(--color-gold); margin-bottom: 4px; }
.lg-terms dd { font-size: 14px; line-height: 1.7; color: var(--color-cream-2); margin: 0; }
/* Risk */
.lg-risk ul, .lg-check { margin: 0 0 16px; padding-left: 0; list-style: none; }
.lg-risk li, .lg-check li { font-size: 15px; line-height: 1.8; color: var(--color-cream-2); padding-left: 26px; position: relative; margin-bottom: 10px; }
.lg-risk li::before { content: "⚠"; position: absolute; left: 0; color: var(--color-bear); }
.lg-risk li strong { color: var(--color-cream); }
.lg-check li::before { content: "✓"; position: absolute; left: 0; color: var(--color-bull); font-weight: 700; }
.lg-check li strong { color: var(--color-cream); }
.lg-dont { margin: 0 0 16px; padding-left: 0; list-style: none; }
.lg-dont li { font-size: 15px; line-height: 1.8; color: var(--color-cream-2); margin-bottom: 12px; padding-left: 4px; }
.lg-dont li strong { color: var(--color-cream); }
.lg-eeat { border: 1px solid rgba(196,160,82,0.28); border-left: 3px solid var(--color-gold); border-radius: 12px; padding: 22px 26px; background: rgba(196,160,82,0.04); }
.lg-eeat-h { font-size: 16px; font-weight: 700; color: var(--color-gold); margin-bottom: 10px; }
.lg-eeat-body { font-size: 14.5px; line-height: 1.8; color: var(--color-cream-2); margin: 0 0 14px; }
.lg-eeat-body strong { color: var(--color-cream); }
.lg-eeat-ref { margin: 0 0 14px; font-size: 13.5px; line-height: 1.7; color: var(--color-cream-3, #8a8270); }
.lg-eeat-ref-h { font-size: 12px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-gold); margin-right: 8px; }
.lg-eeat-meta { font-size: 12.5px; color: var(--color-cream-3, #8a8270); border-top: 1px solid rgba(255,255,255,0.07); padding-top: 12px; }
.lg-disclaimer { font-size: 13px !important; color: var(--color-faint) !important; font-style: italic; border-top: 1px solid var(--color-hairline); padding-top: 14px; margin-top: 6px !important; }
.lg-cta-inline { background: rgba(196,160,82,0.07); border: 1px solid rgba(196,160,82,0.25); border-radius: 12px; padding: 18px 20px; margin-top: 18px; }
.lg-cta-inline p { font-size: 15px !important; margin: 0 !important; }
/* Tools grid */
.lg-tools { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.lg-tool { display: block; border: 1px solid var(--color-hairline); border-radius: 12px; padding: 20px; background: rgba(255,255,255,0.012); transition: transform var(--duration-base), border-color var(--duration-base); }
.lg-tool:hover { transform: translateY(-3px); border-color: var(--color-gold); }
.lg-tool-h { font-family: var(--font-display-th); font-size: 18px; color: var(--color-cream); margin-bottom: 7px; }
.lg-tool p { font-size: 14px !important; line-height: 1.7 !important; color: var(--color-cream-2) !important; margin: 0 !important; }
/* FAQ title */
.lg-faq-title { font-family: var(--font-display-th); font-size: clamp(24px, 4vw, 34px); color: var(--color-cream); text-align: center; margin: 0 0 28px; }
/* Final CTA */
.lg-final { text-align: center; }
.lg-final h2 { font-family: var(--font-display-th); font-size: clamp(26px, 4.5vw, 38px); color: var(--color-cream); margin: 0 0 12px; }
.lg-final p { font-size: 16px; color: var(--color-cream-2); margin: 0 0 26px; }
.lg-final-btns { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.lg-btn { display: inline-block; padding: 14px 28px; border-radius: 999px; font-family: var(--font-mono); font-size: 14px; letter-spacing: 0.04em; transition: all var(--duration-base); }
.lg-btn-primary { background: var(--color-gold); color: var(--color-bg-base); font-weight: 600; }
.lg-btn-primary:hover { background: var(--color-gold-bright); }
.lg-btn-ghost { border: 1px solid var(--color-hairline-bright); color: var(--color-cream); }
.lg-btn-ghost:hover { border-color: var(--color-gold); color: var(--color-gold); }
@media (max-width: 640px) {
  .lg-cards, .lg-terms, .lg-tools { grid-template-columns: 1fr; }
}

/* ════ Brokers · premium intro card ════ */
.brokers-intro-sec { padding: 36px 0 0; }
.brokers-intro-card { border: 1px solid var(--color-hairline); border-radius: 18px; padding: 36px 40px; background: linear-gradient(180deg, rgba(196,160,82,0.045), rgba(255,255,255,0.008)); text-align: center; }
.brokers-intro-lead { font-size: 16px; line-height: 1.85; color: var(--color-cream-2); max-width: 760px; margin: 0 auto 30px; }
.brokers-intro-lead strong { color: var(--color-cream); }
.brokers-intro-tldr-h { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-gold); margin-bottom: 20px; }
.brokers-intro-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; max-width: 780px; margin: 0 auto; text-align: left; }
.bi-item { display: flex; gap: 13px; align-items: flex-start; border: 1px solid var(--color-hairline); border-radius: 12px; padding: 15px 17px; background: rgba(255,255,255,0.012); }
.bi-num { flex-shrink: 0; width: 25px; height: 25px; border-radius: 50%; background: var(--color-gold); color: var(--color-bg-base); font-family: var(--font-mono); font-size: 13px; font-weight: 700; display: flex; align-items: center; justify-content: center; }
.bi-item p { margin: 0; font-size: 14px; line-height: 1.6; color: var(--color-cream-2); }
.bi-item strong { color: var(--color-cream); }
.brokers-intro-foot { margin-top: 28px; font-size: 14px; color: var(--color-muted); line-height: 1.8; }
.brokers-intro-foot a { color: var(--color-gold); border-bottom: 1px solid rgba(196,160,82,0.3); transition: color var(--duration-base); }
.brokers-intro-foot a:hover { color: var(--color-gold-bright); }
.brokers-intro-date { color: var(--color-faint); }
@media (max-width: 640px) {
  .brokers-intro-card { padding: 24px 20px; }
  .brokers-intro-grid { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════════════════════════════
   HOMEPAGE · v2.22 SEO/GEO/AEO additions
   "What is AuHunter" key points · Who-it's-for grid · inline links
   ════════════════════════════════════════════════════════════ */

/* Inline contextual internal link (gold underline) */
.ilink {
  color: var(--color-gold);
  border-bottom: 1px solid var(--color-hairline-bright);
  transition: color var(--duration-fast) var(--ease-out),
              border-color var(--duration-fast) var(--ease-out);
}
.ilink:hover { color: var(--color-gold-bright); border-color: var(--color-gold); }

/* What-is lead · 5 key points */
.about-lead .sec-desc { max-width: 780px; }
.about-points {
  list-style: none;
  margin: 44px auto 0;
  max-width: 840px;
  display: grid;
  gap: 14px;
}
.about-points li {
  position: relative;
  padding-left: 30px;
  color: var(--color-cream-2);
  font-size: 16px;
  line-height: 1.75;
}
.about-points li::before {
  content: '—';
  position: absolute;
  left: 0;
  top: 0;
  color: var(--color-gold);
  font-family: var(--font-mono);
}
.about-points li strong { color: var(--color-cream); font-weight: 500; }

/* Who it's for / not for · two-column fit grid */
.fit-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  max-width: 980px;
  margin: 8px auto 0;
}
.fit-col {
  background: var(--color-surface);
  border: 1px solid var(--color-hairline);
  border-radius: var(--border-radius-md);
  padding: 34px 30px;
}
.fit-col.yes { border-top: 2px solid var(--color-bull); }
.fit-col.no  { border-top: 2px solid var(--color-bear); }
.fit-col h3 {
  font-family: var(--font-display-th);
  font-weight: 500;
  font-size: 22px;
  letter-spacing: 0.01em;
  margin-bottom: 22px;
  color: var(--color-cream);
}
.fit-col ul { list-style: none; display: grid; gap: 13px; }
.fit-col li {
  position: relative;
  padding-left: 28px;
  color: var(--color-cream-2);
  font-size: 15px;
  line-height: 1.6;
}
.fit-col li::before {
  position: absolute;
  left: 0;
  top: 0;
  font-family: var(--font-mono);
  font-weight: 500;
}
.fit-col.yes li::before { content: '✓'; color: var(--color-bull); }
.fit-col.no  li::before { content: '✗'; color: var(--color-bear); }
.fit-col li strong { color: var(--color-cream); font-weight: 500; }

@media (max-width: 720px) {
  .fit-grid { grid-template-columns: 1fr; gap: 16px; }
  .fit-col { padding: 26px 22px; }
  .about-points li { font-size: 15px; }
}

/* ── Hero · live TradingView embed (v2.23 · replaces SVG mock) ── */
.hero-chart-card .chart-head { align-items: flex-start; }
.chart-tv-tag {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-gold);
  white-space: nowrap;
}
.hero-tv-frame {
  position: relative;
  width: 100%;
  height: 360px;
  margin: 18px 0 4px;
  border: 1px solid var(--color-hairline);
  border-radius: var(--border-radius-sm);
  overflow: hidden;
  background: var(--color-bg-elevated);
}
.hero-tv-frame iframe,
.hero-tv-frame .tradingview-widget-container,
.hero-tv-frame .tradingview-widget-container__widget {
  position: absolute;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
  border: 0;
  display: block;
}
@media (max-width: 980px) {
  .hero-tv-frame { height: 300px; }
}

/* ── Hero · premium gold-framed live card (matches reference mockup) ── */
.hero-chart-card {
  border: 1.5px solid transparent;
  border-radius: 16px;
  padding: 22px 22px 16px;
  background:
    linear-gradient(180deg, var(--color-surface) 0%, var(--color-bg-elevated) 100%) padding-box,
    linear-gradient(135deg, var(--color-gold-bright) 0%, var(--color-gold-deep) 45%, var(--color-gold-bright) 100%) border-box;
  box-shadow:
    0 30px 90px -25px rgba(0, 0, 0, 0.85),
    0 0 60px -16px rgba(201, 169, 97, 0.22),
    0 0 0 1px rgba(201, 169, 97, 0.05) inset;
}
.hero-chart-card .frame-corner { display: none; }   /* premium border replaces corner accents */

.hero-price-widgets {
  margin: 4px 0 2px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.hero-price-widgets .tradingview-widget-container { width: 100%; }
.hero-price-widgets .hero-mini-chart {
  border-top: 1px solid var(--color-hairline);
  margin-top: 6px;
  padding-top: 8px;
}

/* Indicator-label row (Trend / Order Block / Liquidity / Structure / Chart Pattern) */
.hero-indicator-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 9px 18px;
  margin-top: 16px;
  padding-top: 15px;
  border-top: 1px solid var(--color-hairline);
}
.hi-tag {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.03em;
  color: var(--color-cream-2);
  white-space: nowrap;
}
.hi-tag svg {
  width: 15px;
  height: 15px;
  color: var(--color-gold);
  flex-shrink: 0;
}

/* ── Homepage polish v2.30 · limitations, stronger CTA, mobile readability ── */
.limit-text {
  max-width: 880px;
  font-size: 17px;
  line-height: 1.75;
  color: var(--color-cream-2);
  font-weight: 300;
}
.limit-text strong { color: var(--color-cream); font-weight: 500; }

.btn-gold.btn-lg {
  padding: 18px 38px;
  font-size: 15px;
  letter-spacing: 0.02em;
}
.cta-note {
  margin-top: 20px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-muted);
}

/* Mobile readability — bump body text + key sections on small screens */
@media (max-width: 640px) {
  .hero-sub { font-size: 17px; line-height: 1.7; }
  .sec-desc { font-size: 16px; line-height: 1.7; }
  .about-points li,
  .fit-col li { font-size: 15px; line-height: 1.65; }
  .limit-text { font-size: 16px; line-height: 1.7; }
  .suite-tile .suite-name { font-size: 14px; }
}

/* ── Concept illustrations (SVG, gold monochrome) · honest "concept art", not screenshots ── */
.concept-figure {
  position: relative;
  margin: 56px auto 0;
  max-width: 760px;
  border: 1px solid var(--color-hairline);
  border-radius: 12px;
  background: linear-gradient(180deg, var(--color-surface) 0%, var(--color-bg-elevated) 100%);
  padding: 30px 30px 18px;
}
.concept-figure svg {
  display: block;
  width: 100%;
  height: auto;
  max-height: 300px;
}
.concept-tag {
  position: absolute;
  top: 14px;
  right: 16px;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-muted);
  border: 1px solid var(--color-hairline-bright);
  border-radius: 999px;
  padding: 4px 11px;
}
.concept-figure figcaption {
  margin-top: 16px;
  text-align: center;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--color-muted);
}
@media (max-width: 640px) {
  .concept-figure { padding: 20px 16px 14px; margin-top: 40px; }
  .concept-figure figcaption { font-size: 10px; }
}

/* ── Indicator card media · real featured image OR branded placeholder ── */
.feat-media {
  margin: -56px -48px 32px;          /* full-bleed past card padding */
  aspect-ratio: 16 / 10;
  overflow: hidden;
  position: relative;
  background: var(--color-bg-elevated);
  border-bottom: 1px solid var(--color-hairline);
}
.feat-media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.6s ease; }
.feat-card:hover .feat-media img { transform: scale(1.04); }
.feat-media.is-placeholder {
  display: flex; align-items: center; justify-content: center;
  background:
    radial-gradient(120% 130% at 50% 0%, rgba(201,169,97,0.08), transparent 60%),
    linear-gradient(180deg, var(--color-surface), var(--color-bg-base));
}
.feat-media-art { width: 72%; max-width: 320px; height: auto; }
.feat-media-note {
  position: absolute; bottom: 12px; right: 14px;
  font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--color-muted);
  border: 1px solid var(--color-hairline-bright); border-radius: 999px; padding: 3px 9px;
}
.feat-arrow { top: auto; bottom: 48px; }          /* image occupies the top now */
@media (max-width: 980px) {
  .feat-media { margin: -40px -32px 24px; }
  .feat-arrow { bottom: 40px; right: 32px; }
}

/* ── "เห็นของจริง" · live AuHunter indicator chart (TradingView embed) ── */
.live-chart-card {
  border: 1px solid var(--color-hairline-bright);
  border-radius: 12px;
  background: linear-gradient(180deg, var(--color-surface) 0%, var(--color-bg-base) 100%);
  padding: 20px 20px 16px;
  box-shadow: 0 30px 80px -30px rgba(0, 0, 0, 0.8);
}
.live-chart-head {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 8px;
  padding: 2px 4px 16px;
}
.lch-title { font-family: var(--font-mono); font-size: 13px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--color-cream); }
.lch-title .lch-dot { color: var(--color-muted); margin: 0 4px; }
.lch-sub {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--color-gold);
}
.live-chart-frame {
  position: relative; width: 100%;
  aspect-ratio: 16 / 9;
  border-radius: 8px; overflow: hidden;
  background: var(--color-bg-base);
  border: 1px solid var(--color-hairline);
}
.live-chart-frame iframe { position: absolute; inset: 0; width: 100%; height: 100%; display: block; }
@media (max-width: 640px) {
  .live-chart-frame { aspect-ratio: 3 / 4; }
  .lch-title { font-size: 11px; letter-spacing: 0.16em; }
  .lch-sub { font-size: 9px; }
}

/* ── Featured cards · breathing room + defined card look (v2.37) ── */
.featured-grid {
  gap: 28px;
  background: none;
  border-top: none;
  border-bottom: none;
}
.feat-card {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-hairline);
  border-radius: 14px;
  overflow: hidden;
}
.feat-card:hover {
  background: var(--color-surface);
  border-color: var(--color-hairline-bright);
}
@media (max-width: 980px) {
  .featured-grid { gap: 20px; }
}

/* ── Top-bar utility menu · "เมนูสำคัญ" · refined + prominent ── */
.nav-utility-menu {
  display: flex;
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0;
}
.nav-utility-menu li { position: relative; margin: 0; padding: 0; }
.nav-utility-menu li + li { margin-left: 28px; }
.nav-utility-menu li + li::before {
  content: '';
  position: absolute;
  left: -15px;
  top: 50%;
  transform: translateY(-50%);
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: var(--color-gold-deep);
}
.nav-utility-menu a {
  position: relative;
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-cream);
  text-decoration: none;
  white-space: nowrap;
  padding: 3px 0;
  transition: color var(--duration-base) var(--ease-out);
}
.nav-utility-menu a::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  height: 1.5px;
  background: linear-gradient(90deg, var(--color-gold-bright), var(--color-gold-deep));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--duration-base) var(--ease-out);
}
.nav-utility-menu a:hover { color: var(--color-gold-bright); }
.nav-utility-menu a:hover::after { transform: scaleX(1); }
.nav-utility-menu .current-menu-item > a,
.nav-utility-menu .current_page_item > a { color: var(--color-gold-bright); }
.nav-utility-menu .current-menu-item > a::after,
.nav-utility-menu .current_page_item > a::after { transform: scaleX(1); }
/* SIGNAL (first item) = highlighted gold pill · focal point on desktop */
.nav-utility-menu li:first-child { margin-right: 8px; }
.nav-utility-menu li:first-child > a {
  padding: 7px 16px;
  border: 1px solid var(--color-gold-deep);
  border-radius: 999px;
  color: var(--color-gold-bright);
  background: rgba(201, 169, 97, 0.08);
}
.nav-utility-menu li:first-child > a::after { display: none; }
.nav-utility-menu li:first-child > a:hover {
  color: var(--color-gold-bright);
  background: rgba(201, 169, 97, 0.16);
  border-color: var(--color-gold-bright);
}
.nav-utility-menu li:nth-child(2)::before { display: none; }  /* no dot right after the pill */

/* mobile drawer · prominent "ทางลัด" quick-links group at top */
.nav-drawer-quick {
  margin-bottom: 22px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--color-hairline);
}
.nav-drawer-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: 14px;
}
.nav-drawer-utility {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.nav-drawer-utility li { margin: 0; padding: 0; }
.nav-drawer-utility a {
  display: flex;
  align-items: center;
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 500;
  color: var(--color-gold-bright);
  text-decoration: none;
  padding: 13px 16px;
  border: 1px solid var(--color-gold-deep);
  border-radius: 12px;
  background: rgba(201, 169, 97, 0.06);
  transition: background var(--duration-base) var(--ease-out);
}
.nav-drawer-utility a:hover,
.nav-drawer-utility a:active { background: rgba(201, 169, 97, 0.15); }
.nav-drawer-utility a::before { content: '→'; margin-right: 10px; color: var(--color-gold); font-family: var(--font-mono); }

/* ── Back-to-top button (global) ── */
.back-to-top {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 90;
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  padding: 0;
  border-radius: 50%;
  border: 1px solid var(--color-gold-deep);
  background: linear-gradient(180deg, var(--color-surface) 0%, var(--color-bg-elevated) 100%);
  color: var(--color-gold-bright);
  cursor: pointer;
  box-shadow: 0 12px 32px -10px rgba(0, 0, 0, 0.75), 0 0 0 1px rgba(201, 169, 97, 0.05) inset;
  opacity: 0;
  visibility: hidden;
  transform: translateY(12px);
  transition: opacity 0.3s var(--ease-out), transform 0.3s var(--ease-out), background 0.2s, border-color 0.2s;
}
.back-to-top.is-visible { opacity: 1; visibility: visible; transform: translateY(0); }
.back-to-top:hover {
  background: rgba(201, 169, 97, 0.12);
  border-color: var(--color-gold-bright);
  transform: translateY(-3px);
}
.back-to-top svg { width: 20px; height: 20px; }
@media (max-width: 640px) {
  .back-to-top { right: 16px; bottom: 16px; width: 44px; height: 44px; }
}
@media (prefers-reduced-motion: reduce) {
  .back-to-top { transition: opacity 0.2s; transform: none; }
  .back-to-top.is-visible { transform: none; }
}

/* ── Footer refinement (v2.44.0) ── */
.site-footer:not(.site-footer-app) { position: relative; overflow: hidden; }
.site-footer:not(.site-footer-app)::before {
  content: '';
  position: absolute;
  top: 0; left: 50%;
  width: 680px; height: 320px;
  transform: translateX(-50%);
  background: radial-gradient(ellipse at top, rgba(201, 169, 97, 0.07), transparent 70%);
  pointer-events: none;
  z-index: 0;
}
.site-footer:not(.site-footer-app) > .container { position: relative; z-index: 1; }

/* brand block */
.footer-brand-id { display: flex; align-items: center; gap: 14px; }
.footer-brand-rule { width: 52px; height: 1px; background: linear-gradient(90deg, var(--color-gold), transparent); }
.footer-brand-meta { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--color-faint); }

/* column header gold dash */
.footer-col h4 { display: flex; align-items: center; gap: 9px; }
.footer-col h4::before { content: ''; width: 16px; height: 1px; background: var(--color-gold-deep); flex-shrink: 0; }

/* animated gold underline on text links */
.footer-col a { position: relative; display: inline-block; }
.footer-col a::after {
  content: ''; position: absolute; left: 0; bottom: -3px;
  width: 100%; height: 1px; background: var(--color-gold);
  transform: scaleX(0); transform-origin: left;
  transition: transform var(--duration-base) var(--ease-out);
}
.footer-col a:hover::after { transform: scaleX(1); }

/* contact column · icons + color hover (no sliding underline) */
.footer-contact a, .footer-contact-static { display: inline-flex; align-items: center; gap: 9px; }
.footer-contact a::after { display: none; }
.footer-contact-static { color: var(--color-muted); font-size: 13px; font-weight: 300; }
.footer-ico { color: var(--color-gold-deep); flex-shrink: 0; transition: color var(--duration-fast); }
.footer-contact a:hover .footer-ico { color: var(--color-gold); }

@media (prefers-reduced-motion: reduce) {
  .footer-col a::after { transition: none; }
}

/* ── Footer responsive (v2.45.0) ── */
.footer-brand-meta { letter-spacing: 0.16em; line-height: 1.8; }

/* Tablet · brand full-width on top, 3 link columns stay side-by-side */
@media (max-width: 980px) {
  .footer-grid { grid-template-columns: repeat(3, 1fr); gap: 36px 28px; margin-bottom: 48px; }
  .footer-brand-block { grid-column: 1 / -1; margin-bottom: 4px; }
  .footer-tagline { max-width: 520px; }
}

/* Phone · stacked sections with hairline dividers (no more bare list) */
@media (max-width: 600px) {
  .site-footer:not(.site-footer-app) { padding: 56px 0 32px; }
  .footer-grid { grid-template-columns: 1fr; gap: 0; margin-bottom: 36px; }
  .footer-brand-block { padding-bottom: 30px; gap: 16px; }
  .footer-tagline { max-width: 100%; font-size: 14px; }
  .footer-col { padding: 24px 0; border-top: 0.5px solid var(--color-hairline); }
  .footer-col h4 { margin-bottom: 18px; }
  .footer-col li { margin-bottom: 16px; }
  .footer-col a, .footer-contact a, .footer-contact-static { font-size: 14px; }
  .footer-bottom { flex-direction: column; align-items: flex-start; gap: 18px; }
  .footer-legal { gap: 12px; }
  .footer-trademark { font-size: 10px; padding-top: 22px; }
}

/* ════════════════════════════════════════════════════════════
   FOOTER · full redesign (v2.46.0)
   Asymmetric brand/links zones + signature giant wordmark
   ════════════════════════════════════════════════════════════ */
.footer-main {
  display: grid;
  grid-template-columns: 1fr 1.15fr;
  gap: 80px;
  align-items: start;
  margin-bottom: 0;
}
.footer-brand-block { gap: 22px; }
.footer-brand-id { gap: 16px; }
.footer-tagline { max-width: 380px; }
.footer-brand-rule { width: 56px; }

.footer-links {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 44px;
}

/* signature outlined giant wordmark */
.footer-wordmark {
  font-family: var(--font-display-en);
  font-weight: 400;
  font-size: clamp(56px, 13.5vw, 192px);
  line-height: 0.92;
  letter-spacing: 0.012em;
  color: rgba(201, 169, 97, 0.05);
  -webkit-text-stroke: 1px rgba(201, 169, 97, 0.22);
  margin: 36px 0 -6px;
  padding-top: 40px;
  border-top: 0.5px solid var(--color-hairline);
  user-select: none;
  white-space: nowrap;
  overflow: hidden;
  pointer-events: none;
}

/* bottom bar refresh */
.footer-bottom { border-top: 0.5px solid var(--color-hairline); margin-top: 0; }

/* ── Tablet ── */
@media (max-width: 980px) {
  .footer-main { grid-template-columns: 1fr; gap: 52px; }
  .footer-tagline { max-width: 580px; }
  .footer-links { gap: 36px 28px; }
  .footer-wordmark { margin-top: 30px; padding-top: 34px; }
}

/* ── Phone ── */
@media (max-width: 600px) {
  .footer-main { gap: 34px; }
  .footer-links { grid-template-columns: 1fr; gap: 0; }
  .footer-wordmark {
    font-size: clamp(44px, 19vw, 92px);
    -webkit-text-stroke-width: 0.75px;
    margin-top: 22px;
    padding-top: 28px;
    text-align: center;
  }
}

/* ════════════════════════════════════════════════════════════
   FOOTER · terminal-style redesign (v2.47.0)
   ════════════════════════════════════════════════════════════ */
/* Pre-footer CTA band */
.footer-cta {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 56px;
  align-items: center;
  padding-bottom: 56px;
  margin-bottom: 56px;
  border-bottom: 0.5px solid var(--color-hairline);
}
.footer-cta-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 7px 14px; border-radius: 100px;
  border: 1px solid var(--color-gold-deep);
  background: rgba(201, 169, 97, 0.08);
  color: var(--color-gold);
  font-family: var(--font-mono); font-size: 10.5px;
  letter-spacing: 0.16em; text-transform: uppercase;
}
.footer-cta-eyebrow svg { width: 13px; height: 13px; }
.footer-cta-title {
  font-family: var(--font-display-th), var(--font-display-en), serif;
  font-weight: 300;
  font-size: clamp(32px, 4.2vw, 54px);
  line-height: 1.08;
  color: var(--color-cream);
  margin: 20px 0 18px;
}
.footer-cta-title em { color: var(--color-gold); font-style: normal; }
.footer-cta-desc { color: var(--color-cream-2); font-size: 14.5px; line-height: 1.8; max-width: 520px; font-weight: 300; }
.footer-cta-desc strong { color: var(--color-cream); font-weight: 500; }
.footer-cta-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 28px; }
.footer-cta-btn {
  display: inline-flex; align-items: center; gap: 9px;
  height: 52px; padding: 0 28px; border-radius: 4px;
  background: linear-gradient(135deg, var(--color-gold-bright), var(--color-gold) 55%, var(--color-gold-deep));
  color: #0a0806; font-size: 14px; font-weight: 600; letter-spacing: 0.01em;
  transition: transform var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast);
}
.footer-cta-btn:hover { transform: translateY(-2px); box-shadow: 0 14px 34px -12px rgba(201,169,97,0.45); }
.footer-cta-btn.ghost {
  background: none; border: 1px solid var(--color-hairline-bright);
  color: var(--color-cream); font-weight: 400;
}
.footer-cta-btn.ghost:hover { border-color: var(--color-gold); color: var(--color-gold); box-shadow: none; }

/* Terminal card */
.footer-terminal {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-hairline);
  border-radius: 14px; padding: 22px;
}
.ft-head { display: flex; justify-content: space-between; align-items: flex-start; padding-bottom: 16px; border-bottom: 0.5px solid var(--color-hairline); margin-bottom: 16px; }
.ft-eyebrow { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; color: var(--color-muted); }
.ft-symbol { font-family: var(--font-display-en); font-size: 26px; color: var(--color-cream); letter-spacing: 0.02em; margin-top: 4px; }
.ft-badge { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; color: var(--color-gold); border: 1px solid var(--color-gold-deep); border-radius: 100px; padding: 4px 11px; background: rgba(201,169,97,0.08); white-space: nowrap; }
.ft-rows { display: flex; flex-direction: column; gap: 9px; }
.ft-row { display: flex; align-items: center; gap: 12px; padding: 10px 12px; background: var(--color-surface); border: 0.5px solid var(--color-hairline); border-radius: 10px; }
.ft-ic { width: 30px; height: 30px; flex-shrink: 0; display: grid; place-items: center; border-radius: 8px; border: 1px solid var(--color-gold-deep); background: rgba(201,169,97,0.07); color: var(--color-gold); }
.ft-label { font-size: 13px; color: var(--color-cream-2); }
.ft-val { margin-left: auto; font-family: var(--font-mono); font-size: 11.5px; color: var(--color-cream); letter-spacing: 0.02em; }
.ft-conf { margin-top: 14px; padding: 14px; border: 0.5px solid var(--color-hairline); border-radius: 10px; background: rgba(201,169,97,0.04); }
.ft-conf-head { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.05em; margin-bottom: 10px; color: var(--color-muted); }
.ft-conf-note { color: var(--color-gold-deep); }
.ft-conf-bar { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; }
.ft-seg { text-align: center; font-size: 11px; padding: 7px 4px; border-radius: 6px; background: rgba(201,169,97,0.10); border: 0.5px solid var(--color-gold-deep); color: var(--color-gold); }

/* Main · brand + 4 columns */
.footer-main { grid-template-columns: minmax(0, 0.85fr) minmax(0, 2.1fr); gap: 64px; margin-bottom: 8px; }
.footer-links { grid-template-columns: repeat(4, 1fr); gap: 32px; }

/* Risk band */
.footer-risk { display: flex; gap: 14px; align-items: flex-start; padding: 18px 20px; border: 0.5px solid var(--color-hairline); border-radius: 12px; background: rgba(0,0,0,0.2); margin-top: 8px; }
.footer-risk-ic { color: var(--color-gold); flex-shrink: 0; line-height: 0; margin-top: 1px; }
.footer-risk-ic svg { width: 18px; height: 18px; }
.footer-risk p { font-size: 11.5px; line-height: 1.7; color: var(--color-muted); margin: 0; }
.footer-risk strong { color: var(--color-gold); font-weight: 500; }

/* ── Tablet ── */
@media (max-width: 980px) {
  .footer-cta { grid-template-columns: 1fr; gap: 40px; padding-bottom: 44px; margin-bottom: 44px; }
  .footer-main { grid-template-columns: 1fr; gap: 44px; }
  .footer-links { grid-template-columns: repeat(2, 1fr); gap: 34px 28px; }
}

/* ── Phone ── */
@media (max-width: 600px) {
  .footer-cta { gap: 30px; padding-bottom: 36px; margin-bottom: 36px; }
  .footer-cta-actions { gap: 12px; }
  .footer-cta-btn { flex: 1 1 100%; justify-content: center; height: 50px; }
  .footer-links { grid-template-columns: 1fr; gap: 0; }
  .footer-terminal { padding: 18px; }
  .footer-risk { flex-direction: column; gap: 10px; }
}

/* ════════════════════════════════════════════════════════════
   FOOTER · card treatment (v2.48.0)
   Brand card + chips · each link column as a card with icon title
   ════════════════════════════════════════════════════════════ */
.footer-main { gap: 28px; }
.footer-links { gap: 16px; }

/* brand as a card */
.footer-brand-block {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-hairline);
  border-radius: 16px;
  padding: 28px;
  gap: 18px;
}
.footer-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 4px; }
.footer-chip {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 7px 13px; border-radius: 100px;
  border: 1px solid var(--color-hairline-bright);
  background: rgba(201, 169, 97, 0.06);
  color: var(--color-cream-2); font-size: 12px;
}
.footer-chip svg { width: 13px; height: 13px; color: var(--color-gold); flex-shrink: 0; }

/* each column as a card */
.footer-col {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-hairline);
  border-radius: 14px;
  padding: 22px 20px;
  transition: border-color var(--duration-base) var(--ease-out), background var(--duration-base) var(--ease-out);
}
.footer-col:hover { border-color: rgba(201, 169, 97, 0.35); background: var(--color-surface); }
.footer-col h4 {
  display: flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--color-cream); margin-bottom: 16px;
}
.footer-col h4::before { display: none; }
.footer-col h4 svg { width: 15px; height: 15px; color: var(--color-gold); flex-shrink: 0; }

/* ── Tablet · 2 cards per row ── */
@media (max-width: 980px) {
  .footer-links { grid-template-columns: repeat(2, 1fr); gap: 14px; }
}
/* ── Phone · stacked cards (keep card look, not bare list) ── */
@media (max-width: 600px) {
  .footer-links { grid-template-columns: 1fr; gap: 12px; }
  .footer-col { padding: 18px 20px; border: 1px solid var(--color-hairline); border-radius: 12px; }
}

/* ── Footer · mobile 2-column cards + remove newsletter (v2.50.0) ── */
@media (max-width: 600px) {
  .footer-links { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .footer-col { padding: 16px 14px; }
  .footer-col h4 { font-size: 10.5px; margin-bottom: 13px; }
  .footer-col a, .footer-contact a, .footer-contact-static { font-size: 13px; overflow-wrap: anywhere; }
  .footer-col li { margin-bottom: 13px; }
}

/* ── Footer · equal-height cards (v2.51.0) ── */
.footer-main { align-items: stretch; }
.footer-links { grid-auto-rows: 1fr; }
