/* ─────────────────────────────────────────────────────────
   Shopify Essentials Build — /products/shopify-essentials-build/
   ───────────────────────────────────────────────────────── */

.seb-eyebrow { font-size: 12px; font-weight: 700; letter-spacing: 0.22em; text-transform: uppercase; color: var(--red); margin: 0 0 14px; }

.seb-h2 { font-size: clamp(2rem, 3.6vw, 3rem); font-weight: 900; letter-spacing: -0.01em; line-height: 1.05; margin: 0 0 14px; color: var(--black); text-transform: uppercase; }
.seb-h2 em { font-style: normal; color: var(--red); font-weight: 900; }
.seb-h2--center { text-align: center; }

.seb-section-inner { max-width: 1200px; margin: 0 auto; }
.seb-section-lead { font-size: 17px; line-height: 1.65; color: var(--muted); margin: 0 0 48px; }
.seb-section-lead--center { text-align: center; }

/* Buttons */
.seb-btn { display: inline-flex; align-items: center; gap: 10px; padding: 17px 28px; font-size: 12px; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; text-decoration: none; border-radius: 8px; transition: background 0.22s, color 0.22s, transform 0.22s; }
.seb-btn svg { width: 14px; height: 14px; transition: transform 0.22s; }
.seb-btn:hover svg { transform: translateX(4px); }
.seb-btn--primary { background: var(--red); color: var(--white); box-shadow: 0 12px 28px rgba(255,44,85,0.25); }
.seb-btn--primary:hover { background: var(--black); transform: translateY(-2px); }
.seb-btn--ghost { background: transparent; color: inherit; border: 2px solid currentColor; }

/* ── HERO ──────────────────────────────────────────── */
.seb-hero { position: relative; padding: 80px 48px 96px; background: radial-gradient(circle at 88% 10%, rgba(255,44,85,0.18) 0%, transparent 45%), radial-gradient(circle at 0% 100%, rgba(255,44,85,0.08) 0%, transparent 50%), var(--black); color: var(--white); overflow: hidden; }
.seb-hero::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,0.03) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px); background-size: 64px 64px; pointer-events: none; mask-image: linear-gradient(180deg, rgba(0,0,0,0.5) 0%, transparent 80%); -webkit-mask-image: linear-gradient(180deg, rgba(0,0,0,0.5) 0%, transparent 80%); }
.seb-hero-watermark { position: absolute; bottom: -36px; right: -24px; font-size: clamp(6rem, 16vw, 14rem); font-weight: 900; letter-spacing: -0.04em; color: rgba(255,255,255,0.04); pointer-events: none; white-space: nowrap; line-height: 1; }
.seb-hero-inner { position: relative; z-index: 1; max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr); gap: 64px; align-items: center; }
.seb-hero-text { min-width: 0; }
.seb-hero-h1 { font-size: clamp(2.4rem, 5vw, 3.8rem); font-weight: 900; letter-spacing: -0.02em; line-height: 1; margin: 0 0 18px; color: var(--white); text-transform: uppercase; }
.seb-hero-sub { font-size: 19px; line-height: 1.55; color: rgba(255,255,255,0.88); margin: 0 0 14px; max-width: 560px; }
.seb-hero-body { font-size: 15.5px; line-height: 1.7; color: rgba(255,255,255,0.66); margin: 0 0 32px; max-width: 560px; }
.seb-hero-actions { display: inline-flex; gap: 14px; flex-wrap: wrap; }
.seb-hero .seb-btn--ghost { color: var(--white); border-color: rgba(255,255,255,0.4); }
.seb-hero .seb-btn--ghost:hover { background: var(--white); color: var(--black); border-color: var(--white); }
.seb-hero-media { display: flex; justify-content: center; min-width: 0; }
.seb-hero-thumb { width: 100%; max-width: 480px; height: auto; display: block; border-radius: 12px; box-shadow: 0 28px 64px rgba(0,0,0,0.4); }

