/*
 * public.css — Formulaires publics Pawa Radio Cloud
 * Design SaaS hébergeur radio professionnel — dark theme indigo
 */

/* ═══════════════════════════════════ ROOT ═══════════════════════════════════ */
:root {
  --prc-bg:       #0a0e1a;
  --prc-surface:  #111827;
  --prc-surface2: #1e293b;
  --prc-border:   rgba(99,102,241,.18);
  --prc-border2:  #334155;
  --prc-text:     #f1f5f9;
  --prc-text2:    #94a3b8;
  --prc-text3:    #64748b;
  --prc-accent:   #6366f1;
  --prc-accent2:  #7c3aed;
  --prc-grad:     linear-gradient(135deg,#6366f1,#7c3aed);
  --prc-radius:   14px;
  --prc-rsm:      8px;
  --prc-shadow:   0 8px 40px rgba(0,0,0,.45);
  --prc-inh:      48px;
}

/* ═══════════════════════════ WRAP + CARTE ═══════════════════════════════════ */
.prc-pub-wrap {
  min-height:100vh; padding:40px 16px; background:var(--prc-bg);
  display:flex; flex-direction:column; align-items:center;
}
.prc-pub-center { justify-content:center; }
.prc-pub-register-wrap .prc-pub-card { margin:0 auto; }

.prc-pub-card {
  background:var(--prc-surface); border:1px solid var(--prc-border);
  border-radius:var(--prc-radius); box-shadow:var(--prc-shadow);
  padding:40px 36px; width:100%; color:var(--prc-text);
}
.prc-pub-card-sm   { max-width:460px; }
.prc-pub-card-wide { max-width:780px; }

.prc-pub-card-header { text-align:center; margin-bottom:28px; }
.prc-pub-logo-img    { max-height:52px; margin-bottom:12px; }
.prc-pub-logo-icon   { font-size:38px; margin-bottom:12px; }
.prc-pub-card-title  { margin:0 0 6px; font-size:22px; font-weight:800; color:var(--prc-text); }
.prc-pub-card-sub    { margin:0; font-size:14px; color:var(--prc-text2); }
.prc-pub-card-footer,.prc-pub-footer-link { text-align:center; margin-top:24px; font-size:13px; color:var(--prc-text3); }

/* ═══════════════════════ INDICATEUR D'ÉTAPES ════════════════════════════════ */
.prc-steps { display:flex; align-items:center; justify-content:center; margin-bottom:32px; }
.prc-step  { display:flex; flex-direction:column; align-items:center; gap:4px; min-width:64px; }
.prc-step-num {
  width:34px; height:34px; border-radius:50%;
  background:var(--prc-surface2); border:2px solid var(--prc-border2);
  display:flex; align-items:center; justify-content:center;
  font-size:13px; font-weight:700; color:var(--prc-text3); transition:all .25s;
}
.prc-step-lbl  { font-size:11px; color:var(--prc-text3); white-space:nowrap; transition:color .25s; }
.prc-step-bar  { flex:1; height:2px; background:var(--prc-border2); min-width:20px; max-width:60px; margin-bottom:20px; transition:background .25s; }
.prc-step.prc-step-on .prc-step-num { background:var(--prc-grad); border-color:var(--prc-accent); color:#fff; box-shadow:0 0 0 4px rgba(99,102,241,.2); }
.prc-step.prc-step-on .prc-step-lbl { color:var(--prc-accent); font-weight:600; }
.prc-step.prc-step-done .prc-step-num { background:rgba(99,102,241,.12); border-color:var(--prc-accent); color:var(--prc-accent); }

/* ═══════════════════════ SECTION TITLE ═════════════════════════════════════ */
.prc-sec-title { font-size:16px; font-weight:700; color:var(--prc-text); margin:0 0 20px; display:flex; align-items:center; gap:8px; }
.prc-sec-title i { color:var(--prc-accent); }

/* ═════════════════════════ GRILLE ══════════════════════════════════════════ */
.prc-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.prc-col2 { grid-column:1/-1; }

/* ════════════════════════ CHAMPS ════════════════════════════════════════════ */
.prc-f { display:flex; flex-direction:column; gap:6px; }
.prc-f-row { flex-direction:row; align-items:center; gap:10px; }
.prc-lbl { font-size:13px; font-weight:600; color:var(--prc-text2); display:flex; align-items:center; gap:6px; }
.prc-lbl i { color:var(--prc-accent); font-size:12px; }
.prc-lbl-row { display:flex; align-items:center; justify-content:space-between; }
.prc-req { color:#f87171; font-size:12px; }
.prc-opt { color:var(--prc-text3); font-weight:400; font-size:11px; }

.prc-inp {
  height:var(--prc-inh); background:var(--prc-surface2); border:1.5px solid var(--prc-border2);
  border-radius:var(--prc-rsm); color:var(--prc-text); font-size:14px; padding:0 14px;
  width:100%; box-sizing:border-box; transition:border-color .2s,box-shadow .2s; appearance:none;
}
.prc-inp:focus { outline:none; border-color:var(--prc-accent); box-shadow:0 0 0 3px rgba(99,102,241,.18); }
.prc-inp::placeholder { color:var(--prc-text3); }
.prc-inp-err { border-color:#f87171 !important; }
textarea.prc-inp { height:auto; padding:12px 14px; resize:vertical; min-height:80px; }
select.prc-inp {
  cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236366f1' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 14px center; padding-right:36px;
}

.prc-inp-grp { position:relative; display:flex; align-items:center; }
.prc-inp-grp .prc-inp { width:100%; }
.prc-inp-ico { position:absolute; left:14px; color:var(--prc-text3); font-size:13px; pointer-events:none; z-index:1; }
.prc-inp-ico-pad { padding-left:38px; }
.prc-eye-btn { position:absolute; right:4px; background:none; border:none; color:var(--prc-text3); cursor:pointer; padding:8px 10px; font-size:14px; transition:color .15s; }
.prc-eye-btn:hover { color:var(--prc-accent); }

/* ════════════════════════ CHECKBOX ═════════════════════════════════════════ */
.prc-chk-lbl { display:flex; align-items:flex-start; gap:10px; cursor:pointer; user-select:none; }
.prc-chk-native { position:absolute; opacity:0; width:0; height:0; }
.prc-chk-box { flex-shrink:0; width:20px; height:20px; margin-top:1px; border:2px solid var(--prc-border2); border-radius:5px; background:rgba(255,255,255,.03); transition:all .2s; position:relative; }
.prc-chk-box::after { content:''; display:none; position:absolute; left:5px; top:1px; width:5px; height:9px; border:2px solid #fff; border-top:none; border-left:none; transform:rotate(45deg); }
.prc-chk-native:checked ~ .prc-chk-box { background:var(--prc-grad); border-color:var(--prc-accent); }
.prc-chk-native:checked ~ .prc-chk-box::after { display:block; }
.prc-chk-lbl:hover .prc-chk-box { border-color:var(--prc-accent); }
.prc-chk-text { font-size:13px; color:var(--prc-text2); line-height:1.5; }

/* ════════════════════════ BOUTONS ═══════════════════════════════════════════ */
.prc-btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  height:44px; padding:0 22px; border-radius:var(--prc-rsm);
  font-size:14px; font-weight:600; cursor:pointer; border:none;
  text-decoration:none; transition:all .2s; white-space:nowrap; box-sizing:border-box;
}
.prc-btn-full { width:100%; }
.prc-btn-lg   { height:52px; font-size:15px; border-radius:var(--prc-radius); }
.prc-btn-sm   { height:34px; padding:0 14px; font-size:12px; }
.prc-btn-primary { background:var(--prc-grad); color:#fff; box-shadow:0 4px 16px rgba(99,102,241,.35); }
.prc-btn-primary:hover { filter:brightness(1.1); transform:translateY(-1px); }
.prc-btn-primary:disabled { opacity:.55; cursor:not-allowed; transform:none; filter:none; }
.prc-btn-ghost { background:var(--prc-surface2); border:1.5px solid var(--prc-border2); color:var(--prc-text2); }
.prc-btn-ghost:hover { border-color:var(--prc-accent); color:var(--prc-accent); }
.prc-link-btn { background:none; border:none; color:var(--prc-accent); cursor:pointer; font-size:13px; text-decoration:underline; text-underline-offset:3px; padding:2px 0; }
.prc-link-btn:hover { color:var(--prc-accent2); }

/* ════════════════════════ MESSAGES ═════════════════════════════════════════ */
.prc-pub-flash { padding:12px 16px; border-radius:var(--prc-rsm); font-size:13px; font-weight:500; margin-bottom:20px; display:flex; align-items:flex-start; gap:8px; }
.prc-pub-flash-success { background:rgba(74,222,128,.1); border:1px solid rgba(74,222,128,.3); color:#4ade80; }
.prc-pub-flash-error   { background:rgba(248,113,113,.1); border:1px solid rgba(248,113,113,.3); color:#f87171; }
.prc-ferr { font-size:12px; color:#f87171; display:block; margin-top:2px; }
.prc-hint { font-size:12px; color:var(--prc-text3); }

/* ══════════════════════ FORCE MOT DE PASSE ══════════════════════════════════ */
.prc-pw-bar-wrap { height:4px; background:var(--prc-surface2); border-radius:4px; margin-top:6px; overflow:hidden; }
.prc-pw-bar { height:100%; width:0; border-radius:4px; transition:width .3s,background .3s; }

/* ═══════════════════════ LOGO UPLOAD ═══════════════════════════════════════ */
.prc-logo-upload { display:flex; align-items:flex-start; gap:14px; }
.prc-logo-preview { width:72px; height:72px; border-radius:var(--prc-rsm); border:1.5px dashed var(--prc-border2); overflow:hidden; flex-shrink:0; display:flex; align-items:center; justify-content:center; background:var(--prc-surface2); font-size:26px; }
.prc-logo-preview img { width:100%; height:100%; object-fit:cover; }
.prc-logo-actions { display:flex; flex-direction:column; gap:6px; align-items:flex-start; }
.prc-file-name { font-size:11px; color:var(--prc-text3); }

/* ═══════════════════════ RÉCAP PLAN ════════════════════════════════════════ */
.prc-plan-recap { margin-top:10px; padding:12px 16px; background:rgba(99,102,241,.07); border:1px solid rgba(99,102,241,.22); border-radius:var(--prc-rsm); }
.prc-plan-feat-mini { margin:0; padding:0; list-style:none; display:flex; flex-wrap:wrap; gap:6px 16px; font-size:12px; color:#c7d2fe; }
.prc-yes { color:#4ade80; }
.prc-no  { color:#f87171; }

/* ═══════════════════════════ OTP ════════════════════════════════════════════ */
.prc-otp-wrap { text-align:center; padding:8px 0 16px; }
.prc-otp-icon { font-size:48px; }
.prc-otp-sub  { font-size:14px; color:var(--prc-text2); line-height:1.6; margin:8px 0 24px; }
.prc-otp-inputs { display:flex; justify-content:center; gap:10px; margin-bottom:28px; }
.prc-otp-d {
  width:50px; height:58px; text-align:center; font-size:26px; font-weight:800;
  font-family:monospace; background:var(--prc-surface2); border:2px solid var(--prc-border2);
  border-radius:var(--prc-rsm); color:var(--prc-text); caret-color:var(--prc-accent);
  transition:border-color .2s,box-shadow .2s; -moz-appearance:textfield;
}
.prc-otp-d::-webkit-outer-spin-button,.prc-otp-d::-webkit-inner-spin-button { -webkit-appearance:none; }
.prc-otp-d:focus { outline:none; border-color:var(--prc-accent); box-shadow:0 0 0 3px rgba(99,102,241,.2); }
.prc-otp-d.prc-otp-ok  { border-color:rgba(99,102,241,.5); color:var(--prc-accent); }
.prc-otp-d.prc-otp-err { border-color:#f87171; animation:prc-shake .3s; }
@keyframes prc-shake { 0%,100%{transform:translateX(0)} 25%{transform:translateX(-4px)} 75%{transform:translateX(4px)} }
.prc-otp-resend-row { display:flex; align-items:center; justify-content:center; gap:10px; margin-top:20px; font-size:13px; color:var(--prc-text3); }
.prc-otp-timer { margin-top:12px; font-size:12px; color:var(--prc-text3); display:flex; align-items:center; justify-content:center; gap:6px; }
#r-timer,#rp-timer { font-weight:700; color:var(--prc-text2); }

/* ════════════════════ NAVIGATION ÉTAPES ════════════════════════════════════ */
.prc-step-nav { display:flex; align-items:center; justify-content:space-between; margin-top:28px; padding-top:20px; border-top:1px solid var(--prc-border); }

/* ═════════════════════════ LIENS ════════════════════════════════════════════ */
.prc-link-strong { color:var(--prc-accent); font-weight:600; text-decoration:none; transition:color .15s; }
.prc-link-strong:hover { color:var(--prc-accent2); text-decoration:underline; }
.prc-link-xs { font-size:12px; color:var(--prc-text3); text-decoration:none; transition:color .15s; }
.prc-link-xs:hover { color:var(--prc-accent); }

/* ═════════════════════ PLANS TARIFAIRES ════════════════════════════════════ */
.prc-pub-trial-banner { text-align:center; padding:12px 20px; background:rgba(99,102,241,.1); border:1px solid rgba(99,102,241,.25); border-radius:var(--prc-rsm); /*color:#a5b4fc;*/ font-size:14px; margin-bottom:32px; }
.prc-pub-plans-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:20px; }
.prc-pub-plan-card { background:var(--prc-surface); border:1.5px solid var(--prc-border); border-radius:var(--prc-radius); padding:28px; display:flex; flex-direction:column; gap:16px; position:relative; transition:border-color .2s,transform .2s; }
.prc-pub-plan-card:hover { border-color:var(--prc-accent); transform:translateY(-2px); }
.prc-pub-plan-popular { border-color:var(--prc-accent); box-shadow:0 0 0 3px rgba(99,102,241,.15); }
.prc-pub-popular-badge { position:absolute; top:-13px; left:50%; transform:translateX(-50%); background:var(--prc-grad); color:#fff; font-size:11px; font-weight:700; padding:4px 14px; border-radius:20px; white-space:nowrap; }
.prc-pub-plan-header h3 { color: #ffffff; margin:0 0 4px; font-size:18px; font-weight:700; }
.prc-pub-plan-genre { font-size:12px; color:var(--prc-text3); }
.prc-pub-plan-header p { margin:6px 0 0; font-size:13px; color:#3cff00; }
.prc-pub-plan-price { font-size:28px; font-weight:800; color:var(--prc-accent); }
.prc-pub-plan-price small { font-size:13px; font-weight:400; color:var(--prc-text3); }
.prc-pub-plan-features { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:8px; flex:1; }
.prc-pub-plan-features li { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--prc-text2); }
.prc-pub-plan-features li i { color:var(--prc-accent); width:16px; }

/* ════════════════════════ RESPONSIVE ═══════════════════════════════════════ */
@media(max-width:600px){
  .prc-pub-card { padding:24px 16px; }
  .prc-grid { grid-template-columns:1fr; }
  .prc-col2 { grid-column:1; }
  .prc-otp-d { width:40px; height:48px; font-size:20px; }
  .prc-otp-inputs { gap:7px; }
  .prc-step-lbl { display:none; }
  .prc-step-bar { min-width:14px; max-width:28px; }
}

/* ════════════════ COMPAT anciennes classes (existant) ═══════════════════════ */
.prc-pub-form-card { background:var(--prc-surface); border:1px solid var(--prc-border); border-radius:var(--prc-radius); padding:36px; color:var(--prc-text); }
.prc-pub-btn { display:inline-flex; align-items:center; gap:8px; padding:0 20px; height:44px; border-radius:var(--prc-rsm); font-weight:600; font-size:14px; cursor:pointer; text-decoration:none; border:none; transition:all .2s; }
.prc-pub-btn-primary { background:var(--prc-grad); color:#fff; box-shadow:0 4px 16px rgba(99,102,241,.3); }
.prc-pub-btn-outline { background:var(--prc-surface2); border:1.5px solid var(--prc-border2); color:var(--prc-text2); }
.prc-pub-btn-full { width:100%; justify-content:center; }
.prc-pub-input { height:var(--prc-inh); background:var(--prc-surface2); border:1.5px solid var(--prc-border2); border-radius:var(--prc-rsm); color:var(--prc-text); font-size:14px; padding:0 14px; width:100%; box-sizing:border-box; transition:border-color .2s; }
.prc-pub-input:focus { outline:none; border-color:var(--prc-accent); box-shadow:0 0 0 3px rgba(99,102,241,.15); }
.prc-pub-alert { padding:12px 16px; border-radius:var(--prc-rsm); font-size:13px; margin-bottom:16px; }
.prc-pub-alert-error { background:rgba(248,113,113,.1); border:1px solid rgba(248,113,113,.3); color:#f87171; }
.prc-pub-alert-success { background:rgba(74,222,128,.1); border:1px solid rgba(74,222,128,.3); color:#4ade80; }
.prc-pub-link { color:var(--prc-accent); text-decoration:none; }
.prc-pub-link-strong { color:var(--prc-accent); font-weight:600; text-decoration:none; }