Toggle menu
Toggle preferences menu
Toggle personal menu
Not logged in
Your IP address will be publicly visible if you make any edits.

Join the Playtest on Steam Now: SpiritVale

Module:GameInfo/styles.css: Difference between revisions

From SpiritVale Wiki
No edit summary
No edit summary
Tags: Mobile edit Mobile web edit
 
(101 intermediate revisions by the same user not shown)
Line 1: Line 1:
/* Module:GameInfo/styles.css */
/* SpiritVale Wiki — Module:GameInfo/styles.css */
/* Phase 4.1 — Mockup Match + TemplateStyles-safe (NO var(), NO vendor pseudos) */
/* GameInfo-family layout and skill-specific presentation.
  Surface hierarchy:
  - bg1 = outer card / inactive neutral base
  - bg2 = grouped section surface
  - bg3 = inner framed block / pill surface
*/
/* -------------------------------------------------------------------------- */
/* Canonical ownership map                                                    */
/* -------------------------------------------------------------------------- */
/* This sheet owns GameInfo-family presentation only. That includes:          */
/* - GameInfo card shells and internal layout                                  */
/* - skill card presentation and module-local responsive changes              */
/* - module-local pills, panels, tabs, metadata blocks, and reference blocks  */
/*                                                                            */
/* It does NOT own:                                                            */
/* - shared site tokens / utilities / slider anatomy (Common.css)              */
/* - skin and chrome theme logic (Citizen.css)                                */
/* - definitions-only token styling (Definitions stylesheet)                   */
/*                                                                            */
/* Responsive cleanup note: GameInfo now maps its legacy mobile cutoffs into  */
/* the canonical six-viewpoint ladder. The module still uses descending range  */
/* queries for parity, but the breakpoints themselves are now canonical.      */
/* -------------------------------------------------------------------------- */
/* Canonical ladder                                                            */
/* -------------------------------------------------------------------------- */
/* - default: <640px                                                          */
/* - sm:      >=640px                                                          */
/* - md:      >=768px                                                          */
/* - lg:      >=1024px                                                        */
/* - xl:      >=1280px                                                        */
/* - 2xl:    >=1536px                                                        */
/* -------------------------------------------------------------------------- */


/* ----------------------------------------------------------------------------
 
  BASE CARD + SAFETY
/* -------------------------------------------------------------------------- */
---------------------------------------------------------------------------- */
/* 1) Base card and safety                                                    */
/* -------------------------------------------------------------------------- */


.sv-gi-card,
.sv-gi-card,
.sv-skill-card {
.sv-skill-card{
   max-width: 600px;
   max-width:600px;
   margin: 18px auto;
   margin:18px auto;
 
   border-radius:22px;
   border-radius: 22px;
   overflow:visible;
   border: 1px solid rgba(255,255,255,0.085);
 
  background-color: #0f1b33;
  background-image:
    radial-gradient(1200px 520px at 50% -20%, rgba(96,165,250,0.22), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02)),
    radial-gradient(900px 360px at 50% 0, rgba(255,255,255,0.06), transparent 55%),
    linear-gradient(180deg, #0f1b33, #0c162b);


   box-shadow: 0 16px 38px rgba(0,0,0,0.55), inset 0 1px 0 rgba(255,255,255,0.04);
   background:var(--sv-ui-bg1);
   overflow: visible;
   background-image:none;


   color: rgba(235,244,255,0.92);
   color:var(--sv-ui-text2);
   font-size: 12px;
   font-size:15px;
   line-height: 1.35;
   line-height:1.35;
}
}


.sv-gi-top,
.sv-gi-top,
.sv-skill-top {
.sv-skill-top{ padding:14px 18px 4px; }
  padding: 14px 14px 4px;
  border-radius: 22px 22px 0 0;
  overflow: visible;
}


.sv-gi-bottom,
.sv-gi-bottom,
.sv-skill-bottom {
.sv-skill-bottom{ padding:10px 18px 12px; }
  padding: 10px 14px 12px;
  border-top: 1px solid rgba(255,255,255,0.050);
  border-radius: 0 0 22px 22px;
  background-image: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,0.08));
}


