/* Public marketing site — light mode */

/* ---------- nav ---------- */
.nav {
  position: sticky; top: 0; z-index: 50;
  backdrop-filter: blur(14px);
  background: rgba(255,255,255,.78);
  border-bottom: 1px solid var(--border);
}
.nav__inner {
  display: flex; align-items: center; gap: 22px;
  max-width: var(--container); margin: 0 auto;
  padding: 14px 28px;
}
.nav__brand { display: inline-flex; align-items: center; gap: 12px; }
.nav__logo {
  width: 40px; height: 40px; border-radius: 9px;
  object-fit: cover;
  filter: drop-shadow(3px 3px 0 rgba(115, 79, 252, 0.18));
}
.nav__wordmark {
  font-family: 'Space Grotesk', 'Inter', sans-serif;
  font-weight: 700; letter-spacing: .04em; font-size: 1.05rem;
  color: var(--text);
}
.nav__sub {
  display: block; font-size: .65rem; letter-spacing: .3em;
  color: var(--muted); font-weight: 500;
  margin-top: 1px;
}
.nav__links { display: flex; gap: 22px; margin-left: auto; }
.nav__links a {
  color: var(--text-2); font-size: .93rem; font-weight: 500;
  padding: 6px 2px; position: relative;
}
.nav__links a:hover { color: var(--text); }
.nav__cta { display: flex; align-items: center; gap: 10px; }
.nav__burger { display: none; }

/* Cart icon button in nav */
.nav__cart {
  position: relative;
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px;
  border-radius: 10px;
  border: 1px solid var(--border-strong);
  background: var(--surface);
  color: var(--text-2);
  box-shadow: 2px 2px 0 rgba(10, 10, 20, 0.06);
  transition: transform .15s var(--ease), box-shadow .15s var(--ease), color .15s, border-color .15s;
}
.nav__cart:hover {
  transform: translate(-1px, -1px);
  box-shadow: 4px 4px 0 rgba(115, 79, 252, 0.22);
  border-color: var(--c-purple);
  color: var(--text);
}
.nav__cart-badge {
  position: absolute;
  top: -6px; right: -6px;
  min-width: 20px; height: 20px;
  padding: 0 6px;
  border-radius: 999px;
  background: var(--accent-grad);
  color: #fff;
  font-family: 'Space Grotesk', sans-serif;
  font-size: .72rem; font-weight: 700;
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 2px 2px 0 rgba(115, 79, 252, 0.20);
}

@media (max-width: 980px) {
  .nav__links { display: none; }
  .nav__cta .btn--ghost { display: none; }
}

/* ---------- hero ---------- */
.hero {
  position: relative;
  padding: clamp(60px, 10vw, 130px) 0 clamp(80px, 10vw, 140px);
  overflow: hidden;
}
.hero__inner {
  position: relative; z-index: 2;
  max-width: var(--container); margin: 0 auto; padding: 0 28px;
}
.hero__eyebrow {
  display: inline-block; font-size: .8rem; letter-spacing: .18em;
  text-transform: uppercase; color: var(--text-2);
  padding: 6px 12px; border-radius: 999px;
  background: var(--surface);
  border: 1px solid var(--border-strong);
  box-shadow: 2px 2px 0 rgba(10, 10, 20, 0.06);
  margin-bottom: 22px;
}
.hero__title {
  font-size: clamp(2.8rem, 7vw, 6rem);
  line-height: 1.02;
  letter-spacing: -0.03em;
  margin: 0 0 28px;
  color: var(--text);
  text-shadow: var(--tshadow-lg);
}
.hero__title em { font-style: italic; color: var(--text-2); font-weight: 400; }
.hero__title .grad {
  /* Override shadow: bigger and offset more for the hero */
  filter: drop-shadow(5px 5px 0 rgba(115, 79, 252, 0.22));
}
.hero__sub {
  max-width: 620px; font-size: clamp(1rem, 1.4vw, 1.18rem);
  color: var(--text-2); margin-bottom: 36px;
}
.hero__cta { display: flex; gap: 12px; flex-wrap: wrap; }
.hero__meta {
  display: flex; gap: 50px; margin-top: 64px; flex-wrap: wrap;
  padding-top: 28px; border-top: 1px solid var(--border);
}
.hero__meta > div { display: flex; flex-direction: column; }
.hero__meta strong {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1.6rem; letter-spacing: -0.02em;
  color: var(--text);
  text-shadow: var(--tshadow-sm);
}
.hero__meta span { font-size: .78rem; letter-spacing: .18em; text-transform: uppercase; color: var(--muted); }

