/* ════════════════════════════════════════════════════════
   Envíos Públicos — El Rincón del Cornudo
   envios.css v1.0.0
════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Syne:wght@700;800&family=DM+Sans:wght@400;500&display=swap');

.rcenv-wrap, .rcenv-galeria-wrap {
    --e-bg:      #0d0d0f;
    --e-surface: #16161a;
    --e-s2:      #1e1e26;
    --e-border:  #2a2a35;
    --e-accent:  #e8405a;
    --e-text:    #f0f0f5;
    --e-muted:   #66667a;
    --e-green:   #10b981;
    font-family: 'DM Sans', sans-serif;
    box-sizing: border-box;
}
.rcenv-wrap *, .rcenv-galeria-wrap * { box-sizing: border-box; }

/* ── FORMULARIO ─────────────────────────────────────── */
.rcenv-wrap {
    background: var(--e-bg);
    border: 1px solid var(--e-border);
    border-radius: 18px;
    padding: 28px 24px;
    max-width: 680px;
    margin: 0 auto 32px;
}

/* Selector tipo */
.rcenv-type-selector {
    display: flex;
    gap: 10px;
    margin-bottom: 24px;
    flex-wrap: wrap;
}
.rcenv-type-btn {
    flex: 1;
    min-width: 100px;
    padding: 12px 10px;
    background: var(--e-s2);
    border: 2px solid var(--e-border);
    border-radius: 12px;
    color: var(--e-muted) !important;
    font-family: 'Syne', sans-serif !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    cursor: pointer;
    transition: all .18s;
    text-align: center;
    outline: none;
}
.rcenv-type-btn:hover  { border-color: var(--e-accent); color: var(--e-text) !important; }
.rcenv-type-btn.active { border-color: var(--e-accent); background: rgba(232,64,90,.1); color: var(--e-accent) !important; }

/* Campos */
.rcenv-field   { margin-bottom: 16px; }
.rcenv-label   { display: block; font-size: 13px; font-weight: 600; color: var(--e-muted); margin-bottom: 6px; text-transform: uppercase; letter-spacing: .05em; }
.rcenv-req     { color: var(--e-accent); }

.rcenv-input, .rcenv-textarea {
    width: 100% !important;
    background: var(--e-s2) !important;
    border: 1.5px solid var(--e-border) !important;
    border-radius: 11px !important;
    padding: 11px 14px !important;
    color: var(--e-text) !important;
    font-family: 'DM Sans', sans-serif !important;
    font-size: 14px !important;
    outline: none !important;
    transition: border-color .15s !important;
    box-shadow: none !important;
    -webkit-text-fill-color: var(--e-text) !important;
}
.rcenv-input::placeholder, .rcenv-textarea::placeholder { color: var(--e-muted) !important; opacity: 1 !important; }
.rcenv-input:focus, .rcenv-textarea:focus { border-color: var(--e-accent) !important; }

.rcenv-textarea { resize: vertical !important; line-height: 1.5 !important; }
.rcenv-relato   { min-height: 200px !important; }

.rcenv-char-count { text-align: right; font-size: 11px; color: var(--e-muted); margin-top: 4px; }

/* Drop area */
.rcenv-drop-area {
    border: 2px dashed var(--e-border);
    border-radius: 14px;
    padding: 32px 20px;
    text-align: center;
    cursor: pointer;
    transition: border-color .18s, background .18s;
    position: relative;
    background: var(--e-s2);
}
.rcenv-drop-area:hover, .rcenv-drop-area.drag-over {
    border-color: var(--e-accent);
    background: rgba(232,64,90,.06);
}
.rcenv-drop-icon { font-size: 36px; margin-bottom: 8px; }
.rcenv-drop-text { font-size: 14px; color: var(--e-text); margin-bottom: 4px; }
.rcenv-link      { color: var(--e-accent); text-decoration: underline; cursor: pointer; }
.rcenv-drop-hint { font-size: 11px; color: var(--e-muted); }
.rcenv-file-input {
    position: absolute; inset: 0; opacity: 0; cursor: pointer; width: 100%; height: 100%;
}

/* Preview */
.rcenv-preview { margin-top: 12px; text-align: center; }
.rcenv-preview img { max-width: 100%; max-height: 280px; border-radius: 10px; object-fit: cover; }
.rcenv-remove-file {
    display: block; margin: 8px auto 0;
    background: none; border: 1px solid var(--e-border);
    color: var(--e-muted); border-radius: 8px; padding: 5px 14px;
    font-size: 12px; cursor: pointer; transition: all .15s;
}
.rcenv-remove-file:hover { border-color: var(--e-accent); color: var(--e-accent); }

