/* OXOForms Templates page theme overrides and UI */
:root {
  --oxo-primary: var(--primary);
  --oxo-accent: #a78bfa;
  --oxo-neutral: var(--bg-elev);
  --oxo-radius: 18px;
  --oxo-shadow: var(--shadow);
}

.templates-hero { text-align:center; }
.templates-hero .headline-xl { font-weight: 900; letter-spacing: -0.035em; }
.templates-hero .controls { display:grid; gap: 12px; justify-items:center; margin-top: 16px; }
.search-label input { width: min(900px, 100%); padding: 14px 16px; border-radius: 999px; border:1px solid var(--border); background: var(--oxo-neutral); color: var(--text); box-shadow: var(--oxo-shadow); }
.search-label input:focus { outline: 2px solid color-mix(in srgb, var(--oxo-primary), transparent 70%); }
.filters { display:flex; flex-wrap:wrap; gap: 10px; justify-content:center; }
.pill { border-radius: 999px; padding: 8px 12px; border:1px solid var(--border); background: var(--oxo-neutral); color: var(--text); cursor:pointer; transition: background .2s, color .2s, border-color .2s; }
.pill[aria-pressed="true"] { background: var(--oxo-primary); color: var(--primary-ink); border-color: transparent; font-weight: 800; }
.pill:focus { outline: 2px solid color-mix(in srgb, var(--oxo-primary), transparent 70%); }
.clear-filters.small { padding: 8px 12px; border-radius: 999px; }

.utilbar { display:flex; align-items:center; justify-content: space-between; gap: 12px; margin-bottom: 12px; }
.utilbar .left { display:flex; align-items:center; gap: 10px; }
.toggle { display:inline-flex; background: var(--oxo-neutral); border-radius: 999px; border:1px solid var(--border); }
.toggle-btn { padding: 8px 12px; border:0; background: transparent; color: var(--text); border-radius: 999px; cursor:pointer; }
.toggle-btn[aria-pressed="true"] { background: var(--oxo-primary); color: var(--primary-ink); font-weight: 800; }
.select { padding: 10px 12px; border-radius: 12px; border:1px solid var(--border); background: var(--oxo-neutral); color: var(--text); }

.templates-grid { display:grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.templates-grid.list { grid-template-columns: 1fr; }
.template-card { display:grid; grid-template-columns: 1fr; gap: 12px; border:1px solid var(--border); border-radius: var(--oxo-radius); background: var(--oxo-neutral); box-shadow: var(--oxo-shadow); padding: 14px; }
.template-card.list { grid-template-columns: 140px 1fr; align-items: center; }
.template-thumb { width: 100%; height: 140px; border-radius: 12px; border:1px solid var(--border); background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02)); object-fit: cover; }
.template-meta { display:grid; gap: 6px; }
.template-title { margin: 0; font-size: 1.1rem; font-weight: 800; }
.template-desc { margin: 0; color: var(--muted); }
.badges { display:flex; gap: 8px; flex-wrap:wrap; }
.badge { display:inline-flex; align-items:center; gap:6px; padding: 4px 10px; border-radius: 999px; border:1px solid var(--border); color: var(--text); background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02)); font-size: .8rem; font-weight: 700; }
.badge--cat { border-color: color-mix(in srgb, var(--oxo-primary), var(--border) 70%); color: var(--oxo-primary); }
.badge--new { color: #10b981; border-color: #065f46; }
.badge--popular { color: #f59e0b; border-color: #7c2d12; }
.template-actions { display:flex; gap: 10px; align-items:center; }
.template-actions .btn { padding: 10px 14px; }
.preview-link { color: var(--muted); text-decoration: underline; cursor:pointer; }

.preview { position: fixed; inset: 0; display:none; }
.preview[aria-hidden="false"] { display:block; }
.preview__backdrop { position:absolute; inset:0; background: rgba(0,0,0,.5); }
.preview__panel { position:absolute; right:0; top:0; bottom:0; width: min(720px, 100%); border-radius: 0; overflow:auto; box-shadow: var(--oxo-shadow); }
.preview__close { position:absolute; top: 8px; right: 12px; border:0; background: transparent; color: var(--text); font-size: 24px; cursor: pointer; }
.preview__body { display:grid; grid-template-columns: 1fr; gap: 16px; padding-top: 28px; }
.preview__media img { width: 100%; height: 240px; object-fit: cover; border-radius: 12px; border:1px solid var(--border); background: #0d0e13; }
.preview__content h2 { margin: 0 0 8px; }
.fields, .features { padding-left: 18px; color: var(--muted); }

.seo h2 { margin-top: 0; }

/* Accessibility */
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

/* Responsive */
@media (max-width: 1200px) {
  .templates-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 900px) {
  .utilbar { flex-wrap: wrap; }
  .templates-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .templates-grid { grid-template-columns: 1fr; }
  .template-card.list { grid-template-columns: 100px 1fr; }
}
