/* =====================================
   KOE FLOWER – DARK LUXURY THEME
   ===================================== */

:root {
  --koe-bg: #000000;
  --koe-panel: #0A0A0A;
  --koe-panel-alt: #111111;
  --koe-gold: #D4AF37;
  --koe-gold-soft: #C9A43A;
  --koe-text: #F5F5F5;
  --koe-text-muted: #B3B3B3;
  --koe-border: #222222;

  --koe-radius-card: 12px;
  --koe-radius-pill: 999px;

  --koe-font-heading: "Cormorant Garamond", "Times New Roman", serif;
  --koe-font-body: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --koe-transition-fast: 150ms ease-out;
}

/* Base layout */

html, body { width: 100%; height: 100%; margin: 0; padding: 0; }

body {
  background-color: var(--koe-bg);
  color: var(--koe-text);
  font-family: var(--koe-font-body);
  font-size: 16px;
  line-height: 1.6;
}

h1, h2, h3, h4, h5, h6 { color: var(--koe-text); font-family: var(--koe-font-heading); }

legend { padding: 7px 0; margin-bottom: 20px; border-bottom: 1px solid #333333; }

label { font-size: 12px; font-weight: normal; color: var(--koe-text-muted); }

/* Chrome border line */
button:focus { outline: none !important; }

/* container */
#container { width: 100%; min-height: 100%; position: absolute; margin-bottom: 300px; }

/* content */
#content, #column-left, #column-right { padding-bottom: 730px; }
@media (min-width: 576px) { #content, #column-left, #column-right { padding-bottom: 400px; } }

/* Alerts */
#alert { z-index: 9999; position: fixed; top: 30%; left: 50%; width: 400px; margin-left: -200px; }
@media (min-width: 992px), (min-width: 1140px), (min-width: 1320px) { #alert { width: 600px; margin-left: -300px; } }
#alert .alert { margin-bottom: 15px; }
#alert .alert-primary { box-shadow: 0 0 0 5px rgba(13,110,253,.15); }
#alert .alert-secondary { box-shadow: 0 0 0 5px rgba(108,117,125,.15); }
#alert .alert-success  { box-shadow: 0 0 0 5px rgba(25,135,84,.15); }
#alert .alert-warning  { box-shadow: 0 0 0 5px rgba(255,193,7,.15); }
#alert .alert-danger   { box-shadow: 0 0 0 5px rgba(220,53,69,.15); }
#alert .alert-info     { box-shadow: 0 0 0 5px rgba(13,202,240,.15); }
#alert .alert-light    { box-shadow: 0 0 0 5px rgba(248,249,250,.15); }
#alert .alert-dark     { box-shadow: 0 0 0 5px rgba(33,37,41,.15); }

/* =====================================
   KOE HEADER
   ===================================== */

.koe-header { background-color: var(--koe-bg); border-bottom: 1px solid #111111; padding: 10px 0; }

.koe-logo img { max-width: 200px; }

.koe-logo-text { font-family: var(--koe-font-heading); font-size: 22px; letter-spacing: .04em; color: var(--koe-gold); }
.koe-logo-text span { margin-left: 4px; }

/* Icon row on the right */
.koe-nav-icons { display: inline-flex; align-items: center; justify-content: flex-end; gap: 18px; }

.koe-icon-link { display: inline-flex; align-items: center; justify-content: center; width: 28px; height: 28px; cursor: pointer; }

.koe-icon { display: block; width: 22px; height: 22px; position: relative; }

/* generic line drawing */
.koe-icon::before, .koe-icon::after { content: ""; position: absolute; border: 1.5px solid var(--koe-gold); }

/* Home */
.koe-icon-home::before { left: 3px; right: 3px; bottom: 3px; height: 10px; border-top: none; }
.koe-icon-home::after  { left: 5px; right: 5px; top: 3px; bottom: 9px; border-left: 1.5px solid var(--koe-gold); border-top: 1.5px solid var(--koe-gold); border-right: none; border-bottom: none; transform: rotate(45deg); }

/* Bag */
.koe-icon-bag::before { left: 4px; right: 4px; bottom: 4px; top: 7px; border-radius: 3px; }
.koe-icon-bag::after  { left: 7px; right: 7px; top: 4px; height: 5px; border-radius: 10px; border-bottom: none; }

/* Search */
.koe-icon-search::before { width: 11px; height: 11px; border-radius: 50%; top: 3px; left: 4px; }
.koe-icon-search::after  { width: 8px; height: 0; border-top: 1.5px solid var(--koe-gold); right: 3px; bottom: 3px; transform-origin: left center; transform: rotate(45deg); }

/* User */
.koe-icon-user::before { width: 9px; height: 9px; border-radius: 50%; top: 2px; left: 6px; }
.koe-icon-user::after  { left: 4px; right: 4px; bottom: 3px; height: 9px; border-radius: 50% 50% 0 0; border-top: none; }

/* Basket */
.koe-icon-basket::before { left: 4px; right: 4px; bottom: 4px; height: 8px; border-top: none; }
.koe-icon-basket::after  { left: 5px; right: 5px; top: 6px; height: 7px; border-radius: 2px; }

/* Mail */
.koe-icon-mail::before { left: 3px; right: 3px; top: 5px; bottom: 5px; }
.koe-icon-mail::after  { left: 4px; right: 4px; top: 7px; height: 0; border-top: 1.5px solid var(--koe-gold); transform: skewX(25deg); }

/* Icon hover */
.koe-icon-link:hover .koe-icon::before, .koe-icon-link:hover .koe-icon::after { border-color: var(--koe-gold-soft); }

/* Logo alignment */
#logo { margin: 0; text-align: left; }

/* =====================================
   MENU
   ===================================== */

#menu {
  background-color: #000 !important;
  background-image: none !important;
  border: 1px solid #111 !important;
  min-height: 40px;
  border-radius: 4px;
  padding: 0 1rem;
  margin-bottom: 20px;
}
#menu .navbar-nav > li > a {
  color: var(--koe-text) !important;
  padding: 10px 15px;
  background: transparent;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: 12px;
}
#menu .navbar-nav > li > a:hover { background: #111 !important; color: var(--koe-gold) !important; }
#menu .dropdown-menu { border-top-left-radius: 0; border-top-right-radius: 0; background: var(--koe-panel); }
#menu .dropdown-menu a { color: var(--koe-text); font-size: 13px; }
#menu .dropdown-menu a:hover { background: #111; color: var(--koe-gold); }
#menu .dropdown-inner { display: flex; flex-direction: column; }
#menu .dropdown-inner ul { width: 100%; min-width: 200px; }
@media (min-width: 960px) { #menu .dropdown:hover .dropdown-menu { display: block; } #menu .dropdown-inner { flex-direction: row; } }
#category { float: left; font-size: 14px; font-weight: 600; line-height: 40px; color: var(--koe-gold); }
#menu .navbar-toggler i { color: var(--koe-text); border-color: var(--koe-text); font-size: .9em; }

/* =====================================
   HERO SECTION
   ===================================== */

#common-home { background: var(--koe-bg); }
.koe-hero { padding: 80px 0 56px; border-bottom: 1px solid #111; }

.koe-hero-title {
  font-family: var(--koe-font-heading);
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: 52px;
  line-height: 1.15;
  color: var(--koe-gold);
  margin: 0 0 24px;
}

/* SHARP CTA + no dark hover */
.koe-hero-btn {
  border-radius: 0;
  border-width: 1px;
  border-color: var(--koe-gold);
  color: var(--koe-gold);
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: 12px;
  padding: 10px 28px;
  background: transparent;
  transition: box-shadow var(--koe-transition-fast), color var(--koe-transition-fast), border-color var(--koe-transition-fast);
}
.koe-hero-btn:hover {
  background: transparent;
  color: #e7cc77;
  border-color: #e7cc77;
  box-shadow: 0 0 16px rgba(212,175,55,.28);
}

/* Jar mock (legacy demo element) */
.koe-jar-mock {
  width: 260px; height: 260px; border-radius: 26px;
  background: radial-gradient(circle at top, #2b2b2b 0%, #050505 55%, #000 100%);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 22px 60px rgba(0,0,0,.9);
  margin-top: 10px;
}
.koe-jar-inner { text-align: center; color: var(--koe-gold); font-family: var(--koe-font-heading); text-transform: uppercase; letter-spacing: .16em; font-size: 12px; }
.koe-jar-crown { width: 22px; height: 14px; margin: 0 auto 12px; position: relative; }
.koe-jar-crown::before, .koe-jar-crown::after { content: ""; position: absolute; border: 1.5px solid var(--koe-gold); }
.koe-jar-crown::before { left: 0; right: 0; bottom: 0; border-top: none; }
.koe-jar-crown::after { width: 18px; height: 8px; top: -6px; left: 2px; border-top: 1.5px solid var(--koe-gold); border-left: none; border-right: none; }
.koe-jar-text-main { margin-bottom: 10px; line-height: 1.4; }
.koe-jar-text-sub  { font-size: 11px; }

/* =====================================
   CATEGORY TILES
   ===================================== */

.koe-categories { padding-top: 24px; }

/* tighter gutters between tiles (Bootstrap 5) */
.koe-categories .row {
  --bs-gutter-x: 12px;   /* horizontal gap between tiles */
  --bs-gutter-y: 16px;   /* vertical gap */
}

/* Border-only tiles; height hugs icon+label (no forced square) */
.koe-category-tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
  padding: 20px 14px 18px;   /* tighter box */
  background: transparent;
  border: 1px solid var(--koe-gold);
  border-radius: 0;
  text-align: center;
  text-decoration: none;
  color: var(--koe-gold);
  gap: 6px;                 /* spacing between icon & label */
  transition:
    border-color var(--koe-transition-fast),
    transform var(--koe-transition-fast),
    box-shadow var(--koe-transition-fast),
    background-color var(--koe-transition-fast);
}
.koe-category-tile:hover {
  border-color: #e7cc77;
  transform: translateY(-2px);
  box-shadow: 0 14px 40px rgba(0,0,0,.7);
  color: var(--koe-gold);
}

/* ICON: PNG only; shift down slightly */
.koe-category-icon {
  border: 0 !important;
  border-radius: 0 !important;
  background: none !important;
  line-height: 0;
  transform: translateY(6px);   /* move the PNG down in the box */
}
.koe-category-icon::before,
.koe-category-icon::after,
.koe-category-icon-flower::after,
.koe-category-icon-vapes::after,
.koe-category-icon-edibles::after,
.koe-category-icon-concentrates::after {
  content: none !important;
  display: none !important;
  width: 0 !important; height: 0 !important;
  border: 0 !important; background: none !important; box-shadow: none !important;
}
.koe-category-icon img {
  width: 96px;   /* tweak 88–110px as you like */
  height: auto;
  display: block;
  image-rendering: -webkit-optimize-contrast;
}

/* Labels larger + tight */
.koe-category-label {
  font-size: 17px;
  line-height: 1.1;
  text-transform: uppercase;
  letter-spacing: .16em;
  color: var(--koe-gold);
}

/* =====================================
   FEATURED HEADING
   ===================================== */

.koe-featured-heading { margin-top: 32px; margin-bottom: 24px; text-align: center; }

/* ===== Featured divider — feathered ends (no layout impact) ===== */
.koe-featured-divider{
  position: relative;
  width: min(680px, 90%);
  height: 2px;                 /* hairline thickness */
  margin: 0 auto 16px;
  border: 0;                   /* kill the solid line so gradient shows */
  background: linear-gradient(
    90deg,
    rgba(212,175,55,0)   0%,
    rgba(212,175,55,.45) 12%,
    rgba(212,175,55,.85) 50%,
    rgba(212,175,55,.45) 88%,
    rgba(212,175,55,0) 100%
  );
  background-clip: padding-box;
}

.koe-featured-divider::after{
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 8px;
  height: 8px;
  transform: translate(-50%, -50%) rotate(45deg);
  border: 1px solid var(--koe-gold);
  background: #050505;
  box-shadow: 0 0 8px rgba(212,175,55,.35); /* subtle glow like your reference */
}
.koe-featured-title { font-family: var(--koe-font-heading); font-size: 20px; text-transform: uppercase; letter-spacing: .18em; color: var(--koe-gold); }

/* =====================================
   FORMS / MISC BOOTSTRAP OVERRIDES
   ===================================== */

div.required .col-form-label:before, div.required .form-label:before { content: "* "; color: #FF4C4C; font-weight: bold; }
.form-switch-lg { font-size: 20px; min-height: 30px; line-height: 30px; }
.nav-tabs { margin-bottom: 15px; }
.form-check .form-check-input { margin-top: .25rem; }
@media (min-width: 768px) { .col-form-label { text-align: right; } }

/* =====================================
   FOOTER
   ===================================== */

footer {
  position: absolute; bottom: -1px; width: 100%; padding-top: 30px;
  background: #050505; border-top: 1px solid #111; color: var(--koe-text-muted);
}
footer hr { border-top: none; border-bottom: 1px solid #333; }
footer a { color: var(--koe-text-muted); text-decoration: none; }
footer a:hover { color: var(--koe-gold); }
footer h5 { font-family: var(--koe-font-body); font-size: 13px; font-weight: 600; color: var(--koe-text); margin: 10px 0; }
.koe-footer-brand { font-family: var(--koe-font-heading); }
.koe-footer-name { font-size: 14px; letter-spacing: .14em; text-transform: uppercase; color: var(--koe-gold); }
.koe-footer-tagline { font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--koe-text-muted); margin-top: 3px; }

/* =====================================
   BREADCRUMB
   ===================================== */

.breadcrumb { margin: 14px 0 18px 0; padding: 8px 0; border: 1px solid #222; border-radius: 4px; background: #050505; }
.breadcrumb i { font-size: 15px; }
.breadcrumb > li.breadcrumb-item { padding: 0 20px; position: relative; white-space: nowrap; }
.breadcrumb > li.breadcrumb-item > a { text-decoration: none; color: var(--koe-text-muted); }
.breadcrumb > li.breadcrumb-item:after { content: ""; display: block; position: absolute; top: -3px; right: -5px; width: 29px; height: 29px; border-right: 1px solid #222; border-bottom: 1px solid #222; transform: rotate(-45deg); }
.breadcrumb > li.breadcrumb-item + li:before { content: ""; padding: 0; }

/* =====================================
   PRODUCT THUMBS
   ===================================== */

.product-thumb {
  border: 1px solid #111; background: var(--koe-panel); position: relative; height: 100%;
  border-radius: 12px; overflow: hidden;
  transition: border-color var(--koe-transition-fast), transform var(--koe-transition-fast), box-shadow var(--koe-transition-fast);
}
.product-thumb:hover { border-color: var(--koe-gold); transform: translateY(-4px); box-shadow: 0 16px 40px rgba(0,0,0,.8); }
.product-thumb .image { text-align: center; background: #050505; }
.product-thumb .image img { max-width: 100%; }
.product-thumb .image a:hover { opacity: .9; }
.product-thumb .description { padding: 15px; margin-bottom: 45px; }
.product-thumb .description h4 { font-weight: 600; font-family: var(--koe-font-heading); }
.product-thumb .description h4 a { color: var(--koe-text); }

.product-thumb .button { display: flex; position: absolute; width: 100%; bottom: 0; }
.product-thumb .button button {
  width: 33.33%; border: none; border-top: 1px solid #111; background: #050505; color: var(--koe-text-muted);
  line-height: 38px; text-align: center;
}
.product-thumb .button button:hover { color: var(--koe-gold); background: #111; cursor: pointer; }
.product-thumb .button button + button { border-left: 1px solid #111; }

@media (min-width: 960px) {
  .product-list .product-thumb { display: flex; }
  .product-list .product-thumb .image { flex-direction: column; margin-bottom: 0; }
  .product-list .product-thumb .content { flex-direction: column; flex: 75%; position: relative; }
  .product-list .product-thumb .button { border-left: 1px solid #111; width: calc(100% - 15px); margin-left: 15px; }
}

/* Ratings */
.rating .fa-stack { width: 20px; }
.rating .fa-star { color: #FC0; font-size: 15px; }
.rating .fa-star + .fa-star { color: #E69500; }

/* Prices */
.price { color: var(--koe-gold); }
.price-new { font-weight: 600; }
.price-old { color: #dc512c; text-decoration: line-through; }
.price-tax { color: var(--koe-text-muted); font-size: 12px; display: block; }

/* =====================================
   BLOG (if used)
   ===================================== */

.blog-thumb { border: 1px solid #111; background: var(--koe-panel); margin-bottom: 15px; }
.blog-thumb h4 { font-weight: 600; }
.blog-thumb .image { text-align: center; margin-bottom: 15px; }
.blog-thumb .image a:hover { opacity: .9; }
.blog-thumb .description { padding: 15px; }

/* =====================================
   COOKIE STRIP
   ===================================== */

#cookie { position: fixed; bottom: 0; left: 0; width: 100%; height: 150px; z-index: 9999; opacity: .95; color: #ecf0f1; background: #343a40; }
#cookie div { font-size: 16px; color: #fff; }

/* =====================================
   MOBILE TUNING
   ===================================== */

@media (max-width: 767.98px) {
  .koe-hero { padding: 36px 0 24px; text-align: center; }
  .koe-hero-title { font-size: 30px; letter-spacing: .10em; }
  .koe-hero-btn { margin-top: 10px; }

  .koe-jar-mock { width: 220px; height: 220px; margin: 24px auto 0; }

  .koe-categories { padding-top: 16px; }
  .koe-category-tile { padding: 18px 12px 16px; }
  .koe-category-icon img { width: 90px; }
}


/* ===== CATEGORY TILE FIX — override inline rules from home.twig ===== */
#common-home .koe-categories .koe-category-tile{
  width:100% !important;           /* kill the 85% width */
  aspect-ratio:auto !important;    /* kill the forced square */
  padding:16px 12px 14px !important;  /* tighter box around icon + text */
  border-radius:0;
}

/* Move the PNG down a bit & tighten stack */
#common-home .koe-category-icon{
  transform: translateY(12px);     /* push icon downward */
  line-height:0;
}
#common-home .koe-category-icon img{
  width:104px;                     /* bump icon size (tweak 96–112) */
  height:auto; display:block;
}
#common-home .koe-category-label{
  margin-top:2px;
  font-size:18px;                  /* bigger text */
  line-height:1.1;
  letter-spacing:.18em;
  color:#D4AF37;
}

/* Reduce the gaps between tiles (works for BS4 or BS5) */
#common-home .koe-categories .row{
  margin-left:-8px;  margin-right:-8px;     /* smaller gutters */
}
#common-home .koe-categories [class^="col-"],
#common-home .koe-categories [class*=" col-"]{
  padding-left:8px; padding-right:8px;
}

/* ===== PATCH C — Tile centering, square ratio, tighter/even gaps ===== */
#common-home .koe-categories .row{
  /* smaller, even gutters between tiles (works BS4/BS5) */
  margin-left:-8px;  margin-right:-8px;
}
#common-home .koe-categories [class^="col-"],
#common-home .koe-categories [class*=" col-"]{
  padding-left:8px;  padding-right:8px;
}

#common-home .koe-category-tile{
  /* perfect center stack */
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;

  /* true squares */
  aspect-ratio:1 / 1;

  /* tighter box around icon+text */
  padding:18px 12px;
  gap:10px;

  /* keep your current look */
  background:transparent;
  border:1px solid var(--koe-gold);
  border-radius:0;
  text-align:center;
  color:var(--koe-gold);
  text-decoration:none;
}

#common-home .koe-category-tile:hover{
  border-color: var(--koe-gold-soft);
  transform: translateY(-2px);
  box-shadow: 0 14px 40px rgba(0,0,0,.7);
}

#common-home .koe-category-icon{
  /* remove any vertical nudge so it truly centers */
  line-height:0;
  transform:none;
  display:flex;
  align-items:center;
  justify-content:center;
  background:none !important;
  border:0 !important;
}
#common-home .koe-category-icon::before,
#common-home .koe-category-icon::after{
  content:none !important; display:none !important;
}

#common-home .koe-category-icon img{
  /* icon size (tweak 96–110px if you want) */
  width:104px;
  height:auto;
  display:block;
}

#common-home .koe-category-label{
  margin-top:6px;                 /* small, consistent gap under icon */
  font-size:18px;
  line-height:1.1;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--koe-gold);
}


