/* ============================================================
   GastroJobs — Estilos principales v2
   ============================================================ */

/* ── Variables ──────────────────────────────────────────────────────────────── */
:root {
    --gj-orange:        #F05A28;
    --gj-orange-dark:   #d44820;
    --gj-orange-light:  #fff3ef;
    --gj-navy:          #1a2e4a;
    --gj-navy-light:    #2d4a6e;
    --gj-bg:            #f7f8fa;
    --gj-white:         #ffffff;
    --gj-border:        #e5e7eb;
    --gj-text:          #111827;
    --gj-muted:         #6b7280;
    --gj-success:       #16a34a;
    --gj-radius:        10px;
    --gj-radius-lg:     14px;
    --gj-radius-xl:     22px;
    --gj-shadow:        0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
    --gj-shadow-md:     0 4px 24px rgba(0,0,0,.08), 0 2px 8px rgba(0,0,0,.04);
    --gj-shadow-lg:     0 12px 48px rgba(0,0,0,.12), 0 4px 16px rgba(0,0,0,.06);
    --gj-glow-orange:   0 4px 24px rgba(240,90,40,.35);
}

/* ── Reset y base ───────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

body {
    font-family: 'Inter', system-ui, -apple-system, sans-serif;
    color: var(--gj-text);
    background: var(--gj-bg);
    font-size: 15px;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
}

a { color: var(--gj-orange); text-decoration: none; }
a:hover { color: var(--gj-orange-dark); text-decoration: underline; }

.text-orange    { color: var(--gj-orange) !important; }
.text-navy      { color: var(--gj-navy)   !important; }
.text-white-75  { color: rgba(255,255,255,.75); }
.bg-orange      { background-color: var(--gj-orange) !important; }

/* ── Navbar ─────────────────────────────────────────────────────────────────── */
.navbar {
    background: rgba(255,255,255,.92) !important;
    border-bottom: 1px solid var(--gj-border);
    padding: .65rem 0;
    box-shadow: 0 1px 0 rgba(0,0,0,.06);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

.navbar-brand {
    font-weight: 800;
    font-size: 1.35rem;
    color: var(--gj-orange) !important;
    letter-spacing: -.6px;
}
.navbar-brand i { color: var(--gj-orange); }
.navbar-brand:hover { text-decoration: none; opacity: .9; }

.navbar .nav-link {
    color: var(--gj-text) !important;
    font-weight: 500;
    padding: .4rem .75rem;
    border-radius: var(--gj-radius);
    transition: background .15s, color .15s;
    font-size: .9rem;
}
.navbar .nav-link:hover { background: var(--gj-bg); color: var(--gj-orange) !important; }

.navbar-toggler { border-color: var(--gj-border); }
.navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='%232d2d2d' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

/* ── Botones ────────────────────────────────────────────────────────────────── */
.btn {
    border-radius: var(--gj-radius);
    font-weight: 600;
    font-size: .875rem;
    transition: all .18s ease;
    transform: translateY(0);
    letter-spacing: -.01em;
}
.btn:hover  { transform: translateY(-1px); }
.btn:active { transform: translateY(0) scale(.97); }

.btn-primary,
.btn-orange {
    background: var(--gj-orange);
    border-color: var(--gj-orange);
    color: #fff;
}
.btn-primary:hover,
.btn-orange:hover {
    background: var(--gj-orange-dark);
    border-color: var(--gj-orange-dark);
    color: #fff;
    box-shadow: var(--gj-glow-orange);
}
.btn-primary:focus,
.btn-orange:focus {
    box-shadow: 0 0 0 .25rem rgba(240,90,40,.25);
}

.btn-outline-primary {
    color: var(--gj-orange);
    border-color: var(--gj-orange);
    background: transparent;
}
.btn-outline-primary:hover {
    background: var(--gj-orange);
    border-color: var(--gj-orange);
    color: #fff;
    box-shadow: var(--gj-glow-orange);
}

.btn-navy {
    background: var(--gj-navy);
    border-color: var(--gj-navy);
    color: #fff;
}
.btn-navy:hover {
    background: var(--gj-navy-light);
    border-color: var(--gj-navy-light);
    color: #fff;
    box-shadow: 0 4px 20px rgba(26,46,74,.35);
}

.btn-lg { padding: .7rem 1.75rem; font-size: .95rem; }
.btn-sm { padding: .3rem .85rem; font-size: .8rem; }

/* ── Cards ──────────────────────────────────────────────────────────────────── */
.card {
    background: var(--gj-white);
    border: 1px solid var(--gj-border) !important;
    border-radius: var(--gj-radius-lg);
    box-shadow: var(--gj-shadow);
    transition: box-shadow .25s ease, transform .25s ease;
}
.card:hover {
    box-shadow: var(--gj-shadow-md);
    transform: translateY(-2px);
}

/* ── Job card (pública) ─────────────────────────────────────────────────────── */
.job-card {
    background: var(--gj-white);
    border: 1px solid var(--gj-border);
    border-radius: var(--gj-radius-lg);
    padding: 1.25rem 1.5rem;
    transition: box-shadow .2s ease, border-color .2s ease, transform .2s ease;
    display: block;
    color: inherit;
    text-decoration: none !important;
}
.job-card:hover {
    box-shadow: var(--gj-shadow-md);
    border-color: var(--gj-orange);
    color: inherit;
    transform: translateY(-2px);
}
.job-card:hover .job-card-title { color: var(--gj-orange); }

.job-card-title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--gj-navy);
    margin-bottom: .25rem;
    transition: color .15s;
    letter-spacing: -.02em;
}
.job-card-company {
    font-size: .85rem;
    color: var(--gj-muted);
    font-weight: 500;
}
.job-card-meta {
    font-size: .8rem;
    color: var(--gj-muted);
    display: flex;
    flex-wrap: wrap;
    gap: .5rem 1rem;
    margin-top: .5rem;
}
.job-card-meta i { color: var(--gj-orange); }

