/* ============ 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; --radius-sm:9px; --radius-lg:18px;
  --ease:cubic-bezier(.32,.72,0,1); --ease-out:cubic-bezier(.16,1,.3,1);
  --ring:0 0 0 3px rgba(109,94,252,.32);
}
/* ---------- LIGHT (default) ---------- */
html[data-theme="light"]{
  --bg:#f7f7f8; --panel:#ffffff; --panel-2:#f4f4f6; --panel-3:#ececef;
  --hover:#f3f3f5; --line:#ececee; --line-2:#e2e2e6;
  --ink:#1a1b1f; --ink-2:#5f6068; --ink-3:#96979e;
  --sidebar:#0e0f12; --sidebar-2:#191a1f; --sidebar-line:#24262c;
  --sidebar-ink:#bcbdc4; --sidebar-ink-2:#6e6f78; --sidebar-active:rgba(109,94,252,.2);
  --shadow:0 1px 2px rgba(16,19,26,.04),0 8px 24px rgba(16,19,26,.06);
  --shadow-sm:0 1px 2px rgba(16,19,26,.05),0 1px 1px rgba(16,19,26,.03);
  --shadow-md:0 2px 4px rgba(16,19,26,.05),0 10px 26px rgba(16,19,26,.08);
  --shadow-lg:0 12px 28px rgba(16,19,26,.1),0 40px 80px rgba(16,19,26,.12);
  --acc-soft:#efedff;
}
/* ---------- DARK (more dark, near-black) ---------- */
html[data-theme="dark"]{
  --bg:#0d0d10; --panel:#17171a; --panel-2:#1e1e22; --panel-3:#26262b;
  --hover:#202024; --line:#28282d; --line-2:#323238;
  --ink:#ececef; --ink-2:#9fa0a8; --ink-3:#6a6b73;
  --sidebar:#141417; --sidebar-2:#1f1f24; --sidebar-line:#2a2a30;
  --sidebar-ink:#c2c3cb; --sidebar-ink-2:#74757e; --sidebar-active:rgba(125,110,252,.22);
  --shadow:0 1px 2px rgba(0,0,0,.3),0 8px 24px rgba(0,0,0,.35);
  --shadow-sm:0 1px 2px rgba(0,0,0,.35);
  --shadow-md:0 2px 6px rgba(0,0,0,.35),0 12px 30px rgba(0,0,0,.4);
  --shadow-lg:0 16px 40px rgba(0,0,0,.5),0 40px 90px rgba(0,0,0,.55);
  --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:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-feature-settings:"cv02","cv03","cv04","ss01";letter-spacing:-.006em;transition:background .2s,color .2s}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;transition:filter .14s,background .14s,transform .12s,border-color .14s}