/* PATCH C.1 — tighter horizontal gaps between tiles (override g-3) */
#common-home .koe-categories .row.g-3{
  --bs-gutter-x: 6px;   /* was ~16px; lower = tighter */
  --bs-gutter-y: 14px;  /* keep vertical breathing room */
}

/* fallback for older BS builds */
#common-home .koe-categories [class^="col-"],
#common-home .koe-categories [class*=" col-"]{
  padding-left:6px;
  padding-right:6px;
}

/* Fill each column: kill the 85% tile width + auto margins from home.twig */
#common-home .koe-categories .col-6.col-md-3 > a.koe-category-tile{
  max-width:100% !important;
  width:100% !important;
  margin-inline:0 !important;
}


/* Raise the tile labels a bit */
#common-home .koe-category-label{
  transform: translateY(-8px);   /* tweak: -4px … -14px */
  margin-top: 0;                 /* tighten gap under icon */
  white-space: nowrap;           /* avoid wrap pushing height */
}

/* ===== A — HEADER SCALE TWEAKS ===== */

/* Brand size (works whether you're using the image logo or the text fallback) */
.koe-logo img { max-width: 240px; }          /* was 200px */
.koe-logo-text { font-size: 26px; letter-spacing: .06em; }  /* was 22px */

/* Right icon row: slightly bigger hit-area + SVGs */
.koe-nav-icons { gap: 20px; }                 /* was 18px */
.koe-icon-link { width: 42px; height: 42px; } /* was 38px */
.koe-icon svg { width: 28px; height: 28px; }  /* was 26px */

