/* ==========================================================================
   Finca Raíz Pro - Estilos del frontend
   ========================================================================== */

:root {
    --fr-primary:      #2d7a3e;
    --fr-primary-dark: #1f5a2c;
    --fr-danger:       #dc3545;
    --fr-danger-dark:  #b92838;
    --fr-text:         #22313f;
    --fr-muted:        #6b7280;
    --fr-bg:           #f5f7fa;
    --fr-card-bg:      #ffffff;
    --fr-border:       #e5e7eb;
    --fr-radius:       10px;
    --fr-shadow:       0 4px 14px rgba(0, 0, 0, .06);
    --fr-shadow-hover: 0 10px 30px rgba(0, 0, 0, .12);
}

/* --------------------------------------------------------------------------
   AUTH (login/register)
   -------------------------------------------------------------------------- */
.fr-auth-wrapper {
    min-height: 100vh;
    padding: 60px 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #1f5a2c 0%, #2d7a3e 50%, #4caf50 100%);
}

.fr-auth-card {
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, .25);
    padding: 40px;
    width: 100%;
    max-width: 460px;
}

.fr-auth-brand {
    text-align: center;
    margin-bottom: 30px;
}

.fr-auth-brand i {
    font-size: 3.2rem;
    color: var(--fr-primary);
    margin-bottom: 10px;
}

.fr-auth-brand h1 {
    margin: 0;
    font-size: 1.9rem;
    color: var(--fr-text);
    letter-spacing: 2px;
}

.fr-auth-brand p {
    margin: 6px 0 0;
    color: var(--fr-muted);
    font-size: .95rem;
}

.fr-auth-links {
    text-align: center;
    margin-top: 20px;
    color: var(--fr-muted);
    font-size: .95rem;
}

.fr-auth-links a {
    color: var(--fr-primary);
    font-weight: 600;
    text-decoration: none;
}

.fr-auth-links a:hover { text-decoration: underline; }

/* --------------------------------------------------------------------------
   FORMULARIOS GENERALES
   -------------------------------------------------------------------------- */
.fr-form label,
.fr-property-form label {
    display: block;
    font-weight: 600;
    margin: 14px 0 6px;
    color: var(--fr-text);
    font-size: .92rem;
}

.fr-form input[type="text"],
.fr-form input[type="email"],
.fr-form input[type="tel"],
.fr-form input[type="password"],
.fr-property-form input[type="text"],
.fr-property-form input[type="number"],
.fr-property-form input[type="email"],
.fr-property-form input[type="file"],
.fr-property-form select,
.fr-property-form textarea,
.fr-form textarea,
.fr-form select {
    width: 100%;
    padding: 11px 14px;
    border: 1px solid var(--fr-border);
    border-radius: 8px;
    font-size: .95rem;
    background: #fff;
    color: var(--fr-text);
    transition: border-color .2s, box-shadow .2s;
}

.fr-form input:focus,
.fr-property-form input:focus,
.fr-property-form select:focus,
.fr-property-form textarea:focus,
.fr-form textarea:focus,
.fr-form select:focus {
    outline: none;
    border-color: var(--fr-primary);
    box-shadow: 0 0 0 3px rgba(45, 122, 62, .15);
}

.fr-checkbox {
    display: flex !important;
    align-items: center;
    gap: 8px;
    font-weight: 500 !important;
}

/* --------------------------------------------------------------------------
   BOTONES
   -------------------------------------------------------------------------- */
.fr-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 18px;
    border: 1px solid transparent;
    border-radius: 8px;
    background: #eee;
    color: var(--fr-text);
    cursor: pointer;
    text-decoration: none;
    font-size: .95rem;
    font-weight: 600;
    transition: transform .15s, box-shadow .2s, background .2s, color .2s;
}

.fr-btn:hover { transform: translateY(-1px); box-shadow: var(--fr-shadow); }

