/* ═══════════════════════════════════════════════════════════
   leframe.css — Sistema de diseño LeFrame Review
   Colocar en /css/leframe.css e importar en cada página
   ═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Google+Sans:wght@400;500;700&family=Google+Sans+Mono&display=swap');

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

:root {
  --accent:        #667eea;
  --accent-dark:   #5a67d8;
  --accent-dim:    rgba(102,126,234,0.14);
  --accent-border: rgba(102,126,234,0.32);
  --green:         #48bb78;
  --green-dark:    #38a169;
  --green-dim:     rgba(72,187,120,0.12);
  --green-border:  rgba(72,187,120,0.3);
  --red:           #e05252;
  --red-dark:      #c53030;
  --red-dim:       rgba(224,82,82,0.1);
  --red-border:    rgba(224,82,82,0.28);
  --bg:            #111;
  --bg-2:          #181818;
  --bg-3:          #1e1e1e;
  --bg-4:          #242424;
  --bg-5:          #2a2a2a;
  --border:        #222;
  --border-2:      #2a2a2a;
  --border-3:      #363636;
  --text:          #eee;
  --text-2:        #aaa;
  --text-3:        #666;
  --text-4:        #444;
  --font:          'Google Sans', Arial, sans-serif;
  --font-mono:     'Google Sans Mono', 'Courier New', monospace;
  --r:             6px;
  --r-lg:          10px;
  --r-xl:          14px;
  --shadow:        0 4px 20px rgba(0,0,0,.35);
  --shadow-lg:     0 8px 36px rgba(0,0,0,.55);
}

html { font-size:16px; }
body { font-family:var(--font); background:var(--bg); color:var(--text); min-height:100vh; line-height:1.5; -webkit-font-smoothing:antialiased; }

::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--bg-5); border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:var(--border-3); }

/* ── NAVBAR ── */
.navbar { background:var(--bg-2); border-bottom:1px solid var(--border); height:52px; padding:0 1.5rem; display:flex; align-items:center; justify-content:space-between; position:sticky; top:0; z-index:200; gap:1rem; }
.navbar-left  { display:flex; align-items:center; gap:.5rem; min-width:0; }
.navbar-right { display:flex; align-items:center; gap:.65rem; flex-shrink:0; }

