/* ===== Party Box — Magical Checkout overlay =====================================
 * A dedicated, multi-step checkout that opens over the builder (build.html).
 * Layered on top of the castle design system (castle.css) + funnel.css, reusing
 * the same gold/cream/serif tokens so it feels like one continuous storybook.
 * Self-contained: the DOM is injected by checkout.js, so build.html only needs
 * to load this stylesheet + that script.
 * ============================================================================ */

.co-scrim{position:fixed;inset:0;z-index:120;display:none;overflow-y:auto;
  padding:clamp(10px,3vw,28px);background:radial-gradient(120% 120% at 50% -10%,rgba(58,42,29,.55),rgba(6,4,2,.9) 60%);
  backdrop-filter:blur(8px);
  scrollbar-width:thin;scrollbar-color:rgba(231,192,115,.55) transparent}
.co-scrim::-webkit-scrollbar{width:9px}
.co-scrim::-webkit-scrollbar-track{background:transparent}
.co-scrim::-webkit-scrollbar-thumb{background:linear-gradient(var(--gold),var(--gold-deep));
  border-radius:999px;border:2px solid transparent;background-clip:padding-box}
/* display:flex + child margin:auto centers the card when it fits, yet keeps BOTH
   the top and bottom reachable by scrolling when it's taller than the viewport. */
.co-scrim.show{display:flex;animation:co-fade .35s ease}
@keyframes co-fade{from{opacity:0}to{opacity:1}}

.co{position:relative;display:grid;grid-template-columns:330px 1fr;width:100%;max-width:980px;margin:auto;
  border-radius:26px;overflow:hidden;color:var(--cream);
  border:1px solid rgba(231,192,115,.42);
  box-shadow:0 40px 120px rgba(0,0,0,.7),0 0 0 1px rgba(231,192,115,.12) inset;
  animation:co-rise .45s cubic-bezier(.2,.9,.25,1)}
@keyframes co-rise{from{transform:translateY(24px) scale(.98);opacity:0}to{transform:none;opacity:1}}

.co-x{position:absolute;top:14px;right:16px;z-index:5;width:38px;height:38px;border-radius:50%;
  border:1px solid rgba(231,192,115,.4);background:rgba(12,8,5,.5);color:var(--cream);
  font-size:22px;line-height:1;cursor:pointer;transition:.2s}
.co-x:hover{background:rgba(231,192,115,.16);border-color:var(--gold);transform:rotate(90deg)}

