/* ============ ROIQ OS · estilos ============ */
:root{
  --acc:#6d5efc; --acc-2:#8b7cff; --acc-ink:#fff;
  --green:#16a34a; --green-bg:#e7f7ec;
  --amber:#d97706; --amber-bg:#fdf0dc;
  --blue:#2563eb; --blue-bg:#e6efff;
  --purple:#7c3aed; --purple-bg:#f1ebff;
  --red:#dc2626; --red-bg:#fde7e7;
  --grey:#64748b; --grey-bg:#eef1f6;
  --radius:14px;
}
/* ---------- LIGHT (default) ---------- */
html[data-theme="light"]{
  --bg:#f6f7fb; --panel:#ffffff; --panel-2:#f1f2f7; --panel-3:#e9ebf2;
  --hover:#f1f2f7; --line:#e7e9f0; --line-2:#dfe2ec;
  --ink:#10131a; --ink-2:#5b6172; --ink-3:#8b90a0;
  --sidebar:#0f1219; --sidebar-2:#171b25; --sidebar-line:#232838;
  --sidebar-ink:#b8bdcb; --sidebar-ink-2:#6b7180; --sidebar-active:rgba(109,94,252,.18);
  --shadow:0 1px 2px rgba(16,19,26,.04),0 8px 24px rgba(16,19,26,.06);
  --acc-soft:#efedff;
}
/* ---------- DARK (more dark, near-black) ---------- */
html[data-theme="dark"]{
  --bg:#0a0c10; --panel:#13161d; --panel-2:#1a1e26; --panel-3:#222732;
  --hover:#1c212b; --line:#262b35; --line-2:#2e333f;
  --ink:#e9ebf1; --ink-2:#9aa0ad; --ink-3:#646b78;
  --sidebar:#070809; --sidebar-2:#13161d; --sidebar-line:#1d222b;
  --sidebar-ink:#aab0bd; --sidebar-ink-2:#5e6573; --sidebar-active:rgba(125,110,252,.22);
  --shadow:0 1px 2px rgba(0,0,0,.3),0 8px 24px rgba(0,0,0,.35);
  --acc:#7d6efc; --acc-soft:rgba(125,110,252,.16);
  --green-bg:rgba(34,197,94,.16); --amber-bg:rgba(217,119,6,.18);
  --blue-bg:rgba(59,130,246,.18); --purple-bg:rgba(124,58,237,.2);
  --red-bg:rgba(220,38,38,.18); --grey-bg:rgba(100,116,139,.2);
  --green:#4ade80; --amber:#fbbf24; --blue:#60a5fa; --purple:#b69bff; --red:#f87171; --grey:#94a3b8;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Inter,Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;transition:background .2s,color .2s}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit}
/* selects bonitos (sin cuadritos feos del navegador) */
select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-color:var(--panel);color:var(--ink);border:1px solid var(--line);border-radius:8px;padding:7px 28px 7px 11px;font-size:13px;cursor:pointer;background-image:url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238b90a0' fill='none' stroke-width='1.6' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;transition:border-color .12s}
select:hover{border-color:var(--line-2)} select:focus{border-color:var(--acc);outline:none}
a{color:var(--acc);text-decoration:none}
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:9px}
::-webkit-scrollbar-track{background:transparent}
.mono{font-family:ui-monospace,Menlo,Consolas,monospace}
.hidden{display:none!important}

