/* ==========================================================================
   SSPA Gift Certificates — Minimal UI (v5)  [DIRECT REPLACEMENT / OVERRIDE]
   Paste at the END of sspa.inc.css.v5.php (or any global v5 css include)
   ========================================================================== */

:root{
  --sspa-bg: #f6f7fb;
  --sspa-card: #ffffff;
  --sspa-text: #111827;
  --sspa-muted: #6b7280;
  --sspa-line: rgba(17,24,39,.08);
  --sspa-shadow: 0 10px 28px rgba(17,24,39,.08);
  --sspa-radius: 16px;

  --sspa-primary: #111827;          /* minimal “ink” */
  --sspa-primary-2: #0b1220;
  --sspa-accent: #06b6d4;           /* keeps your “info” vibe but calmer */
  --sspa-accent-2: #0891b2;
}

/* Page background + base */
body.sspa-obook-body{
  background: var(--sspa-bg) !important;
  color: var(--sspa-text);
}

/* General card polish */
.card{
  border-radius: var(--sspa-radius);
  border: 1px solid var(--sspa-line);
  background: var(--sspa-card);
}
.card.shadow-sm{
  box-shadow: var(--sspa-shadow) !important;
}

/* Sidebar card tweaks */
.sspa-sidecard{
  border-radius: var(--sspa-radius);
  border: 1px solid var(--sspa-line);
  box-shadow: var(--sspa-shadow);
}
.sspa-locinfo .h5,
.sspa-locinfo h5{
  font-weight: 700;
  letter-spacing: -.01em;
}

/* Headings spacing */
.h4{
  font-weight: 750;
  letter-spacing: -.02em;
}
.text-muted.small{
  color: var(--sspa-muted) !important;
}

/* ==========================================================================
   Buttons — keep bootstrap classes, but minimal look
   ========================================================================== */

/* Default buttons */
.btn{
  border-radius: 12px;
  font-weight: 600;
  letter-spacing: -.01em;
}

/* Your current CTAs are btn-info: make them minimal + premium */
.btn.btn-info{
  background: var(--sspa-primary) !important;
  border-color: var(--sspa-primary) !important;
  color: #fff !important;
}
.btn.btn-info:hover,
.btn.btn-info:focus{
  background: var(--sspa-primary-2) !important;
  border-color: var(--sspa-primary-2) !important;
  color: #fff !important;
}

/* Light buttons */
.btn.btn-light{
  background: #fff !important;
  border-color: var(--sspa-line) !important;
  color: var(--sspa-text) !important;
}
.btn.btn-light:hover,
.btn.btn-light:focus{
  background: #fbfbfc !important;
}

/* Outline dark (Cart FAB uses this) */
.btn.btn-outline-dark{
  border-color: var(--sspa-line) !important;
  color: var(--sspa-text) !important;
  background: rgba(255,255,255,.92) !important;
  backdrop-filter: blur(8px);
}
.btn.btn-outline-dark:hover{
  background: #fff !important;
  border-color: rgba(17,24,39,.18) !important;
}

/* Smaller “Buy” button */
.btn.btn-sm{
  padding: .55rem .8rem;
  border-radius: 12px;
}

/* ==========================================================================
   Giftcard grid cards
   ========================================================================== */

.gc-col{
  margin-bottom: 12px;
}

.gc-card{
  border: 1px solid var(--sspa-line);
  border-radius: 18px;
  overflow: hidden;
  background: var(--sspa-card);
  box-shadow: 0 8px 20px rgba(17,24,39,.06);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.gc-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 36px rgba(17,24,39,.10);
  border-color: rgba(17,24,39,.14);
}

.gc-hero{
  position: relative;
  height: 170px;
  background: linear-gradient(135deg, rgba(17,24,39,.06), rgba(17,24,39,.02));
}
.gc-img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.02);
}
.gc-img-fallback{
  width: 100%;
  height: 100%;
  background:
    radial-gradient(1200px 280px at 20% 30%, rgba(6,182,212,.25), transparent 60%),
    radial-gradient(900px 260px at 85% 65%, rgba(17,24,39,.18), transparent 55%),
    linear-gradient(135deg, rgba(17,24,39,.06), rgba(17,24,39,.02));
}
.gc-overlay{
  position:absolute; inset:0;
  background: linear-gradient(to top, rgba(17,24,39,.65), rgba(17,24,39,.06));
}

.gc-pill{
  position:absolute; top:12px; left:12px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(255,255,255,.55);
  font-size: 12px;
  font-weight: 700;
  color: var(--sspa-text);
}