.job-card-badge {
    display: inline-block;
    font-size: .72rem;
    font-weight: 700;
    padding: .2rem .65rem;
    border-radius: 99px;
    background: var(--gj-orange-light);
    color: var(--gj-orange);
    border: 1px solid rgba(240,90,40,.2);
    letter-spacing: .01em;
}

/* ── Hero (landing) ─────────────────────────────────────────────────────────── */
.hero-section {
    background: linear-gradient(135deg, var(--gj-navy) 0%, #1e3a5f 60%, #2d4a6e 100%);
    position: relative;
    overflow: hidden;
}

/* Orbe naranja original — mantenido, ahora con drift */
.hero-section::before {
    content: '';
    position: absolute;
    top: -120px; right: -120px;
    width: 520px; height: 520px;
    background: radial-gradient(circle, rgba(240,90,40,.22) 0%, transparent 68%);
    border-radius: 50%;
    pointer-events: none;
    animation: orb-drift-a 11s ease-in-out infinite;
}
/* Orbe blanco inferior izquierdo */
.hero-section::after {
    content: '';
    position: absolute;
    bottom: -100px; left: -80px;
    width: 420px; height: 420px;
    background: radial-gradient(circle, rgba(255,255,255,.07) 0%, transparent 68%);
    border-radius: 50%;
    pointer-events: none;
    animation: orb-drift-b 13s ease-in-out infinite;
}

/* Orbes extra (divs .hero-orb dentro del section) */
.hero-orb {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    will-change: transform;
}
.hero-orb-1 {
    width: 360px; height: 360px;
    top: 30%; left: -140px;
    background: radial-gradient(circle, rgba(45,100,160,.28) 0%, transparent 70%);
    animation: orb-drift-c 9s ease-in-out infinite;
}
.hero-orb-2 {
    width: 280px; height: 280px;
    bottom: -60px; right: 15%;
    background: radial-gradient(circle, rgba(100,160,220,.18) 0%, transparent 70%);
    animation: orb-drift-d 7s ease-in-out infinite;
}
.hero-orb-3 {
    width: 180px; height: 180px;
    top: 10%; left: 40%;
    background: radial-gradient(circle, rgba(255,255,255,.06) 0%, transparent 70%);
    animation: orb-drift-a 15s ease-in-out infinite reverse;
}

@keyframes orb-drift-a {
    0%   { transform: translate(0, 0)      scale(1); }
    33%  { transform: translate(30px, 20px) scale(1.06); }
    66%  { transform: translate(-15px, 35px) scale(.96); }
    100% { transform: translate(0, 0)      scale(1); }
}
@keyframes orb-drift-b {
    0%   { transform: translate(0, 0)       scale(1); }
    40%  { transform: translate(20px, -30px) scale(1.08); }
    75%  { transform: translate(-25px, 15px) scale(.94); }
    100% { transform: translate(0, 0)       scale(1); }
}
@keyframes orb-drift-c {
    0%   { transform: translate(0, 0)       scale(1); }
    50%  { transform: translate(40px, -20px) scale(1.05); }
    100% { transform: translate(0, 0)       scale(1); }
}
@keyframes orb-drift-d {
    0%   { transform: translate(0, 0)       scale(1); }
    35%  { transform: translate(-20px, 25px) scale(1.1); }
    70%  { transform: translate(15px, -10px) scale(.95); }
    100% { transform: translate(0, 0)       scale(1); }
}

/* Hero pill badge */
.hero-badge {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    background: rgba(240,90,40,.15);
    color: #ff8c6b;
    border: 1px solid rgba(240,90,40,.3);
    border-radius: 99px;
    padding: .35rem .9rem;
    font-size: .78rem;
    font-weight: 600;
    letter-spacing: .02em;
    backdrop-filter: blur(4px);
    animation: badge-appear .6s ease both;
}
@keyframes badge-appear {
    from { opacity: 0; transform: translateY(-8px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ── Search bar ─────────────────────────────────────────────────────────────── */
.search-bar {
    background: var(--gj-white);
    border-radius: var(--gj-radius-xl);
    padding: .45rem .45rem .45rem .45rem;
    display: flex;
    gap: .4rem;
    box-shadow: 0 8px 40px rgba(0,0,0,.2), 0 2px 12px rgba(0,0,0,.1);
}
.search-bar .form-control {
    border: none;
    background: transparent;
    font-size: .925rem;
    font-weight: 500;
}
.search-bar .form-control:focus { box-shadow: none; outline: none; }
.search-bar .form-control::placeholder { color: #9ca3af; }
.search-bar .divider {
    width: 1px;
    background: var(--gj-border);
    margin: .25rem 0;
    flex-shrink: 0;
}
.search-bar .btn { border-radius: 14px; }

/* ── Stats bar ──────────────────────────────────────────────────────────────── */
.stats-bar {
    background: var(--gj-white);
    border-bottom: 1px solid var(--gj-border);
    padding: 1rem 0;
}
.stats-bar .stat-item {
    text-align: center;
    padding: 0 1rem;
}
.stats-bar .stat-icon {
    font-size: 1.1rem;
    color: var(--gj-orange);
    display: block;
    margin-bottom: .15rem;
}
.stats-bar .stat-num {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--gj-navy);
    line-height: 1.1;
    letter-spacing: -.04em;
}
.stats-bar .stat-label {
    font-size: .72rem;
    color: var(--gj-muted);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: .04em;
}

/* ── Logos strip ────────────────────────────────────────────────────────────── */
.logos-strip {
    background: var(--gj-white);
    border-bottom: 1px solid var(--gj-border);
    padding: 1.25rem 0;
    overflow: hidden;
}
.logos-strip-title {
    font-size: .72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--gj-muted);
    margin-bottom: .85rem;
}
.logos-track {
    display: flex;
    gap: 2.5rem;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
}
.logo-item {
    font-weight: 800;
    font-size: .95rem;
    color: #9ca3af;
    letter-spacing: -.03em;
    transition: color .2s;
    white-space: nowrap;
}
.logo-item:hover { color: var(--gj-navy); }

/* ── Category cards ─────────────────────────────────────────────────────────── */
.category-card {
    background: var(--gj-white);
    border: 1px solid var(--gj-border);
    border-radius: var(--gj-radius-lg);
    padding: 1.35rem 1rem;
    text-align: center;
    text-decoration: none !important;
    color: var(--gj-text);
    display: block;
    transition: all .22s ease;
}
.category-card:hover {
    border-color: var(--gj-orange);
    color: var(--gj-orange);
    transform: translateY(-3px);
    box-shadow: var(--gj-shadow-md);
}
.category-card .cat-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto .6rem;
    font-size: 1.4rem;
    transition: transform .2s;
}
.category-card:hover .cat-icon { transform: scale(1.1); }
.category-card span {
    font-size: .85rem;
    font-weight: 600;
    letter-spacing: -.01em;
}

/* ── Match pill (job cards) ─────────────────────────────────────────────────── */
.match-pill {
    display: inline-flex;
    align-items: center;
    gap: .28rem;
    font-size: .69rem;
    font-weight: 700;
    padding: .18rem .55rem;
    border-radius: 99px;
    letter-spacing: .01em;
    white-space: nowrap;
    transition: transform .15s ease;
}
.match-pill i { font-size: .65rem; }
.job-card:hover .match-pill { transform: scale(1.05); }
.match-pill-high {
    background: #d1fae5;
    color: #065f46;
    border: 1px solid rgba(16,185,129,.25);
}
.match-pill-mid {
    background: var(--gj-orange-light);
    color: var(--gj-orange);
    border: 1px solid rgba(240,90,40,.2);
}
.match-pill-low {
    background: #f3f4f6;
    color: var(--gj-muted);
    border: 1px solid var(--gj-border);
}

/* ── Score badge ────────────────────────────────────────────────────────────── */
.score-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px; height: 52px;
    border-radius: 50%;
    font-size: 1rem;
    font-weight: 800;
    color: #fff;
    flex-shrink: 0;
    letter-spacing: -.02em;
}
.score-badge.score-high   { background: var(--gj-success); }
.score-badge.score-good   { background: var(--gj-orange); }
.score-badge.score-mid    { background: #f59e0b; }
.score-badge.score-low    { background: #ef4444; }

/* ── Forms ──────────────────────────────────────────────────────────────────── */
.form-control, .form-select {
    border-radius: var(--gj-radius);
    border-color: var(--gj-border);
    font-size: .9rem;
    padding: .6rem .95rem;
    background: var(--gj-white);
    font-family: 'Inter', system-ui, sans-serif;
    transition: border-color .15s, box-shadow .15s;
}
.form-control:focus, .form-select:focus {
    border-color: var(--gj-orange);
    box-shadow: 0 0 0 .2rem rgba(240,90,40,.12);
}
.form-label { font-weight: 600; font-size: .85rem; color: var(--gj-text); }

/* ── Dashboard sidebar ──────────────────────────────────────────────────────── */
.sidebar {
    background: var(--gj-white);
    border-right: 1px solid var(--gj-border);
    min-height: calc(100vh - 57px);
    padding: 1rem .75rem;
}
.sidebar .nav-link {
    color: var(--gj-text);
    font-weight: 500;
    font-size: .875rem;
    padding: .6rem .9rem;
    border-radius: var(--gj-radius);
    display: flex;
    align-items: center;
    gap: .6rem;
    transition: all .15s;
    margin-bottom: 2px;
}
.sidebar .nav-link i { font-size: 1rem; width: 18px; text-align: center; color: var(--gj-muted); }
.sidebar .nav-link:hover {
    background: var(--gj-orange-light);
    color: var(--gj-orange);
    text-decoration: none;
}
.sidebar .nav-link:hover i { color: var(--gj-orange); }
.sidebar .nav-link.active {
    background: var(--gj-orange);
    color: #fff !important;
    font-weight: 600;
}
.sidebar .nav-link.active i { color: #fff !important; }

.sidebar-section {
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: var(--gj-muted);
    padding: .75rem .9rem .25rem;
    margin-top: .25rem;
}

/* ── Dashboard topbar ───────────────────────────────────────────────────────── */
.dash-topbar {
    background: rgba(255,255,255,.92);
    border-bottom: 1px solid var(--gj-border);
    padding: .65rem 1.5rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: sticky;
    top: 0;
    z-index: 100;
    box-shadow: var(--gj-shadow);
    backdrop-filter: blur(8px);
}

/* ── Tables ─────────────────────────────────────────────────────────────────── */
.table { font-size: .875rem; }
.table thead th {
    background: var(--gj-bg);
    font-weight: 700;
    font-size: .75rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--gj-muted);
    border-bottom: 1px solid var(--gj-border);
    white-space: nowrap;
}
.table tbody tr:hover { background: #fafafa; }
.table td { border-color: #f0f0f0; vertical-align: middle; }

/* ── Badges ─────────────────────────────────────────────────────────────────── */
.badge { font-weight: 700; letter-spacing: .02em; }

/* ── Alerts ─────────────────────────────────────────────────────────────────── */
.alert { border-radius: var(--gj-radius-lg); font-size: .875rem; }

/* ── Progress ───────────────────────────────────────────────────────────────── */
.progress { border-radius: 99px; background: #eee; }

/* ── Accordion ──────────────────────────────────────────────────────────────── */
.accordion-button:not(.collapsed) { color: var(--gj-orange); background: var(--gj-orange-light); box-shadow: none; }
.accordion-button:focus { box-shadow: none; }
.accordion-button { font-weight: 600; font-size: .9rem; }
.accordion-item { border-color: var(--gj-border); }

/* ── Nav tabs ───────────────────────────────────────────────────────────────── */
.nav-tabs { border-color: var(--gj-border); }
.nav-tabs .nav-link { color: var(--gj-muted); border: none; border-bottom: 2px solid transparent; font-weight: 500; }
.nav-tabs .nav-link.active { color: var(--gj-orange); border-bottom-color: var(--gj-orange); background: transparent; }
.nav-tabs .nav-link:hover:not(.active) { color: var(--gj-text); border-bottom-color: var(--gj-border); }

/* ── Pagination ─────────────────────────────────────────────────────────────── */
.page-link { color: var(--gj-orange); border-color: var(--gj-border); font-size: .875rem; }
.page-link:hover { background: var(--gj-orange-light); color: var(--gj-orange); border-color: var(--gj-border); }
.page-item.active .page-link { background: var(--gj-orange); border-color: var(--gj-orange); }
.page-item.disabled .page-link { color: var(--gj-muted); }

/* ── Section headers ────────────────────────────────────────────────────────── */
.section-title {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--gj-navy);
    margin-bottom: .3rem;
    letter-spacing: -.04em;
    line-height: 1.2;
}
.section-subtitle {
    font-size: .9rem;
    color: var(--gj-muted);
}

/* ── Footer ─────────────────────────────────────────────────────────────────── */
footer {
    background: var(--gj-navy) !important;
    border-top: 3px solid var(--gj-orange);
}

/* ── Glassmorphism card ─────────────────────────────────────────────────────── */
.glass-card {
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: var(--gj-radius-xl);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
}

/* ── Mock UI card (landing) ─────────────────────────────────────────────────── */
.mock-ui-card {
    background: var(--gj-white);
    border: 1px solid var(--gj-border);
    border-radius: var(--gj-radius-xl);
    box-shadow: var(--gj-shadow-lg);
    overflow: hidden;
}
.mock-ui-topbar {
    background: var(--gj-bg);
    border-bottom: 1px solid var(--gj-border);
    padding: .65rem 1rem;
    display: flex;
    align-items: center;
    gap: .5rem;
}
.mock-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
}

/* ── Scroll animations ──────────────────────────────────────────────────────── */
.fade-up {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity .55s ease, transform .55s ease;
}
.fade-up.visible {
    opacity: 1;
    transform: translateY(0);
}
.fade-up.delay-1 { transition-delay: .1s; }
.fade-up.delay-2 { transition-delay: .2s; }
.fade-up.delay-3 { transition-delay: .3s; }
.fade-up.delay-4 { transition-delay: .4s; }
.fade-up.delay-5 { transition-delay: .5s; }

/* ── CTA Section ────────────────────────────────────────────────────────────── */
.cta-section {
    background: linear-gradient(135deg, var(--gj-navy) 0%, #162540 100%);
    position: relative;
    overflow: hidden;
}
.cta-section::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 30% 50%, rgba(240,90,40,.15) 0%, transparent 60%);
    pointer-events: none;
}

/* ── Utility ────────────────────────────────────────────────────────────────── */
.min-width-0     { min-width: 0; }
.cursor-pointer  { cursor: pointer; }
.text-truncate-2 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.hover-orange:hover { color: var(--gj-orange) !important; }
.border-orange      { border-color: var(--gj-orange) !important; }
.rounded-xl         { border-radius: var(--gj-radius-xl); }

/* ── Responsive ─────────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
    .hero-section  { padding: 3rem 0 2rem; }
    .search-bar    { flex-wrap: wrap; border-radius: var(--gj-radius-lg); }
    .search-bar .divider { display: none; }
    .stats-bar .stat-item { padding: 0 .5rem; }
    .stats-bar .stat-num  { font-size: 1.2rem; }
    .sidebar { min-height: auto; }
    .job-card { padding: 1rem; }
    .section-title { font-size: 1.25rem; }
}
@media (max-width: 576px) {
    .btn-lg { padding: .6rem 1.3rem; font-size: .9rem; }
    .score-badge { width: 44px !important; height: 44px !important; font-size: .9rem !important; }
    .logos-track  { gap: 1.25rem; }
}

/* ── Botón Google OAuth ──────────────────────────────────────────────────────── */
.btn-google {
    background: #fff;
    color: #3c4043;
    border: 1px solid #dadce0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    transition: background .15s, box-shadow .15s;
}
.btn-google:hover {
    background: #f8f9fa;
    box-shadow: 0 1px 3px rgba(0,0,0,.15);
    color: #3c4043;
    text-decoration: none;
}
.btn-google svg { flex-shrink: 0; }

/* ============================================================
   Oficios — Directorio de servicios
   ============================================================ */

/* ── Hero de la sección de oficios ──────────────────────────────────────────── */
.trades-hero {
    background: linear-gradient(135deg, var(--gj-navy) 0%, var(--gj-navy-light) 100%);
    position: relative;
    overflow: hidden;
}
.trades-search-form .form-select,
.trades-search-form .form-control {
    border-radius: var(--gj-radius);
    font-size: .95rem;
    height: 48px;
}

/* ── Tarjeta de perfil en listado ────────────────────────────────────────────── */
.trade-card {
    background: #fff;
    border: 1px solid var(--gj-border);
    border-radius: var(--gj-radius-lg);
    padding: 1.1rem 1.25rem;
    text-decoration: none;
    color: var(--gj-text);
    transition: box-shadow .15s, border-color .15s, transform .15s;
}
.trade-card:hover {
    box-shadow: var(--gj-shadow-md);
    border-color: var(--gj-orange);
    transform: translateY(-2px);
    color: var(--gj-text);
    text-decoration: none;
}
.trade-cat-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
    flex-shrink: 0;
}
.trade-cat-icon-lg {
    width: 60px;
    height: 60px;
    font-size: 1.8rem;
}
.trade-card-title {
    font-weight: 700;
    font-size: .95rem;
    color: var(--gj-text);
}
.trade-card-category {
    font-size: .78rem;
    color: var(--gj-muted);
}
.trade-card-location {
    font-size: .78rem;
    color: var(--gj-muted);
}
.trade-price {
    font-size: .8rem;
    font-weight: 600;
    color: var(--gj-orange);
}

/* ── Estrellas ────────────────────────────────────────────────────────────────── */
.trade-stars { color: #f59e0b; font-size: .8rem; }
.trade-stars-lg { font-size: 1rem; }
.trade-rating-text { font-size: .82rem; font-weight: 600; color: var(--gj-text); }

/* ── Badges ───────────────────────────────────────────────────────────────────── */
.trade-disponible-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: #dcfce7;
    color: #16a34a;
    font-size: .7rem;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 20px;
}
.trade-verified-badge {
    display: inline-flex;
    align-items: center;
    background: #e0f2fe;
    color: #0284c7;
    font-size: .72rem;
    font-weight: 600;
    padding: 3px 9px;
    border-radius: 20px;
}

/* ── Galería de fotos ────────────────────────────────────────────────────────── */
.trade-photos-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: 8px;
}
.trade-photo-thumb {
    border-radius: var(--gj-radius);
    overflow: hidden;
    aspect-ratio: 4/3;
    background: var(--gj-border);
}
.trade-photo-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .2s;
}
.trade-photo-thumb:hover img { transform: scale(1.05); }

