/* ══════════════════════════════
   CHECKOUT PAGE — Design tokens & layout
══════════════════════════════ */
:root {
  --brown: #1C0F06;
  --brown-m: #2E1A0A;
  --gold: #C9921A;
  --gold-l: #E8A820;
  --gold-xl: #F5C842;
  --gold-pale: #FDF0D0;
  --gold-glow: rgba(201,146,26,.11);
  --cream: #FBF7F0;
  --cream-d: #F0E8D8;
  --cream-dd: #E4D6C0;
  --text-1: #1C0F06;
  --text-2: #5C3D20;
  --text-3: #9A7550;
  --border: rgba(160,128,80,.15);
  --white: #FFFFFF;
  --success: #27AE60;
  --danger: #C0392B;
  --r: 14px;
  --r-sm: 9px;
  --T: .24s cubic-bezier(.4,0,.2,1);
}
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { font-size: 15px; scroll-behavior: smooth; }
body.page-checkout {
  font-family: 'DM Sans', sans-serif;
  background: var(--cream);
  color: var(--text-1);
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
}
body.page-checkout::after {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9999;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='250' height='250'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.78' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='250' height='250' filter='url(%23n)' opacity='.022'/%3E%3C/svg%3E");
}

/* Nav */
.page-checkout .checkout-nav {
  background: rgba(28,15,6,.97);
  backdrop-filter: blur(20px);
  height: 68px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 5%;
  border-bottom: 1px solid rgba(201,146,26,.1);
  position: sticky;
  top: 0;
  z-index: 200;
}
.page-checkout .checkout-nav .nav-logo {
  font-family: 'Playfair Display', serif;
  font-size: 1.35rem;
  font-weight: 800;
  color: var(--gold-l);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: .5rem;
}
.page-checkout .checkout-nav .nav-logo em { font-style: italic; color: rgba(255,255,255,.82); }
.page-checkout .checkout-nav .nav-logo img { height: 32px; width: auto; display: block; }
.page-checkout .checkout-nav .nav-links { display: flex; align-items: center; gap: 2rem; list-style: none; }
.page-checkout .checkout-nav .nav-links a {
  font-size: .74rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(255,255,255,.48);
  text-decoration: none;
  transition: color var(--T);
}
.page-checkout .checkout-nav .nav-links a:hover { color: var(--gold-l); }
.page-checkout .checkout-nav .nav-back {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  background: transparent;
  border: 1.5px solid rgba(255,255,255,.18);
  color: rgba(255,255,255,.6);
  border-radius: var(--r-sm);
  padding: .42rem 1.1rem;
  font-family: 'DM Sans', sans-serif;
  font-size: .73rem;
  font-weight: 700;
  letter-spacing: .07em;
  text-transform: uppercase;
  cursor: pointer;
  text-decoration: none;
  transition: all var(--T);
}
.page-checkout .checkout-nav .nav-back:hover { border-color: rgba(255,255,255,.4); color: #fff; }

/* Page header */
.page-checkout .checkout-page-header {
  background: var(--brown);
  padding: 3rem 5% 2.8rem;
  position: relative;
  overflow: hidden;
}
.page-checkout .checkout-page-header::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 55% 75% at 88% 50%, rgba(201,146,26,.08), transparent);
}
.page-checkout .ph-eyebrow { display: inline-flex; align-items: center; gap: .4rem; font-size: .62rem; letter-spacing: .2em; text-transform: uppercase; font-weight: 700; color: var(--gold); margin-bottom: .7rem; }
.page-checkout .ph-eyebrow::before { content: ''; width: 24px; height: 1.5px; background: var(--gold); }
.page-checkout .ph-title { font-family: 'Playfair Display', serif; font-size: clamp(1.9rem, 3.8vw, 3rem); font-weight: 800; color: #fff; line-height: 1.1; }
.page-checkout .ph-title em { font-style: italic; color: var(--gold-l); }
.page-checkout .ph-meta { display: flex; align-items: center; gap: 1.5rem; margin-top: .85rem; font-size: .78rem; color: rgba(255,255,255,.32); flex-wrap: wrap; }
.page-checkout .ph-meta strong { color: rgba(255,255,255,.6); }
.page-checkout .breadcrumb { display: flex; align-items: center; gap: .5rem; font-size: .7rem; color: rgba(255,255,255,.28); margin-bottom: 1.1rem; }
.page-checkout .breadcrumb a { color: rgba(255,255,255,.32); text-decoration: none; transition: color var(--T); }
.page-checkout .breadcrumb a:hover { color: var(--gold-l); }
.page-checkout .breadcrumb-sep { opacity: .3; }

/* Progress bar */
.page-checkout .progress-bar { background: var(--white); border-bottom: 1px solid var(--border); padding: 1rem 5%; }
.page-checkout .steps { display: flex; align-items: center; max-width: 600px; margin: 0 auto; }
.page-checkout .step-item { display: flex; align-items: center; gap: .55rem; flex: 1; position: relative; }
.page-checkout .step-item:not(:last-child)::after { content: ''; position: absolute; left: calc(50% + 18px); right: calc(-50% + 18px); height: 1px; background: var(--border); top: 50%; }
.page-checkout .step-dot { width: 30px; height: 30px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: .72rem; font-weight: 800; flex-shrink: 0; }
.page-checkout .step-dot.done { background: var(--gold); color: #fff; }
.page-checkout .step-dot.active { background: var(--brown); color: var(--gold-l); border: 2px solid var(--gold); }
.page-checkout .step-dot.pending { background: var(--cream-d); color: var(--text-3); }
.page-checkout .step-text { font-size: .65rem; font-weight: 700; text-transform: uppercase; letter-spacing: .09em; }
.page-checkout .step-item.s-done .step-text { color: var(--gold); }
.page-checkout .step-item.s-active .step-text { color: var(--text-1); }
.page-checkout .step-item.s-pending .step-text { color: var(--text-3); }

/* Layout */
.page-checkout .checkout-layout { display: grid; grid-template-columns: 1fr 400px; gap: 2rem; max-width: 1260px; margin: 0 auto; padding: 2.5rem 5% 5rem; align-items: start; }

/* Form sections */
.page-checkout .form-section { background: var(--white); border: 1px solid var(--border); border-radius: var(--r); overflow: hidden; margin-bottom: 1.2rem; }
.page-checkout .fs-header { padding: 1.2rem 1.8rem; border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: .8rem; background: var(--cream); }
.page-checkout .fs-number { width: 28px; height: 28px; border-radius: 50%; background: var(--brown); color: var(--gold-l); display: flex; align-items: center; justify-content: center; font-size: .72rem; font-weight: 800; flex-shrink: 0; }
.page-checkout .fs-title { font-family: 'Playfair Display', serif; font-size: .98rem; font-weight: 700; color: var(--text-1); }
.page-checkout .fs-subtitle { font-size: .72rem; color: var(--text-3); margin-top: .05rem; }
.page-checkout .fs-body { padding: 1.6rem 1.8rem; }

.page-checkout .f-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.page-checkout .f-group { margin-bottom: 1rem; position: relative; }
.page-checkout .f-group:last-child { margin-bottom: 0; }
.page-checkout .f-label { display: flex; align-items: center; justify-content: space-between; font-size: .67rem; font-weight: 700; letter-spacing: .09em; text-transform: uppercase; color: var(--text-2); margin-bottom: .42rem; }
.page-checkout .f-label .req { color: var(--gold); font-size: .75rem; line-height: 1; }
.page-checkout .f-label .opt { font-size: .65rem; font-weight: 500; text-transform: none; letter-spacing: 0; color: var(--text-3); font-style: italic; }
.page-checkout .f-input, .page-checkout .f-select, .page-checkout .f-textarea {
  width: 100%;
  background: var(--cream);
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  padding: .72rem 1rem;
  font-family: 'DM Sans', sans-serif;
  font-size: .85rem;
  color: var(--text-1);
  outline: none;
  transition: border-color var(--T), background var(--T), box-shadow var(--T);
}
.page-checkout .f-input:focus, .page-checkout .f-select:focus, .page-checkout .f-textarea:focus { border-color: var(--gold); background: var(--white); box-shadow: 0 0 0 3px rgba(201,146,26,.1); }
.page-checkout .f-input.error { border-color: var(--danger); }
.page-checkout .f-error { font-size: .68rem; color: var(--danger); margin-top: .3rem; display: none; }
.page-checkout .f-error.show { display: block; }
.page-checkout .f-input-icon { position: absolute; right: .9rem; top: 2.05rem; font-size: .9rem; pointer-events: none; }
.page-checkout .f-select { -webkit-appearance: none; cursor: pointer; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='7' viewBox='0 0 10 7'%3E%3Cpath d='M1 1l4 4 4-4' stroke='rgba(92,61,32,.6)' stroke-width='1.4' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right .9rem center; }
.page-checkout .f-textarea { resize: vertical; min-height: 85px; line-height: 1.65; }
.page-checkout .f-hint { font-size: .68rem; color: var(--text-3); margin-top: .35rem; line-height: 1.5; }

.page-checkout .delivery-opts { display: flex; flex-direction: column; gap: .75rem; }
.page-checkout .d-opt { display: flex; align-items: center; gap: 1rem; padding: 1rem 1.2rem; border: 1.5px solid var(--border); border-radius: var(--r-sm); cursor: pointer; transition: all var(--T); background: var(--cream); }
.page-checkout .d-opt:hover { border-color: rgba(201,146,26,.3); background: var(--gold-pale); }
.page-checkout .d-opt.sel { border-color: var(--gold); background: var(--gold-pale); }
.page-checkout .d-icon {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--gold-pale), rgba(201,146,26,.12));
  border: 1px solid rgba(201,146,26,.2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  flex-shrink: 0;
  line-height: 1;
  box-shadow: 0 2px 12px rgba(201,146,26,.15);
}
.page-checkout .d-opt.sel .d-icon {
  background: linear-gradient(135deg, rgba(201,146,26,.25), rgba(201,146,26,.12));
  border-color: rgba(201,146,26,.4);
  box-shadow: 0 4px 16px rgba(201,146,26,.2);
}
.page-checkout .d-radio { width: 18px; height: 18px; border-radius: 50%; border: 2px solid var(--border); flex-shrink: 0; display: flex; align-items: center; justify-content: center; transition: all var(--T); }
.page-checkout .d-opt.sel .d-radio { border-color: var(--gold); background: var(--gold); }
.page-checkout .d-opt.sel .d-radio::after { content: ''; width: 6px; height: 6px; border-radius: 50%; background: #fff; }
.page-checkout .d-info { flex: 1; min-width: 0; }
.page-checkout .d-name { font-size: .9rem; font-weight: 700; color: var(--text-1); }
.page-checkout .d-desc { font-size: .72rem; color: var(--text-3); margin-top: .1rem; }
.page-checkout .d-price { font-family: 'Playfair Display', serif; font-size: 1rem; font-weight: 700; color: var(--text-1); flex-shrink: 0; }
.page-checkout .d-price.free { color: var(--success); font-size: .88rem; font-weight: 800; }

.page-checkout .pay-opts { display: grid; grid-template-columns: 1fr 1fr; gap: .7rem; }
.page-checkout .pay-opt { padding: 1rem 1.1rem; border: 1.5px solid var(--border); border-radius: var(--r-sm); cursor: pointer; transition: all var(--T); background: var(--cream); display: flex; align-items: center; gap: .75rem; }
.page-checkout .pay-opt:hover { border-color: rgba(201,146,26,.3); background: var(--gold-pale); }
.page-checkout .pay-opt.sel { border-color: var(--gold); background: var(--gold-pale); }
.page-checkout .pay-icon { font-size: 1.4rem; flex-shrink: 0; }
.page-checkout .pay-name { font-size: .82rem; font-weight: 700; color: var(--text-1); }
.page-checkout .pay-detail { font-size: .68rem; color: var(--text-3); margin-top: .08rem; }
.page-checkout .pay-radio { width: 16px; height: 16px; border-radius: 50%; border: 2px solid var(--border); flex-shrink: 0; margin-left: auto; transition: all var(--T); }
.page-checkout .pay-opt.sel .pay-radio { background: var(--gold); border-color: var(--gold); }

.page-checkout .pay-fields { margin-top: 1rem; padding: 1.2rem; background: var(--cream-d); border-radius: var(--r-sm); border: 1px solid var(--border); }
.page-checkout .pay-fields-title { font-size: .68rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--text-2); margin-bottom: .9rem; }

/* Order sidebar */
.page-checkout .order-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--r); overflow: hidden; position: sticky; top: 88px; }
.page-checkout .oc-header { background: var(--brown); padding: 1.4rem 1.8rem; border-bottom: 1px solid rgba(201,146,26,.1); }
.page-checkout .oc-title { font-family: 'Playfair Display', serif; font-size: 1rem; font-weight: 700; color: #fff; }
.page-checkout .oc-sub { font-size: .7rem; color: rgba(255,255,255,.32); margin-top: .15rem; }
.page-checkout .oc-edit { font-size: .67rem; color: var(--gold); text-decoration: none; transition: color var(--T); float: right; margin-top: .1rem; }
.page-checkout .oc-edit:hover { color: var(--gold-l); }
.page-checkout .oc-items { padding: 1.4rem 1.8rem; border-bottom: 1px solid var(--border); display: flex; flex-direction: column; gap: .9rem; max-height: 260px; overflow-y: auto; }
.page-checkout .oc-item { display: flex; align-items: center; gap: .9rem; }
.page-checkout .oc-item-img { width: 46px; height: 46px; border-radius: 8px; object-fit: cover; background: var(--cream-d); flex-shrink: 0; overflow: hidden; }
.page-checkout .oc-item-img img { width: 100%; height: 100%; object-fit: cover; }
.page-checkout .oc-item-info { flex: 1; min-width: 0; }
.page-checkout .oc-item-name { font-size: .82rem; font-weight: 700; color: var(--text-1); line-height: 1.3; }
.page-checkout .oc-item-qty { font-size: .7rem; color: var(--text-3); margin-top: .1rem; }
.page-checkout .oc-item-price { font-family: 'Playfair Display', serif; font-size: .92rem; font-weight: 700; color: var(--text-1); flex-shrink: 0; }

.page-checkout .oc-summary { padding: 1.4rem 1.8rem; border-bottom: 1px solid var(--border); }
.page-checkout .sum-row { display: flex; justify-content: space-between; align-items: center; padding: .48rem 0; border-bottom: 1px solid rgba(160,128,80,.06); font-size: .82rem; }
.page-checkout .sum-row:last-child { border-bottom: none; }
.page-checkout .sum-lbl { color: var(--text-3); }
.page-checkout .sum-val { font-weight: 700; color: var(--text-1); }
.page-checkout .sum-val.free { color: var(--success); }
.page-checkout .sum-val.gold { color: var(--gold); }
.page-checkout .oc-total { display: flex; justify-content: space-between; align-items: center; padding: 1.2rem 1.8rem; background: var(--cream); border-bottom: 1px solid var(--border); }
.page-checkout .ot-label { font-size: .95rem; font-weight: 700; color: var(--text-1); }
.page-checkout .ot-value { font-family: 'Playfair Display', serif; font-size: 1.55rem; font-weight: 800; color: var(--text-1); }
.page-checkout .ot-note { font-size: .67rem; color: var(--text-3); text-align: right; margin-top: .1rem; }

.page-checkout .oc-cta { padding: 1.4rem 1.8rem; }
.page-checkout .place-btn {
  width: 100%;
  padding: 1rem;
  border: none;
  border-radius: var(--r-sm);
  background: linear-gradient(135deg, var(--gold), var(--gold-l));
  color: #fff;
  font-family: 'DM Sans', sans-serif;
  font-size: .9rem;
  font-weight: 700;
  letter-spacing: .07em;
  text-transform: uppercase;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .55rem;
  box-shadow: 0 6px 24px rgba(201,146,26,.38);
  transition: all var(--T);
  text-decoration: none;
  box-sizing: border-box;
}
.page-checkout .place-btn:hover { transform: translateY(-2px); box-shadow: 0 10px 32px rgba(201,146,26,.52); }
.page-checkout .place-btn:disabled { opacity: .7; cursor: not-allowed; transform: none; }
.page-checkout .wa-btn {
  width: 100%;
  margin-top: .7rem;
  padding: .82rem;
  border: 1.5px solid rgba(37,211,102,.35);
  border-radius: var(--r-sm);
  background: rgba(37,211,102,.07);
  color: #1a7a40;
  font-family: 'DM Sans', sans-serif;
  font-size: .8rem;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  transition: all var(--T);
  text-decoration: none;
  box-sizing: border-box;
}
.page-checkout .wa-btn:hover { background: rgba(37,211,102,.15); border-color: rgba(37,211,102,.55); }
.page-checkout .oc-trust { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: .5rem; padding: 1rem 1.8rem; background: var(--cream); border-top: 1px solid var(--border); }
.page-checkout .trust-item { display: flex; flex-direction: column; align-items: center; gap: .25rem; text-align: center; }
.page-checkout .trust-item span:first-child { font-size: 1rem; }
.page-checkout .trust-item span:last-child { font-size: .58rem; font-weight: 700; color: var(--text-3); line-height: 1.3; }

/* Success overlay */
.page-checkout .success-overlay { display: none; position: fixed; inset: 0; z-index: 500; background: rgba(28,15,6,.65); backdrop-filter: blur(6px); align-items: center; justify-content: center; }
.page-checkout .success-overlay.show { display: flex; }
.page-checkout .success-card { background: var(--white); border-radius: var(--r); padding: 3rem 2.5rem; max-width: 460px; width: 90%; text-align: center; box-shadow: 0 24px 80px rgba(0,0,0,.3); animation: checkoutPopIn .5s cubic-bezier(.34,1.56,.64,1); }
@keyframes checkoutPopIn { from { opacity: 0; transform: scale(.85); } to { opacity: 1; transform: scale(1); } }
.page-checkout .success-icon { font-size: 3.5rem; margin-bottom: 1.2rem; }
.page-checkout .success-title { font-family: 'Playfair Display', serif; font-size: 1.6rem; font-weight: 800; color: var(--text-1); margin-bottom: .5rem; }
.page-checkout .success-title em { font-style: italic; color: var(--gold); }
.page-checkout .success-desc { font-size: .85rem; color: var(--text-3); line-height: 1.8; max-width: 320px; margin: 0 auto 1.8rem; }
.page-checkout .success-order { background: var(--cream); border-radius: var(--r-sm); padding: 1rem 1.4rem; font-size: .82rem; margin-bottom: 1.8rem; border: 1px solid var(--border); }
.page-checkout .success-order span { font-weight: 700; color: var(--gold); }
.page-checkout .success-cta { background: var(--gold); color: #fff; border: none; border-radius: var(--r-sm); padding: .8rem 2rem; font-family: 'DM Sans', sans-serif; font-size: .82rem; font-weight: 700; cursor: pointer; transition: all var(--T); display: inline-block; text-decoration: none; }
.page-checkout .success-cta:hover { background: var(--gold-l); transform: translateY(-1px); }

/* Toast */
.page-checkout .checkout-toast { position: fixed; bottom: 1.8rem; right: 1.8rem; z-index: 9000; background: var(--brown); color: #fff; padding: .9rem 1.4rem; border-radius: var(--r-sm); font-size: .8rem; font-weight: 600; display: flex; align-items: center; gap: .5rem; box-shadow: 0 12px 40px rgba(0,0,0,.25); border-left: 3px solid var(--gold); transform: translateX(140%); transition: transform .32s cubic-bezier(.34,1.56,.64,1); }
.page-checkout .checkout-toast.show { transform: translateX(0); }

/* Footer */
.page-checkout .footer-mini { background: var(--brown); padding: 2rem 5%; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem; border-top: 1px solid rgba(201,146,26,.08); }
.page-checkout .footer-brand { font-family: 'Playfair Display', serif; font-size: 1.1rem; font-weight: 800; color: var(--gold-l); }
.page-checkout .footer-brand em { font-style: italic; color: rgba(255,255,255,.7); }
.page-checkout .footer-links { display: flex; gap: 1.5rem; }
.page-checkout .footer-links a { font-size: .72rem; color: rgba(255,255,255,.3); text-decoration: none; transition: color var(--T); }
.page-checkout .footer-links a:hover { color: var(--gold-l); }
.page-checkout .footer-copy { font-size: .68rem; color: rgba(255,255,255,.18); }

@keyframes checkoutFadeUp { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: translateY(0); } }
.page-checkout .form-section { animation: checkoutFadeUp .4s ease both; }
.page-checkout .form-section:nth-child(2) { animation-delay: .06s; }
.page-checkout .form-section:nth-child(3) { animation-delay: .12s; }
.page-checkout .form-section:nth-child(4) { animation-delay: .18s; }

@media (max-width: 960px) {
  .page-checkout .checkout-layout { grid-template-columns: 1fr; }
  .page-checkout .order-card { position: static; }
  .page-checkout .f-row { grid-template-columns: 1fr; }
  .page-checkout .pay-opts { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .page-checkout .checkout-nav .nav-links { display: none; }
  .page-checkout .steps { gap: 0; }
  .page-checkout .step-text { display: none; }
}