.gc-value-pill{
  position:absolute; top:12px; right:12px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(6,182,212,.16);
  border: 1px solid rgba(6,182,212,.22);
  font-size: 12px;
  font-weight: 800;
  color: #0b1220;
}

.gc-title{
  position:absolute; left:14px; right:14px; bottom:12px;
  color:#fff;
  font-weight: 800;
  letter-spacing: -.02em;
  font-size: 16px;
  line-height: 1.15;
  text-shadow: 0 8px 22px rgba(0,0,0,.35);
}

.gc-footer{
  padding: 12px 14px 14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
}
.gc-price{
  font-weight: 850;
  letter-spacing: -.02em;
  font-size: 16px;
  color: var(--sspa-text);
}
.gc-actions{
  flex: 1;
  display:flex;
  justify-content:flex-end;
}

/* ==========================================================================
   Customize modal (gc-modal) + blocks
   ========================================================================== */

.gc-modal{
  border-radius: 18px;
  border: 1px solid var(--sspa-line);
  box-shadow: var(--sspa-shadow);
}
.modal-header{
  border-bottom: 1px solid var(--sspa-line);
}
.modal-footer{
  border-top: 1px solid var(--sspa-line);
}

.gc-block{
  border: 1px solid var(--sspa-line);
  border-radius: 16px;
  padding: 14px;
  background: #fff;
}
.gc-block + .gc-block{
  margin-top: 12px;
}

.gc-block-title{
  font-weight: 800;
  letter-spacing: -.01em;
  margin-bottom: 10px;
}

.gc-label{
  font-size: 12px;
  font-weight: 700;
  color: var(--sspa-muted);
  margin-bottom: 6px;
}

/* Inputs */
.form-control{
  border-radius: 12px;
  border-color: var(--sspa-line);
  box-shadow: none !important;
}
.form-control:focus{
  border-color: rgba(6,182,212,.45) !important;
  box-shadow: 0 0 0 .2rem rgba(6,182,212,.10) !important;
}

/* Amount row */
.gc-amount-row{
  display:flex;
  align-items:center;
  gap: 10px;
}
.gc-currency{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width: 34px;
  height: 44px;
  border-radius: 12px;
  border: 1px solid var(--sspa-line);
  background: rgba(17,24,39,.02);
  font-weight: 800;
  color: var(--sspa-text);
}
.gc-amount-input{
  height: 44px;
  font-weight: 800;
  letter-spacing: -.02em;
}

/* Preset chips */
.gc-chip-wrap{
  display:flex;
  flex-wrap: wrap;
  gap: 8px;
}
.gc-chip{
  border: 1px solid var(--sspa-line);
  background: #fff;
  border-radius: 999px;
  padding: 8px 12px;
  font-weight: 750;
  font-size: 13px;
  color: var(--sspa-text);
  transition: background .15s ease, border-color .15s ease, transform .15s ease;
}
.gc-chip:hover{
  transform: translateY(-1px);
  border-color: rgba(17,24,39,.16);
  background: rgba(17,24,39,.02);
}
.gc-chip.is-active{
  border-color: rgba(6,182,212,.45);
  background: rgba(6,182,212,.14);
}

/* Fixed amount display */
.gc-fixed-amount{
  display:flex;
  align-items:baseline;
  gap: 4px;
  font-weight: 900;
  letter-spacing: -.03em;
  font-size: 28px;
}

/* Helper + counter */
.gc-help{
  margin-top: 8px;
  font-size: 12px;
  color: var(--sspa-muted);
}
.gc-counter{
  margin-top: 6px;
  font-size: 12px;
  color: var(--sspa-muted);
  text-align: right;
}

/* Preview card */
.gc-preview{
  border: 1px solid var(--sspa-line);
  border-radius: 18px;
  overflow:hidden;
  background:#fff;
  box-shadow: 0 8px 24px rgba(17,24,39,.06);
}
.gc-preview-hero{
  position: relative;
  height: 160px;
  background: linear-gradient(135deg, rgba(6,182,212,.20), rgba(17,24,39,.08));
}
.gc-preview-img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display:block;
}
.gc-preview-overlay{
  position:absolute; inset:0;
  background: linear-gradient(to top, rgba(17,24,39,.55), rgba(17,24,39,.00));
}
.gc-preview-title{
  position:absolute; left:14px; right:14px; bottom:12px;
  color:#fff;
  font-weight: 900;
  letter-spacing: -.02em;
  text-shadow: 0 10px 26px rgba(0,0,0,.40);
}
.gc-preview-amount{
  font-size: 28px;
  font-weight: 950;
  letter-spacing: -.03em;
}

