/* ===== Character Modal v2 ===== */

.character-modal{
  width:min(980px,96vw);
  height:min(680px,82vh);
  display:flex;
  flex-direction:column;
  gap:var(--gap,16px);
  box-sizing:border-box;
}

.character{
  --cm-bg: var(--quote, var(--dialog-bg, #d1cfcf));
  --cm-panel: var(--podform, var(--panel-bg-light, #cbc9ca));
  --cm-bord: var(--bord, var(--panel-border, #b5b5b5));
  --cm-text: var(--text, var(--text-color, #333));
  --cm-muted: var(--sec-text, var(--muted-color, #666));
  --cm-accent: var(--accent, var(--primary-color, #915252));
  --cm-accent2: var(--accent2, var(--primary-hover, #723636));
  --cm-radius: var(--radius, 6px);
  --cm-gap: var(--gap, 16px);
  --cm-gap-sm: var(--small-gap, 8px);
  --cm-font: var(--main-font, inherit);

  --cm-ava: calc(var(--avatar-size,40px) * 2.25);
  --cm-slot: calc(var(--avatar-size,40px) * 1.7);

  font-family:var(--cm-font);
  color:var(--cm-text);
  box-sizing:border-box;
}
.character *{ box-sizing:border-box; }

.cm-sr{
  position:absolute!important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);
  border:0;
}

/* ===== Header ===== */
.cm-header{
  position:relative;
  display:grid;
  grid-template-columns: 1fr minmax(280px, 1.2fr) 1fr;
  align-items:center;
  gap:var(--cm-gap);
  padding:var(--cm-gap);
  background:var(--cm-bg);
  border:1px solid var(--cm-bord);
  border-radius:var(--cm-radius);
  flex:0 0 auto;
}

.cm-close{
  position:absolute;
  top:var(--cm-gap-sm);
  right:var(--cm-gap-sm);
  width:36px;height:36px;
  display:grid;place-items:center;
  cursor:pointer;
  border-radius:calc(var(--cm-radius) - 2px);
  border:1px solid var(--cm-bord);
  background:transparent;
  color:var(--cm-text);
}
.cm-close:hover{
  border-color:var(--cm-accent);
  background:color-mix(in srgb, var(--cm-panel) 55%, transparent);
}
.cm-close:focus-visible{
  outline:2px solid var(--cm-accent);
  outline-offset:2px;
}

.cm-side{
  display:grid;
  grid-template-columns: var(--cm-ava) 1fr;
  gap:var(--cm-gap-sm);
  align-items:center;
  min-width:0;
}
.cm-side--right{
  grid-template-columns: var(--cm-ava) 1fr;
  justify-content:end;
}
.cm-side__text{ min-width:0; }
.cm-side__text--right{ text-align:left; }

.cm-avatar{
  width:var(--cm-ava);
  height:var(--cm-ava);
  border-radius:var(--cm-radius);
  overflow:hidden;
  border:1px solid var(--cm-bord);
  background:var(--cm-panel);
}
.cm-avatar img{ width:100%;height:100%;object-fit:cover;display:block; }

.cm-title{
  margin:0;
  font-size:28px;
  line-height:1.1;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.cm-role{
  margin-top:6px;
  display:inline-flex;
  align-items:center;
  padding:6px 10px;
  border-radius:calc(var(--cm-radius) - 2px);
  border:1px solid var(--cm-bord);
  background:var(--cm-panel);
  color:var(--cm-muted);
  font-size:14px;
  width:fit-content;
}

.cm-soul-label{ font-size:12px;color:var(--cm-muted);margin-bottom:4px; }
.cm-soul-name{
  display:inline-flex;
  gap:6px;
  align-items:center;
  font-weight:600;
  color:var(--cm-text);
  text-decoration:none;
}
.cm-soul-name:hover{ color:var(--cm-accent); }
.cm-link{ color:inherit;text-decoration:none; }

/* Center bars */
.cm-mid{ display:grid; gap:var(--cm-gap-sm); min-width:0; }
.cm-barrow{
  display:grid;
  grid-template-columns: 100px 1fr 52px;
  gap:var(--cm-gap-sm);
  align-items:center;
  font-size:14px;
  color:var(--cm-muted);
}
.cm-barrow__label{
  display:flex;
  align-items:center;
  gap:8px;
}
.cm-barrow__value{ text-align:right;color:var(--cm-text); }

.cm-bar{
  height:12px;
  border-radius:999px;
  background:var(--cm-panel);
  border:1px solid var(--cm-bord);
  overflow:hidden;
}
.cm-bar__fill{ display:block;height:100%;background:var(--cm-accent); }

/* ===== Tabs ===== */
.modal__tabs{
  flex:0 0 auto;
  display:flex;
  border:1px solid var(--cm-bord);
  border-radius:var(--cm-radius);
  overflow:hidden;
  background:var(--cm-bg);
}

.modal__tab{
  position:relative;
  flex:1;
  min-height:52px;
  border:0;
  background:transparent;
  color:var(--cm-muted);
  cursor:pointer;
  display:grid;
  place-items:center;
  font-size:18px;
  line-height:1;
}
.modal__tab + .modal__tab{ border-left:1px solid var(--cm-bord); }
.modal__tab:hover{ color:var(--cm-accent); }

.modal__tab.active{
  background:var(--cm-panel);
  color:var(--cm-text);
}

/* marker */
.modal__tab.active::before{
  content:"";
  position:absolute;
  left:0; right:0; bottom:0;
  height:3px;
  background:var(--cm-accent);
}

/* tooltip */
.modal__tab[data-title]::after{
  content:attr(data-title);
  position:absolute;
  top:-10px;
  left:50%;
  transform:translate(-50%,-100%);
  padding:6px 8px;
  border-radius:calc(var(--cm-radius) - 2px);
  border:1px solid var(--cm-bord);
  background:var(--cm-bg);
  color:var(--cm-text);
  font-size:12px;
  white-space:nowrap;
  opacity:0;
  pointer-events:none;
  box-shadow:0 8px 18px rgba(0,0,0,.12);
}
.modal__tab:hover::after{ opacity:1; }

.modal__tab:focus-visible{
  outline:2px solid var(--cm-accent);
  outline-offset:-2px;
}

/* badge */
.cm-badge{
  position:absolute;
  top:6px;
  right:8px;
  min-width:18px;
  height:18px;
  padding:0 6px;
  border-radius:999px;
  display:grid;
  place-items:center;
  font-size:12px;
  line-height:1;
  border:1px solid var(--cm-bord);
  background:color-mix(in srgb, var(--cm-bg) 80%, transparent);
  color:var(--cm-text);
}

/* ===== Body ===== */
.cm-body{
  flex:1 1 auto;
  min-height:0;
  overflow:auto;
  scrollbar-gutter:stable;
  padding-right:2px;
}
@supports not (scrollbar-gutter: stable){
  .cm-body{ overflow-y:scroll; }
}

/* Contents */
.modal__content{ display:none; }
.modal__content.active{ display:block; }

.cm-section{
  padding:var(--cm-gap);
  background:var(--cm-bg);
  border:1px solid var(--cm-bord);
  border-radius:var(--cm-radius);
}

.cm-h3{ margin:0 0 var(--cm-gap-sm); font-size:18px; }
.cm-p{ margin:0 0 var(--cm-gap-sm); color:var(--cm-text); }
.cm-muted{ color:var(--cm-muted); }

.cm-list{ margin:0; padding-left:18px; color:var(--cm-muted); }

.cm-card{
  border:1px solid var(--cm-bord);
  border-radius:var(--cm-radius);
  background:var(--cm-panel);
}

/* chips */
.cm-chips{ display:flex; flex-wrap:wrap; gap:8px; }
.cm-chip{
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--cm-bord);
  background:var(--cm-panel);
  font-size:12px;
  color:var(--cm-text);
}

/* Gift layout */
.cm-gift{
  display:grid;
  grid-template-columns: 320px 1fr;
  gap:var(--cm-gap);
  align-items:start;
}
.cm-gift__media{
  border:1px solid var(--cm-bord);
  border-radius:var(--cm-radius);
  overflow:hidden;
  background:var(--cm-panel);
}
.cm-gift__media img{ width:100%; height:auto; display:block; }
.cm-gift__text{ min-width:0; }

/* details */
.cm-details{
  margin-top:var(--cm-gap-sm);
  border:1px solid var(--cm-bord);
  border-radius:var(--cm-radius);
  background:var(--cm-panel);
  overflow:hidden;
}
.cm-details>summary{
  cursor:pointer;
  padding:12px 14px;
  color:var(--cm-text);
  list-style:none;
}
.cm-details>summary::-webkit-details-marker{ display:none; }
.cm-details__body{ padding:0 14px 14px; color:var(--cm-muted); }

/* toolbar */
.cm-toolbar{
  display:flex;
  gap:var(--cm-gap-sm);
  align-items:center;
  justify-content:space-between;
  margin-bottom:var(--cm-gap);
  position:relative;
}

.cm-input{
  flex:1;
  min-width:160px;
  padding:10px 12px;
  border-radius:calc(var(--cm-radius) - 2px);
  border:1px solid var(--cm-bord);
  background:var(--cm-panel);
  color:var(--cm-text);
  outline:none;
}
.cm-input:focus{ border-color:var(--cm-accent); }

.cm-btn{
  padding:10px 12px;
  border-radius:calc(var(--cm-radius) - 2px);
  border:1px solid var(--cm-bord);
  background:var(--cm-accent);
  color:var(--button-text, #dddbdc);
  cursor:pointer;
}
.cm-btn:hover{ background:var(--cm-accent2); }
.cm-btn:focus-visible{ outline:2px solid var(--cm-accent); outline-offset:2px; }

/* hidden must win */
[hidden]{ display:none!important; }

/* tooltip for slots */
.cm-tip{ position:relative; }
.cm-tip:hover::after,
.cm-tip:focus-visible::after{
  content:attr(data-tooltip);
  position:absolute;
  left:50%;
  top:-10px;
  transform:translate(-50%,-100%);
  white-space:pre-line;
  z-index:50;
  max-width:320px;
  padding:10px 12px;
  border-radius:calc(var(--cm-radius) - 2px);
  border:1px solid var(--cm-bord);
  background:var(--cm-bg);
  color:var(--cm-text);
  font-size:13px;
  box-shadow:0 8px 18px rgba(0,0,0,.15);
}
.cm-tip:hover::before,
.cm-tip:focus-visible::before{
  content:"";
  position:absolute;
  left:50%;
  top:-10px;
  transform:translate(-50%,-6px);
  border:6px solid transparent;
  border-top-color:var(--cm-bord);
  z-index:51;
}

/* Inventory slots grid */
.inv-grid{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(var(--cm-slot), var(--cm-slot)));
  gap:var(--cm-gap-sm);
  justify-content:start;
}

.inv-slot{
  width:var(--cm-slot);
  height:var(--cm-slot);
  border-radius:calc(var(--cm-radius) - 2px);
  border:1px solid var(--cm-bord);
  background:var(--cm-panel);
  cursor:pointer;

  background-image:var(--slot-img);
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;

  position:relative;
  padding:0;
}
.inv-slot:hover{ border-color:var(--cm-accent); }
.inv-slot:focus-visible{ outline:2px solid var(--cm-accent); outline-offset:2px; }

.inv-qty{
  position:absolute;
  right:6px;
  bottom:6px;
  padding:2px 6px;
  border-radius:999px;
  border:1px solid var(--cm-bord);
  background:color-mix(in srgb, var(--cm-bg) 85%, transparent);
  color:var(--cm-text);
  font-size:12px;
  line-height:1.1;
}

/* Popover filters */
.cm-section--inv{ position:relative; }
.inv-popover{
  position:absolute;
  top:54px;
  right:0;
  width:min(360px, 92vw);
  border-radius:var(--cm-radius);
  border:1px solid var(--cm-bord);
  background:var(--cm-bg);
  box-shadow:0 12px 28px rgba(0,0,0,.18);
  z-index:30;
  overflow:hidden;
}

.inv-popover__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  padding:10px 12px;
  border-bottom:1px solid var(--cm-bord);
  background:color-mix(in srgb, var(--cm-panel) 45%, transparent);
}
.inv-popover__title{ font-weight:600; color:var(--cm-text); }
.inv-popover__close{
  width:32px;height:32px;
  display:grid;place-items:center;
  border-radius:calc(var(--cm-radius) - 2px);
  border:1px solid var(--cm-bord);
  background:transparent;
  cursor:pointer;
}
.inv-popover__close:hover{ border-color:var(--cm-accent); }
.inv-popover__body{ padding:10px 12px; display:grid; gap:10px; }
.inv-popover__foot{
  padding:10px 12px;
  border-top:1px solid var(--cm-bord);
  display:flex;
  justify-content:flex-end;
}

.inv-filters__row{ display:flex; flex-wrap:wrap; gap:10px; }
.inv-filters__row label{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:13px;
  color:var(--cm-text);
}

/* Achievements grid */
.ach-grid{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(var(--cm-slot), var(--cm-slot)));
  gap:var(--cm-gap-sm);
  justify-content:start;
}
.ach-slot{
  width:var(--cm-slot);
  border:1px solid var(--cm-bord);
  border-radius:calc(var(--cm-radius) - 2px);
  background:var(--cm-panel);
  padding:8px;
  display:grid;
  gap:8px;
}
.ach-slot::before{
  content:"";
  width:100%;
  aspect-ratio:1/1;
  border-radius:calc(var(--cm-radius) - 2px);
  border:1px solid var(--cm-bord);
  background:var(--cm-bg);
  background-image:var(--slot-img);
  background-size:cover;
  background-position:center;
}
.ach-name{
  font-size:12px;
  color:var(--cm-text);
  line-height:1.2;
  min-height:2.4em;
  overflow:hidden;
}

/* Appearance split */
.ap-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:var(--cm-gap);
  align-items:start;
}
.ap-col{ min-width:0; }

.ap-col__head{
  display:grid;
  grid-template-columns: 1fr auto;
  align-items:center;
  gap:10px;
  margin-bottom:var(--cm-gap-sm);
}

/* mini icon preview */
.ap-mini{
  width:42px;height:42px;
  border-radius:calc(var(--cm-radius) - 2px);
  border:1px solid var(--cm-bord);
  background:var(--cm-panel);
  display:grid;
  place-items:center;
  color:var(--cm-accent);
  font-size:18px;
}

/* banner bg preview */
.ap-banner{
  width:180px;
  height:42px;
  border-radius:calc(var(--cm-radius) - 2px);
  border:1px solid var(--cm-bord);
  background:var(--cm-panel);
  background-size:cover;
  background-position:center;
}

/* icons/bgs grids */
.cm-grid{ display:grid; gap:var(--cm-gap-sm); }
.cm-grid--icons{ grid-template-columns: repeat(auto-fill, minmax(64px, 1fr)); }
.ap-bgs{ grid-template-columns: repeat(2, minmax(0, 1fr)); }

.cm-icon,
.cm-bg{ cursor:pointer; padding:0; }

.cm-icon{
  height:64px;
  display:grid;
  place-items:center;
  font-size:22px;
  color:var(--cm-muted);
  background:var(--cm-panel);
}
.cm-icon:hover{ color:var(--cm-accent); border-color:var(--cm-accent); }

.cm-bg{
  height:74px;
  overflow:hidden;
  background:var(--cm-panel);
}
.cm-bg__thumb{
  display:block;
  width:100%;
  height:100%;
  background-size:cover;
  background-position:center;
}

.is-active{
  border-color:var(--cm-accent)!important;
  box-shadow:0 0 0 2px color-mix(in srgb, var(--cm-accent) 35%, transparent);
}

/* Responsive */
@media (max-width: 920px){
  .cm-header{ grid-template-columns:1fr; }
  .cm-gift{ grid-template-columns:1fr; }
  .ap-grid{ grid-template-columns:1fr; }
}