button:active{transform:translateY(.5px) scale(.985)}
/* foco accesible para teclado */
:focus-visible{outline:none;box-shadow:var(--ring)}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[contenteditable]:focus-visible,.nav-item:focus-visible{border-radius:8px}
/* respeta usuarios que prefieren menos movimiento */
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}
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 (usa tokens del tema → coincide con la app en claro/oscuro) ---------- */
#login{position:fixed;inset:0;z-index:100;background:radial-gradient(900px 480px at 50% -8%,var(--acc-soft),transparent 60%),var(--bg);display:flex;align-items:center;justify-content:center;padding:20px}
.login-card{width:404px;max-width:94vw;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);padding:38px 34px;box-shadow:var(--shadow-lg);animation:modalIn .32s var(--ease-out)}
.brand{display:flex;align-items:center;gap:12px;margin-bottom:28px}
.logo{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,var(--acc),var(--acc-2));display:grid;place-items:center;font-weight:800;color:#fff;font-size:15px;letter-spacing:-.5px}
.brand .logo{box-shadow:0 6px 18px rgba(109,94,252,.34)}
.brand b{color:var(--ink);font-size:17px;letter-spacing:-.2px}
.brand span{color:var(--ink-3);font-size:10.5px;display:block;font-weight:700;letter-spacing:.16em;text-transform:uppercase}
.login-card h2{color:var(--ink);font-size:22px;margin-bottom:5px;letter-spacing:-.5px;font-weight:800}
.login-card p.sub{color:var(--ink-2);font-size:13px;margin-bottom:24px}
.gbtn{width:100%;background:var(--panel-2);color:var(--ink);border:1px solid var(--line);padding:12px;border-radius:11px;font-weight:600;font-size:14px;display:flex;align-items:center;justify-content:center;gap:10px}
.gbtn:hover{background:var(--hover)}
.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:var(--ink-3);font-size:11px;margin:18px 0}
.or::before,.or::after{content:"";flex:1;height:1px;background:var(--line)}
.fld{margin-bottom:14px}
.fld label{color:var(--ink-2);font-size:12px;display:block;margin-bottom:6px;font-weight:600}
.fld input{width:100%;background:var(--panel-2);border:1px solid var(--line);color:var(--ink);padding:11px 13px;border-radius:10px;font-size:14px;outline:none;transition:border-color .14s,box-shadow .14s}
.fld input::placeholder{color:var(--ink-3)}
.fld input:focus{border-color:var(--acc);box-shadow:var(--ring)}
.btn-primary{width:100%;background:linear-gradient(135deg,var(--acc),var(--acc-2));color:#fff;padding:12px;border-radius:11px;font-weight:700;font-size:14px;margin-top:8px;box-shadow:0 6px 16px rgba(109,94,252,.3);transition:filter .14s,transform .12s}
.btn-primary:hover{filter:brightness(1.06);transform:translateY(-1px)}
.btn-primary:active{transform:translateY(0)}
.login-foot{text-align:center;color:var(--ink-3);font-size:11px;margin-top:20px;line-height:1.6}

/* ---------- 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:20px;height:20px;display:grid;place-items:center;flex-shrink:0;color:var(--sidebar-ink-2)}
.nav-item:hover .ico,.nav-item.active .ico{color:var(--acc-2)}
.ic-svg{display:block}
.nav-item .ico svg{width:18px;height:18px}
.icobtn svg,.searchbox span svg{display:block}
.icobtn[data-ico]{color:var(--ink-2)}
.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)}
.btn svg,.lockbtn svg{flex-shrink:0}
.lockbtn.on{background:var(--acc-soft);color:var(--acc);border-color:transparent}
.lockbtn.on:hover{background:var(--acc-soft);filter:brightness(.97)}

.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;margin:0 auto}
.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:empty::before{content:attr(data-ph);color:var(--ink-3);pointer-events:none}
.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{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
/* candado en el sidebar (al lado del nombre) */
.nav-lock{opacity:0;width:19px;height:19px;display:grid;place-items:center;border-radius:5px;color:var(--sidebar-ink-2);flex-shrink:0;transition:opacity .12s,background .12s,color .12s}
.nav-item:hover .nav-lock{opacity:.6}
.nav-lock:hover{opacity:1;background:var(--sidebar-2);color:#fff}
.nav-lock.on{opacity:.95;color:var(--acc-2)}
.nav-lock svg{display:block}
.nav-item:hover .nav-lock+.add,.nav-item .nav-lock+.add{margin-left:2px}
/* chip de "bloqueada" en el encabezado */
.lock-chip{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;color:var(--ink-2);background:var(--panel-2);border:1px solid var(--line);padding:3px 9px;border-radius:7px}
.lock-chip svg{display:block}
.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}
.vis-ic{display:inline-grid;place-items:center;vertical-align:-3px;color:var(--acc)}
.vis-ic svg,.vis-table svg{display:block}
.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}
/* ===== home del espacio: una columna unificada, centrada o full ===== */
.space-wrap{max-width:760px;margin:0 auto}
.space-wrap.wide{max-width:1100px}
.sp-toolbar{display:flex;align-items:center;justify-content:flex-end;gap:8px;min-height:30px;margin-bottom:6px}
.sp-bigicon{display:inline-grid;place-items:center;font-size:42px;line-height:1;width:56px;height:56px;border-radius:13px;margin-bottom:4px}
.sp-bigicon.clickable{cursor:pointer;transition:background .12s}
.sp-bigicon.clickable:hover{background:var(--panel-2)}
.sp-desc{margin:4px 0 18px;min-height:20px;padding:2px 4px}
.grid-dyn{display:grid;gap:16px}
/* editor-galería: tarjetas de contenido + bloques de texto en una misma columna; texto = fila completa, tarjetas = N columnas */
.ed-gallery{display:flex;flex-wrap:wrap;gap:14px;align-items:flex-start}
.ed-gallery>.block-wrap{width:100%}
.ed-gallery>.add-block{width:100%;opacity:.5;transition:opacity .12s}
.ed-gallery:hover>.add-block{opacity:.85}
.ed-gallery>.block-wrap.is-item{width:calc((100% - (var(--cols,3) - 1) * 14px) / var(--cols,3));position:relative}
.ed-gallery>.block-wrap.is-item>.b-gutter{position:absolute;left:3px;top:3px;width:auto;padding:0;z-index:3;opacity:0;background:var(--panel-2);border-radius:6px}
.ed-gallery>.block-wrap.is-item:hover>.b-gutter{opacity:.95}
.ed-gallery>.block-wrap.is-item>.b-gutter .b-add{display:none}
.ed-gallery>.block-wrap.is-item>.b-body{width:100%;min-width:0}
.itemref-card{display:flex;flex-direction:column;align-items:flex-start;gap:9px;padding:15px 16px;border:1px solid var(--line);border-radius:13px;background:var(--panel);box-shadow:var(--shadow-sm);cursor:pointer;position:relative;width:100%;transition:transform .14s var(--ease-out),border-color .14s,box-shadow .16s}
.itemref-card:hover{border-color:var(--acc);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.itemref-card .qi{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;font-size:19px;flex-shrink:0}
.itemref-card .ir-meta{min-width:0;width:100%}
.itemref-card .qt{font-weight:600;font-size:13.5px;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.itemref-card .qd{font-size:11.5px;color:var(--ink-2)}
.itemref-card .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}
.itemref-card:hover .card-del{opacity:1}
.itemref-card .card-del:hover{background:var(--red-bg);color:var(--red)}

/* ===== Inicio: dashboard de widgets ===== */
.home-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px}
.widgets-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;align-items:start}
.widget{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .16s,border-color .14s}
.widget:hover{box-shadow:var(--shadow-md)}
.w-head{display:flex;align-items:center;gap:9px;padding:12px 15px 11px;border-bottom:1px solid var(--line)}
.w-ic{display:grid;place-items:center;color:var(--ink-3)}
.w-title{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-2);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.w-actions{display:inline-flex;gap:1px;opacity:0;transition:opacity .12s}
.widget:hover .w-actions{opacity:1}
.w-act{width:24px;height:22px;display:grid;place-items:center;border-radius:6px;color:var(--ink-3);cursor:pointer;font-size:12px}
.w-act:hover{background:var(--panel-2);color:var(--ink)}
.w-drag{cursor:grab;letter-spacing:-1px}
.w-del:hover{background:var(--red-bg);color:var(--red)}
.w-body{padding:14px 16px;flex:1;min-width:0}
.w-body>.grid-4{gap:12px}
.w-body table{width:100%}
.w-body table td{padding:8px 6px;font-size:13px}
.widget.w-dragging{opacity:.4}
.widget.w-over{box-shadow:0 0 0 2px var(--acc)}
.w-stat{display:flex;flex-direction:column;gap:4px;padding:6px 2px 4px}
.w-statnum{font-size:40px;font-weight:800;letter-spacing:-1.5px;color:var(--ink);line-height:1}
.w-statlab{font-size:12.5px;color:var(--ink-2);font-weight:500}
.w-statsel{margin-top:14px;max-width:210px}
.w-shorts{display:flex;flex-direction:column;gap:1px}
.w-short{display:flex;align-items:center;gap:10px;padding:8px 9px;border-radius:9px;cursor:pointer;font-size:13.5px;color:var(--ink);font-weight:500;transition:background .12s}
.w-short:hover{background:var(--panel-2)}
.w-short-ic{display:grid;place-items:center;color:var(--acc)}
.w-note{min-height:36px}
/* selector de plantillas de widget */
.wpick{display:flex;flex-direction:column;gap:7px;max-height:58vh;overflow:auto;margin-top:6px}
.wpick-item{display:flex;align-items:center;gap:12px;padding:11px 12px;border:1px solid var(--line);border-radius:11px;cursor:pointer;transition:.12s}
.wpick-item:hover{border-color:var(--acc);background:var(--panel-2)}
.wpick-ic{width:38px;height:38px;border-radius:10px;background:var(--acc-soft);color:var(--acc);display:grid;place-items:center;flex-shrink:0}
.wpick-n{font-weight:600;font-size:13.5px;color:var(--ink)}
.wpick-d{font-size:12px;color:var(--ink-2)}
@media (max-width:780px){.widgets-grid{grid-template-columns:1fr}.widget{grid-column:span 1!important}}

