:root{
  --bg0:#050814;
  --bg1:#070b18;
  --bg2:#0a1226;
  --card:rgba(255,255,255,.04);
  --card2:rgba(255,255,255,.06);
  --line:rgba(255,255,255,.10);
  --text:#e9eefc;
  --muted:#a9b4d6;
  --accent:#6bd6ff;
  --accent2:#a78bfa;
  --g-asa:#6bd6ff;
  --g-ase:#57d18c;
  /* ARK 2 accent (vivid red) */
  --g-ark2:#ff3b3b;
  --g-global:#f5c542;
  --ok:#57d18c;
  --err:#ff6b6b;
  --shadow: 0 18px 60px rgba(0,0,0,.55);
  --r:16px;
  --w: 1200px;
  --topbar-h:86px;
  color-scheme: dark;
}

*{ box-sizing:border-box }
html,body{ height:100% }
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Apple Color Emoji","Segoe UI Emoji";
  background:#04060e;
  color:var(--text);
}
body::before{
  content:'';
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:0;
  background:
    radial-gradient(1200px 900px at 12% 0%, rgba(124,58,237,.20), transparent 62%),
    radial-gradient(1100px 850px at 88% 8%, rgba(59,130,246,.16), transparent 64%),
    radial-gradient(1000px 1000px at 50% 115%, rgba(0,0,0,.90), transparent 58%),
    radial-gradient(ellipse at 50% 32%, rgba(0,0,0,.06) 0%, rgba(0,0,0,.26) 45%, rgba(0,0,0,.55) 78%, rgba(0,0,0,.86) 100%);
}


a{ color:inherit; text-decoration:none }
code{ font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono"; }
.muted{ color:var(--muted) }

/* Topbar (inspirée "gaming/portal") */
.topbar{
  position: sticky;
  top:0;
  z-index:50;
  height: var(--topbar-h);
  display:flex;
  align-items:center;
  background:
    radial-gradient(1100px 170px at 50% 0%, rgba(107,214,255,.10), transparent 60%),
    linear-gradient(180deg, rgba(6,10,22,.92), rgba(6,10,22,.55));
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(14px);
}

.topbar__inner{
  width:min(var(--w), calc(100% - 32px));
  margin:0 auto;
  display:flex;
  align-items:center;
  gap:18px;
}

.brand{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:900;
  letter-spacing:.4px;
  padding:14px 12px;
  border-radius: 12px;
}
.brand__logo{
  width:28px;
  height:28px;
  border-radius:8px;
  object-fit:cover;
  border:1px solid rgba(255,255,255,.18);
  box-shadow: 0 6px 18px rgba(0,0,0,.35);
}
.brand__text{ line-height:1; }
.brand__edit{
  margin-left:6px;
  padding:8px 10px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.35);
  color:#fff;
  font-weight:800;
  font-size:12px;
  cursor:pointer;
}
.brand__edit:hover{ border-color: rgba(107,214,255,.45); box-shadow: 0 0 14px rgba(107,214,255,.25); }
.brand::before{
  content:"";
  width:34px; height:34px;
  border-radius:12px;
  background: radial-gradient(circle at 30% 30%, rgba(107,214,255,.9), rgba(167,139,250,.65));
  box-shadow: 0 10px 30px rgba(107,214,255,.15);
}

.nav{
  display:flex;
  align-items:center;
  gap:6px;
  flex:1;
}
.nav__item{
  padding:10px 12px;
  border-radius: 12px;
  color: var(--muted);
  font-weight:600;
  font-size:14px;
  border:1px solid transparent;
}
.nav__item:hover{
  color: var(--text);
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.06);
}
.nav__item.is-active{
  color: var(--text);
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.10);
}
.nav__item.is-disabled{
  opacity:.55;
  cursor:default;
  pointer-events:auto;
}

/* Hide items that must not be visible when logged out (e.g. Map interactive). */
.nav__item.is-hidden{display:none}

.topbar__right{
  display:flex;
  align-items:center;
  gap:10px;
}
.sep{ opacity:.35; }

.linkbtn{
  appearance:none;
  border:none;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.09);
  color: var(--text);
  font-weight:700;
  font-size:13px;
  padding:10px 12px;
  border-radius: 12px;
  cursor:pointer;
}
.linkbtn:hover{
  background: rgba(255,255,255,.07);
  border-color: rgba(255,255,255,.14);
}
.userpill{
  padding:8px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.09);
  /* Make the username visually pop (gaming portal style) */
  color: #d7ecff;
  font-weight:700;
  font-size:13px;
}

/* Slight accent for the username glyph */
.userpill{ box-shadow: 0 0 0 1px rgba(120,200,255,.06) inset; }

/* --- User dropdown (Dofus-like) --------------------------------------- */
.user-menu{ position:relative; }
.user-menu__btn{
  display:flex;
  align-items:center;
  gap:10px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  color: var(--text);
  padding:10px 12px;
  border-radius:999px;
  cursor:pointer;
}
.user-menu__btn:hover{ background: rgba(255,255,255,.07); border-color: rgba(255,255,255,.14); }
.user-menu__avatar{
  width:32px;
  height:32px;
  border-radius:10px;
  object-fit:cover;
  border:1px solid rgba(255,255,255,.18);
  box-shadow: 0 0 0 2px rgba(0,0,0,.25) inset;
  background: radial-gradient(circle at 30% 30%, rgba(107,214,255,.55), rgba(167,139,250,.35));
}
.user-menu__name{ font-weight:800; font-size:13px; color:#d7ecff; }
.user-menu__chev{ opacity:.75; font-weight:900; }
.user-menu__panel{
  position:absolute;
  right:0;
  top: calc(100% + 18px);
  width: 260px;
  padding:10px;
  background: rgba(10,14,20,.96);
  border:1px solid rgba(255,255,255,.10);
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0,0,0,.55);
  display:none;
}
.user-menu__panel.is-open{ display:block; }
.user-menu__meta{ padding: 4px 6px 10px; }
.user-menu__badge{
  display:inline-block;
  padding:6px 10px;
  border-radius: 999px;
  font-weight:900;
  font-size:12px;
  background: rgba(130,210,255,.10);
  border:1px solid rgba(130,210,255,.18);
  color:#d7ecff;
}
.user-menu__badge--muted{ background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.12); color: rgba(255,255,255,.78); }
.user-menu__item{
  width:100%;
  display:block;
  text-align:left;
  padding:12px 12px;
  border-radius: 12px;
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  color: var(--text);
  font-weight:800;
  text-decoration:none;
  margin-top:8px;
}
.user-menu__item:hover{ background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.14); }
.user-menu__item--danger{ background: rgba(255,80,80,.08); border-color: rgba(255,80,80,.18); }
.user-menu__item--danger:hover{ background: rgba(255,80,80,.14); }
.user-menu__sep{ height:1px; background: rgba(255,255,255,.08); margin: 10px 4px 0; }

/* HOME SLIDES OVERRIDE (single scroll container) */
body.page--home{
  overflow: hidden;
  height: 100vh;
}
body.page--home main{
  padding-top: var(--topbar-h) !important;
}
body.page--home .home-scroll{
  position: relative;
  width: 100vw;
  height: calc(100vh - var(--topbar-h));
  overflow-y: auto;
  overflow-x: hidden;
  scroll-snap-type: y mandatory;
  scroll-behavior: smooth;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}
body.page--home .home-scroll::-webkit-scrollbar{
  width: 0;
  height: 0;
}
body.page--home .slide{
  width: 100vw;
  height: calc(100vh - var(--topbar-h));
  scroll-snap-align: start;
  scroll-snap-stop: always;
  position: relative;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
body.page--home .chapter__media{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
body.page--home .chapter::before,
body.page--home .chapter::after{
  display: none !important;
}

.page{
  width:min(var(--w), calc(100% - 32px));
  margin: 24px auto 64px;
}

/* Full-bleed sections (Dofus-like: background takes full width of the screen) */
.bleed{
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  overflow-x: hidden;
}
.page--home{
  width: min(100%, 100%);
  margin: 0;
}
.page--home .page{
  width: 100%;
  margin: 0;
  padding: 0;
}
.page--home main{
  padding-top: var(--topbar-h) !important;
}
.page--home .home-scroll,
.page.page--home .home-scroll{
  position: relative;
  top: 0;
  left: 0;
  right: 0;
  height: auto;
  overflow: visible;
  scroll-behavior: smooth;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  overflow-x: hidden;
  scroll-snap-type: none;
}
.page--home .home-scroll::-webkit-scrollbar,
.page.page--home .home-scroll::-webkit-scrollbar{
  width: 0;
  height: 0;
}
body.page--home{
  overflow: auto;
  height: auto;
  scroll-snap-type: y mandatory;
}
html, body{
  overscroll-behavior: none;
  margin: 0;
  height: 100%;
}
html{ scroll-snap-type: y mandatory; }

.btn-edit{
  position: absolute;
  top: 18px;
  left: 18px;
  z-index: 2;
  border-radius: 999px;
  padding: 8px 12px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.45);
  color: #fff;
  font-weight: 900;
  cursor: pointer;
}
.page--home .chapter,
.page.page--home .chapter{
  min-height: calc(100vh - var(--topbar-h));
  scroll-snap-align: start;
  scroll-snap-stop: always;
  position: relative;
  display: flex;
  align-items: stretch;
  padding: 0;
  background: transparent;
  width: 100vw;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.page--home .chapter::before,
.page.page--home .chapter::before{
  display:none;
}
.page--home .chapter::after,
.page.page--home .chapter::after{
  display:none;
}
.chapter__media{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  background-size: cover;
  background-position: center;
  filter: none;
  z-index:0;
}
.chapter__media video,
video.chapter__media{
  object-fit: cover;
  width:100%;
  height:100%;
}
.page--home .chapter > *:not(.chapter__media),
.page.page--home .chapter > *:not(.chapter__media){
  position: relative;
  z-index: 1;
}
.page--home .chapter > .hero,
.page--home .chapter > .banner,
.page--home .chapter > .section,
.page.page--home .chapter > .hero,
.page.page--home .chapter > .banner,
.page.page--home .chapter > .section{
  min-height: calc(100vh - var(--topbar-h));
  width: 100%;
}
.page--home .chapter > .banner,
.page.page--home .chapter > .banner{
  display:flex;
  align-items:center;
}
.page--home .chapter > .section,
.page.page--home .chapter > .section{
  display:flex;
  align-items:center;
}
.page--home .chapter--footer,
.page.page--home .chapter--footer{
  display:flex;
  align-items:center;
  justify-content:center;
}
.chapters-dots{
  position: fixed;
  right: 18px;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  gap: 10px;
  z-index: 120;
}
.chapter-dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.35);
  background: rgba(255,255,255,.12);
  cursor: pointer;
  position: relative;
}
.chapter-dot__label{
  position: absolute;
  right: 18px;
  top: 50%;
  transform: translateY(-50%);
  opacity: 0;
  background: rgba(0,0,0,.55);
  border: 1px solid rgba(255,255,255,.14);
  color: #fff;
  padding: 4px 8px;
  border-radius: 999px;
  font-size: 11px;
  white-space: nowrap;
  pointer-events: none;
  transition: opacity .15s ease, transform .15s ease;
}
.chapter-dot:hover .chapter-dot__label{
  opacity: 1;
  transform: translateY(-50%) translateX(-4px);
}
.chapter-dot.is-active{
  background: var(--accent);
  box-shadow: 0 0 12px rgba(107,214,255,.55);
  border-color: rgba(107,214,255,.65);
}

.chapter > .hero,
.chapter > .banner,
.chapter > .section{
  opacity: .85;
  transform: translateY(14px);
  transition: opacity .4s ease, transform .4s ease;
}
.chapter.is-active > .hero,
.chapter.is-active > .banner,
.chapter.is-active > .section{
  opacity: 1;
  transform: translateY(0);
}

/* Locations chapter */
.locations{
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 18px;
  align-items: stretch;
}
.locations__list{
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.locations__item{
  text-align: left;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.35);
  color: #fff;
  padding: 14px 16px;
  cursor: pointer;
  transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}
.locations__item.is-active{
  border-color: rgba(107,214,255,.6);
  box-shadow: 0 16px 40px rgba(0,0,0,.35);
  transform: translateY(-1px);
}
.locations__title{ font-weight: 900; display:block; }
.locations__sub{ color: rgba(255,255,255,.7); font-size: 12px; }
.locations__media{
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.12);
  background: #0b0f1e;
  background-size: cover;
  background-position: center;
  min-height: 360px;
  box-shadow: 0 18px 55px rgba(0,0,0,.45);
  transition: opacity .25s ease;
}
@media (max-width: 900px){
  .locations{ grid-template-columns: 1fr; }
  .locations__media{ min-height: 260px; }
}
.container{
  width:min(var(--w), calc(100% - 32px));
  margin:0 auto;
}

/* Buttons */
.btn{
  appearance:none;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: var(--text);
  padding: 12px 14px;
  border-radius: 14px;
  cursor:pointer;
  font-weight:800;
  font-size:14px;
  display:inline-flex;
  gap:10px;
  align-items:center;
}
.btn:hover{ background: rgba(255,255,255,.07); }
.btn.primary{
  border-color: rgba(107,214,255,.25);
  background: linear-gradient(180deg, rgba(107,214,255,.20), rgba(107,214,255,.08));
}
.btn.primary:hover{
  border-color: rgba(107,214,255,.40);
}
.btn.ghost{
  background: transparent;
}
.btn.w100{ width:100%; justify-content:center; }
.btn:disabled{ opacity:.55; cursor:not-allowed; }
.btn.is-loading{ opacity:.75; }

.link{ color: var(--accent); font-weight:800; }
.link:hover{ text-decoration: underline; }

/* Hero */
.hero{
  position: relative;
  min-height: calc(92vh - var(--topbar-h));
  border-radius: calc(var(--r) + 6px);
  overflow:hidden;
  box-shadow: var(--shadow);
  border:1px solid rgba(255,255,255,.10);
}
.hero.bleed{
  border-radius: 0;
  border-left: 0;
  border-right: 0;
}

.hero__bg{
  position:absolute;
  inset:0;
  background: #02040b;
}
.hero__layer{
  position:absolute;
  inset:0;
  opacity:0;
  transition: opacity 900ms ease;
  transform: scale(1.06);
  filter: saturate(1.05) contrast(1.05);
}
.hero__layer.is-active{ opacity:1; }
.hero__media{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}
.hero__overlay{
  position:absolute;
  inset:0;
  background:
    radial-gradient(900px 500px at 18% 10%, rgba(0,0,0,.15), rgba(0,0,0,.75) 58%),
    radial-gradient(900px 600px at 85% 25%, rgba(0,0,0,.05), rgba(0,0,0,.70) 60%),
    linear-gradient(180deg, rgba(5,8,20,.35), rgba(5,8,20,.85));
}

.hero__content{
  position: relative;
  padding: 54px 54px 46px;
  max-width: 720px;
}
.hero__brandline{
  display:flex;
  align-items:center;
  gap:10px;
  color: var(--muted);
  font-weight:800;
}
.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.10);
  color: var(--text);
  font-size:12px;
}
.dot{ opacity:.55; }

.hero h1{
  margin: 14px 0 10px;
  font-size: 44px;
  line-height: 1.05;
  letter-spacing: .2px;
}
.lead{
  margin: 0 0 18px;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.55;
}

.hero__actions{
  display:flex;
  gap:12px;
  flex-wrap: wrap;
  margin: 18px 0 22px;
}

.hero__meta{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: 18px;
}
.meta__item{
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  padding: 12px 12px;
}
.meta__k{ color: var(--muted); font-weight:800; font-size:12px; }
.meta__v{ font-weight:900; font-size:16px; margin-top:4px; }
.hero__caption .meta__v{ font-weight:800; font-size:14px; color: var(--accent); }

.hero__hint{
  margin-top: 14px;
  color: rgba(233,238,252,.75);
  font-size: 12px;
}
.kbd{
  display:inline-flex;
  padding:2px 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);
  margin-right: 8px;
  font-weight:900;
}

/* Sections */
.section{ margin-top: 18px; }
.grid3{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 14px;
}
.card{
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.09);
  border-radius: calc(var(--r) + 4px);
  padding: 18px 18px;
  box-shadow: 0 10px 35px rgba(0,0,0,.35);
}
.card h2{ margin: 0 0 8px; font-size: 18px; }
.card p{ margin: 0 0 12px; color: var(--muted); line-height: 1.55; }

.split{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 14px;
}
.panel{
  background: rgba(255,255,255,.035);
  border:1px solid rgba(255,255,255,.08);
  border-radius: calc(var(--r) + 4px);
  padding: 18px;
}
.panel h2{ margin:0 0 10px; font-size:18px; }
.bullets{ margin:0; padding-left:18px; color: var(--muted); }
.bullets li{ margin:8px 0; }
.steps{ margin:0; padding-left:18px; color: var(--muted); }
.steps li{ margin:8px 0; }

/* Full width banners (inspired by big game portals) */
.banner{
  position: relative;
  padding: 78px 0;
  background:
    radial-gradient(900px 420px at 25% 30%, rgba(0,0,0,.18), rgba(0,0,0,.70) 60%),
    linear-gradient(180deg, rgba(2,4,11,.15), rgba(2,4,11,.85));
  border-top: 1px solid rgba(255,255,255,.08);
  border-bottom: 1px solid rgba(255,255,255,.08);
  overflow:hidden;
}
.banner::before{
  content:"";
  position:absolute;
  inset:-2px;
  background-image: var(--bg);
  background-size: cover;
  background-position: center;
  filter: saturate(1.05) contrast(1.05);
  transform: scale(1.03);
  opacity: .42;
}
.banner::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(900px 420px at 25% 30%, rgba(0,0,0,.10), rgba(0,0,0,.78) 62%),
    linear-gradient(180deg, rgba(5,8,20,.25), rgba(5,8,20,.92));
}
.banner__inner{
  position: relative;
  z-index: 1;
  width:min(var(--w), calc(100% - 32px));
  margin:0 auto;
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 18px;
  align-items:center;
}
.banner h2{ margin:0 0 10px; font-size: 34px; }
.banner p{ margin:0 0 14px; color: rgba(233,238,252,.78); line-height:1.6; }
.banner__card{
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: calc(var(--r) + 6px);
  padding: 18px;
  box-shadow: 0 16px 55px rgba(0,0,0,.45);
}

.site-footer{
  width: 100%;
  padding: 20px 40px;
  background: #05070d;
  color: #ffffff;
  border-top: 1px solid rgba(255,255,255,0.08);
  font-size: 12px;
}
.site-footer *{
  color: #ffffff;
}
.footer-inner{
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
}
.footer-links{
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}
.footer-links a{
  color: #ffffff;
  text-decoration: none;
  font-size: 14px;
  opacity: .9;
}
.footer-links a:hover{
  opacity: 1;
}
.footer-links a.is-disabled{
  opacity: .55;
  cursor: default;
}

/* Auth Modal */
.modal{
  position: fixed;
  inset:0;
  display:none;
  place-items:center;
  z-index: 200;
}
.modal.is-open{ display:grid; }
.modal__backdrop{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.65);
  backdrop-filter: blur(8px);
}
.modal__dialog{
  position: relative;
  width: min(560px, calc(100% - 24px));
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(10,18,38,.92), rgba(7,11,24,.92));
  border:1px solid rgba(255,255,255,.12);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.modal__head{
  display:flex;
  justify-content: space-between;
  align-items:center;
  padding: 14px 16px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.modal__title{
  font-weight: 900;
  letter-spacing:.2px;
}
.iconbtn{
  appearance:none;
  border:none;
  background: rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.10);
  color: var(--text);
  width:36px; height:36px;
  border-radius: 12px;
  cursor:pointer;
}
.iconbtn:hover{ background: rgba(255,255,255,.08); }

.modal__tabs{
  display:flex;
  gap:8px;
  padding: 12px 16px 0;
}
.tab{
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  color: var(--muted);
  font-weight:900;
  padding: 10px 12px;
  border-radius: 14px;
  cursor:pointer;
}
.tab.is-active{
  color: var(--text);
  border-color: rgba(107,214,255,.35);
  background: rgba(107,214,255,.10);
}
.modal__body{ padding: 14px 16px 16px; }
.pane{ display:none; }
.pane.is-active{ display:block; }
.field{ margin: 10px 0; }
.field label{ display:block; font-weight:800; color: var(--muted); font-size:12px; margin-bottom:6px; }
.field input{
  width:100%;
  border-radius: 14px;
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  color: var(--text);
  padding: 12px 12px;
  outline:none;
}
.field input:focus{
  border-color: rgba(107,214,255,.40);
  box-shadow: 0 0 0 3px rgba(107,214,255,.10);
}
.row2{ display:grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.hint{ color: rgba(233,238,252,.70); font-size: 12px; margin-top: 10px; }
.msg{ margin:10px 0 0; color: var(--muted); min-height: 18px; font-weight:700; }
.w100{ width:100% }

@media (max-width: 900px){
  .hero__content{ padding: 40px 18px 28px; }
  .hero h1{ font-size: 34px; }
  .hero__meta{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .grid3{ grid-template-columns: 1fr; }
  .split{ grid-template-columns: 1fr; }
  .topbar__inner{ width: calc(100% - 18px); }
}


/* Map page: keep topbar visible above the app */
.site-topbar--map{
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 5000;
}
body.has-site-topbar{
  padding-top: 64px;
}


/* Map shell (iframe wrapper) */
.mapShell{height: calc(100vh - var(--topbar-h,64px));}
.mapShell__frame{width:100%;height:100%;border:0;display:block;}
body:has(.mapShell){overflow:hidden;}


/* Full-bleed pages (Map) */
.page--full{width:100%;margin:0;padding:0;}
.page--full .mapShell{height: calc(100vh - var(--topbar-h,64px));}




/* --- Game selector (ASE/ASA/ARK2) --- */
.game-select{position:relative;margin-left:12px}
.game-select__btn{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid rgba(255,255,255,.14);border-radius:12px;background:rgba(0,0,0,.30);text-decoration:none;color:inherit}
.game-select__btn:hover{background:rgba(0,0,0,.42)}
.game-select__chev{opacity:.75}
.game-select__menu{position:absolute;top:calc(100% + 10px);left:0;min-width:260px;padding:8px;border:1px solid rgba(255,255,255,.14);border-radius:14px;background:rgba(10,12,18,.95);backdrop-filter:blur(10px);box-shadow:0 18px 60px rgba(0,0,0,.55);display:none;z-index:50}
.game-select.is-open .game-select__menu{display:block}
.game-select__item{display:flex;align-items:center;gap:10px;padding:10px 10px;border-radius:10px;text-decoration:none;color:#fff}
.game-select__item:hover{background:rgba(255,255,255,.07)}
.game-select__item.is-active{background:rgba(255,255,255,.10)}
.muted{opacity:.75}

.game-badge{display:inline-flex;align-items:center;justify-content:center;height:22px;min-width:48px;padding:0 10px;border-radius:999px;font-size:12px;letter-spacing:.06em;font-weight:800}
.game-badge--asa{background:rgba(70,140,255,.22);border:1px solid rgba(70,140,255,.35)}
.game-badge--ase{background:rgba(80,255,170,.18);border:1px solid rgba(80,255,170,.30)}
.game-badge--ark2{background:rgba(255,59,59,.18);border:1px solid rgba(255,59,59,.36)}
.badge--game{margin-left:8px}

/* News cards */
.card--news .card__media{height:160px;border-radius:16px 16px 0 0;background-size:cover;background-position:center}
.card__meta{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.tag{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.25);font-size:12px;font-weight:700;letter-spacing:.04em}
.news-hero{border-radius:18px;overflow:hidden;min-height:260px;background-size:cover;background-position:center;position:relative;margin-bottom:18px}
.news-hero__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.20),rgba(0,0,0,.85))}
.news-hero__inner{position:relative;padding:22px;max-width:900px}
.news-body{max-width:900px;line-height:1.7}


