/* monVFX — Brief projet — styles namespacés sous .vfx-brief-wrap
   pour ne pas entrer en conflit avec le thème WordPress actif. */

.vfx-brief-wrap{
  --bg:#232323;
  --surface:#2a2a2a;
  --surface-2:#303030;
  --line: rgba(245,245,243,0.10);
  --line-strong: rgba(245,245,243,0.20);
  --text:#F5F4F1;
  --text-dim: rgba(245,244,241,0.58);
  --text-faint: rgba(245,244,241,0.34);
  --accent:#FF6B1A;
  --accent-dim: rgba(255,107,26,0.14);
  --danger:#FF6B5E;
  --radius: 10px;
  --font-display:'Montserrat', sans-serif;
  --font-body:'Open Sans', sans-serif;
  --font-mono:'IBM Plex Mono', monospace;

  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  padding:56px 20px 80px;
  opacity:0;
  transition:opacity .35s ease;
  text-transform: none;
  background-image: url("https://black-cog.com/wp-content/uploads/vfx-briefs/vfx_banner_project.jpg");
  background-repeat: no-repeat;
  background-size: 100%;
}
.vfx-brief-wrap.is-ready{ opacity:1; }
.vfx-brief-wrap *{ box-sizing:border-box; }
.vfx-brief-wrap ::selection{ background:var(--accent); color:#161311; }
.vfx-brief-wrap a{ color:var(--accent); }

.vfx-brief-wrap .vfx-inner{ max-width:760px; margin:0 auto; }

.vfx-brief-wrap .masthead{
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:24px; gap:16px;
}
.vfx-brief-wrap .brand{
  font-family:var(--font-display); font-weight:700; font-size:15px;
  letter-spacing:0.08em; text-transform:none;
  display:flex; align-items:center; gap:10px; color:var(--text);
}
.vfx-brief-wrap .brand .dot{ width:8px;height:8px;border-radius:50%; background:var(--accent); box-shadow:0 0 12px var(--accent); }

.vfx-brief-wrap .lang-switch{
  display:flex; align-items:center; gap:6px;
  font-family:var(--font-mono); font-size:12px; letter-spacing:0.05em;
}
.vfx-brief-wrap .lang-btn{
  background:none; border:none; cursor:pointer; padding:4px 2px;
  color:var(--text-faint); font-family:var(--font-mono); font-size:12px;
  letter-spacing:0.05em; transition:color .15s;
}
.vfx-brief-wrap .lang-btn:hover{ color:var(--text-dim); }
.vfx-brief-wrap .lang-btn.active{ color:var(--accent); font-weight:700; cursor:default; }
.vfx-brief-wrap .lang-sep{ color:var(--text-faint); }

.vfx-brief-wrap .eyebrow{ font-family:var(--font-mono); font-size:12px; letter-spacing:0.06em; color:var(--text-faint); text-transform:none; margin-bottom:6px; }

/* ---- visual banner placeholder ---- */
.vfx-brief-wrap .hero-banner{
  width:100%;
  aspect-ratio:16/5;
  border-radius:var(--radius);
  border:1px dashed var(--line-strong);
  background:
    linear-gradient(135deg, rgba(255,107,26,0.06), rgba(255,107,26,0) 60%),
    var(--surface);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:32px;
  color:var(--text-faint);
  font-family:var(--font-mono);
  font-size:12px;
  letter-spacing:0.08em;
  text-transform:none;
  overflow:hidden;
}
@media (max-width:600px){ .vfx-brief-wrap .hero-banner{ aspect-ratio:16/9; } }

.vfx-brief-wrap h1{
  font-family:var(--font-display); font-weight:700;
  font-size:clamp(26px,4vw,34px); letter-spacing:-0.01em; margin:6px 0 8px; color:var(--text);
}
.vfx-brief-wrap .lede{ color:var(--text-dim); font-size:15px; max-width:52ch; margin:0 0 36px; }

.vfx-brief-wrap .timecode-bar{ margin-bottom:36px; }
.vfx-brief-wrap .timecode-row{ display:flex; align-items:baseline; justify-content:space-between; margin-bottom:10px; font-family:var(--font-mono); }
.vfx-brief-wrap .timecode{ font-size:13px; letter-spacing:0.08em; color:var(--text); }
.vfx-brief-wrap .timecode .sep{ color:var(--text-faint); }
.vfx-brief-wrap .timecode .current{ color:var(--accent); }
.vfx-brief-wrap .step-label{ font-size:12px; color:var(--text-dim); letter-spacing:0.04em; }
.vfx-brief-wrap .scrub{ position:relative; height:3px; background:var(--line); border-radius:2px; overflow:hidden; }
.vfx-brief-wrap .scrub-fill{ position:absolute; inset:0 auto 0 0; width:20%; background:var(--accent); transition:width .45s cubic-bezier(.65,0,.35,1); }
.vfx-brief-wrap .ticks{ display:flex; justify-content:space-between; margin-top:8px; }
.vfx-brief-wrap .tick{ font-family:var(--font-mono); font-size:10px; color:var(--text-faint); letter-spacing:0.05em; }
.vfx-brief-wrap .tick.active{ color:var(--accent); }

.vfx-brief-wrap .card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:36px; }
@media (max-width:600px){
  .vfx-brief-wrap .card{ padding:24px; }
  .vfx-brief-wrap{ padding:32px 14px 60px; }
}