.sv-gi-card,
.sv-gi-card,
.sv-gi-card *,
.sv-gi-card *,
.sv-skill-card,
.sv-skill-card,
.sv-skill-card * {
.sv-skill-card *{ box-sizing:border-box; }
  box-sizing: border-box;
 
.sv-gi-error{
  max-width:600px;
  margin:18px auto;
  padding:10px 12px;
 
  overflow-wrap:anywhere;
  word-break:break-word;
}
 
.sv-gi-card summary,
.sv-skill-card summary{ list-style:none; }
 
/* -------------------------------------------------------------------------- */
/* 2) Icons and fallback badges                                                */
/* -------------------------------------------------------------------------- */
 
.sv-skill-icon,
.sv-meta-icon,
.sv-ref-ico,
.sv_skill_scaling__stat-icon{
  font-size:0;
  line-height:0;
}
 
.sv-skill-icon a,
.sv-meta-icon a,
.sv-ref-ico a,
.sv_skill_scaling__stat-icon a{ text-decoration:none; }
 
.sv-skill-icon .sv-miss{
  width:22px;
  height:22px;
  font-size:13px;
  line-height:1;
}
 
.sv-meta-icon .sv-miss,
.sv-ref-ico .sv-miss{
  width:18px;
  height:18px;
  font-size:12px;
  line-height:1;
}
 
/* -------------------------------------------------------------------------- */
/* 2b) Interactive link treatment                                              */
/* -------------------------------------------------------------------------- */
 
.sv-disclose-pop a,
.sv-disclose-pop-title a,
.sv-tip-pop a,
.sv-tip-pop-title a,
.sv-def-pop a,
.sv-def-pop-title a,
.sv-pop a,
.sv-pop-title a,
.sv-gi-card .sv-ref-title a,
.sv-skill-card .sv-ref-title a{
  color:var(--sv-ui-link, #8fc7ff);
  text-decoration-line:underline;
  text-decoration-color:currentColor;
}
 
.sv-disclose-pop a:hover,
.sv-disclose-pop-title a:hover,
.sv-tip-pop a:hover,
.sv-tip-pop-title a:hover,
.sv-def-pop a:hover,
.sv-def-pop-title a:hover,
.sv-pop a:hover,
.sv-pop-title a:hover,
.sv-gi-card .sv-ref-title a:hover,
.sv-skill-card .sv-ref-title a:hover,
.sv-disclose-pop a:focus,
.sv-disclose-pop-title a:focus,
.sv-tip-pop a:focus,
.sv-tip-pop-title a:focus,
.sv-def-pop a:focus,
.sv-def-pop-title a:focus,
.sv-pop a:focus,
.sv-pop-title a:focus,
.sv-gi-card .sv-ref-title a:focus,
.sv-skill-card .sv-ref-title a:focus{
  color:var(--sv-ui-link-hover, #b8ddff);
}
 
.sv-disclose-pop-title a,
.sv-tip-pop-title a,
.sv-def-pop-title a,
.sv-pop-title a{
  font:inherit;
}
 
/* -------------------------------------------------------------------------- */
/* 3) Skill header                                                            */
/* -------------------------------------------------------------------------- */
 
.sv-skill-head{
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:2px 0 10px;
}
 
.sv-skill-icon{
  flex:0 0 auto;
  width:64px;
  height:64px;
 
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
 
  border-radius:16px;
}
 
.sv-skill-headtext{
  min-width:0;
  flex:0 1 auto;
}
 
.sv-skill-title-row{
  display:flex;
  align-items:center;
  gap:10px;
}
 
.sv-skill-title{
  min-width:0;
  word-wrap:break-word;
 
  font-weight:900;
  font-size:22px;
  line-height:1.10;
  letter-spacing:0.2px;
  color:var(--sv-ui-text1);
}
}


.sv-gi-card a,
.sv-skill-desc{
.sv-skill-card a {
  margin-top:6px;
   color: rgba(170,220,255,0.95);
  word-wrap:break-word;
   text-decoration: none;
 
  font-size:14px;
   line-height:1.35;
   color:var(--sv-ui-text2);
}
}
.sv-gi-card a:hover,
 
.sv-skill-card a:hover {
/* -------------------------------------------------------------------------- */
   text-decoration: underline;
/* 4) Meta and requirements block                                              */
/* -------------------------------------------------------------------------- */
 
.sv-skill-meta-block{
  margin:8px 0 10px;
 
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  align-items:stretch;
  gap:10px;
}
 
.sv-skill-meta-block--single{
   grid-template-columns:minmax(0, 1fr);
}
}


/* Hide contract */
.sv-skill-meta-block__bubble{
.sv-hidden { display: none !important; }
  min-width:0;
[hidden] { display: none !important; }
  min-height:108px;
  max-height:108px;
  padding:10px 12px;
 
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;


/* Safe details reset (NO ::marker / NO vendor marker pseudos) */
  border-radius:16px;
.sv-gi-card summary,
  background:var(--sv-ui-bg2);
.sv-skill-card summary {
  background-image:none;
   list-style: none;
   box-shadow:none;
}
}


/* Focus */
.sv-skill-meta-block__bubble--meta .sv-skill-meta,
.sv-tip-btn:focus,
.sv-skill-meta-block__bubble--req .sv-reqrow{
.sv-disclose-btn:focus,
   width:100%;
.sv-tab:focus,
   margin:0;
.sv-level-range--custom:focus {
   outline: 2px solid rgba(170,220,255,0.55);
   outline-offset: 2px;
}
}


/* Missing icon badge */
/* -------------------------------------------------------------------------- */
.sv-miss {
/* 5) Meta row                                                                */
   display: inline-block;
/* -------------------------------------------------------------------------- */
   width: 18px;
 
  height: 18px;
.sv-skill-meta{
  border-radius: 999px;
   display:grid;
  border: 1px solid rgba(255,255,255,0.050);
   grid-template-columns:repeat(2, minmax(0, 1fr));
  background: rgba(255,255,255,0.05);
   justify-items:center;
   font-weight: 900;
   align-items:center;
   font-size: 12px;
   gap:8px;
  line-height: 18px;
   text-align: center;
}
}


/* Image wrapper produced by Lua */
.sv-gi-card .sv-meta-card,
.sv-img { display: inline-block; }
.sv-skill-card .sv-meta-card{
.sv-img img {
  position:relative;
   display: block;
 
   border-radius: 10px;
  display:flex;
   box-shadow: 0 10px 18px rgba(0,0,0,0.35);
  align-items:center;
  justify-content:center;
  gap:6px;
 
  width:100%;
  min-height:36px;
  padding:0 8px;
 
  border-radius:14px;
  border:1px solid var(--sv-ui-line2);
  background:var(--sv-ui-bg3);
  background-image:none;
  color:var(--sv-ui-text1);
}
 
.sv-gi-card .sv-meta-card:hover,
.sv-skill-card .sv-meta-card:hover{ background:var(--sv-ui-bg3); }
 
.sv-gi-card .sv-meta-icon,
.sv-skill-card .sv-meta-icon{
  flex:0 0 auto;
  width:20px;
  height:20px;
 
   display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
 
   border-radius:14px;
   background:var(--sv-ui-bg3);
  background-image:none;
}
}


/* Shared “panel surface” */
.sv-gi-card .sv-meta-textwrap,
.sv-skill-level,
.sv-skill-card .sv-meta-textwrap{
.sv-scaling-row,
   min-width:0;
.sv-core-row,
   flex:0 1 auto;
.sv-tabs {
   border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.050);
  background: rgba(255,255,255,0.04);
   box-shadow: inset 0 1px 0 rgba(255,255,255,0.03);
}
}


/* ----------------------------------------------------------------------------
.sv-gi-card .sv-meta-text,
  HEADER (ICON + TITLE + NOTES + DESCRIPTION)
.sv-skill-card .sv-meta-text{
---------------------------------------------------------------------------- */
  min-width:0;
  word-wrap:break-word;
  text-align:center;


.sv-skill-head {
  font-weight:900;
  display: grid;
   font-size:12px;
   grid-template-columns: 124px 1fr;
   line-height:1.02;
   gap: 14px;
   letter-spacing:0.08px;
   align-items: start;
   color:var(--sv-ui-text1);
   padding: 2px 0 10px;
}
}


.sv-skill-icon {
.sv-gi-card .sv-meta-lines span,
  width: 124px;
.sv-skill-card .sv-meta-lines span{ display:block; }
  height: 124px;
 
  border-radius: 14px;
.sv-gi-card .sv-meta-text .sv-def,
  border: 1px solid rgba(255,255,255,0.050);
.sv-skill-card .sv-meta-text .sv-def{ cursor:default; }
   background: rgba(255,255,255,0.04);
 
   box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
.sv-gi-card .sv-meta-text .sv-def-text,
  overflow: hidden;
.sv-skill-card .sv-meta-text .sv-def-text{
   color:inherit;
   border-bottom:none;
}
}


.sv-skill-headtext { min-width: 0; }
.sv-gi-card .sv-meta-text .sv-meta-lines span + span,
.sv-skill-card .sv-meta-text .sv-meta-lines span + span{
  margin-top:1px;


.sv-skill-title-row {
  font-size:10px;
  display: flex;
   font-weight:800;
   align-items: center;
   letter-spacing:0.12px;
   gap: 10px;
   color:var(--sv-ui-text3);
   min-width: 0;
}
}


.sv-skill-title {
.sv-gi-card .sv-meta-hit,
   min-width: 0;
.sv-skill-card .sv-meta-hit{
   font-weight: 900;
   position:absolute;
   font-size: 20px;
   top:0;
  line-height: 1.05;
   right:0;
   letter-spacing: 0.2px;
   bottom:0;
   color: rgba(245,250,255,0.98);
   left:0;
   text-shadow: 0 2px 0 rgba(0,0,0,0.35);
   z-index:5;
   word-wrap: break-word;
   opacity:0;
}
}


.sv-skill-desc {
.sv-gi-card .sv-meta-hit .sv-def,
   margin-top: 8px;
.sv-skill-card .sv-meta-hit .sv-def{
   max-width: 56ch;
   display:block;
  font-size: 12px;
   width:100%;
   line-height: 1.35;
   height:100%;
  color: rgba(210,224,245,0.86);
  word-wrap: break-word; /* no line-clamp (TemplateStyles-safe) */
}
}


/* ----------------------------------------------------------------------------
/* -------------------------------------------------------------------------- */
  NOTES TIP (works with <details> OR span-button markup)
/* 6) Requirements and users row                                              */
---------------------------------------------------------------------------- */
/* -------------------------------------------------------------------------- */
 
.sv-gi-card .sv-reqrow,
.sv-skill-card .sv-reqrow{
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:8px;
}


.sv-tip { position: relative; display: inline-block; }
.sv-gi-card .sv-disclose,
.sv-tip > summary { cursor: pointer; }
.sv-skill-card .sv-disclose{
  min-width:0;
  max-width:none;
  width:100%;
}


.sv-tip-btn {
.sv-gi-card .sv-reqrow .sv-disclose-btn,
   display: inline-block;
.sv-skill-card .sv-reqrow .sv-disclose-btn{
   width: 30px;
   width:100%;
   height: 30px;
   min-height:36px;
   border-radius: 999px;
   padding:0 12px;
   background: rgba(255,255,255,0.10);
   border-radius:14px;
   border: 1px solid rgba(255,255,255,0.050);
   background:var(--sv-ui-bg3);
   box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
   background-image:none;
  text-align: center;
   box-shadow:none;
  line-height: 30px;
  cursor: pointer;
}
}


.sv-tip-btn:hover { background: rgba(255,255,255,0.13); }
/* -------------------------------------------------------------------------- */
/* 7) Level selector wrapper                                                  */
/* -------------------------------------------------------------------------- */


