/* OPEN10X Design — component codex gallery styles (ported from UI Codex harness, federation-integrated). */
:root{
  --ink:#16181D; --muted:#5B6270; --faint:#6B7280; --line:#ECEEF5;
  --accent:#7C4A2D; --accent2:#A06A45; --cyan:#C99A6B; --bg:#FFFFFF; --ok:#0B7A43; --star:#F5A623;
  --radius:14px; --shadow:0 18px 50px rgba(16,24,40,.10),0 2px 8px rgba(16,24,40,.04);
  --mono:ui-monospace,SFMono-Regular,Menlo,monospace;
}
*{box-sizing:border-box}
.codex-root{color:var(--ink);font-family:"Pretendard",system-ui,sans-serif;-webkit-font-smoothing:antialiased}
.codex-root .wrap{max-width:1280px;margin:0 auto;padding:0 22px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

.codex-root .hero{padding:26px 0 14px}
.codex-root .hero h1{font-size:clamp(1.6rem,3.4vw,2.3rem);font-weight:950;letter-spacing:-.025em;line-height:1.06;margin:0}
.codex-root .hero h1 em{font-style:normal;color:var(--accent)}
@supports ((-webkit-background-clip:text) or (background-clip:text)){.codex-root .hero h1 em{background:linear-gradient(100deg,var(--accent),var(--accent2) 46%,var(--cyan));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}}
.codex-root .hero p{color:var(--muted);font-size:15px;font-weight:600;margin:11px 0 0;max-width:64ch;line-height:1.6}
.codex-root .hero .meta{display:flex;gap:15px;flex-wrap:wrap;margin-top:13px;color:var(--faint);font-size:12.5px;font-weight:800}
.codex-root .hero .meta b{color:var(--accent)}

.codexsearch{width:100%;max-width:460px;height:40px;border:1px solid var(--line);border-radius:10px;padding:0 14px;font:inherit;font-size:14px;font-weight:600;background:#fff;color:var(--ink)}
.codexsearch:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}

.codex-root .filters{position:sticky;top:0;z-index:20;background:#fff;padding:12px 0 8px;border-bottom:1px solid var(--line)}
.codex-root .frow{display:flex;gap:7px;flex-wrap:wrap;align-items:center}
.codex-root .frow + .frow{margin-top:8px}
.codex-root .frow .lbl{font-size:11px;font-weight:800;color:var(--faint);margin-right:2px;letter-spacing:.04em}
.codex-root .chip{border:1px solid var(--line);background:#fff;color:var(--muted);font:inherit;font-size:12.5px;font-weight:800;padding:6px 12px;border-radius:999px;cursor:pointer;transition:.13s;white-space:nowrap}
.codex-root .chip:hover{border-color:color-mix(in srgb,var(--accent) 36%,#fff);color:var(--ink)}
.codex-root .chip.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.codex-root .chip:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.codex-root .chip .n{opacity:.55;font-weight:700;margin-left:5px}
.codex-root .chip.dom{font-size:12px;padding:5px 11px}
.codex-root .chip.fav{border-color:#F3D9A3;color:#B9791A}
.codex-root .chip.fav.on{background:var(--star);border-color:var(--star);color:#3a2600}

.codex-root .grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(320px,100%),1fr));gap:18px;padding:20px 0 90px}
.codex-root .empty{color:var(--faint);font-weight:700;padding:40px 0}
.codex-root .mcard{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff;display:flex;flex-direction:column;transition:box-shadow .16s,transform .16s,border-color .16s}
.codex-root .mcard:hover{box-shadow:var(--shadow);transform:translateY(-3px);border-color:#dfe2ef}
.codex-root .mcard__prev{position:relative;aspect-ratio:16/10;min-height:160px;overflow:hidden;background:#F4F6FB;border-bottom:1px solid var(--line);display:grid;place-items:center;padding:14px}
.codex-root .mcard__prev > *{max-width:100%}
.codex-root .mcard__prev.paused *{animation-play-state:paused !important}
.codex-root .mcard__badge{position:absolute;top:9px;left:9px;z-index:5;font-size:9.5px;font-weight:900;letter-spacing:.03em;padding:4px 8px;border-radius:999px;background:rgba(255,255,255,.92);color:var(--accent);box-shadow:0 1px 3px rgba(16,24,40,.12)}
.codex-root .fav-btn{position:absolute;top:8px;right:8px;z-index:6;width:32px;height:32px;border-radius:50%;border:1px solid var(--line);background:rgba(255,255,255,.94);color:#c2c8d4;font-size:16px;line-height:1;cursor:pointer;display:grid;place-items:center;transition:.13s;box-shadow:0 1px 4px rgba(16,24,40,.14)}
.codex-root .mcard__head{display:flex;align-items:center;justify-content:space-between;gap:8px}
.codex-root .mcard__dom{font-size:10.5px;font-weight:900;letter-spacing:.04em;text-transform:uppercase;color:var(--accent)}
.codex-root .fav-btn:hover{color:var(--star);transform:scale(1.08)}
.codex-root .fav-btn.on{color:var(--star);border-color:#F3D9A3;background:#FFF8EC}
.codex-root .fav-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.codex-root .mcard__foot{padding:12px 14px;display:flex;flex-direction:column;gap:9px}
.codex-root .mcard__meta strong{font-size:14.5px;font-weight:850;letter-spacing:-.01em;display:block}
.codex-root .mcard__meta small{display:block;color:var(--muted);font-size:12px;font-weight:600;margin-top:3px;line-height:1.45}
.codex-root .mcard__acts{display:flex;gap:7px}
.codex-root .actbtn{flex:1;border:1px solid var(--line);background:#fff;color:var(--ink);font:inherit;font-size:11.5px;font-weight:850;padding:8px 6px;border-radius:8px;cursor:pointer;transition:.13s;white-space:nowrap}
.codex-root .actbtn:hover{border-color:var(--accent);color:var(--accent)}
.codex-root .actbtn:focus-visible{outline:2px solid var(--accent);outline-offset:1px}
.codex-root .actbtn.done{background:var(--ok);border-color:var(--ok);color:#fff}
.codex-root .actbtn.prompt:hover{border-color:var(--accent2);color:var(--accent2)}
.codex-root .mcard__codewrap{border-top:1px dashed var(--line)}
.codex-root .mcard__codetoggle{width:100%;text-align:left;border:0;background:#FAFAFE;color:var(--muted);font:inherit;font-size:11px;font-weight:800;padding:7px 14px;cursor:pointer;font-family:var(--mono);display:flex;gap:10px;align-items:center}
.codex-root .mcard__codetoggle .tabs{display:flex;gap:4px}
.codex-root .mcard__codetoggle .tab{padding:2px 8px;border-radius:6px}
.codex-root .mcard__codetoggle .tab.sel{background:var(--ink);color:#fff}
.codex-root .mcard__code{display:none;margin:0;padding:12px 14px;background:#0b1018;color:#cdd6f4;font-family:var(--mono);font-size:10.5px;line-height:1.55;overflow:auto;max-height:260px;white-space:pre-wrap;word-break:break-word}
.codex-root .mcard.open .mcard__code{display:block}

.codex-root footer.foot{border-top:1px solid var(--line);padding:22px 0;color:var(--faint);font-size:12.5px;font-weight:700;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}
@media (prefers-reduced-motion:reduce){.codex-root .mcard,.codex-root .chip,.codex-root .actbtn,.codex-root .fav-btn{transition:none}.codex-root .mcard:hover{transform:none}.codex-root .mcard__prev *{animation-play-state:paused !important}}
