/* rules-page.css — Правила в стиле главной FunFernus */

/* Центрируем контент правил */
.rules-centered{
  max-width: 980px;
  margin: 0 auto;
  padding: 10px 0 40px;
}

/* Чуть компактнее hero на странице правил */
.rules-hero{
  position: relative;
  overflow: hidden;
}

/* Секции правил */
.rules-main{
  display: grid;
  gap: 22px;
}

.rules-section{
  scroll-margin-top: 128px; /* учитываем шапку + верхнюю навигацию */
}

/* Заголовок секции (как в примере) */
.section-header{
  display:flex;
  align-items:center;
  gap: 12px;
  margin: 18px 0 12px;
}
.section-icon{
  width:44px; height:44px;
  display:grid; place-items:center;
  border-radius: 16px;
  background: rgba(255,140,0,.14);
  border:1px solid rgba(255,180,80,.28);
}
.section-title-content h2{
  margin:0;
  font-size: 22px;
  font-weight: 900;
  letter-spacing: -0.02em;
}
.section-subtitle{
  margin: 6px 0 0;
  color: rgba(233,236,244,.72);
  font-size: 13px;
  text-align:left;
}

/* Карточка правила */
.rule-card{
  border-radius: 22px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(20,23,42,.55);
  box-shadow: 0 18px 70px rgba(0,0,0,.38);
  overflow:hidden;
}

.rule-header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 12px;
  padding: 14px 16px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(520px 190px at 18% 0%, rgba(255,140,0,.12), transparent 60%),
    rgba(12,14,24,.30);
}

.rule-number{
  margin:0;
  font-size: 16px;
  font-weight: 900;
  letter-spacing: -0.01em;
}

.rule-penalty{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 14px;
  border:1px solid rgba(255,180,80,.40);
  background: rgba(255,140,0,.12);
  color: rgba(255,224,160,.98);
  font-weight: 900;
  font-size: 12px;
  white-space: nowrap;
}
.rule-penalty i{opacity:.9}

/* Тело правила */
.rule-content{
  padding: 14px 16px;
  color: rgba(233,236,244,.86);
  line-height: 1.7;
  font-size: 14px;
}
.rule-content p{margin: 0 0 10px;}
.rule-content ul{margin: 6px 0 12px 18px; padding:0;}
.rule-content li{margin: 6px 0;}

.rule-content h4{
  margin: 12px 0 8px;
  font-size: 13px;
  letter-spacing: .2px;
  color: rgba(255,224,160,.96);
  display:flex; align-items:center; gap:8px;
}
.rule-content h4 i{opacity:.9}

/* Мелкие блоки внутри правила */
.rule-definition,
.rule-examples,
.rule-limitations,
.rule-notes{
  margin: 10px 0;
  padding: 10px 12px;
  border-radius: 16px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(12,14,24,.28);
}

/* ===== Верхняя навигация по разделам ===== */
.rules-topnav-wrap{
  position: sticky;
  top: 74px;
  z-index: 25;
  backdrop-filter: blur(10px);
  background: rgba(7, 8, 16, .55);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.rules-topnav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 10px 0;
}
.rules-topnav .top-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 10px 12px;
  border-radius: 16px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  color: rgba(233,236,244,.86);
  text-decoration:none;
  font-weight: 900;
  font-size: 13px;
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
  white-space: nowrap;
}
.rules-topnav .top-link:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.06);
  border-color: rgba(255,180,80,.22);
}
.rules-topnav .top-link.active{
  border-color: rgba(255,180,80,.40);
  background: rgba(255,140,0,.10);
  color: rgba(255,224,160,.98);
}

/* Мобильный dropdown */
.rules-sections-dropdown{display:none; position:relative;}
.btn.small{padding: 9px 12px; font-size: 13px; border-radius: 16px;}
.rules-sections-menu{
  position:absolute;
  right:0;
  top: calc(100% + 10px);
  min-width: 220px;
  padding: 10px;
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(14,16,30,.95);
  box-shadow: 0 18px 70px rgba(0,0,0,.45);
  display:none;
}
.rules-sections-menu.open{display:block;}
.rules-sections-menu a{
  display:block;
  padding: 10px 12px;
  border-radius: 14px;
  text-decoration:none;
  color: rgba(233,236,244,.86);
  font-weight: 800;
  font-size: 13px;
}
.rules-sections-menu a:hover{
  background: rgba(255,140,0,.10);
}

@media (max-width: 768px){
  .rules-topnav{justify-content:flex-end;}
  .rules-topnav .top-link{display:none;}
  .rules-sections-dropdown{display:block;}
}