/* Top category bar (under the logo) — a touch larger */
#menu { min-height: 44px; }                   /* was 40px */
#menu .navbar-nav > li > a{
  font-size: 13px;                            /* was 12px */
  letter-spacing: .10em;                      /* was .08em */
  padding: 12px 16px;                         /* was 10px 15px */
}

/* =====================================
   INFORMATION PAGES (ABOUT / PRIVACY / TERMS)
   ===================================== */

.koe-info {
  max-width: 900px;
  margin-bottom: 60px;
}

.koe-info-title {
  font-family: var(--koe-font-heading);
  font-size: 28px;
  line-height: 1.3;
  color: var(--koe-gold);
  margin: 0 0 18px;
}

.koe-info-body {
  font-size: 15px;
  line-height: 1.7;
  color: var(--koe-text);
}

/* Gold section headings inside info pages */
.koe-info-body h2,
.koe-info-body h3,
.koe-info-body h4 {
  font-family: var(--koe-font-heading);
  color: var(--koe-gold);
  margin-top: 26px;
  margin-bottom: 10px;
}

/* Comfortable paragraph + list spacing */
.koe-info-body p {
  margin-bottom: 12px;
}

.koe-info-body ul,
.koe-info-body ol {
  margin-bottom: 14px;
  padding-left: 1.3rem;
}

