/* ============================================================
   WEB DESIGN LABS — SitePad Builder CSS
   Deploy to: /templates/website/WebDesignLabs/css/builder.css
   ============================================================ */

/* ── MISSING CSS VARIABLE FALLBACKS (WiseCP doesn't set these) */
:root {
  --success:        #15803d;
  --warning-text:   #92400e;
  --success-bg:     #d1fae5;
  --border:         var(--border, #e2e8f0);
}

/* ── BUILDER PAGE HERO ────────────────────────────────────── */
.sp-hero { padding: clamp(2.5rem,5vw,4rem) 0; text-align: center;
  background: linear-gradient(160deg,var(--primary-light,#dbeafe) 0%,var(--bg,#fff) 65%);
  border-bottom: 1px solid var(--border,#e2e8f0); }
.sp-hero__eyebrow { font-family: var(--f-mono,monospace); font-size: .68rem;
  letter-spacing: .14em; text-transform: uppercase; color: var(--primary,#0066ff); margin-bottom: .6rem; }
.sp-hero__title { font-family: var(--f-display,sans-serif); font-size: clamp(1.75rem,4vw,2.6rem);
  font-weight: 800; line-height: 1.1; letter-spacing: -.02em; color: var(--text,#0f172a); margin-bottom: .75rem; }
.sp-hero__sub { font-size: .95rem; color: var(--text-muted,#64748b);
  max-width: 50ch; margin: 0 auto 1.5rem; line-height: 1.7; }

/* ── HOW IT WORKS STEPS ───────────────────────────────────── */
.sp-steps { display: grid; grid-template-columns: repeat(4,1fr); gap: 1px;
  background: var(--border,#e2e8f0); border: 1px solid var(--border,#e2e8f0);
  border-radius: var(--r-lg,12px); overflow: hidden; margin-bottom: 2.5rem; }
@media(max-width:640px){ .sp-steps { grid-template-columns: 1fr 1fr; } }
.sp-step { background: var(--bg,#fff); padding: 1.25rem; text-align: center; }
.sp-step__num { width: 30px; height: 30px; border-radius: 50%; background: var(--primary,#0066ff);
  color: #fff; font-family: var(--f-display,sans-serif); font-weight: 800; font-size: .85rem;
  display: flex; align-items: center; justify-content: center; margin: 0 auto .6rem; }
.sp-step__title { font-family: var(--f-display,sans-serif); font-weight: 700;
  font-size: .82rem; color: var(--text,#0f172a); margin-bottom: .2rem; }
.sp-step__desc { font-size: .7rem; color: var(--text-muted,#64748b); line-height: 1.4; }

/* ── CATEGORY FILTER TABS ─────────────────────────────────── */
.sp-cats { display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; margin-bottom: 1.75rem; }
.sp-cat { font-size: .78rem; font-weight: 500; padding: 6px 16px;
  border: 1.5px solid var(--border,#e2e8f0); border-radius: 99px;
  background: var(--bg,#fff); color: var(--text-muted,#64748b);
  cursor: pointer; transition: all .15s; white-space: nowrap; }
.sp-cat:hover { border-color: var(--primary,#0066ff); color: var(--primary,#0066ff); }
.sp-cat.active { background: var(--primary,#0066ff); border-color: var(--primary,#0066ff); color: #fff; }

/* ── THEME GRID ───────────────────────────────────────────── */
.sp-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(220px,1fr));
  gap: 1.25rem; margin-bottom: 2rem; }
.sp-card { border: 1.5px solid var(--border,#e2e8f0); border-radius: var(--r-lg,12px);
  overflow: hidden; cursor: pointer; transition: all .18s;
  background: var(--bg,#fff); position: relative; }
.sp-card:hover { border-color: var(--primary,#0066ff); box-shadow: 0 4px 20px rgba(0,0,0,.1); transform: translateY(-2px); }
.sp-card.active { border: 2.5px solid var(--primary,#0066ff);
  box-shadow: 0 0 0 3px rgba(0,102,255,.12); }

.sp-thumb { position: relative; height: 150px; overflow: hidden; background: var(--bg-soft,#f8fafd); }
.sp-thumb img { width: 100%; height: 100%; object-fit: cover; object-position: top center;
  display: block; transition: transform .4s ease; }
.sp-card:hover .sp-thumb img { transform: scale(1.04); }

.sp-thumb-overlay { position: absolute; inset: 0; display: flex; align-items: center;
  justify-content: center; background: rgba(0,0,0,.45); opacity: 0; transition: opacity .18s; }
.sp-card:hover .sp-thumb-overlay { opacity: 1; }
.sp-preview-btn { background: #fff; color: var(--text,#0f172a); font-size: .75rem; font-weight: 600;
  padding: 7px 16px; border-radius: var(--r-md,8px); border: none; cursor: pointer; }

.sp-check { position: absolute; top: 8px; right: 8px; width: 24px; height: 24px;
  border-radius: 50%; background: var(--primary,#0066ff); color: #fff;
  font-size: 12px; font-weight: 700; display: none; align-items: center; justify-content: center; }
.sp-card.active .sp-check { display: flex; }

.sp-card-body { padding: 10px 12px 12px; }
.sp-card-name { font-family: var(--f-display,sans-serif); font-weight: 700;
  font-size: .875rem; color: var(--text,#0f172a); margin-bottom: 3px; }
.sp-card-cat { font-size: .7rem; color: var(--text-muted,#64748b); text-transform: capitalize; }
.sp-card-actions { display: flex; gap: 6px; margin-top: 8px; }
.sp-card-actions a, .sp-card-actions button { font-size: .7rem; font-weight: 600;
  padding: 5px 10px; border-radius: var(--r-md,8px); cursor: pointer;
  transition: all .15s; text-decoration: none; border: none; }
.sp-btn-demo { background: var(--bg-soft,#f8fafd); color: var(--text-muted,#64748b);
  border: 1px solid var(--border,#e2e8f0) !important; }
.sp-btn-demo:hover { border-color: var(--primary,#0066ff) !important; color: var(--primary,#0066ff); }
.sp-btn-select { background: var(--primary,#0066ff); color: #fff; }
.sp-btn-select:hover { opacity: .88; }

/* ── DEMO LIGHTBOX ─────────────────────────────────────────── */
/* FIX: z-index 9999 to appear above WiseCP admin bar */
.sp-lightbox { position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,.82); display: none;
  align-items: center; justify-content: center; padding: 1rem; }
.sp-lightbox.open { display: flex; }
.sp-lightbox-inner { background: var(--bg,#fff); border-radius: var(--r-lg,12px);
  overflow: hidden; width: 100%; max-width: 1100px;
  height: 90vh; display: flex; flex-direction: column; }
.sp-lightbox-bar { display: flex; align-items: center; justify-content: space-between;
  padding: .75rem 1.25rem; border-bottom: 1px solid var(--border,#e2e8f0);
  background: var(--bg-soft,#f8fafd); flex-shrink: 0; }
.sp-lightbox-title { font-family: var(--f-display,sans-serif); font-weight: 700;
  font-size: .95rem; color: var(--text,#0f172a); }
.sp-lightbox-actions { display: flex; gap: 8px; align-items: center; }
.sp-lightbox-close { background: none; border: none; font-size: 1.4rem;
  color: var(--text-muted,#64748b); cursor: pointer; line-height: 1; padding: 0 4px; }
.sp-lightbox iframe { flex: 1; border: none; width: 100%; }

/* ── SELECTED THEME PANEL ─────────────────────────────────── */
.sp-selected-panel { background: var(--bg,#fff); border: 1.5px solid var(--primary,#0066ff);
  border-radius: var(--r-lg,12px); padding: 1.25rem 1.5rem; margin-bottom: 1.75rem; display: none; }
.sp-selected-panel.visible { display: flex; gap: 1rem; align-items: center; flex-wrap: wrap; }
.sp-selected-thumb { width: 80px; height: 55px; border-radius: var(--r-md,8px);
  overflow: hidden; flex-shrink: 0; border: 1px solid var(--border,#e2e8f0); }
.sp-selected-thumb img { width: 100%; height: 100%; object-fit: cover; object-position: top; }
.sp-selected-info { flex: 1; min-width: 140px; }
.sp-selected-label { font-size: .68rem; text-transform: uppercase; letter-spacing: .08em;
  color: var(--text-muted,#64748b); margin-bottom: 2px; }
.sp-selected-name { font-family: var(--f-display,sans-serif); font-weight: 700;
  font-size: 1rem; color: var(--text,#0f172a); }
.sp-selected-cat { font-size: .75rem; color: var(--text-muted,#64748b); }
.sp-selected-cta { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }

/* ── ORDER BRIDGE PAGE ────────────────────────────────────── */
.ob-wrap { max-width: 720px; margin: 0 auto; padding: clamp(2rem,4vw,3.5rem) 1rem; }
.ob-card { background: var(--bg,#fff); border: 1.5px solid var(--border,#e2e8f0);
  border-radius: var(--r-lg,12px); padding: 1.75rem 2rem; margin-bottom: 1.5rem; }
.ob-card h2 { font-family: var(--f-display,sans-serif); font-weight: 700;
  font-size: 1.1rem; color: var(--text,#0f172a); margin-bottom: 1.25rem;
  padding-bottom: .75rem; border-bottom: 1px solid var(--border,#e2e8f0); }
.ob-theme-row { display: flex; gap: 1rem; align-items: center;
  background: var(--bg-soft,#f8fafd); border-radius: var(--r-md,8px);
  padding: .875rem 1rem; margin-bottom: 1rem; }
.ob-theme-img { width: 70px; height: 48px; border-radius: 6px;
  overflow: hidden; flex-shrink: 0; border: 1px solid var(--border,#e2e8f0); }
.ob-theme-img img { width: 100%; height: 100%; object-fit: cover; object-position: top; }
.ob-theme-name { font-family: var(--f-display,sans-serif); font-weight: 700;
  font-size: .9rem; color: var(--text,#0f172a); }
.ob-theme-change { font-size: .75rem; color: var(--primary,#0066ff); cursor: pointer;
  text-decoration: underline; margin-top: 2px; background: none; border: none; padding: 0; }
.ob-domain-row { display: flex; gap: 8px; margin-bottom: .75rem; }
.ob-domain-input { flex: 1; padding: .65rem .9rem;
  border: 1.5px solid var(--border,#e2e8f0); border-radius: var(--r-md,8px);
  font-family: inherit; font-size: .9rem; color: var(--text,#0f172a);
  background: var(--bg,#fff); outline: none; transition: border-color .2s; }
.ob-domain-input:focus { border-color: var(--primary,#0066ff); }
.ob-tld-select { padding: .65rem .75rem; border: 1.5px solid var(--border,#e2e8f0);
  border-radius: var(--r-md,8px); font-size: .85rem; color: var(--text,#0f172a);
  background: var(--bg,#fff); cursor: pointer; outline: none; }
.ob-domain-note { font-size: .72rem; color: var(--text-muted,#64748b); }
.ob-plans { display: grid; grid-template-columns: repeat(3,1fr); gap: .75rem; }
@media(max-width:500px){ .ob-plans { grid-template-columns: 1fr; } }
.ob-plan { border: 1.5px solid var(--border,#e2e8f0); border-radius: var(--r-md,8px);
  padding: .875rem 1rem; cursor: pointer; transition: all .15s;
  position: relative; background: var(--bg,#fff); }
.ob-plan:hover { border-color: var(--primary,#0066ff); }
.ob-plan.selected { border-color: var(--primary,#0066ff);
  box-shadow: 0 0 0 2px rgba(0,102,255,.15); }
.ob-plan-popular { position: absolute; top: -1px; left: 50%; transform: translateX(-50%);
  background: var(--primary,#0066ff); color: #fff; font-size: .62rem; font-weight: 700;
  padding: 2px 10px; border-radius: 0 0 6px 6px; letter-spacing: .05em;
  text-transform: uppercase; white-space: nowrap; }
.ob-plan-name { font-family: var(--f-display,sans-serif); font-weight: 700;
  font-size: .85rem; color: var(--text,#0f172a); margin-bottom: 3px; margin-top: .3rem; }
.ob-plan-price { font-family: var(--f-display,sans-serif); font-size: 1.3rem;
  font-weight: 800; color: var(--primary,#0066ff); line-height: 1; }
.ob-plan-period { font-size: .68rem; color: var(--text-muted,#64748b); }
.ob-plan-features { margin-top: .6rem; padding-top: .6rem;
  border-top: 1px solid var(--border,#e2e8f0); display: flex; flex-direction: column; gap: 3px; }
.ob-plan-feat { font-size: .7rem; color: var(--text-muted,#64748b);
  display: flex; align-items: center; gap: 5px; }
.ob-plan-feat::before { content: '✓'; color: var(--primary,#0066ff); font-weight: 700; font-size: .65rem; }
.ob-summary { background: var(--bg-soft,#f8fafd); border-radius: var(--r-md,8px);
  padding: 1rem 1.25rem; margin-bottom: 1.25rem; }
.ob-summary-row { display: flex; justify-content: space-between;
  font-size: .82rem; padding: 4px 0; }
.ob-summary-row:last-child { border-top: 1px solid var(--border,#e2e8f0);
  margin-top: 6px; padding-top: 10px; font-family: var(--f-display,sans-serif);
  font-weight: 700; font-size: .95rem; color: var(--text,#0f172a); }
.ob-summary-label { color: var(--text-muted,#64748b); }
.ob-summary-val { color: var(--text,#0f172a); font-weight: 500; }
/* FIX 11: error box for order form */
.ob-error { display: none; background: #fee2e2; color: #991b1b;
  border: 1px solid #fecaca; border-radius: var(--r-md,8px);
  padding: .875rem 1rem; margin-bottom: 1rem; font-size: .85rem; }
.ob-error.visible { display: block; }
.ob-proceed { width: 100%; padding: .875rem; font-family: var(--f-display,sans-serif);
  font-weight: 700; font-size: 1rem; border-radius: var(--r-md,8px);
  background: var(--primary,#0066ff); color: #fff; border: none;
  cursor: pointer; transition: opacity .15s; display: flex;
  align-items: center; justify-content: center; gap: 8px; }
.ob-proceed:hover { opacity: .88; }
.ob-proceed:disabled { opacity: .5; cursor: not-allowed; }
.ob-wa-alt { text-align: center; margin-top: .75rem; font-size: .78rem; color: var(--text-muted,#64748b); }
.ob-wa-alt a { color: var(--primary,#0066ff); font-weight: 600; }

/* ── INCLUDES STRIP ───────────────────────────────────────── */
.sp-includes { display: grid; grid-template-columns: repeat(auto-fill,minmax(180px,1fr));
  gap: .875rem; margin-top: 1.5rem; }
.sp-include { display: flex; align-items: flex-start; gap: .65rem; }
.sp-include-icon { width: 28px; height: 28px; border-radius: var(--r-md,8px);
  background: var(--primary-light,#dbeafe); display: flex; align-items: center;
  justify-content: center; font-size: 13px; flex-shrink: 0; }
.sp-include-text strong { display: block; font-size: .78rem; font-weight: 600;
  color: var(--text,#0f172a); margin-bottom: 1px; }
.sp-include-text span { font-size: .7rem; color: var(--text-muted,#64748b); }

/* ── TRY BUILDER PAGE ─────────────────────────────────────── */
.try-cred-box { background: var(--bg-soft,#f8fafd); border: 1.5px solid var(--border,#e2e8f0);
  border-radius: var(--r-lg,12px); padding: 1.5rem; margin-bottom: 1rem; }
.try-cred-row { display: flex; justify-content: space-between; align-items: center;
  padding: .5rem 0; border-bottom: 1px solid var(--border,#e2e8f0); font-size: .85rem; }
.try-cred-row:last-child { border-bottom: none; }
.try-cred-label { color: var(--text-muted,#64748b); font-size: .78rem; }
.try-cred-val { font-family: var(--f-mono,monospace); font-weight: 600;
  color: var(--text,#0f172a); word-break: break-all; }

/* ── POST-PAYMENT ACTIVATION STEPS ───────────────────────── */
.sp-activate-steps { display: flex; flex-direction: column; gap: .75rem; }
.sp-activate-step { display: flex; gap: .875rem; align-items: flex-start;
  padding: 1rem 1.25rem; background: var(--bg,#fff);
  border: 1px solid var(--border,#e2e8f0); border-radius: var(--r-md,8px); }
.sp-activate-num { width: 28px; height: 28px; border-radius: 50%;
  background: var(--primary,#0066ff); color: #fff; font-weight: 700;
  font-size: .8rem; display: flex; align-items: center;
  justify-content: center; flex-shrink: 0; margin-top: 1px; }
.sp-activate-body strong { display: block; font-size: .85rem;
  font-weight: 600; color: var(--text,#0f172a); margin-bottom: 2px; }
.sp-activate-body span { font-size: .78rem; color: var(--text-muted,#64748b); line-height: 1.5; }

/* ── RESPONSIVE ───────────────────────────────────────────── */
@media(max-width:768px) {
  .ob-card { padding: 1.25rem; }
  .sp-selected-panel.visible { flex-direction: column; align-items: flex-start; }
  .sp-lightbox-inner { height: 95vh; }
}