.sv-ico,
.sv-skill-level{
.sv-ico--info {
   margin:8px 0 10px;
   font-weight: 900;
  padding:10px 12px;
   font-size: 12px;
 
   line-height: 1;
  display:flex;
   color: rgba(245,250,255,0.95);
  flex-direction:column;
   gap:8px;
 
   border-radius:16px;
   background:var(--sv-ui-bg2);
  background-image:none;
  box-shadow:none;
}
}


/* Popovers (fixed width + percent max-width; NO min()/calc()/vw) */
.sv-skill-level:not([data-sv-level-hide-ticks="0"]) .sv-level-ticklabels{ display:none; }
.sv-tip-pop,
.sv-disclose-pop {
  position: absolute;
  z-index: 200;
  padding: 10px 10px 8px;


  border-radius: 12px;
/* -------------------------------------------------------------------------- */
  border: 1px solid rgba(255,255,255,0.050);
/* 8) Skill scaling                                                            */
  background:
/* -------------------------------------------------------------------------- */
    radial-gradient(700px 260px at 40% 0, rgba(96,165,250,0.12), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.03)),
    linear-gradient(180deg, #0b1428, #0a1326);
  box-shadow: 0 16px 36px rgba(0,0,0,0.55), inset 0 1px 0 rgba(255,255,255,0.04);


   width: 380px;
.sv_skill_scaling{
   max-width: 92%;
  margin:8px 0 10px;
  padding:10px 12px 12px;
 
  border-radius:18px;
  background:var(--sv-ui-bg2);
   background-image:none;
   box-shadow:none;
}
}


.sv-tip-pop {
.sv_skill_scaling .sv-skill-level,
   top: 40px;
.sv_skill_scaling__level{
   right: 0;
   margin:0 0 10px;
  padding:0 0 10px;
 
  border:0;
   border-radius:0;
  background:transparent;
  box-shadow:none;
  border-bottom:1px solid var(--sv-ui-line1);
}
}


.sv-disclose-pop {
.sv_skill_scaling__body{
   top: 46px;
  display:grid;
   left: 0;
  grid-template-columns:minmax(0, 1fr) minmax(0, 252px);
  column-gap:16px;
  row-gap:12px;
   align-items:stretch;
   justify-items:stretch;
}
}


/* Arrow (TemplateStyles-safe pseudo-element) */
.sv_skill_scaling__group{
.sv-tip-pop:before,
  width:100%;
.sv-disclose-pop:before {
  min-width:0;
   content: "";
  min-height:116px;
   position: absolute;
  max-height:116px;
   top: -6px;
   padding:10px 12px;
   width: 11px;
 
   height: 11px;
   display:flex;
   transform: rotate(45deg);
   align-items:center;
   background: rgba(18,28,52,0.98);
   justify-content:center;
   border-left: 1px solid rgba(255,255,255,0.050);
   overflow:hidden;
   border-top: 1px solid rgba(255,255,255,0.050);
 
   border-radius:16px;
   background:var(--sv-ui-bg3);
   background-image:none;
   box-shadow:none;
}
}
.sv-tip-pop:before { right: 14px; }
.sv-disclose-pop:before { left: 20px; }


.sv-tip-pop-head,
.sv_skill_scaling__group--primary-stats{
.sv-disclose-pop-head {
   grid-column:1;
   display: flex;
   grid-row:1;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
   margin-bottom: 6px;
}
}


.sv-tip-pop-title,
.sv_skill_scaling__group--core{
.sv-disclose-pop-title {
   grid-column:2;
   font-weight: 900;
   grid-row:1;
   font-size: 12px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.62);
}
}


.sv-tip-pop-hint,
.sv_skill_scaling__cluster{
.sv-disclose-pop-hint {
  display:flex;
   font-size: 12px;
  align-items:center;
   color: rgba(255,255,255,0.50);
  justify-content:center;
  gap:14px;
 
  flex-wrap:wrap;
  width:100%;
  height:100%;
  max-width:100%;
   margin:0 auto;
 
   min-width:0;
}
}


.sv-tip-pop-body {
.sv_skill_scaling__column{
   color: rgba(255,255,255,0.82);
  min-width:0;
   font-size: 12px;
  padding:0;
   line-height: 1.35;
  border:0;
  border-radius:0;
   background:transparent;
   background-image:none;
   box-shadow:none;
}
}
.sv-tip-pop-body ul { margin: 8px 0 0; padding-left: 18px; }
.sv-tip-pop-body li { margin: 6px 0; }


/* ----------------------------------------------------------------------------
.sv_skill_scaling__column--stats,
  META (SEGMENTED STRIP)
.sv_skill_scaling__column--core{
---------------------------------------------------------------------------- */
  display:flex;
  align-items:center;
  justify-content:center;
}


.sv-skill-meta {
.sv_skill_scaling__column--core{
   margin-top: 10px;
   width:100%;
   display: grid;
   min-width:0;
  grid-template-columns: repeat(4, 1fr);
   min-height:100%;
  gap: 0;
  border-top: 1px solid rgba(255,255,255,0.050);
   border-bottom: 1px solid rgba(255,255,255,0.050);
}
}


.sv-meta-card {
.sv_skill_scaling__column--primary{
   min-height: 52px;
   display:flex;
   display: grid;
   flex-direction:column;
   grid-template-columns: 40px 1fr;
   justify-content:center;
   align-items: center;
   align-items:center;
   padding: 5px 6px;
   text-align:center;
  border-right: 1px solid rgba(255,255,255,0.050);
}
}
.sv-meta-card:nth-child(4) { border-right: none; }


.sv-meta-icon {
.sv_skill_scaling__primary-value{
   width: 34px;
   word-wrap:break-word;
   height: 34px;
   overflow-wrap:anywhere;
   border-radius: 10px;
 
   background: rgba(255,255,255,0.04);
   font-weight:900;
   border: 1px solid rgba(255,255,255,0.050);
   font-size:34px;
   box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
   line-height:0.95;
   overflow: hidden;
   letter-spacing:-0.50px;
   color:var(--sv-ui-text1);
}
}


.sv-meta-textwrap {
.sv_skill_scaling__primary-label{
   display: flex;
  margin-top:6px;
   align-items: center;
 
   justify-content: center;
   font-weight:900;
   min-width: 0;
   font-size:10px;
   line-height:1.05;
   letter-spacing:0.22px;
  text-transform:uppercase;
  color:var(--sv-ui-text3);
}
}


.sv-meta-text {
.sv_skill_scaling__stats-grid{
   font-weight: 700;
   display:grid;
   font-size: 12px;
  grid-template-columns:repeat(2, max-content);
   line-height: 1.12;
   justify-content:center;
   letter-spacing: 0.14px;
   justify-items:center;
   color: rgba(235,244,255,0.92);
   align-content:center;
   text-align: center;
 
   word-wrap: break-word;
   row-gap:8px;
   column-gap:10px;
  margin:0 auto;
 
   grid-template-areas:
    "str agi"
    "vit int"
    "dex luk";
}
}


.sv-meta-lines span { display: block; }
.sv_skill_scaling__stat-pill--str{ grid-area:str; }
.sv_skill_scaling__stat-pill--vit{ grid-area:vit; }
.sv_skill_scaling__stat-pill--dex{ grid-area:dex; }
.sv_skill_scaling__stat-pill--agi{ grid-area:agi; }
.sv_skill_scaling__stat-pill--int{ grid-area:int; }
.sv_skill_scaling__stat-pill--luk{ grid-area:luk; }


/* ----------------------------------------------------------------------------
.sv_skill_scaling__pill{
  REQUIREMENTS / USERS (GRID, CENTERED BUTTONS)
  position:relative;
---------------------------------------------------------------------------- */
  min-width:0;


