/* ============================================================
   LandingSky Public Styles v1.3.0
   ============================================================ */

:root {
  --ls-primary:   #000;
  --ls-primary-h: #4C4C4C;
  --ls-danger:    #dc2626;
  --ls-success:   #16a34a;
  --ls-warning:   #d97706;
  --ls-text:      #111827;
  --ls-muted:     #6b7280;
  --ls-border:    #e5e7eb;
  --ls-bg:        #f9fafb;
  --ls-card-bg:   #ffffff;
  --ls-radius:    10px;
  --ls-shadow:    0 1px 3px rgba(0,0,0,.08);
  --ls-shadow-lg: 0 8px 24px rgba(0,0,0,.10);
}

.ls-templates-wrap *,
.ls-templates-grid *,
.ls-card *,
.ls-single-template *,
.ls-archive-page *,
.ls-myaccount *,
.ls-plan-selector * {
  box-sizing: border-box;
}

/* ============================================================
   RESULTS HEADER (count + filter dropdown + sort dropdown)
   ============================================================ */
.ls-results-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
  flex-wrap: wrap;
  gap: 10px;
}
.ls-results-count {
  font-size: 13.5px;
  color: var(--ls-muted);
  margin: 0;
}
.ls-results-count strong { color: var(--ls-text); }

.ls-header-controls {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.ls-sort-wrap {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--ls-muted);
  background: #fff;
  border: 1px solid var(--ls-border);
  border-radius: 7px;
  padding: 0 10px 0 12px;
  height: 34px;
}
.ls-sort-wrap label {
    white-space: nowrap;
    font-weight: 500;
    flex-shrink: 0;
    margin: 0 !important;
}
.ls-sort-select {
  border: none;
  outline: none;
  padding: 0 18px 0 0;
  font-size: 13px;
  color: var(--ls-text);
  font-weight: 600;
  background: transparent url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236b7280'/%3E%3C/svg%3E") no-repeat right 2px center;
  appearance: none;
  cursor: pointer;
  height: 100%;
}
.ls-sort-wrap:focus-within {
  border-color: var(--ls-primary);
  box-shadow: 0 0 0 3px rgba(37,99,235,.08);
}

/* ============================================================
   TEMPLATE GRID
   ============================================================ */
.ls-templates-wrap { width: 100%; }

.ls-templates-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

@media (max-width: 1024px) {
  .ls-templates-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 700px) {
  .ls-templates-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
}
@media (max-width: 420px) {
  .ls-templates-grid { grid-template-columns: 1fr; }
}

/* ── Template card ──────────────────────────────────────── */
.ls-card {
  background: var(--ls-card-bg);
  border: 1px solid var(--ls-border);
  border-radius: var(--ls-radius);
  overflow: hidden;
  transition: box-shadow .2s ease, transform .2s ease;
  cursor: pointer;
}
.ls-card:hover {
  box-shadow: var(--ls-shadow-lg);
  transform: translateY(-2px);
}

.ls-card__thumb {
  position: relative;
  aspect-ratio: 4 / 3;
  background: #ebebeb;
  overflow: hidden;
}
.ls-card__thumb a {
  display: block;
  height: 100%;
}
.ls-card__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .3s ease;
    object-position: top;
}
.ls-card:hover .ls-card__thumb img { transform: scale(1.03); }

.ls-card__thumb-placeholder {
  width: 100%;
  height: 100%;
  background: #dde6f0;
}

.ls-card__pro-badge {
    background: #5154e5;
    color: #fff;
    font-size: 9px !important;
    font-weight: 600;
    letter-spacing: .6px;
    padding: 3px 7px;
    border-radius: 4px;
    text-transform: uppercase;
}

.ls-card__thumb .ls-card__pro-badge {
    position: absolute;
    right: 8px;
    top: 8px;
}

.ls-card__thumb .ls-card__pro-badg {
    display: block;
    position: absolute;
    top: 9px;
    right: 9px;
}

.ls-card__body {
  padding: 12px 14px 14px;
}
.ls-card__name {
    margin: 0 0 4px;
    font-size: 16px !important;
    font-weight: 600 !important;
    line-height: 1.35 !important;
    color: var(--ls-text) !important;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    letter-spacing: -0.2px !important;
}
.ls-card__name a {
  color: inherit;
  text-decoration: none;
}
.ls-card__name a:hover { color: var(--ls-primary); }

.ls-card__cat {
  font-size: 12px;
  color: var(--ls-muted);
  margin: 0;
}
.ls-card__cat a {
  color: var(--ls-muted);
  text-decoration: none;
}
.ls-card__cat a:hover { color: var(--ls-primary); text-decoration: underline; }

