/* ============================================================
   Farbodfilms — cards, shop, product, cart, checkout, etc.
   ============================================================ */

/* ---- Product card ---- */
.card {
  position: relative;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--bg2);
  cursor: pointer;
  transition: border-color 0.25s ease, transform 0.25s ease;
}
.card:hover { border-color: color-mix(in oklab, var(--accent) 60%, var(--line)); transform: translateY(-3px); }
.card-media { position: relative; aspect-ratio: 16 / 11; overflow: hidden; }
.card-lg .card-media { aspect-ratio: 16 / 10; }
.card-state {
  position: absolute; top: 12px; left: 12px;
  font-size: 9.5px; letter-spacing: 0.14em;
  padding: 5px 9px; border-radius: 100px;
  background: rgba(10,10,12,0.55); backdrop-filter: blur(6px);
  color: #fff; z-index: 2;
}
.card-flag {
  position: absolute; top: 12px; right: 12px;
  font-size: 9.5px; letter-spacing: 0.14em;
  padding: 5px 9px; border-radius: 100px;
  background: var(--accent); color: var(--accent-fg); z-index: 2;
}
.card-body { padding: 20px 22px 22px; }
.card-row { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; }
.card-name { font-size: 22px; }
.card-price { font-family: var(--font-display); font-size: 19px; color: var(--fg); }
.card-tag { font-size: 14px; color: var(--fg-dim); margin: 7px 0 16px; }
.card-looks { display: flex; flex-wrap: wrap; gap: 6px; }
.chip {
  font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase;
  padding: 5px 9px; border-radius: 100px;
  border: 1px solid var(--line); color: var(--fg-dim);
}

/* bundle card: split preview of both looks */
.card-split { position: absolute; inset: 0; display: flex; }
.card-split-cell { position: relative; flex: 1; overflow: hidden; }
.card-split-cell + .card-split-cell { border-left: 1.5px solid var(--bg); }
.card-split-label {
  position: absolute; bottom: 10px; left: 50%; transform: translateX(-50%);
  z-index: 3; font-size: 9px; letter-spacing: 0.12em; text-transform: uppercase;
  padding: 4px 8px; border-radius: 100px;
  background: rgba(10,10,12,0.55); backdrop-filter: blur(6px);
  color: #fff; white-space: nowrap;
}

/* coming-soon card */
.card-soon { cursor: default; opacity: 0.92; }
.card-soon:hover { transform: none; border-color: var(--line); }
.card-media-soon {
  display: grid; place-items: center;
  background:
    repeating-linear-gradient(45deg, var(--bg2) 0 11px, var(--panel) 11px 22px);
}
.soon-mark {
  font-size: 30px; letter-spacing: 0.16em; color: var(--fg-faint);
  font-family: var(--font-mono);
}

/* ============================================================
   Shop
   ============================================================ */
.page-shop { max-width: 1280px; margin: 0 auto; padding: 132px 32px 90px; }
.shop-head { max-width: 640px; margin-bottom: 44px; }
.shop-title { font-size: clamp(40px, 6vw, 80px); margin-bottom: 18px; }
.shop-intro { font-size: 16px; color: var(--fg-dim); line-height: 1.6; }
.shop-filters { display: flex; gap: 8px; margin-top: 28px; }
.filter {
  font-size: 13px; color: var(--fg-dim);
  padding: 9px 16px; border-radius: 100px;
  border: 1px solid var(--line);
  transition: all 0.2s ease;
}
.filter:hover { color: var(--fg); }
.filter.is-active { background: var(--fg); color: var(--bg); border-color: var(--fg); }
.shop-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }

/* ============================================================
   Product page
   ============================================================ */