.sv-reqrow {
  border-radius:14px;
   margin: 5px 0;
   border:1px solid var(--sv-ui-line2);
   display: grid;
   background:var(--sv-ui-bg3);
   grid-template-columns: 1fr 1fr;
   background-image:none;
   gap: 5px;
   box-shadow:none;
}
}
.sv-reqrow > *:only-child { grid-column: 1 / -1; }


.sv-disclose { position: relative; }
.sv_skill_scaling__stat-pill{
.sv-disclose > summary { cursor: pointer; }
  border-radius:999px;


.sv-disclose > summary,
   width:50px;
.sv-disclose-btn {
   min-width:50px;
   width: 100%;
   min-height:22px;
   padding: 6px 8px;
   padding:4px 6px;
   border-radius: 12px;
 
   border: 1px solid rgba(255,255,255,0.050);
   display:inline-flex;
  background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02));
   align-items:center;
   display: flex;
   justify-content:center;
   align-items: center;
   white-space:nowrap;
   justify-content: center;
   gap: 6px;
  text-align: center;
  color: rgba(235,244,255,0.92);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.2px;
}
}


.sv-disclose-count {
.sv_skill_scaling__stat-main{
   color: rgba(255,255,255,0.70);
   min-width:0;
   font-weight: 900;
   display:flex;
   font-size: 12px;
  align-items:center;
   justify-content:center;
}
}


/* Requirements/Users list */
.sv_skill_scaling__stat-visual{
.sv-disclose-list {
   min-width:0;
   margin: 0;
   display:flex;
   padding-left: 18px;
   align-items:center;
   color: rgba(255,255,255,0.82);
   justify-content:center;
   font-size: 12px;
   gap:6px;
   line-height: 1.35;
}
}
.sv-disclose-list li { margin: 6px 0; }


/* ----------------------------------------------------------------------------
.sv_skill_scaling__stat-label{ display:none; }
  LEVEL SELECTOR (TemplateStyles-safe: CUSTOM slider; no range vendor pseudos)
---------------------------------------------------------------------------- */


.sv-skill-level { padding: 8px 10px; }
.sv_skill_scaling__stat-icon{
  width:12px;
  height:12px;


.sv-level-ui {
   display:flex;
  width: 100%;
   align-items:center;
   display: flex;
   justify-content:center;
   flex-direction: column;
  gap: 6px;
   align-items: center;
}
}


.sv-level-label {
.sv_skill_scaling__stat-icon .sv-img img{
   width: 100%;
   width:12px;
  text-align: center;
   height:12px;
  font-weight: 800;
   box-shadow:none;
  opacity: 0.95;
   font-size: 12px;
   white-space: nowrap; /* keep "Level X / Y" on one line */
}
}


/* If Lua ever emits a <br> inside the label, suppress it */
.sv_skill_scaling__stat-icon .sv-miss{
.sv-level-label br { display: none; }
  width:12px;
  height:12px;
  font-size:9px;
  line-height:1;
}


/* If Lua/JS wraps pieces in spans, keep them inline */
.sv_skill_scaling__stat-value{
.sv-level-label span,
  font-weight:900;
.sv-level-label b,
  font-size:12px;
.sv-level-label strong,
  line-height:1;
.sv-level-label em,
  letter-spacing:-0.10px;
.sv-level-label i {
  color:var(--sv-ui-text1);
  display: inline;
  white-space: nowrap;
}
}


.sv-level-slider {
.sv_skill_scaling__stat-hit,
   width: 100%;
.sv_skill_scaling__core-hit{
   display: flex;
   position:absolute;
   justify-content: center;
   top:0;
   right:0;
  bottom:0;
  left:0;
  z-index:5;
  opacity:0;
}
}


/* Custom slider shell */
.sv_skill_scaling__stat-hit .sv-def,
.sv-level-range--custom {
.sv_skill_scaling__core-hit .sv-def{
   display: block;            /* critical if this is emitted as a <span> */
   display:block;
  position: relative;
   width:100%;
   width: 100%;              /* do NOT shrink */
   height:100%;
  max-width: 560px;          /* matches the mockup feel inside 600px card */
  margin: 0 auto;
   height: 26px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.050);
  background: rgba(0,0,0,0.12);
  cursor: pointer;
}
}


/* Track with ticks baked in (replaces ::-webkit-slider-* styling) */
.sv_skill_scaling__stat-pill.is-inactive{
.sv-level-track {
   background:var(--sv-ui-bg1);
   position: absolute;
   background-image:none;
  left: 10px;
   box-shadow:none;
  right: 10px;
  top: 50%;
  margin-top: -5px;
  height: 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.050);
   background:
    linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.04)),
    repeating-linear-gradient(
      to right,
      transparent 0,
      transparent 10.8%,
      rgba(255,255,255,0.28) 10.8%,
      rgba(255,255,255,0.28) 11.11%
    );
   overflow: hidden;
}
}


/* Fill (optional; JS can set width) */
.sv_skill_scaling__stat-pill.is-inactive .sv_skill_scaling__stat-icon,
.sv-level-fill {
.sv_skill_scaling__stat-pill.is-inactive .sv_skill_scaling__stat-value{ display:none; }
   display: block;
 
   height: 100%;
.sv_skill_scaling__stat-pill.is-inactive::before{
   width: 0%;
   content:"—";
   border-radius: 999px;
   font-weight:900;
   background: linear-gradient(90deg, rgba(170,220,255,0.35), rgba(255,255,255,0.12));
   font-size:12px;
   line-height:1;
   color:var(--sv-ui-text3);
}
}


