/* Shared cart UI — header cart button + slide-in drawer + toast.
   Loaded on pages that aren't /shop or the PDP (which already get this via shop.css)
   so the cart works identically everywhere. Assumes the brand CSS variables exist. */
.site-nav{display:flex;align-items:center;gap:24px}
.cart-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;color:var(--bone);border:1px solid var(--line);background:transparent;cursor:pointer;transition:border-color .2s,background .2s}
.cart-btn:hover{border-color:var(--ceil);background:rgba(57,198,214,.08)}
.cart-btn svg{width:18px;height:18px}
.cart-count{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--ceil);color:var(--ink);font-size:.62rem;font-weight:800;letter-spacing:.04em;display:flex;align-items:center;justify-content:center}
.cart-count.is-hidden{display:none}

.cart-drawer .btn{display:inline-flex;align-items:center;justify-content:center;padding:16px 28px;border-radius:var(--radius-sm);font-weight:700;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;transition:all .15s;border:1px solid transparent;text-decoration:none}
.cart-drawer .btn--primary{background:var(--ceil);color:var(--ink);flex:1}
.cart-drawer .btn--primary:hover{background:var(--mint)}
.cart-drawer .btn--ghost{background:transparent;color:var(--bone);border-color:var(--line)}
.cart-drawer .btn--ghost:hover{border-color:var(--bone)}

.cart-drawer{position:fixed;inset:0;z-index:100;pointer-events:none;visibility:hidden;opacity:0;transition:opacity .25s,visibility 0s linear .25s}
.cart-drawer.is-open{pointer-events:auto;visibility:visible;opacity:1;transition:opacity .25s,visibility 0s}
.cart-drawer__scrim{position:absolute;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(2px)}
.cart-drawer__panel{position:absolute;top:0;right:0;width:min(420px,100vw);height:100%;background:var(--ink);border-left:1px solid var(--line);display:flex;flex-direction:column;transform:translateX(100%);transition:transform .35s var(--ease-out,ease)}
.cart-drawer.is-open .cart-drawer__panel{transform:translateX(0)}
.cart-drawer__head{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--line)}
.cart-drawer__title{font-weight:800;font-size:.85rem;letter-spacing:.22em;text-transform:uppercase}
.cart-drawer__close{font-size:1.6rem;color:var(--bone);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:none;border:0;cursor:pointer;transition:background .15s}
.cart-drawer__close:hover{background:var(--line)}
.cart-drawer__body{flex:1;overflow-y:auto;padding:20px 24px}
.cart-drawer__empty{text-align:center;padding:40px 0;color:var(--bone-60);font-size:.95rem}
.cart-line{display:grid;grid-template-columns:80px 1fr;gap:14px;padding:16px 0;border-bottom:1px solid var(--line)}
.cart-line__img{width:80px;height:100px;object-fit:cover;border-radius:var(--radius-sm);background:var(--graphite)}
.cart-line__name{font-weight:700;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:var(--bone);margin-bottom:4px}
.cart-line__opts{font-size:.78rem;color:var(--bone-60);margin-bottom:6px}
.cart-line__price{font-weight:700;font-size:.85rem;color:var(--bone);margin-bottom:8px}
.cart-line__stepper{display:flex;align-items:center;gap:6px;font-size:.85rem}
.cart-line__stepper button{width:32px;height:32px;border:1px solid var(--line);border-radius:6px;color:var(--bone);font-weight:600;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center}
.cart-line__stepper button:hover{border-color:var(--bone)}
.cart-line__remove{margin-left:auto;font-size:.7rem;color:var(--bone-60);text-transform:uppercase;letter-spacing:.12em;border:none!important;width:auto!important;padding:0 6px}
.cart-line__remove:hover{color:var(--err)}
.cart-drawer__foot{padding:20px 24px;border-top:1px solid var(--line)}
.cart-drawer__shipping{font-weight:700;font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ceil);text-align:center;margin-bottom:14px}
.cart-drawer__subtotal{display:flex;justify-content:space-between;font-weight:700;font-size:1rem;margin-bottom:16px}
.cart-drawer__actions{display:flex;flex-direction:column;gap:8px}
.toast-host{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:200;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{background:var(--graphite);color:var(--bone);border:1px solid var(--line);border-radius:var(--radius-sm);padding:12px 18px;display:flex;align-items:center;gap:14px;font-size:.85rem;pointer-events:auto}
.toast__action{color:var(--ceil);font-weight:700;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;background:none;border:0;cursor:pointer}
body.no-scroll{overflow:hidden}
