/* ═══════════════════════════════════════════
   EcoSello – Frontend Styles
   Tema: Orgánico / Natural / Refined
═══════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;700&family=DM+Sans:wght@400;500;600&display=swap');

:root {
    --eco-green:      #2d7a4f;
    --eco-green-dark: #1a4731;
    --eco-green-light:#e8f5ed;
    --eco-gold:       #b5862a;
    --eco-text:       #1c2e24;
    --eco-muted:      #6b7c72;
    --eco-border:     #d0e4d8;
    --eco-bg:         #f7faf8;
    --eco-white:      #ffffff;
    --eco-radius:     12px;
    --eco-shadow:     0 4px 20px rgba(45,122,79,.10);
}

.eco-wrap {
    font-family: 'DM Sans', sans-serif;
    color: var(--eco-text);
    max-width: 860px;
    margin: 0 auto;
    padding: 20px 0;
}

/* ── ALERTAS ── */
.eco-alert {
    padding: 14px 20px;
    border-radius: var(--eco-radius);
    margin-bottom: 24px;
    font-weight: 500;
}
.eco-alert--error   { background: #fdecea; border-left: 4px solid #c0392b; color: #5c1010; }
.eco-alert--success { background: var(--eco-green-light); border-left: 4px solid var(--eco-green); color: var(--eco-green-dark); }

/* ── HEADER REGISTRO ── */
.eco-register-header {
    text-align: center;
    padding: 40px 20px 32px;
    background: linear-gradient(135deg, #f0f9f3 0%, #e4f5ec 100%);
    border-radius: var(--eco-radius);
    margin-bottom: 32px;
    border: 1px solid var(--eco-border);
}
.eco-leaf-icon { font-size: 48px; margin-bottom: 12px; }
.eco-register-header h2 {
    font-family: 'Playfair Display', serif;
    font-size: 28px;
    color: var(--eco-green-dark);
    margin: 0 0 8px;
}
.eco-register-header p { color: var(--eco-muted); margin: 0; }

/* ── FORMULARIO ── */
.eco-form { background: var(--eco-white); border-radius: var(--eco-radius); padding: 32px; box-shadow: var(--eco-shadow); border: 1px solid var(--eco-border); }

.eco-fieldset {
    border: 1px solid var(--eco-border);
    border-radius: 10px;
    padding: 24px;
    margin-bottom: 24px;
    background: var(--eco-bg);
}
.eco-fieldset legend {
    font-family: 'Playfair Display', serif;
    font-size: 15px;
    font-weight: 700;
    color: var(--eco-green);
    padding: 0 10px;
}

.eco-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.eco-field { display: flex; flex-direction: column; gap: 6px; }
.eco-field--full { grid-column: 1 / -1; }
.eco-field label { font-size: 13px; font-weight: 600; color: var(--eco-muted); text-transform: uppercase; letter-spacing: .5px; }
.eco-field input[type="text"],
.eco-field input[type="email"],
.eco-field input[type="tel"],
.eco-field input[type="url"],
.eco-field input[type="password"] {
    border: 1.5px solid var(--eco-border);
    border-radius: 8px;
    padding: 10px 14px;
    font-family: 'DM Sans', sans-serif;
    font-size: 15px;
    color: var(--eco-text);
    background: var(--eco-white);
    transition: border-color .2s, box-shadow .2s;
    outline: none;
}
.eco-field input:focus { border-color: var(--eco-green); box-shadow: 0 0 0 3px rgba(45,122,79,.12); }
.eco-hint { font-size: 13px; color: var(--eco-muted); margin: 0 0 12px; }

/* ── BOTÓN ── */
.eco-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 14px 32px;
    border-radius: 50px;
    font-family: 'DM Sans', sans-serif;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    border: none;
    transition: transform .15s, box-shadow .15s;
}
.eco-btn--primary {
    background: linear-gradient(135deg, var(--eco-green), var(--eco-green-dark));
    color: #fff;
    box-shadow: 0 4px 14px rgba(45,122,79,.35);
    width: 100%;
    justify-content: center;
    margin-top: 8px;
}
.eco-btn--primary:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(45,122,79,.4); }

