@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

:root{
  --bg0:#07070a;
  --bg1:#0f1220;
  --card:rgba(255,255,255,.06);
  --card2:rgba(255,255,255,.08);
  --text:rgba(255,255,255,.92);
  --muted:rgba(255,255,255,.66);
  --line:rgba(255,255,255,.12);
  --accent:#f7c948;
  --accent2:#7c3aed;
  --ok:#22c55e;
  --danger:#ef4444;
  --shadow:0 18px 60px rgba(0,0,0,.55);
  --radius:18px;
  --radius2:26px;
  --focus:0 0 0 4px rgba(124,58,237,.35);
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  color:var(--text);
  background:
    radial-gradient(1000px 500px at 20% -10%, rgba(124,58,237,.35), transparent 55%),
    radial-gradient(900px 500px at 80% 0%, rgba(247,201,72,.22), transparent 50%),
    linear-gradient(180deg, var(--bg0), var(--bg1));
}

a{ color:inherit; text-decoration:none; }

.container{
  max-width:1100px;
  margin:0 auto;
  padding:24px 16px 48px;
}

.topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:10px 0 22px;
}

.brand{
  display:flex;
  gap:12px;
  align-items:center;
}

.brandMark{
  width:44px;
  height:44px;
  border-radius:14px;
  background:
    radial-gradient(16px 16px at 30% 30%, rgba(255,255,255,.55), transparent 65%),
    linear-gradient(135deg, rgba(124,58,237,.95), rgba(247,201,72,.85));
  box-shadow: 0 10px 36px rgba(124,58,237,.25);
}

.brandTitle{
  display:flex;
  flex-direction:column;
  line-height:1.05;
}
.brandTitle strong{ font-size:14px; letter-spacing:.12em; text-transform:uppercase; }
.brandTitle span{ font-size:12px; color:var(--muted); }

.pill{
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  padding:10px 14px;
  border-radius:999px;
  color:var(--muted);
  font-size:13px;
}

.navRow{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin: 0 0 18px;
}

.navRow[aria-label="Navigation"]{
  padding-bottom:4px;
}

.navLink{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.03);
  color: var(--muted);
  font-size:13px;
  transition: transform .08s ease, background .12s ease, border-color .12s ease;
}
.navLink:hover{
  transform: translateY(-1px);
  border-color: rgba(124,58,237,.35);
  background: rgba(124,58,237,.10);
  color: var(--text);
}
.navLink.activeNav{
  border-color: rgba(124,58,237,.65);
  background: rgba(124,58,237,.18);
  color: var(--text);
  font-weight: 700;
  box-shadow: 0 0 0 1px rgba(124,58,237,.22) inset;
}

.grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:18px;
}
@media (max-width: 900px){
  .grid{ grid-template-columns: 1fr; }
}

.card{
  background:linear-gradient(180deg, var(--card), rgba(255,255,255,.03));
  border:1px solid var(--line);
  border-radius: var(--radius2);
  box-shadow: var(--shadow);
  overflow:hidden;
}

.cardInner{ padding:22px; }

.hero{
  min-height:310px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:18px;
  padding:28px 22px 22px;
  background:
    radial-gradient(600px 260px at 20% 0%, rgba(247,201,72,.18), transparent 60%),
    radial-gradient(500px 220px at 90% 10%, rgba(124,58,237,.20), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
}

.hero h1{
  margin:0;
  font-size:36px;
  letter-spacing:-.02em;
}
.hero p{
  margin:10px 0 0;
  color:var(--muted);
  font-size:15px;
  max-width:52ch;
}

.heroMedia{
  height:150px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(140px 90px at 25% 35%, rgba(247,201,72,.35), transparent 65%),
    radial-gradient(140px 90px at 72% 20%, rgba(124,58,237,.35), transparent 62%),
    linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  position:relative;
  overflow:hidden;
}
.heroMedia:after{
  content:'';
  position:absolute;
  inset:-40px;
  background: conic-gradient(from 180deg, rgba(247,201,72,.00), rgba(247,201,72,.20), rgba(124,58,237,.18), rgba(247,201,72,.00));
  filter: blur(18px);
  opacity:.75;
  animation: spinGlow 10s linear infinite;
}
@keyframes spinGlow{
  from{ transform: rotate(0deg); }
  to{ transform: rotate(360deg); }
}

.sectionTitle{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:14px;
}
.sectionTitle h2{
  margin:0;
  font-size:18px;
  letter-spacing:-.01em;
}
.sectionTitle span{
  color:var(--muted);
  font-size:13px;
}

form{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.field label{
  display:block;
  color:var(--muted);
  font-size:13px;
  margin-bottom:6px;
}

.field input{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.18);
  color:var(--text);
  outline:none;
}
.field input:focus{
  box-shadow: var(--focus);
  border-color: rgba(124,58,237,.55);
}

.btnRow{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.btn{
  appearance:none;
  cursor:pointer;
  border:none;
  border-radius: 14px;
  padding: 12px 14px;
  background: linear-gradient(135deg, rgba(124,58,237,.95), rgba(247,201,72,.85));
  color:rgba(10,10,15,.95);
  font-weight:700;
}
.btn.secondary{
  background: rgba(255,255,255,.05);
  color:var(--text);
  border:1px solid rgba(255,255,255,.14);
  font-weight:600;
}

.note{
  font-size:13px;
  color:var(--muted);
  line-height:1.45;
}

.alert{
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.12);
  padding:12px 14px;
  background: rgba(255,255,255,.04);
  color:var(--muted);
  font-size:13px;
}
.alert.error{
  border-color: rgba(239,68,68,.35);
  background: rgba(239,68,68,.10);
  color: rgba(255,255,255,.9);
}
.alert.ok{
  border-color: rgba(34,197,94,.35);
  background: rgba(34,197,94,.10);
  color: rgba(255,255,255,.92);
}

.footerLine{
  margin-top:26px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.10);
  color:var(--muted);
  font-size:12px;
}

.gridHalf{
  grid-template-columns: 1fr 1fr;
}

.featureGrid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:10px;
}

.featureItem{
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  padding:12px;
  background:rgba(255,255,255,.03);
}

.featureItem strong{
  display:block;
  font-size:14px;
  margin-bottom:6px;
}

.featureItem p{
  margin:0;
  font-size:13px;
  color:var(--muted);
  line-height:1.45;
}

.steps{
  margin:0;
  padding-left:18px;
  display:flex;
  flex-direction:column;
  gap:10px;
}

.steps li{
  color:var(--text);
}

.steps p{
  margin:4px 0 0;
  color:var(--muted);
  font-size:13px;
}

.chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:9px 12px;
  font-size:12px;
  color:var(--text);
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.04);
}

.chipInvoicePaid{
  border-color: rgba(34,197,94,.35);
  background: rgba(34,197,94,.1);
}
.chipInvoiceUnpaid{
  border-color: rgba(250,204,21,.35);
  background: rgba(250,204,21,.08);
}
.chipInvoiceOverdue{
  border-color: rgba(239,68,68,.45);
  background: rgba(239,68,68,.12);
}

.trustList{
  margin:0;
  padding-left:18px;
  display:flex;
  flex-direction:column;
  gap:8px;
  color:var(--muted);
  font-size:14px;
}

.showcaseGrid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:12px;
}

.showcaseItem{
  border:1px solid rgba(255,255,255,.12);
  border-radius:16px;
  padding:12px;
  background:rgba(255,255,255,.03);
}

.showcaseItem h3{
  margin:10px 0 6px;
  font-size:15px;
}

.visualPlaceholder{
  height:150px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.14);
  background:linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.01));
  position:relative;
  overflow:hidden;
}

.visualPlaceholder::after{
  content:'';
  position:absolute;
  inset:0;
  opacity:.8;
}

.visualA::after{
  background:radial-gradient(120px 70px at 30% 30%, rgba(247,201,72,.45), transparent 60%);
}

.visualB::after{
  background:radial-gradient(120px 70px at 60% 40%, rgba(124,58,237,.45), transparent 60%);
}

.visualC::after{
  background:
    radial-gradient(100px 60px at 30% 35%, rgba(247,201,72,.30), transparent 60%),
    radial-gradient(110px 70px at 70% 45%, rgba(124,58,237,.30), transparent 60%);
}

.seasonGrid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap:10px;
}

.seasonItem{
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  padding:12px;
  background:rgba(255,255,255,.03);
}

.seasonItem strong{
  display:block;
  margin-bottom:6px;
}

.seasonItem p{
  margin:0;
  color:var(--muted);
  font-size:13px;
  line-height:1.4;
}

.faqList{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.faqList details{
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;
  padding:10px 12px;
  background:rgba(255,255,255,.03);
}

.faqList summary{
  cursor:pointer;
  font-weight:600;
}

.faqList p{
  margin:8px 0 0;
  color:var(--muted);
  font-size:13px;
}

.ctaBand .cardInner{
  text-align:center;
}

.ctaBand h2{
  margin:0 0 8px;
  font-size:28px;
  letter-spacing:-.02em;
}

.ctaBand p{
  margin:0 auto 14px;
  max-width:64ch;
  color:var(--muted);
}

@media (max-width: 900px){
  .gridHalf{
    grid-template-columns: 1fr;
  }

  .featureGrid{
    grid-template-columns: 1fr;
  }

  .showcaseGrid{
    grid-template-columns: 1fr;
  }

  .seasonGrid{
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 640px){
  .container{
    padding:16px 12px 36px;
  }

  .hero{
    min-height: 0;
    padding:20px 16px;
  }

  .hero h1{
    font-size:28px;
  }

  .cardInner{
    padding:16px;
  }

  .seasonGrid{
    grid-template-columns: 1fr;
  }

  .ctaBand h2{
    font-size:22px;
  }
}

/* =========================================================
   Stage 11 UI Foundation (design-system seed)
   ========================================================= */

:root{
  --space-1:6px;
  --space-2:10px;
  --space-3:14px;
  --space-4:18px;
  --space-5:24px;
  --space-6:32px;

  --font-xs:12px;
  --font-sm:13px;
  --font-md:15px;
  --font-lg:18px;
  --font-xl:24px;
  --font-2xl:clamp(30px, 4.8vw, 42px);

  --line-soft:rgba(255,255,255,.10);
  --line-strong:rgba(255,255,255,.18);
  --surface-soft:rgba(255,255,255,.03);
  --surface-mid:rgba(255,255,255,.05);
  --surface-strong:rgba(255,255,255,.08);

  --shadow-soft:0 10px 28px rgba(0,0,0,.28);
  --shadow-card:0 18px 60px rgba(0,0,0,.55);
  --shadow-accent:0 14px 34px rgba(124,58,237,.30);
}

body{
  font-size:var(--font-md);
  line-height:1.55;
}

h1,h2,h3{
  line-height:1.18;
}

.sectionTitle h2{
  font-size:var(--font-lg);
  letter-spacing:-.01em;
}

.sectionTitle span{
  font-size:var(--font-sm);
}

.hero{
  gap:var(--space-4);
}

.hero h1{
  font-size:var(--font-2xl);
  max-width:18ch;
}

.hero p{
  font-size:var(--font-md);
  max-width:62ch;
}

.sectionLead{
  margin:0;
  color:var(--muted);
  font-size:var(--font-md);
  line-height:1.6;
  max-width:70ch;
}

.card{
  box-shadow:var(--shadow-card);
  border-color:var(--line-soft);
}

.card:hover{
  border-color:var(--line-strong);
}

.cardInner{
  padding:clamp(16px, 2.2vw, 24px);
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:44px;
  padding:11px 16px;
  border-radius:14px;
  transition: transform .14s ease, box-shadow .18s ease, opacity .16s ease, filter .16s ease;
  box-shadow:var(--shadow-accent);
}

.btn:hover{
  transform:translateY(-1px);
  filter:saturate(1.06);
}

.btn:active{
  transform:translateY(0);
}

.btn:focus-visible{
  outline:none;
  box-shadow:var(--focus), var(--shadow-accent);
}

.btn.secondary{
  box-shadow:none;
  background:var(--surface-mid);
  border:1px solid var(--line-strong);
}

.btn.secondary:hover{
  background:rgba(124,58,237,.13);
  border-color:rgba(124,58,237,.34);
}

.btn.ghost{
  background:transparent;
  border:1px dashed var(--line-strong);
  color:var(--text);
  box-shadow:none;
}

.btn.block{
  width:100%;
}

form{
  gap:var(--space-3);
}

.field label{
  font-size:var(--font-sm);
  letter-spacing:.01em;
}

.field input,
.field select,
.field textarea{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--line-soft);
  background:rgba(0,0,0,.18);
  color:var(--text);
  outline:none;
  transition:border-color .15s ease, box-shadow .18s ease, background .18s ease;
}

.field textarea{
  min-height:120px;
  resize:vertical;
}

.field input:hover,
.field select:hover,
.field textarea:hover{
  border-color:var(--line-strong);
  background:rgba(255,255,255,.04);
}

.field input:focus,
.field select:focus,
.field textarea:focus{
  border-color:rgba(124,58,237,.55);
  box-shadow:var(--focus);
}

.navLink{
  transition:transform .12s ease, background .18s ease, border-color .18s ease, color .18s ease;
}

.navLink:focus-visible{
  outline:none;
  box-shadow:var(--focus);
}

.featureItem,
.showcaseItem,
.seasonItem,
.faqList details{
  background:var(--surface-soft);
  border-color:var(--line-soft);
  transition:border-color .18s ease, background .18s ease, transform .14s ease;
}

.featureItem:hover,
.showcaseItem:hover,
.seasonItem:hover,
.faqList details:hover{
  border-color:var(--line-strong);
  background:var(--surface-mid);
  transform:translateY(-1px);
}

.faqList summary{
  outline:none;
}

.faqList summary:focus-visible{
  box-shadow:var(--focus);
  border-radius:8px;
}

.promoBanner{
  border-radius:16px;
  border:1px solid rgba(124,58,237,.30);
  background:
    radial-gradient(700px 220px at 10% 0%, rgba(124,58,237,.20), transparent 56%),
    radial-gradient(700px 220px at 90% 0%, rgba(247,201,72,.16), transparent 56%),
    rgba(255,255,255,.03);
  padding:14px 16px;
  box-shadow:var(--shadow-soft);
}

.promoBanner strong{
  display:block;
  margin-bottom:4px;
}

.contentSection{
  display:flex;
  flex-direction:column;
  gap:var(--space-3);
}

.formGrid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
}

.locationList{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.locationCard{
  border:1px solid var(--line-soft);
  border-radius:14px;
  background:var(--surface-soft);
  padding:12px;
  transition:border-color .18s ease, background .18s ease, transform .14s ease;
}

.locationCard:hover{
  border-color:var(--line-strong);
  background:var(--surface-mid);
  transform:translateY(-1px);
}

.locationCard h3{
  margin:0;
  font-size:16px;
}

.spacer-sm{ height:var(--space-2); }
.spacer-md{ height:var(--space-3); }
.spacer-lg{ height:var(--space-5); }

@media (max-width: 900px){
  .btnRow{
    gap:8px;
  }

  .hero p{
    max-width:100%;
  }
}

@media (max-width: 640px){
  .topbar{
    gap:10px;
    padding-bottom:16px;
  }

  .pill{
    padding:8px 11px;
    font-size:12px;
  }

  .btn{
    min-height:42px;
    padding:10px 13px;
    font-size:14px;
  }

  .sectionLead{
    font-size:14px;
  }

  .formGrid{
    grid-template-columns: 1fr;
  }
}

.calendarGrid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap:10px;
}

.calendarDay{
  border:1px solid var(--line-soft);
  border-radius:14px;
  background:var(--surface-soft);
  padding:10px;
  min-height:120px;
}

.calendarDay.today{
  border-color:rgba(124,58,237,.55);
  background:rgba(124,58,237,.12);
}

.calendarDay h3{
  margin:0;
  font-size:16px;
}