/* Thumb (optional; JS positions with left:%) */
.sv_skill_scaling__stat-pill--str.is-active{
.sv-level-thumb {
   border-color:rgba(145,63,82,0.96);
  position: absolute;
   background:#32131d;
  left: 0%;
   background-image:none;
  top: 50%;
  margin-top: -9px;
  margin-left: -9px;
  width: 18px;
  height: 18px;
   border-radius: 999px;
  background: rgba(255,255,255,0.92);
   border: 1px solid rgba(0,0,0,0.35);
   box-shadow: 0 6px 14px rgba(0,0,0,0.35);
}
}
.sv_skill_scaling__stat-pill--str.is-active .sv_skill_scaling__stat-value{ color:#ffdce5; }


/* Tick labels */
.sv_skill_scaling__stat-pill--vit.is-active{
.sv-level-ticklabels {
   border-color:rgba(158,112,22,0.96);
   display: flex;
   background:#352609;
   justify-content: space-between;
   background-image:none;
   margin-top: 4px;
}
  padding: 0 2px;
.sv_skill_scaling__stat-pill--vit.is-active .sv_skill_scaling__stat-value{ color:#ffefc9; }


   width: 100%;               /* do NOT shrink */
.sv_skill_scaling__stat-pill--dex.is-active{
   max-width: 560px;         /* align with slider width */
   border-color:rgba(118,146,24,0.96);
   margin-left: auto;
   background:#243208;
  margin-right: auto;
   background-image:none;
}
.sv_skill_scaling__stat-pill--dex.is-active .sv_skill_scaling__stat-value{ color:#edf8cc; }


  font-size: 12px;
.sv_skill_scaling__stat-pill--agi.is-active{
   color: rgba(255,255,255,0.65);
   border-color:rgba(125,62,152,0.96);
   font-weight: 800;
   background:#2b1438;
   line-height: 1.1;
   background-image:none;
}
}
.sv-level-ticklabels span { min-width: 1ch; text-align: center; }
.sv_skill_scaling__stat-pill--agi.is-active .sv_skill_scaling__stat-value{ color:#f0dcff; }


/* ----------------------------------------------------------------------------
.sv_skill_scaling__stat-pill--int.is-active{
  SKILL SCALING (DESKTOP/TABLET: 3 COL)
  border-color:rgba(45,118,191,0.96);
---------------------------------------------------------------------------- */
  background:#11263d;
  background-image:none;
}
.sv_skill_scaling__stat-pill--int.is-active .sv_skill_scaling__stat-value{ color:#d8eeff; }


.sv-skill-scaling { margin-top: 10px; }
.sv_skill_scaling__stat-pill--luk.is-active{
.sv-scaling-row { overflow: hidden; }
  border-color:rgba(183,150,22,0.96);
  background:#3a2f07;
  background-image:none;
}
.sv_skill_scaling__stat-pill--luk.is-active .sv_skill_scaling__stat-value{ color:#fff2ba; }


.sv-scaling-grid {
.sv_skill_scaling__core-grid{
   display: grid;
   display:grid;
   grid-template-columns: 1fr 1fr 1.35fr;
   grid-template-columns:repeat(3, minmax(0, 1fr));
   gap: 0;
   gap:8px;
  justify-items:center;
  justify-content:center;
  align-content:center;
  width:100%;
  max-width:228px;
  margin:0 auto;
}
}


.sv-scaling-col {
.sv_skill_scaling__core-pill{
   padding: 10px 10px 8px;
  border-radius:14px;
   min-width: 0;
  min-height:25px;
  min-width:70px;
   padding:8px 6px;
 
   display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
}
}
.sv-scaling-col + .sv-scaling-col {
 
   border-left: 1px solid rgba(255,255,255,0.050);
.sv_skill_scaling__core-pill.is-active{
  background:var(--sv-ui-bg3);
   background-image:none;
}
}


.sv-scaling-value {
.sv_skill_scaling__core-main{
   font-weight: 900;
   min-width:0;
   font-size: 16px;
   display:flex;
   line-height: 1.05;
   align-items:baseline;
   color: rgba(235,244,255,0.92);
   justify-content:center;
   text-align: center;
   flex-wrap:wrap;
   word-wrap: break-word;
   gap:4px;
}
}


.sv-scaling-label {
.sv_skill_scaling__core-value{
   margin-top: 4px;
   min-width:0;
   font-weight: 800;
   word-wrap:break-word;
   font-size: 12px;
 
   letter-spacing: 0.12em;
   font-weight:900;
   text-transform: uppercase;
   font-size:14px;
   color: rgba(255,255,255,0.62);
   line-height:1.02;
  text-align: center;
   color:var(--sv-ui-text1);
}
}


.sv-scaling-list { display: grid; gap: 4px; }
.sv_skill_scaling__core-unit{
.sv-scaling-item {
   font-weight:900;
   font-weight: 800;
   font-size:10px;
   font-size: 12px;
   line-height:1.05;
   line-height: 1.15;
   color:var(--sv-ui-text3);
   color: rgba(255,255,255,0.82);
  text-align: center;
  word-wrap: break-word;
}
}


/* ----------------------------------------------------------------------------
.sv_skill_scaling__core-label{
  CORE STATS (DESKTOP/TABLET: 6 COL STRIP)
  margin-top:5px;
---------------------------------------------------------------------------- */


.sv-skill-core { margin-top: 10px; }
  font-weight:900;
.sv-core-row { overflow: hidden; }
  font-size:10px;
  line-height:1.10;
  letter-spacing:0.14px;
  text-transform:uppercase;
  color:var(--sv-ui-text3);
}


.sv-core-grid {
.sv_skill_scaling__core-pill.is-inactive{
   display: grid;
   background:var(--sv-ui-bg1);
  grid-template-columns: 1fr 1.25fr 1.25fr 1fr 1fr 1.25fr;
  gap: 0;
}
}


.sv-core-cell {
.sv_skill_scaling__core-pill.is-inactive .sv_skill_scaling__core-value,
  padding: 5px;
.sv_skill_scaling__core-pill.is-inactive .sv_skill_scaling__core-unit,
  min-width: 0;
.sv_skill_scaling__core-pill.is-inactive .sv_skill_scaling__core-label{
   overflow: hidden;
   color:var(--sv-ui-text3);
}
}
.sv-core-cell + .sv-core-cell {
 
   border-left: 1px solid rgba(255,255,255,0.050);
/* -------------------------------------------------------------------------- */
/* 9) Tab panels and content                                                  */
/* -------------------------------------------------------------------------- */
 
.sv-skill-tabs{
   margin:10px 0 0;
}
}


.sv-core-top {
.sv-skill-tabs .sv-tabs-panels{
   display: flex;
   margin-top:10px;
  align-items: baseline;
  justify-content: center;
  gap: 6px;
}
}


.sv-core-num {
.sv-skill-tabs .sv-tabpanel{
   font-weight: 900;
   min-width:0;
  font-size: 16px;
   background-image:none;
   line-height: 1.05;
   box-shadow:none;
  color: rgba(235,244,255,0.92);
   word-wrap: break-word;
}
}


.sv-core-unit {
.sv-skill-tabs .sv-tab-empty{
   font-weight: 800;
  padding:14px 12px;
   font-size: 12px;
  text-align:center;
   color: rgba(255,255,255,0.75);
 
  letter-spacing: 0.02em;
  border-radius:14px;
  background:var(--sv-ui-bg2);
 
   font-weight:900;
   font-size:13px;
   color:var(--sv-ui-text3);
}
}


.sv-core-label {
.sv-skill-tabs .sv-tab-section + .sv-tab-section{
  margin-top: 4px;
   margin-top:12px;
  font-weight: 800;
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.62);
  text-align: center;
   line-height: 1.05;
  white-space: nowrap;
  overflow: hidden;
}
}
.sv-core-label--tight { letter-spacing: 0.03em; }


/* ----------------------------------------------------------------------------
.sv-skill-tabs .sv-tab-section-title{
  TABS (SEGMENTED BAR)
  width:100%;
---------------------------------------------------------------------------- */
  margin:0 0 8px;
  text-align:center;
 
  font-weight:900;
  font-size:11px;
  line-height:1.05;
  letter-spacing:0.22px;
  text-transform:uppercase;
  color:var(--sv-ui-text3);
}


.sv-skill-tabs { margin-top: 10px; }
/* -------------------------------------------------------------------------- */
.sv-tabs { overflow: hidden; }
/* 10) Mechanics tab                                                          */
/* -------------------------------------------------------------------------- */
/* Mechanics stays two-column through sm / md / lg. It only collapses into a  */
/* single-column stack in the default viewpoint (<640px).                      */


.sv-tabs-list {
.sv-skill-tabs .sv-mech-panel{
   display: grid;
   display:grid;
   grid-template-columns: repeat(4, 1fr);
   grid-template-columns:repeat(2, minmax(0, 1fr));
   gap: 0;
  column-gap:14px;
   border-bottom: 1px solid rgba(255,255,255,0.050);
   row-gap:12px;
   align-items:start;
}
}


.sv-tab {
.sv-skill-tabs .sv-mech-panel__group{
   border: 0;
   min-width:0;
   margin: 0;
   max-width:100%;
   padding: 10px 8px;
  min-height:0;
   padding:10px 12px 12px;


   background: transparent;
   display:flex;
   color: rgba(255,255,255,0.78);
   flex-direction:column;
  justify-content:flex-start;
  align-items:stretch;
  align-self:start;


   font-weight: 800;
   border:0;
   font-size: 12px;
  border-radius:16px;
   letter-spacing: 0.06em;
   background:var(--sv-ui-bg2);
   text-transform: uppercase;
   background-image:none;
   box-shadow:none;
}


   cursor: pointer;
.sv-skill-tabs .sv-mech-panel__mods,
   line-height: 1.05;
.sv-skill-tabs .sv-mech-panel__keywords{
   grid-column:auto;
   margin-top:0;
  min-height:0;
}


  min-width: 0;
.sv-skill-tabs .sv-mech-panel__mods{
  text-align: center;
   overflow:visible;
  white-space: nowrap;
   overflow: hidden;
}
}


.sv-tab + .sv-tab { border-left: 1px solid rgba(255,255,255,0.050); }
.sv-skill-tabs .sv-mech-panel__keywords{
  justify-content:flex-start;
}


.sv-tab[aria-selected="true"] {
.sv-skill-tabs .sv-mech-panel .sv-tab-section-title{
   color: rgba(235,244,255,0.92);
   margin:0 0 8px;
  background:
   text-align:center;
    radial-gradient(600px 220px at 50% 0, rgba(96,165,250,0.14), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02));
   box-shadow: inset 0 1px 0 rgba(255,255,255,0.05);
}
}


.sv-tabs-panels { padding: 10px 10px 12px; }
/* Modifiers --------------------------------------------------------------- */
.sv-tabpanel { display: none; }
.sv-tabpanel[data-active="1"] { display: block; }


/* Keyword pills */
.sv-skill-tabs .sv-mech-mod-grid{
.sv-tab-pills {
   display:grid;
   display: flex;
   grid-template-columns:repeat(3, minmax(0, 1fr));
   flex-wrap: wrap;
   gap:8px;
   gap: 8px;
  align-content:start;
   justify-content: center;
   justify-items:stretch;
}
}


.sv-pill {
.sv-skill-tabs .sv-mech-mod-pill{
   display: inline-block;
   position:relative;
   padding: 6px 10px;
  min-width:0;
   border-radius: 999px;
  width:100%;
   border: 1px solid rgba(255,255,255,0.050);
  min-height:56px;
   background: rgba(255,255,255,0.03);
   padding:6px 8px;
   color: rgba(235,244,255,0.92);
 
   font-weight: 800;
   display:flex;
   font-size: 12px;
  flex-direction:column;
   line-height: 1.05;
   justify-content:center;
   white-space: nowrap;
   align-items:center;
   text-align:center;
 
   border-radius:14px;
   border:1px solid var(--sv-ui-line2);
  background:var(--sv-ui-bg3);
   background-image:none;
   box-shadow:none;
}
}


/* Mechanics/Keywords grid */
.sv-skill-tabs .sv-mech-mod-pill__label{
.sv-kw-root { display: grid; gap: 10px; }
  min-width:0;
  word-wrap:break-word;
  overflow-wrap:anywhere;
 
  font-weight:900;
  font-size:10px;
  line-height:1.02;
  letter-spacing:0.10px;
  text-transform:uppercase;
  color:var(--sv-ui-text3);
}
 
.sv-skill-tabs .sv-mech-mod-pill__value{
  margin-top:3px;
  min-width:0;
  word-wrap:break-word;
  overflow-wrap:anywhere;
 
  font-weight:900;
  font-size:12px;
  line-height:1.02;
  color:var(--sv-ui-text1);
}


.sv-kw-grid {
.sv-skill-tabs .sv-mech-mod-pill__hit{
   display: grid;
   position:absolute;
   grid-template-columns: repeat(3, 1fr);
  top:0;
   gap: 8px;
  right:0;
  bottom:0;
   left:0;
  z-index:5;
   opacity:0;
}
}


.sv-kw-cell {
.sv-skill-tabs .sv-mech-mod-pill__hit .sv-def{
  border-radius: 12px;
   display:block;
  border: 1px solid rgba(255,255,255,0.050);
   width:100%;
   background: rgba(255,255,255,0.03);
   height:100%;
   padding: 8px 8px 7px;
   min-width: 0;
}
}


.sv-kw-label {
/* Keywords ---------------------------------------------------------------- */
   font-weight: 800;
 
  font-size: 12px;
.sv-skill-tabs .sv-mech-panel__keywords .sv-tab-pills{
   letter-spacing: 0.08em;
   display:grid;
  text-transform: uppercase;
   grid-template-columns:repeat(2, minmax(0, 1fr));
  color: rgba(255,255,255,0.62);
   gap:8px;
   text-align: center;
   align-content:start;
   line-height: 1.05;
   justify-items:stretch;
   white-space: nowrap;
   margin:0;
   overflow: hidden;
}
}


.sv-kw-value {
.sv-skill-tabs .sv-mech-keyword-pill{
   margin-top: 6px;
   position:relative;
   font-weight: 900;
  min-width:0;
   font-size: 12px;
  width:100%;
   color: rgba(235,244,255,0.92);
  min-height:56px;
   text-align: center;
  padding:6px 10px;
   word-wrap: break-word;
 
   display:flex;
   align-items:center;
   justify-content:center;
   text-align:center;
 
   border-radius:16px;
  border:1px solid var(--sv-ui-line2);
  background:var(--sv-ui-bg3);
  background-image:none;
  box-shadow:none;
}
}


/* ----------------------------------------------------------------------------
.sv-skill-tabs .sv-mech-keyword-pill__label{
  EFFECTS / EVENTS (CARD GRID)
  display:block;
---------------------------------------------------------------------------- */
  min-width:0;
  width:100%;
  word-wrap:break-word;
  overflow-wrap:anywhere;


.sv-ref-grid {
  font-weight:900;
   display: grid;
  font-size:12px;
   grid-template-columns: repeat(2, 1fr);
   line-height:1.08;
   gap: 10px;
   color:var(--sv-ui-text1);
   text-align:center;
}
}