.hero__orb {
  position: absolute; top: -160px; right: -240px;
  width: 880px; height: 880px; pointer-events: none; z-index: 1;
  background:
    radial-gradient(closest-side, rgba(115, 79, 252, .22), transparent 70%),
    radial-gradient(closest-side at 65% 50%, rgba(0, 187, 255, .18), transparent 70%),
    radial-gradient(closest-side at 35% 60%, rgba(227, 0, 255, .15), transparent 70%);
  filter: blur(20px);
  opacity: .9;
  animation: orb-drift 22s ease-in-out infinite alternate;
}
@keyframes orb-drift {
  to { transform: translate3d(-30px, 30px, 0) scale(1.05); }
}

/* ---------- section base ---------- */
.services-strip, .process, .services, .portfolio, .about, .contact, .form-section { padding: clamp(60px, 8vw, 110px) 0; }

/* ---------- cards (services strip) ---------- */
.card {
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-lg);
  padding: 28px;
  box-shadow: var(--bshadow-sm);
  transition: transform .15s var(--ease), box-shadow .15s var(--ease);
}
.card:hover { transform: translate(-2px, -2px); box-shadow: 5px 5px 0 rgba(10, 10, 20, 0.10); }
.card__num {
  display: inline-block; font-family: 'Space Grotesk', sans-serif;
  font-size: 1.2rem;
  background: var(--accent-grad); -webkit-background-clip: text; background-clip: text;
  color: transparent;
  margin-bottom: 14px;
}

/* ---------- process steps ---------- */
.process__list {
  list-style: none; padding: 0; margin: 30px 0 0;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px;
}
.process__list li {
  position: relative; padding: 24px;
  border: 1px solid var(--border-strong); border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--bshadow-sm);
}
.process__step {
  display: inline-block; font-family: 'Space Grotesk', sans-serif;
  font-weight: 700; letter-spacing: -.01em; font-size: 1.1rem;
  background: var(--accent-grad); -webkit-background-clip: text; background-clip: text; color: transparent;
  margin-bottom: 8px;
}
.process__list p { margin: 0; color: var(--text-2); }
@media (max-width: 880px) { .process__list { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .process__list { grid-template-columns: 1fr; } }

/* ---------- services / about / contact ---------- */
.service {
  border: 1px solid var(--border-strong); border-radius: var(--radius-lg);
  padding: 30px; background: var(--surface);
  box-shadow: var(--bshadow-sm);
}
.service ul { margin: 12px 0 0 18px; color: var(--text-2); }
.service li { margin: 4px 0; }

/* ---------- cart ---------- */
.cart { padding: 30px 0 clamp(60px, 8vw, 110px); }

.cart__layout {
  display: grid;
  grid-template-columns: 1.8fr 1fr;
  gap: 28px;
  align-items: start;
}
@media (max-width: 880px) { .cart__layout { grid-template-columns: 1fr; } }

.cart-lines { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 14px; }
.cart-line {
  display: grid;
  grid-template-columns: 90px 1fr auto auto auto;
  gap: 16px;
  align-items: center;
  padding: 14px;
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--bshadow-sm);
}
.cart-line__media { display: block; width: 90px; height: 90px; border-radius: 10px; overflow: hidden; background: var(--bg-2); }
.cart-line__media img { display: block; width: 100%; height: 100%; object-fit: cover; }
.cart-line__placeholder { width: 100%; height: 100%; background: var(--accent-grad-soft); }
.cart-line__body { min-width: 0; }
.cart-line__title { display: block; color: var(--text); font-weight: 700; font-size: 1.05rem; }
.cart-line__body .muted { font-size: .85rem; margin: 2px 0 0; }
.cart-line__unit { display: inline-block; margin-top: 6px; color: var(--text-2); font-size: .85rem; }