/* ── Shimmer skeleton loader ─────────────────────────────── */
@keyframes ls-shimmer {
  0%   { background-position: -200% 0; }
  100% { background-position:  200% 0; }
}

.ls-shimmer-box,
.ls-shimmer-line {
  background: linear-gradient(
    90deg,
    #ebebeb 25%,
    #d8d8d8 37%,
    #ebebeb 63%
  );
  background-size: 400% 100%;
  animation: ls-shimmer 1.6s ease-in-out infinite;
  animation-delay: var(--sk-delay, 0s);
}

/* Skeleton card overrides */
.ls-card-skeleton {
  pointer-events: none;
}
.ls-card-skeleton .ls-card__thumb {
  background: none;
  display: block;
}
.ls-card-skeleton .ls-card__thumb .ls-shimmer-box {
  display: block;
  width: 100%;
  height: 100%;
}
.ls-shimmer-line {
  border-radius: 4px;
  display: block;
}
.ls-shimmer-line--title {
  height: 14px;
  width: 70%;
  margin-bottom: 8px;
}
.ls-shimmer-line--sub {
  height: 11px;
  width: 42%;
}

/* ── Clear filters button ────────────────────────────────── */
.ls-clear-filters {
    display: inline-flex !important;
    align-items: center;
    gap: 5px;
    font-size: 12.5px !important;
    font-weight: 500 !important;
    color: var(--ls-muted) !important;
    background: none !important;
    border-radius: 7px !important;
    padding: 0 5px !important;
    height: 34px;
    cursor: pointer !important;
    white-space: nowrap !important;
    transition: color .15s, border-color .15s !important;
}
.ls-clear-filters:hover {
  color: var(--ls-danger);
  border-color: #fca5a5;
}
.ls-clear-filters svg {
    flex-shrink: 0;
    width: 8px;
    height: 8px;
}
/* ── Empty state ────────────────────────────────────────── */
.ls-empty-state {
  text-align: center;
  padding: 60px 20px;
  color: var(--ls-muted);
  font-size: 15px;
}

/* ── Pagination ─────────────────────────────────────────── */
.ls-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  margin-top: 40px;
  flex-wrap: wrap;
}
.ls-page-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    height: 36px;
    padding: 0 10px;
    border: 1px solid var(--ls-border);
    border-radius: 6px;
    background: #fff;
    color: var(--ls-text) !important;
    font-size: 13px;
    text-decoration: none !important;
    transition: all .15s;
}
.ls-page-btn:hover { border-color: var(--ls-primary); color: var(--ls-primary); }
.ls-page-btn--active {
    background: var(--ls-primary);
    color: #fff !important;
    border-color: var(--ls-primary);
}
.ls-page-ellipsis { padding: 0 4px; color: var(--ls-muted); font-size: 14px; }

/* ============================================================
   SINGLE TEMPLATE PAGE
   ============================================================ */
.ls-single-template {
  max-width: 1160px;
  margin: 0 auto;
  padding: 28px 20px 72px;
}

/* Breadcrumb */
.ls-breadcrumb {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--ls-muted);
  margin-bottom: 22px;
  flex-wrap: wrap;
}
.ls-breadcrumb a { color: var(--ls-primary); text-decoration: none; }
.ls-breadcrumb a:hover { text-decoration: underline; }
.ls-breadcrumb__sep { color: #d1d5db; }

/* Two-column layout */
.ls-single-template__layout {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 36px;
  align-items: start;
  margin-bottom: 48px;
}
@media (max-width: 860px) {
  .ls-single-template__layout {
    grid-template-columns: 1fr;
  }
}

/* Left: preview + title */
.ls-template-hero-img {
    position: relative;
    border-radius: var(--ls-radius);
    overflow: hidden;
    border: 1px solid var(--ls-border);
    background: #dde6f0;
    margin-bottom: 20px;
}
.ls-template-hero-img img {
    width: 100%;
    display: block;
}
.ls-template-hero-img__placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  color: var(--ls-muted);
  font-size: 14px;
}

.ls-template-title {
    font-size: 28px !important;
    font-weight: 600 !important;
    color: var(--ls-text) !important;
    margin: 0 0 10px;
    line-height: 1.25 !important;
}

.ls-template-subtitle {
  font-size: 13px;
  color: var(--ls-muted);
  margin: 0 0 16px;
}
.ls-template-subtitle a {
  color: var(--ls-primary);
  text-decoration: none;
}
.ls-template-subtitle a:hover { text-decoration: underline; }