.navbar-brand { display:flex; align-items:center; gap:.45rem; text-decoration:none; flex-shrink:0; }
.navbar-brand .dot  { width:7px; height:7px; border-radius:50%; background:var(--accent); flex-shrink:0; }
.navbar-brand .name { font-size:.95rem; font-weight:700; color:#fff; letter-spacing:.02em; }

.navbar-sep    { color:var(--border-3); font-size:1.3rem; user-select:none; flex-shrink:0; }
.navbar-crumb  { font-size:.82rem; color:var(--text-3); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

.navbar-user { display:flex; align-items:center; gap:.45rem; font-size:.82rem; color:var(--text-2); }
.navbar-user i { font-size:15px; color:var(--text-3); }

/* ── BOTONES ── */
.btn {
  display:inline-flex; align-items:center; gap:.38rem;
  padding:.45rem .95rem; border-radius:var(--r);
  font-family:var(--font); font-size:.84rem; font-weight:500;
  cursor:pointer; border:1px solid transparent;
  text-decoration:none; white-space:nowrap;
  transition:background .13s, border-color .13s, color .13s, box-shadow .13s;
  line-height:1.4; user-select:none;
}
.btn i { font-size:15px; flex-shrink:0; }

.btn-primary { background:var(--accent); color:#fff; border-color:var(--accent); }
.btn-primary:hover { background:var(--accent-dark); border-color:var(--accent-dark); box-shadow:0 3px 12px rgba(102,126,234,.28); }

.btn-green { background:var(--green); color:#fff; border-color:var(--green); }
.btn-green:hover { background:var(--green-dark); border-color:var(--green-dark); }

.btn-ghost { background:transparent; color:var(--text-2); border-color:var(--border-3); }
.btn-ghost:hover { background:var(--bg-5); color:var(--text); border-color:#484848; }

.btn-danger { background:transparent; color:var(--red); border-color:var(--red-border); }
.btn-danger:hover { background:var(--red-dim); border-color:var(--red); }

.btn-sm  { padding:.3rem .68rem;   font-size:.78rem; }
.btn-sm i { font-size:13px; }
.btn-xs  { padding:.18rem .46rem;  font-size:.72rem; }
.btn-xs i { font-size:12px; }

/* ── BADGES ── */
.badge { display:inline-flex; align-items:center; gap:3px; padding:.13rem .5rem; border-radius:20px; font-size:.7rem; font-weight:500; border:1px solid transparent; }
.badge-accent { background:var(--accent-dim); color:var(--accent); border-color:var(--accent-border); }
.badge-green  { background:var(--green-dim);  color:var(--green);  border-color:var(--green-border);  }
.badge-gray   { background:var(--bg-5); color:var(--text-3); border-color:var(--border-3); }

/* ── LAYOUT ── */
.page-body { max-width:1380px; margin:0 auto; padding:2rem 1.5rem; }

/* ── FORMULARIOS ── */
.form-group { margin-bottom:1.1rem; }
.form-group label { display:block; color:var(--text-2); font-size:.8rem; font-weight:500; margin-bottom:.38rem; }
.form-group small  { display:block; color:var(--text-4); font-size:.73rem; margin-top:.3rem; }

input[type="text"], input[type="email"], input[type="password"], input[type="file"],
textarea, select {
  width:100%; padding:.58rem .82rem;
  background:var(--bg-4); border:1px solid var(--border-3);
  color:var(--text); border-radius:var(--r);
  font-family:var(--font); font-size:.86rem;
  transition:border-color .13s, box-shadow .13s;
  outline:none;
}
input[type="text"]:focus, input[type="email"]:focus,
input[type="password"]:focus, textarea:focus, select:focus {
  border-color:var(--accent); box-shadow:0 0 0 3px rgba(102,126,234,.1);
}
textarea { resize:vertical; min-height:80px; }
select   { cursor:pointer; }
input[type="file"]     { padding:.48rem; cursor:pointer; color:var(--text-3); }
input[type="checkbox"] { accent-color:var(--accent); width:15px; height:15px; }

/* ── MODAL ── */
.modal { display:none; position:fixed; inset:0; background:rgba(0,0,0,.72); justify-content:center; align-items:center; z-index:1000; backdrop-filter:blur(4px); }
.modal-box { background:var(--bg-3); border:1px solid var(--border-2); border-radius:var(--r-xl); width:92%; max-width:490px; max-height:88vh; overflow-y:auto; box-shadow:var(--shadow-lg); }
.modal-box::-webkit-scrollbar { width:4px; }
.modal-box::-webkit-scrollbar-thumb { background:var(--bg-5); border-radius:2px; }
.modal-header { padding:1.2rem 1.4rem .9rem; border-bottom:1px solid var(--border); display:flex; align-items:center; gap:.55rem; }
.modal-header h3 { color:var(--text); font-size:.98rem; font-weight:600; flex:1; }
.modal-header > i { color:var(--accent); font-size:17px; }
.modal-close { background:transparent; border:none; color:var(--text-3); cursor:pointer; font-size:18px; padding:2px; display:flex; align-items:center; border-radius:4px; transition:color .12s, background .12s; }
.modal-close:hover { color:var(--text); background:var(--bg-5); }
.modal-body   { padding:1.2rem 1.4rem; }
.modal-footer { padding:.9rem 1.4rem 1.2rem; display:flex; gap:.6rem; border-top:1px solid var(--border); }

/* ── TABS ── */
.tabs-bar { display:flex; border-bottom:1px solid var(--border-2); margin-bottom:1.4rem; }
.tab-btn {
  padding:.6rem 1.2rem; background:none; border:none;
  border-bottom:2px solid transparent; margin-bottom:-1px;
  font-family:var(--font); font-size:.84rem; font-weight:500;
  color:var(--text-3); cursor:pointer;
  display:flex; align-items:center; gap:.4rem;
  transition:color .14s, border-color .14s;
}
.tab-btn i { font-size:14px; }
.tab-btn:hover  { color:var(--text-2); }
.tab-btn.active { color:var(--accent); border-bottom-color:var(--accent); }
.tab-panel        { display:none; }
.tab-panel.active { display:block; }

/* ── SECTION HEADER ── */
.section-header { display:flex; align-items:center; justify-content:space-between; gap:1rem; margin-bottom:1.1rem; flex-wrap:wrap; }
.section-title  { font-size:.72rem; font-weight:700; color:var(--text-3); text-transform:uppercase; letter-spacing:.07em; display:flex; align-items:center; gap:.38rem; }
.section-title i { font-size:13px; color:var(--accent); }
.section-count  { color:var(--text-4); font-weight:400; }

/* ── EMPTY STATE ── */
.empty-state { text-align:center; padding:4rem 2rem; background:var(--bg-3); border:1px dashed var(--border-3); border-radius:var(--r-lg); color:var(--text-3); }
.empty-state i { font-size:2.4rem; display:block; margin-bottom:1rem; opacity:.25; }
.empty-state p { margin-bottom:1.2rem; font-size:.88rem; }

/* ── COVER PREVIEW ── */
.cover-preview { width:100%; aspect-ratio:16/9; background:var(--bg-4); border:1px solid var(--border-3); border-radius:var(--r); display:flex; align-items:center; justify-content:center; color:var(--text-4); overflow:hidden; margin-bottom:.6rem; }
.cover-preview img { width:100%; height:100%; object-fit:cover; display:block; }