/* ===== editor de bloques estilo Notion (gutter + handle + menú) ===== */
.block-wrap{display:flex;align-items:flex-start;position:relative;border-radius:6px}
.b-gutter{display:flex;align-items:center;justify-content:flex-end;gap:1px;width:44px;flex-shrink:0;padding:5px 4px 0 0;opacity:0;transition:opacity .12s}
.block-wrap:hover>.b-gutter{opacity:1}
.b-add,.b-handle{color:var(--ink-3);border-radius:6px;width:20px;height:22px;display:grid;place-items:center;font-size:13px;cursor:pointer;user-select:none;transition:background .1s,color .1s}
.b-add{font-size:15px} .b-handle{cursor:grab;font-size:11px;letter-spacing:-1px}
.b-add:hover,.b-handle:hover{background:var(--panel-2);color:var(--ink)}
.b-body{flex:1;min-width:0}
.block-wrap.b-dragging{opacity:.35}
.block-wrap.b-over{box-shadow:inset 0 2px 0 0 var(--acc)}
.add-block{margin-left:44px}
.block.h3 .bc{font-size:16px;font-weight:700;letter-spacing:-.2px;margin-top:2px}
.block.quote .bc{border-left:3px solid var(--acc);padding-left:13px;color:var(--ink-2);font-style:italic}
.block.numbered{align-items:flex-start}
.b-num{color:var(--ink-3);min-width:20px;text-align:right;padding-top:3px;font-size:14px;font-variant-numeric:tabular-nums;flex-shrink:0}
.bc.done{text-decoration:line-through;color:var(--ink-3)}
.b-divider{padding:9px 0}
.b-divider hr{border:none;border-top:1px solid var(--line-2);margin:0}
.embed-block.file iframe{width:100%;height:540px;border:none;display:block;background:var(--panel)}

