/* ============================================================
   SSRP Solutions — WooCommerce skin
   Recreates the "premium dark" single variable-product design on
   real WooCommerce markup. Builds on assets/ssrp-app.css (tokens,
   .nav, .btn, .card, .eyebrow, .imgph, .glow-*, .footer, .badge-soft).
   Single attribute ("Package") → one swatch row. Operations = blue hue.
   ============================================================ */

/* Tokens the bespoke product CSS uses that the base system expresses as
   literals — define them here so this file is self-sufficient. */
:root{
  --r-pill:999px;
  --dur-fast:.2s; --dur-mid:.3s;
  --ease:cubic-bezier(.22,1,.36,1);
  --fw-hairline:200; --fw-medium:500; --fw-semibold:600; --fw-bold:700;
  --lh-body:1.62;
  --lift:translateY(-1px);
  --glow-teal:0 10px 28px -10px rgba(20,169,138,.8);
  --shadow-card:0 30px 80px -40px rgba(0,0,0,.9);
}

/* ---- page shell ---- */
.shop-main{padding:clamp(116px,14vh,150px) clamp(20px,6vw,72px) clamp(48px,6vw,72px);position:relative}
.shop-wrap{max-width:var(--maxw);margin:0 auto;position:relative;z-index:2}

/* ---- breadcrumb ---- */
.woocommerce-breadcrumb{font-size:13px;color:#fff;display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-bottom:26px}
.woocommerce-breadcrumb a{color:var(--ink2);transition:color var(--dur-fast)}
.woocommerce-breadcrumb a:hover{color:#fff}
.woocommerce-breadcrumb .sep{color:var(--ink3);opacity:.6}

/* ---- product layout ---- */
.product.single{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:clamp(28px,4vw,56px);align-items:start}
@media(max-width:920px){.product.single{grid-template-columns:1fr;gap:32px}}

/* ---- gallery ---- */
.woocommerce-product-gallery{position:sticky;top:96px}
@media(max-width:920px){.woocommerce-product-gallery{position:static}}
.gallery-main{height:clamp(340px,46vw,520px);border-radius:var(--radius);position:relative;align-items:flex-start}
.gallery-main .badge-sale{position:absolute;top:18px;left:18px;z-index:3;font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:var(--fw-semibold);
  background:var(--b600);color:#fff;padding:7px 13px;border-radius:var(--r-pill);box-shadow:0 8px 22px -8px rgba(26,143,214,.7)}
.gallery-main .tagm{left:22px;bottom:22px;position:absolute}
.gallery-thumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:14px}
.gallery-thumbs .thumb{height:74px;border-radius:13px;cursor:pointer;border:1px solid var(--line);position:relative;overflow:hidden;
  background:linear-gradient(180deg,transparent 28%,rgba(8,12,21,.82)),repeating-linear-gradient(135deg,#141d30 0 10px,#11192a 10px 20px);transition:border-color var(--dur-fast),transform var(--dur-fast)}
.gallery-thumbs .thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.gallery-thumbs .thumb.active{border-color:var(--b500);box-shadow:0 0 0 1px var(--b500),0 0 18px -4px rgba(26,143,214,.6)}
.gallery-thumbs .thumb:hover{transform:var(--lift)}

/* ---- summary ---- */
.entry-summary{display:flex;flex-direction:column}
.summary-tags{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.pill-cat{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--b300);border:1px solid var(--line2);border-radius:var(--r-pill);padding:6px 12px}
.entry-summary .product_title{font-size:clamp(30px,3.6vw,44px);font-weight:var(--fw-hairline);letter-spacing:-.028em;line-height:1.05;margin:0;text-wrap:balance}
.entry-summary .product_title b{font-weight:var(--fw-bold)}

.woocommerce-product-rating{display:flex;align-items:center;gap:12px;margin-top:18px}
.stars{--pct:96%;font-size:17px;letter-spacing:2px;position:relative;display:inline-block;font-family:Arial,sans-serif;line-height:1}
.stars::before{content:"★★★★★";color:var(--line2)}
.stars::after{content:"★★★★★";color:#F6B23C;position:absolute;left:0;top:0;width:var(--pct);overflow:hidden;white-space:nowrap}
.rating-meta{font-size:13.5px;color:var(--ink2)}
.rating-meta a{color:var(--b300)}
.rating-meta a:hover{color:#fff}

/* price (summary range from WC get_price_html) */
.ssrp-price{display:flex;align-items:baseline;gap:12px;margin:22px 0 0;flex-wrap:wrap;font-family:var(--mono)}
.ssrp-price .woocommerce-Price-amount{font-size:30px;font-weight:var(--fw-bold);letter-spacing:-.02em;color:#fff}
.ssrp-price del{opacity:.5;font-size:18px;color:var(--ink2);font-weight:var(--fw-medium)}
.ssrp-price del .woocommerce-Price-amount{font-size:inherit;color:inherit;font-weight:inherit;text-decoration:none}
.ssrp-price ins{text-decoration:none}
.ssrp-price .from,.ssrp-price>small{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink3);font-family:var(--sans);font-weight:var(--fw-semibold);align-self:center}

.short-desc{color:var(--ink2);font-size:15px;line-height:var(--lh-body);margin-top:20px;max-width:520px}
.short-desc p{margin:0 0 10px}

/* ---- variations form ---- */
.variations_form{margin-top:28px;border-top:1px solid var(--line);padding-top:26px}
.variations_form table.variations{display:none}                 /* hidden — replaced by injected swatches */
.ssrp-variations{display:flex;flex-direction:column;gap:22px}
.ssrp-variations .v-row .v-label{display:flex;align-items:center;justify-content:flex-start;margin-bottom:11px;gap:2rem}
.ssrp-variations .v-label .lab{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink3);font-weight:var(--fw-semibold)}
.ssrp-variations .v-label .lab::after{content:":"}
.ssrp-variations .v-label .pick{font-size:13.5px;color:var(--ink3);font-weight:var(--fw-medium)}
.ssrp-variations .v-label .pick.has{color:#fff}
.swatches{display:flex;gap:10px;flex-wrap:wrap}
.swatch{display:inline-flex;flex-direction:column;gap:3px;align-items:flex-start;cursor:pointer;
  border:1px solid var(--line2);border-radius:14px;padding:12px 16px;background:rgba(255,255,255,.02);
  transition:border-color var(--dur-fast),background var(--dur-fast),transform var(--dur-fast);min-width:118px;text-align:left}
.swatch:hover{border-color:rgba(255,255,255,.4);transform:var(--lift)}
.swatch .s-name{font-size:14px;font-weight:var(--fw-semibold);color:#fff}
.swatch .s-sub{font-family:var(--mono);font-size:11px;color:var(--ink3)}
.swatch.selected{border-color:var(--b500);background:rgba(26,143,214,.10);box-shadow:0 0 0 1px var(--b500),0 8px 22px -12px rgba(26,143,214,.7)}
.swatch.selected .s-sub{color:var(--b200)}
.swatch.soldout{opacity:.4;cursor:not-allowed}
.swatch.soldout:hover{transform:none;border-color:var(--line2)}
.swatch.soldout .s-name{text-decoration:line-through}

/* resolved-variation panel (WC fills .woocommerce-variation) */
.single_variation_wrap{margin-top:22px}
.woocommerce-variation.single_variation{transition:opacity var(--dur-fast)}
.woocommerce-variation:not(:empty){border:1px solid var(--line);background:rgba(255,255,255,.02);border-radius:16px;padding:18px 20px;margin-bottom:20px}
.woocommerce-variation-price .price,
.woocommerce-variation-price .woocommerce-Price-amount{font-family:var(--mono);font-size:26px;font-weight:var(--fw-bold);color:#fff;letter-spacing:-.02em}
.woocommerce-variation-price del{font-size:16px;opacity:.5;color:var(--ink2);font-weight:var(--fw-medium)}
.woocommerce-variation-price del .woocommerce-Price-amount{font-size:inherit;color:inherit;font-weight:inherit}
.woocommerce-variation-price ins{text-decoration:none}
.woocommerce-variation-description{font-size:14px;color:var(--ink2);line-height:1.55;margin-top:12px}
.woocommerce-variation-description p{margin:0 0 8px}
.woocommerce-variation-availability{margin-top:14px}
.woocommerce-variation-availability:empty{display:none}              /* no lone dot when WC has no stock text */
.woocommerce-variation-availability .stock{display:inline-flex;align-items:center;gap:9px;margin:0;font-size:13px;color:var(--ink2)}
.woocommerce-variation-availability .stock::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--t400);box-shadow:0 0 12px var(--t400)}
.woocommerce-variation-availability .stock.out-of-stock{color:var(--ink3)}
.woocommerce-variation-availability .stock.out-of-stock::before{background:var(--ink3);box-shadow:none}

/* add-to-cart row */
.woocommerce-variation-add-to-cart{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.woocommerce-variation-add-to-cart.woocommerce-variation-add-to-cart-disabled .single_add_to_cart_button{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none;pointer-events:none}
.quantity{display:inline-flex;align-items:center;border:1px solid var(--line2);border-radius:var(--r-pill);background:rgba(255,255,255,.02);overflow:hidden}
.quantity .ssrp-qty-btn{width:46px;height:52px;background:none;border:none;color:var(--ink2);font-size:19px;cursor:pointer;transition:color var(--dur-fast),background var(--dur-fast)}
.quantity .ssrp-qty-btn:hover{color:#fff;background:rgba(255,255,255,.05)}
.quantity input.qty{width:52px;height:52px;text-align:center;background:none;border:none;color:#fff;font-family:var(--mono);font-size:16px;outline:none;-moz-appearance:textfield}
.quantity input.qty::-webkit-outer-spin-button,.quantity input.qty::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.single_add_to_cart_button{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  flex:1;min-width:220px;height:52px;padding:0 26px;
  background:var(--b600);color:#fff;border:1px solid transparent;border-radius:var(--r-pill);
  font-family:var(--sans);font-size:14.5px;font-weight:var(--fw-semibold);letter-spacing:.01em;line-height:1;cursor:pointer;
  box-shadow:0 10px 28px -10px rgba(26,143,214,.8);
  transition:transform var(--dur-fast),box-shadow var(--dur-fast),background var(--dur-fast),opacity var(--dur-fast)}
.single_add_to_cart_button:hover{transform:var(--lift);box-shadow:0 14px 34px -10px rgba(26,143,214,.9)}
.single_add_to_cart_button.added{background:var(--t600);box-shadow:var(--glow-teal)}
.single_add_to_cart_button.disabled,
.single_add_to_cart_button.wc-variation-selection-needed,
.single_add_to_cart_button[disabled]{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none;pointer-events:none}
/* suppress WC's icon-font ::after (spinner/tick) — WC core CSS is intentionally not loaded */
.single_add_to_cart_button::after{display:none !important}
.reset_variations{font-size:13px;color:var(--ink3);margin-top:14px;cursor:pointer;width:fit-content;display:inline-flex;align-items:center;gap:7px}
.reset_variations:hover{color:#fff}

.buy-assurances{display:flex;gap:20px;flex-wrap:wrap;margin-top:22px}
.buy-assurances span{display:inline-flex;align-items:center;gap:9px;font-size:13px;color:var(--ink2)}
.buy-assurances span::before{content:"✓";color:var(--b300);font-weight:var(--fw-bold)}

/* product meta */
.product_meta{margin-top:26px;border-top:1px solid var(--line);padding-top:20px;display:flex;flex-direction:column;gap:10px;font-size:13px;color:var(--ink3)}
.product_meta .row{display:flex;gap:10px}
.product_meta .row b{color:var(--ink2);font-weight:var(--fw-semibold);min-width:92px}
.product_meta .row a{color:var(--ink2)}
.product_meta .row a:hover{color:#fff}
.product_meta .row .mono{font-family:var(--mono)}

/* ---- tabs (WC .wc-tabs skinned) ---- */
.woocommerce-tabs{margin-top:clamp(56px,7vw,88px)}
.woocommerce-tabs ul.tabs{display:flex;gap:6px;border-bottom:1px solid var(--line);flex-wrap:wrap;list-style:none;margin:0;padding:0}
.woocommerce-tabs ul.tabs li{margin:0}
.woocommerce-tabs ul.tabs li a{display:block;color:var(--ink2);font-size:14.5px;font-weight:var(--fw-semibold);font-family:var(--sans);
  padding:14px 20px;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color var(--dur-fast),border-color var(--dur-fast)}
.woocommerce-tabs ul.tabs li a:hover{color:#fff}
.woocommerce-tabs ul.tabs li.active a{color:#fff;border-bottom-color:var(--b500)}
.woocommerce-tabs .panel{padding-top:34px;max-width:760px}
.woocommerce-tabs .panel h2{font-size:22px;font-weight:var(--fw-semibold);letter-spacing:-.01em;margin:0 0 14px}
.woocommerce-tabs .panel p{color:var(--ink2);font-size:15px;line-height:var(--lh-body);margin-bottom:14px}
.woocommerce-tabs .panel h3{font-size:18px;font-weight:var(--fw-semibold);letter-spacing:-.01em;color:#fff;margin:26px 0 12px}
.woocommerce-tabs .panel ul{list-style:none;display:flex;flex-direction:column;gap:11px;margin:8px 0 18px;padding:0}
.woocommerce-tabs .panel ul li{font-size:14.5px;color:var(--ink2);padding-left:26px;position:relative;line-height:1.5}
.woocommerce-tabs .panel ul li::before{content:"";position:absolute;left:0;top:5px;width:12px;height:12px;border-radius:3px;background:rgba(26,143,214,.25);border:1px solid var(--b500)}
.woocommerce-tabs .panel ul li strong{color:#fff;font-weight:var(--fw-semibold)}
.woocommerce-tabs .shop_attributes{width:100%;border-collapse:collapse;font-size:14px}
.woocommerce-tabs .shop_attributes th,.woocommerce-tabs .shop_attributes td{text-align:left;padding:14px 0;border-bottom:1px solid var(--line);vertical-align:top}
.woocommerce-tabs .shop_attributes th{color:var(--ink3);font-weight:var(--fw-medium);width:42%}
.woocommerce-tabs .shop_attributes td{color:#fff}
.woocommerce-tabs .shop_attributes td p{margin:0;color:#fff}
/* reviews */
.woocommerce-Reviews .commentlist{list-style:none;margin:0;padding:0}
.woocommerce-Reviews .comment_container{display:flex;gap:16px;padding:22px 0;border-bottom:1px solid var(--line)}
.woocommerce-Reviews .avatar{width:44px;height:44px;border-radius:50%;flex:none;border:1px solid var(--line2)}
.woocommerce-Reviews .meta{font-size:13px;color:var(--ink3);margin-bottom:8px}
.woocommerce-Reviews .meta strong{color:#fff;font-size:15px;font-weight:var(--fw-semibold)}
.woocommerce-Reviews .description{color:var(--ink2);font-size:14.5px;line-height:1.6}
.woocommerce-Reviews #respond{margin-top:24px}
.woocommerce-noreviews{color:var(--ink2);font-size:14.5px}

/* ---- related (WC product loop skinned as cards) ---- */
.related.products,.upsells.products{margin-top:clamp(56px,7vw,88px)}
.related.products>h2,.upsells.products>h2{font-size:clamp(24px,3vw,34px);font-weight:var(--fw-bold);letter-spacing:-.02em;margin:0 0 6px}
.related.products ul.products,.upsells.products ul.products{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin:28px 0 0;padding:0;list-style:none}
@media(max-width:980px){.related.products ul.products{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.related.products ul.products{grid-template-columns:1fr}}
ul.products li.product{border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,0));
  overflow:hidden;display:flex;flex-direction:column;padding:0;transition:transform var(--dur-fast),border-color var(--dur-fast);text-align:left;margin:0}
ul.products li.product:hover{transform:var(--lift);border-color:var(--line2)}
ul.products li.product a img{width:100%;height:150px;object-fit:cover;border-bottom:1px solid var(--line);margin:0}
ul.products li.product .woocommerce-loop-product__title{font-size:16px;font-weight:var(--fw-semibold);letter-spacing:-.01em;line-height:1.3;color:#fff;padding:18px 20px 0}
ul.products li.product .price{font-family:var(--mono);font-size:16px;font-weight:var(--fw-bold);color:#fff;padding:10px 20px 0;display:block}
ul.products li.product .price del{font-size:12.5px;color:var(--ink3);opacity:.6}
ul.products li.product .price del .woocommerce-Price-amount{font-size:inherit;color:inherit}
ul.products li.product .price ins{text-decoration:none}
ul.products li.product .button{margin:14px 20px 20px}
ul.products li.product .star-rating{margin:10px 20px 0}

/* ---- WooCommerce messages / notices ---- */
.woocommerce-message,.woocommerce-info,.woocommerce-error{border:1px solid var(--line2);background:rgba(255,255,255,.03);
  border-radius:14px;padding:14px 18px;color:var(--ink2);font-size:14px;list-style:none;margin:0 0 20px}
.woocommerce-message{border-color:rgba(24,200,161,.4);background:rgba(24,200,161,.08)}
.woocommerce-error{border-color:rgba(237,83,22,.45);background:rgba(237,83,22,.08)}

/* WC core CSS is intentionally not loaded — restore the a11y screen-reader helper
   so WooCommerce's sr-only price text ("Original price was…") stays hidden. */
.screen-reader-text{position:absolute !important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ---- sticky add-to-cart bar ---- */
.ssrp-sticky-cart{position:fixed;left:0;right:0;bottom:0;z-index:250;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:13px clamp(16px,5vw,48px);
  background:rgba(10,14,24,.82);backdrop-filter:blur(20px) saturate(150%);-webkit-backdrop-filter:blur(20px) saturate(150%);
  border-top:1px solid var(--line2);box-shadow:0 -18px 50px -20px rgba(0,0,0,.7);
  transform:translateY(120%);opacity:0;visibility:hidden;
  transition:transform .4s var(--ease),opacity .3s var(--ease),visibility .3s}
.ssrp-sticky-cart.show{transform:none;opacity:1;visibility:visible}
.ssrp-sticky-cart .scb-info{display:flex;flex-direction:column;gap:2px;min-width:0}
.scb-title{font-size:14.5px;font-weight:var(--fw-semibold);color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:46vw}
.scb-meta{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}
.scb-pkg{font-size:12.5px;color:var(--ink3);letter-spacing:.03em}
.scb-price{font-family:var(--mono);font-size:15px;font-weight:var(--fw-bold);color:#fff;display:inline-flex;align-items:baseline;gap:8px}
.scb-price del{font-size:12px;opacity:.5;color:var(--ink2);font-weight:var(--fw-medium)}
.scb-price del .woocommerce-Price-amount{font-size:inherit;color:inherit;font-weight:inherit}
.scb-price ins{text-decoration:none}
.scb-add{flex:none;display:inline-flex;align-items:center;justify-content:center;gap:9px;
  height:46px;padding:0 28px;border:1px solid transparent;border-radius:var(--r-pill);cursor:pointer;
  background:var(--b600);color:#fff;font-family:var(--sans);font-size:14px;font-weight:var(--fw-semibold);line-height:1;
  box-shadow:0 10px 28px -10px rgba(26,143,214,.8);transition:transform var(--dur-fast),box-shadow var(--dur-fast),background var(--dur-fast)}
.scb-add:hover{transform:var(--lift);box-shadow:0 14px 34px -10px rgba(26,143,214,.9)}
@media(max-width:560px){
  .ssrp-sticky-cart{padding:10px 16px;gap:12px}
  .scb-title{font-size:13px;max-width:42vw}
  .scb-add{height:44px;padding:0 18px;font-size:13px}
}
/* swatch pulse when the sticky button is tapped before a package is chosen */
@keyframes ssrpPulse{0%,100%{box-shadow:0 0 0 0 rgba(26,143,214,0)}45%{box-shadow:0 0 0 3px rgba(26,143,214,.55)}}
.swatches.ssrp-pulse .swatch{animation:ssrpPulse .65s ease}

/* cart-link count in nav */
.nav .ssrp-cart-count{min-width:19px;height:19px;padding:0 5px;border-radius:999px;background:var(--b600);color:#fff;font-size:11px;font-weight:var(--fw-bold);font-family:var(--mono);display:inline-flex;align-items:center;justify-content:center;margin-left:6px}

/* ============================================================
   CART & CHECKOUT (classic shortcodes, SSRP dark skin)
   ============================================================ */
/* page frame: clear the fixed nav + center to the brand width */
.woocommerce-cart #content,
.woocommerce-checkout #content,
.woocommerce-account #content{max-width:var(--maxw);margin:0 auto;
  padding:clamp(116px,14vh,150px) clamp(20px,6vw,72px) clamp(56px,7vw,96px)}
.woocommerce-cart #content article,
.woocommerce-checkout #content article{margin:0;max-width:none}

/* page heading + step indicator (injected via hooks) */
.ssrp-shop-head{margin-bottom:34px}
.ssrp-shop-head .steps{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink3);margin-bottom:14px}
.ssrp-shop-head .steps .cur{color:var(--b300)}
.ssrp-shop-head .steps .sep{opacity:.5}
.ssrp-shop-head h1{font-size:clamp(28px,4vw,46px);font-weight:var(--fw-hairline);letter-spacing:-.025em;line-height:1.04;margin:0}
.ssrp-shop-head h1 b{font-weight:var(--fw-bold)}

/* shared order-summary card */
.cart_totals,#order_review{border:1px solid var(--line2);border-radius:18px;
  background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,0));
  box-shadow:var(--shadow-card);padding:clamp(20px,2.4vw,28px)}
.cart_totals h2,#order_review_heading{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink3);font-weight:var(--fw-semibold);margin:0 0 16px}

/* trust badges (injected via hooks) */
.ssrp-trust{list-style:none;margin:18px 0 0;padding:18px 0 0;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:12px}
.ssrp-trust li{display:flex;gap:10px;align-items:flex-start;font-size:12.5px;color:var(--ink3);line-height:1.5}
.ssrp-trust li strong{color:var(--ink2);font-weight:var(--fw-semibold)}
.ssrp-trust li::before{content:"✓";color:var(--b300);font-weight:var(--fw-bold);flex:none}
.ssrp-access-note{margin-top:16px;font-size:12.5px;line-height:1.55;color:var(--ink3)}
.ssrp-access-note strong{color:var(--ink2)}

/* primary action buttons */
.woocommerce #content .button,
.wc-proceed-to-checkout .checkout-button,
#payment #place_order,
.woocommerce-cart .actions .button{display:inline-flex;align-items:center;justify-content:center;gap:10px;
  background:var(--b600);color:#fff;border:1px solid transparent;border-radius:var(--r-pill);
  font-family:var(--sans);font-size:14.5px;font-weight:var(--fw-semibold);line-height:1;padding:15px 26px;cursor:pointer;
  box-shadow:0 10px 28px -10px rgba(26,143,214,.8);transition:transform var(--dur-fast),box-shadow var(--dur-fast)}
.woocommerce #content .button:hover,.wc-proceed-to-checkout .checkout-button:hover,#payment #place_order:hover{transform:var(--lift);box-shadow:0 14px 34px -10px rgba(26,143,214,.9)}
.wc-proceed-to-checkout .checkout-button,#payment #place_order{width:100%}
.wc-proceed-to-checkout{margin-top:20px}
/* secondary buttons (update cart, apply coupon) */
.woocommerce-cart .actions button[name="update_cart"],.woocommerce .coupon .button{background:transparent;color:#fff;border:1px solid var(--line2);box-shadow:none}
.woocommerce-cart .actions button[name="update_cart"]:hover,.woocommerce .coupon .button:hover{border-color:rgba(255,255,255,.4);background:rgba(255,255,255,.03);transform:none}

/* ---- CART ---- */
.woocommerce-cart .woocommerce{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(0,1fr);column-gap:clamp(24px,3vw,48px);row-gap:0;align-items:start}
@media(max-width:900px){.woocommerce-cart .woocommerce{grid-template-columns:1fr}}
.woocommerce-cart .ssrp-shop-head,.woocommerce-cart .woocommerce-notices-wrapper{grid-column:1/-1}
.woocommerce-cart .woocommerce-notices-wrapper:empty{display:none}  /* no phantom gap row */
.woocommerce-cart form.woocommerce-cart-form{grid-column:1;min-width:0;margin-bottom:1rem;}
.woocommerce-cart .cart-collaterals{grid-column:2;width:100%!important;float:none!important;position:sticky;top:100px}
.woocommerce-cart .cart-collaterals .cart_totals{width:100%!important;float:none!important}
@media(max-width:900px){.woocommerce-cart .cart-collaterals{grid-column:1;position:static}}

/* line items as clean flex rows — no table-grid fighting */
.woocommerce-cart table.cart,
.woocommerce-cart table.cart tbody{display:block;width:100%;border:0}
.woocommerce-cart table.cart thead{display:none}
.woocommerce-cart table.cart tr{display:block}
.woocommerce-cart table.cart tr.cart_item,
.woocommerce-cart table.cart tr.woocommerce-cart-form__cart-item{display:flex;align-items:center;gap:18px;width:100%;border-bottom:1px solid var(--line);padding:20px 0}
.woocommerce-cart table.cart tr.cart_item td{display:block;padding:0;border:0;color:var(--ink2);font-size:14px}
/* drop image, unit-price, and quantity columns — single-item purchases */
.woocommerce-cart td.product-thumbnail,
.woocommerce-cart td.product-price,
.woocommerce-cart td.product-quantity{display:none!important}
.woocommerce-cart td.product-remove{order:1;flex:none}
.woocommerce-cart td.product-remove a.remove{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;
  border:1px solid var(--line2);color:var(--ink3)!important;font-size:15px;line-height:1;text-decoration:none;transition:color var(--dur-fast),border-color var(--dur-fast)}
.woocommerce-cart td.product-remove a.remove:hover{color:#fff!important;border-color:rgba(255,255,255,.4);background:transparent!important}
.woocommerce-cart td.product-name{order:2;flex:1;min-width:0}
.woocommerce-cart td.product-name a{color:#fff;font-weight:var(--fw-semibold);font-size:15.5px;line-height:1.4}
.woocommerce-cart td.product-name a:hover{color:var(--b300)}
.woocommerce-cart td.product-name .variation,.woocommerce-cart td.product-name dl{font-size:12.5px;color:var(--ink3);margin:6px 0 0}
.woocommerce-cart td.product-subtotal{order:3;flex:none;margin-left:auto;font-family:var(--mono);color:#fff;font-weight:var(--fw-bold);font-size:16px;white-space:nowrap}
/* actions row (coupon + update) */
.woocommerce-cart td.actions{display:flex!important;gap:12px;flex-wrap:wrap;align-items:center;padding:22px 0 0!important;border:0}
.woocommerce-cart .coupon{display:flex;gap:10px;flex:1;min-width:260px}
.woocommerce-cart .coupon label{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;padding:0;margin:-1px}
.woocommerce-cart .coupon input#coupon_code,.woocommerce-cart .coupon input.input-text{flex:1;min-width:0;background:rgba(255,255,255,.04);border:1px solid var(--line2);border-radius:12px;
  padding:13px 16px;color:#fff;font-family:var(--sans);font-size:14px;outline:none;transition:border-color var(--dur-fast),box-shadow var(--dur-fast)}
.woocommerce-cart .coupon input::placeholder{color:var(--ink3)}
.woocommerce-cart .coupon input:focus{border-color:var(--t400);box-shadow:0 0 0 3px rgba(24,200,161,.16)}
.woocommerce-cart .coupon .button{white-space:nowrap}
/* cart totals table */
.cart_totals table{width:100%;border-collapse:collapse}
.cart_totals th{text-align:left;font-weight:var(--fw-medium);color:var(--ink2);font-size:14px;padding:12px 0;border-bottom:1px solid var(--line)}
.cart_totals td{text-align:right;font-family:var(--mono);color:#fff;font-size:14px;padding:12px 0;border-bottom:1px solid var(--line)}
.cart_totals tr.order-total th{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:#fff;vertical-align:middle}
.cart_totals tr.order-total td{font-size:22px;font-weight:var(--fw-bold)}
.cart_totals tr:last-child th,.cart_totals tr:last-child td{border-bottom:none}

/* cart empty state */
.cart-empty.woocommerce-info{text-align:left}
.woocommerce-cart .return-to-shop{margin-top:18px}

/* ---- CHECKOUT ---- */
.woocommerce-checkout form.checkout.woocommerce-checkout{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(0,1fr);grid-template-rows:min-content 1fr;gap:clamp(24px,3vw,48px);align-items:start}
@media(max-width:900px){.woocommerce-checkout form.checkout.woocommerce-checkout{grid-template-columns:1fr;grid-template-rows:none}}
/* billing spans both rows so the summary sits at the TOP of column 2 (not row 2) */
#customer_details{grid-column:1;grid-row:1 / -1;min-width:0}
.woocommerce-checkout #order_review_heading{grid-column:2;grid-row:1;align-self:start}
.woocommerce-checkout #order_review{grid-column:2;grid-row:2;align-self:start;position:sticky;top:100px}
@media(max-width:900px){
  .woocommerce-checkout #customer_details{grid-row:auto}
  .woocommerce-checkout #order_review_heading,.woocommerce-checkout #order_review{grid-column:1;grid-row:auto;position:static}
}
/* section headings as numbered cards */
#customer_details h3,.woocommerce-billing-fields h3,.woocommerce-shipping-fields h3,.woocommerce-additional-fields h3{
  font-size:18px;font-weight:var(--fw-semibold);letter-spacing:-.01em;color:#fff;margin:0 0 18px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.woocommerce-billing-fields,.woocommerce-additional-fields{margin-bottom:8px}
/* form fields — restore the two-column layout (WC core CSS is dropped) */
.woocommerce-billing-fields__field-wrapper,
.woocommerce-shipping-fields__field-wrapper,
.woocommerce-additional-fields__field-wrapper{display:grid;grid-template-columns:1fr 1fr;gap:0 18px}
@media(max-width:560px){
  .woocommerce-billing-fields__field-wrapper,
  .woocommerce-shipping-fields__field-wrapper,
}
.woocommerce form .form-row{grid-column:1 / -1;margin:0 0 16px;display:flex;flex-direction:column}
.woocommerce form .form-row-first{grid-column:1}
.woocommerce form .form-row-last{grid-column:2}
.woocommerce form .form-row label{font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink3);font-weight:var(--fw-semibold);margin-bottom:7px}
.woocommerce form .form-row .required{color:var(--t300);border:0}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce-checkout .select2-container .select2-selection{background:rgba(255,255,255,.04);border:1px solid var(--line2);border-radius:12px;
  padding:13px 16px;color:#fff;font-family:var(--sans);font-size:15px;width:100%;outline:none;transition:border-color var(--dur-fast),box-shadow var(--dur-fast);min-height:50px}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus{border-color:var(--t400);box-shadow:0 0 0 3px rgba(24,200,161,.16)}
.woocommerce form .form-row input::placeholder,.woocommerce form .form-row textarea::placeholder{color:var(--ink3)}
.woocommerce .select2-container--default .select2-selection--single .select2-selection__rendered{color:#fff;line-height:24px;padding:0}
.woocommerce .select2-dropdown{background:var(--panel);border:1px solid var(--line2);color:#fff}
.woocommerce .select2-container--default .select2-results__option--highlighted{background:var(--b600)}
/* order review table */
#order_review .shop_table{width:100%;border-collapse:collapse;margin-bottom:8px}
#order_review .shop_table th,#order_review .shop_table td{text-align:left;font-size:13.5px;color:var(--ink2);padding:11px 0;border-bottom:1px solid var(--line)}
#order_review .shop_table td{text-align:right;font-family:var(--mono);color:#fff}
#order_review .shop_table .product-name{color:#fff;font-family:var(--sans)}
#order_review .shop_table .product-quantity{display:none}  /* single-item — no "× 1" */
#order_review .order-total th{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:#fff}
#order_review .order-total td{font-size:20px;font-weight:var(--fw-bold)}
/* payment box */
/* payment area sits flush inside the order-summary card — no nested boxes */
#payment{background:transparent!important;border:0;padding:0;margin-top:6px}
#payment ul.payment_methods{list-style:none;margin:0;padding:0;border:none!important}
#payment ul.payment_methods li{margin-bottom:8px;color:var(--ink2)}
#payment div.payment_box{background:rgba(255,255,255,.03)!important;border:0;border-radius:10px;color:var(--ink2);font-size:13px;margin-top:8px;padding:14px}
#payment div.payment_box::before{display:none}
/* no-gateway / info notice: plain muted text, not a nested box */
#payment .woocommerce-info,#payment .woocommerce-notice,#payment .wc_payment_methods>li.woocommerce-info{
  border:0!important;background:transparent!important;padding:0!important;margin:0 0 8px!important;color:var(--ink3);font-size:13px;line-height:1.55}
#payment .woocommerce-privacy-policy-text{color:var(--ink3);font-size:12px;line-height:1.5}
#payment .place-order{padding-top:14px}

/* ---- distraction-free chrome on cart & checkout ---- */
/* nav: logo only — hide links, CTA, burger, back-link, and the mobile drawer */
.woocommerce-cart .nav-links,      .woocommerce-checkout .nav-links,
.woocommerce-cart .nav .nav-cta,   .woocommerce-checkout .nav .nav-cta,
.woocommerce-cart .nav-burger,     .woocommerce-checkout .nav-burger,
.woocommerce-cart .topback,        .woocommerce-checkout .topback,
.woocommerce-cart .ssrp-drawer,    .woocommerce-checkout .ssrp-drawer,
.woocommerce-cart .ssrp-drawer-backdrop, .woocommerce-checkout .ssrp-drawer-backdrop{display:none !important}

/* footer: keep only the legal copyright/disclosure line */
.woocommerce-cart .footer-grid,    .woocommerce-checkout .footer-grid,
.woocommerce-cart .footer-bottom > div:not(:first-child),
.woocommerce-checkout .footer-bottom > div:not(:first-child){display:none !important}
.woocommerce-cart .footer-bottom,  .woocommerce-checkout .footer-bottom{margin-top:0;border-top:none;justify-content:center;text-align:center}
.woocommerce-cart .footer,         .woocommerce-checkout .footer{padding-top:clamp(28px,4vw,44px)}
/* sticky footer on tall screens: full-height flex column pushes the footer to the bottom */
body.woocommerce-cart,
body.woocommerce-checkout{min-height:100vh;display:flex;flex-direction:column}
body.woocommerce-cart #content,
body.woocommerce-checkout #content{flex:1 0 auto}
body.woocommerce-cart .footer,
body.woocommerce-checkout .footer{flex-shrink:0}

/* ---- accessibility: visible focus for shop controls (override outline:none) ---- */
.swatch:focus-visible,
.single_add_to_cart_button:focus-visible,
.scb-add:focus-visible,
.gallery-thumbs .thumb:focus-visible,
.quantity .ssrp-qty-btn:focus-visible,
.quantity input.qty:focus-visible,
.woocommerce-tabs ul.tabs li a:focus-visible,
.reset_variations:focus-visible,
.woocommerce-cart td.product-remove a.remove:focus-visible,
.woocommerce-breadcrumb a:focus-visible,
.woocommerce form .form-row input:focus-visible,
.woocommerce form .form-row select:focus-visible,
.woocommerce form .form-row textarea:focus-visible,
.woocommerce-cart .coupon input:focus-visible{outline:2px solid var(--b300)!important;outline-offset:2px!important}
/* sold-out swatch: don't rely on color alone — line-through already present; lift opacity a touch for legibility */
.swatch.soldout{opacity:.55}

/* ============================================================
   SHOP ARCHIVE (/shop/, product category & tag archives)
   ============================================================ */
.shop-archive-desc{color:var(--ink2);font-size:15px;line-height:var(--lh-body);margin-top:14px;max-width:680px}
.shop-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin:0 0 26px}
.woocommerce-result-count{margin:0;color:var(--ink3);font-size:13px}
.woocommerce-ordering{margin:0}
.woocommerce-ordering select.orderby{background:rgba(255,255,255,.04);border:1px solid var(--line2);border-radius:10px;
  padding:10px 38px 10px 14px;color:#fff;font-family:var(--sans);font-size:14px;cursor:pointer;appearance:none;-webkit-appearance:none;
  background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="8" viewBox="0 0 12 8"><path d="M1 1l5 5 5-5" fill="none" stroke="%23868FA3" stroke-width="1.6" stroke-linecap="round" stroke-linejoin="round"/></svg>');
  background-repeat:no-repeat;background-position:right 14px center}
.woocommerce-ordering select.orderby:focus{border-color:var(--t400);outline:none}

/* product grid — scoped to archive bodies so it never clashes with related/upsell grids */
.woocommerce-shop ul.products,
.post-type-archive-product ul.products,
.tax-product_cat ul.products,
.tax-product_tag ul.products{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;list-style:none;margin:0;padding:0}
@media(max-width:980px){.woocommerce-shop ul.products,.post-type-archive-product ul.products,.tax-product_cat ul.products,.tax-product_tag ul.products{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.woocommerce-shop ul.products,.post-type-archive-product ul.products,.tax-product_cat ul.products,.tax-product_tag ul.products{grid-template-columns:1fr}}

/* pagination */
.woocommerce-pagination{margin-top:36px}
.woocommerce-pagination ul{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;list-style:none;margin:0;padding:0}
.woocommerce-pagination ul li{margin:0}
.woocommerce-pagination a,.woocommerce-pagination span{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 10px;
  border:1px solid var(--line2);border-radius:10px;color:var(--ink2);font-size:14px;transition:border-color var(--dur-fast),color var(--dur-fast)}
.woocommerce-pagination a:hover{color:#fff;border-color:rgba(255,255,255,.4)}
.woocommerce-pagination span.current{background:var(--b600);color:#fff;border-color:transparent}

/* WooCommerce "Sale!" flash on product cards + single gallery */
ul.products li.product{position:relative}
ul.products li.product .onsale,
.woocommerce-product-gallery .onsale{position:absolute;top:14px;left:14px;z-index:3;margin:0;
  background:var(--t600);color:#fff;font-family:var(--sans);font-size:11px;font-weight:var(--fw-semibold);
  letter-spacing:.12em;text-transform:uppercase;line-height:1;padding:7px 12px;border-radius:var(--r-pill);
  box-shadow:0 8px 22px -8px rgba(20,169,138,.7)}