/* --- V14 News layout -------------------------------------------------- */
.hero__video,.hero__image,.hero__fallback{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero__fallback{opacity:.15}
.news-grid{display:grid;grid-template-columns:1.35fr .65fr;gap:16px;align-items:start}
@media (max-width:980px){.news-grid{grid-template-columns:1fr}}
.news-feature{display:grid;grid-template-columns:1fr;gap:12px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:20px;overflow:hidden}
.news-feature__img{display:block;min-height:280px;background-size:cover;background-position:center}
.news-feature__img.is-empty{background:rgba(255,255,255,.05)}
.news-feature__body{padding:16px}
.news-feature__title{margin:6px 0 8px;font-size:22px}
.news-feature__title a{color:var(--titleColor);text-decoration:none}
.news-feature__excerpt{margin:0 0 12px;color:rgba(255,255,255,.85)}
.news-list{display:grid;gap:12px}
.news-card{display:grid;grid-template-columns:120px 1fr;gap:12px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:16px;overflow:hidden}
.news-card__img{display:block;background-size:cover;background-position:center;min-height:92px}
.news-card__body{padding:12px}
.news-card__title{margin:6px 0 6px;font-size:16px}
.news-card__title a{color:#fff;text-decoration:none}
.news-card__excerpt{margin:0;color:rgba(255,255,255,.75);font-size:13px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.news-meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center}

/* Accent borders by game */
.news-feature[data-game="asa"], .news-card[data-game="asa"], .news-full[data-game="asa"], .news-row[data-game="asa"]{border-color:rgba(107,214,255,.45)}
.news-feature[data-game="ase"], .news-card[data-game="ase"], .news-full[data-game="ase"], .news-row[data-game="ase"]{border-color:rgba(87,209,140,.45)}
.news-feature[data-game="ark2"], .news-card[data-game="ark2"], .news-full[data-game="ark2"], .news-row[data-game="ark2"]{border-color:rgba(255,59,59,.70)}
.news-feature[data-game="global"], .news-card[data-game="global"], .news-full[data-game="global"], .news-row[data-game="global"]{border-color:rgba(245,197,66,.50)}
.tag{display:inline-flex;align-items:center;padding:3px 8px;border-radius:999px;background:rgba(255,255,255,.08);font-size:12px;color:rgba(255,255,255,.85)}
.tag--warn{background:rgba(255,209,102,.22)}
.news-full{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:24px;overflow:hidden}
.news-full__hero{height:340px;background-size:cover;background-position:center}
.news-full__head{padding:18px 18px 8px}
.news-full__title{margin:8px 0 8px;font-size:34px;line-height:1.05}
.news-full__excerpt{margin:0;color:rgba(255,255,255,.85)}
.news-full__content{padding:0 18px 18px}
.news-full__footer{padding:0 18px 18px}
.prose h1,.prose h2,.prose h3{color:var(--titleColor)}
.prose p{color:rgba(255,255,255,.88)}
.prose a{color:var(--accent)}
.news-row{display:grid;grid-template-columns:160px 1fr;gap:12px;padding:12px;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);margin-bottom:12px}
.news-row__img{display:block;border-radius:12px;background-size:cover;background-position:center;min-height:92px}
.news-row__title{margin:6px 0 6px}
.userbox{display:flex;align-items:center;gap:10px}
.userpill{padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.08);color:var(--accent);font-weight:700}
.userpill--admin{box-shadow:0 0 0 2px rgba(255,255,255,.1) inset}
.btn--sm{padding:8px 10px;font-size:13px;border-radius:12px}



/* --- V16.1 News polish ------------------------------------------------ */
.section-title{font-size:22px;letter-spacing:.2px;margin:0 0 10px}
.news-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:18px;align-items:start}
@media (max-width: 980px){.news-grid{grid-template-columns:1fr}}
.news-feature{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);border-radius:18px;overflow:hidden;box-shadow:var(--shadow)}
.news-feature__img{width:100%;height:320px;object-fit:cover;display:block}
@media (max-width: 980px){.news-feature__img{height:240px}}
.news-feature__body{padding:18px 18px 16px}
.news-feature__title{font-size:28px;line-height:1.15;margin:8px 0 10px}
.news-feature__meta{display:flex;gap:10px;flex-wrap:wrap;align-items:center;color:var(--muted);font-size:13px}
.badge{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);font-size:12px}
.badge--ase{background:rgba(87,209,140,.10);border-color:rgba(87,209,140,.35)}
.badge--asa{background:rgba(107,214,255,.10);border-color:rgba(107,214,255,.35)}
.badge--ark2{background:rgba(255,59,59,.10);border-color:rgba(255,59,59,.45)}
.badge--global{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.18)}
.news-feature__excerpt{color:rgba(233,238,252,.90);font-size:15px;line-height:1.65;margin:10px 0 0}
.news-list{display:grid;gap:12px}
.news-card{display:flex;gap:12px;align-items:stretch;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.10);border-radius:16px;overflow:hidden;transition:transform .12s ease, background .12s ease}
.news-card:hover{transform:translateY(-1px);background:rgba(255,255,255,.045)}
.news-card__img{width:168px;min-width:168px;height:106px;object-fit:cover;display:block}
@media (max-width: 520px){.news-card{flex-direction:column}.news-card__img{width:100%;min-width:100%;height:160px}}
.news-card__body{padding:12px 12px 10px;flex:1}
.news-card__title{margin:6px 0 6px;font-size:16px;line-height:1.25}
.news-card__excerpt{margin:0;color:var(--muted);font-size:13px;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}



/* --- V16.1 Section typography ---------------------------------------- */
.section{padding:34px 0}
.section__head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin:0 0 18px}
.section__title{font-size:24px;letter-spacing:.2px;margin:0}
.section__sub{margin:0;color:var(--muted);max-width:780px;line-height:1.6}
@media (max-width: 720px){.section__head{flex-direction:column;align-items:flex-start}}
/* Ensure anchor-based thumbnails work */
.news-card__img{display:block;background-size:cover;background-position:center;width:168px;min-width:168px;height:106px;border-right:1px solid rgba(255,255,255,.08)}
@media (max-width: 520px){.news-card__img{width:100%;min-width:100%;height:160px;border-right:none;border-bottom:1px solid rgba(255,255,255,.08)}}


/* ===================== V17 — Actualités Premium =====================
   Objectif: rendu "portal" type Ankama (1 grosse news + previews),
   typographie plus clean, cartes plus lisibles. (Overrides only)
*/
.section#news{scroll-margin-top: calc(var(--topbar-h) + 14px)}

.section__title{font-size:26px; letter-spacing:.3px}
.section__sub{font-size:15px}

.news-grid{grid-template-columns: 1.45fr .55fr; gap:22px}
@media (max-width: 980px){.news-grid{grid-template-columns:1fr}}

.news-feature{border-radius:22px;}
.news-feature__img{height:380px; min-height:380px; background-size:cover; background-position:center; display:block;}
@media (max-width: 980px){.news-feature__img{height:260px; min-height:260px}}

.news-feature__body{padding:20px 20px 18px}
.news-feature__title{font-size:32px; line-height:1.12; margin:10px 0 10px}
.news-feature__excerpt{font-size:15.5px; line-height:1.65; margin:0 0 14px; color:rgba(233,238,252,.92)}

.news-list{gap:14px}
.news-card{border-radius:18px}
.news-card__img{width:190px; min-width:190px; height:118px; background-size:cover; background-position:center;}
@media (max-width: 520px){.news-card__img{width:100%;min-width:100%;height:170px}}
.news-card__title{font-size:16.5px}
.news-card__excerpt{font-size:13.2px}

/* Better emphasis for the game badge inside news blocks */
.news-meta .game-badge{font-size:11px; height:22px}



/* --- Actualités page (Dofus-like grid) --- */
.page--news .container{max-width:1180px;}
.news-header{padding:24px 0 18px;}
.news-header h1{font-size:40px;letter-spacing:.2px;margin:0 0 8px;}
.news-header p{margin:0;color:rgba(255,255,255,.72);max-width:760px}

.news-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 10px;border-radius:999px;
  background:rgba(0,0,0,.45);
  border:2px solid var(--accent,#4aa3ff);
  box-shadow:0 8px 18px rgba(0,0,0,.35);
  font-weight:700;font-size:12px;letter-spacing:.2px;
}

.news-featured{
  --accent:#4aa3ff;
  display:grid;grid-template-columns: 1.35fr 1fr;
  gap:18px;
  border-radius:22px;
  border:3px solid rgba(255,255,255,.08);
  box-shadow: 0 18px 45px rgba(0,0,0,.45);
  background: radial-gradient(1200px 420px at 30% 0%, rgba(255,255,255,.08), transparent 60%),
              rgba(10,14,24,.78);
  overflow:hidden;
  position:relative;
}
.news-featured::before{
  content:"";
  position:absolute;inset:0;
  border:3px solid var(--accent);
  border-radius:22px;
  opacity:.55;
  pointer-events:none;
}
.news-featured__media{
  min-height:320px;
  background-size:cover;background-position:center;
  position:relative;
  display:block;
}
.news-featured__media::after{
  content:"";
  position:absolute;inset:0;
  background: linear-gradient(90deg, rgba(0,0,0,.0) 0%, rgba(0,0,0,.55) 70%, rgba(0,0,0,.7) 100%);
}
.news-featured__media .news-badge{position:absolute;left:16px;top:16px;z-index:2}
.news-featured__body{padding:18px 18px 22px;position:relative;z-index:2}
.news-featured__title{margin:0 0 10px;font-size:28px;line-height:1.15}
.news-featured__title a{color:#fff;text-decoration:none}
.news-featured__title a:hover{color:var(--accent)}
.news-featured__meta{color:rgba(255,255,255,.7);font-size:13px;margin-bottom:12px}
.news-featured__excerpt{color:rgba(255,255,255,.82);margin:0 0 16px;line-height:1.45;max-width:52ch}

.news-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:16px;
  margin-top:18px;
}
.news-card{
  --accent:#4aa3ff;
  border-radius:18px;
  background: rgba(10,14,24,.75);
  border:3px solid rgba(255,255,255,.08);
  box-shadow: 0 14px 28px rgba(0,0,0,.40);
  overflow:hidden;
  position:relative;
  transform: translateZ(0);
}
.news-card::before{
  content:"";
  position:absolute;inset:0;
  border:3px solid var(--accent);
  border-radius:18px;
  opacity:.55;
  pointer-events:none;
}
.news-card:hover{transform: translateY(-2px);box-shadow:0 18px 34px rgba(0,0,0,.48)}
.news-card__media{
  height:160px;
  display:block;
  background-size:cover;background-position:center;
  position:relative;
}
.news-card__media::after{
  content:"";
  position:absolute;inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.05) 0%, rgba(0,0,0,.55) 100%);
}
.news-card__media .news-badge{position:absolute;left:12px;top:12px;z-index:2}
.news-card__body{padding:12px 14px 14px}
.news-card__title{margin:0 0 6px;font-size:16px;line-height:1.25}
.news-card__title a{color:#fff;text-decoration:none}
.news-card__title a:hover{color:var(--accent)}
.news-card__meta{font-size:12px;color:rgba(255,255,255,.65);margin-bottom:8px}
.news-card__excerpt{margin:0;color:rgba(255,255,255,.78);font-size:13px;line-height:1.35;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;min-height:3.9em;
}

.news-more{display:flex;justify-content:center;margin:22px 0 8px}
@media (max-width: 980px){
  .news-featured{grid-template-columns:1fr}
  .news-featured__media{min-height:240px}
  .news-grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 640px){
  .news-grid{grid-template-columns:1fr}
}

/* --- News detail (pro) --- */
.news-full-pro{
  --accent:#4aa3ff;
  border-radius:22px;
  background: rgba(10,14,24,.78);
  border:3px solid rgba(255,255,255,.08);
  box-shadow:0 22px 55px rgba(0,0,0,.48);
  overflow:hidden;
  position:relative;
}
.news-full-pro::before{
  content:"";
  position:absolute;inset:0;
  border:3px solid var(--accent);
  border-radius:22px;
  opacity:.55;
  pointer-events:none;
}
.news-full-pro__head{
  padding:20px 22px 16px;
  background: radial-gradient(900px 260px at 30% 0%, rgba(255,255,255,.10), transparent 60%);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.news-full-pro__title{
  margin:10px 0 8px;
  font-size:34px;
  line-height:1.12;
  color: var(--title, #fff);
  text-shadow:0 10px 28px rgba(0,0,0,.55);
}
.news-full-pro__meta{color:rgba(255,255,255,.72);font-size:13px}
.news-full-pro__hero{
  height:360px;
  background-size:cover;background-position:center;
  position:relative;
}
.news-full-pro__hero::after{
  content:"";
  position:absolute;inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.0) 0%, rgba(10,14,24,.78) 100%);
}
.news-full-pro__content{
  padding:18px 22px 22px;
  color:rgba(255,255,255,.88);
  line-height:1.65;
  font-size:16px;
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif;
}
.news-full-pro__content h2{margin:18px 0 10px;font-size:22px}
.news-full-pro__content h3{margin:14px 0 8px;font-size:18px}
.news-full-pro__content p{margin:0 0 12px}
.news-full-pro__content ul, .news-full-pro__content ol{margin:0 0 12px 22px}
.news-full-pro__content ul{list-style: disc}
.news-full-pro__content li{margin:6px 0}
.news-full-pro__content a{color:var(--accent);text-decoration:none}
.news-full-pro__content a:hover{text-decoration:underline}
.news-full-pro__content blockquote{
  margin:14px 0;padding:12px 14px;
  border-left:4px solid var(--accent);
  background:rgba(255,255,255,.06);
  border-radius:14px;
  color:rgba(255,255,255,.86);
}

/* YouTube embeds inside news */
.yt-embed{position:relative;margin:14px 0;padding-top:56.25%;border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.10);box-shadow:0 18px 50px rgba(0,0,0,.45);background:#0b0f1a}
.yt-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.yt-embed__bar{position:absolute;left:10px;top:10px;z-index:2}
.yt-embed__link{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:rgba(0,0,0,.38);border:1px solid rgba(255,255,255,.14);color:#fff;text-decoration:none;font-weight:700;font-size:13px;backdrop-filter:blur(8px)}
.yt-embed__link:hover{filter:brightness(1.12)}

/* YouTube lightweight embed (thumbnail + play -> iframe) */
.yt-lite{position:relative;margin:14px 0;aspect-ratio:16/9;border-radius:18px;overflow:hidden;
  border:2px solid rgba(255,255,255,.16);box-shadow:0 18px 60px rgba(0,0,0,.55);
  background:#0b0f1a;
  background-size:cover;
  background-position:center;
}
.yt-lite{transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease}
.yt-lite:hover{transform:translateY(-2px);box-shadow:0 26px 90px rgba(0,0,0,.65), 0 0 0 1px rgba(255,255,255,.08) inset;border-color:rgba(122,183,255,.38)}
.yt-lite::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(0,0,0,.38), rgba(0,0,0,.55));}
.yt-lite__open{position:absolute;top:12px;right:12px;z-index:3;display:inline-flex;align-items:center;gap:8px;
  padding:8px 12px;border-radius:999px;background:rgba(0,0,0,.38);border:1px solid rgba(255,255,255,.18);
  color:#fff;text-decoration:none;font-weight:800;font-size:13px;backdrop-filter:blur(10px)}
.yt-lite__open:hover{filter:brightness(1.12)}
.yt-lite__play{position:absolute;inset:0;margin:auto;z-index:3;width:92px;height:92px;border-radius:999px;
  border:1px solid rgba(255,255,255,.22);background:rgba(0,0,0,.35);backdrop-filter:blur(12px);
  box-shadow:0 10px 35px rgba(0,0,0,.55);cursor:pointer;
  transition:transform .14s ease, box-shadow .14s ease, filter .14s ease, background .14s ease, border-color .14s ease}

/* Hard fix: hide any stray play buttons that are NOT direct children of a .yt-lite card.
   Some legacy renders injected <button class="yt-lite__play"> next to the card, which created a double overlay.
   We default-hide all play buttons, and re-enable only the one inside the card. */
.yt-lite__play{display:none!important;}
.yt-lite > .yt-lite__play{display:block!important;}
/* Defensive: never show 2 play buttons (some browsers/content injections could duplicate nodes) */
.yt-lite__play + .yt-lite__play{display:none!important;}
.yt-lite button.yt-lite__play ~ button.yt-lite__play{display:none!important;}
.yt-lite.is-playing .yt-lite__play{display:none!important;}
.yt-lite:not(.is-playing) .yt-lite__play{animation:ytPulse 2.2s ease-in-out infinite}
@keyframes ytPulse{0%,100%{transform:scale(1);}50%{transform:scale(1.04);}}
.yt-lite:hover .yt-lite__play{transform:scale(1.05);filter:brightness(1.08);box-shadow:0 18px 52px rgba(0,0,0,.62);border-color:rgba(255,255,255,.30);background:rgba(0,0,0,.42)}
.yt-lite__play::before{content:"";display:block;margin-left:6px;width:0;height:0;border-top:16px solid transparent;
  border-bottom:16px solid transparent;border-left:26px solid #fff;}
.yt-lite__play:hover{filter:brightness(1.12);box-shadow:0 14px 45px rgba(0,0,0,.62);}
.yt-lite iframe{position:absolute;inset:0;width:100%;height:100%;border:0;z-index:2}
.news-full-pro__footer{padding:0 22px 22px}

/* --- Actualites layout (Dofus-like) --- */
.newsLayout{display:block;margin-top:18px}
.newsFeatured{display:block;position:relative;border-radius:20px;overflow:hidden;border:4px solid rgba(255,255,255,.12);box-shadow:0 24px 70px rgba(0,0,0,.55), 0 2px 0 rgba(255,255,255,.06) inset, inset 0 0 0 1px rgba(255,255,255,.08);text-decoration:none;transform:translateZ(0)}
.newsFeatured .newsMedia{height:320px;background-size:cover;background-position:center;filter:saturate(1.05)}
.newsFeatured .newsOverlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:22px;background:linear-gradient(to top, rgba(0,0,0,.78), rgba(0,0,0,.10))}
.newsFeatured h2{margin:10px 0 6px;font-size:34px;line-height:1.1}
.newsFeatured p{margin:0;max-width:70ch;opacity:.92}
.newsMeta{display:flex;gap:10px;align-items:center;font-size:13px;opacity:.9}
.newsMeta .badge.game{padding:.25rem .55rem;border-radius:999px;border:2px solid rgba(255,255,255,.18);background:rgba(0,0,0,.25);font-weight:700}
.newsMeta .date{opacity:.8}
.newsGrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:18px}
.newsCard{position:relative;border-radius:18px;overflow:hidden;border:4px solid rgba(255,255,255,.12);box-shadow:0 18px 46px rgba(0,0,0,.45), 0 2px 0 rgba(255,255,255,.06) inset, inset 0 0 0 1px rgba(255,255,255,.08);text-decoration:none;color:inherit;transform:translateZ(0);transition:transform .12s ease, box-shadow .12s ease}
.newsCard:hover{transform:translateY(-3px);box-shadow:0 24px 60px rgba(0,0,0,.55), 0 2px 0 rgba(255,255,255,.07) inset, inset 0 0 0 1px rgba(255,255,255,.10)}
.newsCard .thumb{height:130px;background-size:cover;background-position:center}
.newsCard .body{padding:12px 12px 14px}
.newsCard .title{margin-top:8px;font-weight:800;font-size:16px;line-height:1.2}
.newsCard .excerpt{margin-top:6px;font-size:13px;opacity:.85;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.moreWrap{display:flex;justify-content:center;margin:18px 0 8px}
.game-asa{border-color:rgba(86,168,255,.95)!important}
.game-ase{border-color:rgba(90,230,140,.95)!important}
.game-ark2{border-color:rgba(255,59,59,.95)!important}
.game-global{border-color:rgba(255,220,120,.70)!important}
@media (max-width: 980px){.newsGrid{grid-template-columns:repeat(2,minmax(0,1fr))}.newsFeatured .newsMedia{height:280px}}
@media (max-width: 620px){.newsGrid{grid-template-columns:1fr}.newsFeatured h2{font-size:26px}.newsFeatured .newsMedia{height:220px}}

/* Actualites: keep news images clean (no dark filters/gradients on media) */
.page--actualites .newsFeatured .newsMedia{filter:none}
.page--actualites .newsFeatured .newsOverlay{background:transparent}
.page--actualites .news-featured__media::after,
.page--actualites .news-card__media::after{background:none}

/* Featured news readability: keep image clear while improving text contrast */
.page--actualites .newsFeatured .newsOverlay{position:absolute;isolation:isolate}
.page--actualites .newsMeta{font-size:17px}
.page--actualites .newsMeta .badge.game{font-size:.9em}
.page--actualites .newsMeta .date{font-size:.95em}
.page--actualites .newsMeta .cmt{font-size:.95em}
.page--actualites .newsCard .excerpt{
  font-size:16.2px;
  line-height:1.45;
}
.page--actualites .newsFeatured p{font-size:17.6px}
.page--actualites .newsFeatured .newsOverlay::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:0;
  background:linear-gradient(
    to top,
    rgba(0,0,0,.68) 0%,
    rgba(0,0,0,.50) 34%,
    rgba(0,0,0,.18) 62%,
    rgba(0,0,0,0) 100%
  );
}
.page--actualites .newsFeatured .newsOverlay > *{position:relative;z-index:1}
.page--actualites .newsFeatured h2{
  text-shadow:
    0 2px 14px rgba(0,0,0,.90),
    0 1px 2px rgba(0,0,0,.75);
}
.page--actualites .newsFeatured p{
  text-shadow:0 1px 8px rgba(0,0,0,.85);
}
.page--actualites .newsFeatured .newsMeta{
  text-shadow:0 1px 8px rgba(0,0,0,.85);
}

/* --- V20.6 Actualites immersive background --- */
.page--actualites{position:relative;z-index:0}
.page--actualites .container{position:relative;z-index:2}
.actualitesBg{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;background:#070a12}
.actualitesBg__media{position:absolute;inset:-2%;width:104%;height:104%;object-fit:cover;transform:scale(1.03);filter:saturate(1.05)}
.actualitesBg__media[style]{background-size:cover;background-position:center}
.actualitesBg__overlay{position:absolute;inset:0;
  background:
    radial-gradient(80% 60% at 50% 25%, rgba(34,54,105,.55), rgba(0,0,0,0) 60%),
    radial-gradient(70% 60% at 20% 10%, rgba(80,50,140,.35), rgba(0,0,0,0) 55%),
    linear-gradient(180deg, rgba(0,0,0,.65), rgba(0,0,0,.86) 35%, rgba(0,0,0,.92));
  backdrop-filter: blur(2px);
}

.actualitesAdmin{display:flex;justify-content:flex-end;align-items:center;gap:10px;flex-wrap:wrap;margin:8px 0 -8px}
.actualitesAdmin .btn{backdrop-filter:blur(10px)}

/* Minimal modal (scoped) */
.aModal{position:fixed;inset:0;z-index:1200;display:none}
.aModal.is-open{display:block}
.aModal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.65)}
.aModal__panel{position:relative;max-width:680px;margin:10vh auto 0; background:rgba(15,20,35,.82);
  border:1px solid rgba(255,255,255,.14);border-radius:22px;box-shadow:0 30px 120px rgba(0,0,0,.65);
  padding:18px 18px 16px;backdrop-filter:blur(18px)}
.aModal__head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:14px}
.aModal__title{font-weight:900;font-size:18px}
.aModal__sub{margin-top:4px}
.aForm{display:flex;flex-direction:column;gap:12px}
.aRow{display:flex;flex-direction:column;gap:6px}
.aLabel{font-size:13px;opacity:.9}
.aSelect,.aFile{width:100%;padding:10px 12px;border-radius:14px;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);color:#fff}
.aCropper{position:relative;height:170px;border-radius:14px;overflow:hidden;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.04);cursor:grab;user-select:none}
.aCropper.is-dragging{cursor:grabbing}
.aCropper__media{position:absolute;inset:0;background-size:cover;background-position:50% 50%;transform:scale(1.04)}
.aCropper__overlay{position:absolute;left:10px;right:10px;bottom:10px;padding:6px 10px;border-radius:10px;background:rgba(0,0,0,.42);font-size:12px;color:rgba(255,255,255,.92);pointer-events:none}
.aCropper__actions{display:flex;justify-content:flex-end;margin-top:8px}
.aRow--actions{display:flex;gap:10px;justify-content:flex-end;margin-top:6px}
@media (max-width: 720px){.aModal__panel{margin:8vh 14px 0}}


/* News detail readability */
.news-full-pro__content{
  line-height: 1.65;
  font-size: 16px;
}
.news-full-pro__content a{
  word-break: break-word;
  overflow-wrap: anywhere;
}
.news-full-pro__footer{
  display:flex;
  gap:12px;
  align-items:center;
}
.news-full-pro__footer .btn.primary{
  border: 1px solid rgba(120,180,255,.65);
  box-shadow: 0 8px 24px rgba(40,120,255,.15);
}