/* menú flotante de bloque */
.float-menu{min-width:194px;max-height:80vh;overflow:auto}
.float-menu .fm-head{font-size:9.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-3);font-weight:700;padding:9px 9px 3px}
.float-menu .fm-item{display:flex;align-items:center;gap:9px}
.float-menu .fm-l{flex:1;white-space:nowrap}
.float-menu .fm-dot{width:14px;height:14px;border-radius:4px;flex-shrink:0;border:1px solid var(--line-2)}
.float-menu .fm-arr{color:var(--ink-3);font-size:15px}
.pop-menu .pm-item.danger{color:var(--red)}
.pop-menu .pm-item.danger:hover{background:var(--red-bg)}

/* página centrada (estilo Notion) */
.pagehdr{max-width:760px;margin:0 auto;width:100%}
.pagehdr.wide,.doc.wide{max-width:1100px!important}

/* ===== selector de iconos (SVG + color + emojis) ===== */
.icon-picker{margin-top:4px}
.ip-bar{display:flex;align-items:center;gap:10px;margin-bottom:11px;flex-wrap:wrap}
.ip-tabs{display:flex;gap:3px;background:var(--panel-2);border-radius:9px;padding:3px}
.ip-tab{font-size:12.5px;font-weight:600;color:var(--ink-2);padding:5px 12px;border-radius:7px;cursor:pointer;transition:.12s}
.ip-tab.active{background:var(--panel);color:var(--ink);box-shadow:var(--shadow-sm)}
.ip-colors{display:flex;gap:7px;margin-left:auto;align-items:center}
.ip-color{width:19px;height:19px;border-radius:50%;cursor:pointer;border:2px solid var(--panel);box-shadow:0 0 0 1px var(--line-2);transition:transform .1s}
.ip-color:hover{transform:scale(1.15)}
.ip-color.sel{box-shadow:0 0 0 2px var(--acc);transform:scale(1.1)}
.ip-grid{display:grid;grid-template-columns:repeat(9,1fr);gap:4px;max-height:240px;overflow:auto;padding:3px}
.ip-ic,.ip-em{aspect-ratio:1;display:grid;place-items:center;border-radius:9px;cursor:pointer;border:1px solid transparent;color:var(--acc);transition:background .1s,transform .1s}
.ip-em{font-size:19px;color:var(--ink)}
.ip-ic:hover,.ip-em:hover{background:var(--panel-2);transform:translateY(-1px)}
.ip-ic.sel,.ip-em.sel{background:var(--acc-soft);border-color:var(--acc)}
.ent-ico svg{display:block}
.emoji.clickable{cursor:pointer;border-radius:8px;padding:3px;transition:background .12s}
.emoji.clickable:hover{background:var(--panel-2)}