.ls-preview-link {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: 1px solid rgba(255,255,255,.6);
  border-radius: 7px;
  padding: 7px 13px;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--ls-text);
  text-decoration: none;
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  box-shadow: 0 1px 6px rgba(0,0,0,.12);
  transition: background .15s, color .15s, box-shadow .15s;
}
.ls-preview-link:hover {
  background: #fff;
  color: var(--ls-primary);
  box-shadow: 0 2px 10px rgba(0,0,0,.16);
}

/* Tags */
.ls-tags { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 28px; }
.ls-tag {
  display: inline-block;
  background: var(--ls-bg);
  border: 1px solid var(--ls-border);
  border-radius: 20px;
  padding: 4px 13px;
  font-size: 12px;
  color: var(--ls-muted);
  text-decoration: none;
}
.ls-tag:hover { border-color: var(--ls-primary); color: var(--ls-primary); background: #eff6ff; }

/* ── Right sidebar ──────────────────────────────────────── */
.ls-single-template__sidebar {
  position: sticky;
  top: 20px;
}

/* ── Product info table ─────────────────────────────────── */
.ls-product-info {
  border: 1px solid var(--ls-border);
  border-radius: var(--ls-radius);
  overflow: hidden;
  margin-top: 20px;
}
.ls-product-info__heading {
  font-size: 13px;
  font-weight: 600;
  color: var(--ls-text);
  padding: 11px 14px;
  border-bottom: 1px solid var(--ls-border);
  margin: 0;
  background: var(--ls-bg);
}
.ls-product-info table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12.5px;
  margin: 0;
}
.ls-product-info td {
  padding: 7px 14px;
  line-height: 1.4;
  border: none;
  vertical-align: top;
}
.ls-product-info td:first-child {
  color: var(--ls-muted);
  font-weight: 500;
  width: 48%;
}
.ls-product-info td:last-child {
  color: var(--ls-text);
  font-weight: 500;
}

/* ── Description section ────────────────────────────────── */
.ls-description-section {
  margin-bottom: 48px;
}
.ls-description-heading {
    font-size: 20px !important;
    font-weight: 600 !important;
    color: var(--ls-text) !important;
    margin: 0 0 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--ls-border);
    letter-spacing: -0.52px !important;
}

.ls-overview {
  font-size: 15px;
  line-height: 1.75;
  color: #374151;
}
.ls-overview p:first-child { margin-top: 0; }
.ls-overview p:last-child { margin-bottom: 0; }

/* ── "You may like this" carousel ───────────────────────── */
.ls-carousel {
  margin-top: 56px;
}
.ls-carousel__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
}
.ls-carousel__title {
    font-size: 20px !important;
    font-weight: 600 !important;
    color: var(--ls-text) !important;
    margin: 0;
}
.ls-carousel__nav { display: flex; gap: 8px; }
.ls-carousel__btn {
    width: 38px;
    height: 38px;
    border: 1.5px solid var(--ls-border);
    border-radius: 50% !important;
    background: #fff !important;
    cursor: pointer !important;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ls-text) !important;
    box-shadow: 0 1px 4px rgba(0,0,0,.07);
    transition: border-color .15s, background .15s, color .15s, box-shadow .15s, transform .1s;
    flex-shrink: 0;
    padding: 0 !important;
    line-height: 1 !important;
}
.ls-carousel__btn:hover {
  border-color: var(--ls-primary);
  background: #eff6ff;
  color: var(--ls-primary);
  box-shadow: 0 2px 8px rgba(37,99,235,.15);
  transform: scale(1.06);
}
.ls-carousel__btn:active { transform: scale(.96); }
.ls-carousel__btn:disabled {
  opacity: .35;
  cursor: not-allowed;
  pointer-events: none;
  border-color: var(--ls-border);
  background: #fff;
  color: var(--ls-muted);
  box-shadow: none;
  transform: none;
}

.ls-carousel__track-wrap {
  overflow: hidden;
}
.ls-carousel__track {
  display: flex;
  gap: 20px;
  transition: transform .3s ease;
}
.ls-carousel__track .ls-card {
  flex: 0 0 calc(25% - 15px);
  min-width: 0;
}
@media (max-width: 900px) {
  .ls-carousel__track .ls-card { flex: 0 0 calc(33.33% - 14px); }
}
@media (max-width: 640px) {
  .ls-carousel__track .ls-card { flex: 0 0 calc(50% - 10px); }
}