.vfx-brief-wrap .step{ display:none; animation:vfxFade .4s ease; }
.vfx-brief-wrap .step.active{ display:block; }
@keyframes vfxFade{ from{ opacity:0; transform:translateY(6px);} to{ opacity:1; transform:translateY(0);} }

.vfx-brief-wrap .step h2{ font-family:var(--font-display); font-weight:700; font-size:21px; margin:0 0 4px; color:var(--text); }
.vfx-brief-wrap .step .sub{ color:var(--text-dim); font-size:13.5px; margin:0 0 28px; }

.vfx-brief-wrap .field{ margin-bottom:22px; }
.vfx-brief-wrap .field label{
  display:block; font-size:12.5px; font-weight:600; letter-spacing:0.02em;
  color:var(--text-dim); margin-bottom:8px; text-transform: none;
}
.vfx-brief-wrap .field .hint{ font-size:12px; color:var(--text-faint); margin-top:6px; }

.vfx-brief-wrap input[type=text],
.vfx-brief-wrap input[type=email],
.vfx-brief-wrap input[type=tel],
.vfx-brief-wrap input[type=number],
.vfx-brief-wrap input[type=date],
.vfx-brief-wrap textarea,
.vfx-brief-wrap select{
  width:100%; background:var(--surface-2); border:1px solid var(--line); color:var(--text);
  font-family:var(--font-body); font-size:14.5px; padding:12px 14px; border-radius:8px;
  outline:none; transition:border-color .2s, box-shadow .2s;
}
.vfx-brief-wrap textarea{ resize:vertical; min-height:84px; }
.vfx-brief-wrap input::placeholder, .vfx-brief-wrap textarea::placeholder{ color:var(--text-faint); }
.vfx-brief-wrap input:focus, .vfx-brief-wrap textarea:focus, .vfx-brief-wrap select:focus{
  border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-dim);
}

.vfx-brief-wrap .grid-cards{ display:grid; grid-template-columns:repeat(auto-fit, minmax(150px,1fr)); gap:10px; }
.vfx-brief-wrap .choice-card{
  border:1px solid var(--line); background:var(--surface-2); border-radius:8px;
  padding:14px 14px; cursor:pointer; font-size:13.5px; color:var(--text-dim);
  transition:border-color .15s, color .15s, background .15s; user-select:none;
}
.vfx-brief-wrap .choice-card:hover{ border-color:var(--line-strong); color:var(--text); }
.vfx-brief-wrap .choice-card.selected{ border-color:var(--accent); background:var(--accent-dim); color:var(--text); }
.vfx-brief-wrap .choice-card .name{ font-weight:600; display:block; }