/* --- Profile (Gestion de compte) -------------------------------------- */
.profile__header{display:flex;align-items:center;gap:16px;margin-bottom:18px;}
.profile__avatarWrap{position:relative;width:72px;height:72px;}
.profile__avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.04);}
.profile__avatarBtn{position:absolute;right:-4px;bottom:-4px;width:28px;height:28px;border-radius:999px;display:grid;place-items:center;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);cursor:pointer;font-weight:900;}
.profile__avatarBtn:hover{background:rgba(255,255,255,.12);}
.profile__card{padding:18px;}
.profile__cardTitle{margin:0 0 10px;font-size:18px;}
.profileRows{display:flex;flex-direction:column;}
.profileRow{display:grid;grid-template-columns:140px 1fr 44px;gap:12px;align-items:center;padding:12px 8px;border-top:1px solid rgba(255,255,255,.06);}
.profileRow:first-child{border-top:none;}
.profileRow__label{color:rgba(255,255,255,.8);font-weight:800;}
.profileRow__value{color:rgba(255,255,255,.92);font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.profileRow__action{justify-self:end;}
.profileRow--wideAction{grid-template-columns:140px 1fr auto;}
.profileRow__actionBtn{justify-self:end;white-space:nowrap;padding:8px 12px;min-height:36px;}
.pwdTrap{position:absolute;left:-10000px;top:auto;width:1px;height:1px;opacity:0;pointer-events:none;}
.pwdInlineError{margin:4px 0 0;color:#ff7f7f;font-size:12px;font-weight:700;}
.pwdPendingState{display:flex;align-items:center;gap:10px;margin-top:4px;padding:10px 12px;border-radius:12px;border:1px solid rgba(107,214,255,.35);background:rgba(107,214,255,.10);color:#dff3ff;font-size:12px;font-weight:700;}
.pwdPendingState[hidden]{display:none !important;}
.pwdSpinner{width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.35);border-top-color:#6bd6ff;animation:pwdSpin .9s linear infinite;flex:0 0 14px;}
@keyframes pwdSpin{to{transform:rotate(360deg);}}
.notice{margin:12px 0;padding:12px 14px;border-radius:14px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.04);}
.notice.is-ok{border-color:rgba(110,231,183,.25);background:rgba(110,231,183,.08);}
.notice.is-err{border-color:rgba(255,99,99,.25);background:rgba(255,99,99,.08);}
.profile__footer{margin-top:16px;display:flex;justify-content:flex-end;}

@media (max-width: 720px){
  .profile__header{align-items:flex-start;}
  .profileRow{grid-template-columns:110px 1fr 44px;}
  .profileRow--wideAction{grid-template-columns:110px 1fr auto;}
}


/* Comment count badge on news cards */
.newsMeta .cmt{margin-left:10px; font-size:12px; color:rgba(255,255,255,.8); display:inline-flex; align-items:center; gap:6px;}
.newsMeta .cmtIcon{filter:drop-shadow(0 1px 1px rgba(0,0,0,.45));}


/* Simple modal (profile password) */
.modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center}
.modal[hidden]{display:none}
.modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.65)}
.modal__panel{position:relative;max-width:520px;width:calc(100% - 24px);background:rgba(18,18,22,.98);border:1px solid rgba(255,255,255,.08);border-radius:16px;box-shadow:0 10px 30px rgba(0,0,0,.45);overflow:hidden}
.modal__head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.06)}
.modal__head h3{margin:0;font-size:16px}
.modal__body{padding:14px 16px;display:grid;gap:10px}
.modal__foot{padding:12px 16px;border-top:1px solid rgba(255,255,255,.06);display:flex;gap:10px;justify-content:flex-end}
.field{display:grid;gap:6px}
.field span{font-size:12px;color:rgba(255,255,255,.75)}
.field input{height:40px;border-radius:12px;border:1px solid rgba(255,255,255,.10);background:rgba(0,0,0,.25);color:#fff;padding:0 12px;outline:none}
.field input:focus{border-color:rgba(255,200,80,.5)}
.field input:-webkit-autofill,
.field input:-webkit-autofill:hover,
.field input:-webkit-autofill:focus{
  -webkit-text-fill-color:#fff !important;
  box-shadow:0 0 0 1000px rgba(0,0,0,.25) inset !important;
  border:1px solid rgba(255,255,255,.10) !important;
}
.field input:-moz-autofill,
.field input:-moz-autofill:focus{
  color:#fff !important;
  box-shadow:0 0 0 1000px rgba(0,0,0,.25) inset !important;
  border:1px solid rgba(255,255,255,.10) !important;
}
.small{font-size:12px}

/* Immersive background (shared with /actualites) */
.actualites-bg{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.actualites-bg__media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1.04);filter:blur(6px) brightness(1.05) contrast(1.1) saturate(1.08)}
.actualites-bg__overlay{position:absolute;inset:0;background:radial-gradient(ellipse at center, rgba(0,0,0,.25) 0%, rgba(0,0,0,.55) 70%), linear-gradient(to bottom, rgba(0,0,0,.55), rgba(0,0,0,.85))}

/* --- Auth modal visibility: rely on aria-hidden (robust against stray .is-open) --- */
.modal[aria-hidden="true"]{ display:none !important; }
.modal[aria-hidden="false"]{ display:grid !important; }
.modal[aria-hidden="false"]{ display:grid !important; }


/* V21.4.15 - Square avatars (topbar + comments) */
.userMenu__avatar, .userPill__avatar, .comment__avatar, .profile__avatar, .avatar {
  border-radius: 10px !important;
}


/* Keep topbar aligned and always above overlays */
.topbar{ position: sticky; top:0; z-index: 500; }


/* Smooth immersive overlay (reduce visible horizontal band) */
.actualites-bg__overlay{
  background:
    radial-gradient(ellipse at 50% 30%,
      rgba(0,0,0,.12) 0%,
      rgba(0,0,0,.32) 45%,
      rgba(0,0,0,.60) 78%,
      rgba(0,0,0,.86) 100%
    ),
    linear-gradient(to bottom,
      rgba(0,0,0,.55) 0%,
      rgba(0,0,0,.50) 35%,
      rgba(0,0,0,.58) 70%,
      rgba(0,0,0,.88) 100%
    );
}
.actualites-bg__overlay::after{
  content:'';
  position:absolute;
  inset:0;
  opacity:0.035;
  mix-blend-mode: overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='120' height='120' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E");
  background-size:120px 120px;
  pointer-events:none;
}


/* V21.4.16 strong fixes (apply everywhere) */
.topbar{ position:sticky !important; top:0 !important; z-index:9999 !important; }
.topbar, .nav, header{ transform:none !important; }

/* Prevent content from sliding under sticky topbar on pages with large fixed backgrounds */
main{ padding-top: 10px; }
@media (max-width: 768px){ main{ padding-top: 8px; } }

/* Square user avatar everywhere (including letter bubbles) */
.userMenu__avatar, .userPill__avatar, .comment__avatar, .profile__avatar, .avatar,
.userMenu__bubble, .userPill__bubble, .comment__avatarBubble {
  border-radius: 10px !important;
}

/* Ensure username always visible in topbar dropdown */
.userMenu__name, .userPill__name{ display:inline-flex !important; }


/* Ensure immersive bg visible on pages that render it */
.has-imm-bg .actualites-bg{ display:block !important; }
.has-imm-bg .actualites-bg__media{ display:block !important; }
.has-imm-bg .actualites-bg__overlay{ display:block !important; position:absolute; inset:0; }


/* V21.4.19 - Topbar fixed (always visible) */
.topbar{
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  z-index: 9999 !important;
}
/* Reserve space so content doesn't hide under topbar */
main{
  padding-top: 78px !important;
}
@media (max-width: 768px){
  main{ padding-top: 70px !important; }
}
/* V21.4.19 - Square user avatar everywhere */
.user-menu__avatar, .comment__avatar, .profile__avatar, .avatar{
  border-radius: 10px !important;
}
/* Ensure username is visible everywhere */
.user-menu__name{
  display: inline-flex !important;
  visibility: visible !important;
  opacity: 1 !important;
}


/* V21.4.20 - Topbar fixed + dropdown usable */
.topbar{
  position: fixed !important;
  top: 0 !important; left:0 !important; right:0 !important;
  z-index: 10000 !important;
  overflow: visible !important;
}
.topbar__inner{ overflow: visible !important; }

/* Reserve exact space so content starts right under topbar (no extra bar) */
:root{ --topbar-h: 64px; }
.topbar{ height: var(--topbar-h) !important; border-bottom: none !important; box-shadow: none !important; }
main{ padding-top: var(--topbar-h) !important; }
@media (max-width: 768px){
  :root{ --topbar-h: 60px; }
  main{ padding-top: var(--topbar-h) !important; }
}

/* Square avatars everywhere (force override) */
.user-menu__avatar,
.user-menu__btn .user-menu__avatar,
.comment__avatar,
.profile__avatar,
.avatar{
  border-radius: 10px !important;
}

/* Ensure the user menu button stays clickable above overlays */
.user-menu, .user-menu__btn, .user-menu__panel{ position: relative; z-index: 10001; }

main, .page, .container, .section, .card{ position:relative; z-index:1; }


/* YouTube lite thumb */
.yt-lite{
  position: relative;
  background-size: cover;
  background-position: center;
  overflow: hidden;
}
.yt-lite__thumb{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
  opacity: .95;
}
.yt-lite__play{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  width:74px;
  height:74px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.35);
  backdrop-filter: blur(6px);
  cursor:pointer;
}
.yt-lite__play::before{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-40%,-50%);
  width:0;
  height:0;
  border-left: 18px solid rgba(255,255,255,.95);
  border-top: 12px solid transparent;
  border-bottom: 12px solid transparent;
}

/* Profile tabs + guides list */
.profileTabs{
  display:flex;
  gap:8px;
  margin: 12px 0 16px;
  flex-wrap:wrap;
}
.profileTabBtn{
  appearance:none;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  color: var(--text);
  padding:10px 14px;
  border-radius: 12px;
  font-weight:700;
  cursor:pointer;
}
.profileTabBtn.is-active{
  border-color: rgba(255,255,255,.20);
  background: rgba(255,255,255,.10);
}
.profileTab{ display:none; }
.profileTab.is-active{ display:block; }

.ogOnboarding{
  display:flex;
  justify-content:center;
}
.ogOnboarding__card{
  width:min(760px, calc(100vw - 32px));
  padding:20px;
}
.ogOnboarding__title{
  margin:0 0 8px;
  font-size:28px;
  line-height:1.1;
}
.ogOnboarding__form{
  display:grid;
  gap:12px;
  margin-top:14px;
}
.ogOnboarding__check{
  display:flex;
  align-items:flex-start;
  gap:10px;
  color:rgba(233,238,252,.92);
  font-size:14px;
}
.ogOnboarding__check input{
  margin-top:2px;
}
.ogOnboarding__actions{
  display:flex;
  justify-content:flex-end;
}
.ogOnboarding__emailPlain{
  color:#fff;
  font-weight:800;
  font-size:15px;
  line-height:1.45;
}
.ogGateModal{
  z-index: 22000 !important;
}
.ogGateModal .modal__backdrop{
  background: rgba(0,0,0,.78);
  backdrop-filter: blur(6px);
}
.ogGateModal .modal__panel{
  width: min(680px, calc(100% - 24px));
}
.ogGateModal .modal__head{
  justify-content: center;
  align-items: center;
  flex-direction: column;
  gap: 8px;
}
.ogGateModal .modal__head h3{
  font-size: 24px;
}
.ogOnboarding__brand{
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.ogOnboarding__brandLogo{
  width: 28px;
  height: 28px;
  object-fit: contain;
}
.ogOnboarding__brandText{
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(233,238,252,.96);
}

.guideStats{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:12px;
}
.guideStat{
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius: 12px;
  padding:12px;
}
.guideStat__label{ color:var(--muted); font-size:12px; text-transform:uppercase; letter-spacing:.14em; }
.guideStat__value{ font-size:20px; font-weight:900; margin-top:4px; }

.guideList{ display:grid; gap:10px; }
.guideRow{
  display:grid;
  grid-template-columns: 110px 1fr auto;
  gap:12px;
  align-items:center;
  padding:12px;
  border:1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  background: rgba(255,255,255,.03);
}
.guideRow__thumb{
  width:110px;
  height:66px;
  border-radius:10px;
  background-size:cover;
  background-position:center;
  border:1px solid rgba(255,255,255,.12);
}
.guideRow__title{ font-weight:900; }
.guideRow__excerpt{ color:var(--muted); font-size:13px; margin-top:4px; }
.guideRow__meta{ display:flex; gap:6px; flex-wrap:wrap; margin-top:6px; }
.badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:4px 8px;
  border-radius:999px;
  font-size:12px;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
}
.badge--status{
  background: rgba(107,214,255,.14);
  border-color: rgba(107,214,255,.35);
}
.badge--status-draft{ background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.12); }
.badge--status-pending{ background: rgba(245,158,11,.18); border-color: rgba(245,158,11,.45); }
.badge--status-rejected{ background: rgba(255,107,107,.18); border-color: rgba(255,107,107,.45); }
.badge--status-validated,
.badge--status-published{ background: rgba(87,209,140,.18); border-color: rgba(87,209,140,.45); }
.guideRow__note{
  margin-top:6px;
  font-size:12px;
  color:var(--muted);
}
.guideRow__note.is-rejected{ color: #ff8b8b; }
.guideRow__note.is-validated{ color: #7ee3b3; }
.guideRow__noteBtn{
  margin-left:8px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.25);
  color: var(--text);
  font-size: 11px;
  padding: 4px 8px;
  border-radius: 999px;
  cursor: pointer;
}
.guideRow__noteBtn:hover{ border-color: rgba(87,209,140,.25); }
.guideRow__actions{ display:flex; gap:8px; }
.guideRow__deleteForm{ margin:0; }
.guideRow__deleteBtn{
  border-color: rgba(245, 132, 132, .40);
  color: #ffd7d7;
}
.guideRow__deleteBtn:hover{
  border-color: rgba(255, 156, 156, .60);
  background: rgba(122, 31, 31, .28);
}

@media (max-width: 900px){
  .guideStats{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .guideRow{ grid-template-columns: 90px 1fr; }
  .guideRow__actions{ grid-column: 1 / -1; }
}
@media (max-width: 600px){
  .guideStats{ grid-template-columns: 1fr; }
}

/* Profile premium refresh (futuristic, no layout rewrite) */
.section.profile{
  max-width: 1120px;
  margin-inline: auto;
}
.profileTitle{
  margin: 0;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  letter-spacing: .02em;
}
.profileTitle__icon{
  width: 26px;
  height: 26px;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #8fd9ff;
  background: linear-gradient(145deg, rgba(34,211,238,.22), rgba(124,58,237,.18));
  border: 1px solid rgba(143,217,255,.35);
}
.profileTitle__icon svg{ width: 16px; height: 16px; display:block; }

.profile__header{
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(126, 162, 255, .20);
  background:
    linear-gradient(180deg, rgba(16,24,38,.82), rgba(11,16,28,.78));
  box-shadow: 0 14px 34px rgba(4,8,16,.38);
}
.profile__avatar{
  border-radius: 16px;
  border: 1px solid rgba(118,184,255,.35);
  box-shadow: 0 8px 26px rgba(36,110,185,.28);
}
.profile__avatarBtn{
  border-color: rgba(128,200,255,.38);
  background: rgba(14,29,52,.84);
  color: #dcecff;
}
.profile__avatarBtn svg{
  width: 14px;
  height: 14px;
  display: block;
}
.profile__avatarBtn:hover{
  background: rgba(28,46,74,.92);
}

.profileTabBtn{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-radius: 12px;
  border-color: rgba(122, 169, 255, .25);
  background: rgba(14,22,36,.78);
  color: rgba(225,236,255,.92);
}
.profileTabBtn__icon{
  width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #8fd9ff;
}
.profileTabBtn__icon svg{ width: 16px; height: 16px; display: block; }
.profileTabBtn.is-active{
  border-color: rgba(124,58,237,.65);
  background: linear-gradient(145deg, rgba(34,211,238,.18), rgba(124,58,237,.22));
  box-shadow: 0 8px 24px rgba(90,94,240,.22);
}

.profile__card{
  border-radius: 18px;
  border: 1px solid rgba(124, 158, 255, .20);
  background: linear-gradient(180deg, rgba(14,21,35,.82), rgba(8,12,22,.82));
  box-shadow: 0 14px 34px rgba(2,6,14,.36);
}
.profile__cardTitle{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: rgba(233,243,255,.98);
}
.profile__cardTitle--center{
  width: 100%;
  justify-content: center;
}
.profileCardIcon{
  width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #78cfff;
}
.profileCardIcon svg{ width: 16px; height: 16px; display:block; }

.profileRow{
  border-top: 0;
  border: 1px solid rgba(122, 162, 235, .22);
  border-radius: 14px;
  padding: 13px 12px;
  background: linear-gradient(180deg, rgba(18,30,50,.62), rgba(12,20,36,.58));
}
.profileRow + .profileRow{ margin-top: 8px; }
.profileRow[hidden]{
  display: none !important;
}
.profileRow__label{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: rgba(193,212,236,.94);
  letter-spacing: .01em;
  font-size: 14px;
  font-weight: 800;
}
.profileRow__icon{
  width: 16px;
  height: 16px;
  color: #8fd9ff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 16px;
}
.profileRow__icon svg{ width: 15px; height: 15px; display: block; }
.profileRow__value{
  color: rgba(241,247,255,.98);
  font-size: 15px;
  font-weight: 800;
  line-height: 1.35;
  white-space: normal;
  overflow: visible;
  text-overflow: unset;
  word-break: break-word;
}
.profileRow__actions{
  justify-self: end;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.profileRow__action.iconbtn{
  width: 36px;
  height: 36px;
  border-radius: 10px;
  border: 1px solid rgba(117,169,255,.35);
  background: rgba(20,36,62,.82);
  color: #bfe4ff;
}
.profileRow__action.iconbtn svg{
  width: 16px;
  height: 16px;
  display: block;
  margin: 0 auto;
}
.modal .iconbtn svg{
  width: 14px;
  height: 14px;
  display: block;
  margin: 0 auto;
}
.profileRow__action.iconbtn:hover{
  background: rgba(32,52,84,.92);
}

.profileRow__actionBtn{
  border-color: rgba(122, 174, 255, .34);
  background: rgba(20,34,58,.70);
}
.profileRow__actionBtn:hover{
  border-color: rgba(124,58,237,.55);
  background: rgba(38,48,78,.82);
}
.profileInfoBtn{
  position: relative;
  width: 32px;
  height: 32px;
  border-radius: 999px;
  border: 1px solid rgba(126, 174, 255, .44);
  background: rgba(16, 34, 60, .82);
  color: #c8e7ff;
  font-weight: 900;
  font-size: 12px;
  line-height: 1;
}
.profileInfoBtn:hover{
  background: rgba(32, 52, 84, .92);
}
.profileInfoBtn::after{
  content: attr(data-tooltip);
  position: absolute;
  left: 50%;
  top: calc(100% + 10px);
  transform: translateX(-50%) translateY(-4px);
  min-width: 220px;
  max-width: 300px;
  padding: 9px 10px;
  border-radius: 10px;
  border: 1px solid rgba(130,175,255,.38);
  background: rgba(10,20,38,.96);
  color: #e8f4ff;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.35;
  text-align: left;
  opacity: 0;
  pointer-events: none;
  z-index: 25;
  box-shadow: 0 14px 40px rgba(3,8,16,.58);
  transition: opacity .16s ease, transform .16s ease;
}
.profileInfoBtn::before{
  content: "";
  position: absolute;
  left: 50%;
  top: calc(100% + 5px);
  width: 10px;
  height: 10px;
  transform: translateX(-50%) rotate(45deg);
  border-top: 1px solid rgba(130,175,255,.38);
  border-left: 1px solid rgba(130,175,255,.38);
  background: rgba(10,20,38,.96);
  opacity: 0;
  pointer-events: none;
  z-index: 24;
  transition: opacity .16s ease;
}
.profileInfoBtn:hover::after,
.profileInfoBtn:focus-visible::after{
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}
.profileInfoBtn:hover::before,
.profileInfoBtn:focus-visible::before{
  opacity: 1;
  transform: translateX(-50%) rotate(45deg);
}

#profBirthdate{
  font-size: 15px;
  font-weight: 800;
  color: rgba(241,247,255,.98);
  letter-spacing: .01em;
}

.profileLogoutBtn{
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.profileLogoutBtn__icon{
  width: 16px;
  height: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #ffb6b6;
}
.profileLogoutBtn__icon svg{ width: 15px; height: 15px; display: block; }

.guideStat{
  border-color: rgba(122,165,240,.22);
  background: linear-gradient(180deg, rgba(20,32,52,.64), rgba(14,22,38,.62));
}
.guideStat__label{ color: rgba(167,193,225,.84); }
.guideStat__value{ color: rgba(240,247,255,.98); }

.guideRow{
  border-color: rgba(120,160,232,.20);
  background: linear-gradient(180deg, rgba(17,28,44,.66), rgba(12,19,32,.62));
}
.guideRow__title{ color: rgba(239,246,255,.98); }
.guideRow__excerpt{ color: rgba(178,200,230,.88); }

.securityBox{
  margin-top: 12px;
  border: 1px solid rgba(122, 162, 235, .22);
  border-radius: 12px;
  background: rgba(12, 20, 36, .55);
  padding: 12px;
}
.securityBox__title{
  font-size: 14px;
  font-weight: 900;
  color: rgba(230, 242, 255, .96);
  margin-bottom: 8px;
}
.securityKey{
  margin: 8px 0;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px dashed rgba(132, 180, 255, .42);
  background: rgba(9, 16, 30, .75);
  color: #f0f7ff;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  word-break: break-all;
}
.securityQrWrap{
  margin: 10px 0 8px;
  padding: 10px;
  border: 1px solid rgba(132, 180, 255, .24);
  border-radius: 10px;
  background: rgba(9, 16, 30, .68);
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.securityQrCode{
  width: 196px;
  height: 196px;
  padding: 6px;
  border-radius: 8px;
  background: #0b1322;
  display: grid;
  place-items: center;
  cursor: zoom-in;
  transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.securityQrCode:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(0,0,0,.28);
}
.securityQrCode:focus-visible{
  outline: none;
  box-shadow: 0 0 0 3px rgba(72, 201, 255, .22), 0 10px 18px rgba(0,0,0,.28);
}
.securityQrCode img,
.securityQrCode canvas{
  display: block;
  width: 184px !important;
  height: 184px !important;
}
.securityQrHint{
  font-size: 12px;
  text-align: center;
}
.securityLine{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.securityBackupCodes{
  margin: 8px 0;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(132, 180, 255, .24);
  background: rgba(9, 16, 30, .7);
  color: #ecf6ff;
  font-size: 13px;
  line-height: 1.55;
  white-space: pre-wrap;
}
.securityToggle{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: rgba(220, 236, 255, .92);
  font-weight: 800;
}
.securitySessions{
  margin-top: 14px;
}
.securitySessions__head{
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 8px;
}
.securitySessions__list{
  display: grid;
  gap: 8px;
}
.securitySession{
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  border: 1px solid rgba(122, 162, 235, .18);
  border-radius: 10px;
  padding: 10px 12px;
  background: rgba(10, 18, 32, .54);
}
.securitySession__title{
  font-size: 13px;
  font-weight: 800;
  color: rgba(233, 244, 255, .96);
}
.securitySession__meta{
  font-size: 12px;
  color: rgba(184, 207, 236, .86);
}
.modal__head--withBack{
  display: grid;
  grid-template-columns: 36px 1fr 36px;
  align-items: center;
}
.modalBackBtn{
  justify-self: start;
}
.birthdateGrid{
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 8px;
}
#identityModal .modal__panel,
#birthdateModal .modal__panel,
#mobileModal .modal__panel,
#addressModal .modal__panel,
#mfaDisableModal .modal__panel{
  border-radius: 18px;
  border: 1px solid rgba(120,170,255,.24);
  background:
    radial-gradient(120% 120% at 0% 0%, rgba(67,120,255,.18), transparent 55%),
    radial-gradient(100% 100% at 100% 0%, rgba(36,206,255,.13), transparent 52%),
    linear-gradient(180deg, rgba(12,20,34,.98), rgba(8,14,26,.98));
  box-shadow: 0 30px 70px rgba(2,6,14,.62);
}
#identityModal .modal__head h3,
#birthdateModal .modal__head h3,
#mobileModal .modal__head h3,
#addressModal .modal__head h3,
#mfaDisableModal .modal__head h3{
  font-size: 18px;
  font-weight: 900;
  letter-spacing: .02em;
}
#identityModal .field span,
#birthdateModal .field span,
#mobileModal .field span,
#addressModal .field span,
#mfaDisableModal .field span{
  font-size: 13px;
  font-weight: 800;
  color: rgba(217,233,252,.92);
  letter-spacing: .02em;
}
#identityModal .field input,
#birthdateModal .field select,
#mobileModal .field input,
#addressModal .field input,
#addressModal .field select,
#identityModal .field select,
#mfaDisableModal .field input{
  min-height: 48px;
  border-radius: 12px;
  border: 1px solid rgba(132,180,255,.30);
  background: linear-gradient(180deg, rgba(16,33,57,.86), rgba(10,22,41,.86));
  color: #f2f8ff;
  font-size: 15px;
  font-weight: 700;
  padding: 0 13px;
  outline: none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}
#birthdateModal .field select{
  font-size: 16px;
  font-weight: 800;
  min-height: 48px;
  letter-spacing: 0;
}
#birthdateModal .field span{
  font-size: 13px;
  font-weight: 800;
}
#birthdateModal .birthdateGrid{
  gap: 8px;
}
#birthdateModal .field select option{
  font-size: 15px;
}
#birthdateModal .modal__foot .btn{
  min-height: 40px;
  font-size: 14px;
  font-weight: 800;
}
#identityModal .field input::placeholder,
#mobileModal .field input::placeholder,
#addressModal .field input::placeholder,
#mfaDisableModal .field input::placeholder{
  color: rgba(188,208,236,.66);
}
#identityModal .field input:focus,
#birthdateModal .field select:focus,
#mobileModal .field input:focus,
#addressModal .field input:focus,
#addressModal .field select:focus,
#identityModal .field select:focus,
#mfaDisableModal .field input:focus{
  border-color: rgba(90,220,255,.72);
  box-shadow: 0 0 0 3px rgba(77,214,255,.17), inset 0 1px 0 rgba(255,255,255,.12);
}
#birthdateModal .field select,
#addressModal .field select,
#identityModal .field select{
  color-scheme: dark;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, #9cd9ff 50%),
    linear-gradient(135deg, #9cd9ff 50%, transparent 50%),
    linear-gradient(180deg, rgba(16,33,57,.86), rgba(10,22,41,.86));
  background-position:
    calc(100% - 18px) calc(50% - 3px),
    calc(100% - 12px) calc(50% - 3px),
    0 0;
  background-size: 6px 6px, 6px 6px, 100% 100%;
  background-repeat: no-repeat;
  padding-right: 34px;
}
#addressCountryCode{
  color-scheme: dark;
}
#addressCountryCode option{
  background: #122645;
  color: #ecf6ff;
  font-weight: 700;
}
#addressCountryCode option:checked{
  background: #245ea5;
  color: #ffffff;
}
#mfaDisableModal .modal__body .muted{
  margin: 0 0 4px;
  color: rgba(197, 214, 236, .88);
  font-size: 13px;
  line-height: 1.4;
}
#mfaDisableModal .modal__foot .btn{
  min-height: 40px;
  font-size: 14px;
  font-weight: 800;
}
#mfaQrModal{
  z-index: 26000;
}
#mfaQrModal .modal__backdrop{
  background:
    radial-gradient(62% 52% at 50% 20%, rgba(34, 211, 238, .14), transparent 75%),
    rgba(4, 8, 16, .82);
  backdrop-filter: blur(10px);
}
#mfaQrModal .mfaQrModal__panel{
  width: min(640px, calc(100vw - 28px));
  border-radius: 18px;
  border: 1px solid rgba(167, 196, 236, .30);
  background:
    radial-gradient(120% 110% at 0% 0%, rgba(66, 117, 190, .16), transparent 56%),
    linear-gradient(180deg, rgba(14, 22, 38, .98), rgba(10, 16, 28, .98));
  box-shadow: 0 28px 68px rgba(0,0,0,.58);
}
#mfaQrModal .mfaQrModal__head{
  padding: 14px 16px 12px;
}
#mfaQrModal .mfaQrModal__head h3{
  margin: 0;
  font-size: 17px;
  font-weight: 900;
  letter-spacing: .01em;
}
#mfaQrModal .mfaQrModal__body{
  padding: 4px 16px 16px;
  display: grid;
  gap: 12px;
}
#mfaQrModal .mfaQrModal__frame{
  margin: 0 auto;
  padding: 14px;
  border-radius: 14px;
  border: 1px solid rgba(166, 196, 238, .24);
  background: rgba(12, 22, 38, .76);
}
#mfaQrModal #mfaQrModalImg{
  display: block;
  width: min(420px, 76vw);
  height: auto;
  background: #0b1322;
  border-radius: 10px;
  box-shadow: inset 0 0 0 1px rgba(174, 205, 244, .12);
}
#mfaQrModal .mfaQrModal__hint{
  margin: 0;
  text-align: center;
  font-size: 13px;
  color: rgba(202, 218, 240, .88);
}
@media (max-width: 640px){
  .birthdateGrid{
    grid-template-columns: 1fr;
  }
  #birthdateModal .field select{
    min-height: 46px;
    font-size: 15px;
  }
  .profileInfoBtn::after{
    min-width: 170px;
    max-width: 220px;
  }
  #mfaQrModal #mfaQrModalImg{
    width: min(86vw, 360px);
  }
}