/* botones de icono (lock solo-icono) + pestañas con icono */
.btn.iconbtn{padding:6px 8px}
.btn.iconbtn svg{display:block}
.vtab .vtab-ic{display:inline-grid;place-items:center}
.vtab .vtab-ic svg{display:block}

/* campos editables inline (nombre/descr de espacio, títulos) */
.page-name{outline:none;border-radius:7px;padding:0 5px;margin:0 -2px;transition:background .12s}
.page-name[contenteditable]:hover{background:var(--panel-2)}
.page-name:focus{background:var(--panel-2)}
#spDesc[contenteditable]{outline:none;border-radius:7px;transition:background .12s;cursor:text}
#spDesc[contenteditable]:hover,#spDesc:focus{background:var(--panel-2)}
.page-title:empty:before,#spTitle:empty:before,#spDesc:empty:before{content:attr(data-ph);color:var(--ink-3);pointer-events:none}

/* ===== Agentes ===== */
.agents-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px}
.agent-card{padding:16px 17px;display:flex;flex-direction:column;gap:11px;transition:.14s}
.agent-card:hover{border-color:var(--acc);transform:translateY(-1px);box-shadow:var(--shadow)}
.ag-top{display:flex;align-items:flex-start;gap:11px}
.ag-emoji{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-size:21px;flex-shrink:0;background:var(--acc-soft)}
.ag-name{font-weight:700;font-size:14.5px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ag-state{width:9px;height:9px;border-radius:50%;background:var(--ink-3);flex-shrink:0;margin-top:6px}
.ag-state.on{background:var(--green);box-shadow:0 0 0 3px var(--green-bg)}
.ag-desc{font-size:12.8px;color:var(--ink-2);line-height:1.5;min-height:38px}
.ag-meta{display:flex;justify-content:space-between;font-size:11.5px;color:var(--ink-3);border-top:1px solid var(--line);padding-top:10px}
.ag-actions{display:flex;gap:7px;flex-wrap:wrap}
.ag-actions .btn{flex:0 0 auto}
.run-out{background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:12px 14px;margin-bottom:10px;font-size:13px;color:var(--ink);white-space:pre-wrap;line-height:1.55}

/* ============ POLISH UI/UX (Inter · micro-interacciones · elevación) ============ */
table,.mono,.kcode,.num,td,th{font-feature-settings:"tnum"}
.card{transition:box-shadow .18s var(--ease-out),border-color .16s,transform .18s var(--ease-out)}
h1.page{font-weight:800;letter-spacing:-.7px}
.page-title{letter-spacing:-.7px}
/* botones con elevación sutil y feedback táctil */
.btn{box-shadow:0 1px 2px rgba(16,19,26,.08),inset 0 1px 0 rgba(255,255,255,.08)}
.btn:hover{filter:brightness(1.07);transform:translateY(-1px);box-shadow:0 4px 12px rgba(109,94,252,.28)}
.btn:active{transform:translateY(0) scale(.985);box-shadow:0 1px 2px rgba(16,19,26,.1)}
.btn.ghost{box-shadow:var(--shadow-sm)}
.btn.ghost:hover{filter:none;background:var(--hover);border-color:var(--line-2);box-shadow:var(--shadow-sm)}
.btn.danger:hover{box-shadow:0 4px 12px rgba(220,38,38,.22)}
.icobtn{transition:background .14s,color .14s,transform .12s}
.icobtn:hover{color:var(--ink)}
.icobtn:active{transform:scale(.92)}
/* topbar más sólido */
.topbar{backdrop-filter:saturate(1.1)}
.searchbox{transition:border-color .15s,box-shadow .15s}
.searchbox:focus-within{border-color:var(--acc);box-shadow:var(--ring)}
/* sidebar: ítems con transición de fondo más suave */
.nav-item{transition:background .14s var(--ease-out),color .14s}
.nav-item.active{font-weight:600}
.badge{box-shadow:0 1px 3px rgba(109,94,252,.4)}
/* inputs/areas con foco de marca */
.field input:focus,.field select:focus,.field textarea:focus,.fld input:focus,.col-cfg input:focus{box-shadow:var(--ring)}
/* modal con entrada animada desde el centro */
.modal-bg{transition:opacity .16s}
.modal{box-shadow:var(--shadow-lg);animation:modalIn .22s var(--ease-out)}
@keyframes modalIn{from{opacity:0;transform:translateY(10px) scale(.97)}to{opacity:1;transform:none}}
.modal h3{letter-spacing:-.3px;font-weight:700}
/* menús flotantes con sombra de elevación y entrada */
.pop-menu,.slash-menu,.search-results,.bell-panel{box-shadow:var(--shadow-md);animation:popIn .14s var(--ease-out)}
@keyframes popIn{from{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:none}}
/* kanban: tarjetas con elevación al pasar */
.kc{transition:transform .14s var(--ease-out),border-color .14s,box-shadow .16s}
.kc:hover{box-shadow:var(--shadow-md)}
.quick,.sc,.agent-card{transition:transform .16s var(--ease-out),border-color .14s,box-shadow .18s}
.quick:hover,.sc:hover{box-shadow:var(--shadow-md)}
/* callout un poco más refinado */
.callout{border-radius:12px}
/* toast con sombra fuerte */
.toast{box-shadow:var(--shadow-lg);font-weight:500;letter-spacing:-.1px}
/* vtabs activo con leve peso */
.vtab.active{font-weight:600}
/* scrollbar más fina y discreta */
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:9px;border:3px solid transparent;background-clip:content-box}
::-webkit-scrollbar-thumb:hover{background:var(--ink-3);background-clip:content-box}
/* ===== Dashboard DTM ===== */
.dtm-head{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.dtm-title{font-size:19px;font-weight:800;letter-spacing:-.3px;margin:0 0 3px}
.dtm-dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:8px;vertical-align:middle}
.dtm-chan{font-size:14px;font-weight:700;margin:0 0 10px;color:var(--ink)}
.dtm-distros{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.dtm-distro .dtm-dh{font-size:12.5px;font-weight:700;color:var(--ink-2);text-transform:uppercase;letter-spacing:.04em;margin:0 0 12px}
/* cards de resultados (5 en fila) */
.dtm-cards5{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px}
/* distribución: donut (visual) + tabla (datos) — sin repetir info */
.dtm-distrow{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.dtm-donut-box{flex-shrink:0}
.dtm-donut{width:118px;height:118px;display:block}
.dtm-donut-t{font-size:19px;font-weight:800;fill:var(--ink)}
.dtm-donut-s{font-size:8px;fill:var(--ink-3);text-transform:uppercase;letter-spacing:.08em}
.dtm-disttbl{flex:1;min-width:220px}
.dtm-leg-dot{display:inline-block;width:9px;height:9px;border-radius:3px;margin-right:7px;vertical-align:middle;flex-shrink:0}
/* tabla compacta dentro de distribuciones */
.dtm-table.dtm-mini{font-size:12px}
.dtm-table.dtm-mini th,.dtm-table.dtm-mini td{padding:6px 8px}
.dtm-table tr.dtm-tot td{background:var(--panel-2);font-weight:800;border-top:2px solid var(--line)}
/* gráfico de área (escala uniforme, sin distorsión) */
.dtm-area-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}
.dtm-area{width:100%;height:auto;display:block;overflow:visible}
.dtm-area-grid{stroke:var(--line);stroke-width:1;stroke-dasharray:3 4}
.dtm-area-ax{fill:var(--ink-3);font-size:11px}
.dtm-area-day{font-size:10px}
.dtm-area-mes{font-size:11px}
.dtm-area-dot{fill:var(--acc);stroke:var(--panel);stroke-width:1.5}
@media (max-width:860px){.dtm-distros{grid-template-columns:1fr}.dtm-cards5{grid-template-columns:repeat(2,1fr)}.dtm-area-day{font-size:13px}}
.dtm-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.dtm-errnote{margin:-6px 0 16px;color:var(--amber)}
.dtm-table{width:100%;border-collapse:collapse;font-size:13px}
.dtm-table th{padding:9px 12px;text-align:right;font-weight:600;color:var(--ink-2);font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--line);white-space:nowrap}
.dtm-table td{padding:9px 12px;text-align:right;border-bottom:1px solid var(--line);white-space:nowrap;color:var(--ink)}
.dtm-table th.l,.dtm-table td.l{text-align:left}
.dtm-table td.strong{font-weight:700}
.dtm-table tbody tr:nth-child(even){background:var(--panel-2)}
.dtm-table tbody tr:last-child td{border-bottom:none}
.dtm-table tbody tr:hover{background:var(--acc-soft)}

