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

:root{
  --bg:#f1f5f9;
  --card:#ffffff;
  --primary:#172554;
  --primary2:#1e3a8a;
  --primary3:#2563eb;
  --text:#0f172a;
  --muted:#64748b;
  --border:#e2e8f0;
  --soft:#f8fafc;
  --success:#dcfce7;
  --warning:#fffbeb;
  --shadow:0 10px 30px rgba(15,23,42,.07);
  --shadow-soft:0 4px 16px rgba(15,23,42,.055);
  --radius:20px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
  background:var(--bg);
  color:var(--text);
  font-size:15px;
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
.hidden{display:none!important}

/* LOGIN */
.login-screen{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:32px;
  background:linear-gradient(135deg,#eef2ff 0%,#f8fafc 45%,#e0f2fe 100%);
}
.login-card{
  background:rgba(255,255,255,.96);
  border:1px solid rgba(226,232,240,.9);
  border-radius:26px;
  padding:36px;
  width:100%;
  max-width:440px;
  text-align:center;
  box-shadow:0 24px 70px rgba(15,23,42,.14);
  backdrop-filter:blur(10px);
}
.logo{
  margin:0 auto 14px;
  width:68px;
  height:68px;
  background:var(--primary2);
  color:white;
  border-radius:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:35px;
  font-weight:800;
  box-shadow:0 12px 26px rgba(30,58,138,.25);
}
.login-card h1{margin:0;font-size:25px;letter-spacing:-.025em;font-weight:800}
.login-card p{margin:7px 0 22px;color:var(--muted)}
.login-card input{
  width:100%;
  padding:14px 15px;
  margin-top:12px;
  border-radius:14px;
  border:1px solid #cbd5e1;
  font-size:15px;
  outline:none;
  transition:.2s;
}
.login-card small{display:block;margin-top:16px;color:var(--muted);font-size:12px}
input:focus,select:focus{
  border-color:#3b82f6;
  box-shadow:0 0 0 4px rgba(59,130,246,.12);
}

/* BOTONES */
button{
  background:var(--primary2);
  color:white;
  border:0;
  padding:12px 16px;
  border-radius:14px;
  font-weight:700;
  font-size:14px;
  cursor:pointer;
  box-shadow:0 6px 14px rgba(30,58,138,.12);
  transition:.16s ease;
}
button:hover{transform:translateY(-1px);filter:brightness(1.04)}
button:active{transform:translateY(0)}
.secondary{
  background:white;
  color:var(--primary);
  box-shadow:none;
}

/* HEADER */
header{
  background:var(--primary);
  color:white;
  padding:16px 26px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  box-shadow:0 10px 28px rgba(15,23,42,.16);
}
header h1{
  margin:0;
  font-size:21px;
  font-weight:800;
  letter-spacing:-.02em;
}
header p{
  margin:3px 0 0;
  color:#bfdbfe;
  font-size:13px;
}
.header-right{
  display:flex;
  gap:14px;
  align-items:center;
}
.clock{
  min-width:190px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;
  padding:8px 14px;
  text-align:right;
  font-size:21px;
  line-height:1.05;
  font-weight:800;
  letter-spacing:.03em;
}
.clock small{
  color:#bfdbfe;
  font-size:11px;
  font-weight:500;
  letter-spacing:0;
}

/* LAYOUT */
.layout{
  display:grid;
  grid-template-columns:240px 1fr;
  gap:24px;
  padding:24px;
}
aside{
  display:flex;
  flex-direction:column;
  gap:9px;
}
.nav{
  background:white;
  color:#334155;
  text-align:left;
  display:flex;
  align-items:center;
  gap:10px;
  min-height:46px;
  padding:12px 15px;
  border-radius:14px;
  box-shadow:var(--shadow-soft);
  font-size:14px;
  font-weight:700;
}
.nav:hover{background:#f8fafc;color:#0f172a}
.nav.active{
  background:var(--primary2);
  color:white;
  box-shadow:0 12px 24px rgba(30,58,138,.22);
}

/* MAIN */
main{min-width:0}
.stats{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
  margin-bottom:20px;
}
.stat{
  background:white;
  border:1px solid rgba(226,232,240,.95);
  border-radius:20px;
  padding:18px 20px;
  box-shadow:var(--shadow-soft);
}
.stat span{
  display:block;
  color:var(--muted);
  font-size:13px;
  font-weight:500;
  margin-bottom:5px;
}
.stat b{
  font-size:27px;
  letter-spacing:-.035em;
  font-weight:800;
}
.card{
  background:white;
  border:1px solid rgba(226,232,240,.95);
  border-radius:22px;
  padding:24px;
  box-shadow:var(--shadow);
}
.card h2{
  margin:0 0 16px;
  font-size:21px;
  font-weight:800;
  letter-spacing:-.025em;
}
.card h3{
  margin-top:0;
  font-size:16px;
  font-weight:800;
}
.card p{color:#475569}

/* FORMULARIOS */
.form-grid{
  display:grid;
  grid-template-columns:1fr 1fr 240px;
  gap:14px;
  margin:18px 0;
}
.form-grid.two{grid-template-columns:1fr 170px}
input,select{
  padding:13px 14px;
  border:1px solid #cbd5e1;
  border-radius:14px;
  outline:none;
  font-size:15px;
  background:white;
  color:#0f172a;
}
label{
  display:block;
  color:#475569;
  font-size:13px;
  font-weight:700;
  margin-bottom:5px;
}
.camera-box{
  border:1.5px dashed #cbd5e1;
  padding:30px;
  border-radius:20px;
  text-align:center;
  color:#64748b;
  background:#f8fafc;
  margin-top:20px;
}

/* TABLAS */
table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  background:white;
  border:1px solid var(--border);
  border-radius:18px;
  overflow:hidden;
  font-size:14px;
}
th,td{
  padding:13px 14px;
  border-bottom:1px solid #edf2f7;
  text-align:left;
  vertical-align:middle;
}
tr:last-child td{border-bottom:0}
th{
  background:#f8fafc;
  color:#64748b;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.04em;
  font-weight:800;
}
td b{font-weight:800}

/* TICKETS */
.ticket{
  background:white;
  border:1px solid #cbd5e1;
  max-width:370px;
  margin:24px auto;
  padding:17px;
  font-family:"Courier New", monospace;
  font-size:13px;
  border-radius:16px;
  box-shadow:var(--shadow-soft);
}
.ticket h3{
  text-align:center;
  margin:0;
  font-size:16px;
  letter-spacing:.02em;
}
.ticket p{
  text-align:center;
  margin:4px 0;
  color:#334155;
}
.ticket hr{
  border:0;
  border-top:1px dashed #94a3b8;
  margin:10px 0;
}
.line{
  display:flex;
  justify-content:space-between;
  gap:14px;
  padding:3px 0;
}
.center{text-align:center!important}

/* REPORTES */
.space-between{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  margin-bottom:18px;
}
.report-submenu{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  background:#f8fafc;
  border:1px solid #e2e8f0;
  border-radius:18px;
  padding:12px;
  margin:18px 0 14px;
}
.report-btn{
  background:white;
  color:#334155;
  border:1px solid #e2e8f0;
  box-shadow:none;
}
.report-btn.active{
  background:#1e3a8a;
  color:white;
  border-color:#1e3a8a;
  box-shadow:0 10px 20px rgba(30,58,138,.18);
}
.report-filters{margin-bottom:18px}
.report-filter-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
  background:#f8fafc;
  border:1px solid #e2e8f0;
  border-radius:18px;
  padding:16px;
}
.report-filter-grid.one{grid-template-columns:1fr}

/* TARIFAS / USUARIOS */
.rate-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
.rate-grid>div{
  border:1px solid #e2e8f0;
  border-radius:20px;
  padding:18px;
  background:#fff;
}
.rate-grid input{width:100%;margin:2px 0 13px}
.notice{
  background:#fffbeb;
  color:#92400e!important;
  padding:14px 16px;
  border:1px solid #fde68a;
  border-radius:16px;
  font-size:13px;
}
.user-form{
  display:grid;
  grid-template-columns:1.2fr 1fr 1fr 1fr;
  gap:14px;
  margin:18px 0;
}
.action-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.small-btn{
  padding:7px 10px;
  border-radius:10px;
  font-size:12px;
  box-shadow:none;
}
.small-btn.gray{background:#f1f5f9;color:#334155}
.small-btn.red{background:#fee2e2;color:#991b1b}
.role-select{
  padding:7px 10px;
  border-radius:10px;
  font-size:12px;
}

/* RESPONSIVE */
@media(max-width:1000px){
  .layout{grid-template-columns:1fr}
  aside{display:grid;grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr)}
  .form-grid,.form-grid.two{grid-template-columns:1fr}
  .rate-grid{grid-template-columns:1fr}
  header{align-items:flex-start;gap:14px;flex-direction:column}
}
@media(max-width:900px){
  .user-form{grid-template-columns:1fr}
}
@media(max-width:800px){
  .report-submenu{grid-template-columns:1fr 1fr}
  .report-filter-grid{grid-template-columns:1fr}
}
@media(max-width:640px){
  .stats{grid-template-columns:1fr}
  aside{grid-template-columns:1fr}
  .header-right{flex-wrap:wrap}
  .clock{min-width:160px;text-align:left}
}

/* IMPRESIÓN POS */
@media print{
  body{background:white}
  body *{visibility:hidden}
  .ticket,.ticket *{visibility:visible}
  .ticket{
    position:absolute;
    left:0;
    top:0;
    margin:0;
    box-shadow:none;
    border:0;
    border-radius:0;
    width:300px;
    max-width:300px;
    padding:8px;
    font-size:12px;
  }
  .app header,.layout aside,.stats,.card>h2,.form-grid,.camera-box,.space-between button{display:none!important}
}
.entry-grid{grid-template-columns:1fr 1fr 1.2fr 240px}
.ticket-rule{
  border:1px solid #e2e8f0;
  border-radius:10px;
  padding:7px;
  font-size:11px;
  line-height:1.25;
  margin:8px 0!important;
}
@media(max-width:1000px){.entry-grid{grid-template-columns:1fr}}

.small-note{font-size:12px!important;padding:10px!important;margin-top:8px!important}

.subscription-form{
  display:grid;
  grid-template-columns:1fr 1fr 1.2fr 1fr 1fr;
  gap:14px;
  margin:18px 0;
}
.auth-box{
  background:#eff6ff;
  color:#1e3a8a;
  border:1px solid #bfdbfe;
  border-radius:14px;
  padding:12px;
  margin:12px 0;
  font-weight:700;
}
@media(max-width:1000px){.subscription-form{grid-template-columns:1fr}}



/* ===== Mejora visual profesional Cachorros 1 ===== */
:root{
  --primary:#0f2f6e;
  --primary2:#1e40af;
  --primary3:#2563eb;
  --bg:#eef3f8;
  --card:#ffffff;
  --text:#0f172a;
  --muted:#64748b;
  --border:#e2e8f0;
  --shadow:0 16px 38px rgba(15,23,42,.08);
  --shadow-soft:0 8px 22px rgba(15,23,42,.06);
}

body{
  background:
    radial-gradient(circle at top left, rgba(37,99,235,.10), transparent 34%),
    linear-gradient(180deg,#f8fafc 0%,#eef3f8 100%);
  font-family:Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
}

header{
  background:linear-gradient(135deg,#0f2f6e 0%,#172554 55%,#0f172a 100%);
  border-bottom:1px solid rgba(255,255,255,.08);
}

header h1{
  font-size:22px;
  letter-spacing:-.03em;
}

header::before{
  content:"";
  width:44px;
  height:44px;
  border-radius:16px;
  background:rgba(255,255,255,.10);
  position:absolute;
  display:none;
}

.logo{
  background:linear-gradient(135deg,#1e40af,#2563eb);
  box-shadow:0 18px 34px rgba(37,99,235,.28);
}

.layout{
  align-items:start;
}

aside{
  position:sticky;
  top:18px;
}

.nav{
  position:relative;
  display:flex!important;
  align-items:center;
  gap:11px;
  min-height:48px;
  border:1px solid rgba(226,232,240,.92);
  background:rgba(255,255,255,.94);
  color:#334155;
  box-shadow:0 8px 20px rgba(15,23,42,.045);
  overflow:hidden;
}

.nav::before{
  content:"";
  position:absolute;
  left:0;
  top:10px;
  bottom:10px;
  width:4px;
  border-radius:99px;
  background:transparent;
}

.nav:hover{
  transform:translateY(-1px);
  background:#f8fafc;
}

.nav.active{
  background:linear-gradient(135deg,#1d4ed8,#1e3a8a);
  color:#fff;
  box-shadow:0 16px 30px rgba(30,64,175,.25);
  border-color:rgba(37,99,235,.8);
}

.nav.active::before{
  background:#93c5fd;
}

.nav-icon{
  width:26px;
  height:26px;
  border-radius:10px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:#eff6ff;
  color:#1e40af;
  font-weight:800;
  font-size:14px;
  flex:0 0 auto;
}

.nav.active .nav-icon{
  background:rgba(255,255,255,.18);
  color:#fff;
}

.card,.stat{
  border:1px solid rgba(226,232,240,.95);
  box-shadow:var(--shadow-soft);
}

.card{
  border-radius:24px;
}

.stat{
  position:relative;
  overflow:hidden;
}

.stat::after{
  content:"";
  position:absolute;
  right:-20px;
  top:-25px;
  width:72px;
  height:72px;
  border-radius:50%;
  background:rgba(37,99,235,.08);
}

.stat span{
  font-weight:650;
}

.stat b{
  color:#0f172a;
}

.dashboard-stats .stat:nth-child(1)::before{content:"🚗";font-size:24px;position:absolute;right:20px;bottom:18px}
.dashboard-stats .stat:nth-child(2)::before{content:"₡";font-size:28px;font-weight:800;position:absolute;right:24px;bottom:15px;color:#1e40af}
.dashboard-stats .stat:nth-child(3)::before{content:"✓";font-size:26px;position:absolute;right:22px;bottom:16px;color:#16a34a}
.dashboard-stats .stat:nth-child(4)::before{content:"⏱";font-size:24px;position:absolute;right:20px;bottom:18px}

table{
  border-radius:20px;
  box-shadow:0 8px 22px rgba(15,23,42,.035);
}

th{
  background:linear-gradient(180deg,#f8fafc,#f1f5f9);
  color:#475569;
}

tbody tr{
  transition:.14s ease;
}

tbody tr:hover{
  background:#f8fafc;
}

.plate-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:6px 11px;
  border-radius:10px;
  background:#0f172a;
  color:white;
  font-weight:800;
  letter-spacing:.04em;
  font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}

.vehicle-pill{
  display:inline-flex;
  align-items:center;
  gap:7px;
  background:#eff6ff;
  color:#1e3a8a;
  border:1px solid #bfdbfe;
  padding:6px 10px;
  border-radius:999px;
  font-weight:700;
}

.status-pill{
  display:inline-flex;
  align-items:center;
  background:#ecfdf5;
  color:#047857;
  border:1px solid #bbf7d0;
  padding:6px 10px;
  border-radius:999px;
  font-weight:700;
}

input,select{
  border-radius:14px;
  border-color:#cbd5e1;
  background:#fff;
}

button{
  border-radius:14px;
}

.report-btn.active{
  background:linear-gradient(135deg,#1d4ed8,#1e3a8a)!important;
}

.ticket{
  border-radius:18px;
}

/* Tarjetas de ingreso/salida más limpias */
.camera-box{
  background:linear-gradient(135deg,#f8fafc,#eff6ff);
}

/* Responsive refinado */
@media(max-width:1000px){
  aside{position:static}
}

.rtsp-box{
  display:grid;
  grid-template-columns:1fr 180px;
  gap:14px;
  align-items:end;
  background:#f8fafc;
  border:1px solid #e2e8f0;
  border-radius:18px;
  padding:16px;
  margin:18px 0;
}
.rtsp-box label{grid-column:1/-1}
.camera-preview{
  height:260px;
  border-radius:22px;
  background:linear-gradient(135deg,#0f172a,#1e293b);
  color:white;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  letter-spacing:.02em;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);
}
.backup-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  margin:18px 0;
}
.backup-card{
  background:#fff;
  border:1px solid #e2e8f0;
  border-radius:20px;
  padding:20px;
  box-shadow:0 8px 22px rgba(15,23,42,.04);
}
.backup-card h3{margin-top:0}
.backup-card input{width:100%;margin:12px 0}
@media(max-width:900px){
  .rtsp-box,.backup-grid{grid-template-columns:1fr}
}

.void-auth{
  display:grid;
  grid-template-columns:260px 1fr;
  gap:14px;
  background:#f8fafc;
  border:1px solid #e2e8f0;
  border-radius:18px;
  padding:16px;
  margin:18px 0;
}
@media(max-width:800px){.void-auth{grid-template-columns:1fr}}

.role-hidden,
.nav.role-hidden,
button.role-hidden{
  display:none!important;
  visibility:hidden!important;
}


/* Ticket identidad Cachorros 1 */
.ticket-business-name{
  font-size:22px!important;
  font-weight:900!important;
  text-align:center!important;
  letter-spacing:.06em!important;
  margin:0 0 6px!important;
}
.ticket-business-info{
  text-align:center!important;
  font-size:12px!important;
  margin:2px 0!important;
  color:#111827!important;
}
.ticket-warning{
  text-align:center!important;
  font-size:11px!important;
  line-height:1.25!important;
  font-weight:700!important;
  color:#111827!important;
  margin-top:8px!important;
}

iframe.print-helper{display:none!important;}