/* ---------- LOGIN ---------- */
#login{position:fixed;inset:0;z-index:100;background:radial-gradient(1100px 560px at 75% -10%,#1c2030,#0b0d12);display:flex;align-items:center;justify-content:center}
.login-card{width:392px;background:#11151f;border:1px solid #232838;border-radius:20px;padding:36px 32px;box-shadow:0 30px 90px rgba(0,0,0,.55)}
.brand{display:flex;align-items:center;gap:12px;margin-bottom:28px}
.logo{width:40px;height:40px;border-radius:11px;background:linear-gradient(135deg,var(--acc),#b39bff);display:grid;place-items:center;font-weight:800;color:#fff;font-size:15px;letter-spacing:-.5px}
.brand b{color:#fff;font-size:17px;letter-spacing:-.2px}
.brand span{color:#6b7180;font-size:10.5px;display:block;font-weight:600;letter-spacing:.16em;text-transform:uppercase}
.login-card h2{color:#fff;font-size:21px;margin-bottom:5px;letter-spacing:-.4px}
.login-card p.sub{color:#7c8294;font-size:13px;margin-bottom:24px}
.gbtn{width:100%;background:#fff;color:#1a1a1a;padding:12px;border-radius:11px;font-weight:600;font-size:14px;display:flex;align-items:center;justify-content:center;gap:10px}
.gbtn:hover{filter:brightness(.96)}
.gbtn .g{width:18px;height:18px;border-radius:50%;background:conic-gradient(from -45deg,#ea4335 0 25%,#fbbc05 0 50%,#34a853 0 75%,#4285f4 0)}
.or{display:flex;align-items:center;gap:12px;color:#5a6072;font-size:11px;margin:18px 0}
.or::before,.or::after{content:"";flex:1;height:1px;background:#232838}
.fld{margin-bottom:13px}
.fld label{color:#9aa0b2;font-size:12px;display:block;margin-bottom:6px;font-weight:500}
.fld input{width:100%;background:#0c0f17;border:1px solid #262d40;color:#fff;padding:11px 13px;border-radius:10px;font-size:14px;outline:none}
.fld input:focus{border-color:var(--acc)}
.btn-primary{width:100%;background:linear-gradient(135deg,var(--acc),#8b7cff);color:#fff;padding:12px;border-radius:11px;font-weight:700;font-size:14px;margin-top:6px}
.btn-primary:hover{filter:brightness(1.06)}
.login-foot{text-align:center;color:#5a6072;font-size:11px;margin-top:20px}

/* ---------- APP SHELL ---------- */
#app{display:none;height:100vh;grid-template-columns:252px 1fr;transition:grid-template-columns .18s}
#app.sb-collapsed{grid-template-columns:1fr}
#app.sb-collapsed .sidebar{display:none}
#sbShow{position:fixed;top:9px;left:9px;z-index:60;display:none;width:34px;height:34px;border-radius:9px;background:var(--panel);border:1px solid var(--line);color:var(--ink-2);font-size:16px;cursor:pointer;box-shadow:var(--shadow)}
#app.sb-collapsed #sbShow{display:grid;place-items:center}
#sbHide:hover{background:var(--sidebar-2);color:#fff}
.page-emoji{cursor:pointer;border-radius:8px;padding:0 2px}
.page-emoji:hover{background:var(--panel-2)}
.doc.wide,.page-title.wide,.space-blocks.wide{max-width:1100px!important}
.sidebar{background:var(--sidebar);color:var(--sidebar-ink);display:flex;flex-direction:column;border-right:1px solid var(--sidebar-line)}
.ws{padding:14px;display:flex;align-items:center;gap:11px;border-bottom:1px solid var(--sidebar-line)}
.ws .logo{width:32px;height:32px;font-size:12px;border-radius:9px}
.ws b{color:#fff;font-size:13.5px;letter-spacing:-.1px}
.ws span{font-size:10px;color:var(--sidebar-ink-2)}
.nav{flex:1;overflow:auto;padding:10px 8px;display:flex;flex-direction:column;min-height:0}
.nav-sec{font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--sidebar-ink-2);font-weight:700;padding:15px 10px 6px;display:flex;align-items:center}
.nav-sec .add{margin-left:auto;cursor:pointer;font-size:14px;color:var(--sidebar-ink-2);width:18px;height:18px;display:grid;place-items:center;border-radius:5px}
.nav-sec .add:hover{background:var(--sidebar-2);color:#fff}
.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:9px;font-size:13.5px;color:var(--sidebar-ink);cursor:pointer;transition:.12s;position:relative}
.nav-item:hover{background:var(--sidebar-2);color:#fff}
.nav-item.active{background:var(--sidebar-active);color:#fff}
.nav-item.active::before{content:"";position:absolute;left:0;top:7px;bottom:7px;width:3px;border-radius:3px;background:var(--acc)}
.nav-item .ico{width:18px;text-align:center;font-size:14px}
.nav-item .badge{margin-left:auto;background:var(--acc);color:#fff;font-size:10px;font-weight:700;padding:1px 7px;border-radius:20px}
.nav-item .badge.soon{background:var(--sidebar-2);color:var(--sidebar-ink-2)}
.nav-sub{padding-left:14px}
.nav-sub .nav-item{font-size:13px;color:var(--sidebar-ink)}
.sidebar-foot{border-top:1px solid var(--sidebar-line);padding:10px;display:flex;align-items:center;gap:10px}
.av{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:11px;flex-shrink:0}
.sidebar-foot .nm{font-size:12.5px;color:#fff;font-weight:600}
.sidebar-foot .rl{font-size:10.5px;color:var(--sidebar-ink-2)}

/* ---------- MAIN ---------- */
.main{display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}
.topbar{height:54px;background:var(--panel);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;padding:0 22px;flex-shrink:0}
.crumb{font-size:13px;color:var(--ink-2)}
.crumb b{color:var(--ink)}
.search{margin-left:auto;display:flex;align-items:center;gap:8px;background:var(--panel-2);border:1px solid var(--line);border-radius:9px;padding:7px 12px;width:260px;color:var(--ink-3);font-size:13px}
.icobtn{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;color:var(--ink-2);font-size:15px}
.icobtn:hover{background:var(--panel-2)}
.content{flex:1;overflow:auto;padding:26px 32px 70px}
.view{display:none;animation:fade .22s ease}
.view.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
h1.page{font-size:26px;letter-spacing:-.5px;margin-bottom:4px;display:flex;align-items:center;gap:11px;color:var(--ink)}
h1.page .emoji{font-size:25px}
.page-sub{color:var(--ink-2);font-size:13.5px;margin-bottom:24px}
.row{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.pad{padding:18px 20px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
h3.sec{font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-2);font-weight:700;margin:28px 0 13px;display:flex;align-items:center;gap:8px}
.pill{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;padding:3px 10px;border-radius:7px;white-space:nowrap}
.pill.g{background:var(--green-bg);color:var(--green)} .pill.a{background:var(--amber-bg);color:var(--amber)}
.pill.b{background:var(--blue-bg);color:var(--blue)} .pill.p{background:var(--purple-bg);color:var(--purple)}
.pill.r{background:var(--red-bg);color:var(--red)} .pill.grey{background:var(--grey-bg);color:var(--grey)}
.pill.acc{background:var(--acc-soft);color:var(--acc)}
.btn{display:inline-flex;align-items:center;gap:7px;background:var(--acc);color:#fff;padding:9px 15px;border-radius:9px;font-size:13px;font-weight:600;transition:.12s}
.btn:hover{filter:brightness(1.07)}
.btn.ghost{background:var(--panel-2);color:var(--ink);border:1px solid var(--line)}
.btn.sm{padding:6px 11px;font-size:12px}
.btn.danger{background:var(--red-bg);color:var(--red)}

.stat .lab{font-size:12.5px;color:var(--ink-2);font-weight:500;display:flex;align-items:center;gap:8px}
.stat .num{font-size:30px;font-weight:800;letter-spacing:-1px;margin-top:8px;color:var(--ink)}
.stat .delta{font-size:12px;font-weight:600;margin-top:4px}
.delta.up{color:var(--green)} .delta.down{color:var(--red)}
.sparkline{height:40px;margin-top:12px;display:flex;align-items:flex-end;gap:4px}
.sparkline span{flex:1;background:linear-gradient(180deg,var(--acc-2),var(--acc));border-radius:3px 3px 0 0;opacity:.85}
.quick{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:12px;border:1px solid var(--line);background:var(--panel);transition:.12s;cursor:pointer}
.quick:hover{border-color:var(--acc);transform:translateY(-1px);box-shadow:var(--shadow)}
.quick .qi{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;font-size:19px;flex-shrink:0}
.quick .qt{font-weight:600;font-size:13.5px;color:var(--ink)} .quick .qd{font-size:11.5px;color:var(--ink-2)}
.banner{background:linear-gradient(120deg,#11151f,#1c2233);border-radius:16px;padding:22px 26px;color:#fff;display:flex;align-items:center;gap:20px;margin-bottom:24px}
.banner .bt{font-size:18px;font-weight:700} .banner .bd{font-size:13px;color:#aab0c0;margin-top:3px;max-width:560px}

/* doc / notion blocks */
.doc{max-width:760px}
.block{padding:4px 0;font-size:15px;line-height:1.6;color:var(--ink);display:flex;gap:9px;align-items:flex-start}
.block .bc{flex:1;outline:none;min-height:1.4em;border-radius:4px;padding:2px 4px}
.block .bc:focus{background:var(--panel-2)}
.block .bc:empty::before{content:attr(data-ph);color:var(--ink-3)}
.block.h1 .bc{font-size:24px;font-weight:800;letter-spacing:-.5px}
.block.h2 .bc{font-size:19px;font-weight:700}
.block.todo input{margin-top:6px;width:16px;height:16px;accent-color:var(--acc)}
.block.bullet .bc::before{content:"•  ";color:var(--ink-3)}
.block .handle{color:var(--ink-3);font-size:12px;opacity:0;margin-top:5px;cursor:grab;user-select:none}
.block:hover .handle{opacity:.6}
.add-block{color:var(--ink-3);font-size:13px;cursor:pointer;padding:6px 4px;display:inline-flex;gap:7px;align-items:center}
.add-block:hover{color:var(--acc)}
.callout{background:var(--acc-soft);border:1px solid var(--line);border-radius:11px;padding:14px 16px;display:flex;gap:11px;font-size:13.5px;margin:14px 0;line-height:1.5;color:var(--ink)}
.callout.info{background:var(--blue-bg)}
.tag{display:inline-block;background:var(--panel-3);color:var(--ink-2);font-size:11.5px;padding:2px 9px;border-radius:6px;font-weight:600;margin-right:6px}

/* tabs */
.vtabs{display:flex;align-items:center;gap:4px;border-bottom:1px solid var(--line);margin-bottom:18px;flex-wrap:wrap}
.vtab{padding:8px 12px;font-size:13px;color:var(--ink-2);border-bottom:2px solid transparent;cursor:pointer;display:flex;align-items:center;gap:6px;font-weight:500}
.vtab:hover{color:var(--ink)}
.vtab.active{color:var(--ink);border-bottom-color:var(--acc)}

/* kanban */
.kanban{display:flex;gap:12px;align-items:flex-start;overflow-x:auto;padding-bottom:12px}
.col{flex:0 0 246px;width:246px;background:var(--panel-2);border:1px solid var(--line);border-radius:12px;padding:10px;min-height:80px}
.col.drop{outline:2px dashed var(--acc);outline-offset:-2px}
.col h4{font-size:12.5px;font-weight:600;display:flex;align-items:center;gap:7px;padding:4px 4px 11px;color:var(--ink)}
.col h4 .ct{margin-left:auto;background:var(--panel-3);color:var(--ink-2);font-size:10.5px;padding:1px 8px;border-radius:20px;font-weight:700}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.kc{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:11px 12px;margin-bottom:9px;cursor:pointer;transition:.1s;box-shadow:var(--shadow)}
.kc:hover{border-color:var(--acc);transform:translateY(-1px)}
.kc.dragging{opacity:.4}
.kc .kcode{font-family:ui-monospace,Menlo,monospace;font-size:13px;font-weight:700;color:var(--ink);margin-bottom:8px}
.kc .meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.kc .doc-ico{font-size:11px;color:var(--ink-3);display:flex;align-items:center;gap:5px;margin-bottom:7px}
.mini-av{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:9.5px;color:#fff;font-weight:700;flex-shrink:0}
.asg{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--ink-2);margin-bottom:7px}

/* table */
.tablewrap{overflow:auto;border-radius:12px}
table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3);font-weight:700;padding:11px 14px;border-bottom:1px solid var(--line);white-space:nowrap}
td{padding:11px 14px;border-bottom:1px solid var(--line);color:var(--ink)}
tr:last-child td{border-bottom:none}
tbody tr:hover td{background:var(--panel-2)}
.lnk{color:var(--blue);font-family:ui-monospace,monospace;font-size:12px}
.fnum{font-family:ui-monospace,monospace;font-weight:700;color:var(--acc)}

/* prop panel */
.prop{display:grid;grid-template-columns:200px 1fr}
.pk{padding:11px 14px;color:var(--ink-2);font-size:13px;display:flex;align-items:center;gap:9px;border-bottom:1px solid var(--line)}
.pv{padding:11px 14px;font-size:13.5px;color:var(--ink);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.empty-v{color:var(--ink-3)}
.pv input{width:100%;border:1px solid transparent;background:none;outline:none;color:var(--ink);font-size:13.5px;padding:5px 7px;border-radius:7px;transition:border-color .1s}
.pv input:hover{border-color:var(--line)} .pv input:focus{border-color:var(--acc);background:var(--panel)}
.backlink{color:var(--ink-2);font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;margin-bottom:14px}
.backlink:hover{color:var(--acc)}

/* naming */
.gen-tabs{display:flex;gap:8px;margin-bottom:18px}
.gen-tab{padding:9px 16px;border-radius:10px;background:var(--panel);border:1px solid var(--line);font-size:13px;font-weight:600;color:var(--ink-2);cursor:pointer}
.gen-tab.active{background:var(--acc-soft);border-color:var(--acc);color:var(--acc)}
.gen-wrap{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{margin-bottom:14px}
.field label{font-size:12px;font-weight:600;color:var(--ink-2);display:block;margin-bottom:6px}
.field select,.field input,.field textarea{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:9px;font-size:13.5px;background:var(--panel);color:var(--ink);outline:none}
.field select:focus,.field input:focus{border-color:var(--acc)}
.grid-22{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.output{background:linear-gradient(135deg,#11151f,#1c2233);border-radius:14px;padding:22px;color:#fff}
.output .cap{font-size:10.5px;color:#6b7180;text-transform:uppercase;letter-spacing:.12em;margin-bottom:10px}
.output .gen-name{font-family:ui-monospace,Menlo,monospace;font-size:22px;color:#9ee7c5;word-break:break-all;line-height:1.5;font-weight:700}
.output .parts{display:flex;flex-wrap:wrap;gap:6px;margin-top:16px}
.output .parts span{background:#1a1f2e;border:1px solid #2a3142;color:#aab0c0;font-size:11px;padding:4px 9px;border-radius:7px;font-family:ui-monospace,monospace}
.output .parts span b{color:#fff}
.copybtn{background:#fff;color:#11151f;padding:9px 15px;border-radius:9px;font-size:12.5px;font-weight:700;margin-top:18px;display:inline-flex;gap:7px;align-items:center}
.legend{font-size:12px;color:var(--ink-2);line-height:1.7;margin-top:14px}
.legend b{color:var(--acc)}

/* embeds & shortcuts */
.embed{aspect-ratio:16/9;border-radius:12px;background:linear-gradient(135deg,#1a1f2e,#0f1219);display:grid;place-items:center;position:relative;overflow:hidden;border:1px solid var(--line)}
.embed.miro{background:linear-gradient(135deg,#fff6da,#ffe9a8)}
.play{width:56px;height:56px;border-radius:50%;background:rgba(255,255,255,.95);display:grid;place-items:center;font-size:20px;color:var(--acc)}
.embed.miro .play{color:#9a7b00}
.embed .lbl{position:absolute;bottom:10px;left:12px;color:#fff;font-size:12px;font-weight:600;background:rgba(0,0,0,.5);padding:3px 9px;border-radius:7px}
.embed.miro .lbl{color:#5b4b00;background:rgba(255,255,255,.7)}
.sc{display:flex;align-items:center;gap:13px;padding:13px 15px;border:1px solid var(--line);border-radius:12px;background:var(--panel);transition:.12s;cursor:pointer}
.sc:hover{border-color:var(--acc);transform:translateY(-1px)}
.sc .ic{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;font-size:19px;flex-shrink:0}
.sc .t{font-weight:600;font-size:13.5px;color:var(--ink)} .sc .d{font-size:11.5px;color:var(--ink-2)}
.sc .arr{margin-left:auto;color:var(--ink-3)}

.members{display:flex;flex-direction:column}
.mrow{display:flex;align-items:center;gap:12px;padding:12px 4px;border-bottom:1px solid var(--line)}
.mrow:last-child{border:none}
.mrow .nm{font-weight:600;font-size:13.5px;color:var(--ink)} .mrow .em{font-size:12px;color:var(--ink-2)}
.note{font-size:12px;color:var(--ink-3);margin-top:5px}
.proj-tile{cursor:pointer}
.proj-tile.new{border-style:dashed;display:grid;place-items:center;min-height:120px;color:var(--ink-2);font-weight:600}
.proj-tile.new:hover{color:var(--acc);border-color:var(--acc)}

/* modal */
.modal-bg{position:fixed;inset:0;background:rgba(8,10,15,.55);z-index:90;display:none;align-items:center;justify-content:center;backdrop-filter:blur(2px)}
.modal-bg.open{display:flex}
.modal{width:440px;max-width:94vw;max-height:86vh;overflow-y:auto;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:24px;box-shadow:0 30px 80px rgba(0,0,0,.4)}
.modal h3{font-size:17px;margin-bottom:4px;color:var(--ink)}
.modal p{font-size:13px;color:var(--ink-2);margin-bottom:18px}
.modal .actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}
.emoji-pick{display:flex;gap:5px;flex-wrap:wrap;margin-top:6px;max-height:220px;overflow:auto;padding:2px}
.emoji-pick span{width:34px;height:34px;display:grid;place-items:center;border-radius:8px;border:1px solid var(--line);cursor:pointer;font-size:17px}
.emoji-pick span.sel{border-color:var(--acc);background:var(--acc-soft)}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:#11151f;color:#fff;padding:11px 18px;border-radius:10px;font-size:13px;z-index:120;opacity:0;transition:.25s;pointer-events:none}
.toast.show{opacity:1}

/* search */
.searchbox{margin-left:auto;position:relative;display:flex;align-items:center;gap:8px;background:var(--panel-2);border:1px solid var(--line);border-radius:9px;padding:0 12px;width:300px}
.searchbox span{color:var(--ink-3);font-size:13px}
.searchbox input{flex:1;border:none;background:none;outline:none;color:var(--ink);font-size:13px;padding:8px 0}
.search-results{position:absolute;top:42px;left:0;right:0;background:var(--panel);border:1px solid var(--line);border-radius:11px;box-shadow:var(--shadow);max-height:380px;overflow:auto;z-index:60;padding:6px}
.sr-item{display:flex;align-items:center;gap:9px;padding:9px 11px;border-radius:8px;cursor:pointer;font-size:13px}
.sr-item:hover{background:var(--panel-2)}
.sr-item .k{font-size:10px;color:var(--ink-3);margin-left:auto;text-transform:uppercase;letter-spacing:.04em}
.sr-empty{padding:14px;color:var(--ink-3);font-size:13px;text-align:center}

/* bell */
.bell-panel{position:absolute;top:42px;right:0;width:300px;background:var(--panel);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);z-index:60;padding:8px}
.bell-panel .bp-h{font-size:12px;font-weight:700;color:var(--ink-2);padding:8px 10px;text-transform:uppercase;letter-spacing:.06em}
.bell-panel .bp-row{display:flex;gap:9px;align-items:flex-start;padding:9px 10px;border-radius:8px;font-size:13px}
.bell-panel .bp-row:hover{background:var(--panel-2)}

/* slash menu */
.slash-menu{position:absolute;z-index:130;width:248px;background:var(--panel);border:1px solid var(--line);border-radius:11px;box-shadow:var(--shadow);padding:6px;max-height:300px;overflow:auto}
.slash-item{display:flex;align-items:center;gap:11px;padding:8px 10px;border-radius:8px;cursor:pointer}
.slash-item.sel,.slash-item:hover{background:var(--acc-soft)}
.slash-item .si-ic{width:30px;height:30px;border-radius:7px;display:grid;place-items:center;background:var(--panel-2);font-size:14px;flex-shrink:0}
.slash-item .si-t{font-size:13px;font-weight:600;color:var(--ink)} .slash-item .si-d{font-size:11px;color:var(--ink-3)}

/* format bar */
.format-bar{position:absolute;z-index:130;background:#11151f;border:1px solid #2a3142;border-radius:9px;display:flex;align-items:center;padding:3px;gap:1px;box-shadow:0 8px 24px rgba(0,0,0,.4)}
.format-bar button{color:#e6e9f0;width:32px;height:30px;border-radius:6px;font-size:14px;font-weight:700}
.format-bar button:hover{background:#2a3142}
.format-bar .sep{width:1px;height:18px;background:#2a3142;margin:0 3px}

/* embed blocks */
.embed-block{margin:10px 0;border:1px solid var(--line);border-radius:11px;overflow:hidden;background:var(--panel-2)}
.embed-block .eb-bar{display:flex;align-items:center;gap:8px;padding:7px 10px;font-size:11.5px;color:var(--ink-2);border-bottom:1px solid var(--line)}
.embed-block .eb-bar .sp{margin-left:auto;display:flex;gap:6px}
.embed-block .eb-bar button{font-size:11px;color:var(--ink-2);padding:3px 8px;border-radius:6px;border:1px solid var(--line)}
.embed-block .eb-bar button:hover{color:var(--acc);border-color:var(--acc)}
.embed-block iframe{width:100%;border:none;display:block;background:#000}
.embed-block.miro iframe{height:420px} .embed-block.loom iframe{aspect-ratio:16/9;height:auto}

/* config + / - on resources */
.sec-add{margin-left:auto;display:inline-flex;gap:6px}
.chipbtn{width:26px;height:26px;border-radius:7px;border:1px solid var(--line);color:var(--ink-2);display:grid;place-items:center;font-size:15px;background:var(--panel)}
.chipbtn:hover{border-color:var(--acc);color:var(--acc)}
.sc .del,.card .del-x{margin-left:8px;color:var(--ink-3);cursor:pointer;font-size:14px}
.sc .del:hover{color:var(--red)}
.col-cfg{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.col-cfg input{flex:1;padding:7px 10px;border:1px solid var(--line);border-radius:8px;background:var(--panel);color:var(--ink);font-size:13px}
.col-cfg .dotpick{width:26px;height:26px;border-radius:50%;border:2px solid var(--line);cursor:pointer}
.tabsrow{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px}
.ctab{padding:7px 13px;border-radius:8px;border:1px solid var(--line);font-size:13px;font-weight:600;color:var(--ink-2);cursor:pointer;background:var(--panel)}
.ctab.active{background:var(--acc-soft);border-color:var(--acc);color:var(--acc)}
.mact{display:inline-flex;gap:6px;align-items:center}
.mrow .mact{margin-left:8px}
.mact button{font-size:11.5px;color:var(--ink-2);padding:4px 9px;border-radius:7px;border:1px solid var(--line);background:var(--panel);white-space:nowrap}
.mact button:hover{border-color:var(--acc);color:var(--acc)}
.mact button.danger:hover{border-color:var(--red);color:var(--red)}

/* más colores de pill */
.pill.t{background:rgba(13,148,136,.16);color:#0d9488}
.pill.o{background:rgba(234,88,12,.16);color:#ea580c}
.pill.pk{background:rgba(219,39,119,.16);color:#db2777}
html[data-theme="dark"] .pill.t{color:#2dd4bf} html[data-theme="dark"] .pill.o{color:#fb923c} html[data-theme="dark"] .pill.pk{color:#f472b6}

/* pill-select (propiedad clicable) */
.pill-select{cursor:pointer;border:1px dashed transparent}
.pill-select:hover{border-color:var(--line-2)}
.pill-empty{cursor:pointer;color:var(--ink-3);font-size:12.5px;border:1px dashed var(--line);padding:3px 10px;border-radius:7px}
.pill-empty:hover{border-color:var(--acc);color:var(--acc)}
/* pop menu flotante */
.pop-menu{position:fixed;z-index:140;min-width:180px;background:var(--panel);border:1px solid var(--line);border-radius:11px;box-shadow:var(--shadow);padding:6px}
.pop-menu .pm-item{display:flex;align-items:center;gap:9px;padding:7px 9px;border-radius:8px;cursor:pointer;font-size:13px}
.pop-menu .pm-item:hover{background:var(--panel-2)}
.swatch{width:16px;height:16px;border-radius:5px;flex-shrink:0;cursor:pointer;border:1px solid rgba(0,0,0,.15)}

/* option editor (config) */
.opt-row{display:flex;align-items:center;gap:8px;margin-bottom:7px}
.opt-row input{flex:1;padding:6px 9px;border:1px solid var(--line);border-radius:7px;background:var(--panel);color:var(--ink);font-size:12.5px}
.opt-row .swatch{width:24px;height:24px}

/* list view */
.lv-status{display:flex;align-items:center;gap:7px;margin:18px 0 8px;font-weight:700;font-size:13px}
.lv-status .ct{background:var(--panel-3);color:var(--ink-2);font-size:10.5px;padding:1px 8px;border-radius:20px}

/* batch preview */
.batch-prev{background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:12px;max-height:200px;overflow:auto;font-family:ui-monospace,monospace;font-size:12px;color:var(--ink-2);line-height:1.7}
.team-dot{width:11px;height:11px;border-radius:50%;display:inline-block;margin-right:7px;vertical-align:middle}

/* árbol lateral */
.nav-caret{display:inline-block;width:15px;text-align:center;font-size:9px;color:var(--sidebar-ink-2);transition:transform .12s;cursor:pointer;flex-shrink:0}
.nav-caret.open{transform:rotate(90deg)}
.nav-spacer{display:inline-block;width:15px;flex-shrink:0}
.nav-item .ttl{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nav-item .add{margin-left:auto;opacity:0;font-size:14px;width:18px;height:18px;display:grid;place-items:center;border-radius:5px;color:var(--sidebar-ink-2)}
.nav-item:hover .add{opacity:1}
.nav-item .add:hover{background:var(--sidebar-2);color:#fff}
.nav-sec .add{margin-left:auto;cursor:pointer;font-size:14px}

/* bloque subpágina */
.pageref{display:flex;align-items:center;gap:9px;padding:7px 6px;border-radius:7px;cursor:pointer;font-size:15px;color:var(--ink);font-weight:500}
.pageref:hover{background:var(--panel-2)}
.pageref .pr-ic{font-size:16px}
.page-title{font-size:28px;font-weight:800;letter-spacing:-.6px;outline:none;border-radius:6px;padding:2px 4px;margin-bottom:4px}
.page-title:focus{background:var(--panel-2)}
.crumbs{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--ink-2);margin-bottom:10px;flex-wrap:wrap}
.crumbs a{cursor:pointer;color:var(--ink-2)} .crumbs a:hover{color:var(--acc)}

/* matriz de visibilidad */
.vis-table{width:100%;border-collapse:collapse;font-size:13px}
.vis-table th,.vis-table td{padding:9px 12px;border-bottom:1px solid var(--line);text-align:center}
.vis-table th:first-child,.vis-table td:first-child{text-align:left}
.vis-table input{width:17px;height:17px;accent-color:var(--acc);cursor:pointer}
.item-card{cursor:pointer}
.card-del{position:absolute;top:8px;right:10px;width:22px;height:22px;border-radius:6px;display:grid;place-items:center;color:var(--ink-3);font-size:13px;opacity:0;transition:.12s}
.item-card:hover .card-del,.kc:hover .card-del{opacity:1}
.card-del:hover{background:var(--red-bg);color:var(--red)}

/* reorden en sidebar */
.nav-item[draggable="true"]{cursor:default}
.nav-item.nav-drag{opacity:.4}
.nav-item.nav-over{box-shadow:inset 0 2px 0 var(--acc)}

/* tabla editable (vista base de datos) */
.dtable{width:100%;border-collapse:collapse;font-size:13px;background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.dtable th{background:var(--panel-2);text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-3);font-weight:700;padding:9px 12px;border-bottom:1px solid var(--line);white-space:nowrap}
.dtable td{padding:6px 12px;border-bottom:1px solid var(--line);border-right:1px solid var(--line)}
.dtable td:last-child{border-right:none}
.dtable tr:last-child td{border-bottom:none}
.dtable input.cell{width:100%;border:none;background:none;outline:none;color:var(--ink);font-size:13px;padding:3px}
.dtable input.cell:focus{background:var(--panel-2);border-radius:5px}
.dtable .cellpill{cursor:pointer;display:inline-flex;min-height:22px;align-items:center}
.dtable .cellpill .pill-empty{font-size:11px}
.dtable .addrow{padding:9px 12px;color:var(--ink-3);font-size:13px;cursor:pointer}
.dtable .addrow:hover{color:var(--acc)}
.space-blocks{max-width:820px;margin-bottom:8px}