.vfx-brief-wrap .budget-value{ font-family:var(--font-mono); font-size:22px; color:var(--accent); margin-bottom:6px; letter-spacing:0.01em; }
.vfx-brief-wrap .budget-value .between{ color:var(--text-faint); font-size:15px; margin:0 8px; }
.vfx-brief-wrap .range-wrap{ position:relative; height:36px; margin-top:14px; }
.vfx-brief-wrap .range-track{ position:absolute; top:16px; left:0; right:0; height:3px; background:var(--line); border-radius:2px; }
.vfx-brief-wrap .range-fill{ position:absolute; top:16px; height:3px; background:var(--accent); border-radius:2px; }
.vfx-brief-wrap .range-mid-marker{
  position:absolute; top:10px; left:50%; width:1px; height:16px;
  background:var(--line-strong); transform:translateX(-0.5px);
}
.vfx-brief-wrap .range-mid-label{
  position:absolute; top:30px; left:50%; transform:translateX(-50%);
  font-family:var(--font-mono); font-size:10px; color:var(--text-faint);
  letter-spacing:0.04em; white-space:nowrap;
}
.vfx-brief-wrap input[type=range]{
  -webkit-appearance:none; appearance:none; position:absolute; top:0; left:0; width:100%; height:36px;
  background:transparent; pointer-events:none; margin:0;
}
.vfx-brief-wrap input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none; pointer-events:all; width:18px;height:18px; border-radius:50%;
  background:var(--text); border:3px solid var(--accent); cursor:grab; margin-top:8px;
  box-shadow:0 2px 6px rgba(0,0,0,0.4);
}
.vfx-brief-wrap input[type=range]::-moz-range-thumb{
  pointer-events:all; width:16px;height:16px; border-radius:50%;
  background:var(--text); border:3px solid var(--accent); cursor:grab; box-shadow:0 2px 6px rgba(0,0,0,0.4);
}
.vfx-brief-wrap input[type=range]::-webkit-slider-runnable-track{ background:transparent; }
.vfx-brief-wrap input[type=range]::-moz-range-track{ background:transparent; }

.vfx-brief-wrap .checkbox-row{ display:flex; align-items:center; gap:10px; margin-top:22px; font-size:13px; color:var(--text-dim); }
.vfx-brief-wrap .checkbox-row input{ width:16px;height:16px; accent-color:var(--accent); }

