/* components.css — Piezas: marca, nav, acciones, feed, tarjetas, panel, modal.
   Reglas estéticas: radio 0, hairlines de 1px, acciones sin relleno, acento como filete. */

/* marca mínima (sin wordmark de texto) */
.mark{display:inline-block;font-size:16px;color:var(--accent);margin-bottom:24px;line-height:1}

/* navegación */
#nav{display:flex;flex-direction:column;gap:1px;flex:1}
.nav-item{display:flex;align-items:center;gap:12px;padding:8px 0 8px 12px;color:var(--ink-soft);font-size:15px;border-left:2px solid transparent}
.nav-item:hover{color:var(--ink)}
.nav-item.active{color:var(--accent);border-left-color:var(--accent)}
.nav-item .dot{width:9px;height:9px;flex:0 0 auto}     /* cuadrado, no círculo */
.nav-item .ico{width:9px;color:var(--mut);font-size:12px;text-align:center}

/* acciones: borde fino + versalitas (nada de píldoras rellenas) */
.action{display:inline-block;border:1px solid var(--line-strong);color:var(--ink);padding:9px 16px;font-family:var(--sans);font-size:12px;letter-spacing:.14em;text-transform:uppercase}
.action:hover{border-color:var(--accent);color:var(--accent)}
.action--full{display:block;width:100%;text-align:center}
.link{color:var(--mut);font-family:var(--sans);font-size:12px;letter-spacing:.04em;border-bottom:1px solid var(--line-strong);padding-bottom:1px}
.link:hover{color:var(--accent);border-color:var(--accent)}
.sidebar .action{margin-top:18px}
.auth-status{margin-top:14px;color:var(--mut);font-size:12px;font-family:var(--sans)}
.auth-status a{color:var(--accent);border-bottom:1px solid var(--accent)}

/* pills (móvil) */
.pill{white-space:nowrap;display:flex;align-items:center;gap:8px;color:var(--ink-soft);font-family:var(--sans);font-size:14px;padding-bottom:4px;border-bottom:1px solid transparent}
.pill.active{color:var(--accent);border-color:var(--accent)}
.pill .dot{width:9px;height:9px}

/* cabecera de feed */
.feed-head{position:sticky;top:0;z-index:3;background:var(--bg);border-bottom:1px solid var(--line);padding:18px var(--pad) 12px;display:flex;flex-direction:column;gap:10px}
.fh-title{font-family:var(--serif);font-size:24px;font-weight:600}
.fh-title .count{font-family:var(--sans);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--mut);margin-left:10px}
.sortbar{display:flex;gap:18px}
.sortb{color:var(--mut);font-family:var(--sans);font-size:12px;letter-spacing:.04em;padding-bottom:2px;border-bottom:1px solid transparent}
.sortb.on{color:var(--accent);border-color:var(--accent)}

/* compose */
.compose{display:flex;flex-direction:column;gap:10px;padding:16px var(--pad);border-bottom:1px solid var(--line)}
.compose input,.compose textarea,.modal input,.modal textarea{background:var(--bg-soft);border:1px solid var(--line-strong);color:var(--ink);padding:10px 12px;font:inherit;width:100%;border-radius:0}
.compose textarea{min-height:92px;resize:vertical;font-family:var(--serif);font-size:16px}
.compose .c-actions{display:flex;justify-content:flex-end}

/* tarjetas: separadas por hairline, sin relleno, sin radio */
.card{display:grid;grid-template-columns:44px 1fr;gap:14px;padding:18px var(--pad);border-bottom:1px solid var(--line)}
.card:hover{background:var(--bg-soft)}
.avatar{width:44px;height:60px;object-fit:cover;border:1px solid var(--line-strong)}  /* portada en miniatura, nítida */
.avatar.letter{display:flex;align-items:center;justify-content:center;color:#000;font-family:var(--serif);font-weight:700;font-size:20px}
.card-head{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;margin-bottom:2px}
.card-head .name{font-family:var(--sans);font-weight:600;font-size:14px}
.card-head .handle,.card-head .date,.card-head .sep{color:var(--mut);font-family:var(--sans);font-size:12px}
.badge{font-family:var(--sans);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mut)}
.badge::before{content:"— "}
.badge.wattpad{color:var(--ink-soft)}
.badge.propio{color:var(--accent)}
.card-title{font-family:var(--serif);font-weight:600;font-size:19px;margin:6px 0}
.card-body{font-family:var(--serif);font-size:16.5px;line-height:1.66}
.card-body p{margin:0 0 12px}
.card-body img{margin:8px 0;border:1px solid var(--line-strong)}
.orig,.card .link{margin-top:6px;display:inline-block}
.empty{padding:32px var(--pad);color:var(--mut);font-family:var(--sans)}

