/* ===================================================================
   EDC THEME (scoped) — safe to drop in
   - No global selectors
   - Keeps your fonts and button styles
   - Uses your brand tokens if present (falls back safely)
   =================================================================== */

.edc{
  /* map to your tokens (fallbacks keep the demo look) */
  --edc-bg:        var(--bg, #f7f7fb);
  --edc-panel:     var(--panel, #ffffff);
  --edc-text:      var(--ink, #1f2937);
  --edc-muted:     var(--muted, #6b7280);
  --edc-border:    var(--line, #e5e7eb);
  --edc-chip-bg:   var(--chip, #eef2ff);
  --edc-danger:    var(--danger, #b91c1c);
  --edc-ok:        var(--ok, #065f46);
  --edc-shadow:    0 2px 6px rgba(0,0,0,.06);
}

/* page spacing container (optional helper) */
.edc .edc-main{max-width:1100px;margin:18px auto 48px;padding:0 16px}

/* ---------- Cards ---------- */
.edc .card{
  background:var(--edc-panel);
  border:1px solid var(--edc-border);
  border-radius:14px;
  box-shadow:var(--edc-shadow);
  margin-bottom:16px;
  overflow:hidden;
}
.edc .card>header{
  background:#fff;
  color:var(--edc-text);
  padding:14px 16px;
  border-bottom:1px solid var(--edc-border);
}
.edc .card>header h2{margin:0;font-size:16px;display:flex;align-items:center;gap:8px}
.edc .card>header .tag{
  font-weight:500; font-size:12px;
  color:inherit; background:var(--edc-chip-bg);
  padding:2px 8px; border-radius:999px; border:1px solid #e0e7ff;
}
.edc .section-body{padding:16px}
/* .edc fieldset{border:none;margin:0;padding:0} */

/* ---------- 12-col grid ---------- */
.edc .grid{display:grid;grid-template-columns:repeat(12,1fr);gap:12px}
.edc .col-12{grid-column:span 12}
.edc .col-9{grid-column:span 9}
.edc .col-8{grid-column:span 8}
.edc .col-6{grid-column:span 6}
.edc .col-4{grid-column:span 4}
.edc .col-3{grid-column:span 3}
.edc .col-2{grid-column:span 2}
.edc .col-1{grid-column:span 1}
@media (max-width:900px){
  .edc .col-9,.edc .col-8,.edc .col-6,.edc .col-4,.edc .col-3,.edc .col-2,.edc .col-1{grid-column:span 12}
}

/* ---------- Labels & helpers ---------- */
.edc label{
  font-size:13px;color:var(--edc-muted);margin-bottom:4px;
  text-transform:none; letter-spacing:0; line-height:1.2; word-break:normal; overflow-wrap:anywhere;
}
.edc .req::after{content:" *"; color:var(--edc-danger)}
.edc .help{font-size:12px;color:var(--edc-muted);margin-top:4px}
.edc .note{font-size:12px;color:var(--edc-muted)}
.edc .section-caption{font-size:12px;color:var(--edc-muted);margin-bottom:8px}

/* ---------- Form controls ---------- */
.edc input[type="text"],
.edc input[type="date"],
.edc input[type="number"],
.edc select,
.edc textarea{
  width:100%; padding:10px 12px; font-size:14px; background:#fff;
  border:1px solid var(--edc-border); border-radius:10px; color:var(--edc-text);
}
.edc textarea{min-height:92px;resize:vertical}

/* keep disabled text readable (e.g., Safari) */
.edc input[disabled], .edc select[disabled], .edc textarea[disabled]{
  opacity:1; color:var(--edc-text); -webkit-text-fill-color:var(--edc-text);
}

/* ---------- Inline helpers ---------- */
.edc .inline{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.edc .inline-group{display:flex;gap:16px;align-items:center;flex-wrap:wrap}

/* ---------- Chips/Pills ---------- */
.edc .chip{
  display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;
  background:var(--edc-chip-bg);color:inherit;font-size:12px;border:1px solid #e0e7ff;
}
.edc .pill{font-size:12px;padding:2px 8px;border-radius:999px;border:1px solid var(--edc-border)}

/* ---------- Dividers ---------- */
.edc .hr{height:1px;background:var(--edc-border);margin:8px 0 12px}
.edc .divider{border-top:1px dashed var(--edc-border);margin:10px 0}

/* ---------- Sticky action bar (layout only) ---------- */
.edc .sticky-actions{
  position:sticky;bottom:0;background:#ffffffcc;backdrop-filter:blur(6px);
  padding:12px 16px;border-top:1px solid var(--edc-border);
  display:flex;gap:10px;justify-content:space-between;align-items:center;
}
.edc .btns{display:flex;gap:10px;flex-wrap:wrap;padding:12px 0 4px}
.edc .hidden{display:none}

/* optional status colors for small text bits inside EDC */
.edc .warn{color:var(--edc-danger);font-weight:600}
.edc .ok{color:var(--edc-ok);font-weight:600}

/* ---------- Tables (used inside EDC pages) ---------- */
.edc .table{width:100%;border-collapse:collapse;font-size:13px}
.edc .table th,.edc .table td{border:1px solid var(--edc-border);padding:8px;vertical-align:top}
.edc .table th{text-align:left;background:#fafafa}

/* ---------- Print tweaks ---------- */
@media print{
  .edc .sticky-actions,.edc .btns{display:none}
}


/* Make the EDC grid authoritative */
.edc fieldset.grid { grid-template-columns: repeat(12, minmax(0,1fr)); gap:12px; }

.edc fieldset.grid > [class^="col-"],
.edc fieldset.grid > [class*=" col-"] {
  width: auto !important;
  max-width: none !important;
  flex: initial !important;  
  justify-self: stretch;    
  min-width: 0;             
}

.edc fieldset.grid input[type="text"],
.edc fieldset.grid input[type="number"],
.edc fieldset.grid input[type="date"],
.edc fieldset.grid select,
.edc fieldset.grid textarea {
  width: 100% !important;
  min-width: 0 !important;
}

.edc .g-12{grid-column:span 12}.edc .g-9{grid-column:span 9}
.edc .g-8{grid-column:span 8}.edc .g-6{grid-column:span 6}
.edc .g-4{grid-column:span 4}.edc .g-3{grid-column:span 3}
.edc .g-2{grid-column:span 2}.edc .g-1{grid-column:span 1}


.small{
  padding: .35rem .60rem;   /* tighter paddings */
  font-size: 12px !important;          /* smaller text */
  line-height: 1.2;
  border-radius: 8px;       /* slightly tighter radius */
  min-height: 30px;         /* decent tap target */
}

/* Optional: tidy icons inside small buttons */
.small > svg,
.small > i{
  width: 1em;
  height: 1em;
  vertical-align: -0.125em;
}

.tag { font-weight: 500; color:#4338ca; background: #eef2ff; padding:2px 8px; border-radius:999px; font-size:12px; }

.badge { padding: 2px 8px; border-radius: 999px; border:1px solid var(--border); font-size: 12px; }
    .badge.good { background:#ecfdf5; color:#065f46; border-color:#a7f3d0; }
    .badge.warn { background:#fef3c7; color:#92400e; border-color:#fde68a; }
    .badge.bad  { background:#fee2e2; color:#991b1b; border-color:#fecaca; }

.btn.small { padding: 6px 10px; font-size: 13px; border-radius: 10px; border: #E4E7EB 1px solid}

input[type="text"], select, input[type="number"] {
      width: auto; min-width: 180px; padding: 9px 10px; font-size: 14px;
      border: 1px solid var(--border); border-radius: 10px; background: #fff;
    }

    @media print { .sticky-actions, .btn, input, .drawer, select { display:none !important; } header.top { position: static; box-shadow:none; } }


    footer.site-footer{margin:32px 0 18px;color:#7E8389;font-size:14px;text-align:center}