:root{ --qc-radius: 12px; --qc-border:#ddd; --qc-bg:#fff; --qc-text:#111; --qc-muted:#666; }
body.qc-lock{ overflow:hidden; touch-action:none; }

.qc-wrap{ width:100%; max-width:100%; margin:0; padding:8px; box-sizing:border-box; }
.qc-top{ display:flex; gap:8px; margin-bottom:8px; }
.qc-top input[type="search"]{ flex:1; padding:12px 14px; border:1px solid var(--qc-border); border-radius:10px; width:100%; box-sizing:border-box; }

.qc-table-wrap{ width:100%; overflow-x:auto; background:var(--qc-bg); border:1px solid #eee; border-radius:var(--qc-radius); }
.qc-table{ width:100%; border-collapse:collapse; table-layout:auto; }
.qc-table th, .qc-table td{ padding:12px 12px; border-bottom:1px solid #f0f0f0; text-align:left; vertical-align:middle; }
.qc-table thead th{ font-weight:600; background:#fafafa; }
.qc-empty{ text-align:center; color:var(--qc-muted); padding:16px; }

.qc-actions-head{ width:56px; min-width:56px; }
.qc-actions{ text-align:right; white-space:nowrap; min-width:56px; }

/* Hamburger Button */
.qc-row-ham{ width:44px; height:44px; border-radius:10px; border:1px solid var(--qc-border); background:#fff; display:inline-flex; align-items:center; justify-content:center; cursor:pointer; }
.qc-ham{ position:relative; width:20px; height:2px; background:#222; border-radius:2px; display:block; }
.qc-ham::before, .qc-ham::after{ content:""; position:absolute; left:0; width:20px; height:2px; background:#222; border-radius:2px; }
.qc-ham::before{ top:-6px; }
.qc-ham::after{ top:6px; }

/* Popover menu (force vertical & responsive) */
.qc-popover[hidden]{ display:none !important; }
.qc-popover{ position:fixed; z-index:1002; min-width:220px; max-width:90vw; background:#fff; border:1px solid #e8e8e8; border-radius:12px; box-shadow:0 10px 30px rgba(0,0,0,.12); padding:6px;
  display:flex; flex-direction:column; align-items:stretch; gap:6px; }
.qc-popover .qc-pop-item{ display:block !important; width:100% !important; text-align:left; padding:10px 12px; border:0; background:#fff; border-radius:8px; cursor:pointer; font:inherit; }
.qc-popover .qc-pop-item:hover{ background:#f7f7f7; }
.qc-popover .qc-pop-item.danger{ color:#d33; }

/* Modal */
.qc-modal[hidden]{ display:none !important; }
.qc-modal{ position:fixed; inset:0; background:rgba(0,0,0,.45); display:grid; place-items:center; z-index:1001; padding:16px; box-sizing:border-box; }
.qc-modal-inner{ background:#fff; width:100%; max-width:780px; border-radius:var(--qc-radius); padding:0; box-sizing:border-box; max-height:92vh; display:flex; flex-direction:column; overflow:hidden; }
#qc-form, #qc-proj-form{ display:flex; flex-direction:column; height:100%; min-height:0; }
.qc-form-scroll{ flex:1 1 auto; min-height:0; overflow:auto; -webkit-overflow-scrolling:touch; overscroll-behavior:contain; padding:16px; }
.qc-form-actions{ position:sticky; bottom:0; background:#fff; border-top:1px solid #eee; padding:12px 16px; display:flex; gap:8px; justify-content:flex-end; }

.qc-btn-primary{ background:#111; color:#fff; border:0; padding:10px 14px; border-radius:10px; cursor:pointer; }
.qc-btn-ghost{ background:#fff; color:#111; border:1px solid var(--qc-border); padding:10px 14px; border-radius:10px; cursor:pointer; }
.qc-chip{ padding:6px 10px; border:1px solid #ddd; background:#fff; border-radius:999px; cursor:pointer; font-size:.9rem; }

/* Badges */
.qc-badge{ display:inline-block; padding:4px 8px; border-radius:999px; font-size:.85rem; border:1px solid #ddd; }
.qc-badge.qc-pending{ background:#fffbe6; border-color:#ffe58f; }
.qc-badge.qc-active{ background:#e6fffb; border-color:#87e8de; }
.qc-badge.qc-completed{ background:#f6ffed; border-color:#b7eb8f; }

/* Fields */
.qc-field{ display:flex; flex-direction:column; gap:6px; margin-bottom:10px; }
.qc-field input, .qc-field select, .qc-field textarea{ padding:12px 14px; border:1px solid var(--qc-border); border-radius:10px; width:100%; box-sizing:border-box; }
.qc-inline{ display:flex; flex-wrap:wrap; gap:12px; }
.qc-grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:8px; }

/* Services builder */
#qc-services{ display:flex; flex-direction:column; gap:12px; margin-bottom:12px; }
.qc-service-row{ display:grid; grid-template-columns:1fr 1fr minmax(140px, 220px); gap:12px; border:1px solid #eee; border-radius:12px; padding:12px; }
.qc-service-col{ display:flex; flex-direction:column; gap:8px; }
.qc-subgroup{ border-left:3px solid #eee; padding-left:10px; margin:6px 0; }
.qc-group-title{ font-weight:600; }
.qc-subtext{ color:#666; font-size:.9rem; }
.qc-remove-service{ margin-top:auto; border:1px solid #ddd; background:#fff; border-radius:8px; padding:8px 10px; cursor:pointer; }
.qc-subtitle{ font-weight:700; margin:6px 0; }

/* Totals */
.qc-totals{ display:flex; flex-direction:column; gap:4px; font-size:1rem; margin-top:8px; }
.qc-total-line{ font-weight:800; font-size:1.2rem; }

/* Floating + */
.qc-plus{ position:fixed; right:16px; bottom:16px; width:52px; height:52px; border-radius:50%; background:#111; color:#fff; border:0; font-size:28px; line-height:1; display:flex; align-items:center; justify-content:center; z-index:1000; cursor:pointer; }

@media (max-width: 900px){
  .qc-service-row{ grid-template-columns:1fr; }
  .qc-grid-2{ grid-template-columns:1fr; }
  .qc-modal-inner{ max-width:100%; border-radius:0; }
}