.cart-line__qty { display: inline-flex; align-items: center; gap: 6px; }
.cart-line__qty input[type=number] { width: 70px; text-align: center; }
.cart-line__total { font-family: 'Space Grotesk', sans-serif; font-size: 1.1rem; }
.cart-line__remove button {
  width: 32px; height: 32px; padding: 0; border-radius: 999px;
  font-size: 1.1rem; line-height: 1;
  color: #9f1239;
}

@media (max-width: 700px) {
  .cart-line { grid-template-columns: 70px 1fr; grid-template-rows: auto auto; row-gap: 10px; }
  .cart-line__media { width: 70px; height: 70px; }
  .cart-line__qty, .cart-line__total, .cart-line__remove { grid-column: 2 / 3; justify-self: start; }
}

.cart__summary {
  position: sticky; top: 92px;
  padding: 22px 26px 26px;
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-lg);
  background: var(--surface);
  box-shadow: 4px 4px 0 rgba(115, 79, 252, 0.16);
}
.cart__summary h2 { margin-bottom: 14px; text-shadow: none; }
.cart__row { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; }
.cart__row strong { font-family: 'Space Grotesk', sans-serif; font-size: 1.2rem; }
.cart__checkout { display: flex; flex-direction: column; gap: 14px; margin-top: 18px; }
.cart__checkout button { width: 100%; }
.cart__continue { display: inline-block; margin-top: 18px; color: var(--muted); font-size: .9rem; }
.cart__continue:hover { color: var(--text); }

/* Add-to-cart row on shop_item.html */
.shop-detail__buy {
  display: inline-flex; align-items: center; gap: 10px;
  margin-top: 4px;
}
.shop-detail__buy input[type=number] {
  width: 80px; text-align: center;
}
.shop-detail__custom {
  display: inline-block;
  margin-top: 12px;
  color: var(--muted);
  font-size: .9rem;
  border-bottom: 1px solid var(--border-strong);
}
.shop-detail__custom:hover { color: var(--text); }

/* ---------- checkout result ---------- */
.checkout-result { padding: 30px 0 clamp(60px, 8vw, 110px); }
.checkout-result .panel { box-shadow: 4px 4px 0 rgba(115, 79, 252, 0.16); }

/* ---------- shop (catalog) ---------- */
.shop { padding: clamp(40px, 6vw, 80px) 0 clamp(60px, 8vw, 110px); }

.shop-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 22px;
}
.shop-card {
  display: flex; flex-direction: column;
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-lg);
  background: var(--surface);
  overflow: hidden;
  box-shadow: var(--bshadow-sm);
  color: var(--text);
  transition: transform .15s var(--ease), box-shadow .15s var(--ease);
}
.shop-card:hover {
  transform: translate(-2px, -2px);
  box-shadow: 5px 5px 0 rgba(115, 79, 252, 0.20);
  color: var(--text);
}
.shop-card__media { aspect-ratio: 4/3; background: var(--bg-2); }
.shop-card__media img { display: block; width: 100%; height: 100%; object-fit: cover; }
.shop-card__placeholder {
  width: 100%; height: 100%;
  background: var(--accent-grad-soft);
}
.shop-card__body { padding: 18px 22px 22px; display: flex; flex-direction: column; gap: 6px; }
.shop-card__cat {
  font-size: .72rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--muted); font-weight: 600;
}
.shop-card__body h3 { margin: 2px 0 2px; font-size: 1.15rem; }
.shop-card__body p { color: var(--text-2); margin: 0; font-size: .92rem; }
.shop-card__price {
  margin-top: auto;
  padding-top: 12px;
  display: flex; align-items: baseline; gap: 8px;
}
.shop-card__price strong {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1.2rem; letter-spacing: -0.01em;
}

/* ---------- shop detail ---------- */
.shop-detail { padding: 50px 0 clamp(60px, 8vw, 110px); }
.shop-detail__layout {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 40px;
  align-items: start;
  margin-top: 18px;
}
@media (max-width: 880px) { .shop-detail__layout { grid-template-columns: 1fr; } }