/* ===== FAQ — аккуратный аккордеон ===== */
.faq-container{
  display:grid;
  gap: 12px;
}
.faq-item{
  border-radius: 22px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(20,23,42,.55);
  box-shadow: 0 18px 70px rgba(0,0,0,.38);
  overflow:hidden;
}
.faq-question{
  width:100%;
  border:0;
  background:
    radial-gradient(520px 190px at 18% 0%, rgba(255,140,0,.10), transparent 60%),
    rgba(12,14,24,.30);
  color: rgba(233,236,244,.92);
  padding: 14px 16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  cursor:pointer;
  font-weight: 900;
  font-size: 14px;
  text-align:left;
}
.faq-question span{flex:1;}
.faq-question i{transition: transform .2s ease; opacity:.85;}
.faq-answer{
  padding: 0 16px;
  max-height: 0;
  overflow:hidden;
  transition: max-height .25s ease, padding .25s ease;
  color: rgba(233,236,244,.86);
  line-height: 1.7;
  font-size: 14px;
}
.faq-answer p{margin: 12px 0 14px;}
.faq-item.active .faq-answer{
  padding: 0 16px 12px;
  max-height: 340px;
}
.faq-item.active .faq-question i{transform: rotate(180deg);}

/* Футер страницы правил */
.footer-simple{
  padding: 26px 0;
  border-top: 1px solid rgba(255,255,255,.08);
  background: rgba(7,8,16,.55);
}
.footer-simple-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}
.footer-simple-brand{
  display:flex;
  align-items:center;
  gap:10px;
}
.footer-simple-text{
  line-height:1.2;
}
.footer-simple-text span{
  display:block;
  color:rgba(233,236,244,.6);
  font-size:12px;
}
.footer-simple-copy{
  color:rgba(233,236,244,.6);
  font-size:12px;
}

/* Адаптив */
@media (max-width: 768px){
  .rules-centered{padding-left: 0; padding-right: 0;}
  .rule-header{flex-direction: column; align-items:flex-start;}
  .rule-penalty{align-self:flex-end;}
  .section-header{margin-top: 10px;}
}


