/*
  Recruiter — Recherche Talents (R12). Migrated verbatim from the canonical
  mockups (app/views/mockups/recruiter/talent_search.html.erb +
  app/views/mockups/shared/_talent_card_styles.html.erb inline <style> blocks).
  Zero inline CSS: the view carries only class hooks; the few dynamic values go
  through data-attrs / Stimulus. Scoped under .ts-page.
*/

.ts-page {
  --ts-gold: #A38543;
  --ts-gold-light: #C9A54A;
  --ts-gold-deep: #8B6F33;
  --ts-gold-luminous: linear-gradient(135deg, #B8912A 0%, #C9A54A 35%, #E8CC6E 70%, #FFF4C2 100%);
  --ts-cream: #F8F4ED;
  --ts-cream-border: #E8DDC4;
  --ts-ink: #0A0A0A;
  --ts-ink-soft: #5B5B5B;
  --ts-ink-mute: #8A8A8A;
  --ts-line: #ECECEC;
  --ts-bg: #FFFFFF;
  --ts-success: #1F7A4A;
  font-family: 'Geist', -apple-system, BlinkMacSystemFont, sans-serif;
  background: var(--ts-bg);
  min-height: 100vh;
  color: var(--ts-ink);
}

/* === Hero === */
.ts-hero { max-width: 1280px; margin: 0 auto; padding: 48px 40px 24px; text-align: center; }
.ts-hero h1 { font-size: 42px; font-weight: 700; letter-spacing: -0.02em; line-height: 1.1; margin: 0 0 12px; font-family: 'Geist', sans-serif; }
.ts-hero h1 em { font-family: 'Geist', system-ui, sans-serif; font-style: italic; background: linear-gradient(135deg, #C9A54A, #E8CC6E); -webkit-background-clip: text; background-clip: text; color: transparent; font-weight: 400; }
.ts-hero p { font-size: 14px; color: var(--ts-ink-soft); margin: 0 0 28px; }
.ts-hero p strong { color: var(--ts-ink); font-weight: 600; }

/* === Mode toggle === */
.ts-mode-toggle { display: inline-flex; background: #fff; border-radius: 100px; padding: 4px; box-shadow: 0 2px 12px rgba(0,0,0,0.04); margin-bottom: 24px; }
.ts-mode-btn { background: transparent; border: none; font-family: inherit; font-size: 13px; font-weight: 600; padding: 10px 22px; border-radius: 100px; cursor: pointer; color: var(--ts-ink-soft); transition: all 0.2s; display: inline-flex; align-items: center; gap: 8px; position: relative; }
.ts-mode-btn.active { background: linear-gradient(99deg, #BD9733 0%, #E5D29F 25%, #E8CC6E 50%, #E5D29F 75%, #FFF4C2 100%); color: #000; font-weight: 700; box-shadow: 0 2px 8px rgba(189,151,51,0.35); }
.ts-mode-btn.active:hover { background: #000; color: #A38543; }
.ts-mode-btn[disabled] { cursor: default; }
.ts-beta { background: var(--ts-cream); color: var(--ts-gold-deep); padding: 2px 7px; border-radius: 8px; font-size: 9px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; }
.ts-mode-btn.active .ts-beta { background: rgba(0,0,0,0.18); color: #000; }

/* Future-brick annotation pill (AI mode = Brique 3) */
.ts-future-pill { display: inline-flex; align-items: center; gap: 6px; margin: 0 0 18px; padding: 5px 12px; border-radius: 999px; background: #F5F5F5; color: #8A8A8A; font-size: 11px; font-weight: 600; border: 1px dashed #D9D9D9; }
.ts-future-badge { font-size: 9px; font-weight: 800; letter-spacing: 0.5px; text-transform: uppercase; color: #8B6F33; background: #F8F4ED; border: 1px solid #E8DDC4; border-radius: 6px; padding: 2px 7px; }

.ts-mode-panel { max-width: 1280px; margin: 0 auto; padding: 0 40px; }

/* === Filter bar === */
.ts-filter-bar { display: flex; align-items: center; gap: 8px; padding: 6px; background: #fff; border: 1px solid var(--ts-line); border-radius: 100px; box-shadow: 0 2px 12px rgba(0,0,0,0.04); max-width: 1100px; margin: 0 auto; }
.ts-cell-wrap { flex: 1; position: relative; min-width: 0; }
.ts-cell { width: 100%; padding: 8px 28px 8px 16px; border-radius: 100px; cursor: pointer; transition: background 0.15s; position: relative; min-width: 0; background: transparent; border: none; text-align: left; font-family: inherit; }
.ts-cell:hover, .ts-cell.active { background: var(--ts-cream); }
.ts-cell-label { display: block; color: var(--ts-ink-mute); font-size: 10px; text-transform: uppercase; letter-spacing: 0.05em; font-weight: 600; }
.ts-cell-value { display: block; color: var(--ts-ink); font-weight: 600; font-size: 12px; margin-top: 1px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ts-chevron { position: absolute; right: 8px; top: 50%; transform: translateY(-50%); color: var(--ts-ink-mute); }
.ts-divider { width: 1px; height: 24px; background: var(--ts-line); flex-shrink: 0; }
.ts-reset { width: 36px; height: 36px; border-radius: 50%; background: #fff; border: 1px solid var(--ts-line); cursor: pointer; display: flex; align-items: center; justify-content: center; color: var(--ts-ink-soft); flex-shrink: 0; text-decoration: none; }
.ts-reset:hover { border-color: var(--ts-gold); color: var(--ts-gold); }
.ts-search-btn { width: 44px; height: 44px; border-radius: 50%; background: var(--ts-gold-luminous); border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; color: var(--ts-ink); position: relative; box-shadow: 0 2px 8px rgba(163,133,67,0.25); flex-shrink: 0; }
.ts-search-btn::before { content: ""; position: absolute; top: 1px; left: 1px; right: 1px; height: 50%; background: linear-gradient(180deg, rgba(255,255,255,0.5), transparent); border-radius: 99px 99px 0 0; pointer-events: none; }

/* Dropdown panels (open via the recruiter-talent-filters Stimulus controller) */
.ts-cell-panel { position: absolute; top: calc(100% + 8px); left: 0; min-width: 200px; background: #fff; border: 1px solid var(--ts-line); border-radius: 14px; box-shadow: 0 12px 40px rgba(0,0,0,0.12); padding: 6px; z-index: 50; display: none; }
.ts-cell-wrap.open .ts-cell-panel { display: block; }
.ts-cell-wrap.open .ts-cell { background: var(--ts-cream); }
.ts-cell-opt { display: block; width: 100%; text-align: left; padding: 9px 12px; border-radius: 9px; font-size: 13px; color: var(--ts-ink); text-decoration: none; cursor: pointer; }
.ts-cell-opt:hover { background: var(--ts-cream); }
.ts-cell-opt.selected { background: var(--ts-cream); font-weight: 700; color: var(--ts-gold-deep); }

.ts-advanced-link { text-align: center; margin-top: 14px; }
.ts-advanced-link button { background: transparent; border: none; color: var(--ts-ink-soft); font-family: inherit; font-size: 12px; cursor: pointer; text-decoration: underline; text-decoration-style: dotted; text-decoration-color: var(--ts-ink-mute); text-underline-offset: 4px; display: inline-flex; align-items: center; gap: 6px; }
.ts-advanced-link button:hover { color: var(--ts-gold); }

.ts-mode-switch { display: inline-flex; align-items: center; gap: 4px; padding: 4px; border: 1px solid var(--ts-line); border-radius: 999px; background: #fff; margin: 0 0 14px; }
.ts-mode-switch a { padding: 8px 13px; border-radius: 999px; font-size: 12px; font-weight: 700; color: var(--ts-ink-mute); text-decoration: none; }
.ts-mode-switch a.active { background: var(--ts-ink); color: #fff; }

/* === Results === */
.ts-results { max-width: 1280px; margin: 32px auto 0; padding: 0 40px 64px; }
.ts-results-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }
.ts-results-title { font-size: 13px; color: var(--ts-ink-mute); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 700; }
.ts-results-title strong { color: var(--ts-ink); font-weight: 700; }
.ts-results-sort { display: flex; gap: 8px; align-items: center; background: #fff; border: 1px solid var(--ts-line); padding: 6px 10px; border-radius: 100px; font-size: 12px; color: var(--ts-ink-soft); }
.ts-results-sort select { background: transparent; border: none; font-family: inherit; font-size: 12px; color: var(--ts-ink); font-weight: 600; cursor: pointer; outline: none; }
.ts-empty { text-align: center; padding: 60px 20px; color: var(--ts-ink-soft); font-size: 14px; border: 1px dashed var(--ts-line); border-radius: 18px; background: #fff; }

/* === Talent card === */
.ts-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 20px; }
.ts-card { background: #fff; border-radius: 14px; border: 1px solid rgba(0,0,0,0.05); overflow: hidden; box-shadow: 0 2px 14px rgba(0,0,0,0.05); transition: all 0.3s ease; display: flex; flex-direction: column; height: 100%; cursor: pointer; }
.ts-card:hover { transform: translateY(-3px); box-shadow: 0 8px 30px rgba(0,0,0,0.1); }
.ts-card-link { text-decoration: none; color: inherit; display: block; }
.ts-card-photo { position: relative; aspect-ratio: 1/1; overflow: hidden; border-radius: 14px 14px 0 0; }
.ts-card-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.ts-card-photo-gradient { position: absolute; bottom: 0; left: 0; right: 0; height: 50%; background: linear-gradient(0deg, rgba(0,0,0,0.55), transparent); pointer-events: none; }
.ts-card-role-tag { position: absolute; bottom: 10px; left: 10px; background: rgba(0,0,0,0.55); backdrop-filter: blur(8px); color: #fff; font-size: 11px; font-weight: 600; padding: 4px 10px 4px 6px; border-radius: 6px; display: inline-flex; align-items: center; gap: 7px; max-width: calc(100% - 20px); }
.ts-card-role-tag .flag { font-size: 14px; line-height: 1; }
.ts-card-info { padding: 12px 14px 0; flex: 1; display: flex; flex-direction: column; }
.ts-card-name-row { display: flex; align-items: flex-start; gap: 10px; }
.ts-card-name-left { display: flex; align-items: center; gap: 5px; flex: 1; min-width: 0; padding-top: 2px; }
.ts-card-name { font-size: 14px; font-weight: 700; color: var(--ts-ink); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ts-card-role { font-size: 12px; font-weight: 500; color: var(--ts-gold); margin-top: 1px; }
.ts-card-status { display: flex; align-items: center; gap: 10px; margin-top: 6px; font-size: 11px; color: var(--ts-ink-soft); flex-wrap: wrap; }
.ts-card-status .avail-pair { display: flex; align-items: center; gap: 3px; }
.ts-card-status .avail-dot { width: 6px; height: 6px; border-radius: 50%; background: #2E7D32; display: inline-block; }
.ts-card-current { font-size: 11px; color: var(--ts-ink-soft); margin-top: 4px; }
.ts-card-current strong { font-weight: 600; color: var(--ts-ink); }

/* Recent jobs mini-carousel */
.ts-card-jobs { margin-top: 8px; }
.ts-card-jobs-label { font-size: 9px; font-weight: 700; letter-spacing: 1px; color: var(--ts-ink-mute); text-transform: uppercase; margin-bottom: 5px; }
.ts-card-job-row { display: flex; align-items: center; gap: 6px; }
.ts-card-job-box { flex: 1; min-width: 0; padding: 6px 10px; border: 1px solid rgba(163,133,67,0.22); border-radius: 6px; background: linear-gradient(180deg, #FFFDF6 0%, #FBF6E4 100%); }
.ts-card-job-title { font-size: 10.5px; font-weight: 700; color: var(--ts-ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ts-card-job-title .stars { color: var(--ts-gold); font-size: 9px; display: inline-flex; align-items: center; gap: 2px; flex-shrink: 0; }
.ts-card-job-place { font-size: 9.5px; color: var(--ts-ink-soft); margin-top: 1px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ts-card-job-nav { flex-shrink: 0; width: 20px; height: 20px; border-radius: 50%; border: 1px solid rgba(163,133,67,0.35); background: linear-gradient(180deg, #FFFDF6 0%, #F5E9C2 100%); color: var(--ts-gold-deep); cursor: pointer; display: inline-flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; transition: all 0.15s; }
.ts-card-job-nav:hover { background: linear-gradient(135deg, #C4A559, #D4BC7A, #E5D4A0, #EFE2B8); color: #3A2C12; }
.ts-card-job-counter { flex-shrink: 0; font-size: 9px; font-weight: 600; color: var(--ts-ink-mute); min-width: 22px; text-align: right; }

/* Creds */
.ts-card-creds { display: flex; gap: 6px; margin-top: 8px; margin-bottom: 12px; flex-wrap: wrap; }
.ts-card-cred { font-size: 10px; font-weight: 500; color: var(--ts-ink-soft); padding: 2px 8px; border: 1px solid rgba(0,0,0,0.08); border-radius: 4px; }
.ts-card-cred.michelin { display: inline-flex; align-items: center; gap: 4px; padding: 2px 8px; border-radius: 100px; background: #C0392B; color: #fff; font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .3px; border: none; }

/* Quick preview button */
.ts-card-preview-btn { margin-top: auto; width: 100%; padding: 8px 12px; border: 1px solid #D4BC7A; border-radius: 8px; background: linear-gradient(135deg, rgba(201,165,74,.10), rgba(232,204,110,.05)); color: #7A5E1F; font-size: 11.5px; font-weight: 700; letter-spacing: 0.3px; white-space: nowrap; cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 6px; transition: all 0.15s; font-family: inherit; }
.ts-card-preview-btn:hover { filter: brightness(1.03); border-color: #C9A84C; }

/* Card actions */
.ts-card-actions { padding: 8px 12px 12px; display: flex; flex-direction: column; gap: 8px; align-items: stretch; }
.ts-card-actions turbo-frame { display: flex; }
.ts-card-actions form { flex: 1; display: flex; }
.ts-card-actions .ts-btn { width: 100%; white-space: nowrap; }
.ts-btn { flex: 1; padding: 9px 0; border-radius: 8px; border: none; font-family: inherit; font-size: 11.5px; font-weight: 700; letter-spacing: 0.5px; text-transform: uppercase; cursor: pointer; transition: all 0.2s; text-decoration: none; display: flex; align-items: center; justify-content: center; gap: 6px; }
.ts-btn.gold { background: linear-gradient(135deg, #C4A559 0%, #D4BC7A 40%, #E5D4A0 70%, #D4BC7A 100%); color: #fff; }
.ts-btn.gold:hover { filter: brightness(1.05); }
.ts-btn.dark { background: none; border: none; color: #9A7A28; letter-spacing: 0.3px; }
.ts-btn.dark:hover { color: #7A5E1F; }
.ts-btn.dark.is-shortlisted { color: #1F7A4A; }
.ts-btn.dark.is-shortlisted svg { fill: #1F7A4A; stroke: #1F7A4A; }

/* Tastellers "T VERIFIED" badge on the photo */
.ts-card-photo .vb { position: absolute; top: 10px; right: 10px; z-index: 5; display: inline-flex; justify-content: center; align-items: center; gap: 6px; height: 20px; padding: 4px 8px; background: linear-gradient(135deg, #A38543 0%, #CDB563 50%, #B19136 100%); color: #242424; border-radius: 4px; font-family: 'Geist', system-ui, sans-serif; font-size: 10px; font-weight: 700; letter-spacing: .6px; text-transform: uppercase; line-height: 1; box-sizing: border-box; }
.ts-card-photo .vb::before { content: ""; width: 10px; height: 12px; background: url("/images/verified-t.svg") no-repeat center/contain; display: inline-block; flex-shrink: 0; }
.ts-card-photo .vb::after { content: "VERIFIED"; }

/* === Quick Preview Drawer === */
@keyframes qpFadeIn { from { opacity: 0 } to { opacity: 1 } }
@keyframes qpSlideLeft { from { transform: translateX(40px); opacity: 0 } to { transform: translateX(0); opacity: 1 } }
.ts-qp-overlay { position: fixed; inset: 0; background: rgba(20,16,10,0.45); backdrop-filter: blur(4px); z-index: 1000; display: flex; justify-content: flex-end; animation: qpFadeIn 0.2s ease-out; }
.ts-qp-overlay[hidden] { display: none; }
.ts-qp-drawer { width: 390px; max-width: 100vw; height: 100vh; background: #fff; display: flex; flex-direction: column; box-shadow: -12px 0 40px rgba(0,0,0,0.25); animation: qpSlideLeft 0.28s ease-out; }
.ts-qp-drawer { position: relative; }
.ts-qp-close.is-floating { position: absolute; top: 14px; right: 14px; z-index: 3; }
.ts-qp-content { display: flex; flex-direction: column; height: 100%; }
.ts-qp-hero { position: relative; height: 220px; overflow: hidden; background: #222; flex-shrink: 0; }
.ts-qp-hero img { width: 100%; height: 100%; object-fit: cover; }
.ts-qp-hero-grad { position: absolute; inset: 0; background: linear-gradient(180deg, transparent 40%, rgba(0,0,0,0.75)); }
.ts-qp-close { position: absolute; top: 14px; right: 14px; width: 30px; height: 30px; border-radius: 8px; background: #fff; border: 1px solid rgba(0,0,0,0.08); cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 14px; line-height: 1; padding: 0; color: #666; box-shadow: 0 2px 8px rgba(0,0,0,0.12); z-index: 2; transition: all 0.15s; }
.ts-qp-close:hover { background: #1a1a1a; color: #E5D4A0; border-color: #1a1a1a; }
.ts-qp-hero-info { position: absolute; left: 18px; bottom: 14px; color: #fff; right: 60px; }
.ts-qp-hero-name { display: flex; align-items: center; gap: 7px; margin-bottom: 2px; }
.ts-qp-hero-name span { font-size: 18px; font-weight: 700; }
.ts-qp-hero-flag { font-size: 14px; }
.ts-qp-hero-role { font-size: 13px; color: #E5D4A0; font-weight: 500; }
.ts-qp-body { flex: 1; overflow-y: auto; padding: 16px 20px 20px; }
.ts-qp-label { font-size: 9px; font-weight: 700; letter-spacing: 1.2px; color: var(--ts-ink-mute); text-transform: uppercase; margin-bottom: 7px; }
.ts-qp-status { display: flex; gap: 16px; font-size: 11.5px; color: #3A332A; margin-bottom: 16px; }
.ts-qp-status .dot { width: 7px; height: 7px; border-radius: 50%; background: #2E7D32; }
.ts-qp-status .pair { display: flex; align-items: center; gap: 5px; }
.ts-qp-current-box { padding: 10px 12px; border-radius: 8px; background: #FAF6EC; border: 1px solid rgba(201,165,74,0.25); margin-bottom: 16px; display: flex; justify-content: space-between; align-items: center; }
.ts-qp-current-role { font-size: 12.5px; font-weight: 700; color: #18140C; }
.ts-qp-current-place { font-size: 10.5px; color: #6B6560; margin-top: 1px; }
.ts-qp-current-badge { font-size: 11px; color: #9A7A28; font-weight: 600; white-space: nowrap; }
.ts-qp-badges { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 16px; }
.ts-qp-badge { font-size: 10.5px; font-weight: 600; color: var(--ts-ink); padding: 4px 10px; border: 1px solid rgba(0,0,0,0.12); border-radius: 4px; }
.ts-qp-langs { font-size: 11.5px; color: #3A332A; margin-bottom: 18px; }
.ts-qp-timeline { position: relative; padding-left: 28px; margin-bottom: 18px; }
.ts-qp-timeline-rail { position: absolute; left: 11px; top: 4px; bottom: 4px; width: 1.5px; background: var(--ts-line); }
.ts-qp-timeline-item { position: relative; margin-bottom: 12px; }
.ts-qp-timeline-item:last-child { margin-bottom: 0; }
.ts-qp-timeline-dot { position: absolute; left: -22px; top: 2px; width: 16px; height: 16px; border-radius: 5px; background: #fff; border: 1.5px solid var(--ts-line); box-shadow: 0 1px 4px rgba(0,0,0,0.08); z-index: 2; }
.ts-qp-timeline-dot.current { border-color: var(--ts-gold); box-shadow: 0 0 0 2.5px rgba(163,133,67,0.15), 0 1px 4px rgba(0,0,0,0.08); }
.ts-qp-timeline-content { display: flex; justify-content: space-between; align-items: flex-start; gap: 8px; }
.ts-qp-timeline-main { min-width: 0; flex: 1; }
.ts-qp-timeline-title { font-size: 12px; font-weight: 700; color: var(--ts-ink); display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.ts-qp-timeline-current-tag { font-size: 9px; font-weight: 700; letter-spacing: 0.4px; padding: 2px 7px; border-radius: 999px; background: #DCFCE7; color: #15803D; border: 1px solid #BBF7D0; text-transform: uppercase; white-space: nowrap; }
.ts-qp-timeline-place { font-size: 10.5px; color: var(--ts-ink-soft); margin-top: 2px; }
.ts-qp-timeline-side { text-align: right; flex-shrink: 0; }
.ts-qp-timeline-year { font-size: 10.5px; color: var(--ts-ink-mute); }
.ts-qp-timeline-stars { font-size: 10.5px; color: var(--ts-gold); margin-top: 1px; }
.ts-qp-bio { font-size: 11.5px; color: #3A332A; line-height: 1.6; margin: 0 0 18px; }
.ts-qp-edu { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: 8px; border: 1px solid rgba(0,0,0,0.06); margin-bottom: 18px; }
.ts-qp-edu-icon { width: 30px; height: 30px; border-radius: 6px; background: linear-gradient(135deg, #FFF5D6, #E5D4A0); display: flex; align-items: center; justify-content: center; font-size: 14px; flex-shrink: 0; }
.ts-qp-edu-school { font-size: 12px; font-weight: 700; color: #18140C; }
.ts-qp-edu-diploma { font-size: 10.5px; color: #6B6560; margin-top: 1px; }
.ts-qp-mentor { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: 8px; border: 1px solid rgba(0,0,0,0.06); }
.ts-qp-mentor-avatar { width: 32px; height: 32px; border-radius: 50%; background: linear-gradient(135deg, #C4A559, #D4BC7A); display: flex; align-items: center; justify-content: center; color: #fff; font-size: 11px; font-weight: 800; flex-shrink: 0; }
.ts-qp-mentor-main { flex: 1; min-width: 0; }
.ts-qp-mentor-name { font-size: 12px; font-weight: 700; color: #18140C; }
.ts-qp-mentor-quote { font-size: 10.5px; color: #6B6560; font-style: italic; margin-top: 1px; }
.ts-qp-footer { padding: 12px 20px; border-top: 1px solid rgba(0,0,0,0.08); background: #fff; display: flex; gap: 10px; flex-shrink: 0; }
.ts-qp-footer turbo-frame { flex: 1; display: flex; }
.ts-qp-footer form { flex: 1; display: flex; }
.ts-qp-footer button, .ts-qp-footer a { flex: 1; padding: 13px 0; border-radius: 8px; font-size: 12px; font-weight: 700; letter-spacing: 0.6px; text-transform: uppercase; cursor: pointer; font-family: inherit; display: flex; align-items: center; justify-content: center; gap: 6px; text-decoration: none; }
.ts-qp-footer .shortlist-btn { border: 1.5px solid #C4A559; background: #fff; color: #8C6D34; width: 100%; }
.ts-qp-footer .shortlist-btn.is-shortlisted { background: #E9F6EE; border-color: #1F7A4A; color: #1F7A4A; }
.ts-qp-footer .view-btn { border: none; background: linear-gradient(135deg, #C4A559, #D4BC7A, #E5D4A0, #EFE2B8); color: #fff; box-shadow: 0 2px 10px rgba(184,145,42,0.28); }
.ts-qp-nav-arrow { position: fixed; top: 50%; transform: translateY(-50%); width: 46px; height: 46px; border-radius: 50%; background: #fff; border: 1px solid rgba(0,0,0,0.08); cursor: pointer; color: #1a1a1a; display: flex; align-items: center; justify-content: center; box-shadow: 0 8px 24px rgba(0,0,0,0.22), 0 1px 3px rgba(0,0,0,0.08); z-index: 1001; transition: all 0.2s; padding: 0; }
.ts-qp-nav-arrow:hover { background: linear-gradient(135deg, #1a1a1a, #2C2A26); color: #E5D4A0; border-color: #1a1a1a; transform: translateY(-50%) scale(1.08); }
.ts-qp-nav-arrow:disabled { opacity: 0.3; cursor: not-allowed; }
.ts-qp-nav-prev { right: 470px; }
.ts-qp-nav-next { right: 410px; }

/* === Responsive === */
@media (max-width: 720px) {
  .ts-hero { padding: 32px 20px 16px; }
  .ts-hero h1 { font-size: 32px; }
  .ts-mode-panel { padding: 0 20px; }
  .ts-results { padding: 0 20px 40px; }
  .ts-filter-bar { display: grid; grid-template-columns: 1fr auto; gap: 8px; border-radius: 18px; }
  .ts-filter-bar > * { min-width: 0; }
  .ts-divider { display: none; }
  .ts-cell-wrap { flex: 1 1 45%; }
  .ts-results-head { align-items: flex-start; gap: 10px; }
  .ts-results-sort { width: 100%; }
  .ts-results-sort select { width: 100%; }
}

/* ── Drawer : bouton Pitch vidéo + modale (AC3.14) ── */
.ts-qp-video-btn { width: 100%; padding: 11px 12px; border-radius: 10px; border: 1px solid rgba(0,0,0,0.08); background: #FAF6EC; cursor: pointer; display: flex; align-items: center; gap: 11px; margin-bottom: 18px; font-family: inherit; }
.ts-qp-video-btn:hover { background: #F6EFDC; }
.ts-qp-video-play { width: 30px; height: 30px; border-radius: 50%; background: linear-gradient(135deg, #C4A559, #D4BC7A); display: flex; align-items: center; justify-content: center; color: #fff; font-size: 11px; flex-shrink: 0; }
.ts-qp-video-meta { flex: 1; text-align: left; display: flex; flex-direction: column; }
.ts-qp-video-title { font-size: 12.5px; font-weight: 700; color: #18140C; }
.ts-qp-video-sub { font-size: 10px; color: #888; margin-top: 1px; }
.ts-qp-video-chevron { font-size: 14px; color: #18140C; }

/* Modale centrée par défaut (dialog::modal centré par le navigateur via margin auto). */
.ts-qp-video-modal { border: none; border-radius: 16px; padding: 0; width: min(90vw, 640px); max-width: 90vw; margin: auto; overflow: hidden; box-shadow: 0 20px 60px rgba(0,0,0,0.3); }
.ts-qp-video-modal::backdrop { background: rgba(0,0,0,0.55); }
.ts-qp-video-modal-head { display: flex; align-items: center; justify-content: space-between; padding: 12px 14px 12px 18px; border-bottom: 1px solid rgba(0,0,0,0.06); }
.ts-qp-video-modal-title { font-size: 13px; font-weight: 700; color: #18140C; }
.ts-qp-video-modal-tools { display: flex; align-items: center; gap: 4px; }
.ts-qp-video-modal-btn { background: none; border: none; line-height: 1; color: #6B6560; cursor: pointer; padding: 6px; border-radius: 8px; display: inline-flex; align-items: center; justify-content: center; font-size: 22px; transition: background 0.15s; }
.ts-qp-video-modal-btn svg { width: 17px; height: 17px; }
.ts-qp-video-modal-btn:hover { background: #F3EFE6; color: #18140C; }
.ts-qp-video-frame { aspect-ratio: 16 / 9; background: linear-gradient(135deg, #1C1A17, #2A2620); display: flex; align-items: center; justify-content: center; }
.ts-qp-video-frame svg { width: 56px; height: 56px; color: rgba(255,255,255,0.85); }
.ts-qp-video-frame:fullscreen { width: 100vw; height: 100vh; aspect-ratio: auto; }

/* Initiales (or sur fond noir) quand le talent n'a pas de photo de profil. */
.ts-card-photo-initials, .ts-qp-hero-initials { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; background: #0D0D0D; color: #C9A54A; font-family: 'Geist', system-ui, sans-serif; font-weight: 700; letter-spacing: 1px; }
.ts-card-photo-initials { font-size: 46px; }
.ts-qp-hero-initials { font-size: 64px; }
