@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@500;600;700;800&family=Sora:wght@600;700;800&display=swap');

:root{
  --bg-0:#04070f;
  --bg-1:#080d17;
  --bg-2:#0b111d;
  --surface:#0c121d;
  --surface-2:#111826;
  --surface-3:#151f30;
  --border:rgba(255,255,255,.13);
  --line:rgba(255,255,255,.11);
  --text:#f6f8fc;
  --text-dim:#b7c1cf;
  --accent:#ff8a1f;
  --accent-2:#22d3ee;
  --accent-soft:rgba(255,138,31,.22);
  --cyan-soft:rgba(34,211,238,.20);
  --violet:#a78bfa;
  --green:#34d399;
  --red:#fb7185;
  --hover:rgba(255,255,255,.08);
  --active:rgba(255,138,31,.14);
  --focus:#22d3ee;
  --radius:18px;
  --shadow:0 24px 54px rgba(0,0,0,.58);
}

*{ box-sizing:border-box; }
[hidden]{ display:none !important; }
html, body{ height:100%; margin:0; }

body.sq-body{
  font-family:"Manrope", system-ui, sans-serif;
  color:var(--text);
  background-color:var(--bg-0);
  background-image:
    linear-gradient(135deg, rgba(4,7,15,.92), rgba(11,17,29,.70)),
    repeating-linear-gradient(145deg, rgba(255,255,255,.035) 0, rgba(255,255,255,.035) 1px, transparent 1px, transparent 7px),
    url("fondo.png");
  background-attachment:fixed;
  background-repeat:no-repeat;
  background-size:cover;
}

h1,h2,h3,h4,h5,h6{
  font-family:"Sora", "Manrope", system-ui, sans-serif;
  letter-spacing:0;
  color:#fff;
}

a{ color:var(--accent); text-decoration:none; }
a:hover{ color:var(--accent-2); }

/* Sidebar */
.sidebar{
  position:fixed;
  inset:0 auto 0 0;
  width:260px;
  background:rgba(10,11,16,.96);
  border-right:1px solid var(--border);
  padding:18px 16px 80px;
  z-index:1200;
  overflow-y:auto;
  backdrop-filter:blur(8px);
  box-shadow:8px 0 30px rgba(0,0,0,.6);
}

.brand{
  display:flex;
  align-items:center;
  gap:.6rem;
  padding:10px 12px;
  margin-bottom:16px;
  border-radius:var(--radius);
  background:
    radial-gradient(circle at 0 0, rgba(90,168,255,.35), transparent 60%),
    linear-gradient(135deg, rgba(15,23,42,.95), rgba(15,23,42,.88));
  border:1px solid rgba(148,163,184,.5);
  box-shadow:0 10px 26px rgba(0,0,0,.7);
  color:var(--text);
}
.brand-logo{
  width:34px;
  height:34px;
  border-radius:10px;
  background:#020617;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
  box-shadow:0 4px 12px rgba(0,0,0,.8);
}
.brand-logo img{ max-width:100%; max-height:100%; object-fit:contain; }
.brand-title{ display:flex; flex-direction:column; line-height:1.1; }
.brand-title strong{ font-size:.96rem; color:#f9fafb; letter-spacing:.04em; }
.brand-title span{ font-size:.72rem; color:#cbd5f5; text-transform:uppercase; letter-spacing:.16em; }

.nav-section{ margin-top:8px; font-size:.86rem; }
.nav-label{
  margin:10px 2px 6px;
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.16em;
  color:rgba(148,163,184,.9);
}
.nav-link{
  display:block;
  color:var(--text);
  text-decoration:none;
  padding:9px 11px;
  border-radius:12px;
  margin-bottom:6px;
  transition: background .16s ease, transform .06s ease, border-color .16s ease;
  border:1px solid transparent;
  font-size:.88rem;
}
.nav-link:hover{
  background:var(--hover);
  transform:translateY(-1px);
  border-color:rgba(148,163,184,.3);
}
.nav-link.active{
  background:var(--active);
  border-color:rgba(148,163,184,.6);
  box-shadow:0 6px 16px rgba(0,0,0,.6);
}
.nav-link:focus-visible{ outline:2px solid var(--focus); outline-offset:2px; }

.sidebar-user{
  margin-top:12px;
  padding:8px 10px;
  border-radius:12px;
  background:rgba(15,23,42,.9);
  font-size:.8rem;
  color:var(--text-dim);
  border:1px solid rgba(148,163,184,.35);
}
.sidebar-user strong{ color:var(--text); }

.logout{ margin-top:18px; }

/* Topbar mobile */
.topbar{
  position:sticky;
  top:0;
  z-index:1150;
  display:none;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px 14px;
  padding-top: calc(10px + env(safe-area-inset-top));
  background: rgba(0,0,0,.78);
  border-bottom:1px solid var(--border);
  backdrop-filter:blur(8px);
}
.topbar__toggle{
  border:1px solid var(--border);
  background:rgba(15,23,42,.9);
  color:#fff;
  border-radius:10px;
  padding:6px 11px;
  font-weight:600;
  font-size:.86rem;
}
.topbar__title{ display:flex; flex-direction:column; font-size:.8rem; color:#e5e7eb; line-height:1.1; }
.topbar__title strong{ font-size:.86rem; letter-spacing:.06em; text-transform:uppercase; }
.topbar__title span{ font-size:.72rem; color:#9ca3af; }

/* Content */
.contenido{
  margin-left:260px;
  min-height:100vh;
  padding:26px 32px 38px;
}
.contenido--full{ margin-left:0; max-width:1100px; margin:0 auto; padding:36px 20px 40px; }

.panel{
  background:
    radial-gradient(circle at 0 0, rgba(148,163,184,.18), transparent 55%),
    linear-gradient(135deg, rgba(15,23,42,.96), rgba(15,23,42,.92));
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:22px;
  box-shadow:var(--shadow);
}

/* Flashes */
.sq-flashes{ margin-bottom:12px; }
.sq-alert{
  position:relative;
  padding:10px 14px;
  border-radius:12px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.06);
}
.sq-alert + .sq-alert{ margin-top:8px; }
.sq-alert__close{ position:absolute; right:8px; top:8px; border:0; background:transparent; color:var(--text-dim); cursor:pointer; }
.sq-alert--ok{ border-color:rgba(34,197,94,.5); }
.sq-alert--warn{ border-color:rgba(251,191,36,.5); }
.sq-alert--err{ border-color:rgba(248,113,113,.5); }

/* Forms */
input, select, textarea{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.16);
  color:var(--text);
  border-radius:10px;
  padding:8px 10px;
  outline:none;
}
input:focus, select:focus, textarea:focus{
  border-color:var(--focus);
  box-shadow:0 0 0 .15rem rgba(154,209,255,.18);
  background:rgba(255,255,255,.08);
}
label{ display:block; margin:.5rem 0 .25rem; color:var(--text-dim); }

/* Buttons */
.btn, .sq-btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.24);
  cursor:pointer;
  font-weight:600;
  letter-spacing:.2px;
  text-decoration:none;
  color:#fff;
  background:rgba(255,255,255,.08);
}
.btn:hover, .sq-btn:hover{ background:rgba(255,255,255,.12); }
.btn-outline{ background:rgba(255,255,255,.06); }
.btn-primary{ background:rgba(90,168,255,.18); border-color:rgba(90,168,255,.4); }
.btn-disabled,
.btn:disabled,
.sq-btn:disabled{
  opacity:.62;
  cursor:not-allowed;
  background:rgba(255,255,255,.045);
}
.btn-outline-secondary, .btn-outline-primary{ background:rgba(255,255,255,.06); }
.btn-sm{ padding:4px 8px; font-size:.85rem; }
.btn-mini{
  display:inline-flex; align-items:center; gap:6px;
  padding:4px 8px; border-radius:10px; border:1px solid rgba(255,255,255,.24);
  cursor:pointer; font-weight:600; font-size:.85rem; color:#fff; background:rgba(255,255,255,.08);
}
.btn-sec{ background:rgba(255,255,255,.06); }
.btn-group{ display:inline-flex; gap:6px; }