.page-product { max-width: 1280px; margin: 0 auto; padding: 110px 32px 90px; }
.back {
  font-size: 12px; letter-spacing: 0.06em; color: var(--fg-dim);
  margin-bottom: 28px; transition: color 0.2s ease;
}
.back:hover { color: var(--fg); }
.pp-grid { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: 56px; align-items: start; }
.pp-media { position: sticky; top: 100px; }
.pp-thumbs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: 12px; }
.pp-thumb {
  position: relative; aspect-ratio: 16 / 10; border-radius: var(--radius);
  overflow: hidden; border: 1px solid var(--line);
  transition: border-color 0.2s ease;
}
.pp-thumb.is-active { border-color: var(--accent); }
.pp-thumb-cap {
  position: absolute; bottom: 6px; left: 7px;
  font-size: 8px; letter-spacing: 0.1em; text-transform: uppercase;
  color: rgba(255,255,255,0.8); text-shadow: 0 1px 3px rgba(0,0,0,0.7);
}
.pp-title { font-size: clamp(40px, 5.5vw, 72px); margin: 6px 0 12px; }
.pp-tagline { font-size: 18px; color: var(--fg-dim); font-style: italic; margin-bottom: 22px; }
.pp-swatch { height: 8px; border-radius: 100px; margin-bottom: 22px; }
.pp-desc { font-size: 15.5px; line-height: 1.65; color: var(--fg-dim); margin-bottom: 26px; }
.pp-looks { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 30px; }

.pp-includes { margin-bottom: 30px; display: flex; flex-direction: column; gap: 10px; }
.pp-h { font-size: 10px; letter-spacing: 0.16em; color: var(--fg-faint); text-transform: uppercase; margin-bottom: 4px; }
.pp-inc {
  display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 14px;
  text-align: left;
  padding: 14px 16px; border: 1px solid var(--line); border-radius: var(--radius);
  transition: border-color 0.2s ease, background 0.2s ease;
}
.pp-inc:hover { border-color: var(--accent); }
.pp-inc-sw { width: 30px; height: 30px; border-radius: 6px; grid-row: span 1; }
.pp-inc-name { font-family: var(--font-display); font-size: 17px; grid-column: 2; }
.pp-inc-tag { display: none; }
.pp-inc-arrow { color: var(--fg-faint); }

.pp-buy {
  border: 1px solid var(--line); border-radius: var(--radius);
  padding: 24px; background: var(--bg2);
}
.pp-price-row { display: flex; align-items: baseline; gap: 12px; margin-bottom: 18px; }
.pp-price { font-family: var(--font-display); font-size: 38px; }
.pp-save { font-size: 11px; color: var(--accent-fg); background: var(--accent); padding: 4px 9px; border-radius: 100px; letter-spacing: 0.1em; }
.pp-buy-btns { display: flex; flex-direction: column; gap: 10px; }
.pp-meta { list-style: none; margin-top: 22px; display: flex; flex-direction: column; gap: 10px; }
.pp-meta li { font-size: 12.5px; color: var(--fg-dim); display: flex; gap: 10px; }
.pp-meta .mono { color: var(--fg-faint); font-size: 10px; letter-spacing: 0.1em; min-width: 78px; }

.pp-related { margin-top: 90px; }
.pp-related .section-title { margin-bottom: 28px; }

/* ---- bundle media: both looks shown ---- */
.pp-bundle-stack { display: flex; flex-direction: column; gap: 22px; }
.pp-bundle-head { display: flex; align-items: center; gap: 11px; margin-bottom: 10px; }
.pp-bundle-sw { width: 22px; height: 22px; border-radius: 6px; }
.pp-bundle-name { font-family: var(--font-display); font-size: 20px; letter-spacing: -0.01em; }
.pp-bundle-link { margin-left: auto; font-size: 11px; letter-spacing: 0.08em; color: var(--fg-faint); transition: color 0.2s ease; }
.pp-bundle-link:hover { color: var(--accent); }

/* ============================================================
   Cart drawer
   ============================================================ */