/* ==========================================================================
   Cart Offcanvas polish
   ========================================================================== */

.offcanvas{
  border-left: 1px solid var(--sspa-line);
}
.offcanvas-header{
  border-bottom: 1px solid var(--sspa-line);
}
#sspaCartList .list-group-item{
  border: 1px solid var(--sspa-line);
  border-radius: 14px;
  margin-bottom: 10px;
}
#sspaCartList .list-group-item:last-child{
  margin-bottom: 0;
}

/* “Remove” link minimal */
#sspaCartList .btn-link{
  text-decoration: none;
  font-weight: 700;
}
#sspaCartList .btn-link:hover{
  text-decoration: underline;
}

/* Cart FAB badge: make less “loud” */
#sspaCartBtn .badge{
  border-radius: 999px;
  font-weight: 800;
}
#sspaCartBtn .badge.bg-info{
  background: rgba(6,182,212,.18) !important;
  color: var(--sspa-text) !important;
  border: 1px solid rgba(6,182,212,.22);
}

/* ==========================================================================
   Mobile spacing tune
   ========================================================================== */
@media (max-width: 575.98px){
  .gc-hero{ height: 155px; }
  .gc-title{ font-size: 15px; }
  .gc-footer{ padding: 12px; }
  .gc-price{ font-size: 15px; }
}

/* ==========================================================
   Gift Certificate Preview — spacing like legacy UI (less cramped)
   REPLACE your existing preview-v2 block with this
   ========================================================== */

/* Dark card itself */
.gc-cardmock{
  position: relative;
  border-radius: 22px;
  overflow: hidden;
  height: 210px;                        /* <- slightly shorter = less cramped */
  padding: 24px 24px 18px;              /* <- more inner padding */
  color: #fff;
  background: linear-gradient(135deg, #083e6a, #0b2f50 55%, #081a2c);
  margin: 2px;                          /* <- subtle inset like legacy */
}

/* soft circular highlight */
.gc-cardmock-bg{
  position:absolute;
  inset:-44px -92px auto auto;
  width: 280px;
  height: 280px;
  border-radius: 999px;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.12), rgba(255,255,255,0) 60%);
  opacity: .75;
  pointer-events: none;
}

.gc-cardmock-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  position: relative;
  z-index: 2;
}

/* IMPORTANT: stop wrapping (your new one wraps -> feels cramped) */
.gc-cardmock-label{
  font-size: 12px;
  letter-spacing: .18em;
  font-weight: 800;
  opacity: .95;
  white-space: nowrap;                 /* <- keep on one line */
}

.gc-cardmock-exp{
  font-size: 12px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(0,0,0,.20);
  border: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.92);
  font-weight: 700;
  white-space: nowrap;
}

.gc-cardmock-amount{
  margin-top: 18px;
  font-weight: 900;
  letter-spacing: -.02em;
  font-size: 46px;
  line-height: 1;
  position: relative;
  z-index: 2;
}

.gc-cardmock-subtitle{
  margin-top: 10px;
  font-size: 18px;
  font-weight: 700;
  color: rgba(255,255,255,.92);
  position: relative;
  z-index: 2;
}

.gc-cardmock-dash{
  margin-top: 16px;
  border-top: 2px dashed rgba(255,255,255,.22);
  position: relative;
  z-index: 2;
}

.gc-cardmock-code{
  margin-top: 16px;
  position: relative;
  z-index: 2;
}

.gc-cardmock-code-label{
  font-size: 12px;
  letter-spacing: .18em;
  font-weight: 800;
  opacity: .85;
}

.gc-cardmock-code-val{
  margin-top: 6px;
  font-size: 22px;
  font-weight: 900;
  letter-spacing: .10em;
}

/* Note area beneath card (match the old “bigger spacing”) */
.gc-preview-note{
  margin-top: 14px;
  background: rgba(255,255,255,.55);   /* slight lift like legacy */
  border-radius: 16px;
  padding: 14px 16px 12px;
}

.gc-preview-note-dash{
  border-top: 2px dashed rgba(17,24,39,.20);
  margin: 6px 0 12px;
}

.gc-preview-note-msg{
  font-size: 15px;
  line-height: 1.45;
  color: rgba(17,24,39,.80);
  font-weight: 500;
  white-space: pre-wrap;
  word-break: break-word;
}

