/* Rating Articles — responsive, modern UI */
.ra-container { max-width: 1120px; margin: 0 auto; padding: 20px 16px 56px; }

/* Hero */
.ra-hero { position: relative; border-radius: 18px; overflow: hidden; border: 1px solid rgba(56,189,248,.25); background: linear-gradient(160deg, rgba(2,6,23,.75), rgba(15,23,42,.85)); min-height: 220px; display:flex; align-items: flex-end; }
.ra-hero__image { position:absolute; inset:0; background-position:center; background-size:cover; filter: brightness(.7); }
.ra-hero__overlay { position:absolute; inset:0; background:
  radial-gradient(60% 60% at 50% 0%, rgba(59,130,246,.25), transparent),
  radial-gradient(50% 40% at 15% 0%, rgba(99,102,241,.18), transparent),
  radial-gradient(35% 35% at 80% 10%, rgba(34,197,94,.14), transparent);
  pointer-events:none;
}
.ra-hero__inner { position:relative; z-index:2; width:100%; padding:18px; display:flex; flex-direction:column; gap:.5rem; }
.ra-hero__title { margin:0; font-size: clamp(1.35rem, 2.8vw, 2.1rem); color:#e2e8f0; }
.ra-hero__meta { display:flex; flex-wrap:wrap; gap:.5rem .6rem; color:#cbd5e1; align-items:center; }
.ra-pill { display:inline-flex; align-items:center; gap:.4rem; padding:.28rem .6rem; border-radius:999px; background: rgba(59,130,246,.16); border:1px solid rgba(59,130,246,.32); color:#bfdbfe; font-size:.9rem; }

/* Grid list */
.ra-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(230px,1fr)); gap:20px; }

/* Neo card style inspired by the reference */
.ra-card.ra-card--neo { position:relative; width:100%; border-radius:20px; background:#07182E; padding:6px; overflow:hidden; box-shadow: rgba(100,100,111,0.2) 0px 7px 20px 0px; transition: transform 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275), box-shadow .25s ease; border:1px solid rgba(255,255,255,0.04); display:flex; flex-direction:column; }
.ra-card.ra-card--neo::before { content:''; position:absolute; width:110px; height:130%; background-image: linear-gradient(180deg, rgb(0, 183, 255), rgb(255, 48, 255)); top:-15%; left:-15%; animation: ra-rotBGimg 3s linear infinite; transition: all 0.2s linear; z-index:0; opacity:0.9; }
.ra-card.ra-card--neo::after { content:''; position:absolute; inset:5px; border-radius:15px; background:#ffffff; z-index:0; }
.ra-card.ra-card--neo:hover::before { background-image: linear-gradient(180deg, rgb(81, 255, 0), purple); animation: ra-rotBGimg 3.5s linear infinite; }
.ra-card--neo .ra-card__top,
.ra-card--neo .ra-card__bottom { position:relative; z-index:1; }
@keyframes ra-rotBGimg { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.ra-card.ra-card--neo:hover { transform: scale(1.03); box-shadow: rgba(100,100,111,0.26) 0px 10px 26px 0px; }
.ra-card--neo .ra-card__top { height:160px; border-radius:15px; position:relative; background-image: var(--ra-thumb, linear-gradient(45deg, rgb(4,159,187) 0%, rgb(80,246,255) 100%)), linear-gradient(45deg, rgb(4,159,187) 0%, rgb(80,246,255) 100%); background-size: cover; background-position: center; overflow:hidden; }
.ra-card--neo .ra-card__top::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, rgba(27,35,61,.08), rgba(27,35,61,.6)); }
.ra-card--neo .ra-card__skew { position:absolute; bottom:-1px; left:0; height:32px; width:160px; background:#1b233d; transform: skew(-40deg); box-shadow:-10px -10px 0 0 #1b233d; border-bottom-right-radius:12px; z-index:2; display:flex; align-items:center; padding-left:18px; }
.ra-card--neo .ra-card__skew-label { transform: skew(40deg); color:#e2e8f0; font-weight:800; font-size:.9rem; letter-spacing:.01em; text-transform: capitalize; }
.ra-card--neo .ra-card__top::before { content:""; position:absolute; top:30px; left:0; height:15px; width:15px; border-top-left-radius:15px; box-shadow:-5px -5px 0 2px #1b233d; z-index:2; }
.ra-card--neo .ra-card__top-meta { position:absolute; top:10px; left:12px; right:12px; display:flex; align-items:center; justify-content:space-between; gap:.6rem; z-index:3; }
.ra-card--neo .ra-card__pill { display:none; }
.ra-card--neo .ra-card__score { display:inline-flex; align-items:center; justify-content:center; gap:.25rem; min-width:62px; padding:.35rem .7rem; border-radius:12px; background:rgba(255,255,255,0.9); color:#0f172a; font-weight:800; box-shadow:inset 0 1px 0 rgba(255,255,255,.65); }
.ra-card--neo .ra-card__score-star { color:#f59e0b; font-size:.95rem; }
.ra-card--neo .ra-card__bottom { margin-top:14px; padding:10px 6px 6px; display:flex; flex-direction:column; gap:.55rem; color:#e2e8f0; }
.ra-card--neo .ra-card__title { margin:0; font-size:1.05rem; letter-spacing:.02em; color:#f8fafc; }
.ra-card--neo .ra-card__title a { color:inherit; }
.ra-card--neo .ra-card__meta { margin:0; color:#e2e8f0; font-size:.95rem; }
.ra-card--neo .ra-card__row { display:flex; justify-content:space-between; gap:.5rem; margin-top:.2rem; }
.ra-card--neo .ra-card__stat { flex:1; text-align:center; padding:6px 4px; color:#e0f2fe; border-right:1px solid rgba(255,255,255,0.12); }
.ra-card--neo .ra-card__stat:last-child { border-right:0; }
.ra-card--neo .ra-card__stat-big { display:block; font-size:0.8rem; font-weight:800; color:#dc3432; }
.ra-card--neo .ra-card__stat-label { display:block; font-size:.8rem; color:#3F51B5; }
.ra-card__excerpt,
.ra-card__meta { margin:0; color:#e2e8f0; font-size:.95rem; }
.ra-card--neo .ra-card__meta { margin:0; color:#795548; font-size:.75rem; display:none; }
.ra-card--neo .ra-actions { display:flex; justify-content:center; margin-top:.2rem; }
.ra-card--neo .ra-btn { display:inline-flex; align-items:center; gap:.35rem; padding:.55rem 1rem; border-radius:14px; border:1px solid rgba(255,255,255,0.16); background:#23305a; color:#e8edf7; font-weight:700; }
.ra-card--neo .ra-btn--primary { background:linear-gradient(120deg, #1f7ef7, #2f9bff); border-color:rgba(255,255,255,0.18); }
.ra-card--neo .ra-btn:hover { text-decoration:none; filter:brightness(1.05); }

@media (max-width: 520px) {
  .ra-card--neo .ra-card__top { height: 140px; }
  .ra-card--neo .ra-card__row { flex-wrap: wrap; }
  .ra-card--neo .ra-card__stat { flex: 1 1 45%; border-right:0; }
}

/* Layout with sidebar filters */
.ra-layout { display:grid; grid-template-columns: 280px 1fr; gap:18px; align-items:flex-start; }
.ra-sidebar { position:sticky; top:0; align-self:flex-start; border:1px solid rgba(56,189,248,.25); border-radius:16px; background:rgba(15,23,42,.1); padding:14px; backdrop-filter: blur(6px); margin-top:0; }
.ra-filter { display:flex; flex-direction:column; gap:12px; }
.ra-filter__group label { display:block; font-weight:700; color:#e2e8f0; margin-bottom:4px; }
.ra-filter input[type="search"],
.ra-filter input[type="number"],
.ra-filter select { width:100%; border-radius:10px; border:1px solid rgba(148,163,184,.4); background:rgba(15,23,42,.3); color:#e2e8f0; padding:.55rem .7rem; }
.ra-filter__range { display:flex; align-items:center; gap:.4rem; }
.ra-filter__range span { color:#cbd5e1; }
.ra-filter__actions { display:flex; gap:.5rem; flex-wrap:wrap; }
.ra-filter .ra-btn { flex:1 1 auto; justify-content:center; }
.ra-filter__actions { margin-top:10px; }

/* Overrides per latest request */
.ra-sidebar {
  position: sticky;
  top: 100px;
  align-self: flex-start;
  border: 1px solid rgba(56, 189, 248, .25);
  border-radius: 10px;
  background: rgb(255 255 255);
  padding: 47px 20px 46px 20px;
  backdrop-filter: blur(6px);
  margin-top: 65px;
}
.ra-filter__group label {
  display: block;
  font-weight: 700;
  color: #3F51B5;
  margin-bottom: 15px;
  margin-top: 10px;
}
.ra-filter input[type="search"],
.ra-filter input[type="number"],
.ra-filter select {
  width: 100%;
  border-radius: 10px;
  border: 1px solid rgba(148, 163, 184, .4);
  background: rgb(15 23 42 / 0%);
  color: #3F51B5;
  padding: .55rem .7rem;
}
button.ra-btn.ra-btn--primary {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .55rem 1rem;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: #23305a;
  color: #e8edf7;
  font-weight: 700;
}

/* Rating item layout */
.ra-item-shell { max-width: 1120px; margin: 0 auto; padding: 0 16px 56px; }
.ra-item-hero { position: relative; background: linear-gradient(135deg, #0b1c3c, #0a234f); color:#e5ecf7; border-radius: 16px; overflow:hidden; padding:22px; margin-bottom:18px; }
.ra-item-hero__bg { position:absolute; inset:0; background: radial-gradient(60% 60% at 30% 0%, rgba(59,130,246,.35), transparent), radial-gradient(40% 40% at 80% 0%, rgba(34,197,94,.2), transparent); opacity:.6; }
.ra-item-hero__inner { position:relative; display:flex; align-items:center; justify-content:space-between; gap:18px; }
.ra-item-hero__brand { display:flex; align-items:center; gap:12px; }
.ra-item-hero__logo { width:52px; height:52px; border-radius:12px; background:#0e315f; display:grid; place-items:center; font-weight:800; font-size:1.3rem; color:#7cc4ff; border:1px solid rgba(255,255,255,.15); }
.ra-item-hero__logo i { font-size:1.4rem; color:#7cc4ff; }
.ra-item-hero__label { margin:0; color:#9db8dd; font-size:.9rem; }
.ra-item-hero__title { margin:0; font-size:1.6rem; color:#f8fbff; }
.ra-item-hero__meta { margin-top:4px; color:#cdd9ec; font-size:.95rem; }
.ra-item-hero__stats { display:flex; align-items:center; }
.ra-score-badge { background:#0d1a31; border:1px solid rgba(255,255,255,.12); border-radius:12px; padding:10px 14px; color:#e5ecf7; text-align:center; min-width:130px; box-shadow:0 12px 24px rgba(0,0,0,.15); }
.ra-score-number { font-size:1.5rem; font-weight:800; display:block; }
.ra-score-stars { margin:4px 0; }

.ra-item-layout { display:grid; grid-template-columns: 2fr 320px; gap:18px; align-items:start; }
.ra-item-main { display:flex; flex-direction:column; gap:14px; }
.ra-panel { border:1px solid #e5e7eb; border-radius:12px; background:#fff; box-shadow:0 6px 18px rgba(0,0,0,.06); overflow:hidden; }
.ra-panel__header { padding:12px 14px; border-bottom:1px solid #e5e7eb; background:#f8fafc; }
.ra-panel__header h3 { margin:0; color:#0f172a; }
.ra-panel__body { padding:14px; color:#0f172a; }
.ra-fields--inline { display:flex; flex-wrap:wrap; gap:10px 16px; }
.ra-fields--inline .ra-fields__item { background:#f1f5f9; border-radius:8px; padding:8px 10px; }

.ra-reviews-list { display:flex; flex-direction:column; gap:12px; }
.ra-review-card { display:flex; gap:12px; border:1px solid #e5e7eb; border-radius:10px; padding:12px; background:#fff; }
.ra-review-card__avatar { width:42px; height:42px; border-radius:50%; background:#e0e7ff; color:#1e3a8a; display:grid; place-items:center; font-weight:800; }
.ra-review-card__content { flex:1; display:flex; flex-direction:column; gap:6px; }
.ra-review-card__top { display:flex; justify-content:space-between; align-items:center; }
.ra-review-card__author { font-weight:700; color:#0f172a; }
.ra-review-card__meta { color:#64748b; font-size:.9rem; }
.ra-review-card__rating { display:flex; align-items:center; gap:.5rem; }
.ra-review-card__text { color:#0f172a; line-height:1.45; }
.ra-review-card__evidence { margin-top:.25rem; }
.ra-review-card__evidence .ra-btn--ghost { background:rgba(59,130,246,.08); color:#0f172a; border:1px solid rgba(59,130,246,.25); padding:.35rem .6rem; border-radius:10px; font-size:.9rem; }
.ra-evidence-thumb { border:1px solid rgba(59,130,246,.25); border-radius:10px; padding:0; background:#f8fafc; cursor:pointer; overflow:hidden; }
.ra-evidence-thumb img { width:68px; height:68px; object-fit:cover; display:block; }
.ra-alert { padding:12px 14px; border-radius:12px; border:1px solid transparent; margin-top:10px; font-size:.95rem; }
.ra-alert--info { background:rgba(59,130,246,.1); color:#0f172a; border-color:rgba(59,130,246,.3); }

.ra-item-aside { position:sticky; top:16px; }
.ra-info-card { border:1px solid #e5e7eb; border-radius:12px; background:#fff; padding:14px; box-shadow:0 6px 18px rgba(0,0,0,.05); }
.ra-info-card h4 { margin:0 0 10px; color:#0f172a; }
.ra-info-card ul { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:6px; color:#0f172a; }
.ra-info-card__image { margin-top:10px; width:100%; aspect-ratio: 4/3; border-radius:10px; background-size:cover; background-position:center; border:1px solid #e5e7eb; display:block; cursor:pointer; }

@media (max-width: 980px) {
  .ra-item-layout { grid-template-columns: 1fr; }
  .ra-item-aside { position:static; }
}
@media (max-width: 640px) {
  .ra-item-hero__inner { flex-direction:column; align-items:flex-start; }
  .ra-item-hero__stats { width:100%; }
}

/* Requested tweaks */
.ra-item-shell {
    max-width: 1120px;
    margin: 0 auto;
    padding: 20px 16px 56px;
}
.ra-item-hero__inner div {
    color: #ffffff !important;
}

/* Star animation */
.ra-stars-animated {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.ra-stars-animated i {
  color: #fbbf24;
  font-size: 1.2rem;
  animation: ra-star-pulse 2s ease-in-out infinite;
}
.ra-stars-animated i:nth-child(2) { animation-delay: 0.35s; }
.ra-stars-animated i:nth-child(3) { animation-delay: 0.7s; }
@keyframes ra-star-pulse {
  0%   { transform: scale(1); opacity: 0.3; filter: grayscale(1); }
  30%  { transform: scale(1.05); opacity: 0.8; filter: grayscale(0.4); }
  60%  { transform: scale(0.95); opacity: 0.6; filter: grayscale(0.8); }
  100% { transform: scale(1); opacity: 0.3; filter: grayscale(1); }
}

/* Modal for image */
.ra-modal { position:fixed; inset:0; display:flex; align-items:center; justify-content:center; z-index:9999; }
.ra-modal[hidden] { display:none; }
.ra-modal__backdrop { position:absolute; inset:0; background:rgba(0,0,0,0.5); }
.ra-modal__dialog { position:relative; background:#0b0b12; padding:10px; border-radius:12px; box-shadow:0 18px 42px rgba(0,0,0,.35); max-width:90vw; max-height:90vh; display:flex; align-items:center; justify-content:center; }
.ra-modal__dialog img { max-width:100%; max-height:80vh; border-radius:10px; display:block; }
.ra-modal__close { position:absolute; top:8px; right:10px; background:rgba(0,0,0,.6); color:#fff; border:0; border-radius:50%; width:30px; height:30px; cursor:pointer; font-size:1.1rem; }
.ra-modal__close:hover { background:rgba(0,0,0,.8); }
.ra-modal-open { overflow:hidden; }

/* Ten-star bar */
.ra-ten-stars { position:relative; display:inline-block; line-height:1; font-size:1rem; }
.ra-ten-stars__base { color:#e2e8f0; opacity:0.6; }
.ra-ten-stars__fill { position:absolute; inset:0; color:#fbbf24; overflow:hidden; width:0; animation: ra-ten-fill 1.1s ease forwards; }
.ra-ten-stars { --p: 0%; }
.ra-ten-stars__fill { width: var(--p); }
@keyframes ra-ten-fill {
  from { width:0; }
  to   { width: var(--p); }
}
a.ra-btn {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .55rem 1rem;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: #23305a;
  color: #e8edf7;
  font-weight: 700;
}
.ra-main { min-width:0; }

@media (max-width: 900px) {
  .ra-layout { grid-template-columns: 1fr; }
  .ra-sidebar { position:static; }
}

/* Article content */
.ra-section { margin-top: 16px; padding:16px; border:1px solid rgba(56,189,248,.25); background:linear-gradient(160deg, rgba(2,6,23,.55), rgba(15,23,42,.65)); border-radius:16px; color:#cbd5e1; }
.ra-section h3 { margin:0 0 8px 0; color:#93c5fd; }
.ra-fields { display:grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap:10px 14px; margin: 6px 0 0; }
.ra-fields__item { display:flex; gap:.5rem; align-items:center; }
.ra-fields__label { color:#94a3b8; }

/* Stars */
.ra-stars { --s: 1; display:inline-block; font-size: 0; line-height:0; position:relative; width: calc(5 * 1.1em * var(--s)); height: 1.1em; }
.ra-stars::before { content:'★★★★★'; letter-spacing:.1em; font-size:1.1em; color: rgba(148,163,184,.4); }
.ra-stars__fill { position:absolute; top:0; left:0; height:100%; overflow:hidden; white-space:nowrap; }
.ra-stars__fill::before { content:'★★★★★'; letter-spacing:.1em; font-size:1.1em; color:#fbbf24; }
.ra-badge { padding:.22rem .5rem; border-radius:8px; background: rgba(16,185,129,.18); border:1px solid rgba(16,185,129,.35); color:#bbf7d0; font-weight:600; font-size:.9rem; }

/* Reviews */
.ra-review { border:1px solid rgba(56,189,248,.25); border-radius:12px; padding:12px; background: rgba(2,6,23,.45); }
.ra-review__meta { display:flex; gap:.6rem; flex-wrap:wrap; align-items:center; color:#a5b4fc; }
.ra-review__text { margin:.4rem 0 0; color:#cbd5e1; }

/* Form */
.ra-form .row { display:grid; grid-template-columns: repeat(auto-fit,minmax(180px,1fr)); gap:.8rem; }
.ra-form label { display:block; color:#cbd5e1; }
.ra-form input[type="number"],
.ra-form textarea { width:100%; border-radius:10px; border:1px solid rgba(59,130,246,.35); background:rgba(15,23,42,.6); color:#e2e8f0; padding:.6rem .7rem; }
.ra-form textarea { min-height: 110px; }
.ra-form .actions { margin-top:.6rem; }
.ra-evidence { margin:0 0 .75rem; padding:.75rem; border:1px dashed rgba(148,163,184,.6); border-radius:12px; background:rgba(148,163,184,.1); color:#e2e8f0; }
.ra-evidence label { display:block; font-weight:600; color:#e2e8f0; }

@media (max-width: 640px) {
  .ra-hero { min-height: 180px; }
}

/* Score scale (1–10) */
.ra-scale { display:flex; gap:.35rem; flex-wrap:wrap; --size: 34px; }
.ra-scale input[type="radio"] { position: absolute; opacity: 0; width:0; height:0; }
.ra-scale__option { width: var(--size); height: var(--size); display:inline-flex; align-items:center; justify-content:center; border-radius:999px; border:1px solid rgba(148,163,184,.45); color:#a5b4fc; font-weight:700; background: rgba(15,23,42,.6); cursor:pointer; user-select:none; transition: all .14s ease; }
.ra-scale__option:hover { border-color: rgba(59,130,246,.6); box-shadow: 0 6px 18px rgba(59,130,246,.18); }
.ra-scale input[type="radio"]:checked + .ra-scale__option { background: linear-gradient(160deg, rgba(59,130,246,.35), rgba(99,102,241,.35)); color:#e2e8f0; border-color: rgba(59,130,246,.9); }
.ra-question { border-top: 1px dashed rgba(148,163,184,.18); padding-top:.5rem; }
