/* ============================================================
   ACHIEVEMENTS — "Trofeeën & Rang" (mockup / productie-kandidaat)
   Bouwt voort op raids-ui.css (--rui-* tokens). Prefix .ach-.
   Theme-aware via [data-bs-theme]; mobiel-first.
   ============================================================ */

/* ---------- TIER + ZELDZAAMHEID TOKENS ---------- */
.ach{
  /* rarity */
  --ach-bronze:#c1813f; --ach-bronze-2:#e0a35d;
  --ach-silver:#9aa7b4; --ach-silver-2:#c2cdd8;
  --ach-gold:#d6a418;   --ach-gold-2:#f3cb52;
  --ach-legend:#8b5cf6; --ach-legend-2:#c4a7ff;
}
/* tier-kleur op een container; zet --tier + --tier-2 */
.ach-t-rookie  {--tier:#7c8aa0; --tier-2:#9aa7ba}
.ach-t-ace     {--tier:#c1813f; --tier-2:#e0a35d}
.ach-t-veteran {--tier:#7f97a8; --tier-2:#aebfcc}
.ach-t-expert  {--tier:#d6a418; --tier-2:#f3cb52}
.ach-t-elite   {--tier:#8b5cf6; --tier-2:#b79bff}
.ach-t-legend  {--tier:#16c8db; --tier-2:#56e6f4}

/* ---------- TROFEEËNKAST: --rui-eiland op het publieke profiel ---------- */
.ach-trophy{margin-top:16px}
.ach-trophy .sec-head{display:flex;align-items:center;gap:10px;margin:0 2px 12px}
.ach-trophy .sec-head h2{margin:0;font-family:var(--rui-font);font-weight:700;font-size:var(--rui-fs-xl)}
.ach-trophy .sec-head .ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:var(--rui-accent-soft);color:var(--rui-accent-strong)}
.ach-trophy .sec-head .ic svg{width:18px;height:18px}
.ach-trophy .sec-head .grow{flex:1}
/* "Bekijk alle trofeeën"-link onder de trofeeënkast (achRenderTrophyBlock) */
.ach .allink{display:inline-flex;align-items:center;gap:6px;margin-top:14px;font-family:var(--rui-font);font-weight:600;font-size:var(--rui-fs-md);color:var(--rui-accent-strong);text-decoration:none}
.ach .allink:hover{text-decoration:underline}
.ach .allink svg{width:16px;height:16px;flex:0 0 auto}

/* ---------- RANG-HERO (profiel + hub) ---------- */
.ach-rankhero{
  position:relative;overflow:hidden;border-radius:var(--rui-r-4);border:1px solid var(--rui-line);
  background:
    radial-gradient(120% 150% at 0% 0%, color-mix(in srgb,var(--tier) 22%, transparent) 0%, transparent 52%),
    var(--rui-card);
  box-shadow:var(--rui-sh-1);padding:18px;display:flex;gap:18px;align-items:center}
.ach-rankhero .emb{flex:0 0 auto}
.ach-rankhero .body{min-width:0;flex:1}
/* flair bij hogere rangen: tier-getinte rand vanaf Expert, extra gloed voor Legende */
.ach-rankhero.ach-t-expert,.ach-rankhero.ach-t-elite,.ach-rankhero.ach-t-legend{border-color:color-mix(in srgb,var(--tier) 38%,var(--rui-line))}
.ach-rankhero.ach-t-legend{box-shadow:0 0 0 1px color-mix(in srgb,var(--tier) 34%,transparent),0 6px 22px color-mix(in srgb,var(--tier) 22%,transparent)}
.ach-rankhero .eyebrow{font-size:var(--rui-fs-xs);text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--rui-faint)}
.ach-rankhero .rank{font-family:var(--rui-font);font-weight:700;font-size:var(--rui-fs-2xl);line-height:1.1;
  background:linear-gradient(95deg,var(--tier),var(--tier-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.ach-rankhero .meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:6px}
.ach-rankhero .pts{font-family:var(--rui-font);font-weight:700;color:var(--rui-text)}
.ach-rankhero .pts b{color:var(--tier)}

/* hexagon-emblem */
.ach-emblem{position:relative;width:84px;height:92px;display:grid;place-items:center}
.ach-emblem .hex{position:absolute;inset:0;clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);
  background:linear-gradient(155deg,var(--tier),var(--tier-2));box-shadow:0 6px 18px color-mix(in srgb,var(--tier) 40%,transparent)}
.ach-emblem .hex::after{content:"";position:absolute;inset:3px;clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);
  background:var(--rui-card);opacity:.10}
.ach-emblem .ico{position:relative;z-index:1;color:#fff;display:grid;place-items:center}
.ach-emblem .ico svg{width:34px;height:34px;filter:drop-shadow(0 1px 1px rgba(0,0,0,.25))}
.ach-emblem.sm{width:46px;height:50px}
.ach-emblem.sm .ico svg{width:20px;height:20px}
.ach-emblem.lg{width:104px;height:114px}
.ach-emblem.lg .ico svg{width:44px;height:44px}
/* legende glans */
.ach-t-legend .ach-emblem .hex{animation:achShine 4.5s linear infinite;background:linear-gradient(110deg,#0a8ea0,#16c8db 40%,#9beaf2 50%,#16c8db 60%,#0a8ea0)}
@keyframes achShine{0%{background-position:0% 50%}100%{background-position:200% 50%}}
.ach-t-legend .ach-emblem .hex{background-size:200% 100%}
@media (prefers-reduced-motion:reduce){.ach-t-legend .ach-emblem .hex{animation:none}}

/* voortgangsbalk naar volgende rang */
.ach-prog{margin-top:12px}
.ach-prog .bar{height:9px;border-radius:99px;background:var(--rui-card-2);border:1px solid var(--rui-line);overflow:hidden;position:relative}
.ach-prog .bar i{position:absolute;inset:0 auto 0 0;border-radius:99px;background:linear-gradient(90deg,var(--tier),var(--tier-2));display:block}
.ach-prog .lbl{display:flex;justify-content:space-between;gap:8px;margin-top:6px;font-size:var(--rui-fs-md);color:var(--rui-muted);font-weight:600}
.ach-prog .lbl b{color:var(--rui-text)}

/* featured badge naast de rang */
.ach-featured{display:inline-flex;align-items:center;gap:8px;height:30px;padding:0 10px 0 4px;border-radius:var(--rui-r-pill);
  background:var(--rui-card-2);border:1px solid var(--rui-line);font-family:var(--rui-font);font-weight:600;font-size:var(--rui-fs-md);color:var(--rui-text)}
.ach-featured .mini{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;color:#fff;background:var(--rk,var(--ach-gold))}
.ach-featured .mini svg{width:13px;height:13px}

/* ---------- BADGE-RASTER ---------- */
.ach-catlabel{display:flex;align-items:center;gap:10px;margin:20px 2px 10px}
.ach-catlabel .emo{font-size:16px}
.ach-catlabel h3{margin:0;font-family:var(--rui-font);font-weight:700;font-size:var(--rui-fs-lg)}
.ach-catlabel .count{font-family:var(--rui-font);font-size:var(--rui-fs-md);font-weight:600;color:var(--rui-faint);background:var(--rui-card-2);border:1px solid var(--rui-line);border-radius:99px;padding:1px 9px}
.ach-catlabel .grow{flex:1}

.ach-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}

.ach-badge{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;
  padding:16px 12px 13px;border-radius:var(--rui-r-3);background:var(--rui-card);border:1px solid var(--rui-line);
  box-shadow:var(--rui-sh-1);transition:border-color var(--rui-dur) var(--rui-ease),transform var(--rui-dur) var(--rui-ease)}
.ach-badge:hover{border-color:var(--rui-accent-line);transform:translateY(-1px)}
/* disc met zeldzaamheids-ring */
.ach-disc{position:relative;width:60px;height:60px;border-radius:50%;display:grid;place-items:center;
  background:radial-gradient(circle at 30% 25%,color-mix(in srgb,var(--rar,var(--ach-gold)) 26%,var(--rui-card)),var(--rui-card-2));
  border:2px solid var(--rar,var(--ach-gold));color:var(--rar,var(--ach-gold))}
.ach-disc svg{width:28px;height:28px}
.ach-disc::after{content:"";position:absolute;inset:-5px;border-radius:50%;border:1px solid color-mix(in srgb,var(--rar,var(--ach-gold)) 30%,transparent)}
.ach-badge .nm{font-family:var(--rui-font);font-weight:700;font-size:var(--rui-fs-md);line-height:1.2}
.ach-badge .desc{font-size:var(--rui-fs-sm);color:var(--rui-muted);line-height:1.3}
/* zeldzaamheids-classe */
.ach-r-bronze{--rar:var(--ach-bronze)} .ach-r-silver{--rar:var(--ach-silver)}
.ach-r-gold{--rar:var(--ach-gold)} .ach-r-legend{--rar:var(--ach-legend)}
/* rarity-pill (rechtsboven) */
.ach-badge .rar{position:absolute;top:8px;right:8px;font-family:var(--rui-font);font-size:10px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;white-space:nowrap;
  color:var(--rar,var(--ach-gold));background:color-mix(in srgb,var(--rar,var(--ach-gold)) 14%,transparent);border-radius:99px;padding:2px 7px}
/* Pro-dag-marker */
.ach-badge .pro{position:absolute;top:8px;left:8px;display:inline-flex;align-items:center;gap:3px;font-family:var(--rui-font);font-size:10px;font-weight:700;white-space:nowrap;
  color:var(--rui-accent-strong);background:var(--rui-accent-soft);border-radius:99px;padding:2px 7px}
.ach-badge .pro svg{width:11px;height:11px}
/* verdiend-vinkje — als status-badge op de disc (rechtsonder), nooit over de tekst */
.ach-badge .earned{position:absolute;top:54px;left:calc(50% + 13px);width:20px;height:20px;border-radius:50%;display:grid;place-items:center;background:var(--rui-ok);color:#fff;border:2px solid var(--rui-card);box-shadow:var(--rui-sh-1)}
.ach-badge .earned svg{width:11px;height:11px}

/* locked-staat */
.ach-badge.locked{background:var(--rui-card-2)}
.ach-badge.locked .ach-disc{filter:grayscale(.9);opacity:.5;border-color:var(--rui-line-2);color:var(--rui-faint);background:var(--rui-card-2)}
.ach-badge.locked .ach-disc::after{border-color:var(--rui-line)}
.ach-badge.locked .nm{color:var(--rui-muted)}
.ach-badge.locked .rar{opacity:.6}
.ach-badge .lock{position:absolute;top:54px;left:calc(50% + 13px);width:20px;height:20px;border-radius:50%;display:grid;place-items:center;background:var(--rui-line-2);color:var(--rui-faint);border:2px solid var(--rui-card-2)}
.ach-badge .lock svg{width:11px;height:11px}

/* mini voortgangsbalk in een (bijna gehaalde) badge */
.ach-badge .mprog{width:100%;margin-top:2px}
.ach-badge .mprog .bar{height:6px;border-radius:99px;background:var(--rui-card);border:1px solid var(--rui-line);overflow:hidden;position:relative}
.ach-badge.locked .mprog .bar{background:var(--rui-card)}
.ach-badge .mprog .bar i{position:absolute;inset:0 auto 0 0;border-radius:99px;background:var(--rar,var(--rui-accent))}
.ach-badge .mprog .t{font-size:var(--rui-fs-sm);color:var(--rui-faint);font-weight:600;margin-top:4px;font-variant-numeric:tabular-nums}

/* ---------- HUB-specifiek ---------- */
.ach-hubstats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:12px}
.ach-stat{background:var(--rui-card-2);border:1px solid var(--rui-line);border-radius:var(--rui-r-3);padding:12px 10px;text-align:center}
.ach-stat .n{font-family:var(--rui-font);font-weight:700;font-size:var(--rui-fs-xl);line-height:1;color:var(--rui-text)}
.ach-stat .n b{color:var(--rui-accent-strong)}
.ach-stat .l{font-size:var(--rui-fs-md);color:var(--rui-muted);font-weight:600;margin-top:4px}
.ach-tabs{display:inline-flex;background:var(--rui-card-2);border:1px solid var(--rui-line);border-radius:var(--rui-r-2);padding:3px;gap:2px;margin:18px 0 4px}
.ach-tabs button{appearance:none;border:0;background:transparent;color:var(--rui-muted);font-family:var(--rui-font);font-weight:600;font-size:var(--rui-fs-sm);padding:7px 13px;border-radius:7px;cursor:pointer;min-height:34px}
.ach-tabs button[aria-pressed="true"]{background:var(--rui-accent);color:var(--rui-accent-ink)}
/* pagina-wrap voor de hub */
.ach-page{max-width:1120px;margin:0 auto;padding:18px 16px 48px}
/* Pro-dagen-teller in de hero */
.ach-prodays{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 11px;border-radius:99px;background:var(--rui-accent-soft);color:var(--rui-accent-strong);font-family:var(--rui-font);font-weight:700;font-size:var(--rui-fs-md)}
.ach-prodays svg{width:14px;height:14px}
/* featured kiezen in de hub */
.ach-pinnable{cursor:pointer}
.ach-badge.is-featured{border-color:var(--rui-accent);box-shadow:0 0 0 2px var(--rui-accent-soft),var(--rui-sh-1)}
.ach-pinnable:focus-visible{outline:2px solid var(--rui-accent-strong);outline-offset:2px}
/* tab-filter: verborgen tegels/lege categorieën */
.ach-badge[hidden],.ach-catlabel[hidden],.ach-grid[hidden]{display:none!important}

/* ---------- COMMUNITY RANG-CHIP (naast de naam) ---------- */
.ach-rankchip{display:inline-flex;align-items:center;gap:6px;height:20px;padding:0 9px 0 3px;border-radius:99px;
  font-family:var(--rui-font);font-weight:700;font-size:var(--rui-fs-xs);white-space:nowrap;
  color:#fff;background:linear-gradient(95deg,var(--tier),var(--tier-2));
  box-shadow:0 1px 2px color-mix(in srgb,var(--tier) 45%,transparent)}
.ach-rankchip .pip{width:15px;height:15px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.22)}
.ach-rankchip .pip svg{width:10px;height:10px}
.ach-t-legend .ach-rankchip,.ach-rankchip.ach-t-legend{box-shadow:0 0 0 1px rgba(86,230,244,.5),0 2px 8px rgba(22,200,219,.5)}
/* featured mini naast de rang-chip */
.ach-featmini{display:inline-grid;place-items:center;width:20px;height:20px;border-radius:50%;color:#fff;background:var(--rk,var(--ach-gold));box-shadow:0 1px 2px rgba(0,0,0,.2)}
.ach-featmini svg{width:12px;height:12px}
/* author-rij MET rang-chip mag niet wrappen (design-principe): naam kort in met ellipsis,
   pills/chip blijven op één regel; horizontaal scrollen pas als allerlaatste redmiddel.
   Gescoped via :has() zodat rijen zonder chip hun bestaande gedrag houden. */
.by:has(.ach-rankchip){flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}
.by:has(.ach-rankchip)::-webkit-scrollbar{display:none}
.by:has(.ach-rankchip) > .n{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:0 1 auto}
.by:has(.ach-rankchip) > :not(.n){flex:0 0 auto}

/* demo: een community-postregel (alleen voor de mockup-context) */
.ach-demo-post{display:flex;gap:12px;padding:14px;border:1px solid var(--rui-line);border-radius:var(--rui-r-4);background:var(--rui-card);box-shadow:var(--rui-sh-1)}
.ach-demo-post .av{flex:0 0 auto;width:42px;height:42px;border-radius:50%;background:var(--rui-card-2);border:1px solid var(--rui-line);overflow:hidden}
.ach-demo-post .av img{width:100%;height:100%;object-fit:cover}
.ach-demo-post .by{display:flex;align-items:center;gap:7px;flex-wrap:nowrap;overflow:hidden}
.ach-demo-post .by .n{font-family:var(--rui-font);font-weight:700;color:var(--rui-text)}
.ach-demo-post .by .n a{color:inherit;text-decoration:none}
.ach-demo-post .iv-team{display:inline-flex;align-items:center;height:20px;padding:0 9px;border-radius:99px;color:#fff;font-family:var(--rui-font);font-weight:700;font-size:var(--rui-fs-xs)}
.ach-demo-post .rui-pill{height:20px}
.ach-demo-post .when{color:var(--rui-faint);font-size:var(--rui-fs-md);margin-top:6px}
.ach-demo-post .msg{color:var(--rui-text);font-size:var(--rui-fs-base);line-height:1.5;margin-top:4px}

/* ---------- UNLOCK-TOAST ---------- */
.ach-toast{display:flex;align-items:center;gap:13px;width:340px;max-width:calc(100vw - 32px);
  padding:13px 15px;border-radius:var(--rui-r-4);background:var(--rui-elev);border:1px solid var(--rui-line);
  box-shadow:var(--rui-sh-3);position:relative;overflow:hidden}
.ach-toast::before{content:"";position:absolute;inset:0 auto 0 0;width:4px;background:linear-gradient(180deg,var(--ach-gold),var(--ach-gold-2))}
.ach-toast .tico{flex:0 0 auto;width:44px;height:48px;display:grid;place-items:center;position:relative}
.ach-toast .tico .hex{position:absolute;inset:0;clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);background:linear-gradient(155deg,var(--ach-gold),var(--ach-gold-2));box-shadow:0 4px 12px rgba(214,164,24,.45)}
.ach-toast .tico svg{position:relative;z-index:1;width:22px;height:22px;color:#fff}
.ach-toast .tb{min-width:0;flex:1}
.ach-toast .tb .e{font-family:var(--rui-font);font-size:var(--rui-fs-xs);font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--rui-accent-strong)}
.ach-toast .tb .t{font-family:var(--rui-font);font-weight:700;font-size:var(--rui-fs-lg);line-height:1.2;color:var(--rui-text)}
.ach-toast .tb .d{font-size:var(--rui-fs-md);color:var(--rui-muted);margin-top:1px}
.ach-toast .tb .d b{color:var(--rui-accent-strong)}
.ach-toast .x{flex:0 0 auto;align-self:flex-start;border:0;background:transparent;color:var(--rui-faint);cursor:pointer;padding:2px;line-height:0}
.ach-toast .x svg{width:16px;height:16px}

/* ---------- MOBIEL ---------- */
@media (max-width:575px){
  .ach-rankhero{padding:15px;gap:13px}
  .ach-rankhero .rank{font-size:var(--rui-fs-xl)}
  .ach-emblem.lg{width:78px;height:86px}
  .ach-emblem.lg .ico svg{width:34px;height:34px}
  .ach-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .ach-hubstats{gap:8px}
  .ach-badge{padding:14px 8px 11px}
  .ach-disc{width:52px;height:52px}
  .ach-disc svg{width:24px;height:24px}
  .ach-badge .earned,.ach-badge .lock{top:46px;left:calc(50% + 11px)}
}
