.cabH-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(77,44,29,.42);backdrop-filter:blur(6px);z-index:9999}
.cabH-modal.show{display:flex}
.cabH-box{width:min(920px,94vw);max-height:90vh;overflow:auto;background:var(--color-background);border:1px solid rgba(0,0,0,.06);border-radius:20px;box-shadow:0 20px 60px rgba(0,0,0,.25);padding:18px;color:var(--color-text);font-family:'Orelega One',sans-serif}
.cabH-hdr{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.cabH-title{margin:0;font-size:1.15rem;color:var(--color-primary);letter-spacing:.3px}
.cabH-x{border:none;background:rgba(77,44,29,.08);border-radius:12px;cursor:pointer;padding:8px 10px;color:var(--color-secondary)}
.cabH-x:hover{background:rgba(77,44,29,.15)}
.cabH-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:12px}
.cabH-card{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:16px;padding:14px;box-shadow:0 4px 16px rgba(0,0,0,.06)}
.cabH-pill{padding:6px 10px;border-radius:999px;background:#fff;border:1px solid #e5e7eb;color:#6b7280;font-size:12px}
.cabH-inline{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.cabH-input{padding:10px 12px;border:1px solid #e5e7eb;border-radius:10px;width:100%;font-family:inherit}
.cabH-input:focus{outline:none;border-color:var(--color-secondary);box-shadow:0 0 0 3px rgba(107,62,39,.18)}
.cabH-btn{padding:10px 14px;border:none;border-radius:999px;background:var(--color-primary);color:#fff;cursor:pointer;font-weight:700;transition:transform .15s ease,background .2s ease,box-shadow .2s;box-shadow:0 8px 16px rgba(77,44,29,.25)}
.cabH-btn:hover{background:var(--color-secondary);transform:translateY(-1px);box-shadow:0 12px 22px rgba(77,44,29,.28)}
.cabH-btn.ghost{background:#fff;color:var(--color-primary);border:1px solid #e5e7eb;box-shadow:none}
.cabH-btn.ghost:hover{background:rgba(77,44,29,.06)}
.cabH-punch{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-top:10px}
.cabH-slot{height:48px;border:1px dashed #d1d5db;border-radius:12px;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#ffffff,#faf7f4);color:#4b5563;position:relative;font-weight:700}
.cabH-slot.used{background:linear-gradient(180deg, rgba(172,80,38,.12), rgba(172,80,38,.04));border-color:#d6b59c;color:#6b3e27;box-shadow:inset 0 0 0 1px rgba(172,80,38,.12)}
.cabH-slot.used::after{content:"✔";position:absolute;right:8px;top:6px;font-size:12px;color:var(--color-green)}
#cabH-punch.readonly .cabH-slot{pointer-events:none}
.cabH-help{color:#6b7280;font-size:12px}
.cabH-circle{--pct:0;--color:var(--color-green);width:180px;height:180px;aspect-ratio:1/1;border-radius:50%;position:relative;margin:auto;background:conic-gradient(var(--color) calc(var(--pct) * 1%), #e5e7eb 0);box-shadow:0 8px 22px rgba(0,0,0,.08), inset 0 0 0 10px #fff;will-change:background;transform:translateZ(0);contain:paint}
.cabH-circle::before{content:"";position:absolute;inset:16px;background:#fff;border-radius:50%;box-shadow:inset 0 0 0 1px rgba(0,0,0,.06)}
.cabH-circle .label{position:absolute;inset:0;display:grid;place-items:center;font-weight:800;color:var(--color-primary)}
.cabH-circle .sub{position:absolute;inset:0;display:grid;place-items:end center;padding-bottom:16px;color:#6b7280;font-size:12px}
#cabH-admin .cabH-card{background:#fff}
#cabH-usersList .cabH-inline{border-bottom:1px solid #eee;padding:6px 0}
#cabH-badgeState{background:#fff;border:1px solid #e5e7eb}
.cabH-hidden{display:none}
.cabH-justify-between{justify-content:space-between}
.cabH-end{justify-content:flex-end}
.cabH-grow{flex:1}
.cabH-form-row{align-items:flex-end;margin-top:8px}
.cabH-label-muted{font-size:12px;color:#6b7280}
.cabH-text-strong{font-weight:700}
.cabH-span-4{grid-column:span 4}
.cabH-span-6{grid-column:span 6}
.cabH-span-8{grid-column:span 8}
.cabH-mb-8{margin-bottom:8px}
.cabH-my-6{margin:6px 0}
.cabH-my-10{margin:10px 0}
.cabH-mt-6{margin-top:6px}
.cabH-mt-8{margin-top:8px}
.cabH-mt-10{margin-top:10px}
.cabH-gap-8{gap:8px}
.cabH-max-140{max-width:140px}
.cabH-max-220{max-width:220px}
.cabH-max-240{max-width:240px}
.cabH-users-scroll{max-height:240px;overflow:auto}
@media (max-width:900px){.cabH-box{width:min(96vw,820px);max-height:calc(100svh - 24px);padding:14px;border-radius:16px}.cabH-grid{grid-template-columns:1fr;gap:10px}}
@media (max-width:640px){.cabH-modal{padding:8px}.cabH-box{width:100%;max-width:100%;height:auto;max-height:calc(100svh - 8px);margin:0;border-radius:14px;padding:12px}.cabH-hdr{gap:8px}.cabH-title{font-size:1rem}.cabH-x{padding:6px 8px;border-radius:10px}.cabH-card{padding:12px;border-radius:14px}.cabH-input{padding:12px;font-size:16px;border-radius:10px}.cabH-btn{padding:12px 16px;border-radius:999px;font-size:16px}.cabH-punch{grid-template-columns:repeat(3,1fr);gap:8px}.cabH-slot{height:52px;border-radius:12px;font-size:16px}.cabH-circle{width:150px;height:150px}.cabH-circle::before{inset:12px}.cabH-circle .sub{padding-bottom:12px}#cabH-usersList{max-height:200px;overflow:auto}#cabH-badgeState,#cabH-adminBadge{font-size:12px}}
@media (max-width:380px){.cabH-punch{grid-template-columns:repeat(2,1fr)}}
@supports(height:100dvh){.cabH-box{max-height:calc(100dvh - 24px)}}
@supports(padding:max(0px)){.cabH-box{padding-bottom:max(12px, env(safe-area-inset-bottom));padding-left:max(12px, env(safe-area-inset-left));padding-right:max(12px, env(safe-area-inset-right))}}
.cabH-input:focus,.cabH-btn:focus,.cabH-x:focus{outline:3px solid rgba(107,62,39,.35);outline-offset:2px}
@media (max-width:640px){.cabH-x{width:40px;height:40px;font-size:18px}}

/* Ajustes de usabilidad y lectura en movil sin cambiar diseño */
@media (max-width:640px){
  .cabH-hdr{
    position:sticky;
    top:0;
    z-index:3;
    background:#fff;
    padding-bottom:8px;
    border-bottom:1px solid rgba(0,0,0,.06);
  }
  .cabH-title{
    max-width:70%;
    line-height:1.2;
  }
  .cabH-inline{
    gap:10px;
  }
  .cabH-form-row{
    align-items:stretch;
  }
  .cabH-form-row .cabH-grow{
    flex:1 1 100%;
    min-width:100%;
  }
  .cabH-form-row .cabH-btn{
    width:100%;
  }
  .cabH-max-140,.cabH-max-220,.cabH-max-240{
    max-width:none;
    width:100%;
  }
  #cabH-adminBody .cabH-inline{
    width:100%;
  }
  #cabH-adminBody .cabH-inline .cabH-btn{
    flex:1 1 calc(50% - 8px);
    min-width:140px;
  }
  #cabH-admPunch{
    margin-top:12px;
  }
  #cabH-usersList .cabH-inline{
    align-items:flex-start;
    flex-direction:column;
    gap:8px;
  }
  #cabH-usersList .cabH-inline > div:last-child{
    width:100%;
    display:flex;
    gap:8px;
  }
  #cabH-usersList .cabH-inline > div:last-child .cabH-btn{
    flex:1;
  }
}