.gc-preview-note-from{
  margin-top: 10px;
  font-size: 14px;
  color: rgba(17,24,39,.65);
  font-weight: 600;
}

/* Wallet badge spacing */
.gc-preview-wallet{
  padding: 14px 0 2px;
  display:flex;
  justify-content:center;
}

.gc-wallet-badge{
  height: 44px;
  width: auto;
  display:block;
}

/* small screens: keep it from feeling squished */
@media (max-width: 991.98px){
  .gc-preview-v2{ padding: 18px; }
  .gc-cardmock{ height: 200px; padding: 22px 22px 16px; }
  .gc-cardmock-amount{ font-size: 42px; }
}

/* ===== FINAL: make preview match legacy proportions ===== */

#gcCustomizeModal .gc-modal-xl{
  max-width: 1120px !important;
}

/* keep preview tray nice */
#gcCustomizeModal .gc-preview-v2{
  padding: 22px !important;
}

/* card should fill the column, not be artificially capped */
#gcCustomizeModal .gc-cardmock{
  max-width: none !important;
  width: 100% !important;
  margin: 0 !important;

  height: 260px !important;
  padding: 28px 30px 20px !important; /* extra right padding prevents Exp.Date clipping */
}

/* stop title wrapping like the old UI */
#gcCustomizeModal .gc-cardmock-subtitle{
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

/* keep header on one line */
#gcCustomizeModal .gc-cardmock-label{
  white-space: nowrap !important;
}

/* When the giftcard modal is open, push the Cart FAB up so footer CTAs remain tappable */
body.modal-open #sspaCartBtn{
  bottom: 90px !important; /* adjust: 80–120 depending on your footer height */
}

/* Mobile: reduce preview height so it doesn’t dominate */
@media (max-width: 575.98px){

  /* shrink tray padding */
  #gcCustomizeModal .gc-preview-v2{
    padding: 14px !important;
  }

  /* shrink card mock */
  #gcCustomizeModal .gc-cardmock{
    height: 170px !important;
    padding: 16px 16px 12px !important;
    border-radius: 18px !important;
  }

  #gcCustomizeModal .gc-cardmock-amount{
    font-size: 36px !important;
    margin-top: 12px !important;
  }

  #gcCustomizeModal .gc-cardmock-subtitle{
    font-size: 16px !important;
    margin-top: 8px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  #gcCustomizeModal .gc-cardmock-code-val{
    font-size: 18px !important;
  }

  /* tighten note area */
  #gcCustomizeModal .gc-preview-note{
    margin-top: 10px !important;
    padding: 12px 12px 10px !important;
  }

  #gcCustomizeModal .gc-preview-note-msg{
    font-size: 14px !important;
    line-height: 1.45 !important;
  }
}

#gcCustomizeModal .modal-footer{
  position: sticky;
  bottom: 0;
  background: #fff;
  z-index: 5;
}

