63 lines
4.5 KiB
CSS
63 lines
4.5 KiB
CSS
/* Extracted from single-file version */
|
|
:root{ --panel: rgba(20,22,30,0.88); --text:#e7eaf1; --muted:#9aa0aa; --pc:#7dd3fc; --npc:#a78bfa; --monster:#fca5a5; --hl:#fde047; --dead:#ef4444; }
|
|
*{ box-sizing:border-box; }
|
|
html,body{ margin:0; padding:0; background:transparent; color:var(--text); font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Helvetica Neue,Arial,sans-serif; }
|
|
.wrapper{ width:100%; display:flex; justify-content:center; }
|
|
.panel{ margin:8px; padding:10px 12px; border-radius:14px; background:var(--panel); backdrop-filter: blur(6px); width: calc(100vw - 16px); max-width:none; }
|
|
.header{ display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:6px; gap:8px; }
|
|
.h-title{ font-weight:700; letter-spacing:0.5px; }
|
|
.h-sub{ font-size:12px; color:var(--muted); }
|
|
.list{ display:flex; flex-wrap:wrap; gap:10px; align-items:stretch; justify-content:flex-start; }
|
|
|
|
/* Status pill */
|
|
.statuspill{ font-size:12px; padding:2px 8px; border-radius:999px; border:1px solid rgba(255,255,255,0.18); background:rgba(255,255,255,0.06); }
|
|
.statuspill.ok{ border-color:#14532d; background:#052e16; color:#bbf7d0; }
|
|
.statuspill.warn{ border-color:#334155; background:#0b1220; color:#e5e7eb; }
|
|
.statuspill.bad{ border-color:#7f1d1d; background:#1a0b0b; color:#fecaca; }
|
|
|
|
/* Vertical cards that flow left→right */
|
|
.row{ position:relative; display:flex; flex-direction:column; align-items:center; gap:8px; padding:10px; border-radius:12px; background: rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.06); width: clamp(150px, 14vw, 220px); transition: width .15s ease, opacity .15s ease, transform .15s ease; }
|
|
.row.active{ outline:2px solid var(--hl); box-shadow:0 0 16px rgba(253,224,71,0.35) inset; }
|
|
.type-pc{ border-top:3px solid var(--pc); }
|
|
.type-npc{ border-top:3px solid var(--npc); }
|
|
.type-monster{ border-top:3px solid var(--monster); }
|
|
|
|
.portrait{ width:96px; height:96px; border-radius:12px; object-fit:cover; background:rgba(255,255,255,0.06); }
|
|
.noavatar{ width:96px; height:96px; border-radius:12px; background:rgba(255,255,255,0.06); }
|
|
.name{ display:flex; flex-direction:column; align-items:center; text-align:center; min-width:0; }
|
|
.name .n{ font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width: 100%; }
|
|
.name .meta{ font-size:12px; color:var(--muted); }
|
|
.tags{ display:flex; gap:6px; flex-wrap:wrap; justify-content:center; margin-top:2px; font-size:12px; }
|
|
.tag{ display:inline-flex; align-items:center; gap:6px; padding:2px 8px; border-radius:10px; border:1px solid rgba(255,255,255,0.12); background:rgba(255,255,255,0.06); }
|
|
.tag .ico_wrap{ width:16px; height:16px; border-radius:5px; overflow:hidden; background:#0b1220; display:inline-flex; }
|
|
.tag img.ico{ width:100%; height:100%; display:block; }
|
|
.concStar{ position:absolute; top:8px; right:8px; font-weight:700; filter: drop-shadow(0 0 6px rgba(253,224,71,0.6)); }
|
|
|
|
/* DEAD state */
|
|
.dead{ border-color: rgba(239,68,68,0.7); box-shadow: inset 0 0 0 2px rgba(239,68,68,0.35); }
|
|
.dead .portrait{ filter: grayscale(1) brightness(0.55); }
|
|
.deathBadge{ position:absolute; top:8px; left:8px; width:22px; height:22px; border-radius:999px; background:#7f1d1d; color:#fff; display:flex; align-items:center; justify-content:center; font-size:13px; box-shadow:0 0 2px rgba(239,68,68,0.7), 0 2px 6px rgba(0,0,0,0.4); }
|
|
.dead .name .n{ text-decoration: line-through; opacity:0.7; }
|
|
.dead .tags{ opacity:0.7; }
|
|
/* Shrink mode for dead cards */
|
|
.shrunk{ width: clamp(120px, 11vw, 170px); opacity:.72; transform: scale(.95); }
|
|
|
|
.footer{ margin-top:6px; font-size:12px; color:var(--muted); display:flex; justify-content:space-between; }
|
|
.hideall{ display:none; }
|
|
|
|
/* --- overlay for auth/errors --- */
|
|
.overlay{ position:fixed; inset:0; display:none; align-items:center; justify-content:center; background:rgba(0,0,0,0.6); z-index:9999; }
|
|
.overlay.show{ display:flex; }
|
|
.overlay .box{ background:#0b0d12; color:#e9eef4; border:1px solid #293145; border-radius:12px; padding:16px; width:min(520px,92vw); }
|
|
.overlay .box h3{ margin:0 0 8px; font-size:18px; }
|
|
.overlay .box p{ margin:8px 0; color:#94a3b8; }
|
|
.overlay .row{ display:flex; gap:8px; align-items:center; margin-top:10px; }
|
|
.overlay input{ flex:1; padding:8px; border-radius:8px; border:1px solid #293145; background:#0d111a; color:#e9eef4; }
|
|
.overlay button{ padding:8px 10px; border-radius:10px; border:1px solid #334155; background:#111827; color:#e9eef4; cursor:pointer; }
|
|
|
|
@media (max-width: 740px){
|
|
.list{ flex-direction:column; }
|
|
.row{ width:auto; align-items:flex-start; }
|
|
.name{ align-items:flex-start; text-align:left; }
|
|
}
|