/* =========================
   Clients Manager (CMC) – LIGHT + TEAL ACCENT (Metsamaakler style)
   ========================= */

:root{
  /* Base */
  --cmc-bg: #ffffff;
  --cmc-card: #ffffff;
  --cmc-border: rgba(17,36,41,0.14);

  --cmc-text: rgba(17,36,41,0.92);
  --cmc-dim: rgba(17,36,41,0.62);

  --cmc-shadow: 0 14px 36px rgba(0,0,0,0.10);

  /* Accent (teal) */
  --cmc-accent: #3f8a8b;          /* teal */
  --cmc-accent-soft: rgba(63,138,139,0.14);
  --cmc-accent-border: rgba(63,138,139,0.28);

  /* Status */
  --cmc-green: #00a853;
  --cmc-red: #d81f1f;

  /* Buttons */
  --cmc-mint: #6fe8cd;
  --cmc-dark: #0b1b1f;

  /* Inputs / modal */
  --cmc-input-bg: rgba(17,36,41,0.06);
  --cmc-modal-bg: #ffffff;
  --cmc-overlay: rgba(0,0,0,0.35);
}

/* Optional: if theme adds weird backgrounds to code/pre around shortcode */
.cmc-app pre,
.cmc-app code{ background: transparent !important; }

/* hide helper for filtering */
.cmc-hidden{ display:none !important; }

.cmc-app{
  background: var(--cmc-bg);
  border: 1px solid var(--cmc-border);
  border-radius: 18px;
  padding: 18px;
  color: var(--cmc-text);
}

.cmc-empty{
  color: var(--cmc-dim);
  padding: 14px;
  border: 1px dashed var(--cmc-border);
  border-radius: 14px;
}

/* Topbar */
.cmc-topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom: 16px;
}

.cmc-filters{
  display:flex;
  align-items:center;
  gap: 10px;
  flex-wrap: wrap;
}

.cmc-filter select{
  padding:10px 12px;
  border-radius: 12px;
  border: 1px solid var(--cmc-border);
  background: var(--cmc-input-bg);
  color: var(--cmc-text);
  outline: none;
  min-width: 240px;
}
.cmc-filter select:focus{
  border-color: var(--cmc-accent-border);
  box-shadow: 0 0 0 3px var(--cmc-accent-soft);
}

/* Search input */
.cmc-search input#cmc-search{
  width: 320px;
  max-width: 100%;
  padding:10px 12px;
  border-radius: 12px;
  border: 1px solid var(--cmc-border);
  background: var(--cmc-input-bg);
  color: var(--cmc-text);
  outline: none;
  box-sizing: border-box;
}
.cmc-search input#cmc-search:focus{
  border-color: var(--cmc-accent-border);
  box-shadow: 0 0 0 3px var(--cmc-accent-soft);
}
.cmc-search input#cmc-search::placeholder{
  color: rgba(17,36,41,0.45);
}

/* Primary top button */
.cmc-add-btn{
  padding: 10px 18px;
  border-radius: 999px;
  border: 1px solid var(--cmc-accent-border);
  background: var(--cmc-accent);
  color: #fff;
  font-weight: 900;
  cursor:pointer;
  box-shadow: 0 10px 22px rgba(0,0,0,0.08);
}
.cmc-add-btn:hover{ opacity:.95; }