/* --- V25.5 Profile fixed-grid layout (Dofus-like) --- */
.section.profile,
#identityModal,
#birthdateModal,
#mobileModal,
#addressModal{
  font-family: "Inter", "Poppins", "Segoe UI", "SF Pro Text", Roboto, sans-serif;
}
.section.profile{
  --pf-card-bg: rgba(31, 40, 55, .90);
  --pf-line: rgba(156, 181, 216, .16);
  --pf-line-strong: rgba(166, 194, 232, .28);
  --pf-text: #eef4ff;
  --pf-muted: #b6c7df;
}
.section.profile .profile__header{
  margin-bottom: 10px;
  padding: 10px 12px;
  border-radius: 6px;
  border: 1px solid var(--pf-line-strong);
  background: rgba(32, 41, 56, .76);
  box-shadow: 0 1px 6px rgba(6, 10, 18, .18);
}
.section.profile .profile__avatarWrap{
  width: 96px;
  height: 96px;
}
.section.profile .profile__avatar{
  width: 96px;
  height: 96px;
  border-radius: 6px;
}
.section.profile .profile__avatarBtn{
  border-radius: 6px;
}
.section.profile .profileAvatarTrigger{
  position: absolute;
  inset: 0;
  border: 0;
  padding: 0;
  margin: 0;
  border-radius: 6px;
  background: transparent;
  overflow: hidden;
  cursor: pointer;
}
.section.profile .profileAvatarTrigger::before{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(5, 10, 18, .02), rgba(5, 10, 18, .62));
  opacity: 0;
  transition: opacity .18s ease;
}
.section.profile .profileAvatarTrigger__hint{
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  min-height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 8px;
  background: rgba(8, 12, 20, .88);
  color: #f4f8ff;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .07em;
  transform: translateY(100%);
  transition: transform .18s ease;
}
.section.profile .profile__avatarWrap:hover .profileAvatarTrigger::before,
.section.profile .profile__avatarWrap:focus-within .profileAvatarTrigger::before{
  opacity: 1;
}
.section.profile .profile__avatarWrap:hover .profileAvatarTrigger__hint,
.section.profile .profile__avatarWrap:focus-within .profileAvatarTrigger__hint{
  transform: translateY(0);
}
.section.profile .profileAvatarTrigger:focus-visible{
  outline: 2px solid rgba(132, 196, 255, .68);
  outline-offset: 2px;
}
.section.profile .profileTitle{
  font-size: 25px;
  line-height: 1.14;
}
.section.profile .profileTitle__icon{
  width: 36px;
  height: 36px;
}
.section.profile .profileTitle__icon svg{
  width: 22px;
  height: 22px;
}
.section.profile .profile__title .muted{
  font-size: 15px;
  color: var(--pf-muted);
}

.section.profile .profileTabs{
  margin-bottom: 10px;
  padding: 3px;
  border-radius: 6px;
  border: 1px solid var(--pf-line-strong);
  background: rgba(31, 40, 55, .60);
}
.section.profile .profileTabBtn{
  min-height: 36px;
  border-radius: 6px;
  border: 1px solid transparent;
  background: transparent;
  color: #d8e7ff;
  font-size: 16px;
  font-weight: 800;
}
.section.profile .profileTabBtn:hover{
  background: rgba(112, 138, 174, .16);
  border-color: rgba(158, 187, 225, .30);
}
.section.profile .profileTabBtn.is-active{
  border-color: rgba(162, 196, 242, .40);
  background: rgba(110, 146, 197, .24);
  box-shadow:0 6px 18px rgba(76,120,194,.14);
}
.section.profile .profileTab{
  display:none;
}
.section.profile .profileTab.is-active{
  display:block;
  animation:profileTabFade .2s ease both;
}

.section.profile .subscriptionSummaryCard{
  margin-top:14px;
  border-color:rgba(250,204,21,.16);
  background:
    radial-gradient(120% 120% at 100% 0%, rgba(250,204,21,.08), transparent 36%),
    rgba(255,255,255,.028);
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease;
  will-change:transform;
}
.section.profile .subscriptionSummaryCard:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 20px rgba(0,0,0,.35), 0 0 15px rgba(255,200,50,.15);
  border-color:rgba(250,204,21,.24);
}
.section.profile .subscriptionSummaryCard__head{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:14px;
  align-items:center;
}
.section.profile .subscriptionSummaryCard__title{
  margin:0 0 8px;
}
.section.profile .subscriptionSummaryCard__meta{
  min-width:0;
}
.section.profile .subscriptionSummaryCard__btn{
  min-height:42px;
  min-width:190px;
  border-radius:10px;
}
.section.profile .subscriptionTab{
  margin-top:0;
}

.section.profile .profileDangerZone{
  margin-top:14px;
}

