/* ================================================================== */
/* FLASH SALE — flashsale.css — Doctor Vape (biały, 3 kolumny)       */
/* ================================================================== */

:root {
  --fsc-dark:   #2b2b2b;
  --fsc-green:  #1db954;
  --fsc-green2: #17a348;
  --fsc-g1:     #f5f5f5;
  --fsc-g2:     #e8e8e8;
  --fsc-g3:     #999;
  --fsc-g4:     #555;
}

/* ================================================================== */
/* ANIMOWANA RAMKA                                                     */
/* ================================================================== */

@property --fsc-angle {
  syntax: "<angle>";
  initial-value: 0deg;
  inherits: false;
}

@keyframes fsc-rotate {
  to { --fsc-angle: 360deg; }
}

.flashsale-outer {
  width: 100%;
  box-sizing: inherit;
  /* max-width: 1750px; */
  margin: 0 auto;
}

.flashsale-wrapper {
  position: relative;
  width: 100%;
  /* max-width: 1530px; */
  margin: 24px auto;
  padding: 2px;
  border-radius: 14px;
  animation: fsc-rotate 4s linear infinite;
  isolation: isolate;
  background: conic-gradient(
    from var(--fsc-angle),
    #e8e8e8, #2b2b2b, #e8e8e8, #fff, #2b2b2b, #e8e8e8
  );
  box-sizing: border-box;
}

.flashsale-wrapper--ended {
  animation: none;
  background: var(--fsc-g2);
  opacity: 0.85;
}

/* ================================================================== */
/* INNER                                                               */
/* ================================================================== */

.flashsale-inner {
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  position: relative;
  z-index: 1;
}

/* ================================================================== */
/* BADGE BAR — górny ciemny pasek                                     */
/* ================================================================== */

.flashsale-badge-bar {
  background: var(--fsc-dark);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 9px 24px;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
}

.flashsale-badge-bar__right {
  color: rgba(255, 255, 255, 0.4);
  font-weight: 600;
  letter-spacing: 1px;
}

/* ================================================================== */
/* TRZY KOLUMNY                                                        */
/* ================================================================== */

.flashsale-cols {
  display: grid;
  grid-template-columns: 260px 1fr 1fr;
  border-bottom: 1px solid var(--fsc-g2);
}

/* ------------------------------------------------------------------ */
/* KOL 1 — zdjęcie                                                    */
/* ------------------------------------------------------------------ */

.flashsale-img-side {
  /* background: var(--fsc-g1); */
  display: flex;
  flex-direction: column;
  align-items: stretch;
  border-right: 1px solid var(--fsc-g2);
  position: relative;
}

.flashsale-img-side__photo {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px 20px 12px;
}

.flashsale-card__image-link {
  display: block;
  text-align: center;
}

.flashsale-card__image {
  max-width: 160px;
  max-height: 160px;
  object-fit: contain;
  display: block;
  margin: 0 auto;
}

.flashsale-card__name-under {
  background: #fff;
  border-top: 1px solid var(--fsc-g2);
  font-size: 16px;
  font-weight: 600;
  color: var(--fsc-dark);
  padding: 10px 14px;
  line-height: 1.4;
  text-align: center;
  text-decoration: none;
  display: block;
}

.flashsale-card__name-under:hover { color: var(--fsc-green); }

/* Sold out */
.flashsale-soldout-overlay {
  position: absolute;
  inset: 0;
  background: rgba(245, 245, 245, 0.75);
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
}

.flashsale-soldout-badge svg {
  fill: #aaa;
  opacity: 0.35;
  width: 100px;
  height: 100px;
  transform: rotate(-20deg);
  display: block;
}

/* ------------------------------------------------------------------ */
/* KOL 2 — cena + stock + countdown + CTA                             */
/* ------------------------------------------------------------------ */

.flashsale-cta-side {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 28px;
  gap: 18px;
  border-right: 1px solid var(--fsc-g2);
}

.flashsale-card__price-30days {
  font-size: 13px;
  color: var(--fsc-g3);
  margin-bottom: 4px;
}

