/* ── Engenharia Clínica — Admin CSS ── */
:root {
  --ec-navy:      #0a1628;
  --ec-navy-mid:  #0f2044;
  --ec-navy-light:#1a3a6b;
  --ec-gold:      #c8a96e;
  --ec-gold-light:#e8c98a;
  --ec-white:     #f8f6f0;
  --ec-gray:      #e8e4dc;
  --ec-gray-mid:  #9a9488;
  --ec-teal:      #0f6e56;
  --ec-teal-light:#1d9e75;
  --ec-coral:     #993c1d;
  --ec-red:       #c84b3c;
}

/* LOADING */
.engclinica-loading { text-align:center; padding:80px 20px; color:#666; }
.engclinica-spinner {
  width:36px; height:36px; border:3px solid #e8e4dc;
  border-top-color:var(--ec-navy); border-radius:50%;
  animation:ec-spin .8s linear infinite; margin:0 auto 16px;
}
@keyframes ec-spin { to { transform:rotate(360deg); } }

/* HERO */
.ec-hero {
  background:var(--ec-navy);
  padding:26px 28px 22px;
  border-radius:8px;
  position:relative;
  overflow:hidden;
  margin-bottom:20px;
}
.ec-hero::before {
  content:'';
  position:absolute; right:-70px; top:-70px;
  width:240px; height:240px; border-radius:50%;
  border:1px solid rgba(200,169,110,.1);
  pointer-events:none;
}
.ec-hero-eyebrow {
  font-size:9px; letter-spacing:.3em; color:var(--ec-gold);
  text-transform:uppercase; margin-bottom:8px;
}
.ec-hero-title {
  font-size:22px; font-weight:700;
  color:var(--ec-white); line-height:1.2; margin-bottom:4px;
}
.ec-hero-title span { color:var(--ec-gold-light); }
.ec-hero-sub { font-size:12px; color:var(--ec-gray-mid); margin-bottom:16px; }
.ec-hero-meta { display:flex; gap:24px; flex-wrap:wrap; }
.ec-hero-meta-item label {
  font-size:9px; color:var(--ec-gray-mid);
  letter-spacing:.1em; text-transform:uppercase;
  display:block; margin-bottom:2px;
}
.ec-hero-meta-item span {
  font-size:13px; color:var(--ec-gold-light); font-weight:500;
}

/* DOC TYPE GRID */
.ec-section-label {
  font-size:11px; font-weight:600; color:var(--ec-gray-mid);
  letter-spacing:.1em; text-transform:uppercase; margin-bottom:14px;
}
.ec-doc-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(230px,1fr));
  gap:12px; margin-bottom:20px;
}
.ec-doc-card {
  background:#fff;
  border:1px solid var(--ec-gray);
  border-radius:10px;
  padding:18px 20px 16px;
  cursor:pointer;
  position:relative;
  overflow:hidden;
  transition:border-color .15s, box-shadow .15s;
  text-align:left; font-family:inherit;
}
.ec-doc-card:hover {
  box-shadow:0 4px 20px rgba(0,0,0,.08);
}
.ec-doc-accent {
  position:absolute; top:0; left:0; width:3px; height:100%;
  border-radius:10px 0 0 10px;
}
.ec-doc-top { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.ec-doc-icon {
  width:42px; height:42px; border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  font-size:20px;
}
.ec-doc-count {
  font-size:11px; font-weight:700;
  padding:3px 10px; border-radius:20px; color:#fff;
}
.ec-doc-name { font-weight:600; font-size:14px; color:var(--ec-navy); margin-bottom:3px; }
.ec-doc-desc { font-size:11px; color:var(--ec-gray-mid); line-height:1.4; }
.ec-doc-footer { display:flex; gap:8px; align-items:center; margin-top:12px; }
.ec-doc-badge {
  font-size:10px; font-weight:500;
  padding:2px 8px; border-radius:4px;
}
.ec-doc-arrow { font-size:11px; color:var(--ec-gray-mid); margin-left:auto; }

/* TOOLBAR */
.ec-toolbar {
  display:flex; align-items:center; gap:10px;
  margin-bottom:16px; flex-wrap:wrap;
}
.ec-back-btn {
  background:transparent; border:1px solid var(--ec-gray);
  border-radius:6px; padding:6px 14px;
  cursor:pointer; font-size:13px; color:var(--ec-gray-mid);
  font-family:inherit; line-height:1.4;
}
.ec-back-btn:hover { background:var(--ec-gray); color:var(--ec-navy); }
.ec-doc-label-icon {
  width:32px; height:32px; border-radius:8px;
  display:flex; align-items:center; justify-content:center; font-size:18px;
}
.ec-doc-label-title { font-weight:600; font-size:15px; color:var(--ec-navy); }
.ec-tab-group { display:flex; gap:6px; margin-left:auto; }
.ec-tab-btn {
  padding:6px 16px; border-radius:6px;
  font-size:13px; font-weight:500; border:1px solid;
  cursor:pointer; font-family:inherit; transition:all .15s;
}
.ec-tab-btn.active  { background:var(--ec-navy); color:var(--ec-gold-light); border-color:var(--ec-navy); }
.ec-tab-btn.inactive{ background:transparent; color:var(--ec-gray-mid); border-color:var(--ec-gray); }
.ec-tab-btn.inactive:hover { background:var(--ec-gray); }
.ec-tab-count {
  background:var(--ec-gold); color:var(--ec-navy);
  border-radius:10px; padding:1px 7px; font-size:11px; margin-left:4px;
}

/* FORM SECTION */
.ec-form-section {
  margin-bottom:14px; border-radius:10px;
  overflow:hidden; border:1px solid var(--ec-gray);
  box-shadow:0 1px 4px rgba(0,0,0,.04);
}
.ec-section-head {
  background:var(--ec-navy); padding:10px 18px;
}
.ec-section-head-title {
  font-weight:700; font-size:12px; color:var(--ec-gold-light);
  letter-spacing:.06em; text-transform:uppercase;
}
.ec-section-body {
  background:#fff; padding:12px 18px 4px;
  display:grid; grid-template-columns:1fr 1fr;
  gap:4px 24px;
}
.ec-field-wrap { padding-bottom:14px; }
.ec-field-wrap.full { grid-column:1/-1; }
.ec-field-label {
  font-size:11px; font-weight:600; color:var(--ec-gray-mid);
  text-transform:uppercase; letter-spacing:.06em;
  display:block; margin-bottom:5px;
}
.ec-field-req { color:var(--ec-red); margin-left:2px; }
.ec-field-input, .ec-field-select, .ec-field-textarea {
  width:100%; padding:8px 11px; border-radius:6px;
  border:1px solid var(--ec-gray); background:#faf9f6;
  font-size:13px; color:#1a1a2e; font-family:inherit;
  outline:none; transition:border .15s;
}
.ec-field-select {
  padding-right:32px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239a9488' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 10px center;
  appearance:none; cursor:pointer;
}
.ec-field-textarea { resize:vertical; line-height:1.6; }
.ec-field-input:focus, .ec-field-select:focus, .ec-field-textarea:focus {
  border-color:var(--ec-navy-light);
  box-shadow:0 0 0 2px rgba(26,58,107,.08);
}

/* ACTIONS */
.ec-form-actions {
  display:flex; gap:10px; margin-top:6px;
  padding-top:16px; border-top:1px solid var(--ec-gray);
}
.ec-btn-save {
  flex:1; background:var(--ec-navy); color:var(--ec-gold-light);
  border:none; border-radius:8px;
  padding:12px 24px; font-size:14px; font-weight:600;
  cursor:pointer; font-family:inherit; transition:background .15s;
}
.ec-btn-save:hover { background:var(--ec-navy-mid); }
.ec-btn-save:disabled { opacity:.6; cursor:not-allowed; }
.ec-btn-pdf {
  background:transparent; color:var(--ec-navy);
  border:1px solid var(--ec-navy); border-radius:8px;
  padding:12px 20px; font-size:14px; font-weight:600;
  cursor:pointer; font-family:inherit; white-space:nowrap;
  transition:background .15s;
}
.ec-btn-pdf:hover { background:#f0f2f8; }

/* EDIT BANNER */
.ec-edit-banner {
  background:#fff8e8; border:1px solid #e8c98a;
  border-radius:8px; padding:10px 16px;
  margin-bottom:14px; font-size:13px; color:#854f0b;
  display:flex; align-items:center; gap:8px;
}
.ec-edit-banner-btn {
  margin-left:auto; background:transparent;
  border:1px solid #e8c98a; border-radius:5px;
  padding:3px 10px; cursor:pointer; font-size:12px;
  color:#854f0b; font-family:inherit;
}

/* RECORD LIST */
.ec-record-list { display:flex; flex-direction:column; gap:10px; }
.ec-record-item {
  background:#fff; border:1px solid var(--ec-gray);
  border-radius:10px; padding:14px 18px;
  display:flex; align-items:center; gap:14px;
  box-shadow:0 1px 4px rgba(0,0,0,.04);
  transition:box-shadow .15s;
}
.ec-record-item:hover { box-shadow:0 2px 10px rgba(0,0,0,.08); }
.ec-record-icon {
  width:40px; height:40px; border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  font-size:20px; flex-shrink:0;
}
.ec-record-info { flex:1; min-width:0; }
.ec-record-title {
  font-weight:600; font-size:14px; color:var(--ec-navy);
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.ec-record-meta { font-size:12px; color:var(--ec-gray-mid); margin-top:2px; }
.ec-record-status {
  font-size:11px; font-weight:600;
  padding:3px 10px; border-radius:20px; white-space:nowrap; flex-shrink:0;
}
.ec-record-actions { display:flex; gap:6px; flex-shrink:0; }
.ec-btn-edit {
  background:transparent; border:1px solid var(--ec-gray);
  border-radius:6px; padding:5px 12px; cursor:pointer;
  font-size:12px; color:var(--ec-navy); font-family:inherit;
}
.ec-btn-edit:hover { background:var(--ec-gray); }
.ec-btn-print-rec {
  background:var(--ec-navy); border:none; border-radius:6px;
  padding:5px 12px; cursor:pointer; font-size:12px;
  color:var(--ec-gold-light); font-family:inherit;
}
.ec-btn-del {
  background:transparent; border:1px solid #fca5a5;
  border-radius:6px; padding:5px 10px; cursor:pointer;
  font-size:12px; color:#dc2626; font-family:inherit;
}
.ec-btn-del:hover { background:#fef2f2; }
.ec-btn-new-dashed {
  background:transparent; border:1px dashed var(--ec-gray);
  border-radius:10px; padding:14px; cursor:pointer;
  font-size:13px; color:var(--ec-gray-mid);
  font-family:inherit; width:100%; margin-top:2px;
  transition:background .15s;
}
.ec-btn-new-dashed:hover { background:#faf9f6; }

/* EMPTY STATE */
.ec-empty { text-align:center; padding:48px 24px; color:var(--ec-gray-mid); }
.ec-empty-icon { font-size:40px; margin-bottom:12px; }
.ec-empty-title { font-size:15px; font-weight:600; color:var(--ec-navy); margin-bottom:6px; }
.ec-empty-desc { font-size:13px; margin-bottom:20px; }

/* INFO BOX */
.ec-info-box {
  background:#f0f9f5; border:1px solid #9fe1cb;
  border-radius:10px; padding:12px 16px;
  display:flex; gap:10px; align-items:flex-start;
  font-size:12px; color:var(--ec-teal); line-height:1.6;
  margin-top:16px;
}

/* TOAST */
#ec-toast {
  position:fixed; bottom:32px; left:50%; transform:translateX(-50%);
  background:var(--ec-teal); color:#fff;
  padding:11px 28px; border-radius:8px;
  font-size:13px; font-weight:500; z-index:99999;
  box-shadow:0 4px 20px rgba(0,0,0,.2);
  opacity:0; transition:opacity .3s; pointer-events:none;
}
#ec-toast.show { opacity:1; }

/* CONFIG PAGE */
.engclinica-config-wrap h1 { margin-bottom:20px; }
.engclinica-config-wrap .form-table th { width:200px; }
