/* gs-character.css — trang nhân vật v2: bố cục kiểu irminsul, MÀU/FONT theo theme site */
.gsv2{
  --card:var(--gs-card-bg,#1f2430);
  --card2:#262c3a;
  --row:#2c313f;
  --rowlt:#343b4c;
  --line:var(--gs-border,rgba(255,255,255,.08));
  --txt:var(--gs-text,#e9eefc);
  --mut:rgba(255,255,255,.55);
  --gold:#f3c258;
  --blue:#57a7f5;
  --rad:var(--gs-radius,12px);
  --thumb:var(--gs-thumb,64px);
  width:100vw;margin-left:calc(50% - 50vw);
  background:transparent;color:var(--txt);
  font-size:16px;line-height:1.55;
}
.gsv2-inner{max-width:1560px;margin:0 auto;padding:24px clamp(14px,3vw,44px) 64px}
.gsv2 *{box-sizing:border-box}
.gsv2 img{max-width:100%;display:block}

/* CARD */
.gsv2-card{background:var(--card);border:1px solid var(--line);border-radius:var(--rad);overflow:hidden;box-shadow:var(--gs-shadow,0 8px 20px rgba(0,0,0,.25))}
.gsv2-section{padding:20px 22px 22px;margin-top:20px}
.gsv2-h2{margin:0 0 18px;padding:0 0 12px;font-size:20px;font-weight:700;color:#fff;border-bottom:1px solid var(--line)}

/* HEADER 2 cột */
.gsv2-head2{display:grid;grid-template-columns:420px 1fr;gap:20px;align-items:start}
.gsv2-col-left,.gsv2-col-right{display:flex;flex-direction:column;gap:20px}
.gsv2-splash{background:radial-gradient(circle at 50% 32%,#2c313f,#13161d 75%);height:580px}
.gsv2-splash img{width:100%;height:100%;object-fit:cover;object-position:center 16%}
.gsv2-meta-card{padding:6px 20px}
.gsv2-namecard{padding:22px 24px}
.gsv2-name{margin:0;font-size:34px;font-weight:800;color:#fff;line-height:1.12}
.gsv2-title{margin:2px 0 12px;color:var(--mut);font-style:italic;font-size:16px}
.gsv2-badges{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:14px}
.gsv2-stars{font-size:19px;letter-spacing:2px;color:var(--gold)}
.gsv2-badge{display:inline-flex;align-items:center;gap:7px;background:var(--row);border:1px solid var(--line);border-radius:24px;padding:5px 13px;font-size:14px;font-weight:600}
.gsv2-badge img{width:22px;height:22px}
.gsv2-desc{color:var(--mut);font-size:15px;line-height:1.65}

/* META TABLE */
.gsv2-meta{width:100%;border-collapse:collapse}
.gsv2-meta td{padding:11px 6px;border-top:1px solid var(--line);font-size:15px;vertical-align:top}
.gsv2-meta tr:first-child td{border-top:0}
.gsv2-meta td:first-child{color:var(--mut);width:46%;white-space:nowrap}
.gsv2-meta td:last-child{color:var(--txt);font-weight:600;text-align:right}

/* TABLES */
.gsv2-table{width:100%;border-collapse:collapse}
.gsv2-table td{padding:11px 14px;border-top:1px solid var(--line);font-size:15px}
.gsv2-table tr:first-child td{border-top:0}
.gsv2-table td:first-child{color:var(--mut)}
.gsv2-statval,.gsv2-table td:last-child{text-align:right;font-weight:700;color:var(--txt)}
.gsv2-statname{display:flex;align-items:center;gap:10px}
.gsv2-sicon{width:24px;height:24px;flex:0 0 auto}
.gsv2-stats-table tr{background:rgba(255,255,255,.02)}

/* SLIDER */
.gsv2-lvlctl{display:flex;align-items:center;gap:16px;margin:4px 0 16px}
.gsv2-lvllabel{min-width:120px;color:var(--mut);font-weight:600}
.gsv2-lvllabel b{color:var(--gsv2-elem,var(--gold));font-size:17px}
.gsv2-lvlctl input[type=range]{flex:1;-webkit-appearance:none;appearance:none;height:6px;border-radius:4px;background:rgba(255,255,255,.12);outline:none;cursor:pointer}
.gsv2-lvlctl input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--gsv2-elem,#57a7f5);border:2px solid rgba(255,255,255,.85);box-shadow:0 0 6px rgba(0,0,0,.5)}
.gsv2-lvlctl input[type=range]::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--gsv2-elem,#57a7f5);border:2px solid rgba(255,255,255,.85)}
.gsv2-lvlctl input[type=range]::-moz-range-track{height:6px;border-radius:4px;background:rgba(255,255,255,.12)}
.gsv2-lvlctl input[type=range]::-moz-range-progress{height:6px;border-radius:4px;background:var(--gsv2-elem,#57a7f5)}

/* MATERIALS */
.gsv2-mats{display:flex;flex-wrap:wrap;gap:12px}
.gsv2-mat{width:calc(var(--thumb) + 14px);background:var(--card2);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.gsv2-mat img{width:100%;height:var(--thumb);object-fit:contain;background:linear-gradient(160deg,#3a4153,#222734);padding:5px}
.gsv2-mat__q{display:block;text-align:center;font-size:13px;font-weight:700;padding:4px 2px;background:rgba(0,0,0,.25)}
.gsv2-phase{display:flex;align-items:center;gap:16px;padding:12px 0;border-top:1px solid var(--line)}
.gsv2-phase:first-child{border-top:0}
.gsv2-phase__label{min-width:110px;color:var(--mut);font-weight:600}

/* TALENTS */
.gsv2-tabs{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.gsv2-tab{background:#13161d;border:2px solid var(--line);border-radius:50%;padding:6px;cursor:pointer;line-height:0;transition:box-shadow .2s,border-color .2s}
.gsv2-tab img{width:48px;height:48px}
.gsv2-tab.is-active{border-color:var(--gsv2-elem,var(--gold));box-shadow:0 0 14px 3px color-mix(in srgb,var(--gsv2-elem,#f3c258) 55%,transparent)}
.gsv2-panel{display:none}
.gsv2-panel.is-active{display:block}
.gsv2-slotlabel{color:var(--gold);font-weight:700;font-size:15px;letter-spacing:.4px;text-transform:uppercase;margin:0 0 12px}
.gsv2-rtab{background:#13161d;border:2px solid var(--line);color:var(--txt);cursor:pointer;border-radius:8px;padding:6px 16px;font-weight:700;transition:border-color .2s,color .2s}
.gsv2-rtab.is-active{border-color:var(--gsv2-elem,var(--gold));color:var(--gsv2-elem,var(--gold))}
/* ===== Tool: character picker + controls ===== */
.gtool-search{width:100%;max-width:420px;background:#13161d;color:#e9eefc;border:1px solid var(--line);border-radius:10px;padding:10px 14px;font-size:15px;margin-bottom:12px}
.gtool-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(78px,1fr));gap:8px;max-height:360px;overflow:auto;padding:6px;background:rgba(0,0,0,.2);border:1px solid var(--line);border-radius:12px}
.gtool-pick{cursor:pointer;border:2px solid transparent;border-radius:9px;overflow:hidden;background:#13161d;transition:border-color .15s,transform .1s}
.gtool-pick:hover{transform:translateY(-2px)}
.gtool-pick.sel{border-color:var(--gsv2-elem,#f3c258);box-shadow:0 0 10px color-mix(in srgb,var(--gsv2-elem,#f3c258) 50%,transparent)}
.gtool-pick__img{height:66px;background:#0d0f15 center top/cover no-repeat}
.gtool-pick__name{font-size:10.5px;line-height:1.2;padding:3px 3px 4px;color:#cfd6e6;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gtool-pick.sel .gtool-pick__name{color:var(--gsv2-elem,#f3c258);font-weight:700}
.gtool-sel{display:flex;gap:16px;align-items:center;margin:18px 0;padding:14px;background:var(--card2);border:1px solid var(--line);border-radius:12px}
.gtool-sel__img{width:84px;height:84px;border-radius:10px;background:#0d0f15 center top/cover no-repeat;flex:0 0 auto}
.gtool-sel__name{font-size:22px;font-weight:800;color:#fff}
.gtool-sel__sub{color:var(--mut);font-size:13px;margin-top:2px}
.gtool-ctl{margin:14px 0}
.gtool-ctl__label{display:flex;justify-content:space-between;margin-bottom:6px;font-weight:600;color:var(--mut)}
.gtool-ctl__label b{color:var(--gsv2-elem,#f3c258)}
.gsv2-charuse{display:flex;flex-wrap:wrap;gap:14px}
.gsv2-cu-item{display:flex;flex-direction:column;align-items:center;width:84px;text-decoration:none;color:var(--txt)}
.gsv2-cu-img{width:80px;height:80px;border-radius:10px;overflow:hidden;display:flex;align-items:flex-end;justify-content:center;background-size:cover;background-position:center}
.gsv2-cu-img img{width:100%;height:100%;object-fit:cover}
.gsv2-cu-name{font-size:12.5px;margin-top:6px;text-align:center;line-height:1.25}
.gsv2-cu-item:hover .gsv2-cu-name{color:var(--gsv2-elem,var(--gold))}
.gsv2-talent-2col{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:start}
.gsv2-talent-left{background:var(--card2);border:1px solid var(--line);border-radius:10px;padding:16px}
.gsv2-talent-name{color:var(--gold);font-size:19px;font-weight:700;margin:0 0 10px}
.gsv2-talent-desc{line-height:1.7;color:var(--txt)}
.gsv2-subhead{color:#fff;font-weight:700;font-size:16px;margin:0 0 12px}
.gsv2-levelup{margin-top:20px;border-top:1px solid var(--line);padding-top:16px}

/* SUBCARDS (passive / constellation) */
.gsv2-cardgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.gsv2-subcard{background:var(--card2);border:1px solid var(--line);border-radius:10px;padding:16px}
.gsv2-subcard__head{display:flex;align-items:center;gap:13px;margin-bottom:10px}
.gsv2-subcard__head img{width:50px;height:50px;background:#13161d;border:1px solid var(--line);border-radius:50%;padding:5px;flex:0 0 auto}
.gsv2-subcard__head strong{color:var(--gold);display:block;line-height:1.3;font-size:16px}
.gsv2-sublabel{color:var(--blue);font-size:13px;font-weight:600}
.gsv2-subcard .gsv2-desc{font-size:14.5px;line-height:1.65;color:var(--txt)}

/* highlight tokens trong mô tả genshin-db */
.gsv2 .text-highlight,.gsv2 .tooltip-highlight{color:var(--gold);font-weight:700}

/* ===== POLISH PASS — tinh chỉnh cho đẹp hơn (chỉ bổ sung) ===== */
.gsv2-card{transition:box-shadow .2s ease,border-color .2s ease}
.gsv2-h2{position:relative;padding-left:14px}
.gsv2-h2::before{content:"";position:absolute;left:0;top:2px;bottom:12px;width:4px;border-radius:3px;background:linear-gradient(180deg,var(--gsv2-elem,var(--gold)),transparent)}
.gsv2-badge{background:linear-gradient(180deg,var(--rowlt),var(--row));transition:transform .15s,border-color .15s,box-shadow .15s}
.gsv2-badge:hover{transform:translateY(-1px);border-color:var(--gsv2-elem,var(--gold))}
.gsv2-mat{transition:transform .15s,box-shadow .15s,border-color .15s}
.gsv2-mat:hover{transform:translateY(-3px);box-shadow:0 10px 20px rgba(0,0,0,.42);border-color:rgba(255,255,255,.22)}
.gsv2-mat img{transition:transform .2s ease}
.gsv2-mat:hover img{transform:scale(1.07)}
.gsv2-tab{transition:transform .15s,box-shadow .2s,border-color .2s}
.gsv2-tab:hover{transform:translateY(-2px)}
.gsv2-rtab{transition:transform .12s,border-color .2s,color .2s}
.gsv2-rtab:hover{transform:translateY(-1px);border-color:var(--gsv2-elem,var(--gold))}
.gsv2-subcard{transition:transform .16s,box-shadow .16s,border-color .16s}
.gsv2-subcard:hover{transform:translateY(-3px);box-shadow:0 10px 22px rgba(0,0,0,.34);border-color:rgba(255,255,255,.18)}
.gsv2-cu-img{transition:transform .16s,box-shadow .2s}
.gsv2-cu-item:hover .gsv2-cu-img{transform:translateY(-3px);box-shadow:0 10px 18px rgba(0,0,0,.45)}
.gsv2-meta tr,.gsv2-table tr{transition:background .15s}
.gsv2-table tbody tr:hover td,.gsv2-meta tr:hover td{background:rgba(255,255,255,.045)}
/* scrollbar sáng cho mọi lưới chọn */
.gtool-grid,.gap-mgrid{scrollbar-width:thin;scrollbar-color:#ffffff rgba(255,255,255,.12)}
.gtool-grid::-webkit-scrollbar,.gap-mgrid::-webkit-scrollbar{width:10px}
.gtool-grid::-webkit-scrollbar-thumb,.gap-mgrid::-webkit-scrollbar-thumb{background:#fff;border-radius:8px;border:3px solid var(--card)}
.gtool-grid::-webkit-scrollbar-track,.gap-mgrid::-webkit-scrollbar-track{background:rgba(255,255,255,.08);border-radius:8px}

/* RESPONSIVE */
@media(max-width:1100px){
  .gsv2-head2{grid-template-columns:330px 1fr}
  .gsv2-splash{height:500px}
}
@media(max-width:820px){
  .gsv2{font-size:15px}
  .gsv2-head2{grid-template-columns:1fr}
  .gsv2-splash{height:auto}
  .gsv2-splash img{height:auto;max-height:540px;object-fit:contain}
  .gsv2-talent-2col{grid-template-columns:1fr}
  .gsv2-cardgrid{grid-template-columns:1fr}
  .gsv2-name{font-size:28px}
  .gsv2-lvllabel{min-width:94px}
}