/* Tabs mini (vídeo) */
.rcenv-tabs-mini { display: flex; gap: 8px; margin-bottom: 14px; }
.rcenv-tab-mini {
    padding: 7px 14px; background: var(--e-s2);
    border: 1.5px solid var(--e-border); border-radius: 8px;
    color: var(--e-muted) !important; font-size: 13px; font-weight: 600;
    cursor: pointer; transition: all .15s; outline: none;
}
.rcenv-tab-mini.active { border-color: var(--e-accent); color: var(--e-accent) !important; background: rgba(232,64,90,.08); }

/* YouTube embed en galería */
.rcenv-yt-wrap { position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden; border-radius: 10px; }
.rcenv-yt-wrap iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: none; }

/* Aviso legal */
.rcenv-legal { margin: 20px 0 16px; }
.rcenv-check-label {
    display: flex; gap: 10px; align-items: flex-start; cursor: pointer;
    font-size: 12px; color: var(--e-muted); line-height: 1.5;
}
.rcenv-check-label input { margin-top: 2px; flex-shrink: 0; accent-color: var(--e-accent); width: 15px; height: 15px; }

/* Submit */
.rcenv-submit-row { text-align: center; }
.rcenv-submit-btn {
    background: linear-gradient(135deg, #e8405a, #c0283e) !important;
    border: none !important; border-radius: 12px !important;
    color: #fff !important; font-family: 'Syne', sans-serif !important;
    font-size: 16px !important; font-weight: 700 !important;
    padding: 14px 36px !important; cursor: pointer !important;
    transition: opacity .15s, transform .15s !important;
    width: 100% !important; max-width: 320px !important;
}
.rcenv-submit-btn:hover { opacity: .9 !important; transform: translateY(-1px) !important; }
.rcenv-submit-btn:disabled { opacity: .4 !important; cursor: not-allowed !important; transform: none !important; }

/* Progreso */
.rcenv-progress { margin-top: 16px; }
.rcenv-progress-bar {
    height: 6px; background: var(--e-border); border-radius: 3px; overflow: hidden; margin-bottom: 6px;
}
.rcenv-progress-bar::after {
    content: ''; display: block; height: 100%;
    background: linear-gradient(90deg, #e8405a, #ff6b8a);
    width: var(--pct, 0%); transition: width .3s;
}
.rcenv-progress-text { font-size: 12px; color: var(--e-muted); text-align: center; }

/* Mensajes */
.rcenv-msg {
    margin-top: 14px; padding: 12px 16px; border-radius: 10px;
    font-size: 14px; text-align: center;
}
.rcenv-msg.error { background: rgba(239,68,68,.12); color: #f87171; border: 1px solid rgba(239,68,68,.3); }
.rcenv-msg.ok    { background: rgba(16,185,129,.12); color: #34d399; border: 1px solid rgba(16,185,129,.3); }

/* Éxito */
.rcenv-success { text-align: center; padding: 32px 20px; }
.rcenv-success-icon { font-size: 56px; margin-bottom: 12px; }
.rcenv-success h3 { font-family: 'Syne', sans-serif; font-size: 22px; color: var(--e-text); margin: 0 0 8px; }
.rcenv-success p  { color: var(--e-muted); font-size: 14px; margin: 0 0 20px; }
.rcenv-reset-btn {
    background: var(--e-s2); border: 1px solid var(--e-border);
    color: var(--e-text) !important; border-radius: 10px; padding: 10px 24px;
    font-size: 14px; cursor: pointer; transition: border-color .15s;
}
.rcenv-reset-btn:hover { border-color: var(--e-accent); }

/* ── GALERÍA ─────────────────────────────────────────── */
.rcenv-galeria-wrap { max-width: 1100px; margin: 0 auto; }

.rcenv-galeria-filtros {
    display: flex; gap: 8px; margin-bottom: 20px; flex-wrap: wrap;
}
.rcenv-filtro {
    padding: 7px 16px; background: var(--e-s2);
    border: 1.5px solid var(--e-border); border-radius: 20px;
    color: var(--e-muted) !important; font-size: 13px; font-weight: 600;
    cursor: pointer; transition: all .15s; outline: none;
}
.rcenv-filtro:hover, .rcenv-filtro.active {
    border-color: var(--e-accent); color: var(--e-accent) !important;
    background: rgba(232,64,90,.08);
}

.rcenv-galeria {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 18px;
}

.rcenv-item {
    background: var(--e-surface);
    border: 1px solid var(--e-border);
    border-radius: 14px;
    overflow: hidden;
    transition: transform .2s, box-shadow .2s, border-color .2s;
}
.rcenv-item:hover { transform: translateY(-3px); box-shadow: 0 10px 32px rgba(232,64,90,.2); border-color: var(--e-accent); }
.rcenv-item.hidden { display: none; }

.rcenv-item-media { position: relative; }
.rcenv-item-media img {
    width: 100% !important; height: 200px !important;
    object-fit: cover !important; display: block !important;
    cursor: zoom-in !important; border-radius: 0 !important;
    border: none !important; margin: 0 !important;
}
.rcenv-item-media video { width: 100%; display: block; max-height: 220px; background: #000; }

.rcenv-badge {
    position: absolute; top: 10px; left: 10px;
    font-size: 10px; font-weight: 700; padding: 3px 8px;
    border-radius: 20px; color: #fff !important;
    font-family: 'Syne', sans-serif;
}
.rcenv-badge.foto   { background: #e8405a; }
.rcenv-badge.video  { background: #7c3aed; }
.rcenv-badge.relato { background: #0284c7; }

.rcenv-item-relato {
    height: 120px; display: flex; align-items: center;
    justify-content: center; background: #0a1628; position: relative;
}
.rcenv-relato-icon { font-size: 48px; }

.rcenv-item-info { padding: 14px 16px; }
.rcenv-item-title {
    font-family: 'Syne', sans-serif !important;
    font-size: 14px !important; font-weight: 700 !important;
    color: var(--e-text) !important; margin: 0 0 6px !important;
    line-height: 1.35 !important;
}
.rcenv-item-meta {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 8px;
}
.rcenv-item-apodo, .rcenv-item-date { font-size: 11px; color: var(--e-muted); }
.rcenv-item-desc { font-size: 12px; color: var(--e-muted); line-height: 1.5; margin-bottom: 8px; }
.rcenv-relato-preview { font-size: 13px; color: #a1a1b5; line-height: 1.6; margin-bottom: 10px; font-style: italic; }

.rcenv-ver-relato {
    background: none; border: 1px solid var(--e-accent);
    color: var(--e-accent) !important; border-radius: 8px;
    padding: 5px 12px; font-size: 12px; cursor: pointer;
    transition: background .15s; font-weight: 600;
}
.rcenv-ver-relato:hover { background: rgba(232,64,90,.1); }

.rcenv-empty { text-align: center; padding: 40px; color: var(--e-muted); font-size: 15px; }

/* Modal relato */
.rcenv-modal {
    position: fixed; inset: 0; background: rgba(0,0,0,.85);
    z-index: 99999; display: flex; align-items: center; justify-content: center; padding: 20px;
}
.rcenv-modal-box {
    background: #16161a; border: 1px solid #2a2a35; border-radius: 16px;
    max-width: 680px; width: 100%; max-height: 85vh;
    overflow-y: auto; padding: 28px; position: relative;
}
.rcenv-modal-close {
    position: absolute; top: 14px; right: 14px;
    background: #1e1e26; border: none; border-radius: 50%;
    color: #f0f0f5; width: 30px; height: 30px; font-size: 14px;
    cursor: pointer; display: flex; align-items: center; justify-content: center;
}
.rcenv-modal-box h3 { font-family: 'Syne', sans-serif; color: #f0f0f5; margin: 0 32px 18px 0; }
.rcenv-modal-body { color: #d1d5db; font-size: 15px; line-height: 1.8; white-space: pre-wrap; font-family: Georgia, serif; }

/* Lightbox */
.rcenv-lightbox {
    position: fixed; inset: 0; background: rgba(0,0,0,.93);
    z-index: 999999; display: flex; align-items: center; justify-content: center; cursor: zoom-out;
}
.rcenv-lightbox img { max-width: 92vw; max-height: 92vh; border-radius: 10px; }

@media (max-width: 600px) {
    .rcenv-wrap { padding: 18px 14px; }
    .rcenv-galeria { grid-template-columns: 1fr 1fr; gap: 12px; }
    .rcenv-type-btn { font-size: 12px !important; padding: 9px 6px; }
}
@media (max-width: 400px) {
    .rcenv-galeria { grid-template-columns: 1fr; }
}
