/*
  Talent Job detail (R12) — migrated from the canonical mockup
  app/views/mockups/talent/job.html.erb (inline <style> block, incl. the
  "lisibilité" readability pass). Zero inline CSS; dynamic match ring degree is
  set via a data-attr + the talent-match Stimulus controller. Future-brick
  (Brick 3 AI compatibility) annotated + grayed.
*/
.page-job-listing *{margin:0;padding:0;box-sizing:border-box;}
.page-job-listing{font-family:'Inter','DM Sans',sans-serif;background:#FFFFFF;color:#1a1a1a;min-height:100vh;}
.page-job-listing button{cursor:pointer;border:none;background:none;font-family:inherit;}
.page-job-listing a{text-decoration:none;color:inherit;}

/* ── BACK BAR ── */
.page-job-listing .back-bar{padding:14px 0 0;max-width:1060px;margin:0 auto;padding-left:24px;}
.page-job-listing .back-link{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#888;cursor:pointer;transition:color .15s;}
.page-job-listing .back-link:hover{color:#C4A559;transform:translateY(-1px);}

/* ── LAYOUT ── */
.page-job-listing .page{max-width:1060px;margin:0 auto;padding:28px 24px 60px;display:grid;grid-template-columns:1fr 320px;gap:24px;align-items:start;}
.page-job-listing .left{display:flex;flex-direction:column;gap:16px;}

/* Banner */
.page-job-listing .banner{border-radius:16px;overflow:hidden;background:linear-gradient(135deg,#1a1a1a 0%,#2d2d2d 50%,#3a2820 100%);padding:28px 28px 24px;position:relative;}
.page-job-listing .banner::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 30%,rgba(255,255,255,.04) 0%,transparent 60%);}
.page-job-listing .banner::after{content:'';position:absolute;inset:0;opacity:.03;background-image:repeating-linear-gradient(45deg,#fff 0px,#fff 1px,transparent 1px,transparent 12px);}
.page-job-listing .banner-badge{display:inline-flex;align-items:center;gap:5px;padding:5px 13px;border-radius:100px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);font-size:9.5px;font-weight:700;color:rgba(255,255,255,.7);letter-spacing:.5px;margin-bottom:12px;position:relative;z-index:1;}
.page-job-listing .banner-title{font-family:'Playfair Display',Georgia,serif;font-size:31px;font-weight:800;color:#fff;line-height:1.15;margin-bottom:6px;position:relative;z-index:1;}
.page-job-listing .banner-title em{font-style:italic;font-weight:400;color:#6EDBA8;}
.page-job-listing .banner-sub{font-size:13px;color:rgba(255,255,255,.5);position:relative;z-index:1;}

/* Tags */
.page-job-listing .tags{display:flex;flex-wrap:wrap;gap:6px;align-items:center;}
.page-job-listing .tag{font-size:11px;font-weight:700;padding:6px 13px;border-radius:100px;border:1px solid rgba(0,0,0,.06);color:#555;background:#fff;display:inline-flex;align-items:center;gap:4px;white-space:nowrap;line-height:1;}
.page-job-listing .tag.gold{background:rgba(184,145,42,.07);border-color:rgba(184,145,42,.18);color:#8C6D34;}
.page-job-listing .tag.green{background:rgba(27,122,78,.06);border-color:rgba(27,122,78,.15);color:#1B7A4E;}
.page-job-listing .tag.michelin{background:#C0392B;color:#fff;border:none;text-transform:uppercase;letter-spacing:.4px;}

/* Static spacing utilities (migrated from inline mockup styles) */
.page-job-listing .mb16{margin-bottom:16px;}
.page-job-listing .mb14{margin-bottom:14px;}
.page-job-listing .mb8{margin-bottom:8px;}
.page-job-listing .tc-av.tc-av-add{background:linear-gradient(135deg,#6B4EBF,#8B6EDF);font-size:18px;}

/* Cards */
.page-job-listing .card{background:#fff;border-radius:14px;border:1px solid rgba(0,0,0,.04);box-shadow:0 2px 12px rgba(0,0,0,.04);overflow:hidden;}
.page-job-listing .card-header{padding:18px 22px 14px;border-bottom:1px solid rgba(0,0,0,.04);}
.page-job-listing .card-label{font-size:10px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;color:#C4A559;margin-bottom:5px;}
.page-job-listing .card-title{font-family:'Playfair Display',serif;font-size:22px;font-weight:800;color:#1a1a1a;letter-spacing:-.3px;}
.page-job-listing .card-body{padding:16px 20px 20px;}

/* Info grid */
.page-job-listing .info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.page-job-listing .info-key{font-size:9px;font-weight:600;color:#bbb;text-transform:uppercase;letter-spacing:.4px;margin-bottom:3px;}
.page-job-listing .info-val{font-size:13px;font-weight:600;color:#1a1a1a;}
.page-job-listing .info-val.gold{color:#C4A559;}
.page-job-listing .info-val.green{color:#1B7A4E;}

/* Description */
.page-job-listing .desc-text{font-size:13px;color:#555;line-height:1.75;}
.page-job-listing .desc-text p{margin-bottom:10px;}
.page-job-listing .desc-text p:last-child{margin-bottom:0;}

/* Section label inside card */
.page-job-listing .s-label{font-size:9.5px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:#C4A559;margin-bottom:8px;margin-top:16px;}
.page-job-listing .s-label:first-child{margin-top:0;}

/* Check-lists (responsabilités / prérequis) */
.page-job-listing .req-check-list{display:flex;flex-direction:column;gap:8px;}
.page-job-listing .rc-item{display:flex;align-items:flex-start;gap:9px;font-size:12.5px;color:#444;line-height:1.55;}
.page-job-listing .rc-ic{width:16px;height:16px;border-radius:50%;background:rgba(184,145,42,.1);color:#A8893C;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;}

/* Profile attributes */
.page-job-listing .attr-tags{display:flex;flex-wrap:wrap;gap:5px;}
.page-job-listing .attr-tag{font-size:11px;font-weight:600;padding:5px 12px;border-radius:100px;background:rgba(27,122,78,.05);border:1px solid rgba(27,122,78,.12);color:#1B7A4E;}

/* Environment tags */
.page-job-listing .env-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:8px;}
.page-job-listing .env-tag{font-size:11px;font-weight:600;padding:6px 12px;border-radius:100px;background:#FAFAFA;border:1px solid rgba(0,0,0,.05);color:#555;display:inline-flex;align-items:center;gap:5px;white-space:nowrap;line-height:1;}
.page-job-listing .env-tag.on{background:rgba(184,145,42,.06);border-color:rgba(184,145,42,.18);color:#8C6D34;}
.page-job-listing .env-tag.michelin{background:#C0392B;color:#fff;border:none;text-transform:uppercase;letter-spacing:.4px;font-weight:600;}
.page-job-listing .env-tag.palace{background:#1C1A17;color:#F5D480;border:none;text-transform:uppercase;letter-spacing:.4px;font-weight:600;}

/* Team */
.page-job-listing .team-card{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;background:#FAFAFA;border:1px solid rgba(0,0,0,.04);}
.page-job-listing .tc-av{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#1a1a1a,#333);display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:13px;font-weight:700;color:rgba(255,255,255,.8);flex-shrink:0;}
.page-job-listing .tc-info{flex:1;}
.page-job-listing .tc-name{font-size:14px;font-weight:700;display:flex;align-items:center;flex-wrap:wrap;}
.page-job-listing .tc-role{font-size:12px;color:#888;margin-top:1px;}
.page-job-listing .chip-michelin{display:inline-flex;align-items:center;gap:4px;padding:7px 15px;border-radius:9999px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;background:#C0392B;color:#fff;line-height:1;margin-left:4px;}
.page-job-listing .chip-palace{display:inline-flex;align-items:center;gap:4px;padding:7px 15px;border-radius:9999px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;background:#1C1A17;color:#F5D480;line-height:1;}

/* ── RIGHT SIDEBAR ── */
.page-job-listing .sidebar{display:flex;flex-direction:column;gap:14px;position:sticky;top:100px;}
.page-job-listing .apply-card{background:#fff;border-radius:14px;border:1px solid rgba(0,0,0,.04);box-shadow:0 2px 12px rgba(0,0,0,.04);padding:20px;}
.page-job-listing .apply-estab{display:flex;align-items:center;gap:10px;margin-bottom:16px;}
.page-job-listing .apply-estab-icon{width:42px;height:42px;border-radius:10px;background:linear-gradient(135deg,#C4A559 0%,#D4BC7A 40%,#E5D4A0 70%,#EFE2B8 100%);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.page-job-listing .apply-estab-name{font-size:14px;font-weight:700;}
.page-job-listing .apply-estab-loc{font-size:11.5px;color:#888;}
.page-job-listing .btn-apply{width:100%;padding:14px;border-radius:10px;font-size:13px;font-weight:800;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.2);position:relative;overflow:hidden;background:linear-gradient(135deg,#C4A559 0%,#D4BC7A 40%,#E5D4A0 70%,#EFE2B8 100%);box-shadow:0 2px 10px rgba(184,145,42,.28);transition:all .25s;letter-spacing:.2px;margin-bottom:8px;white-space:nowrap;display:block;text-align:center;text-decoration:none;}
.page-job-listing .btn-apply::before{content:'';position:absolute;top:0;left:0;right:0;height:45%;background:linear-gradient(180deg,rgba(255,255,255,.5),transparent);border-radius:10px 10px 0 0;pointer-events:none;}
.page-job-listing .btn-apply:hover{transform:translateY(-2px);box-shadow:0 4px 18px rgba(184,145,42,.42);}
.page-job-listing .btn-applied{width:100%;padding:14px;border-radius:10px;font-size:13px;font-weight:800;color:#1B7A4E;background:rgba(27,122,78,.08);border:1.5px solid rgba(27,122,78,.25);margin-bottom:8px;display:flex;align-items:center;justify-content:center;gap:7px;letter-spacing:.2px;}
.page-job-listing .btn-apply-locked{width:100%;padding:14px;border-radius:10px;font-size:13px;font-weight:800;color:#9A7B2E;background:rgba(184,145,42,.08);border:1.5px dashed rgba(184,145,42,.40);margin-bottom:8px;display:flex;align-items:center;justify-content:center;gap:7px;letter-spacing:.2px;cursor:not-allowed;}
.page-job-listing .btn-save{width:100%;padding:11px;border-radius:10px;font-size:11px;font-weight:600;color:#666;background:#fff;border:1.5px solid rgba(0,0,0,.07);transition:all .2s;margin-bottom:10px;display:flex;align-items:center;justify-content:center;gap:6px;}
.page-job-listing .btn-save:hover{border-color:#C4A559;color:#C4A559;transform:translateY(-1px);}
.page-job-listing .btn-save.saved{border-color:#C4A559;color:#C4A559;background:rgba(184,145,42,.06);}
.page-job-listing .btn-save svg{margin:0;}
.page-job-listing .apply-meta{font-size:10.5px;color:#aaa;text-align:center;line-height:1.6;}
.page-job-listing .apply-meta b{color:#C4A559;}
.page-job-listing .pj-preview-note{font-size:12px;color:#8C6D34;background:rgba(196,165,89,.10);border:1px solid rgba(196,165,89,.30);border-radius:10px;padding:12px 14px;text-align:center;font-weight:600;}
.page-job-listing .apply-card form{margin:0;}

/* Match card (Brick 3 — compatibilité IA) */
.page-job-listing .match-card{background:#fff;border-radius:14px;border:1px solid rgba(0,0,0,.04);box-shadow:0 2px 12px rgba(0,0,0,.04);padding:18px;position:relative;}
.page-job-listing .match-title{font-family:'Playfair Display',serif;font-size:17px;font-weight:700;margin-bottom:12px;}
.page-job-listing .match-score{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;background:rgba(27,122,78,.04);border:1px solid rgba(27,122,78,.1);margin-bottom:10px;}
.page-job-listing .match-ring{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:conic-gradient(#1B7A4E 0deg,#2EAA72 300deg,rgba(0,0,0,.04) 300deg);}
.page-job-listing .match-ring-inner{width:34px;height:34px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:14px;font-weight:700;color:#1B7A4E;}
.page-job-listing .match-val{font-size:14px;font-weight:800;color:#1B7A4E;}
.page-job-listing .match-sub{font-size:11px;color:#888;}
.page-job-listing .match-list{display:flex;flex-direction:column;gap:5px;}
.page-job-listing .match-item{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:500;color:#1B7A4E;}
.page-job-listing .match-item .ic{width:16px;height:16px;border-radius:50%;background:rgba(27,122,78,.08);display:flex;align-items:center;justify-content:center;font-size:8px;flex-shrink:0;}

/* Similar */
.page-job-listing .similar-card{background:#fff;border-radius:14px;border:1px solid rgba(0,0,0,.04);box-shadow:0 2px 12px rgba(0,0,0,.04);padding:18px;}
.page-job-listing .sim-title{font-family:'Playfair Display',serif;font-size:17px;font-weight:700;margin-bottom:12px;}
.page-job-listing .sim-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid rgba(0,0,0,.04);cursor:pointer;}
.page-job-listing .sim-item:last-child{border-bottom:none;padding-bottom:0;}
.page-job-listing .sim-item:hover .sim-name{color:#C4A559;}
.page-job-listing .sim-icon{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#C4A559,#E5D4A0);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;}
.page-job-listing .sim-info{flex:1;}
.page-job-listing .sim-name{font-size:12.5px;font-weight:700;color:#1a1a1a;transition:color .15s;}
.page-job-listing .sim-sub{font-size:10.5px;color:#aaa;margin-top:1px;}
.page-job-listing .sim-match{font-size:11px;font-weight:700;color:#C4A559;}

/* Future-brick (Brick 3) annotation on the match card */
.page-job-listing .pj-future{filter:grayscale(.9);opacity:.6;pointer-events:none;}
.page-job-listing .pj-future-badge{position:absolute;top:12px;right:12px;z-index:3;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);pointer-events:auto;white-space:nowrap;}

@media(max-width:780px){
  .page-job-listing .page{grid-template-columns:1fr;}
  .page-job-listing .sidebar{position:static;}
}