.drawer-scrim {
  position: fixed; inset: 0; z-index: 70;
  background: rgba(0,0,0,0.5); backdrop-filter: blur(2px);
  opacity: 0; pointer-events: none; transition: opacity 0.3s ease;
}
.drawer-scrim.is-open { opacity: 1; pointer-events: auto; }
.drawer {
  position: fixed; top: 0; right: 0; bottom: 0; z-index: 71;
  width: min(420px, 92vw);
  background: var(--bg); border-left: 1px solid var(--line);
  transform: translateX(100%); transition: transform 0.34s cubic-bezier(0.4,0,0.1,1);
  display: flex; flex-direction: column;
}
.drawer.is-open { transform: translateX(0); }
.drawer-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 22px 24px; border-bottom: 1px solid var(--line);
  font-size: 11px; letter-spacing: 0.14em; color: var(--fg-dim);
}
.drawer-x { font-size: 16px; color: var(--fg-dim); transition: color 0.2s; }
.drawer-x:hover { color: var(--fg); }
.drawer-empty { padding: 60px 24px; text-align: center; color: var(--fg-dim); }
.drawer-empty span { display: block; margin-top: 8px; font-size: 11px; color: var(--fg-faint); }
.drawer-items { flex: 1; overflow-y: auto; padding: 8px 0; }
.drawer-item {
  display: grid; grid-template-columns: auto 1fr auto auto; align-items: center; gap: 14px;
  padding: 16px 24px; border-bottom: 1px solid var(--line);
}
.drawer-sw { width: 44px; height: 44px; border-radius: 8px; }
.drawer-item-name { font-family: var(--font-display); font-size: 16px; display: block; }
.drawer-item-sub { font-size: 10px; color: var(--fg-faint); }
.drawer-item-price { font-family: var(--font-display); font-size: 15px; }
.drawer-item-x { font-size: 12px; color: var(--fg-faint); transition: color 0.2s; }
.drawer-item-x:hover { color: var(--fg); }
.drawer-foot { padding: 22px 24px; border-top: 1px solid var(--line); }
.drawer-total { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 6px; }
.drawer-total .mono { font-size: 11px; color: var(--fg-faint); letter-spacing: 0.12em; }
.drawer-total-num { font-family: var(--font-display); font-size: 26px; }
.drawer-note { font-size: 10px; color: var(--fg-faint); margin-bottom: 16px; letter-spacing: 0.08em; }

/* ============================================================
   Checkout
   ============================================================ */
.page-checkout { max-width: 1080px; margin: 0 auto; padding: 120px 32px 90px; }
.checkout-grid { display: grid; grid-template-columns: 1.2fr 0.8fr; gap: 48px; align-items: start; }
.checkout-title { font-size: clamp(34px, 4.4vw, 56px); margin-bottom: 30px; }
.field { margin-bottom: 16px; }
.field label { display: block; font-size: 10px; letter-spacing: 0.12em; color: var(--fg-faint); margin-bottom: 8px; }
.field input {
  width: 100%; background: var(--bg2); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 13px 15px; color: var(--fg); font-size: 15px;
  transition: border-color 0.2s ease;
}
.field input:focus { outline: none; border-color: var(--accent); }
.field input::placeholder { color: var(--fg-faint); }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.pay-methods { display: flex; gap: 8px; margin: 20px 0 18px; }
.pay-method {
  flex: 1; padding: 12px; border: 1px solid var(--line); border-radius: var(--radius);
  font-size: 13px; color: var(--fg-dim); transition: all 0.2s ease;
}
.pay-method:hover { color: var(--fg); }
.pay-method.is-active { border-color: var(--accent); color: var(--fg); background: var(--bg2); }
.pay-redirect { font-size: 12px; color: var(--fg-faint); margin: 8px 0 20px; }
.card-fields { margin-bottom: 22px; }
.checkout-secure { font-size: 11px; color: var(--fg-faint); text-align: center; margin-top: 14px; letter-spacing: 0.06em; }

