/* ============================================================
   landing.css — 2 sections
   ============================================================ */

/* ============================================================
   LOGIN PAGE
============================================================ */

/* ============================================================
   LANDING PAGE
============================================================ */
#login-page {
  position:relative; min-height:100vh; background:var(--bg);
  overflow-x:hidden;
}
html, body { overflow-x:hidden; }

/* NAV */
.lp-nav {
  position:sticky; top:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 40px; height:56px;
  background:var(--bg1); backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  overflow:visible;
}
.lp-nav-logo { display:flex; align-items:center; gap:10px; font-family:'Barlow Condensed',sans-serif; font-weight:900; font-size:20px; color:var(--text); white-space:nowrap; text-decoration:none; }
.lp-nav-logo .nmark { width:34px; height:34px; background:var(--red); border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:14px; color:#fff; flex-shrink:0; }
.lp-nav-actions { display:flex; align-items:center; gap:10px; }
.lp-btn-ghost { background:none; border:1px solid var(--border); color:var(--text2); padding:7px 18px; border-radius:8px; font-size:13px; font-weight:600; cursor:pointer; transition:all .15s; font-family:'Barlow',sans-serif; }
.lp-btn-ghost:hover { border-color:var(--border2); color:var(--text); }
.lp-btn-red { background:var(--red); border:none; color:#fff; padding:8px 20px; border-radius:8px; font-size:13px; font-weight:700; cursor:pointer; transition:opacity .15s; font-family:'Barlow Condensed',sans-serif; letter-spacing:.5px; }
.lp-btn-red:hover { opacity:.88; }

/* BURGER */
.lp-burger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:8px; border-radius:8px; background:none; border:none; }
.lp-burger span { display:block; width:22px; height:2px; background:var(--text); border-radius:2px; transition:all .25s; }
.lp-burger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.lp-burger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.lp-burger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* MOBILE MENU */
.lp-mobile-menu {
  display:none; position:absolute; top:54px; left:0; right:0; z-index:99;
  background:var(--bg1); border-bottom:1px solid var(--border);
  flex-direction:column; padding:16px 20px; gap:8px;
  box-shadow:0 8px 24px rgba(0,0,0,.3);
  animation:slideDown .2s ease;
}
@keyframes slideDown { from{opacity:0;transform:translateY(-8px)} to{opacity:1;transform:translateY(0)} }
.lp-mobile-menu.open { display:flex; }
.lp-mobile-menu a, .lp-mobile-menu button {
  display:block; padding:14px 16px; border-radius:10px; font-size:16px; font-weight:700;
  color:var(--text); background:var(--bg2); border:1px solid var(--border);
  cursor:pointer; text-align:left; font-family:'Barlow Condensed',sans-serif; letter-spacing:.3px;
  transition:background .12s;
}
.lp-mobile-menu a:hover, .lp-mobile-menu button:hover { background:var(--bg3); }
.lp-mobile-menu .lp-mm-red { background:var(--red); color:#fff; border-color:var(--red); }
.lp-mobile-menu .lp-mm-sep { height:1px; background:var(--border); border:none; padding:0; margin:4px 0; }

/* HERO */
.lp-hero {
  position:relative; min-height:auto; display:flex; align-items:center;
  overflow:hidden; background:var(--bg);
}
.lp-hero-bg {
  position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(ellipse at 60% 40%, rgba(183,28,28,.12) 0%, transparent 55%),
    radial-gradient(ellipse at 10% 80%, rgba(201,168,50,.05) 0%, transparent 45%);
}
.lp-hero-grid {
  position:absolute; inset:0; z-index:0; opacity:.06;
  background-image:
    linear-gradient(var(--border) 1px, transparent 1px),
    linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size:40px 40px;
}
.lp-hero-content {
  position:relative; z-index:2; max-width:1280px; margin:0 auto;
  padding:40px 40px 30px; display:grid; grid-template-columns:1fr 440px; gap:60px; align-items:center;
  width:100%;
}
.lp-hero-left { }
.lp-tag {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--red-glow); border:1px solid rgba(183,28,28,.3);
  border-radius:20px; padding:5px 14px; font-size:11px; font-weight:700;
  color:var(--red); letter-spacing:1px; text-transform:uppercase; margin-bottom:20px;
}
.lp-tag-dot { width:6px; height:6px; border-radius:50%; background:var(--red); animation:blink 1.5s ease-in-out infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.3} }
.lp-hero-title {
  font-family:'Barlow Condensed',sans-serif; font-size:clamp(48px,7vw,80px);
  font-weight:900; line-height:.95; color:var(--text); margin-bottom:20px;
  letter-spacing:-1px;
}
.lp-hero-title .accent { color:var(--red); display:block; }
.lp-hero-title .accent2 { color:var(--gold); font-size:.65em; display:block; font-weight:600; letter-spacing:2px; font-family:'Barlow',sans-serif; text-transform:uppercase; margin-top:8px; }
.lp-hero-sub { font-size:16px; color:var(--text2); line-height:1.6; margin-bottom:32px; max-width:520px; }
.lp-hero-sub strong { color:var(--text); }
.lp-features-row { display:flex; flex-wrap:wrap; gap:10px; margin-bottom:32px; }
.lp-feat-pill {
  display:flex; align-items:center; gap:6px;
  background:var(--bg3); border:1px solid var(--border); border-radius:20px;
  padding:6px 14px; font-size:12px; font-weight:600; color:var(--text2);
}
.lp-feat-pill .fi { font-size:14px; }
.lp-stats { display:flex; gap:28px; }
.lp-stat-val { font-family:'Barlow Condensed',sans-serif; font-size:32px; font-weight:900; color:#fff; }
.lp-stat-lbl { font-size:11px; color:var(--text3); margin-top:2px; }

/* AUTH CARD */
.lp-auth-card {
  background:var(--bg2); border:1px solid var(--border);
  border-radius:20px; padding:32px; box-shadow:0 20px 60px rgba(0,0,0,.5);
  animation:cardIn .5s cubic-bezier(.34,1.2,.64,1);
}
@keyframes cardIn { from{transform:translateY(30px);opacity:0} to{transform:translateY(0);opacity:1} }
.auth-tabs { display:flex; background:var(--bg3); border-radius:10px; padding:4px; margin-bottom:24px; }
.auth-tab { flex:1; text-align:center; padding:8px; border-radius:7px; font-size:13px; font-weight:700; cursor:pointer; color:var(--text3); transition:all .15s; }
.auth-tab.active { background:var(--bg1); color:var(--text); box-shadow:0 1px 4px rgba(0,0,0,.3); }
.auth-field { margin-bottom:14px; }
.auth-label { font-size:10px; font-weight:700; color:var(--text3); text-transform:uppercase; letter-spacing:.5px; margin-bottom:5px; display:block; }
.auth-input {
  width:100%; background:var(--bg3); border:1px solid var(--border);
  border-radius:9px; padding:11px 13px; color:var(--text); font-size:13px;
  outline:none; transition:border-color .15s; font-family:'Barlow',sans-serif;
}
.auth-input:focus { border-color:var(--red); }
.auth-input::placeholder { color:var(--text3); }
.auth-role { display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-bottom:16px; }
.auth-role-btn {
  padding:10px; border-radius:10px; border:2px solid var(--border);
  background:var(--bg3); cursor:pointer; text-align:center; transition:all .15s;
}
.auth-role-btn:hover { border-color:var(--border2); }
.auth-role-btn.sel { border-color:var(--red); background:var(--red-glow); }
.auth-role-btn .ri { font-size:20px; margin-bottom:4px; }
.auth-role-btn .rn { font-size:12px; font-weight:700; color:var(--text); }
.auth-role-btn .rs { font-size:9px; color:var(--text3); }
.auth-submit {
  width:100%; padding:13px; border-radius:10px; border:none;
  background:var(--red); color:#fff; font-size:14px; font-weight:700;
  cursor:pointer; font-family:'Barlow Condensed',sans-serif; letter-spacing:.5px;
  transition:opacity .15s, transform .1s; margin-top:4px;
}
.auth-submit:hover { opacity:.9; }
.auth-submit:active { transform:scale(.98); }
.auth-error {
  background:rgba(183,28,28,.12); border:1px solid rgba(183,28,28,.25);
  border-radius:8px; padding:9px 12px; font-size:11px; color:#EF5350;
  margin-bottom:12px; display:none;
}
.auth-switch { text-align:center; font-size:12px; color:var(--text3); margin-top:16px; }
.auth-switch a { color:var(--red); cursor:pointer; font-weight:600; }
.auth-divider { display:flex; align-items:center; gap:10px; margin:16px 0; }
.auth-divider::before, .auth-divider::after { content:''; flex:1; height:1px; background:var(--border); }
.auth-divider span { font-size:11px; color:var(--text3); }
.auth-forgot { font-size:11px; color:var(--text3); text-align:right; margin-top:4px; cursor:pointer; }
.auth-forgot:hover { color:var(--red); }

/* SECTIONS */
.lp-section { max-width:1200px; margin:0 auto; padding:80px 40px; }
.lp-section-title { color:var(--text); font-family:'Barlow Condensed',sans-serif; font-size:42px; font-weight:900; margin-bottom:8px; }
.lp-section-sub { font-size:15px; color:var(--text2); margin-bottom:48px; }
.lp-section-label { font-size:11px; font-weight:700; color:var(--red); letter-spacing:2px; text-transform:uppercase; margin-bottom:10px; }

/* ROLE CARDS */
.lp-role-card {
  background:var(--bg2); border:1px solid var(--border); border-radius:18px;
  overflow:hidden; display:flex; flex-direction:column;
  transition:transform .18s, box-shadow .18s, border-color .18s;
}
.lp-role-card:hover { transform:translateY(-4px); box-shadow:0 16px 40px rgba(0,0,0,.25); }
.lp-role-top { padding:22px 20px 18px; border-bottom:1px solid var(--border); }
.lp-role-icon { font-size:32px; margin-bottom:10px; }
.lp-role-label { font-family:'Barlow Condensed',sans-serif; font-size:22px; font-weight:900; margin-bottom:3px; }
.lp-role-sub { font-size:10px; color:var(--text3); font-weight:600; letter-spacing:.3px; }
.lp-role-body { padding:18px 20px; flex:1; display:flex; flex-direction:column; }
.lp-role-list { list-style:none; padding:0; margin:0 0 18px; flex:1; }
.lp-role-list li { font-size:12px; color:var(--text2); padding:7px 0; border-bottom:1px solid var(--border); line-height:1.45; }
.lp-role-list li:last-child { border-bottom:none; }
.lp-role-list li strong { color:var(--text); }
.lp-role-cta {
  display:block; width:100%; padding:11px; border-radius:10px;
  font-size:12px; font-weight:700; cursor:pointer; text-align:center;
  font-family:'Barlow Condensed',sans-serif; letter-spacing:.3px;
  transition:opacity .15s; color:#fff;
}
.lp-role-cta:hover { opacity:.85; }

/* NEWS SECTION */
.lp-news { display:grid; grid-template-columns:1fr 1fr 1fr; gap:16px; }
.lp-news-card {
  background:var(--bg2); border:1px solid var(--border); border-radius:14px;
  padding:20px; cursor:pointer; transition:all .15s; color:var(--text);
}
.lp-news-card:hover { transform:translateY(-2px); border-color:var(--border2); }
.lp-news-card.featured { grid-column:span 2; background:var(--bg4); border-color:rgba(183,28,28,.3); }

/* AD BANNER */
.lp-ad {
  display:flex; align-items:center; gap:16px; padding:16px 24px;
  background:var(--bg2); border:1px solid var(--border); border-radius:14px;
  margin:0 40px; position:relative;
}
.lp-ad-label { position:absolute; top:6px; right:12px; font-size:8px; color:var(--text3); letter-spacing:1px; text-transform:uppercase; }
.lp-ad-cta { background:var(--bg3); border:1px solid var(--border); border-radius:8px; padding:7px 16px; font-size:12px; font-weight:700; color:var(--red); white-space:nowrap; flex-shrink:0; }

/* DEVISE */
.lp-devise {
  text-align:center; padding:80px 40px;
  background:var(--bg3);
  border-top:1px solid var(--border); border-bottom:1px solid var(--border);
}
.lp-devise-text {
  color:var(--text) !important;
  font-family:'Barlow Condensed',sans-serif; font-size:clamp(28px,5vw,56px);
  font-weight:900; color:#fff; line-height:1.1; max-width:800px; margin:0 auto 16px;
}
.lp-devise-text em { color:var(--red); font-style:normal; }


/* ===== CAROUSEL COMPÉTITIONS ===== */
#lp-carousel::-webkit-scrollbar { display:none; }
.lp-comp-card {
  flex-shrink:0; width:210px; background:var(--bg2);
  border:1px solid var(--border); border-radius:16px;
  padding:16px; cursor:pointer; scroll-snap-align:start;
  transition:transform .18s, box-shadow .18s, border-color .18s;
  position:relative; overflow:hidden;
}
.lp-comp-card:hover { transform:translateY(-4px); box-shadow:0 12px 32px rgba(0,0,0,.25); border-color:var(--border2); }
.lp-comp-logo {
  width:56px; height:56px; border-radius:12px; margin-bottom:10px;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 12px rgba(0,0,0,.3);
}
.lp-comp-badge {
  position:absolute; top:10px; right:10px;
  font-size:8px; font-weight:800; padding:2px 7px;
  border-radius:10px; letter-spacing:.5px; text-transform:uppercase;
}
.lp-comp-badge.nfxp { background:rgba(183,28,28,.2); color:var(--red); border:1px solid rgba(183,28,28,.3); }
.lp-comp-badge.ext  { background:var(--bg3); color:var(--text3); border:1px solid var(--border); }
.lp-comp-date { font-size:11px; font-weight:700; color:var(--red); margin-bottom:4px; letter-spacing:.5px; }
.lp-comp-name { font-size:13px; font-weight:800; color:var(--text); line-height:1.25; margin-bottom:4px; }
.lp-comp-loc  { font-size:10px; color:var(--text3); margin-bottom:2px; }
.lp-comp-tag  { font-size:9px; font-weight:700; padding:2px 7px; border-radius:4px; }
.lp-comp-tag.gi   { background:rgba(46,125,50,.2);  color:#4CAF50; border:1px solid rgba(46,125,50,.3); }
.lp-comp-tag.nogi { background:rgba(183,28,28,.15); color:#EF5350; border:1px solid rgba(183,28,28,.25); }
.lp-comp-tag.mma  { background:rgba(21,101,192,.2); color:#42A5F5; border:1px solid rgba(21,101,192,.3); }
.lp-comp-tag.kids { background:rgba(201,168,50,.15);color:var(--gold); border:1px solid rgba(201,168,50,.25); }
.lp-comp-spots { font-size:10px; font-weight:700; margin-top:6px; }
.lp-comp-spots.open { color:#4CAF50; }
.lp-comp-spots.full { color:var(--text3); }
.lp-comp-coaching { font-size:9px; font-weight:700; margin-top:4px; }
.lp-comp-coaching.nfxp { color:var(--gold); }
.lp-comp-coaching.none { color:var(--text3); }