/* Tables */
.tabla, .table{
  width:100%;
  border-collapse:collapse;
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);
  border-radius:12px;
  overflow:hidden;
}
.tabla th, .tabla td, .table th, .table td{
  padding:10px 12px;
  border-bottom:1px solid var(--border);
  color:var(--text);
}
.tabla thead th, .table thead th{ color:#e9eef5; font-weight:600; }
.tabla tbody tr:hover, .table tbody tr:hover{ background:rgba(255,255,255,.06); }
.table-responsive{ overflow-x:auto; }
.table-sm th, .table-sm td{ padding:6px 8px; font-size:.9rem; }
.table-bordered{ border:1px solid var(--border); }
.table-light{ color:var(--text-dim); }

/* Layout helpers */
.muted{ color:var(--text-dim); }
.text-muted{ color:var(--text-dim); }
.text-danger{ color:#ff8b8b; }
.text-end{ text-align:right; }
.small{ font-size:.85rem; }
.d-flex{ display:flex; }
.align-items-center{ align-items:center; }
.justify-content-between{ justify-content:space-between; }
.flex-wrap{ flex-wrap:wrap; }
.gap-2{ gap:8px; }
.me-1{ margin-right:4px; }
.me-2{ margin-right:8px; }
.ms-auto{ margin-left:auto; }
.m-0{ margin:0; }
.mb-0{ margin-bottom:0; }
.mt-3{ margin-top:12px; }
.mb-3{ margin-bottom:12px; }
.d-grid{ display:grid; }
.form-control, .form-select{ width:100%; }
.grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.row{ display:flex; gap:12px; align-items:end; flex-wrap:wrap; }
.row.g-3{ gap:12px; }
.col-12, .col-6, .col-md-3, .col-lg-4, .col-lg-8{ flex:1 1 100%; }
.acciones{ display:flex; flex-wrap:wrap; gap:10px; margin-top:16px; }
.pill{ display:inline-block; padding:2px 8px; border-radius:999px; background:rgba(255,255,255,.08); border:1px solid var(--border); }
.check-grid{ display:flex; flex-wrap:wrap; gap:8px 14px; margin:6px 0 12px; }
.dashboard-head{ display:flex; justify-content:space-between; gap:16px; align-items:flex-start; margin-bottom:14px; }
.metricas{ display:grid; grid-template-columns:repeat(auto-fit,minmax(170px,1fr)); gap:10px; margin:14px 0; }
.metrica{ background:rgba(255,255,255,.05); border:1px solid var(--border); border-radius:10px; padding:12px; min-height:76px; }
.metrica span{ display:block; color:var(--text-dim); font-size:.86rem; }
.metrica strong{ display:block; margin-top:8px; font-size:1.45rem; color:#fff; }
.bloque-dashboard{ margin-top:18px; padding-top:14px; border-top:1px solid var(--border); }
.lista-limpia{ margin:0; padding-left:18px; color:var(--text-dim); }
.lista-pills{ display:flex; flex-wrap:wrap; gap:8px; }

/* Fichaje */
.fichaje{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
}
.fichaje--visor{ align-items:stretch; }
.fichaje-panel{
  width:min(1180px, 100%);
  background:linear-gradient(135deg, rgba(15,23,42,.97), rgba(2,6,23,.96));
  border:1px solid var(--border);
  border-radius:16px;
  padding:24px;
  box-shadow:var(--shadow);
}
.fichaje-card{
  width:min(520px, 100%);
  background:linear-gradient(135deg, rgba(15,23,42,.97), rgba(2,6,23,.96));
  border:1px solid var(--border);
  border-radius:16px;
  padding:26px;
  box-shadow:var(--shadow);
}
.fichaje-local{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
  margin-bottom:16px;
  padding-bottom:12px;
  border-bottom:1px solid var(--border);
}
.fichaje-local span{ color:var(--text-dim); font-weight:600; }
.fichaje-local strong{ color:#fff; text-align:right; }
.fichaje-form{ display:grid; gap:10px; margin-top:16px; }
.fichaje-form input,
.fichaje-form select{ width:100%; font-size:1.05rem; padding:11px 12px; }
.fichaje-acciones{ display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-top:8px; }
.fichaje-acciones .btn{ justify-content:center; min-height:44px; }
.fichaje-ultimo{
  margin-top:16px;
  padding:10px 12px;
  border-radius:10px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.05);
}
.fichaje-ultimo span{ display:block; color:var(--text-dim); font-size:.86rem; }
.fichaje-ultimo strong{ display:block; margin-top:4px; }
.fichaje-cabecera,
.fichaje-toolbar,
.fichaje-persona__top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
}
.fichaje-cabecera{
  padding-bottom:16px;
  margin-bottom:16px;
  border-bottom:1px solid var(--border);
}
.fichaje-cabecera span,
.fichaje-persona__top span{ color:var(--text-dim); font-weight:600; }
.fichaje-cabecera h1,
.fichaje-toolbar h2{ margin:.15rem 0; }
.fichaje-reloj{ text-align:right; }
.fichaje-reloj strong{ display:block; margin-top:4px; font-size:1.5rem; color:#fff; }
.fichaje-toolbar{ margin:12px 0 16px; }
.fichaje-add{
  width:54px;
  height:54px;
  border-radius:50%;
  border:1px solid rgba(90,168,255,.55);
  background:rgba(90,168,255,.22);
  color:#fff;
  font-size:2rem;
  line-height:1;
  cursor:pointer;
}
.fichaje-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:12px; }
.fichaje-persona{
  border:1px solid rgba(34,197,94,.42);
  border-radius:12px;
  padding:14px;
  background:rgba(255,255,255,.05);
}
.fichaje-persona--pausa{ border-color:rgba(251,191,36,.62); }
.fichaje-persona__top strong{ display:block; margin-top:4px; font-size:1.05rem; color:#fff; }
.fichaje-contador{
  margin:14px 0 4px;
  font-size:2rem;
  font-weight:700;
  color:#fff;
  font-family:"Space Grotesk", system-ui, sans-serif;
}
.fichaje-pausa{
  margin-top:12px;
  padding:8px 10px;
  border:1px solid rgba(251,191,36,.55);
  border-radius:10px;
  background:rgba(251,191,36,.08);
}
.fichaje-pausa span{ display:block; color:var(--text-dim); font-size:.84rem; }
.fichaje-pausa strong{ display:block; margin-top:3px; }
.fichaje-card-actions{ display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-top:14px; }
.fichaje-card-actions .btn{ justify-content:center; }
.fichaje-action{ min-width:0; }
.fichaje-action summary{
  list-style:none;
  width:100%;
  min-height:36px;
  justify-content:center;
}
.fichaje-action summary::-webkit-details-marker{ display:none; }
.fichaje-action-form{
  grid-column:1 / -1;
  display:grid;
  gap:7px;
  margin-top:8px;
  padding:9px;
  border:1px solid var(--border);
  border-radius:10px;
  background:rgba(255,255,255,.045);
}
.fichaje-action-form input,
.fichaje-action-form select{ width:100%; }
.fichaje-action-form .btn-mini{ justify-content:center; }
.fichaje-vacio{
  grid-column:1 / -1;
  min-height:220px;
  display:grid;
  place-items:center;
  text-align:center;
  border:1px dashed var(--border);
  border-radius:12px;
  background:rgba(255,255,255,.03);
}
.fichaje-modal{ display:none; position:fixed; inset:0; z-index:1500; align-items:center; justify-content:center; padding:20px; }
.fichaje-modal.is-open{ display:flex; }
.fichaje-modal__backdrop{ position:absolute; inset:0; background:rgba(0,0,0,.68); backdrop-filter:blur(5px); }
.fichaje-modal__card{
  position:relative;
  width:min(460px, 100%);
  background:linear-gradient(135deg, rgba(15,23,42,.98), rgba(2,6,23,.98));
  border:1px solid var(--border);
  border-radius:14px;
  padding:22px;
  box-shadow:var(--shadow);
}
.fichaje-modal__close{
  position:absolute;
  top:10px;
  right:10px;
  border:1px solid var(--border);
  border-radius:50%;
  width:34px;
  height:34px;
  background:rgba(255,255,255,.08);
  color:#fff;
  cursor:pointer;
}
.teclado-visible .fichaje-modal.is-open{
  align-items:flex-start;
  overflow:auto;
  padding-bottom:250px;
}
.teclado-fichaje{
  display:none;
  position:fixed;
  inset:auto 0 0;
  z-index:1700;
  padding:10px 14px calc(10px + env(safe-area-inset-bottom));
  background:rgba(2,6,23,.96);
  border-top:1px solid rgba(255,255,255,.16);
  box-shadow:0 -18px 42px rgba(0,0,0,.55);
}
.teclado-fichaje.is-open{ display:block; }
.teclado-fichaje__panel{
  max-width:900px;
  margin:0 auto;
}
.teclado-fichaje__keys{
  display:grid;
  grid-template-columns:repeat(10, minmax(42px, 1fr));
  gap:7px;
}
.teclado-fichaje__keys button{
  min-height:42px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:8px;
  background:rgba(255,255,255,.08);
  color:#fff;
  font-weight:700;
  font-size:.98rem;
  cursor:pointer;
}
.teclado-fichaje__keys button:active{
  transform:translateY(1px);
  background:rgba(90,168,255,.24);
}
.teclado-fichaje__key--wide{ grid-column:span 2; }
.teclado-fichaje__key--ok{
  background:rgba(25,199,133,.22) !important;
  border-color:rgba(25,199,133,.46) !important;
}
.teclado-activo{
  border-color:rgba(34,211,238,.72) !important;
  box-shadow:0 0 0 .18rem rgba(34,211,238,.20) !important;
}

/* Necesidades */
.necesidades-head,
.section-title,
.necesidad-card__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
}
.necesidades-head{ margin-bottom:14px; }
.necesidades-head h1{ margin-bottom:4px; }
.necesidades-modo{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:12px 0 18px;
}
.necesidades-section{ margin-top:22px; }
.section-title{
  align-items:center;
  margin-bottom:12px;
}
.section-title h2{ margin:0; font-size:1.25rem; }
.crear-tipo-dia{
  display:flex;
  gap:8px;
  align-items:end;
  flex-wrap:wrap;
}
.crear-tipo-dia input{ min-width:220px; }
.necesidades-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(min(650px, 100%),1fr));
  gap:14px;
}
.necesidad-card{
  border:1px solid var(--border);
  border-radius:12px;
  padding:14px;
  background:rgba(255,255,255,.04);
}
.necesidad-card__head{ align-items:center; margin-bottom:12px; }
.necesidad-card__head span{ color:var(--text-dim); font-size:.82rem; font-weight:600; }
.necesidad-card__head h3{ margin:2px 0 0; font-size:1.08rem; }
.necesidad-card__actions{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.necesidad-card__head strong{
  white-space:nowrap;
  border:1px solid var(--border);
  border-radius:999px;
  padding:4px 9px;
  background:rgba(255,255,255,.06);
  font-size:.86rem;
}
.necesidad-copy{ position:relative; }
.necesidad-copy summary{ list-style:none; cursor:pointer; }
.necesidad-copy summary::-webkit-details-marker{ display:none; }
.necesidad-copy form{
  position:absolute;
  right:0;
  top:calc(100% + 6px);
  z-index:40;
  width:260px;
  padding:10px;
  border:1px solid var(--border);
  border-radius:10px;
  background:linear-gradient(135deg, rgba(15,23,42,.98), rgba(2,6,23,.98));
  box-shadow:var(--shadow);
}
.copy-grid{ display:grid; grid-template-columns:1fr 1fr; gap:7px 10px; }
.copy-actions{ display:flex; gap:8px; justify-content:flex-end; margin-top:10px; }
.timeline-24{ margin-bottom:12px; }
.timeline-24__horas{
  display:grid;
  grid-template-columns:repeat(24, minmax(18px,1fr));
  gap:0;
  color:rgba(185,194,204,.72);
  font-size:.68rem;
}
.timeline-24__horas span{ text-align:left; }
.timeline-24__pista{
  position:relative;
  height:34px;
  margin-top:4px;
  border:1px solid var(--border);
  border-radius:10px;
  overflow:hidden;
  background:
    repeating-linear-gradient(90deg, rgba(255,255,255,.08) 0, rgba(255,255,255,.08) 1px, transparent 1px, transparent calc(100% / 24)),
    rgba(255,255,255,.03);
}
.timeline-24__segmento{
  position:absolute;
  top:5px;
  bottom:5px;
  min-width:3px;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  border-radius:7px;
  border:1px solid rgba(255,255,255,.32);
  color:#fff;
  font-size:.72rem;
  font-weight:700;
}
.timeline-24__segmento.is-muted{ opacity:.35; }
.timeline-24__segmento--c0{ background:rgba(90,168,255,.45); }
.timeline-24__segmento--c1{ background:rgba(34,197,94,.42); }
.timeline-24__segmento--c2{ background:rgba(251,191,36,.42); }
.timeline-24__segmento--c3{ background:rgba(244,114,182,.40); }
.timeline-24__segmento--c4{ background:rgba(45,212,191,.40); }
.timeline-24__segmento--c5{ background:rgba(167,139,250,.42); }
.necesidad-add{
  display:grid;
  grid-template-columns:minmax(86px,.8fr) minmax(86px,.8fr) minmax(140px,1.4fr) minmax(70px,.65fr) auto;
  gap:8px;
  align-items:end;
  margin-bottom:12px;
  padding-bottom:12px;
  border-bottom:1px solid var(--border);
}
.necesidad-add label,
.necesidad-edit label{ margin-top:0; }
.necesidad-add input,
.necesidad-add select,
.necesidad-edit input,
.necesidad-edit select{ width:100%; min-width:0; }
.necesidad-add__accion .btn{ width:100%; justify-content:center; white-space:nowrap; }
.necesidad-lista{ display:grid; gap:8px; }
.necesidad-item{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  align-items:center;
}
.necesidad-edit{
  display:grid;
  grid-template-columns:82px 82px minmax(130px,1fr) 68px minmax(100px,1fr) auto auto;
  gap:8px;
  align-items:center;
}
.mini-check{
  display:flex;
  align-items:center;
  gap:5px;
  margin:0;
  white-space:nowrap;
  color:var(--text-dim);
  font-size:.86rem;
}
.mini-check input{ width:auto; }
.btn-danger{ border-color:rgba(248,113,113,.55); color:#ffd1d1; }
.necesidad-vacia{
  border:1px dashed var(--border);
  border-radius:10px;
  padding:12px;
  color:var(--text-dim);
  background:rgba(255,255,255,.03);
}
.necesidad-vacia--grande{ padding:22px; text-align:center; }

/* Calendar */
.calendario{ display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:12px; }
.dia{ border:1px solid var(--border); border-radius:12px; padding:10px; background:rgba(255,255,255,.04); }
.dia-titulo{ font-weight:600; margin-bottom:6px; }
.dia-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:8px;
  margin-bottom:8px;
}
.dia-base{ color:var(--text-dim); font-size:.8rem; }
.dia-especial{ position:relative; flex:0 0 auto; }
.dia-especial summary{ list-style:none; cursor:pointer; justify-content:center; }
.dia-especial summary::-webkit-details-marker{ display:none; }
.dia-especial-form{
  position:absolute;
  right:0;
  top:calc(100% + 6px);
  z-index:50;
  width:220px;
  padding:9px;
  border:1px solid var(--border);
  border-radius:10px;
  background:linear-gradient(135deg, rgba(15,23,42,.98), rgba(2,6,23,.98));
  box-shadow:var(--shadow);
}
.necesidades-dia{ display:grid; gap:6px; margin-bottom:8px; }
.necesidad-plan{ display:block; }
.necesidad-plan summary{ cursor:pointer; list-style:none; }
.necesidad-plan summary::-webkit-details-marker{ display:none; }
.necesidad-linea{
  display:grid;
  grid-template-columns:auto minmax(80px,1fr) auto;
  gap:6px;
  align-items:center;
  padding:5px 7px;
  border-radius:8px;
  border:1px solid var(--border);
  font-size:.82rem;
  background:rgba(255,255,255,.04);
}
.necesidad-linea--ok{ border-color:rgba(34,197,94,.45); }
.necesidad-linea--falta{ border-color:rgba(248,113,113,.55); }
.necesidad-linea--exceso{ border-color:rgba(251,191,36,.55); }
.asignar-necesidad{
  margin-top:6px;
  padding:8px;
  border:1px solid var(--border);
  border-radius:8px;
  background:rgba(255,255,255,.035);
}
.form-mini{ display:grid; gap:6px; }
.form-mini select,
.form-mini input,
.form-mini textarea{ width:100%; min-width:0; }
.form-mini input[type="checkbox"]{ width:auto; }
.form-mini label.inline{
  display:flex;
  align-items:center;
  gap:8px;
}
.form-mini .btn-mini{ justify-content:center; }
.asignaciones{ list-style:none; margin:0; padding:0; }
.asignaciones li{ padding:4px 0; border-bottom:1px dashed rgba(255,255,255,.08); }
.asignaciones li:last-child{ border-bottom:0; }
.asignaciones .vacio{ color:var(--text-dim); }
.asignacion-linea{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:8px;
}
.asignacion-linea details{ min-width:72px; }
.asignacion-linea summary{ list-style:none; cursor:pointer; justify-content:center; }
.asignacion-linea summary::-webkit-details-marker{ display:none; }
.asignacion-edit{
  margin-top:7px;
  padding:8px;
  border:1px solid var(--border);
  border-radius:8px;
  background:rgba(255,255,255,.04);
  min-width:210px;
}
.conflictos{ margin-top:4px; display:flex; flex-wrap:wrap; gap:4px; color:#ffd1d1; }
.planificador-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  margin-bottom:10px;
}
.planificador-head h1{ margin-bottom:4px; }
.planificador-estado{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:6px;
  min-width:190px;
}
.pill--warn{
  border-color:rgba(251,191,36,.62);
  background:rgba(251,191,36,.12);
  color:#fff4d4;
}
.planificador-actions{
  align-items:center;
  margin-bottom:14px;
}
.planificador-save{
  display:inline-flex;
  margin:0;
}
.planificador-copybar{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
  margin:2px 0 14px;
  padding:8px;
  border:1px solid rgba(34,211,238,.28);
  border-radius:8px;
  background:rgba(34,211,238,.075);
}
.calendario-planificador{
  grid-template-columns:repeat(auto-fill,minmax(310px,1fr));
  align-items:start;
}
.dia-plan{
  display:flex;
  flex-direction:column;
  gap:9px;
  min-height:310px;
}
.dia-plan .dia-head{
  margin-bottom:0;
  padding-bottom:8px;
  border-bottom:1px solid rgba(255,255,255,.09);
}
.dia-copy-actions{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:6px;
}
.planificador-target-toggle{
  border-color:rgba(34,211,238,.36);
}
.planificador-target-toggle.is-selected{
  border-color:rgba(52,211,153,.72);
  background:rgba(52,211,153,.18);
  color:#d8ffe8;
}
.dia-plan.is-copy-source{
  border-color:rgba(255,138,31,.68);
  box-shadow:0 0 0 1px rgba(255,138,31,.22), inset 0 1px 0 rgba(255,255,255,.08);
}
.dia-plan.is-copy-target{
  border-color:rgba(52,211,153,.66);
  box-shadow:0 0 0 1px rgba(52,211,153,.20), inset 0 1px 0 rgba(255,255,255,.08);
}
.planificador-special{
  margin:0;
}
.planificador-special select{
  width:100%;
  margin-top:4px;
}
.asignaciones-draft{
  display:grid;
  gap:8px;
}
.asignaciones-draft .vacio{
  padding:8px;
  border:1px dashed rgba(255,255,255,.16);
  border-radius:8px;
  color:var(--text-dim);
  background:rgba(255,255,255,.025);
}
.asignacion-card{
  display:grid;
  gap:8px;
  padding:9px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:8px;
  background:linear-gradient(135deg, rgba(255,255,255,.065), rgba(255,255,255,.025));
}
.asignacion-card__top,
.asignacion-card__person,
.asignacion-card__tools{
  display:flex;
  align-items:center;
  gap:8px;
}
.asignacion-card__top{
  justify-content:space-between;
  align-items:flex-start;
}
.asignacion-card__person{ min-width:0; }
.asignacion-card__person strong,
.resource-card strong{
  display:block;
  color:#fff;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.asignacion-card__person span:not(.resource-avatar),
.resource-card small{
  display:block;
  color:var(--text-dim);
  font-size:.78rem;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.asignacion-card__tools{
  justify-content:flex-end;
  flex-wrap:wrap;
}
.asignacion-card__edit summary{
  width:100%;
  justify-content:center;
  list-style:none;
}
.asignacion-card__edit summary::-webkit-details-marker{ display:none; }
.asignacion-edit-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
  margin-top:8px;
}
.asignacion-edit-grid label{ margin:0; }
.asignacion-edit-grid select,
.asignacion-edit-grid input{ width:100%; }
.resource-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(132px,1fr));
  gap:7px;
}
.resource-card{
  min-width:0;
  min-height:58px;
  display:flex;
  align-items:center;
  gap:8px;
  text-align:left;
  padding:7px;
  border:1px solid rgba(34,211,238,.28);
  border-radius:8px;
  color:var(--text);
  background:rgba(34,211,238,.075);
  cursor:pointer;
}
.resource-card:hover{
  border-color:rgba(34,211,238,.58);
  background:rgba(34,211,238,.13);
}
.resource-card.is-disabled{
  opacity:.48;
  cursor:not-allowed;
  border-color:rgba(255,255,255,.12);
  background:rgba(255,255,255,.035);
}
.resource-avatar{
  flex:0 0 34px;
  width:34px;
  height:34px;
  display:inline-grid;
  place-items:center;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.18);
  color:#fff;
  background:linear-gradient(135deg, rgba(255,138,31,.45), rgba(34,211,238,.32));
  font-size:.76rem;
  font-weight:800;
}
.resource-card__text{
  min-width:0;
  display:block;
}
.planificador-add summary{
  width:100%;
  justify-content:center;
  list-style:none;
}
.planificador-add summary::-webkit-details-marker{ display:none; }
.planificador-add-form{
  margin-top:8px;
  padding:8px;
  border:1px solid var(--border);
  border-radius:8px;
  background:rgba(255,255,255,.035);
}
.planificador-add-grid{
  display:grid;
  grid-template-columns:1.2fr .75fr .75fr;
  gap:8px;
}
.planificador-add-grid label{ margin:0; }
.planificador-add-grid select,
.planificador-add-grid input{ width:100%; }
.estado{ display:inline-block; padding:3px 8px; border-radius:999px; border:1px solid var(--border); }
.estado--ok{ border-color:rgba(34,197,94,.55); }
.estado--falta{ border-color:rgba(248,113,113,.6); }
.estado--exceso{ border-color:rgba(251,191,36,.65); }
.jornada-ajuste{ display:block; min-width:240px; }
.jornada-ajuste summary{ list-style:none; cursor:pointer; justify-content:center; }
.jornada-ajuste summary::-webkit-details-marker{ display:none; }
.jornada-ajuste-form{
  width:min(320px, 100%);
  margin-top:8px;
  padding:9px;
  border:1px solid var(--border);
  border-radius:10px;
  background:linear-gradient(135deg, rgba(15,23,42,.98), rgba(2,6,23,.98));
  box-shadow:var(--shadow);
}
.ausencia-crear summary,
.ausencia-justificar summary{ list-style:none; cursor:pointer; }
.ausencia-crear summary::-webkit-details-marker,
.ausencia-justificar summary::-webkit-details-marker{ display:none; }
.ausencia-justificar__form{
  margin-top:8px;
  width:min(320px, 100%);
  padding:9px;
  border:1px solid var(--border);
  border-radius:10px;
  background:rgba(255,255,255,.04);
}
.fichaje-usuario{
  display:grid;
  grid-template-columns:minmax(240px, 1.2fr) minmax(220px, .8fr);
  gap:12px;
  align-items:end;
  margin-bottom:14px;
}
.fichaje-usuario select{ width:100%; }
.fichaje-usuario__acciones,
.fichaje-usuario__pausas{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:end;
}
.fichaje-usuario__pausas{
  grid-column:1 / -1;
  padding-top:10px;
  border-top:1px solid var(--border);
}
.fichaje-usuario__pausas label{ width:100%; margin:0; }
.vacaciones-calendario{
  display:grid;
  grid-template-columns:repeat(7, minmax(90px, 1fr));
  gap:1px;
  margin-top:16px;
  border:1px solid var(--border);
  border-radius:12px;
  overflow:hidden;
  background:var(--border);
}
.vacaciones-head{
  padding:8px;
  background:rgba(255,255,255,.08);
  color:#fff;
  font-weight:600;
  text-align:center;
}
.vacaciones-dia{
  min-height:102px;
  padding:8px;
  background:rgba(255,255,255,.04);
}
.vacaciones-dia.is-muted{ opacity:.42; }
.vacaciones-dia__num{
  color:#fff;
  font-weight:700;
  margin-bottom:6px;
}
.vacaciones-dia__items{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.vacaciones-chip{
  display:block;
  width:100%;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  padding:3px 6px;
  border-radius:7px;
  border:1px solid rgba(90,168,255,.36);
  background:rgba(90,168,255,.14);
  color:#e9eef5;
  font-size:.78rem;
}

/* Squadra premium theme */
.role-admin{ --accent:#a78bfa; --accent-soft:rgba(167,139,250,.23); --active:rgba(167,139,250,.14); }
.role-director{ --accent:#ff8a1f; --accent-soft:rgba(255,138,31,.24); --active:rgba(255,138,31,.14); }
.role-rrhh{ --accent:#34d399; --accent-soft:rgba(52,211,153,.20); --active:rgba(52,211,153,.13); }
.role-jefe{ --accent:#22d3ee; --accent-soft:rgba(34,211,238,.21); --active:rgba(34,211,238,.13); }
.role-trabajador{ --accent:#22d3ee; --accent-soft:rgba(34,211,238,.20); --active:rgba(34,211,238,.13); }

body.sq-body{
  min-height:100%;
  font-size:15px;
  line-height:1.5;
}
body.sq-body::selection{
  color:#06101a;
  background:var(--accent);
}
h1{
  margin:.05rem 0 .45rem;
  font-size:clamp(1.72rem, 2.4vw, 2.62rem);
  line-height:1.05;
  font-weight:800;
}
h2{ font-size:1.28rem; }
h3{ font-size:1.05rem; }

.sidebar{
  width:282px;
  padding:18px 15px 86px;
  background:
    linear-gradient(180deg, rgba(8,13,23,.98), rgba(5,8,15,.97)),
    repeating-linear-gradient(145deg, #0b0f17 0, #0b0f17 3px, #090d15 3px, #090d15 6px);
  border-right:1px solid rgba(255,255,255,.12);
  box-shadow:16px 0 42px rgba(0,0,0,.55);
}
.brand{
  border-radius:12px;
  padding:12px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.075), rgba(255,255,255,.025)),
    linear-gradient(135deg, rgba(255,138,31,.18), rgba(34,211,238,.10));
  border:1px solid rgba(255,255,255,.14);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.09), 0 18px 34px rgba(0,0,0,.42);
}
.brand-logo{
  width:42px;
  height:42px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.16);
  background:#050914;
}
.brand-title strong{
  font-family:"Sora","Manrope",sans-serif;
  font-size:1rem;
}
.brand-title span{ color:#b7c1cf; }
.sidebar-user{
  border-radius:10px;
  padding:11px 12px;
  background:linear-gradient(135deg, rgba(255,255,255,.07), rgba(255,255,255,.025));
  border:1px solid rgba(255,255,255,.12);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}
.nav-label{
  margin:16px 5px 7px;
  color:#8f9bad;
  font-family:"Sora","Manrope",sans-serif;
  font-size:.68rem;
}
.nav-link{
  position:relative;
  display:flex;
  align-items:center;
  min-height:38px;
  border-radius:8px;
  padding:9px 11px 9px 14px;
  color:#e8edf7;
  border:1px solid transparent;
  background:transparent;
  font-weight:700;
  letter-spacing:0;
}
.nav-link::before{
  content:"";
  width:4px;
  align-self:stretch;
  margin:-2px 10px -2px -5px;
  border-radius:999px;
  background:rgba(255,255,255,.14);
}
.nav-link:hover{
  background:rgba(255,255,255,.065);
  border-color:rgba(255,255,255,.10);
}
.nav-link.active{
  color:#fff;
  background:linear-gradient(135deg, var(--active), rgba(255,255,255,.055));
  border-color:var(--accent);
  box-shadow:0 0 0 1px var(--accent-soft), 0 16px 30px rgba(0,0,0,.28);
}
.nav-link.active::before{ background:var(--accent); box-shadow:0 0 16px var(--accent-soft); }
.logout .btn{ width:100%; justify-content:center; }

.topbar{
  background:rgba(5,8,15,.90);
  border-bottom:1px solid rgba(255,255,255,.13);
}
.topbar__toggle{
  border-radius:8px;
  background:rgba(255,255,255,.08);
}

.contenido{
  margin-left:282px;
  padding:30px 34px 42px;
}
.contenido--full{
  margin-left:0;
  max-width:1180px;
  padding:38px 22px 44px;
}
.panel{
  position:relative;
  overflow:hidden;
  border-radius:18px;
  padding:24px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.065), rgba(255,255,255,.02)),
    repeating-linear-gradient(145deg, rgba(255,255,255,.025) 0, rgba(255,255,255,.025) 3px, transparent 3px, transparent 7px),
    linear-gradient(145deg, rgba(13,18,30,.98), rgba(7,10,17,.96));
  border:1px solid rgba(255,255,255,.13);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08), var(--shadow), 0 0 0 1px var(--accent-soft);
}
.panel::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:3px;
  background:linear-gradient(90deg, var(--accent), var(--accent-2), var(--violet));
  opacity:.86;
}