.flashsale-card__price-row {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.flashsale-card__price-promo {
  font-size: 36px;
  font-weight: 700;
  color: var(--fsc-green);
  line-height: 1;
}

.flashsale-card__savings {
  display: inline-block;
  background: var(--fsc-green);
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 20px;
  white-space: nowrap;
}

.flashsale-card__stock { display: flex; flex-direction: column; gap: 5px; }

.flashsale-stock-labels {
  display: flex;
  justify-content: space-between;
  font-size: 14px;
  font-weight: 600;
}

.flashsale-stock-labels__remaining { color: var(--fsc-dark); }
.flashsale-stock-labels__sold      { color: var(--fsc-g3); }

.flashsale-stock-bar {
  width: 100%;
  height: 12px;
  background: var(--fsc-g2);
  border-radius: 12px;
  overflow: hidden;
}

.flashsale-stock-bar__fill {
  height: 100%;
  background: var(--fsc-green);
  border-radius: 3px;
  min-width: 4px;
  transition: width 0.4s ease;
}

/* Countdown */

.flashsale-cd-wrap { display: flex; flex-direction: column; gap: 6px; }

.flashsale-countdown__label {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--fsc-g3);
  text-align: center;
}

.flashsale-countdown {display: flex;/* align-items: center; */justify-content: center;gap: 16px;}

.flashsale-countdown__unit {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}

.flashsale-countdown__value {
  font-size: 32px;
  font-weight: 700;
  color: var(--fsc-dark);
  font-variant-numeric: tabular-nums;
  padding: 6px 8px;
  border-radius: 6px;
  background: var(--fsc-g1);
  border: 1.5px solid var(--fsc-g2);
  min-width: 42px;
  text-align: center;
  line-height: 1;
  display: inline-block;
}

.flashsale-countdown__unit .flashsale-countdown__label {
  font-size: 9px;
  letter-spacing: 0.5px;
  text-transform: lowercase;
  margin: 0;
}

.flashsale-countdown__sep {
  font-size: 18px;
  font-weight: 700;
  color: var(--fsc-g3);
  padding-top: 6px;
  line-height: 1;
}

/* CTA */

.flashsale-card__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--fsc-dark);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-size: 18px;
  font-weight: 700;
  padding: 13px 20px;
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: 1px;
  width: 100%;
  transition: background 0.2s;
}