.fr-btn-primary { background: var(--fr-primary); color: #fff; }
.fr-btn-primary:hover { background: var(--fr-primary-dark); color: #fff; }

.fr-btn-danger { background: var(--fr-danger); color: #fff; }
.fr-btn-danger:hover { background: var(--fr-danger-dark); color: #fff; }

.fr-btn-outline {
    background: transparent;
    color: var(--fr-primary);
    border-color: var(--fr-primary);
}
.fr-btn-outline:hover { background: var(--fr-primary); color: #fff; }

.fr-btn-lg { padding: 14px 26px; font-size: 1.05rem; }
.fr-btn-sm { padding: 6px 10px;  font-size: .85rem; }

.fr-form button[type="submit"] { width: 100%; margin-top: 20px; justify-content: center; }

/* --------------------------------------------------------------------------
   ALERTAS
   -------------------------------------------------------------------------- */
.fr-alert {
    padding: 12px 16px;
    border-radius: 8px;
    margin-bottom: 16px;
    font-size: .95rem;
    border: 1px solid transparent;
}
.fr-alert-error   { background: #fdecea; color: #7f1d1d; border-color: #fecaca; }
.fr-alert-success { background: #e8f6ec; color: #14532d; border-color: #bbf7d0; }

/* --------------------------------------------------------------------------
   PORTAL (dashboard, form, mis propiedades)
   -------------------------------------------------------------------------- */
.fr-portal {
    background: var(--fr-bg);
    min-height: 100vh;
}

.fr-portal-header {
    background: #fff;
    box-shadow: var(--fr-shadow);
    position: sticky;
    top: 0;
    z-index: 100;
}

.fr-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 24px 20px;
}

.fr-portal-header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    padding-top: 14px;
    padding-bottom: 14px;
}

.fr-brand {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-weight: 800;
    font-size: 1.35rem;
    color: var(--fr-primary);
    text-decoration: none;
    letter-spacing: 1px;
}
.fr-brand i { font-size: 1.6rem; }

.fr-portal-nav {
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
}
.fr-portal-nav a {
    color: var(--fr-text);
    text-decoration: none;
    padding: 8px 14px;
    border-radius: 8px;
    font-weight: 600;
    font-size: .95rem;
    transition: background .2s;
}
.fr-portal-nav a:hover { background: #eef2f7; color: var(--fr-primary); }

.fr-portal-user {
    display: flex;
    align-items: center;
    gap: 12px;
}
.fr-user-name { color: var(--fr-muted); font-size: .9rem; }

/* --- Welcome dashboard --- */
.fr-welcome-card {
    background: linear-gradient(135deg, var(--fr-primary) 0%, #4caf50 100%);
    color: #fff;
    padding: 30px;
    border-radius: var(--fr-radius);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    margin-bottom: 28px;
    box-shadow: var(--fr-shadow);
}
.fr-welcome-card h2 { margin: 0 0 6px; font-size: 1.6rem; }
.fr-welcome-card p  { margin: 0; opacity: .92; }
.fr-welcome-count   { text-align: center; }
.fr-welcome-count .fr-num   { display: block; font-size: 3rem; font-weight: 800; line-height: 1; }
.fr-welcome-count .fr-label { font-size: .85rem; opacity: .9; }

.fr-actions-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 20px;
}

.fr-action-card {
    background: var(--fr-card-bg);
    padding: 26px;
    border-radius: var(--fr-radius);
    text-decoration: none;
    color: var(--fr-text);
    box-shadow: var(--fr-shadow);
    transition: transform .2s, box-shadow .2s;
    border: 1px solid transparent;
}
.fr-action-card:hover { transform: translateY(-3px); box-shadow: var(--fr-shadow-hover); border-color: var(--fr-primary); }
.fr-action-card i { font-size: 2rem; color: var(--fr-primary); margin-bottom: 12px; display: block; }
.fr-action-card h3 { margin: 0 0 6px; font-size: 1.15rem; }
.fr-action-card p  { margin: 0; color: var(--fr-muted); font-size: .9rem; }

.fr-action-primary { background: linear-gradient(135deg, var(--fr-primary), #4caf50); color: #fff; }
.fr-action-primary i,
.fr-action-primary p { color: #fff; opacity: .95; }

/* --- Page title / secciones del form --- */
.fr-page-title {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
    gap: 10px;
    flex-wrap: wrap;
}
.fr-page-title h2 { margin: 0; color: var(--fr-text); }

.fr-property-form { background: var(--fr-card-bg); padding: 30px; border-radius: var(--fr-radius); box-shadow: var(--fr-shadow); }

.fr-form-section { padding-bottom: 24px; margin-bottom: 24px; border-bottom: 1px dashed var(--fr-border); }
.fr-form-section:last-of-type { border-bottom: 0; }
.fr-form-section h3 { color: var(--fr-primary); margin: 0 0 14px; font-size: 1.15rem; }

.fr-form-grid-3 { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 14px; }

.fr-current-thumb {
    display: flex; align-items: center; gap: 10px;
    background: #f9fafb; padding: 10px;
    border-radius: 8px; margin-bottom: 10px;
}
.fr-current-thumb img { max-height: 100px; border-radius: 6px; }
.fr-hint { color: var(--fr-muted); font-size: .85rem; }

.fr-gallery-current { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 14px; }
.fr-gallery-item    { position: relative; border: 1px solid var(--fr-border); padding: 6px; border-radius: 8px; }
.fr-gallery-item img { width: 90px; height: 90px; object-fit: cover; display: block; border-radius: 4px; }
.fr-gallery-remove   { display: flex; align-items: center; gap: 4px; font-size: .78rem; margin-top: 4px; color: var(--fr-danger); }

.fr-form-actions {
    display: flex; gap: 10px; align-items: center;
    justify-content: flex-end; padding-top: 10px;
}

/* --- Tabla mis propiedades --- */
.fr-table-wrapper { overflow-x: auto; background: #fff; border-radius: var(--fr-radius); box-shadow: var(--fr-shadow); }
.fr-table { width: 100%; border-collapse: collapse; }
.fr-table th, .fr-table td { padding: 12px 14px; text-align: left; border-bottom: 1px solid var(--fr-border); }
.fr-table th { background: #f9fafb; font-size: .85rem; text-transform: uppercase; color: var(--fr-muted); letter-spacing: .5px; }
.fr-table tr:last-child td { border-bottom: 0; }
.fr-thumb-cell img { width: 60px; height: 45px; object-fit: cover; border-radius: 4px; }
.fr-text-right { text-align: right; }
.fr-muted { color: var(--fr-muted); }

.fr-badge {
    display: inline-block; padding: 3px 10px;
    border-radius: 999px; font-size: .78rem; font-weight: 600;
    background: #eef2f7; color: var(--fr-text);
}
.fr-badge-publish { background: #dcfce7; color: #14532d; }
.fr-badge-draft   { background: #fef3c7; color: #78350f; }
.fr-badge-pending { background: #dbeafe; color: #1e3a8a; }

.fr-empty-state {
    text-align: center; padding: 60px 20px;
    background: #fff; border-radius: var(--fr-radius); box-shadow: var(--fr-shadow);
}
.fr-empty-state i { font-size: 4rem; color: #d1d5db; margin-bottom: 16px; }
.fr-empty-state h3 { margin: 0 0 16px; }

.fr-pagination ul { display: flex; gap: 8px; justify-content: center; list-style: none; padding: 20px 0; }
.fr-pagination a, .fr-pagination span { padding: 8px 14px; border: 1px solid var(--fr-border); border-radius: 8px; text-decoration: none; color: var(--fr-text); }
.fr-pagination .current span { background: var(--fr-primary); color: #fff; border-color: var(--fr-primary); }

/* --------------------------------------------------------------------------
   ARCHIVE (listado público - migrado del código antiguo)
   -------------------------------------------------------------------------- */
.propiedades-archive-wrapper { max-width: 1400px; margin: 0 auto; padding: 20px; }
.propiedades-slogan { text-align: center; color: var(--fr-primary); font-weight: 600; margin-bottom: 20px; }

.propiedades-layout-grid { display: grid; grid-template-columns: 1fr 320px; gap: 30px; align-items: start; }
.propiedades-main-content { min-width: 0; }
.propiedades-sidebar-filtros { position: relative; }

.filtros-sticky { position: sticky; top: 20px; background: #f8f9fa; border-radius: 8px; padding: 20px; box-shadow: 0 2px 8px rgba(0,0,0,.1); }
.filtros-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; padding-bottom: 15px; border-bottom: 2px solid var(--fr-primary); }
.filtros-header h2 { margin: 0; font-size: 1.3rem; color: var(--fr-primary); }
.btn-limpiar-filtros { background: var(--fr-danger); color: #fff; border: 0; padding: 8px 12px; border-radius: 5px; cursor: pointer; font-size: .85rem; }
.btn-limpiar-filtros:hover { background: var(--fr-danger-dark); }

.filtro-grupo { margin-bottom: 20px; }
.filtro-grupo label { display: block; font-weight: 600; margin-bottom: 8px; color: #333; }
.filtro-grupo label i { margin-right: 5px; color: var(--fr-primary); }
.filtro-grupo select, .filtro-grupo input[type="number"] {
    width: 100%; padding: 10px; border: 1px solid #ddd; border-radius: 5px; font-size: .95rem;
}

.resultados-info { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 15px; margin-bottom: 25px; padding: 15px; background: #fff; border-radius: 8px; box-shadow: 0 2px 4px rgba(0,0,0,.05); }
.resultados-count { color: #555; }
.ordenar-grupo { display: flex; align-items: center; gap: 10px; }
.ordenar-grupo label { font-weight: 600; }
.ordenar-grupo select { padding: 8px 12px; border: 1px solid #ddd; border-radius: 5px; }

.btn-toggle-filtros { display: none; background: var(--fr-primary); color: #fff; border: 0; padding: 10px 20px; border-radius: 5px; cursor: pointer; font-weight: 600; }

.propiedades-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 25px; margin-bottom: 30px; }

.propiedad-card { background: #fff; border-radius: 8px; overflow: hidden; box-shadow: 0 2px 8px rgba(0,0,0,.1); transition: transform .3s, box-shadow .3s; display: flex; flex-direction: column; }
.propiedad-card:hover { transform: translateY(-5px); box-shadow: 0 4px 16px rgba(0,0,0,.15); }

.propiedad-imagen { position: relative; height: 220px; overflow: hidden; }
.propiedad-imagen img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s; }
.propiedad-card:hover .propiedad-imagen img { transform: scale(1.05); }

.badge-operacion { position: absolute; top: 10px; left: 10px; background: var(--fr-primary); color: #fff; padding: 5px 12px; border-radius: 5px; font-size: .85rem; font-weight: 600; }
.galeria-count   { position: absolute; bottom: 10px; right: 10px; background: rgba(0,0,0,.7); color: #fff; padding: 5px 10px; border-radius: 5px; font-size: .85rem; }

.propiedad-contenido { padding: 20px; flex: 1; display: flex; flex-direction: column; }
.propiedad-precio    { font-size: 1.5rem; font-weight: bold; color: var(--fr-primary); margin-bottom: 10px; }
.propiedad-titulo    { margin: 0 0 10px; font-size: 1.1rem; }
.propiedad-titulo a  { color: #333; text-decoration: none; }
.propiedad-titulo a:hover { color: var(--fr-primary); }
.propiedad-ubicacion { color: #666; margin-bottom: 15px; font-size: .9rem; }
.propiedad-ubicacion i { margin-right: 5px; color: var(--fr-danger); }

.propiedad-caracteristicas { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; margin-top: auto; }
.caracteristica-item { display: flex; align-items: center; gap: 8px; font-size: .85rem; color: #555; }
.caracteristica-item i { color: var(--fr-primary); }

.propiedad-observaciones {
    margin-top: 12px;
    padding: 10px;
    background: #fffbeb;
    border-left: 3px solid #f59e0b;
    border-radius: 4px;
    color: #78350f;
    font-size: .85rem;
    display: flex;
    gap: 8px;
    align-items: flex-start;
}
.propiedad-observaciones i { margin-top: 3px; }

.propiedad-footer { display: flex; justify-content: space-between; align-items: center; padding: 15px 20px; border-top: 1px solid #eee; }
.propiedad-tipo { background: #f0f0f0; padding: 5px 10px; border-radius: 5px; font-size: .85rem; color: #666; }
.btn-ver-mas { background: var(--fr-primary); color: #fff; padding: 8px 15px; border-radius: 5px; text-decoration: none; font-size: .9rem; font-weight: 600; }
.btn-ver-mas:hover { background: var(--fr-primary-dark); }

.sin-resultados { text-align: center; padding: 60px 20px; background: #fff; border-radius: 8px; }
.sin-resultados i { font-size: 4rem; color: #ddd; margin-bottom: 20px; }
.sin-resultados h3 { color: #333; margin-bottom: 10px; }

.paginacion { margin-top: 40px; }
.paginacion ul { display: flex; justify-content: center; gap: 10px; list-style: none; padding: 0; }
.paginacion li a, .paginacion li span { padding: 10px 15px; background: #fff; border: 1px solid #ddd; border-radius: 5px; color: #333; text-decoration: none; }
.paginacion li a:hover { background: var(--fr-primary); color: #fff; border-color: var(--fr-primary); }
.paginacion li.current span { background: var(--fr-primary); color: #fff; border-color: var(--fr-primary); }

/* --------------------------------------------------------------------------
   RESPONSIVE
   -------------------------------------------------------------------------- */
@media (max-width: 1024px) {
    .propiedades-layout-grid { grid-template-columns: 1fr 280px; gap: 20px; }
    .propiedades-grid { grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: 20px; }
}

@media (max-width: 768px) {
    .propiedades-archive-wrapper { padding: 15px; }
    .propiedades-layout-grid { grid-template-columns: 1fr; gap: 20px; }
    .propiedades-sidebar-filtros { order: -1; display: none; }
    .propiedades-sidebar-filtros.active { display: block; position: fixed; inset: 0; z-index: 9999; background: rgba(0,0,0,.5); overflow-y: auto; padding: 20px; }
    .propiedades-sidebar-filtros.active .filtros-sticky { position: relative; top: 0; max-width: 500px; margin: 0 auto; }
    .btn-toggle-filtros { display: block; width: 100%; }
    .resultados-info { flex-direction: column; align-items: stretch; }
    .propiedades-grid { grid-template-columns: 1fr; gap: 20px; }
    .propiedad-caracteristicas { grid-template-columns: 1fr; }
    .propiedad-footer { flex-direction: column; gap: 10px; align-items: stretch; }
    .btn-ver-mas { text-align: center; }

    .fr-portal-header-inner { flex-direction: column; align-items: stretch; }
    .fr-welcome-card { flex-direction: column; text-align: center; }
    .fr-form-grid-3 { grid-template-columns: 1fr; }
}