.calendarOrderList{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.calendarOrderItem{
  border:1px solid var(--line-soft);
  border-radius:10px;
  background:rgba(255,255,255,.02);
  padding:8px;
}

.calendarOrderHeader{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  margin-bottom:4px;
}

/* —— Kalendarz zamówień (jasny premium, spójny z „Zamów kwiaty”) —— */
.calendarOpsHint{
  border-radius:16px;
  border:1px solid rgba(25,102,110,.14);
  background:linear-gradient(180deg, rgba(255,255,255,.99), rgba(248,251,250,.94));
  box-shadow:
    0 1px 0 rgba(255,255,255,.9) inset,
    0 10px 28px rgba(25,102,110,.07);
  padding:16px 18px;
  max-width:none;
  align-self:stretch;
}
.calendarOpsHintInner{
  display:flex;
  flex-direction:column;
  gap:0;
}
.calendarOpsHintLabel{
  display:block;
  font-size:11px;
  font-weight:700;
  letter-spacing:.09em;
  text-transform:uppercase;
  color:rgba(25,102,110,.52);
  margin-bottom:8px;
}
.calendarOpsHintText{
  margin:0;
  font-size:13px;
  line-height:1.55;
  color:#4f666b;
}
.calendarOpsHintText strong{
  color:var(--sf-primary);
  font-weight:600;
}
.calendarOpsHintAccent{
  margin:12px 0 0;
  padding-top:12px;
  border-top:1px solid rgba(25,102,110,.1);
  font-size:12px;
  line-height:1.45;
  font-weight:600;
  color:var(--sf-primary);
}

.calendarPageLayout{
  align-items:stretch;
  gap:clamp(16px,2.2vw,22px);
}

.calendarMonthCard .sectionTitle{
  margin-bottom:16px;
  align-items:flex-end;
}
.calendarMonthCard .sectionTitle h2{
  font-size:clamp(18px,2vw,22px);
}
.calendarMonthCard .sectionTitle span{
  font-size:11px;
  letter-spacing:.06em;
}

.calendarMonthDowRow{
  display:grid;
  grid-template-columns:repeat(7, minmax(0, 1fr));
  gap:6px;
  margin-bottom:8px;
  padding:8px 8px 10px;
  border-radius:12px;
  border:1px solid rgba(25,102,110,.1);
  background:rgba(25,102,110,.04);
}
.calendarMonthDow{
  font-size:10px;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:rgba(25,102,110,.55);
  text-align:center;
}

.calendarMonthGrid{
  display:grid;
  grid-template-columns:repeat(7, minmax(0, 1fr));
  gap:7px;
}

.calendarMonthPad{
  min-height:1px;
}

.calendarMonthCell{
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:5px;
  min-height:84px;
  padding:11px 9px 10px;
  border-radius:14px;
  border:1px solid var(--sf-line);
  background:linear-gradient(180deg, #ffffff, #f9fbf9);
  color:var(--sf-text);
  font:inherit;
  text-align:left;
  cursor:pointer;
  box-shadow:0 1px 0 rgba(255,255,255,.95) inset;
  transition:border-color .16s ease, background .16s ease, box-shadow .16s ease, transform .12s ease;
}
.calendarMonthCell:hover{
  border-color:rgba(138,168,58,.55);
  background:linear-gradient(180deg, rgba(252,255,245,.98), #fff);
  box-shadow:0 4px 16px rgba(167,199,63,.14);
  transform:translateY(-1px);
}
.calendarMonthCell:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(25,102,110,.16);
}

.calendarMonthCell.is-today{
  border-color:rgba(238,114,51,.45);
  background:linear-gradient(180deg, rgba(255,250,247,.98), #fff);
  box-shadow:0 0 0 1px rgba(238,114,51,.12) inset;
}

.calendarMonthCell.is-selected{
  border-color:rgba(138,168,58,.75);
  background:rgba(167,199,63,.18);
  box-shadow:0 0 0 2px rgba(167,199,63,.22) inset;
}

.calendarMonthCell--tone-policy,
.calendarMonthCell--tone-past{
  opacity:.78;
  background:#f3f5f4;
  color:var(--sf-muted);
}
.calendarMonthCell--tone-cutoff{
  border-color:rgba(238,114,51,.35);
  background:rgba(238,114,51,.06);
}
.calendarMonthCell--tone-paused{
  border-color:rgba(220,90,90,.35);
  background:rgba(220,90,90,.06);
}
.calendarMonthCell--tone-no_slot{
  border-style:dashed;
  border-color:rgba(25,102,110,.22);
  background:#fafbfb;
}
.calendarMonthCell--tone-free{
  border-color:rgba(167,199,63,.35);
  background:linear-gradient(180deg, rgba(252,255,245,.95), #fff);
}
.calendarMonthCell--tone-orders_one,
.calendarMonthCell--tone-orders_many{
  border-color:rgba(124,58,237,.22);
  background:linear-gradient(180deg, rgba(250,248,255,.98), #fff);
}

.calendarMonthCellTop{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:6px;
}
.calendarMonthCellNum{
  font-size:15px;
  font-weight:800;
  letter-spacing:-.03em;
  color:#173d43;
}
.calendarMonthCellDow{
  font-size:10px;
  font-weight:600;
  color:rgba(25,102,110,.45);
  text-transform:lowercase;
}
.calendarMonthBadge{
  align-self:flex-start;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:24px;
  padding:3px 8px;
  border-radius:999px;
  font-size:11px;
  font-weight:700;
  background:rgba(167,199,63,.22);
  border:1px solid rgba(138,168,58,.4);
  color:#3d5120;
}
.calendarMonthCellPreview{
  display:flex;
  flex-direction:column;
  gap:3px;
  font-size:10px;
  line-height:1.3;
  color:var(--sf-muted);
  max-height:2.7em;
  overflow:hidden;
}
.calendarMonthCellPreviewLine{
  display:block;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.calendarMonthCellState{
  font-size:10px;
  font-weight:600;
  letter-spacing:.02em;
  color:rgba(25,102,110,.45);
  margin-top:auto;
}

.calendarDayPanelWrap{
  min-width:0;
}
.calendarDayPanel .cardInner{
  display:flex;
  flex-direction:column;
  gap:0;
  padding:clamp(20px,2.4vw,28px);
}

.calendarDayPanelEmpty{
  text-align:center;
  padding:32px 20px 26px;
}
.calendarEmptyIllu{
  width:60px;
  height:60px;
  margin:0 auto 14px;
  border-radius:18px;
  border:1px dashed rgba(25,102,110,.22);
  background:linear-gradient(145deg, rgba(25,102,110,.04), rgba(167,199,63,.06));
}
.calendarEmptyTitle{
  margin:0 0 8px;
  font-size:17px;
  font-weight:700;
  color:var(--sf-primary);
}
.calendarEmptyText{
  margin:0 auto;
  max-width:40ch;
}

.calendarDayPanelWrap .is-hidden{
  display:none !important;
}

.calendarPanelDayHeader{
  margin-bottom:0;
  padding-bottom:18px;
  border-bottom:1px solid var(--sf-line);
}
.calendarPanelDayMeta{
  margin:0 0 8px;
  font-size:11px;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:rgba(25,102,110,.5);
}
.calendarPanelDayTitle{
  margin:0 0 10px;
  font-size:clamp(22px,2.4vw,28px);
  font-weight:800;
  letter-spacing:-.03em;
  color:#173d43;
}
.calendarPanelDayStatus{
  margin:0;
  font-size:14px;
  line-height:1.5;
  color:var(--sf-text);
}
.calendarPanelDayDetail{
  margin:10px 0 0;
  color:var(--sf-muted);
}

.calendarPanelSection{
  margin-top:22px;
  padding-top:20px;
  border-top:1px solid var(--sf-line);
}
.calendarPanelSectionHead{
  margin:-4px -6px 14px;
  padding:12px 14px 14px;
  border-radius:14px;
  background:
    linear-gradient(135deg, rgba(25,102,110,.05) 0%, rgba(167,199,63,.06) 55%, rgba(255,255,255,.4) 100%);
  border:1px solid rgba(25,102,110,.08);
  box-shadow:0 1px 0 rgba(255,255,255,.75) inset;
}
.calendarPanelSection .sectionTitle{
  margin-bottom:0;
}
.calendarPanelSection .sectionTitle h3{
  font-size:16px;
  font-weight:800;
  letter-spacing:-.02em;
  color:#173d43;
}
.calendarPanelSection .sectionTitle span{
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-weight:600;
  color:rgba(25,102,110,.48);
}

.calendarDeliveryList{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.calendarDeliveryItem{
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:5px;
  width:100%;
  text-align:left;
  font:inherit;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--sf-line);
  background:#fff;
  color:var(--sf-text);
  cursor:pointer;
  box-shadow:0 1px 2px rgba(25,102,110,.04);
  transition:border-color .16s ease, box-shadow .16s ease, background .16s ease;
}
.calendarDeliveryItem:hover{
  border-color:rgba(25,102,110,.22);
  background:#fff;
  box-shadow:0 6px 18px rgba(25,102,110,.09);
}
.calendarDeliveryItem.is-selected{
  border-color:rgba(25,102,110,.42);
  background:rgba(25,102,110,.04);
  box-shadow:0 0 0 1px rgba(25,102,110,.12) inset;
}
.calendarDeliveryItemTitle{
  font-size:14px;
  font-weight:700;
  color:#173d43;
}
.calendarDeliveryItemSub{
  font-size:12px;
  color:var(--sf-muted);
  line-height:1.4;
}

.calendarPanelEmptyInline{
  margin:0;
  padding:12px 14px;
  border-radius:12px;
  border:1px dashed rgba(25,102,110,.2);
  background:rgba(25,102,110,.03);
  color:var(--sf-muted);
}

.calendarAddForm.is-disabled{
  opacity:.58;
  pointer-events:none;
}
.calendarAddBlocked{
  border-radius:14px;
  border:1px solid rgba(25,102,110,.14);
  background:rgba(25,102,110,.04);
  padding:12px 14px;
  margin-bottom:12px;
}

.calendarFormHint{
  margin-top:8px;
  font-size:12px;
  line-height:1.45;
  color:var(--sf-muted);
}

.calendarDayPanel .calendarSelect,
.calendarDayPanel .field input,
.calendarDayPanel .field select{
  width:100%;
  min-height:44px;
  border-radius:12px;
  border:1px solid rgba(25,102,110,.2);
  background:#fff;
  color:var(--sf-text);
  padding:10px 12px;
  font:inherit;
  font-size:14px;
  color-scheme:light;
  transition:border-color .15s ease, box-shadow .15s ease;
}
.calendarDayPanel .field select,
.calendarDayPanel .calendarSelect{
  appearance:none;
  -webkit-appearance:none;
  padding-right:38px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M6 9l6 6 6-6' stroke='%2319666e' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 12px center;
  background-size:16px 16px;
}
.calendarDayPanel .field input:hover,
.calendarDayPanel .field select:hover,
.calendarDayPanel .calendarSelect:hover{
  border-color:rgba(25,102,110,.32);
  background:#fff;
}
.calendarDayPanel .field input:focus,
.calendarDayPanel .field select:focus,
.calendarDayPanel .calendarSelect:focus{
  outline:none;
  border-color:var(--sf-primary);
  box-shadow:0 0 0 3px rgba(25,102,110,.14);
}
.calendarSelect:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(25,102,110,.14);
}

.calendarDayPanel .field{
  gap:0;
}
.calendarDayPanel .field label{
  display:block;
  margin-bottom:7px;
  font-size:11px;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:rgba(25,102,110,.55);
}
.calendarDayPanel .field + .field{
  margin-top:14px;
}

.calendarDayPanel .locationChoiceList{
  border-radius:14px;
  border:1px solid rgba(25,102,110,.12);
  background:#fff;
  padding:12px;
}
.calendarDayPanel .locationChoiceItem{
  border-radius:10px;
  padding:9px 11px;
}
.calendarDayPanel .locationChoiceItem:has(input:checked){
  border-color:rgba(25,102,110,.28);
  background:rgba(25,102,110,.06);
}

.calendarManagePlaceholder{
  margin:0;
  padding:12px 14px;
  border-radius:12px;
  border:1px dashed rgba(25,102,110,.2);
  background:rgba(25,102,110,.03);
  color:var(--sf-muted);
  font-size:13px;
}
.calendarManageSelected{
  font-size:13px;
  line-height:1.45;
  margin:0 0 14px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(25,102,110,.12);
  background:linear-gradient(180deg, #fff, #fafcfb);
  color:var(--sf-text);
}
.calendarManageForm{
  margin-bottom:14px;
}
.calendarManageForm .field label{
  font-size:11px;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:rgba(25,102,110,.55);
}
.calendarManageForm--danger{
  padding-top:0;
  margin-top:0;
  border-top:none;
}

.calendarToolbarActions{
  grid-column:1 / -1;
  flex-wrap:wrap;
  gap:10px;
}

.calendarToolbar{
  display:block;
  padding:12px 14px;
  margin-bottom:4px;
  border-radius:14px;
  border:1px solid rgba(25,102,110,.12);
  background:rgba(255,255,255,.72);
  box-shadow:0 1px 0 rgba(255,255,255,.9) inset;
}
.calendarToolbar .field{
  margin:0;
}
.calendarToolbar .field label{
  font-size:11px;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:rgba(25,102,110,.55);
  margin-bottom:7px;
}
.calendarToolbar .field select.orderFlowSelect,
.calendarToolbar .field .orderFlowSelect{
  width:100%;
  min-height:44px;
  border-radius:12px;
  border:1px solid rgba(25,102,110,.2);
  background:#fff;
  color:var(--sf-text);
  color-scheme:light;
  padding:10px 12px;
  font-size:14px;
  font:inherit;
  appearance:none;
  -webkit-appearance:none;
  padding-right:38px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M6 9l6 6 6-6' stroke='%2319666e' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 12px center;
  background-size:16px 16px;
  transition:border-color .15s ease, box-shadow .15s ease;
}
.calendarToolbar .field select.orderFlowSelect:hover,
.calendarToolbar .field .orderFlowSelect:hover{
  border-color:rgba(25,102,110,.32);
}
.calendarToolbar .field select.orderFlowSelect:focus,
.calendarToolbar .field .orderFlowSelect:focus{
  outline:none;
  border-color:var(--sf-primary);
  box-shadow:0 0 0 3px rgba(25,102,110,.12);
}
.calendarToolbarMonthWrap.orderFlowDateWrap{
  min-height:44px;
}
.calendarToolbarMonthWrap .flatpickr-input{
  display:none !important;
}
.calendarToolbarMonthWrap .flatpickr-alt-input{
  min-height:44px;
  padding:11px 12px !important;
  font-size:14px !important;
}

.calendarToolbarCompact{
  width:100%;
}
.calendarToolbarRow{
  display:flex;
  flex-wrap:nowrap;
  align-items:flex-end;
  gap:10px 12px;
  width:100%;
}
.calendarToolbarField--month{
  flex:1 1 200px;
  min-width:180px;
  max-width:260px;
}
.calendarToolbarField--location{
  flex:1 1 200px;
  min-width:160px;
  max-width:280px;
}
.calendarToolbarFilterBtn{
  flex:0 0 auto;
  display:flex;
  align-items:flex-end;
  padding-bottom:2px;
}
.calendarToolbarFilterBtn .btn,
.calendarToolbarSubmitBtn{
  min-height:44px;
  padding-left:18px;
  padding-right:18px;
}
@media (max-width: 720px){
  .calendarToolbarRow{
    flex-wrap:wrap;
  }
  .calendarToolbarFilterBtn{
    flex:1 1 100%;
    justify-content:stretch;
  }
  .calendarToolbarFilterBtn .btn{
    width:100%;
  }
}

.calendarMonthView{
  display:flex;
  align-items:stretch;
  gap:10px;
  margin-top:4px;
}
.calendarMonthNavSide{
  flex:0 0 auto;
  align-self:center;
  min-width:44px;
  min-height:44px;
  padding:10px 12px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:12px;
  font-weight:700;
  font-size:15px;
  line-height:1;
}
.calendarMonthCore{
  flex:1 1 auto;
  min-width:0;
}

.calendarDeliveryCard{
  display:flex;
  flex-direction:row;
  align-items:stretch;
  gap:0;
  width:100%;
  text-align:left;
  font:inherit;
  padding:0;
  border-radius:16px;
  border:1px solid var(--sf-line);
  background:#fff;
  color:var(--sf-text);
  cursor:pointer;
  overflow:hidden;
  box-shadow:0 2px 8px rgba(25,102,110,.06);
  transition:border-color .16s ease, box-shadow .16s ease, transform .12s ease;
}
.calendarDeliveryCard:hover{
  border-color:rgba(25,102,110,.22);
  box-shadow:0 8px 22px rgba(25,102,110,.1);
  transform:translateY(-1px);
}
.calendarDeliveryCard.is-selected{
  border-color:rgba(25,102,110,.42);
  box-shadow:0 0 0 2px rgba(25,102,110,.1) inset;
}
.calendarDeliveryCardMedia{
  flex:0 0 118px;
  width:118px;
  min-height:118px;
  background:linear-gradient(145deg, rgba(25,102,110,.06), rgba(167,199,63,.08));
  position:relative;
}
.calendarDeliveryCardMedia--empty{
  background:linear-gradient(145deg, rgba(25,102,110,.07), rgba(167,199,63,.1));
}
.calendarDeliveryCardImg{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.calendarDeliveryCardBody{
  flex:1 1 auto;
  min-width:0;
  padding:16px 18px 16px 16px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.calendarDeliveryCardTop{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.calendarDeliveryCardTitle{
  margin:0;
  font-size:16px;
  font-weight:800;
  letter-spacing:-.02em;
  line-height:1.35;
  color:#173d43;
}
.calendarDeliveryCardPrice{
  flex:0 0 auto;
  font-size:14px;
  font-weight:800;
  letter-spacing:-.02em;
  color:var(--sf-primary);
  white-space:nowrap;
}
.calendarDeliveryCardDate{
  margin:0;
  font-size:12px;
  font-weight:600;
  color:rgba(25,102,110,.62);
  text-transform:capitalize;
}
.calendarDeliveryCardMeta{
  margin:0;
  font-size:12px;
  line-height:1.45;
  color:var(--sf-muted);
}
.calendarDeliveryCardDeadline{
  margin:0;
  font-size:12px;
  line-height:1.45;
  font-weight:600;
  color:#4f666b;
}
.calendarDeliveryCardFooter{
  margin-top:auto;
  padding-top:4px;
}

.calendarOrderFormPlain{
  margin-top:6px;
  padding:0;
  border:none;
  background:transparent;
  box-shadow:none;
}
.calendarMainMonthLabel{
  margin:0 0 14px;
  font-size:clamp(17px,2vw,20px);
  font-weight:800;
  letter-spacing:-.02em;
  color:#173d43;
  text-align:center;
}
.calendarManageButtonsRow{
  display:flex;
  flex-wrap:nowrap;
  align-items:center;
  justify-content:flex-start;
  gap:12px;
  margin-bottom:14px;
}
.calendarManageButtonsRow .btn,
.calendarManageButtonsRow .calendarManageCancelForm .btn{
  flex:0 0 auto;
  white-space:nowrap;
}
.calendarManageCancelForm{
  margin:0;
  display:inline-flex;
  align-items:center;
}
.calendarManageButtonsRow .calendarManageForm{
  margin-bottom:0;
}
@media (max-width: 440px){
  .calendarManageButtonsRow{
    flex-wrap:wrap;
  }
}
.calendarFormFieldset{
  border:none;
  margin:0;
  padding:0;
  min-width:0;
}
.orderFlowFlatpickrCal .flatpickr-monthSelect-month.selected,
.orderFlowFlatpickrCal .flatpickr-monthSelect-month.startRange,
.orderFlowFlatpickrCal .flatpickr-monthSelect-month.endRange{
  background-color:rgba(25,102,110,.94) !important;
  border-color:#19666e !important;
  color:#fff !important;
  box-shadow:none !important;
}
.calendarPanelSection .calendarOrderFormPlain .orderFlowForm{
  padding-top:2px;
}
.calendarDeliveryDateLine{
  margin-bottom:14px;
}
.calendarDeliveryDateLine strong{
  color:#173d43;
}

.calendarRescheduleActions{
  margin-bottom:12px;
}
.calendarReschedulePanel--plain{
  margin-top:10px;
  padding:14px 16px;
  border-radius:14px;
  border:1px solid rgba(25,102,110,.1);
  background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(250,252,251,.98));
  box-shadow:0 1px 0 rgba(255,255,255,.85) inset;
}
.calendarReschedulePanelInner{
  padding:0;
}

@media (max-width: 720px){
  .calendarMonthView{
    flex-wrap:wrap;
  }
  .calendarMonthNavSide{
    order:2;
    flex:1 1 calc(50% - 6px);
    justify-content:center;
  }
  .calendarMonthCore{
    order:1;
    flex:1 1 100%;
    width:100%;
  }
  .calendarMonthNavSide--prev{ order:2; }
  .calendarMonthNavSide--next{ order:3; }
  .calendarDeliveryCard{
    flex-direction:column;
  }
  .calendarDeliveryCardMedia{
    flex:0 0 auto;
    width:100%;
    min-height:140px;
  }
}

.customerContextBar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(124,58,237,.38);
  background:
    radial-gradient(600px 180px at 0 0, rgba(124,58,237,.16), transparent 60%),
    radial-gradient(600px 180px at 100% 0, rgba(247,201,72,.14), transparent 60%),
    rgba(255,255,255,.03);
  margin:0 0 14px;
}

.customerContextBrand{
  display:flex;
  flex-direction:column;
  gap:2px;
}

.customerContextBrand strong{
  font-size:18px;
  letter-spacing:-.01em;
}

.customerContextBrand span{
  font-size:13px;
  color:var(--muted);
}

.panelModuleGrid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
}

.adminKpiGrid{
  grid-template-columns:repeat(4,minmax(0,1fr));
}

.adminModuleGrid{
  grid-template-columns:repeat(3,minmax(0,1fr));
}

/* —— Admin dashboard (jasny panel — spójnie z produktami / cennikami) —— */
.adminDashPage{
  display:flex;
  flex-direction:column;
  gap:clamp(18px, 2.4vw, 24px);
}

.adminDashHeaderInner{
  display:flex;
  flex-direction:column;
  gap:12px;
  padding-top:clamp(20px, 2.4vw, 28px);
  padding-bottom:clamp(20px, 2.4vw, 28px);
}

.adminDashTitle{
  margin:0;
  font-size:clamp(26px, 3.2vw, 34px);
  font-weight:800;
  letter-spacing:-.03em;
  line-height:1.15;
  color:#184950;
}

.adminDashLead{
  margin:0;
  color:#4f666b;
  font-size:var(--font-md);
  line-height:1.6;
  max-width:62ch;
}

.adminDashSession{
  margin:4px 0 0;
  font-size:13px;
  font-weight:600;
  color:#708489;
}

.adminDashSession strong{
  color:#173d43;
  font-weight:800;
}

.adminDashKpiRow{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}

.adminDashKpiCard{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:8px;
  min-height:128px;
  padding:18px 18px 16px;
  border-radius:14px;
  border:1px solid var(--sf-line-soft);
  background:linear-gradient(180deg, #fdfefe, #f0f7f6);
  box-shadow:0 1px 0 rgba(255,255,255,.9) inset, var(--sf-shadow-1);
  text-decoration:none;
  color:#173d43;
  transition:border-color .2s ease, transform .16s ease, box-shadow .2s ease, background .2s ease;
  border-left:4px solid #19666e;
}

.adminDashKpiCard:hover{
  border-color:rgba(25,102,110,.35);
  background:linear-gradient(180deg, #ffffff, #e8f2f1);
  box-shadow:0 4px 18px rgba(25,102,110,.1);
  transform:translateY(-2px);
}

.adminDashKpiCard:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(25,102,110,.22), var(--sf-shadow-1);
}

.adminDashKpiLabel{
  font-size:11px;
  font-weight:800;
  color:#708489;
  letter-spacing:.07em;
  text-transform:uppercase;
  line-height:1.35;
}

.adminDashKpiValue{
  font-size:clamp(28px, 4vw, 36px);
  font-weight:800;
  letter-spacing:-.035em;
  line-height:1;
  color:var(--sf-primary);
}

.adminDashKpiHint{
  margin-top:auto;
  font-size:12px;
  color:#5f7479;
  line-height:1.45;
  max-width:30ch;
  font-weight:500;
}

.adminDashAttention .cardInner{
  padding-top:clamp(18px, 2.4vw, 26px);
  padding-bottom:clamp(18px, 2.4vw, 26px);
}

.adminDashAttention .sectionTitle{
  margin-bottom:4px;
}

.adminDashAttention .sectionTitle h2{
  color:#184950;
  letter-spacing:-.02em;
}

.adminDashAttention .sectionTitle span{
  color:var(--sf-muted);
  font-weight:600;
}

.adminDashAttentionLead{
  margin:0 0 20px;
  max-width:62ch;
  line-height:1.55;
  color:#5f7479;
  font-size:var(--font-sm);
}

.adminDashAttentionList{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:12px;
}

.adminDashAttentionItem{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px 20px;
  flex-wrap:wrap;
  padding:16px 18px;
  border-radius:14px;
  border:1px solid var(--sf-line-soft);
  background:linear-gradient(180deg, #fcfefd, #f8fbfa);
  box-shadow:0 1px 0 rgba(255,255,255,.85) inset;
}

.adminDashAttentionItem--hot{
  border-color:rgba(238,114,51,.35);
  background:linear-gradient(135deg, rgba(238,114,51,.08), #fbfdfc);
}

.adminDashAttentionItem--hot .adminDashAttentionTitleRow strong{
  color:#8f3f18;
}

.adminDashAttentionMain{
  flex:1;
  min-width:min(100%, 260px);
}

.adminDashAttentionTitleRow{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:6px;
}

.adminDashAttentionTitleRow strong{
  font-size:var(--font-md);
  font-weight:800;
  letter-spacing:-.01em;
  color:#173d43;
}

.adminDashAttentionBadge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:2rem;
  font-size:12px;
  font-weight:800;
  padding:5px 11px;
  border-radius:999px;
  border:1px solid var(--sf-line);
  background:#fff;
  color:#355056;
  line-height:1;
}

.adminDashAttentionBadge--hot{
  border-color:rgba(238,114,51,.45);
  background:rgba(238,114,51,.12);
  color:#8f3f18;
}

.adminDashAttentionBody{
  margin:0;
  max-width:56ch;
  font-size:var(--font-sm);
  line-height:1.55;
  color:#5f7479;
}

.adminDashAttentionCta{
  flex-shrink:0;
  align-self:center;
  min-width:108px;
}

.adminDashBlocks{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
  align-items:stretch;
}

.adminDashBlock{
  min-height:100%;
  display:flex;
  flex-direction:column;
}

.adminDashBlock .cardInner{
  display:flex;
  flex-direction:column;
  flex:1;
  min-height:300px;
  padding:clamp(20px, 2.5vw, 28px);
}

.adminDashBlock .sectionTitle{
  margin-bottom:2px;
}

.adminDashBlock .sectionTitle h2{
  font-size:var(--font-lg);
  color:#184950;
  letter-spacing:-.02em;
}

.adminDashBlockLead{
  margin:0 0 18px;
  line-height:1.55;
  color:#5f7479;
  font-size:var(--font-sm);
}

.adminDashStatList{
  margin:0;
  padding:12px 16px;
  flex:1;
  border-radius:12px;
  border:1px solid var(--sf-line-soft);
  background:linear-gradient(180deg, #f8fbfa, #f2f7f6);
  box-shadow:0 1px 0 rgba(255,255,255,.8) inset;
}

.adminDashStatRow{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:14px;
  padding:10px 0;
  border-bottom:1px solid #e3ebe9;
  font-size:var(--font-sm);
}

.adminDashStatRow:first-child{
  padding-top:2px;
}

.adminDashStatRow:last-child{
  border-bottom:none;
  padding-bottom:2px;
}

.adminDashStatRow dt{
  margin:0;
  color:#5f7479;
  font-weight:600;
}

.adminDashStatRow dd{
  margin:0;
  font-weight:800;
  font-size:var(--font-md);
  color:#173d43;
  font-variant-numeric:tabular-nums;
  letter-spacing:-.02em;
}

.adminDashBlockActions{
  flex-wrap:wrap;
  gap:10px;
  margin-top:auto;
  padding-top:20px;
}

.adminDashSystem .cardInner{
  padding:clamp(18px, 2.2vw, 24px);
}

.adminDashSystem .sectionTitle h2{
  color:#184950;
  letter-spacing:-.02em;
}

.adminDashSystem .sectionTitle span{
  color:var(--sf-muted);
  font-weight:600;
}

.adminDashSystemLead{
  margin:0 0 16px;
  max-width:64ch;
  line-height:1.55;
  color:#5f7479;
  font-size:var(--font-sm);
}

.adminDashSystemChips{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:18px;
}

.adminDashSystem .chip{
  font-size:12px;
  font-weight:700;
  padding:8px 14px;
  color:#355056;
  border:1px solid var(--sf-line-soft);
  background:#f6faf8;
}

.adminDashSystemActions{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px 12px;
  padding-top:4px;
}

.adminDashSystemActions form{
  display:inline-flex;
  margin:0;
}

@media (max-width:1100px){
  .adminDashKpiRow{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .adminDashBlocks{
    grid-template-columns:1fr;
  }
  .adminDashBlock .cardInner{
    min-height:0;
  }
}

@media (max-width:560px){
  .adminDashKpiRow{
    grid-template-columns:1fr;
  }
  .adminDashAttentionItem{
    flex-direction:column;
    align-items:stretch;
  }
  .adminDashAttentionCta{
    align-self:stretch;
    width:100%;
    min-width:0;
  }
}

/* —— Admin: zamówienia (lista + kalendarz) — jasny motyw Stage 27 —— */
.adminOrdersPage{
  display:flex;
  flex-direction:column;
  gap:clamp(16px, 2vw, 22px);
}

.adminOrdersHeaderInner{
  display:flex;
  flex-direction:column;
  gap:12px;
  padding-top:clamp(20px, 2.4vw, 28px);
  padding-bottom:clamp(20px, 2.4vw, 28px);
}

.adminOrdersTitle{
  margin:0;
  font-size:clamp(26px, 3.2vw, 34px);
  font-weight:800;
  letter-spacing:-.03em;
  line-height:1.15;
  color:#184950;
}

.adminOrdersHero .adminOrdersLead{
  margin:0;
  color:#4f666b;
  font-size:var(--font-md);
  line-height:1.6;
  max-width:62ch;
}

.adminOrdersHeaderMeta{
  margin:4px 0 0;
  font-size:12px;
  font-weight:600;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:rgba(25,102,110,.55);
}

.adminOrdersToolbar .cardInner.adminOrdersToolbarInner{
  display:flex;
  flex-direction:column;
  gap:16px;
  padding-top:clamp(18px, 2vw, 24px);
  padding-bottom:clamp(18px, 2vw, 24px);
}

.adminOrdersToolbarBand{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:10px;
  width:100%;
}

.adminOrdersToolbarLabel{
  font-size:11px;
  font-weight:800;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:#5f7479;
}

/* Segment — jak belka nawigacji panelu (jasna, teal akcent) */
.adminOrdersSegment{
  display:inline-flex;
  flex-wrap:wrap;
  align-items:center;
  padding:6px;
  gap:6px;
  width:100%;
  max-width:100%;
  border-radius:14px;
  border:1px solid var(--sf-line-soft);
  background:var(--sf-nav);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.75);
}

.adminOrdersPill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:0 20px;
  border-radius:10px;
  font-size:13px;
  font-weight:700;
  border:1px solid transparent;
  background:transparent;
  color:#4f666b;
  text-decoration:none;
  transition:background .15s ease, color .15s ease, border-color .15s ease, box-shadow .15s ease;
}

.adminOrdersPill:hover{
  background:var(--sf-surface-strong);
  color:var(--sf-primary);
  border-color:var(--sf-line-soft);
}

.adminOrdersPill--active{
  border-color:rgba(25,102,110,.32);
  background:rgba(25,102,110,.12);
  color:#0f4a50;
  box-shadow:
    inset 4px 0 0 #19666e,
    inset 0 1px 0 rgba(255,255,255,.5),
    0 1px 0 rgba(25,102,110,.06);
}

.adminOrdersSectionTitle h2{
  color:#184950;
  letter-spacing:-.02em;
}

.adminOrdersSectionMeta{
  font-size:var(--font-sm);
  font-weight:600;
  color:var(--sf-muted);
}

.adminOrdersListCard .sectionTitle span,
.adminOrdersDayCard .sectionTitle span,
.adminOrdersAggCard .sectionTitle span{
  color:var(--sf-muted);
}

.adminOrdersTableWrap{
  border-radius:14px;
  border:1px solid var(--sf-line-soft);
  background:linear-gradient(180deg, #fdfefe, #f8fbfa);
  box-shadow:0 1px 0 rgba(255,255,255,.8), var(--sf-shadow-1);
}

.adminOrdersTableWrap--list,
.adminOrdersTableWrap--day,
.adminOrdersTableWrap--agg{
  border-color:var(--sf-line);
}

.adminOrdersTable{
  font-size:14px;
  line-height:1.45;
}

.adminOrdersTable--list th,
.adminOrdersTable--day th,
.adminOrdersAggTable th{
  font-size:11px;
  letter-spacing:.08em;
}

.adminOrdersTable th{
  color:#4a5f64;
  font-weight:800;
  font-size:12px;
  letter-spacing:.06em;
  text-transform:uppercase;
  background:linear-gradient(180deg, #f4f9f8, #eef4f3);
  border-bottom:2px solid rgba(25,102,110,.14);
  padding:14px 16px !important;
  vertical-align:bottom;
}

.adminOrdersTable td{
  color:var(--sf-text);
  padding:14px 16px !important;
  border-bottom:1px solid #e3ebe9;
  vertical-align:top;
}

.adminOrdersTable tbody tr:nth-child(even) td{
  background:rgba(25,102,110,.02);
}

.adminOrdersTable tbody tr:hover td{
  background:rgba(25,102,110,.06);
}

.adminOrdersPage .adminOrdersTable a{
  text-decoration:none;
}

.adminOrdersThNum,
.adminOrdersCellNum{
  text-align:right;
  font-variant-numeric:tabular-nums;
}

.adminOrdersThActions{
  text-align:right;
  width:1%;
  white-space:nowrap;
}

.adminOrdersThActionsLabel{
  display:inline-block;
}

.adminOrdersThQty{
  min-width:7rem;
}

.adminOrdersCellDate{
  color:#2d4549;
  font-weight:600;
  white-space:nowrap;
}

.adminOrdersCellCompany strong{
  color:#173d43;
  font-weight:700;
}

.adminOrdersCellMuted{
  color:var(--sf-muted);
}

.adminOrdersCellProduct{
  color:var(--sf-text);
  line-height:1.45;
}

.adminOrdersProductSub{
  display:block;
  margin-top:4px;
  font-size:12px;
  font-weight:500;
  color:var(--sf-muted);
}

.adminOrdersCellValue{
  font-weight:700;
  color:var(--sf-primary);
}

.adminOrdersCellId{
  color:#4f666b;
  font-weight:600;
}

.adminOrdersCellStatus{
  min-width:132px;
}

.adminOrdersStatusStack{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:8px;
  max-width:22rem;
}

.adminOrdersStatusChip{
  flex-shrink:0;
}

.adminOrdersTypeBadge{
  display:inline-block;
  margin-top:6px;
  margin-right:6px;
  font-size:10px;
  font-weight:800;
  letter-spacing:.06em;
  text-transform:uppercase;
  padding:3px 8px;
  border-radius:8px;
  border:1px solid rgba(167,199,63,.45);
  background:rgba(167,199,63,.14);
  color:#3f5a0f;
}

.adminOrdersTypeLine{
  display:block;
  margin-top:6px;
  font-size:12px;
  color:var(--sf-muted);
  line-height:1.35;
}

.adminOrdersActionLink{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:40px;
  padding:8px 14px;
  border-radius:10px;
  border:1px solid rgba(25,102,110,.35);
  background:var(--sf-surface-strong);
  font-size:12px;
  font-weight:700;
  color:var(--sf-primary);
  box-shadow:0 1px 0 rgba(255,255,255,.9) inset;
  transition:border-color .15s ease, background .15s ease, box-shadow .15s ease, color .15s ease;
}

.adminOrdersActionLink:hover{
  border-color:rgba(25,102,110,.55);
  background:rgba(25,102,110,.06);
  color:#0d3d42;
  box-shadow:0 4px 14px rgba(25,102,110,.1);
}

.adminOrdersActionLink:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(25,102,110,.2);
}

.adminOrdersActionLinkIcon{
  font-size:14px;
  line-height:1;
  opacity:.85;
}

.adminOrdersDash{
  color:#a8b8bc;
  font-weight:600;
}

/* Statusy — chip: pastele + ciemny tekst */
.adminOrdersStatusPill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:6px 14px;
  border-radius:999px;
  font-size:12px;
  font-weight:800;
  letter-spacing:.02em;
  border:1px solid var(--sf-line);
  background:#f0f4f3;
  color:#355056;
  line-height:1.2;
}

.adminOrdersStatusPill--draft{
  border-color:#c5ced1;
  background:#eef1f3;
  color:#4a5565;
}

.adminOrdersStatusPill--submitted{
  border-color:rgba(234,179,8,.45);
  background:rgba(250,204,21,.16);
  color:#854d0e;
}

.adminOrdersStatusPill--confirmed{
  border-color:rgba(25,102,110,.4);
  background:rgba(25,102,110,.12);
  color:#0f4a50;
}

.adminOrdersStatusPill--cancelled{
  border-color:rgba(220,38,38,.35);
  background:rgba(248,113,113,.12);
  color:#991b1b;
}

.adminOrdersStatusPill--completed{
  border-color:rgba(22,163,74,.4);
  background:rgba(34,197,94,.12);
  color:#14532d;
}

.adminOrdersStatusPill--unknown{
  border-color:var(--sf-line);
  background:#f6f8f7;
  color:var(--sf-muted);
}

/* Kalendarz — tylko ta strona: siatka kolumn + komórki */
.adminOrdersPage .adminOrdersCalendarLayout{
  grid-template-columns:minmax(0, 1fr) minmax(0, 1.14fr);
  gap:clamp(16px, 2.2vw, 24px);
  align-items:start;
}

.adminOrdersCalendarTitle .adminOrdersMonthLabel{
  display:block;
  margin-top:6px;
  font-size:clamp(18px, 2.6vw, 24px);
  font-weight:800;
  letter-spacing:-.02em;
  color:#184950;
}

.adminOrdersCalendarHint{
  margin:14px 0 0;
  font-size:var(--font-sm);
  line-height:1.55;
  color:#5f7479;
}

.adminOrdersCalendarGrid a.calendarMonthCell{
  text-decoration:none;
  color:inherit;
  cursor:pointer;
}

/* Dni z dostawami — wyraźny teal, spójny z panelem */
.adminOrdersPage .adminOrdersCalendarGrid .calendarMonthCell--tone-orders_one,
.adminOrdersPage .adminOrdersCalendarGrid .calendarMonthCell--tone-orders_many{
  border-color:rgba(25,102,110,.42);
  background:linear-gradient(165deg, rgba(25,102,110,.1), #ffffff);
  box-shadow:0 0 0 1px rgba(25,102,110,.06) inset;
}

.adminOrdersPage .adminOrdersCalendarGrid .calendarMonthCell .calendarMonthCellNum{
  color:#0f4a50;
}

.adminOrdersPage .adminOrdersCalendarGrid .calendarMonthBadge{
  background:rgba(25,102,110,.12);
  border-color:rgba(25,102,110,.35);
  color:#0f4a50;
  font-weight:800;
}

.adminOrdersPage .adminOrdersCalendarGrid .calendarMonthCell:hover{
  border-color:rgba(25,102,110,.5);
  background:linear-gradient(165deg, rgba(25,102,110,.14), #fbfcfc);
  box-shadow:0 6px 20px rgba(25,102,110,.1);
  transform:translateY(-1px);
}

.adminOrdersPage .adminOrdersCalendarGrid .calendarMonthCell:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(25,102,110,.22);
}

.adminOrdersPage .adminOrdersCalendarGrid .calendarMonthCell.is-selected{
  border-color:#19666e;
  background:linear-gradient(180deg, rgba(25,102,110,.16), rgba(25,102,110,.06));
  box-shadow:
    0 0 0 2px rgba(25,102,110,.2) inset,
    0 4px 18px rgba(25,102,110,.12);
  transform:none;
}

.adminOrdersPage .adminOrdersCalendarGrid .calendarMonthCell.is-selected .calendarMonthCellNum{
  color:#063a40;
}

.adminOrdersDayColumn{
  display:flex;
  flex-direction:column;
  gap:clamp(14px, 2vw, 20px);
  min-width:0;
}

.adminOrdersDayHead{
  display:flex;
  flex-wrap:wrap;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px 24px;
  padding-bottom:16px;
  margin-bottom:4px;
  border-bottom:1px solid var(--sf-line-soft);
}

.adminOrdersDayHeadText{
  min-width:min(100%, 220px);
}

.adminOrdersDayTitle{
  margin:0 0 6px;
  font-size:var(--font-lg);
  font-weight:800;
  letter-spacing:-.02em;
  color:#184950;
}

.adminOrdersDayWeekday{
  margin:0 0 4px;
  font-size:13px;
  font-weight:700;
  color:var(--sf-primary);
  text-transform:capitalize;
}

.adminOrdersDayDate{
  display:block;
  margin:0;
  font-size:clamp(22px, 2.8vw, 28px);
  font-weight:800;
  letter-spacing:-.02em;
  color:#173d43;
}

.adminOrdersDayIso{
  margin:8px 0 0;
  font-size:12px;
  font-weight:600;
  color:#5f7479;
}

.adminOrdersDayIsoLabel{
  color:rgba(25,102,110,.55);
  margin-right:6px;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
  font-size:10px;
}

.adminOrdersDayKpis{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}

.adminOrdersDayKpi{
  min-width:140px;
  padding:12px 16px;
  border-radius:12px;
  border:1px solid var(--sf-line-soft);
  background:linear-gradient(180deg, var(--sf-surface-strong), #f4f9f8);
  box-shadow:var(--sf-shadow-1);
}

.adminOrdersDayKpiLabel{
  display:block;
  font-size:10px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#708489;
  margin-bottom:6px;
}

.adminOrdersDayKpiValue{
  font-size:26px;
  font-weight:800;
  letter-spacing:-.03em;
  color:var(--sf-primary);
  line-height:1;
}

.adminOrdersSubhead{
  margin:16px 0 0;
  font-size:15px;
  font-weight:800;
  letter-spacing:-.015em;
  color:#184950;
}

.adminOrdersDaySubtitle{
  margin:6px 0 14px;
  font-size:var(--font-sm);
  line-height:1.55;
  color:#5f7479;
  max-width:62ch;
}

.adminOrdersAggCard--purchase{
  border-color:rgba(25,102,110,.2);
  box-shadow:var(--sf-shadow-2);
}

.adminOrdersAggCard--purchase .cardInner{
  padding-top:clamp(22px, 2.4vw, 28px);
}

.adminOrdersAggHead{
  display:flex;
  flex-wrap:wrap;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px 24px;
  margin-bottom:16px;
  padding-bottom:16px;
  border-bottom:1px solid var(--sf-line-soft);
}

.adminOrdersAggHeadTitles{
  flex:1;
  min-width:min(100%, 280px);
}

.adminOrdersAggBadge{
  display:inline-flex;
  align-items:center;
  padding:4px 10px;
  margin-bottom:10px;
  border-radius:999px;
  font-size:10px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#0f4a50;
  border:1px solid rgba(25,102,110,.35);
  background:rgba(25,102,110,.08);
}

.adminOrdersAggTitle{
  margin:0 0 8px;
  font-size:clamp(19px, 2.2vw, 22px);
  font-weight:800;
  letter-spacing:-.02em;
  color:#184950;
}

.adminOrdersAggDeck{
  margin:0;
  font-size:var(--font-sm);
  line-height:1.55;
  color:#5f7479;
  max-width:56ch;
}

.adminOrdersAggHeadMeta{
  text-align:right;
  padding:10px 14px;
  border-radius:12px;
  border:1px solid var(--sf-line-soft);
  background:#f8fbfa;
}

.adminOrdersAggMetaLabel{
  display:block;
  font-size:10px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#708489;
  margin-bottom:4px;
}

.adminOrdersAggMetaValue{
  font-size:14px;
  font-weight:800;
  font-variant-numeric:tabular-nums;
  color:#173d43;
}

.adminOrdersAggQty{
  font-size:17px;
  font-weight:800;
  color:var(--sf-primary);
}

.adminOrdersAggTable tbody tr:nth-child(odd) td{
  background:rgba(25,102,110,.03);
}

.adminOrdersAggTable .adminOrdersCellProduct{
  font-size:14px;
}

.adminOrdersCellVariant{
  color:#4f666b;
  font-size:13px;
  font-weight:500;
}

.adminOrdersAggTable .adminOrdersCellProduct strong{
  color:#173d43;
}

@media (max-width:900px){
  .adminOrdersPage .adminOrdersCalendarLayout{
    grid-template-columns:1fr;
  }
}

/* —— Admin: cenniki (global / firmy / promocje) —— */
.adminPricingPage{
  display:flex;
  flex-direction:column;
  gap:clamp(16px, 2vw, 22px);
}

.adminPricingHeaderInner{
  display:flex;
  flex-direction:column;
  gap:14px;
  padding-top:clamp(20px, 2.4vw, 28px);
  padding-bottom:clamp(20px, 2.4vw, 28px);
}

.adminPricingTitle{
  margin:0;
  font-size:clamp(26px, 3.2vw, 34px);
  font-weight:800;
  letter-spacing:-.03em;
  color:#184950;
}

.adminPricingLead{
  margin:0;
  color:#4f666b;
  font-size:var(--font-md);
  line-height:1.6;
  max-width:70ch;
}

.adminPricingKpiRow{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:12px;
  margin-top:6px;
}

.adminPricingKpi{
  padding:14px 16px;
  border-radius:12px;
  border:1px solid var(--sf-line-soft);
  background:linear-gradient(180deg, var(--sf-surface-strong), #f4f9f8);
  box-shadow:var(--sf-shadow-1);
}

.adminPricingKpiLabel{
  display:block;
  font-size:10px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#708489;
  margin-bottom:8px;
  line-height:1.35;
}

.adminPricingKpiValue{
  font-size:clamp(22px, 3vw, 28px);
  font-weight:800;
  letter-spacing:-.03em;
  color:var(--sf-primary);
  line-height:1;
}

.adminPricingKpiValue--warn{
  color:#b45309;
}

.adminPricingToolbar .cardInner.adminPricingToolbarInner{
  padding-top:clamp(16px, 2vw, 22px);
  padding-bottom:clamp(16px, 2vw, 22px);
}

.adminPricingToolbarBand{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.adminPricingToolbarLabel{
  font-size:11px;
  font-weight:800;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:#5f7479;
}

.adminPricingSegment{
  display:inline-flex;
  flex-wrap:wrap;
  gap:6px;
  padding:6px;
  width:100%;
  border-radius:14px;
  border:1px solid var(--sf-line-soft);
  background:var(--sf-nav);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.75);
}

.adminPricingPill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:0 18px;
  border-radius:10px;
  font-size:13px;
  font-weight:700;
  border:1px solid transparent;
  color:#4f666b;
  text-decoration:none;
  transition:background .15s ease, color .15s ease, border-color .15s ease, box-shadow .15s ease;
}

.adminPricingPill:hover{
  background:var(--sf-surface-strong);
  color:var(--sf-primary);
  border-color:var(--sf-line-soft);
}

.adminPricingPill--active{
  border-color:rgba(25,102,110,.32);
  background:rgba(25,102,110,.12);
  color:#0f4a50;
  box-shadow:
    inset 4px 0 0 #19666e,
    inset 0 1px 0 rgba(255,255,255,.5),
    0 1px 0 rgba(25,102,110,.06);
}

.adminPricingGrid{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(260px, 320px);
  gap:clamp(16px, 2vw, 22px);
  align-items:start;
}

.adminPricingMain{
  display:flex;
  flex-direction:column;
  gap:clamp(14px, 2vw, 18px);
  min-width:0;
}

.adminPricingFlash .cardInner{
  padding-top:16px;
  padding-bottom:16px;
}

.adminPricingImportCard .sectionTitle{
  margin-bottom:12px;
}

.adminPricingImportForm{
  margin-bottom:8px;
}

.adminPricingImportActions{
  margin-top:4px;
}

.adminPricingImportHint{
  margin:12px 0 0;
  font-size:12px;
  line-height:1.5;
  color:#5f7479;
}

.adminPricingImportHint code{
  font-size:11px;
  padding:1px 6px;
  border-radius:6px;
  background:rgba(25,102,110,.06);
  color:#0f4a50;
}

.adminPricingSectionTitle h2{
  color:#184950;
  letter-spacing:-.02em;
}

.adminPricingPanel .sectionTitle span{
  color:var(--sf-muted);
  font-weight:600;
}

.adminPricingCompanyForm{
  margin-bottom:16px;
  max-width:420px;
}

.adminPricingCompanyField select{
  font-weight:600;
}

.adminPricingTableWrap{
  border-radius:14px;
  border:1px solid var(--sf-line);
  background:linear-gradient(180deg, #fdfefe, #f8fbfa);
  box-shadow:0 1px 0 rgba(255,255,255,.8), var(--sf-shadow-1);
}

.adminPricingPage .adminPricingTable{
  font-size:14px;
  line-height:1.45;
}

.adminPricingPage .adminPricingTable th{
  color:#4a5f64;
  font-weight:800;
  font-size:11px;
  letter-spacing:.07em;
  text-transform:uppercase;
  background:linear-gradient(180deg, #f4f9f8, #eef4f3);
  border-bottom:2px solid rgba(25,102,110,.14);
  padding:14px 16px !important;
}

.adminPricingPage .adminPricingTable td{
  padding:14px 16px !important;
  border-bottom:1px solid #e3ebe9;
  vertical-align:top;
}

.adminPricingPage .adminPricingTable tbody tr:nth-child(even) td{
  background:rgba(25,102,110,.02);
}

.adminPricingPage .adminPricingTable tbody tr:hover td{
  background:rgba(25,102,110,.06);
}

.adminPricingThNum,
.adminPricingCellMoney{
  text-align:right;
  font-variant-numeric:tabular-nums;
}

.adminPricingThActions{
  text-align:right;
  white-space:nowrap;
  width:1%;
}

.adminPricingCellStrong{
  font-weight:700;
  color:#173d43;
}

.adminPricingCellMuted{
  color:#4f666b;
  font-size:13px;
}

.adminPricingCellNowrap{
  white-space:nowrap;
  font-size:12px;
}

.adminPricingDateSep{
  margin:0 6px;
  color:rgba(25,102,110,.45);
  font-weight:600;
}

.adminPricingEmDash{
  color:#a8b8bc;
  font-weight:600;
}

.adminPricingStatusChip{
  display:inline-flex;
  align-items:center;
  padding:5px 12px;
  border-radius:999px;
  font-size:11px;
  font-weight:800;
  letter-spacing:.02em;
  border:1px solid var(--sf-line);
  background:#f0f4f3;
  color:#355056;
}

.adminPricingStatusChip--active{
  border-color:rgba(22,163,74,.4);
  background:rgba(34,197,94,.1);
  color:#14532d;
}

.adminPricingStatusChip--scheduled{
  border-color:rgba(234,179,8,.45);
  background:rgba(250,204,21,.14);
  color:#854d0e;
}

.adminPricingStatusChip--expired{
  border-color:rgba(220,38,38,.3);
  background:rgba(248,113,113,.1);
  color:#991b1b;
}

.adminPricingStatusChip--inactive{
  border-color:#c5ced1;
  background:#eef1f3;
  color:#4a5565;
}

.adminPricingModeChip{
  display:inline-flex;
  align-items:center;
  padding:5px 12px;
  border-radius:999px;
  font-size:11px;
  font-weight:800;
  border:1px solid var(--sf-line-soft);
}

.adminPricingModeChip--override{
  border-color:rgba(25,102,110,.4);
  background:rgba(25,102,110,.1);
  color:#0f4a50;
}

.adminPricingModeChip--fallback{
  border-color:rgba(100,116,139,.35);
  background:rgba(148,163,184,.1);
  color:#475569;
}

.adminPricingActionLink{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:38px;
  padding:8px 12px;
  border-radius:10px;
  border:1px solid rgba(25,102,110,.35);
  background:var(--sf-surface-strong);
  font-size:12px;
  font-weight:700;
  color:var(--sf-primary);
  text-decoration:none;
  transition:border-color .15s ease, background .15s ease, box-shadow .15s ease;
}

.adminPricingActionLink:hover{
  border-color:rgba(25,102,110,.55);
  background:rgba(25,102,110,.06);
  box-shadow:0 4px 12px rgba(25,102,110,.08);
}

.adminPricingFootnote{
  margin:14px 0 0;
  font-size:12px;
  line-height:1.55;
  color:#5f7479;
  max-width:72ch;
}

.adminPricingAside.adminPricingAttention{
  border-color:rgba(25,102,110,.18);
}

.adminPricingAttention .cardInner{
  padding-top:clamp(18px, 2vw, 24px);
}

.adminPricingAttentionTitle{
  margin:0 0 8px;
  font-size:18px;
  font-weight:800;
  letter-spacing:-.02em;
  color:#184950;
}

.adminPricingAttentionLead{
  margin:0 0 18px;
  font-size:13px;
  line-height:1.5;
  color:#5f7479;
}

.adminPricingAttentionBlock{
  padding:14px 0;
  border-top:1px solid var(--sf-line-soft);
}

.adminPricingAttentionBlock:first-of-type{
  border-top:none;
  padding-top:0;
}

.adminPricingAttentionSub{
  margin:0 0 10px;
  font-size:12px;
  font-weight:800;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--sf-primary);
}

.adminPricingAttentionList{
  margin:0;
  padding-left:18px;
  color:#355056;
  font-size:13px;
  line-height:1.55;
}

.adminPricingAttentionMeta{
  display:block;
  margin-top:2px;
  font-size:11px;
  font-weight:600;
  color:#708489;
}

.adminPricingAttentionEmpty{
  margin:0;
  font-size:12px;
  color:#708489;
  line-height:1.5;
}

.adminPricingAttentionHint{
  margin:10px 0 0;
  font-size:11px;
  line-height:1.45;
  color:#708489;
}

@media (max-width:1100px){
  .adminPricingKpiRow{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .adminPricingGrid{
    grid-template-columns:1fr;
  }
}

@media (max-width:520px){
  .adminPricingKpiRow{
    grid-template-columns:1fr;
  }
}

.adminMetricValue{
  display:block;
  margin-top:6px;
  font-size:26px;
  font-weight:800;
  color:var(--text);
}

.panelModuleCard{
  display:flex;
  flex-direction:column;
  gap:6px;
  border:1px solid var(--line-soft);
  border-radius:12px;
  background:var(--surface-soft);
  padding:12px;
  transition:border-color .18s ease, background .18s ease, transform .14s ease;
}

.panelModuleCard strong{
  font-size:14px;
}

.panelModuleCard span{
  color:var(--muted);
  font-size:12px;
}

.panelModuleCard:hover{
  border-color:var(--line-strong);
  background:var(--surface-mid);
  transform:translateY(-1px);
}

.locationChoiceList{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:10px;
  border-radius:12px;
  border:1px solid var(--line-soft);
  background:var(--surface-soft);
}

.locationChoiceItem{
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius:10px;
  border:1px solid transparent;
  background:rgba(255,255,255,.02);
}

.locationChoiceItem:has(input:checked){
  border-color:rgba(124,58,237,.46);
  background:rgba(124,58,237,.14);
}

.checkboxRow{
  display:flex;
  align-items:flex-start;
  gap:8px;
  color:var(--text);
}

.catalogWeeklyOffers{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.catalogWeeklyOfferCard{
  border:1px solid var(--line-soft);
  border-radius:14px;
  padding:12px;
  background:var(--surface-soft);
}

.catalogWeeklyItems{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
  margin-top:8px;
}

.catalogWeeklyItem{
  border:1px solid var(--line-soft);
  border-radius:10px;
  background:rgba(255,255,255,.02);
  padding:8px;
  display:flex;
  flex-direction:column;
  gap:4px;
}

.catalogWeeklyItem span{
  color:var(--muted);
  font-size:12px;
}

.catalogWeeklyItem em{
  font-style:normal;
  font-size:12px;
  color:var(--accent);
}

.catalogCategoryList{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.catalogCategoryCard{
  border:1px solid var(--line-soft);
  border-radius:14px;
  background:var(--surface-soft);
  padding:12px;
}

.catalogProductGrid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  margin-top:10px;
}

.catalogProductCard{
  border:1px solid var(--line-soft);
  border-radius:12px;
  background:rgba(255,255,255,.02);
  padding:10px;
  display:flex;
  flex-direction:column;
  gap:8px;
}

.catalogProductVisual{
  height:98px;
  border:1px solid var(--line-soft);
  border-radius:10px;
  background:linear-gradient(135deg, rgba(124,58,237,.20), rgba(247,201,72,.18));
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:8px;
}

.catalogProductVisual span{
  font-size:12px;
  color:rgba(255,255,255,.9);
}

.promoBadge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  border-radius:999px;
  padding:7px 10px;
  border:1px solid rgba(247,201,72,.45);
  background:rgba(247,201,72,.12);
  color:rgba(255,255,255,.95);
  font-size:12px;
}

.catalogPrice{
  font-size:20px;
  font-weight:700;
  letter-spacing:-.01em;
}

.catalogPriceHint{
  font-size:12px;
  color:var(--muted);
}

.catalogDetailHero{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.catalogDetailPrimary{
  min-height:220px;
  border-radius:14px;
  border:1px solid var(--line-soft);
  background:linear-gradient(135deg, rgba(124,58,237,.24), rgba(247,201,72,.2));
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:16px;
}

.catalogDetailThumbs{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
}

.catalogDetailThumb{
  border:1px solid var(--line-soft);
  border-radius:10px;
  background:rgba(255,255,255,.03);
  padding:8px;
  min-height:60px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  font-size:12px;
  color:var(--muted);
}

.catalogVariantList{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.catalogVariantCard{
  border:1px solid var(--line-soft);
  border-radius:12px;
  background:var(--surface-soft);
  padding:10px;
}

@media (max-width: 900px){
  .navRow{
    flex-wrap:nowrap;
    overflow-x:auto;
    padding-bottom:6px;
  }

  .navLink{
    white-space:nowrap;
  }

  .customerContextBar{
    flex-direction:column;
    align-items:flex-start;
  }

  .calendarGrid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .calendarMonthGrid{
    gap:5px;
  }
  .calendarMonthCell{
    min-height:72px;
    padding:8px 6px 8px;
  }
  .calendarMonthCellNum{
    font-size:14px;
  }

  .catalogProductGrid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .catalogDetailThumbs{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .panelModuleGrid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .adminKpiGrid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .adminModuleGrid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media (max-width: 640px){
  .calendarGrid{
    grid-template-columns: 1fr;
  }

  .catalogWeeklyItems,
  .catalogProductGrid{
    grid-template-columns:1fr;
  }

  .catalogDetailThumbs{
    grid-template-columns:1fr;
  }

  .panelModuleGrid{
    grid-template-columns:1fr;
  }

  .adminKpiGrid,
  .adminModuleGrid{
    grid-template-columns:1fr;
  }
}

/* Stage 19 — Customer operational dashboard */
.dashboardHero{
  margin-bottom:var(--space-4);
}
.dashboardHeroInner{
  min-height:0;
  padding:var(--space-5) var(--space-4);
}
.dashboardPendingAlert{
  margin:0 0 var(--space-4);
}
.dashboardOpsGrid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--space-4);
  margin-bottom:var(--space-4);
}
.dashboardStatCard .cardInner{
  min-height:100%;
}
.dashboardStatValue{
  margin:0 0 var(--space-2);
  font-size:clamp(22px,4vw,28px);
  font-weight:700;
  letter-spacing:-.02em;
}
.dashboardStatEmpty{
  margin:0;
  color:var(--muted);
  font-size:var(--font-md);
  line-height:1.5;
}
.dashboardStatHint{
  margin-top:var(--space-3);
  font-size:var(--font-xs);
}
.dashboardCtaBar{
  margin-bottom:var(--space-4);
}
.dashboardCtaNote{
  align-self:center;
  flex:1;
  min-width:min(100%,220px);
}
.dashboardMainGrid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:var(--space-4);
  margin-bottom:var(--space-4);
}
.dashboardPanel .dashboardOfferTitle{
  margin:0 0 var(--space-2);
  font-size:var(--font-lg);
  font-weight:650;
}
.dashboardLocationList{
  list-style:none;
  margin:0 0 var(--space-3);
  padding:0;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.dashboardLocationItem{
  border:1px solid var(--line-soft);
  border-radius:12px;
  padding:10px 12px;
  background:var(--surface-soft);
  display:flex;
  flex-direction:column;
  gap:4px;
}
.dashboardLocationItem strong{
  font-size:14px;
}
.dashboardMiniList{
  margin:var(--space-2) 0 var(--space-3);
  padding-left:18px;
  color:var(--muted);
  font-size:var(--font-sm);
  line-height:1.5;
}
.dashboardCountdown{
  margin:var(--space-3) 0;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(247,201,72,.35);
  background:rgba(247,201,72,.08);
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px;
}
.dashboardCountdownLabel{
  color:var(--muted);
  font-size:var(--font-sm);
}
.dashboardCountdownValue{
  font-size:var(--font-lg);
  letter-spacing:.02em;
}
.dashboardAutomation{
  margin-bottom:var(--space-4);
}
.dashboardRecent{
  margin-bottom:var(--space-4);
}
.dashboardTableWrap{
  overflow-x:auto;
  margin-bottom:var(--space-3);
  -webkit-overflow-scrolling:touch;
}
.dashboardTable{
  width:100%;
  border-collapse:collapse;
  font-size:var(--font-sm);
}
.dashboardTable th,
.dashboardTable td{
  text-align:left;
  padding:10px 12px;
  border-bottom:1px solid var(--line-soft);
}
.dashboardTable th{
  color:var(--muted);
  font-weight:600;
}
.dashboardTable a{
  text-decoration:underline;
  text-underline-offset:3px;
}
.dashboardShortcuts{
  margin-bottom:var(--space-4);
}
.panelModuleGridCompact .panelModuleCard{
  padding:10px 12px;
}
.panelModuleGridCompact .panelModuleCard strong{
  font-size:13px;
}
.panelModuleGridCompact .panelModuleCard span{
  font-size:11px;
}

@media (max-width: 900px){
  .dashboardOpsGrid{
    grid-template-columns:1fr;
  }
  .dashboardMainGrid{
    grid-template-columns:1fr;
  }
}

@media (max-width: 640px){
  .dashboardCtaBar .btnRow{
    flex-direction:column;
    align-items:stretch;
  }
  .dashboardCtaBar .btn,
  .dashboardCtaBar .btn.secondary,
  .dashboardCtaBar .btn.ghost{
    width:100%;
  }
}

/* Stage 22 — promocje czasowe */
.catalogPriceWas{
  text-decoration:line-through;
  color:var(--muted);
  margin-right:8px;
  font-size:0.92em;
}
.promoBadge{
  margin:8px 0;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(247,201,72,.4);
  background:rgba(247,201,72,.09);
  display:flex;
  flex-direction:column;
  gap:6px;
}
.promoBadgeTitle{
  font-weight:600;
}
.promoBadgeState{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--muted);
}
.promoBadgeCd{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.promoRibbonRow{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin:10px 0 0;
}
.promoRibbon{
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(90,140,120,.35);
  background:rgba(90,140,120,.08);
  display:flex;
  flex-direction:column;
  gap:4px;
}
.promoRibbonTitle{
  font-weight:600;
}
.promoRibbonSub{
  font-size:var(--font-sm);
  color:var(--muted);
}
.promoRibbonMeta{
  font-size:11px;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.05em;
}
.promoRibbonCountdown{
  display:flex;
  align-items:center;
  gap:8px;
  margin-top:4px;
}
.promoCountdownLabel{
  color:var(--muted);
  font-size:var(--font-sm);
}
.promoCountdownValue{
  font-size:var(--font-lg);
  letter-spacing:.02em;
}
.promoStatePill{
  display:inline-block;
  padding:4px 10px;
  border-radius:999px;
  font-size:11px;
  font-weight:600;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.promoStatePill--scheduled{
  background:rgba(120,140,200,.15);
  border:1px solid rgba(120,140,200,.35);
}
.promoStatePill--active{
  background:rgba(90,160,120,.15);
  border:1px solid rgba(90,160,120,.35);
}
.promoStatePill--expired{
  background:rgba(160,160,160,.12);
  border:1px solid rgba(160,160,160,.3);
  color:var(--muted);
}
.customerPromoGrid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:var(--space-3);
}
.customerPromoCard .promoCardTitle{
  margin:8px 0 0;
  font-size:20px;
}
.customerPromoCard .promoCardDates{
  font-size:var(--font-sm);
  color:var(--muted);
  margin:8px 0;
}
.promoCardCountdown{
  margin-top:8px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(247,201,72,.35);
  background:rgba(247,201,72,.07);
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.promoTargetList{
  margin:8px 0 0;
  padding-left:18px;
  color:var(--muted);
  font-size:var(--font-sm);
}
.promoTargetKind{
  display:inline-block;
  margin-right:6px;
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--muted);
}
.customerWeeklyOfferStack{
  display:flex;
  flex-direction:column;
  gap:var(--space-3);
}
.customerWeeklyOfferItems{
  margin:8px 0 0;
  padding-left:18px;
}
.weeklyOfferHeroDecor{
  background:linear-gradient(135deg, rgba(247,201,72,.2) 0%, rgba(90,140,120,.12) 48%, transparent 100%);
}
.customerWeeklyOfferCardInner{
  display:flex;
  flex-direction:column;
  gap:var(--space-3);
}
.weeklyOfferCardHead{
  padding-bottom:4px;
  border-bottom:1px solid rgba(0,0,0,.06);
}
.weeklyOfferCardTitle{
  margin:0;
  font-size:clamp(1.25rem, 2.5vw, 1.65rem);
}
.weeklyOfferCardDates{
  margin:6px 0 0;
}
.weeklyOfferCardLead{
  margin:10px 0 0;
  color:var(--muted);
  font-size:var(--font-sm);
  max-width:62ch;
}
.weeklyOfferHero{
  display:grid;
  grid-template-columns:minmax(240px, 1fr) minmax(280px, 1.35fr);
  gap:var(--space-3);
  align-items:stretch;
}
@media (max-width:900px){
  .weeklyOfferHero{
    grid-template-columns:1fr;
  }
}
.weeklyOfferHeroCol--time{
  min-width:0;
}
.weeklyOfferHeroCol--product{
  min-width:0;
}
.weeklyOfferTimePanel{
  display:flex;
  flex-direction:column;
  gap:14px;
  height:100%;
  padding:16px 18px;
  border-radius:16px;
  border:1px solid rgba(90,140,120,.28);
  background:linear-gradient(165deg, rgba(255,255,255,.95) 0%, rgba(90,140,120,.06) 100%);
}
.weeklyOfferTimePanelLabel{
  font-size:11px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--muted);
}
.weeklyOfferProgress{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.weeklyOfferProgressTrack{
  height:10px;
  border-radius:999px;
  background:rgba(0,0,0,.08);
  overflow:hidden;
  border:1px solid rgba(0,0,0,.05);
}
.weeklyOfferProgressFill{
  height:100%;
  width:0%;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(90,140,120,.85), rgba(247,201,72,.95));
  transition:width .4s ease;
}
.weeklyOfferProgressHint{
  margin:0;
  font-size:11px;
}
.weeklyOfferCountdownBlock{
  margin-top:auto;
}
.weeklyOfferCountdownBlock .promoCountdownValue{
  font-size:clamp(1.1rem, 2.5vw, 1.45rem);
}
.weeklyOfferProductCard{
  display:grid;
  grid-template-columns:minmax(140px, 200px) 1fr;
  gap:var(--space-3);
  align-items:start;
  padding:16px 18px;
  border-radius:16px;
  border:1px solid rgba(0,0,0,.08);
  background:var(--surface, #fff);
  box-shadow:0 10px 28px rgba(20,30,24,.06);
}
@media (max-width:600px){
  .weeklyOfferProductCard{
    grid-template-columns:1fr;
  }
}
.weeklyOfferProductVisual{
  position:relative;
  border-radius:14px;
  overflow:hidden;
  aspect-ratio:1;
  background:rgba(0,0,0,.04);
  display:flex;
  align-items:center;
  justify-content:center;
}
.weeklyOfferProductImg{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.weeklyOfferProductPlaceholder{
  padding:12px;
  text-align:center;
  font-size:var(--font-sm);
  color:var(--muted);
  line-height:1.35;
}
.weeklyOfferSaveBadge{
  position:absolute;
  top:10px;
  left:10px;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.02em;
  color:#1a1a1a;
  background:linear-gradient(135deg, #f7c948, #f0e6a8);
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 4px 12px rgba(0,0,0,.12);
}
.weeklyOfferProductBody{
  display:flex;
  flex-direction:column;
  gap:10px;
  min-width:0;
}
.weeklyOfferProductName{
  margin:0;
  font-size:1.25rem;
  line-height:1.25;
}
.weeklyOfferVariant{
  margin:0;
}
.weeklyOfferPill{
  display:inline-block;
  align-self:flex-start;
  padding:4px 10px;
  border-radius:999px;
  font-size:11px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.04em;
  background:rgba(90,140,120,.12);
  border:1px solid rgba(90,140,120,.35);
  color:var(--accent-strong, #3d5c4f);
}
.weeklyOfferPriceBlock{
  margin-top:4px;
}
.weeklyOfferPriceRow{
  display:flex;
  flex-wrap:wrap;
  align-items:baseline;
  gap:10px 14px;
}
.weeklyOfferPriceWas{
  font-size:var(--font-sm);
  color:var(--muted);
  text-decoration:line-through;
}
.weeklyOfferPriceNow{
  font-size:1.35rem;
  font-weight:700;
  letter-spacing:-.02em;
  color:var(--text, #1a1a1a);
}
.weeklyOfferPriceHint{
  margin:4px 0 0;
}
.weeklyOfferCtaRow{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:8px;
}
.weeklyOfferEmptyProduct{
  padding:12px 0;
}
.weeklyOfferMore{
  margin-top:4px;
  padding-top:var(--space-3);
  border-top:1px solid rgba(0,0,0,.06);
}
.weeklyOfferMoreTitle{
  margin:0 0 10px;
  font-size:1rem;
}
.weeklyOfferMoreList{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.weeklyOfferMoreItem{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 14px;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.06);
  background:rgba(0,0,0,.02);
}
.weeklyOfferMoreItemMain{
  flex:1;
  min-width:200px;
}
.weeklyOfferFooterRow{
  margin-top:4px;
}
.weeklyItemBadge{
  margin-left:8px;
  font-style:normal;
  color:var(--accent-strong);
}
.adminPromoProductRows{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.adminPromoProductRow{
  display:grid;
  grid-template-columns:minmax(140px,1.2fr) 120px 100px 1fr;
  gap:10px;
  align-items:center;
}
@media (max-width:900px){
  .adminPromoProductRow{
    grid-template-columns:1fr;
  }
}
.adminWeeklyOfferChecks{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-top:8px;
}
.adminTableWrap{
  overflow-x:auto;
}

/* Stage 26 - SmartFlowers branding refinement (light premium) */
:root{
  --sf-primary:#19666e;
  --sf-secondary:#a7c73f;
  --sf-accent:#ee7233;
  --sf-bg:#f6f7f5;
  --sf-surface:#ffffff;
  --sf-text:#1d2a2e;
  --sf-muted:#68767a;
  --sf-line:#e6ebea;
}

body{
  color:var(--sf-text);
  background:var(--sf-bg);
  font-family:"Inter", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
}

.container{
  max-width:1220px;
  padding:28px 20px 64px;
}

.topbar{
  background:transparent;
  border-bottom:1px solid var(--sf-line);
  margin-bottom:18px;
}

.brandMark{
  border-radius:12px;
  background:var(--sf-primary);
  box-shadow:none;
}

.brandTitle strong{
  color:var(--sf-primary);
  letter-spacing:.08em;
}

.brandTitle span{
  color:var(--sf-muted);
}

.pill{
  background:#fff;
  border:1px solid var(--sf-line);
  color:var(--sf-muted);
}

.navLink{
  border:1px solid transparent;
  background:transparent;
  color:var(--sf-muted);
  font-weight:600;
}

.navLink:hover{
  background:#fff;
  color:var(--sf-primary);
  border-color:var(--sf-line);
  transform:none;
}

.navLink.activeNav{
  background:#fff;
  color:var(--sf-primary);
  border-color:rgba(25,102,110,.25);
  box-shadow:none;
}

.card{
  background:var(--sf-surface);
  border:1px solid var(--sf-line);
  border-radius:22px;
  box-shadow:none;
  overflow:visible;
}

.card:hover{
  border-color:#dbe3e1;
}

.cardInner{
  padding:28px;
}

.hero{
  min-height:0;
  background:#fff;
  padding:34px 28px;
  gap:20px;
}

.hero h1{
  color:#173d43;
  font-size:clamp(34px,5vw,52px);
  letter-spacing:-.03em;
  max-width:15ch;
}

.hero p,
.sectionLead,
.note{
  color:var(--sf-muted);
}

.heroMedia{
  display:none;
}

.sectionTitle h2{
  color:#173d43;
  font-size:clamp(22px,2.6vw,30px);
  letter-spacing:-.02em;
}

.sectionTitle span{
  color:var(--sf-muted);
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.btn{
  background:var(--sf-accent);
  color:#fff;
  border:1px solid var(--sf-accent);
  box-shadow:none;
  border-radius:12px;
}

.btn:hover{
  filter:brightness(.98);
}

.btn.secondary{
  background:#fff;
  color:var(--sf-primary);
  border-color:rgba(25,102,110,.25);
}

.btn.ghost{
  background:transparent;
  color:var(--sf-primary);
  border:1px solid var(--sf-line);
}

.chip{
  background:#f8faf9;
  border:1px solid #e8edeb;
  color:var(--sf-text);
}

.customerContextBar{
  background:#fff;
  border:1px solid var(--sf-line);
}

.featureItem,
.showcaseItem,
.seasonItem,
.faqList details,
.catalogProductCard,
.catalogCategoryCard,
.catalogWeeklyOfferCard,
.panelModuleCard,
.dashboardLocationItem{
  border:1px solid var(--sf-line);
  background:#fff;
  box-shadow:none;
}

.featureItem:hover,
.showcaseItem:hover,
.seasonItem:hover,
.faqList details:hover,
.catalogProductCard:hover,
.panelModuleCard:hover,
.dashboardLocationItem:hover{
  border-color:#dbe3e1;
  background:#fff;
  transform:none;
}

.promoBanner,
.promoRibbon,
.promoBadge,
.dashboardCountdown,
.promoCardCountdown{
  background:#fbfcfb;
  border:1px solid #e8eeec;
}

.promoRibbonMeta,
.promoBadgeState{
  color:var(--sf-secondary);
}

.catalogPrice,
.adminMetricValue{
  color:var(--sf-primary);
}

.dashboardTable th{
  color:var(--sf-muted);
  border-bottom:1px solid var(--sf-line);
}

.dashboardTable td{
  border-bottom:1px solid #edf1f0;
}

.alert{
  background:#fff;
  border:1px solid var(--sf-line);
  color:var(--sf-muted);
}

.alert.ok{
  border-color:rgba(167,199,63,.45);
  background:rgba(167,199,63,.1);
  color:#3f5a0f;
}

.alert.error{
  border-color:rgba(238,114,51,.45);
  background:rgba(238,114,51,.08);
  color:#8f3f18;
}

.homeHero{
  padding-top:44px;
  padding-bottom:44px;
}

.homeHero .btnRow{
  margin-top:8px;
}

.grid{
  gap:20px;
}

.dashboardOpsGrid,
.dashboardMainGrid{
  gap:20px;
}

.footerLine{
  border-top:1px solid var(--sf-line);
  color:#8a979b;
  text-transform:none;
  letter-spacing:0;
}

@media (max-width: 900px){
  .container{
    padding:20px 14px 40px;
  }

  .cardInner{
    padding:20px;
  }

  .hero{
    padding:26px 20px;
  }
}

/* Stage 25 - UI/UX refinement (premium look, no logic changes) */
:root{
  --bg0:#090b10;
  --bg1:#121725;
  --card:rgba(255,255,255,.07);
  --card2:rgba(255,255,255,.1);
  --line:rgba(255,255,255,.14);
  --muted:rgba(255,255,255,.72);
  --accent:#ffd166;
  --accent2:#6d5efc;
  --radius:20px;
  --radius2:28px;
}

.appShell{
  letter-spacing:.001em;
}

.container{
  max-width:1200px;
  padding:26px 18px 56px;
}

.pageContent{
  display:flex;
  flex-direction:column;
  gap:18px;
}

.topbar{
  padding:8px 0 18px;
  border-bottom:1px solid rgba(255,255,255,.08);
  margin-bottom:14px;
}

.brandTitle strong{
  font-size:15px;
  letter-spacing:.1em;
}

.pill{
  background:rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.18);
  color:rgba(255,255,255,.82);
}

.navRow{
  margin:0 0 10px;
}

.navLink{
  padding:10px 16px;
  font-size:12px;
  font-weight:600;
  letter-spacing:.02em;
}

.navLink.activeNav{
  background:linear-gradient(135deg, rgba(109,94,252,.28), rgba(255,209,102,.2));
  border-color:rgba(109,94,252,.7);
}

.card{
  border-radius:var(--radius2);
  box-shadow:0 16px 40px rgba(0,0,0,.33);
}

.hero{
  min-height:280px;
  padding:30px 24px 24px;
}

.hero h1{
  max-width:16ch;
}

.sectionTitle{
  margin-bottom:16px;
}

.sectionTitle h2{
  font-size:20px;
}

.btnRow{
  gap:12px;
}

.btn{
  min-height:46px;
  padding:12px 18px;
  font-size:14px;
}

.btn.ghost{
  border-style:solid;
}

.customerContextBar{
  border-radius:16px;
  margin:0 0 12px;
}

.dashboardOpsGrid{
  gap:14px;
}

.dashboardMainGrid{
  gap:14px;
}

.dashboardStatValue{
  font-size:clamp(24px,4.4vw,32px);
}

.dashboardTable th{
  text-transform:uppercase;
  letter-spacing:.05em;
  font-size:11px;
}

.catalogCategoryList{
  gap:14px;
}

.catalogCategoryCard{
  border-radius:16px;
  padding:14px;
}

.catalogProductGrid{
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}

.catalogProductCard{
  border-radius:14px;
  padding:12px;
  min-height:100%;
}

.catalogProductVisual{
  height:128px;
  border-radius:12px;
}

.catalogPrice{
  font-size:22px;
}

.adminMetricValue{
  font-size:30px;
  letter-spacing:-.02em;
}

.panelModuleCard{
  border-radius:14px;
  padding:14px;
}

.panelModuleCard strong{
  font-size:15px;
}

.footerLine{
  margin-top:30px;
  font-size:11px;
  letter-spacing:.04em;
  text-transform:uppercase;
}

@media (max-width: 900px){
  .container{
    padding:18px 14px 40px;
  }

  .hero{
    padding:22px 18px;
  }

  .catalogProductGrid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media (max-width: 640px){
  .pageContent{
    gap:14px;
  }

  .topbar{
    align-items:flex-start;
    margin-bottom:10px;
  }

  .pill{
    width:100%;
  }

  .catalogProductGrid{
    grid-template-columns:1fr;
  }

  .btnRow{
    flex-direction:column;
    align-items:stretch;
  }

  .btn,
  .btn.secondary,
  .btn.ghost{
    width:100%;
  }
}

/* Stage 27 - Visual refinement pass 2 (calmer premium depth) */
:root{
  --sf-primary:#19666e;
  --sf-secondary:#a7c73f;
  --sf-accent:#ee7233;

  --sf-bg:#edf1f0;
  --sf-bg-soft:#f3f6f5;
  --sf-surface:#fbfcfb;
  --sf-surface-strong:#ffffff;
  --sf-nav:#f4f7f6;
  --sf-line:#dbe4e2;
  --sf-line-soft:#e7eeec;
  --sf-text:#203035;
  --sf-muted:#63767b;

  --sf-shadow-1:0 2px 10px rgba(25,102,110,.05);
  --sf-shadow-2:0 12px 28px rgba(18,35,40,.08);
  --sf-shadow-3:0 20px 44px rgba(12,24,28,.10);
}

body{
  color:var(--sf-text);
  background:
    radial-gradient(1000px 420px at 8% -10%, rgba(25,102,110,.05), transparent 62%),
    radial-gradient(900px 380px at 92% -12%, rgba(167,199,63,.04), transparent 65%),
    linear-gradient(180deg, var(--sf-bg-soft), var(--sf-bg));
}

.container{
  max-width:1240px;
  padding:30px 22px 68px;
}

.topbar{
  background:rgba(251,253,252,.72);
  backdrop-filter: blur(6px);
  border:1px solid var(--sf-line-soft);
  border-radius:16px;
  padding:14px 16px;
  margin-bottom:16px;
  box-shadow:var(--sf-shadow-1);
}

.brandMark{
  background:linear-gradient(160deg, #19666e, #215e64);
  box-shadow:0 8px 18px rgba(25,102,110,.2);
}

.pill{
  background:var(--sf-surface-strong);
  border-color:var(--sf-line);
  color:var(--sf-muted);
}

.navRow{
  background:var(--sf-nav);
  border:1px solid var(--sf-line-soft);
  border-radius:14px;
  padding:6px;
  margin:0 0 14px;
}

.navLink{
  border-radius:10px;
  border:1px solid transparent;
  color:#4f666b;
  background:transparent;
  font-weight:600;
}

.navLink:hover{
  background:var(--sf-surface-strong);
  border-color:var(--sf-line-soft);
  color:var(--sf-primary);
}

.navLink.activeNav{
  background:rgba(25,102,110,.1);
  border-color:rgba(25,102,110,.22);
  color:var(--sf-primary);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.45);
}

.pageContent{
  gap:20px;
}

.card{
  background:linear-gradient(180deg, var(--sf-surface), var(--sf-surface-strong));
  border:1px solid var(--sf-line-soft);
  border-radius:22px;
  box-shadow:var(--sf-shadow-2);
}

.card:hover{
  border-color:var(--sf-line);
  box-shadow:var(--sf-shadow-3);
}

.cardInner{
  padding:30px;
}

.hero{
  background:
    linear-gradient(180deg, rgba(255,255,255,.84), rgba(249,252,251,.96));
  border-radius:22px;
  min-height:0;
  padding:38px 32px;
}

.hero h1{
  color:#184950;
  font-size:clamp(34px,4.9vw,50px);
  max-width:16ch;
}

.sectionTitle{
  margin-bottom:18px;
}

.sectionTitle h2{
  color:#1a4b52;
  font-size:clamp(21px,2.5vw,29px);
}

.sectionTitle span{
  color:#72868b;
}

.sectionLead{
  color:var(--sf-muted);
}

.note{
  color:var(--sf-muted);
}

.btn{
  background:var(--sf-accent);
  border-color:var(--sf-accent);
  color:#fff;
  box-shadow:0 10px 20px rgba(238,114,51,.22);
}

.btn:hover{
  filter:brightness(.96);
  box-shadow:0 12px 22px rgba(238,114,51,.26);
}

.btn.secondary{
  background:var(--sf-surface-strong);
  color:var(--sf-primary);
  border-color:rgba(25,102,110,.22);
  box-shadow:var(--sf-shadow-1);
}

.btn.ghost{
  background:#f7faf9;
  color:var(--sf-primary);
  border-color:var(--sf-line);
  box-shadow:none;
}

.customerContextBar{
  background:linear-gradient(180deg, #f7faf9, #f2f7f6);
  border:1px solid var(--sf-line);
  box-shadow:var(--sf-shadow-1);
}

.dashboardHero .hero{
  background:
    radial-gradient(700px 300px at 0% 0%, rgba(25,102,110,.06), transparent 62%),
    linear-gradient(180deg, #f8fbfa, #f3f8f7);
}

.dashboardStatCard,
.dashboardPanel,
.dashboardAutomation,
.dashboardRecent,
.dashboardShortcuts{
  background:linear-gradient(180deg, #fcfefd, #f8fbfa);
}

.dashboardCountdown,
.promoBadge,
.promoRibbon,
.promoBanner,
.promoCardCountdown{
  background:#f5f9f7;
  border:1px solid var(--sf-line);
}

.promoBadgeState,
.promoRibbonMeta{
  color:#7b9c1f;
}

.featureItem,
.catalogProductCard,
.catalogCategoryCard,
.catalogWeeklyOfferCard,
.panelModuleCard,
.dashboardLocationItem{
  border:1px solid var(--sf-line-soft);
  background:linear-gradient(180deg, #fdfefe, #f8fbfa);
  box-shadow:0 1px 0 rgba(255,255,255,.8), var(--sf-shadow-1);
}

.dashboardTable th{
  color:#708489;
  border-bottom:1px solid var(--sf-line);
  background:#f8fbfa;
}

.dashboardTable td{
  border-bottom:1px solid #e5ecea;
}

.catalogPrice,
.adminMetricValue{
  color:var(--sf-primary);
}

.chip{
  background:#f6faf8;
  border-color:#dfebe8;
  color:#355056;
}

.chipInvoicePaid{
  background:rgba(167,199,63,.12);
  border-color:rgba(167,199,63,.36);
}

.chipInvoiceUnpaid{
  background:rgba(238,114,51,.08);
  border-color:rgba(238,114,51,.28);
}

.alert{
  background:#f8fbfa;
  border-color:var(--sf-line);
  color:#5f7479;
}

.alert.ok{
  background:rgba(167,199,63,.13);
  border-color:rgba(167,199,63,.35);
  color:#49651a;
}

.alert.error{
  background:rgba(238,114,51,.1);
  border-color:rgba(238,114,51,.35);
  color:#93461f;
}

.footerLine{
  margin-top:34px;
  border-top:1px solid var(--sf-line);
  color:#7d9095;
}

@media (max-width: 900px){
  .container{
    padding:20px 14px 42px;
  }

  .topbar{
    padding:12px;
  }

  .cardInner{
    padding:22px;
  }

  .hero{
    padding:28px 22px;
  }
}

/* --- Homepage landing (light UI); scoped via :has(.homeLanding) --- */
body.appShell:has(.homeLanding){
  font-family:Poppins, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  color:#1b2b2d;
  background:#f4f8f7;
}

body.appShell:has(.homeLanding) .pageContent{
  gap:0;
}

body.appShell:has(.homeLanding) .brandTitle span{
  color:#5f7479;
}

body.appShell:has(.homeLanding) .pill{
  background:#fff;
  border-color:rgba(25,102,110,.22);
  color:#355056;
}

body.appShell:has(.homeLanding) .navLink{
  background:#fff;
  border-color:rgba(25,102,110,.18);
  color:#355056;
}

body.appShell:has(.homeLanding) .navLink:hover{
  border-color:rgba(25,102,110,.45);
  background:rgba(25,102,110,.08);
  color:#19666e;
  transform:translateY(-1px);
}

body.appShell:has(.homeLanding) .navLink.activeNav{
  border-color:rgba(25,102,110,.55);
  background:rgba(25,102,110,.14);
  color:#144f56;
  font-weight:700;
  box-shadow:none;
}

body.appShell:has(.homeLanding) .footerLine{
  margin-top:28px;
  padding-left:clamp(16px,3vw,28px);
  padding-right:clamp(16px,3vw,28px);
  border-top-color:rgba(25,102,110,.15);
  color:#6a8287;
}

body.appShell:has(.homeLanding) .topbar,
body.appShell:has(.homeLanding) .navRow{
  display:none;
}

body.appShell:has(.homeLanding) .container{
  max-width:100%;
  padding:0 0 40px;
}

html:has(.homeLanding){
  scroll-behavior:smooth;
}

.homeLanding section[id]{
  scroll-margin-top:96px;
}

.homeSiteHeader{
  position:sticky;
  top:0;
  z-index:100;
  width:100%;
  background:rgba(244,248,247,.92);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
}

.homeSiteHeaderInner{
  max-width:1320px;
  margin:0 auto;
  padding:14px clamp(18px,3vw,32px);
  display:flex;
  align-items:center;
  gap:clamp(16px,2.5vw,40px);
}

.homeSiteLogoLink{
  display:flex;
  align-items:center;
  flex-shrink:0;
  line-height:0;
  text-decoration:none;
}

.homeSiteLogo{
  display:block;
  height:clamp(46px,5.2vw,58px);
  width:auto;
  object-fit:contain;
}

.homeSiteNav{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
  gap:clamp(8px,1.8vw,32px);
}

.homeSiteNavLink{
  font-size:15px;
  font-weight:500;
  letter-spacing:.01em;
  color:#355056;
  text-decoration:none;
  padding:10px 2px;
  border-bottom:2px solid transparent;
  transition:color .15s ease, border-color .15s ease;
}

.homeSiteNavLink:hover{
  color:#19666e;
  border-bottom-color:rgba(25,102,110,.35);
}

.homeSiteActions{
  display:flex;
  align-items:center;
  gap:12px;
  flex-shrink:0;
}

.homeSiteLogin{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 16px;
  border-radius:999px;
  font-size:14px;
  font-weight:600;
  color:#19666e;
  text-decoration:none;
  border:1px solid rgba(25,102,110,.28);
  background:rgba(255,255,255,.75);
  transition:background .15s ease, border-color .15s ease, transform .1s ease;
}

.homeSiteLogin:hover{
  background:#fff;
  border-color:rgba(25,102,110,.45);
  transform:translateY(-1px);
}

.homeSiteLoginIcon{
  display:flex;
  color:inherit;
}

.homeSiteLoginText{
  white-space:nowrap;
}

.homeSiteRegisterCta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 22px;
  border-radius:999px;
  font-size:14px;
  font-weight:700;
  letter-spacing:.02em;
  color:#fff;
  text-decoration:none;
  background:#ee7233;
  box-shadow:0 8px 26px rgba(238,114,51,.35);
  border:2px solid transparent;
  transition:transform .1s ease, box-shadow .15s ease;
}

.homeSiteRegisterCta:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 32px rgba(238,114,51,.42);
}

.homeSiteRegisterCta:focus-visible,
.homeSiteLogin:focus-visible,
.homeSiteNavLink:focus-visible{
  outline:3px solid rgba(167,199,63,.55);
  outline-offset:3px;
}

.homeSiteNavLink.homeSiteNavLink--active{
  color:#19666e;
  border-bottom-color:rgba(25,102,110,.55);
  font-weight:600;
}

/* --- Customer panel: landing-style header + account menu --- */
body.appShell--customerPanelHeader,
body.appShell--adminPanelHeader{
  font-family:Poppins, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
}

body.appShell--customerPanelHeader .container,
body.appShell--adminPanelHeader .container{
  max-width:100%;
  padding:clamp(12px,2vw,20px) clamp(16px,3vw,28px) 48px;
}

body.appShell--customerPanelHeader .footerLine,
body.appShell--adminPanelHeader .footerLine{
  margin-top:28px;
  padding-left:clamp(16px,3vw,28px);
  padding-right:clamp(16px,3vw,28px);
  border-top-color:rgba(25,102,110,.15);
  color:#6a8287;
}

.customerPanelSiteHeader{
  border-bottom:1px solid rgba(25,102,110,.1);
}

.customerPanelSiteHeaderInner{
  max-width:1320px;
}

.customerPanelSiteNav{
  flex:1;
  min-width:0;
}

.customerPanelAccount{
  position:relative;
  flex-shrink:0;
  display:flex;
  align-items:center;
}

.customerPanelAccountTrigger{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 12px 10px 14px;
  margin:0;
  border:1px solid rgba(25,102,110,.22);
  border-radius:999px;
  background:rgba(255,255,255,.75);
  cursor:pointer;
  font:inherit;
  color:#355056;
  transition:background .15s ease, border-color .15s ease, box-shadow .15s ease;
}

.customerPanelAccountTrigger:hover{
  background:#fff;
  border-color:rgba(25,102,110,.38);
}

.customerPanelAccount.is-open .customerPanelAccountTrigger{
  border-color:rgba(25,102,110,.45);
  box-shadow:0 12px 28px rgba(15,40,42,.08);
}

.customerPanelAccountTrigger:focus-visible{
  outline:3px solid rgba(167,199,63,.55);
  outline-offset:3px;
}

.customerPanelCompanyName{
  font-size:14px;
  font-weight:700;
  color:#1b2b2d;
  max-width:min(42vw, 220px);
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

.customerPanelHamburger{
  display:flex;
  align-items:center;
  justify-content:center;
  color:#19666e;
  flex-shrink:0;
}

.customerPanelAccountMenu{
  position:absolute;
  top:calc(100% + 8px);
  right:0;
  min-width:min(100vw - 32px, 260px);
  padding:8px;
  margin:0;
  border-radius:14px;
  border:1px solid rgba(25,102,110,.16);
  background:rgba(255,255,255,.98);
  box-shadow:0 16px 40px rgba(15,40,42,.12);
  z-index:200;
}

.customerPanelAccountMenu[hidden]{
  display:none !important;
}

.customerPanelAccountMenuLink{
  display:block;
  padding:10px 12px;
  border-radius:10px;
  font-size:14px;
  font-weight:500;
  color:#355056;
  text-decoration:none;
  transition:background .12s ease, color .12s ease;
}

.customerPanelAccountMenuLink:hover{
  background:rgba(25,102,110,.08);
  color:#19666e;
}

.customerPanelAccountMenuLink:focus-visible{
  outline:2px solid rgba(167,199,63,.55);
  outline-offset:1px;
}

.customerPanelAccountMenuForm{
  margin:6px 0 0;
  padding:6px 0 0;
  border-top:1px solid rgba(25,102,110,.1);
}

.customerPanelAccountMenuBtn{
  display:block;
  width:100%;
  padding:10px 12px;
  border-radius:10px;
  border:0;
  margin:0;
  background:transparent;
  font:inherit;
  font-size:14px;
  font-weight:600;
  color:#c2410c;
  text-align:left;
  cursor:pointer;
  transition:background .12s ease;
}

.customerPanelAccountMenuBtn:hover{
  background:rgba(238,114,51,.1);
}

.customerPanelAccountMenuBtn:focus-visible{
  outline:2px solid rgba(167,199,63,.55);
  outline-offset:1px;
}

@media (max-width: 900px){
  .customerPanelSiteHeaderInner{
    flex-wrap:wrap;
  }

  .customerPanelSiteNav{
    order:3;
    flex:1 1 100%;
    justify-content:center;
    gap:10px 14px;
    padding-top:12px;
    margin-top:4px;
    border-top:1px solid rgba(25,102,110,.1);
  }

  .customerPanelAccount{
    margin-left:auto;
  }

  .customerPanelCompanyName{
    max-width:min(52vw, 200px);
  }
}

/* --- Customer: Zamów kwiaty (order flow) --- */
.orderFlowIntro{
  margin-bottom:4px;
}

.orderFlowIntroHero{
  min-height:0;
}

.orderFlowIntroHero--withWidget{
  display:grid;
  grid-template-areas:
    "introMain nameWidget"
    "introMedia introMedia";
  grid-template-columns:minmax(0,1fr) minmax(200px,280px);
  gap:clamp(14px,2vw,22px) clamp(18px,2.5vw,32px);
  align-items:start;
}

.orderFlowIntroMain{
  grid-area:introMain;
  min-width:0;
}

.orderFlowNameDayWidget{
  grid-area:nameWidget;
  align-self:start;
  margin:0;
  padding:14px 16px;
  border-radius:16px;
  border:1px solid rgba(25,102,110,.12);
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(249,252,251,.94));
  box-shadow:0 1px 0 rgba(255,255,255,.85) inset, 0 8px 22px rgba(15,40,42,.05);
}

.orderFlowNameDayWidgetHead{
  display:flex;
  align-items:center;
  gap:8px;
  margin-bottom:10px;
}

.orderFlowNameDayWidgetIcon{
  display:flex;
  color:rgba(25,102,110,.55);
  flex-shrink:0;
}

.orderFlowNameDayWidgetTitle{
  margin:0;
  font-size:13px;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:#63767b;
}

.orderFlowNameDayWidgetList{
  margin:0;
  padding:0;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:10px;
}

.orderFlowNameDayWidgetItem{
  display:flex;
  flex-direction:column;
  gap:3px;
  padding-bottom:8px;
  border-bottom:1px solid rgba(25,102,110,.08);
}

.orderFlowNameDayWidgetItem:last-child{
  padding-bottom:0;
  border-bottom:none;
}

.orderFlowNameDayWidgetDate{
  font-size:12px;
  font-weight:600;
  color:#355056;
  letter-spacing:.02em;
}

.orderFlowNameDayWidgetNames{
  font-size:13px;
  line-height:1.45;
  color:#4f666b;
}

.orderFlowIntroHero--withWidget .heroMedia{
  grid-area:introMedia;
  min-height:0;
}

@media (max-width:900px){
  .orderFlowIntroHero--withWidget{
    grid-template-areas:
      "introMain"
      "nameWidget"
      "introMedia";
    grid-template-columns:1fr;
  }
}

.orderFlowIntroLead{
  max-width:62ch;
}

.orderFlowGrid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(300px,440px);
  gap:clamp(18px,2.5vw,28px);
  align-items:start;
}

.orderFlowMain{
  min-width:0;
}

.orderFlowSidebar{
  position:sticky;
  top:clamp(72px,12vh,96px);
  align-self:start;
}

.orderFlowHint{
  margin:0 0 16px;
}

.orderFlowToolbar{
  display:flex;
  flex-wrap:wrap;
  align-items:flex-end;
  gap:12px 16px;
  margin-bottom:18px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(25,102,110,.12);
  background:rgba(255,255,255,.65);
}

.orderFlowToolbarField{
  margin:0;
  min-width:160px;
}

.orderFlowToolbarField label,
.orderFlowLabel{
  font-size:12px;
  font-weight:600;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:#63767b;
}

.orderFlowSelect{
  width:100%;
  min-height:44px;
  border-radius:12px;
  border:1px solid rgba(25,102,110,.2);
  padding:8px 12px;
  font:inherit;
  cursor:pointer;
  color-scheme:light;
  background-color:#fff;
  color:#1b2b2d;
}

.orderFlowToolbar .orderFlowToolbarField select.orderFlowSelect,
.orderFlowToolbarField select.orderFlowSelect{
  padding:8px 36px 8px 12px;
  background-color:#fff;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M6 9l6 6 6-6' stroke='%2319666e' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 12px center;
  background-size:16px 16px;
  color-scheme:light;
  color:#1b2b2d;
  border:1px solid rgba(25,102,110,.2);
  box-shadow:none;
  -webkit-appearance:none;
  appearance:none;
  transition:border-color .15s ease, box-shadow .15s ease, background-color .15s ease;
}

.orderFlowToolbar .orderFlowToolbarField select.orderFlowSelect:hover{
  border-color:rgba(25,102,110,.32);
  background-color:#fff;
  color:#1b2b2d;
  box-shadow:none;
}

.orderFlowToolbar .orderFlowToolbarField select.orderFlowSelect:focus{
  border-color:#19666e;
  background-color:#fff;
  color:#1b2b2d;
  box-shadow:0 0 0 3px rgba(25,102,110,.16);
  outline:none;
}

.orderFlowToolbar .orderFlowToolbarField select.orderFlowSelect:focus-visible{
  outline:none;
}

.orderFlowToolbar .orderFlowToolbarField select.orderFlowSelect option,
.orderFlowToolbarField select.orderFlowSelect option{
  background-color:#fff;
  color:#1b2b2d;
}

.orderFlowPromoOnly{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:14px;
  font-weight:600;
  color:#355056;
  cursor:pointer;
  user-select:none;
  margin:0 0 4px;
}

.orderFlowPromoOnly input{
  width:18px;
  height:18px;
  accent-color:#19666e;
}

.orderFlowTiles{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:18px;
}

@media (max-width:1100px){
  .orderFlowTiles{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}

@media (max-width:640px){
  .orderFlowTiles{
    grid-template-columns:1fr;
  }
}

.orderFlowTile{
  transition:border-color .15s ease, box-shadow .15s ease, background .15s ease;
}

.orderFlowTile--hidden{
  display:none !important;
}

.orderFlowTile--selected{
  border-color:rgba(167,199,63,.75) !important;
  box-shadow:0 0 0 1px rgba(167,199,63,.45), 0 12px 28px rgba(25,102,110,.1);
  background:linear-gradient(180deg, rgba(167,199,63,.08), rgba(255,255,255,.96));
}

.orderFlowTileVisual{
  border-radius:14px;
  overflow:hidden;
}

.orderFlowTiles .catalogProductVisual.orderFlowTileVisual{
  height:166px;
  min-height:166px;
}

/* order-flow.php: wyższy obszar zdjęcia; kalendarz (orderFlowTiles bez tej klasy) bez zmian */
.orderFlowPageCatalogTiles .catalogProductVisual.orderFlowTileVisual{
  height:274px;
  min-height:274px;
}

.orderFlowTileFooter{
  margin-top:auto;
  display:flex;
  flex-direction:column;
  gap:6px;
  padding-top:4px;
}

.orderFlowTilePriceRow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  min-width:0;
}

.orderFlowTilePrice,
.orderFlowTilePriceHint{
  flex:1;
  min-width:0;
  line-height:1.2;
}

.orderFlowTilePriceHint{
  font-size:12px;
}

.orderFlowTilePrice{
  margin:0;
}

.orderFlowSelectBtn--compact{
  flex-shrink:0;
  min-height:36px;
  padding:8px 14px;
  font-size:13px;
  font-weight:700;
  border-radius:12px;
}

.orderFlowDetailLink{
  align-self:flex-start;
  margin:0;
  padding:0;
  border:none;
  background:none;
  font:inherit;
  font-size:13px;
  font-weight:600;
  color:#19666e;
  text-decoration:underline;
  text-decoration-color:rgba(25,102,110,.35);
  text-underline-offset:3px;
  cursor:pointer;
  transition:color .15s ease, text-decoration-color .15s ease;
}

.orderFlowDetailLink:hover{
  color:#134f56;
  text-decoration-color:rgba(25,102,110,.55);
}

.orderFlowDetailLink:focus-visible{
  outline:2px solid rgba(167,199,63,.75);
  outline-offset:3px;
  border-radius:4px;
}

@media (max-width:640px){
  .orderFlowTilePriceRow .orderFlowSelectBtn--compact{
    width:auto;
    min-width:min(100%, 7.5rem);
  }
}

.orderFlowFormCard.orderFlowFormScope{
  background:#ffffff;
  border:1px solid rgba(25,102,110,.1);
  border-radius:18px;
  box-shadow:
    0 18px 44px rgba(15,40,42,.06),
    0 6px 16px rgba(15,40,42,.04);
}

.orderFlowFormInner{
  padding-top:clamp(20px, 2.4vw, 26px);
}

.orderFlowFormCard .sectionTitle h2{
  font-size:1.2rem;
  letter-spacing:-.02em;
  color:#1b2b2d;
}

.orderFlowFormLead{
  margin:0 0 19px;
  color:#63767b;
  font-size:14px;
  line-height:1.5;
}

.orderFlowForm{
  gap:19px;
}

.orderFlowForm .orderFlowField{
  margin-bottom:0;
}

.orderFlowForm .orderFlowField:last-of-type{
  margin-bottom:0;
}

.orderFlowFieldLabel,
.orderFlowForm .orderFlowField > label{
  display:block;
  font-size:13px;
  font-weight:600;
  letter-spacing:.02em;
  color:#355056;
  margin-bottom:10px;
}

.orderFlowInput,
.orderFlowFormScope .orderFlowForm .field select.orderFlowInput{
  width:100%;
  min-height:48px;
  padding:13px 16px;
  border-radius:12px;
  border:1px solid rgba(25,102,110,.18);
  background:#fff;
  font-size:15px;
  font-family:inherit;
  color:#1b2b2d;
  outline:none;
  transition:border-color .15s ease, box-shadow .15s ease, background .15s ease;
  box-sizing:border-box;
}

.orderFlowInput:hover{
  border-color:rgba(25,102,110,.3);
}

.orderFlowInput:focus{
  border-color:#19666e;
  box-shadow:0 0 0 3px rgba(25,102,110,.16);
}

.orderFlowInput:focus-visible{
  outline:none;
}

body.appShell--customerPanelHeader .orderFlowFormScope .field .orderFlowInput,
body.appShell--customerPanelHeader .orderFlowFormScope .field select.orderFlowInput{
  background:#fff;
  color:#1b2b2d;
  border-color:rgba(25,102,110,.18);
}

body.appShell--customerPanelHeader .orderFlowFormScope .field .orderFlowInput:hover{
  border-color:rgba(25,102,110,.3);
}

body.appShell--customerPanelHeader .orderFlowFormScope .field .orderFlowInput:focus{
  border-color:#19666e;
  box-shadow:0 0 0 3px rgba(25,102,110,.16);
}

.orderFlowDateWrap{
  display:block;
  width:100%;
  min-height:48px;
  border-radius:12px;
  border:1px solid rgba(25,102,110,.18);
  background:#fff;
  box-sizing:border-box;
  transition:border-color .15s ease, box-shadow .15s ease;
  cursor:pointer;
}

.orderFlowDateWrap:hover:not(:focus-within){
  border-color:rgba(25,102,110,.3);
}

.orderFlowDateWrap:focus-within{
  border-color:#19666e;
  box-shadow:0 0 0 3px rgba(25,102,110,.16);
}

.orderFlowDateWrap .orderFlowDateInput{
  display:block;
  width:100%;
  min-width:0;
  border:none !important;
  box-shadow:none !important;
  border-radius:12px;
  background:#fff !important;
  cursor:pointer;
}

.orderFlowDateWrap .orderFlowDateInput:hover{
  background:#fff !important;
}

body.appShell--customerPanelHeader .orderFlowDateWrap .orderFlowDateInput:hover,
body.appShell--customerPanelHeader .orderFlowDateWrap .orderFlowDateInput:focus{
  border:none !important;
  box-shadow:none !important;
}

.orderFlowFlatpickrCal.flatpickr-calendar{
  font-family:Poppins, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  border-radius:14px;
  border:1px solid rgba(25,102,110,.14);
  box-shadow:0 14px 40px rgba(15,40,42,.14);
  padding:4px 6px 10px;
  z-index:400;
  background:#fff;
}

.orderFlowFlatpickrCal .flatpickr-months{
  padding:8px 6px 4px;
}

.orderFlowFlatpickrCal .flatpickr-current-month{
  font-size:15px;
  font-weight:700;
  color:#1b2b2d;
  padding:4px 0 8px;
}

.orderFlowFlatpickrCal .flatpickr-weekdays{
  padding:6px 0 4px;
}

.orderFlowFlatpickrCal span.flatpickr-weekday{
  font-size:11px;
  font-weight:600;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:#63767b;
}

.orderFlowFlatpickrCal .flatpickr-day{
  border-radius:10px;
  border:1px solid transparent;
  color:#355056;
  font-weight:500;
  max-width:none;
  height:36px;
  line-height:36px;
}

.orderFlowFlatpickrCal .flatpickr-day:hover,
.orderFlowFlatpickrCal .flatpickr-day:focus{
  background:rgba(167,199,63,.22);
  border-color:rgba(167,199,63,.35);
  color:#1b3b2a;
}

.orderFlowFlatpickrCal .flatpickr-day.today{
  border-color:rgba(25,102,110,.22);
  background:rgba(25,102,110,.06);
  color:#19666e;
  font-weight:600;
}

.orderFlowFlatpickrCal .flatpickr-day.today:hover{
  background:rgba(167,199,63,.22);
  border-color:rgba(167,199,63,.38);
}

.orderFlowFlatpickrCal .flatpickr-day.selected,
.orderFlowFlatpickrCal .flatpickr-day.startRange,
.orderFlowFlatpickrCal .flatpickr-day.endRange{
  background:rgba(167,199,63,.42);
  border-color:rgba(167,199,63,.55);
  color:#1b3b2a;
  font-weight:600;
  box-shadow:none;
}

.orderFlowFlatpickrCal .flatpickr-day.selected:hover{
  background:rgba(167,199,63,.5);
  border-color:rgba(167,199,63,.62);
}

.orderFlowFlatpickrCal .flatpickr-day.flatpickr-disabled{
  color:#9eb4b7 !important;
  background:rgba(25,102,110,.05) !important;
  border-color:transparent !important;
  cursor:default !important;
  text-decoration:none !important;
  opacity:.88;
}

.orderFlowFlatpickrCal .flatpickr-day.flatpickr-disabled:hover{
  color:#9eb4b7 !important;
  background:rgba(25,102,110,.06) !important;
}

.orderFlowFlatpickrCal .flatpickr-months .flatpickr-prev-month,
.orderFlowFlatpickrCal .flatpickr-months .flatpickr-next-month{
  fill:#19666e;
}

.orderFlowInput--invalid{
  border-color:rgba(238,114,51,.55);
  box-shadow:0 0 0 3px rgba(238,114,51,.12);
}

.orderFlowQtyRow{
  display:flex;
  align-items:stretch;
}

.orderFlowQtyInput{
  max-width:120px;
  text-align:center;
  font-weight:600;
  font-variant-numeric:tabular-nums;
}

.orderFlowQtyHint{
  margin:10px 0 0;
  font-size:12px;
  color:#8a9a9c;
  line-height:1.4;
}

.orderFlowQtyError{
  margin:10px 0 0;
  font-size:13px;
  color:#b45309;
}

.orderFlowSegment{
  display:flex;
  width:100%;
  max-width:min(100%, 420px);
  margin:0 auto;
  padding:4px;
  gap:4px;
  border-radius:999px;
  background:rgba(25,102,110,.07);
  border:1px solid rgba(25,102,110,.12);
  box-sizing:border-box;
}

.orderFlowSegmentItem{
  position:relative;
  flex:1;
  min-width:0;
  margin:0;
  cursor:pointer;
}

.orderFlowSegmentInput{
  position:absolute;
  opacity:0;
  width:1px;
  height:1px;
  margin:0;
  border:0;
  clip:rect(0 0 0 0);
}

.orderFlowSegmentLabel{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:10px 12px;
  border-radius:999px;
  font-size:14px;
  font-weight:600;
  color:#4f666b;
  text-align:center;
  line-height:1.25;
  transition:background .15s ease, color .15s ease, box-shadow .15s ease;
}

.orderFlowSegmentItem:hover .orderFlowSegmentLabel{
  color:#19666e;
  background:rgba(255,255,255,.55);
}

.orderFlowSegmentInput:focus-visible + .orderFlowSegmentLabel{
  box-shadow:0 0 0 3px rgba(167,199,63,.45);
}

.orderFlowSegmentInput:checked + .orderFlowSegmentLabel{
  background:rgba(167,199,63,.42);
  color:#1b3b2a;
  box-shadow:0 1px 0 rgba(255,255,255,.65) inset;
}

.orderFlowCyclicWrap{
  margin-top:0;
}

.orderFlowCyclicNote{
  margin:12px 0 0;
  max-width:none;
}

.orderFlowSelectedBox{
  border-radius:14px;
  border:1px dashed rgba(25,102,110,.2);
  padding:16px 18px;
  margin-bottom:0;
  min-height:76px;
  background:rgba(249,252,251,.95);
}

.orderFlowSelectedEmpty{
  margin:0;
  color:#63767b;
  font-size:14px;
  line-height:1.45;
}

.orderFlowSelectedDetail strong{
  display:block;
  font-size:16px;
  font-weight:700;
  color:#1b2b2d;
  margin-bottom:6px;
}

.orderFlowSelectedDetail .note{
  margin:0;
  color:#4f666b;
}

.orderFlowSummary{
  margin:9px 0 0;
  padding:0;
  border-radius:16px;
  border:1px solid rgba(25,102,110,.12);
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(249,252,251,.96));
  overflow:hidden;
}

.orderFlowSummaryHead{
  padding:12px 16px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#63767b;
  background:rgba(25,102,110,.06);
  border-bottom:1px solid rgba(25,102,110,.1);
}

.orderFlowSummaryBody{
  padding:14px 16px 16px;
}

.orderFlowSummaryRow{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:12px;
  font-size:14px;
  color:#4f666b;
  margin-bottom:10px;
}

.orderFlowSummaryRow span{
  color:#63767b;
}

.orderFlowSummaryRow strong{
  font-weight:600;
  color:#1b2b2d;
  font-variant-numeric:tabular-nums;
}

.orderFlowSummaryDivider{
  height:1px;
  margin:12px 0 14px;
  background:linear-gradient(90deg, transparent, rgba(25,102,110,.14), transparent);
}

.orderFlowSummaryRow--total{
  margin-bottom:0;
  font-size:15px;
  color:#1b2b2d;
}

.orderFlowSummaryRow--total span{
  font-weight:600;
  color:#355056;
}

.orderFlowSummaryRow--total strong{
  font-size:1.35rem;
  font-weight:700;
  color:#19666e;
  letter-spacing:-.02em;
}

.orderFlowCyclicSummary{
  margin:12px 16px 16px;
  padding:12px 14px;
  border-radius:12px;
  background:rgba(25,102,110,.05);
  border:1px solid rgba(25,102,110,.08);
  max-width:none;
}

.orderFlowSubmitRow{
  margin-top:5px;
}

.orderFlowCta{
  width:100%;
  justify-content:center;
  min-height:50px;
  font-size:15px;
  font-weight:700;
  letter-spacing:.02em;
}

.orderFlowLegal{
  margin:23px 0 0;
  max-width:none;
  line-height:1.55;
  color:#8a9a9c;
  font-size:13px;
}

/* Order flow: modal produktu */
.orderFlowModal{
  position:fixed;
  inset:0;
  z-index:300;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:clamp(16px,4vw,32px);
  box-sizing:border-box;
}

.orderFlowModal[hidden]{
  display:none !important;
}

.orderFlowModalBackdrop{
  position:absolute;
  inset:0;
  background:rgba(15,40,42,.45);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}

.orderFlowModalDialog{
  position:relative;
  z-index:1;
  width:min(100%, 520px);
  max-height:min(88vh, 720px);
  overflow:auto;
  border-radius:18px;
  box-shadow:0 24px 48px rgba(15,40,42,.18);
  border:1px solid rgba(25,102,110,.12);
  background:#fff;
  padding:clamp(20px,3vw,28px);
  font-family:inherit;
}

.orderFlowModalClose{
  position:absolute;
  top:12px;
  right:12px;
  width:40px;
  height:40px;
  border-radius:999px;
  border:1px solid rgba(25,102,110,.15);
  background:rgba(255,255,255,.95);
  font-size:22px;
  line-height:1;
  color:#355056;
  cursor:pointer;
  transition:background .15s ease, border-color .15s ease;
}

.orderFlowModalClose:hover{
  background:rgba(167,199,63,.2);
  border-color:rgba(25,102,110,.25);
}

.orderFlowModalClose:focus-visible{
  outline:3px solid rgba(167,199,63,.55);
  outline-offset:2px;
}

.orderFlowModalMedia{
  border-radius:14px;
  overflow:hidden;
  margin-bottom:16px;
  border:1px solid rgba(25,102,110,.1);
  background:rgba(249,252,251,.9);
}

.orderFlowModalMedia img{
  display:block;
  width:100%;
  height:auto;
  max-height:min(42vh, 320px);
  object-fit:cover;
}

.orderFlowModalTitle{
  margin:0 0 8px;
  padding-right:28px;
  font-size:1.35rem;
  font-weight:700;
  letter-spacing:-.02em;
  color:#1b2b2d;
}

.orderFlowModalMeta{
  margin:0 0 10px;
  font-size:12px;
  font-weight:600;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:#63767b;
}

.orderFlowModalPrice{
  font-size:1.15rem;
  font-weight:700;
  color:#19666e;
  margin-bottom:14px;
}

.orderFlowModalBody{
  font-size:14px;
  line-height:1.55;
  color:#355056;
  margin-bottom:20px;
  white-space:pre-wrap;
}

.orderFlowModalActions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:flex-end;
}

body.orderFlowModalOpen{
  overflow:hidden;
}

body.calendarProductPickerOpen{
  overflow:hidden;
}

.orderFlowModal--productPicker .orderFlowModalDialog--picker{
  width:min(100%, 920px);
  max-height:min(92vh, 820px);
  display:flex;
  flex-direction:column;
  padding:clamp(18px,2.5vw,26px);
}
.calendarPickerModalLead{
  margin:0 0 14px;
  font-size:13px;
  color:var(--sf-muted);
}
.calendarPickerScroll{
  flex:1;
  min-height:0;
  overflow:auto;
  margin-top:2px;
  padding:2px 4px 8px 0;
}
.calendarSelectedProductBox{
  margin-bottom:10px;
}
.calendarPickBouquetRow{
  margin-top:0;
}
.calendarBouquetField .orderFlowSelectedBox{
  min-height:52px;
}

@media (max-width:960px){
  .orderFlowGrid{
    grid-template-columns:1fr;
  }

  .orderFlowSidebar{
    position:static;
  }
}

.homeLanding{
  --home-primary:#19666e;
  --home-accent:#a7c73f;
  --home-cta:#ee7233;
  --home-radius:14px;
  --home-shadow:0 12px 40px rgba(15,40,42,.08);
  --home-shadow-hover:0 18px 48px rgba(15,40,42,.12);
}

.homeHeroSection{
  position:relative;
  min-height:100vh;
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  overflow:hidden;
}

.homeHeroBg{
  position:absolute;
  inset:0;
  overflow:hidden;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}

.homeHeroVideo{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}

.homeHeroScrim{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.4);
}

.homeHeroContent{
  position:relative;
  z-index:1;
  padding:clamp(32px,6vw,80px) clamp(20px,4vw,48px);
  max-width:720px;
}

.homeHeroContent h1{
  margin:0;
  font-size:clamp(1.85rem,4.2vw,2.85rem);
  font-weight:700;
  letter-spacing:-.03em;
  line-height:1.15;
  color:#fff;
  text-shadow:0 2px 28px rgba(0,0,0,.35);
}

.homeHeroLead{
  margin:clamp(16px,2.5vw,22px) auto 0;
  max-width:52ch;
  font-size:clamp(1rem,1.6vw,1.15rem);
  line-height:1.55;
  color:rgba(255,255,255,.94);
  text-shadow:0 1px 18px rgba(0,0,0,.35);
}

.homeHeroContent .homeBtn{
  margin-top:clamp(24px,3vw,32px);
}

.homeBtn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:14px 26px;
  border-radius:999px;
  font-weight:600;
  font-size:15px;
  border:2px solid transparent;
  text-decoration:none;
  transition:transform .1s ease, box-shadow .15s ease, background .15s ease;
}

.homeBtn:focus-visible{
  outline:3px solid rgba(167,199,63,.55);
  outline-offset:3px;
}

.homeBtnCta{
  background:var(--home-cta);
  color:#fff;
  box-shadow:0 8px 28px rgba(238,114,51,.35);
}

.homeBtnCta:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 32px rgba(238,114,51,.42);
}

.homeSection{
  padding:clamp(36px,5vw,64px) 0;
}

.homeInner{
  max-width:1120px;
  margin:0 auto;
  padding:0 clamp(16px,3vw,28px);
}

.homeSectionTitle{
  margin:0 0 clamp(20px,3vw,30px);
  font-size:clamp(1.5rem,2.6vw,1.85rem);
  font-weight:700;
  letter-spacing:-.02em;
  color:var(--home-primary);
  text-align:center;
}

.homeSectionTitleLeft{
  text-align:left;
  margin-bottom:clamp(18px,2.5vw,26px);
}

.homeProductGrid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
  gap:clamp(20px,3vw,28px);
}

.homeProductCard{
  background:#fff;
  border-radius:var(--home-radius);
  box-shadow:var(--home-shadow);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:transform .15s ease, box-shadow .15s ease;
}

.homeProductCard:hover{
  transform:translateY(-4px);
  box-shadow:var(--home-shadow-hover);
}

.homeProductImg{
  aspect-ratio:4/3;
  background-size:cover;
  background-position:center;
}

.homeProductBody{
  padding:20px 22px 22px;
}

.homeProductName{
  margin:0;
  font-size:1.1rem;
  font-weight:600;
  color:#1b2b2d;
}

.homeProductMeta{
  margin:8px 0 0;
  font-size:14px;
  color:#5f7479;
}

.homePromoBar{
  width:100%;
  background:var(--home-primary);
  color:#fff;
  padding:clamp(18px,3vw,26px) clamp(16px,3vw,28px);
}

.homePromoInner{
  max-width:1120px;
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  flex-wrap:wrap;
}

.homePromoTitle{
  margin:0;
  font-size:clamp(1.15rem,2.2vw,1.45rem);
  font-weight:700;
}

.homePromoSub{
  margin:8px 0 0;
  max-width:54ch;
  font-size:15px;
  line-height:1.5;
  color:rgba(255,255,255,.88);
}

.homeBtnPromo{
  flex-shrink:0;
  background:var(--home-accent);
  color:#2a3210;
  font-weight:600;
  box-shadow:0 8px 24px rgba(0,0,0,.15);
}

.homeBtnPromo:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 28px rgba(0,0,0,.2);
}

.homeSplit{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(22px,4vw,44px);
  align-items:center;
}

.homeSplitPhoto{
  border-radius:clamp(12px,2vw,16px);
  min-height:clamp(240px,32vw,400px);
  background-size:cover;
  background-position:center;
  box-shadow:var(--home-shadow);
}

.homeFeatureList{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:clamp(20px,3vw,28px);
}

.homeFeatureItem{
  margin:0;
  padding:clamp(18px,2.5vw,22px) clamp(18px,2.5vw,24px);
  background:#fff;
  border-radius:var(--home-radius);
  box-shadow:var(--home-shadow);
}

.homeFeatureHeading{
  margin:0 0 8px;
  font-size:1.05rem;
  font-weight:600;
  color:var(--home-primary);
}

.homeFeatureItem p{
  margin:0;
  color:#4a5f63;
  line-height:1.55;
  font-size:15px;
}

.homeProse{
  margin:0 0 16px;
  color:#4a5f63;
  line-height:1.6;
  font-size:16px;
}

.homeBulletList{
  margin:0 0 24px;
  padding:0 0 0 1.15em;
  color:#355056;
  line-height:1.7;
}

.homeFinalCta{
  padding-bottom:clamp(44px,7vw,72px);
}

.homeFinalInner{
  text-align:center;
  padding:clamp(32px,4.5vw,48px) clamp(20px,4vw,40px);
  background:#fff;
  border-radius:clamp(14px,2vw,18px);
  box-shadow:var(--home-shadow);
  max-width:720px;
}

.homeFinalTitle{
  margin:0 0 12px;
  font-size:clamp(1.45rem,2.8vw,1.9rem);
  font-weight:700;
  color:var(--home-primary);
  letter-spacing:-.02em;
}

.homeFinalLead{
  margin:0 auto 24px;
  max-width:48ch;
}

@media (min-width:769px){
  .homeHeroSection{
    justify-content:flex-start;
    text-align:left;
  }

  .homeHeroContent{
    margin-left:clamp(0px,4vw,72px);
    margin-right:auto;
  }

  .homeHeroLead{
    margin-left:0;
    margin-right:0;
  }
}

@media (max-width:900px){
  .homeSplit{
    grid-template-columns:1fr;
    gap:28px;
  }

  .homeProductGrid{
    grid-template-columns:repeat(auto-fit, minmax(160px, 1fr));
  }

  .homePromoInner{
    flex-direction:column;
    align-items:flex-start;
  }

  .homeBtnPromo{
    width:100%;
    justify-content:center;
  }

  .homeSiteHeaderInner{
    flex-wrap:wrap;
    padding:14px 16px;
    gap:12px 16px;
  }

  .homeSiteLogo{
    height:44px;
  }

  .homeSiteNav{
    order:3;
    flex:1 1 100%;
    justify-content:center;
    gap:10px 14px;
    padding-top:12px;
    margin-top:4px;
    border-top:1px solid rgba(25,102,110,.1);
  }

  .homeSiteNavLink{
    font-size:14px;
    padding:8px 2px;
  }

  .homeSiteActions{
    margin-left:auto;
    gap:8px;
  }

  .homeSiteLogin{
    padding:9px 12px;
  }

  .homeSiteLoginText{
    position:absolute;
    width:1px;
    height:1px;
    padding:0;
    margin:-1px;
    overflow:hidden;
    clip:rect(0,0,0,0);
    white-space:nowrap;
    border:0;
  }

  .homeSiteRegisterCta{
    padding:11px 16px;
    font-size:13px;
  }

  .homeLanding section[id]{
    scroll-margin-top:120px;
  }
}

/* --- Register (B2B onboarding) — view-only; scoped via :has(.registerOnboarding) --- */
body.appShell:has(.registerOnboarding),
body.appShell:has(.loginOnboarding){
  font-family:Poppins, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  color:#1b2b2d;
  background:#ffffff;
}

body.appShell:has(.registerOnboarding) .pageContent,
body.appShell:has(.loginOnboarding) .pageContent{
  gap:0;
}

body.appShell:has(.registerOnboarding) .container{
  max-width:1180px;
  padding:clamp(12px,2vw,20px) clamp(16px,3vw,28px) 48px;
  overflow-x:clip;
}

body.appShell:has(.loginOnboarding) .container{
  max-width:100%;
  width:100%;
  padding:0 0 48px;
}

body.appShell:has(.registerOnboarding) .topbar,
body.appShell:has(.registerOnboarding) .navRow,
body.appShell:has(.loginOnboarding) .topbar,
body.appShell:has(.loginOnboarding) .navRow{
  display:none !important;
}

body.appShell:has(.registerOnboarding) .footerLine{
  margin-top:40px;
  border-top-color:rgba(25,102,110,.12);
  color:#6a8287;
}

body.appShell:has(.loginOnboarding) .footerLine{
  margin-top:0;
  padding:28px clamp(16px,3vw,32px) 0;
  max-width:1180px;
  margin-left:auto;
  margin-right:auto;
  border-top-color:rgba(25,102,110,.12);
  color:#6a8287;
}

.registerOnboarding,
.loginOnboarding{
  --reg-primary:#19666e;
  --reg-accent:#a7c73f;
  --reg-cta:#ee7233;
  --reg-line:rgba(25,102,110,.14);
  --reg-muted:#5f7479;
}

.registerMinimalHeader{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  width:100%;
  margin-bottom:clamp(28px,4vw,40px);
  min-height:52px;
}

.registerHeaderBrand{
  display:flex;
  align-items:center;
  gap:clamp(8px,1.5vw,14px);
}

.registerBack{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  min-width:48px;
  min-height:48px;
  margin:-6px 0;
  color:#19666e;
  text-decoration:none;
  transition:color .15s ease;
}

.registerBack:hover{
  color:#124850;
}

.registerBackSvg{
  display:block;
  width:clamp(42px,6vw,54px);
  height:clamp(42px,6vw,54px);
}

.registerBack:focus-visible{
  outline:3px solid rgba(167,199,63,.55);
  outline-offset:2px;
  border-radius:8px;
}

.registerHeaderLogoLink{
  display:flex;
  align-items:center;
  line-height:0;
  text-decoration:none;
}

.registerHeaderLogoImg{
  display:block;
  height:clamp(40px,4.4vw,49px);
  width:auto;
  object-fit:contain;
}

.registerOnboardingGrid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:clamp(20px,3.5vw,32px);
  align-items:start;
}

.registerOnboardingAside{
  padding-top:0;
}

.registerAsideTitle{
  margin:0 0 12px;
  font-size:clamp(1.5rem,2.5vw,1.95rem);
  font-weight:800;
  letter-spacing:-.03em;
  line-height:1.18;
  color:#0a2326;
}

.registerAsideLead{
  margin:0 0 18px;
  font-size:1.05rem;
  line-height:1.6;
  color:var(--reg-muted);
  max-width:42ch;
}

.registerBenefitList{
  margin:0;
  padding:0;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:14px;
}

.registerBenefitList li{
  position:relative;
  padding-left:28px;
  font-size:15px;
  line-height:1.5;
  color:#355056;
}

.registerBenefitList li::before{
  content:'';
  position:absolute;
  left:0;
  top:.35em;
  width:16px;
  height:16px;
  border-radius:50%;
  background:rgba(167,199,63,.22);
  border:2px solid var(--reg-accent);
  box-sizing:border-box;
}

.registerBenefitList li::after{
  content:'';
  position:absolute;
  left:5px;
  top:.55em;
  width:5px;
  height:9px;
  border:solid var(--reg-primary);
  border-width:0 2px 2px 0;
  transform:rotate(45deg);
}

.registerOnboardingFormCol{
  min-width:0;
  padding-top:clamp(10px,1.8vw,22px);
}

.registerFormCard{
  background:#ffffff;
  border:1px solid rgba(25,102,110,.1);
  border-radius:16px;
  box-shadow:
    0 18px 44px rgba(15,40,42,.07),
    0 6px 16px rgba(15,40,42,.04);
  padding:clamp(20px,3.5vw,32px);
}

.registerLoginHint{
  margin:0 0 14px;
  font-size:12px;
  line-height:1.45;
  color:#9aa8ac;
  font-weight:400;
  text-align:right;
}

.registerLoginHintLink{
  color:#7d8f94;
  font-weight:500;
  text-decoration:underline;
  text-decoration-color:rgba(125,143,148,.35);
  text-underline-offset:2px;
}

.registerLoginHintLink:hover{
  color:#19666e;
  text-decoration-color:rgba(25,102,110,.42);
}

.registerAlert{
  margin:0 0 16px;
  padding:14px 16px;
  border-radius:12px;
  font-size:14px;
  line-height:1.45;
}

.registerAlertError{
  background:rgba(238,114,51,.08);
  border:1px solid rgba(238,114,51,.28);
  color:#8f3f18;
}

.registerAlertOk{
  background:rgba(34,197,94,.1);
  border:1px solid rgba(34,197,94,.32);
  color:#14532d;
}

.registerForm{
  display:flex;
  flex-direction:column;
  gap:16px;
}

.registerField{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.registerFieldHint{
  font-size:12px;
  color:#6b7b80;
  margin-top:-2px;
  line-height:1.4;
}

.registerLabel{
  font-size:13px;
  font-weight:600;
  letter-spacing:.02em;
  color:#355056;
}

.registerInput{
  width:100%;
  padding:14px 16px;
  border-radius:12px;
  border:1px solid var(--reg-line);
  background:#fff;
  font-size:15px;
  font-family:inherit;
  color:#1b2b2d;
  transition:border-color .15s ease, box-shadow .15s ease;
}

.registerInput:hover{
  border-color:rgba(25,102,110,.28);
}

.registerInput:focus{
  outline:none;
  border-color:var(--reg-primary);
  box-shadow:0 0 0 3px rgba(25,102,110,.18);
}

.registerFormActions{
  margin-top:4px;
}

.registerCta{
  width:100%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:15px 24px;
  border:none;
  border-radius:12px;
  font-size:15px;
  font-weight:700;
  font-family:inherit;
  letter-spacing:.02em;
  color:#fff;
  background:var(--reg-cta);
  cursor:pointer;
  box-shadow:0 8px 24px rgba(238,114,51,.32);
  transition:transform .1s ease, box-shadow .15s ease;
}

.registerCta:hover{
  transform:translateY(-1px);
  box-shadow:0 12px 28px rgba(238,114,51,.4);
}

.registerCta:focus-visible{
  outline:3px solid rgba(167,199,63,.55);
  outline-offset:3px;
}

.registerFootnote{
  margin:0;
  font-size:13px;
  line-height:1.55;
  color:#3d5156;
  font-weight:500;
}

.registerOptionalToggle{
  margin:-4px 0 0;
}

.registerOptionalBtn{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 2px;
  background:none;
  border:none;
  cursor:pointer;
  font:inherit;
  font-size:13px;
  font-weight:600;
  color:var(--reg-primary,#19666e);
  letter-spacing:.01em;
  transition:color .15s ease;
}

.registerOptionalBtn:hover{
  color:#0e454b;
}

.registerOptionalChevron{
  transition:transform .25s ease;
}

.registerOptionalBtn[aria-expanded="true"] .registerOptionalChevron{
  transform:rotate(180deg);
}

.registerOptionalFields{
  display:grid;
  grid-template-rows:0fr;
  transition:grid-template-rows .3s ease;
}

.registerOptionalInner{
  overflow:hidden;
  display:flex;
  flex-direction:column;
  gap:16px;
  opacity:0;
  transition:opacity .25s ease;
}

.registerOptionalFields.registerOptionalOpen{
  grid-template-rows:1fr;
}

.registerOptionalFields.registerOptionalOpen .registerOptionalInner{
  opacity:1;
  padding-top:4px;
}

@media (max-width:900px){
  .registerOnboardingGrid{
    grid-template-columns:1fr;
    gap:22px;
  }

  .registerOnboardingAside{
    order:2;
    padding-top:0;
  }

  .registerOnboardingFormCol{
    order:1;
  }

  .registerAsideLead{
    max-width:none;
  }
}

/* --- Login (spójny z rejestracją) — view-only --- */
.loginTopAlign{
  max-width:1180px;
  margin-left:auto;
  margin-right:auto;
  padding:clamp(12px,2vw,20px) clamp(16px,3vw,28px) 0;
  width:100%;
  box-sizing:border-box;
}

.loginSplit{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  align-items:stretch;
  width:100%;
  min-height:calc(100svh - clamp(100px,15vh,140px));
}

.loginBrandPanel{
  background:#a7c73f;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:clamp(36px,5vw,64px) clamp(28px,4vw,52px);
}

.loginBrandInner{
  max-width:38ch;
  margin:0 auto;
}

.loginBrandText{
  margin:0;
  font-size:clamp(1.15rem,2vw,1.35rem);
  line-height:1.55;
  font-weight:400;
  color:#ffffff;
  letter-spacing:.01em;
}

.loginBrandHello{
  display:block;
  font-size:clamp(1.85rem,3.2vw,2.5rem);
  font-weight:700;
  line-height:1.15;
  letter-spacing:-.03em;
  margin-bottom:clamp(14px,2vw,20px);
}

.loginFormColumn{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:clamp(32px,4.5vw,56px) clamp(24px,4vw,48px);
  background:#ffffff;
}

.loginFormCard{
  display:flex;
  flex-direction:column;
  width:100%;
  max-width:440px;
  min-width:0;
  background:#ffffff;
  border:1px solid rgba(25,102,110,.1);
  border-radius:16px;
  box-shadow:
    0 18px 44px rgba(15,40,42,.07),
    0 6px 16px rgba(15,40,42,.04);
  padding:clamp(20px,3.5vw,32px);
}

.loginFormHead{
  margin:0 0 20px;
}

.loginFormTitle{
  margin:0 0 8px;
  font-size:clamp(1.35rem,2.4vw,1.55rem);
  font-weight:800;
  letter-spacing:-.03em;
  line-height:1.2;
  color:#0a2326;
}

.loginFormLead{
  margin:0;
  font-size:14px;
  line-height:1.55;
  color:var(--reg-muted);
  font-weight:500;
}

.loginFormCard .registerAlert{
  margin:0 0 16px;
}

.loginFormCard .registerForm{
  gap:16px;
}

.loginFormCard .registerField{
  gap:8px;
}

.loginFormCard .registerFormActions{
  margin-top:4px;
}

.loginFormCard .registerInput{
  min-height:48px;
  box-sizing:border-box;
}

.loginFormMeta{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:14px;
  margin-top:20px;
  text-align:center;
}

.loginFormCard .loginForgotWrap{
  margin:0;
  text-align:center;
}

.loginForgotLink{
  font-size:12px;
  font-weight:500;
  color:#6f8287;
  text-decoration:underline;
  text-decoration-color:rgba(111,130,135,.4);
  text-underline-offset:2px;
}

.loginForgotLink:hover{
  color:#19666e;
  text-decoration-color:rgba(25,102,110,.45);
}

.loginFormCard .loginRegisterHint{
  margin:0;
  font-size:13px;
  line-height:1.5;
  text-align:center;
  color:#9aa8ac;
}

.loginFormCard .registerCta{
  width:100%;
}

.loginRegisterLink{
  font-weight:500;
  color:#6f8287;
  text-decoration:underline;
  text-decoration-color:rgba(111,130,135,.4);
  text-underline-offset:2px;
  margin-left:4px;
}

.loginRegisterLink:hover{
  color:#19666e;
  text-decoration-color:rgba(25,102,110,.45);
}

@media (max-width:900px){
  .loginSplit{
    grid-template-columns:1fr;
    min-height:auto;
  }

  .loginFormColumn{
    order:1;
    padding:clamp(24px,5vw,36px) clamp(16px,4vw,24px);
  }

  .loginBrandPanel{
    order:2;
    min-height:auto;
    padding:clamp(28px,5vw,40px) clamp(20px,4vw,32px);
  }
}

/* Admin gate (/admin/gate) — współdzieli układ i komponenty z customer/login */
.adminGatePage .loginFormCard .registerAlertOk{
  margin:0 0 16px;
}

.adminGatePage .loginFormLead{
  max-width:42ch;
}

.adminGatePage .adminGateFootnote{
  max-width:36ch;
  margin-left:auto;
  margin-right:auto;
  font-size:12px;
  line-height:1.55;
  color:#7a8f94;
}

/* Admin login (/admin/login) — jak admin/gate + customer/login */
.adminLoginPage .loginFormCard .registerAlertOk{
  margin:0 0 16px;
}

.adminLoginPage .loginFormLead{
  max-width:42ch;
}

.adminLoginPage .adminLoginFootnote{
  max-width:36ch;
  margin-left:auto;
  margin-right:auto;
  font-size:12px;
  line-height:1.55;
  color:#7a8f94;
}

/* --- Stage 28.1: Admin product list (spójnie z admin pricing / orders) --- */

.adminProductsPage{
  display:flex;
  flex-direction:column;
  gap:clamp(16px, 2vw, 22px);
}

.adminProductsHeaderInner{
  display:flex;
  flex-direction:column;
  gap:12px;
  padding-top:clamp(20px, 2.4vw, 28px);
  padding-bottom:clamp(20px, 2.4vw, 28px);
}

.adminProductsTitle{
  margin:0;
  font-size:clamp(26px, 3.2vw, 34px);
  font-weight:800;
  letter-spacing:-.03em;
  line-height:1.15;
  color:#184950;
}

.adminProductsLead{
  margin:0;
  color:#4f666b;
  font-size:var(--font-md);
  line-height:1.6;
  max-width:68ch;
}

.adminProductsCardInner{
  padding-top:clamp(20px, 2.4vw, 28px);
  padding-bottom:clamp(22px, 2.6vw, 32px);
}

.adminProductsFlash{
  margin-bottom:18px;
}

.adminProductsEmpty{
  margin-top:8px;
}

.adminProductsToolbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px 24px;
  flex-wrap:wrap;
  padding-bottom:18px;
  margin-bottom:6px;
  border-bottom:1px solid var(--sf-line-soft);
}

.adminProductsToolbarLeft{
  min-width:min(100%, 200px);
}

.adminProductsToolbarRight{
  display:flex;
  align-items:center;
  gap:10px;
  flex-shrink:0;
}

.adminProductsMeta{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px 10px;
  font-size:14px;
  color:#4f666b;
  font-weight:500;
}

.adminProductsMeta strong{
  color:#173d43;
  font-weight:800;
}

.adminProductsSep{
  color:rgba(25,102,110,.35);
  font-weight:700;
}

.adminProductsAddBtn{
  white-space:nowrap;
  min-height:44px;
  padding-left:20px;
  padding-right:20px;
  border-radius:12px;
  font-weight:700;
}

.adminProductsTableWrap{
  margin-top:8px;
  border-radius:14px;
  border:1px solid var(--sf-line);
  background:linear-gradient(180deg, #fdfefe, #f8fbfa);
  box-shadow:0 1px 0 rgba(255,255,255,.8), var(--sf-shadow-1);
  -webkit-overflow-scrolling:touch;
}

.adminProductsTable{
  min-width:860px;
  font-size:14px;
  line-height:1.45;
}

.adminProductsPage .adminProductsTable th{
  color:#4a5f64;
  font-weight:800;
  font-size:11px;
  letter-spacing:.07em;
  text-transform:uppercase;
  background:linear-gradient(180deg, #f4f9f8, #eef4f3);
  border-bottom:2px solid rgba(25,102,110,.14);
  padding:14px 14px !important;
  vertical-align:bottom;
}

.adminProductsPage .adminProductsTable td{
  padding:14px 14px !important;
  border-bottom:1px solid #e3ebe9;
  vertical-align:middle;
}

.adminProductsPage .adminProductsTable tbody tr:nth-child(even) td{
  background:rgba(25,102,110,.02);
}

.adminProductsPage .adminProductsTable tbody tr:hover td{
  background:rgba(25,102,110,.06);
}

.adminProdColSort{
  width:48px;
  text-align:center !important;
}

.adminProdColCenter{
  text-align:center !important;
}

.adminProdColNum{
  font-variant-numeric:tabular-nums;
}

.adminProdColActions{
  text-align:right !important;
  width:1%;
  white-space:nowrap;
}

.adminProdThActionsLabel{
  display:inline-block;
}

.adminProdCellOrder{
  font-weight:700;
  font-variant-numeric:tabular-nums;
  color:#5f7479;
  font-size:13px;
}

.adminProdCellName{
  min-width:140px;
}

.adminProdName{
  font-weight:700;
  color:#173d43;
  display:block;
  line-height:1.4;
}

.adminProdSku{
  display:block;
  font-size:12px;
  font-weight:600;
  color:#708489;
  margin-top:4px;
}

.adminProdCellSlug,
.adminProdSlug{
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  font-size:12px;
  letter-spacing:-.01em;
  word-break:break-word;
  color:#4f666b;
  max-width:18rem;
}

.adminProdTypePill{
  display:inline-flex;
  align-items:center;
  padding:5px 11px;
  border-radius:999px;
  font-size:11px;
  font-weight:800;
  letter-spacing:.02em;
  white-space:nowrap;
  border:1px solid transparent;
}

.adminProdType--mono{
  background:rgba(25,102,110,.1);
  border-color:rgba(25,102,110,.2);
  color:#0f4a50;
}
.adminProdType--seasonal{
  background:rgba(167,199,63,.14);
  border-color:rgba(138,168,58,.28);
  color:#3f5a0f;
}
.adminProdType--holiday{
  background:rgba(238,114,51,.1);
  border-color:rgba(238,114,51,.22);
  color:#8f3f18;
}
.adminProdType--wreath{
  background:rgba(140,100,180,.1);
  border-color:rgba(140,100,180,.22);
  color:#5b3d75;
}
.adminProdType--special{
  background:rgba(80,140,200,.1);
  border-color:rgba(80,140,200,.22);
  color:#2d5a7a;
}

.adminProdStatusChip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:5px 12px;
  border-radius:999px;
  font-size:11px;
  font-weight:800;
  letter-spacing:.02em;
}

.adminProdStatusChip--active{
  border:1px solid rgba(22,163,74,.4);
  background:rgba(34,197,94,.1);
  color:#14532d;
}

.adminProdStatusChip--inactive{
  border:1px solid #c5ced1;
  background:#eef1f3;
  color:#4a5565;
}

.adminProdFeaturedBadge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:4px 10px;
  border-radius:999px;
  font-size:10px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:#8f3f18;
  border:1px solid rgba(238,114,51,.35);
  background:rgba(238,114,51,.08);
}

.adminProdCellDash{
  color:#a8b8bc;
  font-weight:600;
}

.adminProdCellNum{
  font-weight:700;
  color:#2d4549;
}

.adminProdRow--inactive td{
  color:#63767b;
}

.adminProdRow--inactive .adminProdName{
  color:#4f666b;
}

.adminProdActions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:wrap;
  gap:8px;
}

.adminProdToggleForm{
  display:inline-flex;
  margin:0;
}

.adminProdLinkBtn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:38px;
  padding:8px 14px;
  border-radius:10px;
  border:1px solid rgba(25,102,110,.35);
  background:var(--sf-surface-strong);
  font-size:12px;
  font-weight:700;
  color:var(--sf-primary);
  text-decoration:none;
  transition:border-color .15s ease, background .15s ease, box-shadow .15s ease;
}

.adminProdLinkBtn:hover{
  border-color:rgba(25,102,110,.55);
  background:rgba(25,102,110,.06);
  box-shadow:0 4px 12px rgba(25,102,110,.08);
}

.adminProdLinkBtn:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(25,102,110,.2);
}

.adminProdGhostBtn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:38px;
  padding:8px 12px;
  margin:0;
  border-radius:10px;
  border:1px dashed var(--sf-line);
  background:transparent;
  font-size:12px;
  font-weight:700;
  color:#4f666b;
  cursor:pointer;
  font-family:inherit;
  transition:border-color .15s ease, background .15s ease, color .15s ease;
}

.adminProdGhostBtn:hover{
  border-color:rgba(25,102,110,.35);
  border-style:solid;
  background:rgba(25,102,110,.04);
  color:var(--sf-primary);
}

.adminProdGhostBtn:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(25,102,110,.18);
}

@media (max-width:960px){
  .adminProductsToolbar{
    align-items:flex-start;
    flex-direction:column;
  }

  .adminProductsToolbarRight{
    width:100%;
  }

  .adminProductsAddBtn{
    width:100%;
    justify-content:center;
  }
}

/* --- Admin: lista firm (spójnie z produktami / cennikami) --- */

.adminCompaniesPage{
  display:flex;
  flex-direction:column;
  gap:clamp(16px, 2vw, 22px);
}

.adminCompaniesHeaderInner{
  display:flex;
  flex-direction:column;
  gap:12px;
  padding-top:clamp(20px, 2.4vw, 28px);
  padding-bottom:clamp(20px, 2.4vw, 28px);
}

.adminCompaniesTitle{
  margin:0;
  font-size:clamp(26px, 3.2vw, 34px);
  font-weight:800;
  letter-spacing:-.03em;
  line-height:1.15;
  color:#184950;
}

.adminCompaniesLead{
  margin:0;
  color:#4f666b;
  font-size:var(--font-md);
  line-height:1.6;
  max-width:68ch;
}

.adminCompaniesCardInner{
  padding-top:clamp(20px, 2.4vw, 28px);
  padding-bottom:clamp(22px, 2.6vw, 32px);
}

.adminCompaniesEmpty{
  margin-top:8px;
}

.adminCompaniesToolbar{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px 24px;
  flex-wrap:wrap;
  padding-bottom:18px;
  margin-bottom:6px;
  border-bottom:1px solid var(--sf-line-soft);
}

.adminCompaniesToolbarLeft{
  min-width:min(100%, 200px);
  padding-top:4px;
}

.adminCompaniesToolbarRight{
  flex:1;
  min-width:min(100%, 320px);
}

.adminCompaniesMeta{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px 10px;
  font-size:14px;
  color:#4f666b;
  font-weight:500;
}

.adminCompaniesMeta strong{
  color:#173d43;
  font-weight:800;
}

.adminCompaniesSep{
  color:rgba(25,102,110,.35);
  font-weight:700;
}

.adminCompaniesFilterHint{
  font-size:13px;
  color:#708489;
}

.adminCompaniesFilterHint strong{
  color:var(--sf-primary);
  font-weight:800;
}

.adminCompaniesSegment{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:6px;
  padding:6px;
  width:100%;
  border-radius:14px;
  border:1px solid var(--sf-line-soft);
  background:var(--sf-nav);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.75);
}

.adminCompaniesPill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:0 16px;
  border-radius:10px;
  font-size:13px;
  font-weight:700;
  border:1px solid transparent;
  color:#4f666b;
  text-decoration:none;
  transition:background .15s ease, color .15s ease, border-color .15s ease, box-shadow .15s ease;
}

.adminCompaniesPill:hover{
  background:var(--sf-surface-strong);
  color:var(--sf-primary);
  border-color:var(--sf-line-soft);
}

.adminCompaniesPill--active{
  border-color:rgba(25,102,110,.32);
  background:rgba(25,102,110,.12);
  color:#0f4a50;
  box-shadow:
    inset 4px 0 0 #19666e,
    inset 0 1px 0 rgba(255,255,255,.5),
    0 1px 0 rgba(25,102,110,.06);
}

.adminCompaniesTableWrap{
  margin-top:8px;
  border-radius:14px;
  border:1px solid var(--sf-line);
  background:linear-gradient(180deg, #fdfefe, #f8fbfa);
  box-shadow:0 1px 0 rgba(255,255,255,.8), var(--sf-shadow-1);
  -webkit-overflow-scrolling:touch;
}

.adminCompaniesTable{
  min-width:920px;
  font-size:14px;
  line-height:1.45;
}

.adminCompaniesPage .adminCompaniesTable th{
  color:#4a5f64;
  font-weight:800;
  font-size:11px;
  letter-spacing:.07em;
  text-transform:uppercase;
  background:linear-gradient(180deg, #f4f9f8, #eef4f3);
  border-bottom:2px solid rgba(25,102,110,.14);
  padding:14px 14px !important;
  vertical-align:bottom;
}

.adminCompaniesPage .adminCompaniesTable td{
  padding:14px 14px !important;
  border-bottom:1px solid #e3ebe9;
  vertical-align:middle;
}

.adminCompaniesPage .adminCompaniesTable tbody tr:nth-child(even) td{
  background:rgba(25,102,110,.02);
}

.adminCompaniesPage .adminCompaniesTable tbody tr:hover td{
  background:rgba(25,102,110,.06);
}

.adminCompColId{
  width:52px;
  text-align:center !important;
}

.adminCompColCenter{
  text-align:center !important;
}

.adminCompColNum{
  font-variant-numeric:tabular-nums;
}

.adminCompColActions{
  text-align:right !important;
  width:1%;
  white-space:nowrap;
}

.adminCompThActionsLabel{
  display:inline-block;
}

.adminCompCellId{
  font-weight:700;
  font-variant-numeric:tabular-nums;
  color:#5f7479;
  font-size:13px;
}

.adminCompCellName{
  min-width:140px;
}

.adminCompName{
  font-weight:700;
  color:#173d43;
}

.adminCompCellMuted{
  color:#4f666b;
  font-size:13px;
  max-width:14rem;
  word-break:break-word;
}

.adminCompCellDate{
  font-size:13px;
  font-weight:600;
  color:#4f666b;
  font-variant-numeric:tabular-nums;
  white-space:nowrap;
}

.adminCompCellNum{
  font-weight:700;
  color:#2d4549;
}

.adminCompDash{
  color:#a8b8bc;
  font-weight:600;
}

.adminCompMailLink{
  color:var(--sf-primary);
  font-weight:600;
  text-decoration:none;
  border-bottom:1px solid rgba(25,102,110,.25);
  transition:border-color .15s ease, color .15s ease;
}

.adminCompMailLink:hover{
  border-bottom-color:rgba(25,102,110,.5);
  color:#0d3d42;
}

.adminCompStatusChip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:5px 12px;
  border-radius:999px;
  font-size:11px;
  font-weight:800;
  letter-spacing:.02em;
}

.adminCompStatusChip--pending{
  border:1px solid rgba(234,179,8,.45);
  background:rgba(250,204,21,.14);
  color:#854d0e;
}

.adminCompStatusChip--approved{
  border:1px solid rgba(22,163,74,.4);
  background:rgba(34,197,94,.1);
  color:#14532d;
}

.adminCompStatusChip--blocked{
  border:1px solid rgba(220,38,38,.3);
  background:rgba(248,113,113,.1);
  color:#991b1b;
}

.adminCompActions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
}

.adminCompLinkBtn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:38px;
  padding:8px 14px;
  border-radius:10px;
  border:1px solid rgba(25,102,110,.35);
  background:var(--sf-surface-strong);
  font-size:12px;
  font-weight:700;
  color:var(--sf-primary);
  text-decoration:none;
  transition:border-color .15s ease, background .15s ease, box-shadow .15s ease;
}

.adminCompLinkBtn:hover{
  border-color:rgba(25,102,110,.55);
  background:rgba(25,102,110,.06);
  box-shadow:0 4px 12px rgba(25,102,110,.08);
}

.adminCompLinkBtn:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(25,102,110,.2);
}

@media (max-width:960px){
  .adminCompaniesToolbar{
    flex-direction:column;
  }

  .adminCompaniesToolbarRight{
    width:100%;
  }
}

/* --- Stage 28.2: Admin product edit form --- */

.adminProductEditPage{
  display:flex;
  flex-direction:column;
  gap:16px;
}

.adminProductEditHeader{
  border-radius:22px;
}

.adminProductEditHeader:hover{
  border-color:var(--sf-line-soft);
  box-shadow:var(--sf-shadow-2);
}

.adminProductEditHeaderInner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:22px 28px;
}

.adminProductEditTitle{
  margin:0;
  font-size:clamp(22px,3vw,30px);
  font-weight:700;
  letter-spacing:-.02em;
  color:#184950;
  line-height:1.25;
}

.adminProductEditLead{
  margin:4px 0 0;
  font-size:14px;
  color:#72868b;
  line-height:1.4;
}

.adminProductEditBackBtn{
  flex-shrink:0;
  padding:8px 18px !important;
  font-size:13px !important;
}

.adminProductEditAlert{
  border-radius:12px;
  padding:12px 18px;
}

.adminProductForm{
  display:flex;
  flex-direction:column;
  gap:16px;
}

.adminProductFormCard{
  border-radius:22px;
}

.adminProductFormCard:hover{
  border-color:var(--sf-line-soft);
  box-shadow:var(--sf-shadow-2);
}

.adminProductFormCard .cardInner{
  padding:24px 28px;
}

.adminProductFormCard .sectionTitle{
  margin-bottom:16px;
}

.adminProductFormCard .sectionTitle h2{
  font-size:clamp(16px,2vw,20px);
  color:#1a4b52;
}

.adminProductFormCard .field{
  margin-bottom:14px;
}

.adminProductFormCard .field:last-child{
  margin-bottom:0;
}

.adminProductFormCard .field label{
  display:block;
  margin-bottom:5px;
  font-size:13px;
  font-weight:500;
  color:#4a6268;
  letter-spacing:.01em;
}

.adminProductFormCard .field input,
.adminProductFormCard .field select,
.adminProductFormCard .field textarea{
  width:100%;
  padding:10px 12px;
  border:1px solid #d5dfdd;
  border-radius:10px;
  background:#fff;
  font-size:14px;
  color:#1b2b2d;
  transition:border-color .15s, box-shadow .15s;
}

.adminProductFormCard .field input:hover,
.adminProductFormCard .field select:hover,
.adminProductFormCard .field textarea:hover{
  border-color:#b8c9c6;
}

.adminProductFormCard .field input:focus,
.adminProductFormCard .field select:focus,
.adminProductFormCard .field textarea:focus{
  outline:none;
  border-color:rgba(25,102,110,.5);
  box-shadow:0 0 0 3px rgba(25,102,110,.1);
}

.adminProductFormCard .field textarea{
  min-height:100px;
  resize:vertical;
}

.adminProductFormGrid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0 20px;
}

.adminProductField--name{
  grid-column:1 / -1;
}

.adminProductField--slug{
  grid-column:1 / -1;
}

.adminProductField--sort{
  max-width:160px;
}

.fieldRequired{
  color:#ee7233;
  font-weight:600;
}

.fieldHint{
  color:#8fa4a8;
  font-weight:400;
  font-size:12px;
}

.adminProductFlagsRow{
  display:flex;
  gap:24px;
  flex-wrap:wrap;
  margin-top:6px;
  padding:14px 16px;
  background:rgba(25,102,110,.035);
  border:1px solid rgba(25,102,110,.07);
  border-radius:10px;
}

.adminProductFlagsRow .formCheck{
  font-size:14px;
  color:#2a4a50;
}

.adminProductCategoryChecks{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(190px, 1fr));
  gap:6px 20px;
}

.adminProductCategoryChecks .formCheck{
  font-size:14px;
  padding:6px 0;
}

.adminProductInfoTable{
  overflow-x:auto;
}

.adminProductInfoTable .dashboardTable{
  min-width:380px;
  font-size:13px;
}

.adminProductMediaUrl{
  max-width:260px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

.adminProductDeps{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.adminProductSectionNote{
  margin-top:8px;
  font-size:12px;
}

.adminProductSectionGap{
  margin-top:22px;
  padding-top:18px;
  border-top:1px solid rgba(25,102,110,.08);
}

.adminProductBtnRow{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
}

@media (max-width:700px){
  .adminProductEditHeaderInner{
    flex-direction:column;
    align-items:flex-start;
    padding:18px 20px;
  }

  .adminProductFormCard .cardInner{
    padding:18px 18px;
  }

  .adminProductFormGrid{
    grid-template-columns:1fr;
  }

  .adminProductField--sort{
    max-width:none;
  }

  .adminProductFlagsRow{
    flex-direction:column;
    gap:10px;
  }

  .adminProductCategoryChecks{
    grid-template-columns:1fr;
  }

  .adminProductBtnRow{
    flex-direction:column;
    align-items:stretch;
  }
}

/* --- Stage 28.3: Admin product media management --- */

.adminMediaPrimary{
  margin-bottom:18px;
}

.adminMediaPrimaryLabel,
.adminMediaGalleryLabel{
  font-size:13px;
  font-weight:600;
  color:#4a6268;
  margin-bottom:10px;
  text-transform:uppercase;
  letter-spacing:.04em;
}

.adminMediaGalleryLabel{
  margin-top:18px;
}

.adminMediaCard{
  display:flex;
  align-items:center;
  gap:14px;
  padding:10px 14px;
  border:1px solid #e2eae8;
  border-radius:12px;
  background:#fcfefd;
}

.adminMediaCard--primary{
  border-color:rgba(25,102,110,.25);
  background:rgba(25,102,110,.03);
}

.adminMediaThumb{
  width:72px;
  height:72px;
  object-fit:cover;
  border-radius:8px;
  border:1px solid #e2eae8;
  flex-shrink:0;
  background:#f0f4f3;
}

.adminMediaCardInfo{
  flex:1;
  min-width:0;
}

.adminMediaCardAlt{
  display:block;
  font-size:13px;
  font-weight:500;
  color:#1b2b2d;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.adminMediaCardMeta{
  display:block;
  font-size:11px;
  color:#8fa4a8;
  margin-top:2px;
}

.adminMediaCardActions{
  display:flex;
  gap:6px;
  flex-shrink:0;
}

.adminMediaInlineForm{
  display:inline;
}

.adminMediaActionBtn{
  padding:5px 12px !important;
  font-size:12px !important;
}

.adminMediaGallery{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.adminMediaEmpty{
  padding:24px 16px;
  text-align:center;
  color:#8fa4a8;
  font-size:14px;
  border:1px dashed #d5dfdd;
  border-radius:12px;
  background:#fafcfb;
}

.adminMediaUploadForm .field{
  margin-bottom:12px;
}

.adminMediaUploadForm input[type="file"]{
  padding:8px 10px;
  font-size:13px;
  border:1px solid #d5dfdd;
  border-radius:10px;
  background:#fff;
  width:100%;
}

.adminMediaUploadOptions{
  margin-bottom:14px;
}

.adminMediaUploadBtn{
  display:flex;
}

@media (max-width:600px){
  .adminMediaCard{
    flex-direction:column;
    align-items:flex-start;
    gap:10px;
  }

  .adminMediaThumb{
    width:100%;
    height:auto;
    max-height:200px;
  }

  .adminMediaCardActions{
    flex-wrap:wrap;
  }
}

/* --- Stage 28.3: Catalog product images (public views) --- */

.catalogProductVisual{
  overflow:hidden;
  position:relative;
}

.catalogProductImg{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  border-radius:inherit;
}

.catalogProductImgPlaceholder{
  font-size:12px;
  color:rgba(255,255,255,.7);
}

.catalogDetailPrimary{
  overflow:hidden;
  position:relative;
}

.catalogDetailImg{
  width:100%;
  height:100%;
  min-height:220px;
  max-height:400px;
  object-fit:cover;
  display:block;
  border-radius:inherit;
}

.catalogDetailImgPlaceholder{
  color:rgba(255,255,255,.7);
  font-size:14px;
}

.catalogDetailThumb{
  overflow:hidden;
}

.catalogDetailThumbImg{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  border-radius:inherit;
  min-height:60px;
}

/* ─── Stage 28.4: Admin product pricing section ─── */

.adminPriceTable{margin-bottom:0;}
.adminPriceTable table{font-size:14px;}
.adminPriceColRight{text-align:right !important;}
.adminPriceActions{display:flex;gap:6px;justify-content:center;align-items:center;flex-wrap:wrap;}

.chip--sm{font-size:11px;padding:2px 8px;border-radius:10px;background:rgba(255,255,255,.06);color:rgba(255,255,255,.55);display:inline-block;}

.adminPriceEndedDetails{margin-top:16px;}
.adminPriceEndedSummary{cursor:pointer;color:rgba(255,255,255,.5);font-size:13px;padding:6px 0;user-select:none;}
.adminPriceEndedSummary:hover{color:rgba(255,255,255,.7);}
.adminPriceTable--ended table{opacity:.6;}

.adminPriceFormGrid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px 18px;
}
@media(max-width:640px){
  .adminPriceFormGrid{grid-template-columns:1fr;}
}

.adminPriceBtnRow{
  display:flex;
  gap:10px;
  margin-top:16px;
  align-items:center;
}

.adminPriceForm select,
.adminPriceForm input[type="text"],
.adminPriceForm input[type="date"]{
  width:100%;
}

/* Kalendarz zamówień — nagłówek strony (proporcje, mniej „pustki”) */
.card:has(.calendarOpsHint) .hero{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(260px,400px);
  gap:clamp(16px,2.5vw,26px);
  align-items:start;
  padding:clamp(22px,2.8vw,30px) clamp(22px,3vw,34px);
  min-height:0;
}
.card:has(.calendarOpsHint) .hero .heroMedia{
  display:none;
}
.card:has(.calendarOpsHint) .hero .contentSection{
  min-width:0;
}
.card:has(.calendarOpsHint) .hero h1{
  max-width:none;
  font-size:clamp(26px,3.2vw,36px);
  letter-spacing:-.03em;
  color:var(--sf-primary);
}
.card:has(.calendarOpsHint) .hero .sectionLead{
  margin-top:10px;
  max-width:56ch;
  line-height:1.55;
}

@media (max-width:900px){
  .card:has(.calendarOpsHint) .hero{
    grid-template-columns:1fr;
  }
}

.calendarDayPanel .checkboxRow{
  align-items:flex-start;
  gap:10px;
  padding:11px 13px;
  border-radius:12px;
  border:1px solid rgba(25,102,110,.1);
  background:rgba(25,102,110,.03);
}
.calendarDayPanel .checkboxRow input[type="checkbox"]{
  accent-color:var(--sf-primary);
  width:18px;
  height:18px;
  margin-top:2px;
  flex-shrink:0;
}
.calendarDayPanel .btnRow{
  margin-top:6px;
}

/* (activation page styles moved inline to the view) */