/* ---- LEFT: the enchanted brand + step rail + running summary ---------------- */
.co-aside{position:relative;overflow:hidden;padding:30px 26px;
  background:linear-gradient(165deg,#3a2a1d 0%,#1c130b 55%,#120c07 100%)}
.co-aside::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(60% 40% at 80% 0%,rgba(231,192,115,.22),transparent 70%)}
.co-stars{position:absolute;inset:0;pointer-events:none;z-index:0}
.co-stars i{position:absolute;width:3px;height:3px;border-radius:50%;background:#fff7e8;opacity:.7;
  box-shadow:0 0 6px 1px rgba(255,247,232,.8);animation:co-tw var(--d,4s) ease-in-out var(--t,0s) infinite}
@keyframes co-tw{0%,100%{opacity:.12;transform:scale(.6)}50%{opacity:.95;transform:scale(1.15)}}

.co-aside-in{position:relative;z-index:1;display:flex;flex-direction:column;height:100%}
.co-brand{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-size:22px;font-weight:700;color:var(--cream)}
.co-brand img{height:34px;width:auto}
.co-tagline{margin:8px 0 26px;font-size:12.5px;color:#cdbfa6;line-height:1.5}

/* step rail */
.co-rail{display:flex;flex-direction:column;gap:2px;margin-bottom:auto}
.co-rstep{display:flex;align-items:flex-start;gap:13px;padding:11px 0;position:relative}
.co-rstep .dot{flex:none;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;
  font-weight:800;font-size:13px;color:#cdbfa6;background:rgba(12,8,5,.5);
  border:1.5px solid rgba(231,192,115,.35);transition:.3s}
.co-rstep .rt{font-weight:800;font-size:14px;color:#e6d6bf;transition:.3s}
.co-rstep .rs{font-size:11.5px;color:#9c8a6d;margin-top:1px}
/* connector line between dots */
.co-rstep:not(:last-child)::before{content:"";position:absolute;left:14.5px;top:41px;bottom:-11px;width:1.5px;
  background:rgba(231,192,115,.25)}
.co-rstep.done:not(:last-child)::before{background:linear-gradient(var(--gold),var(--gold-deep))}
.co-rstep.active .dot{color:#4a330f;background:linear-gradient(120deg,#ffe9bf,var(--gold) 60%,var(--gold-deep));
  border-color:var(--gold);box-shadow:0 0 0 4px rgba(231,192,115,.18),0 0 14px rgba(231,192,115,.5)}
.co-rstep.active .rt{color:var(--cream)}
.co-rstep.done .dot{color:var(--gold);border-color:var(--gold);background:rgba(231,192,115,.12)}

/* running total chip on the rail */
.co-mini{margin-top:24px;padding:16px 18px;border-radius:16px;
  background:linear-gradient(150deg,rgba(231,192,115,.16),rgba(255,247,232,.04));
  border:1px solid rgba(231,192,115,.3)}
.co-mini .ml{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:800}
.co-mini .mv{font-family:var(--serif);font-size:32px;color:var(--cream);margin-top:2px}
.co-mini .mn{font-size:12px;color:#cdbfa6;margin-top:6px;line-height:1.45}
.co-mini .mn b{color:var(--gold)}
.co-secure{display:flex;align-items:center;gap:7px;margin-top:16px;font-size:11.5px;color:#b6a888}
.co-secure svg{width:14px;height:14px;stroke:var(--gold);fill:none}

/* ---- RIGHT: the form panels ------------------------------------------------ */
.co-main{display:flex;flex-direction:column;min-width:0;
  background:linear-gradient(180deg,#221710,#160f09);overflow:hidden}
.co-head{padding:30px 32px 6px}
.co-eyebrow{font-size:11.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);font-weight:800}
.co-head h2{font-family:var(--serif);font-size:clamp(26px,3.5vw,34px);color:var(--cream);line-height:1.05;margin:7px 0 4px}
.co-head p{color:#cdbfa6;font-size:14px;line-height:1.5}

.co-body{padding:14px 32px 6px;flex:1}
.co-panel{display:none;animation:co-slide .35s ease}
.co-panel.on{display:block}
@keyframes co-slide{from{opacity:0;transform:translateX(14px)}to{opacity:1;transform:none}}

/* fields */
.co-grid{display:grid;gap:14px}
.co-grid.two{grid-template-columns:1fr 1fr}
.co-grid.three{grid-template-columns:1.4fr 1fr 1fr}
@media(max-width:560px){.co-grid.two,.co-grid.three{grid-template-columns:1fr}}
.co-fld{display:flex;flex-direction:column;gap:6px;min-width:0}
.co-fld>span{font-size:12px;font-weight:800;color:#e6d6bf;letter-spacing:.02em}
.co-fld>span .req{color:var(--gold)}
.co-in{width:100%;font-family:var(--sans);font-size:15px;color:var(--cream);
  background:rgba(12,8,5,.55);border:1.5px solid rgba(231,192,115,.28);border-radius:12px;
  padding:12px 14px;transition:.18s}
.co-in::placeholder{color:#8a7a5f}
.co-in:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(231,192,115,.15);background:rgba(20,13,8,.7)}
.co-in.bad{border-color:#e08a8a;box-shadow:0 0 0 3px rgba(224,138,138,.15)}
select.co-in{appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23e7c073' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:34px}
select.co-in option{background:#1c130b;color:var(--cream)}

/* section label inside a panel */
.co-seclbl{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:800;
  margin:20px 0 12px;display:flex;align-items:center;gap:10px}
.co-seclbl::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,rgba(231,192,115,.35),transparent)}

/* the optional "create account" magic card */
.co-acct{margin-top:18px;border:2px dashed rgba(231,192,115,.5);border-radius:16px;overflow:hidden;
  background:rgba(231,192,115,.06);transition:.25s}
.co-acct.on{border-style:solid;border-color:var(--gold);background:rgba(231,192,115,.1)}
.co-acct-top{display:flex;align-items:center;gap:14px;padding:15px 17px;cursor:pointer}
.co-acct-top .em{font-size:26px;filter:drop-shadow(0 0 8px rgba(231,192,115,.5))}
.co-acct-top .tt{font-weight:800;color:var(--cream);font-size:15px}
.co-acct-top .ts{font-size:12.5px;color:#cdbfa6;margin-top:2px;line-height:1.4}
.co-acct-top .ts b{color:var(--gold)}
.co-sw{flex:none;width:46px;height:26px;border-radius:999px;background:rgba(12,8,5,.6);
  border:1.5px solid rgba(231,192,115,.4);position:relative;transition:.25s}
.co-sw i{position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;
  background:#cdbfa6;transition:.25s}
.co-acct.on .co-sw{background:linear-gradient(120deg,var(--gold),var(--gold-deep));border-color:var(--gold)}
.co-acct.on .co-sw i{left:22px;background:#4a330f}
.co-acct-body{max-height:0;opacity:0;overflow:hidden;transition:.3s;padding:0 17px}
.co-acct.on .co-acct-body{max-height:240px;opacity:1;padding:0 17px 17px}

/* "same as shipping" inline check */
.co-check{display:flex;align-items:center;gap:11px;cursor:pointer;font-size:14px;color:#e6d6bf;
  padding:13px 15px;border-radius:13px;border:1.5px solid rgba(231,192,115,.28);background:rgba(12,8,5,.4);
  margin-bottom:4px;transition:.2s}
.co-check:hover{border-color:rgba(231,192,115,.5)}
.co-check .bx{flex:none;width:22px;height:22px;border-radius:7px;border:2px solid var(--gold);
  display:grid;place-items:center;color:#4a330f;font-size:14px;font-weight:900;background:transparent;transition:.2s}
.co-check.on{border-color:var(--gold);background:rgba(231,192,115,.1)}
.co-check.on .bx{background:var(--gold)}
.co-check .bx::after{content:"✓";opacity:0;transition:.15s}
.co-check.on .bx::after{opacity:1}
.co-check b{color:var(--cream);font-weight:800}

/* demo payment ribbon */
.co-paynote{display:flex;align-items:center;gap:9px;margin:4px 0 16px;padding:10px 14px;border-radius:12px;
  font-size:12.5px;color:#e6d6bf;background:rgba(231,192,115,.08);border:1px solid rgba(231,192,115,.25)}
.co-paynote b{color:var(--gold)}
.co-cardrow{position:relative}
.co-cardbrands{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:15px;letter-spacing:2px;opacity:.7}

/* review list */
.co-review{border:1px solid rgba(231,192,115,.25);border-radius:16px;overflow:hidden;margin-top:4px}
.co-review .rrow{display:flex;justify-content:space-between;gap:14px;padding:12px 16px;font-size:13.5px;
  border-bottom:1px solid rgba(231,192,115,.12)}
.co-review .rrow:last-child{border-bottom:0}
.co-review .rrow .k{color:#9c8a6d;font-weight:800;font-size:11px;letter-spacing:.12em;text-transform:uppercase}
.co-review .rrow .v{color:var(--cream);text-align:right;line-height:1.45}
.co-review .rtot{display:flex;justify-content:space-between;align-items:center;padding:15px 16px;
  background:rgba(231,192,115,.1)}
.co-review .rtot span{font-family:var(--serif);font-size:17px;color:var(--cream)}
.co-review .rtot b{font-family:var(--serif);font-size:26px;color:var(--gold)}

/* footer / actions */
.co-foot{display:flex;align-items:center;gap:12px;padding:18px 32px 26px;
  border-top:1px solid rgba(231,192,115,.18);background:linear-gradient(180deg,transparent,rgba(0,0,0,.2))}
.co-err{flex:1;color:#ffb3b3;font-size:13px;font-weight:700;min-height:1em}
.co-btn{font-family:var(--sans);font-weight:800;font-size:14.5px;border-radius:999px;padding:13px 26px;
  cursor:pointer;border:1px solid transparent;transition:.2s;white-space:nowrap}
.co-btn.ghost{background:rgba(12,8,5,.4);border-color:rgba(231,192,115,.4);color:var(--cream)}
.co-btn.ghost:hover{border-color:var(--gold);background:rgba(231,192,115,.12)}
.co-btn.primary{color:#4a330f;background:linear-gradient(100deg,#ffe9bf,var(--gold) 55%,var(--gold-deep));
  box-shadow:0 10px 26px rgba(231,192,115,.32);position:relative;overflow:hidden}
.co-btn.primary:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(231,192,115,.42)}
.co-btn.primary:disabled{opacity:.6;cursor:wait;transform:none}
/* gold-foil shimmer sweep on the place-order button */
.co-btn.primary::after{content:"";position:absolute;top:0;left:-60%;width:40%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.65),transparent);
  transform:skewX(-18deg);animation:co-foil 3.2s ease-in-out infinite}
@keyframes co-foil{0%{left:-60%}55%,100%{left:130%}}

/* tiny sparkle that bursts when account toggles on / order places */
.co-spark{position:fixed;z-index:200;pointer-events:none;font-size:18px;animation:co-pop .9s ease forwards}
@keyframes co-pop{0%{opacity:0;transform:translate(0,0) scale(.4)}
  30%{opacity:1}100%{opacity:0;transform:translate(var(--dx,0),var(--dy,-40px)) scale(1.2)}}

/* ---- responsive: collapse to a single column ------------------------------- */
@media(max-width:720px){
  .co{grid-template-columns:1fr}
  .co-aside{display:none}
  .co-head{padding-top:40px}
}