/* === Refined rules page redesign === */
.rules-centered{
  max-width: 1120px;
  margin: 0 auto;
  padding: 18px 0 44px;
}
.rules-main{display:grid; gap:28px;}
.rules-stack{display:grid; gap:18px;}
.rules-section{scroll-margin-top:140px;}
.rules-hero{
  padding: 34px 0 18px;
}
.rules-hero .hero-inner{
  max-width: 860px;
}
.rules-hero .hero-inner p{
  max-width: 720px;
}
.rules-topnav-wrap{
  top: 73px;
  background: rgba(8,10,18,.72);
  border-bottom: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 18px 50px rgba(0,0,0,.22);
}
.rules-topnav{
  gap:10px;
  justify-content: center;
  flex-wrap: wrap;
  padding: 12px 0;
}
.rules-topnav .top-link{
  min-height: 42px;
  padding: 10px 14px;
  background: rgba(255,255,255,.045);
  border-color: rgba(255,255,255,.09);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
}
.rules-topnav .top-link.active{
  box-shadow: 0 10px 30px rgba(255,140,0,.18), inset 0 1px 0 rgba(255,255,255,.06);
}
.section-header.elegant{
  margin: 0 0 14px;
  padding: 16px 18px;
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255,140,0,.08), rgba(20,23,42,.56));
  box-shadow: 0 18px 50px rgba(0,0,0,.26);
}
.section-icon{
  width: 52px;
  height: 52px;
  border-radius: 18px;
  box-shadow: 0 0 0 1px rgba(255,180,80,.08) inset, 0 14px 34px rgba(255,140,0,.08);
}
.section-title-content h2{font-size: 28px;}
.section-subtitle{font-size:14px; max-width:760px;}
.exact-rule-card{
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255,175,70,.045), rgba(20,23,42,.72));
  border: 1px solid rgba(255,255,255,.1);
  box-shadow: 0 24px 70px rgba(0,0,0,.34);
  overflow: hidden;
}
.exact-rule-card:hover{
  border-color: rgba(255,180,80,.22);
  box-shadow: 0 28px 80px rgba(0,0,0,.4);
}
.rule-header{
  padding: 18px 18px 16px;
  align-items: center;
  background: radial-gradient(600px 220px at 15% 0%, rgba(255,140,0,.15), transparent 60%), rgba(10,12,22,.34);
}
.rule-heading-wrap{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
}
.rule-chip{
  flex:0 0 auto;
  min-width:64px;
  text-align:center;
  padding: 10px 12px;
  border-radius: 16px;
  background: rgba(255,140,0,.16);
  border: 1px solid rgba(255,180,80,.32);
  color: rgba(255,226,168,.98);
  font-weight: 900;
}
.rule-number{font-size:18px; line-height:1.35;}
.rule-penalty{
  flex:0 0 auto;
  white-space: normal;
  max-width: 320px;
  justify-content:center;
}
.exact-rule-content{
  display:grid;
  gap:12px;
  padding: 18px;
}
.rule-subpoint{
  padding: 14px 14px 12px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(9,12,20,.34);
}
.subpoint-head{
  display:grid;
  grid-template-columns: 76px minmax(0, 1fr);
  gap:12px;
  align-items:start;
}
.subpoint-num{
  display:inline-flex;
  justify-content:center;
  align-items:center;
  min-height: 38px;
  padding: 8px 10px;
  border-radius: 14px;
  background: rgba(255,140,0,.12);
  border:1px solid rgba(255,180,80,.24);
  color: rgba(255,215,128,.96);
  font-weight:900;
  font-variant-numeric: tabular-nums;
}
.subpoint-lead{
  margin: 0;
  font-size: 14px;
  line-height: 1.72;
  color: rgba(240,242,248,.95);
}
.subpoint-label{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin: 12px 0 4px 88px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  color: rgba(255,232,180,.96);
  font-size: 12px;
  font-weight: 800;
}
.subpoint-body{
  margin-left: 88px;
  color: rgba(233,236,244,.84);
  line-height: 1.72;
  font-size: 14px;
}
.subpoint-body p{margin: 8px 0 0;}
.rule-points{
  margin: 10px 0 0 18px;
  padding:0;
}
.rule-points li{margin: 8px 0;}
.penalty-box{
  border-color: rgba(255,180,80,.24);
  background: linear-gradient(180deg, rgba(255,140,0,.11), rgba(16,18,30,.46));
}
.note-box{
  border-color: rgba(255,255,255,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.045), rgba(16,18,30,.42));
}
.info-box{
  border-color: rgba(255,210,120,.18);
  background: linear-gradient(180deg, rgba(255,200,110,.08), rgba(16,18,30,.42));
}
.faq-container{margin-top: 6px;}
.faq-item{border-radius:24px;}
.faq-question{padding:16px 18px;}
.faq-answer{font-size:14px;}

@media (max-width: 960px){
  .rules-centered{max-width: 100%;}
  .rule-header{align-items:flex-start;}
  .rule-heading-wrap{align-items:flex-start;}
  .rule-penalty{max-width: 260px;}
}

@media (max-width: 768px){
  .rules-topnav-wrap{top: 68px;}
  .rules-topnav{
    justify-content:flex-end;
    padding: 10px 0;
  }
  .rules-sections-dropdown{display:block;}
  .rules-sections-menu{
    min-width: 240px;
    max-width: min(92vw, 300px);
  }
  .section-header.elegant{
    padding: 14px;
    gap: 10px;
  }
  .section-title-content h2{font-size:24px;}
  .rule-header{
    flex-direction: column;
    align-items: stretch;
  }
  .rule-penalty{
    max-width: none;
    width: fit-content;
  }
}

@media (max-width: 560px){
  .rules-hero{padding: 24px 0 12px;}
  .rules-topnav-wrap{top: 64px;}
  .rules-centered{padding: 10px 0 28px;}
  .section-icon{width:46px; height:46px;}
  .section-title-content h2{font-size:22px;}
  .section-subtitle{font-size:13px;}
  .exact-rule-content{padding: 14px; gap:10px;}
  .rule-chip{min-width:58px; padding: 8px 10px;}
  .rule-number{font-size:16px;}
  .subpoint-head{
    grid-template-columns: 1fr;
    gap:8px;
  }
  .subpoint-num{
    width: fit-content;
    min-height: 34px;
  }
  .subpoint-label,
  .subpoint-body{
    margin-left: 0;
  }
  .subpoint-body{font-size:13.5px;}
  .faq-question,
  .faq-answer{font-size:13.5px;}
}


/* ===== Sidebar navigation refresh ===== */
.rules-centered{
  max-width: 1260px;
}

.rules-shell{
  display:grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 28px;
  align-items:start;
}

.rules-sidebar{
  position: relative;
}