/* ── ESTADO ── */
.eco-status {
    text-align: center;
    padding: 48px 32px;
    border-radius: var(--eco-radius);
    border: 1px solid var(--eco-border);
}
.eco-status--pendiente  { background: #fffbf0; }
.eco-status--aprobada   { background: var(--eco-green-light); }
.eco-status--rechazada  { background: #fdecea; }
.eco-status__icon { font-size: 56px; margin-bottom: 16px; }
.eco-status h3 { font-family: 'Playfair Display', serif; font-size: 24px; margin: 0 0 10px; }

/* ── BADGES ── */
.eco-badge {
    display: inline-block;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .6px;
}
.eco-badge--aprobada { background: var(--eco-green-light); color: var(--eco-green-dark); }
.eco-badge--pendiente { background: #fff3cd; color: #856404; }
.eco-badge--rechazada { background: #fdecea; color: #7b1e1e; }

/* ── PORTAL ── */
.eco-portal-header {
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 28px 32px;
    background: linear-gradient(135deg, var(--eco-green-dark), var(--eco-green));
    border-radius: var(--eco-radius);
    margin-bottom: 28px;
    color: #fff;
}
.eco-portal-avatar { font-size: 48px; background: rgba(255,255,255,.15); width: 72px; height: 72px; display: flex; align-items: center; justify-content: center; border-radius: 50%; }
.eco-portal-header h2 { font-family: 'Playfair Display', serif; margin: 0 0 6px; font-size: 22px; color: #fff; }
.eco-portal-header .eco-badge--aprobada { background: rgba(255,255,255,.2); color: #fff; }

.eco-portal-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.eco-portal-card {
    background: var(--eco-white);
    border: 1px solid var(--eco-border);
    border-radius: var(--eco-radius);
    padding: 24px;
    box-shadow: var(--eco-shadow);
}
.eco-portal-card h3 { font-family: 'Playfair Display', serif; margin: 0 0 16px; color: var(--eco-green-dark); font-size: 17px; border-bottom: 1px solid var(--eco-border); padding-bottom: 10px; }
.eco-portal-card--cert, .eco-portal-card--resources { grid-column: auto; }

/* Certificado */
.eco-cert {
    text-align: center;
    padding: 24px 16px;
    background: linear-gradient(160deg, #fefdf8 0%, #f0faf4 100%);
    border: 2px solid var(--eco-gold);
    border-radius: 10px;
}
.eco-cert-seal { font-size: 44px; }
.eco-cert-title { font-size: 11px; letter-spacing: 3px; color: var(--eco-gold); font-weight: 700; margin: 4px 0; }
.eco-cert-name { font-family: 'Playfair Display', serif; font-size: 18px; color: var(--eco-green-dark); margin: 6px 0 4px; }
.eco-cert-text { font-size: 13px; color: var(--eco-muted); margin: 0; }

/* Docs list */
.eco-doc-list { list-style: none; padding: 0; margin: 0; }
.eco-doc-link {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border-radius: 8px;
    text-decoration: none;
    color: var(--eco-text);
    background: var(--eco-bg);
    margin-bottom: 8px;
    transition: background .15s;
}
.eco-doc-link:hover { background: var(--eco-green-light); }
.eco-doc-link small { margin-left: auto; color: var(--eco-muted); font-size: 12px; }
.eco-doc-icon { font-size: 18px; }

/* Recursos */
.eco-resource-list { list-style: none; padding: 0; margin: 0; }
.eco-resource-list li { padding: 8px 0; border-bottom: 1px solid var(--eco-border); }
.eco-resource-list li a { color: var(--eco-green); text-decoration: none; font-weight: 500; }
.eco-resource-list li a:hover { text-decoration: underline; }

/* ── DIRECTORIO ── */
.eco-directorio { display: flex; flex-direction: column; gap: 12px; }
.eco-dir-card {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 18px;
    background: var(--eco-white);
    border: 1px solid var(--eco-border);
    border-radius: 10px;
    box-shadow: 0 2px 8px rgba(0,0,0,.04);
}
.eco-dir-icon { font-size: 28px; flex-shrink: 0; }
.eco-dir-info { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.eco-dir-info strong { color: var(--eco-green-dark); font-size: 15px; }
.eco-dir-info a { color: var(--eco-green); font-size: 13px; text-decoration: none; }
.eco-dir-info small { color: var(--eco-muted); font-size: 12px; }

/* ── EMPTY ── */
.eco-empty { color: var(--eco-muted); font-style: italic; text-align: center; padding: 20px; }

/* ── RESPONSIVE ── */
@media (max-width: 640px) {
    .eco-grid-2 { grid-template-columns: 1fr; }
    .eco-portal-grid { grid-template-columns: 1fr; }
    .eco-portal-header { flex-direction: column; text-align: center; }
}
