/* ============================================================
   app.custom.css — extinderi peste app.css (nu modifica app.css)
   Paleta moștenită: --blue #004798 · --green #009c5a · --yellow
   ============================================================ */

/* ---- Navigație principală ---- */
.mainnav{display:flex;flex-wrap:wrap;gap:2px;flex:1;justify-content:center}
.navlink{color:rgba(255,255,255,.85);font-size:13px;font-weight:600;padding:7px 11px;border-radius:8px;white-space:nowrap}
.navlink:hover{background:rgba(255,255,255,.12);color:#fff}
.navlink.on{background:rgba(255,255,255,.18);color:#fff}
@media(max-width:920px){
  .mainnav{order:3;width:100%;justify-content:flex-start;margin-top:10px;overflow-x:auto}
  .topbar{flex-wrap:wrap}
}

/* ---- Page head actions ---- */
.head-actions{display:flex;align-items:center;gap:12px;margin-left:auto}
.page-head{align-items:center}

/* ---- Status badges noi (pipeline EN) în paleta existentă ---- */
.st-pending{background:#fbf0d8;color:#7a5b06}
.st-confirmed{background:#e1f5ee;color:#0f6e56}
.st-checked_in{background:#e6f1fb;color:#0c447c}
.st-in_progress{background:#e4ecfb;color:#1d3f8a}
.st-completed{background:#eef1f4;color:#5a6478}
.st-no_show{background:#f6e3d2;color:#8a4b1a}
.st-canceled{background:#fcebeb;color:#a32d2d}
/* statusuri remindere */
.st-sent{background:#e1f5ee;color:#0f6e56}
.st-failed{background:#fcebeb;color:#a32d2d}
.st-missed{background:#f6e3d2;color:#8a4b1a}

/* ---- Butoane mici ---- */
.btn-sm{padding:5px 10px;font-size:12px}
.btn-ghost.btn-sm{color:var(--blue);border-color:var(--line)}
.btn-ghost.btn-sm:hover{background:#f6f9fe;border-color:var(--blue)}

/* ---- Form grid generic ---- */
.form-grid{display:flex;flex-direction:column;gap:8px;max-width:760px}
.form-grid h3{margin:14px 0 2px;font-size:14px;font-weight:700;color:var(--ink)}
.form-grid h3:first-of-type{margin-top:0}
.form-grid label{display:flex;flex-direction:column;gap:5px;font-size:13px;font-weight:600;color:var(--ink2)}
.actions{margin-top:14px}
.chk{flex-direction:row !important;align-items:center;gap:8px !important;font-weight:600}
.chk input{accent-color:var(--blue);width:16px;height:16px}

/* ---- Autocomplete sugestii ---- */
.suggest{position:relative;background:#fff;border:1px solid var(--line);border-radius:0 0 10px 10px;margin-top:-4px;max-height:220px;overflow-y:auto;z-index:20}
.suggest:empty{display:none;border:0}
.suggest-item{padding:9px 12px;font-size:13px;cursor:pointer;border-bottom:1px solid #f1f3f7}
.suggest-item:hover{background:#f6f9fe}
.suggest-item:last-child{border-bottom:0}

/* ---- Două coloane (admin editors) ---- */
.cols2{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:900px){.cols2{grid-template-columns:1fr 1fr}}

/* ---- Calendar ---- */
.cal-filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.cal-filters .inp{flex:0 0 auto;min-width:180px}
#calendar{--fc-border-color:var(--line);--fc-today-bg-color:#fef9e0;font-size:13px}
.fc .fc-button-primary{background:var(--blue);border-color:var(--blue);text-transform:none;font-weight:600}
.fc .fc-button-primary:hover{background:var(--blue-dark);border-color:var(--blue-dark)}
.fc .fc-button-primary:not(:disabled).fc-button-active{background:var(--blue-dark);border-color:var(--blue-dark)}
.fc-event{cursor:pointer;border:none;font-weight:600}
.fc-event.ev-canceled{opacity:.45;text-decoration:line-through}
.fc-event.ev-pending{opacity:.85}
.fc .fc-toolbar-title{font-size:18px;font-weight:800;color:var(--ink)}

/* ---- Modal ---- */
.modal{position:fixed;inset:0;background:rgba(15,23,36,.45);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}
.modal-card{background:#fff;border-radius:16px;border-top:4px solid var(--yellow);padding:26px;width:100%;max-width:440px;position:relative;max-height:90vh;overflow-y:auto}
.modal-card h2{color:var(--ink);text-transform:none;font-size:18px;letter-spacing:0}
.modal-close{position:absolute;top:12px;right:14px;background:none;border:none;font-size:26px;line-height:1;color:var(--muted);cursor:pointer}
.modal-close:hover{color:var(--ink)}
.modal-card form{display:flex;flex-direction:column;gap:10px;margin-top:8px}
.modal-card label{display:flex;flex-direction:column;gap:5px;font-size:13px;font-weight:600;color:var(--ink2)}

/* ---- Select & mono ---- */
.sel{min-width:160px}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px}
.swatch{display:inline-block;width:20px;height:20px;border-radius:5px;border:1px solid var(--line);vertical-align:middle}

/* ---- Tabel mini ---- */
.tbl.mini{font-size:13px}
.tbl.mini th,.tbl.mini td{padding:8px 10px}
.tbl.mini tbody tr{cursor:default}
.tbl.mini tbody tr:hover{background:transparent}
.tbl tbody tr.sel{background:#eef4fc}

/* card-uri în care tabelul nu e clickabil întreg */
.card .tbl tbody tr{cursor:default}
.card .tbl tbody tr[onclick]{cursor:pointer}

/* ---- Variabile template ---- */
.varlist{display:flex;flex-wrap:wrap;gap:6px}
.var-chip{font-family:ui-monospace,monospace;font-size:12px;padding:5px 9px;background:#eef4fc;color:var(--blue);border:1px solid #d3e3f6;border-radius:6px;cursor:pointer}
.var-chip:hover{background:var(--blue);color:#fff}
.preview{border:1px solid var(--line);border-radius:10px;padding:16px;background:#fff;min-height:80px;font-size:14px}
.preview pre{white-space:pre-wrap;margin:0;font-family:inherit}

/* ---- Statistici (rapoarte) ---- */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:20px}
.stat{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px 20px;border-top:3px solid var(--blue)}
.stat-num{font-size:28px;font-weight:800;color:var(--ink);line-height:1}
.stat-lbl{font-size:13px;color:var(--muted);margin-top:6px}

/* ---- note info ---- */
.note.info{background:#e6f1fb;color:#0c447c;border:1px solid #c5ddf5}

/* tag cu bordură colorată per serviciu */
.tag{border:1px solid transparent}

hr{border:none;border-top:1px solid var(--line);margin:18px 0}

@media(max-width:560px){
  .cols2{grid-template-columns:1fr}
  .head-actions{flex-wrap:wrap}
}

/* ---- Follow-up pe pagina programării ---- */
.fu-form label{display:block;font-size:13px;font-weight:600;color:var(--ink2);margin:10px 0 5px}
.fu-toggle{display:flex;gap:8px;flex-wrap:wrap}
.fu-radio{display:flex !important;align-items:center;gap:6px;margin:0 !important;padding:8px 12px;border:1px solid var(--line);border-radius:8px;cursor:pointer;font-weight:600}
.fu-radio input{accent-color:var(--blue)}
.fu-quick{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}
.fu-preview-wrap{margin-top:12px}
.fu-preview-label{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.fu-preview{border:1px solid var(--line);border-radius:10px;padding:14px;background:#fbfcfe;font-size:14px;min-height:50px}
.fu-pv-to{font-size:12px;color:var(--muted);margin-bottom:6px}
.fu-pv-subj{font-weight:700;color:var(--ink);margin-bottom:8px}
.fu-pv-body{color:#2b3445;line-height:1.5}
#fu_custom input{margin-bottom:8px}

/* ---- Status follow-up în lista de remindere ---- */
.fu-st{font-size:12px;font-weight:600;display:inline-block}
.fu-st-pending{color:#0c447c}
.fu-st-sent{color:#0f6e56}
.fu-st-canceled{color:#8a4b1a}
.fu-st-failed{color:#a32d2d}
.fu-pv-sms{margin-top:8px;font-size:12px;color:var(--muted);border-top:1px dashed var(--line);padding-top:6px}

/* ---- Carduri follow-up pe categorii ---- */
.fu-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:8px}
.fu-cardbox{border:1px solid var(--line);border-radius:12px;padding:14px;background:#fbfcfe}
.fu-cardbox-h{font-weight:800;color:var(--ink);font-size:15px;margin-bottom:10px;padding-bottom:8px;border-bottom:2px solid var(--yellow)}
.fu-cardbox form label{display:block;font-size:12px;font-weight:600;color:var(--ink2);margin:8px 0 4px}
.fu-cardbox .fu-toggle{gap:4px}
.fu-cardbox .fu-radio{padding:5px 8px;font-size:12px}
.fu-cardbox .actions{margin-top:12px}
.fu-cardbox .btn-primary{width:100%;text-align:center}

/* ---- Pagina client: mașini & expirări ---- */
.veh-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line)}
.veh-row:last-child{border-bottom:none}
.veh-info{flex:1}
.veh-exp{display:flex;gap:14px;flex-wrap:wrap;margin-top:6px;font-size:12px}
.veh-exp span{font-weight:600}
.exp-ok{color:#0f6e56}
.exp-soon{color:#8a4b1a}
.exp-over{color:#a32d2d}
.card-top{display:flex;justify-content:space-between;align-items:center}

/* ---- Editare inline contact (programare) ---- */
.contact-edit{margin-top:12px;padding:14px;border:1px solid var(--line);border-radius:10px;background:#fbfcfe}
.contact-edit label{display:block;font-size:12px;font-weight:600;color:var(--ink2);margin:6px 0 4px}
.contact-edit .actions{margin-top:10px}

/* ---- Checkbox-uri canal (carduri follow-up) ---- */
.ch-checks{display:flex;flex-direction:column;gap:6px}
.ch-check{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--ink2)}
.ch-check input{accent-color:var(--blue)}
.ch-val{font-weight:400;color:var(--muted);font-size:12px}