.checkout-summary {
  border: 1px solid var(--line); border-radius: var(--radius);
  padding: 24px; background: var(--bg2); position: sticky; top: 100px;
}
.checkout-summary > .mono { font-size: 10px; letter-spacing: 0.16em; color: var(--fg-faint); }
.summary-items { margin: 16px 0; display: flex; flex-direction: column; gap: 12px; }
.summary-item { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 12px; }
.summary-sw { width: 34px; height: 34px; border-radius: 7px; }
.summary-name { font-size: 14px; }
.summary-price { font-family: var(--font-display); font-size: 15px; }
.summary-line { display: flex; justify-content: space-between; padding-top: 14px; border-top: 1px solid var(--line); font-size: 14px; color: var(--fg-dim); }
.summary-line .mono { font-size: 10px; letter-spacing: 0.1em; }
.summary-total { font-size: 18px; color: var(--fg); }
.summary-total span:last-child { font-family: var(--font-display); }
.summary-note { font-size: 10px; color: var(--fg-faint); margin-top: 14px; letter-spacing: 0.06em; }
.checkout-empty { text-align: center; padding: 80px 0; }
.checkout-empty h1 { font-size: 36px; margin-bottom: 24px; }

/* ============================================================
   Success
   ============================================================ */
.page-success { min-height: 100vh; display: grid; place-items: center; padding: 120px 24px 60px; }
.success-inner { max-width: 540px; width: 100%; text-align: center; }
.success-check {
  width: 64px; height: 64px; border-radius: 50%;
  display: grid; place-items: center; margin: 0 auto 24px;
  background: var(--accent); color: var(--accent-fg);
  font-size: 30px; box-shadow: 0 0 0 8px color-mix(in oklab, var(--accent) 18%, transparent);
}
.success-title { font-size: clamp(32px, 4.5vw, 52px); margin: 6px 0 12px; }
.success-sub { font-size: 16px; color: var(--fg-dim); margin-bottom: 34px; }
.success-downloads { display: flex; flex-direction: column; gap: 10px; text-align: left; margin-bottom: 30px; }
.download {
  display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 14px;
  padding: 16px 18px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--bg2);
}
.download-sw { width: 40px; height: 40px; border-radius: 8px; }
.download-name { font-family: var(--font-display); font-size: 17px; display: block; }
.download-sub { font-size: 10px; color: var(--fg-faint); letter-spacing: 0.04em; }
.download-btn {
  font-size: 11px; letter-spacing: 0.1em; padding: 10px 14px;
  border: 1px solid var(--accent); color: var(--accent); border-radius: var(--radius);
  transition: all 0.2s ease;
}
.download-btn:hover { background: var(--accent); color: var(--accent-fg); }
.success-next {
  display: flex; flex-direction: column; gap: 8px; align-items: center;
  padding: 22px; border: 1px dashed var(--line); border-radius: var(--radius); margin-bottom: 22px;
}
.success-next .mono { font-size: 10px; letter-spacing: 0.14em; color: var(--fg-faint); }
.success-next button { color: var(--accent); font-size: 14px; }

/* ============================================================
   About
   ============================================================ */
.page-about { max-width: 1080px; margin: 0 auto; padding: 140px 32px 90px; }
.about-hero { max-width: 760px; margin-bottom: 48px; }
.about-title { font-size: clamp(34px, 5vw, 64px); line-height: 1.05; }
.about-body { display: grid; grid-template-columns: 0.8fr 1.2fr; gap: 48px; align-items: start; }
.about-media { aspect-ratio: 4 / 5; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--line); position: sticky; top: 100px; }
.about-text p { font-size: 17px; line-height: 1.7; color: var(--fg-dim); margin-bottom: 20px; }
.inline-link { color: var(--accent); font: inherit; text-decoration: underline; text-underline-offset: 3px; }

/* ============================================================
   FAQ
   ============================================================ */
