/*
  Talent Dashboard (R8) — migrated from the canonical mockup
  app/views/mockups/talent/dashboard.html.erb (inline <style> block).
  Zero inline CSS: the view body carries only class hooks. Availability-state
  colors (AC8.4) + future-brick (Brique 3/4) annotation styles added at bottom.
*/
:root{
  --gold-btn: linear-gradient(135deg, #C4A559 0%, #D4BC7A 40%, #E5D4A0 70%, #EFE2B8 100%);
  --gold-base: #A8893C;
  --gold-primary: #C4A559;
  --gold-ultra-soft: #F7EDCC;
  --mid: #6B6B6B;
  --light-text: #9A9A9A;
  --line-soft: #F0EDE3;
  --line: #E8E8E4;
}
.td-main{max-width:1280px;margin:0 auto;padding:28px 32px 60px;}

.td-top-banner{display:grid;grid-template-columns:2fr 1fr 1fr;gap:16px;align-items:stretch;margin-bottom:16px;}

.tdb-card{
  background:
    radial-gradient(120% 80% at 0% 0%, rgba(255,244,194,0.06) 0%, rgba(255,255,255,0) 55%),
    radial-gradient(120% 80% at 100% 100%, rgba(189,151,51,0.04) 0%, rgba(255,255,255,0) 60%),
    linear-gradient(180deg, #FFFFFF 0%, #FBFAF7 60%, #F6F4EE 100%);
  border:1px solid rgba(0,0,0,0.05);
  border-radius:14px;padding:20px;display:flex;flex-direction:column;transition:all .2s;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.9) inset,
    0 0 0 1px rgba(255,255,255,0.5) inset,
    0 1px 2px rgba(20,16,8,0.03),
    0 6px 20px -10px rgba(120,98,40,0.08);
}
.tdb-card:hover{
  box-shadow:
    0 1px 0 rgba(255,255,255,0.9) inset,
    0 0 0 1px rgba(255,255,255,0.6) inset,
    0 2px 4px rgba(20,16,8,0.04),
    0 14px 32px -14px rgba(120,98,40,0.14);
}
.tdb-card-title{font-family:'Geist',system-ui,sans-serif;font-size:18px;font-weight:600;color:#1a1a1a;margin-bottom:14px;display:flex;align-items:center;gap:8px;line-height:1.2;}

.tdb-hello-consolidated{display:flex;flex-direction:column;}
.tdb-hello-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;}
.tdb-hello-row{display:flex;flex-direction:row;gap:16px;align-items:flex-start;flex:1;min-width:0;}
.tdb-avatar{width:88px;height:88px;border-radius:50%;background:var(--gold-btn);border:3px solid #fff;box-shadow:0 3px 12px rgba(168,137,60,.26);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;}
.tdb-avatar span{font-family:'Geist',system-ui,sans-serif;font-size:38px;font-weight:600;color:#fff;line-height:1;}
.tdb-avatar img{width:100%;height:100%;object-fit:cover;display:block;}
.tdb-hello-info{display:flex;flex-direction:column;gap:4px;min-width:0;}
.tdb-greet{font-family:'Geist',system-ui,sans-serif;font-size:24px;font-weight:600;color:#1a1a1a;line-height:1.15;}
.tdb-greet em{font-style:italic;color:var(--gold-base);font-weight:500;}
.tdb-role{font-size:11px;color:#888;font-weight:500;}

.tdb-filleuls-banner{display:flex;align-items:center;gap:12px;padding:10px 14px;margin:8px 0;background:linear-gradient(90deg,rgba(196,165,89,0.06) 0%,rgba(248,226,122,0.10) 100%);border:1px solid rgba(196,165,89,0.22);border-radius:10px;flex-wrap:wrap;}
.tdb-filleuls-icon{width:22px;height:22px;border-radius:50%;background:rgba(196,165,89,0.16);color:#A8893C;display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0;}
.tdb-filleuls-text{flex:1;min-width:140px;line-height:1.3;}
.tdb-filleuls-title{font-size:12px;font-weight:600;color:#1a1a1a;}
.tdb-filleuls-sub{font-size:11px;color:#6B6B6B;}
.tdb-filleuls-progress{display:flex;gap:4px;flex-shrink:0;}
.tdb-fp-seg{width:18px;height:6px;border-radius:3px;background:rgba(196,165,89,0.18);display:inline-block;}
.tdb-fp-seg.tdb-fp-on{background:linear-gradient(90deg,#C4A559,#D4BC7A);}
.tdb-filleuls-cta{font-size:12px;color:#A8893C;font-weight:600;text-decoration:none;flex-shrink:0;white-space:nowrap;}
.tdb-filleuls-cta:hover{color:#1a1a1a;}

.tdb-badges{display:flex;flex-direction:row;gap:5px;flex-wrap:wrap;margin:6px 0 2px;}
.tdb-badge{font-size:9px;font-weight:700;padding:3px 9px;border-radius:100px;letter-spacing:.02em;line-height:1.3;white-space:nowrap;}
.tdb-b-score{background:linear-gradient(135deg,rgba(184,151,90,.1),rgba(184,151,90,.04));color:#8C6D34;border:1px solid rgba(184,151,90,.2);}
.tdb-b-role{background:linear-gradient(135deg,rgba(46,125,50,.08),rgba(46,125,50,.04));color:#2E7D32;border:1px solid rgba(46,125,50,.15);}

.tdb-hello-links{display:flex;gap:16px;flex-wrap:wrap;margin-top:6px;}
.tdb-cta-link{font-size:11px;font-weight:700;color:var(--gold-base);transition:color .15s;text-decoration:none;}
.tdb-cta-link:hover{color:#1a1a1a;}
.tdb-cta-link-muted{color:#6B6B6B !important;}
.tdb-cta-link-muted:hover{color:#A8893C !important;}

.tdb-vis-compact{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0;}
.tdb-vis-status{display:flex;align-items:center;gap:10px;}
.tdb-vis-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;}
.tdb-vis-dot-on{background:#4ADE80;box-shadow:0 0 0 4px rgba(74,222,128,.2);}
.tdb-vis-dot-open{background:#F5B301;box-shadow:0 0 0 4px rgba(245,179,1,.2);}
.tdb-vis-dot-off{background:#B0B0B0;box-shadow:0 0 0 4px rgba(176,176,176,.18);}
.tdb-vis-text{font-family:'Geist',system-ui,sans-serif;font-size:16px;font-weight:600;color:#1a1a1a;line-height:1;}
.tdb-toggle{width:42px;height:24px;border-radius:13px;position:relative;cursor:pointer;background:rgba(0,0,0,.08);transition:background .2s;flex-shrink:0;border:none;padding:0;}
.tdb-toggle.tdb-toggle-on{background:linear-gradient(135deg,#4CAF50,#2E7D32);}
.tdb-toggle.tdb-toggle-open{background:linear-gradient(135deg,#F6C453,#E0A52E);}
.tdb-toggle-thumb{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.2);transition:left .2s;}
.tdb-toggle.tdb-toggle-on .tdb-toggle-thumb,.tdb-toggle.tdb-toggle-open .tdb-toggle-thumb{left:21px;}
.tdb-vis-sub{font-size:11px;color:#9A9A9A;font-weight:500;}
.tdb-vis-states{display:flex;gap:6px;margin-top:6px;}
.tdb-vis-state-btn{font-size:10px;font-weight:600;padding:3px 9px;border-radius:100px;border:1px solid rgba(0,0,0,.08);background:#fff;color:#6B6B6B;cursor:pointer;transition:all .15s;font-family:inherit;}
.tdb-vis-state-btn:hover{border-color:var(--gold-primary);color:#1a1a1a;}
.tdb-vis-state-btn.tdb-vis-state-active{background:var(--gold-ultra-soft);border-color:var(--gold-primary);color:#8C6D34;}

.tdb-hello-divider{height:1px;background:rgba(196,165,89,0.14);margin:auto 0 16px;}

.tdb-hello-comp{
  display:flex;flex-direction:column;gap:10px;
  background:linear-gradient(180deg,rgba(255,255,255,0.6),rgba(248,244,237,0.5));
  border:1px solid rgba(0,0,0,0.04);border-radius:12px;padding:14px 16px;
}
.tdb-comp-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:2px;}
.tdb-comp-label{font-family:'Geist',system-ui,sans-serif;font-size:18px;font-weight:600;color:#1a1a1a;line-height:1.2;}
.tdb-comp-pct{font-family:'Geist',system-ui,sans-serif;font-weight:600;color:var(--gold-base);line-height:1;}
.tdb-comp-pct-num{font-size:32px;}
.tdb-comp-pct-sign{font-size:18px;margin-left:1px;}
.tdb-comp-track{height:6px;background:rgba(0,0,0,.04);border-radius:4px;overflow:hidden;}
.tdb-comp-fill{height:100%;background:var(--gold-btn);border-radius:4px;transition:width .4s ease;}
.tdb-comp-missing-row{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;}
.tdb-comp-missing-left{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.tdb-comp-missing-label{font-size:11px;color:#888;font-weight:500;line-height:1.3;}
.tdb-comp-missing-badges{display:flex;flex-wrap:wrap;gap:6px;}
.tdb-miss-badge{font-size:11px;font-weight:600;padding:4px 10px;border-radius:100px;background:rgba(184,151,90,.1);color:var(--gold-base);border:1px solid rgba(184,151,90,.2);text-decoration:none;line-height:1.3;transition:all .15s;}
.tdb-miss-badge:hover{background:rgba(184,151,90,.18);color:#1a1a1a;}
.tdb-comp-cta{font-size:12px;font-weight:500;color:var(--gold-base);text-decoration:none;cursor:pointer;white-space:nowrap;transition:color .15s;}
.tdb-comp-cta:hover{color:#8C6D34;}

/* Agenda */
.td-agenda-header{padding:18px 20px;}
.td-agenda-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.td-agenda-title{display:flex;align-items:center;gap:8px;font-family:'Geist',system-ui,sans-serif;font-size:19px;font-weight:500;color:#1a1a1a;line-height:1;}
.td-agenda-icon{color:var(--gold-base);}
.td-agenda-all{font-size:11px;font-weight:500;color:var(--gold-base);text-decoration:none;}
.td-agenda-all:hover{color:#8C6D34;}
.td-agenda-sep-line{height:1px;background:rgba(0,0,0,.05);margin-bottom:10px;}
.td-agenda-events{display:flex;flex-direction:column;gap:12px;}
.td-agenda-event{display:flex;align-items:center;gap:14px;}
.td-agenda-date{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 10px;background:#FAF5E4;border:1px solid #F7EDCC;border-radius:10px;min-width:46px;flex-shrink:0;}
.td-agenda-day{font-family:'Geist',system-ui,sans-serif;font-size:22px;font-weight:600;color:#1a1a1a;line-height:1;}
.td-agenda-month{font-size:9px;font-weight:600;letter-spacing:.14em;color:var(--gold-base);text-transform:uppercase;margin-top:3px;}
.td-agenda-details{flex:1;min-width:0;}
.td-agenda-event-title{font-size:13px;font-weight:600;color:#1a1a1a;line-height:1.25;}
.td-agenda-event-sub{font-size:11px;color:var(--mid);margin-top:3px;line-height:1.3;}
.td-agenda-sync{display:flex;align-items:center;gap:6px;margin-top:14px;padding:9px 11px;background:#FAF5E4;border-radius:10px;font-size:11px;color:var(--mid);}
.td-agenda-sync-icon{color:var(--gold-base);font-weight:500;}

/* Quick actions */
.tdb-actions-list{display:flex;flex-direction:column;gap:4px;}
.tdb-action{display:flex;align-items:center;gap:10px;padding:7px 8px;border-radius:8px;font-size:12px;cursor:pointer;text-decoration:none;color:#1a1a1a;transition:background .15s;}
.tdb-action:hover{background:rgba(184,151,90,.06);}
.tdb-action-icon{width:26px;height:26px;border-radius:7px;background:rgba(184,151,90,.1);color:var(--gold-base);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.tdb-action-text{flex:1;font-size:12px;font-weight:600;color:#1a1a1a;}
.tdb-action-chev{margin-left:auto;color:#ccc;font-size:14px;}

/* AI Quick Search (compact — inside actions card) */
.td-quick-ai-mini{margin-top:auto;padding:10px 12px;border-radius:10px;background:linear-gradient(135deg,rgba(196,165,89,0.06),rgba(248,226,122,0.10));border:1px solid rgba(196,165,89,0.22);display:flex;flex-direction:column;gap:8px;}
.td-quick-ai-mini-header{display:inline-flex;align-items:center;gap:6px;color:#A38543;font-weight:700;font-size:11px;}
.td-quick-ai-form{display:flex;gap:6px;align-items:stretch;background:#FAF7F0;border:1px solid #EADFC4;border-radius:9999px;padding:3px 3px 3px 12px;}
.td-quick-ai-input{flex:1;border:none;background:transparent;outline:none;font-size:11px;color:#18140C;min-width:0;font-family:inherit;}
.td-quick-ai-btn{padding:4px 10px;font-size:10px;font-weight:700;display:inline-flex;align-items:center;gap:4px;white-space:nowrap;border-radius:9999px;background:var(--gold-btn);color:#1a1208;border:1px solid rgba(196,165,89,.4);box-shadow:0 2px 8px rgba(184,145,42,.18);cursor:pointer;transition:all .18s;}
.td-quick-ai-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(184,145,42,.28);}

/* KPI row */
.td-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;}
.td-kpi{
  background:
    radial-gradient(120% 80% at 0% 0%, rgba(255,244,194,0.06) 0%, rgba(255,255,255,0) 55%),
    radial-gradient(120% 80% at 100% 100%, rgba(189,151,51,0.04) 0%, rgba(255,255,255,0) 60%),
    linear-gradient(180deg, #FFFFFF 0%, #FBFAF7 60%, #F6F4EE 100%);
  border:1px solid rgba(0,0,0,0.05);border-radius:14px;padding:16px 18px;
  display:flex;align-items:center;gap:14px;text-decoration:none;color:inherit;
  transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease;cursor:pointer;
  box-shadow:0 1px 0 rgba(255,255,255,0.9) inset,0 0 0 1px rgba(255,255,255,0.5) inset,0 1px 2px rgba(20,16,8,0.03),0 6px 20px -10px rgba(120,98,40,0.08);
}
.td-kpi:hover{transform:translateY(-1px);border-color:var(--gold-primary);
  box-shadow:0 1px 0 rgba(255,255,255,0.9) inset,0 0 0 1px rgba(255,255,255,0.6) inset,0 2px 4px rgba(20,16,8,0.04),0 14px 32px -14px rgba(120,98,40,0.14);
}
.td-kpi-icon{width:44px;height:44px;border-radius:50%;background:var(--gold-ultra-soft);color:var(--gold-base);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600;flex-shrink:0;}
.td-kpi-body{display:flex;flex-direction:column;gap:2px;min-width:0;}
.td-kpi-num{font-family:'Geist','Inter',system-ui,sans-serif;font-size:26px;font-weight:600;color:#1a1a1a;line-height:1.05;letter-spacing:-0.01em;}
.td-kpi-label{font-size:12px;color:var(--mid);font-weight:500;line-height:1.2;}
.td-kpi-trend{display:inline-flex;align-self:flex-start;font-size:11px;font-weight:600;padding:2px 8px;border-radius:8px;margin-top:3px;line-height:1.3;}
.td-kpi-trend-pos{background:rgba(46,125,50,.08);color:#2E7D32;}
.td-kpi-trend-text{font-size:11px;color:var(--light-text);font-weight:500;margin-top:3px;line-height:1.3;}

/* Proposals banner */
.td-proposals-banner{display:flex;align-items:center;gap:14px;padding:14px 18px;border-radius:14px;background:linear-gradient(99deg,#FFF8E8 0%,#F8E8B8 100%);border:1px solid #E8D49A;text-decoration:none;color:#3a2f12;margin-bottom:24px;font-weight:600;}
.td-proposals-text{flex:1;font-size:14px;}
.td-proposals-cta{font-size:12px;color:#8C6D34;font-weight:700;}

/* Section label */
.td-section-label{display:inline-flex;align-items:center;gap:8px;font-size:9px;font-weight:800;letter-spacing:2px;color:#B8975A;text-transform:uppercase;margin-bottom:14px;}
.td-section-label::after{content:'';display:inline-block;width:60px;height:1px;background:linear-gradient(90deg,#D5C9A8,transparent);}

/* Two column */
.td-two-col{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:24px;align-items:start;}
.td-main-stack{display:flex;flex-direction:column;gap:28px;min-width:0;}

/* Pipeline */
.td-pipeline-cols{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.td-pipeline-col{
  background:
    radial-gradient(120% 80% at 0% 0%, rgba(255,244,194,0.06) 0%, rgba(255,255,255,0) 55%),
    radial-gradient(120% 80% at 100% 100%, rgba(189,151,51,0.04) 0%, rgba(255,255,255,0) 60%),
    linear-gradient(180deg, #FFFFFF 0%, #FBFAF7 60%, #F6F4EE 100%);
  border:1px solid rgba(0,0,0,0.05);border-radius:14px;overflow:hidden;padding:16px 14px;
  box-shadow:0 1px 0 rgba(255,255,255,0.9) inset,0 0 0 1px rgba(255,255,255,0.5) inset,0 1px 2px rgba(20,16,8,0.03),0 6px 20px -10px rgba(120,98,40,0.08);
}
.td-pcol-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.td-pcol-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;}
.td-pcol-subtitle{font-weight:400;font-size:9px;text-transform:none;letter-spacing:0;color:#9a9690;}
.td-pcol-count{font-size:11px;font-weight:700;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;}
.td-pcol-body{display:flex;flex-direction:column;gap:10px;min-height:80px;}
.td-pcol-empty{font-size:11px;color:#9a9690;font-style:italic;text-align:center;padding:14px 6px;}
.td-col-envoyee .td-pcol-title{color:#64748B;}.td-col-envoyee .td-pcol-count{background:#64748B;}
.td-col-vue .td-pcol-title{color:#3B82C8;}.td-col-vue .td-pcol-count{background:#3B82C8;}
.td-col-entretien .td-pcol-title{color:#B8975A;}.td-col-entretien .td-pcol-count{background:linear-gradient(135deg,#D4BC7A,#C4A559);}
.td-col-offre .td-pcol-title{color:#4A8256;}.td-col-offre .td-pcol-count{background:#4A8256;}
.td-p-card{background:#fff;border-radius:10px;padding:14px 14px 13px;border:1px solid rgba(0,0,0,.06);transition:all .2s;cursor:pointer;text-decoration:none;display:block;color:inherit;}
.td-p-card:hover{border-color:#B8975A;box-shadow:0 2px 8px rgba(184,145,42,.08);transform:translateY(-1px);}
.td-p-card-estab{font-family:'Geist',sans-serif;font-size:13px;font-weight:700;color:#1a1a1a;line-height:1.35;margin-bottom:4px;}
.td-p-card-role{font-family:'Geist',sans-serif;font-size:12px;font-weight:500;color:#B8975A;line-height:1.45;margin-bottom:10px;}
.td-p-card-meta{display:flex;align-items:center;justify-content:space-between;}
.td-p-card-date{font-size:10.5px;color:#A09890;font-weight:500;}
.td-p-card-score{font-size:10.5px;font-weight:700;padding:3px 8px;border-radius:10px;background:#F5ECCC;color:#8A6A1A;}
.td-p-card-score-green{background:rgba(74,130,86,.12);color:#4A8256;}
/* Establishment logo + interview person */
.td-p-card-head{display:flex;align-items:flex-start;gap:11px;margin-bottom:13px;}
.td-p-logo{width:30px;height:30px;border-radius:8px;background:var(--gold-btn);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Geist',system-ui,sans-serif;font-size:11px;font-weight:700;letter-spacing:.02em;flex-shrink:0;box-shadow:0 1px 4px rgba(168,137,60,.25);}
.td-p-card-head>div:last-child{min-width:0;padding-top:1px;}
.td-p-card-head .td-p-card-estab{margin-bottom:4px;}
.td-p-card-head .td-p-card-role{margin-bottom:0;}
.td-p-person{display:flex;align-items:center;gap:8px;margin-bottom:10px;padding:6px 8px;background:#FAF5E4;border:1px solid #F1E6C8;border-radius:8px;}
.td-p-person-av{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#9B7B3F,#C9A84C);color:#fff;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;flex-shrink:0;font-family:'Geist',system-ui,sans-serif;}
.td-p-person-name{font-size:11px;font-weight:600;color:#6B5520;line-height:1.1;}
.td-p-person-label{font-size:9px;color:#A09890;letter-spacing:.04em;text-transform:uppercase;}

/* Opportunities */
.td-oppo-list{display:flex;flex-direction:column;gap:14px;}
.td-oppo-card{display:flex;flex-direction:column;gap:16px;
  background:
    radial-gradient(120% 80% at 0% 0%, rgba(255,244,194,0.06) 0%, rgba(255,255,255,0) 55%),
    radial-gradient(120% 80% at 100% 100%, rgba(189,151,51,0.04) 0%, rgba(255,255,255,0) 60%),
    linear-gradient(180deg, #FFFFFF 0%, #FBFAF7 60%, #F6F4EE 100%);
  border:1px solid rgba(0,0,0,.04);border-radius:14px;padding:20px 22px;
  transition:border-color .18s ease,box-shadow .18s ease;
  box-shadow:0 1px 0 rgba(255,255,255,0.9) inset,0 0 0 1px rgba(255,255,255,0.5) inset,0 1px 2px rgba(20,16,8,0.03),0 6px 20px -10px rgba(120,98,40,0.08);
}
.td-oppo-card:hover{border-color:var(--gold-primary);
  box-shadow:0 1px 0 rgba(255,255,255,0.9) inset,0 0 0 1px rgba(255,255,255,0.6) inset,0 2px 4px rgba(20,16,8,0.04),0 14px 32px -14px rgba(120,98,40,0.14);
}
.td-oppo-header{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;}
.td-oppo-id{display:flex;gap:14px;align-items:flex-start;flex:1;min-width:0;}
.td-oppo-logo{width:52px;height:52px;border-radius:12px;background:var(--gold-btn);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Geist',system-ui,sans-serif;font-size:17px;font-weight:700;flex-shrink:0;box-shadow:0 2px 8px rgba(168,137,60,.25);}
.td-oppo-content{flex:1;min-width:0;}
.td-oppo-estab{font-size:15px;font-weight:600;color:#1a1a1a;line-height:1.25;display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.td-oppo-estab-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 9px 4px 8px;border-radius:999px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;flex-shrink:0;}
.td-oppo-ub-palace{background:#1C1A17;color:#F5D480;}
.td-oppo-ub-michelin{background:#5B2A2E;color:#F3C9A8;}
.td-oppo-ub-hotel5{background:#B8912A;color:#FFFBEA;}
.td-oppo-role{font-size:13px;font-weight:500;color:var(--gold-base);margin-top:3px;line-height:1.3;}
.td-oppo-match{display:inline-flex;align-items:center;font-size:11px;font-weight:600;padding:4px 11px;border-radius:14px;background:transparent;white-space:nowrap;flex-shrink:0;}
.td-oppo-match-excellent{background:#2E7D32;color:#fff;border:none;}
.td-oppo-match-strong{background:#4A8256;color:#fff;border:none;}
.td-oppo-meta{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin:12px 0 0;font-size:12px;color:var(--mid);}
.td-oppo-meta-item{display:inline-flex;align-items:center;gap:5px;color:var(--mid);}
.td-oppo-buttons{display:flex;flex-direction:row;gap:12px;align-items:center;justify-content:flex-start;}
.td-oppo-btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;border-radius:24px;font-size:13px;font-weight:600;text-decoration:none;cursor:pointer;transition:all .18s ease;border:1px solid transparent;white-space:nowrap;}
.td-oppo-btn-apply{background:var(--gold-btn);color:#1a1208;box-shadow:0 2px 8px rgba(184,145,42,.18);border:1px solid rgba(196,165,89,.4);}
.td-oppo-btn-apply:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(184,145,42,.28);}
.td-oppo-btn-view{background:transparent;color:var(--gold-base);border:1px solid var(--gold-primary);}
.td-oppo-btn-view:hover{background:rgba(184,145,42,.06);}
.td-oppo-btn-shortlist{background:transparent;color:var(--gold-base);border:1px solid var(--gold-primary);}
.td-oppo-btn-shortlist:hover{background:rgba(184,145,42,.06);}

/* Sidebar — uses shared DS partials (messages_card, network_card, invitations_card) */
.td-sidebar{display:flex;flex-direction:column;gap:20px;min-width:0;align-self:start;margin-top:34px;}

/* Animations */
@keyframes td-fadeUp{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:none;}}
.td-anim-1{animation:td-fadeUp .5s ease .05s both;}
.td-anim-2{animation:td-fadeUp .5s ease .12s both;}
.td-anim-3{animation:td-fadeUp .5s ease .2s both;}
.td-anim-5{animation:td-fadeUp .5s ease .36s both;}

/* ---------------------------------------------------------------------------
   Future-brick annotation (Brique 3 = IA/matching, Brique 4 = messagerie).
   Elements stay visible to preserve the design but are de-emphasized so the
   client understands they are not active yet in Brick 1.
---------------------------------------------------------------------------- */
.td-future{position:relative;filter:grayscale(0.9);opacity:.55;pointer-events:none;}
.td-future-badge{position:absolute;top:8px;right:8px;z-index:2;font-size:9px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:3px 8px;border-radius:100px;background:#1C1A17;color:#E8D49A;border:1px solid rgba(196,165,89,.35);box-shadow:0 1px 4px rgba(0,0,0,.15);pointer-events:auto;white-space:nowrap;}
/* Inline future-brick chip (for small in-flow elements like the IA badge) */
.td-future-chip{filter:grayscale(0.9);opacity:.6;}
.td-future-tag{display:inline-flex;align-items:center;font-size:8px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;padding:2px 6px;border-radius:100px;background:#1C1A17;color:#E8D49A;border:1px solid rgba(196,165,89,.35);vertical-align:middle;margin-left:4px;}

/* ---------------------------------------------------------------------------
   Inline-style migration (task 020/006) — semantic hooks replacing the last
   inline style="" attributes in the view. Appearance is preserved 1:1.
---------------------------------------------------------------------------- */
.td-quick-ai-spark{font-size:12px;}      /* ✦ spark glyph */
.td-kpi-static{cursor:default;}          /* Réseau KPI — illustratif, non-cliquable */
.td-proposals-emoji{font-size:22px;}     /* 📨 proposals banner emoji */

/* CV status card (right sidebar) */
.td-cv-head{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.td-cv-gold{color:hsl(var(--brand-gold-main));}
.td-cv-body{font-size:13px;color:#6B6B6B;}
.td-cv-action{margin-top:10px;}

/* Responsive */
@media(max-width:1024px){
  .td-two-col{grid-template-columns:1fr;}
  .td-pipeline-cols{grid-template-columns:repeat(2,1fr);}
  .td-kpi-row{grid-template-columns:repeat(2,1fr);}
  .td-top-banner{grid-template-columns:1fr 1fr;}
  .td-top-banner .tdb-hello-consolidated{grid-column:1 / -1;}
  .td-sidebar{position:static;max-height:none;overflow-y:visible;top:auto;}
}
@media(max-width:640px){
  .td-top-banner{grid-template-columns:1fr;}
  .td-kpi-row{grid-template-columns:repeat(2,1fr);gap:12px;}
  .td-kpi{flex-direction:column;align-items:center;text-align:center;aspect-ratio:1;justify-content:center;padding:14px 10px;gap:8px;}
  .td-kpi-icon{width:36px;height:36px;font-size:17px;}
  .td-kpi-num{font-size:22px;}
  .td-kpi-label{font-size:11px;}
  .td-kpi-trend,.td-kpi-trend-text{font-size:10px;}
  .td-pipeline-cols{grid-template-columns:1fr;}
  .td-main{padding:20px 16px 40px;}
  /* Hero card: let grid/flex items shrink and the greeting + availability toggle
     row wrap instead of overflowing (and being clipped) on narrow screens. */
  .tdb-card,.tdb-hello-consolidated,.tdb-hello-top{min-width:0;}
  .tdb-hello-top{flex-wrap:wrap;gap:10px;}
}
</content>