/* Cards grid */
.cmc-cards{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

/* Card */
.cmc-card{
  background: var(--cmc-card);
  border: 1px solid var(--cmc-border);
  border-radius: 18px;
  padding: 18px;
  box-shadow: var(--cmc-shadow);
  display:flex;
  flex-direction:column;
  min-height: 280px;
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.cmc-card:hover{
  transform: translateY(-1px);
  border-color: rgba(63,138,139,0.22);
  box-shadow: 0 18px 44px rgba(0,0,0,0.12);
}

/* Lines area */
.cmc-card-lines{
  display:flex;
  flex-direction:column;
  gap: 12px;
  flex: 1 1 auto;
  min-height: 0;
}

/* line */
.cmc-line{
  display:flex;
  flex-direction:column;
  gap: 4px;
}

.cmc-label{
  font-size: 12px;
  font-weight: 900;
  color: var(--cmc-dim);
  text-transform: uppercase;
  letter-spacing: .6px;
}

.cmc-value{
  font-size: 18px;
  font-weight: 800;
  color: var(--cmc-text);
  line-height: 1.25;
  word-break: break-word;
}

/* Clamp extra info so card doesn't break */
.cmc-line:nth-child(3) .cmc-value{
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  overflow: hidden;
}

/* Reminder colors */
.cmc-reminder-text{
  font-weight: 900;
  font-size: 16px;
  line-height: 1.2;
}
.cmc-reminder-ok{ color: var(--cmc-green); }
.cmc-reminder-bad{ color: var(--cmc-red); }

/* Actions */
.cmc-card-actions{
  display:flex;
  justify-content: space-between;
  align-items:center;
  gap: 14px;
  margin-top: 12px;
}

.cmc-edit-client-btn,
.cmc-delete-btn{
  appearance:none;
  border:0;
  border-radius:999px;
  padding: 12px 22px;
  font-weight:900;
  cursor:pointer;
  line-height:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width: 120px;
}

/* Edit: teal filled */
.cmc-edit-client-btn{
  background: var(--cmc-accent);
  color: #fff;
  box-shadow: 0 10px 18px rgba(0,0,0,0.10);
}

/* Delete: red outline */
.cmc-delete-btn{
  background: rgba(216,31,31,0.10);
  color: var(--cmc-red);
  border: 1px solid rgba(216,31,31,0.22);
  box-shadow: 0 10px 18px rgba(0,0,0,0.06);
}

.cmc-edit-client-btn:hover,
.cmc-delete-btn:hover{ opacity:.95; }

/* Results counter */
.cmc-results{
  margin-top: 10px;
  color: rgba(17,36,41,0.60);
  font-weight: 800;
  font-size: 13px;
}

/* Popup overlay */
.cmc-popup-overlay{
  position: fixed !important;
  inset: 0 !important;
  display: none;
  align-items: center !important;
  justify-content: center !important;
  padding: 18px !important;
  background: var(--cmc-overlay) !important;
  z-index: 2147483647 !important;
}

body.cmc-modal-open{ overflow:hidden !important; }

.cmc-popup{
  background: var(--cmc-modal-bg);
  border: 1px solid var(--cmc-border);
  border-radius: 16px;
  max-width: 900px;
  width: 100%;
  padding: 18px;
  color: var(--cmc-text);
  position: relative !important;
  z-index: 2147483647 !important;
  max-height: 90vh;
  overflow: auto;
  box-shadow: 0 18px 50px rgba(0,0,0,0.16);
}

.close-popup{
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  width: 44px !important;
  height: 44px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  border-radius:999px !important;
  background: rgba(17,36,41,0.06) !important;
  border: 1px solid var(--cmc-border) !important;
  cursor:pointer !important;
  color: rgba(17,36,41,0.75) !important;
}

/* Modal header */
.cmc-modal-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 14px;
  margin-bottom: 12px;
}

.cmc-modal-head-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.cmc-modal-subtitle{
  margin-top: 4px;
  color: rgba(17,36,41,0.58);
  font-weight: 700;
  font-size: 13px;
}

.cmc-btn{
  padding: 10px 16px;
  border-radius: 999px;
  border: 1px solid var(--cmc-border);
  background: rgba(17,36,41,0.06);
  color: var(--cmc-text);
  font-weight: 900;
  cursor:pointer;
}
.cmc-btn:hover{ opacity:.95; }
.cmc-btn-edit{ background: var(--cmc-accent); color: #fff; border-color: var(--cmc-accent); }
.cmc-btn-del{ background: rgba(216,31,31,0.10); color: var(--cmc-red); border-color: rgba(216,31,31,0.22); }
.cmc-btn-save{ background: rgba(17,36,41,0.06); }

/* View grid */
.cmc-view-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px 14px;
  margin-top: 10px;
}

.cmc-view-row{
  background: rgba(17,36,41,0.04);
  border: 1px solid rgba(17,36,41,0.10);
  border-radius: 14px;
  padding: 12px;
  min-width: 0;
}

.cmc-view-row-wide{ grid-column: span 2; }

.cmc-view-label{
  font-weight: 900;
  color: rgba(17,36,41,0.60);
  font-size: 12px;
  margin-bottom: 6px;
  text-transform: uppercase;
  letter-spacing: .6px;
}

.cmc-view-value{
  font-weight: 800;
  color: var(--cmc-text);
  font-size: 14px;
  line-height: 1.35;
  word-break: break-word;
}

.cmc-view-pre{ white-space: pre-wrap; }

/* Form */
#cmc-popup-form{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px 14px;
  margin-top: 10px;
}

