#kit-app * { box-sizing: border-box; color:#111; }
    #kit-app h2 { margin: 0 0 10px; font-size: 20px; }
    #kit-app h3 { margin: 0 0 10px; font-size: 16px; }
    #kit-app .grid { display:grid; gap:14px; }
    #kit-app .grid.cols-2 { grid-template-columns: 1fr 1fr; }
    #kit-app .grid.cols-3 { grid-template-columns: 1fr 1fr 1fr; }
    #kit-app .card { border:1px solid #e6e6e6; border-radius:14px; padding:14px; background:#fff; box-shadow:0 1px 2px rgba(0,0,0,0.04); }
    #kit-app .section-title { display:flex; align-items:baseline; justify-content:space-between; gap:10px; }
    #kit-app .muted { opacity:.75; }
    #kit-app .hr { height:1px; background:#eee; margin:12px 0; }
    #kit-app label { display:block; font-size:12px; opacity:.8; margin:10px 0 6px; }
    #kit-app input[type="text"], #kit-app input[type="date"], #kit-app input[type="number"], #kit-app select, #kit-app textarea {
      width:100%; padding:10px 10px; border-radius:10px; border:1px solid #ddd; background:#fff;
    }
    #kit-app textarea{ min-height:72px; }
    #kit-app .row { display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
    #kit-app button { padding:10px 12px; border-radius:10px; border:1px solid #ddd; background:#f7f7f7; cursor:pointer; }
    #kit-app button.primary { background:#eaeaea; border-color:#cfcfcf; font-weight:600; }
    #kit-app button.danger { background:#fff2f2; border-color:#ffd7d7; }
    #kit-app button:disabled { opacity:.5; cursor:not-allowed; }
    #kit-app a.cal-link {
      display:inline-flex; align-items:center; justify-content:center;
      text-decoration:none; padding:10px 12px; border-radius:10px;
      border:1px solid #cfcfcf; background:#eaeaea; font-weight:600;
    }
    #kit-app a.cal-link[aria-disabled="true"] { opacity:.45; pointer-events:none; }
    #kit-app .badge { display:inline-flex; align-items:center; padding:3px 8px; border-radius:999px; font-size:12px; border:1px solid #eee; }
    #kit-app .badge.ok { background:#f3fff6; border-color:#cfead6; color:#0a7a2f; }
    #kit-app .badge.warn { background:#fff8ef; border-color:#ffe2b8; color:#b26a00; }
    #kit-app .ok { color:#0a7a2f; }
    #kit-app .warn { color:#b26a00; }
    #kit-app .bad { color:#b00020; }
    #kit-app .pill { display:inline-flex; align-items:center; gap:8px; padding:6px 10px; border:1px solid #e6e6e6; border-radius:999px; margin:6px 6px 0 0; background:#fff; }
    #kit-app .pill button { padding:6px 10px; border-radius:999px; }
    #kit-app .list { margin:0; padding-left:18px; }

    /* Checkbox picker */
    #kit-app .picker { border:1px solid #eee; border-radius:12px; padding:10px; background:#fff; max-height: 260px; overflow:auto; }
    #kit-app .picker .search { margin-bottom:8px; }
    #kit-app .picker-grid { display:grid; grid-template-columns: 1fr 1fr; gap:8px; }
    #kit-app .check { display:flex; gap:8px; align-items:flex-start; padding:6px 8px; border:1px solid #f2f2f2; border-radius:10px; background:#fff; }
    #kit-app .check input { margin-top:2px; }

    /* Equipment grouped UI (parent + children + qty) */
    #kit-app .group {
      border:1px solid #f2f2f2;
      border-radius:12px;
      padding:8px;
      background:#fff;
    }
    #kit-app .group-title {
      display:flex;
      gap:8px;
      align-items:flex-start;
      padding:6px 8px;
      border:1px solid #f2f2f2;
      border-radius:10px;
      background:#fff;
    }
    #kit-app .group-children {
      margin-top:8px;
      padding-left:14px;
      display:grid;
      grid-template-columns: 1fr;
      gap:8px;
    }
    #kit-app .qty {
      display:flex;
      gap:8px;
      align-items:center;
      margin-left:auto;
    }
    #kit-app input.qty-input{
      width:84px;
      padding:6px 8px;
      border-radius:10px;
      border:1px solid #ddd;
    }

    /* People multi-picker */
    #kit-app .mp { border:1px solid #eee; border-radius:12px; padding:10px; background:#fff; max-height: 220px; overflow:auto; }
    #kit-app .mp .search { margin-bottom:8px; }
    #kit-app .mp-grid { display:grid; grid-template-columns: 1fr 1fr; gap:8px; }

    /* Booking kit quantities */
    #kit-app .kit-req { border:1px solid #eee; border-radius:12px; padding:10px; background:#fff; }
    #kit-app .kit-req .rowline{
      display:flex; gap:10px; align-items:center; justify-content:space-between;
      padding:8px; border:1px solid #f2f2f2; border-radius:10px; margin-bottom:8px;
    }
    #kit-app .kit-req .rowline:last-child{ margin-bottom:0; }
    #kit-app .kit-req .name { font-weight:600; }
    #kit-app .kit-req .qtybox { display:flex; gap:8px; align-items:center; }
    #kit-app .kit-req input { width:90px; padding:6px 8px; }

    /* Modal */
    #kit-app .modal-backdrop{
      position:fixed; inset:0; background:rgba(0,0,0,.45);
      display:none; align-items:center; justify-content:center;
      padding:18px; z-index:9999;
    }
    #kit-app .modal{
      width:min(780px, 100%); background:#fff; border-radius:14px;
      border:1px solid #e6e6e6; box-shadow:0 10px 30px rgba(0,0,0,.18);
      padding:14px;
      max-height: calc(100vh - 36px);
      overflow:auto;
    }
    #kit-app .modal-header{ display:flex; align-items:center; justify-content:space-between; gap:10px; }

    @media (max-width: 980px){
      #kit-app .grid.cols-2, #kit-app .grid.cols-3 { grid-template-columns: 1fr; }
      #kit-app .picker-grid { grid-template-columns: 1fr; }
      #kit-app .mp-grid { grid-template-columns: 1fr; }
    }