.flashsale-card__btn:hover    { background: #444; color: #fff; }
.flashsale-card__btn:disabled,
.flashsale-card__btn--loading { opacity: 0.6; pointer-events: none; }

.flashsale-card__ended-msg {
  font-size: 16px;
  font-weight: 700;
  color: var(--fsc-g3);
  text-align: center;
  padding: 12px 0;
}

/* ------------------------------------------------------------------ */
/* KOL 3 — benefity                                                   */
/* ------------------------------------------------------------------ */

.flashsale-benefits-col {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 28px 24px;
}

.flashsale-benefit {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 0;
  border-bottom: 1px solid var(--fsc-g2);
}

.flashsale-benefit:first-child { border-top: 1px solid var(--fsc-g2); }

.flashsale-marketing__icon {
  flex-shrink: 0;
  width: 34px;
  height: 34px;
  border-radius: 8px;
  background: var(--fsc-g1);
  border: 1px solid var(--fsc-g2);
  display: flex;
  align-items: center;
  justify-content: center;
}

.flashsale-marketing__icon svg { stroke: var(--fsc-dark); display: block; }

.flashsale-benefit__body strong {
  display: block;
  font-size: 18px;
  font-weight: 700;
  color: var(--fsc-dark);
  margin-bottom: 2px;
}

.flashsale-benefit__body p {
  font-size: 14px;
  color: var(--fsc-g3);
  margin: 0;
  line-height: 1.5;
}

/* ================================================================== */
/* URGENCY STRIP                                                       */
/* ================================================================== */

.flashsale-urgency-strip {
  background: var(--fsc-g1);
  border-top: 1px solid var(--fsc-g2);
  text-align: center;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 9px 16px;
  color: var(--fsc-g4);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.flashsale-urgency-strip strong { color: var(--fsc-dark); }

/* ================================================================== */
/* BADGE NA STRONIE PRODUKTU                                          */
/* ================================================================== */

.fsc-product-info {
  border: 2px solid var(--fsc-dark);
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 12px;
  background: var(--fsc-g1);
  width: 100%;
}

.fsc-product-info__header {
  background: var(--fsc-dark);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  padding: 9px 14px;
  display: flex;
  align-items: center;
  gap: 6px;
}

.fsc-product-info__stock-row {
  display: flex;
  justify-content: space-between;
  padding: 8px 14px 4px;
  font-size: 13px;
  font-weight: 600;
}

.fsc-product-info__stock-row .fsc-remaining { color: var(--fsc-green); }
.fsc-product-info__stock-row .fsc-sold      { color: var(--fsc-g3); }

.fsc-product-info__bar {
  height: 6px;
  background: var(--fsc-g2);
  margin: 2px 14px 10px;
  border-radius: 3px;
  overflow: hidden;
}

.fsc-product-info__bar-fill {
  height: 100%;
  background: var(--fsc-green);
  border-radius: 3px;
  min-width: 4px;
}

.fsc-product-info__countdown-wrap {
  border-top: 1px solid var(--fsc-g2);
  padding: 10px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
}

.fsc-product-info__countdown-label {
  font-size: 11px;
  color: var(--fsc-g3);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 700;
}

.fsc-product-info__countdown { display: flex; align-items: flex-start; gap: 4px; }

.fsc-cd-unit { display: flex; flex-direction: column; align-items: center; }

.fsc-cd-unit span {
  color: var(--fsc-dark);
  font-size: 18px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  padding: 5px 8px;
  border-radius: 5px;
  min-width: 38px;
  text-align: center;
  line-height: 1;
  border: 1.5px solid var(--fsc-g2);
  background: #fff;
  display: inline-block;
}

.fsc-cd-unit small { font-size: 9px; color: var(--fsc-g3); margin-top: 3px; text-transform: lowercase; }

.fsc-cd-sep { font-size: 18px; font-weight: 700; color: var(--fsc-g3); padding-top: 5px; line-height: 1; }

/* ================================================================== */
/* ADMIN                                                               */
/* ================================================================== */

.flashsale-admin .panel { margin-bottom: 20px; }
.flashsale-admin .form-wrapper { padding: 10px 20px; }

.flashsale-admin .form-group { display: flex; align-items: flex-start; margin-bottom: 16px; width: 100%; }
.flashsale-admin .form-group .control-label { width: 260px; min-width: 260px; padding-top: 7px; font-weight: 600; font-size: 13px; color: #555; }
.flashsale-admin .form-group .control-label.required::before { content: '* '; color: var(--fsc-green); }
.flashsale-admin .form-group > div { flex: 1; position: relative; }
.flashsale-admin .form-group .form-control { width: 100%; max-width: 400px; }
.flashsale-admin .form-group .input-group { max-width: 200px; }
.flashsale-admin .form-group .input-group .form-control { max-width: 100%; }

.flashsale-admin .panel-footer { display: flex; align-items: center; gap: 10px; padding: 12px 20px; background: #f9f9f9; border-top: 1px solid #eee; flex-direction: row-reverse; }

#product-search-results { position: absolute; top: 100%; left: 0; z-index: 9999; background: #fff; border: 1px solid #ddd; border-radius: 4px; box-shadow: 0 4px 16px rgba(0,0,0,0.10); list-style: none; margin: 2px 0 0; padding: 0; max-height: 280px; overflow-y: auto; min-width: 400px; max-width: 600px; }
#product-search-results li { padding: 9px 14px; cursor: pointer; font-size: 13px; border-bottom: 1px solid #f5f5f5; display: flex; flex-direction: column; gap: 2px; }
#product-search-results li:hover, #product-search-results li.active { background: var(--fsc-g1); }
#product-search-results li small { color: #aaa; font-size: 11px; }
#product-search-results li.no-results { color: #aaa; font-style: italic; cursor: default; }
#product-search.product-selected { border-color: var(--fsc-green); background: #f0fff4; }
.fsa-product-name { font-weight: 600; color: #333; }
#product-search-results li:hover .fsa-product-name { color: var(--fsc-dark); }

.flashsale-discount-btns { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 8px; }
.fsa-discount-btn { font-size: 12px; padding: 4px 12px; border-radius: 20px; background: var(--fsc-g1); border: 1px solid var(--fsc-g2); color: #555; cursor: pointer; transition: all 0.15s; }
.fsa-discount-btn:hover:not(:disabled) { background: #f0fff4; border-color: var(--fsc-green); color: var(--fsc-green2); }
.fsa-discount-btn.active { background: var(--fsc-dark); border-color: var(--fsc-dark); color: #fff; font-weight: 600; }
.fsa-discount-btn:disabled { opacity: 0.4; cursor: not-allowed; }

.flashsale-custom-price { margin-top: 8px; display: flex; align-items: center; gap: 8px; }
#savings-preview { margin-top: 5px; font-size: 12px; font-weight: 600; }

.flashsale-duration-btns { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 6px; }
.flashsale-duration-btns .btn { font-size: 11px; padding: 3px 10px; border-radius: 20px; background: var(--fsc-g1); border: 1px solid var(--fsc-dark); color: var(--fsc-dark); }
.flashsale-duration-btns .btn:hover { background: var(--fsc-dark); color: #fff; }

.flashsale-table th { background: #f5f5f5; font-weight: 600; }
.flashsale-table .badge-success { background: var(--fsc-green); }
.flashsale-table .badge-info { background: #17a2b8; }
.flashsale-table .badge-default { background: #aaa; }
.flashsale-actions { white-space: nowrap; }
.flashsale-progress-mini { width: 80px; height: 5px; background: var(--fsc-g2); border-radius: 3px; overflow: hidden; margin-bottom: 3px; }
.flashsale-progress-bar-mini { height: 100%; background: var(--fsc-dark); border-radius: 3px; min-width: 2px; }

/* ================================================================== */
/* ADMIN STATS                                                         */
/* ================================================================== */

.fss-wrap { font-family: 'Open Sans', Arial, sans-serif; padding: 0 0 40px; max-width: 100%; }
.fss-tabs { list-style: none; display: flex; gap: 0; margin: 0 0 24px; padding: 0; border-bottom: 3px solid var(--fsc-dark); }
.fss-tabs li { margin-bottom: -3px; }
.fss-tabs li a { display: block; padding: 10px 24px; color: #777; font-weight: 600; font-size: 13px; text-decoration: none; background: #f8f8f8; border: 1px solid #ddd; border-bottom: none; border-radius: 4px 4px 0 0; transition: all 0.15s; }
.fss-tabs li a:hover { color: var(--fsc-dark); background: #fff; }
.fss-tabs li.active a { background: #fff; color: var(--fsc-dark); border-color: var(--fsc-dark); border-bottom: 3px solid #fff; font-weight: 700; }

.fss-filter { background: #fff; border: 1px solid #e8e8e8; border-radius: 8px; padding: 14px 20px; margin-bottom: 24px; box-shadow: 0 1px 4px rgba(0,0,0,0.04); }
.fss-filter__row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.fss-filter__row label { font-size: 13px; color: #555; font-weight: 600; display: flex; align-items: center; gap: 8px; }
.fss-filter__row input[type="date"] { padding: 6px 10px; border: 1px solid #ddd; border-radius: 5px; font-size: 13px; color: #333; background: #fafafa; }

.fss-kpi-grid { display: grid; grid-template-columns: repeat(8, 1fr); gap: 14px; margin-bottom: 28px; }
@media (max-width: 1400px) { .fss-kpi-grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 1000px) { .fss-kpi-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width:  700px) { .fss-kpi-grid { grid-template-columns: repeat(2, 1fr); } }

.fss-kpi { border-radius: 12px; padding: 20px 16px; text-align: center; color: #fff; box-shadow: 0 4px 12px rgba(0,0,0,0.10); position: relative; overflow: hidden; }
.fss-kpi::after { content: ''; position: absolute; top: -20px; right: -20px; width: 80px; height: 80px; background: rgba(255,255,255,0.08); border-radius: 50%; }
.fss-kpi__val { font-size: 20px; font-weight: 800; line-height: 1.2; position: relative; z-index: 1; }
.fss-kpi__label { font-size: 10px; font-weight: 700; opacity: 0.88; margin-top: 5px; text-transform: uppercase; letter-spacing: 0.6px; position: relative; z-index: 1; }
.fss-kpi--dark   { background: linear-gradient(135deg, #2b2b2b, #1e1e1e); }
.fss-kpi--green  { background: linear-gradient(135deg, #1db954, #158a3e); }
.fss-kpi--teal   { background: linear-gradient(135deg, #00b894, #00897b); }
.fss-kpi--orange { background: linear-gradient(135deg, #ff6b35, #e55b2a); }
.fss-kpi--purple { background: linear-gradient(135deg, #9b59b6, #7d3c98); }
.fss-kpi--gray   { background: linear-gradient(135deg, #636e72, #4a5568); }
.fss-kpi--red    { background: linear-gradient(135deg, #e63946, #c0392b); }
.fss-kpi--blue   { background: linear-gradient(135deg, #00a0e3, #0080b8); }

.fss-charts-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 28px; }
.fss-charts-grid .fss-chart-box:first-child { grid-column: 1 / -1; }
@media (max-width: 900px) { .fss-charts-grid { grid-template-columns: 1fr; } }

.fss-chart-box { background: #fff; border: 1px solid #e8e8e8; border-radius: 10px; padding: 20px; box-shadow: 0 1px 6px rgba(0,0,0,0.05); min-width: 0; }
.fss-chart-box__title { font-size: 13px; font-weight: 700; color: #333; margin-bottom: 16px; padding-bottom: 10px; border-bottom: 1px solid #f0f0f0; }

.fss-section { background: #fff; border: 1px solid #e8e8e8; border-radius: 10px; padding: 20px; margin-bottom: 20px; box-shadow: 0 1px 6px rgba(0,0,0,0.05); overflow-x: auto; }
.fss-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.fss-section__title { font-size: 14px; font-weight: 700; color: #222; margin: 0 0 16px; padding-bottom: 10px; border-bottom: 2px solid #f0f0f0; }

.fss-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.fss-table th { background: #f7f8fa; padding: 10px 12px; text-align: left; font-weight: 700; color: #555; border-bottom: 2px solid #e8e8e8; white-space: nowrap; font-size: 11px; text-transform: uppercase; letter-spacing: 0.3px; }
.fss-table td { padding: 9px 12px; border-bottom: 1px solid #f2f2f2; vertical-align: middle; color: #444; }
.fss-table tbody tr:hover td { background: var(--fsc-g1); }
.fss-row-active td { background: #f0fff4 !important; }

.fss-mini-bar { width: 56px; height: 5px; background: var(--fsc-g2); border-radius: 3px; overflow: hidden; display: inline-block; vertical-align: middle; margin-right: 4px; }
.fss-mini-bar__fill { height: 100%; background: var(--fsc-dark); border-radius: 3px; }

.fss-badge { display: inline-block; padding: 3px 9px; border-radius: 20px; font-size: 11px; font-weight: 700; color: #fff; }
.fss-badge--green { background: var(--fsc-green); }
.fss-badge--gray  { background: #aaa; }
.fss-badge--dark  { background: var(--fsc-dark); }
.fss-badge--red   { background: #e63946; }
.fss-badge--blue  { background: #00a0e3; }

.fss-profit-pos { color: var(--fsc-green); font-weight: 700; }
.fss-profit-neg { color: #e63946; font-weight: 700; }
.fss-empty { color: #bbb; font-style: italic; padding: 30px 0; text-align: center; font-size: 14px; }

/* ================================================================== */
/* RESPONSIVE                                                         */
/* ================================================================== */

@media (max-width: 800px) {
  .flashsale-cols { grid-template-columns: 1fr; }
  .flashsale-img-side { border-right: none; border-bottom: 1px solid var(--fsc-g2); }
  .flashsale-cta-side { border-right: none; border-bottom: 1px solid var(--fsc-g2); }
  .flashsale-card__btn { width: 100%; }
  .flashsale-urgency-strip { flex-wrap: wrap; font-size: 10px; padding: 10px 12px; }
  .flashsale-countdown__value { font-size: 18px; min-width: 38px; }
  .flashsale-badge-bar { flex-direction: column; align-items: flex-start; gap: 2px; }
}

@media (max-width: 480px) {
  .flashsale-cta-side    { padding: 20px 16px; gap: 14px; }
  .flashsale-benefits-col { padding: 20px 16px; }
}