.shop-detail__hero {
  background: var(--bg-2);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--bshadow-sm);
  aspect-ratio: 4 / 3;
}
.shop-detail__hero img { display: block; width: 100%; height: 100%; object-fit: cover; }
.shop-detail__hero--empty { background: var(--accent-grad-soft); }

.shop-detail__thumbs { display: flex; gap: 8px; margin-top: 12px; flex-wrap: wrap; }
.shop-detail__thumbs .thumb {
  padding: 0; border: 1px solid var(--border-strong); background: transparent;
  width: 70px; height: 70px; border-radius: 10px; overflow: hidden;
  cursor: pointer; transition: transform .12s, border-color .12s;
}
.shop-detail__thumbs .thumb img { display: block; width: 100%; height: 100%; object-fit: cover; }
.shop-detail__thumbs .thumb:hover { transform: translate(-1px, -1px); border-color: var(--c-purple); }
.shop-detail__thumbs .thumb.is-active { border-color: var(--c-purple); box-shadow: 2px 2px 0 rgba(115, 79, 252, 0.20); }

.shop-detail__info h1 { font-size: clamp(1.8rem, 3.5vw, 2.6rem); margin: 8px 0 6px; }
.shop-detail__tag { color: var(--text-2); font-size: 1.04rem; }
.shop-detail__price {
  display: flex; align-items: baseline; gap: 10px;
  margin: 16px 0 22px;
}
.shop-detail__price strong {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1.7rem;
}
.shop-detail__desc { margin-top: 22px; color: var(--text-2); }
.shop-detail__specs { margin: 6px 0 0 18px; color: var(--text-2); }
.shop-detail__specs li { margin: 3px 0; }

/* ---------- showcase ---------- */
.showcase-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 22px;
}
.showcase-item {
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--surface);
  box-shadow: var(--bshadow-sm);
  transition: transform .15s var(--ease), box-shadow .15s var(--ease);
}
.showcase-item:hover { transform: translate(-2px, -2px); box-shadow: 5px 5px 0 rgba(10, 10, 20, 0.10); }
.showcase-item__media { background: var(--bg-2); }
.showcase-item__media img {
  display: block; width: 100%; aspect-ratio: 4/3; object-fit: cover;
}
.embed-wrap {
  position: relative; width: 100%; aspect-ratio: 16/9;
  background: #000;
}
.embed-wrap iframe {
  position: absolute; inset: 0; width: 100%; height: 100%;
  border: 0;
}
.showcase-item__fallback {
  display: block; padding: 30px; text-align: center;
  color: var(--text-2); font-weight: 600;
}
.showcase-item__body { padding: 18px 22px 24px; }
.showcase-item__body h3 { margin-bottom: 6px; }
.showcase-item__body p { color: var(--text-2); margin: 0; }

/* ---------- portfolio (legacy placeholder) ---------- */
.portfolio__item {
  border: 1px solid var(--border-strong); border-radius: var(--radius-lg);
  overflow: hidden; background: var(--surface);
  box-shadow: var(--bshadow-sm);
  transition: transform .15s var(--ease), box-shadow .15s var(--ease);
}
.portfolio__item:hover { transform: translate(-2px, -2px); box-shadow: 5px 5px 0 rgba(10, 10, 20, 0.10); }
.portfolio__media {
  aspect-ratio: 4 / 3;
  background:
    radial-gradient(circle at calc(20% + var(--seed, 0) * 7%) 30%, rgba(115,79,252,.45), transparent 60%),
    radial-gradient(circle at calc(80% - var(--seed, 0) * 5%) 70%, rgba(0,187,255,.45), transparent 60%),
    radial-gradient(circle at 50% 100%, rgba(227,0,255,.35), transparent 60%),
    var(--bg-2);
  position: relative;
}
.portfolio__tag {
  position: absolute; left: 16px; bottom: 14px;
  font-size: .8rem; letter-spacing: .18em; text-transform: uppercase;
  color: #fff;
  text-shadow: 2px 2px 0 rgba(10, 10, 20, 0.35);
}
.portfolio__meta { padding: 18px 22px 24px; }