.rules-sidebar-card{
  position: sticky;
  top: 110px;
  border-radius: 28px;
  padding: 22px;
  background:
    linear-gradient(180deg, rgba(255,170,60,.08), rgba(255,140,0,.02)),
    rgba(10,13,36,.72);
  border: 1px solid rgba(255,184,77,.20);
  box-shadow: 0 20px 60px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.04);
  overflow:hidden;
}

.rules-sidebar-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 15% 15%, rgba(255,171,59,.18), transparent 30%),
    radial-gradient(circle at 82% 85%, rgba(255,140,0,.14), transparent 34%);
  pointer-events:none;
}

.rules-sidebar-top,
.rules-side-links{
  position:relative;
  z-index:1;
}

.rules-sidebar-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.14em;
  color: var(--accent-2);
  margin-bottom: 12px;
}

.rules-sidebar-top h2{
  margin:0;
  font-size: 24px;
  line-height:1.05;
}

.rules-sidebar-top p{
  margin: 12px 0 18px;
  color: rgba(233,236,244,.72);
  line-height:1.5;
  font-size:14px;
}

.rules-side-links{
  display:grid;
  gap:10px;
}

.rules-side-link{
  display:flex;
  align-items:center;
  gap:12px;
  padding: 14px 16px;
  border-radius: 18px;
  color: var(--text);
  text-decoration:none;
  background: rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
  transition: transform .22s ease, border-color .22s ease, background .22s ease, box-shadow .22s ease;
}

.rules-side-link i{
  width: 20px;
  text-align:center;
  color: var(--accent-2);
}

.rules-side-link span{
  font-weight: 700;
}

.rules-side-link:hover,
.rules-side-link.active{
  transform: translateX(4px);
  border-color: rgba(255,184,77,.34);
  background: linear-gradient(90deg, rgba(255,170,60,.14), rgba(255,255,255,.05));
  box-shadow: 0 14px 34px rgba(255,140,0,.12);
}

.rules-main{
  min-width: 0;
}