#cmc-popup-form label{
  grid-column: span 2;
  font-weight: 900;
  color: rgba(17,36,41,0.60);
  font-size: 12px;
}

#cmc-popup-form input[type="text"],
#cmc-popup-form input[type="email"],
#cmc-popup-form input[type="datetime-local"],
#cmc-popup-form textarea,
#cmc-popup-form select{
  grid-column: span 2;
  width: 100%;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid var(--cmc-border);
  background: rgba(17,36,41,0.05);
  color: var(--cmc-text);
  box-sizing: border-box;
  outline: none;
}
#cmc-popup-form input:focus,
#cmc-popup-form textarea:focus,
#cmc-popup-form select:focus{
  border-color: var(--cmc-accent-border);
  box-shadow: 0 0 0 3px var(--cmc-accent-soft);
}

#client_display_name,
#client_phone,
#client_email,
#client_company{ grid-column: span 1; }

#client_extra{ min-height: 120px; }

.cmc-reminder-row{
  grid-column: span 2;
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap:10px;
  padding:10px 12px;
  border-radius: 14px;
  border: 1px dashed rgba(17,36,41,0.18);
  background: rgba(17,36,41,0.04);
}

.cmc-reminder-row label{ margin:0; font-weight:900; }
.cmc-reminder-row input{ width:18px; height:18px; margin:0; }

#cmc-datetime-wrapper{ grid-column: span 2; }

.cmc-save-btn{
  grid-column: span 2;
  padding: 12px 22px;
  border-radius: 999px;
  border: 1px solid var(--cmc-accent-border);
  background: var(--cmc-accent);
  color: #fff;
  font-weight: 900;
  cursor:pointer;
}
.cmc-save-btn:hover{ opacity:.95; }

/* Select options (dropdown list) */
.cmc-app select option,
.cmc-popup select option,
#cmc-popup-form select option,
.cmc-filter select option{
  color: rgba(17,36,41,0.92) !important;
  background: #ffffff !important;
}

/* Responsive */
@media (max-width: 1100px){
  .cmc-cards{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 700px){
  .cmc-cards{ grid-template-columns: 1fr; }
  .cmc-topbar{ flex-direction:column; align-items:stretch; }
  .cmc-filters{ width:100%; }
  .cmc-filter select{ min-width:0; width:100%; }
  .cmc-search input#cmc-search{ width:100%; }
  #cmc-popup-form{ grid-template-columns: 1fr; }
  #client_display_name,#client_phone,#client_email,#client_company{ grid-column: span 1; }
  .cmc-view-grid{ grid-template-columns: 1fr; }
  .cmc-view-row-wide{ grid-column: span 1; }
  .cmc-modal-head{ flex-direction: column; align-items: stretch; }
  .cmc-modal-head-actions{ justify-content: flex-start; }
}
