/* ============================================================
   platforma.css — platforma de clienți OTTO
   (cont.html, contul-meu.html). Folosește tokenii din :root ai
   paginii (--orange, --serif, --cream-* …), ca fisa-online.css.
   ============================================================ */

/* ---- containere ---- */
.pf-auth { max-width: 560px; margin: 0 auto; padding: 3rem 1.5rem 5rem; }
.pf-cont { max-width: 980px; margin: 0 auto; padding: 3rem 1.5rem 5rem; }

/* ---- tab-uri login / cont nou ---- */
.pf-tabs { display: flex; gap: 0.6rem; margin-bottom: 1.4rem; }
.pf-tab {
  flex: 1; padding: 0.9rem 1rem; font-family: inherit; font-size: 0.97rem; font-weight: 600;
  border: 1.5px solid var(--cream-3); background: #fff; color: var(--text-soft);
  border-radius: var(--radius-sm, 6px); cursor: pointer; transition: border-color .2s, color .2s, background .2s;
}
.pf-tab:hover { border-color: var(--orange-light); color: var(--orange-deep); }
.pf-tab.active { border-color: var(--orange); background: var(--orange-pale); color: var(--orange-deep); }

/* ---- carduri & câmpuri (aliniate cu .fo-card / .fo-field) ---- */
.pf-card {
  background: #fff; border: 1px solid var(--cream-3);
  border-radius: var(--radius-md, 12px); padding: 1.6rem;
  box-shadow: var(--shadow-sm, 0 2px 8px rgba(26,20,14,.06));
}
.pf-card + .pf-card { margin-top: 1.2rem; }
.pf-pane-title { font-family: var(--serif); font-weight: 500; font-size: 1.5rem; margin-bottom: 0.4rem; color: var(--text); }
.pf-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 0 1.2rem; }
.pf-field { margin-bottom: 1.1rem; }
.pf-field label { display: block; font-size: 0.82rem; font-weight: 500; margin-bottom: 0.45rem; color: var(--text); letter-spacing: .01em; }
.pf-req { color: var(--orange-deep); }
.pf-field input, .pf-field select, .pf-field textarea {
  width: 100%; padding: 0.8rem 0.95rem; font-family: inherit; font-size: 0.95rem;
  border: 1.5px solid var(--cream-3); border-radius: var(--radius-sm, 6px);
  background: #fff; color: var(--text); transition: border-color .2s, box-shadow .2s;
}
.pf-field input:focus, .pf-field select:focus, .pf-field textarea:focus {
  outline: none; border-color: var(--orange); box-shadow: 0 0 0 3px rgba(255,136,0,.12);
}
.pf-field input.invalid { border-color: #d9534f; }
.pf-err { color: #d9534f; font-size: 0.8rem; margin-top: 0.35rem; display: none; }
.pf-err.show { display: block; }
.pf-err-form { margin: 0.2rem 0 0.9rem; font-size: 0.88rem; }
.pf-ok { color: #2e7d32; background: #edf7ed; border: 1px solid #c8e6c9; border-radius: var(--radius-sm, 6px); padding: 0.7rem 0.9rem; font-size: 0.88rem; margin-bottom: 0.9rem; }
.pf-note { color: var(--text-soft); font-size: 0.85rem; line-height: 1.5; margin-top: 0.9rem; }

.pf-cb { display: flex; align-items: flex-start; gap: 0.6rem; cursor: pointer; font-size: 0.92rem; color: var(--text-soft); line-height: 1.45; margin: 0.4rem 0 1rem; }
.pf-cb input { width: auto; margin-top: 0.15rem; flex-shrink: 0; cursor: pointer; accent-color: var(--orange); }
.pf-cb a { color: var(--orange-deep); text-decoration: underline; }

/* ---- butoane ---- */
.pf-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem; width: 100%;
  padding: 0.95rem 1.5rem; font-family: inherit; font-size: 0.97rem; font-weight: 600;
  color: #fff; background: var(--orange); border: none; border-radius: var(--radius-sm, 6px);
  cursor: pointer; transition: background .2s, transform .15s;
}
.pf-btn:hover:not(:disabled) { background: var(--orange-deep); transform: translateY(-1px); }
.pf-btn:disabled { opacity: 0.6; cursor: not-allowed; }
.pf-btn .pf-btn-loading { display: none; }
.pf-btn.loading .pf-btn-text { display: none; }
.pf-btn.loading .pf-btn-loading { display: inline; }
.pf-btn-secondary {
  display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.7rem 1.2rem;
  font-family: inherit; font-size: 0.88rem; font-weight: 600; color: var(--text-soft);
  background: #fff; border: 1.5px solid var(--cream-3); border-radius: var(--radius-sm, 6px);
  cursor: pointer; transition: border-color .2s, color .2s; text-decoration: none;
}
.pf-btn-secondary:hover { border-color: var(--orange-light); color: var(--orange-deep); }
.pf-btn-danger:hover { border-color: #d9534f; color: #d9534f; }
.pf-link {
  display: block; margin: 0.9rem auto 0; background: none; border: none; cursor: pointer;
  font-family: inherit; font-size: 0.85rem; color: var(--orange-deep); text-decoration: underline;
}

/* ---- banner cont neaprobat ---- */
.pf-banner {
  display: flex; gap: 0.8rem; align-items: flex-start;
  background: var(--orange-pale); border: 1px solid var(--orange-light);
  border-radius: var(--radius-md, 12px); padding: 1rem 1.2rem; margin-bottom: 1.6rem;
  font-size: 0.92rem; color: var(--text); line-height: 1.5;
}
.pf-banner[hidden] { display: none; }

/* ---- antetul din Contul meu ---- */
.pf-head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; margin-bottom: 1.6rem; }
.pf-head-name { font-family: var(--serif); font-size: 1.6rem; font-weight: 500; color: var(--text); }
.pf-head-mail { color: var(--text-soft); font-size: 0.88rem; }
.pf-head-actions { display: flex; gap: 0.6rem; flex-wrap: wrap; }

/* ---- listă comenzi ---- */
.pf-section-title { font-family: var(--serif); font-weight: 500; font-size: clamp(1.5rem, 3vw, 1.9rem); color: var(--text); margin: 2rem 0 1rem; }
.pf-empty { color: var(--text-mute); font-size: 0.92rem; padding: 1.6rem; text-align: center; border: 1.5px dashed var(--cream-3); border-radius: var(--radius-md, 12px); }
.pf-order { margin-bottom: 1.2rem; }
.pf-order-top { display: flex; align-items: baseline; justify-content: space-between; gap: 0.8rem; flex-wrap: wrap; }
.pf-order-nr { font-weight: 700; color: var(--text); font-size: 1.02rem; }
.pf-order-date { color: var(--text-mute); font-size: 0.82rem; }
.pf-order-meta { color: var(--text-soft); font-size: 0.88rem; margin-top: 0.3rem; }
.pf-order-actions { display: flex; gap: 0.6rem; flex-wrap: wrap; margin-top: 1rem; }

/* status pill */
.pf-status { display: inline-flex; align-items: center; gap: 0.4rem; padding: 0.25rem 0.7rem; border-radius: 999px; font-size: 0.78rem; font-weight: 600; }
.pf-status::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: currentColor; }
.pf-status-nou { background: #fff6e8; color: #b86a00; }
.pf-status-lucru { background: #e8f1fb; color: #1e5a96; }
.pf-status-gata { background: #edf7ed; color: #2e7d32; }
.pf-status-anulata { background: #f4f4f4; color: #777; }

/* timeline vizual: Primită → În lucru → Gata */
.pf-timeline { display: flex; align-items: center; margin: 1.1rem 0 0.2rem; }
.pf-tl-step { display: flex; flex-direction: column; align-items: center; gap: 0.35rem; flex: 0 0 auto; min-width: 72px; }
.pf-tl-dot {
  width: 1.5rem; height: 1.5rem; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  background: var(--cream-2); border: 2px solid var(--cream-3); color: transparent; font-size: 0.7rem; font-weight: 700;
  transition: background .2s, border-color .2s;
}
.pf-tl-step.done .pf-tl-dot { background: var(--orange); border-color: var(--orange); color: #fff; }
.pf-tl-label { font-size: 0.72rem; color: var(--text-mute); }
.pf-tl-step.done .pf-tl-label { color: var(--text); font-weight: 600; }
.pf-tl-line { flex: 1; height: 2px; background: var(--cream-3); margin: 0 0.3rem 1.2rem; }
.pf-tl-line.done { background: var(--orange); }

/* documente livrate */
.pf-files { margin-top: 1rem; display: flex; flex-direction: column; gap: 0.5rem; }
.pf-file {
  display: flex; align-items: center; gap: 0.6rem; padding: 0.65rem 0.9rem;
  border: 1.5px solid var(--cream-3); border-radius: var(--radius-sm, 6px);
  font-size: 0.88rem; color: var(--text); text-decoration: none; transition: border-color .2s, background .2s;
}
.pf-file:hover { border-color: var(--orange-light); background: var(--orange-pale); }
.pf-file svg { flex-shrink: 0; color: var(--orange-deep); }

/* ---- cerere de ofertă ---- */
.co-rand { display: flex; gap: 0.9rem; align-items: flex-end; flex-wrap: wrap; padding: 0.8rem 0; border-bottom: 1px dashed var(--cream-3); }
.co-rand-cat { align-items: center; }
.co-rand a { color: var(--text); text-decoration: none; }
.co-rand a:hover { color: var(--orange-deep); }
.co-pret { flex: 0 0 150px; text-align: right; font-size: 0.86rem; color: var(--text-soft); }
.co-pret label { display: block; font-size: 0.82rem; }
.co-pret-val strong { color: var(--text); }
.co-x { flex: 0 0 auto; width: 2rem; height: 2rem; border: 1.5px solid var(--cream-3); background: #fff; border-radius: 50%; color: var(--text-mute); font-size: 1.1rem; line-height: 1; cursor: pointer; }
.co-x:hover { border-color: #d9534f; color: #d9534f; }
.co-pill { display: inline-flex; min-width: 1.3rem; justify-content: center; background: var(--orange); color: #fff; border-radius: 999px; font-size: 0.72rem; padding: 0.1rem 0.4rem; margin-left: 0.3rem; }
.co-total { margin-top: 1.1rem; padding: 0.9rem 1.1rem; background: var(--orange-pale); border: 1px solid var(--orange-light); border-radius: var(--radius-sm, 8px); font-size: 0.95rem; }
.co-total strong { font-size: 1.1rem; }
.muted-mic { color: var(--text-mute); font-size: 0.8rem; margin-top: 0.25rem; }

/* oferte în cont */
.pf-of-top { display: flex; align-items: baseline; justify-content: space-between; gap: 0.8rem; flex-wrap: wrap; }
.pf-countdown { font-size: 0.8rem; color: var(--text-soft); }
.pf-countdown strong { color: var(--orange-deep); }

/* ---- pagina de promovare ---- */
.promo-cta { display: flex; gap: 0.8rem; flex-wrap: wrap; justify-content: center; margin-top: 1.8rem; }
.promo { max-width: 1100px; margin: 0 auto; padding: 3rem 1.5rem 5rem; }
.promo-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1.4rem; }
.promo-card { background: #fff; border: 1px solid var(--cream-3); border-radius: var(--radius-md, 12px); padding: 1.6rem; box-shadow: var(--shadow-sm, 0 2px 8px rgba(26,20,14,.06)); }
.promo-num { width: 2.4rem; height: 2.4rem; display: flex; align-items: center; justify-content: center; background: var(--orange); color: #fff; border-radius: 50%; font-family: var(--serif); font-size: 1.2rem; font-weight: 600; margin-bottom: 0.9rem; }
.promo-card h3 { font-family: var(--serif); font-weight: 500; font-size: 1.25rem; margin-bottom: 0.5rem; color: var(--text); }
.promo-card p { color: var(--text-soft); font-size: 0.92rem; line-height: 1.6; }
.promo-final { text-align: center; margin-top: 3.5rem; padding: 2.6rem 1.5rem; background: var(--orange-pale); border: 1px solid var(--orange-light); border-radius: var(--radius-md, 12px); }
.promo-final h2 { font-family: var(--serif); font-weight: 500; font-size: clamp(1.6rem, 4vw, 2.2rem); color: var(--text); margin-bottom: 0.6rem; }
.promo-final p { color: var(--text-soft); max-width: 560px; margin: 0 auto; line-height: 1.6; }

/* modal simplu (date de facturare) */
.pf-modal { position: fixed; inset: 0; z-index: 70; display: flex; align-items: flex-start; justify-content: center; padding: 6vh 1rem; background: rgba(26,20,14,.45); overflow-y: auto; }
.pf-modal[hidden] { display: none; }
.pf-modal-box { width: 100%; max-width: 480px; }

@media (max-width: 560px) {
  .pf-grid-2 { grid-template-columns: 1fr; gap: 0; }
  .pf-head { flex-direction: column; align-items: flex-start; }
  .pf-timeline { margin-left: -0.3rem; }
  .pf-tl-step { min-width: 58px; }
}

/* ---- modal selector decoruri (cererea de ofertă, fluxul PAL) ----
   aceleași stiluri ca selectorul din fișa online (fo-modal), redenumite
   co-dlg ca să nu depindă de fisa-online.css */
/* alegerea decorului = acțiunea EVIDENTĂ a câmpului de material */
.co-decor-btn { margin-top: 0.45rem; padding: 0.55rem 0.9rem; border: 1.5px solid var(--orange-light); background: var(--orange-pale); font-family: inherit; font-size: 0.85rem; font-weight: 600; color: var(--orange-deep); cursor: pointer; border-radius: var(--radius-sm, 6px); display: inline-block; }
.co-decor-btn:hover { border-color: var(--orange); background: #ffe9cf; }
/* acțiunile rare devin linkuri discrete — o singură acțiune primară per card */
.pf-btn-mic { background: none; border: none; padding: 0.2rem 0.3rem; font-family: inherit; font-size: 0.8rem; font-weight: 600; color: var(--text-soft); cursor: pointer; text-decoration: underline; text-underline-offset: 3px; border-radius: 4px; }
.pf-btn-mic:hover { color: var(--orange-deep); }
.pf-btn-mic.pf-btn-danger { background: none; border: none; color: #a33; }
#co-pal-adauga { border: none; background: none; padding: 0.2rem 0; font-size: 0.85rem; color: var(--text-soft); text-decoration: underline; text-underline-offset: 3px; }
#co-pal-adauga:hover { color: var(--orange-deep); border: none; background: none; }
.co-dlg { position: fixed; inset: 0; z-index: 10000; background: rgba(20,16,10,.55); display: flex; align-items: center; justify-content: center; padding: 1rem; }
.co-dlg[hidden] { display: none; }
.co-dlg-box { background: #fff; width: 100%; max-width: 760px; max-height: 88vh; border-radius: var(--radius-md, 12px); display: flex; flex-direction: column; overflow: hidden; box-shadow: var(--shadow-lg, 0 24px 60px rgba(26,20,14,.3)); }
.co-dlg-head { display: flex; align-items: center; justify-content: space-between; padding: 1.1rem 1.3rem; border-bottom: 1px solid var(--cream-3); }
.co-dlg-head h3 { font-family: var(--serif); font-weight: 500; font-size: 1.4rem; }
.co-dlg-close { background: none; border: none; cursor: pointer; color: var(--text-soft); padding: 0.3rem; line-height: 0; border-radius: 4px; }
.co-dlg-close svg { width: 22px; height: 22px; }
.co-dlg-close:hover { color: var(--orange-deep); }
.co-dlg-tools { padding: 1rem 1.3rem 0.6rem; }
.co-dlg-tools input[type=search] { width: 100%; padding: 0.75rem 1rem; font-family: inherit; font-size: 0.95rem; border: 1.5px solid var(--cream-3); border-radius: var(--radius-sm, 6px); }
.co-dlg-tools input[type=search]:focus { outline: none; border-color: var(--orange); box-shadow: 0 0 0 3px rgba(255,136,0,.12); }
.co-dlg-suppliers { display: flex; gap: 0.4rem; flex-wrap: wrap; margin-top: 0.7rem; }
.co-sup-chip { padding: 0.4rem 0.9rem; font-family: inherit; font-size: 0.78rem; border: 1px solid var(--cream-3); background: #fff; color: var(--text-soft); border-radius: 50px; cursor: pointer; transition: background .2s, color .2s, border-color .2s; }
.co-sup-chip:hover { border-color: var(--orange); color: var(--orange-deep); }
.co-sup-chip.active { background: var(--dark); color: #fff; border-color: var(--dark); }
.co-dlg-count { padding: 0.2rem 1.3rem; font-size: 0.78rem; color: var(--text-mute); }
.co-dlg-grid { padding: 0.6rem 1.3rem 1rem; overflow-y: auto; display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 0.8rem; }
.co-dlg-loading { grid-column: 1 / -1; padding: 2.4rem 1rem; text-align: center; color: var(--text-mute); font-size: 0.9rem; }
.co-color-card { content-visibility: auto; contain-intrinsic-size: 170px; display: flex; flex-direction: column; border: 1px solid var(--cream-3); border-radius: var(--radius-sm, 6px); overflow: hidden; cursor: pointer; background: #fff; text-align: left; padding: 0; font-family: inherit; transition: transform .2s, box-shadow .2s, border-color .2s; }
.co-color-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md, 0 8px 20px rgba(26,20,14,.12)); border-color: var(--orange-light); }
.co-color-card img { width: 100%; aspect-ratio: 1/1; object-fit: cover; background: var(--cream-2); }
.co-color-card .cc-info { padding: 0.5rem 0.6rem; }
.co-color-card .cc-name { font-size: 0.8rem; font-weight: 600; color: var(--text); line-height: 1.2; }
.co-color-card .cc-code { font-size: 0.72rem; color: var(--text-mute); margin-top: 2px; }
.co-dlg-more { padding: 0 1.3rem 1.2rem; text-align: center; }
.co-dlg-more button { padding: 0.7rem 1.6rem; font-family: inherit; font-size: 0.88rem; font-weight: 600; border: 1.5px solid var(--cream-3); background: #fff; color: var(--text-soft); border-radius: var(--radius-sm, 6px); cursor: pointer; }
.co-dlg-more button:hover { border-color: var(--orange-light); color: var(--orange-deep); }