@media (max-width: 980px){
  .rules-shell{
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .rules-sidebar-card{
    position: sticky;
    top: 82px;
    padding: 16px;
    border-radius: 22px;
  }

  .rules-sidebar-top p{
    margin-bottom: 14px;
    font-size: 13px;
  }

  .rules-side-links{
    display:flex;
    gap:10px;
    overflow:auto;
    padding-bottom: 2px;
    scrollbar-width: none;
  }

  .rules-side-links::-webkit-scrollbar{ display:none; }

  .rules-side-link{
    flex: 0 0 auto;
    min-width: max-content;
    padding: 12px 14px;
    border-radius: 16px;
  }

  .rules-side-link:hover,
  .rules-side-link.active{
    transform:none;
  }
}

@media (max-width: 640px){
  .rules-centered{
    padding-top: 4px;
  }

  .rules-sidebar-card{
    top: 74px;
    padding: 14px;
  }

  .rules-sidebar-top h2{
    font-size: 20px;
  }

  .rules-sidebar-top p{
    display:none;
  }

  .rules-side-link{
    padding: 11px 13px;
    font-size: 14px;
  }
}

.rules-topnav-wrap{display:none !important;}


/* Sticky fixes */
.rules-page{overflow:visible;}
.rules-shell, .rules-main, .rules-sidebar{overflow:visible;}
.rules-sidebar{align-self:start;}
.rules-sidebar-card{position:sticky; top:88px;}
.rules-side-links{display:grid; gap:10px;}

@media (min-width: 981px){
  .rules-sidebar{position:sticky; top:88px;}
  .rules-sidebar-card{position:sticky; top:88px;}
}

@media (max-width: 980px){
  .rules-shell{grid-template-columns:1fr;}
  .rules-sidebar{position:sticky; top:72px; z-index:35; margin-bottom:10px;}
  .rules-sidebar-card{position:sticky; top:72px; padding:12px 14px; border-radius:18px;}
  .rules-sidebar-top{display:none;}
  .rules-side-links{display:flex; flex-wrap:nowrap; overflow-x:auto; -webkit-overflow-scrolling:touch; padding-bottom:2px; gap:8px;}
  .rules-side-link{flex:0 0 auto; min-width:max-content; padding:10px 12px; border-radius:14px; font-size:13px;}
  .rules-side-link i{width:auto;}
}

@media (max-width: 640px){
  .rules-sidebar{top:64px;}
  .rules-sidebar-card{top:64px;}
}


/* Sticky navigation polish */
.rules-page{overflow:visible;}
.rules-shell{align-items:start;}
.rules-sidebar{display:block; align-self:start; min-width:0;}
.rules-sidebar-card{position:sticky; top:96px; max-height:calc(100vh - 116px); overflow:auto; scrollbar-width:none;}
.rules-sidebar-card::-webkit-scrollbar{display:none;}
.rules-side-links{display:grid; gap:10px;}

@media (min-width: 981px){
  .rules-sidebar{position:relative;}
  .rules-sidebar-card{top:96px;}
}

@media (max-width: 980px){
  .rules-shell{grid-template-columns:1fr;}
  .rules-sidebar{position:sticky; top:74px; z-index:60; margin-bottom:10px;}
  .rules-sidebar-card{top:74px; max-height:none; overflow:visible; padding:12px 14px; border-radius:18px;}
  .rules-sidebar-top{display:none;}
  .rules-side-links{display:flex; flex-wrap:nowrap; gap:8px; overflow-x:auto; -webkit-overflow-scrolling:touch; padding:2px 0 4px;}
  .rules-side-link{flex:0 0 auto; min-width:max-content; padding:10px 12px; border-radius:14px; font-size:13px;}
  .rules-side-link span{display:inline;}
}

@media (max-width: 640px){
  .rules-page{padding-top:14px;}
  .rules-sidebar{top:64px;}
  .rules-sidebar-card{top:64px; display:block;}
  .rules-side-link{padding:10px 12px; font-size:12.5px;}
}


/* ===== Final sticky/sidebar layout overrides ===== */
.rules-centered{
  max-width: 1280px;
}
.rules-shell{
  display:grid;
  grid-template-columns: minmax(250px, 290px) minmax(0, 1fr);
  gap: 22px;
  align-items: start;
}
.rules-main,
.rules-sidebar,
.rules-shell,
.rules-page,
main{
  overflow: visible;
}
.rules-sidebar{
  position: sticky;
  top: 96px;
  align-self: start;
  height: fit-content;
  z-index: 30;
}
.rules-sidebar-card{
  position: relative;
  top: auto;
  max-height: calc(100vh - 118px);
  overflow: auto;
  scrollbar-width: none;
}
.rules-sidebar-card::-webkit-scrollbar{
  display: none;
}
.rules-side-links{
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
.rules-side-link{
  min-width: 0;
}
.rules-side-link span{
  white-space: normal;
}
@media (max-width: 980px){
  .rules-shell{
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .rules-sidebar{
    position: sticky;
    top: 72px;
    z-index: 70;
    margin-bottom: 6px;
  }
  .rules-sidebar-card{
    max-height: none;
    overflow: visible;
    padding: 12px;
    border-radius: 18px;
  }
  .rules-sidebar-top{
    display: none;
  }
  .rules-side-links{
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }
  .rules-side-link{
    min-width: 0;
    white-space: normal;
    justify-content: center;
    text-align: center;
    padding: 11px 10px;
    line-height: 1.25;
  }
  .rules-side-link i{
    margin-right: 6px;
    width: auto;
  }
}
@media (max-width: 560px){
  .rules-sidebar{
    top: 64px;
  }
  .rules-sidebar-card{
    padding: 10px;
    border-radius: 16px;
  }
  .rules-side-links{
    grid-template-columns: 1fr 1fr;
  }
  .rules-side-link{
    padding: 10px 8px;
    font-size: 12px;
  }
}

.rules-sidebar{position:sticky; top:92px; align-self:start}
@media (max-width: 980px){
  .rules-sidebar{position:sticky; top:74px; z-index:30; margin-bottom:18px}
  .rules-sidebar-card{padding:14px}
  .rules-side-links{display:grid !important; grid-template-columns:repeat(2,minmax(0,1fr)); gap:10px}
  .rules-side-link{min-width:0; justify-content:center; text-align:center; padding:12px 10px !important}
  .rules-side-link span{font-size:13px; line-height:1.25}
}
@media (max-width: 640px){
  .rules-side-links{grid-template-columns:1fr 1fr}
}
.rules-admin-fab{position:fixed; right:20px; bottom:20px; z-index:1200; display:none}
.rules-admin-fab.show{display:inline-flex}
.rules-admin-panel{position:fixed; inset:0; background:rgba(5,8,18,.72); z-index:5200; display:none; align-items:center; justify-content:center; padding:20px}
.rules-admin-panel.open{display:flex}
.rules-admin-card{width:min(1100px, 96vw); max-height:90vh; overflow:auto; background:rgba(15,18,32,.98); border:1px solid rgba(255,255,255,.12); border-radius:24px; box-shadow:0 30px 90px rgba(0,0,0,.5); padding:22px}
.rules-admin-top{display:flex; gap:14px; justify-content:space-between; align-items:flex-start; margin-bottom:16px}
.rules-admin-top h3{margin:0 0 6px; font-size:28px}
.rules-admin-top p{margin:0; color:var(--muted)}
.rules-admin-actions,.rules-admin-quick{display:flex; flex-wrap:wrap; gap:10px}
.rules-admin-grid{display:grid; grid-template-columns:1.15fr .85fr; gap:16px}
.rules-admin-textarea{width:100%; min-height:58vh; background:rgba(8,10,20,.9); color:var(--text); border:1px solid rgba(255,255,255,.1); border-radius:18px; padding:16px; font:14px/1.5 ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; resize:vertical}
.rules-admin-help{background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); border-radius:18px; padding:16px}
.rules-admin-help h4{margin:0 0 10px}
.rules-admin-help p,.rules-admin-help li{color:var(--muted)}
.rules-admin-help ul{margin:10px 0 0 18px; padding:0}
.rules-admin-auth{display:flex; gap:10px; margin-top:12px}
.rules-admin-auth input{flex:1; min-width:0; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12); color:var(--text); border-radius:14px; padding:12px 14px}
@media (max-width: 920px){.rules-admin-grid{grid-template-columns:1fr}}

.rules-quick-builder{margin-bottom:16px; padding:18px; border-radius:22px; background:rgba(18,21,37,.78); border:1px solid rgba(255,179,71,.18); box-shadow:0 14px 40px rgba(0,0,0,.24)}
.rules-quick-builder h4{margin:0 0 14px; display:flex; align-items:center; gap:10px; font-size:18px}
.rules-builder-grid{display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:14px}
.rules-builder-grid label{display:grid; gap:8px; font-size:13px; color:var(--muted)}
.rules-builder-grid label:nth-child(4),.rules-builder-grid label:nth-child(6){grid-column:1/-1}
.rules-builder-grid input,.rules-builder-grid select,.rules-builder-grid textarea{width:100%; border-radius:16px; border:1px solid rgba(255,255,255,.10); background:rgba(9,12,22,.82); color:#fff; padding:12px 14px; font:inherit; resize:vertical}
.rules-builder-grid input:focus,.rules-builder-grid select:focus,.rules-builder-grid textarea:focus{outline:none; border-color:rgba(255,179,71,.4); box-shadow:0 0 0 3px rgba(255,179,71,.10)}
.rules-builder-actions{display:flex; align-items:center; gap:12px; margin-top:14px; flex-wrap:wrap}
.rules-builder-actions span{color:var(--muted); font-size:13px}
@media (max-width: 860px){.rules-builder-grid{grid-template-columns:1fr}.rules-builder-grid label:nth-child(4),.rules-builder-grid label:nth-child(6){grid-column:auto}}
.rules-inline-row{display:flex; gap:10px; align-items:center}
.rules-inline-row .btn{flex:0 0 auto}
.rules-inline-row input{flex:1 1 auto}
.rules-subitems-block{margin-top:16px; padding:14px; border-radius:20px; border:1px solid rgba(255,255,255,.08); background:rgba(255,255,255,.04)}
.rules-subitems-top{display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:12px}
.rules-subitems-top h5{margin:0; font-size:15px}
#rulesSubpointsWrap{display:grid; gap:12px}
.rules-subitem-row{padding:12px; border-radius:18px; border:1px solid rgba(255,255,255,.08); background:rgba(9,12,22,.55)}
.rules-subitem-head{display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:10px}
.rules-builder-grid.compact{grid-template-columns:220px minmax(0,1fr)}
.rules-builder-grid.compact label:last-child{grid-column:auto}
@media (max-width: 860px){
  .rules-inline-row{flex-direction:column; align-items:stretch}
  .rules-subitems-top,.rules-subitem-head{flex-direction:column; align-items:stretch}
  .rules-builder-grid.compact{grid-template-columns:1fr}
}

.rule-card-flash{animation:ruleCardFlash 1.8s ease;}
@keyframes ruleCardFlash{0%{box-shadow:0 0 0 0 rgba(255,166,0,.0);}20%{box-shadow:0 0 0 3px rgba(255,166,0,.35),0 0 40px rgba(255,166,0,.18);}100%{box-shadow:0 0 0 0 rgba(255,166,0,0);}}
