/* ════════════════════════════════════════
   YBN FRANCE — Global Stylesheet
   Style inspiré SouthPark RP (sombre, violet-gris, accents rouge/orange)
════════════════════════════════════════ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}

:root{
  --acc:#E8340A;
  --acc2:#FF6B1A;
  --grad:linear-gradient(135deg,#E8340A,#FF6B1A);
  --bg:#18121f;
  --bg2:#110e18;
  --bg3:#0d0a13;
  --nav:rgba(11,9,17,.96);
  --card:rgba(255,255,255,.04);
  --card2:rgba(255,255,255,.07);
  --border:rgba(255,255,255,.07);
  --borderacc:rgba(232,52,10,.32);
  --text:#fff;
  --muted:rgba(255,255,255,.5);
  --muted2:rgba(255,255,255,.28);
  --success:#22c55e;
  --danger:#ef4444;
  --warn:#f59e0b;
  --info:#3b82f6;
}

body{font-family:'Montserrat',sans-serif;background:var(--bg2);color:var(--text);overflow-x:hidden;min-height:100vh;}

::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg3)}
::-webkit-scrollbar-thumb{background:var(--borderacc);border-radius:3px}

/* ── UTILITY ── */
.hidden{display:none!important}
.grad-text{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.fadeup{animation:fadeUp .6s cubic-bezier(.22,1,.36,1) both}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(1.35)}}

/* Ripple */
.rip{position:absolute;border-radius:50%;background:rgba(255,255,255,.28);width:0;height:0;transform:translate(-50%,-50%);animation:rpl .55s ease-out forwards;pointer-events:none}
@keyframes rpl{to{width:280px;height:280px;opacity:0}}