.dashboard-head,
.welcome-hero{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  margin-bottom:18px;
}
.welcome-hero{
  min-height:280px;
  align-items:center;
}
.dashboard-kicker{
  display:inline-flex;
  align-items:center;
  margin-bottom:7px;
  border:1px solid var(--accent-soft);
  border-radius:999px;
  padding:4px 9px;
  background:rgba(255,255,255,.055);
  color:#eaf2fb;
  font-family:"Sora","Manrope",sans-serif;
  font-size:.72rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.muted,.text-muted{ color:#b7c1cf; }

.metricas{
  grid-template-columns:repeat(auto-fit,minmax(185px,1fr));
  gap:12px;
}
.metrica,
.tile,
.necesidad-card,
.dia,
.feature-card,
.notice-panel,
.fichaje-persona,
.fichaje-card,
.fichaje-panel,
.card{
  border-radius:8px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.075), rgba(255,255,255,.025)),
    linear-gradient(145deg, rgba(12,18,29,.95), rgba(8,12,20,.88));
  border:1px solid rgba(255,255,255,.13);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.07), 0 18px 34px rgba(0,0,0,.34);
}
.metrica{
  position:relative;
  min-height:96px;
  padding:14px 15px;
  overflow:hidden;
}
.metrica::before{
  content:"";
  position:absolute;
  inset:0 auto 0 0;
  width:4px;
  background:linear-gradient(180deg, var(--accent), var(--accent-2));
}
.metrica span{
  color:#b7c1cf;
  font-family:"Sora","Manrope",sans-serif;
  font-size:.75rem;
  font-weight:700;
  letter-spacing:.05em;
  text-transform:uppercase;
}
.metrica strong{
  margin-top:9px;
  font-family:"Sora","Manrope",sans-serif;
  font-size:1.92rem;
  line-height:1;
}