/* ============================================================
   PLAN SELECTOR (radio style)
   ============================================================ */
.ls-plan-selector {
  background: #fff;
  border: 1px solid var(--ls-border);
  border-radius: var(--ls-radius);
  overflow: hidden;
}

.ls-plan-options {
  border-bottom: 1px solid var(--ls-border);
}

.ls-plan-option {
  border-bottom: 1px solid var(--ls-border);
}
.ls-plan-option:last-child { border-bottom: none; }

.ls-plan-radio-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
  cursor: pointer;
  user-select: none;
}
.ls-plan-radio-row input[type="radio"] {
  margin: 0;
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  accent-color: var(--ls-primary);
  cursor: pointer;
}

.ls-plan-radio-name {
  flex: 1;
  font-size: 14px;
  font-weight: 600;
  color: var(--ls-text);
  display: flex;
  align-items: center;
  gap: 7px;
}

.ls-plan-popular-badge {
  background: #fef3c7;
  color: #92400e;
  font-size: 10px;
  font-weight: 600;
  padding: 2px 7px;
  border-radius: 10px;
  letter-spacing: .2px;
}

.ls-plan-radio-price {
  font-size: 13px;
  font-weight: 600;
  color: var(--ls-text);
  white-space: nowrap;
  margin-left: auto;
}

.ls-plan-option__features {
  display: none;
  list-style: none;
  margin: 0;
  padding: 0 16px 14px 42px;
}
.ls-plan-option--selected .ls-plan-option__features { display: block; }
.ls-plan-option__features li {
  font-size: 13px;
  color: #374151;
  padding: 3px 0;
  display: flex;
  align-items: flex-start;
  gap: 7px;
}
.ls-plan-option__features li::before {
  content: '✓';
  color: var(--ls-success);
  font-weight: 600;
  flex-shrink: 0;
  margin-top: 1px;
}

.ls-plan-actions {
  padding: 16px;
}