/* ── Vista de perfil individual ──────────────────────────────────────────────── */
.trade-profile-header {
    background: #fff;
    border: 1px solid var(--gj-border);
    border-radius: var(--gj-radius-lg);
    padding: 1.5rem;
}
.trade-section {
    background: #fff;
    border: 1px solid var(--gj-border);
    border-radius: var(--gj-radius-lg);
    padding: 1.5rem;
}
.trade-review-item {
    padding: 1rem 0;
    border-bottom: 1px solid var(--gj-border);
}
.trade-review-item:last-child { border-bottom: none; }
.trade-review-reply {
    background: #f7f8fa;
    border-left: 3px solid var(--gj-orange);
    padding: .65rem 1rem;
    border-radius: 0 var(--gj-radius) var(--gj-radius) 0;
    margin-top: .5rem;
}
.trade-sidebar-card {
    background: #fff;
    border: 1px solid var(--gj-border);
    border-radius: var(--gj-radius-lg);
    padding: 1.25rem;
}
.trade-contact-locked {
    text-align: center;
    padding: .5rem 0;
}

/* ── Selector interactivo de estrellas ───────────────────────────────────────── */
.trade-star-picker {
    display: flex;
    gap: 6px;
    font-size: 1.8rem;
    cursor: pointer;
    color: #d1d5db;
}
.trade-star-picker .bi-star-fill { color: #f59e0b; }
.trade-star-btn { transition: transform .1s; }
.trade-star-btn:hover { transform: scale(1.15); }

/* ── Dashboard: preview de fotos ─────────────────────────────────────────────── */
.trade-photo-preview { border-radius: var(--gj-radius); overflow: hidden; }
