/* Estilos para cámara, muro y panel — reutiliza tokens de styles.css */
.wrap{max-width:520px;margin:0 auto;padding:28px 20px 60px;text-align:center}
.back-home{display:inline-block;margin-bottom:14px;color:var(--ink-soft);text-decoration:none;font-size:.85rem;letter-spacing:.1em}
.lead{color:var(--ink-soft);max-width:34ch;margin:0 auto 22px}

/* ---------- cámara ---------- */
.camera-stage{position:relative;width:100%;aspect-ratio:3/4;background:#0c1f1d;border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-bottom:16px}
.camera-stage video,.camera-stage canvas,.camera-stage img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hidden{display:none!important}
.shutter{width:74px;height:74px;border-radius:50%;border:4px solid var(--rose-deep);background:#fff;cursor:pointer;margin:0 auto;display:block;box-shadow:0 2px 10px rgba(0,0,0,.15)}
.shutter:active{transform:scale(.94)}
.field{display:block;width:100%;margin:10px 0;padding:12px 14px;border:1px solid var(--line);background:#fff;font-family:inherit;font-size:1rem;color:var(--ink);border-radius:8px}
textarea.field{resize:vertical;min-height:60px}
.row{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:8px}
.note{font-size:.82rem;color:var(--ink-soft);margin-top:14px}
.state-msg{padding:30px 10px}
.state-msg .big{font-size:1.5rem;margin-bottom:8px}
.spinner{width:34px;height:34px;border:3px solid var(--line);border-top-color:var(--rose-deep);border-radius:50%;animation:spin 1s linear infinite;margin:18px auto}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- muro ---------- */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:18px}
@media(max-width:420px){.grid{grid-template-columns:repeat(2,1fr)}}
.grid .cell{position:relative;aspect-ratio:1;overflow:hidden;background:var(--rose);border-radius:6px;cursor:pointer}
.grid .cell img{width:100%;height:100%;object-fit:cover;display:block}
.empty{color:var(--ink-soft);margin-top:40px}
.lightbox{position:fixed;inset:0;background:rgba(12,31,29,.92);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:100;padding:20px}
.lightbox img{max-width:100%;max-height:80vh;border-radius:8px}
.lightbox .cap{color:#eef6f4;margin-top:14px;text-align:center;max-width:34ch}
.lightbox .cap .who{font-size:1.1rem;letter-spacing:.08em}
.lightbox-close{position:absolute;top:16px;right:20px;color:#eef6f4;font-size:2rem;cursor:pointer;line-height:1}

/* ---------- admin ---------- */
.admin-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px;margin-bottom:14px;text-align:left}
.admin-card img{width:100%;border-radius:8px;display:block;margin-bottom:10px}
.admin-card .meta{font-size:.9rem;color:var(--ink-soft);margin-bottom:10px}
.admin-card .who{color:var(--ink);font-size:1.05rem}
.tabs{display:flex;gap:8px;justify-content:center;margin:16px 0}
.tab{padding:8px 18px;border:1px solid var(--line);background:#fff;cursor:pointer;font-family:inherit;letter-spacing:.1em;text-transform:uppercase;font-size:.78rem;color:var(--ink-soft)}
.tab.active{background:var(--rose-deep);color:#fff;border-color:var(--rose-deep)}
.btn-sm{padding:9px 18px;border:1px solid var(--ink);background:transparent;color:var(--ink);cursor:pointer;font-family:inherit;letter-spacing:.12em;text-transform:uppercase;font-size:.76rem;border-radius:6px}
.btn-sm.ok{background:var(--rose-deep);color:#fff;border-color:var(--rose-deep)}
.btn-sm.danger{border-color:#b34a3f;color:#b34a3f}
.count-badge{display:inline-block;min-width:20px;padding:0 6px;background:var(--rose-deep);color:#fff;border-radius:10px;font-size:.75rem;margin-left:6px}
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;padding:10px 20px;border-radius:8px;font-size:.9rem;opacity:0;transition:opacity .3s;z-index:200}
.toast.show{opacity:1}