/* ── NAV ── */
.ybn-nav{
  position:fixed;top:0;left:0;right:0;z-index:600;
  height:60px;display:flex;align-items:center;justify-content:space-between;
  padding:0 2.5rem;
  background:var(--nav);
  backdrop-filter:blur(22px);
  border-bottom:1px solid var(--border);
}
.nav-brand{display:flex;align-items:center;gap:10px;cursor:pointer;text-decoration:none;font-weight:800;font-size:17px;letter-spacing:.4px;color:var(--text);}
.nav-logobox{width:30px;height:30px;border-radius:7px;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:900;flex-shrink:0;}
.nav-links{display:flex;gap:1.6rem;list-style:none;}
.nav-links a{color:var(--muted);font-size:13.5px;font-weight:600;text-decoration:none;transition:color .2s;letter-spacing:.3px;cursor:pointer;}
.nav-links a:hover,.nav-links a.active{color:#fff;}
.nav-links a.active{border-bottom:2px solid var(--acc);padding-bottom:2px;}
.nav-right{display:flex;align-items:center;gap:8px;}
.nav-user{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;}
.nav-avatar{width:30px;height:30px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;border:2px solid var(--borderacc);}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:7px;padding:0 18px;height:38px;border-radius:8px;font-family:'Montserrat',sans-serif;font-size:13px;font-weight:700;border:none;cursor:pointer;position:relative;overflow:hidden;transition:transform .15s,box-shadow .25s;letter-spacing:.3px;text-decoration:none;white-space:nowrap;vertical-align:middle;}
.btn::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,0);transition:background .2s}
.btn:hover::after{background:rgba(255,255,255,.09)}
.btn:active{transform:scale(.96)}
.btn-acc{background:var(--grad);color:#fff}
.btn-acc:hover{box-shadow:0 0 24px rgba(232,52,10,.55);transform:translateY(-1px)}
.btn-disc{background:#5865F2;color:#fff}
.btn-disc:hover{box-shadow:0 0 20px rgba(88,101,242,.48);transform:translateY(-1px)}
.btn-ghost{background:rgba(255,255,255,.06);border:1px solid var(--border);color:var(--text)}
.btn-ghost:hover{border-color:rgba(255,255,255,.24);background:rgba(255,255,255,.1)}
.btn-danger{background:rgba(239,68,68,.14);border:1px solid rgba(239,68,68,.3);color:#f87171}
.btn-danger:hover{background:rgba(239,68,68,.24)}
.btn-success{background:rgba(34,197,94,.14);border:1px solid rgba(34,197,94,.3);color:#4ade80}
.btn-success:hover{background:rgba(34,197,94,.24)}
.btn-warn{background:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.28);color:#fbbf24}
.btn-lg{height:50px;font-size:15px;padding:0 32px;border-radius:12px}
.btn-xl{height:56px;font-size:16px;padding:0 44px;border-radius:14px}
.btn-block{width:100%;justify-content:center}

/* ── NOTIFICATIONS ── */
.notif-wrap{position:fixed;top:72px;right:18px;z-index:900;display:flex;flex-direction:column;gap:8px;}
.notif{background:#1c1426;border:1px solid var(--border);border-radius:10px;padding:.8rem 1.1rem;min-width:270px;max-width:340px;display:flex;align-items:center;gap:10px;font-size:13.5px;font-weight:600;animation:slideIn .3s ease;box-shadow:0 8px 28px rgba(0,0,0,.55);}
@keyframes slideIn{from{opacity:0;transform:translateX(36px)}to{opacity:1;transform:translateX(0)}}
.notif.ok{border-left:3px solid var(--success);}
.notif.err{border-left:3px solid var(--danger);}
.notif.inf{border-left:3px solid var(--info);}
.notif.ok i{color:var(--success)}
.notif.err i{color:var(--danger)}
.notif.inf i{color:var(--info)}

/* ── MODAL ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.78);z-index:700;display:none;align-items:center;justify-content:center;padding:1rem;}
.modal-overlay.open{display:flex;}
.modal{background:#1a1224;border:1px solid var(--borderacc);border-radius:16px;padding:2rem;max-width:480px;width:100%;max-height:88vh;overflow-y:auto;animation:fadeUp .3s ease;}
.modal h3{font-size:18px;font-weight:800;margin-bottom:.4rem;}
.modal p{font-size:13.5px;color:var(--muted);font-family:'Inter',sans-serif;line-height:1.65;margin-bottom:1.25rem;}
.modal-footer{display:flex;gap:8px;justify-content:flex-end;}
.modal-textarea{background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:8px;padding:.7rem .9rem;color:var(--text);font-family:'Montserrat',sans-serif;font-size:13px;font-weight:500;outline:none;width:100%;resize:vertical;min-height:90px;margin-bottom:1rem;}
.modal-textarea:focus{border-color:var(--borderacc);}

/* ── PAGE SHELL ── */
.page-content{padding-top:60px;min-height:100vh;}

/* ── PAGE HERO (shared) ── */
.page-hero{padding:4rem 3rem 2.5rem;text-align:center;border-bottom:1px solid var(--border);background:radial-gradient(ellipse 65% 45% at 50% 0%,rgba(232,52,10,.09) 0%,transparent 70%);}
.page-hero .eyebrow{font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--acc2);margin-bottom:.6rem;}
.page-hero h1{font-size:clamp(34px,6vw,64px);font-weight:900;line-height:1;}
.page-hero p{color:var(--muted);font-family:'Inter',sans-serif;font-size:15px;max-width:540px;margin:.75rem auto 0;line-height:1.65;}

/* ── SHARED COMPONENTS ── */
.eyebrow{font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--acc2);margin-bottom:.6rem;}
.section-title{font-size:clamp(28px,5vw,50px);font-weight:900;line-height:1;margin-bottom:.5rem;}
.section-sub{font-size:14px;color:var(--muted);max-width:460px;line-height:1.7;margin-bottom:2.25rem;font-family:'Inter',sans-serif;font-weight:300;}

.rule-item{display:flex;gap:12px;align-items:flex-start;padding:1rem 1.25rem;background:var(--card);border:1px solid var(--border);border-radius:10px;margin-bottom:8px;transition:all .2s;}
.rule-item:hover{border-color:var(--borderacc);background:rgba(232,52,10,.05);}
.rule-icon{width:36px;height:36px;border-radius:8px;background:rgba(232,52,10,.1);display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--acc2);flex-shrink:0;}
.rule-t{font-size:14px;font-weight:700;margin-bottom:3px;}
.rule-d{font-size:12.5px;color:var(--muted);line-height:1.6;font-family:'Inter',sans-serif;font-weight:300;}

.alert{display:flex;gap:10px;align-items:flex-start;border-radius:10px;padding:.9rem 1.1rem;margin:1rem 0;font-family:'Inter',sans-serif;font-size:13px;line-height:1.6;}
.alert i{flex-shrink:0;margin-top:1px;}
.alert.danger{background:rgba(239,68,68,.09);border:1px solid rgba(239,68,68,.22);color:#fca5a5;}
.alert.warn{background:rgba(245,158,11,.07);border:1px solid rgba(245,158,11,.2);color:#fde68a;}
.alert.info{background:rgba(59,130,246,.07);border:1px solid rgba(59,130,246,.2);color:#93c5fd;}
.alert.ok{background:rgba(34,197,94,.07);border:1px solid rgba(34,197,94,.2);color:#86efac;}

/* ── FORM ── */
.form-section{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:1.5rem;margin-bottom:14px;}
.form-section-title{font-size:13.5px;font-weight:700;letter-spacing:.4px;margin-bottom:1rem;display:flex;align-items:center;gap:8px;color:var(--acc2);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px;}
.form-row.full{grid-template-columns:1fr;}
.form-group{display:flex;flex-direction:column;gap:5px;}
.form-label{font-size:11.5px;font-weight:700;color:var(--muted);letter-spacing:.6px;text-transform:uppercase;}
.form-input,.form-select,.form-textarea{background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:8px;padding:.68rem .9rem;color:var(--text);font-family:'Montserrat',sans-serif;font-size:13px;font-weight:500;transition:border-color .2s;outline:none;width:100%;}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--borderacc);}
.form-input::placeholder,.form-textarea::placeholder{color:var(--muted2);}
.form-textarea{resize:vertical;min-height:100px;line-height:1.6;}
.form-select option{background:#1a1520;color:#fff;}
.char-count{font-size:10px;color:var(--muted2);text-align:right;margin-top:2px;}
.form-check{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-size:13px;font-family:'Inter',sans-serif;line-height:1.6;margin-bottom:8px;}
.form-check input[type=checkbox]{margin-top:3px;accent-color:var(--acc);width:15px;height:15px;flex-shrink:0;}

/* ── STATUS BADGES ── */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:100px;font-size:11px;font-weight:700;}
.badge-pending{background:rgba(245,158,11,.12);color:#fbbf24;border:1px solid rgba(245,158,11,.25);}
.badge-accepted{background:rgba(34,197,94,.12);color:#4ade80;border:1px solid rgba(34,197,94,.25);}
.badge-refused{background:rgba(239,68,68,.12);color:#f87171;border:1px solid rgba(239,68,68,.25);}
.badge-staff{background:var(--grad);color:#fff;font-size:10px;padding:2px 8px;}

/* ── STEP ROWS ── */
.step-row{display:flex;gap:11px;align-items:flex-start;margin-bottom:10px;font-family:'Inter',sans-serif;font-size:13px;line-height:1.5;}
.step-n{width:24px;height:24px;flex-shrink:0;border-radius:50%;background:var(--grad);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;}

/* ── FOOTER ── */
.ybn-footer{padding:2rem 3rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;border-top:1px solid var(--border);}
.foot-brand{display:flex;align-items:center;gap:9px;font-weight:800;font-size:15px;}
.foot-copy{font-size:11px;color:var(--muted);margin-top:3px;font-family:'Inter',sans-serif;}
.foot-links{display:flex;gap:1.3rem;list-style:none;}
.foot-links a{color:var(--muted);font-size:12.5px;font-weight:600;text-decoration:none;transition:color .2s;cursor:pointer;}
.foot-links a:hover{color:#fff;}
.foot-soc{display:flex;gap:8px;}
.soc-btn{width:33px;height:33px;border-radius:7px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:13px;transition:all .2s;cursor:pointer;text-decoration:none;}
.soc-btn:hover{border-color:var(--borderacc);color:var(--acc2);background:rgba(232,52,10,.08);}

/* ── CONFETTI ── */
.confetti-layer{position:fixed;inset:0;pointer-events:none;z-index:999;overflow:hidden;}
.conf-piece{position:absolute;top:-10px;border-radius:2px;animation:confFall linear forwards;}
@keyframes confFall{to{transform:translateY(110vh) rotate(720deg);opacity:0;}}

/* ── LOGIN BOX ── */
.login-screen{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 60px);}
.login-box{background:rgba(10,8,16,.97);border:1px solid var(--borderacc);border-radius:20px;padding:3rem 2.5rem;text-align:center;max-width:460px;width:90%;position:relative;}
.login-box::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:50%;height:2px;background:var(--grad);border-radius:0 0 4px 4px;}
.login-logo{font-size:58px;font-weight:900;line-height:.9;margin-bottom:.5rem;}
.login-sub{color:var(--muted);font-family:'Inter',sans-serif;font-size:14px;margin-bottom:1.5rem;line-height:1.6;}
.login-perms{text-align:left;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:10px;padding:1.1rem;margin-bottom:1.5rem;}
.login-perm-title{font-size:12px;color:var(--muted);margin-bottom:.6rem;font-family:'Inter',sans-serif;}
.login-perm{display:flex;align-items:center;gap:9px;font-size:13px;padding:4px 0;font-family:'Inter',sans-serif;}
.pcheck{color:var(--success);font-size:13px;flex-shrink:0;}

/* ── RESULT RING ── */
.result-ring-wrap{width:160px;height:160px;margin:0 auto 1.75rem;position:relative;}
.result-ring-wrap svg{position:absolute;inset:0;transform:rotate(-90deg);}
.result-inner{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.result-score{font-size:54px;font-weight:900;line-height:1;}
.result-denom{font-size:15px;color:var(--muted);}