@keyframes profileTabFade{
  from{
    opacity:0;
    transform:translateY(8px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}

.section.profile .profile__card{
  padding: 14px;
  border-radius: 6px;
  border: 1px solid var(--pf-line-strong);
  background: var(--pf-card-bg);
  box-shadow: 0 2px 8px rgba(6, 11, 20, .16);
}
.section.profile .profile__cardTitle{
  margin-bottom: 9px;
  font-size: 19px;
}

.section.profile .profileRows{
  border: 1px solid var(--pf-line);
  border-radius: 6px;
  background: rgba(255,255,255,.01);
  overflow: hidden;
}
.section.profile .profileRow,
.section.profile .profileRow--wideAction{
  margin: 0;
  min-height: 50px;
  border: 0;
  border-bottom: 1px solid var(--pf-line);
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  grid-template-columns: 220px minmax(0, 1fr) 160px;
  align-items: center;
  gap: 8px;
  padding: 7px 10px;
}
.section.profile .profileRow:last-child,
.section.profile .profileRow--wideAction:last-child{
  border-bottom: 0;
}
.section.profile .profileRow:hover,
.section.profile .profileRow--wideAction:hover{
  background: rgba(255,255,255,.015);
}
.section.profile .profileRow__label{
  color: #c4d3e9;
  font-size: 16px;
  font-weight: 800;
}
.section.profile .profileRow__value{
  color: var(--pf-text);
  font-size: 17px;
  font-weight: 700;
  line-height: 1.3;
  white-space: normal;
  overflow: visible;
  text-overflow: unset;
  word-break: break-word;
}
.section.profile .profileMembershipStatus{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.section.profile .profileMembershipStatus__badge{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:0 12px;
  border-radius:999px;
  border:1px solid rgba(166, 186, 212, .34);
  background:rgba(255,255,255,.06);
  color:#eef6ff;
  font-size:14px;
  font-weight:900;
  letter-spacing:.05em;
  text-transform:uppercase;
}
.section.profile .profileMembershipStatus__badge.is-premium{
  border-color:rgba(250, 204, 21, .58);
  background:linear-gradient(135deg, rgba(119, 83, 8, .34), rgba(250, 204, 21, .18));
  color:#fff1b3;
  box-shadow:0 0 14px rgba(250, 204, 21, .18);
}
.section.profile .profileMembershipStatus__meta{
  color:#c8d8ee;
  font-size:14px;
  font-weight:600;
}
.section.profile .profileSubscriptionCard{
  margin-top: 14px;
}
.section.profile .profileSubscriptionOverview{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:14px;
  align-items:center;
  padding:14px;
  border:1px solid var(--pf-line);
  border-radius:6px;
  background:rgba(255,255,255,.02);
}
.section.profile .profileSubscriptionOverview__main{
  display:grid;
  gap:8px;
}
.section.profile .profileSubscriptionOverview__status{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:28px;
  width:max-content;
  padding:0 12px;
  border-radius:999px;
  border:1px solid rgba(166,186,212,.34);
  background:rgba(255,255,255,.06);
  color:#eef6ff;
  font-size:13px;
  font-weight:900;
  letter-spacing:.05em;
  text-transform:uppercase;
}
.section.profile .profileSubscriptionOverview__status.is-premium{
  border-color:rgba(250,204,21,.58);
  background:linear-gradient(135deg, rgba(119,83,8,.34), rgba(250,204,21,.18));
  color:#fff1b3;
  box-shadow:0 0 14px rgba(250,204,21,.18);
}
.section.profile .profileSubscriptionOverview__status.is-soon{
  border-color:rgba(251,191,36,.56);
  background:linear-gradient(135deg, rgba(120,53,15,.34), rgba(251,191,36,.18));
  color:#fff2cc;
  box-shadow:0 0 14px rgba(251,191,36,.16);
}
.section.profile .profileSubscriptionOverview__status.is-expired{
  border-color:rgba(248,113,113,.38);
  background:rgba(127,29,29,.18);
  color:#ffd6d6;
}
.section.profile .profileSubscriptionOverview__title{
  color:#f3f7ff;
  font-size:20px;
  font-weight:900;
  line-height:1.25;
}
.section.profile .profileSubscriptionOverview__meta{
  color:#c8d8ee;
  font-size:14px;
  line-height:1.5;
}
.section.profile .profileSubscriptionOverview__state{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.section.profile .profileSubscriptionOverview__stateBadge{
  display:inline-flex;
  align-items:center;
  min-height:26px;
  padding:0 10px;
  border-radius:999px;
  border:1px solid rgba(166,186,212,.28);
  background:rgba(255,255,255,.05);
  color:#eef6ff;
  font-size:12px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.section.profile .profileSubscriptionOverview__stateBadge.is-premium{
  border-color:rgba(250,204,21,.48);
  background:rgba(250,204,21,.12);
  color:#fff4bf;
}
.section.profile .profileSubscriptionOverview__stateBadge.is-soon{
  border-color:rgba(251,191,36,.46);
  background:rgba(251,191,36,.12);
  color:#fff3d1;
}
.section.profile .profileSubscriptionOverview__stateBadge.is-expired{
  border-color:rgba(248,113,113,.38);
  background:rgba(127,29,29,.18);
  color:#ffd6d6;
}
.section.profile .profileSubscriptionOverview__stateText{
  color:#d4e0f1;
  font-size:13px;
  line-height:1.45;
}
.section.profile .profileSubscriptionOverview__actions{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
}
.section.profile .profileSubscriptionOverview__btn{
  min-height:40px;
}
.section.profile .profileSubscriptionOverview__btn--secondary{
  border-color:rgba(158,187,225,.34);
  background:rgba(255,255,255,.03);
}
.section.profile .profileSubscriptionGrid{
  margin-top:12px;
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:10px;
}
.section.profile .profileSubscriptionStat{
  display:grid;
  gap:6px;
  padding:12px;
  border:1px solid var(--pf-line);
  border-radius:6px;
  background:rgba(255,255,255,.02);
}
.section.profile .profileSubscriptionStat__label{
  color:#aebfd8;
  font-size:12px;
  font-weight:800;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.section.profile .profileSubscriptionStat__value{
  color:#f3f7ff;
  font-size:15px;
  font-weight:800;
  line-height:1.45;
}
.section.profile .profileSubscriptionBenefits{
  margin-top:14px;
}
.section.profile .profileSubscriptionBenefits__head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:10px;
}
.section.profile .profileSubscriptionBenefits__title{
  margin:0;
  color:#eef4ff;
  font-size:16px;
  font-weight:900;
}
.section.profile .profileSubscriptionBenefits__hint{
  color:#aebfd8;
  font-size:12px;
}
.section.profile .profileSubscriptionBenefits__grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:10px;
}
.section.profile .profileSubscriptionBenefit{
  display:grid;
  grid-template-columns:40px minmax(0,1fr);
  gap:10px;
  align-items:start;
  padding:12px;
  border:1px solid var(--pf-line);
  border-radius:6px;
  background:rgba(255,255,255,.02);
}
.section.profile .profileSubscriptionBenefit.is-active{
  border-color:rgba(250,204,21,.28);
  background:linear-gradient(180deg, rgba(250,204,21,.08), rgba(255,255,255,.02));
}
.section.profile .profileSubscriptionBenefit__icon{
  width:40px;
  height:40px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:12px;
  border:1px solid rgba(166,186,212,.24);
  background:rgba(255,255,255,.04);
  color:#fff1b3;
  font-size:18px;
  line-height:1;
}
.section.profile .profileSubscriptionBenefit__body{
  display:grid;
  gap:5px;
  min-width:0;
}
.section.profile .profileSubscriptionBenefit__title{
  color:#f4f8ff;
  font-size:14px;
  font-weight:800;
  line-height:1.35;
}
.section.profile .profileSubscriptionBenefit__text{
  color:#b9c9e0;
  font-size:13px;
  line-height:1.5;
}
.section.profile .profileSubscriptionHistory{
  margin-top:14px;
}
.section.profile .profileSubscriptionHistory__head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:10px;
}
.section.profile .profileSubscriptionHistory__title{
  margin:0;
  color:#eef4ff;
  font-size:16px;
  font-weight:900;
}
.section.profile .profileSubscriptionHistory__hint{
  color:#aebfd8;
  font-size:12px;
}
.section.profile .profileSubscriptionHistory__list{
  display:grid;
  gap:8px;
}
.section.profile .profileSubscriptionHistory__item{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:10px;
  align-items:center;
  padding:12px;
  border:1px solid var(--pf-line);
  border-radius:6px;
  background:rgba(255,255,255,.02);
}
.section.profile .profileSubscriptionHistory__itemMain{
  display:grid;
  gap:4px;
  min-width:0;
}
.section.profile .profileSubscriptionHistory__itemAction{
  color:#f4f8ff;
  font-size:15px;
  font-weight:800;
}
.section.profile .profileSubscriptionHistory__itemMeta{
  color:#aebfd8;
  font-size:12px;
}
.section.profile .profileSubscriptionHistory__itemSide{
  display:grid;
  gap:6px;
  justify-items:end;
}
.section.profile .profileSubscriptionHistory__badge{
  display:inline-flex;
  align-items:center;
  min-height:24px;
  padding:0 10px;
  border-radius:999px;
  border:1px solid rgba(125,211,252,.32);
  background:rgba(56,189,248,.10);
  color:#dff5ff;
  font-size:12px;
  font-weight:800;
}
.section.profile .profileSubscriptionHistory__itemReason{
  color:#d4e0f1;
  font-size:13px;
  text-align:right;
  line-height:1.45;
  max-width:340px;
}
.section.profile .profileSubscriptionHistory__empty{
  padding:12px;
  border:1px dashed var(--pf-line);
  border-radius:6px;
  color:#aebfd8;
  font-size:14px;
  background:rgba(255,255,255,.015);
}
.section.profile .profileSubscriptionSection{
  animation:profileSubscriptionFade .3s ease both;
}
.section.profile .profileSubscriptionSection:nth-of-type(2){ animation-delay:.08s; }
.section.profile .profileSubscriptionSection:nth-of-type(3){ animation-delay:.16s; }
.section.profile .profileSubscriptionSection:nth-of-type(4){ animation-delay:.24s; }
.section.profile .profileSubscriptionSection:nth-of-type(5){ animation-delay:.32s; }
.section.profile .profileSubscriptionOverview{
  position:relative;
  gap:18px;
  padding:18px 18px 16px;
  border-color:rgba(250,204,21,.16);
  background:
    radial-gradient(120% 120% at 0% 0%, rgba(250,204,21,.10), transparent 42%),
    radial-gradient(120% 120% at 100% 0%, rgba(56,189,248,.10), transparent 38%),
    rgba(255,255,255,.03);
  box-shadow:0 20px 50px rgba(0,0,0,.45), 0 0 40px rgba(255,200,50,.08);
  transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease, background .3s ease;
  will-change:transform;
}
.section.profile .profileSubscriptionOverview:hover{
  transform:translateY(-4px);
  box-shadow:0 25px 60px rgba(0,0,0,.55), 0 0 50px rgba(255,200,50,.15);
  border-color:rgba(250,204,21,.24);
}
.section.profile .profileSubscriptionOverview__title{
  font-size:24px;
}
.section.profile .profileSubscriptionOverview__meta{
  font-size:15px;
  color:#dce8f7;
}
.section.profile .profileSubscriptionOverview__subMeta{
  color:#a8c0df;
  font-size:13px;
  font-weight:700;
  line-height:1.45;
}
.section.profile .profileSubscriptionOverview__meter{
  display:grid;
  gap:7px;
  margin-top:4px;
  max-width:420px;
}
.section.profile .profileSubscriptionOverview__meterHead{
  display:grid;
  gap:4px;
}
.section.profile .profileSubscriptionOverview__meterLabel{
  color:#9fb7d8;
  font-size:12px;
  font-weight:800;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.section.profile .profileSubscriptionOverview__meterValue{
  color:#fff5cf;
  font-size:20px;
  font-weight:900;
  line-height:1.1;
}
.section.profile .profileSubscriptionOverview__progress{
  position:relative;
  overflow:hidden;
  height:8px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.06);
}
.section.profile .profileSubscriptionOverview__progressBar{
  display:block;
  height:100%;
  width:0;
  border-radius:inherit;
  background:linear-gradient(90deg, #e5c35c, #d9b24a, #4fb0ff);
  box-shadow:0 0 18px rgba(250,204,21,.22);
  transition:width .45s ease;
  animation:progressGlow 4s ease-in-out infinite;
}
.section.profile .profileSubscriptionOverview__actions{
  align-self:stretch;
  justify-content:flex-end;
  align-content:start;
}
.section.profile .profileSubscriptionOverview__btn{
  min-width:220px;
  min-height:44px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  border-radius:10px;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease;
  will-change:transform;
}
.section.profile .profileSubscriptionOverview__btn:hover{
  transform:translateY(-2px);
  box-shadow:0 6px 16px rgba(0,0,0,.3);
}
.section.profile .profileSubscriptionOverview__btn--primary{
  border-color:rgba(250,204,21,.42);
  background:linear-gradient(135deg, rgba(125,89,14,.96), rgba(250,204,21,.82));
  color:#fffaf0;
  box-shadow:0 14px 30px rgba(155,105,14,.24), 0 0 0 1px rgba(255,231,153,.10) inset;
}
.section.profile .profileSubscriptionOverview__btn--primary:hover{
  box-shadow:0 8px 20px rgba(255,200,50,.35), 0 0 20px rgba(255,200,50,.25);
}
.section.profile .profileSubscriptionOverview__btn--secondary{
  border-color:rgba(157,184,223,.34);
  background:rgba(14,22,40,.56);
  color:#edf5ff;
}
.section.profile .profileSubscriptionGrid{
  gap:12px;
}
.section.profile .profileSubscriptionStat{
  grid-template-columns:34px minmax(0,1fr);
  grid-template-areas:
    "icon label"
    "icon value";
  gap:6px 10px;
  align-items:center;
  min-height:108px;
  padding:14px;
  border-color:rgba(166,194,232,.18);
  background:rgba(255,255,255,.028);
  box-shadow:0 10px 20px rgba(3,8,22,.12);
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  will-change:transform;
}
.section.profile .profileSubscriptionStat:hover{
  transform:translateY(-4px);
  border-color:rgba(250,204,21,.28);
  box-shadow:0 10px 25px rgba(0,0,0,.4), 0 0 20px rgba(255,200,50,.15);
}
.section.profile .profileSubscriptionStat__icon{
  grid-area:icon;
  width:34px;
  height:34px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:10px;
  border:1px solid rgba(250,204,21,.18);
  background:linear-gradient(180deg, rgba(250,204,21,.10), rgba(56,189,248,.10));
  color:#fff2be;
  font-size:12px;
  font-weight:900;
  letter-spacing:.06em;
}
.section.profile .profileSubscriptionStat__label{
  grid-area:label;
  opacity:.78;
}
.section.profile .profileSubscriptionStat__value{
  grid-area:value;
  font-size:18px;
  line-height:1.3;
}
.section.profile .profileSubscriptionBenefits__head,
.section.profile .profileSubscriptionHistory__head{
  margin-bottom:12px;
}
.section.profile .profileSubscriptionBenefits__grid{
  gap:12px;
}
.section.profile .profileSubscriptionBenefit{
  min-height:108px;
  padding:14px;
  border-color:rgba(166,194,232,.18);
  background:rgba(255,255,255,.028);
  box-shadow:0 10px 20px rgba(3,8,22,.12);
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  will-change:transform;
}
.section.profile .profileSubscriptionBenefit:hover{
  transform:translateY(-5px);
  border-color:rgba(255,200,50,.5);
  box-shadow:0 15px 35px rgba(0,0,0,.4), 0 0 25px rgba(255,200,50,.15);
}
.section.profile .profileSubscriptionBenefit__icon{
  border-color:rgba(250,204,21,.20);
  background:linear-gradient(180deg, rgba(250,204,21,.12), rgba(56,189,248,.10));
  font-size:11px;
  font-weight:900;
  letter-spacing:.08em;
}
.section.profile .profileSubscriptionBenefit__title{
  font-size:15px;
}
.section.profile .profileSubscriptionBenefit__text{
  color:#c5d5eb;
}
.section.profile .profileSubscriptionHistory__heading{
  display:grid;
  gap:4px;
}
.section.profile .profileSubscriptionHistory__filters{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.section.profile .profileSubscriptionHistory__filter{
  min-height:34px;
  padding:0 12px;
  border-radius:999px;
  border:1px solid rgba(157,184,223,.24);
  background:rgba(255,255,255,.03);
  color:#d8e8ff;
  font:inherit;
  font-size:13px;
  font-weight:800;
  cursor:pointer;
  transition:transform .18s ease, border-color .18s ease, background .18s ease, color .18s ease;
  will-change:transform;
}
.section.profile .profileSubscriptionHistory__filter:hover{
  transform:translateY(-2px);
  border-color:rgba(250,204,21,.28);
  background:rgba(250,204,21,.08);
  box-shadow:0 6px 16px rgba(0,0,0,.3);
}
.section.profile .profileSubscriptionHistory__filter.is-active{
  border-color:rgba(250,204,21,.42);
  background:linear-gradient(135deg, rgba(119,83,8,.24), rgba(250,204,21,.14));
  color:#fff3c4;
}
.section.profile .profileSubscriptionHistory__list{
  position:relative;
  gap:12px;
}
.section.profile .profileSubscriptionHistory__groupLabel{
  position:sticky;
  top:0;
  z-index:1;
  padding:6px 10px;
  border:1px solid rgba(157,184,223,.18);
  border-radius:999px;
  background:rgba(9,15,28,.82);
  backdrop-filter:blur(8px);
  color:#c8d8ee;
  font-size:12px;
  font-weight:900;
  letter-spacing:.05em;
  text-transform:uppercase;
}
.section.profile .profileSubscriptionHistory__item{
  position:relative;
  grid-template-columns:18px minmax(0,1fr) auto;
  gap:12px;
  align-items:start;
  padding:14px 14px 14px 12px;
  border-color:rgba(166,194,232,.18);
  background:rgba(255,255,255,.028);
  box-shadow:0 10px 20px rgba(3,8,22,.10);
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  will-change:transform;
}
.section.profile .profileSubscriptionHistory__item:hover{
  transform:translateX(3px);
  background:rgba(255,255,255,.03);
  box-shadow:0 16px 28px rgba(3,8,22,.18);
}
.section.profile .profileSubscriptionHistory__item.is-grant{
  border-left:2px solid rgba(56,189,248,.42);
}
.section.profile .profileSubscriptionHistory__item.is-revoke{
  border-left:2px solid rgba(248,113,113,.42);
}
.section.profile .profileSubscriptionHistory__item.is-purchase{
  border-left:2px solid rgba(250,204,21,.42);
}
.section.profile .profileSubscriptionHistory__item.is-grant .profileSubscriptionHistory__line{
  color:rgba(56,189,248,.92);
}
.section.profile .profileSubscriptionHistory__item.is-revoke .profileSubscriptionHistory__line{
  color:rgba(248,113,113,.92);
}
.section.profile .profileSubscriptionHistory__item.is-purchase .profileSubscriptionHistory__line{
  color:rgba(250,204,21,.92);
}
.section.profile .profileSubscriptionHistory__line{
  position:relative;
  display:flex;
  justify-content:center;
  min-height:100%;
}
.section.profile .profileSubscriptionHistory__line::before{
  content:"";
  position:absolute;
  top:-14px;
  bottom:-14px;
  width:2px;
  border-radius:999px;
  background:linear-gradient(to bottom, rgba(80,200,255,.4), rgba(255,200,50,.2));
}
.section.profile .profileSubscriptionHistory__dot{
  position:relative;
  z-index:1;
  width:10px;
  height:10px;
  margin-top:4px;
  border-radius:999px;
  border:2px solid rgba(9,15,28,.92);
  background:currentColor;
  color:rgba(56,189,248,.88);
  box-shadow:0 0 10px currentColor, 0 0 0 4px rgba(56,189,248,.12);
}
.section.profile .profileSubscriptionHistory__item.is-revoke .profileSubscriptionHistory__dot{
  color:rgba(248,113,113,.88);
  box-shadow:0 0 10px currentColor, 0 0 0 4px rgba(248,113,113,.10);
}
.section.profile .profileSubscriptionHistory__item.is-purchase .profileSubscriptionHistory__dot{
  color:rgba(250,204,21,.88);
  box-shadow:0 0 10px currentColor, 0 0 0 4px rgba(250,204,21,.10);
}
.section.profile .profileSubscriptionHistory__itemHead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}
.section.profile .profileSubscriptionHistory__itemAction{
  font-size:16px;
}
.section.profile .profileSubscriptionHistory__itemMeta{
  font-size:12px;
}
.section.profile .profileSubscriptionHistory__itemSide{
  align-self:center;
}
.section.profile .profileSubscriptionHistory__badge{
  min-height:26px;
  padding:0 12px;
  border-color:rgba(157,184,223,.24);
  background:rgba(56,189,248,.08);
}
.section.profile .profileSubscriptionHistory__itemReason{
  color:#d7e4f5;
  font-size:13px;
  text-align:left;
  max-width:none;
}
.section.profile .profileDangerZone{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-top:16px;
  padding:16px;
  border:1px solid rgba(166,194,232,.16);
  border-radius:10px;
  background:rgba(255,255,255,.024);
}
.section.profile .profileDangerZone__content{
  display:grid;
  gap:4px;
}
.section.profile .profileDangerZone__title{
  color:#eef4ff;
  font-size:14px;
  font-weight:900;
  letter-spacing:.05em;
  text-transform:uppercase;
}
.section.profile .profileDangerZone__text{
  color:#b7c8de;
  font-size:13px;
  line-height:1.5;
}
.section.profile .profileLogoutBtn{
  min-height:42px;
  border-radius:10px;
  border-color:rgba(255,80,80,.4);
  background:rgba(180,40,40,.15);
  color:#ffd2d2;
  transition:transform .18s ease, border-color .18s ease, background .18s ease, color .18s ease;
  will-change:transform;
}
.section.profile .profileLogoutBtn:hover{
  transform:translateY(-2px);
  border-color:rgba(255,96,96,.48);
  background:rgba(200,50,50,.25);
  color:#ffe8e8;
}
.section.profile .profileSubscriptionOverview__btn:focus-visible,
.section.profile .profileSubscriptionHistory__filter:focus-visible,
.section.profile .profileLogoutBtn:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(125,211,252,.14), 0 0 0 1px rgba(186,230,253,.28) inset;
}
.section.profile .profileSubscriptionOverview,
.section.profile .profileSubscriptionStat,
.section.profile .profileSubscriptionBenefit,
.section.profile .profileSubscriptionHistory__item,
.section.profile .profileSubscriptionOverview__btn,
.section.profile .profileSubscriptionHistory__filter,
.section.profile .profileLogoutBtn{
  transition:
    transform .2s ease,
    box-shadow .2s ease,
    border-color .2s ease,
    background .2s ease,
    color .2s ease;
}
@keyframes profileSubscriptionFade{
  from{
    opacity:0;
    transform:translateY(8px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}
@keyframes progressGlow{
  0%{ filter:brightness(1); }
  50%{ filter:brightness(1.1); }
  100%{ filter:brightness(1); }
}
.section.profile .profileRow__action{
  width: 160px;
  justify-self: end;
  display: inline-flex;
  justify-content: flex-end;
  align-items: center;
}
.section.profile .profileRow__actions{
  width: 160px;
  justify-self: end;
  display: inline-flex;
  justify-content: flex-end;
  align-items: center;
  gap: 8px;
}

.section.profile .profileRow__actionBtn{
  min-height: 34px;
  height: 34px;
  min-width: 104px;
  padding: 0 12px;
  border-radius: 6px;
  border: 1px solid rgba(161, 191, 228, .42);
  background: rgba(98, 126, 167, .18);
  color: #edf5ff;
  font-size: 16px;
  font-weight: 800;
  box-shadow: none;
}

@media (max-width: 900px){
  .section.profile .subscriptionSummaryCard__head{
    grid-template-columns:1fr;
  }
  .section.profile .subscriptionSummaryCard__btn{
    width:100%;
  }
  .section.profile .profileSubscriptionGrid{
    grid-template-columns:repeat(2, minmax(0,1fr));
  }
  .section.profile .profileSubscriptionBenefits__grid{
    grid-template-columns:1fr;
  }
  .section.profile .profileDangerZone{
    flex-direction:column;
    align-items:stretch;
  }
}
@media (max-width: 680px){
  .section.profile .profileSubscriptionOverview{
    grid-template-columns:1fr;
  }
  .section.profile .profileSubscriptionOverview__actions{
    justify-content:stretch;
  }
  .section.profile .profileSubscriptionOverview__btn{
    width:100%;
  }
  .section.profile .profileSubscriptionGrid{
    grid-template-columns:1fr;
  }
  .section.profile .profileSubscriptionStat{
    min-height:auto;
  }
  .section.profile .profileSubscriptionHistory__item{
    grid-template-columns:18px minmax(0,1fr);
  }
  .section.profile .profileSubscriptionHistory__itemSide{
    grid-column:2;
    justify-items:start;
  }
  .section.profile .profileSubscriptionHistory__itemReason{
    text-align:left;
    max-width:none;
  }
  .section.profile .profileSubscriptionHistory__itemHead{
    align-items:flex-start;
    flex-direction:column;
  }
  .section.profile .profileSubscriptionHistory__groupLabel{
    position:static;
  }
}
@media (prefers-reduced-motion: reduce){
  .section.profile .profileSubscriptionSection,
  .section.profile .profileSubscriptionOverview,
  .section.profile .profileTab.is-active,
  .section.profile .subscriptionSummaryCard,
  .section.profile .profileSubscriptionOverview__btn,
  .section.profile .profileSubscriptionStat,
  .section.profile .profileSubscriptionBenefit,
  .section.profile .profileSubscriptionHistory__item,
  .section.profile .profileSubscriptionHistory__filter,
  .section.profile .profileLogoutBtn{
    animation:none !important;
    transition:none !important;
    transform:none !important;
  }
  .section.profile .profileSubscriptionOverview__progressBar{
    transition:none !important;
    animation:none !important;
  }
}
.section.profile .profileRow__actionBtn:hover{
  border-color: rgba(180, 210, 248, .58);
  background: rgba(116, 149, 194, .26);
}
.section.profile #btnResendVerifyEmail:not(:disabled){
  border-color: rgba(156, 206, 255, .56);
  background: rgba(92, 150, 216, .30);
  color: #f5faff;
}
.section.profile #btnResendVerifyEmail:not(:disabled):hover{
  background: rgba(110, 170, 236, .36);
}
.section.profile .profileRow__actionBtn:disabled{
  background: rgba(129, 146, 170, .18);
  border-color: rgba(166, 184, 208, .36);
  color: rgba(219, 230, 245, .90);
  cursor: default;
  pointer-events: none;
}

.section.profile .profileRow__action.iconbtn,
.section.profile .profileInfoBtn{
  width: 34px;
  min-width: 34px;
  height: 34px;
  border-radius: 6px;
  border: 1px solid rgba(161, 191, 228, .42);
  background: rgba(98, 126, 167, .15);
  color: #e8f2ff;
}
.section.profile .profileRow__action.iconbtn:hover,
.section.profile .profileInfoBtn:hover{
  background: rgba(116, 149, 194, .24);
  border-color: rgba(180, 210, 248, .54);
}
.section.profile .profileRow__action.iconbtn svg{
  width: 14px;
  height: 14px;
}

.section.profile .profileLogoutBtn{
  min-height: 42px;
  height: 42px;
  padding: 0 12px;
  border-radius: 10px;
  border: 1px solid rgba(255,80,80,.4);
  background: rgba(180,40,40,.15);
  color: #ffd2d2;
  font-size: 13px;
  font-weight: 800;
  box-shadow: none;
  transition: transform .2s ease, background .2s ease, border-color .2s ease, color .2s ease;
}
.section.profile .profileLogoutBtn:hover{
  transform: translateY(-2px);
  border-color: rgba(255,96,96,.48);
  background: rgba(200,50,50,.25);
  color: #ffe8e8;
}
.section.profile .profileLogoutBtn__icon{
  color: rgba(240, 170, 170, .94);
}
.section.profile .notice{
  border-radius: 6px;
}

/* Security tab premium polish */
.section.profile .profileTab[data-tab="security"] .profileRows{
  border-color: var(--pf-line);
  background: rgba(255,255,255,.012);
}
.section.profile .profileTab[data-tab="security"] .profileRow,
.section.profile .profileTab[data-tab="security"] .profileRow--wideAction{
  grid-template-columns: 220px minmax(0, 1fr) 190px;
}
.section.profile .profileTab[data-tab="security"] #secMfaStatus{
  display: inline-flex;
  align-items: center;
  max-width: max-content;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid rgba(169, 197, 236, .32);
  background: rgba(108, 141, 187, .18);
  color: #f0f6ff;
  font-size: 13px;
  font-weight: 800;
}
.section.profile .profileTab[data-tab="security"] #btnMfaPrimary{
  transition: background .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease;
}
.section.profile .profileTab[data-tab="security"] #btnMfaPrimary.is-pending{
  border-color: rgba(240, 193, 108, .55);
  background: rgba(166, 124, 52, .24);
  color: #ffe8bf;
  box-shadow: 0 0 0 1px rgba(255, 210, 135, .10) inset;
}
.section.profile .profileTab[data-tab="security"] #btnMfaPrimary.is-pending:disabled{
  opacity: 1;
  cursor: default;
  pointer-events: none;
}
.section.profile .profileTab[data-tab="security"] #btnMfaPrimary.is-active{
  border-color: rgba(102, 205, 150, .58);
  background: rgba(58, 136, 99, .28);
  color: #dcffe8;
  box-shadow: 0 0 0 1px rgba(120, 228, 174, .10) inset;
}
.section.profile .profileTab[data-tab="security"] #btnMfaPrimary.is-active:hover{
  border-color: rgba(126, 224, 175, .72);
  background: rgba(66, 154, 112, .34);
}
.section.profile .profileTab[data-tab="security"] .securityIntro{
  margin: 0 0 10px;
  padding: 12px;
  border: 1px solid var(--pf-line);
  border-radius: 6px;
  background: rgba(25, 36, 52, .78);
}
.section.profile .profileTab[data-tab="security"] .securityIntro--withMedia{
  display: grid;
  grid-template-columns: minmax(190px, 250px) minmax(0, 1fr);
  gap: 14px;
  align-items: stretch;
}
.section.profile .profileTab[data-tab="security"] .securityIntro--noMedia{
  grid-template-columns: minmax(0, 1fr);
}
.section.profile .profileTab[data-tab="security"] .securityIntro__mediaCol{
  display: grid;
  gap: 8px;
}
.section.profile .profileTab[data-tab="security"] .securityIntro__mediaFrame{
  position: relative;
  border: 0;
  border-radius: 0;
  overflow: visible;
  background: transparent;
}
.section.profile .profileTab[data-tab="security"] .securityIntro__mediaImg{
  width: 100%;
  max-height: 240px;
  height: auto;
  display: block;
  object-fit: cover;
  border-radius: 6px;
}
.section.profile .profileTab[data-tab="security"] .securityIntro__mediaCol.is-admin .securityIntro__mediaFrame{
  min-height: 200px;
  border: 1px solid rgba(155, 186, 228, .35);
  border-radius: 6px;
  overflow: hidden;
  background: rgba(14, 24, 39, .84);
}
.section.profile .profileTab[data-tab="security"] .securityIntro__mediaCol.is-admin .securityIntro__mediaImg{
  height: 100%;
  max-height: none;
  border-radius: 0;
}
.section.profile .profileTab[data-tab="security"] .securityIntro__mediaEmpty{
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-size: 28px;
  font-weight: 900;
  color: rgba(201, 220, 244, .78);
  letter-spacing: .08em;
}
.section.profile .profileTab[data-tab="security"] .securityIntro__mediaAdmin{
  display: grid;
  gap: 4px;
}
.section.profile .profileTab[data-tab="security"] .securityIntro__mediaAdmin .btn{
  justify-self: start;
}
.section.profile .profileTab[data-tab="security"] .securityIntro__mediaAdmin .muted{
  min-height: 18px;
  font-size: 13px;
}
.section.profile .profileTab[data-tab="security"] .securityIntro__mediaHint{
  color: #b8cce8;
}
.section.profile .profileTab[data-tab="security"] .securityIntro__title{
  margin: 0 0 6px;
  color: #eef5ff;
  font-size: 18px;
  font-weight: 900;
  line-height: 1.25;
}
.section.profile .profileTab[data-tab="security"] .securityIntro__subtitle{
  margin: 10px 0 6px;
  color: #d8e8ff;
  font-size: 16px;
  font-weight: 800;
  line-height: 1.25;
}
.section.profile .profileTab[data-tab="security"] .securityIntro__text{
  margin: 0;
  color: #b9cbe5;
  font-size: 16px;
  line-height: 1.45;
}
.section.profile .profileTab[data-tab="security"] .securityBox{
  margin-top: 10px;
  border: 1px solid var(--pf-line);
  border-radius: 6px;
  background: rgba(25, 36, 52, .78);
  padding: 12px;
}
.section.profile .profileTab[data-tab="security"] .securityBox__title{
  margin: 0 0 8px;
  font-size: 17px;
  font-weight: 900;
  color: #eaf3ff;
}
.section.profile .profileTab[data-tab="security"] .securityBox .muted{
  color: #b7c9e3;
  font-size: 16px;
}
.section.profile .profileTab[data-tab="security"] .securityKey{
  margin: 8px 0;
  border-radius: 6px;
  border: 1px dashed rgba(164, 195, 236, .40);
  background: rgba(20, 32, 50, .86);
  color: #eef5ff;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 16px;
  font-weight: 900;
  line-height: 1.35;
  letter-spacing: .045em;
}
.section.profile .profileTab[data-tab="security"] .securityKey.is-masked{
  font-size: 17px;
  letter-spacing: .14em;
}
.section.profile .profileTab[data-tab="security"] .securityQrWrap{
  border-radius: 6px;
  border-color: rgba(165, 195, 235, .32);
  background: rgba(19, 31, 48, .84);
}
.section.profile .profileTab[data-tab="security"] .securityLine{
  gap: 8px;
}
.section.profile .profileTab[data-tab="security"] .securityLine .btn{
  min-height: 34px;
  height: 34px;
  padding: 0 12px;
  border-radius: 6px;
  font-size: 15px;
  font-weight: 800;
}
.section.profile .profileTab[data-tab="security"] #mfaSetupCode{
  min-height: 40px;
  border-radius: 6px;
}
.section.profile .profileTab[data-tab="security"] .securityBackupCodes{
  margin: 8px 0;
  border-radius: 6px;
  border-color: rgba(165, 195, 235, .28);
  background: rgba(18, 30, 47, .84);
  color: #eff6ff;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 15px;
  line-height: 1.5;
}
.section.profile .profileTab[data-tab="security"] .securitySessions{
  margin-top: 10px;
  border: 1px solid var(--pf-line);
  border-radius: 6px;
  background: rgba(25, 36, 52, .74);
  overflow: hidden;
}
.section.profile .profileTab[data-tab="security"] .securitySessions__head{
  margin: 0;
  padding: 10px 12px;
  border-bottom: 1px solid var(--pf-line);
  background: rgba(255,255,255,.01);
}
.section.profile .profileTab[data-tab="security"] .securitySessions__head .securityLine{
  gap: 8px;
}
.section.profile .profileTab[data-tab="security"] .securitySessions__head .btn{
  min-height: 34px;
  height: 34px;
  padding: 0 12px;
  border-radius: 6px;
}
.section.profile .profileTab[data-tab="security"] .securitySessions__list{
  gap: 0;
}
.section.profile .profileTab[data-tab="security"] .securitySession{
  border: 0;
  border-top: 1px solid var(--pf-line);
  border-radius: 0;
  background: transparent;
  padding: 9px 12px;
  grid-template-columns: minmax(0, 1fr) auto;
}
.section.profile .profileTab[data-tab="security"] .securitySession:first-child{
  border-top: 0;
}
.section.profile .profileTab[data-tab="security"] .securitySession__title{
  font-size: 13px;
  font-weight: 800;
  color: #e5f0ff;
}
.section.profile .profileTab[data-tab="security"] .securitySession__meta{
  margin-top: 3px;
  font-size: 12px;
  color: #aec2de;
}
.section.profile .profileTab[data-tab="security"] .securitySession .btn{
  min-height: 32px;
  height: 32px;
  padding: 0 10px;
  border-radius: 6px;
  font-size: 12px;
}
.section.profile .profileTab[data-tab="security"] .securityRowActions{
  width: 190px;
  gap: 8px;
}
.section.profile .profileTab[data-tab="security"] .securityNotifyRows{
  overflow: visible;
}
.section.profile .profileTab[data-tab="security"] .securityInfoEmoji{
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  min-width: 32px;
  height: 32px;
  border-radius: 6px;
  border: 1px solid rgba(161, 191, 228, .42);
  background: rgba(98, 126, 167, .15);
  font-size: 15px;
  line-height: 1;
  cursor: default;
  user-select: none;
}
.section.profile .profileTab[data-tab="security"] .securityInfoEmoji:hover{
  background: rgba(116, 149, 194, .24);
  border-color: rgba(180, 210, 248, .54);
}
.section.profile .profileTab[data-tab="security"] .securityInfoEmoji::after{
  content: attr(data-tooltip);
  position: absolute;
  left: 50%;
  top: calc(100% + 10px);
  transform: translateX(-50%) translateY(-4px);
  min-width: 230px;
  max-width: 290px;
  padding: 9px 10px;
  border-radius: 10px;
  border: 1px solid rgba(130,175,255,.38);
  background: rgba(10,20,38,.97);
  color: #e8f4ff;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.35;
  text-align: left;
  opacity: 0;
  pointer-events: none;
  z-index: 40;
  box-shadow: 0 14px 40px rgba(3,8,16,.58);
  transition: opacity .16s ease, transform .16s ease;
}
.section.profile .profileTab[data-tab="security"] .securityInfoEmoji::before{
  content: "";
  position: absolute;
  left: 50%;
  top: calc(100% + 5px);
  width: 10px;
  height: 10px;
  transform: translateX(-50%) rotate(45deg);
  border-top: 1px solid rgba(130,175,255,.38);
  border-left: 1px solid rgba(130,175,255,.38);
  background: rgba(10,20,38,.97);
  opacity: 0;
  pointer-events: none;
  z-index: 39;
  transition: opacity .16s ease;
}
.section.profile .profileTab[data-tab="security"] .securityInfoEmoji:hover::after,
.section.profile .profileTab[data-tab="security"] .securityInfoEmoji:focus-visible::after{
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}
.section.profile .profileTab[data-tab="security"] .securityInfoEmoji:hover::before,
.section.profile .profileTab[data-tab="security"] .securityInfoEmoji:focus-visible::before{
  opacity: 1;
}
.section.profile .profileTab[data-tab="security"] .securityInfoEmoji:focus-visible{
  outline: 2px solid rgba(130, 205, 255, .58);
  outline-offset: 2px;
}
.section.profile .profileTab[data-tab="security"] .securityToggle{
  position: relative;
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  height: 34px;
  min-width: 108px;
  padding: 0 12px 0 46px;
  border: 1px solid rgba(161, 191, 228, .42);
  border-radius: 6px;
  background: rgba(98, 126, 167, .16);
  color: #edf5ff;
  font-size: 13px;
  font-weight: 800;
  cursor: pointer;
  user-select: none;
}
.section.profile .profileTab[data-tab="security"] .securityToggle:hover{
  border-color: rgba(180, 210, 248, .58);
  background: rgba(116, 149, 194, .24);
}
.section.profile .profileTab[data-tab="security"] .securityToggle input{
  position: absolute;
  opacity: 0;
  width: 1px;
  height: 1px;
  pointer-events: none;
}
.section.profile .profileTab[data-tab="security"] .securityToggle span{
  position: relative;
}
.section.profile .profileTab[data-tab="security"] .securityToggle span::before{
  content: "";
  position: absolute;
  left: -34px;
  top: 50%;
  width: 24px;
  height: 14px;
  transform: translateY(-50%);
  border-radius: 999px;
  border: 1px solid rgba(168, 194, 230, .50);
  background: rgba(140, 159, 187, .40);
  transition: background .18s ease, border-color .18s ease;
}
.section.profile .profileTab[data-tab="security"] .securityToggle span::after{
  content: "";
  position: absolute;
  left: -33px;
  top: 50%;
  width: 10px;
  height: 10px;
  transform: translateY(-50%);
  border-radius: 50%;
  background: #eef5ff;
  box-shadow: 0 1px 3px rgba(0,0,0,.35);
  transition: left .18s ease;
}
.section.profile .profileTab[data-tab="security"] .securityToggle input:checked + span::before{
  border-color: rgba(142, 214, 255, .66);
  background: rgba(92, 170, 228, .58);
}
.section.profile .profileTab[data-tab="security"] .securityToggle input:checked + span::after{
  left: -21px;
}
.section.profile .profileTab[data-tab="security"] .securityToggle input:focus-visible + span{
  outline: 2px solid rgba(130, 205, 255, .58);
  outline-offset: 3px;
  border-radius: 4px;
}

