:root{
  --ink:#0E1117; --ink-2:#141925; --ink-3:#1B2230; --line:#283143;
  --text:#E6EAF1; --text-2:#9AA4B6; --text-3:#616B7E;
  --brass:#D7A94C; --brass-dim:#8a6c30; --danger:#E2685C; --good:#6FCF97; --link:#82B4FF;
  --radius:14px; --radius-sm:9px;
  --mono:"Space Mono",ui-monospace,Menlo,monospace; --display:"Space Grotesk",system-ui,sans-serif; --body:"Inter",system-ui,sans-serif;
  --shadow:0 18px 50px -20px rgba(0,0,0,.7);
}
*{ box-sizing:border-box; }
html,body{ height:100%; }
body{ margin:0; color:var(--text); font-family:var(--body); overflow:hidden; -webkit-font-smoothing:antialiased;
  background:radial-gradient(1200px 600px at 80% -10%,#182033 0%,transparent 60%),radial-gradient(900px 500px at -10% 110%,#14161f 0%,transparent 55%),var(--ink); }
button{ font-family:inherit; cursor:pointer; }
input,textarea{ font-family:inherit; }
::selection{ background:rgba(215,169,76,.3); }
:focus-visible{ outline:2px solid var(--brass); outline-offset:2px; border-radius:6px; }
a{ color:var(--link); text-decoration:none; } a:hover{ text-decoration:underline; }

/* gate */
.gate{ height:100%; display:grid; place-items:center; padding:24px; overflow-y:auto; }
.panel{ width:100%; max-width:460px; background:linear-gradient(180deg,var(--ink-2),#10141d); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); padding:34px 32px 30px; position:relative; overflow:hidden; margin:auto; }
.panel::before{ content:""; position:absolute; left:0; right:0; top:0; height:3px; background:linear-gradient(90deg,transparent,var(--brass-dim),transparent); opacity:.6; }
.mark{ display:flex; align-items:center; gap:11px; margin-bottom:22px; }
.mark .hook{ width:26px; height:26px; flex:0 0 auto; }
.mark h1{ font-family:var(--display); font-weight:700; font-size:19px; letter-spacing:.5px; margin:0; }
.mark .tag{ font-size:11px; color:var(--text-3); letter-spacing:2px; text-transform:uppercase; margin-top:2px; }
.lead{ font-family:var(--display); font-weight:600; font-size:24px; line-height:1.2; margin:6px 0; letter-spacing:-.2px; }
.sub{ color:var(--text-2); font-size:14px; line-height:1.55; margin:0 0 22px; }
label.fld{ display:block; font-size:12px; color:var(--text-2); letter-spacing:.4px; margin:0 0 7px; text-transform:uppercase; }
.input{ width:100%; background:var(--ink-3); border:1px solid var(--line); color:var(--text); border-radius:var(--radius-sm); padding:13px 14px; font-size:15px; transition:border-color .15s,background .15s; }
.input:focus{ border-color:var(--brass-dim); background:#1d2533; outline:none; }
.input::placeholder{ color:var(--text-3); }
.hint{ font-size:12px; color:var(--text-3); margin-top:8px; line-height:1.5; }
.btn{ width:100%; border:none; border-radius:var(--radius-sm); padding:13px 16px; font-size:14.5px; font-weight:600; letter-spacing:.2px; background:var(--brass); color:#241a06; transition:filter .15s,transform .05s; }
.btn:hover{ filter:brightness(1.07); } .btn:active{ transform:translateY(1px); } .btn:disabled{ opacity:.45; cursor:not-allowed; }
.btn.ghost{ background:transparent; color:var(--text-2); border:1px solid var(--line); }
.btn.ghost:hover{ color:var(--text); background:var(--ink-3); }
.btn.danger{ background:var(--danger); color:#2a0d0a; }
.row{ display:flex; gap:10px; } .row .btn{ width:auto; flex:1; }
.err{ color:var(--danger); font-size:13px; margin-top:12px; min-height:18px; }
.switcher{ margin-top:18px; font-size:13px; color:var(--text-3); text-align:center; }
.switcher a{ color:var(--brass); cursor:pointer; }
.keycard{ margin:6px 0 4px; background:linear-gradient(160deg,#241d10,#1a1609); border:1px solid var(--brass-dim); border-radius:12px; padding:18px; }
.keycard .klabel{ font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--brass); margin-bottom:9px; }
.keycode{ font-family:var(--mono); font-weight:700; font-size:21px; letter-spacing:2px; color:#F4DFA8; word-break:break-all; }
.copyline{ display:flex; gap:8px; margin-top:14px; }
.copyline .input{ font-family:var(--mono); font-size:13px; padding:9px 11px; }
.mini{ border:1px solid var(--line); background:var(--ink-3); color:var(--text-2); border-radius:8px; padding:0 13px; font-size:12.5px; font-weight:600; white-space:nowrap; }
.mini:hover{ color:var(--text); }
.warnbox{ background:rgba(226,104,92,.08); border:1px solid rgba(226,104,92,.3); color:#f0b3ac; border-radius:10px; padding:11px 13px; font-size:12.5px; line-height:1.5; margin-top:14px; }
.infobox{ background:rgba(130,180,255,.07); border:1px solid rgba(130,180,255,.25); color:#bcd2f5; border-radius:10px; padding:11px 13px; font-size:12.5px; line-height:1.55; margin-top:14px; }

/* shell */
.app{ display:none; height:100%; grid-template-columns:262px 1fr; }
.app.on{ display:grid; }
.side-backdrop{ display:none; }
.side{ background:linear-gradient(180deg,#10141d,#0d1017); border-right:1px solid var(--line); display:flex; flex-direction:column; min-height:0; }
.side-top{ padding:18px 18px 14px; border-bottom:1px solid var(--line); }
.room-name{ font-family:var(--display); font-weight:700; font-size:16px; display:flex; align-items:center; gap:9px; }
.room-name .hook{ width:20px; height:20px; flex:0 0 auto; }
.room-meta{ font-size:11px; color:var(--text-3); letter-spacing:1.4px; text-transform:uppercase; margin-top:4px; }
.me-card{ margin:14px 18px; background:var(--ink-3); border:1px solid var(--line); border-radius:11px; padding:12px; }
.me-row{ display:flex; align-items:center; gap:10px; }
.dot{ width:11px; height:11px; border-radius:50%; flex:0 0 auto; box-shadow:0 0 0 3px rgba(255,255,255,.04); }
.me-name{ font-weight:600; font-size:14px; font-family:var(--display); }
.me-sub{ font-size:11px; color:var(--text-3); margin-top:1px; }
.me-actions{ display:flex; gap:7px; margin-top:11px; flex-wrap:wrap; }
.me-actions .mini{ flex:1 1 44%; text-align:center; padding:7px 0; }
.members{ flex:1; overflow-y:auto; padding:6px 10px 14px; min-height:0; }
.members h3{ font-size:11px; letter-spacing:1.6px; text-transform:uppercase; color:var(--text-3); margin:12px 8px 8px; }
.mem{ display:flex; align-items:center; gap:10px; padding:7px 8px; border-radius:9px; font-size:14px; }
.mem:hover{ background:var(--ink-3); }
.mem .nm{ flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.mem .pres{ width:7px; height:7px; border-radius:50%; background:var(--text-3); flex:0 0 auto; }
.mem .pres.live{ background:var(--good); box-shadow:0 0 7px var(--good); }
.mem .typing{ font-size:10px; color:var(--brass); letter-spacing:.5px; }
.mem .muted{ font-size:10px; color:var(--text-3); }
.side-foot{ padding:12px 18px 16px; border-top:1px solid var(--line); display:flex; flex-direction:column; gap:8px; }
.side-foot .mini{ width:100%; padding:8px 0; text-align:center; }

.main{ display:flex; flex-direction:column; min-height:0; min-width:0; position:relative; }
.bar{ min-height:58px; flex:0 0 auto; border-bottom:1px solid var(--line); display:flex; align-items:center; justify-content:space-between; padding:0 16px; background:rgba(16,20,29,.6); backdrop-filter:blur(6px); }
.bar .left{ display:flex; align-items:center; gap:12px; min-width:0; }
.bar .htitle{ font-family:var(--display); font-weight:600; font-size:15px; }
.bar .hsub{ font-size:12px; color:var(--text-3); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:42vw; }
.bar .right{ display:flex; align-items:center; gap:4px; }
.icon{ width:34px; height:34px; border-radius:9px; border:1px solid transparent; background:none; color:var(--text-2); display:grid; place-items:center; }
.icon:hover{ background:var(--ink-3); color:var(--text); } .icon.on{ color:var(--brass); }
.hamburger{ display:none; }
.searchwrap{ display:none; align-items:center; gap:8px; flex:1; }
.searchwrap.on{ display:flex; }
.searchwrap input{ flex:1; background:var(--ink-3); border:1px solid var(--line); color:var(--text); border-radius:9px; padding:8px 12px; font-size:14px; }

.freeze{ display:none; background:rgba(226,104,92,.12); border-bottom:1px solid rgba(226,104,92,.4); color:#f0b3ac; font-size:12.5px; padding:7px 16px; text-align:center; }
.freeze.on{ display:block; }
.pinned{ display:none; align-items:center; gap:10px; padding:9px 16px; background:rgba(215,169,76,.07); border-bottom:1px solid var(--brass-dim); font-size:13px; color:#ecd9a8; cursor:pointer; }
.pinned.on{ display:flex; }
.pinned .ptext{ flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.pinned .punpin{ border:none; background:none; color:var(--text-3); font-size:12px; }
.pinned .punpin:hover{ color:var(--danger); }

.stream{ flex:1; overflow-y:auto; padding:22px 8px 8px; min-height:0; }
.wrap{ max-width:760px; margin:0 auto; padding:0 14px; }
.day{ text-align:center; margin:18px 0 14px; }
.day span{ font-size:11px; color:var(--text-3); letter-spacing:1px; background:var(--ink-2); border:1px solid var(--line); padding:3px 11px; border-radius:20px; }
.newdiv{ display:flex; align-items:center; gap:10px; margin:16px 0; color:var(--brass); font-size:11px; letter-spacing:1.5px; text-transform:uppercase; }
.newdiv::before,.newdiv::after{ content:""; height:1px; flex:1; background:linear-gradient(90deg,transparent,var(--brass-dim),transparent); }
.sys{ text-align:center; color:var(--text-3); font-size:12.5px; margin:10px 0; font-style:italic; }

.msg{ display:flex; gap:12px; padding:3px 6px; border-radius:10px; position:relative; }
.msg:hover{ background:rgba(255,255,255,.018); }
.msg.grouped{ margin-top:2px; } .msg.fresh{ margin-top:16px; }
.msg.flash{ animation:flash 1.4s ease; }
@keyframes flash{ 0%{ background:rgba(215,169,76,.18);} 100%{ background:transparent;} }
.msg.mention{ box-shadow:inset 2px 0 0 var(--brass); }
.av{ width:36px; height:36px; border-radius:10px; flex:0 0 auto; display:grid; place-items:center; font-family:var(--display); font-weight:700; font-size:15px; color:#0c0f15; }
.av.hidden{ visibility:hidden; height:0; }
.body{ flex:1; min-width:0; }
.head{ display:flex; align-items:baseline; gap:9px; margin-bottom:1px; }
.author{ font-family:var(--display); font-weight:600; font-size:14px; }
.time{ font-size:11px; color:var(--text-3); }
.text{ font-size:14.5px; line-height:1.5; color:#dde2ec; white-space:pre-wrap; overflow-wrap:anywhere; }
.text code{ font-family:var(--mono); background:#0c0f15; border:1px solid var(--line); border-radius:5px; padding:1px 5px; font-size:13px; }
.mention-tag{ color:var(--brass); background:rgba(215,169,76,.13); border-radius:5px; padding:0 3px; }
.mention-tag.me{ background:rgba(215,169,76,.3); color:#f3dca6; }
.inline-img{ max-width:340px; max-height:260px; border-radius:10px; margin-top:7px; border:1px solid var(--line); display:block; cursor:pointer; }
.filechip{ display:inline-flex; align-items:center; gap:9px; margin-top:7px; background:var(--ink-3); border:1px solid var(--line); border-radius:10px; padding:9px 12px; font-size:13px; cursor:pointer; }
.filechip:hover{ border-color:var(--brass-dim); }
.rquote{ border-left:2px solid var(--line); padding:2px 0 2px 9px; margin-bottom:4px; font-size:12.5px; color:var(--text-2); cursor:pointer; }
.rquote:hover{ border-left-color:var(--brass); }
.reacts{ display:flex; flex-wrap:wrap; gap:6px; margin-top:6px; }
.react{ display:inline-flex; align-items:center; gap:5px; font-size:12.5px; background:var(--ink-3); border:1px solid var(--line); border-radius:20px; padding:2px 9px; color:var(--text-2); }
.react:hover{ border-color:var(--brass-dim); }
.react.on{ border-color:var(--brass); color:#f1dca6; background:rgba(215,169,76,.1); }
.react .em{ font-size:13.5px; }
.addr{ opacity:0; position:absolute; top:-13px; right:10px; display:flex; gap:1px; background:var(--ink-2); border:1px solid var(--line); border-radius:24px; padding:3px; box-shadow:var(--shadow); transition:opacity .12s; z-index:5; }
.msg:hover .addr{ opacity:1; }
.addr button{ background:none; border:none; font-size:15px; padding:3px 6px; border-radius:50%; line-height:1; color:var(--text-2); }
.addr button:hover{ background:var(--ink-3); color:var(--text); }
.addr .sep{ width:1px; background:var(--line); margin:3px 2px; }

.fab{ position:absolute; right:22px; bottom:118px; display:none; align-items:center; gap:7px; background:var(--brass); color:#241a06; border:none; border-radius:22px; padding:8px 14px; font-size:13px; font-weight:600; box-shadow:var(--shadow); z-index:6; }
.fab.on{ display:flex; }

.composer{ flex:0 0 auto; border-top:1px solid var(--line); padding:8px 18px 14px; background:rgba(16,20,29,.6); position:relative; }
.cwrap{ max-width:760px; margin:0 auto; }
.typingbar{ height:16px; font-size:11.5px; color:var(--brass); padding:0 4px 3px; }
.reply-ctx{ display:none; align-items:center; gap:8px; background:var(--ink-3); border:1px solid var(--line); border-left:2px solid var(--brass); border-radius:9px; padding:7px 10px; margin-bottom:8px; font-size:12.5px; color:var(--text-2); }
.reply-ctx.on{ display:flex; }
.reply-ctx .x{ border:none; background:none; color:var(--text-3); font-size:15px; margin-left:auto; }
.cbox{ display:flex; gap:8px; align-items:flex-end; background:var(--ink-3); border:1px solid var(--line); border-radius:14px; padding:8px 8px 8px 12px; transition:border-color .15s; }
.cbox.focus{ border-color:var(--brass-dim); }
.attach{ width:34px; height:34px; border-radius:9px; border:none; background:none; color:var(--text-2); display:grid; place-items:center; flex:0 0 auto; }
.attach:hover{ background:var(--ink); color:var(--text); }
.cinput{ flex:1; background:none; border:none; color:var(--text); font-size:14.5px; line-height:1.5; resize:none; max-height:160px; padding:6px 0; }
.cinput:focus{ outline:none; } .cinput::placeholder{ color:var(--text-3); }
.send{ width:38px; height:38px; border-radius:10px; border:none; background:var(--brass); color:#241a06; display:grid; place-items:center; flex:0 0 auto; transition:filter .15s,transform .05s; }
.send:hover{ filter:brightness(1.07); } .send:active{ transform:translateY(1px); } .send:disabled{ opacity:.4; cursor:not-allowed; }
.cfoot{ display:flex; justify-content:space-between; margin-top:7px; font-size:11px; color:var(--text-3); padding:0 4px; }
.lockwarn{ color:var(--danger); }

.mpop{ position:absolute; bottom:100%; left:18px; margin-bottom:6px; width:240px; background:var(--ink-2); border:1px solid var(--line); border-radius:11px; box-shadow:var(--shadow); overflow:hidden; display:none; z-index:20; }
.mpop.on{ display:block; }
.mpop .mp{ display:flex; align-items:center; gap:9px; padding:9px 12px; font-size:14px; cursor:pointer; }
.mpop .mp.sel,.mpop .mp:hover{ background:var(--ink-3); }

.empty{ text-align:center; color:var(--text-3); margin-top:14vh; }
.empty .big{ font-family:var(--display); font-size:18px; color:var(--text-2); margin-bottom:8px; }

/* modal + toast */
.scrim{ position:fixed; inset:0; background:rgba(6,8,12,.66); backdrop-filter:blur(3px); display:none; place-items:center; padding:24px; z-index:50; overflow-y:auto; }
.scrim.on{ display:grid; }
.modal{ width:100%; max-width:460px; background:var(--ink-2); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); padding:26px; margin:auto; }
.modal h2{ font-family:var(--display); font-size:19px; margin:0 0 8px; }
.modal p{ color:var(--text-2); font-size:14px; line-height:1.6; margin:0 0 16px; }
.modal .row{ margin-top:18px; }
.toast{ position:fixed; bottom:22px; left:50%; transform:translateX(-50%) translateY(20px); background:var(--ink-3); border:1px solid var(--line); color:var(--text); padding:11px 18px; border-radius:10px; font-size:13.5px; box-shadow:var(--shadow); opacity:0; transition:opacity .2s,transform .2s; z-index:60; pointer-events:none; }
.toast.on{ opacity:1; transform:translateX(-50%) translateY(0); }
.banner{ background:rgba(215,169,76,.1); border-bottom:1px solid var(--brass-dim); color:#f1dca6; font-size:12.5px; padding:8px 16px; text-align:center; }

/* admin sheet */
.asheet-scrim{ position:fixed; inset:0; background:rgba(6,8,12,.72); backdrop-filter:blur(4px); display:none; place-items:center; padding:24px; z-index:55; }
.asheet-scrim.on{ display:grid; }
.asheet{ width:100%; max-width:860px; max-height:86vh; background:var(--ink-2); border:1px solid var(--line); border-radius:16px; box-shadow:var(--shadow); display:flex; flex-direction:column; overflow:hidden; }
.asheet-top{ display:flex; align-items:center; justify-content:space-between; padding:18px 22px; border-bottom:1px solid var(--line); }
.asheet-top h2{ font-family:var(--display); margin:0; font-size:18px; display:flex; align-items:center; gap:10px; }
.asheet-top h2 .kdot{ color:var(--brass); }
.asheet-tabs{ display:flex; gap:4px; padding:10px 16px 0; border-bottom:1px solid var(--line); flex-wrap:wrap; }
.atab{ border:none; background:none; color:var(--text-2); font-size:13px; font-weight:600; padding:9px 13px; border-radius:9px 9px 0 0; border-bottom:2px solid transparent; }
.atab.on{ color:var(--text); border-bottom-color:var(--brass); }
.asheet-body{ padding:18px 22px; overflow-y:auto; }
.acard{ background:var(--ink-3); border:1px solid var(--line); border-radius:12px; padding:16px; margin-bottom:14px; }
.acard h3{ font-size:12px; letter-spacing:1.4px; text-transform:uppercase; color:var(--text-3); margin:0 0 12px; }
.arow{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding:9px 0; border-bottom:1px solid var(--line); font-size:14px; flex-wrap:wrap; }
.arow:last-child{ border-bottom:none; }
.arow .who{ display:flex; align-items:center; gap:10px; min-width:0; }
.arow .meta{ color:var(--text-3); font-size:12px; }
.arow .acts{ display:flex; gap:6px; flex-wrap:wrap; }
.toggle{ display:flex; align-items:center; gap:9px; font-size:14px; color:var(--text); cursor:pointer; margin-bottom:8px; }
.toggle input{ width:16px; height:16px; accent-color:var(--brass); }
.ainput{ width:100%; background:var(--ink); border:1px solid var(--line); color:var(--text); border-radius:9px; padding:10px 12px; font-size:14px; margin-bottom:10px; }
textarea.ainput{ min-height:84px; resize:vertical; }
.tag-admin{ font-size:10px; color:var(--brass); border:1px solid var(--brass-dim); border-radius:20px; padding:1px 7px; }
.tag-off{ font-size:10px; color:var(--text-3); border:1px solid var(--line); border-radius:20px; padding:1px 7px; }
.tree{ font-size:13.5px; line-height:1.9; }
.tree .node{ display:flex; align-items:center; gap:8px; }
.tree .kids{ margin-left:18px; border-left:1px solid var(--line); padding-left:14px; }
.pill{ border:1px solid var(--line); background:none; color:var(--text-2); border-radius:8px; padding:4px 10px; font-size:12px; font-weight:600; }
.pill:hover{ color:var(--text); }
.pill-rm{ border:1px solid rgba(226,104,92,.4); background:none; color:var(--danger); border-radius:8px; padding:4px 10px; font-size:12px; font-weight:600; }
.pill-rm:hover{ background:rgba(226,104,92,.1); }

@media (max-width:760px){
  .app.on{ grid-template-columns:1fr; }
  .side{ position:fixed; inset:0 auto 0 0; width:284px; z-index:40; transform:translateX(-100%); transition:transform .22s ease; }
  .side.open{ transform:none; }
  .hamburger{ display:grid; place-items:center; }
  .side-backdrop{ position:fixed; inset:0; background:rgba(0,0,0,.5); z-index:39; }
  .side-backdrop.on{ display:block; }
  .bar .hsub{ max-width:30vw; }
  .inline-img{ max-width:78vw; }
}
@media (prefers-reduced-motion: reduce){ *{ transition:none !important; animation:none !important; } }

/* ---- file cards, notes, privacy list, member menu (client v2 additions) ---- */
.filecard{ background:var(--ink-3); border:1px solid var(--line); border-radius:11px; padding:11px 13px; margin-top:4px; max-width:380px; }
.filehead{ display:flex; align-items:center; gap:9px; font-size:13.5px; }
.fileicon{ flex:0 0 auto; }
.filename{ flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.filesize{ color:var(--text-3); font-size:12px; flex:0 0 auto; }
.fileholder{ margin-top:9px; }
.fileholder .inline-img{ margin-top:0; }
.fileholder a.mini{ display:inline-block; text-decoration:none; padding:7px 13px; }
.note{ font-size:12px; color:var(--brass); margin-top:4px; }
.amenu-h{ font-size:11px; letter-spacing:1.4px; text-transform:uppercase; color:var(--text-3); margin:6px 0 8px; }
.modal .btn.ghost, .modal .btn.danger, .modal .btn{ margin-top:8px; }
.plist{ margin:0 0 14px; padding-left:18px; color:var(--text-2); font-size:13.5px; line-height:1.6; }
.plist li{ margin-bottom:9px; }
.plist b{ color:var(--text); }

/* ============================ OWNER DASHBOARD ============================ */
.owner{ display:none; position:fixed; inset:0; z-index:40; overflow-y:auto;
  background:radial-gradient(1200px 600px at 80% -10%,#182033 0%,transparent 60%),radial-gradient(900px 500px at -10% 110%,#14161f 0%,transparent 55%),var(--ink); }
.owner-bar{ display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:18px 26px; border-bottom:1px solid var(--line); position:sticky; top:0;
  background:rgba(14,17,23,.82); backdrop-filter:blur(8px); z-index:2; }
.owner-brand{ display:flex; align-items:center; gap:12px; }
.owner-brand .hook{ width:26px; height:26px; }
.ob-title{ font-family:var(--display); font-size:17px; letter-spacing:.2px; }
.ob-sub{ font-size:11.5px; color:var(--text-3); text-transform:uppercase; letter-spacing:1.4px; margin-top:2px; }
.owner-body{ max-width:980px; margin:0 auto; padding:26px 22px 60px; }
.owner-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(290px,1fr)); gap:16px; }
.owner-note{ margin-top:22px; padding:14px 16px; border:1px solid var(--line); border-radius:var(--radius);
  background:rgba(20,25,37,.5); color:var(--text-2); font-size:12.5px; line-height:1.55; }
.ocard{ border:1px solid var(--line); border-radius:var(--radius); background:var(--ink-2);
  padding:16px 16px 14px; display:flex; flex-direction:column; gap:9px; transition:border-color .15s; }
.ocard:hover{ border-color:var(--brass-dim); }
.ocard-h{ display:flex; align-items:center; justify-content:space-between; gap:8px; }
.ocard-name{ font-family:var(--display); font-size:16px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.ocard-stats{ font-size:12px; color:var(--text-2); line-height:1.5; }
.ocard-acts{ display:flex; flex-wrap:wrap; gap:6px; margin-top:4px; }
.ocard-acts .mini, .ocard-acts .pill-rm{ flex:0 0 auto; }
@media (max-width:560px){ .owner-bar{ padding:14px 16px; } .owner-grid{ grid-template-columns:1fr; } }
