/* Marketplace app styles - aligned to the meshbrasil.com design system in style.css */

/* cards */
.mkt-card { background: var(--white); border-radius: 8px; box-shadow: 0 2px 10px rgba(0,0,0,.10); padding: 28px; max-width: 460px; margin: 32px auto; }
.mkt-card--wide { max-width: 720px; }
.mkt-card h1 { margin: 0 0 18px; }   /* inherits the site h1 size (no shrink); just spacing */
.mkt-card h2 { margin: 0 0 16px; }
.mkt-card p.sub { color: var(--muted); margin-bottom: 22px; }

/* form fields */
.mkt-field { margin-bottom: 16px; }
.mkt-field label { display: block; font-weight: 700; margin-bottom: 6px; font-family: var(--font-title); }
.mkt-field input, .mkt-field select, .mkt-field textarea { width: 100%; padding: 11px 14px; font-size: 16px; font-family: var(--font-body); border: 1px solid #cfd4d2; border-radius: 6px; background: var(--bg-off); }
.mkt-field input:focus, .mkt-field select:focus, .mkt-field textarea:focus { outline: 2px solid var(--green); border-color: var(--green); }
.mkt-field input[type="checkbox"] { width: auto; accent-color: var(--green-dark); vertical-align: middle; }

/* primary full-width button (form submits) - same palette as .btn */
.mkt-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; width: 100%; cursor: pointer; border: 2px solid var(--green-dark); background: var(--green-dark); color: #fff; font-family: var(--font-title); font-weight: 700; font-size: 16px; padding: 11px 18px; border-radius: 6px; }
.mkt-btn:hover { background: var(--green-deep); border-color: var(--green-deep); }
.mkt-btn svg.btn__ico { width: 1.15em; height: 1.15em; flex: 0 0 auto; stroke: currentColor; }

/* danger variant for delete actions (restrained: outline, fills on hover) */
.btn--danger { background: #fff; color: #b00020; border-color: #c0414f; }
.btn--danger:hover { background: #b00020; color: #fff; border-color: #b00020; }

/* action button rows */
.mkt-actions { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; margin-top: 18px; }

.mkt-divider { text-align: center; color: var(--muted); margin: 18px 0; }
.mkt-msg { min-height: 1.3em; margin-top: 12px; font-weight: 700; }
.mkt-msg--error { color: #b00020; }
.mkt-msg--ok { color: var(--green-dark); }
#g_id_signin { display: flex; justify-content: center; margin-top: 6px; }

/* status pill (profile valid / incompleto) - tooltip via title attribute */
.mkt-pill { display: inline-block; font-family: var(--font-title); font-size: 12px; font-weight: 700; letter-spacing: .4px; text-transform: uppercase; padding: 3px 12px; border-radius: 999px; cursor: default; }
.mkt-pill--ok { background: var(--green); color: #fff; }
.mkt-pill--warn { background: #f4c542; color: #3a2f00; }
#perfil-status { margin: 0 0 16px; }

/* normalize button height: an <a class="btn"> inherits the 1.6 body line-height
   and renders taller than a sibling <button class="btn"> without this. */
.btn, .mkt-btn { line-height: 1.2; }

/* header: brand left, menu + profile pushed right */
.nav__brand { margin-right: auto; }
.nav__profile { display: inline-flex; align-items: center; gap: 6px; margin-left: 22px; color: #fff; text-decoration: none; font-family: var(--font-title); font-weight: 700; font-size: 16px; }
.nav__profile:hover { color: var(--green-bright); }
.nav__profile-ico { width: 22px; height: 22px; flex: 0 0 auto; }
@media (max-width: 768px) { .nav__profile { margin-left: 14px; } }

/* browse: search card + grid */
.mkt-search { background: #fff; border-radius: 8px; box-shadow: 0 2px 10px rgba(0,0,0,.10); padding: 20px 20px 22px; margin: 20px 0 18px; }
.mkt-search__title { font-size: clamp(28px, 3.6vw, 38px); font-weight: 500; color: #000; line-height: 1.1; margin: 0 0 16px; }
.mkt-filters { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.mkt-filters select, .mkt-filters input { font-family: inherit; font-size: 15px; padding: 9px 11px; border: 1px solid #cfd4d2; border-radius: 6px; background: var(--bg-off); }
.mkt-check { display: flex; align-items: center; gap: 6px; font-size: 15px; color: var(--text); margin-left: auto; }
.mkt-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; margin-bottom: 24px; }
@media (max-width: 780px){ .mkt-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 460px){ .mkt-grid { grid-template-columns: 1fr; } }
.mkt-lcard { background: #fff; border-radius: 8px; overflow: hidden; box-shadow: 0 2px 10px rgba(0,0,0,.10); display: flex; flex-direction: column; text-decoration: none; color: inherit; transition: box-shadow .15s, transform .15s; }
.mkt-lcard:hover { box-shadow: 0 4px 16px rgba(0,0,0,.14); transform: translateY(-2px); text-decoration: none; }
.mkt-lcard:hover .mkt-lcard__title, .mkt-lcard:hover .mkt-lcard__price, .mkt-lcard:hover .mkt-lcard__meta { text-decoration: none; }
.mkt-lcard--sold { opacity: .6; }
.mkt-lcard__photo { height: 140px; background: linear-gradient(135deg,#e7ebe8,#d3dad5); position: relative; }
.mkt-lcard__badge { position: absolute; top: 8px; left: 8px; background: rgba(0,0,0,.62); color: #fff; font-size: 10px; font-weight: 700; padding: 3px 7px; border-radius: 5px; text-transform: uppercase; letter-spacing: .3px; }
.mkt-lcard__body { padding: 12px 14px 14px; }
.mkt-lcard__title { font-family: var(--font-title); font-weight: 700; color: var(--ink); font-size: 16px; line-height: 1.2; }
.mkt-lcard__price { color: var(--green-dark); font-weight: 700; font-size: 17px; margin-top: 2px; }
.mkt-lcard__meta { color: var(--muted); font-size: 13px; margin-top: 2px; }
.mkt-empty { background: #fff; border-radius: 8px; padding: 28px; text-align: center; color: var(--muted); }

/* listing detail */
.mkt-crumb { color: #fff; font-size: 13px; margin: 14px 2px 10px; }
.mkt-crumb a { color: #fff; }
.mkt-detail { display: grid; grid-template-columns: 1.3fr 1fr; gap: 22px; background: #fff; border-radius: 8px; box-shadow: 0 2px 10px rgba(0,0,0,.10); padding: 22px; margin-bottom: 24px; }
@media (max-width: 780px){ .mkt-detail { grid-template-columns: 1fr; } }
.mkt-detail__photo { height: 260px; background: linear-gradient(135deg,#e7ebe8,#d3dad5); border-radius: 8px; display: flex; align-items: center; justify-content: center; color: #9aa1ab; }
.mkt-detail__title { font-size: clamp(26px, 3.2vw, 34px); font-weight: 500; color: #000; line-height: 1.12; margin: 0 0 10px; }
.mkt-badge { display: inline-block; background: var(--green-deep); color: #fff; font-size: 11px; font-weight: 700; padding: 4px 10px; border-radius: 5px; text-transform: uppercase; letter-spacing: .3px; }
.mkt-detail__price { color: var(--green-dark); font-weight: 700; font-size: 26px; margin: 12px 0 14px; }
.mkt-fact { font-size: 15px; color: var(--text); margin: 5px 0; }
.mkt-detail__desc { color: var(--text); font-size: 15px; line-height: 1.6; margin: 16px 0; }
.mkt-seller { border-top: 1px solid #eee; padding-top: 16px; }
.mkt-seller h3 { font-weight: 700; font-size: 20px; color: var(--ink); margin: 0 0 8px; }
.mkt-seller__name { font-weight: 700; color: var(--ink); font-size: 16px; margin-bottom: 10px; }
.mkt-contact { display: flex; flex-direction: column; gap: 8px; }
.mkt-contact__btn { display: flex; align-items: center; gap: 10px; background: #fff; color: var(--green-deep); border: 2px solid var(--green-dark); font-weight: 700; font-size: 14px; padding: 10px 14px; border-radius: 6px; text-decoration: none; }
.mkt-contact__btn:hover { background: var(--bg-off); }
.mkt-contact__btn svg { width: 18px; height: 18px; }
