/* =========================================================
   SECOND SERVING — CLEAN CONSOLIDATED STYLESHEET
   Full drop-in replacement
   ========================================================= */

/* =========================================================
   01. TOKENS / DESIGN KNOBS
   ========================================================= */

:root{
  --ss-shell-max: 1200px;
  --ss-shell-text: #2f3e3a;

  /* surfaces */
  --ss-home-panel-bg: rgba(248,244,236,.35);
  --ss-page-card-bg: rgba(255,255,255,.34);
  --ss-form-panel-bg: rgba(255,255,255,.54);
  --ss-field-bg: rgba(255,255,255,.90);
  --ss-inner-points-bg: rgba(255,255,255,.72);

  /* borders */
  --ss-home-panel-border: rgba(0,0,0,.10);
  --ss-page-card-border: rgba(0,0,0,.08);
  --ss-form-panel-border: rgba(0,0,0,.08);
  --ss-field-border: rgba(0,0,0,.12);
  --ss-inner-surface-border: rgba(0,0,0,.08);

  /* radius */
  --ss-home-panel-radius: 22px;
  --ss-card-radius: 18px;
  --ss-field-radius: 12px;
  --ss-inner-surface-radius: 16px;

  /* spacing */
  --ss-shell-first-top: 180px;
  --ss-shell-stack-gap: 16px;
  --ss-shell-stack-gap-mobile: 10px;

  --ss-home-gap: 18px;
  --ss-home-hero-pad-y: 26px;
  --ss-home-hero-pad-x: 28px;
  --ss-home-panel-pad-y: 22px;
  --ss-home-panel-pad-x: 26px;
  --ss-page-panel-pad-y: 24px;
  --ss-page-panel-pad-x: 28px;
  --ss-card-pad: 22px;

  --ss-home-mobile-pad-y: 20px;
  --ss-home-mobile-pad-x: 18px;
  --ss-page-panel-pad-y-mobile: 20px;
  --ss-page-panel-pad-x-mobile: 18px;
  --ss-card-pad-mobile: 18px;

  /* effects */
  --ss-card-shadow: 0 10px 28px rgba(0,0,0,.06);
  --ss-card-blur: 10px;

  /* buttons */
  --ss-btn-bg: #5c7f4f;
  --ss-btn-bg-hover: #4e6e43;
  --ss-btn-text: #fff;
  --ss-btn-ghost-bg: rgba(255,255,255,.65);
  --ss-btn-ghost-bg-hover: rgba(255,255,255,.90);
  --ss-btn-ghost-text: #3f5c53;
  --ss-btn-soft-bg: rgba(255,255,255,.50);
  --ss-btn-soft-text: #3f5c53;

  /* text */


  --ss-number-color: #546d39;
  --ss-title-color: #39554c;
  --ss-subtitle-color: #4d5a57;
  --ss-body-muted: #55635f;
  --ss-meta-muted: #50605c;
  --ss-text-soft: #5a6864;
  --ss-kicker-color: #5b6b66;
  --ss-accent: #2f5d50;

  /* feedback */
  --ss-success-bg: rgba(94,127,58,.14);
  --ss-success-text: #42592a;
  --ss-success-border: rgba(94,127,58,.20);
  --ss-error-bg: rgba(168,70,45,.10);
  --ss-error-text: #7b3924;
  --ss-error-border: rgba(168,70,45,.18);

  /* availability pills */
    --ss-pill-bg: rgba(94,127,58,.12);
  --ss-pill-text: #4f6d31;
  --ss-distance-near-bg: rgba(92,127,79,.18);
  --ss-distance-near-text: #3f5f34;
  --ss-distance-mid-bg: rgba(214,167,33,.14);
  --ss-distance-mid-text: #8a6a12;
  --ss-distance-far-bg: rgba(183,74,74,.12);
  --ss-distance-far-text: #9b3b3b;

  --ss-expire-urgent-bg: rgba(183,74,74,.18);
  --ss-expire-urgent-text: #8f2f2f;
  --ss-expire-urgent-border: rgba(183,74,74,.25);
  --ss-expire-soon-bg: rgba(214,167,33,.14);
  --ss-expire-soon-text: #8a6a12;
  --ss-expire-soon-border: rgba(214,167,33,.18);

  --ss-posted-pill-bg: rgba(120,110,95,.08);
  --ss-posted-pill-text: #6e6458;
  --ss-posted-pill-border: rgba(120,110,95,.12);

  /* background topo */
  --ss-topo-image: url("https://secondserving.org/wp-content/uploads/2026/04/777.webp");
  --ss-topo-size: 1000px;
  --ss-topo-opacity: .05;
}

/* =========================================================
   02. GLOBAL RHYTHM / PAGE FRAME
   ========================================================= */

html{ overflow-y: scroll; }
body{ min-height: 100vh; }

.ss-page{
  min-height: calc(100vh - 220px);
}

.ss-footer{
  margin-top: 0;
}

/* =========================================================
   03. SHELL / PANELS / SURFACES
   ========================================================= */

.ss-shell{
  position: relative;
  isolation: isolate;
  max-width: var(--ss-shell-max);
  margin: 0 auto;
  box-sizing: border-box;
  color: var(--ss-shell-text);
  background: transparent;
}

.ss-shell:first-of-type{
  margin-top: var(--ss-shell-first-top);
}

.ss-shell + .ss-shell{
  margin-top: var(--ss-shell-stack-gap);
}

.ss-shell::before{
  content: "";
  position: fixed;
  inset: 0;
  background-image: var(--ss-topo-image);
  background-repeat: repeat;
  background-size: var(--ss-topo-size);
  opacity: var(--ss-topo-opacity);
  pointer-events: none;
  z-index: 0;
}

.ss-shell > *{
  position: relative;
  z-index: 1;
}

.ss-shell > .ss-home-panel + .ss-home-panel{
  margin-top: 16px;
}

.ss-homepage-shell > .ss-home-panel + .ss-home-panel{
  margin-top: 15px;
}

.ss-homepage-shell > .ss-home-panel:first-child{
  margin-top: 0;
}

.ss-home-panel.ss-trust-block{
  margin-top: 18px;
}

.ss-home-panel.ss-stats-block{
  margin-top: 10px;
}