.sv-ref-card {
.sv-skill-tabs .sv-mech-keyword-pill__hit{
   position: relative;
   position:absolute;
   display: grid;
  top:0;
   grid-template-columns: 56px 1fr;
   right:0;
   gap: 12px;
   bottom:0;
   align-items: center;
   left:0;
   z-index:5;
  opacity:0;
}


  padding: 12px 12px 11px;
.sv-skill-tabs .sv-mech-keyword-pill__hit .sv-def{
   border-radius: 14px;
   display:block;
   border: 1px solid rgba(255,255,255,0.050);
   width:100%;
   background: rgba(255,255,255,0.03);
   height:100%;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.03);
}


   min-height: 86px;
/* Larger keyword mode. */
   color: rgba(235,244,255,0.92);
.sv-skill-tabs .sv-mech-panel__keywords .sv-tab-pills.sv-tab-pills--xl .sv-mech-keyword-pill,
   text-decoration: none;
.sv-skill-tabs .sv-mech-keyword-pill.sv-pill--xl{
   min-height:60px;
   padding:8px 12px;
   border-radius:999px;
}
}


.sv-ref-card:hover { background: rgba(255,255,255,0.045); }
.sv-skill-tabs .sv-mech-panel__keywords .sv-tab-pills.sv-tab-pills--xl .sv-mech-keyword-pill__label,
.sv-skill-tabs .sv-mech-keyword-pill.sv-pill--xl .sv-mech-keyword-pill__label{
  font-size:13px;
  line-height:1.12;
}


.sv-ref-ico {
/* -------------------------------------------------------------------------- */
   width: 56px;
/* 11) Effect cards                                                            */
   height: 56px;
/* -------------------------------------------------------------------------- */
  border-radius: 14px;
 
  background: rgba(255,255,255,0.04);
.sv-gi-card .sv-ref-grid,
  border: 1px solid rgba(255,255,255,0.050);
.sv-skill-card .sv-ref-grid{
   box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
   display:grid;
   grid-template-columns:repeat(2, minmax(0, 1fr));
   gap:10px;
}
}


.sv-ref-text { min-width: 0; }
.sv-gi-card .sv-ref-card,
.sv-skill-card .sv-ref-card{
  min-width:0;
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:10px 10px;


.sv-ref-title-row {
  border-radius:16px;
   display: flex;
   background:var(--sv-ui-bg2);
   align-items: baseline;
   background-image:none;
   justify-content: space-between;
   box-shadow:none;
   gap: 10px;
 
  min-width: 0;
   color:var(--sv-ui-text2);
}
}


.sv-ref-title {
.sv-gi-card .sv-ref-ico,
   font-weight: 900;
.sv-skill-card .sv-ref-ico{
   font-size: 12px;
   flex:0 0 auto;
   line-height: 1.05;
  width:52px;
   word-wrap: break-word;
  height:52px;
 
  display:flex;
  align-items:center;
   justify-content:center;
   overflow:hidden;
 
   border-radius:16px;
}
}