.vfx-brief-wrap .date-grid{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media (max-width:520px){ .vfx-brief-wrap .date-grid{ grid-template-columns:1fr; } }

.vfx-brief-wrap .vfx-type{ border:1px solid var(--line); border-radius:8px; margin-bottom:12px; overflow:hidden; background:var(--surface-2); }
.vfx-brief-wrap .vfx-type-head{ display:flex; align-items:center; justify-content:space-between; padding:14px 16px; cursor:pointer; }
.vfx-brief-wrap .vfx-type-head .left{ display:flex; align-items:center; gap:12px; }
.vfx-brief-wrap .vfx-type-head .switch{ width:34px; height:20px; border-radius:20px; background:var(--line-strong); position:relative; flex:none; transition:background .2s; }
.vfx-brief-wrap .vfx-type-head .switch::after{ content:''; position:absolute; top:2px; left:2px; width:16px; height:16px; border-radius:50%; background:var(--text); transition:transform .2s; }
.vfx-brief-wrap .vfx-type.on .switch{ background:var(--accent); }
.vfx-brief-wrap .vfx-type.on .switch::after{ transform:translateX(14px); background:#161311; }
.vfx-brief-wrap .vfx-type-title{ font-weight:600; font-size:14.5px; color:var(--text); }
.vfx-brief-wrap .vfx-type-desc{ font-size:12px; color:var(--text-faint); }
.vfx-brief-wrap .vfx-type-body{ max-height:0; overflow:hidden; transition:max-height .3s ease; border-top:1px solid transparent; }
.vfx-brief-wrap .vfx-type.on .vfx-type-body{ max-height:340px; border-top-color:var(--line); }
.vfx-brief-wrap .vfx-type-body-inner{ padding:16px; }

.vfx-brief-wrap .dropzone{
  border:1.5px dashed var(--line-strong); border-radius:8px; padding:18px; text-align:center;
  font-size:12.5px; color:var(--text-faint); cursor:pointer; transition:border-color .15s, background .15s; margin-top:10px;
}
.vfx-brief-wrap .dropzone:hover, .vfx-brief-wrap .dropzone.drag{ border-color:var(--accent); background:var(--accent-dim); color:var(--text-dim); }
.vfx-brief-wrap .file-list{ margin-top:8px; display:flex; flex-wrap:wrap; gap:6px; }
.vfx-brief-wrap .file-chip{
  font-family:var(--font-mono); font-size:11px; background:var(--surface); border:1px solid var(--line);
  padding:5px 8px; border-radius:6px; display:flex; align-items:center; gap:6px; color:var(--text-dim);
}
.vfx-brief-wrap .file-chip button{ background:none; border:none; color:var(--text-faint); cursor:pointer; font-size:13px; line-height:1; padding:0; }
.vfx-brief-wrap .file-chip button:hover{ color:var(--danger); }

.vfx-brief-wrap .summary-block{ border:1px solid var(--line); border-radius:8px; padding:16px 18px; margin-bottom:12px; background:var(--surface-2); }
.vfx-brief-wrap .summary-block h3{ font-family:var(--font-mono); font-size:11px; letter-spacing:0.06em; text-transform:none; color:var(--accent); margin:0 0 10px; }
.vfx-brief-wrap .summary-row{ display:flex; justify-content:space-between; gap:16px; font-size:13.5px; padding:5px 0; border-bottom:1px dashed var(--line); }
.vfx-brief-wrap .summary-row:last-child{ border-bottom:none; }
.vfx-brief-wrap .summary-row .k{ color:var(--text-dim); }
.vfx-brief-wrap .summary-row .v{ text-align:right; color:var(--text); }

.vfx-brief-wrap .nav-row{ display:flex; align-items:center; justify-content:space-between; margin-top:32px; gap:12px; }
.vfx-brief-wrap .btn{
  font-family:var(--font-body); font-weight:600; font-size:13.5px; padding:12px 22px; border-radius:8px;
  border:1px solid var(--line-strong); background:transparent; color:var(--text); cursor:pointer;
  transition:border-color .15s, background .15s, transform .1s, opacity .15s;
}
.vfx-brief-wrap .btn:hover{ border-color:var(--text-dim); }
.vfx-brief-wrap .btn:active{ transform:scale(0.98); }
.vfx-brief-wrap .btn.primary{ background:var(--accent); border-color:var(--accent); color:#1a1310; }
.vfx-brief-wrap .btn.primary:hover{ opacity:0.88; }
.vfx-brief-wrap .btn:disabled{ opacity:0.35; cursor:not-allowed; }
.vfx-brief-wrap .btn.ghost{ border-color:transparent; color:var(--text-dim); padding:12px 10px; }

.vfx-brief-wrap .error-msg{ font-size:12px; color:var(--danger); margin-top:6px; display:none; }
.vfx-brief-wrap .field.has-error input, .vfx-brief-wrap .field.has-error textarea{ border-color:var(--danger); }
.vfx-brief-wrap .field.has-error .error-msg{ display:block; }

.vfx-brief-wrap .success{ text-align:center; padding:40px 10px; }
.vfx-brief-wrap .success .icon{
  width:56px;height:56px;border-radius:50%; background:var(--accent-dim); border:1px solid var(--accent);
  display:flex; align-items:center; justify-content:center; margin:0 auto 20px;
}
.vfx-brief-wrap .success h2{ font-family:var(--font-display); font-size:22px; margin-bottom:8px; color:var(--text); }
.vfx-brief-wrap .success p{ color:var(--text-dim); font-size:14px; max-width:40ch; margin:0 auto; }

.vfx-brief-wrap .form-error-banner{
  display:none; background:rgba(255,107,94,0.1); border:1px solid var(--danger);
  color:var(--text); font-size:13px; padding:12px 14px; border-radius:8px; margin-bottom:20px;
}

.vfx-brief-wrap .honeypot{ position:absolute; left:-9999px; opacity:0; height:0; overflow:hidden; }
.vfx-brief-wrap fieldset{ border:none; padding:0; margin:0; }
