/* 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}
/* página de cámara compacta: visor + disparador visibles sin hacer scroll */
.cam-page .wrap{padding-top:12px;padding-bottom:24px}
.cam-page .back-home{margin-bottom:6px}
.cam-page .title{font-size:1.6rem;margin-bottom:6px}
.cam-page .lead{font-size:.92rem;margin:0 auto 12px;max-width:30ch}
.cam-page .camera-stage{max-height:56vh;margin-bottom:12px}
.cam-page #cam-note{margin-top:10px}
/* al confirmar: encoger cabecera y previsualización para que quepa el botón "Subir foto" */
.cam-page.confirming .back-home,
.cam-page.confirming .lead{display:none}
.cam-page.confirming .title{font-size:1.25rem;margin:0 0 8px}
.cam-page.confirming .camera-stage{max-height:38vh}
.cam-page.confirming .field{margin:8px 0}
.cam-page.confirming textarea.field{min-height:46px}
/* estado final "¡Gracias!": cabecera oculta y previsualización pequeña, botones visibles */
.cam-page.done .back-home,
.cam-page.done .wrap > .title,
.cam-page.done .wrap > .lead{display:none}
.cam-page.done .camera-stage{max-height:30vh;margin-bottom:14px}
.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}
/* línea compacta cuando el nombre ya está guardado */
.name-saved{margin:10px 0;font-size:.95rem;color:var(--ink-soft)}
.name-saved b{color:var(--ink);font-weight:500}
.name-edit{border:0;background:none;padding:0;margin-left:4px;font-family:inherit;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--rose-deep);cursor:pointer;border-bottom:1px solid currentColor;line-height:1;padding-bottom:1px}
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}
.section-tabs{margin:4px 0 18px}
.section-divider{width:78%;max-width:300px;height:1px;margin:0 auto 26px;background:linear-gradient(to right,transparent,var(--line) 22%,var(--line) 78%,transparent)}
.section-pane{text-align:center}
/* selector de archivo con el estilo de la web */
/* configuración · música */
.music-admin{max-width:330px;margin:0 auto}
.music-admin .lead{margin:10px 0 4px}
.music-label{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft)}
.music-name{font-size:1.15rem;color:var(--ink);margin:4px 0 10px;word-break:break-word}
.file-name{font-size:.8rem;color:var(--ink-soft);margin:8px auto 0;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
/* rejilla 2×2 de acciones, botones compactos */
.music-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;max-width:300px;margin:8px auto 0}
.btn-sm2{display:flex;align-items:center;justify-content:center;text-align:center;line-height:1.15;
  padding:10px 6px;border:1px solid var(--ink);background:transparent;color:var(--ink);
  font-family:inherit;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;
  border-radius:6px;cursor:pointer;transition:background .2s,color .2s}