/* ============ RESPONSIVE · tablet y móvil ============ */
#sbBackdrop{display:none}

/* —— Tablet / pantallas medianas —— */
@media (max-width:1024px){
  #app{grid-template-columns:212px 1fr}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .gen-wrap{grid-template-columns:1fr}
  .content{padding:24px 24px 70px}
  .searchbox{width:240px}
}

/* —— Móvil: la sidebar pasa a ser un cajón (drawer) sobre el contenido —— */
@media (max-width:768px){
  /* shell a una sola columna; la sidebar deja de empujar */
  #app,#app.sb-collapsed{grid-template-columns:1fr}
  .sidebar{position:fixed;top:0;left:0;height:100vh;height:100dvh;width:min(86vw,300px);z-index:80;
    transform:translateX(-100%);transition:transform .24s var(--ease-out);box-shadow:var(--shadow-lg)}
  #app:not(.sb-collapsed) .sidebar{transform:none}
  #app.sb-collapsed .sidebar{display:flex}            /* sigue montada para poder animar */

  /* backdrop cuando el cajón está abierto */
  #app:not(.sb-collapsed) #sbBackdrop{display:block;position:fixed;inset:0;background:rgba(8,10,15,.5);z-index:70;animation:fade .2s}

  /* topbar compacto, con hueco a la izquierda para la hamburguesa flotante */
  .topbar{height:52px;gap:8px;padding:0 12px 0 52px}
  .crumb{display:none}
  .searchbox{width:auto;flex:1;min-width:0;margin-left:0;padding:0 10px}
  .icobtn{width:32px;height:32px}

  /* contenido con menos aire lateral */
  .content{padding:18px 14px 64px}
  h1.page{font-size:21px}
  h1.page .emoji{font-size:21px}
  .page-sub{font-size:13px;margin-bottom:18px}

  /* rejillas y secciones de dos+ columnas → una sola */
  .grid-2,.grid-3,.grid-4,.gen-wrap,.dtm-distros,.prop{grid-template-columns:1fr!important}
  .dtm-cards5{grid-template-columns:repeat(2,1fr)}
  .row{gap:12px}

  /* panel de propiedades: apila clave encima del valor */
  .pk{border-bottom:none;padding:11px 14px 0}
  .pv{padding:4px 14px 13px}

  /* tablas con scroll horizontal propio (no rompen el ancho de la página) */
  .tablewrap,.dtable,.content table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}

  /* anchos centrados estilo Notion pasan a fluido */
  .doc,.space-wrap,.space-blocks,.pagehdr,.space-wrap.wide,.doc.wide,.pagehdr.wide,.page-title.wide,.space-blocks.wide{max-width:100%!important}
  .add-block{margin-left:26px}
  .b-gutter{width:26px}

  /* editor-galería: tarjetas a ancho completo en móvil */
  .ed-gallery>.block-wrap.is-item{width:100%!important}

  /* paneles flotantes del topbar → a ancho de pantalla */
  .search-results,.bell-panel{position:fixed;left:10px;right:10px;top:58px;width:auto}

  /* modal ocupa casi toda la pantalla */
  .modal{width:96vw;padding:20px 18px}
}

/* —— Móvil pequeño —— */
@media (max-width:420px){
  .dtm-cards5{grid-template-columns:1fr}
  .content{padding:16px 11px 60px}
  .gen-tabs,.tabsrow{flex-wrap:wrap}
}