.page-faq { max-width: 920px; margin: 0 auto; padding: 140px 32px 90px; }
.faq-head { margin-bottom: 44px; max-width: 620px; }
.faq-title { font-size: clamp(32px, 4.6vw, 58px); }
.faq-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: var(--radius); margin-bottom: 56px; }
.faq-step { background: var(--bg); padding: 26px 22px; }
.faq-step-n { font-size: 11px; color: var(--accent); letter-spacing: 0.14em; }
.faq-step h3 { font-size: 18px; margin: 12px 0 8px; }
.faq-step p { font-size: 13.5px; color: var(--fg-dim); line-height: 1.55; }
.faq-list { display: flex; flex-direction: column; margin-bottom: 60px; }
.faq-item { border-bottom: 1px solid var(--line); padding: 22px 4px; cursor: pointer; }
.faq-q { display: flex; align-items: center; justify-content: space-between; gap: 16px; font-family: var(--font-display); font-size: 19px; }
.faq-toggle { color: var(--accent); font-size: 22px; }
.faq-a { font-size: 14.5px; color: var(--fg-dim); line-height: 1.6; margin-top: 14px; max-width: 660px; }
.faq-cta { text-align: center; padding: 50px 0 0; }
.faq-cta h2 { font-size: 32px; margin-bottom: 22px; }

/* ============================================================
   Footer
   ============================================================ */
.footer { border-top: 1px solid var(--line); margin-top: 40px; }
.footer-top { max-width: 1280px; margin: 0 auto; padding: 64px 32px 40px; display: grid; grid-template-columns: 1.2fr 2fr; gap: 48px; }
.footer-tag { font-size: 14px; color: var(--fg-dim); margin-top: 16px; max-width: 280px; }
.footer-cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.footer-col { display: flex; flex-direction: column; gap: 11px; align-items: flex-start; }
.footer-h { font-size: 10px; letter-spacing: 0.14em; color: var(--fg-faint); text-transform: uppercase; margin-bottom: 4px; }
.footer-col button, .footer-col a { font-size: 13.5px; color: var(--fg-dim); text-decoration: none; transition: color 0.2s; text-align: left; }
.footer-col button:hover, .footer-col a:hover { color: var(--fg); }
.footer-bottom { max-width: 1280px; margin: 0 auto; padding: 22px 32px; border-top: 1px solid var(--line); display: flex; justify-content: space-between; font-size: 10.5px; color: var(--fg-faint); letter-spacing: 0.06em; }

/* ============================================================
   Toast
   ============================================================ */
.toast {
  position: fixed; bottom: 28px; left: 50%; transform: translateX(-50%);
  z-index: 90; background: var(--fg); color: var(--bg);
  font-size: 13px; font-weight: 500; padding: 13px 22px; border-radius: 100px;
  box-shadow: 0 10px 40px rgba(0,0,0,0.4);
  animation: toast-in 0.3s ease;
}
@keyframes toast-in { from { opacity: 0; transform: translate(-50%, 12px); } to { opacity: 1; transform: translate(-50%, 0); } }

/* tweak blurb inside panel */
.tweak-blurb { font-size: 11px; line-height: 1.5; color: var(--fg-faint, #888); padding: 0 2px 10px; }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 940px) {
  .hero-ed-grid { grid-template-columns: 1fr; gap: 36px; }
  .values { grid-template-columns: repeat(2, 1fr); }
  .featured-grid { grid-template-columns: 1fr; }
  .shop-grid { grid-template-columns: 1fr 1fr; }
  .pp-grid { grid-template-columns: 1fr; gap: 32px; }
  .pp-media { position: static; }
  .checkout-grid { grid-template-columns: 1fr; }
  .checkout-summary { position: static; }
  .about-body { grid-template-columns: 1fr; }
  .about-media { position: static; max-width: 320px; }
  .faq-steps { grid-template-columns: 1fr; }
  .footer-top { grid-template-columns: 1fr; }
}
@media (max-width: 620px) {
  .nav-links { display: none; }
  .nav-inner { padding: 14px 18px; }
  .values { grid-template-columns: 1fr 1fr; }
  .shop-grid { grid-template-columns: 1fr; }
  .page-shop, .page-product, .page-checkout, .page-about, .page-faq, .featured { padding-left: 18px; padding-right: 18px; }
  .bundle-banner { padding: 44px 24px; }
  .footer-bottom { flex-direction: column; gap: 8px; }
  .filmstrip-cell { width: 128px; height: 80px; }
}