/* inicio: índice de mundos en rejilla con hairlines */
.grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.wcard{display:flex;gap:14px;align-items:center;background:var(--bg);padding:16px var(--pad);border-left:2px solid var(--wa,var(--accent))}
.wcard:hover{background:var(--bg-soft)}
.wcard img{width:48px;height:66px;object-fit:cover;border:1px solid var(--line-strong)}
.wcard-letter{width:48px;height:66px;display:flex;align-items:center;justify-content:center;color:#000;font-family:var(--serif);font-weight:700;font-size:22px;flex:0 0 auto}
.wcard-title{font-family:var(--serif);font-size:17px;font-weight:600}
.wcard-meta{color:var(--mut);font-family:var(--sans);font-size:12px;letter-spacing:.03em;margin-top:3px}
.newstory-cta{padding:18px var(--pad)}

/* panel derecho */
.pcard{border:1px solid var(--line);border-top:2px solid var(--wa,var(--accent));padding:18px}
.pcover{width:100%;border:1px solid var(--line-strong);margin-bottom:12px}
.pcover.letter{aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;color:#000;font-family:var(--serif);font-size:54px;font-weight:700}
.ptitle{font-family:var(--serif);font-size:18px;font-weight:600}
.pdesc{color:var(--ink-soft);font-family:var(--serif);font-style:italic;font-size:14.5px;margin-top:8px}
.pstats{margin-top:12px;color:var(--mut);font-family:var(--sans);font-size:11px;letter-spacing:.1em;text-transform:uppercase}
.pnote{margin-top:10px;color:var(--accent);font-family:var(--sans);font-size:12px}
.panel .action{margin-top:16px}

/* modal */
.modal-backdrop[hidden]{display:none}        /* arregla el "medio apagado": el atributo hidden debe ocultar de verdad */
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.66);display:flex;align-items:center;justify-content:center;z-index:50}
.modal{background:var(--bg);border:1px solid var(--line-strong);padding:24px;width:min(440px,92vw);display:flex;flex-direction:column;gap:14px}
.modal h3{margin:0;font-family:var(--serif);font-size:22px;font-weight:600}
.modal .muted{margin:0;color:var(--mut);font-size:13px;font-family:var(--sans)}
.modal .err{color:#d9685f;font-size:13px;font-family:var(--sans)}
.modal-actions{display:flex;justify-content:flex-end;gap:14px;align-items:center;margin-top:4px}
.color-row{display:flex;align-items:center;gap:10px;color:var(--mut);font-size:13px;font-family:var(--sans)}
.color-row input[type=color]{width:42px;height:30px;border:1px solid var(--line-strong);background:none;padding:0}

/* edición */
.link.danger{color:#d9685f;border-color:transparent}
.link.danger:hover{color:#ff7a6f;border-color:#d9685f}
.fh-actions{display:flex;gap:16px;margin-top:2px}
.card-actions{display:flex;gap:14px;margin-top:8px}
.modal textarea.big{min-height:240px;font-family:var(--serif);font-size:16px;line-height:1.62}
.modal .spacer{flex:1}
.hist{display:flex;flex-direction:column;gap:0;max-height:300px;overflow:auto;border-top:1px solid var(--line)}
.hist-row{display:flex;justify-content:space-between;align-items:center;gap:12px;border-bottom:1px solid var(--line);padding:9px 0;font-family:var(--sans);font-size:13px;color:var(--mut)}