/* ---------- page hero (interior pages) ---------- */
.page-hero { padding: clamp(70px, 9vw, 120px) 0 30px; }
.page-hero__title {
  font-size: clamp(2.2rem, 5.5vw, 4.4rem);
  margin: 0 0 18px;
  letter-spacing: -0.03em;
  line-height: 1.05;
  text-shadow: var(--tshadow-md);
}
.page-hero__sub { font-size: clamp(1rem, 1.4vw, 1.18rem); color: var(--text-2); max-width: 720px; }

/* ---------- order form ---------- */
.file-preview { margin-top: 10px; display: flex; flex-direction: column; gap: 6px; }
.file-preview__item {
  display: flex; justify-content: space-between; gap: 12px;
  padding: 8px 12px; border-radius: 8px;
  background: var(--bg-2);
  border: 1px solid var(--border);
  font-size: .85rem; color: var(--text-2);
}
.file-preview__item.is-too-big { color: #9f1239; border-color: #fda4af; background: #fff1f2; }

/* ---------- CTA banner ---------- */
.cta {
  padding: clamp(60px, 8vw, 100px) 0;
  border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
  background: radial-gradient(ellipse at 50% 0%, rgba(115, 79, 252, .10), transparent 65%);
}
.cta__inner { text-align: center; }
.cta__inner h2 { margin-bottom: 10px; text-shadow: var(--tshadow-md); }
.cta__inner p { color: var(--text-2); margin-bottom: 22px; }

/* ---------- socials ---------- */
.socials { display: inline-flex; gap: 10px; margin-top: 12px; }
.socials__link {
  display: inline-flex; align-items: center; justify-content: center;
  width: 38px; height: 38px;
  border-radius: 10px;
  border: 1px solid var(--border-strong);
  background: var(--surface);
  color: var(--text-2);
  box-shadow: 2px 2px 0 rgba(10, 10, 20, 0.06);
  transition: transform .15s var(--ease), box-shadow .15s var(--ease), color .15s, border-color .15s;
}
.socials__link:hover {
  transform: translate(-1px, -1px);
  box-shadow: 4px 4px 0 rgba(115, 79, 252, 0.22);
  border-color: var(--c-purple);
  color: var(--text);
}
.socials--lg .socials__link { width: 44px; height: 44px; border-radius: 12px; }

/* ---------- footer ---------- */
.footer { background: var(--bg-1); border-top: 1px solid var(--border); padding-top: 50px; }
.footer__inner { max-width: var(--container); margin: 0 auto; padding: 0 28px 30px; display: grid; grid-template-columns: 1.2fr 2fr; gap: 40px; }
.footer__brand { display: flex; align-items: center; gap: 14px; }
.footer__logo { width: 48px; height: 48px; border-radius: 10px; filter: drop-shadow(3px 3px 0 rgba(115, 79, 252, 0.18)); }
.footer__wordmark { font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: 1.1rem; color: var(--text); }
.footer__wordmark span { color: var(--muted); font-weight: 500; letter-spacing: .12em; }
.footer__tag { color: var(--muted); font-size: .88rem; margin-top: 3px; }
.footer__cols { display: grid; grid-template-columns: repeat(2, 1fr); gap: 30px; }
.footer__cols h4 { font-family: 'Space Grotesk', sans-serif; font-size: .8rem; letter-spacing: .18em; text-transform: uppercase; color: var(--muted); margin: 0 0 10px; font-weight: 600; text-shadow: none; }
.footer__cols a { display: block; padding: 4px 0; color: var(--text-2); font-size: .92rem; }
.footer__cols a:hover { color: var(--text); }
.footer__bottom { border-top: 1px solid var(--border); padding: 22px 28px; max-width: var(--container); margin: 0 auto; display: flex; gap: 10px; align-items: center; color: var(--muted); font-size: .82rem; flex-wrap: wrap; }
.footer__dot { color: var(--border-strong); }
.footer--minimal { padding-top: 0; }
.footer--minimal .footer__inner { grid-template-columns: 1fr; }

@media (max-width: 760px) {
  .footer__inner { grid-template-columns: 1fr; }
  .footer__cols { grid-template-columns: 1fr 1fr; }
}