.bloque-dashboard{
  margin-top:20px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.11);
}
.notice-panel,
.feature-card{
  padding:14px 16px;
  border-color:rgba(255,138,31,.32);
}
.notice-panel--cyan{ border-color:rgba(34,211,238,.34); }
.notice-list{
  padding-left:0;
  list-style:none;
}
.notice-list li{
  margin-top:8px;
  padding:9px 11px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.045);
}
.quick-actions{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(190px,1fr));
  gap:10px;
}
.quick-action{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  min-height:74px;
  padding:14px;
  border-radius:8px;
  color:#fff;
  background:
    linear-gradient(135deg, var(--accent-soft), rgba(255,255,255,.035)),
    linear-gradient(145deg, rgba(13,18,30,.96), rgba(8,12,20,.90));
  border:1px solid rgba(255,255,255,.13);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08), 0 16px 30px rgba(0,0,0,.32);
}
.quick-action:hover{
  color:#fff;
  transform:translateY(-1px);
  border-color:var(--accent);
}
.quick-action span{
  font-family:"Sora","Manrope",sans-serif;
  font-weight:800;
}
.quick-action strong{
  color:#cbd5e1;
  font-size:.8rem;
}

input, select, textarea,
.form-control, .form-select{
  border-radius:8px;
  border-color:rgba(255,255,255,.16);
  background:#0f1727;
  color:#f6f8fc;
  font-family:"Manrope",system-ui,sans-serif;
}
textarea{ resize:vertical; }
input::placeholder, textarea::placeholder{ color:#7f8ca0; }
label{
  color:#c8d2e1;
  font-size:.88rem;
  font-weight:700;
}
.btn, .sq-btn, .btn-mini{
  border-radius:8px;
  border-color:rgba(255,255,255,.20);
  background:linear-gradient(145deg, rgba(255,255,255,.10), rgba(255,255,255,.045));
  color:#f8fbff;
  font-family:"Sora","Manrope",sans-serif;
  font-weight:800;
  letter-spacing:0;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.btn:hover, .sq-btn:hover, .btn-mini:hover{
  color:#fff;
  border-color:var(--accent);
  background:linear-gradient(145deg, var(--accent-soft), rgba(255,255,255,.075));
}
.btn-primary{
  background:linear-gradient(145deg, rgba(255,138,31,.82), rgba(217,79,14,.82));
  border-color:rgba(255,191,130,.72);
  color:#fff;
}
.btn-sec{ background:rgba(255,255,255,.055); }
.btn-danger{ border-color:rgba(248,113,113,.55); color:#ffd1d1; }
.pill,
.estado,
.badge{
  border-radius:999px;
  border:1px solid rgba(255,255,255,.13);
  background:rgba(255,255,255,.07);
  font-weight:800;
}

.tabla, .table{
  border-radius:8px;
  background:rgba(255,255,255,.035);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 18px 34px rgba(0,0,0,.22);
}
.tabla th, .tabla td, .table th, .table td{
  padding:11px 12px;
  border-bottom:1px solid rgba(255,255,255,.09);
}
.tabla thead th, .table thead th{
  background:linear-gradient(135deg, rgba(255,255,255,.085), rgba(255,255,255,.035));
  color:#f7fbff;
  font-family:"Sora","Manrope",sans-serif;
  font-size:.8rem;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.tabla tbody tr:hover, .table tbody tr:hover{
  background:rgba(255,138,31,.055);
}

.control-filters{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:12px;
  align-items:end;
  margin:14px 0 18px;
}
.control-filters > div{ min-width:0; }
.control-filters select,
.control-filters input,
.control-filters button{ width:100%; }
.control-summary{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:10px;
  margin:14px 0 22px;
}
.control-metric{
  min-height:94px;
  padding:12px;
  border:1px solid rgba(255,255,255,.13);
  border-radius:8px;
  background:linear-gradient(145deg, rgba(14,20,33,.94), rgba(9,14,24,.86));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06), 0 14px 28px rgba(0,0,0,.24);
}
.control-metric span,
.control-metric small{
  display:block;
  color:#aebed2;
}
.control-metric span{
  font-family:"Sora","Manrope",sans-serif;
  font-weight:800;
  font-size:.82rem;
}
.control-metric strong{
  display:block;
  margin:.28rem 0;
  color:#f8fbff;
  font-size:1.85rem;
  line-height:1;
}
.control-metric small{
  font-size:.78rem;
  line-height:1.3;
}
.control-metric--warn{ border-color:rgba(255,159,65,.46); }
.control-metric--alert{ border-color:rgba(251,113,133,.42); }

.report-section{
  margin-top:24px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.11);
}
.report-section--attention{ border-top-color:rgba(255,159,65,.34); }
.report-section__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}
.report-section__head h2{
  margin:0;
  font-size:1.22rem;
  line-height:1.2;
}
.report-section__head p{
  margin:.25rem 0 0;
  color:#aebed2;
  font-size:.88rem;
  line-height:1.4;
}
.report-list{
  display:grid;
  gap:10px;
}
.report-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:14px;
  align-items:start;
  padding:13px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:8px;
  background:linear-gradient(145deg, rgba(255,255,255,.055), rgba(255,255,255,.025));
}
.report-row--action{
  grid-template-columns:minmax(0,1fr) minmax(220px,320px);
}
.report-row__main,
.report-action{ min-width:0; }
.report-row__title{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
}
.report-row__title strong{
  color:#f8fbff;
  font-size:1rem;
  overflow-wrap:anywhere;
}
.report-row__meta{
  display:flex;
  flex-wrap:wrap;
  gap:6px 8px;
  margin-top:8px;
}
.report-row__meta span{
  display:inline-flex;
  max-width:100%;
  padding:3px 7px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:999px;
  color:#cbd5e1;
  background:rgba(255,255,255,.04);
  font-size:.8rem;
  line-height:1.25;
  overflow-wrap:anywhere;
}
.report-note{
  margin:.72rem 0 0;
  color:#edf4ff;
  line-height:1.45;
  overflow-wrap:anywhere;
  white-space:pre-line;
}
.report-note--muted{
  color:#b6c5d8;
  font-size:.9rem;
}
.report-action{
  display:grid;
  gap:8px;
}
.report-action select,
.report-action textarea,
.report-action button{ width:100%; }
.report-action--text{
  color:#cbd5e1;
  font-size:.9rem;
  line-height:1.4;
  overflow-wrap:anywhere;
}
.report-status{
  display:flex;
  justify-content:flex-end;
}
.report-empty{
  padding:14px;
  border:1px dashed rgba(255,255,255,.16);
  border-radius:8px;
  color:#aebed2;
  background:rgba(255,255,255,.028);
}
.pill--pending{ border-color:rgba(255,190,96,.48); background:rgba(255,190,96,.12); color:#ffe4b5; }
.pill--ok{ border-color:rgba(52,211,153,.42); background:rgba(52,211,153,.10); color:#bbf7d0; }
.pill--bad{ border-color:rgba(251,113,133,.46); background:rgba(251,113,133,.10); color:#fecdd3; }

@media (max-width:720px){
  .report-row,
  .report-row--action{
    grid-template-columns:1fr;
  }
  .report-status{ justify-content:flex-start; }
}

.sq-alert{
  border-radius:8px;
  background:linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.035));
  box-shadow:0 12px 28px rgba(0,0,0,.25);
}
.sq-alert--ok{ border-color:rgba(52,211,153,.55); }
.sq-alert--warn{ border-color:rgba(255,138,31,.58); }
.sq-alert--err{ border-color:rgba(251,113,133,.60); }

.calendario{ grid-template-columns:repeat(auto-fill,minmax(270px,1fr)); }
.dia{
  padding:12px;
  border-color:rgba(255,255,255,.13);
}
.dia-head{ border-bottom:1px solid rgba(255,255,255,.09); padding-bottom:8px; }
.dia-titulo{
  font-family:"Sora","Manrope",sans-serif;
  color:#fff;
}
.necesidad-linea,
.asignar-necesidad,
.asignacion-edit,
.fichaje-action-form,
.ausencia-justificar__form,
.jornada-ajuste-form,
.dia-especial-form,
.necesidad-copy form{
  border-radius:8px;
  background:linear-gradient(145deg, rgba(13,18,30,.98), rgba(7,10,17,.96));
  border:1px solid rgba(255,255,255,.13);
  box-shadow:0 16px 30px rgba(0,0,0,.35);
}
.necesidad-linea--ok{ border-color:rgba(52,211,153,.48); }
.necesidad-linea--falta{ border-color:rgba(251,113,133,.56); }
.necesidad-linea--exceso{ border-color:rgba(255,138,31,.58); }

.fichaje-card,
.fichaje-panel{
  border-color:rgba(34,211,238,.25);
}
.fichaje-local,
.fichaje-cabecera{
  border-bottom-color:rgba(255,255,255,.10);
}
.fichaje-contador{
  font-family:"Sora","Manrope",sans-serif;
  color:#fff;
}
.fichaje-pausa{
  border-radius:8px;
  border-color:rgba(255,138,31,.58);
  background:rgba(255,138,31,.09);
}
.fichaje-usuario{
  padding:14px;
  border-radius:8px;
  border:1px solid rgba(34,211,238,.24);
  background:linear-gradient(135deg, rgba(34,211,238,.08), rgba(255,255,255,.025));
}

.vacaciones-calendario{
  border-radius:8px;
  border-color:rgba(255,255,255,.12);
  background:rgba(255,255,255,.10);
}
.vacaciones-head{
  background:linear-gradient(135deg, var(--accent-soft), rgba(255,255,255,.06));
  font-family:"Sora","Manrope",sans-serif;
}
.vacaciones-dia{
  background:linear-gradient(145deg, rgba(13,18,30,.94), rgba(8,12,20,.88));
}
.vacaciones-chip{
  border-radius:7px;
  border-color:rgba(34,211,238,.38);
  background:rgba(34,211,238,.13);
  font-weight:800;
}

.login-card{
  border-radius:14px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.075), rgba(255,255,255,.025)),
    repeating-linear-gradient(145deg, rgba(255,255,255,.025) 0, rgba(255,255,255,.025) 3px, transparent 3px, transparent 7px),
    linear-gradient(145deg, rgba(13,18,30,.98), rgba(7,10,17,.96));
  border-color:rgba(255,255,255,.13);
}
.login-logo{ border-radius:12px; }