/* Profile tab: public card + avatar presets */
.section.profile .profileTab[data-tab="profile"] .profile__card{
  padding: 12px;
}
.section.profile .publicProfile{
  display: grid;
  grid-template-columns: minmax(250px, 320px) minmax(0, 1fr);
  gap: 14px;
  align-items: center;
}
.section.profile .publicProfile__left{
  display: grid;
  gap: 8px;
  align-content: start;
}
.section.profile .publicProfile__title{
  margin: 0;
  font-size: 20px;
  line-height: 1.28;
  display: block;
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.section.profile .publicProfile__title #publicProfileHeadingName{
  font-weight: 900;
  color: #8fd0ff;
  text-shadow: 0 0 16px rgba(122, 204, 255, .24);
}
.section.profile .publicProfile__avatarWrap{
  width: 100%;
  max-width: 260px;
  position: relative;
  border-radius: 8px;
  overflow: hidden;
}
.section.profile .publicProfile__avatarWrap::before{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(6, 10, 18, .02), rgba(6, 10, 18, .62));
  opacity: 0;
  pointer-events: none;
  transition: opacity .18s ease;
}
.section.profile .publicProfile__avatarWrap::after{
  content: "Modifier l avatar";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  min-height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 8px;
  background: rgba(8, 12, 20, .90);
  color: #f4f8ff;
  font-size: 14px;
  font-weight: 900;
  letter-spacing: .03em;
  transform: translateY(100%);
  pointer-events: none;
  transition: transform .18s ease;
}
.section.profile .publicProfile__avatar{
  width: 100%;
  max-width: 260px;
  aspect-ratio: 1 / 1;
  height: auto;
  border-radius: 8px;
  border: 1px solid rgba(162, 194, 235, .40);
  object-fit: cover;
  cursor: pointer;
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.section.profile .publicProfile__avatar:hover{
  transform: translateY(-1px);
  border-color: rgba(186, 215, 248, .62);
  box-shadow: 0 8px 24px rgba(8, 14, 24, .35);
}
.section.profile .publicProfile__avatarWrap:hover::before{
  opacity: 1;
}
.section.profile .publicProfile__avatarWrap:hover::after{
  transform: translateY(0);
}
.section.profile .publicProfile__since{
  color: #b8cbe6;
  font-size: 13px;
  font-weight: 700;
}
.section.profile .publicProfile__right{
  border: 1px solid var(--pf-line);
  border-radius: 6px;
  background: rgba(22, 31, 47, .58);
  padding: 12px;
  align-self: center;
}
.section.profile .publicProfile__head{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}
.section.profile .publicProfile__headTitle{
  color: #eef5ff;
  font-size: 17px;
  font-weight: 900;
}
.section.profile .publicProfile__editBtn{
  min-height: 34px;
  height: 34px;
  border-radius: 6px;
  font-size: 14px;
  font-weight: 800;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.section.profile .publicProfile__editIcon{
  width: 14px;
  height: 14px;
  display: inline-flex;
}
.section.profile .publicProfile__editIcon svg{
  width: 14px;
  height: 14px;
  display: block;
}
.section.profile .publicProfile__presentation{
  margin: 0;
  color: #deebff;
  font-size: 15px;
  line-height: 1.58;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
}

#profilePresentationModal .profilePresentationModal__panel{
  width: min(700px, calc(100vw - 24px));
}
#profilePresentationModal .profilePresentationInput{
  width: 100%;
  min-height: 180px;
  border-radius: 8px;
  border: 1px solid rgba(162, 194, 235, .38);
  background: rgba(16, 26, 40, .92);
  color: #eef6ff;
  padding: 12px 13px;
  font-size: 14px;
  line-height: 1.45;
  resize: vertical;
  outline: none;
}
#profilePresentationModal .profilePresentationInput:focus{
  border-color: rgba(178, 212, 252, .56);
  box-shadow: 0 0 0 2px rgba(95, 160, 238, .14);
}

#avatarPresetModal .avatarPresetModal__panel{
  width: min(1100px, calc(100vw - 24px));
  max-height: min(90vh, 980px);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
}
#avatarPresetModal .avatarPresetModal__body{
  display: grid;
  grid-template-rows: auto auto auto minmax(0, 1fr) auto;
  gap: 10px;
  align-content: start;
  overflow: hidden;
}
#avatarPresetModal .avatarPresetPreviewWrap{
  width: min(290px, 42vw);
  aspect-ratio: 1 / 1;
  margin: 0 auto;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid rgba(168, 199, 236, .38);
  background: rgba(16, 24, 36, .8);
}
#avatarPresetModal .avatarPresetPreview{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
#avatarPresetModal .avatarPresetGames{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
#avatarPresetModal .avatarPresetGameBtn{
  min-height: 52px;
  border-radius: 8px;
  border: 1px solid rgba(156, 188, 228, .34);
  background: rgba(66, 90, 126, .18);
  color: #eaf3ff;
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  padding: 8px 12px;
  font-size: 15px;
  font-weight: 800;
  cursor: pointer;
  transition: background .16s ease, border-color .16s ease, box-shadow .16s ease;
}
#avatarPresetModal .avatarPresetGameBtn__logo{
  width: 42px;
  height: 36px;
  object-fit: contain;
  display: block;
  flex: 0 0 auto;
  border-radius: 6px;
  border: 1px solid rgba(173, 206, 244, .26);
  background: rgba(8, 14, 24, .42);
}
#avatarPresetModal .avatarPresetGameBtn__text{
  display: inline-flex;
  align-items: center;
  line-height: 1.15;
  text-align: left;
}
#avatarPresetModal .avatarPresetGameBtn:hover{
  border-color: rgba(180, 212, 250, .54);
  background: rgba(86, 114, 154, .28);
}
#avatarPresetModal .avatarPresetGameBtn.is-active{
  border-color: rgba(198, 225, 255, .70);
  background: rgba(105, 145, 194, .36);
  box-shadow: inset 0 0 0 1px rgba(210, 233, 255, .22);
}
#avatarPresetModal .avatarPresetRules{
  margin: 0;
  font-size: 12px;
  line-height: 1.4;
  color: #c2d6f2;
}
#avatarPresetModal .avatarPresetGameBtn__icon{
  width: 22px;
  height: 22px;
  border-radius: 5px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(6, 14, 24, .56);
  color: rgba(242, 248, 255, .96);
  font-size: 12px;
  font-weight: 900;
}
#avatarPresetModal .avatarPresetAdmin{
  border: 1px dashed rgba(164, 196, 234, .36);
  border-radius: 8px;
  background: rgba(18, 28, 42, .54);
  padding: 10px;
  display: grid;
  gap: 8px;
}
#avatarPresetModal .avatarPresetAdmin[hidden]{
  display: none !important;
}
#avatarPresetModal .avatarPresetAdmin__actions{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
#avatarPresetModal .avatarPresetAdmin__actions .btn{
  min-height: 34px;
  height: 34px;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 800;
}
#avatarPresetModal .avatarPresetAdmin__hint{
  margin: 0;
  font-size: 12px;
  line-height: 1.4;
  color: #b8cde8;
}
#avatarPresetModal .avatarPresetUser{
  border: 1px dashed rgba(154, 184, 220, .30);
  border-radius: 8px;
  background: rgba(16, 25, 38, .52);
  padding: 10px;
  display: grid;
  gap: 8px;
}
#avatarPresetModal .avatarPresetUser[hidden]{
  display: none !important;
}
#avatarPresetModal .avatarPresetUser__actions{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
#avatarPresetModal .avatarPresetUser__actions .btn{
  min-height: 34px;
  height: 34px;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 800;
}
#avatarPresetModal #btnAvatarPersonalUpload{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  height: 40px;
  padding: 0 16px;
  border-radius: 10px;
  border: 1px solid rgba(118, 200, 255, .58);
  background: linear-gradient(135deg, rgba(20, 72, 126, .90), rgba(23, 136, 172, .86));
  color: #f5fbff;
  font-size: 14px;
  font-weight: 900;
  line-height: 1;
  text-align: center;
  letter-spacing: .01em;
  box-shadow: 0 10px 24px rgba(3, 30, 62, .38), inset 0 1px 0 rgba(255,255,255,.14);
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, filter .16s ease;
}
#avatarPresetModal #btnAvatarPersonalUpload:hover{
  transform: translateY(-1px);
  border-color: rgba(150, 222, 255, .74);
  filter: brightness(1.06);
  box-shadow: 0 14px 28px rgba(3, 34, 68, .44), inset 0 1px 0 rgba(255,255,255,.16);
}
#avatarPresetModal #btnAvatarPersonalUpload:focus-visible{
  outline: none;
  box-shadow: 0 0 0 3px rgba(72, 192, 255, .22), 0 14px 28px rgba(3, 34, 68, .44);
}
#avatarPresetModal #btnAvatarPersonalUpload:disabled{
  opacity: .62;
  cursor: not-allowed;
  transform: none;
  filter: none;
  box-shadow: none;
}
#avatarPresetModal .avatarPresetUser__hint{
  margin: 0;
  font-size: 12px;
  line-height: 1.4;
  color: #b8cde8;
}
#avatarPresetModal .avatarPresetGrid{
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  justify-content: start;
  gap: 10px;
  overflow: auto;
  max-height: 46vh;
  padding-right: 2px;
  scrollbar-width: thin;
  scrollbar-color: rgba(154, 184, 220, .34) rgba(24, 38, 58, .24);
}
#avatarPresetModal .avatarPresetGrid::-webkit-scrollbar{
  width: 7px;
}
#avatarPresetModal .avatarPresetGrid::-webkit-scrollbar-thumb{
  border-radius: 99px;
  background: rgba(154, 184, 220, .34);
}
#avatarPresetModal .avatarPresetGrid::-webkit-scrollbar-track{
  background: rgba(24, 38, 58, .24);
}
#avatarPresetModal .avatarPresetItem{
  width: 100%;
  height: auto;
  aspect-ratio: 1 / 1;
  border: 1px solid rgba(160, 192, 232, .34);
  border-radius: 8px;
  overflow: hidden;
  padding: 0;
  margin: 0;
  background: rgba(14, 22, 34, .86);
  cursor: pointer;
  transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease;
}
#avatarPresetModal .avatarPresetItem:hover{
  transform: translateY(-1px);
  border-color: rgba(192, 220, 252, .64);
}
#avatarPresetModal .avatarPresetItem.is-selected{
  border-color: rgba(255, 181, 94, .86);
  box-shadow: 0 0 0 2px rgba(255, 166, 65, .28);
}
#avatarPresetModal .avatarPresetItem img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
#avatarPresetModal .avatarPresetSaveBtn{
  min-width: 120px;
  border-color: rgba(255, 156, 58, .70);
  background: #f08a22;
  color: #fff;
  font-weight: 900;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 1;
}
#avatarPresetModal .avatarPresetSaveBtn:hover{
  background: #f39a3d;
  border-color: rgba(255, 176, 96, .82);
}
#avatarPresetModal .avatarPresetResetBtn{
  margin-right: auto;
  border-color: rgba(166, 189, 220, .42);
  color: #d7e7ff;
}
#avatarPresetModal .avatarPresetResetBtn:hover{
  border-color: rgba(194, 214, 242, .58);
  background: rgba(74, 96, 130, .28);
}
#avatarPresetModal .avatarPresetResetBtn:disabled{
  opacity: .55;
  cursor: not-allowed;
}
#avatarPresetModal #avatarPresetEmpty{
  margin: 0;
  padding: 4px 2px 0;
  color: #bed2ed;
}

#avatarResetModal .avatarResetModal__panel{
  width: min(520px, calc(100vw - 24px));
  border-radius: 12px;
  border: 1px solid rgba(165, 194, 235, .24);
  background: linear-gradient(180deg, rgba(20, 28, 41, .98) 0%, rgba(16, 22, 33, .98) 100%);
  box-shadow: 0 24px 56px rgba(0, 0, 0, .46);
}
#avatarResetModal .avatarResetModal__head{
  border-bottom-color: rgba(156, 187, 226, .18);
}
#avatarResetModal .avatarResetModal__head h3{
  margin: 0;
  font-size: 18px;
  font-weight: 900;
  color: #e9f3ff;
}
#avatarResetModal .avatarResetModal__body{
  display: grid;
  gap: 10px;
}
#avatarResetModal .avatarResetModal__lead{
  margin: 0;
  color: #d5e6ff;
  line-height: 1.45;
}
#avatarResetModal .avatarResetModal__foot .btn{
  min-height: 36px;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 800;
}
#avatarResetModal .avatarResetModal__confirm{
  border: 1px solid rgba(138, 176, 226, .62);
  background: rgba(67, 103, 151, .78);
  color: #f4f8ff;
}
#avatarResetModal .avatarResetModal__confirm:hover{
  background: rgba(81, 119, 171, .86);
  border-color: rgba(169, 202, 247, .70);
}
#avatarResetModal .avatarResetModal__confirm:disabled{
  opacity: .72;
  cursor: wait;
}

#avatarPresetDeleteModal .avatarPresetDeleteModal__panel{
  width: min(520px, calc(100vw - 24px));
  border-radius: 12px;
  border: 1px solid rgba(255, 175, 145, .20);
  background: linear-gradient(180deg, rgba(20, 27, 39, .98) 0%, rgba(16, 21, 31, .98) 100%);
  box-shadow: 0 26px 64px rgba(0, 0, 0, .48);
}
#avatarPresetDeleteModal .avatarPresetDeleteModal__head{
  border-bottom-color: rgba(255, 171, 132, .18);
}
#avatarPresetDeleteModal .avatarPresetDeleteModal__head h3{
  margin: 0;
  font-size: 18px;
  font-weight: 900;
  color: #ffe8dc;
}
#avatarPresetDeleteModal .avatarPresetDeleteModal__body{
  display: grid;
  gap: 10px;
}
#avatarPresetDeleteModal .avatarPresetDeleteModal__lead{
  margin: 0;
  color: #f2d4c5;
  line-height: 1.45;
}
#avatarPresetDeleteModal .avatarPresetDeleteModal__target{
  min-height: 40px;
  border-radius: 8px;
  border: 1px solid rgba(255, 172, 136, .28);
  background: rgba(54, 30, 26, .52);
  color: #ffece1;
  display: flex;
  align-items: center;
  padding: 0 12px;
  font-size: 14px;
  font-weight: 800;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
#avatarPresetDeleteModal .avatarPresetDeleteModal__warn{
  margin: 0;
  color: #d7b7aa;
}
#avatarPresetDeleteModal .avatarPresetDeleteModal__foot .btn{
  min-height: 36px;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 800;
}
#avatarPresetDeleteModal .avatarPresetDeleteModal__confirm{
  border: 1px solid rgba(242, 124, 83, .66);
  background: rgba(112, 41, 30, .88);
  color: #fff4ec;
}
#avatarPresetDeleteModal .avatarPresetDeleteModal__confirm:hover{
  background: rgba(132, 48, 35, .92);
  border-color: rgba(250, 151, 117, .74);
}
#avatarPresetDeleteModal .avatarPresetDeleteModal__confirm:disabled{
  opacity: .72;
  cursor: wait;
}

/* Modal fields clean + readable */
#identityModal .field input,
#birthdateModal .field select,
#mobileModal .field input,
#addressModal .field input,
#addressModal .field select,
#identityModal .field select{
  min-height: 40px;
  border-radius: 6px;
  border: 1px solid rgba(161, 191, 228, .44);
  background: rgba(27, 39, 58, .94);
  color: #f0f6ff;
  font-size: 14px;
  font-weight: 700;
  padding: 0 11px;
}
#identityModal .field span,
#birthdateModal .field span,
#mobileModal .field span,
#addressModal .field span{
  font-size: 12px;
  color: rgba(210,226,248,.90);
}

/* Country selector readability: +30% */
#addressCountryCode{
  color-scheme: dark;
  min-height: 52px;
  font-size: 18px;
  font-weight: 800;
  font-family: system-ui, -apple-system, "Segoe UI", "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif;
}
#addressCountryCode option{
  background: #1b2b44;
  color: #eef6ff;
  font-size: 18px;
  font-family: system-ui, -apple-system, "Segoe UI", "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif;
}

/* Chrome fallback: custom country picker with visible flags */
.countrySelectNative{
  position: absolute !important;
  opacity: 0 !important;
  pointer-events: none !important;
  width: 1px !important;
  height: 1px !important;
  margin: 0 !important;
  padding: 0 !important;
}
#addressModal .countryPicker{
  position: relative;
}
#addressModal .countryPicker__btn{
  width: 100%;
  min-height: 52px;
  border-radius: 6px;
  border: 1px solid rgba(161, 191, 228, .44);
  background: rgba(27, 39, 58, .94);
  color: #eef6ff;
  font-size: 18px;
  font-weight: 800;
  text-align: left;
  padding: 0 38px 0 11px;
  font-family: system-ui, -apple-system, "Segoe UI", "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif;
  cursor: pointer;
}
#addressModal .countryPicker__btn.is-placeholder{
  color: rgba(200, 214, 236, .72);
}
#addressModal .countryPicker::after{
  content: "";
  position: absolute;
  right: 13px;
  top: 50%;
  width: 8px;
  height: 8px;
  border-right: 2px solid rgba(198,220,248,.84);
  border-bottom: 2px solid rgba(198,220,248,.84);
  transform: translateY(-60%) rotate(45deg);
  pointer-events: none;
}
#addressModal .countryPicker__menu{
  position: fixed;
  inset: 0;
  padding: 14px;
  background: rgba(4, 8, 14, .64);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 12000;
}
#addressModal .countryPicker__menu[hidden]{
  display: none !important;
}
#addressModal .countryPicker__panel{
  width: min(680px, calc(100vw - 28px));
  max-height: min(74vh, 700px);
  border-radius: 8px;
  border: 1px solid rgba(170, 198, 235, .48);
  background: rgba(23, 35, 54, .98);
  box-shadow: 0 16px 40px rgba(0,0,0,.45);
  display: grid;
  grid-template-rows: auto auto auto minmax(0, 1fr);
  overflow: hidden;
  position: relative;
}
#addressModal .countryPicker__head{
  padding: 16px 16px 10px 16px;
  border-bottom: 1px solid rgba(170, 198, 235, .16);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  position: sticky;
  top: 0;
  z-index: 8;
  background: rgba(20, 32, 50, .92);
  backdrop-filter: blur(10px);
  box-shadow: 0 1px 0 rgba(170, 198, 235, .10);
}
#addressModal .countryPicker__title{
  font-size: 15px;
  font-weight: 900;
  line-height: 1.25;
  color: #eef6ff;
  margin: 0;
  margin-left: 8px;
}
#addressModal .countryPicker__close{
  min-height: 30px;
  padding: 0 10px;
  border-radius: 6px;
  border: 1px solid rgba(161, 191, 228, .44);
  background: rgba(98, 126, 167, .20);
  color: #eef6ff;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
}
#addressModal .countryPicker__panel .countryPicker__hint{
  padding: 0;
  margin: 6px 16px 8px 16px;
  margin-left: 24px;
  display: block;
  border-bottom: 1px solid rgba(170, 198, 235, .10);
  color: rgba(205, 220, 239, .84);
  font-size: 11px;
  font-weight: 700;
  position: sticky;
  top: 45px;
  z-index: 7;
  background: rgba(20, 32, 50, .90);
  backdrop-filter: blur(10px);
}
#addressModal .countryPicker__search{
  margin: 0 16px 12px 16px;
  min-height: 42px;
  border-radius: 6px;
  border: 1px solid rgba(164, 192, 226, .30);
  background: rgba(14, 24, 38, .94);
  color: #ecf5ff;
  font-size: 14px;
  font-weight: 700;
  padding: 0 12px;
  outline: none;
  position: sticky;
  top: 70px;
  z-index: 7;
  backdrop-filter: blur(8px);
  box-shadow: 0 1px 0 rgba(170, 198, 235, .12);
  transition: border-color .18s ease, box-shadow .18s ease, background-color .18s ease;
}
#addressModal .countryPicker__search:focus{
  border-color: rgba(176, 214, 255, .48);
  box-shadow: 0 0 0 2px rgba(112, 174, 248, .12);
  outline: 1px solid rgba(176, 214, 255, .30);
}
#addressModal .countryPicker__search:focus-visible{
  border-color: rgba(176, 214, 255, .48);
  box-shadow: 0 0 0 2px rgba(112, 174, 248, .12);
  outline: 1px solid rgba(176, 214, 255, .30);
}
#addressModal .countryPicker__list{
  display: grid;
  overflow: auto;
  max-height: 56vh;
  padding: 0 12px 12px 12px;
  scrollbar-width: thin;
  scrollbar-color: rgba(145, 176, 214, .24) rgba(22, 34, 52, .18);
}
#addressModal .countryPicker__list::-webkit-scrollbar{
  width: 5px;
}
#addressModal .countryPicker__list::-webkit-scrollbar-thumb{
  border-radius: 99px;
  background: rgba(145, 176, 214, .24);
  border: 1px solid rgba(0,0,0,.12);
}
#addressModal .countryPicker__list::-webkit-scrollbar-track{
  background: rgba(22, 34, 52, .18);
}
#addressModal .countryPicker__sectionTitle{
  position: static;
  padding: 7px 13px 6px 16px;
  margin-top: 10px;
  background: rgba(18, 29, 46, .66);
  border-top: 1px solid rgba(170, 198, 235, .08);
  border-bottom: 1px solid rgba(170, 198, 235, .08);
  color: rgba(199, 215, 238, .72);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .09em;
  text-transform: uppercase;
  line-height: 1.2;
}
#addressModal .countryPicker__list > .countryPicker__sectionTitle:first-child{
  margin-top: 0;
}
#addressModal .countryPicker__option{
  width: 100%;
  border: 0;
  border-bottom: 1px solid rgba(170, 198, 235, .08);
  background: transparent;
  color: #eef6ff;
  font-size: 14px;
  font-weight: 700;
  text-align: left;
  padding: 7px 13px 7px 16px;
  font-family: system-ui, -apple-system, "Segoe UI", "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif;
  cursor: pointer;
  display: grid;
  grid-template-columns: 44px 36px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  min-height: 42px;
  position: relative;
  padding-right: 28px;
  transition: background-color .18s ease, border-color .18s ease, box-shadow .18s ease;
}
#addressModal .countryPicker__option:last-child{
  border-bottom: 0;
}
#addressModal .countryPicker__option:hover{
  background: rgba(102, 146, 206, .09);
}
#addressModal .countryPicker__option.is-selected{
  background: rgba(102, 146, 206, .17);
  box-shadow: inset 3px 0 0 rgba(166, 205, 250, .62);
}
#addressModal .countryPicker__option.is-selected::after{
  content: "\2713";
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  color: rgba(196, 225, 255, .86);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  pointer-events: none;
}
#addressModal .countryPicker__flag{
  width: 24px;
  height: 18px;
  border-radius: 2px;
  object-fit: cover;
  box-shadow: 0 0 0 1px rgba(183, 210, 244, .35);
  grid-column: 2;
  grid-row: 1;
  justify-self: center;
  align-self: center;
}
#addressModal .countryPicker__flagFallback{
  width: 24px;
  height: 18px;
  border-radius: 2px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 900;
  letter-spacing: .03em;
  background: rgba(133, 166, 209, .32);
  color: #ecf6ff;
  grid-column: 2;
  grid-row: 1;
  justify-self: center;
  align-self: center;
}
#addressModal .countryPicker__label{
  display: block;
  font-weight: 700;
  color: #eef6ff;
  font-size: 14px;
  line-height: 1.25;
  grid-column: 3;
  text-align: left;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