.gc-cardmock{
  /* ...keep your existing properties... */
  background:
    linear-gradient(135deg,
      color-mix(in srgb, var(--gc-theme, #083e6a) 92%, #000),
      color-mix(in srgb, var(--gc-theme, #083e6a) 55%, #000) 55%,
      color-mix(in srgb, var(--gc-theme, #083e6a) 25%, #000)
    );
}

/* Offcanvas forms: keep labels from wrapping into ugly 2-line breaks */
#sspaCartCanvas .sspa-label-1line{
  display:block;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

/* Address box: look like a section, not a nested card */
#sspaCartCanvas #sspaAddressBox{
  background:#fff !important;
  border:1px solid rgba(0,0,0,.08) !important;
	margin-top:10px!important;
}
#sspaAddressBox{
}
/* Slightly tighter inputs in offcanvas */
#sspaCartCanvas .form-control-sm{
  border-radius:999px;
}
/* Compact cart summary */
.sspa-summary {
  font-size: 0.9rem;
}

.sspa-summary-row {
  padding: 2px 0;
}

.sspa-summary-row span:last-child {
  font-weight: 500;
}

.sspa-summary-total {
  padding-top: 6px;
  font-size: 1rem;
  font-weight: 600;
  border-top: 1px dashed rgba(0,0,0,.1);
}

.sspa-summary-total span:last-child {
  font-size: 1.05rem;
}
#sspaShipBox .list-group-item {
  padding: 6px 8px;
  font-size: 0.9rem;
}

#sspaShipBox .small {
  font-size: 0.8rem;
}

.sspa-cart-remove {
  opacity: 0.65;
}
.sspa-cart-remove:hover {
  opacity: 1;
}
.sspa-cart-remove {
  min-width: 32px;
  min-height: 32px;
}

/* =========================
   Product search (modern)
   ========================= */

.sspa-search {
  position: relative;
  display: flex;
  align-items: center;
  height: 44px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 4px 16px rgba(0,0,0,.06);
  padding: 0 44px;
  transition: box-shadow .15s ease, border-color .15s ease;
}

.sspa-search:focus-within {
  border-color: rgba(0,0,0,.18);
  box-shadow: 0 6px 20px rgba(0,0,0,.10);
}

.sspa-search-icon {
  position: absolute;
  left: 16px;
  font-size: 16px;
  color: #8a8f98;
  pointer-events: none;
}

.sspa-search-input {
  width: 100%;
  border: 0;
  outline: 0;
  background: transparent;
  font-size: 15px;
  padding: 0;
}

.sspa-search-input::placeholder {
  color: #9aa0a6;
}

.sspa-search-clear {
  position: absolute;
  right: 10px;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 0;
  background: rgba(0,0,0,.06);
  color: #555;
  display: none; /* shown only when typing */
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.sspa-search-clear:hover {
  background: rgba(0,0,0,.12);
}
/* ===== Gift Card Customize Modal: tighter ===== */

/* Slightly narrower than modal-xl */
.gc-modal-xl { max-width: 980px; }

/* Reduce header/body/footer padding */
#gcCustomizeModal .modal-header { padding: 12px 16px; }
#gcCustomizeModal .modal-body   { padding: 12px 16px; }
#gcCustomizeModal .modal-footer { padding: 10px 16px; }

/* Reduce the top/bottom space in the header text stack */
#gcCustomizeModal .modal-title { margin-bottom: 2px !important; }
#gcCustomizeModal .modal-header .text-muted.small { line-height: 1.2; }

/* Reduce grid gutters inside modal */
#gcCustomizeModal .row.g-3 { --bs-gutter-x: 12px; --bs-gutter-y: 12px; }
#gcCustomizeModal .row.g-2 { --bs-gutter-x: 10px; --bs-gutter-y: 10px; }

/* Make your blocks tighter */
#gcCustomizeModal .gc-block { padding: 12px; margin-bottom: 10px; }
#gcCustomizeModal .gc-block-title { margin-bottom: 6px; }
#gcCustomizeModal .gc-help { margin-top: 6px; }

/* Reduce label spacing */
#gcCustomizeModal .gc-label { margin-bottom: 4px; }

/* Smaller textarea by default */
#gcCustomizeModal textarea#gc_message { rows: 3; }

/* Chips wrap tighter */
#gcCustomizeModal .gc-chip-wrap { gap: 8px; }
#gcCustomizeModal .gc-chip { padding: 6px 10px; }

/* Amount row tighter */
#gcCustomizeModal .gc-amount-row { margin-top: 8px !important; }
#gcCustomizeModal .gc-amount-input.form-control-lg {
  padding-top: 10px;
  padding-bottom: 10px;
  font-size: 18px;
}

/* Options area tighter */
#gcCustomizeModal #gcOptionsBlock .mt-3 { margin-top: 10px !important; }
/* Preview column: less vertical space */
#gcCustomizeModal .gc-preview-v2 { padding-top: 2px; }

/* Scale down the mock card slightly and reduce its internal spacing */
#gcCustomizeModal .gc-cardmock { transform: scale(.92); transform-origin: top center; }
#gcCustomizeModal .gc-preview-note { margin-top: 8px; }

/* Make the mock card less tall if you control these classes */
#gcCustomizeModal .gc-cardmock-amount { margin-top: 10px; }
#gcCustomizeModal .gc-cardmock-dash { margin: 10px 0; }
/* Tighten Options block */
#gcOptionsBlock.gc-block {
  padding: 10px 12px;
  border-radius: 12px;
}
/* Smaller checkboxes */
#gcOptionsBlock .form-check {
  margin-bottom: 6px;
}

#gcOptionsBlock .form-check-input {
  width: 16px;
  height: 16px;
  margin-top: 2px;
}

#gcOptionsBlock .form-check-label {
  font-size: 14px;
  line-height: 1.3;
}
#gcOptionsBlock .gc-block-title {
  font-size: 15px;
  font-weight: 600;
  margin-bottom: 8px;
}