/* ── INCLUDED ──────────────────────────────────────── */
.seb-included { padding: 96px 48px; background: var(--white); }
.seb-included-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 22px; }
.seb-included-card { padding: 32px 28px; background: #FFEBEF; border-radius: 12px; }
.seb-included-card h4 { font-size: 18px; font-weight: 800; margin: 0 0 10px; color: var(--black); position: relative; padding-left: 26px; }
.seb-included-card h4::before { content: ""; position: absolute; left: 0; top: 0.3em; width: 12px; height: 12px; background: var(--red); border-radius: 50%; }
.seb-included-card p { font-size: 15px; line-height: 1.6; color: var(--black); margin: 0; }

/* ── COVERED ───────────────────────────────────────── */
.seb-covered { padding: 0 48px 96px; background: var(--white); }
.seb-covered-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; padding: 48px; background: #FFEBEF; border-radius: 12px; }
.seb-covered-label { font-size: 24px; font-weight: 900; margin: 0 0 18px; }
.seb-covered-label--yes { color: #00CA00 !important; }
.seb-covered-label--no  { color: var(--red) !important; }

.seb-covered-label--yes::before { content: "✔ "; }
.seb-covered-label--no::before  { content: "✘ "; }
.seb-covered-grid ul { list-style: none; padding: 0; margin: 0; }
.seb-covered-grid li { position: relative; padding-left: 24px; margin: 14px 0; font-size: 16px; font-weight: 600; color: var(--black); line-height: 1.45; }
.seb-covered-col--yes li::before { content: "✓"; position: absolute; left: 0; color: #00CA00; font-weight: 800; }
.seb-covered-col--no  li::before { content: "✗"; position: absolute; left: 0; color: var(--red); font-weight: 800; }

/* ── TIMELINE — verbatim port of the live shopify-essentials
   build timeline. Donut-chart circles via conic-gradient on a
   --angle custom prop, alternating absolute-positioned content,
   dotted connector, scroll-driven progress bar + circle fill. */

@property --angle {
  syntax: "<angle>";
  initial-value: 0deg;
  inherits: false;
}

.seb-timeline {
  padding: 80px 48px 32px;
  background: var(--white);
  border-top: 1px solid var(--rule);
}
.tl-title-wrap { text-align: center; margin-bottom: 12px; }
.tl-title {
  display: inline-block;
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  font-weight: 900;
  color: var(--red);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1;
  margin: 0;
}

.tl-timeline {
  position: relative;
  max-width: 1000px;
  margin: 0 auto;
  padding: 40px 0 0;
}
.tl-item:last-of-type { margin-bottom: 40px; }

.tl-timeline::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 4px;
  background: #ecf0f1;
  transform: translateX(-50%);
  z-index: 0;
}

.tl-line-progress {
  position: absolute;
  top: 0;
  left: 50%;
  width: 4px;
  background: var(--red);
  transform: translateX(-50%);
  z-index: 1;
  height: 0;
  transition: height 0.5s linear;
}

/* Rows */
.tl-item {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  margin-bottom: 80px;
  z-index: 2;
  opacity: 0;
  transition: opacity 1s ease, transform 1s ease;
}
.tl-item:nth-child(odd)  { transform: translateX(-100px); }
.tl-item:nth-child(even) { transform: translateX(100px); }
.tl-item.is-visible {
  opacity: 1;
  transform: translateX(0);
}

/* Donut circle */
.tl-circle {
  position: relative;
  width: 120px;
  height: 120px;
  border-radius: 50%;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 0 8px var(--white);
  background: conic-gradient(var(--red) var(--angle), #ecf0f1 0);
  --angle: 0deg;
  transition: --angle 2s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.tl-circle::after {
  content: attr(data-label);
  position: absolute;
  width: 90px;
  height: 90px;
  background: var(--white);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 0.85rem;
  font-weight: 800;
  color: var(--red);
  text-transform: uppercase;
  line-height: 1.2;
  white-space: pre-line;
}

/* Absolutely-positioned content on either side */
.tl-content {
  position: absolute;
  width: 38%;
  top: 20px;
  background: transparent;
}
.tl-content h3 {
  font-size: 1.1rem;
  text-transform: uppercase;
  font-weight: 800;
  margin: 0 0 10px 0;
  color: var(--red);
}
.tl-content p {
  font-size: 0.95rem;
  color: var(--black);
  font-weight: 300;
  line-height: 1.55;
  margin: 0;
}
.tl-content strong { font-weight: 700; }

/* Dotted connector */
.tl-connector {
  position: absolute;
  top: 42px;
  width: 0;
  height: 2px;
  border-bottom: 2px dotted #bdc3c7;
  transition: width 1s ease 0.5s;
}

/* The line-progress is :nth-child(1), so the first .tl-item
   is :nth-child(2) → falls into the EVEN branch. That matches
   the live: Sitemap content on the right, Theme Selection on
   the left, etc. */
.tl-item:nth-child(odd) .tl-content {
  left: 0;
  text-align: right;
  padding-right: 40px;
}
.tl-item:nth-child(odd) .tl-connector { right: 0; }
.tl-item.is-visible:nth-child(odd) .tl-connector { width: 100px; }

.tl-item:nth-child(even) .tl-content {
  right: 0;
  text-align: left;
  padding-left: 40px;
}
.tl-item:nth-child(even) .tl-connector { left: 0; }
.tl-item.is-visible:nth-child(even) .tl-connector { width: 100px; }

/* Footer */
.tl-footer {
  text-align: center;
  margin-top: 0;
  margin-bottom: 0;
  color: var(--black);
  font-size: 0.9rem;
  opacity: 0;
  transition: opacity 1s;
}
.tl-footer.is-visible { opacity: 1; }
.tl-logo {
  font-weight: 800;
  color: var(--red);
  font-size: 2em;
  letter-spacing: 5px;
}

/* Responsive — mirrors the live <768 rules */
@media (max-width: 768px) {
  .tl-timeline { margin-left: 30px; }
  .tl-timeline::before,
  .tl-line-progress { left: 31px; }

  .tl-item {
    justify-content: flex-start;
    padding-left: 100px;
    margin-bottom: 50px;
  }
  .tl-item:nth-child(odd),
  .tl-item:nth-child(even) { transform: translateY(30px); }
  .tl-item.is-visible { transform: translateY(0); }

  .tl-circle {
    position: absolute;
    left: -20px;
    width: 100px;
    height: 100px;
  }
  .tl-circle::after { width: 75px; height: 75px; font-size: 0.7rem; }

  .tl-content {
    position: relative;
    width: 100%;
    left: auto !important;
    right: auto !important;
    text-align: left !important;
    padding: 0 !important;
    top: 0;
  }
  .tl-connector { display: none; }
  .tl-footer { text-align: left; margin-top: 10px; }
}

/* ── PRICING ───────────────────────────────────────── */
.seb-pricing { padding: 96px 48px; background: var(--white); border-top: 1px solid var(--rule); }
.seb-pricing-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 24px; max-width: 900px; margin: 0 auto; }
.seb-pricing-card { position: relative; display: flex; flex-direction: column; padding: 36px 32px 30px; border: 1px solid var(--rule); border-radius: 12px; transition: transform 0.22s, border-color 0.22s, box-shadow 0.22s; }
.seb-pricing-card:hover { transform: translateY(-4px); border-color: rgba(255,44,85,0.3); box-shadow: 0 20px 48px rgba(0,0,0,0.06); }
.seb-pricing-card--featured { background: linear-gradient(155deg, #0F0F0F, #1A1A1A); color: var(--white); border-color: var(--red); box-shadow: 0 30px 60px rgba(255,44,85,0.15); }
.seb-pricing-card--featured:hover { transform: translateY(-6px); box-shadow: 0 36px 70px rgba(255,44,85,0.22); }
.seb-pricing-badge { position: absolute; top: -12px; left: 50%; transform: translateX(-50%); padding: 5px 14px; background: var(--red); color: var(--white); font-size: 10px; font-weight: 800; letter-spacing: 0.2em; text-transform: uppercase; border-radius: 999px; box-shadow: 0 6px 14px rgba(255,44,85,0.35); }
.seb-pricing-card h3 { font-size: 22px; font-weight: 900; margin: 0 0 8px; }
.seb-pricing-desc { font-size: 13.5px; color: var(--muted); margin: 0 0 22px; }
.seb-pricing-card--featured .seb-pricing-desc { color: rgba(255,255,255,0.65); }
.seb-pricing-price { font-size: 32px; font-weight: 900; color: var(--red); letter-spacing: -0.03em; line-height: 1; margin-bottom: 4px; font-variant-numeric: tabular-nums; }
.seb-pricing-time { font-size: 11px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted); margin-bottom: 22px; }
.seb-pricing-card--featured .seb-pricing-time { color: rgba(255,255,255,0.55); }
.seb-pricing-card ul { list-style: none; padding: 0; margin: 0 0 24px; flex: 1; }
.seb-pricing-card li { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; line-height: 1.5; margin: 10px 0; }
.seb-pricing-card--featured li { color: rgba(255,255,255,0.85); }
.seb-pricing-card li::before { content: "✓"; color: var(--red); font-weight: 800; flex-shrink: 0; }
.seb-pricing-cta { display: flex; align-items: center; justify-content: center; gap: 8px; width: 100%; padding: 14px 20px; font-size: 11.5px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; text-decoration: none; border-radius: 8px; margin-bottom: 10px; transition: background 0.22s, transform 0.22s; }
.seb-pricing-cta svg { width: 13px; height: 13px; }
.seb-pricing-cta--primary,
.seb-pricing-cta--primary:link,
.seb-pricing-cta--primary:visited { background: var(--black); color: var(--white); }
.seb-pricing-cta--primary:hover,
.seb-pricing-cta--primary:focus,
.seb-pricing-cta--primary:active {
  background: var(--red);
  color: var(--white);
  text-decoration: none;
  transform: translateY(-1px);
}
.seb-pricing-cta--primary:hover svg,
.seb-pricing-cta--primary:focus svg { color: var(--white); stroke: var(--white); }
.seb-pricing-card--featured .seb-pricing-cta--primary { background: var(--red); color: var(--white) !important; }
.seb-pricing-card--featured .seb-pricing-cta--primary svg { color: var(--white) !important; stroke: var(--white) !important; }
.seb-pricing-card--featured .seb-pricing-cta--primary:hover { background: var(--white); color: var(--black) !important; }
.seb-pricing-card--featured .seb-pricing-cta--primary:hover svg { color: var(--black) !important; stroke: var(--black) !important; }
.seb-pricing-cta--ghost { background: transparent; color: var(--black); border: 1px solid var(--rule); }
.seb-pricing-cta--ghost:hover { border-color: var(--red); color: var(--red); }
.seb-pricing-card--featured .seb-pricing-cta--ghost { color: var(--white); border-color: rgba(255,255,255,0.25); }
.seb-pricing-card--featured .seb-pricing-cta--ghost:hover { border-color: var(--white); color: var(--white); }

/* ── ADD-ONS ───────────────────────────────────────── */
.seb-addons { padding: 0 48px 96px; background: var(--white); }
.seb-addons-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 22px; }
.seb-addon-card { padding: 32px 28px; border: 1px solid var(--rule); border-radius: 12px; transition: transform 0.22s, border-color 0.22s, box-shadow 0.22s; }
.seb-addon-card:hover { transform: translateY(-3px); border-color: rgba(255,44,85,0.25); box-shadow: 0 16px 36px rgba(0,0,0,0.05); }
.seb-addon-card h3 { font-size: 18px; font-weight: 900; margin: 0 0 8px; color: var(--black); }
.seb-addon-card p { font-size: 14px; line-height: 1.55; color: var(--muted); margin: 0 0 14px; }
.seb-addon-price { font-size: 24px; font-weight: 900; color: var(--red); margin-bottom: 4px; }
.seb-addon-time { font-size: 11px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted); margin-bottom: 18px; }
.seb-addon-card ul { list-style: none; padding: 0; margin: 0; }
.seb-addon-card li { position: relative; padding-left: 22px; font-size: 13.5px; line-height: 1.55; color: var(--black); margin: 8px 0; }
.seb-addon-card li::before { content: "✓"; position: absolute; left: 0; color: var(--red); font-weight: 800; }

/* ── BOTTOM CTA ────────────────────────────────────── */
.seb-cta { padding: 96px 48px 104px; background: var(--black); color: var(--white); }
.seb-cta-inner { max-width: 880px; margin: 0 auto; text-align: center; }
.seb-cta-faces { display: inline-flex; margin: 0 auto 24px; }
.seb-cta-faces img { width: 56px; height: 56px; border-radius: 50%; border: 3px solid var(--black); margin-left: -16px; object-fit: cover; object-position: top center; background: rgba(255,44,85,0.1); box-shadow: 0 6px 14px rgba(0,0,0,0.35); }
.seb-cta-faces img:first-child { margin-left: 0; }
.seb-cta-eyebrow { font-size: 12px; font-weight: 700; letter-spacing: 0.22em; text-transform: uppercase; color: var(--red); margin: 0 0 18px; }
.seb-cta-h2 { font-size: clamp(1.8rem, 3.4vw, 2.6rem); font-weight: 900; letter-spacing: -0.01em; line-height: 1.15; margin: 0 0 36px; color: var(--white); text-transform: uppercase; }
.seb-cta-h2 em { font-style: normal; color: var(--red); font-weight: 900; }
.seb-cta-actions { display: inline-flex; gap: 14px; flex-wrap: wrap; justify-content: center; }
.seb-cta .seb-btn--ghost { color: var(--white); border-color: rgba(255,255,255,0.4); }
.seb-cta .seb-btn--ghost:hover { background: var(--white); color: var(--black); border-color: var(--white); }

/* ── MOBILE ────────────────────────────────────────── */
@media (max-width: 1100px) { .seb-included-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 960px) {
  .seb-hero-inner { grid-template-columns: 1fr; gap: 40px; }
  .seb-pricing-grid { grid-template-columns: 1fr; }
  .seb-addons-grid { grid-template-columns: 1fr; }
  .seb-covered-grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .seb-hero { padding: 56px 24px 64px; }
  .seb-hero-watermark { display: none; }
  .seb-included, .seb-covered, .seb-timeline, .seb-pricing, .seb-addons, .seb-cta { padding: 64px 24px; }
  .seb-included-grid { grid-template-columns: 1fr; }
  .seb-hero-actions, .seb-cta-actions { flex-direction: column; width: 100%; }
  .seb-btn { width: 100%; justify-content: center; }
  .seb-covered-grid { padding: 28px; }
}