#addressModal .countryPicker__code{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  grid-column: 1;
  justify-self: start;
  min-width: 34px;
  height: 20px;
  padding: 0 6px;
  border-radius: 999px;
  border: 1px solid rgba(176, 202, 236, .22);
  background: rgba(112, 144, 190, .10);
  color: rgba(214, 228, 245, .70);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .02em;
  line-height: 1;
  white-space: nowrap;
}
#addressModal .countryPicker__empty{
  padding: 10px 14px;
  color: rgba(199, 215, 238, .8);
  font-size: 14px;
  font-weight: 700;
}

@media (max-width: 980px){
  .section.profile .profileRow,
  .section.profile .profileRow--wideAction{
    grid-template-columns: 1fr;
    min-height: 0;
    gap: 7px;
    padding: 8px 10px;
  }
  .section.profile .profileRow__action,
  .section.profile .profileRow__actions{
    width: auto;
    justify-self: start;
  }
  .section.profile .profileTab[data-tab="security"] .securityIntro--withMedia{
    grid-template-columns: 1fr;
  }
  .section.profile .profileTab[data-tab="security"] .securityIntro__mediaCol.is-admin .securityIntro__mediaFrame{
    min-height: 180px;
  }
  .section.profile .publicProfile{
    grid-template-columns: 1fr;
  }
  .section.profile .publicProfile__avatarWrap{
    max-width: 220px;
  }
  #avatarPresetModal .avatarPresetModal__panel{
    width: min(980px, calc(100vw - 18px));
  }
  #avatarPresetModal .avatarPresetGrid{
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
}
@media (max-width: 640px){
  #avatarPresetModal .avatarPresetGames{
    grid-template-columns: 1fr;
  }
  #avatarPresetModal .avatarPresetPreviewWrap{
    width: min(230px, 70vw);
  }
  #avatarPresetModal .avatarPresetGrid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
    justify-content: start;
  }
  #avatarPresetModal .avatarPresetItem{
    width: 100%;
    height: auto;
    aspect-ratio: 1 / 1;
  }
}
.chapter--news .section__head{
  flex-direction: column;
  align-items: flex-start;
}
.chapter--news .section__title{ order:1; }
.chapter--news .section__sub{ order:2; }
.chapter--news .section__tabs{ order:3; }
.section__tabs{
  display:flex;
  gap:8px;
  margin-top: 10px;
}
.tab{
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.35);
  color: #fff;
  font-weight: 800;
  cursor: pointer;
}
.tab.is-active{
  border-color: rgba(107,214,255,.5);
  box-shadow: 0 0 18px rgba(107,214,255,.35);
}
.home-bg-preview{
  margin-top: 10px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.35);
  height: 180px;
  overflow: hidden;
}
.home-bg-preview__media{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* HOME SLIDES FORCE (final override) */
body.page--home{
  overflow: hidden !important;
  height: 100vh !important;
}
body.page--home main{
  padding-top: var(--topbar-h) !important;
}
body.page--home .home-scroll{
  position: relative !important;
  width: 100vw !important;
  height: calc(100vh - var(--topbar-h)) !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  scroll-snap-type: y mandatory !important;
  scroll-behavior: smooth !important;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}
body.page--home .slide{
  width: 100vw !important;
  height: calc(100vh - var(--topbar-h)) !important;
  scroll-snap-align: start !important;
  scroll-snap-stop: always !important;
}
body.page--home .chapters-dots{
  position: fixed !important;
  right: 22px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  z-index: 80 !important;
  pointer-events: auto !important;
}
body.page--home .chapter-dot{
  pointer-events: auto !important;
}
body.page--home .site-footer{
  display: none;
}
body.page--home .site-footer--home{
  display: block;
}
body.page--home .home-footer-slide{
  width: 100vw;
  scroll-snap-align: start;
  scroll-snap-stop: always;
}
.chapter--hero{ position: relative; }
.home-sound-btn{
  position: absolute;
  top: calc(var(--topbar-height, var(--topbar-h, 64px)) + 16px);
  right: 16px;
  z-index: 50;
  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.18);
  backdrop-filter: blur(10px);
  color: #fff;
  cursor: pointer;
  transition: transform 160ms ease, background 160ms ease;
}
.home-sound-btn:hover{
  transform: scale(1.06);
  background: rgba(255,255,255,0.16);
}
.home-sound-btn:focus-visible{
  outline: 2px solid rgba(255,255,255,0.8);
  outline-offset: 3px;
}
.home-sound-btn__icon{
  width: 20px;
  height: 20px;
  display: block;
  color: #fff;
}
.home-sound-btn__icon--on{ display: none; }
.home-sound-btn__icon--off{ display: block; }
.home-sound-btn.is-muted .home-sound-btn__icon--on{ display: none; }
.home-sound-btn.is-muted .home-sound-btn__icon--off{ display: block; }
.home-sound-btn:not(.is-muted) .home-sound-btn__icon--on{ display: block; }
.home-sound-btn:not(.is-muted) .home-sound-btn__icon--off{ display: none; }
.home-sound-btn__label{ display:none; }
.home-sound-btn.is-disabled{
  opacity: .45;
  cursor: default;
}
.chapter--hero .home-sound-btn{
  position: absolute !important;
  top: 16px !important;
  right: 16px !important;
  left: auto !important;
  width: 40px !important;
  height: 40px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}
/* Admin edit buttons on home slides: keep overlay, no layout shift */
.home-scroll .btn-edit{
  position: absolute;
  top: 16px;
  left: 16px;
  z-index: 60;
  margin: 0;
}
.chapter--hero .btn-edit{
  left: 16px !important;
  right: auto !important;
}
.home-sound-btn.is-hidden{
  display: none !important;
}
.home-sound-btn__icon--on .eq{ fill: #fff; transform-origin: 50% 100%; animation: eqPulse 1.1s ease-in-out infinite; }
.home-sound-btn__icon--on .eq1{ animation-delay: 0ms; }
.home-sound-btn__icon--on .eq2{ animation-delay: 120ms; }
.home-sound-btn__icon--on .eq3{ animation-delay: 240ms; }
@keyframes eqPulse{
  0%{ transform: scaleY(0.6); opacity: .6; }
  50%{ transform: scaleY(1.15); opacity: 1; }
  100%{ transform: scaleY(0.6); opacity: .6; }
}
@media (prefers-reduced-motion: reduce){
  .home-sound-btn__icon--on .eq{ animation: none; }
}

/* FINAL OVERRIDE: force sound button top-right on HERO */
.chapter--hero{ position: relative !important; }
.chapter--hero .home-sound-btn{
  position: absolute !important;
  top: 16px !important;
  right: 16px !important;
  left: auto !important;
  bottom: auto !important;
  width: 40px !important;
  height: 40px !important;
  max-width: 40px !important;
  max-height: 40px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 999px !important;
}

/* TOPBAR PREMIUM OVERRIDE */
:root{
  --topbar-h: 68px;
}
.topbar{
  position: sticky;
  top: 0;
  z-index: 1000;
  height: var(--topbar-h);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  background: rgba(10, 14, 22, 0.66);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.topbar__inner{
  height: var(--topbar-h);
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  position: relative;
}
.topbar__left{
  display:flex;
  align-items:center;
  gap:12px;
  flex: 0 0 auto;
}
.topbar__center{
  flex: 1 1 auto;
  display:flex;
  justify-content: center;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}
.topbar__right{
  display:flex;
  align-items:center;
  gap:10px;
  flex: 0 0 auto;
  justify-content: flex-end;
}
.topbar__left{
  display: flex;
  align-items: center;
  gap: 12px;
}
.brand{
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: #fff;
  transform-origin: left center;
  transition: transform 180ms ease, opacity 180ms ease;
}
.brand:hover{ transform: scale(1.06); }
.brand:focus-visible{
  outline: 2px solid rgba(107,214,255,.65);
  outline-offset: 3px;
  border-radius: 12px;
}
.brand::before{ display: none !important; content: none !important; }
.brand__logo{
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: block;
  object-fit: cover;
}
.brand__text{
  font-weight: 700;
  letter-spacing: 0.4px;
  font-size: 16px;
  opacity: 0.95;
}
.brand__edit{
  padding: 6px 10px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
  color: #fff;
  font-weight: 700;
  font-size: 12px;
}
.brand__edit--ghost{
  background: transparent;
  border-color: rgba(255,255,255,.12);
  opacity: .85;
}
.brand__edit--ghost:hover{
  opacity: 1;
  border-color: rgba(107,214,255,.45);
  box-shadow: 0 0 12px rgba(107,214,255,.20);
}
.nav{
  display: flex;
  align-items: center;
  gap: 16px;
  margin: 0;
}
.nav__item{
  color: rgba(255,255,255,0.92);
  font-size: 15px;
  font-weight: 650;
  padding: 9px 12px;
  border-radius: 10px;
  transition: background 160ms ease, color 160ms ease, transform 160ms ease, box-shadow 160ms ease, opacity 160ms ease;
  opacity: .92;
}
.nav__item:hover{
  background: rgba(255,255,255,0.08);
  color: #fff;
  box-shadow: inset 0 -2px 0 rgba(107,214,255,.35);
}
.nav__item.is-active{
  color: #ff3b3b;
  background: rgba(255,255,255,0.08);
  box-shadow: inset 0 -2px 0 rgba(255,59,59,.55);
  opacity: 1;
}
.nav__item:focus-visible{
  outline: 2px solid rgba(107,214,255,.65);
  outline-offset: 2px;
}
@media (prefers-reduced-motion: reduce){
  .brand, .nav__item { transition: none; }
  .brand:hover{ transform: none; }
}
@media (max-width: 980px){
  .topbar__center{
    position: static;
    transform: none;
  }
}

/* Topbar nav text size override */
.nav__item{
  font-size: 20px;
}

/* USER MENU PREMIUM (Dofus-like) */
.user-menu{ position: relative; }
.user-menu::after{
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  height: 14px;
  background: transparent;
}
.user-menu__panel{
  position: absolute;
  right: 0;
  top: calc(100% + 12px);
  width: 280px;
  max-width: 92vw;
  padding: 12px;
  background: rgba(10,15,25,.72);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 200, 50, 0.18);
  border-radius: 16px;
  box-shadow: 0 12px 30px rgba(0,0,0,0.45), 0 0 22px rgba(255, 200, 50, 0.08);
  opacity: 0;
  transform: translateY(-8px);
  pointer-events: none;
  transition: opacity 180ms ease, transform 180ms ease, border-color .25s ease, box-shadow .25s ease;
  will-change: transform, opacity;
  z-index: 2200;
}
.user-menu__panel::before{
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -14px;
  height: 14px;
  background: transparent;
}
.user-menu__panel.is-open{
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
  animation: profilePanelFade .18s ease;
}
.user-menu__panel:hover{
  border-color: rgba(255,200,50,0.35);
  box-shadow: 0 15px 40px rgba(0,0,0,0.5), 0 0 25px rgba(255,200,50,0.15);
}
.user-menu__panel.is-closing-now{
  transition: none !important;
}
@keyframes profilePanelFade{
  from{
    opacity: 0;
    transform: translateY(-8px);
  }
  to{
    opacity: 1;
    transform: translateY(0);
  }
}
.user-menu__caret{
  position: absolute;
  top: -8px;
  right: 22px;
  width: 0;
  height: 0;
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-bottom: 8px solid rgba(10,15,25,.9);
  filter: drop-shadow(0 -1px 0 rgba(255, 200, 50, 0.18));
}
.user-menu__head{
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 6px 10px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  margin-bottom: 10px;
  position: relative;
  cursor: pointer;
  border-radius: 14px;
  transition: background .2s ease, transform .2s ease;
  will-change: transform;
}
.user-menu__head::after{
  content: "";
  position: absolute;
  left: 6px;
  right: 6px;
  bottom: -1px;
  height: 1px;
  background: linear-gradient(90deg, rgba(255,255,255,0), rgba(255, 210, 102, .28), rgba(255,255,255,0));
}
.user-menu__head:hover{
  background: rgba(255,255,255,.02);
}
.user-menu__head:focus-visible{
  outline: none;
  box-shadow: 0 0 0 3px rgba(34,211,238,.12);
}
.user-menu__avatar--sm{
  width: 36px;
  height: 36px;
  border-radius: 12px;
  transition: transform .2s ease, box-shadow .2s ease;
  will-change: transform;
}
.user-menu__head:hover .user-menu__avatar--sm,
.user-menu__head:focus-visible .user-menu__avatar--sm{
  transform: scale(1.05);
  box-shadow: 0 0 12px rgba(80,200,255,0.35), 0 0 0 2px rgba(6,12,24,.45) inset;
}
.user-menu__title{ font-weight: 800; font-size: 14px; }
.user-menu__sub{ font-size: 12px; color: rgba(255,255,255,.7); }
.user-menu__headText{
  min-width: 0;
  display: grid;
  gap: 6px;
}
.user-menu__cta{
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(107,214,255,.12);
  border: 1px solid rgba(107,214,255,.25);
  color: #fff;
  font-weight: 800;
  cursor: pointer;
  text-decoration: none;
  overflow: hidden;
  isolation: isolate;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease, background .22s ease, filter .22s ease;
  will-change: transform;
}
.user-menu__section{
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 14px;
  position: relative;
}
.user-menu__sectionLabel{
  display: block;
  padding: 2px 10px 6px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(220, 231, 248, .62);
}
.user-menu__row{
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 44px;
  padding: 11px 12px;
  border-radius: 12px;
  background: rgba(255,255,255,.025);
  border: 1px solid rgba(255,255,255,.06);
  color: #fff;
  text-decoration: none;
  font-weight: 700;
  transition: transform .2s ease, background .2s ease, border-color .2s ease, box-shadow .2s ease;
  will-change: transform;
}
.user-menu__row:hover{
  background: rgba(255,255,255,.03);
  border-color: rgba(255, 215, 120, .16);
  transform: translateX(4px);
  box-shadow: 0 8px 20px rgba(0,0,0,.18);
}
.user-menu__row:focus-visible,
.user-menu__cta:focus-visible{
  outline: none;
  border-color: rgba(134, 239, 255, .45);
  box-shadow: 0 0 0 3px rgba(34, 211, 238, .12), 0 10px 22px rgba(0,0,0,.24);
}
.user-menu__rowMain{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}
.user-menu__rowIcon{
  width: 22px;
  flex: 0 0 22px;
  text-align: center;
  font-size: 15px;
  line-height: 1;
  filter: drop-shadow(0 0 8px rgba(255,255,255,.08));
}
.user-menu__rowText{
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.user-menu__row--meta{
  background: transparent;
  border-color: transparent;
  color: rgba(255,255,255,.65);
  cursor: default;
  justify-content: space-between;
  padding-left: 10px;
  padding-right: 10px;
  transform: none !important;
  box-shadow: none !important;
}
.user-menu__row--danger{
  position: relative;
  margin-top: 10px;
  background: rgba(32, 12, 16, .46);
  border-color: rgba(248,113,113,.18);
  color: #ffd6d6;
}
.user-menu__row--danger::before{
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -7px;
  height: 1px;
  background: linear-gradient(90deg, rgba(255,255,255,0), rgba(248,113,113,.24), rgba(255,255,255,0));
}
.user-menu__row--danger:hover{
  background: rgba(127,29,29,.26);
  border-color: rgba(248,113,113,.34);
  color: #ffeaea;
}
.user-menu__btn:focus-visible{
  outline: 2px solid rgba(107,214,255,.65);
  outline-offset: 2px;
}
@media (prefers-reduced-motion: reduce){
  .user-menu__panel{ transition: none; }
}

/* Topbar profile button refresh (size + hover accent) */
.user-menu__btn{
  position: relative;
  overflow: hidden;
  padding: 12px 14px;
  border-color: rgba(150, 190, 255, .24);
  background: linear-gradient(180deg, rgba(20,32,52,.72), rgba(14,22,36,.72));
  transition: border-color .18s ease, box-shadow .18s ease, background .18s ease, transform .18s ease;
}
.user-menu__avatar{
  width: 38px;
  height: 38px;
  border-radius: 12px;
  border: 1px solid rgba(175, 220, 255, .38);
  box-shadow: 0 0 0 2px rgba(6,12,24,.45) inset, 0 6px 16px rgba(2,8,18,.35);
}
.user-menu__btn::before{
  content: "";
  position: absolute;
  left: 9px;
  right: 9px;
  top: 0;
  height: 3px;
  border-radius: 0 0 8px 8px;
  background: linear-gradient(90deg, rgba(151,255,213,.00), rgba(151,255,213,.95), rgba(151,255,213,.00));
  opacity: 0;
  transform: translateY(-2px);
  transition: opacity .18s ease, transform .18s ease;
  pointer-events: none;
}
.user-menu__btn:hover{
  border-color: rgba(151,255,213,.55);
  background: linear-gradient(180deg, rgba(28,44,68,.82), rgba(16,26,42,.82));
  box-shadow: 0 0 0 1px rgba(151,255,213,.20) inset, 0 10px 22px rgba(4,10,20,.42);
  transform: translateY(-1px);
}
.user-menu__btn:hover::before{
  opacity: 1;
  transform: translateY(0);
}

/* Topbar profile dropdown scale +40% total (menu, typography, buttons) */
.user-menu__panel{
  width: 404px;
  max-width: min(94vw, 404px);
  padding: 17px;
}
.user-menu__head{
  gap: 14px;
  padding: 10px 10px 14px;
}
.user-menu__avatar--sm{
  width: 53px;
  height: 53px;
}
.user-menu__title{
  font-size: 20px;
}
.user-menu__sub{
  font-size: 17px;
}
.user-menu__cta{
  padding: 14px 16px;
  border-radius: 16px;
  font-size: 18px;
}
.user-menu__row{
  padding: 14px 16px;
  border-radius: 16px;
  font-size: 18px;
}
.user-menu__sectionLabel{
  padding-left: 12px;
  padding-right: 12px;
}
.user-menu__row--meta{
  font-size: 15px;
}
@media (max-width: 480px){
  .user-menu__panel{
    width: min(94vw, 404px);
    padding: 14px;
  }
  .user-menu__title{
    font-size: 18px;
  }
  .user-menu__sub{
    font-size: 15px;
  }
  .user-menu__cta,
  .user-menu__row{
    font-size: 16px;
  }
}

.user-menu__sub{
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 2px 10px;
  border-radius: 999px;
  border: 1px solid rgba(150, 190, 255, .28);
  background: rgba(18, 30, 50, .46);
  font-weight: 900;
  letter-spacing: .02em;
}
.user-menu__subDot{
  width: 8px;
  height: 8px;
  border-radius: 999px;
  margin-right: 8px;
  background: currentColor;
  box-shadow: 0 0 10px currentColor;
  opacity: .9;
}
.user-menu__subHint{
  font-size: 12px;
  color: rgba(219, 230, 247, .72);
  line-height: 1.45;
}
.user-menu__sub--standard{
  color: #cbe8ff;
  border-color: rgba(107, 214, 255, .42);
  background: rgba(24, 76, 112, .30);
}
.user-menu__sub--premium{
  color: #ffe97d;
  border-color: rgba(255, 214, 77, .78);
  background: linear-gradient(140deg, rgba(70, 46, 6, .80), rgba(140, 100, 14, .50));
  box-shadow: 0 0 14px rgba(255, 205, 74, .30), inset 0 0 10px rgba(255, 208, 82, .16);
  text-shadow: 0 0 8px rgba(255, 218, 102, .55);
}

.user-menu__cta.user-menu__cta--standard{
  border-color: rgba(255, 205, 84, .56);
  background:
    linear-gradient(135deg, rgba(9, 22, 42, .96) 0%, rgba(18, 49, 80, .92) 46%, rgba(130, 86, 11, .80) 100%);
  color: #fff3c9;
  text-shadow: 0 0 10px rgba(255, 214, 104, .20);
  box-shadow:
    0 10px 24px rgba(2, 10, 24, .42),
    0 0 0 1px rgba(255, 214, 122, .16) inset,
    0 0 16px rgba(255, 193, 59, .14);
}
.user-menu__ctaLabel{
  position: relative;
  z-index: 2;
}
.user-menu__cta.user-menu__cta--standard::after{
  content: "✦";
  position: relative;
  z-index: 2;
  font-size: 16px;
  color: #ffd86c;
  text-shadow: 0 0 10px rgba(255, 210, 94, .55);
}
.user-menu__cta.user-menu__cta--standard::before{
  content: "";
  position: absolute;
  inset: -1px;
  z-index: 1;
  background: linear-gradient(115deg, transparent 18%, rgba(255,255,255,.00) 36%, rgba(255,236,179,.32) 49%, rgba(255,255,255,.00) 62%, transparent 82%);
  transform: translateX(-135%) skewX(-18deg);
  opacity: 0;
  pointer-events: none;
}
.user-menu__cta.user-menu__cta--standard:hover{
  transform: translateY(-2px) scale(1.02);
  border-color: rgba(255, 220, 118, .82);
  filter: brightness(1.05);
  box-shadow:
    0 16px 30px rgba(2, 10, 24, .52),
    0 0 0 1px rgba(255, 226, 145, .24) inset,
    0 0 22px rgba(255, 199, 77, .28),
    0 0 36px rgba(255, 191, 64, .14);
}
.user-menu__cta.user-menu__cta--standard:hover::before{
  opacity: 1;
  transform: translateX(135%) skewX(-18deg);
  transition: transform .78s ease, opacity .22s ease;
}
.user-menu__cta.user-menu__cta--standard:active{
  transform: translateY(0) scale(.99);
  box-shadow:
    0 8px 18px rgba(2, 10, 24, .36),
    0 0 0 1px rgba(255, 226, 145, .18) inset,
    0 0 14px rgba(255, 199, 77, .18);
}
.user-menu__cta.user-menu__cta--standard:focus-visible{
  outline: none;
  border-color: rgba(255, 226, 145, .92);
  box-shadow:
    0 0 0 3px rgba(255, 211, 94, .16),
    0 12px 28px rgba(2, 10, 24, .42),
    0 0 20px rgba(255, 198, 64, .22);
}

.user-menu__cta.user-menu__cta--premium{
  border-color: rgba(255, 219, 92, .88);
  background: linear-gradient(140deg, rgba(78, 52, 8, .92), rgba(160, 108, 10, .78));
  color: #fff3b8;
  box-shadow: 0 0 18px rgba(255, 205, 70, .42), 0 10px 24px rgba(0, 0, 0, .36), inset 0 0 0 1px rgba(255, 238, 152, .20);
  text-shadow: 0 0 10px rgba(255, 223, 126, .72), 0 0 20px rgba(255, 208, 82, .40);
}
.user-menu__cta.user-menu__cta--premium:hover{
  transform: translateY(-2px);
  box-shadow: 0 0 22px rgba(255, 205, 70, .48), 0 14px 28px rgba(0, 0, 0, .4), inset 0 0 0 1px rgba(255, 238, 152, .24);
}
.user-menu__ctaNote{
  margin-top: 8px;
  padding: 0 6px;
  text-align: center;
  font-size: 12px;
  color: rgba(223, 233, 248, .72);
  line-height: 1.45;
}

.user-menu__metaValue{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 34px;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
  color: rgba(244, 249, 255, .92);
  font-weight: 800;
}

@media (prefers-reduced-motion: no-preference){
  .user-menu__cta.user-menu__cta--standard{
    animation: premiumDropdownBreath 3.8s ease-in-out infinite;
  }
}
@keyframes premiumDropdownBreath{
  0%,100%{
    box-shadow:
      0 10px 24px rgba(2, 10, 24, .42),
      0 0 0 1px rgba(255, 214, 122, .16) inset,
      0 0 14px rgba(255, 193, 59, .12);
  }
  50%{
    box-shadow:
      0 12px 28px rgba(2, 10, 24, .46),
      0 0 0 1px rgba(255, 224, 146, .18) inset,
      0 0 18px rgba(255, 201, 76, .18);
  }
}
@media (prefers-reduced-motion: reduce){
  .user-menu__cta,
  .user-menu__cta::before,
  .user-menu__row,
  .user-menu__panel,
  .user-menu__head,
  .user-menu__avatar--sm{
    animation: none !important;
    transition: none !important;
  }
}

/* Topbar background (admin) */
.topbar--bg{
  position: sticky;
}
.topbar--bg::before{
  content:"";
  position:absolute;
  inset:0;
  background-image: var(--topbar-bg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  opacity: .55;
  z-index: 0;
}
.topbar--bg::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, rgba(6,10,22,.85), rgba(6,10,22,.55));
  z-index: 1;
}
.topbar--bg .topbar__inner{
  position: relative;
  z-index: 2;
}

/* HOME FINAL OVERRIDE (main has .page--home, body may not) */
.page--home .home-scroll{
  position: relative !important;
  width: 100vw !important;
  height: calc(100vh - var(--topbar-h)) !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  scroll-snap-type: y mandatory !important;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}
.page--home .slide{
  width: 100vw !important;
  height: calc(100vh - var(--topbar-h)) !important;
  scroll-snap-align: start !important;
  scroll-snap-stop: always !important;
}
.page--home .chapter__media{
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}

/* Auth modal hardening UI */
#authModal .authCheckline{
  display:flex;
  align-items:flex-start;
  gap:10px;
  margin:10px 0;
  font-size:12px;
  color:rgba(233,238,252,.86);
}
#authModal .authCheckline input{
  width:16px;
  height:16px;
  margin-top:2px;
}
#authModal .authCaptchaRow{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:8px;
}
#authModal .authCaptchaQuestion{
  flex:1;
  min-height:40px;
  display:flex;
  align-items:center;
  padding:0 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.03);
  color:var(--text);
  font-weight:700;
}
#authModal .authCaptchaReload{
  padding:10px 12px;
  border-radius:12px;
  white-space:nowrap;
}
#authModal .authOauthSep{
  position: relative;
  margin: 10px 0;
  text-align: center;
}
#authModal .authOauthSep::before{
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 50%;
  border-top: 1px solid rgba(255,255,255,.12);
}
#authModal .authOauthSep span{
  position: relative;
  display: inline-block;
  padding: 0 10px;
  font-size: 12px;
  font-weight: 700;
  color: rgba(233,238,252,.72);
  background: linear-gradient(180deg, rgba(10,18,38,.92), rgba(7,11,24,.92));
}
#authModal .btn--google{
  border-color: rgba(255,255,255,.16);
  background: rgba(255,255,255,.05);
  justify-content: center;
}
#authModal .btn--google:hover{
  border-color: rgba(255,255,255,.26);
  background: rgba(255,255,255,.10);
}
#authModal .googleMark{
  width: 18px;
  height: 18px;
  border-radius: 50%;
  display: inline-grid;
  place-items: center;
  font-size: 11px;
  font-weight: 900;
  color: #1f4ed8;
  background: #fff;
}
#authModal .hint .link{
  font-weight:700;
}
@media (max-width: 700px){
  #authModal .row2{
    grid-template-columns:1fr;
  }
  #authModal .authCaptchaRow{
    flex-direction:column;
    align-items:stretch;
  }
}

