/* ==========================================================
   Green Jofiyat — Reusable UI Components
   ========================================================== */

/* ── Buttons ── */
.btn {
    display: inline-flex; align-items: center; justify-content: center;
    gap: var(--space-sm);
    padding: 0.8rem 1.6rem;
    border-radius: var(--radius-pill);
    border: 1.5px solid transparent;
    font-weight: 600; font-size: var(--text-base);
    line-height: 1; text-align: center;
    transition: var(--transition-base);
    cursor: pointer; white-space: nowrap;
}
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }

.btn--primary { background: var(--gradient-primary); color: #fff; box-shadow: var(--shadow-sm); }
.btn--primary:hover { box-shadow: var(--shadow-md); color: #fff; }

.btn--gold { background: var(--gradient-gold); color: #fff; }
.btn--gold:hover { color: #fff; }

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

.btn--ghost { background: rgba(46,125,79,0.08); color: var(--gj-primary); }
.btn--ghost:hover { background: rgba(46,125,79,0.16); color: var(--gj-primary); }

.btn--white { background: #fff; color: var(--gj-primary); }
.btn--block { display: flex; width: 100%; }
.btn--sm { padding: 0.55rem 1.1rem; font-size: var(--text-sm); }
.btn--lg { padding: 1rem 2.2rem; font-size: var(--text-lg); }

/* ── Badges / pills ── */
.badge {
    display: inline-flex; align-items: center; gap: 0.35rem;
    padding: 0.3rem 0.8rem; border-radius: var(--radius-pill);
    font-size: var(--text-xs); font-weight: 600;
}
/* Solid fills so badges stay legible over product photos */
.badge--eco { background: rgba(46,125,79,0.94); color: #fff; }
.badge--sale { background: var(--gj-danger); color: #fff; }
.badge--new { background: rgba(46,125,79,0.12); color: var(--gj-primary); }
.badge--gold { background: rgba(201,162,75,0.16); color: var(--gj-brown); }

/* ── Card base ── */
.card {
    background: var(--gj-bg-white);
    border: 1px solid var(--gj-border-light);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-card);
    overflow: hidden;
    transition: var(--transition-base);
}
.card:hover { box-shadow: var(--shadow-card-hover); transform: translateY(-4px); }

.card__body { padding: var(--space-lg); }
.card__title { font-size: var(--text-lg); font-weight: 700; margin-bottom: var(--space-xs); }
.card__media { position: relative; aspect-ratio: 1 / 1; overflow: hidden; }
.card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transition-slow); }
.card:hover .card__media img { transform: scale(1.05); }

/* ── Star rating ── */
.gj-rating { display: inline-flex; gap: 2px; color: var(--gj-star); }
.gj-rating .gj-icon { width: 16px; height: 16px; }

/* ── Eco / trust badge row ── */
.trust-badges { display: flex; flex-wrap: wrap; gap: var(--space-md); }
.trust-badge {
    display: inline-flex; align-items: center; gap: var(--space-sm);
    font-size: var(--text-sm); color: var(--gj-text-secondary);
}
.trust-badge .gj-icon { color: var(--gj-primary); }

/* ── Form fields ── */
.field { margin-bottom: var(--space-md); }
.field label { display: block; font-weight: 600; margin-bottom: var(--space-xs); font-size: var(--text-sm); }
.field input, .field textarea, .field select {
    width: 100%; padding: 0.8rem 1rem;
    border: 1.5px solid var(--gj-border); border-radius: var(--radius-md);
    background: var(--gj-bg-white); transition: border-color var(--transition-fast);
}
.field input:focus, .field textarea:focus, .field select:focus {
    outline: none; border-color: var(--gj-primary);
}

/* ── Spinner + wishlist loading ── */
.gj-spinner { display: inline-block; width: 32px; height: 32px; border: 3px solid var(--gj-border); border-top-color: var(--gj-primary); border-radius: 50%; animation: gj-spin .7s linear infinite; }
.gj-wishlist__loading { display: grid; place-items: center; padding: var(--space-3xl) 0; }
@keyframes gj-spin { to { transform: rotate(360deg); } }

/* ── Breadcrumbs ── */
.gj-breadcrumbs { display: flex; flex-wrap: wrap; gap: 0.4rem; font-size: var(--text-sm); color: var(--gj-text-muted); padding: var(--space-md) 0; }
.gj-breadcrumbs a:hover { color: var(--gj-primary); }
.gj-breadcrumbs .sep { opacity: 0.5; }

/* ==========================================================
   Product grid + cards  (GLOBAL — used on shop AND homepage
   featured-products, so must not live in conditional woocommerce.css)
   ========================================================== */
ul.products {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-xl);
    margin: 0 !important; padding: 0 !important; list-style: none;
}
ul.products::before, ul.products::after { display: none !important; }
ul.products li.product { width: auto !important; margin: 0 !important; float: none !important; }
@media (max-width: 991px) { ul.products { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { ul.products { grid-template-columns: 1fr; } }

.gj-product-card {
    position: relative; background: var(--gj-bg-white);
    border: 1px solid var(--gj-border-light); border-radius: var(--radius-lg);
    overflow: hidden; display: flex; flex-direction: column; box-shadow: var(--shadow-card);
    transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
    list-style: none; text-align: start;
}
.gj-product-card:hover { box-shadow: var(--shadow-card-hover); transform: translateY(-6px); border-color: rgba(46,125,79,0.35); }
.gj-product-card__media { position: relative; aspect-ratio: 1 / 1; overflow: hidden; background: var(--gj-bg-alt); display: block; }
.gj-product-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transition-slow); }
.gj-product-card:hover .gj-product-card__media img { transform: scale(1.07); }
.gj-product-card__media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 55%, rgba(26,74,48,0.18) 100%); opacity: 0; transition: opacity var(--transition-base); }
.gj-product-card:hover .gj-product-card__media::after { opacity: 1; }
.gj-product-card__badges { position: absolute; top: 12px; inset-inline-start: 12px; display: flex; flex-direction: column; gap: 6px; z-index: 2; }
.gj-product-card__badges .badge { box-shadow: var(--shadow-sm); }
.gj-product-card__actions { position: absolute; top: 12px; inset-inline-end: 12px; display: flex; flex-direction: column; gap: 8px; z-index: 2; opacity: 0; transform: translateY(-8px); transition: var(--transition-base); }
.gj-product-card:hover .gj-product-card__actions { opacity: 1; transform: translateY(0); }
.gj-card-action { width: 40px; height: 40px; border-radius: var(--radius-circle); background: rgba(255,255,255,0.96); color: var(--gj-text); display: grid; place-items: center; box-shadow: var(--shadow-sm); transition: var(--transition-fast); border: none; backdrop-filter: blur(4px); }
.gj-card-action:hover { background: var(--gj-primary); color: #fff; transform: scale(1.08); }
.gj-wishlist.is-active { background: var(--gj-danger); color: #fff; }
.gj-product-card__body { padding: var(--space-md); display: flex; flex-direction: column; gap: 0.45rem; flex: 1; }
.gj-product-card__vendor { font-size: var(--text-xs); color: var(--gj-olive-dark); font-weight: 600; display: inline-flex; align-items: center; gap: 5px; align-self: flex-start; background: rgba(139,191,90,0.16); padding: 3px 10px; border-radius: var(--radius-pill); }
.gj-product-card__vendor:hover { background: rgba(139,191,90,0.28); color: var(--gj-primary-dark); }
.gj-product-card__title { font-size: var(--text-base); font-weight: 700; line-height: 1.45; color: var(--gj-text); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; min-height: 2.7em; }
.gj-product-card__title a { color: inherit; }
.gj-product-card__title a:hover { color: var(--gj-primary); }
.gj-product-card__rating { display: flex; align-items: center; gap: 1px; color: var(--gj-star); min-height: 18px; }
.gj-product-card__rating .gj-icon { font-size: 15px; }
.gj-product-card__rating .is-off { color: var(--gj-border); }
.gj-product-card__rating small { color: var(--gj-text-muted); margin-inline-start: 5px; font-size: var(--text-xs); }
.gj-product-card__price { font-weight: 800; color: var(--gj-primary-dark); font-size: var(--text-xl); margin-top: auto; display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; }
.gj-product-card__price del { color: var(--gj-text-muted); font-weight: 500; font-size: var(--text-sm); order: 2; }
.gj-product-card__price ins { text-decoration: none; }
.gj-product-card__price .woocommerce-Price-currencySymbol { font-size: 0.7em; font-weight: 600; }
.gj-product-card__stock { font-size: var(--text-xs); color: var(--gj-warning); font-weight: 700; margin: 0; }
.gj-product-card__cart { margin-top: 4px; }
.gj-product-card .gj-product-card__cart a.button,
.gj-product-card .gj-product-card__cart .button {
    display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
    width: 100%; padding: 0.62rem 1.1rem; margin: 0; border: none; border-radius: var(--radius-pill);
    background: var(--gj-primary); color: #fff; font-weight: 700; font-size: var(--text-sm); line-height: 1.5;
    letter-spacing: .01em; cursor: pointer; box-shadow: 0 2px 8px rgba(46,125,79,0.18);
    transition: background var(--transition-fast), box-shadow var(--transition-base), transform var(--transition-base);
}
.gj-product-card .gj-product-card__cart a.button:hover,
.gj-product-card .gj-product-card__cart .button:hover { background: var(--gj-primary-dark); box-shadow: 0 8px 22px rgba(46,125,79,0.34); transform: translateY(-2px); color: #fff; }
.gj-product-card .gj-product-card__cart a.button:active,
.gj-product-card .gj-product-card__cart .button:active { transform: translateY(0) scale(.98); }
.gj-product-card .gj-product-card__cart .gj-atc-icon { font-size: 1.05em; transition: transform var(--transition-base); }
.gj-product-card .gj-product-card__cart .button:hover .gj-atc-icon { transform: translateY(-1px) scale(1.08); }
/* Loading: hide label, show spinner */
.gj-product-card .gj-product-card__cart .button.loading { color: transparent !important; pointer-events: none; position: relative; }
.gj-product-card .gj-product-card__cart .button.loading::after {
    content: ""; position: absolute; top: 50%; left: 50%; width: 18px; height: 18px; margin: -9px 0 0 -9px;
    border: 2px solid rgba(255,255,255,0.45); border-top-color: #fff; border-radius: 50%;
    animation: gj-atc-spin .6s linear infinite;
}
@keyframes gj-atc-spin { to { transform: rotate(360deg); } }
/* Added: brief success flash */
.gj-product-card .gj-product-card__cart .button.added { background: var(--gj-olive); }
.gj-product-card .gj-product-card__cart .added_to_cart {
    display: flex; align-items: center; justify-content: center; width: 100%;
    margin-top: 6px; padding: 0.55rem 1rem; border-radius: var(--radius-pill);
    background: transparent; color: var(--gj-primary); border: 1.5px solid var(--gj-primary); font-weight: 600; font-size: var(--text-sm);
}
.gj-product-card .gj-product-card__cart .added_to_cart:hover { background: var(--gj-primary); color: #fff; }

/* ── Family / store card (GLOBAL — homepage featured-families + families page) ── */
.gj-family-card {
    background: var(--gj-bg-white); border: 1px solid var(--gj-border-light);
    border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-card);
    transition: var(--transition-base); display: flex; flex-direction: column;
}
.gj-family-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-card-hover); }
.gj-family-card__cover { display: block; aspect-ratio: 16 / 7; overflow: hidden; background: var(--gradient-earth); }
.gj-family-card__cover img { width: 100%; height: 100%; object-fit: cover; }
.gj-family-card__body { padding: var(--space-lg); text-align: center; margin-top: -48px; position: relative; }
.gj-family-card__avatar { width: 84px; height: 84px; border-radius: var(--radius-circle); object-fit: cover; border: 4px solid var(--gj-bg-white); margin: 0 auto var(--space-sm); box-shadow: var(--shadow-sm); background: #fff; }
.gj-family-card__name { font-size: var(--text-lg); font-weight: 700; margin-bottom: 2px; }
.gj-family-card__name a:hover { color: var(--gj-primary); }
.gj-family-card__meta { color: var(--gj-text-muted); font-size: var(--text-sm); display: flex; align-items: center; justify-content: center; gap: 6px; margin: 4px 0 var(--space-sm); }
.gj-family-card__stats { display: flex; justify-content: center; gap: var(--space-lg); margin: var(--space-md) 0; }
.gj-family-card__stat strong { display: block; color: var(--gj-primary-dark); font-size: var(--text-lg); }
.gj-family-card__stat span { font-size: var(--text-xs); color: var(--gj-text-muted); }
