:root{--bg:#0f172a;--panel:#111827;--muted:#334155;--text:#e5e7eb;--accent:#22d3ee;--rose:#fb7185;--violet:#a78bfa;--ok:#34d399;--amber:#fbbf24;--line:#334155}
*{box-sizing:border-box}
body{margin:0;background:linear-gradient(120deg,#0b1226,#0f172a 40%);color:var(--text);font-family:Inter,system-ui,Segoe UI,Roboto,Helvetica,Arial}
.app-header{display:flex;gap:10px;align-items:center;background:rgba(17,24,39,.7);backdrop-filter: blur(6px);border:1px solid #1f2937;border-radius:14px;padding:10px 12px;margin:14px}
.layout{display:grid;grid-template-columns:320px 1fr;gap:14px;height:calc(100vh - 72px);padding:0 14px 14px}
.btn{border:1px solid #1f2937;background:#0b1220;color:#e2e8f0;padding:8px 10px;border-radius:10px;cursor:pointer}
.btn:hover{border-color:#334155}
.btn.primary{background:linear-gradient(135deg,#0ea5e9,#8b5cf6);border:none}
.btn.danger{background:#3b0b14;border-color:#7f1d1d;color:#fecaca}
.btn:disabled{opacity:.55;cursor:not-allowed}
.icon-btn{background:#0b1220;border:1px solid #1f2937;border-radius:8px;padding:6px 8px;cursor:pointer}
.icon-btn:hover{border-color:#334155}
.panel{background:rgba(17,24,39,.55);border:1px solid #1f2937;border-radius:16px;overflow:hidden;display:flex;flex-direction:column}
.head{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid #1f2937;background:linear-gradient(180deg,rgba(30,41,59,.7),rgba(17,24,39,.35))}
.body{padding:10px;overflow:auto}
/* Padding específico y posicionamiento relativo para marquee */
#notes-container{position:relative;padding:16px}
.pill{padding:6px 10px;border:1px solid #283548;border-radius:999px;background:#0b1220;color:#cbd5e1;font-size:12px}
.filters .row{display:grid;grid-template-columns:1fr auto;gap:8px;margin-bottom:10px}
input,select,textarea{width:100%;padding:8px 10px;border-radius:10px;border:1px solid #263141;background:#0b1220;color:#e5e7eb}
/* Bloqueo visual en multi-selección */
input:disabled, textarea:disabled, select:disabled{opacity:.6;cursor:not-allowed}
.locked{opacity:.6 !important;cursor:not-allowed !important}
/* Contenedor bloqueado (para grupo de campos) */
.blocked{opacity:.5;pointer-events:none}
.blocked-overlay{position:relative}
.blocked-overlay::after{content:"";position:absolute;inset:0;background:rgba(148,163,184,.15);border-radius:12px;cursor:not-allowed}
.multi-notice{padding:8px 10px;border:1px dashed #334155;border-radius:10px;background:#0b1220;margin-bottom:8px;color:#e2e8f0}
.multi-notice strong{color:#93c5fd}
.tag-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border:1px solid #334155;border-radius:999px;background:#0b1220;margin:3px 4px;font-size:12px;position:relative}
.tag-cloud{display:flex;gap:6px;flex-wrap:wrap}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}
.card{background:#0b1220;border:2px solid #1f2937;border-radius:14px;overflow:hidden;display:flex;flex-direction:column;min-height:240px;position:relative;transition:border-color .15s, box-shadow .15s, transform .12s, background-color .15s;will-change:transform;margin:8px}
.card.selected{border-color:var(--accent);box-shadow:0 0 0 2px rgba(34,211,238,.55),0 0 22px rgba(34,211,238,.6),0 0 42px rgba(34,211,238,.35),0 12px 28px rgba(34,211,238,.08),0 8px 24px rgba(0,0,0,.35);outline:2px solid #3b82f6;background-color:rgba(59,130,246,.05)}
/* Overlay translúcido sobre tarjeta seleccionada */
.card.selected::before{content:"";position:absolute;inset:0;background:rgba(0,0,0,.28);pointer-events:none;border-radius:inherit;z-index:1}
/* Checkmark fijo (esquina sup. izquierda) */
.sel-check{position:absolute;top:8px;left:8px;width:30px;height:30px;border-radius:999px;display:grid;place-items:center;font-weight:800;font-size:18px;color:#052e1a;background:linear-gradient(135deg,#34d399,#22c55e);border:1px solid rgba(16,185,129,.9);box-shadow:0 0 0 2px rgba(2,6,23,.6),0 4px 10px rgba(16,185,129,.45),0 0 18px rgba(34,211,238,.35);opacity:0;transform:scale(.9);transition:opacity .15s ease, transform .18s ease;z-index:2;pointer-events:none}
.card.selected .sel-check{opacity:1;transform:scale(1)}
.card img{width:100%;height:140px;object-fit:cover;background:#0a0f1f}
.card .content{padding:10px;display:flex;flex-direction:column;gap:6px}
.badge{padding:3px 8px;border-radius:999px;border:1px solid #334155;background:#0b1220;font-size:11px}
.row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.spacer{flex:1}
.card .title{font-weight:600}
.card .desc{font-size:13px;color:#cbd5e1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.stars{cursor:pointer;font-size:14px;letter-spacing:1px}
.stars .off{opacity:.35}
/* Visibilidad/color de estrellas */
.stars .star{ color:#FFD54F !important; filter: drop-shadow(0 0 1px rgba(0,0,0,.25)); }
/* Compatibilidad con HTML actual (spans sin clase .star) */
.stars span{ color:#FFD54F; filter: drop-shadow(0 0 1px rgba(0,0,0,.25)); }
.scope{border:1px solid transparent}
.scope.sin_asignar{background:rgba(71,85,105,.2);color:#cbd5e1;border-color:#334155}
.scope.episodio{background:rgba(56,189,248,.18);color:#7dd3fc;border-color:#155e75}
.scope.acto{background:rgba(167,139,250,.16);color:#c4b5fd;border-color:#5b21b6}
.scope.secuencia{background:rgba(34,211,238,.18);color:#99f6e4;border-color:#155e75}
.scope.escena{background:rgba(245,158,11,.16);color:#fbbf24;border-color:#92400e}
.card.ambito-sin_asignar{border-color:#334155}
.card.ambito-episodio{border-color:#155e75}
.card.ambito-acto{border-color:#5b21b6}
.card.ambito-secuencia{border-color:#155e75}
.card.ambito-escena{border-color:#92400e}
.drawer{position:fixed;right:0;top:0;bottom:0;width:480px;background:#0b1220;border-left:1px solid #1f2937;box-shadow:-10px 0 30px rgba(0,0,0,.2);transform:translateX(100%);transition:.25s}
.drawer.open{transform:translateX(0)}
.drawer .inner{height:100%;display:flex;flex-direction:column}
.drawer .header{padding:12px 14px;border-bottom:1px solid #1f2937;display:flex;gap:8px;align-items:center}
.drawer .content{padding:12px 14px;overflow:auto;display:flex;flex-direction:column;gap:10px}
.dropzone{border:2px dashed #334155;border-radius:10px;padding:8px;text-align:center;transition:opacity .15s}
.dropzone.drag{background:#111827}
.dropzone.disabled{opacity:.5;pointer-events:none}
.token-editor{display:flex;gap:6px;flex-wrap:wrap}
.token{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border:1px solid #334155;border-radius:999px;background:#0b1220}
.token .x{cursor:pointer;opacity:.7}
.suggest{position:relative}
.suggest-list{position:absolute;z-index:10;left:0;right:0;background:#0b1220;border:1px solid #1f2937;border-radius:8px;margin-top:6px;max-height:180px;overflow:auto;display:none}
.suggest-list.open{display:block}
.suggest-item{padding:6px 8px;border-bottom:1px solid #0f172a;cursor:pointer}
.suggest-item:hover{background:#0f172a}
.menu{position:absolute;background:#0b1220;border:1px solid #1f2937;border-radius:8px;box-shadow:0 8px 26px rgba(0,0,0,.35);display:none;z-index:50}
.menu.open{display:block}
.menu button{display:block;width:100%;text-align:left;padding:8px 10px;background:none;border:none;color:#e5e7eb;cursor:pointer}
.menu button:hover{background:#0f172a}
.modal{position:fixed;inset:0;background:rgba(2,6,23,.75);display:none;align-items:center;justify-content:center;z-index:1000}
.modal.open{display:flex}
.modal .box{width:min(900px,90vw);height:min(70vh,80vh);background:#0b1220;border:1px solid #1f2937;border-radius:12px;display:flex;flex-direction:column}
.modal .box textarea{flex:1;margin:10px}
#testBadge{position:fixed;bottom:8px;left:8px;font-size:11px;padding:4px 8px;border-radius:999px;background:#0b1220;border:1px solid #1f2937;color:#9ca3af}
.muted{font-size:12px;color:#94a3b8}
.divider{height:1px;background:#1f2937;margin:8px 0}
.rel-header{font-weight:600}
.rel-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.rel-grid > div:last-child{grid-column:1/-1}
.small{font-size:12px}
.crumbs{opacity:.85}
.card .crumbs{font-size:11px;color:#9ca3af}

/* ====== Scope select + chip ====== */
.scope-select{border-radius:9999px;padding:6px 12px;border:1px solid var(--line);background:#0f172a;color:#e2e8f0}
.scope-select:focus{outline:2px solid #64748b33}
.scope-chip{display:inline-block;margin-left:8px;padding:2px 10px;border-radius:9999px;font-size:12px;line-height:18px;border:1px solid transparent}
/* Colores por ámbito (select) */
.scope-episodio{border-color:#1d4ed8;box-shadow:inset 0 0 0 1px #1d4ed8}
.scope-acto{border-color:#7c3aed;box-shadow:inset 0 0 0 1px #7c3aed}
.scope-secuencia{border-color:#0ea5a5;box-shadow:inset 0 0 0 1px #0ea5a5}
.scope-escena{border-color:#ea580c;box-shadow:inset 0 0 0 1px #ea580c}
.scope-any{border-color:#475569;box-shadow:inset 0 0 0 1px #475569}
/* Chip */
.scope-chip.scope-episodio{background:#1d4ed81a;color:#93c5fd;border-color:#1d4ed8}
.scope-chip.scope-acto{background:#7c3aed1a;color:#c4b5fd;border-color:#7c3aed}
.scope-chip.scope-secuencia{background:#0ea5a51a;color:#99f6e4;border-color:#0ea5a5}
.scope-chip.scope-escena{background:#ea580c1a;color:#fdba74;border-color:#ea580c}
.scope-chip.scope-any{background:#33415566;color:#cbd5e1;border-color:#475569}

/* ====== Feedback de selección sin parpadeo ====== */
.card.select-flash::after{content:'';position:absolute;inset:-4px;border-radius:16px;border:2px solid var(--accent);opacity:0;pointer-events:none;animation:selectPulse .42s ease-out}
@keyframes selectPulse{0%{opacity:.95;transform:scale(.98)}70%{opacity:.45}100%{opacity:0;transform:scale(1.06)}}

/* ====== Rectángulo de selección (marquee) ====== */
.selection-rect{position:absolute;border:1px dashed #3b82f6;background:rgba(59,130,246,.15);pointer-events:none;z-index:9999}

/* ====== Secciones agrupadas por ámbito ====== */
.group{margin-bottom:8px}
.group-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 6px;cursor:pointer;background:transparent;border:none;color:var(--text)}
.group-title{font-weight:600}
.group-count{opacity:.8;margin-left:8px}
.group-caret{display:inline-flex;align-items:center;margin-left:8px}
.group-caret::before{content:'\25B6';display:inline-block;transition:transform .18s ease}
.group-header[aria-expanded="true"] .group-caret::before{transform:rotate(90deg)}
.group-body{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.group-separator{border:0;height:1px;background:currentColor;opacity:.18;margin:6px 0}
/* Ocultación del cuerpo al colapsar */
.group-header[aria-expanded="false"] + .group-body{display:none}