.btn-sm2:hover{background:var(--ink);color:#fff}
.btn-sm2.primary{background:var(--rose-deep);border-color:var(--rose-deep);color:#fff}
.btn-sm2.primary:hover{background:var(--ink);border-color:var(--ink)}
.file-pick{position:relative}
.file-pick input[type=file]{position:absolute;width:1px;height:1px;opacity:0;overflow:hidden;border:0;padding:0;margin:-1px}
#music-rename-box{margin-top:12px}
/* editor de contenido (textos/enlaces) */
.content-admin{max-width:380px;margin:0 auto}
.cms-group{border:1px solid var(--line);border-radius:8px;margin-bottom:8px;background:rgba(255,255,255,.4);text-align:left;overflow:hidden}
.cms-group>summary{cursor:pointer;padding:10px 12px;font-family:inherit;letter-spacing:.08em;text-transform:uppercase;font-size:.76rem;color:var(--ink);list-style:none;display:flex;align-items:center;gap:8px}
.cms-group>summary::-webkit-details-marker{display:none}
.cms-group>summary::before{content:"+";color:var(--rose-deep);font-weight:600}
.cms-group[open]>summary::before{content:"–"}
.cms-group[open]>summary{border-bottom:1px solid var(--line)}
.sec-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sec-ctrls{display:flex;align-items:center;gap:5px;text-transform:none;letter-spacing:0}
.sec-btn{width:26px;height:24px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:5px;cursor:pointer;font-size:.6rem;line-height:1;padding:0}
.sec-btn:hover{background:var(--rose)}
.sec-toggle{padding:5px 9px;border:1px solid var(--rose-deep);background:var(--rose-deep);color:#fff;border-radius:5px;cursor:pointer;font-family:inherit;font-size:.6rem;letter-spacing:.04em;text-transform:uppercase;line-height:1;white-space:nowrap}
.sec-toggle.off{background:transparent;color:var(--ink-soft);border-color:var(--line)}
.sec-fixed{font-size:.6rem;letter-spacing:.06em;color:var(--ink-soft);text-transform:uppercase;opacity:.55}
.cms-group.sec-disabled>summary .sec-title{opacity:.45;text-decoration:line-through}
.cms-field{display:block;padding:9px 14px}
.cms-field span{display:block;font-size:.7rem;letter-spacing:.04em;color:var(--ink-soft);margin-bottom:4px}
.content-admin .field{margin:0;font-size:.95rem}
.content-admin textarea.field{min-height:64px;resize:vertical}
/* mini-editor con formato (negrita/cursiva/subrayado) */
.rt-toolbar{display:flex;gap:6px;margin-bottom:6px;flex-wrap:wrap}
.rt-btn{padding:5px 10px;border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:5px;cursor:pointer;font-family:inherit;font-size:.82rem;line-height:1}
.rt-btn:hover{background:var(--rose)}
.rt-btn.rt-clear{font-size:.68rem;letter-spacing:.04em;color:var(--ink-soft);text-transform:uppercase}
.rt-editor{min-height:62px;text-align:left;line-height:1.5}
.rt-editor:focus{outline:none;border-color:var(--rose-deep)}
#cms-save{margin:16px auto 0}
/* códigos QR */
.qr-list{display:flex;flex-direction:column;gap:26px;align-items:center;margin-top:10px}
.qr-item{text-align:center;max-width:300px}
.qr-img{width:190px;height:190px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:8px;display:block;margin:0 auto}
.qr-name{font-size:1.05rem;letter-spacing:.04em;color:var(--ink);margin-top:12px}
.qr-url{font-size:.72rem;color:var(--rose-deep);word-break:break-all;margin:2px 0 6px}
.qr-use{font-size:.82rem;color:var(--ink-soft);margin-bottom:10px}
.qr-item .btn-sm2{display:inline-flex;width:auto;margin:0 auto}
.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}
#sec-fotos .tabs{flex-wrap:wrap;row-gap:8px}
#download-all{width:auto;margin:0;padding:8px 12px;text-decoration:none;white-space:nowrap}
/* moderación en rejilla de miniaturas (poco scroll con muchas fotos) */
.mod-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:8px}
@media(min-width:600px){.mod-grid{grid-template-columns:repeat(3,1fr)}}
.mod-cell{background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden;display:flex;flex-direction:column}
.mod-thumb{position:relative;width:100%;aspect-ratio:1;border:0;padding:0;cursor:pointer;background:var(--rose) center/cover no-repeat;display:block}
.mod-name{position:absolute;left:0;right:0;bottom:0;padding:4px 7px;font-size:.72rem;color:#fff;background:linear-gradient(to top,rgba(0,0,0,.6),transparent);text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mod-acts{display:flex;gap:6px;padding:6px}
.mod-act{flex:1;padding:8px 0;border:1px solid var(--ink);background:#fff;color:var(--ink);border-radius:6px;cursor:pointer;font-size:.85rem;line-height:1;font-family:inherit;letter-spacing:.04em}
.mod-act.ok{background:var(--rose-deep);border-color:var(--rose-deep);color:#fff}
.mod-act.danger{border-color:#b34a3f;color:#b34a3f}
/* lightbox de moderación */
.mod-lightbox{position:fixed;inset:0;background:rgba(12,31,29,.93);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:300;padding:20px;gap:14px}
.mod-lightbox img{max-width:100%;max-height:60vh;border-radius:8px}
.mod-close{position:absolute;top:14px;right:18px;background:none;border:0;color:#eef6f4;font-size:1.7rem;cursor:pointer;line-height:1}
.mod-lb-meta{color:#eef6f4;text-align:center;max-width:34ch}
.mod-lb-meta .who{font-size:1.05rem;letter-spacing:.06em}
.mod-lb-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.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}