.sv-ref-inline {
.sv-gi-card .sv-ref-text,
  font-weight: 900;
.sv-skill-card .sv-ref-text{
  font-size: 12px;
   min-width:0;
   line-height: 1.05;
   flex:1 1 auto;
  color: rgba(235,244,255,0.92);
   white-space: nowrap;
}
}


/* Events stacked layout */
.sv-gi-card .sv-ref-title,
.sv-ref-title-row--stacked {
.sv-skill-card .sv-ref-title{
   flex-direction: column;
   word-wrap:break-word;
   align-items: flex-start;
 
   justify-content: flex-start;
   font-weight:900;
   gap: 6px;
  font-size:15px;
   line-height:1.15;
   color:var(--sv-ui-text1);
}
}
.sv-ref-title-row--stacked .sv-ref-inline {
 
   font-size: 12px;
.sv-gi-card .sv-ref-stats,
   font-weight: 800;
.sv-skill-card .sv-ref-stats{
   color: rgba(255,255,255,0.78);
   display:flex;
  letter-spacing: 0.05em;
   flex-wrap:wrap;
   text-transform: uppercase;
   gap:8px;
   margin-top:8px;
}
}


.sv-ref-stats {
.sv-gi-card .sv-ref-stat,
  margin-top: 6px;
.sv-skill-card .sv-ref-stat{
  display: flex;
   font-weight:900;
  justify-content: space-evenly;
   font-size:12px;
  gap: 14px;
   color:var(--sv-ui-text1);
   font-weight: 900;
   font-size: 12px;
   color: rgba(235,244,255,0.92);
}
}
.sv-ref-stat { white-space: nowrap; }


/* Optional hover pop (NO transition/transform/:focus-within) */
.sv-gi-card .sv-ref-sub,
.sv-ref-pop { display: none; }
.sv-skill-card .sv-ref-sub{
.sv-ref-card:hover .sv-ref-pop { display: block; }
  margin-top:6px;
  font-weight:900;
  font-size:13px;
  color:var(--sv-ui-text3);
}


/* ----------------------------------------------------------------------------
/* -------------------------------------------------------------------------- */
  RESPONSIVE (Project Standard)
/* 12) Responsive                                                              */
  Desktop: > 720
/* -------------------------------------------------------------------------- */
  Tablet:  720–521
  Mobile:  <= 520
---------------------------------------------------------------------------- */


/* Tablet */
@media (max-width:1023px){
@media (max-width: 720px) {
   .sv-gi-card,
   .sv-gi-card,
   .sv-skill-card {
   .sv-skill-card{
     margin: 14px 10px;
     margin:14px 10px;
     border-radius: 20px;
     border-radius:20px;
   }
   }


   .sv-gi-top,
   .sv-gi-top,
   .sv-skill-top {
   .sv-skill-top{ padding:12px 16px 4px; }
     padding: 12px 12px 4px;
 
     border-radius: 20px 20px 0 0;
  .sv-gi-bottom,
  .sv-skill-bottom{ padding:10px 16px 12px; }
 
  .sv-skill-title{ font-size:20px; }
 
  .sv_skill_scaling__body{
     grid-template-columns:minmax(0, 1fr) minmax(0, 236px);
  }
 
  .sv_skill_scaling__primary-value{ font-size:32px; }
 
  .sv_skill_scaling__core-pill{
    min-height:25px;
    min-width:70px;
  }
 
  .sv_skill_scaling__core-value{ font-size:13px; }
  .sv_skill_scaling__core-label{ font-size:9px; }
 
  .sv-gi-card .sv-ref-grid,
  .sv-skill-card .sv-ref-grid{ grid-template-columns:1fr; }
 
  .sv-skill-tabs .sv-mech-panel{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    column-gap:12px;
    row-gap:12px;
     align-items:start;
  }
 
  .sv-skill-tabs .sv-mech-panel__group{
    min-height:0;
    max-height:none;
    padding:9px 10px 10px;
    align-self:start;
  }
 
  .sv-skill-tabs .sv-mech-mod-grid{
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:8px;
  }
 
  .sv-skill-tabs .sv-mech-mod-pill{
    min-height:48px;
    padding:6px 8px;
  }
 
  .sv-skill-tabs .sv-mech-mod-pill__label{
    font-size:10px;
    line-height:1.03;
   }
   }


   .sv-gi-bottom,
   .sv-skill-tabs .sv-mech-mod-pill__value{ font-size:12px; }
   .sv-skill-bottom {
 
     padding: 10px 12px 12px;
   .sv-skill-tabs .sv-mech-panel__keywords .sv-tab-pills{
    border-radius: 0 0 20px 20px;
     gap:8px;
   }
   }


  /* Meta becomes 2x2 segmented */
   .sv-skill-tabs .sv-mech-keyword-pill{
   .sv-skill-meta { grid-template-columns: repeat(2, 1fr); }
    min-height:44px;
    padding:7px 9px;
  }


   .sv-meta-card {
   .sv-skill-tabs .sv-mech-keyword-pill__label{
     border-right: 1px solid rgba(255,255,255,0.050);
     font-size:12px;
     border-bottom: 1px solid rgba(255,255,255,0.050);
     line-height:1.10;
   }
   }
  .sv-meta-card:nth-child(2),
  .sv-meta-card:nth-child(4) { border-right: none; }
  .sv-meta-card:nth-child(3),
  .sv-meta-card:nth-child(4) { border-bottom: none; }


   .sv-tab { padding: 8px 6px; }
   .sv-skill-tabs .sv-mech-panel__keywords .sv-tab-pills.sv-tab-pills--xl .sv-mech-keyword-pill,
   .sv-tabs-panels { padding: 9px 9px 10px; }
   .sv-skill-tabs .sv-mech-keyword-pill.sv-pill--xl{
    min-height:48px;
    padding:9px 10px;
  }


   .sv-pill { padding: 5px 9px; }
   .sv-skill-tabs .sv-mech-panel__keywords .sv-tab-pills.sv-tab-pills--xl .sv-mech-keyword-pill__label,
  .sv-skill-tabs .sv-mech-keyword-pill.sv-pill--xl .sv-mech-keyword-pill__label{
    font-size:13px;
  }
}


   .sv-kw-grid { gap: 7px; }
@media (max-width:767px){
  .sv-kw-cell { padding: 7px 7px 6px; }
   .sv-skill-meta-block{
    grid-template-columns:minmax(0, 1fr);
  }


  /* Keep level slider full-width even on tablet */
   .sv-skill-meta-block__bubble{
   .sv-level-range--custom,
    min-height:auto;
  .sv-level-ticklabels {
     max-height:none;
     max-width: 520px;
   }
   }
}
}