.ss-home-panel,
.ss-phase3-panel{
  position: relative;
  width: 100%;
  max-width: var(--ss-shell-max);
  margin-left: auto;
  margin-right: auto;
  color: var(--ss-shell-text);
  background: var(--ss-home-panel-bg);
  border: 1px solid var(--ss-home-panel-border);
  border-radius: var(--ss-home-panel-radius);
  overflow: hidden;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.ss-home-panel-inner{
  padding: var(--ss-home-panel-pad-y) var(--ss-home-panel-pad-x);
}

.ss-hero-card .ss-home-panel-inner{
  padding: var(--ss-home-hero-pad-y) var(--ss-home-hero-pad-x);
}

.ss-page-panel .ss-home-panel-inner{
  padding: var(--ss-page-panel-pad-y) var(--ss-page-panel-pad-x);
}

.ss-home-panel-header{
  margin: 0 0 18px;
}

.ss-home-panel-copy,
.ss-home-panel-body{
  min-width: 0;
}

.ss-home-panel-header--split{
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
}

.ss-home-panel-header--split .ss-home-panel-copy{
  flex: 1 1 auto;
}

.ss-home-panel-header--hero .ss-home-panel-copy{
  max-width: 900px;
  margin: 0 auto;
}

.ss-home-panel-header--trust{
  display: grid;
  grid-template-columns: 96px minmax(0,1fr);
  gap: 18px;
  align-items: center;
}

.ss-home-panel-header--stack{
  display: block;
  text-align: center;
}

.ss-home-panel-header--stack .ss-home-panel-copy{
  max-width: none;
  margin: 0 auto 20px;
}

.ss-home-panel-header--stack .ss-home-panel-title{
  max-width: 980px;
  margin: 0 auto 14px;
}

.ss-home-panel-header--stack .ss-home-panel-text{
  max-width: 720px;
  margin: 0 auto 12px;
}

.ss-home-panel-header--stack .ss-hero-helper{
  max-width: 640px;
  margin: 0 auto;
  opacity: .8;
}

.ss-shell .ss-card,
.ss-shell .ss-glass,
.ss-card,
.ss-glass{
  background: var(--ss-page-card-bg);
  border: 1px solid var(--ss-page-card-border);
  border-radius: var(--ss-card-radius);
  box-shadow: var(--ss-card-shadow);
  backdrop-filter: blur(var(--ss-card-blur));
  -webkit-backdrop-filter: blur(var(--ss-card-blur));
}

.ss-shell .ss-card,
.ss-card{
  padding: var(--ss-card-pad);
}

.ss-shell .ss-form-wrap,
.ss-shell .ss-card.ss-form-wrap,
.ss-shell .ss-glass.ss-form-wrap,
.ss-form-wrap,
.ss-card.ss-form-wrap,
.ss-glass.ss-form-wrap{
  background: var(--ss-form-panel-bg);
  border: 1px solid var(--ss-form-panel-border);
  border-radius: var(--ss-card-radius);
  box-shadow: var(--ss-card-shadow);
  backdrop-filter: blur(var(--ss-card-blur));
  -webkit-backdrop-filter: blur(var(--ss-card-blur));
  padding: var(--ss-card-pad);
}

/* =========================================================
   04. TYPOGRAPHY / TEXT UTILS
   ========================================================= */

.ss-title,
.ss-home-panel-title{
  margin: 0 0 8px;
  font-size: clamp(28px,4vw,42px);
  line-height: 1.04;
  text-align: center;
  color: var(--ss-title-color);
}

.ss-page-panel .ss-title,
.ss-page-panel .ss-home-panel-title,
.ss-how-panel-title,
.ss-trust-title,
.ss-stats-title{
  text-align: left;
}

.ss-subtitle,
.ss-home-panel-text{
  margin: 0 auto;
  max-width: 680px;
  font-size: 17px;
  line-height: 1.65;
  color: var(--ss-subtitle-color);
  text-align: center;
}

.ss-page-panel .ss-subtitle,
.ss-page-panel .ss-home-panel-text,
.ss-trust-text{
  margin: 0;
  max-width: none;
  text-align: left;
}

.ss-home-panel-kicker,
.ss-stats-kicker,
.ss-trust-kicker{
  margin: 0 0 8px;
  color: var(--ss-kicker-color);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ss-trust-title,
.ss-stats-title,
.ss-how-panel-title{
  margin: 0 0 8px;
  font-size: clamp(26px,3vw,34px);
  line-height: 1.12;
  color: var(--ss-title-color);
}

.ss-trust-text,
.ss-how-desc,
.ss-circle-text{
  color: var(--ss-text-soft);
}

.ss-mini{
  font-size: 12px;
  color: #697874;
}

.ss-hero-helper{
  margin: 6px 0 0;
  font-size: 14px;
  line-height: 1.5;
  color: var(--ss-text-soft);
  opacity: .82;
}

/* =========================================================
   05. PILL SYSTEM
   ========================================================= */

.ss-pill{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  padding: 6px 10px;
  border-radius: 999px;
  background: var(--ss-pill-bg);
  color: var(--ss-pill-text);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .02em;
}

.ss-homepage-shell .ss-pill,
.ss-how-hero-panel .ss-pill{
  margin: 0 auto 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.ss-pill--soft{
  display: inline-flex;
  align-items: center;
  margin-top: 8px;
}

.ss-distance-pill,
.ss-expire-pill{
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: .85rem;
  font-weight: 600;
  line-height: 1.2;
  white-space: nowrap;
}

.ss-distance-pill{
  transition: transform .15s ease, box-shadow .15s ease;
}

.ss-distance-pill:hover{
  transform: translateY(-1px);
}

.ss-distance-pill::before{
  opacity: .7;
  margin-right: 2px;
}

.ss-distance--near{
  background: var(--ss-distance-near-bg);
  color: var(--ss-distance-near-text);
}

.ss-distance--mid{
  background: var(--ss-distance-mid-bg);
  color: var(--ss-distance-mid-text);
}

.ss-distance--far{
  background: var(--ss-distance-far-bg);
  color: var(--ss-distance-far-text);
}

.ss-expire-pill--urgent{
  background: var(--ss-expire-urgent-bg);
  color: var(--ss-expire-urgent-text);
  border: 1px solid var(--ss-expire-urgent-border);
}

.ss-expire-pill--soon{
  background: var(--ss-expire-soon-bg);
  color: var(--ss-expire-soon-text);
  border: 1px solid var(--ss-expire-soon-border);
}

/* =========================================================
   06. BUTTON SYSTEM
   ========================================================= */

.ss-actions{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}

.ss-btn,
.ss-btn:link,
.ss-btn:visited{
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 38px;
  padding: 13px 22px;
  border: 1px solid transparent;
  border-radius: 999px;
  background: var(--ss-btn-bg);
  color: var(--ss-btn-text);
  font-family: inherit;
  font-size: 15px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: .01em;
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
  transition: all 160ms ease;
}

.ss-btn::after{
  content: "→";
  margin-left: 6px;
  font-size: 14px;
}

.ss-btn:hover{
  background: var(--ss-btn-bg-hover);
  color: var(--ss-btn-text);
  text-decoration: none;
  transform: translateY(-1px);
  box-shadow: 0 6px 14px rgba(0,0,0,.08);
}

.ss-btn:focus{
  outline: none;
  box-shadow: 0 0 0 2px rgba(94,127,58,.25);
}

.ss-btn--ghost,
.ss-btn--ghost:link,
.ss-btn--ghost:visited{
  background: var(--ss-btn-ghost-bg);
  color: var(--ss-btn-ghost-text);
  border: 1px solid rgba(0,0,0,.12);
}

.ss-btn--ghost:hover{
  background: var(--ss-btn-ghost-bg-hover);
  color: var(--ss-btn-ghost-text);
  transform: translateY(-1px);
  box-shadow: 0 6px 14px rgba(0,0,0,.05);
}

.ss-btn--soft,
.ss-btn--soft:link,
.ss-btn--soft:visited{
  background: var(--ss-btn-soft-bg);
  color: var(--ss-btn-soft-text);
  border: 1px solid rgba(0,0,0,.10);
}

.ss-btn--soft:hover{
  color: var(--ss-btn-soft-text);
  text-decoration: none;
}

.ss-homepage-actions{
  justify-content: center;
  margin-top: 18px;
}

.ss-panel-filter{
  flex: 0 0 auto;
  margin-left: auto;
}

.ss-panel-filter-input{
  width: 140px;
}

.ss-panel-filter .ss-btn{
  min-width: 150px;
}

.ss-btn.ss-modal-triggering,
.ss-btn.ss-modal-triggering:hover,
.ss-btn.ss-modal-triggering:focus,
.ss-btn.ss-modal-triggering:active{
  transform: none !important;
  box-shadow: none !important;
}

.ss-phase3-toggle{
  min-width: 130px;
  justify-content: center;
  padding: 8px 14px;
  font-size: .85rem;
  border-radius: 999px;
}

.ss-phase3-toggle::after,
.ss-phase3-toggle.is-open .ss-btn-label::after{
  content: "";
}

/* =========================================================
   07. GRID / FORM SYSTEM
   ========================================================= */

.ss-form,
.ss-list,
.ss-meta{
  display: grid;
  gap: 14px;
}

.ss-row,
.ss-row-3,
.ss-grid-2{
  display: grid;
  gap: 14px;
}

.ss-row{
  grid-template-columns: repeat(2,minmax(0,1fr));
}

.ss-row-3{
  grid-template-columns: repeat(3,minmax(0,1fr));
}

.ss-grid-2{
  grid-template-columns: repeat(2,minmax(0,1fr));
}

.ss-field{
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.ss-label{
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .02em;
  color: var(--ss-title-color);
}

.ss-input,
.ss-select,
.ss-textarea{
  width: 100%;
  box-sizing: border-box;
  padding: 12px 14px;
  border: 1px solid var(--ss-field-border);
  border-radius: var(--ss-field-radius);
  background: var(--ss-field-bg);
  color: inherit;
  font: inherit;
  appearance: none;
  -webkit-appearance: none;
}

.ss-textarea{
  min-height: 130px;
  resize: vertical;
}

.ss-help{
  font-size: 12px;
  color: #61706c;
}

.ss-ack{
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 14px;
  line-height: 1.5;
  color: var(--ss-body-muted);
}

/* =========================================================
   08. SHARED NOTES / AJAX / STATES
   ========================================================= */

.ss-ajax-response{
  margin: 0 0 16px;
}

.ss-note{
  padding: 12px 14px;
  border-radius: 12px;
  margin: 0 0 16px;
  border: 1px solid rgba(0,0,0,.08);
}

.ss-note--info{
  background: rgba(255,255,255,.52);
  color: #42514d;
}

.ss-note--success{
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 14px 16px;
  border-radius: 14px;
  background: var(--ss-success-bg);
  color: var(--ss-success-text);
  border: 1px solid var(--ss-success-border);
  box-shadow: 0 4px 12px rgba(0,0,0,.03);
  animation: ss-success-pop 420ms ease;
}

.ss-note--success::before{
  content: "✔";
  flex: 0 0 auto;
  width: 20px;
  height: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(94,127,58,.18);
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
  margin-top: 1px;
}

.ss-note--error{
  background: var(--ss-error-bg);
  color: var(--ss-error-text);
  border-color: var(--ss-error-border);
}

.ss-panel-note{
  margin-bottom: 16px;
}

.ss-btn.is-loading{
  pointer-events: none;
  opacity: .92;
}

.ss-btn.is-loading .ss-btn-label{
  opacity: .78;
}

.ss-btn-spinner{
  display: none;
  width: 16px;
  height: 16px;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  animation: ss-spin .7s linear infinite;
  flex: 0 0 auto;
}

.ss-btn.is-loading .ss-btn-spinner{
  display: inline-block;
}

.ss-btn.is-success{
  background: #4caf50;
  color: #fff;
}

.ss-claim-success{
  overflow: hidden;
  max-height: 1200px;
  opacity: 1;
  transform: scale(1);
  transition:
    opacity 260ms ease,
    transform 260ms ease,
    max-height 360ms ease,
    margin 360ms ease,
    padding-top 360ms ease,
    padding-bottom 360ms ease;
}

.ss-claim-removing{
  opacity: 0;
  transform: scale(.985);
  max-height: 0 !important;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  pointer-events: none;
}

.ss-list > .ss-item{
  will-change: transform;
  transform-origin: center top;
}

.ss-item.is-claimed{
  position: relative;
}

.ss-item.is-completed{
  opacity: .7;
}

.ss-item.is-completed .ss-item-title::after{
  content: " • Completed";
  font-size: .9em;
}

.ss-item.is-expired{
  opacity: .68;
}

.ss-expired-note{
  margin-top: 10px;
  color: #6f6a5f;
}

.ss-input--error{
  border-color: #c62828 !important;
  box-shadow: 0 0 0 3px rgba(198,40,40,.12);
}

.ss-field-error{
  margin-top: 6px;
  font-size: 13px;
  line-height: 1.4;
  color: #c62828;
}

.ss-input-hint{
  grid-column: 1 / -1;
  margin: 12px 0 0;
  padding: 8px 12px;
  font-size: 13px;
  font-weight: 500;
  color: #2f5e46;
  background: rgba(80,140,100,.12);
  border: 1px solid rgba(80,140,100,.25);
  border-radius: 10px;
}

/* =========================================================
   09. SHARED LIST / CARD SYSTEM
   ========================================================= */

.ss-item{
  padding: 18px;
}

.ss-item-head{
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 10px;
}

.ss-item-title{
  margin: 0 0 6px;
  font-size: 20px;
  line-height: 1.2;
  color: var(--ss-title-color);
}

.ss-meta{
  font-size: 14px;
  color: var(--ss-meta-muted);
}

.ss-meta strong{
  color: var(--ss-title-color);
}

.ss-meta p,
.ss-meta div{
  margin: 0;
}

.ss-claim-box{
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(0,0,0,.08);
}

.ss-empty{
  padding: 30px 18px;
  text-align: center;
  color: #5c6b67;
}

.ss-divider,
.ss-item hr{
  margin: 18px 0 16px;
}

.ss-my-pickups-panel .ss-meta > div strong{
  font-weight: 700;
}

/* =========================================================
   10. HOMEPAGE / TRUST / STATS
   ========================================================= */

.ss-trust-block .ss-home-panel-inner,
.ss-stats-block .ss-home-panel-inner,
.ss-phase3-panel .ss-home-panel-inner{
  padding: 16px 18px;
}

.ss-hero-card .ss-home-panel-inner{
  padding: 22px 22px;
}

.ss-trust-block .ss-home-panel-header,
.ss-stats-block .ss-home-panel-header,
.ss-phase3-panel .ss-home-panel-header{
  margin-bottom: 10px;
}

.ss-stats-title,
.ss-trust-title{
  margin-bottom: 6px;
}

.ss-kpis,
.ss-stats-grid{
  display: grid;
  gap: 18px;
  justify-content: center;
  align-items: stretch;
}

.ss-kpis{
  grid-template-columns: repeat(3,200px);
  margin-top: 18px;
}

.ss-stats-grid{
  grid-template-columns: repeat(4,200px);
}

.ss-kpi,
.ss-stat{
  width: 100%;
  max-width: none;
  box-sizing: border-box;
  padding: 12px 14px;
  text-align: center;
  background: rgba(255,255,255,.42);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 16px;
  box-shadow: 0 4px 12px rgba(0,0,0,.03);
}

.ss-kpi strong,
.ss-stat-number{
  display: block;
  margin: 0 0 4px;
  font-size: 26px;
  line-height: 1;
  font-weight: 700;
  letter-spacing: -.01em;
  color: var(--ss-number-color);
}

.ss-kpi span,
.ss-kpi p,
.ss-stat-label{
  margin: 0;
  font-size: 15px;
  line-height: 1.3;
  color: var(--ss-body-muted);
  text-align: center;
}

.ss-trust-points{
  display: grid;
  grid-template-columns: repeat(3,minmax(0,1fr));
  list-style: none;
  padding: 0;
  margin: 0;
  gap: 14px;
  justify-items: stretch;
}

.ss-trust-points li{
  width: 100%;
  max-width: none;
  padding: 0;
  margin: 0;
  background: var(--ss-inner-points-bg);
  border: 1px solid var(--ss-inner-surface-border);
  border-radius: var(--ss-inner-surface-radius);
  box-shadow: 0 4px 12px rgba(0,0,0,.03);
  overflow: hidden;
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease, background 160ms ease;
  font-weight: 600;
  color: var(--ss-title-color);
}

.ss-trust-points li > a,
.ss-trust-points li > .ss-trust-pill-btn,
.ss-trust-points li > .ss-trust-pill-static{
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 46px;
  margin: 0;
  padding: 14px 18px;
  background: transparent;
  border: 0;
  border-radius: inherit;
  box-shadow: none;
  text-decoration: none;
  color: inherit;
  font: inherit;
  font-size: 15px;
  font-weight: 600;
  line-height: 1.3;
  text-align: center;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
}

.ss-trust-pill-btn,
.ss-trust-pill-static{
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

.ss-trust-points li:hover,
.ss-trust-points li:focus-within{
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(0,0,0,.06);
  border-color: rgba(47,93,80,.16);
  background: rgba(255,255,255,.86);
}

.ss-trust-points li > a:hover,
.ss-trust-points li > .ss-trust-pill-btn:hover{
  text-decoration: none;
}

.ss-trust-points li > a:focus-visible,
.ss-trust-points li > .ss-trust-pill-btn:focus-visible{
  outline: 2px solid rgba(47,62,58,.35);
  outline-offset: -2px;
}

.ss-trust-visual{
  display: flex;
  align-items: center;
  justify-content: center;
}

.ss-trust-icon-wrap{
  width: 92px;
  height: 92px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.32);
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
}

.ss-trust-icon{
  width: 42px;
  height: 42px;
  color: var(--ss-accent);
}

/* =========================================================
   11. HOW IT WORKS / CIRCLE FEATURES
   ========================================================= */

.ss-how-shell{
  display: grid;
  gap: 18px;
}

.ss-how-shell > .ss-home-panel{
  width: 100%;
  max-width: none;
  margin: 0;
}

.ss-how-hero-panel,
.ss-how-steps-panel{
  overflow: hidden;
}

.ss-how-hero-panel.ss-hero-card{
  width: 100%;
  max-width: none;
  margin: 0;
}

.ss-how-hero-panel .ss-home-panel-copy{
  max-width: none;
  margin: 0 auto;
  text-align: center;
}

.ss-how-steps-panel .ss-home-panel-header{
  margin-bottom: 22px;
}

.ss-how-grid{
  display: grid;
  grid-template-columns: repeat(4,260px);
  gap: 20px;
  justify-content: center;
  align-items: stretch;
}

.ss-how-step{
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
  padding: 24px 18px 22px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 20px;
  background: rgba(255,255,255,.34);
  box-shadow: 0 4px 12px rgba(0,0,0,.03);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.ss-how-number{
  width: 38px;
  height: 38px;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 0 14px;
  font-weight: 700;
  font-size: 16px;
  line-height: 1;
  background: rgba(73,101,90,.10);
  color: #3f5c53;
}

.ss-how-title{
  margin: 0 0 12px;
  font-size: 18px;
  line-height: 1.35;
  color: #3f5c53;
}

.ss-how-desc{
  margin: 0;
  font-size: 15px;
  line-height: 1.65;
  color: #4f5f59;
  max-width: none;
}

.ss-circle-feature-section{
  padding: 8px 0 0;
  margin-top: 16px;
}

.ss-circle-feature-grid{
  display: grid;
  grid-template-columns: repeat(4,minmax(0,1fr));
  gap: 24px;
  align-items: start;
}

.ss-circle-feature{
  text-align: center;
}

.ss-circle-image-wrap{
  width: 150px;
  height: 150px;
  margin: 0 auto 14px;
  border-radius: 50%;
  overflow: hidden;
  border: 1px solid rgba(47,62,58,.10);
  box-shadow:
    0 8px 18px rgba(0,0,0,.06),
    0 2px 6px rgba(0,0,0,.04);
}

.ss-circle-image{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.ss-circle-title{
  margin: 0 0 8px;
  font-size: 24px;
  line-height: 1.2;
  color: var(--ss-title-color);
}

.ss-circle-text{
  margin: 0 auto;
  max-width: 260px;
  font-size: 15px;
  line-height: 1.6;
}

/* =========================================================
   12. AVAILABLE FOOD PAGE
   ========================================================= */

.ss-hero-filter-row{
  display: flex;
  justify-content: center;
  margin-top: 8px;
}

.ss-hero-filter-grid{
  display: grid;
  grid-template-columns: minmax(220px,320px) minmax(180px,220px) auto auto;
  gap: 12px;
  align-items: center;
  max-width: 760px;
  width: 100%;
}

.ss-hero-filter-grid .ss-input,
.ss-hero-filter-grid .ss-select{
  height: 52px;
  border-radius: 16px;
}

.ss-hero-filter-btn{
  min-height: 52px;
  padding: 0 20px;
  border-radius: 999px;
  white-space: nowrap;
}

.ss-available-panel .ss-home-panel-header--stack{
  text-align: center;
  margin-bottom: 22px;
}

.ss-available-panel .ss-home-panel-header--stack .ss-home-panel-copy{
  max-width: none;
  margin: 0 auto 8px !important;
}

.ss-available-panel .ss-home-panel-title{
  max-width: 920px;
  margin: 0 auto 4px !important;
  font-size: clamp(2.2rem,4vw,3rem);
  line-height: 1.08;
  letter-spacing: -.015em;
  text-wrap: balance;
  text-align: center;
}

.ss-available-panel .ss-title-sub{
  display: block;
  margin-top: 2px !important;
  margin-bottom: 0 !important;
  font-size: clamp(1.6rem,2.6vw,2.2rem);
  line-height: 1.15;
  font-weight: 600;
  opacity: .85;
}

.ss-available-panel .ss-home-panel-text{
  text-align: center;
  margin: 0 auto 16px !important;
  max-width: 680px;
  font-size: 1.05rem;
  line-height: 1.5;
}

.ss-available-panel .ss-hero-helper{
  max-width: 700px;
  margin: 0 auto 4px !important;
  font-size: .92rem;
  line-height: 1.5;
  opacity: .7;
}

.ss-available-panel .ss-hero-filter-row{
  display: flex;
  justify-content: center;
  margin-top: 0 !important;
}

.ss-available-panel .ss-search-summary{
  margin: 4px 0 16px;
  font-size: .95rem;
  color: var(--ss-body-muted);
}

.ss-available-panel .ss-hero-filter-grid{
  grid-template-columns: 180px 160px auto;
  max-width: 620px;
}

.ss-available-panel .ss-hero-filter-grid input[name="ss_zip"]{
  max-width: 180px;
  opacity: .9;
}

.ss-available-panel .ss-hero-filter-grid select{
  max-width: 160px;
}

.ss-available-panel .ss-hero-filter-grid .ss-input,
.ss-available-panel .ss-hero-filter-grid .ss-select{
  height: 54px;
  border-radius: 18px;
  background: rgba(255,255,255,.72);
}

.ss-available-panel .ss-hero-filter-btn{
  min-height: 54px;
  padding: 0 24px;
  background: rgba(255,255,255,.72);
}

.ss-available-panel .ss-hero-filter-grid .ss-btn--soft{
  grid-column: 1 / -1;
  justify-self: center;
  margin-top: 2px;
}

.ss-available-panel .ss-item{
  padding: 22px 22px 20px;
}

.ss-available-panel .ss-item-head{
  display: grid;
  grid-template-columns: minmax(0,1fr) 220px;
  gap: 18px;
  align-items: start;
  margin-bottom: 14px;
}

.ss-available-panel .ss-item-title{
  margin: 0 0 8px;
  font-size: 1.9rem;
  line-height: 1.1;
}

.ss-available-panel .ss-item-head-right{
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
  text-align: right;
}

.ss-available-panel .ss-item-head-right > *{
  margin: 0;
}

.ss-available-panel .ss-item-head-right .ss-mini{
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: .85rem;
  font-weight: 600;
  line-height: 1.2;
  background: var(--ss-posted-pill-bg);
  color: var(--ss-posted-pill-text);
  border: 1px solid var(--ss-posted-pill-border);
  white-space: nowrap;
  opacity: 1;
}

.ss-available-panel .ss-item-head-right .ss-mini::before{
  content: "Posted: ";
  opacity: .7;
  margin-right: 2px;
}

.ss-available-panel .ss-meta{
  display: grid;
  grid-template-columns: minmax(0,1fr);
  gap: 8px;
  font-size: 15px;
  line-height: 1.55;
}

.ss-available-panel .ss-meta strong{
  font-weight: 700;
}

.ss-available-panel .ss-claim-box{
  margin-top: 18px;
  padding-top: 16px;
}

.ss-available-panel .ss-form-wrap{
  border-radius: 20px;
}

.ss-available-panel .ss-form-wrap .ss-btn,
.ss-available-panel .ss-claim-box .ss-btn{
  min-height: 46px;
}

.ss-available-panel .ss-form-wrap small,
.ss-available-panel .ss-claim-box small,
.ss-available-panel .ss-form-wrap .ss-help,
.ss-available-panel .ss-claim-box .ss-help{
  opacity: .78;
  line-height: 1.45;
}

.ss-available-panel .ss-item .ss-pill{
  vertical-align: middle;
}

.ss-pagination{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-top: 20px;
  flex-wrap: wrap;
}

.ss-page-indicator{
  opacity: .8;
}

/* =========================================================
   13. PARTNER DESTINATIONS
   ========================================================= */

.ss-partner-destinations-panel .ss-home-panel-copy{
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

.ss-partner-destinations-panel .ss-title,
.ss-partner-destinations-panel .ss-home-panel-title{
  text-align: center;
}

.ss-partner-destinations-panel .ss-subtitle,
.ss-partner-destinations-panel .ss-home-panel-text,
.ss-partner-destinations-panel .ss-hero-helper{
  text-align: center;
  margin-left: auto;
  margin-right: auto;
  max-width: 720px;
}

.ss-partner-destinations-panel .ss-home-panel-header--stack{
  text-align: center;
  margin-bottom: 22px;
}

.ss-partner-destinations-panel .ss-home-panel-header--stack .ss-home-panel-copy{
  max-width: none;
  margin: 0 auto 8px !important;
}

.ss-partner-destinations-panel .ss-home-panel-title{
  max-width: 920px;
  margin: 0 auto 4px !important;
  font-size: clamp(2.2rem,4vw,3rem);
  line-height: 1.08;
  letter-spacing: -.015em;
  text-wrap: balance;
}

.ss-partner-destinations-panel .ss-title-sub{
  display: block;
  margin-top: 2px !important;
  margin-bottom: 0 !important;
  font-size: clamp(1.6rem,2.6vw,2.2rem);
  line-height: 1.15;
  font-weight: 600;
  opacity: .85;
}

.ss-partner-destinations-panel .ss-home-panel-text{
  margin: 0 auto 16px !important;
  max-width: 680px;
  font-size: 1.05rem;
  line-height: 1.5;
}

.ss-partner-destinations-panel .ss-hero-helper{
  max-width: 700px;
  margin: 0 auto 4px !important;
  font-size: .92rem;
  line-height: 1.5;
  opacity: .7;
}

.ss-partner-destinations-panel .ss-hero-filter-row{
  display: flex;
  justify-content: center;
  margin-top: 0 !important;
}

.ss-partner-destinations-panel .ss-actions{
  justify-content: center;
}




.ss-partner-destinations-panel .ss-hero-filter-grid{
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: center;
    gap: 12px;
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
}

.ss-partner-destinations-panel .ss-hero-filter-grid> * {
    flex: 0 0 auto;
    min-width: 0;
}

.ss-partner-destinations-panel .ss-hero-filter-gridinput[name="ss_zip"] {
    width: 120px;
}

.ss-partner-destinations-panel .ss-hero-filter-grid select[name="ss_radius"] {
    width: 150px;
}

.ss-partner-destinations-panel .ss-hero-filter-gridselect[name="ss_category"] {
    width: 200px;
}

.ss-partner-destinations-panel .ss-hero-filter-grid .ss-btn,
.ss-partner-destinations-panel .ss-hero-filter-grida.ss-btn {
    white-space: nowrap;
}

.ss-partner-destinations-panel .ss-hero-filter-grid input[type="hidden"] {
    display: none !important;
}






.ss-partner-destinations-panel .ss-hero-filter-grid .ss-input,
.ss-partner-destinations-panel .ss-hero-filter-grid .ss-select{
  height: 54px;
  border-radius: 18px;
  background: rgba(255,255,255,.72);
}

.ss-partner-destinations-panel input[name="ss_zip"]{
  min-width: 120px;
  max-width: 140px;
  opacity: .9;
}

.ss-partner-destinations-panel select[name="ss_radius"]{
  min-width: 150px;
  max-width: 160px;
}

.ss-partner-destinations-panel select[name="ss_category"]{
  min-width: 200px;
  max-width: 200px;
}

.ss-partner-destinations-panel .ss-hero-filter-btn{
  min-height: 54px;
  padding: 0 24px;
  background: rgba(255,255,255,.72);
  white-space: nowrap;
}

.ss-partner-destinations-panel .ss-hero-filter-grid .ss-btn--soft{
  grid-column: 1 / -1;
  justify-self: center;
  margin-top: 2px;
}

.ss-partner-destinations-panel .ss-search-summary,
.ss-partner-destinations-panel .ss-search-summary.ss-mini{
  margin: 4px 0 16px;
  font-size: .90rem;
  line-height: 1.5;
  color: var(--ss-body-muted);
  opacity: 1;
}

.ss-partner-destinations-panel .ss-item{
  padding: 22px 22px 20px;
}

.ss-partner-destinations-panel .ss-item-title,
.ss-partner-destinations-panel .ss-card-title,
.ss-partner-destinations-panel .ss-item h3{
  margin: 0 0 8px;
  font-size: 1.9rem;
  line-height: 1.1;
  color: var(--ss-title-color);
}

.ss-partner-destinations-panel .ss-item p,
.ss-partner-destinations-panel .ss-item .ss-mini,
.ss-partner-destinations-panel .ss-partner-location{
  color: var(--ss-body-muted);
}

.ss-partner-destinations-panel .ss-item p{
  margin: 0 0 6px;
}

.ss-partner-destinations-panel .ss-partner-badges,
.ss-partner-destinations-panel .ss-badges{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 10px 0 12px;
}

.ss-partner-destinations-panel .ss-pagination{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-top: 20px;
  flex-wrap: wrap;
}

.ss-partner-destinations-panel .ss-page-indicator{
  opacity: .8;
}

/* =========================================================
   14. HOMEPAGE — PHASE 3 PANELS
   ========================================================= */

.ss-phase3-panel .ss-home-panel-kicker{
  margin: 0 0 4px;
}

.ss-phase3-panel .ss-home-panel-title{
  margin: 0 0 4px !important;
  text-align: left;
  font-size: clamp(26px,3vw,34px);
  line-height: 1.12;
}

.ss-phase3-panel .ss-home-panel-text{
  margin: 0 0 10px !important;
  max-width: none;
  text-align: left;
  font-size: .95rem;
  line-height: 1.45;
}

.ss-phase3-header{
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
}

.ss-phase3-panel-actions{
  flex: 0 0 auto;
  margin-left: auto;
  margin-top: 4px;
}

.ss-recent-deliveries,
.ss-top-destinations{
  width: 100%;
  max-width: none;
  padding: 0;
}

.ss-phase3-panel--recent .ss-recent-deliveries,
.ss-phase3-panel--destinations .ss-top-destinations{
  margin-top: 15px;
}

.ss-recent-delivery-card{
  box-sizing: border-box;
  margin: 0 0 14px;
  padding: 12px 14px;
  background: var(--ss-inner-points-bg);
  border: 1px solid var(--ss-inner-surface-border);
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0,0,0,.03);
}

.ss-recent-deliveries > .ss-recent-delivery-card:last-child,
.ss-recent-deliveries-extra .ss-recent-delivery-card:last-child{
  margin-bottom: 0;
}

.ss-phase3-panel--recent .ss-item-head{
  display: block;
  margin: 0 0 2px;
  font-size: 1.05rem;
  line-height: 1.2;
  font-weight: 700;
  color: var(--ss-title-color);
}

.ss-phase3-panel--recent .ss-item-meta{
  display: inline-flex;
  align-items: center;
  margin: 0 0 6px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: .8rem;
  font-weight: 600;
  line-height: 1.2;
  background: var(--ss-posted-pill-bg);
  color: var(--ss-posted-pill-text);
  border: 1px solid var(--ss-posted-pill-border);
}

.ss-phase3-panel--recent .ss-item-meta::before{
  content: "Delivered: ";
  opacity: .7;
  margin-right: 2px;
}

.ss-phase3-panel--recent .ss-item-body{
  display: grid;
  gap: 2px;
  font-size: .9rem;
  line-height: 1.35;
  color: var(--ss-body-muted);
}

.ss-phase3-panel--recent .ss-item-body div{
  margin: 0;
}

.ss-phase3-panel--recent .ss-item-body strong{
  color: var(--ss-title-color);
  font-weight: 700;
}

.ss-recent-deliveries-extra{
  margin-top: 14px;
}

.ss-phase3-extra[hidden]{
  display: none !important;
}

.ss-phase3-extra{
  overflow: hidden;
}

.ss-phase3-extra.is-animating{
  transition: max-height 260ms ease, opacity 220ms ease;
}

.ss-top-destinations .ss-item{
  display: grid;
  grid-template-columns: minmax(0,1fr) auto;
  align-items: center;
  gap: 14px;
  box-sizing: border-box;
  margin: 0 0 14px;
  padding: 14px 16px;
  background: var(--ss-inner-points-bg);
  border: 1px solid var(--ss-inner-surface-border);
  border-radius: var(--ss-inner-surface-radius);
  box-shadow: 0 4px 12px rgba(0,0,0,.03);
}

.ss-top-destinations .ss-item:last-child{
  margin-bottom: 0;
}

.ss-top-destinations .ss-item-head{
  margin: 0;
  min-width: 0;
  font-size: 1.02rem;
  line-height: 1.3;
  font-weight: 700;
  color: var(--ss-title-color);
}

.ss-top-destinations .ss-item-meta{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  margin: 0;
  padding: 6px 12px;
  border-radius: 999px;
  background: var(--ss-pill-bg);
  color: var(--ss-pill-text);
  font-size: .85rem;
  font-weight: 700;
  line-height: 1.2;
}

.ss-phase3-panel .ss-empty{
  margin-top: 15px;
  padding: 18px 16px;
  text-align: center;
  color: var(--ss-body-muted);
  background: var(--ss-inner-points-bg);
  border: 1px dashed var(--ss-inner-surface-border);
  border-radius: var(--ss-inner-surface-radius);
  box-shadow: 0 4px 12px rgba(0,0,0,.03);
}

/* =========================================================
   15. FOOTER NAV
   ========================================================= */

.ss-footer-links{
  display: flex;
  flex-wrap: wrap;
  gap: 14px 18px;
}

.ss-footer-links a{
  white-space: nowrap;
}

/* =========================================================
   16. ANIMATIONS
   ========================================================= */

@keyframes ss-spin{
  to{ transform: rotate(360deg); }
}

@keyframes ss-success-pop{
  0%{ transform: scale(.96); opacity: 0; }
  100%{ transform: scale(1); opacity: 1; }
}

/* =========================================================
   17. RESPONSIVE
   ========================================================= */

@media (max-width: 1100px){
  .ss-kpis{
    grid-template-columns: repeat(2,200px);
  }

  .ss-stats-grid{
    grid-template-columns: repeat(2,200px);
  }

  .ss-how-grid{
    grid-template-columns: repeat(2,260px);
  }

  .ss-circle-feature-grid{
    grid-template-columns: repeat(2,minmax(0,1fr));
  }

  .ss-trust-points{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px){
  .ss-hero-filter-grid{
    grid-template-columns: 1fr 1fr;
  }

  .ss-hero-filter-btn{
    grid-column: 1 / -1;
    width: 100%;
  }

  .ss-available-panel .ss-home-panel-title{
    max-width: 100%;
  }

  .ss-available-panel .ss-hero-filter-grid{
    grid-template-columns: 1fr 1fr;
  }

  .ss-available-panel .ss-hero-filter-btn{
    grid-column: 1 / -1;
    width: 100%;
  }

  .ss-available-panel .ss-item-head{
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .ss-available-panel .ss-item-head-right{
    align-items: flex-start;
    text-align: left;
  }

  .ss-partner-destinations-panel .ss-hero-filter-grid{
    grid-template-columns: 1fr 1fr;
    max-width: 620px;
  }

  .ss-partner-destinations-panel .ss-hero-filter-btn{
    grid-column: 1 / -1;
    width: 100%;
  }

  .ss-partner-destinations-panel input[name="ss_zip"],
  .ss-partner-destinations-panel select[name="ss_radius"],
  .ss-partner-destinations-panel select[name="ss_category"]{
    max-width: none;
  }
}

@media (max-width: 820px){
  .ss-home-panel-header--split,
  .ss-home-panel-header--trust,
  .ss-row,
  .ss-row-3,
  .ss-grid-2{
    display: grid;
    grid-template-columns: 1fr;
  }

  .ss-home-panel-header--split{
    gap: 14px;
  }

  .ss-panel-filter{
    margin-left: 0;
    width: 100%;
  }

  .ss-panel-filter-input{
    width: 100%;
  }

  .ss-item-head{
    flex-direction: column;
  }

  .ss-phase3-header{
    flex-direction: column;
    align-items: stretch;
  }

  .ss-phase3-panel-actions{
    margin-left: 0;
    margin-top: 0;
  }

  .ss-top-destinations .ss-item{
    grid-template-columns: 1fr;
    align-items: start;
  }
}

@media (max-width: 640px){
  .ss-shell:first-of-type{
    margin-top: 18px;
  }

  .ss-shell + .ss-shell,
  .ss-shell > .ss-home-panel + .ss-home-panel{
    margin-top: var(--ss-shell-stack-gap-mobile);
  }

  .ss-homepage-shell > .ss-home-panel + .ss-home-panel{
    margin-top: var(--ss-home-gap);
  }

  .ss-home-panel-inner,
  .ss-hero-card .ss-home-panel-inner{
    padding: var(--ss-home-mobile-pad-y) var(--ss-home-mobile-pad-x);
  }

  .ss-page-panel .ss-home-panel-inner{
    padding: var(--ss-page-panel-pad-y-mobile) var(--ss-page-panel-pad-x-mobile);
  }

  .ss-shell .ss-card,
  .ss-card,
  .ss-shell .ss-form-wrap,
  .ss-form-wrap{
    padding: var(--ss-card-pad-mobile);
  }

  .ss-title,
  .ss-home-panel-title{
    font-size: clamp(26px,8vw,36px);
  }

  .ss-subtitle,
  .ss-home-panel-text{
    font-size: 16px;
  }

  .ss-kpis,
  .ss-stats-grid{
    grid-template-columns: 200px;
    gap: 14px;
  }

  .ss-how-grid{
    grid-template-columns: 260px;
  }

  .ss-circle-feature-grid{
    grid-template-columns: 1fr;
  }

  .ss-circle-image-wrap{
    width: 132px;
    height: 132px;
  }

  .ss-hero-filter-grid{
    grid-template-columns: 1fr;
  }

  .ss-available-panel .ss-home-panel-header--stack{
    text-align: left;
  }

  .ss-available-panel .ss-home-panel-title,
  .ss-available-panel .ss-hero-helper,
  .ss-available-panel .ss-home-panel-text{
    margin-left: 0;
    margin-right: 0;
    max-width: none;
    text-align: left;
  }

  .ss-available-panel .ss-hero-filter-row{
    justify-content: stretch;
    margin-top: 14px;
  }

  .ss-available-panel .ss-hero-filter-grid{
    grid-template-columns: 1fr;
    max-width: none;
  }

  .ss-available-panel .ss-hero-filter-grid input[name="ss_zip"],
  .ss-available-panel .ss-hero-filter-grid select{
    max-width: none;
  }

  .ss-available-panel .ss-item{
    padding: 18px;
  }

  .ss-available-panel .ss-item-title{
    font-size: 1.55rem;
  }

  .ss-available-panel .ss-item-head-right{
    align-items: flex-start;
    text-align: left;
  }

  .ss-available-panel .ss-item-head-right .ss-mini{
    white-space: normal;
  }

  .ss-partner-destinations-panel .ss-home-panel-header--stack{
    text-align: left;
  }

  .ss-partner-destinations-panel .ss-home-panel-title,
  .ss-partner-destinations-panel .ss-title,
  .ss-partner-destinations-panel .ss-home-panel-text,
  .ss-partner-destinations-panel .ss-subtitle,
  .ss-partner-destinations-panel .ss-hero-helper{
    text-align: left;
    margin-left: 0;
    margin-right: 0;
    max-width: none;
  }

  .ss-partner-destinations-panel .ss-hero-filter-row{
    justify-content: stretch;
    margin-top: 14px;
  }

  .ss-partner-destinations-panel .ss-hero-filter-grid{
    grid-template-columns: 1fr;
    max-width: none;
  }

  .ss-partner-destinations-panel .ss-hero-filter-grid .ss-input,
  .ss-partner-destinations-panel .ss-hero-filter-grid .ss-select,
  .ss-partner-destinations-panel .ss-hero-filter-btn{
    width: 100%;
    max-width: none;
  }

  .ss-partner-destinations-panel .ss-item{
    padding: 18px;
  }

  .ss-partner-destinations-panel .ss-item-title,
  .ss-partner-destinations-panel .ss-card-title,
  .ss-partner-destinations-panel .ss-item h3{
    font-size: 1.55rem;
  }
}

@media (max-width: 480px){
  .ss-homepage-actions{
    flex-direction: column;
    gap: 10px;
  }

  .ss-btn{
    width: 100%;
    max-width: 280px;
  }
}
/* =========================================================
   STATS PANELS — HOMEPAGE + MY PICKUPS
   Drop-in cleanup
========================================================= */

/* shared stats spacing */
.ss-stats-grid--homepage,
.ss-stats-grid--my-pickups {
    display: grid;
    gap: 14px;
    align-items: stretch;
}

/* =========================================================
   HOMEPAGE SNAPSHOT
========================================================= */

.ss-home-stats-panel {
    text-align: center;
}

.ss-home-stats-panel .ss-stats-inner-panel {
    max-width: 920px;
    margin: 0 auto;
}

.ss-stats-grid--homepage {
    grid-template-columns: repeat(3, minmax(180px, 1fr));
    max-width: 760px;
    margin: 28px auto 0;
}

/* lighter inner panels added here */
.ss-home-stats-panel .ss-stat-card {
    background: rgba(255,255,255,0.52);
    border: 1px solid rgba(70, 86, 75, 0.10);
    box-shadow: 0 10px 24px rgba(36, 48, 41, 0.05);
    border-radius: 18px;
    padding: 22px 16px 20px;
    min-height: 122px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
}

.ss-home-stats-panel .ss-stat-number {
    font-size: clamp(2.2rem, 3vw, 3rem);
    line-height: 1;
    font-weight: 700;
    margin: 0 0 10px;
    color: #587a41;
}

.ss-home-stats-panel .ss-stat-label {
    font-size: 1rem;
    line-height: 1.35;
    color: #4f5f58;
    margin: 0;
}

/* =========================================================
   MY PICKUPS STATS ROW
========================================================= */

.ss-stats-grid--my-pickups {
    grid-template-columns: repeat(3, minmax(180px, 1fr));
    max-width: 760px;
    margin: 26px auto 10px;
}

.ss-my-pickups-panel .ss-stat-card {
    background: rgba(255,255,255,0.55);
    border: 1px solid rgba(70, 86, 75, 0.10);
    box-shadow: 0 10px 24px rgba(36, 48, 41, 0.06);
    border-radius: 18px;
    padding: 26px 18px 22px;
    min-height: 134px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
}

.ss-my-pickups-panel .ss-stat-number {
    font-size: clamp(2.1rem, 3.2vw, 3.1rem);
    line-height: 1;
    font-weight: 700;
    margin: 0 0 10px;
    color: #587a41;
}

.ss-my-pickups-panel .ss-stat-label {
    font-size: 1.02rem;
    line-height: 1.35;
    color: #52625a;
    margin: 0;
}

/* keep pickup search/buttons from crowding stats */
.ss-my-pickups-panel .ss-my-pickups-actions {
    justify-content: flex-start;
    gap: 12px;
    margin-top: 10px;
    margin-bottom: 6px;
}

/* section title spacing after stats */
.ss-my-pickups-panel .ss-my-pickups-section--active,
.ss-my-pickups-panel .ss-my-pickups-section--completed {
    margin-top: 20px;
}

/* =========================================================
   TABLET
========================================================= */

@media (max-width: 900px) {
    .ss-stats-grid--homepage,
    .ss-stats-grid--my-pickups {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 12px;
    }

    .ss-home-stats-panel .ss-stat-card {
        min-height: 114px;
        padding: 20px 14px 18px;
    }

    .ss-my-pickups-panel .ss-stat-card {
        min-height: 122px;
        padding: 22px 14px 18px;
    }
}

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

@media (max-width: 640px) {
    .ss-stats-grid--homepage,
    .ss-stats-grid--my-pickups {
        grid-template-columns: 1fr;
        max-width: 360px;
        margin-left: auto;
        margin-right: auto;
    }

    .ss-home-stats-panel .ss-stat-card,
    .ss-my-pickups-panel .ss-stat-card {
        min-height: auto;
    }

    .ss-home-stats-panel .ss-stat-number,
    .ss-my-pickups-panel .ss-stat-number {
        font-size: 2.2rem;
    }

    .ss-my-pickups-panel .ss-my-pickups-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .ss-my-pickups-panel .ss-my-pickups-actions .ss-btn,
    .ss-my-pickups-panel .ss-my-pickups-actions a.ss-btn {
        width: 100%;
        justify-content: center;
    }
}

/* =========================================================
   CONTROL SIZE OVERRIDES
   Force all major page filters/forms to match My Pickups
========================================================= */

/* ---------- MY PICKUPS REFERENCE SIZE ---------- */
.ss-my-pickups-panel .ss-input,
.ss-my-pickups-panel .ss-select,
.ss-my-pickups-panel .ss-btn,
.ss-my-pickups-panel a.ss-btn {
    height: 44px !important;
    min-height: 44px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    border-radius: 12px !important;
    font-size: 0.95rem !important;
}

/* keep pill buttons pill-shaped */
.ss-my-pickups-panel .ss-btn,
.ss-my-pickups-panel a.ss-btn {
    border-radius: 999px !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
}

/* ---------- AVAILABLE FOOD ---------- */
.ss-available-panel .ss-input,
.ss-available-panel .ss-select,
.ss-available-panel .ss-btn,
.ss-available-panel a.ss-btn,
.ss-available-panel .ss-panel-filter-input,
.ss-available-panel .ss-panel-filter-select,
.ss-available-panel .ss-hero-filter-btn {
    height: 44px !important;
    min-height: 44px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    font-size: 0.95rem !important;
}

.ss-available-panel .ss-input,
.ss-available-panel .ss-select,
.ss-available-panel .ss-panel-filter-input,
.ss-available-panel .ss-panel-filter-select {
    padding-left: 14px !important;
    padding-right: 14px !important;
    border-radius: 12px !important;
}

.ss-available-panel .ss-btn,
.ss-available-panel a.ss-btn,
.ss-available-panel .ss-hero-filter-btn {
    padding-left: 20px !important;
    padding-right: 20px !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* ---------- PARTNER DESTINATIONS ---------- */
.ss-partner-destinations-panel .ss-input,
.ss-partner-destinations-panel .ss-select,
.ss-partner-destinations-panel .ss-btn,
.ss-partner-destinations-panel a.ss-btn,
.ss-partner-destinations-panel .ss-panel-filter-input,
.ss-partner-destinations-panel .ss-panel-filter-select,
.ss-partner-destinations-panel .ss-hero-filter-btn {
    height: 44px !important;
    min-height: 44px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    font-size: 0.95rem !important;
}

.ss-partner-destinations-panel .ss-input,
.ss-partner-destinations-panel .ss-select,
.ss-partner-destinations-panel .ss-panel-filter-input,
.ss-partner-destinations-panel .ss-panel-filter-select {
    padding-left: 14px !important;
    padding-right: 14px !important;
    border-radius: 12px !important;
}

.ss-partner-destinations-panel .ss-btn,
.ss-partner-destinations-panel a.ss-btn,
.ss-partner-destinations-panel .ss-hero-filter-btn {
    padding-left: 20px !important;
    padding-right: 20px !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* ---------- HOMEPAGE HERO BUTTONS ---------- */
.ss-homepage-hero-panel .ss-btn,
.ss-homepage-hero-panel a.ss-btn {
    height: 44px !important;
    min-height: 44px !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
    border-radius: 999px !important;
    font-size: 0.95rem !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* ---------- SHOW MORE BUTTON ---------- */
.ss-recent-deliveries-panel .ss-btn,
.ss-recent-deliveries-panel a.ss-btn,
.ss-recent-deliveries-panel .ss-show-more,
.ss-recent-deliveries-panel .ss-btn-show-more {
    height: 40px !important;
    min-height: 40px !important;
    padding-left: 18px !important;
    padding-right: 18px !important;
    border-radius: 999px !important;
    font-size: 0.9rem !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.ss-recent-deliveries-panel .ss-btn:hover,
.ss-recent-deliveries-panel a.ss-btn:hover,
.ss-recent-deliveries-panel .ss-show-more:hover,
.ss-recent-deliveries-panel .ss-btn-show-more:hover {
    background: #4f6f43 !important;
    transform: translateY(-1px);
}


/* =========================================================
   HOMEPAGE HERO BUTTONS — FORCE SMALLER SIZE
========================================================= */

.ss-homepage-actions {
    gap: 12px !important;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
}

.ss-homepage-actions .ss-btn,
.ss-homepage-actions a.ss-btn,
.ss-homepage-hero-panel .ss-homepage-actions .ss-btn,
.ss-homepage-hero-panel .ss-homepage-actions a.ss-btn {
    height: 44px !important;
    min-height: 44px !important;
    padding: 0 20px !important;
    font-size: 0.95rem !important;
    line-height: 1 !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
}

/* keep the button label centered */
.ss-homepage-actions .ss-btn-label,
.ss-homepage-hero-panel .ss-homepage-actions .ss-btn-label {
    display: inline-flex !important;
    align-items: center !important;
    line-height: 1 !important;
}

/* keep spinner from stretching button height */
.ss-homepage-actions .ss-btn-spinner,
.ss-homepage-hero-panel .ss-homepage-actions .ss-btn-spinner {
    width: 14px !important;
    height: 14px !important;
    flex: 0 0 14px !important;
}

/* optional: slightly smaller ghost button padding if needed */
.ss-homepage-actions .ss-btn--ghost {
    padding-left: 18px !important;
    padding-right: 18px !important;
}


/* =========================================================
   SHOW MORE BUTTON — REAL HOVER FIX
========================================================= */

.ss-phase3-panel--recent .ss-phase3-toggle,
.ss-phase3-panel--recent .ss-phase3-toggle:link,
.ss-phase3-panel--recent .ss-phase3-toggle:visited {
    background: rgba(255,255,255,.50) !important;
    color: #3f5c53 !important;
    border: 1px solid rgba(0,0,0,.10) !important;
}

.ss-phase3-panel--recent .ss-phase3-toggle:hover,
.ss-phase3-panel--recent .ss-phase3-toggle:focus,
.ss-phase3-panel--recent .ss-phase3-toggle:active {
    background: #4f6f43 !important;
    color: #ffffff !important;
    border-color: #4f6f43 !important;
    box-shadow: 0 6px 14px rgba(0,0,0,.08) !important;
    transform: translateY(-1px) !important;
    text-decoration: none !important;
}

.ss-phase3-panel--recent .ss-phase3-toggle:hover .ss-btn-label,
.ss-phase3-panel--recent .ss-phase3-toggle:focus .ss-btn-label,
.ss-phase3-panel--recent .ss-phase3-toggle:active .ss-btn-label {
    color: #ffffff !important;
}

/* =========================================================
   PARTNER SIGNUP — MATCH DONATION FORM
======================================================= */

.ss-partner-signup-wrap {
    max-width: 1280px;
    margin: 0 auto;
}

.ss-partner-signup-panel {
    position: relative;
}

.ss-partner-signup-panel .ss-home-panel-inner {
    padding: 26px 28px 24px;
}

.ss-partner-signup-header {
    margin-bottom: 18px;
}

.ss-partner-signup-title {
    margin: 0 0 8px;
    font-size: clamp(2.1rem, 4.2vw, 2.9rem);
    line-height: 1.02;
    color: #3f5b50;
    letter-spacing: -0.02em;
}

.ss-partner-signup-intro {
    margin: 0;
    max-width: 920px;
    font-size: 1rem;
    line-height: 1.65;
    color: #465952;
}

.ss-partner-signup-note {
    margin: 0 0 18px;
}

/* uses your donation-form style rhythm */
.ss-partner-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px 14px;
}

.ss-partner-grid .ss-field--full {
    grid-column: 1 / -1;
}

.ss-partner-grid textarea.ss-input {
    min-height: 120px;
    resize: vertical;
}

.ss-partner-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 18px;
}

.ss-partner-submit {
    min-width: 228px;
}

.ss-partner-help {
    font-size: 0.95rem;
    color: #5c665f;
}

/* success pill alignment with the donation page */
.ss-partner-signup-panel .ss-note--success,
.ss-partner-signup-panel .ss-note--error {
    border-radius: 14px;
}

/* =========================================
   PARTICIPATION PILLS — FORCE SINGLE LAYER
========================================= */

.ss-pill-group {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px 14px;
    margin-top: 10px;
}

.ss-pill {
    display: inline-flex;
    margin: 0;
    padding: 0;
    background: transparent !important;
    box-shadow: none !important;
    border: 0 !important;
}

.ss-pill input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.ss-pill-label {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 18px;
    margin: 0;
    border-radius: 999px;
    border: 1px solid transparent;
    background: #eceee7;
    color: #243126;
    line-height: 1.1;
    cursor: pointer;
    box-shadow: none !important;
    transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}

.ss-pill:hover .ss-pill-label,
.ss-pill-label:hover {
    background: #e4efe6;
    border-color: #b7d8bf;
    color: #1f6a39;
}

.ss-pill input:checked + .ss-pill-label {
    background: #e4efe6 !important;
    border-color: #7fc596 !important;
    color: #1f6a39 !important;
    box-shadow: none !important;
}

.ss-pill input:focus + .ss-pill-label {
    outline: none;
    border-color: #7fc596;
}

.ss-pill::before,
.ss-pill::after,
.ss-pill-label::before,
.ss-pill-label::after {
    display: none !important;
    content: none !important;
}






/* =====================================================================================================================================================
   HOURS — DROPDOWN TIME BUILDER
===================================================================================================================================================== */

.ss-hours-grid {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 10px;
}

.ss-hours-row {
    display: grid;
    grid-template-columns: 120px 120px 250px 14px auto;
    align-items: center;
    gap: 15px;
    padding-left: 0;
}

.ss-day {
    font-weight: 600;
    color: rgba(0, 0, 0, 0.9);
    white-space: nowrap;
    margin-right: 10px;
}

.ss-hours-status {
    width: 110px;
    min-width: 110px;
    text-align: center;
    text-align-last: center;
    border-radius: 8px;
    padding: 6px 10px;
    font-weight: 500;
    justify-self: start;
    transition:
        background-color 0.2s ease,
        border-color 0.2s ease,
        color 0.2s ease,
        opacity 0.2s ease,
        box-shadow 0.2s ease;
    -webkit-appearance: none;
    appearance: none;
}

.ss-hours-timegroup {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 8px;
    transition: opacity 0.2s ease;
}

.ss-hours-part {
    text-align: center;
    text-align-last: center;
    border-radius: 8px;
    padding: 6px 10px;
    font-weight: 500;
    transition:
        background-color 0.2s ease,
        border-color 0.2s ease,
        color 0.2s ease,
        opacity 0.2s ease,
        box-shadow 0.2s ease;
    -webkit-appearance: none;
    appearance: none;
}

.ss-hours-hour {
    width: 72px;
    min-width: 72px;
}

.ss-hours-minute {
    width: 78px;
    min-width: 78px;
}

.ss-hours-ampm {
    width: 82px;
    min-width: 82px;
}

.ss-hours-sep {
    text-align: center;
    opacity: 0.6;
    transition: opacity 0.2s ease;
}

/* =========================================
   STATUS COLORS
========================================= */

/* CLOSED → soft yellow */
.ss-hours-row.is-closed .ss-hours-status {
    background: rgba(236, 190, 110, 0.18) !important;
    border-color: rgba(236, 190, 110, 0.35) !important;
    color: #8a6a2f !important;
    opacity: 1 !important;
    box-shadow: inset 0 0 0 1px rgba(236, 190, 110, 0.15);
}

/* OPEN → green */
.ss-hours-row:not(.is-closed) .ss-hours-status {
    background: rgba(139, 158, 120, 0.16) !important;
    border-color: rgba(139, 158, 120, 0.32) !important;
    color: #556b46 !important;
    opacity: 1 !important;
    box-shadow: inset 0 0 0 1px rgba(139, 158, 120, 0.15);
}

/* =========================================
   CLOSED STATE
========================================= */

.ss-hours-row.is-closed .ss-hours-timegroup,
.ss-hours-row.is-closed .ss-hours-sep {
    opacity: 0.6;
}

.ss-hours-row.is-closed .ss-hours-timegroup .ss-hours-part {
    opacity: 0.65;
    background: rgba(255, 255, 255, 0.78);
}

/* OPEN STATE */
.ss-hours-row:not(.is-closed) .ss-hours-timegroup,
.ss-hours-row:not(.is-closed) .ss-hours-sep,
.ss-hours-row:not(.is-closed) .ss-hours-timegroup .ss-hours-part {
    opacity: 1;
}

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

@media (max-width: 900px) {
    .ss-partner-grid {
        grid-template-columns: 1fr;
    }

    .ss-partner-signup-panel .ss-home-panel-inner {
        padding: 22px 20px 20px;
    }

    .ss-partner-signup-title {
        font-size: clamp(1.9rem, 8vw, 2.8rem);
    }

    .ss-partner-submit {
        min-width: 100%;
    }

    .ss-hours-row {
        grid-template-columns: 1fr;
        gap: 8px;
        padding-left: 0;
    }

    .ss-hours-timegroup {
        flex-wrap: wrap;
    }

    .ss-hours-status,
    .ss-hours-hour,
    .ss-hours-minute,
    .ss-hours-ampm {
        width: auto;
        min-width: 0;
    }
}










/* =========================================
   PARTNER DESTINATION ORG TYPE PILLS
========================================= */

.ss-partner-badges .ss-org-pill {
    display: inline-flex;
    align-items: center;
    vertical-align: middle; /* 👈 key fix */
    position: relative;
    top: -1.2px; /* or -2px depending on font rendering */
    gap: 4px;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
    line-height: 1;
    white-space: nowrap;
    background-color: rgba(0,0,0,.08) !important;
    color: rgba(0,0,0,.75) !important;
}
.ss-partner-badges {
    display: inline-flex;
    align-items: center;
    gap: 12px; /* 👈 space between "Community" and pill */
}
/* Food Pantry */
.ss-partner-badges .ss-org-pill.ss-org-type--food_pantry {
    background-color: rgba(46, 125, 50, 0.14) !important;
    color: #2e7d32 !important;
}

/* Community Meal Site */
.ss-partner-badges .ss-org-pill.ss-org-type--community_meal_site {
    background-color: rgba(255, 143, 0, 0.14) !important;
    color: #ef6c00 !important;
}

/* Shelter */
.ss-partner-badges .ss-org-pill.ss-org-type--shelter {
    background-color: rgba(21, 101, 192, 0.14) !important;
    color: #1565c0 !important;
}

/* School */
.ss-partner-badges .ss-org-pill.ss-org-type--school {
    background-color: rgba(0, 121, 107, 0.14) !important;
    color: #00796b !important;
}

/* Church / Faith Group */
.ss-partner-badges .ss-org-pill.ss-org-type--church_faith_group {
    background-color: rgba(123, 31, 162, 0.14) !important;
    color: #7b1fa2 !important;
}

/* Nonprofit */
.ss-partner-badges .ss-org-pill.ss-org-type--nonprofit {
    background-color: rgba(85, 139, 47, 0.14) !important;
    color: #558b2f !important;
}

/* Government Program */
.ss-partner-badges .ss-org-pill.ss-org-type--government_program {
    background-color: rgba(109, 76, 65, 0.14) !important;
    color: #6d4c41 !important;
}

/* Mutual Aid Group */
.ss-partner-badges .ss-org-pill.ss-org-type--mutual_aid_group {
    background-color: rgba(198, 40, 40, 0.14) !important;
    color: #c62828 !important;
}

/* Senior Center */
.ss-partner-badges .ss-org-pill.ss-org-type--senior_center {
    background-color: rgba(2, 119, 189, 0.14) !important;
    color: #0277bd !important;
}

/* Delivery Partner */
.ss-partner-badges .ss-org-pill.ss-org-type--delivery_partner {
    background-color: rgba(84, 110, 122, 0.14) !important;
    color: #546e7a !important;
}

/* Other */
.ss-partner-badges .ss-org-pill.ss-org-type--other {
    background-color: rgba(0,0,0,.08) !important;
    color: rgba(0,0,0,.75) !important;
}










/* =========================================
   PARTNER CARD — COMPLETE DROP-IN
========================================= */

/* -------------------------
   Header layout
------------------------- */
.ss-partner-card .ss-item-title {
    margin: 0;
}

.ss-partner-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 20px;
}

.ss-partner-head-left {
    flex: 1 1 auto;
    min-width: 0;
}

.ss-partner-badges {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 8px;
}

/* -------------------------
   Top-right pills
   STACKED like donation image
------------------------- */
/* =========================================
   PARTNER CARD — HEADER + TOP RIGHT PILLS
========================================= */

.ss-partner-card .ss-item-title {
    margin: 0;
}

.ss-partner-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 24px;
}

.ss-partner-head-left {
    flex: 1 1 auto;
    min-width: 0;
}

.ss-partner-badges {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 8px;
}

/* Dedicated right column */
.ss-partner-pills-wrap {
    flex: 0 0 240px;
    display: flex;
    justify-content: flex-end;
}

.ss-partner-pills {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-end !important;
    gap: 10px !important;
    width: 100%;
}

/* Hard isolated pill styles */
.ss-partner-pill {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    align-self: flex-end !important;
    min-height: 32px !important;
    padding: 6px 14px !important;
    border-radius: 999px !important;
    font-size: 13px !important;
    line-height: 1 !important;
    font-weight: 700 !important;
    white-space: nowrap !important;
    width: auto !important;
    max-width: 100% !important;
    border: 1px solid transparent !important;
    box-sizing: border-box !important;
}



/* Distance pill */
.ss-partner-pill--distance {
    background: rgba(92,127,79,.18) !important;
    border-color: rgba(118, 160, 122, 0.32) !important;
    color: #3f5f34 !important;
}

/* Since pill */
.ss-partner-pill--since {
    background: rgba(120,110,95,.08) !important;
    border-color: rgba(120,110,95,.12) !important;
    color: #6e6458 !important;
}

/* -------------------------
   Body spacing
------------------------- */
.ss-partner-card-body {
    padding-top: 12px;
}

.ss-partner-location {
    font-size: 16px !important;
    line-height: 1.45;
    color: rgba(0,0,0,.72);
}

.ss-partner-card-body .ss-mini.ss-partner-location {
    margin: -20px 0 20px 0 !important;
}

/* -------------------------
   Shared meta typography
------------------------- */
.ss-partner-card .ss-mini,
.ss-partner-card .ss-meta,
.ss-partner-card .ss-partner-meta {
    margin: 0;
    font-size: 15px;
    line-height: 1.55;
    color: rgba(0,0,0,.82);
}

.ss-partner-card .ss-mini + .ss-mini,
.ss-partner-card .ss-mini + p.ss-mini,
.ss-partner-card p.ss-mini + p.ss-mini,
.ss-partner-card .ss-hours-block + p.ss-mini,
.ss-partner-card p.ss-mini + .ss-hours-block {
    margin-top: 6px;
}

.ss-partner-card .ss-mini strong,
.ss-partner-card .ss-meta strong,
.ss-partner-card .ss-partner-meta strong {
    display: inline-block;
    min-width: 72px;
    margin-right: 2px;
    font-size: 15px;
    line-height: 1.55;
    font-weight: 700;
    color: rgba(29, 57, 46, .95);
    vertical-align: top;
}

.ss-partner-card .ss-mini span,
.ss-partner-card .ss-mini a,
.ss-partner-card .ss-meta span,
.ss-partner-card .ss-meta a,
.ss-partner-card .ss-partner-meta span,
.ss-partner-card .ss-partner-meta a {
    color: rgba(0,0,0,.78);
}

/* -------------------------
   Hours block
------------------------- */
.ss-hours-block {
    margin: 0 0 6px 0;
}

.ss-hours-block > strong {
    display: inline-block;
    min-width: 72px;
    margin-right: 2px;
    font-size: 15px;
    line-height: 1.55;
    font-weight: 700;
    color: rgba(29, 57, 46, .95);
    vertical-align: top;
}

.ss-hours-list {
    display: inline-block;
    vertical-align: top;
    margin: 0;
}

.ss-hours-line {
    font-size: 15px;
    line-height: 1.5;
    color: rgba(0,0,0,.78);
}

.ss-hours-line + .ss-hours-line {
    margin-top: 2px;
}

.ss-hours-line strong {
    display: inline-block;
    min-width: 72px;
    margin-right: 2px;
    font-size: 15px;
    line-height: 1.5;
    font-weight: 700;
    color: rgba(29, 57, 46, .95);
}

/* -------------------------
   Links
------------------------- */
a.ss-meta-link,
a.ss-meta-link:link,
a.ss-meta-link:visited,
a.ss-meta-link:hover,
a.ss-meta-link:active,
a.ss-meta-link:focus {
    color: inherit !important;
    text-decoration: none !important;
    border-bottom: none !important;
    box-shadow: none !important;
    background-image: none !important;
    -webkit-text-decoration: none !important;
}

a.ss-meta-link::before,
a.ss-meta-link::after {
    display: none !important;
    content: none !important;
}

/* -------------------------
   Mobile
------------------------- */
@media (max-width: 768px) {
    .ss-partner-head {
        flex-direction: column;
        align-items: flex-start;
        gap: 14px;
    }

    .ss-partner-pills-wrap {
        flex: 0 0 auto;
        width: 100%;
        justify-content: flex-start;
    }

    .ss-partner-pills {
        align-items: flex-start !important;
    }

    .ss-partner-pill {
        align-self: flex-start !important;
        min-height: 30px !important;
        font-size: 13px !important;
        padding: 6px 12px !important;
    }

    .ss-partner-card .ss-mini,
    .ss-hours-line,
    .ss-partner-location {
        font-size: 14px;
    }

    .ss-partner-card .ss-mini strong,
    .ss-hours-block > strong,
    .ss-hours-line strong {
        min-width: 68px;
        font-size: 14px;
    }
}

/* -------------------------
   Card body spacing
------------------------- */
.ss-partner-card-body {
    padding-top: 12px;
}

.ss-partner-location {
    font-size: 16px !important;
    line-height: 1.45;
    color: rgba(0,0,0,.72);
}

.ss-partner-card-body .ss-mini.ss-partner-location {
    margin: -20px 0 20px 0 !important;
}

/* -------------------------
   Shared meta typography
------------------------- */
.ss-partner-card .ss-mini,
.ss-partner-card .ss-meta,
.ss-partner-card .ss-partner-meta {
    margin: 0;
    font-size: 15px;
    line-height: 1.55;
    color: rgba(0,0,0,.82);
}

.ss-partner-card .ss-mini + .ss-mini,
.ss-partner-card .ss-mini + p.ss-mini,
.ss-partner-card p.ss-mini + p.ss-mini,
.ss-partner-card .ss-hours-block + p.ss-mini,
.ss-partner-card p.ss-mini + .ss-hours-block {
    margin-top: 6px;
}

/* Labels */
.ss-partner-card .ss-mini strong,
.ss-partner-card .ss-meta strong,
.ss-partner-card .ss-partner-meta strong {
    display: inline-block;
    min-width: 72px;
    margin-right: 2px;
    font-size: 15px;
    line-height: 1.55;
    font-weight: 700;
    color: rgba(29, 57, 46, .95);
    vertical-align: top;
}

/* Values */
.ss-partner-card .ss-mini span,
.ss-partner-card .ss-mini a,
.ss-partner-card .ss-meta span,
.ss-partner-card .ss-meta a,
.ss-partner-card .ss-partner-meta span,
.ss-partner-card .ss-partner-meta a {
    color: rgba(0,0,0,.78);
}

/* -------------------------
   Hours block
------------------------- */
.ss-hours-block {
    margin: 0 0 6px 0;
}

.ss-hours-block > strong {
    display: inline-block;
    min-width: 72px;
    margin-right: 2px;
    font-size: 15px;
    line-height: 1.55;
    font-weight: 700;
    color: rgba(29, 57, 46, .95);
    vertical-align: top;
}

.ss-hours-list {
    display: inline-block;
    vertical-align: top;
    margin: 0;
}

.ss-hours-line {
    font-size: 15px;
    line-height: 1.5;
    color: rgba(0,0,0,.78);
}

.ss-hours-line + .ss-hours-line {
    margin-top: 2px;
}

.ss-hours-line strong {
    display: inline-block;
    min-width: 72px;
    margin-right: 2px;
    font-size: 15px;
    line-height: 1.5;
    font-weight: 700;
    color: rgba(29, 57, 46, .95);
}

/* -------------------------
   Links inside meta rows
------------------------- */
a.ss-meta-link,
a.ss-meta-link:link,
a.ss-meta-link:visited,
a.ss-meta-link:hover,
a.ss-meta-link:active,
a.ss-meta-link:focus {
    color: inherit !important;
    text-decoration: none !important;
    border-bottom: none !important;
    box-shadow: none !important;
    background-image: none !important;
    -webkit-text-decoration: none !important;
}

a.ss-meta-link::before,
a.ss-meta-link::after {
    display: none !important;
    content: none !important;
}

/* -------------------------
   Mobile
------------------------- */
@media (max-width: 768px) {
    .ss-partner-head {
        flex-direction: column;
        align-items: flex-start;
        gap: 14px;
    }

    .ss-partner-pills {
        align-items: flex-start;
        margin-left: 0;
        min-width: 0;
    }

    .ss-pill {
        min-height: 30px;
        font-size: 13px;
        padding: 0 12px;
    }

    .ss-partner-card .ss-mini,
    .ss-hours-line,
    .ss-partner-location {
        font-size: 14px;
    }

    .ss-partner-card .ss-mini strong,
    .ss-hours-block > strong,
    .ss-hours-line strong {
        min-width: 68px;
        font-size: 14px;
    }
}
.ss-meta-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 6px 14px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 700;
    line-height: 1;
    white-space: nowrap;
}

.ss-meta-pill--since {
    background: rgba(120,110,95,.08);
    border: 1px solid rgba(120,110,95,.12);
    color: #6e6458;
}

.ss-item-head-right {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 8px;
}
/* =========================================
   META — CLEAN ALIGNED DROP-IN
========================================= */

.ss-meta--tight {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.ss-meta--tight .ss-meta-row {
    display: grid;
    grid-template-columns: 84px minmax(0, 1fr);
    column-gap: 0px;
    align-items: start;
    margin: 0;
}

.ss-meta--tight .ss-meta-row--location {
    grid-template-columns: 1fr;
        margin-top: -10px;
    margin-bottom: 10px;
}

.ss-meta--tight .ss-meta-label {
    font-weight: 700;
    color: #42574f;
    line-height: 1.35;
}

.ss-meta--tight .ss-meta-value {
    min-width: 0;
    color: rgba(0,0,0,.82);
    line-height: 1.35;
}

.ss-meta--tight .ss-location-des {
    font-size: 18px;
    font-weight: 500;
    line-height: 1.3;
    color: #50605c;
}

.ss-meta--tight .ss-meta-link {
    color: inherit;
    text-decoration: underline;
    text-underline-offset: 2px;
}

/* HOURS */
.ss-meta--tight .ss-hours-list {
    display: flex;
        font-weight: 500;
    flex-direction: column;
    gap: 4px;
    margin: 0;
    padding: 0;
}

.ss-meta--tight .ss-hours-list > div {
    display: grid;
    grid-template-columns: 72px minmax(0, 1fr);
    column-gap: 0px;
    align-items: start;
    margin: 0;
}

.ss-meta--tight .ss-hours-list strong,
.ss-meta--tight .ss-hours-list b {
    display: block;
    margin: 0;
    font-weight: 700;
    color: #50605c;
    line-height: 1.35;
}

.ss-meta--tight .ss-hours-list span,
.ss-meta--tight .ss-hours-list em,
.ss-meta--tight .ss-hours-list small {
    display: block;
    margin: 0;
    line-height: 1.35;
    font-style: normal;
    color: #50605c;
}
.ss-meta--tight .ss-meta-row--location {
         margin-top: 5px;
    display: grid;
    grid-template-columns: 84px minmax(0, 1fr);
    column-gap: 0px;
    align-items: start;
}

.ss-meta--tight .ss-meta-value--location,
.ss-meta--tight .ss-location-des {
     margin-top: 0px;
    font-size: 18px;
    font-weight: 500;
    line-height: 1;
    color: #50605c;
}

/* =========================================
   REMOVE PANEL (How It Works - Homepage)
========================================= */

.ss-home-features-panel {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
}

.ss-home-features-panel .ss-home-panel-inner {
    background: transparent !important;
    padding: 0 !important;
    border-radius: 0 !important;
}

/* Optional: tighten spacing now that panel is gone */
.ss-home-features-panel .ss-home-panel-body {
    padding-top: 10px;
}
.ss-location-filter {
    display: grid;
    grid-template-columns: minmax(160px, 180px) minmax(180px, 220px) auto;
    gap: 12px;
    align-items: end;
}

.ss-filter-item {
    min-width: 0;
}

.ss-filter-item--geo .ss-btn {
    width: 100%;
    min-height: 46px;
}

@media (max-width: 900px) {
    .ss-location-filter {
        grid-template-columns: 1fr;
    }

    .ss-filter-item--geo .ss-btn {
        width: 100%;
    }
}