/* Auth modal premium redesign + avatar flash fix */
.user-menu__avatar,
.user-menu__avatar--sm{
  background: #0d1626 !important;
  background-image: none !important;
}

#authModal{
  z-index: 24000;
}
#authModal .modal__backdrop{
  background:
    radial-gradient(60% 50% at 50% 20%, rgba(124,58,237,.28), transparent 75%),
    radial-gradient(55% 45% at 72% 76%, rgba(34,211,238,.16), transparent 78%),
    rgba(3,7,14,.80);
  backdrop-filter: blur(14px);
}
#authModal .modal__dialog{
  width: min(860px, calc(100vw - 56px)) !important;
  max-width: 860px !important;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.14);
  background: linear-gradient(175deg, rgba(12,18,32,.94), rgba(7,12,24,.96));
  box-shadow: 0 30px 90px rgba(0,0,0,.58), 0 0 0 1px rgba(124,58,237,.08) inset;
}
#authModal .modal__head{
  padding: 18px 20px 12px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
#authModal .iconbtn{
  width: 38px;
  height: 38px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.05);
  color: #eff5ff;
}
#authModal .iconbtn:hover{
  border-color: rgba(34,211,238,.45);
  background: rgba(34,211,238,.12);
}
#authModal .iconbtn svg{
  width: 20px;
  height: 20px;
  display: block;
  margin: auto;
}
#authModal .authBrand{
  display: flex;
  align-items: center;
  gap: 12px;
}
#authModal .authBrand__logo{
  width: 46px;
  height: 46px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.20);
  box-shadow: 0 10px 24px rgba(0,0,0,.36);
}
#authModal .authBrand__name{
  font-weight: 900;
  font-size: 20px;
  letter-spacing: .14em;
  color: #f3f7ff;
}
#authModal .authBrand__kicker{
  margin-top: 2px;
  font-size: 11px;
  letter-spacing: .11em;
  text-transform: uppercase;
  color: rgba(190,205,235,.84);
}
#authModal .authModal__titleLine{
  padding: 12px 20px 2px;
  text-align: left;
  color: rgba(223,234,255,.92);
  font-weight: 800;
  font-size: 13px;
  letter-spacing: .06em;
  text-transform: uppercase;
}
#authModal .modal__tabs{
  padding: 12px 20px 0;
  gap: 10px;
}
#authModal .tab{
  flex: 1;
  text-align: center;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  color: rgba(221,230,246,.75);
  font-weight: 800;
}
#authModal .tab:hover{
  color: #f4f7ff;
  border-color: rgba(255,255,255,.22);
  background: rgba(255,255,255,.08);
}
#authModal .tab.is-active{
  color: #f6f9ff;
  border-color: rgba(124,58,237,.58);
  background: linear-gradient(180deg, rgba(124,58,237,.26), rgba(124,58,237,.14));
  box-shadow: 0 8px 24px rgba(70,38,140,.34);
}
#authModal .modal__body{
  padding: 14px 20px 20px;
}
#authModal .field{
  margin: 0 0 12px;
}
#authModal .field:last-child{
  margin-bottom: 0;
}
#authModal .field label{
  margin-bottom: 7px;
  font-size: 12px;
  letter-spacing: .03em;
  color: rgba(193,208,237,.82);
}
#authModal .field input{
  min-height: 44px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  color: #f6f9ff;
}
#authModal .field input::placeholder{
  color: rgba(186,200,227,.52);
}
#authModal .field input:focus{
  border-color: rgba(34,211,238,.52);
  box-shadow: 0 0 0 3px rgba(34,211,238,.12);
}
#authModal .hint{
  color: rgba(198,212,239,.75);
  margin-top: 8px;
}
#authModal .hint ul{
  margin: 0;
  padding-left: 18px;
}
#authModal .msg{
  margin-top: 12px;
  color: rgba(190,205,235,.9);
}
#authModal .btn.primary{
  border-color: rgba(124,58,237,.52);
  background: linear-gradient(180deg, rgba(124,58,237,.32), rgba(124,58,237,.18));
  color: #f5f7ff;
}
#authModal .btn.primary:hover{
  border-color: rgba(124,58,237,.7);
  background: linear-gradient(180deg, rgba(124,58,237,.42), rgba(124,58,237,.24));
}
#authModal .btn--google{
  border-color: rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
}
#authModal .btn--google:hover{
  border-color: rgba(34,211,238,.46);
  background: rgba(34,211,238,.10);
}
#authModal .authOauthSep{
  margin: 12px 0;
}
#authModal .authOauthSep span{
  background: rgba(10,16,29,.96);
}

@media (max-width: 700px){
  #authModal .modal__dialog{
    width: calc(100% - 18px) !important;
    border-radius: 18px;
  }
  #authModal .modal__head{
    padding: 14px 14px 10px;
  }
  #authModal .authBrand__name{
    font-size: 16px;
    letter-spacing: .11em;
  }
  #authModal .authModal__titleLine{
    padding: 10px 14px 2px;
  }
  #authModal .modal__tabs{
    padding: 10px 14px 0;
  }
  #authModal .modal__body{
    padding: 12px 14px 14px;
  }
}

/* Auth modal refinement: compact premium flow */
#authModal .modal__dialog{
  width: min(840px, calc(100vw - 56px)) !important;
  max-width: 840px !important;
  font-family: "Rajdhani", "Bahnschrift", "Segoe UI", Arial, sans-serif;
}
#authModal .modal__head{
  padding: 14px 18px 10px;
}
#authModal .iconbtn{
  border-color: rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  opacity: .9;
}
#authModal .iconbtn:hover{
  opacity: 1;
}
#authModal .authBrand__logo{
  width: 42px;
  height: 42px;
}
#authModal .authBrand__name{
  font-size: 18px;
}
#authModal .authModal__titleLine{
  padding: 10px 18px 0;
}
#authModal .modal__tabs{
  display: inline-flex;
  width: auto;
  margin: 10px 18px 0;
  padding: 5px;
  gap: 5px;
  border: 1px solid rgba(255,255,255,.11);
  border-radius: 999px;
  background: rgba(255,255,255,.03);
}
#authModal .tab{
  flex: 0 0 auto;
  min-width: 120px;
  padding: 8px 14px;
  border: 1px solid transparent;
  border-radius: 999px;
  background: transparent;
  color: rgba(199,212,238,.75);
  font-size: 13px;
}
#authModal .tab:hover{
  border-color: rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
}
#authModal .tab.is-active{
  border-color: rgba(124,58,237,.48);
  background: linear-gradient(180deg, rgba(124,58,237,.26), rgba(124,58,237,.14));
  box-shadow: 0 6px 16px rgba(70,38,140,.28);
}
#authModal .modal__body{
  padding: 12px 18px 18px;
}
#authModal [data-pane="login"] form,
#authModal [data-pane="forgot"] form{
  max-width: 460px;
  margin: 0 auto;
}
#authModal [data-pane="register"] form{
  max-width: 520px;
  margin: 0 auto;
}
#authModal .field input{
  min-height: 46px;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: .02em;
  padding: 0 14px;
}
#authModal .field label{
  font-size: 13px;
  font-weight: 800;
}
#authModal .field input::placeholder{
  font-size: 15px;
}
#authModal .btn.primary{
  min-height: 50px;
  font-size: 15px;
  font-weight: 800;
  letter-spacing: .04em;
}
#authModal .btn--google{
  min-height: 46px;
  border-color: rgba(255,255,255,.20);
  background: rgba(255,255,255,.03);
  font-size: 15px;
  font-weight: 800;
  letter-spacing: .03em;
}
#authModal .btn--google:hover{
  border-color: rgba(34,211,238,.42);
  background: rgba(34,211,238,.08);
}
#authModal .authOauthSep{
  position: static;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin: 10px 0;
  text-align: center;
}
#authModal .authOauthSep::before{
  position: static;
  left: auto;
  right: auto;
  top: auto;
  content: "";
  flex: 1;
  border-top: 1px solid rgba(255,255,255,.14);
}
#authModal .authOauthSep::after{
  content: "";
  flex: 1;
  border-top: 1px solid rgba(255,255,255,.14);
}
#authModal .authOauthSep span{
  padding: 0;
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(198,212,239,.68);
  background: transparent;
}
#authModal .authLoginOptions{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 2px 0 10px;
}
#authModal .authRemember{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: rgba(198,212,239,.82);
}
#authModal .authRemember input{
  width: 15px;
  height: 15px;
}
#authModal .authForgotLink{
  font-size: 12px;
}
#authModal .hint{
  text-align: center;
}

@media (max-width: 700px){
  #authModal .modal__dialog{
    width: calc(100% - 18px) !important;
    max-width: none !important;
  }
  #authModal .modal__tabs{
    margin: 8px 14px 0;
    padding: 4px;
  }
  #authModal .tab{
    min-width: 108px;
    font-size: 12px;
  }
  #authModal .authLoginOptions{
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }
}

/* MFA code modal */
#mfaCodeModal{
  z-index: 25000;
}
#mfaCodeModal .modal__backdrop{
  background:
    radial-gradient(60% 52% at 50% 24%, rgba(34,211,238,.16), transparent 76%),
    rgba(4,8,16,.82);
  backdrop-filter: blur(12px);
}
#mfaCodeModal .mfaCodeModal__dialog{
  width: min(520px, calc(100vw - 30px));
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.14);
  background: linear-gradient(180deg, rgba(12,20,36,.96), rgba(8,13,24,.97));
  box-shadow: 0 24px 60px rgba(0,0,0,.52);
}
#mfaCodeModal .mfaCodeModal__head{
  padding: 16px 16px 10px;
}
#mfaCodeModal .mfaCodeModal__titleWrap{
  display: grid;
  gap: 4px;
}
#mfaCodeModal .mfaCodeModal__title{
  font-size: 18px;
  font-weight: 900;
  color: #f1f6ff;
  letter-spacing: .01em;
}
#mfaCodeModal .mfaCodeModal__subtitle{
  font-size: 13px;
  color: rgba(196,213,238,.86);
}
#mfaCodeModal .mfaCodeModal__field{
  margin: 0;
}
#mfaCodeModal .mfaCodeModal__field span{
  font-size: 12px;
  color: rgba(198,214,240,.88);
}
#mfaCodeModal #mfaCodeInput{
  min-height: 46px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.04);
  color: #f7faff;
  font-size: 18px;
  font-weight: 800;
  letter-spacing: .04em;
  text-align: center;
}
#mfaCodeModal #mfaCodeInput:focus{
  border-color: rgba(34,211,238,.55);
  box-shadow: 0 0 0 3px rgba(34,211,238,.12);
}
#mfaCodeModal .mfaCodeModal__error{
  margin: 2px 0 0;
  color: #ffb8b8;
  font-size: 13px;
  font-weight: 700;
}
#mfaCodeModal .mfaCodeModal__foot{
  padding: 10px 16px 14px;
}

/* Access ban modal */
#authBanModal{
  z-index: 25100;
}
#authBanModal .modal__backdrop{
  background:
    radial-gradient(60% 52% at 50% 24%, rgba(248,113,113,.16), transparent 76%),
    rgba(4,8,16,.84);
  backdrop-filter: blur(12px);
}
#authBanModal .authBanModal__dialog{
  width: min(560px, calc(100vw - 30px));
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.14);
  background: linear-gradient(180deg, rgba(18,14,24,.96), rgba(12,10,18,.97));
  box-shadow: 0 24px 64px rgba(0,0,0,.56);
}
#authBanModal .authBanModal__head{
  padding: 16px 16px 10px;
}
#authBanModal .authBanModal__title{
  font-size: 18px;
  font-weight: 900;
  color: #ffe7e7;
  letter-spacing: .01em;
}
#authBanModal .authBanModal__close{
  border-color: rgba(248,113,113,.34);
  background: rgba(248,113,113,.10);
  color: #ffd8d8;
}
#authBanModal .authBanModal__close:hover{
  border-color: rgba(252,165,165,.46);
  background: rgba(248,113,113,.18);
}
#authBanModal .authBanModal__body{
  display: grid;
  gap: 10px;
  padding: 8px 16px 14px;
}
#authBanModal .authBanModal__lead{
  margin: 0;
  color: #fff4f4;
  font-size: 15px;
  font-weight: 800;
  line-height: 1.45;
}
#authBanModal .authBanModal__timer{
  margin: -2px 0 0;
  color: #ffe4b8;
  font-size: 14px;
  font-weight: 900;
  letter-spacing: .01em;
}
#authBanModal .authBanModal__reason{
  margin: 0;
  color: rgba(255,213,213,.95);
  font-size: 14px;
  line-height: 1.5;
  padding: 10px 12px;
  border: 1px solid rgba(248,113,113,.28);
  border-radius: 10px;
  background: rgba(248,113,113,.08);
}
#authBanModal .authBanModal__support{
  margin: 0;
  color: rgba(242,226,255,.88);
  font-size: 13px;
  line-height: 1.5;
}
#authBanModal .authBanModal__compose{
  margin-top: 4px;
  padding: 10px 12px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 12px;
  background: rgba(255,255,255,.03);
  display: grid;
  gap: 8px;
}
#authBanModal .authBanModal__composeLabel{
  font-size: 12px;
  font-weight: 800;
  color: rgba(220,230,255,.92);
  letter-spacing: .02em;
  text-transform: uppercase;
}
#authBanModal .authBanModal__textarea{
  width: 100%;
  min-height: 108px;
  resize: vertical;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(8,14,26,.78);
  color: #f4f8ff;
  padding: 10px 12px;
  outline: none;
  line-height: 1.5;
}
#authBanModal .authBanModal__textarea:focus{
  border-color: rgba(34,211,238,.55);
  box-shadow: 0 0 0 3px rgba(34,211,238,.12);
}
#authBanModal .authBanModal__composeStatus{
  margin: 0;
  min-height: 18px;
  font-size: 12px;
  color: rgba(226,238,255,.92);
}
#authBanModal .authBanModal__composeActions{
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}
#authBanModal .authBanModal__foot{
  padding: 10px 16px 14px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}
#authBanModal .authBanModal__supportBtn{
  border-color: rgba(248,113,113,.34);
  color: #ffd4d4;
}
#authBanModal .authBanModal__supportBtn:hover{
  border-color: rgba(252,165,165,.50);
  background: rgba(248,113,113,.14);
}

/* Premium activation modal */
#premiumCongratsModal{
  z-index: 25150;
}
#premiumCongratsModal .modal__backdrop{
  background:
    radial-gradient(58% 52% at 50% 20%, rgba(250,204,21,.22), transparent 76%),
    rgba(3,7,14,.84);
  backdrop-filter: blur(12px);
}
#premiumCongratsModal .premiumCongratsModal__dialog{
  width: min(540px, calc(100vw - 30px));
  border-radius: 20px;
  border: 1px solid rgba(250,204,21,.22);
  background:
    radial-gradient(120% 90% at 14% -8%, rgba(250,204,21,.12), transparent 56%),
    linear-gradient(180deg, rgba(17,15,28,.98), rgba(10,11,20,.98));
  box-shadow: 0 28px 70px rgba(0,0,0,.58), 0 0 0 1px rgba(250,204,21,.06) inset;
}
#premiumCongratsModal .premiumCongratsModal__head{
  padding: 16px 16px 10px;
}
#premiumCongratsModal .premiumCongratsModal__titleWrap{
  display: grid;
  gap: 4px;
}
#premiumCongratsModal .premiumCongratsModal__title{
  font-size: 20px;
  font-weight: 900;
  color: #fff5cf;
  letter-spacing: .01em;
}
#premiumCongratsModal .premiumCongratsModal__subtitle{
  font-size: 13px;
  color: rgba(247,229,176,.82);
}
#premiumCongratsModal .premiumCongratsModal__close{
  border-color: rgba(250,204,21,.26);
  background: rgba(250,204,21,.10);
  color: #fff0b0;
}
#premiumCongratsModal .premiumCongratsModal__close:hover{
  border-color: rgba(253,224,71,.42);
  background: rgba(250,204,21,.16);
}
#premiumCongratsModal .premiumCongratsModal__body{
  display: grid;
  gap: 12px;
  padding: 10px 16px 16px;
  text-align: center;
}
#premiumCongratsModal .premiumCongratsModal__icon{
  width: 68px;
  height: 68px;
  margin: 4px auto 0;
  display: grid;
  place-items: center;
  border-radius: 999px;
  border: 1px solid rgba(250,204,21,.28);
  background: radial-gradient(circle at 50% 35%, rgba(253,224,71,.30), rgba(120,53,15,.20));
  color: #fff4c7;
  font-size: 30px;
  box-shadow: 0 0 24px rgba(250,204,21,.18);
}
#premiumCongratsModal .premiumCongratsModal__lead{
  margin: 0;
  color: #fffaf0;
  font-size: 17px;
  font-weight: 800;
  line-height: 1.5;
}
#premiumCongratsModal .premiumCongratsModal__until{
  margin: 0;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid rgba(250,204,21,.18);
  background: rgba(250,204,21,.08);
  color: rgba(255,243,208,.96);
  font-size: 14px;
  line-height: 1.5;
}
#premiumCongratsModal .premiumCongratsModal__foot{
  padding: 0 16px 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}

/* Guide validation modal */
#guideValidatedModal{
  z-index: 25160;
}
#guideValidatedModal .modal__backdrop{
  background:
    radial-gradient(60% 52% at 50% 20%, rgba(34,197,94,.18), transparent 76%),
    rgba(3,8,15,.84);
  backdrop-filter: blur(12px);
}
#guideValidatedModal .guideValidatedModal__dialog{
  width: min(520px, calc(100vw - 30px));
  border-radius: 16px;
  border: 1px solid rgba(34,197,94,.26);
  background:
    radial-gradient(120% 95% at 12% -10%, rgba(34,197,94,.12), transparent 56%),
    linear-gradient(180deg, rgba(12,20,33,.98), rgba(8,13,22,.98));
  box-shadow: 0 24px 60px rgba(0,0,0,.58), 0 0 0 1px rgba(34,197,94,.08) inset;
  animation: guideValidatedModalIn .2s ease;
}
@keyframes guideValidatedModalIn{
  from{
    opacity: 0;
    transform: translateY(6px) scale(.98);
  }
  to{
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
#guideValidatedModal .guideValidatedModal__head{
  padding: 16px 18px 8px;
}
#guideValidatedModal .guideValidatedModal__badge{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 28px;
  padding: 5px 10px;
  border-radius: 999px;
  border: 1px solid rgba(34,197,94,.34);
  background: rgba(34,197,94,.12);
  color: #dafde7;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}
#guideValidatedModal .guideValidatedModal__badgeDot{
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: #4ade80;
  box-shadow: 0 0 10px rgba(74,222,128,.75);
}
#guideValidatedModal .guideValidatedModal__close{
  border-color: rgba(34,197,94,.24);
  background: rgba(34,197,94,.08);
  color: #d9ffe8;
}
#guideValidatedModal .guideValidatedModal__close:hover{
  border-color: rgba(74,222,128,.42);
  background: rgba(34,197,94,.16);
}
#guideValidatedModal .guideValidatedModal__body{
  padding: 8px 18px 14px;
  display: grid;
  gap: 12px;
  justify-items: center;
  text-align: center;
}
#guideValidatedModal .guideValidatedModal__iconWrap{
  width: 74px;
  height: 74px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(34,197,94,.3);
  background: radial-gradient(circle at 50% 36%, rgba(74,222,128,.32), rgba(22,101,52,.26));
  box-shadow: 0 0 26px rgba(34,197,94,.18);
  position: relative;
}
#guideValidatedModal .guideValidatedModal__icon{
  font-size: 32px;
  line-height: 1;
  animation: guideValidatedThumb 1.3s ease-in-out infinite;
  transform-origin: 55% 70%;
}
@keyframes guideValidatedThumb{
  0%, 100%{ transform: rotate(0deg) scale(1); }
  35%{ transform: rotate(-10deg) scale(1.08); }
  70%{ transform: rotate(5deg) scale(1.02); }
}
#guideValidatedModal .guideValidatedModal__check{
  position: absolute;
  right: 3px;
  bottom: 3px;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  font-size: 14px;
  font-weight: 900;
  color: #0b1e14;
  background: #4ade80;
  border: 1px solid rgba(255,255,255,.7);
  box-shadow: 0 0 10px rgba(74,222,128,.45);
}
#guideValidatedModal .guideValidatedModal__title{
  margin: 0;
  color: #effff5;
  font-size: 1.3rem;
  font-weight: 900;
  letter-spacing: .01em;
}
#guideValidatedModal .guideValidatedModal__text{
  margin: 0;
  color: rgba(222,238,255,.9);
  font-size: .97rem;
  line-height: 1.58;
}
#guideValidatedModal .guideValidatedModal__foot{
  padding: 0 18px 18px;
  display: flex;
  gap: 10px;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
}
#guideValidatedModal .guideValidatedModal__foot .btn{
  min-height: 42px;
}
@media (max-width: 560px){
  #premiumCongratsModal .premiumCongratsModal__foot{
    flex-direction: column;
    align-items: stretch;
  }
  #premiumCongratsModal .premiumCongratsModal__foot .btn{
    width: 100%;
  }
}
@media (max-width: 560px){
  #authBanModal .authBanModal__foot{
    flex-direction: column;
    align-items: stretch;
  }
  #authBanModal .authBanModal__foot .btn{
    width: 100%;
  }
  #guideValidatedModal .guideValidatedModal__foot{
    flex-direction: column;
    align-items: stretch;
  }
  #guideValidatedModal .guideValidatedModal__foot .btn{
    width: 100%;
    justify-content: center;
  }
}

.section.profile .profileBroadcastMessages{
  display:grid;
  gap:8px;
  margin:10px 0 14px;
  padding:10px 12px;
  border:1px solid rgba(250,204,21,.22);
  border-radius:10px;
  background:rgba(145,94,14,.12);
}
.section.profile .profileBroadcastMessages__title{
  font-size:12px;
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:#ffe8b3;
}
.section.profile .profileBroadcastMessages__item{
  border:1px solid rgba(250,204,21,.18);
  border-radius:8px;
  background:rgba(0,0,0,.16);
  padding:8px 10px;
}
.section.profile .profileBroadcastMessages__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  color:#fff3cd;
  font-size:13px;
}
.section.profile .profileBroadcastMessages__head span{
  color:#ead9b0;
  font-size:11px;
}
.section.profile .profileBroadcastMessages__body{
  margin-top:5px;
  color:#f7f3ea;
  font-size:13px;
  line-height:1.45;
}
