/* Template modal & template button styles moved from Mapping view */
.ab-btn-template { background:#fff; border:2px solid #0a61ff; color:#0a61ff; font-size:.85rem; font-weight:500; padding:.35rem 1.05rem; border-radius:8px; line-height:1.1; display:inline-flex; align-items:center; gap:.4rem; cursor:pointer; }
.ab-btn-template:hover { background:#0a61ff; color:#fff; }
.ab-btn-template-selected { background:#0a61ff; color:#fff; }
.ab-btn-template-selected i { margin-left:.25rem; }

.ab-template-modal-backdrop { 
  position:fixed; 
  inset:0; 
  background:rgba(0,0,0,.45); 
  display:none; 
  align-items:flex-start; 
  justify-content:center; 
  overflow:auto; 
  z-index:1050; 
  padding:20px 10px;
}
.ab-template-modal-backdrop.show { display:flex; }

.ab-template-modal { 
  background:#fff; 
  width:min(680px, 94%); 
  max-width:94%; 
  margin:auto; 
  border-radius:10px; 
  box-shadow:0 8px 28px rgba(0,0,0,.16); 
  display:flex; 
  flex-direction:column; 
  font-size:.9rem; 
  position:relative; 
  max-height:calc(100vh - 40px); 
}

.ab-template-modal-header { 
  padding:16px 22px 12px; 
  border-bottom:1px solid #e4e7ea; 
  display:flex; 
  align-items:center; 
  justify-content:space-between; 
  flex-shrink:0;
}
.ab-template-modal-header h6 { 
  margin:0; 
  font-weight:600; 
  font-size:1.05rem; 
}
.ab-template-modal-close { 
  background:transparent; 
  border:none; 
  font-size:1.2rem; 
  line-height:1; 
  cursor:pointer; 
  color:#495057; 
}

.ab-template-toolbar { 
  padding:14px 22px 8px; 
  display:flex; 
  align-items:center; 
  gap:10px; 
  flex-shrink:0;
  flex-wrap:wrap;
  position:relative;
}
.ab-template-search { 
  position:relative; 
  flex:1 1 200px; 
  min-width:180px;
}
.ab-template-search input { 
  width:100%; 
  padding:9px 12px 9px 34px; 
  border:1px solid #d1d5db; 
  border-radius:8px; 
  font-size:.84rem; 
  background:#fff; 
}
.ab-template-search input:focus { 
  outline:none; 
  border-color:#1a73e8; 
  box-shadow:0 0 0 2px rgba(26,115,232,.25); 
}
.ab-template-search i { 
  position:absolute; 
  left:10px; 
  top:50%; 
  transform:translateY(-50%); 
  color:#6b7280; 
  font-size:.88rem; 
}

.ab-template-sort-btn { 
  background:#fff; 
  color:#1a73e8; 
  border:1px solid #d1d5db; 
  padding:8px 10px; 
  border-radius:8px; 
  display:inline-flex; 
  align-items:center; 
  justify-content:center; 
  cursor:pointer; 
  font-size:.84rem;
}
.ab-template-sort-btn:hover { background:#f1f5f9; }

.ab-template-sort-panel { 
  position:absolute; 
  top:calc(100% + 4px); 
  right:22px; 
  width:220px; 
  background:#fff; 
  border:1px solid #d1d5db; 
  box-shadow:0 6px 22px rgba(0,0,0,.13); 
  border-radius:10px; 
  padding:12px 14px 16px; 
  z-index:1100; 
  display:none; 
}
.ab-template-sort-panel.show { display:block; }
.ab-template-sort-panel h6 { 
  font-size:.64rem; 
  letter-spacing:.52px; 
  text-transform:uppercase; 
  font-weight:700; 
  margin:0 0 6px; 
  color:#6b7280; 
}
.ab-template-sort-panel select { 
  width:100%; 
  margin-bottom:10px; 
  font-size:.75rem; 
  padding:5px 7px; 
}
.ab-template-sort-panel .ab-apply-sort { width:100%; }

.ab-template-list { 
  list-style:none; 
  margin:0; 
  padding:4px 22px 0; 
  flex:1 1 auto; 
  overflow:auto; 
  min-height:0; 
}

.ab-template-item { 
  position:relative; 
  background:#fff; 
  border:1px solid #e5e7eb; 
  border-radius:12px; 
  padding:12px 16px; 
  margin-bottom:12px; 
  cursor:pointer; 
  display:flex; 
  flex-direction:column; 
  gap:4px; 
  transition:border-color .15s, background-color .15s; 
}
.ab-template-item:hover { border-color:#d0d5db; }
.ab-template-item.active { 
  border-color:#1a73e8; 
  background:#e8f3ff; 
}

.ab-template-date-label { 
  font-size:.62rem; 
  letter-spacing:.48px; 
  text-transform:uppercase; 
  font-weight:600; 
  color:#6b7280; 
}
.ab-template-name { 
  font-weight:600; 
  font-size:.92rem; 
  color:#1f2937; 
}
.ab-template-opened { 
  font-size:.7rem; 
  color:#6b7280; 
}
.ab-template-opened .ab-time-link { 
  color:#1a73e8; 
  text-decoration:none; 
  cursor:default; 
}

.ab-template-actions-btn { 
  position:absolute; 
  top:12px; 
  right:12px; 
  background:transparent; 
  border:none; 
  color:#6b7280; 
  padding:4px 6px; 
  border-radius:6px; 
  cursor:pointer; 
}
.ab-template-actions-btn:hover { 
  background:#eef2f5; 
  color:#374151; 
}

.ab-template-menu { 
  position:absolute; 
  top:36px; 
  right:8px; 
  background:#fff; 
  border:1px solid #d1d5db; 
  border-radius:9px; 
  box-shadow:0 6px 20px rgba(0,0,0,.14); 
  min-width:160px; 
  font-size:.74rem; 
  z-index:50; 
  display:none; 
}
.ab-template-menu.show { display:block; }
.ab-template-menu button { 
  background:transparent; 
  border:none; 
  width:100%; 
  text-align:left; 
  padding:7px 12px; 
  cursor:pointer; 
  font-size:.72rem; 
}
.ab-template-menu button:hover { background:#f5f7fa; }

.ab-template-rename-inline { 
  display:flex; 
  gap:5px; 
  padding:7px 9px 9px; 
}
.ab-template-rename-inline input { 
  flex:1 1 auto; 
  font-size:.7rem; 
  padding:4px 6px; 
  border:1px solid #d1d5db; 
  border-radius:6px; 
}
.ab-template-rename-inline input:focus { 
  outline:none; 
  border-color:#1a73e8; 
  box-shadow:0 0 0 2px rgba(26,115,232,.25); 
}
.ab-template-rename-inline .btn-primary { 
  background:#1a73e8; 
  border-color:#1a73e8; 
}
.ab-template-rename-inline .btn-primary:hover { 
  background:#1663c7; 
  border-color:#1663c7; 
}

.ab-template-empty { 
  padding:30px 24px; 
  font-size:.8rem; 
  color:#6b7280; 
}

.ab-template-modal-footer { 
  padding:14px 22px; 
  border-top:1px solid #e4e7ea; 
  display:flex; 
  justify-content:space-between; 
  align-items:center; 
  flex-shrink:0;
}

.ab-btn-cancel { 
  background:transparent; 
  border:none; 
  color:#1a73e8; 
  font-weight:500; 
  cursor:pointer; 
  font-size:.88rem;
}
.ab-btn-cancel:hover { text-decoration:underline; }

.ab-btn-use { 
  background:#1a73e8; 
  color:#fff; 
  border:none; 
  border-radius:8px; 
  font-weight:500; 
  padding:8px 18px; 
  font-size:.88rem;
}
.ab-btn-use:disabled { 
  opacity:.5; 
  cursor:not-allowed; 
}

/* Responsive adjustments for template modals */
@media (max-width: 1200px) {
  .ab-template-modal { 
    width:min(640px, 96%); 
  }
  .ab-template-modal-header, .ab-template-toolbar, .ab-template-modal-footer { 
    padding-left:18px; 
    padding-right:18px; 
  }
  .ab-template-list { padding:4px 18px 0; }
}

@media (max-width: 992px) {
  .ab-template-modal-backdrop { padding:15px 8px; }
  .ab-template-modal { 
    width:min(580px, 96%); 
    max-height:calc(100vh - 30px); 
  }
  .ab-template-modal-header h6 { font-size:1rem; }
  .ab-template-toolbar { 
    padding:12px 16px 8px; 
    gap:8px; 
  }
  .ab-template-list { padding:4px 16px 0; }
  .ab-template-modal-footer { padding:12px 16px; }
}

@media (max-width: 768px) {
  .ab-template-modal-backdrop { padding:10px 6px; }
  .ab-template-modal { 
    width:98%; 
    max-height:calc(100vh - 20px); 
    border-radius:8px; 
  }
  .ab-template-modal-header { 
    padding:12px 14px 10px; 
  }
  .ab-template-modal-header h6 { font-size:.96rem; }
  .ab-template-toolbar { 
    padding:10px 14px 6px; 
    flex-direction:column; 
  }
  .ab-template-search { 
    width:100%; 
    flex:1 1 100%; 
  }
  .ab-template-list { padding:4px 12px 0; }
  .ab-template-item { 
    padding:10px 14px; 
    margin-bottom:10px; 
  }
  .ab-template-modal-footer { 
    padding:10px 14px; 
    flex-direction:column; 
    gap:8px; 
  }
  .ab-template-modal-footer button { 
    width:100%; 
  }
}

@media (max-width: 576px) {
  .ab-template-modal-backdrop { padding:8px 4px; }
  .ab-template-modal { 
    width:100%; 
    max-height:calc(100vh - 16px); 
    border-radius:6px; 
    font-size:.86rem; 
  }
  .ab-template-modal-header { padding:10px 12px 8px; }
  .ab-template-modal-header h6 { font-size:.92rem; }
  .ab-template-toolbar { padding:8px 12px 6px; }
  .ab-template-search input { 
    padding:7px 10px 7px 30px; 
    font-size:.82rem; 
  }
  .ab-template-list { padding:4px 10px 0; }
  .ab-template-item { 
    padding:8px 12px; 
    margin-bottom:8px; 
  }
  .ab-template-name { font-size:.88rem; }
  .ab-template-modal-footer { padding:8px 12px; }
  .ab-btn-use, .ab-btn-cancel { font-size:.84rem; }
}
