:root {
  /* ─── Bảng màu "tiên hiệp nữ tính": hồng đào + xanh ngọc bích + vàng kim ─── */
  --forest:#7a3b5e;          /* tím mận đậm — dùng cho header/nút chính */
  --forest2:#a8487a;         /* hồng mận - text nhấn */
  --leaf:#e8799a;            /* hồng đào - hover */
  --mint:#ffd9e6;            /* hồng phấn nhạt */
  --sage:#fff0f5;            /* hồng phấn rất nhạt - nền phụ */
  --petal:#ff6fa3;           /* hồng đậm - badge/active */
  --petal2:#ff8fb8;
  --blush:#ffe3ee;
  --ink:#5a3047;             /* nâu tím đậm - chữ chính */
  --mist:#b87a98;            /* tím hồng nhạt - chữ phụ */
  --haze:#f3c9da;            /* viền nhạt hồng */
  --paper:#fdf3f7;           /* nền tổng - hồng kem rất nhẹ */
  --white:#fffbfd;
  --bd:#f5d3e2;              /* viền chuẩn */
  --r:16px;--rp:999px;
  --sh:0 2px 14px rgba(168,72,122,.10);--shd:0 10px 34px rgba(168,72,122,.20);
  --clan:#7c5cff;--clan2:#ece6ff;
  /* vàng kim cho khung/viền trang trí kiểu game */
  --gold:#e0a93e;--gold2:#f5cf78;--gold-deep:#a8721c;
  --jade:#3f9a8a;--jade2:#d9f2ec;  /* xanh ngọc bích phụ trợ */
}
*{box-sizing:border-box;margin:0;padding:0}
body{
  font-family:'Be Vietnam Pro',sans-serif;
  color:var(--ink);min-height:100vh;font-size:15px;-webkit-tap-highlight-color:transparent;
  background:
    radial-gradient(circle at 8% 0%, #ffe1ec 0%, transparent 45%),
    radial-gradient(circle at 95% 10%, #d9f2ec 0%, transparent 40%),
    radial-gradient(circle at 50% 100%, #ffeef5 0%, transparent 55%),
    var(--paper);
  background-attachment:fixed;
  position:relative;
}
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:-1;
  opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='64' height='64' viewBox='0 0 64 64'%3E%3Cg fill='none' stroke='%23a8487a' stroke-width='1'%3E%3Cpath d='M32 4 L52 20 L52 44 L32 60 L12 44 L12 20 Z'/%3E%3Cpath d='M32 14 L42 22 L42 38 L32 46 L22 38 L22 22 Z' opacity='.6'/%3E%3C/g%3E%3C/svg%3E");
  background-repeat:repeat;background-size:64px 64px;
}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-thumb{background:var(--haze);border-radius:4px}

/* ─── Header kiểu "thanh ngọc" treo trên cùng, viền vàng kim, hoa văn vân mây ─── */
.bar{
  background:linear-gradient(180deg,#a8487a,#7a3b5e 90%);
  min-height:58px;display:flex;align-items:center;padding:0 16px;gap:8px;
  position:sticky;top:0;z-index:200;
  box-shadow:0 3px 0 var(--gold), 0 6px 16px rgba(122,59,94,.35);
  border-bottom:1px solid rgba(245,207,120,.5);
  position:relative;overflow:hidden;
  flex-wrap:nowrap;
}
.bar::after{
  content:'';position:absolute;inset:0;pointer-events:none;opacity:.16;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='58' viewBox='0 0 120 58'%3E%3Cg fill='none' stroke='%23f5cf78' stroke-width='1.1'%3E%3Cpath d='M4 14c4-5 10-5 13 0s9 5 13 0 9-5 13 0M44 14c4-5 10-5 13 0s9 5 13 0 9-5 13 0M84 14c4-5 10-5 13 0s9 5 13 0 9-5 13 0'/%3E%3Cpath d='M-6 44c4-5 10-5 13 0s9 5 13 0 9-5 13 0 9 5 13 0 9-5 13 0 9 5 13 0 9-5 13 0' opacity='.7'/%3E%3C/g%3E%3C/svg%3E");
  background-repeat:repeat-x;background-position:0 0,0 100%;background-size:120px 58px;
}
.bar-logo{
  font-family:'Noto Serif SC',serif;
  font-size:clamp(1rem,5.2vw,1.5rem);font-weight:700;color:#fff8e7;display:flex;align-items:center;gap:8px;
  letter-spacing:.02em;text-shadow:0 1px 0 rgba(0,0,0,.18), 0 0 10px rgba(245,207,120,.35);
  position:relative;z-index:1;white-space:nowrap;flex-shrink:0;
}
.bar-sp{flex:1;min-width:4px;position:relative;z-index:1}
.bar-sync{display:flex;align-items:center;gap:5px;font-size:.72rem;color:#ffe1ec;position:relative;z-index:1;white-space:nowrap;flex-shrink:0}
.bar-sync span{display:none}
.bar-user{display:flex;align-items:center;gap:6px;font-size:.76rem;color:#fff0f5;cursor:pointer;padding:4px 10px;border-radius:var(--rp);border:1px solid rgba(245,207,120,.55);background:rgba(255,255,255,.06);transition:background .13s;position:relative;z-index:1;white-space:nowrap;flex-shrink:0}
.bar-user:hover{background:rgba(255,255,255,.16)}
.pulse{width:8px;height:8px;border-radius:50%;background:#7ed6a0;flex-shrink:0;transition:background .3s;box-shadow:0 0 6px rgba(126,214,160,.7)}
.pulse.loading{background:#ffd76a;animation:blink 1s infinite}
.pulse.err{background:#ff7a8a}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}
@media (max-width:400px){
  .bar{padding:0 10px;gap:5px}
  .bar-logo{font-size:1rem;gap:5px}
  .bar-user{padding:4px 7px;font-size:.7rem;gap:3px}
}

.wrap{max-width:900px;margin:0 auto;padding:20px 14px 90px}

/* ─── Tabs điều hướng — như dải lụa/nút bo tròn trong game ─── */
.nav{display:flex;gap:5px;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin-bottom:22px;
  mask-image:linear-gradient(to right,#000 calc(100% - 26px),transparent);
  -webkit-mask-image:linear-gradient(to right,#000 calc(100% - 26px),transparent);}
.nav::-webkit-scrollbar{display:none}
.nav-main{flex-wrap:wrap;overflow-x:visible;mask-image:none;-webkit-mask-image:none;}
.nvb{padding:6px 12px;border-radius:var(--rp);font-size:.76rem;font-weight:700;border:1.5px solid var(--bd);background:var(--white);color:var(--mist);cursor:pointer;transition:all .14s;white-space:nowrap;font-family:inherit;box-shadow:0 1px 0 rgba(255,255,255,.6) inset;flex-shrink:0}
.nvb:hover{color:var(--forest2);border-color:var(--leaf)}
.nvb.on{background:linear-gradient(180deg,#ff8fb8,#e8799a);color:#fff;border-color:var(--gold2);box-shadow:0 3px 10px rgba(232,121,154,.4)}

.chip{padding:6px 13px;border-radius:var(--rp);font-size:.76rem;font-weight:700;border:1.5px solid var(--bd);background:var(--white);color:var(--mist);cursor:pointer;transition:all .14s;white-space:nowrap;font-family:inherit;display:inline-flex;align-items:center}
.chip:hover{border-color:var(--leaf)}
.chip.on{background:linear-gradient(180deg,#ff8fb8,#e8799a);color:#fff;border-color:var(--gold2)}

/* ─── Khung góc hoa văn vân mây cổ trang — dùng chung cho card/modal/login ─── */
.cn-frame{position:relative}
.cn-frame::before{
  content:'';position:absolute;inset:0;pointer-events:none;border-radius:inherit;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30' viewBox='0 0 30 30'%3E%3Cg fill='none' stroke='%23e0a93e' stroke-width='1.7' stroke-linecap='round'%3E%3Cpath d='M3 13 L3 5 Q3 3 5 3 L13 3'/%3E%3Cpath d='M3 17 Q10 17 10 24 Q10 27 14 27' opacity='.6'/%3E%3Ccircle cx='7' cy='7' r='1.4' fill='%23e0a93e' stroke='none'/%3E%3C/g%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30' viewBox='0 0 30 30'%3E%3Cg transform='translate(30,0) scale(-1,1)'%3E%3Cg fill='none' stroke='%23e0a93e' stroke-width='1.7' stroke-linecap='round'%3E%3Cpath d='M3 13 L3 5 Q3 3 5 3 L13 3'/%3E%3Cpath d='M3 17 Q10 17 10 24 Q10 27 14 27' opacity='.6'/%3E%3Ccircle cx='7' cy='7' r='1.4' fill='%23e0a93e' stroke='none'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30' viewBox='0 0 30 30'%3E%3Cg transform='translate(0,30) scale(1,-1)'%3E%3Cg fill='none' stroke='%23e0a93e' stroke-width='1.7' stroke-linecap='round'%3E%3Cpath d='M3 13 L3 5 Q3 3 5 3 L13 3'/%3E%3Cpath d='M3 17 Q10 17 10 24 Q10 27 14 27' opacity='.6'/%3E%3Ccircle cx='7' cy='7' r='1.4' fill='%23e0a93e' stroke='none'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30' viewBox='0 0 30 30'%3E%3Cg transform='translate(30,30) scale(-1,-1)'%3E%3Cg fill='none' stroke='%23e0a93e' stroke-width='1.7' stroke-linecap='round'%3E%3Cpath d='M3 13 L3 5 Q3 3 5 3 L13 3'/%3E%3Cpath d='M3 17 Q10 17 10 24 Q10 27 14 27' opacity='.6'/%3E%3Ccircle cx='7' cy='7' r='1.4' fill='%23e0a93e' stroke='none'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:top left, top right, bottom left, bottom right;
  background-size:30px 30px;
  opacity:.85;
}
.cn-frame.cn-sm::before{background-size:20px 20px}

/* ─── Card chính — như "khung rương/cuộn chỉ" viền vàng kim đặc trưng game ─── */
.card{
  background:var(--white);border-radius:var(--r);
  border:2px solid var(--bd);box-shadow:var(--sh);padding:18px;
  position:relative;
}
.card::after{
  content:'';position:absolute;inset:0;pointer-events:none;border-radius:inherit;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='26' height='26' viewBox='0 0 26 26'%3E%3Cg fill='none' stroke='%23e0a93e' stroke-width='1.5' stroke-linecap='round' opacity='.8'%3E%3Cpath d='M3 11 L3 5 Q3 3 5 3 L11 3'/%3E%3Cpath d='M3 14 Q8 14 8 19 Q8 22 12 22' opacity='.55'/%3E%3C/g%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='26' height='26' viewBox='0 0 26 26'%3E%3Cg transform='translate(26,0) scale(-1,1)'%3E%3Cg fill='none' stroke='%23e0a93e' stroke-width='1.5' stroke-linecap='round' opacity='.8'%3E%3Cpath d='M3 11 L3 5 Q3 3 5 3 L11 3'/%3E%3Cpath d='M3 14 Q8 14 8 19 Q8 22 12 22' opacity='.55'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='26' height='26' viewBox='0 0 26 26'%3E%3Cg transform='translate(0,26) scale(1,-1)'%3E%3Cg fill='none' stroke='%23e0a93e' stroke-width='1.5' stroke-linecap='round' opacity='.8'%3E%3Cpath d='M3 11 L3 5 Q3 3 5 3 L11 3'/%3E%3Cpath d='M3 14 Q8 14 8 19 Q8 22 12 22' opacity='.55'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='26' height='26' viewBox='0 0 26 26'%3E%3Cg transform='translate(26,26) scale(-1,-1)'%3E%3Cg fill='none' stroke='%23e0a93e' stroke-width='1.5' stroke-linecap='round' opacity='.8'%3E%3Cpath d='M3 11 L3 5 Q3 3 5 3 L11 3'/%3E%3Cpath d='M3 14 Q8 14 8 19 Q8 22 12 22' opacity='.55'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:top left, top right, bottom left, bottom right;
  background-size:26px 26px;
}
.card::before{
  content:'';position:absolute;inset:4px;border-radius:calc(var(--r) - 5px);
  border:1px dashed rgba(224,169,62,.35);pointer-events:none;
}
.card+.card{margin-top:14px}
.card-title{font-size:.92rem;font-weight:800;color:var(--forest2);margin-bottom:14px;display:flex;align-items:center;gap:7px}

/* ─── Lưới thẻ hoa — khung kiểu "thiệp hoa" mềm mại bo tròn ─── */
.fg{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:13px}
.fc{
  background:var(--white);border-radius:18px;border:2px solid var(--bd);
  overflow:hidden;transition:transform .14s,box-shadow .14s,border-color .14s;position:relative;
  box-shadow:0 2px 8px rgba(168,72,122,.07);
}
.fc:hover{transform:translateY(-3px);box-shadow:var(--shd);border-color:var(--gold2)}
.fc-img{width:100%;aspect-ratio:1;overflow:hidden;background:linear-gradient(135deg,var(--jade2),var(--blush));position:relative;display:flex;align-items:center;justify-content:center}
.fc-img::before{
  content:'';position:absolute;inset:4px;pointer-events:none;border-radius:10px;
  border:1px solid rgba(245,207,120,.55);z-index:1;
}
.fc-img::after{
  content:'';position:absolute;inset:3px;pointer-events:none;z-index:1;border-radius:9px;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 18 18'%3E%3Cpath d='M2 9 L2 4 Q2 2 4 2 L9 2' fill='none' stroke='%23e0a93e' stroke-width='1.8' stroke-linecap='round'/%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 18 18'%3E%3Cg transform='translate(18,0) scale(-1,1)'%3E%3Cpath d='M2 9 L2 4 Q2 2 4 2 L9 2' fill='none' stroke='%23e0a93e' stroke-width='1.8' stroke-linecap='round'/%3E%3C/g%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 18 18'%3E%3Cg transform='translate(0,18) scale(1,-1)'%3E%3Cpath d='M2 9 L2 4 Q2 2 4 2 L9 2' fill='none' stroke='%23e0a93e' stroke-width='1.8' stroke-linecap='round'/%3E%3C/g%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 18 18'%3E%3Cg transform='translate(18,18) scale(-1,-1)'%3E%3Cpath d='M2 9 L2 4 Q2 2 4 2 L9 2' fill='none' stroke='%23e0a93e' stroke-width='1.8' stroke-linecap='round'/%3E%3C/g%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:top left, top right, bottom left, bottom right;
  background-size:18px 18px;
  opacity:.9;
}
.fc-img img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.fc:hover .fc-img img{transform:scale(1.07)}
.fc-letter{font-size:2.4rem;font-weight:800;line-height:1;font-family:'Noto Serif SC',serif}
.fc-body{padding:10px 11px 12px}
.fc-name{font-size:.82rem;font-weight:700;line-height:1.35;margin-bottom:5px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;color:var(--ink)}
.fc-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:var(--rp);font-size:.66rem;font-weight:700}
.fc-dot{width:6px;height:6px;border-radius:50%}
.fc-owns{font-size:.69rem;color:var(--mist);margin-top:4px;line-height:1.5}

.tc{cursor:pointer;user-select:none}
.tc.ticked{border-color:var(--petal);box-shadow:0 0 0 3px var(--blush),0 0 0 4px var(--gold2)}
.chk{position:absolute;top:7px;right:7px;width:25px;height:25px;border-radius:50%;background:rgba(255,255,255,.8);border:2px solid rgba(255,255,255,.95);display:flex;align-items:center;justify-content:center;font-size:13px;backdrop-filter:blur(3px);transition:all .13s}
.tc.ticked .chk{background:var(--petal);border-color:var(--gold2);color:#fff}

/* clan badges on flower cards */
.fc-clans{display:flex;flex-wrap:wrap;gap:3px;margin-top:5px}
.clan-tag{font-size:.62rem;font-weight:700;padding:2px 7px;border-radius:var(--rp);background:var(--clan2);color:var(--clan);white-space:nowrap;display:inline-block}

/* ─── OVERLAY BACKDROP — dùng ::before + opacity thay vì animate background
   để tránh repaint toàn màn hình (compositor-only, không trigger repaint) ──── */
.zoom-bg::before,.mf-bg::before{
  content:'';position:absolute;inset:0;
  background:rgba(90,48,71,.55);
  opacity:0;transition:opacity .32s ease;
  pointer-events:none;z-index:0;
}
.zoom-bg.on::before,.mf-bg.on::before{opacity:1}
.zoom-bg>*,.mf-bg>*{position:relative;z-index:1}

/* ─── FLOWER ZOOM OVERLAY — như khung "rương báu" mở ra ───────────────── */
.fc.zoomable{cursor:zoom-in}
.zoom-bg{position:fixed;inset:0;z-index:500;display:flex;align-items:center;justify-content:center;padding:28px;pointer-events:none}
.zoom-bg.on{pointer-events:auto}
.zoom-card{
  background:var(--white);border-radius:22px;box-shadow:var(--shd);overflow:hidden;
  width:min(420px,100%);max-height:calc(100vh - 56px);display:flex;flex-direction:column;
  transform:scale(.4);opacity:0;
  cursor:zoom-out;position:relative;border:3px solid var(--gold2);will-change:transform,opacity;
}
.zoom-card::after{
  content:'';position:absolute;inset:0;pointer-events:none;border-radius:inherit;z-index:3;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='38' height='38' viewBox='0 0 38 38'%3E%3Cg fill='none' stroke='%23f5cf78' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M4 17 L4 7 Q4 4 7 4 L17 4'/%3E%3Cpath d='M4 22 Q13 22 13 31 Q13 35 18 35' opacity='.6'/%3E%3Ccircle cx='9' cy='9' r='1.8' fill='%23f5cf78' stroke='none'/%3E%3C/g%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='38' height='38' viewBox='0 0 38 38'%3E%3Cg transform='translate(38,0) scale(-1,1)'%3E%3Cg fill='none' stroke='%23f5cf78' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M4 17 L4 7 Q4 4 7 4 L17 4'/%3E%3Cpath d='M4 22 Q13 22 13 31 Q13 35 18 35' opacity='.6'/%3E%3Ccircle cx='9' cy='9' r='1.8' fill='%23f5cf78' stroke='none'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:top left, top right;
  background-size:38px 38px;
}
.zoom-img{width:100%;aspect-ratio:1;overflow:hidden;background:linear-gradient(135deg,var(--jade2),var(--blush));display:flex;align-items:center;justify-content:center;flex-shrink:0}
.zoom-img img{width:100%;height:100%;object-fit:cover}
.zoom-letter{font-size:6rem;font-weight:800;line-height:1;font-family:'Noto Serif SC',serif}
.zoom-body{padding:18px 20px 22px;overflow-y:auto}
.zoom-name{font-size:1.2rem;font-weight:800;margin-bottom:8px;line-height:1.35;font-family:'Noto Serif SC',serif}
.zoom-owners{margin-top:12px;display:flex;flex-direction:column;gap:6px}
.zoom-owners .fc-clans{margin-top:0}
.zoom-owners .clan-tag{font-size:.74rem;padding:4px 10px}
.zoom-close{position:absolute;top:10px;right:10px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.88);border:2px solid var(--gold2);display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;color:var(--ink);backdrop-filter:blur(3px);z-index:2;transition:background .12s}
.zoom-close:hover{background:#fff}

/* ─── MEMBER FLOWERS POPUP ───────────────────────────────────────────────── */
.mf-bg{position:fixed;inset:0;z-index:500;display:flex;align-items:center;justify-content:center;padding:18px;pointer-events:none}
.mf-bg.on{pointer-events:auto}
.mf-card{background:var(--white);border-radius:22px;overflow:hidden;box-shadow:var(--shd);width:min(560px,100%);max-height:calc(100vh - 56px);display:flex;flex-direction:column;transform:translateY(24px) scale(.96);opacity:0;transition:transform .32s cubic-bezier(.22,1,.36,1),opacity .24s ease;border:3px solid var(--gold2);position:relative;will-change:transform,opacity}
.mf-card::after{
  content:'';position:absolute;inset:0;pointer-events:none;border-radius:inherit;z-index:3;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32'%3E%3Cg fill='none' stroke='%23f5cf78' stroke-width='1.8' stroke-linecap='round'%3E%3Cpath d='M3 14 L3 6 Q3 3 6 3 L14 3'/%3E%3Cpath d='M3 18 Q10 18 10 25 Q10 29 15 29' opacity='.55'/%3E%3C/g%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32'%3E%3Cg transform='translate(32,0) scale(-1,1)'%3E%3Cg fill='none' stroke='%23f5cf78' stroke-width='1.8' stroke-linecap='round'%3E%3Cpath d='M3 14 L3 6 Q3 3 6 3 L14 3'/%3E%3Cpath d='M3 18 Q10 18 10 25 Q10 29 15 29' opacity='.55'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:top left, top right;
  background-size:32px 32px;
}
.mf-head{padding:18px 20px 12px;border-bottom:1.5px solid var(--bd);flex-shrink:0;position:relative;background:linear-gradient(180deg,var(--sage),transparent)}
.mf-title{font-size:1.1rem;font-weight:800;color:var(--forest);font-family:'Noto Serif SC',serif}
.mf-sub{font-size:.78rem;color:var(--mist);margin-top:3px}
.mf-close{position:absolute;top:12px;right:14px;width:32px;height:32px;border-radius:50%;background:var(--sage);border:1.5px solid var(--bd);display:flex;align-items:center;justify-content:center;font-size:15px;cursor:pointer;color:var(--forest2);transition:background .12s}
.mf-close:hover{background:var(--mint)}
.mf-body{padding:14px 20px 20px;overflow-y:auto}
.mf-grp{margin:14px 0 8px;display:flex;align-items:center;gap:8px}
.mf-grp:first-child{margin-top:0}
.mf-grp-bar{width:3px;height:16px;border-radius:2px;flex-shrink:0}
.mf-grp h3{font-size:.85rem;font-weight:800;color:var(--ink)}
.mf-grp-cnt{font-size:.66rem;color:var(--mist);background:var(--sage);border:1px solid var(--bd);padding:1px 7px;border-radius:var(--rp);font-weight:600}
.mf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:9px}
.mf-fc{border-radius:13px;overflow:hidden;border:1.5px solid var(--bd)}
.mf-fc-img{width:100%;aspect-ratio:1;background:linear-gradient(135deg,var(--jade2),var(--blush));display:flex;align-items:center;justify-content:center;overflow:hidden;contain:strict}
.mf-fc-img img{width:100%;height:100%;object-fit:cover}
.mf-fc-letter{font-size:1.6rem;font-weight:800;font-family:'Noto Serif SC',serif}
.mf-fc-name{font-size:.7rem;font-weight:700;padding:6px 7px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;color:var(--ink)}
.mb-name-link{cursor:pointer;transition:color .12s}
.mb-name-link:hover{color:var(--leaf);text-decoration:underline}

/* ─── Tiêu đề nhóm — dải băng nhỏ với thanh màu hồng đào ─── */
.grp{margin:26px 0 13px;display:flex;align-items:center;gap:9px}
.grp-bar{width:4px;height:20px;border-radius:3px;background:linear-gradient(180deg,var(--petal),var(--gold2));flex-shrink:0;position:relative}
.grp-bar::before{content:'';position:absolute;left:50%;top:-7px;width:7px;height:7px;transform:translateX(-50%) rotate(45deg);background:var(--gold2);border-radius:1px}
.grp h2{font-size:1rem;font-weight:800;color:var(--ink);font-family:'Noto Serif SC',serif;letter-spacing:.01em}
.grp-cnt{font-size:.7rem;color:var(--mist);background:var(--sage);border:1px solid var(--bd);padding:2px 8px;border-radius:var(--rp);font-weight:600}

/* ─── TICK SECTION — khung cuộn giấy với "đầu cuộn" vàng kim ─────────────── */
.tsec{border-radius:var(--r);border:2px solid var(--bd);background:var(--white);margin-bottom:14px;overflow:hidden;box-shadow:var(--sh);position:relative}
.tsec::before{content:'';position:absolute;left:0;top:0;bottom:0;width:5px;background:linear-gradient(180deg,var(--gold2),var(--petal))}
.tsec-head{display:flex;align-items:center;gap:10px;padding:14px 16px 14px 19px;cursor:pointer;user-select:none;transition:background .12s,filter .12s;background:linear-gradient(180deg,var(--sage),#fff)}
.tsec-head:hover{filter:brightness(.98)}
.tsec-head:active{filter:brightness(.95)}
.tsec-head-hl{position:relative}
.tsec-ico{font-size:1.2rem;flex-shrink:0;transition:transform .2s;color:var(--forest2)}
.tsec.closed .tsec-ico{transform:rotate(-90deg)}
.tsec-title{font-size:.95rem;font-weight:800;flex:1;color:var(--ink)}
.tsec-cnt{font-size:.74rem;font-weight:700;padding:3px 10px;border-radius:var(--rp);flex-shrink:0}
.tsec-cnt.marked{background:linear-gradient(180deg,#ff8fb8,var(--petal));color:#fff}
.tsec-cnt.unmarked{background:linear-gradient(180deg,#5cc2ad,var(--jade));color:#fff}
.tsec-hint{font-size:.66rem;font-weight:700;color:var(--mist);background:var(--white);border:1px solid var(--bd);padding:3px 8px;border-radius:var(--rp);flex-shrink:0;white-space:nowrap}
.tsec-body{padding:4px 15px 16px 19px}
.tsec.closed .tsec-body{display:none}
@media (max-width:480px){.tsec-hint{display:none}}

.fg-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:12px}
.fg-col{display:flex;flex-direction:column;gap:5px}
.fl{font-size:.76rem;font-weight:700;color:var(--forest2)}
.fi{padding:9px 12px;border-radius:11px;border:1.5px solid var(--bd);background:var(--white);font-family:inherit;font-size:.87rem;color:var(--ink);outline:none;transition:border-color .14s;width:100%}
.fi:focus{border-color:var(--leaf);box-shadow:0 0 0 3px var(--blush)}
.fi::placeholder{color:var(--haze)}
select.fi{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23b87a98' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}

.sbar{position:relative;margin-bottom:16px}
.sbar input{padding-left:38px}
.sico{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--haze);pointer-events:none;font-size:14px}

.cfbar{display:flex;gap:2px;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin-bottom:18px;
  mask-image:linear-gradient(to right,#000 calc(100% - 26px),transparent);
  -webkit-mask-image:linear-gradient(to right,#000 calc(100% - 26px),transparent);}
.cfbar::-webkit-scrollbar{display:none}
.ctab{padding:4px 12px;border-radius:var(--rp);font-size:.74rem;font-weight:700;border:1.5px solid var(--bd);background:var(--white);color:var(--mist);cursor:pointer;transition:all .12s;white-space:nowrap;flex-shrink:0}
.ctab:hover{border-color:var(--mist)}
.ctab.on{border-width:2px;color:var(--ink);box-shadow:0 2px 6px rgba(168,72,122,.18)}

/* ─── Nút bấm — bo tròn dạng "viên kẹo" như UI game ─── */
.btn{display:inline-flex;align-items:center;gap:5px;padding:9px 18px;border-radius:var(--rp);font-family:inherit;font-size:.84rem;font-weight:700;cursor:pointer;border:none;transition:all .13s;box-shadow:0 2px 0 rgba(0,0,0,.08) inset}
.btn-g{background:linear-gradient(180deg,#5cc2ad,var(--jade));color:#fff}.btn-g:hover{filter:brightness(1.07)}
.btn-p{background:linear-gradient(180deg,#ff8fb8,var(--petal));color:#fff}.btn-p:hover{filter:brightness(1.07)}
.btn-v{background:linear-gradient(180deg,#9b82ff,var(--clan));color:#fff}.btn-v:hover{filter:brightness(1.07)}
.btn-o{background:var(--white);color:var(--forest2);border:1.5px solid var(--bd)}.btn-o:hover{border-color:var(--leaf);background:var(--sage)}
.btn-r{background:transparent;color:#d6517a;border:1.5px solid #ffc6da}.btn-r:hover{background:#fff0f5}
.btn:disabled{opacity:.45;cursor:not-allowed}
.btn-sm{padding:6px 12px;font-size:.77rem}
.btn-xs{padding:4px 10px;font-size:.73rem}
.irow{display:flex;gap:8px;align-items:flex-end}
.irow .fi{flex:1}

.mtbl{width:100%;border-collapse:collapse}
.mtbl th{text-align:left;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--mist);padding:9px 12px;border-bottom:2px solid var(--bd)}
.mtbl td{padding:12px 12px;border-bottom:1px solid var(--sage);font-size:.86rem;vertical-align:middle}
.mtbl tr:last-child td{border-bottom:none}
.mtbl tr:hover td{background:var(--sage)}
.mbar-w{display:flex;align-items:center;gap:8px;min-width:90px}
.mbar{flex:1;height:6px;border-radius:3px;background:var(--sage);overflow:hidden;border:1px solid var(--bd)}
.mbar-f{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--petal2),var(--petal));transition:width .4s}
.mlbl{font-size:.74rem;font-weight:700;color:var(--petal);white-space:nowrap}
.ibtn{background:none;border:none;cursor:pointer;padding:4px 7px;border-radius:7px;font-size:.88rem;transition:background .12s;color:var(--mist)}
.ibtn:hover{background:var(--sage)}
.ibtn.del:hover{background:#fff0f5;color:#d6517a}

.stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px;margin-bottom:20px}
.sc{background:var(--white);border-radius:var(--r);border:2px solid var(--bd);padding:13px 14px;position:relative;overflow:hidden}
.sc::after{content:'';position:absolute;top:-14px;right:-14px;width:40px;height:40px;border-radius:50%;background:radial-gradient(circle,var(--gold2) 0%,transparent 70%);opacity:.5}
.sv{font-size:1.6rem;font-weight:800;line-height:1;color:var(--forest2)}
.sl{font-size:.67rem;font-weight:700;color:var(--mist);margin-top:3px;text-transform:uppercase;letter-spacing:.05em}

.savebar{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(180deg,#a8487a,#7a3b5e);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:12px 18px;z-index:150;box-shadow:0 -3px 0 var(--gold), 0 -6px 20px rgba(0,0,0,.2);transform:translateY(100%);transition:transform .22s;overflow:hidden}
.savebar::after{
  content:'';position:absolute;inset:0;pointer-events:none;opacity:.14;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='50' viewBox='0 0 120 50'%3E%3Cg fill='none' stroke='%23f5cf78' stroke-width='1.1'%3E%3Cpath d='M-6 10c4-5 10-5 13 0s9 5 13 0 9-5 13 0 9 5 13 0 9-5 13 0 9 5 13 0 9-5 13 0'/%3E%3C/g%3E%3C/svg%3E");
  background-repeat:repeat-x;background-position:0 100%;background-size:120px 50px;
}
.savebar span, .savebar button{position:relative;z-index:1}
.savebar.on{transform:none}

.toasts{position:fixed;top:64px;right:12px;z-index:999;display:flex;flex-direction:column;gap:7px;pointer-events:none}
.toast{background:linear-gradient(180deg,#a8487a,#7a3b5e);color:#fff;padding:10px 15px;border-radius:11px;font-size:.81rem;font-weight:600;box-shadow:0 4px 18px rgba(0,0,0,.2);animation:tin .22s ease,tout .28s ease 2.2s forwards;pointer-events:auto;max-width:280px;border:1px solid rgba(245,207,120,.4)}
.toast.ok{border-left:3px solid #7ed6a0}
.toast.er{border-left:3px solid #ff7a8a}
.toast.wn{border-left:3px solid #ffd76a}
@keyframes tin{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:none}}
@keyframes tout{from{opacity:1}to{opacity:0;transform:translateX(16px)}}

/* ─── Modal — khung "hộp thoại thoại nhân vật" viền vàng kim bo tròn lớn ─── */
.mbg{position:fixed;inset:0;background:rgba(90,48,71,.45);z-index:400;display:flex;align-items:center;justify-content:center;padding:18px;opacity:0;pointer-events:none;transition:opacity .17s}
.mbg.on{opacity:1;pointer-events:auto}
.mbox{background:var(--white);border-radius:20px;padding:24px;max-width:430px;width:100%;box-shadow:var(--shd);transform:scale(.94);transition:transform .17s;max-height:88vh;overflow-y:auto;border:3px solid var(--gold2);position:relative}
.mbox::after{
  content:'';position:absolute;inset:0;pointer-events:none;border-radius:inherit;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='28' viewBox='0 0 28 28'%3E%3Cg fill='none' stroke='%23e0a93e' stroke-width='1.6' stroke-linecap='round' opacity='.85'%3E%3Cpath d='M3 12 L3 5 Q3 3 5 3 L12 3'/%3E%3Cpath d='M3 15 Q9 15 9 21 Q9 24 13 24' opacity='.55'/%3E%3C/g%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='28' viewBox='0 0 28 28'%3E%3Cg transform='translate(28,0) scale(-1,1)'%3E%3Cg fill='none' stroke='%23e0a93e' stroke-width='1.6' stroke-linecap='round' opacity='.85'%3E%3Cpath d='M3 12 L3 5 Q3 3 5 3 L12 3'/%3E%3Cpath d='M3 15 Q9 15 9 21 Q9 24 13 24' opacity='.55'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='28' viewBox='0 0 28 28'%3E%3Cg transform='translate(0,28) scale(1,-1)'%3E%3Cg fill='none' stroke='%23e0a93e' stroke-width='1.6' stroke-linecap='round' opacity='.85'%3E%3Cpath d='M3 12 L3 5 Q3 3 5 3 L12 3'/%3E%3Cpath d='M3 15 Q9 15 9 21 Q9 24 13 24' opacity='.55'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='28' viewBox='0 0 28 28'%3E%3Cg transform='translate(28,28) scale(-1,-1)'%3E%3Cg fill='none' stroke='%23e0a93e' stroke-width='1.6' stroke-linecap='round' opacity='.85'%3E%3Cpath d='M3 12 L3 5 Q3 3 5 3 L12 3'/%3E%3Cpath d='M3 15 Q9 15 9 21 Q9 24 13 24' opacity='.55'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:top left, top right, bottom left, bottom right;
  background-size:28px 28px;
}
.mbg.on .mbox{transform:none}
.mttl{font-size:1.05rem;font-weight:800;margin-bottom:10px;color:var(--forest2);font-family:'Noto Serif SC',serif}
.mbdy{font-size:.86rem;color:var(--ink);margin-bottom:18px;line-height:1.7}
.mft{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}

.sp{display:inline-block;width:15px;height:15px;border:2px solid var(--haze);border-top-color:var(--leaf);border-radius:50%;animation:spin .65s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading{display:flex;align-items:center;justify-content:center;padding:60px;gap:10px;color:var(--mist);font-size:.87rem}

.empty{text-align:center;padding:48px 16px;color:var(--haze)}
.empty-icon{font-size:2.6rem;margin-bottom:10px}

/* login screen — như "rương khởi đầu" trong game */
.login-wrap{max-width:400px;margin:48px auto;padding:0 14px}
.login-box{background:var(--white);border-radius:20px;border:3px solid var(--gold2);box-shadow:var(--shd);padding:32px;position:relative}
.login-box::before{content:'';position:absolute;inset:7px;border-radius:14px;border:1.5px dashed rgba(224,169,62,.4);pointer-events:none}
.login-box::after{
  content:'';position:absolute;inset:0;pointer-events:none;border-radius:inherit;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='34' height='34' viewBox='0 0 34 34'%3E%3Cg fill='none' stroke='%23e0a93e' stroke-width='1.8' stroke-linecap='round'%3E%3Cpath d='M4 15 L4 6 Q4 4 6 4 L15 4'/%3E%3Cpath d='M4 19 Q11 19 11 26 Q11 30 16 30' opacity='.6'/%3E%3Ccircle cx='8' cy='8' r='1.6' fill='%23e0a93e' stroke='none'/%3E%3C/g%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='34' height='34' viewBox='0 0 34 34'%3E%3Cg transform='translate(34,0) scale(-1,1)'%3E%3Cg fill='none' stroke='%23e0a93e' stroke-width='1.8' stroke-linecap='round'%3E%3Cpath d='M4 15 L4 6 Q4 4 6 4 L15 4'/%3E%3Cpath d='M4 19 Q11 19 11 26 Q11 30 16 30' opacity='.6'/%3E%3Ccircle cx='8' cy='8' r='1.6' fill='%23e0a93e' stroke='none'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='34' height='34' viewBox='0 0 34 34'%3E%3Cg transform='translate(0,34) scale(1,-1)'%3E%3Cg fill='none' stroke='%23e0a93e' stroke-width='1.8' stroke-linecap='round'%3E%3Cpath d='M4 15 L4 6 Q4 4 6 4 L15 4'/%3E%3Cpath d='M4 19 Q11 19 11 26 Q11 30 16 30' opacity='.6'/%3E%3Ccircle cx='8' cy='8' r='1.6' fill='%23e0a93e' stroke='none'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='34' height='34' viewBox='0 0 34 34'%3E%3Cg transform='translate(34,34) scale(-1,-1)'%3E%3Cg fill='none' stroke='%23e0a93e' stroke-width='1.8' stroke-linecap='round'%3E%3Cpath d='M4 15 L4 6 Q4 4 6 4 L15 4'/%3E%3Cpath d='M4 19 Q11 19 11 26 Q11 30 16 30' opacity='.6'/%3E%3Ccircle cx='8' cy='8' r='1.6' fill='%23e0a93e' stroke='none'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:top left, top right, bottom left, bottom right;
  background-size:34px 34px;
}
.login-logo{font-size:2.2rem;margin-bottom:4px;text-align:center}
.login-title{font-size:1.3rem;font-weight:800;text-align:center;color:var(--forest);margin-bottom:4px;font-family:'Noto Serif SC',serif}
.login-sub{font-size:.8rem;color:var(--mist);text-align:center;margin-bottom:24px}
.login-tabs{display:flex;gap:0;margin-bottom:20px;border:1.5px solid var(--bd);border-radius:var(--rp);overflow:hidden}
.login-tab{flex:1;padding:8px;font-family:inherit;font-size:.8rem;font-weight:700;border:none;cursor:pointer;background:transparent;color:var(--mist);transition:all .13s}
.login-tab.on{background:linear-gradient(180deg,#a8487a,#7a3b5e);color:#fff}
.role-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--rp);font-size:.72rem;font-weight:700}
.role-admin{background:#fff3e0;color:#b8740e}
.role-leader{background:var(--clan2);color:var(--clan)}
.role-member{background:var(--sage);color:var(--forest2)}

/* setup */
.setup{max-width:540px;margin:36px auto;background:var(--white);border-radius:var(--r);border:2px solid var(--bd);padding:30px;box-shadow:var(--sh)}
.setup h2{font-size:1.25rem;font-weight:800;margin-bottom:9px;color:var(--forest);font-family:'Noto Serif SC',serif}
.setup p{font-size:.84rem;color:var(--mist);line-height:1.75;margin-bottom:14px}
.setup-steps{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.setup-step{display:flex;align-items:flex-start;gap:12px;background:var(--sage);border-radius:13px;padding:12px 14px;border:1px solid var(--bd)}
.setup-num{width:24px;height:24px;border-radius:50%;background:linear-gradient(180deg,#a8487a,#7a3b5e);color:#fff;font-size:.75rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.setup-text{font-size:.83rem;color:var(--forest2);line-height:1.6}
code{background:var(--sage);padding:1px 6px;border-radius:5px;font-size:.82em;color:var(--forest2);font-family:monospace}
.fb-textarea{font-family:monospace;font-size:.78rem;min-height:130px;resize:vertical;white-space:pre}

.errbox{max-width:470px;margin:36px auto;background:var(--white);border-radius:var(--r);border:2px solid #ffc6da;padding:24px;box-shadow:var(--sh);position:relative}
.errbox h3{font-size:1rem;font-weight:800;color:#c2336a;margin-bottom:8px}
.errbox p{font-size:.85rem;color:var(--ink);margin-bottom:16px;line-height:1.65}

.cpick{display:flex;gap:5px;flex-wrap:wrap}
.csw{width:28px;height:28px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform .12s,border-color .12s;flex-shrink:0}
.csw:hover{transform:scale(1.18)}
.csw.on{border-color:var(--gold-deep)!important;transform:scale(1.15);box-shadow:0 0 0 2px var(--gold2)}

/* section divider — như dải hoa văn phân đoạn trong game */
.sec-div{display:flex;align-items:center;gap:10px;margin:22px 0 14px}
.sec-div-line{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--bd),transparent)}
.sec-div-label{font-size:.72rem;font-weight:700;color:var(--mist);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}

/* ─── FLOWER LABEL BADGE (góc phải ảnh) — viền vàng kim như huy hiệu ─────── */
.fc-label{
  position:absolute;bottom:7px;right:7px;
  width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.72rem;font-weight:800;color:#fff;
  border:2px solid var(--gold2);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  line-height:1;
  box-shadow:0 2px 8px rgba(0,0,0,.22);
  pointer-events:none;
}
.zoom-label{
  position:absolute;bottom:12px;right:12px;
  width:42px;height:42px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.88rem;font-weight:800;color:#fff;
  border:2.5px solid var(--gold2);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  box-shadow:0 3px 12px rgba(0,0,0,.25);
  pointer-events:none;
}
.mf-label{
  position:absolute;bottom:5px;right:5px;
  width:26px;height:26px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.62rem;font-weight:800;color:#fff;
  border:1.5px solid var(--gold2);
  backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);
  pointer-events:none;
}

@media(max-width:480px){
  .fg{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}
  .fg-row{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(3,1fr)}
}
#scroll-top-btn{
  position:fixed;bottom:80px;right:14px;z-index:180;
  display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:10px 11px 8px;
  background:linear-gradient(180deg,rgba(168,72,122,.85),rgba(122,59,94,.85));
  color:#fff0f5;
  border:1.5px solid rgba(245,207,120,.55);
  border-radius:14px;
  cursor:pointer;
  font-family:'Be Vietnam Pro',sans-serif;
  font-size:.6rem;font-weight:700;letter-spacing:.03em;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  box-shadow:0 4px 18px rgba(168,72,122,.3);
  opacity:0;transform:translateY(10px);
  transition:opacity .25s ease,transform .25s ease;
  pointer-events:none;
  line-height:1;
}
#scroll-top-btn.visible{opacity:1;transform:none;pointer-events:auto;}
#scroll-top-btn:hover{background:linear-gradient(180deg,rgba(168,72,122,1),rgba(122,59,94,1));border-color:rgba(245,207,120,.8);}
#scroll-top-btn:active{transform:scale(.94);}