/* Mobile */
@media (max-width:639px){
@media (max-width: 520px) {
   .sv-skill-head{ gap:10px; }
   .sv-skill-head {
 
     grid-template-columns: 92px 1fr;
  .sv-skill-icon{
     gap: 12px;
    width:56px;
    height:56px;
    border-radius:14px;
  }
 
  .sv-skill-title{ font-size:19px; }
 
  .sv-skill-desc{
    font-size:14px;
    line-height:1.40;
  }
 
  .sv_skill_scaling{ padding:9px 10px 10px; }
 
  .sv_skill_scaling .sv-skill-level,
  .sv_skill_scaling__level{ padding:0 0 9px; }
 
  .sv_skill_scaling__body{
     grid-template-columns:1fr;
     row-gap:12px;
  }
 
  .sv_skill_scaling__group{
    min-height:auto;
    max-height:none;
    padding:10px 11px;
  }
 
  .sv_skill_scaling__group--core{
    grid-column:1;
    grid-row:2;
  }
 
  .sv_skill_scaling__cluster{ height:auto; }
 
  .sv_skill_scaling__primary-value{ font-size:32px; }
 
  .sv_skill_scaling__primary-label{
    font-size:11px;
    line-height:1.08;
   }
   }


   .sv-skill-icon {
   .sv_skill_scaling__core-grid{
     width: 92px;
     grid-template-columns:repeat(2, minmax(0, 1fr));
     height: 92px;
     width:100%;
     border-radius: 12px;
     align-items:stretch;
   }
   }


  /* Title row snaps info button right */
   .sv_skill_scaling__core-pill{
   .sv-skill-title-row {
     width:100%;
     display: grid;
     min-width:0;
     grid-template-columns: 1fr auto;
    min-height:30px;
     column-gap: 10px;
     padding:8px 7px;
     row-gap: 6px;
    justify-self:stretch;
     align-items: start;
     justify-content:center;
     align-items:center;
    text-align:center;
   }
   }


   /* Requirements / Users stack */
   .sv_skill_scaling__core-value{ font-size:14px; }
   .sv-reqrow { grid-template-columns: 1fr; }
   .sv_skill_scaling__core-unit{ font-size:11px; }
  .sv_skill_scaling__core-label{ font-size:10px; }


   /* Disclose pop aligns right on mobile */
   .sv_skill_scaling__core-value,
   .sv-disclose-pop { left: auto; right: 0; max-width: 92%; }
   .sv_skill_scaling__core-unit,
  .sv_skill_scaling__core-label{
    width:100%;
    text-align:center;
  }


   /* Scaling becomes “stacked-left + tall-right” */
   .sv-skill-tabs .sv-tab-section-title{
  .sv-scaling-grid { grid-template-columns: 1fr 1fr; }
    margin:0 0 9px;
    font-size:12px;
    line-height:1.08;
  }


   .sv-scaling-col--damage {
   .sv-skill-tabs .sv-mech-panel{
     grid-column: 1;
     grid-template-columns:1fr;
     grid-row: 1;
     row-gap:12px;
    border-right: 1px solid rgba(255,255,255,0.050);
   }
   }


   .sv-scaling-col--modifier {
   .sv-skill-tabs .sv-mech-panel__mods,
    grid-column: 1;
  .sv-skill-tabs .sv-mech-panel__keywords{ grid-column:1; }
     grid-row: 2;
 
     border-top: 1px solid rgba(255,255,255,0.050);
  .sv-skill-tabs .sv-mech-panel__group{
     border-right: 1px solid rgba(255,255,255,0.050);
     min-height:auto;
     max-height:none;
     padding:10px 11px 11px;
   }
   }


   .sv-scaling-col--scaling {
   .sv-skill-tabs .sv-mech-mod-grid{
     grid-column: 2;
     grid-template-columns:repeat(2, minmax(0, 1fr));
    grid-row: 1 / span 2;
     gap:9px;
     display: flex;
    align-items: center;
    justify-content: center;
   }
   }


   /* Core becomes 3x2 */
   .sv-skill-tabs .sv-mech-mod-pill{
  .sv-core-grid { grid-template-columns: repeat(3, 1fr); }
    min-height:50px;
    padding:8px 8px 7px;
    border-radius:14px;
  }


   .sv-core-cell { border-left: 0; border-top: 1px solid rgba(255,255,255,0.050); }
   .sv-skill-tabs .sv-mech-mod-pill__label{
  .sv-core-cell:nth-child(-n+3) { border-top: 0; }
    font-size:10px;
  .sv-core-cell:nth-child(3n+2),
    line-height:1.06;
   .sv-core-cell:nth-child(3n+3) { border-left: 1px solid rgba(255,255,255,0.050); }
   }


  /* Tabs become 2x2 segmented */
   .sv-skill-tabs .sv-mech-mod-pill__value{
   .sv-tabs-list { grid-template-columns: repeat(2, 1fr); }
    margin-top:4px;
    font-size:14px;
    line-height:1.05;
  }


   .sv-tab { padding: 9px 6px; }
   .sv-skill-tabs .sv-mech-panel__keywords .sv-tab-pills{ gap:8px; }
  .sv-tab + .sv-tab { border-left: 1px solid rgba(255,255,255,0.050); }
  .sv-tab:nth-child(2n+1) { border-left: 0; }
  .sv-tab:nth-child(n+3) { border-top: 1px solid rgba(255,255,255,0.050); }


   /* Mechanics grid becomes 2-col */
   .sv-skill-tabs .sv-mech-keyword-pill{
  .sv-kw-grid { grid-template-columns: repeat(2, 1fr); }
    min-height:40px;
    padding:8px 10px;
    border-radius:14px;
  }


   /* Effects/Events become 1-col */
   .sv-skill-tabs .sv-mech-keyword-pill__label{
  .sv-ref-grid { grid-template-columns: 1fr; }
    font-size:13px;
   .sv-ref-card { grid-template-columns: 52px 1fr; }
    line-height:1.12;
   .sv-ref-ico { width: 52px; height: 52px; border-radius: 13px; }
  }
 
   .sv-skill-tabs .sv-mech-panel__keywords .sv-tab-pills.sv-tab-pills--xl .sv-mech-keyword-pill,
   .sv-skill-tabs .sv-mech-keyword-pill.sv-pill--xl{
    min-height:46px;
    padding:10px 12px;
    border-radius:14px;
  }


   /* Level slider uses full available width on mobile */
   .sv-skill-tabs .sv-mech-panel__keywords .sv-tab-pills.sv-tab-pills--xl .sv-mech-keyword-pill__label,
  .sv-level-range--custom,
   .sv-skill-tabs .sv-mech-keyword-pill.sv-pill--xl .sv-mech-keyword-pill__label{
   .sv-level-ticklabels {
     font-size:14px;
     max-width: 100%;
   }
   }
}


/* --------------------------------------------------------------------------
  .sv-skill-card .sv-skill-meta,
  PATCH: Level selector final lockdown (wins even if markup uses spans/inline)
  .sv-gi-card .sv-skill-meta{
--------------------------------------------------------------------------- */
    gap:8px;
    width:100%;
    max-width:none;
    margin-left:auto;
    margin-right:auto;
    justify-content:center;
    align-items:stretch;
  }


.sv-skill-card .sv-skill-level,
  .sv-skill-card .sv-meta-card,
.sv-skill-card .sv-level-ui,
  .sv-gi-card .sv-meta-card{
.sv-skill-card .sv-level-slider,
    flex:1 1 calc(50% - 4px);
.sv-skill-card .sv-level-range--custom,
    min-width:0;
.sv-skill-card .sv-level-ticklabels {
    min-height:36px;
  width: 100% !important;
    gap:8px;
}
    padding:7px 9px;
    justify-content:center;
    align-items:center;
    text-align:center;
  }


.sv-skill-card .sv-level-slider {
  .sv-skill-card .sv-meta-icon,
  display: block !important;
  .sv-gi-card .sv-meta-icon{
}
    width:16px;
    height:16px;
  }


.sv-skill-card .sv-level-range--custom {
  .sv-skill-card .sv-meta-text,
  display: block !important;
  .sv-gi-card .sv-meta-text{
  margin-left: auto !important;
    flex:1 1 auto;
  margin-right: auto !important;
    min-width:0;
}
    font-size:11px;
    line-height:1.08;
    letter-spacing:0;
    text-align:center;
  }


.sv-skill-card .sv-level-label {
  .sv-skill-card .sv-meta-text .sv-meta-lines span + span,
  white-space: nowrap !important;
  .sv-gi-card .sv-meta-text .sv-meta-lines span + span{
}
    margin-top:1px;
    font-size:10px;
  }


.sv-skill-card .sv-level-label br {
  .sv-skill-level{ padding:10px 11px; }
  display: none !important;
}


.sv-skill-card .sv-level-label span,
  /* Absorbed former micro-phone layout compaction into the default viewpoint. */
.sv-skill-card .sv-level-label b,
.sv-skill-card .sv-level-label strong,
.sv-skill-card .sv-level-label em,
.sv-skill-card .sv-level-label i {
  display: inline !important;
  white-space: nowrap !important;
}
}