.ls-add-to-cart-btn {
  display: block;
  width: 100%;
  padding: 13px 20px;
  background: #111827;
  color: #fff;
  border: none;
  border-radius: 8px;
  font-size: 14.5px;
  font-weight: 600;
  cursor: pointer;
  text-align: center;
  transition: background .15s, transform .1s;
}
.ls-add-to-cart-btn:hover { background: #1f2937; }
.ls-add-to-cart-btn:active { transform: scale(.98); }
.ls-add-to-cart-btn.ls-loading {
  opacity: .7;
  pointer-events: none;
}

/* ============================================================
   POPUP / MODAL
   ============================================================ */
.ls-popup-overlay {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: rgba(0,0,0,.55);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.ls-popup {
  background: #fff;
  border-radius: 14px;
  padding: 32px;
  max-width: 440px;
  width: 100%;
  position: relative;
  box-shadow: var(--ls-shadow-lg);
  animation: ls-popup-in .2s ease;
}
@keyframes ls-popup-in {
  from { opacity: 0; transform: scale(.95) translateY(10px); }
  to   { opacity: 1; transform: scale(1)  translateY(0); }
}
.ls-popup--confirm { max-width: 500px; }

.ls-popup__close {
  position: absolute;
  top: 14px;
  right: 16px;
  background: none;
  border: none;
  font-size: 20px;
  cursor: pointer;
  color: var(--ls-muted);
  padding: 4px;
  line-height: 1;
  border-radius: 4px;
}
.ls-popup__close:hover { color: var(--ls-text); background: var(--ls-bg); }

.ls-popup h3 { margin: 0 0 12px; font-size: 18px; color: var(--ls-text); }
.ls-popup p  { margin: 0 0 12px; font-size: 14px; color: #374151; line-height: 1.6; }

.ls-popup__steps {
  padding-left: 18px;
  margin: 12px 0 20px;
  font-size: 13.5px;
  color: #374151;
  line-height: 1.8;
}
.ls-popup__warnings ul {
  padding-left: 18px;
  margin: 8px 0 20px;
  font-size: 13.5px;
  color: #374151;
  line-height: 1.75;
}
.ls-popup__warnings li { margin-bottom: 6px; }
.ls-popup__footnote { font-size: 12px; color: var(--ls-muted); margin-top: 12px; }
.ls-popup__actions { display: flex; gap: 10px; flex-wrap: wrap; }

/* ============================================================
   ARCHIVE PAGE (category / tag)
   ============================================================ */
.ls-archive-page {
  max-width: 1160px;
  margin: 0 auto;
  padding: 28px 20px 72px;
}

.ls-archive-header { margin-bottom: 24px; }
.ls-archive-title {
    font-size: 28px !important;
    font-weight: 600 !important;
    color: var(--ls-text) !important;
    margin: 0 0 12px;
}
.ls-archive-desc { font-size: 14px; color: var(--ls-muted); margin: 0 0 6px; }

/* ============================================================
   BUTTONS (global)
   ============================================================ */
.ls-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px 20px;
  border-radius: 7px;
  border: 1.5px solid transparent;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  transition: all .15s;
  line-height: 1;
  vertical-align: middle;
}
.ls-btn--primary {
  background: var(--ls-primary);
  color: #fff !important;
  border-color: var(--ls-primary);
}
.ls-btn--primary:hover { background: var(--ls-primary-h); border-color: var(--ls-primary-h); color: #fff; }
.ls-btn--secondary {
  background: var(--ls-bg);
  color: var(--ls-text);
  border-color: var(--ls-border);
}
.ls-btn--secondary:hover { border-color: #9ca3af; }
.ls-btn--danger {
  background: var(--ls-danger);
  color: #fff;
  border-color: var(--ls-danger);
}
.ls-btn--danger:hover { background: #b91c1c; }
.ls-btn--danger-outline {
  background: #fff;
  color: var(--ls-danger);
  border-color: #fca5a5;
}
.ls-btn--danger-outline:hover { background: #fef2f2; }
.ls-btn--sm { padding: 6px 12px; font-size: 12px; }

/* ============================================================
   MY ACCOUNT — Subscription & Support
   ============================================================ */
.ls-myaccount { max-width: 760px; }

.ls-myaccount__title {
    font-size: 22px !important;
    font-weight: 600 !important;
    margin: 0 0 20px;
    color: var(--ls-text) !important;
    letter-spacing: -0.2px !important;
}
.ls-myaccount__desc { font-size: 14px; color: var(--ls-muted); margin-bottom: 24px; }

.ls-sub-card {
  background: #fff;
  border: 1px solid var(--ls-border);
  border-radius: var(--ls-radius);
  margin-bottom: 20px;
  overflow: hidden;
}
.ls-sub-card--upgrade {
  background: #eff6ff;
  border-color: #bfdbfe;
  padding: 20px 24px;
}
.ls-sub-card--upgrade p { margin: 0 0 10px; font-size: 14px; }

.ls-sub-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--ls-border);
}
.ls-sub-card__header h3 {
    margin: 0;
    font-size: 18px !important;
    font-weight: 600 !important;
    color: var(--ls-text) !important;
    letter-spacing: -0.2px !important;
}
.ls-sub-card__grid { padding: 12px 0; }
.ls-sub-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 9px 20px;
  font-size: 14px;
  border-bottom: 1px solid #f9fafb;
}
.ls-sub-row:last-child { border-bottom: none; }
.ls-sub-label { color: var(--ls-muted); font-weight: 500; }
.ls-sub-value { font-weight: 600; color: var(--ls-text); }

.ls-status-active   { color: var(--ls-success); }
.ls-status-expired  { color: var(--ls-danger); }
.ls-status-cancelled { color: var(--ls-muted); }
.ls-status-on_hold  { color: var(--ls-warning); }

.ls-license-key-display {
  padding: 14px 20px;
  background: var(--ls-bg);
  border-bottom: 1px solid var(--ls-border);
}
.ls-license-key-display code {
  font-size: 13.5px;
  letter-spacing: .6px;
  word-break: break-all;
  color: var(--ls-text);
  font-family: 'Courier New', Courier, monospace;
}
.ls-sub-hint {
  padding: 10px 20px;
  font-size: 12.5px;
  color: var(--ls-muted);
  margin: 0;
  border-bottom: 1px solid var(--ls-border);
}

.ls-key-change {
  padding: 14px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
}
.ls-key-change__info { font-size: 13px; color: var(--ls-muted); display: flex; flex-direction: column; gap: 2px; }
.ls-key-change__remaining { color: var(--ls-success); font-size: 12px; }
.ls-key-change__exhausted { color: var(--ls-danger); font-size: 12px; }

.ls-sites-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.ls-sites-table thead { background: var(--ls-bg); }
.ls-sites-table th {
  padding: 10px 20px;
  text-align: left;
  font-weight: 600;
  color: var(--ls-muted);
  font-size: 12px;
  border-bottom: 1px solid var(--ls-border);
}
.ls-sites-table td {
  padding: 10px 20px;
  border-bottom: 1px solid #f9fafb;
  font-size: 13px;
}
.ls-sites-table a { color: var(--ls-primary); text-decoration: none; }
.ls-sites-table a:hover { text-decoration: underline; }

.ls-status-badge {
  display: inline-block;
  padding: 2px 9px;
  border-radius: 12px;
  font-size: 11px;
  font-weight: 600;
}
.ls-status-badge--active   { background: #dcfce7; color: #15803d; }
.ls-status-badge--disabled { background: #fee2e2; color: #b91c1c; }

/* ── Notices ─────────────────────────────────────────────── */
.ls-notice {
  padding: 14px 18px;
  border-radius: 8px;
  font-size: 14px;
  margin-bottom: 20px;
  border-left: 4px solid;
}
.ls-notice--success { background: #f0fdf4; border-color: var(--ls-success); color: #166534; }
.ls-notice--warning { background: #fffbeb; border-color: var(--ls-warning); color: #92400e; }
.ls-notice--info    { background: #eff6ff; border-color: var(--ls-primary); color: #1e40af; }
.ls-notice a { color: inherit; font-weight: 600; }

/* ── Support form ─────────────────────────────────────────── */
.ls-form { max-width: 100%; }
.ls-form__row--2col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
@media (max-width: 600px) { .ls-form__row--2col { grid-template-columns: 1fr; } }

.ls-form__group { margin-bottom: 18px; }
.ls-form__group label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--ls-text);
  margin-bottom: 6px;
}
.ls-form__group input,
.ls-form__group select,
.ls-form__group textarea {
  width: 100%;
  padding: 9px 12px;
  border: 1.5px solid var(--ls-border);
  border-radius: 7px;
  font-size: 14px;
  color: var(--ls-text);
  background: #fff;
  transition: border-color .15s;
  font-family: inherit;
}
.ls-form__group input:focus,
.ls-form__group select:focus,
.ls-form__group textarea:focus {
  outline: none;
  border-color: var(--ls-primary);
  box-shadow: 0 0 0 3px rgba(37,99,235,.1);
}
.ls-form__group textarea { resize: vertical; }
.ls-form__actions { display: flex; align-items: center; gap: 14px; margin-top: 8px; }
.ls-form__status { font-size: 13px; }

/* ── Copy key button feedback ────────────────────────────── */
.ls-copy-key-btn.ls-copied { background: #dcfce7; color: #15803d; border-color: #86efac; }

/* ============================================================
   THANK YOU PAGE
   ============================================================ */
.ls-thankyou {
  background: #fff;
  border: 1px solid var(--ls-border);
  border-radius: 16px;
  padding: 48px 40px 40px;
  max-width: 600px;
  margin: 0 auto 40px;
  text-align: center;
  box-shadow: 0 4px 24px rgba(0,0,0,.06);
}
@media (max-width: 640px) {
  .ls-thankyou { padding: 36px 24px 32px; }
}

.ls-thankyou__check {
  margin: 0 auto 20px;
  width: 64px;
  height: 64px;
}
.ls-thankyou__check svg { width: 64px; height: 64px; display: block; }

.ls-thankyou__heading {
  font-size: 26px;
  font-weight: 600;
  color: var(--ls-text);
  margin: 0 0 8px;
}
.ls-thankyou__sub {
  font-size: 15px;
  color: var(--ls-muted);
  margin: 0 0 28px;
  line-height: 1.6;
}

.ls-thankyou__details {
  background: var(--ls-bg);
  border: 1px solid var(--ls-border);
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 28px;
  text-align: left;
}
.ls-thankyou__detail-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 11px 18px;
  border-bottom: 1px solid var(--ls-border);
  font-size: 13.5px;
  gap: 12px;
}
.ls-thankyou__detail-row:last-child { border-bottom: none; }
.ls-thankyou__detail-row--key { flex-wrap: wrap; gap: 8px; }

.ls-thankyou__detail-label {
  color: var(--ls-muted);
  font-weight: 500;
  flex-shrink: 0;
}
.ls-thankyou__detail-value {
  color: var(--ls-text);
  font-weight: 600;
}

.ls-thankyou__key-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.ls-thankyou__key-wrap code {
  font-family: 'Courier New', Courier, monospace;
  font-size: 12.5px;
  letter-spacing: .5px;
  word-break: break-all;
  color: var(--ls-text);
  font-weight: 400;
}
.ls-thankyou__copy-btn {
  background: #fff;
  border: 1px solid var(--ls-border);
  border-radius: 5px;
  padding: 3px 10px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  color: var(--ls-text);
  transition: border-color .15s, background .15s;
  white-space: nowrap;
  flex-shrink: 0;
}
.ls-thankyou__copy-btn:hover { border-color: var(--ls-primary); color: var(--ls-primary); }

.ls-thankyou__plan-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 5px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .3px;
  text-transform: uppercase;
}
.ls-thankyou__plan-badge--pro    { background: #ede9fe; color: #6d28d9; }
.ls-thankyou__plan-badge--agency { background: #fef3c7; color: #92400e; }

.ls-thankyou__steps {
  background: #f0fdf4;
  border: 1px solid #bbf7d0;
  border-radius: 10px;
  padding: 20px 22px;
  text-align: left;
  margin-bottom: 24px;
}
.ls-thankyou__steps h3 {
  font-size: 14px;
  font-weight: 600;
  color: #166534;
  margin: 0 0 12px;
}
.ls-thankyou__steps ol {
  margin: 0;
  padding-left: 20px;
  font-size: 13.5px;
  color: #374151;
  line-height: 1;
}
.ls-thankyou__steps li {
  margin-bottom: 10px;
  line-height: 1.55;
}
.ls-thankyou__steps li:last-child { margin-bottom: 0; }
.ls-thankyou__steps a {
  color: var(--ls-primary);
  text-decoration: none;
  font-weight: 500;
}
.ls-thankyou__steps a:hover { text-decoration: underline; }

.ls-thankyou__actions {
  display: flex;
  gap: 10px;
  justify-content: center;
  flex-wrap: wrap;
}

/* Badges (admin context) */
.lsapi-badge       { background: #e0e7ff; color: #3730a3; }
.lsapi-badge-pro   { background: #f3e8ff; color: #7c3aed; }
.lsapi-badge-agency { background: #fef3c7; color: #92400e; }
.lsapi-badge-free  { background: #d1fae5; color: #065f46; }

/* ── Plan badges (public) ────────────────────────────────── */
.ls-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 5px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .3px;
  text-transform: uppercase;
  vertical-align: middle;
}
.ls-badge--pro    { background: #ede9fe; color: #6d28d9; }
.ls-badge--agency { background: #fef3c7; color: #92400e; }
.ls-badge--free   { background: #d1fae5; color: #065f46; }

/* ── Outline button variant ──────────────────────────────── */
.ls-btn--outline {
  background: #fff;
  color: var(--ls-text);
  border-color: var(--ls-border);
}
.ls-btn--outline:hover { border-color: var(--ls-primary); color: var(--ls-primary); background: #eff6ff; }

/* ── Order status pills ──────────────────────────────────── */
.ls-order-status {
  display: inline-block;
  padding: 2px 9px;
  border-radius: 12px;
  font-size: 11.5px;
  font-weight: 600;
}
.ls-order-status--completed  { background: #dcfce7; color: #15803d; }
.ls-order-status--processing { background: #dbeafe; color: #1d4ed8; }
.ls-order-status--pending    { background: #fef9c3; color: #a16207; }
.ls-order-status--cancelled  { background: #f3f4f6; color: #6b7280; }
.ls-order-status--failed     { background: #fee2e2; color: #b91c1c; }
.ls-order-status--refunded   { background: #fce7f3; color: #9d174d; }
.ls-order-status--on-hold    { background: #fef3c7; color: #92400e; }

/* ============================================================
   MY ACCOUNT DASHBOARD (Task 4)
   ============================================================ */
.ls-dashboard-content { max-width: 760px; margin-top: 28px; }

.ls-dashboard-section { margin-bottom: 32px; }

.ls-dashboard-heading {
    font-size: 20px !important;
    font-weight: 600 !important;
    color: var(--ls-text) !important;
    margin: 0 0 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--ls-border);
    letter-spacing: -0.2px !important;
}

.ls-dashboard-empty {
  font-size: 14px;
  color: var(--ls-muted);
  margin: 0;
}

.ls-dashboard-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13.5px;
  background: #fff;
  border: 1px solid var(--ls-border);
  border-radius: var(--ls-radius);
  overflow: hidden;
}
.ls-dashboard-table thead { background: var(--ls-bg); }
.ls-dashboard-table th {
  padding: 10px 14px;
  text-align: left;
  font-weight: 600;
  font-size: 12px;
  color: var(--ls-muted);
  border-bottom: 1px solid var(--ls-border);
  white-space: nowrap;
}
.ls-dashboard-table td {
  padding: 11px 14px;
  border-bottom: 1px solid #f3f4f6;
  vertical-align: middle;
}
.ls-dashboard-table tbody tr:last-child td { border-bottom: none; }
.ls-dashboard-table a { color: var(--ls-primary); text-decoration: none; font-weight: 500; }
.ls-dashboard-table a:hover { text-decoration: underline; }

/* ── Licenses table (subscription page) ─────────────────── */
.ls-licenses-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13.5px;
}
.ls-licenses-table thead { background: var(--ls-bg); }
.ls-licenses-table th {
  padding: 10px 20px;
  text-align: left;
  font-weight: 600;
  font-size: 12px;
  color: var(--ls-muted);
  border-bottom: 1px solid var(--ls-border);
  white-space: nowrap;
}
.ls-licenses-table td {
  padding: 12px 20px;
  border-bottom: 1px solid #f3f4f6;
  vertical-align: middle;
}
.ls-licenses-table tbody tr:last-child td { border-bottom: none; }

/* ── Short key display ───────────────────────────────────── */
.ls-key-short {
  font-family: 'Courier New', Courier, monospace;
  font-size: 12px;
  color: var(--ls-muted);
  letter-spacing: .4px;
}

/* ── License detail popup ────────────────────────────────── */
.ls-popup--license { max-width: 520px; }

.ls-license-popup-body { padding-top: 4px; }

.ls-license-popup__meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}

/* ============================================================
   DOWNLOADS PAGE (Task 6)
   ============================================================ */
.ls-downloads-page { max-width: 680px; }

.ls-plugin-download-card {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  background: #fff;
  border: 1px solid var(--ls-border);
  border-radius: var(--ls-radius);
  padding: 24px;
  box-shadow: var(--ls-shadow);
}
@media (max-width: 640px) {
  .ls-plugin-download-card { flex-direction: column; }
}

.ls-plugin-download-card__icon {
  flex-shrink: 0;
  width: 52px;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #eff6ff;
  border-radius: 12px;
}

.ls-plugin-download-card__body { flex: 1; min-width: 0; }

.ls-plugin-download-card__title {
    font-size: 20px !important;
    font-weight: 600 !important;
    color: var(--ls-text) !important;
    margin: 0 0 10px;
    letter-spacing: -0.2px !important;
}

.ls-plugin-download-card__desc {
  font-size: 13.5px;
  color: var(--ls-muted);
  margin: 0 0 12px;
  line-height: 1.6;
}

.ls-plugin-download-card__steps {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  font-size: 12.5px;
  color: #374151;
}
.ls-plugin-download-card__sep { color: #9ca3af; }

.ls-plugin-download-card__action {
  flex-shrink: 0;
  text-align: center;
}
.ls-plugin-download-card__note {
  font-size: 11.5px;
  color: var(--ls-muted);
  margin: 8px 0 0;
  white-space: nowrap;
}

/* ============================================================
   SINGLE TEMPLATE — Plugin Download Box (Task 7)
   ============================================================ */
.ls-plugin-download-box {
    display: flex;
    gap: 12px;
    margin-top: 16px;
    padding: 14px 16px;
    background: #fafafa;
    border: 1px solid #dfdfdf;
    border-radius: var(--ls-radius);
    flex-direction: column;
    align-items: center;
}

.ls-plugin-download-box__icon {
    flex-shrink: 0;
    width: 38px;
    height: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #2563EB;
    border-radius: 10px;
    box-shadow: 0 0 #0000, 0 0 #0000, 0 10px 15px -3px #bfdbfe, 0 4px 6px -4px #bfdbfe;
}

.ls-plugin-download-box__content {
    flex: 1;
    min-width: 0;
    text-align: center;
    margin-bottom: 8px;
}

.ls-plugin-download-box__title {
    font-size: 20px;
    font-weight: 600;
    color: #000000;
    margin: 0 0 6px;
}

.ls-plugin-download-box__desc {
    font-size: 15px;
    color: #65676a;
    margin: 0;
    line-height: 1.4;
}

.ls-plugin-download-box__btn {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 7px 14px;
    background: var(--ls-primary) !important;
    color: #fff !important;
    border-radius: 7px;
    font-size: 12.5px;
    font-weight: 600;
    text-decoration: none;
    transition: background .15s;
    white-space: nowrap;
    width: max-content;
}
.ls-plugin-download-box__btn:hover { background: var(--ls-primary-h); color: #fff; }

.ls-carousel__btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.woocommerce-account .woocommerce .woocommerce-EditAccountForm fieldset {
    padding: 0 !important;
    border: none !important;
}
.woocommerce-account h2 {
    text-align: center;
    font-size: 20px !important;
    letter-spacing: -0.2px !important;
}