/* Admin-like helpers */
.container-xxl{ max-width:1200px; margin:24px auto; padding:0 16px; }
.card{ background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); }
.card-body{ padding:18px; }
.shadow-sm{ box-shadow:var(--shadow); }
.tile{ background:rgba(255,255,255,.06); border:1px solid var(--border); border-radius:12px; padding:12px; display:flex; gap:12px; align-items:center; }
.tile-icon{ font-size:1.4rem; opacity:.9; }
.tile-label{ color:var(--text-dim); font-size:.85rem; }
.tile-value{ font-size:1.2rem; font-weight:700; }

/* Misc */
.app-version-badge{
  position:fixed;
  right:12px;
  bottom:10px;
  z-index:1100;
  background: rgba(0,0,0,.78);
  color:#fff;
  border:1px solid var(--border);
  padding:5px 11px;
  border-radius:999px;
  font-size:12px;
  line-height:1.2;
  backdrop-filter: blur(6px);
}

/* Login */
.login{
  min-height:70vh;
  display:flex;
  align-items:center;
  justify-content:center;
}
.login-card{
  width:min(980px, 100%);
  background:
    radial-gradient(circle at 0 0, rgba(90,168,255,.18), transparent 55%),
    linear-gradient(135deg, rgba(17,24,39,.96), rgba(2,6,23,.96));
  border:1px solid var(--border);
  border-radius:20px;
  padding:0;
  box-shadow:var(--shadow);
}
.login-split{
  display:grid;
  grid-template-columns: 1fr 1.1fr;
  gap:0;
  overflow:hidden;
}
.login-left{
  padding:28px 26px;
  background:
    radial-gradient(circle at 0 0, rgba(90,168,255,.18), transparent 55%),
    linear-gradient(135deg, rgba(17,24,39,.98), rgba(2,6,23,.98));
  border-right:1px solid var(--border);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  gap:10px;
}
.login-logo{
  width:140px;
  height:140px;
  border-radius:24px;
  background:#0b1220;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(148,163,184,.4);
  box-shadow:0 10px 26px rgba(0,0,0,.7);
  padding:16px;
}
.login-logo img{
  max-width:100%;
  max-height:100%;
  object-fit:contain;
}
.login-left-title{
  font-family:\"Space Grotesk\", system-ui, sans-serif;
  font-size:1.2rem;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.login-left-sub{
  font-size:.88rem;
  color:var(--text-dim);
  max-width:280px;
}
.login-right{
  padding:28px 30px;
}
.login-form{
  display:grid;
  gap:14px;
  margin-top:14px;
}
.login-actions{
  display:flex;
  gap:10px;
  align-items:center;
  margin-top:6px;
}

@media (max-width: 880px){
  .login-split{ grid-template-columns:1fr; }
  .login-left{ border-right:0; border-bottom:1px solid var(--border); }
}

@media (max-width: 991.98px){
  .topbar{ display:flex; }
  .sidebar{ transform: translateX(-100%); transition: transform .18s ease; }
  .sidebar.is-open{ transform: translateX(0); }
  .contenido{ margin-left:0; padding:20px 18px 30px; }
}

@media (max-width: 720px){
  .grid-2{ grid-template-columns:1fr; }
  .necesidades-head,
  .section-title,
  .necesidad-card__head{ flex-direction:column; align-items:stretch; }
  .necesidad-card__actions{ justify-content:flex-start; }
  .necesidad-copy form{ position:static; width:100%; margin-top:8px; }
  .necesidades-grid{ grid-template-columns:1fr; }
  .necesidad-add,
  .necesidad-item,
  .necesidad-edit{ grid-template-columns:1fr; }
  .fichaje-usuario{ grid-template-columns:1fr; }
  .teclado-fichaje{ padding:8px 8px calc(8px + env(safe-area-inset-bottom)); }
  .teclado-fichaje__keys{
    grid-template-columns:repeat(10, minmax(26px, 1fr));
    gap:5px;
  }
  .teclado-fichaje__keys button{
    min-height:38px;
    border-radius:7px;
    font-size:.78rem;
  }
  .vacaciones-calendario{ grid-template-columns:repeat(7, minmax(46px, 1fr)); }
  .vacaciones-dia{ min-height:82px; padding:6px; }
  .vacaciones-head{ padding:6px 2px; font-size:.78rem; }
  .vacaciones-chip{ font-size:.72rem; }
  .timeline-24__horas{ grid-template-columns:repeat(12, 1fr); row-gap:2px; }
  .crear-tipo-dia input{ min-width:0; width:100%; }
}

/* Theme adapted from ejemplos/*.html */
:root{
  --bg-0:#0f1a2e;
  --surface:#0b111d;
  --surface-2:#0f1727;
  --border:rgba(255,255,255,.14);
  --line:rgba(255,255,255,.10);
  --text:#e9eef5;
  --text-dim:#b9c2cc;
  --accent:#5aa8ff;
  --accent-2:#19c785;
  --accent-soft:rgba(90,168,255,.20);
  --cyan-soft:rgba(42,210,255,.18);
  --active:rgba(255,255,255,.18);
  --focus:#9ad1ff;
  --radius:16px;
  --shadow:0 20px 38px rgba(0,0,0,.54);
}
.role-admin{ --accent:#5aa8ff; --accent-soft:rgba(90,168,255,.20); --active:rgba(255,255,255,.18); }
.role-director{ --accent:#ff9f41; --accent-soft:rgba(255,159,65,.18); --active:rgba(255,159,65,.14); }
.role-rrhh{ --accent:#19c785; --accent-soft:rgba(25,199,133,.18); --active:rgba(25,199,133,.14); }
.role-jefe,
.role-trabajador{ --accent:#38bdf8; --accent-soft:rgba(56,189,248,.18); --active:rgba(56,189,248,.14); }

body.sq-body{
  background-color:#0f1a2e;
  background-image:
    linear-gradient(135deg, rgba(15,26,46,.62), rgba(15,26,46,.42)),
    radial-gradient(120% 120% at 100% 0%, rgba(42,210,255,.16), transparent 58%),
    radial-gradient(100% 120% at 0% 100%, rgba(25,199,133,.10), transparent 55%),
    url("fondo.png");
  background-size:cover;
  background-position:center;
}

.sidebar{
  width:250px;
  background:rgba(10,11,14,.96);
  border-right:1px solid rgba(255,255,255,.06);
  padding:18px 16px 80px;
  box-shadow:8px 0 30px rgba(0,0,0,.70);
}
.brand{
  border-radius:16px;
  background:
    radial-gradient(circle at 0 0, rgba(90,168,255,.36), transparent 60%),
    linear-gradient(135deg, rgba(15,23,42,.95), rgba(15,23,42,.88));
  border:1px solid rgba(148,163,184,.60);
  box-shadow:0 10px 26px rgba(0,0,0,.90);
}
.brand-logo{
  width:34px;
  height:34px;
  border-radius:12px;
}
.brand-title strong{ letter-spacing:.03em; }
.brand-title span{ color:#e5e7eb; }
.sidebar-user{
  border-radius:10px;
  background:rgba(15,23,42,.90);
  border:1px solid rgba(148,163,184,.40);
}
.nav-label{
  margin:10px 2px 4px;
  color:rgba(148,163,184,.95);
  font-size:.72rem;
  letter-spacing:.14em;
}
.nav-link{
  min-height:initial;
  display:block;
  padding:9px 11px;
  border-radius:10px;
  margin-bottom:5px;
  font-weight:700;
  color:#e9eef5;
}
.nav-link::before{ content:none; }
.nav-link:hover{
  background:rgba(255,255,255,.10);
  border-color:rgba(148,163,184,.30);
}
.nav-link.active{
  background:rgba(255,255,255,.18);
  border-color:rgba(148,163,184,.65);
  box-shadow:0 6px 16px rgba(0,0,0,.75);
}

.contenido{
  margin-left:250px;
  padding:26px 32px 38px;
}
.contenido--full{
  margin-left:0;
  max-width:1240px;
  padding:36px 20px 40px;
}
.role-admin .panel,
.role-director .panel,
.role-rrhh .panel,
.role-jefe .panel,
.role-trabajador .panel{
  overflow:visible;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
}
.role-admin .panel::before,
.role-director .panel::before,
.role-rrhh .panel::before,
.role-jefe .panel::before,
.role-trabajador .panel::before{
  display:none;
}

.dashboard-shell{
  max-width:1240px;
  margin:0 auto;
}
.dashboard-hero,
.dashboard-head{
  position:relative;
  overflow:hidden;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.14);
  padding:1.06rem 1.1rem;
  background:
    radial-gradient(130% 120% at 100% 0%, rgba(42,210,255,.20), transparent 58%),
    radial-gradient(100% 120% at 0% 100%, rgba(25,199,133,.13), transparent 55%),
    repeating-linear-gradient(145deg, #0b0f17 0, #0b0f17 3px, #090d15 3px, #090d15 6px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    0 20px 38px rgba(0,0,0,.54),
    0 0 0 1px rgba(42,210,255,.11);
  margin-bottom:1rem;
}
.dashboard-head{
  align-items:flex-start;
}
.dashboard-head::after,
.dashboard-hero::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.08);
}
.dashboard-head > *,
.dashboard-hero > *{
  position:relative;
  z-index:1;
}
.hero-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:.8rem;
  flex-wrap:wrap;
}
.hero-eyebrow,
.dashboard-kicker{
  margin:0;
  color:#98b0cb;
  font-size:.72rem;
  letter-spacing:.13em;
  text-transform:uppercase;
  font-family:"Manrope",system-ui,sans-serif;
}
.hero-title{
  margin:.18rem 0 .14rem;
  color:#f5f9ff;
  font-size:clamp(1.32rem,2.2vw,1.82rem);
  line-height:1.16;
}
.hero-desc{
  margin:0;
  color:#b8c8dc;
  font-size:.94rem;
}
.hero-chip{
  border-radius:999px;
  border:1px solid rgba(255,255,255,.28);
  background:rgba(16,26,43,.78);
  color:#e8f3ff;
  padding:.3rem .78rem;
  font-size:.74rem;
  letter-spacing:.07em;
  text-transform:uppercase;
  font-weight:800;
  white-space:nowrap;
}
.hero-kpis,
.metricas{
  margin-top:.76rem;
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:.54rem;
}
.hero-kpi,
.metrica{
  min-height:auto;
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;
  background:rgba(9,16,30,.72);
  padding:.5rem .6rem;
  box-shadow:none;
}
.metrica::before{ display:none; }
.hero-kpi-k,
.metrica span{
  display:block;
  color:#9fb2ca;
  font-size:.66rem;
  text-transform:uppercase;
  letter-spacing:.09em;
  line-height:1.05;
}
.hero-kpi-v,
.metrica strong{
  display:block;
  margin-top:.14rem;
  color:#f7fcff;
  font-weight:800;
  font-size:1.04rem;
  line-height:1.1;
}
.hero-actions{
  margin-top:.68rem;
  display:flex;
  gap:.48rem;
  flex-wrap:wrap;
}

.cards-grid,
.quick-actions{
  display:grid;
  gap:.84rem;
  grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
}
.status-card,
.quick-action{
  position:relative;
  overflow:hidden;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.14);
  background:
    radial-gradient(120% 120% at 100% 0%, rgba(42,210,255,.14), transparent 58%),
    linear-gradient(145deg, rgba(8,13,24,.96), rgba(7,11,19,.95));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    0 16px 30px rgba(0,0,0,.50);
  color:#eff6ff;
  padding:.82rem .86rem;
  text-decoration:none;
  display:block;
  min-height:152px;
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.status-card:hover,
.quick-action:hover{
  transform:translateY(-3px);
  border-color:rgba(255,255,255,.28);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.10),
    0 24px 42px rgba(0,0,0,.62);
  color:#fff;
}
.status-card.warn{ border-color:rgba(255,159,65,.56); box-shadow:inset 0 1px 0 rgba(255,255,255,.08), 0 16px 30px rgba(0,0,0,.50), 0 0 0 1px rgba(255,159,65,.18); }
.status-card.ok{ border-color:rgba(25,199,133,.56); box-shadow:inset 0 1px 0 rgba(255,255,255,.08), 0 16px 30px rgba(0,0,0,.50), 0 0 0 1px rgba(25,199,133,.18); }
.status-card.danger{ border-color:rgba(255,95,116,.56); box-shadow:inset 0 1px 0 rgba(255,255,255,.08), 0 16px 30px rgba(0,0,0,.50), 0 0 0 1px rgba(255,95,116,.18); }
.status-card.info{ border-color:rgba(56,189,248,.56); box-shadow:inset 0 1px 0 rgba(255,255,255,.08), 0 16px 30px rgba(0,0,0,.50), 0 0 0 1px rgba(56,189,248,.18); }
.status-card.primary{ border-color:rgba(90,168,255,.56); box-shadow:inset 0 1px 0 rgba(255,255,255,.08), 0 16px 30px rgba(0,0,0,.50), 0 0 0 1px rgba(90,168,255,.18); }
.card-k{
  display:block;
  color:#aebfd4;
  font-size:.7rem;
  text-transform:uppercase;
  letter-spacing:.1em;
  line-height:1.05;
}
.card-v{
  display:block;
  margin-top:.24rem;
  color:#f7fcff;
  font-weight:800;
  font-size:1.7rem;
  line-height:1.08;
}
.quick-action span{
  display:block;
  margin-top:.24rem;
  color:#f7fcff;
  font-weight:800;
  font-size:1.35rem;
  line-height:1.08;
}
.card-desc{
  margin-top:.5rem;
  color:#c8d7ea;
  font-size:.84rem;
  line-height:1.3;
}
.card-cta,
.quick-action strong{
  display:block;
  margin-top:.52rem;
  color:#b5d7ff;
  font-size:.82rem;
  font-weight:700;
  letter-spacing:.02em;
}
.summary-card,
.notice-panel,
.feature-card{
  border:1px solid rgba(255,255,255,.14);
  border-radius:16px;
  background:
    radial-gradient(120% 120% at 100% 0%, rgba(42,210,255,.14), transparent 58%),
    linear-gradient(145deg, rgba(8,13,24,.96), rgba(7,11,19,.95));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08), 0 16px 30px rgba(0,0,0,.50);
  color:#eff6ff;
  padding:.86rem .9rem;
  margin:.86rem 0;
}
.summary-card--warn{ border-color:rgba(255,159,65,.42); }
.summary-card--info{ border-color:rgba(56,189,248,.42); }
.jornada-activa-card{ border-color:rgba(25,199,133,.46); }
.summary-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:.6rem;
  flex-wrap:wrap;
}
.summary-title{
  margin:0;
  font-size:1rem;
  color:#f7fbff;
}
.summary-sub{
  margin:.2rem 0 0;
  color:#aac0d8;
  font-size:.82rem;
}
.jornada-activa-grid{
  margin-top:.72rem;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:.62rem;
}
.jornada-activa-grid > div{
  border:1px solid rgba(255,255,255,.12);
  border-radius:10px;
  background:rgba(8,14,26,.72);
  padding:.6rem .68rem;
}
.jornada-activa-label{
  display:block;
  color:#9fb2ca;
  font-size:.68rem;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.jornada-activa-timer{
  display:block;
  margin-top:.22rem;
  color:#f7fbff;
  font-family:"Space Grotesk", system-ui, sans-serif;
  font-size:1.75rem;
  line-height:1.05;
}
.jornada-activa-timer--pausa{ color:#ffd98a; }
.status-grid{
  margin-top:.58rem;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:.44rem;
}
.status-pill{
  display:block;
  border:1px solid rgba(255,255,255,.18);
  border-radius:10px;
  background:rgba(8,14,26,.72);
  padding:.34rem .46rem;
  color:#eff6ff;
}
.status-label{
  display:block;
  color:#9fb2ca;
  font-size:.64rem;
  letter-spacing:.09em;
  text-transform:uppercase;
}
.status-val{
  display:block;
  margin-top:.1rem;
  color:#f7fbff;
  font-weight:800;
  font-size:1rem;
}
.transfer-list{
  display:grid;
  gap:.44rem;
  margin-top:.58rem;
}
.transfer-row{
  display:flex;
  justify-content:space-between;
  gap:.7rem;
  border:1px solid rgba(255,255,255,.12);
  border-radius:10px;
  background:rgba(255,255,255,.03);
  color:#d5e4f7;
  padding:.5rem .58rem;
  font-size:.82rem;
}

.btn, .sq-btn, .btn-mini{
  border-radius:10px;
}
.btn-primary{
  background:linear-gradient(145deg, rgba(90,168,255,.82), rgba(47,111,210,.82));
  border-color:rgba(181,215,255,.72);
}
.tabla tbody tr:hover, .table tbody tr:hover{
  background:rgba(90,168,255,.07);
}

@media (max-width:980px){
  .planificador-head{
    display:grid;
    grid-template-columns:1fr;
  }
  .planificador-estado{
    align-items:flex-start;
  }
}

@media (max-width:700px){
  .calendario-planificador{
    grid-template-columns:1fr;
  }
  .asignacion-card__top,
  .asignacion-card__tools{
    align-items:stretch;
    flex-direction:column;
  }
  .asignacion-edit-grid,
  .planificador-add-grid{
    grid-template-columns:1fr;
  }
  .resource-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width:1020px){
  .hero-kpis,
  .metricas{ grid-template-columns:repeat(3,minmax(0,1fr)); }
  .status-grid{ grid-template-columns:repeat(2,minmax(0,1fr)); }
}
@media (max-width:991.98px){
  .contenido{ margin-left:0; }
}
@media (max-width:700px){
  .dashboard-hero,
  .dashboard-head{ border-radius:16px; padding:.9rem; }
  .hero-kpis,
  .metricas{ grid-template-columns:repeat(2,minmax(0,1fr)); }
  .status-grid{ grid-template-columns:1fr; }
  .card-v{ font-size:1.35rem; }
}