.koe-info-body li {
  margin-bottom: 4px;
}

/* =====================================
   CART / CHECKOUT – ACCORDION + BOTTOM PANELS
   ===================================== */

/* Use Bootstrap 5 accordion CSS variables so we don't fight the component */
#checkout-cart .accordion,
#checkout-checkout .accordion {
  --bs-accordion-color: var(--koe-text);
  --bs-accordion-bg: #050505;
  --bs-accordion-border-color: #222;
  --bs-accordion-border-radius: 0;
  --bs-accordion-inner-border-radius: 0;
  --bs-accordion-btn-color: var(--koe-text);
  --bs-accordion-btn-bg: #050505;
  --bs-accordion-btn-padding-x: 1.2rem;
  --bs-accordion-btn-padding-y: 0.9rem;
  --bs-accordion-btn-focus-box-shadow: none;
  --bs-accordion-active-color: var(--koe-gold);
  --bs-accordion-active-bg: #050505;
}

#checkout-cart .accordion-item,
#checkout-checkout .accordion-item {
  background-color: #050505;
  border-radius: 0;
  border-color: #222;
}

#checkout-cart .accordion-button,
#checkout-checkout .accordion-button {
  font-size: 13px;
  letter-spacing: .08em;
  text-transform: uppercase;
}

/* Kill the default grey hover & box-shadow */
#checkout-cart .accordion-button:not(.collapsed),
#checkout-checkout .accordion-button:not(.collapsed) {
  box-shadow: none;
}

/* Accordion body background + borders */
#checkout-cart .accordion-body,
#checkout-checkout .accordion-body {
  background-color: #050505;
  border-top: 1px solid #222;
}

/* Make the dropdown bars span edge-to-edge cleanly */
#checkout-cart .accordion-item + .accordion-item,
#checkout-checkout .accordion-item + .accordion-item {
  border-top: none;
}