:root{
    --bg:        oklch(0.965 0.012 82);
    --bg-2:      oklch(0.945 0.018 80);
    --btn-ghost:  oklch(0.90 0.026 78);
    --ink:       oklch(0.23 0.025 60);
    --ink-soft:  oklch(0.42 0.022 60);
    --line:      oklch(0.86 0.018 80);
    --line-soft: oklch(0.91 0.014 80);
    --amber:     oklch(0.70 0.135 75);
    --amber-deep:oklch(0.55 0.135 65);
    --serif: "Cormorant Garamond", "Garamond", "Georgia", serif;
    --sans:  Helvetica, "Helvetica Neue", Arial, sans-serif;
    --mono:  "JetBrains Mono", ui-monospace, Menlo, monospace;
  }
  *{box-sizing:border-box; margin:0; padding:0;}
  html, body{ background: var(--bg); color: var(--ink); font-family: var(--sans); font-size:15px; line-height:1.55; -webkit-font-smoothing:antialiased; }
  body{ min-height:100vh; }
  a{ color:inherit; text-decoration:none; }
  button{ font:inherit; color:inherit; background:none; border:none; cursor:pointer; }
  img{max-width:100%; display:block;}

  /* ——— Layout ——— */
  .shell{ max-width: 1320px; margin: 0 auto; padding: 0 40px; padding-left: 40px !important; padding-right: 40px !important; }
  @media (max-width:760px){ .shell{ padding: 0 22px; padding-left: 22px !important; padding-right: 22px !important; } }

  /* ——— Header ——— */
  .topbar{
    border-bottom:1px solid var(--line);
    background: var(--bg);
    position: sticky; top:0; z-index:50;
    backdrop-filter: blur(6px);
  }
  .topbar-inner{
    display:flex; align-items:center; justify-content:space-between;
    height: 78px;
  }
  .brand{
    display:inline-flex; align-items:center; gap: 14px;
    font-family: var(--serif);
    font-weight:500;
    letter-spacing: 0.22em;
    font-size: 17px;
    text-transform: uppercase;
    color: var(--ink);
  }
  .brand img{ width: 48px; height: 48px; object-fit: contain; display:block; }
  .brand .wordmark{ display:flex; flex-direction:column; line-height: 1; }
  .brand .wordmark .name{ font-weight: 600; letter-spacing: 0.24em; }
  .brand .wordmark .sub{ font-family: var(--mono); font-size: 9px; letter-spacing: 0.32em; color: var(--ink-soft); margin-top: 5px; text-transform: uppercase; }
  nav.primary{
    display:flex; gap: 38px;
    font-family: var(--sans);
    font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase;
    color: var(--ink-soft);
  }
  nav.primary a{ position:relative; padding: 6px 0; }
  nav.primary a:hover{ color: var(--ink); }
  nav.primary a.active{ color: var(--ink); }
  nav.primary a.active::after{
    content:""; position:absolute; left:0; right:0; bottom:-2px; height:1px; background: var(--ink);
  }
  .cart-btn{
    font-family: var(--sans);
    font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase;
    display:inline-flex; gap:10px; align-items:center;
    padding: 10px 20px;
    clip-path: polygon(10px 0%, calc(100% - 10px) 0%, 100% 50%, calc(100% - 10px) 100%, 10px 100%, 0% 50%);
    background: var(--btn-ghost);
    transition: background 180ms ease;
  }
  .cart-btn .count{
    font-family: var(--mono); font-size: 14px;
    color: var(--ink); letter-spacing: 0;
  }
  .menu-btn{
    display: none;
    width: 36px; height: 36px;
    align-items: center; justify-content: center;
    flex-shrink: 0;
  }
  .hex-btn { display:block; overflow:visible; color:var(--ink); transition:transform 320ms cubic-bezier(.4,0,.2,1); }
  .hex-btn polygon { transition:fill 280ms ease; }
  .hex-btn.open { color:var(--amber-deep); transform:rotate(30deg); }
  .hex-btn.open polygon { fill:var(--amber-deep); }

  .mob-nav{
    position: fixed; inset: 0; z-index: 48;
    background: oklch(0.23 0.025 60 / 0.45);
    backdrop-filter: blur(3px);
  }
  .mob-nav-panel{
    position: absolute; top: 64px; left: 0; right: 0;
    background: var(--bg);
    border-bottom: 1px solid var(--line);
    display: flex; flex-direction: column;
    padding: 8px 0 20px;
  }
  .mob-nav-panel a{
    font-family: var(--sans);
    font-size: 13px; letter-spacing: 0.22em; text-transform: uppercase;
    color: var(--ink-soft);
    padding: 14px 22px;
    display: block;
  }
  .mob-nav-panel a:hover, .mob-nav-panel a.active{ color: var(--ink); }
  .mob-cart-btn{
    font-family: var(--sans);
    font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase;
    display: inline-flex; align-items: center; gap: 10px;
    padding: 10px 20px;
    clip-path: polygon(10px 0%, calc(100% - 10px) 0%, 100% 50%, calc(100% - 10px) 100%, 10px 100%, 0% 50%);
    background: var(--btn-ghost);
    margin: 8px 22px 0; align-self: flex-start;
    transition: background 180ms ease;
  }

  @media (max-width:760px){
    nav.primary{ display:none; }
    .menu-btn{ display:inline-flex; }
    .topbar-inner{ height: 64px; }
    .brand img{ width: 36px; height: 36px; }
    .brand .wordmark .name{ font-size: 14px; }
    .brand .wordmark .sub{ font-size: 8px; }
    .cart-btn{ display:none; }
  }

  /* ——— Hero ——— */
  .hero{
    padding: 28px 0 120px;
    display:grid; grid-template-columns: 1.05fr 1fr; gap: 80px;
    align-items:end;
    border-bottom:1px solid var(--line);
  }
  .hero > div:first-child{ align-self: start; }
  .hero h1{
    font-family: var(--serif);
    font-weight: 400;
    font-size: clamp(48px, 7vw, 104px);
    line-height: 0.98;
    letter-spacing: -0.01em;
  }
  .hero h1 em{
    font-style: italic;
    color: var(--amber-deep);
    font-weight:400;
  }
  .hero-meta{
    display:flex; flex-direction:column; gap:32px;
    max-width: 460px;
  }
  .hero-brand-el{ margin-top:auto; }
  .hero-brand-el .wordmark{ display:flex; flex-direction:column; line-height:1; align-items:flex-start; }
  .hero-brand-el .wordmark .name{ font-family:var(--serif); font-weight:600; letter-spacing:0.24em; font-size:34px; }
  .hero-brand-el .wordmark .sub{ font-family:var(--mono); font-size:14px; letter-spacing:0.32em; text-transform:uppercase; color:var(--ink-soft); margin-top:11px; }
  .hero-meta-body{ display:flex; flex-direction:column; gap:32px; }
  .hero-meta p{
    font-size: 16px; line-height: 1.65; color: var(--ink-soft);
  }
  .hero-meta .tag{
    font-family: var(--mono);
    font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
    color: var(--ink-soft);
    display:flex; gap:14px; align-items:center;
  }
  .hero-cta{ display:flex; gap: 16px; align-items:center; }
  @media (max-width:880px){
    .hero{ grid-template-columns: 1fr; gap: 48px; padding: 14px 0 72px; }
  }

  .btn{
    display:inline-flex; align-items:center; justify-content:center;
    gap:10px;
    padding: 14px 30px;
    font-family: var(--sans); font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase;
    clip-path: polygon(14px 0%, calc(100% - 14px) 0%, 100% 50%, calc(100% - 14px) 100%, 14px 100%, 0% 50%);
    transition: background 180ms ease, color 180ms ease;
  }
  .btn.primary{ background:var(--ink); color:var(--bg); }
  .btn.primary:hover{ background:var(--amber-deep); }
  .btn.ghost{ background:var(--btn-ghost); color:var(--ink); }
  .btn.ghost:hover{ background:var(--ink); color:var(--bg); }
  .btn.block{ width:100%; padding: 18px 30px; }
  .btn[disabled]{ opacity:.4; cursor:not-allowed; }

  /* ——— Section ——— */
  .section{ padding: 96px 0; border-bottom:1px solid var(--line); }
  .section-head{
    display:flex; align-items:end; justify-content:space-between;
    margin-bottom: 56px; gap: 24px;
  }
  .section-head h2{
    font-family: var(--serif); font-weight: 400;
    font-size: clamp(36px, 4.4vw, 60px); line-height: 1; letter-spacing:-0.005em;
  }
  .eyebrow{
    font-family: var(--mono); font-size: 11px; letter-spacing: 0.22em;
    text-transform: uppercase; color: var(--ink-soft);
    margin-bottom: 18px;
  }
  .label-mono{
    font-family: var(--mono); font-size: 11px; letter-spacing: 0.28em;
    text-transform: uppercase; color: var(--ink-soft);
  }
  .body-soft{
    color: var(--ink-soft); font-size: 15px; line-height: 1.75;
  }
  .price-mono{
    font-family: var(--mono); font-size: 13px;
  }
  @media(max-width:760px){
    .section{ padding: 64px 0; }
    .section-head{ flex-direction: column; align-items:flex-start; gap:18px; margin-bottom:36px; }
  }

  /* ——— Filters ——— */
  .filters{
    display:flex; gap: 6px; flex-wrap:wrap;
    margin-bottom: 36px;
  }
  .filters-mobile{ display:none; }
  .filters-desktop{ display:flex; gap:6px; flex-wrap:wrap; margin-bottom:36px; }
  .filters-toggle{
    display:inline-flex; align-items:center; gap:10px;
    font-family:var(--sans); font-size:12px; letter-spacing:0.22em; text-transform:uppercase;
    padding:11px 20px;
    clip-path:polygon(10px 0%,calc(100% - 10px) 0%,100% 50%,calc(100% - 10px) 100%,10px 100%,0% 50%);
    background:var(--btn-ghost); color:var(--ink);
    margin-bottom:16px;
  }
  .filters-toggle-val{ color:var(--amber-deep); }
  .filters-panel{
    display:flex; flex-wrap:wrap; gap:8px;
    margin-bottom:24px;
  }
  @media(max-width:640px){
    .filters-desktop{ display:none; }
    .filters-mobile{ display:block; }
  }
  .filter{
    padding: 9px 20px;
    clip-path: polygon(10px 0%, calc(100% - 10px) 0%, 100% 50%, calc(100% - 10px) 100%, 10px 100%, 0% 50%);
    background: var(--btn-ghost);
    font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase;
    color: var(--ink-soft);
    transition: background 160ms ease, color 160ms ease;
  }
  .filter:hover{ color: var(--ink); }
  .filter.active{ background: var(--ink); color: var(--bg); }

  /* ——— Product grid ——— */
  .grid{
    display:grid; grid-template-columns: repeat(4, 1fr); gap: 36px 28px;
  }
  @media (max-width:1080px){ .grid{ grid-template-columns: repeat(3, 1fr); } }
  @media (max-width:760px){ .grid{ grid-template-columns: repeat(2, 1fr); gap:28px 16px; } }
  @media (max-width:440px){ .grid{ grid-template-columns: 1fr; gap:20px; } }

  .card{ cursor:pointer; display:flex; flex-direction:column; gap: 18px; }
  .card .thumb{
    aspect-ratio: 4/5;
    background: var(--bg-2);
    border:1px solid var(--line-soft);
    position:relative; overflow:hidden;
    transition: 220ms ease;
  }
  .card:hover .thumb{ border-color: var(--ink-soft); }
  .card .label{ display:flex; justify-content:space-between; align-items:baseline; gap:12px; }
  .card .label .name{ font-family: var(--serif); font-size: 22px; line-height: 1.15; font-weight:500; }
  .card .label .price{ font-family: var(--mono); font-size: 12px; letter-spacing: 0.06em; color: var(--ink-soft); white-space: nowrap; }
  .card .tags{ display:flex; gap: 8px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-soft); }

  /* placeholder SVG fill */
  .placeholder-svg{ width:100%; height:100%; }
  .corner-tag{
    position:absolute; top: 0; left: 0;
    font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform:uppercase;
    color: #fff;
    background: oklch(0.23 0.025 60 / 0.82);
    padding: 7px 12px;
  }
  .corner-id{
    position:absolute; bottom: 14px; right: 14px;
    font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; color: var(--ink-soft);
  }

  /* ——— Product detail ——— */
  .pd{
    display:grid; grid-template-columns: 1.1fr 1fr; gap: 80px;
    padding: 64px 0 120px;
  }
  .pd .gallery .main{
    aspect-ratio: 4/5; background: var(--bg-2);
    border: 1px solid var(--line-soft);
    position:relative; overflow:hidden;
  }
  .pd .gallery .thumbs{
    display:grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
    margin-top: 12px;
  }
  .pd .gallery .thumbs .t{
    aspect-ratio:1; background: var(--bg-2); border:1px solid var(--line-soft);
    position:relative; overflow:hidden; cursor:pointer;
  }
  .pd .info h1{
    font-family: var(--serif); font-weight:400;
    font-size: clamp(40px, 5vw, 64px); line-height:1; letter-spacing:-0.01em;
    margin-bottom: 22px;
  }
  .pd .info .subtitle{
    font-family: var(--mono); font-size: 11px; letter-spacing: 0.22em;
    text-transform: uppercase; color: var(--ink-soft);
    margin-bottom: 28px;
  }
  .pd .info > p.desc{
    font-size: 16px; line-height: 1.7; color: var(--ink-soft);
    max-width: 520px;
    margin-bottom: 36px;
  }
  .pd .info .price-line{
    font-family: var(--serif); font-size: 36px; font-weight:500;
    margin-bottom: 12px;
  }
  .stock-badge{
    font-family: var(--mono); font-size: 11px; letter-spacing: .1em;
    text-transform: uppercase; color: var(--ink-soft); margin-bottom: 24px;
  }
  .field{ margin-bottom: 28px; }
  .field .label{
    display:flex; justify-content:space-between; align-items:baseline;
    font-family: var(--mono); font-size: 11px; letter-spacing: 0.22em;
    text-transform: uppercase; color: var(--ink-soft);
    margin-bottom: 12px;
  }
  .size-opts{
    display:grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 10px;
  }
  .size-opt{
    border:1px solid var(--line); padding: 16px 18px;
    text-align:left; transition: 160ms;
    display:flex; flex-direction:column; gap:4px;
  }
  .size-opt:hover{ border-color: var(--ink-soft); }
  .size-opt.active{ border-color: var(--ink); background: var(--ink); color: var(--bg); }
  .size-opt .s-name{ font-family: var(--serif); font-size: 18px; font-weight:500; }
  .size-opt .s-meta{ font-family: var(--mono); font-size: 11px; letter-spacing:0.12em; opacity: .75; }

  .qty{ display:inline-flex; align-items:center; border:1px solid var(--line); border-radius: 999px; overflow:hidden; }
  .qty button{ width:42px; height:42px; font-size: 18px; }
  .qty button:hover{ background: var(--bg-2); }
  .qty .v{ width: 46px; text-align:center; font-family: var(--mono); font-size: 13px; }
  .row-actions{ display:flex; gap: 14px; align-items:center; margin-top: 8px; }
  .row-actions .btn{ flex:1; }

  .pd .meta-list{
    margin-top: 56px;
    border-top:1px solid var(--line);
  }
  .meta-list .row{
    display:grid; grid-template-columns: 1fr 2fr; gap: 24px;
    padding: 18px 0;
    border-bottom:1px solid var(--line);
    font-size: 14px;
  }
  .meta-list .row .k{
    font-family: var(--mono); font-size:11px; letter-spacing:0.18em; text-transform:uppercase; color: var(--ink-soft);
  }
  @media(max-width:880px){ .pd{ grid-template-columns: 1fr; gap: 48px; padding: 36px 0 80px; } }

  .breadcrumbs{
    font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
    color: var(--ink-soft);
    padding: 28px 0 4px;
  }
  .breadcrumbs a:hover{ color: var(--ink); }
  .breadcrumbs span{ margin: 0 10px; opacity:.5; }

  /* ——— About strip ——— */
  .story{
    display:grid; grid-template-columns: 1fr 1.2fr; gap: 80px; align-items:center;
  }
  .story .lead{
    font-family: var(--serif); font-style: italic; font-size: clamp(24px, 2.5vw, 32px);
    line-height: 1.35; color: var(--ink);
  }
  .story .body{ display:flex; flex-direction:column; gap: 18px; color: var(--ink-soft); font-size: 15px; line-height: 1.7; }
  @media(max-width:880px){ .story{ grid-template-columns: 1fr; gap: 32px; } }

  /* ——— Cart drawer ——— */
  .drawer-overlay{
    position: fixed; inset:0; background: oklch(0.2 0.02 60 / 0.32);
    opacity:0; pointer-events:none; transition: opacity 220ms ease;
    z-index: 80;
  }
  .drawer{
    position: fixed; top:0; right:0; bottom:0;
    width: min(440px, 100vw);
    background: var(--bg);
    z-index: 90;
    transform: translateX(100%);
    transition: transform 280ms cubic-bezier(.2,.7,.2,1);
    display:flex; flex-direction:column;
    border-left:1px solid var(--line);
  }
  .drawer.open{ transform: translateX(0); }
  .drawer-overlay.open{ opacity:1; pointer-events:auto; }
  .drawer-head{
    display:flex; align-items:center; justify-content:space-between;
    padding: 26px 28px;
    border-bottom: 1px solid var(--line);
  }
  .drawer-head h3{ font-family: var(--serif); font-weight:500; font-size: 22px; letter-spacing:.02em; }
  .drawer-close{ font-family: var(--mono); font-size: 11px; letter-spacing: 0.22em; text-transform:uppercase; color: var(--ink-soft); }
  .drawer-close:hover{ color: var(--ink); }
  .cart-notice{
    margin: 14px 28px 6px;
    padding: 12px 14px;
    border: 1px solid var(--line);
    background: var(--bg-2);
    font-family: var(--mono);
    font-size: 10px;
    line-height: 1.6;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--ink-soft);
  }
  .drawer-items{ flex:1; overflow-y:auto; padding: 8px 28px; }
  .drawer-item{
    display:grid; grid-template-columns: 96px 1fr auto; gap: 16px;
    padding: 20px 0;
    border-bottom: 1px solid var(--line-soft);
    align-items:center;
  }
  .drawer-item .di-thumb{ aspect-ratio: 1; overflow:hidden; }
  .di-name{ font-family: var(--serif); font-size: 19px; font-weight:500; line-height:1.2; }
  .di-meta{ font-family: var(--mono); font-size: 11px; letter-spacing:.14em; text-transform:uppercase; color: var(--ink-soft); margin-top: 4px; }
  .di-qty{ display:flex; gap:8px; align-items:center; margin-top: 10px; font-family: var(--mono); font-size: 13px; }
  .di-qty button{ width: 26px; height: 26px; border:1px solid var(--line); border-radius:50%; font-size:13px; line-height:1; }
  .di-qty button:hover{ background: var(--bg-2); }
  .di-qty button[disabled]{ opacity:.35; cursor:not-allowed; }
  .di-qty button[disabled]:hover{ background:transparent; }
  .di-stock-warn{ margin-top:6px; font-family:var(--mono); font-size:10px; letter-spacing:.12em; color:var(--amber-deep); }
  .di-price{ font-family: var(--mono); font-size: 14px; letter-spacing:.04em; align-self:flex-start; }
  .di-remove{ font-family: var(--mono); font-size: 11px; letter-spacing:.18em; text-transform:uppercase; color: var(--ink-soft); margin-top: 8px; }
  .di-remove:hover{ color: var(--amber-deep); }

  .drawer-foot{ padding: 22px 28px 28px; border-top: 1px solid var(--line); }
  .totals{ display:flex; flex-direction:column; gap: 8px; margin-bottom: 14px; }
  .cart-free-ship{
    font-family: var(--mono); font-size: 10px; letter-spacing: .16em; text-transform: uppercase;
    text-align: center; color: var(--ink-soft); margin-bottom: 14px;
  }
  .cart-free-ship-missing::before{ content:" · "; }
  .cart-free-ship--ok{ color: oklch(0.40 0.14 145); }
  .totals .row{ display:flex; justify-content:space-between; font-size:13px; color: var(--ink-soft); }
  .totals .row.grand{ color: var(--ink); font-family: var(--serif); font-size: 24px; font-weight:500; margin-top: 4px; }
  .empty-cart{ padding: 60px 0; text-align:center; color: var(--ink-soft); font-family: var(--serif); font-style: italic; font-size: 22px; }

  /* ——— Checkout view ——— */
  .checkout{ display:grid; grid-template-columns: 1.2fr 1fr; gap:60px; padding: 56px 0 120px; }
  .checkout h1{ font-family: var(--serif); font-weight: 400; font-size: clamp(40px, 5vw, 60px); line-height:1; margin-bottom: 36px; }
  .form-grid{ display:grid; grid-template-columns: 1fr 1fr; gap: 16px; }
  .form-grid .full{ grid-column: span 2; }
  .input-wrap{ display:flex; flex-direction:column; gap: 6px; }
  .input-wrap label{ font-family: var(--mono); font-size: 10px; letter-spacing:.2em; text-transform:uppercase; color: var(--ink-soft); }
  .input-wrap input, .input-wrap textarea, .input-wrap select{
    font-family: "DM Sans", Helvetica, Arial, sans-serif;
    font-size: 15px; font-weight: 400; color:inherit; background: transparent;
    border:none; border-bottom: 1px solid var(--line);
    padding: 10px 0 12px;
    outline:none;
  }
  .input-wrap input:focus, .input-wrap textarea:focus{ border-bottom-color: var(--ink); }
  .summary-card{
    background: var(--bg-2); padding: 32px;
    border:1px solid var(--line-soft);
  }
  .summary-card h3{ font-family: var(--serif); font-weight:500; font-size: 22px; margin-bottom: 18px; }
  .sum-row{ display:flex; justify-content:space-between; padding: 12px 0; border-bottom:1px solid var(--line); font-size: 14px; }
  .sum-prod-row{ display:flex; align-items:flex-start; gap:12px; padding:14px 0; border-bottom:1px solid var(--line-soft); }
  .sum-prod-thumb{ width:72px; height:72px; flex-shrink:0; overflow:hidden; display:block; }
  .sum-prod-info{ flex:1; min-width:0; }
  .sum-prod-name{ font-family:var(--serif); font-size:16px; font-weight:500; line-height:1.25; color:var(--ink); display:block; }
  .sum-prod-name:hover{ color:var(--amber-deep); }
  .sum-prod-right{ flex-shrink:0; display:flex; flex-direction:column; align-items:flex-end; gap:8px; }
  .sum-prod-price{ font-family:var(--mono); font-size:14px; letter-spacing:.04em; }
  .sum-row .l{ flex:1; padding-right: 14px; }
  .sum-row .l small{ display:block; color: var(--ink-soft); font-family: var(--mono); font-size: 10px; letter-spacing:.14em; text-transform: uppercase; margin-top: 4px; }
  @media(max-width:880px){ .checkout{ grid-template-columns: 1fr; gap: 40px; } .checkout aside{ order:-1; } }

  /* ——— Furgonetka checkout ——— */
  .co-furg-intro{
    font-size: 16px; line-height: 1.65; color: var(--ink-soft);
    max-width: 400px; margin-bottom: 36px;
  }
  .co-furg-btn-wrap{ min-height: 56px; }
  #furgonetka-btn-mobile:empty::before{
    content: "Ładowanie płatności…";
    display: block;
    font-family: var(--mono); font-size: 10px; letter-spacing: .12em;
    color: var(--ink-soft); padding: 18px 0;
  }
  .co-furg-btn-wrap.is-disabled{
    opacity:.42;
    pointer-events:none;
    filter:grayscale(1);
  }
  .co-furg-btn-wrap.is-disabled:empty::before{
    border-color:var(--line);
    color:var(--ink-soft);
    cursor:not-allowed;
  }
  .co-furg-disabled-note{
    margin-top:8px;
    font-family:var(--mono);
    font-size:10px;
    letter-spacing:.12em;
    line-height:1.6;
    color:var(--ink-soft);
  }
  .co-furg-notes{ margin: 22px 0 24px; }
  .co-promo{ padding:16px 0; border-bottom:1px solid var(--line); }
  .co-promo-row{ display:flex; gap:8px; }
  .co-promo-row input{
    min-width:0; flex:1; padding:12px 14px;
    border:1px solid var(--line); background:transparent; color:var(--ink);
    font-family:var(--mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase;
    outline:none;
  }
  .co-promo-row input:focus{ border-color:var(--ink); }
  .co-promo-row button{
    flex:0 0 auto; padding:0 14px; border:1px solid var(--ink); background:var(--ink); color:var(--bg);
    font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; cursor:pointer;
  }
  .co-promo-msg{ margin-top:8px; font-family:var(--mono); font-size:10px; letter-spacing:.12em; line-height:1.5; font-weight:bold; }
  .co-promo-err{ color:var(--amber-deep); }
  .co-promo-ok,
  .co-promo-discount{ color:oklch(0.40 0.14 145); }
  @media(max-width:420px){
    .co-promo-row{ flex-direction:column; }
    .co-promo-row button{ min-height:42px; }
  }
  .co-pickup-note{
    margin: 28px 0 20px;
    padding: 16px 20px;
    border-left: 2px solid var(--ink-soft);
    background: var(--bg-2);
    font-size: 13px; line-height: 1.7; color: var(--ink-soft);
  }
  .co-furg-shipping-note{
    font-family: var(--mono); font-size: 11px; letter-spacing: .13em;
    text-transform: uppercase; color: var(--ink-soft); margin-top: 20px;
    padding-top: 20px; border-top: 1px solid var(--line); line-height: 1.7;
  }
  .co-furg-note{
    font-family: var(--mono); font-size: 11px; letter-spacing: .12em;
    color: var(--ink-soft); margin-top: 16px; padding-top: 16px;
    border-top: 1px solid var(--line); line-height: 1.7;
  }
  .co-promo{ margin-top: 12px; }
  .co-promo-row{ display: flex; gap: 8px; }
  .co-promo-row input{
    flex: 1; padding: 8px 12px; border: 1px solid var(--line);
    border-radius: 2px; font-size: 13px; font-family: var(--mono);
    letter-spacing: .08em; background: var(--bg); color: var(--ink);
    outline: none;
  }
  .co-promo-row input:focus{ border-color: var(--gold); }
  .co-promo-row button{
    padding: 8px 14px; background: var(--ink); color: var(--bg);
    border: none; border-radius: 2px; font-size: 12px; cursor: pointer;
    letter-spacing: .08em; white-space: nowrap;
  }
  .co-promo-row button:hover{ background: var(--amber); color: var(--ink); }
  .co-promo-msg{ font-size: 12px; margin-top: 6px; font-family: var(--mono); font-weight: bold; }
  .co-promo-err{ color: #c0392b; }
  .co-promo-ok{ color: #5a8a3a; }
  .co-promo-discount{ color: var(--gold); }

  /* ——— Nowy checkout wieloetapowy (co2) ——— */
  .co2{ display:flex; justify-content:center; padding: 48px 0 110px; }
  .co2-card{ width:100%; max-width: 560px; }
  .co2-title{
    font-family: var(--serif); font-weight: 400;
    font-size: clamp(34px, 5vw, 52px); line-height: 1; margin-bottom: 28px;
  }
  .co2-products{ border-top: 1px solid var(--line); }
  .co2-prod{
    display:flex; align-items:flex-start; gap: 14px;
    padding: 18px 0; border-bottom: 1px solid var(--line-soft);
  }
  .co2-prod-thumb{ width:74px; height:74px; flex-shrink:0; overflow:hidden; display:block; }
  .co2-prod-info{ flex:1; min-width:0; }
  .co2-prod-name{ font-family: var(--serif); font-size: 17px; font-weight: 500; line-height: 1.25; color: var(--ink); display:block; }
  .co2-prod-name:hover{ color: var(--amber-deep); }
  .co2-prod-meta{ font-family: var(--mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-soft); margin-top: 5px; }
  .co2-prod-bottom{ display:flex; align-items:center; gap: 14px; margin-top: 10px; }
  .co2-qty{ display:flex; gap:8px; align-items:center; font-family: var(--mono); font-size: 13px; }
  .co2-qty button{ width:26px; height:26px; border:1px solid var(--line); border-radius:50%; font-size:13px; line-height:1; }
  .co2-qty button:hover{ background: var(--bg-2); }
  .co2-qty button[disabled]{ opacity:.35; cursor:not-allowed; }
  .co2-qty button[disabled]:hover{ background:transparent; }
  .co2-remove{ font-family: var(--mono); font-size: 10px; letter-spacing: .16em; text-transform: uppercase; color: var(--ink-soft); }
  .co2-remove:hover{ color: var(--amber-deep); }
  .co2-prod-price{ flex-shrink:0; font-family: var(--mono); font-size: 14px; letter-spacing: .04em; }
  .co2-stock-warn{ margin-top:6px; font-family: var(--mono); font-size: 10px; letter-spacing: .12em; color: var(--amber-deep); }
  .co2-sum{ margin-top: 8px; }
  .co2-sum-row{
    display:flex; justify-content:space-between; align-items:baseline;
    padding: 13px 0; border-bottom: 1px solid var(--line-soft); font-size: 14px;
  }
  .co2-mono{ font-family: var(--mono); font-size: 14px; letter-spacing: .03em; }
  .co2-sum-discount{ color: oklch(0.40 0.14 145); }
  .co2-ship-note{
    margin-top: 6px; font-family: var(--mono); font-size: 10px;
    letter-spacing: .1em; color: var(--ink-soft);
  }
  .co2-promo{ padding: 16px 0; border-bottom: 1px solid var(--line-soft); }
  .co2-promo-row{ display:flex; gap: 8px; }
  .co2-promo-row input{
    min-width:0; flex:1; padding: 12px 14px;
    border: 1px solid var(--line); background: transparent; color: var(--ink);
    font-family: var(--mono); font-size: 12px; letter-spacing: .1em; text-transform: uppercase; outline: none;
  }
  .co2-promo-row input:focus{ border-color: var(--ink); }
  .co2-promo-row button{
    flex:0 0 auto; padding: 0 16px; border: 1px solid var(--ink); background: var(--ink); color: var(--bg);
    font-family: var(--mono); font-size: 10px; letter-spacing: .16em; text-transform: uppercase; cursor: pointer;
  }
  .co2-promo-row button:hover{ background: var(--amber-deep); border-color: var(--amber-deep); }
  .co2-promo-msg{ margin-top: 8px; font-family: var(--mono); font-size: 10px; letter-spacing: .12em; line-height: 1.5; font-weight: bold; }
  .co2-promo-err{ color: var(--amber-deep); }
  .co2-promo-ok{ color: oklch(0.40 0.14 145); }
  .co2-next{
    width:100%; margin-top: 28px; padding: 18px 24px;
    background: var(--ink); color: var(--bg); border: none; cursor: pointer;
    display:flex; flex-direction:column; gap: 5px; align-items:center;
    clip-path: polygon(14px 0%, calc(100% - 14px) 0%, 100% 50%, calc(100% - 14px) 100%, 14px 100%, 0% 50%);
    transition: background 180ms ease;
  }
  .co2-next:hover{ background: var(--amber-deep); }
  .co2-next-main{ font-family: var(--sans); font-size: 13px; letter-spacing: .22em; text-transform: uppercase; }
  .co2-next-sub{ font-family: var(--mono); font-size: 9px; letter-spacing: .18em; text-transform: uppercase; opacity: .7; }
  .co2-wip{ color: var(--ink-soft); line-height: 1.7; margin-bottom: 24px; }
  .co2-review{ display:flex; flex-direction:column; gap: 18px; }
  .co2-review-block{ padding-bottom: 16px; border-bottom: 1px solid var(--line-soft); }
  .co2-review-block p{ margin: 0; font-size: 14px; line-height: 1.75; color: var(--ink-soft); }
  .co2-review-block strong{ color: var(--ink); font-weight: 600; }
  .co2-review-products{ margin-top: 20px; }
  .co2-review-item{
    display:flex; align-items:flex-start; justify-content:space-between; gap: 16px;
    padding: 12px 0; border-bottom: 1px solid var(--line-soft);
    font-size: 14px; line-height: 1.5;
  }
  .co2-review-item strong{
    flex-shrink:0; font-family: var(--mono); font-size: 12px;
    letter-spacing: .04em; font-weight: 500;
  }
  .co2-review-sum{ margin-top: 10px; }
  .co2-sum-total{ border-top: 1px solid var(--ink); font-weight: 600; color: var(--ink); }
  .co2-terms{
    display:flex;
    gap:10px;
    align-items:flex-start;
    margin:16px 0 0;
    padding:14px 16px;
    border:1px solid var(--line-soft);
    background:var(--bg-2);
    font-size:12px;
    line-height:1.55;
    color:var(--ink-soft);
    cursor:pointer;
  }
  .co2-terms input{
    flex:0 0 auto;
    width:17px;
    height:17px;
    margin-top:1px;
    accent-color:var(--ink);
    cursor:pointer;
  }
  .co2-terms a{
    color:var(--ink);
    text-decoration:underline;
    text-underline-offset:2px;
  }
  .co2-back{
    display:inline-block; margin-bottom: 18px;
    font-family: var(--mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase;
    color: var(--ink-soft); cursor: pointer; background:none; border:none;
  }
  .co2-back:hover{ color: var(--ink); }
  .co2-section-label{
    font-family: var(--mono); font-size: 11px; letter-spacing: .2em; text-transform: uppercase;
    color: var(--ink-soft); margin: 30px 0 14px;
  }
  .co2-section-label:first-of-type{ margin-top: 4px; }
  .co2-ctype{ display:flex; gap: 8px; margin-bottom: 18px; }
  .co2-ctype-opt{
    flex:1; padding: 11px; border: 1px solid var(--line); background: transparent;
    font-family: var(--mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase;
    color: var(--ink-soft); cursor: pointer; transition: border-color 150ms ease, background 150ms ease, color 150ms ease;
  }
  .co2-ctype-opt:hover{ border-color: var(--ink-soft); }
  .co2-ctype-opt.active{ border-color: var(--ink); background: var(--ink); color: var(--bg); }
  .co2-fields{ display:grid; grid-template-columns: 1fr 1fr; gap: 16px 18px; }
  .co2-field{ display:flex; flex-direction:column; gap: 6px; }
  .co2-field-full{ grid-column: span 2; }
  .co2-field label{
    font-family: var(--mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase;
    color: var(--ink-soft);
  }
  .co2-field input,
  .co2-field textarea{
    font-family: "DM Sans", Helvetica, Arial, sans-serif; font-size: 15px; color: inherit;
    background: transparent; border: none; border-bottom: 1px solid var(--line);
    padding: 10px 0 12px; outline: none; resize: vertical;
  }
  .co2-field input:focus,
  .co2-field textarea:focus{ border-bottom-color: var(--ink); }
  .co2-field-error{
    margin-top: 2px;
    font-family: var(--mono);
    font-size: 9px;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--amber-deep);
    line-height: 1.45;
    font-weight: bold;
  }
  .co2-addr{ margin-top: 16px; }
  .co2-doc-check{
    display:flex; align-items:flex-start; gap: 10px; cursor: pointer;
    font-size: 14px; line-height: 1.5;
  }
  .co2-doc-check input{
    margin-top: 2px; width: 16px; height: 16px; flex-shrink:0;
    accent-color: var(--ink); cursor: pointer;
  }
  .co2-doc-note{
    margin-top: 12px; padding: 14px 18px; border-left: 2px solid var(--ink-soft);
    background: var(--bg-2); font-size: 13px; line-height: 1.7; color: var(--ink-soft);
  }
  .co2-doc-note p + p{ margin-top: 10px; }
  .co2-delivery{ display:flex; flex-direction:column; gap: 10px; }
  .co2-delivery-opt{
    display:flex; align-items:center; justify-content:space-between; gap: 14px;
    padding: 8px 18px; border: 1px solid var(--line); background: transparent;
    cursor: pointer; text-align:left; transition: border-color 150ms ease, background 150ms ease;
  }
  .co2-delivery-opt:hover{ border-color: var(--ink-soft); }
  .co2-delivery-opt.active{ border-color: var(--ink); background: var(--ink); color: var(--bg); }
  .co2-delivery-opt.active .co2-delivery-meta{ color: oklch(0.78 0.018 80); }
  .co2-delivery-info{ display:flex; flex-direction:column; gap: 4px; }
  .co2-delivery-name{ font-family: var(--serif); font-size: 17px; font-weight: 500; }
  .co2-delivery-meta{ font-family: var(--mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-soft); }
  .co2-delivery-pay{ font-family: var(--mono); font-size: 10px; letter-spacing: .11em; text-transform: uppercase; color: var(--amber-deep); }
  .co2-delivery-opt.active .co2-delivery-pay{ color: oklch(0.84 0.065 84); }
  .co2-delivery-logos{ display:inline-flex; gap: 10px; align-items:center; flex-shrink: 0; }
  .co2-delivery-logos img{ height: 41px; width: auto; display: block; }
  @media(max-width:480px){
    .co2-delivery-logos img{ height: 28px; }
  }
  .co2-delivery-cost{ flex-shrink:0; font-family: var(--mono); font-size: 13px; letter-spacing: .04em; }
  .co2-point-btn{
    width: 100%;
    padding: 14px 18px;
    border: 1px solid var(--ink);
    background: var(--bg-2);
    color: var(--ink);
    font-family: var(--mono); font-size: 11px; letter-spacing: .18em; text-transform: uppercase;
    font-weight: 600;
    cursor: pointer;
    transition: background 150ms ease, color 150ms ease;
  }
  .co2-point-btn:hover{ background: var(--ink); color: var(--bg); }
  .co2-point-picked{
    display:flex; align-items:center; justify-content:space-between; gap: 14px;
    padding: 14px 16px; border: 1px solid var(--ink); background: var(--bg-2);
  }
  .co2-point-info{ display:flex; flex-direction:column; gap: 3px; min-width:0; }
  .co2-point-info strong{ font-size: 14px; }
  .co2-point-info span{ font-family: var(--mono); font-size: 10px; letter-spacing: .1em; color: var(--ink-soft); }
  .co2-point-change{
    flex-shrink:0; font-family: var(--mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase;
    color: var(--ink-soft); cursor: pointer; background:none; border:none;
  }
  .co2-point-change:hover{ color: var(--amber-deep); }
  html.biomiodek-furgonetka-map-open,
  body.biomiodek-furgonetka-map-open{
    overflow:hidden !important;
    overscroll-behavior:contain;
  }
  .biomiodek-furgonetka-map-shell{
    max-width:100vw !important;
    max-height:100dvh !important;
    box-sizing:border-box !important;
  }
  @media(max-width:760px){
    .biomiodek-furgonetka-map-shell{
      position:fixed !important;
      inset:0 !important;
      left:0 !important;
      top:0 !important;
      right:auto !important;
      bottom:auto !important;
      width:100vw !important;
      min-width:0 !important;
      max-width:100vw !important;
      height:100dvh !important;
      min-height:100dvh !important;
      max-height:100dvh !important;
      margin:0 !important;
      padding:0 !important;
      border:0 !important;
      border-radius:0 !important;
      transform:none !important;
      z-index:2147483000 !important;
      overflow:hidden !important;
    }
    .biomiodek-furgonetka-map-shell iframe,
    .biomiodek-furgonetka-map-shell > div{
      width:100% !important;
      max-width:100% !important;
      height:100% !important;
      max-height:100% !important;
      border-radius:0 !important;
    }
    .biomiodek-furgonetka-map-shell input,
    .biomiodek-furgonetka-map-shell button,
    .biomiodek-furgonetka-map-shell [role="button"]{
      min-height:44px;
    }
  }
  .co2-payment{ margin-top: 18px; }
  .co2-pay-options{ display:grid; grid-template-columns: 1fr 1fr; gap: 10px; }
  .co2-pay-opt{
    min-height: 76px; padding: 15px 14px; border: 1px solid var(--line); background: transparent;
    display:grid; grid-template-columns: minmax(0, 1fr) auto; align-items:center; gap: 10px; text-align:left; cursor:pointer;
  }
  .co2-pay-opt:hover{ border-color: var(--ink-soft); }
  .co2-pay-opt.active{ border-color: var(--ink); background: var(--ink); color: var(--bg); }
  .co2-pay-copy{ display:flex; flex-direction:column; gap:5px; min-width:0; }
  .co2-pay-copy > span{ font-family: var(--serif); font-size: 17px; font-weight: 500; }
  .co2-pay-opt small{ font-family: var(--mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-soft); }
  .co2-pay-opt.active small{ color: oklch(0.78 0.018 80); }
  .co2-pay-surcharge{ font-family: var(--mono); font-size: 12px; letter-spacing:.08em; white-space:nowrap; color: var(--amber-deep); }
  .co2-pay-opt.active .co2-pay-surcharge{ color: var(--bg); }
  .co2-pickup-note{
    margin-top: 14px; padding: 14px 18px; border-left: 2px solid var(--ink-soft);
    background: var(--bg-2); font-size: 13px; line-height: 1.7; color: var(--ink-soft);
  }
  .co2-nav{ display:flex; gap: 12px; margin-top: 30px; }
  .co2-nav-back{
    flex:0 0 auto; padding: 16px 24px; border: 1px solid var(--line); background: transparent;
    font-family: var(--sans); font-size: 12px; letter-spacing: .18em; text-transform: uppercase;
    color: var(--ink); cursor: pointer;
  }
  .co2-nav-back:hover{ border-color: var(--ink); }
  .co2-nav-next{
    flex:1; padding: 16px 24px; border: none; background: var(--ink); color: var(--bg);
    font-family: var(--sans); font-size: 12px; letter-spacing: .22em; text-transform: uppercase; cursor: pointer;
    clip-path: polygon(14px 0%, calc(100% - 14px) 0%, 100% 50%, calc(100% - 14px) 100%, 14px 100%, 0% 50%);
    transition: background 180ms ease;
  }
  .co2-nav-next:hover{ background: var(--amber-deep); }
  .co2-nav-next[disabled]{ opacity:.4; cursor:not-allowed; }
  .co2-nav-next[disabled]:hover{ background: var(--ink); }
  .co2-nav-final .co2-nav-next{ font-size: 11px; letter-spacing: .14em; text-align:center; overflow-wrap:anywhere; }
  @media(max-width:560px){
    .co2{
      padding: 28px 0 calc(86px + env(safe-area-inset-bottom));
    }
    .co2-card{ max-width:none; }
    .co2-title{ font-size: 34px; margin-bottom: 22px; }
    .co2-back{ display:none; }
    .co2-prod{ gap: 12px; padding: 16px 0; }
    .co2-prod-thumb{ width:64px; height:64px; }
    .co2-prod-price{ font-size: 12px; }
    .co2-promo-row{ flex-direction:row; align-items:stretch; }
    .co2-promo-row button{ flex:0 0 112px; min-height: 44px; padding: 12px 10px; }
    .co2-fields{ grid-template-columns: 1fr; }
    .co2-field-full{ grid-column: span 1; }
    .co2-delivery-opt{
      display:grid;
      grid-template-columns: 1fr auto;
      align-items:center;
      padding: 13px 14px;
      gap: 10px 12px;
    }
    .co2-delivery-logos{ grid-column: 1 / -1; justify-content:flex-start; }
    .co2-delivery-cost{ align-self:start; padding-top: 2px; }
    .co2-point-picked{ align-items:flex-start; }
    .co2-pay-options{ grid-template-columns: 1fr; }
    .co2-next{
      position:fixed;
      left:14px;
      right:14px;
      bottom:calc(12px + env(safe-area-inset-bottom));
      z-index:500;
      width:auto;
      min-height:56px;
      margin:0;
      padding: 15px 18px;
      box-shadow:0 -8px 24px rgba(42,34,24,.16);
    }
    .co2-next-main{
      font-size: 12px;
      letter-spacing:.16em;
      text-align:center;
      overflow-wrap:anywhere;
    }
    .co2-next-sub{
      font-size: 8px;
      letter-spacing:.12em;
      text-align:center;
    }
    .co2-nav{
      position:fixed;
      left:0;
      right:0;
      bottom:0;
      z-index:500;
      display:grid;
      grid-template-columns: minmax(104px, .42fr) minmax(0, 1fr);
      gap: 10px;
      margin:0;
      padding: 12px 14px calc(12px + env(safe-area-inset-bottom));
      background: var(--bg);
      border-top: 1px solid var(--line);
      box-shadow: 0 -8px 24px rgba(42,34,24,.12);
    }
    .co2-nav-back,
    .co2-nav-next{
      min-width:0;
      min-height:52px;
      padding: 13px 12px;
      display:flex;
      align-items:center;
      justify-content:center;
      text-align:center;
      line-height:1.2;
    }
    .co2-nav-next{
      font-size:11px;
      letter-spacing:.14em;
      overflow-wrap:anywhere;
    }
    .co2-nav-final .co2-nav-next{ letter-spacing:.12em; }
  }

  /* ——— Footer ——— */
  footer{
    padding: 80px 0 48px;
    border-top: 1px solid var(--line);
  }
  .foot-grid{
    display:grid; grid-template-columns: 2fr 1fr 1fr 1fr 1fr 1.2fr; gap: 48px;
    margin-bottom: 64px;
  }
  .foot-grid h4{ font-family: var(--mono); font-size: 11px; letter-spacing:.22em; text-transform:uppercase; color: var(--ink-soft); margin-bottom: 18px; font-weight: 500; }
  .foot-grid ul{ list-style:none; display:flex; flex-direction:column; gap:10px; font-size: 14px; }
  .foot-grid ul a:hover{ color: var(--amber-deep); }
  .foot-brand .b{ font-family: var(--serif); font-size: 38px; letter-spacing: 0.06em; font-weight: 500; }
  .foot-brand p{ color: var(--ink-soft); max-width: 320px; margin-top: 14px; font-size: 14px; }
  .legal{
    padding: 26px 0;
    border-top: 1px solid var(--line);
    font-size: 12px; line-height: 1.7; color: var(--ink-soft);
    max-width: 760px;
  }
  .legal strong{ color: var(--ink); font-weight: 500; letter-spacing: .04em; }
  .foot-bar{
    display:flex; justify-content:space-between; gap: 24px; padding: 22px 0 0; border-top:1px solid var(--line);
    font-family: var(--mono); font-size: 11px; letter-spacing:.16em; text-transform:uppercase; color: var(--ink-soft);
  }
  @media(max-width:760px){
    .foot-bar{ flex-direction:column; gap: 10px; padding-bottom:32px; }
    .foot-legal{ text-align:left; }
  }
  @media(max-width:1024px){ .foot-grid{ grid-template-columns: 2fr 1fr 1fr; gap: 40px; } }
  @media(max-width:640px){
    .foot-grid{ grid-template-columns: 1fr 1fr; gap: 32px 24px; align-items: start; }
    .foot-brand{ grid-column: 1 / -1; order: 0; }
    .foot-brand-name{ display: none; }
    .foot-pasieka{ order: 3; }
    .foot-informacje{ order: 2; }
    .foot-platnosci{ order: 4; grid-column: 1 / -1; }
  }

  /* ——— Toast ——— */
  .toast{
    position:fixed; bottom: 26px; left: 50%; transform: translateX(-50%) translateY(20px);
    background: var(--ink); color: var(--bg);
    padding: 14px 22px; border-radius: 999px;
    font-family: var(--mono); font-size: 11px; letter-spacing:.18em; text-transform:uppercase;
    text-align:center;
    opacity:0; pointer-events:none;
    transition: all 240ms ease;
    z-index: 200;
  }
  .toast-name{ display:block; letter-spacing:.08em; text-transform:none; opacity:.7; margin-top:3px; font-size:10px; }
  .toast.show{ opacity:1; transform: translateX(-50%) translateY(0); }
  @media(max-width:640px){
    .toast{ bottom:auto; top:50%; transform:translate(-50%,-60%); }
    .toast.show{ transform:translate(-50%,-50%); }
  }

  /* ——— Responsive grids ——— */
  .rg-2col{ display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--line); align-items:stretch; }
  .rg-2col > .cover-wrap-ar{ aspect-ratio:unset; height:100%; min-height:320px; }
  .rg-3col{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:1px; background:var(--line); }
  .rg-1-2{ display:grid; grid-template-columns:1fr 2fr; gap:60px; align-items:start; }
  .rg-txt-2{ display:grid; grid-template-columns:1fr 1fr; gap:32px; }
  .rg-contact{ display:grid; grid-template-columns:1fr 1fr; gap:80px; }
  .rg-pad{ padding:52px 48px; display:flex; flex-direction:column; justify-content:center; gap:20px; background:var(--bg); }
  .rg-pad-lg{ padding:72px 56px; display:flex; flex-direction:column; justify-content:center; gap:24px; background:var(--bg); }
  @media(max-width:760px){
    .rg-2col{ grid-template-columns:1fr; }
    .rg-2col > .cover-wrap-ar{ aspect-ratio:4/3; height:auto; min-height:0; }
    .rg-3col{ grid-template-columns:1fr; }
    .rg-1-2{ grid-template-columns:1fr; gap:32px; }
    .rg-txt-2{ grid-template-columns:1fr; gap:20px; }
    .rg-contact{ grid-template-columns:1fr; gap:40px; }
    .rg-pad{ padding:36px 28px; }
    .rg-pad-lg{ padding:40px 28px; }
  }


  /* ——— RODO banner ——— */
  .rodo{position:fixed;bottom:0;left:0;right:0;background:var(--ink);color:var(--bg);z-index:200;
    display:flex;align-items:center;justify-content:space-between;gap:20px;
    padding:16px 32px;font-size:12px;line-height:1.5;}
  .rodo a{color:var(--amber);text-decoration:underline;}
  .rodo-btn{padding:8px 18px;border:1px solid var(--bg);font-size:11px;letter-spacing:.18em;
    text-transform:uppercase;cursor:pointer;background:none;color:var(--bg);white-space:nowrap;}
  .rodo-btn:hover{background:var(--bg);color:var(--ink);}
  @media(max-width:760px){.rodo{flex-direction:column;gap:12px;text-align:center;}}

  /* ——— Lightbox ——— */
  .lb-ov{position:fixed;inset:0;background:oklch(0.1 0.01 60 / 0.92);z-index:300;
    display:flex;align-items:center;justify-content:center;padding:20px;cursor:zoom-out;}
  .lb-wrap{ position:relative; display:inline-block; line-height:0; cursor:default; }
  .lb-wrap::after{ content:''; position:absolute; top:0; right:0; width:80px; height:80px; background:url('/photos/logo_nobg.png') center/80px 80px no-repeat; pointer-events:none; z-index:301; }
  .lb-img{max-width:90vw;max-height:90vh;object-fit:contain;display:block;}
  .lb-close{position:fixed;top:20px;right:28px;font-family:var(--mono);font-size:12px;
    letter-spacing:.22em;text-transform:uppercase;color:#fff;opacity:.7;cursor:pointer;}
  .lb-close:hover{opacity:1;}

  /* ——— Sticky CTA ——— */
  .sticky-cta{
    position:fixed;bottom:0;left:0;right:0;z-index:60;
    background:var(--bg);border-top:1px solid var(--line);
    padding:14px 24px;display:flex;align-items:center;gap:14px;
    transform:translateY(100%);transition:transform 280ms cubic-bezier(.2,.7,.2,1);
    box-shadow:0 -4px 24px oklch(0.23 0.025 60 / 0.10);
  }
  .sticky-cta.show{transform:translateY(0);}
  .sticky-cta .sct-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px;}
  .sticky-cta .sct-name{font-family:var(--serif);font-size:18px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .sticky-cta .sct-variant{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .sticky-cta .sct-price{font-family:var(--mono);font-size:13px;color:var(--ink-soft);}
  @media(max-width:760px){
    .sticky-cta .sct-name{font-size:15px;}
    .sticky-cta .sct-variant{font-size:10px;}
  }

  /* ——— Site banner ——— */
  .site-banner{
    padding: 13px 24px; text-align: center;
    font-family: var(--mono); font-size: 12px; letter-spacing: .18em;
    text-transform: uppercase; line-height: 1.5;
  }
  .site-banner.info{background:oklch(0.92 0.07 75);color:oklch(0.38 0.1 65);}
  .site-banner.warn{background:oklch(0.91 0.07 25);color:oklch(0.38 0.16 25);}
  .site-banner.ok{background:oklch(0.9 0.08 145);color:oklch(0.32 0.14 145);}

  /* hover lift on cards */
  .card .thumb svg{ transition: transform 600ms cubic-bezier(.2,.7,.2,1); }
  .card:hover .thumb svg{ transform: scale(1.03); }

  /* ——— Extracted layout / component classes ——— */

  /* Page section layouts */
  .pg-hdr      { padding: 56px 0 24px; }
  .pg-hdr-lg   { padding: 56px 0 0; }
  .pg-hdr-shop { padding: 56px 0 28px; }
  .pg-body      { padding: 24px 0 96px; }
  .pg-body-shop { padding: 32px 0 96px; }

  /* Shop — zestawy prezentowe placeholder */
  .zestawy-ph   { padding:72px 0 48px; text-align:center; border-top:1px solid var(--line-soft); }
  .zestawy-bn   { padding:48px 0 0; text-align:center; border-top:1px solid var(--line-soft); margin-top:48px; }
  .zestawy-ph .label-mono,
  .zestawy-bn .label-mono { margin-bottom:16px; }
  .zestawy-ph-h { font-family:var(--serif); font-weight:400; font-size:clamp(28px,3.5vw,44px); line-height:1.1; margin-bottom:20px; }
  .zestawy-ph-h em { font-style:italic; color:var(--amber-deep); }
  .zestawy-bn-h { font-family:var(--serif); font-weight:400; font-size:clamp(22px,3vw,36px); line-height:1.1; margin-bottom:20px; }
  .zestawy-p    { max-width:480px; margin:0 auto 28px; }
  .eyebrow-promo{ margin-bottom:10px; }
  .pg-body-faq  { padding: 24px 0 96px; max-width: 820px; }
  .pg-body-legal{ padding: 24px 0 96px; max-width: 760px; }
  .pg-body-legal-flex{ padding: 24px 0 96px; max-width: 760px; display:flex; flex-direction:column; gap:28px; }

  /* Page headings */
  .pg-h1       { font-family:var(--serif); font-weight:400; font-size:clamp(40px,5.5vw,76px); line-height:.98; letter-spacing:-.005em; max-width:900px; }
  .pg-h1 em    { font-style:italic; color:var(--amber-deep); }
  .pg-h1-lg    { font-family:var(--serif); font-weight:400; font-size:clamp(44px,6vw,88px); line-height:.98; letter-spacing:-.01em; }
  .pg-h1-lg em { font-style:italic; color:var(--amber-deep); }
  .pg-h1-maxw  { max-width:1000px; }
  .pg-h1-faq   { font-family:var(--serif); font-weight:400; font-size:clamp(40px,5.5vw,72px); line-height:.98; letter-spacing:-.005em; }
  .pg-h1-legal { font-family:var(--serif); font-weight:400; font-size:clamp(36px,5vw,64px); line-height:.98; }

  /* Hero */
  .hero-cta    { margin-top:44px; }
  .hero-quote  { font-family:var(--serif); font-style:italic; font-size:22px; line-height:1.4; color:var(--ink); }
  .hero-eyebrow{ margin-bottom:28px; }

  /* Pasieka banner (home full-width photo) */
  .pgb        { width:100%; aspect-ratio:21/8; overflow:hidden; position:relative; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
  .pgb-img    { width:100%; height:100%; object-fit:cover; object-position:center 60%; display:block; }
  .pgb-overlay{ position:absolute; inset:0; background:linear-gradient(135deg,oklch(0.23 0.025 60/.28) 0%,transparent 60%); }
  .pgb-foot   { position:absolute; bottom:32px; left:0; right:0; }
  .pgb-captions{ display:flex; justify-content:space-between; align-items:flex-end; }
  .pgb-cap-l  { font-family:var(--mono); font-size:11px; letter-spacing:.28em; text-transform:uppercase; color:oklch(0.96 0.012 82/.85); }
  .pgb-cap-r  { font-family:var(--mono); font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:oklch(0.96 0.012 82/.7); }

  /* Cover images with hover zoom */
  .cover-wrap   { overflow:hidden; min-height:320px; }
  .cover-wrap-ar{ overflow:hidden; aspect-ratio:4/3; }
  .cover-img    { width:100%; height:100%; object-fit:cover; display:block; transition:transform 700ms cubic-bezier(.2,.7,.2,1); }
  .cover-img:hover   { transform:scale(1.04); }
  .cover-img-t20     { object-position:center 20%; }
  .story-section     { border-top:1px solid var(--line); border-bottom:1px solid var(--line); }

  /* About section */
  .about-section     { border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
  .about-banner      { width:100%; aspect-ratio:21/8; overflow:hidden; position:relative; }
  .about-banner-img  { width:100%; height:100%; object-fit:cover; object-position:center 65%; display:block; }
  .about-banner-ov   { position:absolute; inset:0; background:linear-gradient(to bottom,transparent 55%,oklch(0.23 0.025 60/.5)); }
  .about-badge-wrap  { position:absolute; bottom:36px; left:0; right:0; text-align:center; }
  .about-badge       { display:inline-block; font-family:var(--mono); font-size:11px; letter-spacing:.32em; text-transform:uppercase; color:oklch(0.96 0.012 82); background:oklch(0.23 0.025 60/.55); padding:10px 22px; }

  /* Process section (About — Jak pracujemy) */
  .process-hdr  { padding:72px 0 56px; }
  .process-h2   { font-family:var(--serif); font-weight:400; font-size:clamp(38px,5vw,68px); line-height:.98; letter-spacing:-.005em; max-width:860px; }
  .process-h2 em{ font-style:italic; color:var(--amber-deep); }
  .process-num  { font-family:var(--mono); font-size:11px; letter-spacing:.3em; text-transform:uppercase; color:var(--ink-soft); }
  .process-step { font-family:var(--serif); font-size:clamp(26px,2.5vw,38px); line-height:1.1; font-weight:400; }
  .process-pb   { color:var(--ink-soft); font-size:15px; line-height:1.8; max-width:460px; }
  .process-04        { background:var(--bg-2); border-top:1px solid var(--line); margin-top:1px; }
  .process-04-inner  { padding:68px 0; }
  .process-04-num    { font-family:var(--mono); font-size:11px; letter-spacing:.3em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:20px; }
  .process-04-h      { font-family:var(--serif); font-size:clamp(26px,2.6vw,40px); line-height:1.1; font-weight:400; }
  .shell-pb0    { padding-bottom:0; }
  .shell-pt1    { padding-top:1px; }

  /* Photo grid with captions */
  .photo-grid-col { position:relative; overflow:hidden; aspect-ratio:3/4; }
  .photo-grid-img { width:100%; height:100%; object-fit:cover; display:block; transition:transform 700ms cubic-bezier(.2,.7,.2,1); }
  .photo-grid-img:hover { transform:scale(1.05); }
  .photo-cap      { position:absolute; bottom:0; left:0; right:0; background:linear-gradient(to top,oklch(0.23 0.025 60/.72) 0%,transparent 100%); padding:40px 22px 20px; }
  .photo-cap .cap-num   { font-family:var(--mono); font-size:9px; letter-spacing:.28em; text-transform:uppercase; color:oklch(0.96 0.012 82/.65); margin-bottom:6px; }
  .photo-cap .cap-title { font-family:var(--serif); font-size:19px; color:oklch(0.96 0.012 82); line-height:1.15; font-weight:400; margin-bottom:5px; }
  .photo-cap .cap-sub   { font-family:var(--mono); font-size:10px; letter-spacing:.14em; color:oklch(0.96 0.012 82/.65); line-height:1.4; }

  /* Product card */
  .card-img     { width:100%; height:100%; object-fit:contain; object-position:center; display:block; padding:12px; }
  .sold-out-bar { position:absolute; bottom:0; left:0; right:0; background:oklch(0.23 0.025 60/.72); color:#fff; font-family:var(--mono); font-size:10px; letter-spacing:.28em; text-transform:uppercase; padding:8px; text-align:center; }
  .card .thumb::after { content:''; position:absolute; top:12px; right:18px; width:48px; height:48px; background:url('/photos/logo_nobg.png') center/48px 48px no-repeat; pointer-events:none; z-index:2; }
  .pd .gallery .main::after { content:''; position:absolute; top:31px; right:41px; width:80px; height:80px; background:url('/photos/logo_nobg.png') center/80px 80px no-repeat; pointer-events:none; z-index:2; }
  @media (max-width:760px){ .pd .gallery .main::after { right:35px; } .card .thumb::after { right:21px; } }

  /* Product detail */
  .pd-full-img  { width:100%; height:100%; object-fit:contain; object-position:center; display:block; padding:32px; background:var(--bg-2); }
  .zoom-hint    { position:absolute; bottom:8px; right:10px; font-family:var(--mono); font-size:9px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); opacity:.6; }
  .photo-thumbs { display:flex; gap:8px; margin-top:10px; overflow-x:auto; }
  .photo-thumb  { flex-shrink:0; width:64px; height:64px; padding:0; background:var(--bg-2); border:2px solid var(--line-soft); border-radius:2px; cursor:pointer; overflow:hidden; }
  .photo-thumb img { width:100%; height:100%; object-fit:cover; display:block; }
  .photo-thumb.active { border-color:var(--amber-deep); }
  .price-meta   { font-family:var(--mono); font-size:13px; color:var(--ink-soft); margin-left:10px; letter-spacing:.06em; }
  .pd-sentinel  { display:block; width:1px; height:1px; position:absolute; }
  .pd-related   { padding-top:32px; }
  .btn-flex     { flex:1; }
  .btn-story    { align-self:flex-start; margin-top:8px; }
  .pd-notfound  { padding:96px 0; }
  .pd-notfound a{ margin-top:24px; display:inline-flex; }

  /* Cart drawer */
  .di-thumb-img { width:100%; height:100%; object-fit:contain; display:block; }
  .di-right     { display:flex; flex-direction:column; align-items:flex-end; gap:6px; }

  /* Contact */
  .contact-hdr    { padding:56px 0 0; }
  .contact-h1     { font-family:var(--serif); font-weight:400; font-size:clamp(44px,6vw,88px); line-height:.98; letter-spacing:-.01em; }
  .meta-list-flush{ margin-top:0; border-top:1px solid var(--line); }
  .map-wrap       { margin-top:20px; font-size:0; line-height:0; overflow:hidden; border:1px solid var(--line); }
  .contact-sent   { padding-top:24px; }
  .contact-sent-h { font-family:var(--serif); font-size:22px; font-weight:400; margin-bottom:16px; }
  .form-err       { color:var(--amber-deep); font-family:var(--mono); font-size:11px; letter-spacing:.12em; margin:8px 0; font-weight:bold; }

  /* Checkout */
  .co-ok          { padding:96px 0 140px; max-width:700px; }
  .co-ok h1       { font-family:var(--serif); font-weight:400; font-size:clamp(40px,5vw,68px); line-height:1; margin-bottom:28px; }
  .co-ok p        { color:var(--ink-soft); font-size:17px; line-height:1.7; margin-bottom:36px; max-width:540px; }
  .co-loader      { width:52px; height:52px; border-radius:50%; border:3px solid var(--line); border-top-color:var(--amber-deep); margin:0 auto 28px; animation:co-spin 850ms linear infinite; }
  @keyframes co-spin{ to{ transform:rotate(360deg); } }
  .co-empty       { padding:96px 0 120px; }
  .co-empty-action{ text-align:center; margin-top:28px; }
  .checkout-mini-footer{
    display:block;
    margin:24px auto 40px;
    padding:0 18px;
    max-width:520px;
    font-family:var(--mono);
    font-size:11px;
    line-height:1.7;
    letter-spacing:.08em;
    text-transform:uppercase;
    color:var(--ink-soft);
    text-align:center;
  }
  .checkout-mini-footer-links{
    display:flex;
    flex-wrap:wrap;
    justify-content:center;
    align-items:center;
    gap:7px;
  }
  .checkout-mini-footer a{ color:inherit; text-decoration:none; }
  .checkout-mini-footer a:hover{ color:var(--ink); }
  .checkout-mini-credit{
    margin-top:9px;
    font-size:10px;
    letter-spacing:.06em;
    text-transform:none;
    color:oklch(0.48 0.025 72 / .72);
  }
  .checkout-mini-credit a{ text-decoration:underline; text-underline-offset:2px; }
  @media(max-width:640px){
    .checkout-mini-footer{
      margin:12px auto 0;
      padding:0 18px calc(96px + env(safe-area-inset-bottom));
      max-width:360px;
      font-size:10px;
    }
    .checkout-mini-credit{
      margin-top:7px;
      font-size:9px;
    }
  }
  .eyebrow-mb     { margin:0 0 14px; }
  .eyebrow-top    { margin:28px 0 14px; }
  .grid-mb        { margin-bottom:28px; }
  .promo-row      { display:flex; gap:10px; margin-bottom:6px; }
  .promo-input    { flex:1; padding:11px 14px; border:1px solid var(--line); background:transparent; font-family:var(--mono); font-size:13px; letter-spacing:.1em; outline:none; }
  .promo-msg      { font-family:var(--mono); font-size:11px; letter-spacing:.12em; margin-bottom:6px; font-weight:bold; }
  .promo-msg.err  { color:var(--amber-deep); }
  .promo-msg.ok   { color:oklch(0.40 0.14 145); }
  .co-submit      { margin-top:32px; }
  .co-err{
    margin:0 0 14px;
    padding:11px 14px;
    background:oklch(0.97 0.018 28 / 0.55);
    border-left:3px solid oklch(0.52 0.20 28);
    color:oklch(0.38 0.16 28);
    font-size:13px;
    font-weight:bold;
    line-height:1.55;
    border-radius:2px;
  }
  .sum-meta       { text-align:right; max-width:140px; }
  .sum-grand-row  { border-bottom:none; margin-top:8px; }
  .sum-grand      { font-family:var(--serif); font-size:22px; font-weight:500; }
  .sum-discount   { color:oklch(0.40 0.14 145); }
  .sum-discount-v { font-family:var(--mono); font-size:13px; }
  .btn-cursor-default{ cursor:default; }
  .co-doc-section { margin-top:34px; padding-top:24px; border-top:1px solid var(--line); }
  .co-doc-check,
  .co-terms-label { display:flex; gap:12px; align-items:flex-start; color:var(--ink-soft); font-size:13px; line-height:1.65; }
  .input-wrap input::placeholder,
  .input-wrap textarea::placeholder { font-family:"DM Sans",Helvetica,Arial,sans-serif; font-size:14px; letter-spacing:0; color:var(--ink-soft); opacity:.6; }
  .co-doc-check input,
  .co-terms-label input { margin-top:4px; flex:0 0 auto; }
  .co-doc-options { display:grid; gap:10px; margin-top:16px; }
  .co-doc-opt { display:grid; grid-template-columns:auto 1fr; gap:4px 12px; padding:16px; border:1px solid var(--line); cursor:pointer; }
  .co-doc-opt.active { border-color:var(--ink); background:var(--bg-2); }
  .co-doc-name { font-family:var(--serif); font-size:19px; font-weight:500; line-height:1.2; }
  .co-doc-desc { grid-column:2; color:var(--ink-soft); font-size:13px; line-height:1.55; }
  .co-doc-note { color:var(--ink-soft); font-size:13px; line-height:1.7; margin-top:4px; }
  .co-terms { margin-top:24px; }
  .co-terms a { color:var(--ink); text-decoration:underline; text-underline-offset:3px; }

  /* Footer */
  .foot-sub      { font-family:var(--mono); font-size:10px; letter-spacing:.32em; text-transform:uppercase; color:var(--ink-soft); margin-top:4px; }
  .foot-social   { margin-top:8px; }
  .social-links  { display:flex; gap:14px; }
  .social-link   { display:flex; align-items:center; gap:6px; }
  .foot-legal    { text-align:right; opacity:.7; }
  .site-credit { padding-top:16px; text-align:center; font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); opacity:.7; }
  .site-credit a { color:var(--ink); text-decoration:underline; text-underline-offset:3px; }
  .site-credit a:hover { color:var(--amber-deep); }
  .payment-flags { display:flex; flex-wrap:wrap; gap:8px; align-items:center; }
  .payment-flags img { max-width:92px; max-height:28px; object-fit:contain; background:var(--bg-2); border:1px solid var(--line-soft); padding:4px 6px; }

  /* 404 */
  .nf-page    { padding:96px 0 140px; max-width:700px; }
  .nf-h1      { font-family:var(--serif); font-weight:400; font-size:clamp(40px,5vw,68px); line-height:1; margin-bottom:28px; }
  .nf-body    { color:var(--ink-soft); font-size:17px; line-height:1.7; margin-bottom:36px; max-width:520px; }
  .nf-actions { display:flex; gap:16px; flex-wrap:wrap; }

  /* FAQ accordion */
  .faq-item   { border-bottom:1px solid var(--line); }
  .faq-btn    { width:100%; display:flex; justify-content:space-between; align-items:center; padding:22px 0; gap:16px; text-align:left; cursor:pointer; background:none; border:none; }
  .faq-q      { font-family:var(--serif); font-size:20px; font-weight:500; line-height:1.2; }
  .faq-icon   { font-family:var(--mono); font-size:18px; flex-shrink:0; color:var(--ink-soft); transition:transform 240ms; }
  .faq-icon.open{ transform:rotate(45deg); }
  .faq-answer { color:var(--ink-soft); font-size:15px; line-height:1.8; padding-bottom:22px; }

  /* Legal (Regulamin, Polityka) */
  .legal-item { margin-bottom:32px; }
  .legal-h3   { font-family:var(--serif); font-weight:500; font-size:22px; margin-bottom:10px; }
  .legal-p    { color:var(--ink-soft); font-size:15px; line-height:1.8; }
  .legal-date { font-family:var(--mono); font-size:11px; color:var(--ink-soft); letter-spacing:.14em; margin-top:32px; }
  .polityka-h3{ font-family:var(--serif); font-weight:500; font-size:20px; margin-bottom:8px; }
  .polityka-p { color:var(--ink-soft); font-size:15px; line-height:1.8; }

  /* Odstąpienie */
  .odstap-alt      { margin-top:52px; padding-top:32px; border-top:1px solid var(--line); }
  .odstap-alt-label{ font-family:var(--mono); font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:14px; }
  .odstap-alt-text { color:var(--ink-soft); font-size:14px; line-height:1.85; }
  .odstap-alt-text a{ color:var(--ink); }
  .form-err-p      { font-size:14px; margin:0; color:var(--error, #c0392b); font-weight:bold; }

  /* ——— Mobile fixes ——— */

  /* disabled shipping option */
  .size-opt.disabled{ opacity:.38; cursor:not-allowed; pointer-events:none; }

  /* form-grid → single column on mobile */
  @media(max-width:640px){
    .form-grid{ grid-template-columns:1fr; }
    .form-grid .full{ grid-column:span 1; }
    .cart-free-ship-missing{ display:block; margin-top:4px; }
    .cart-free-ship-missing::before{ content:""; }
  }

  /* hero: wyśrodkowanie treści na mobile */
  @media(max-width:880px){
    .hero h1{ text-align:center; }
    .hero .hero-eyebrow{ text-align:center; }
    .hero-eyebrow-extra{ display:none; }
    .hero-cta{ justify-content:center; flex-wrap:wrap; }
  }
  /* hero CTA buttons: side by side na mobile, nie rozciągnięte */
  @media(max-width:480px){
    .hero-cta{ flex-direction:row; align-items:center; flex-wrap:wrap; gap:12px; }
  }

  /* product detail: stacked actions, tighter spacing */
  @media(max-width:640px){
    .pd{ gap:32px; padding:24px 0 60px; }
    .pd .info .price-line{ font-size:28px; }
    .row-actions{ flex-direction:column; gap:10px; }
    .row-actions .btn{ width:100%; }
    .qty button{ width:48px; height:48px; }
    .pd .meta-list{ margin-top:32px; }
    .meta-list .row{ grid-template-columns: 132px 1fr; gap:12px; }
  }

  /* checkout summary padding on mobile */
  @media(max-width:640px){
    .summary-card{ padding:20px 18px; }
    .breadcrumbs{ padding:14px 0 4px; font-size:10px; }
  }

  /* footer: zachowaj 2 kolumny nawet na bardzo małych ekranach */
  @media(max-width:380px){
    .foot-grid{ grid-template-columns:1fr 1fr; gap:24px 14px; }
    .foot-brand{ grid-column: 1 / -1; }
  }

  /* cart drawer: tighter layout on very small screens */
  @media(max-width:380px){
    .drawer-head{ padding:16px; }
    .cart-notice{ margin:12px 16px 4px; }
    .drawer-items{ padding:8px 16px; }
    .drawer-foot{ padding:14px 16px 20px; }
    .drawer-item{ grid-template-columns:72px 1fr auto; gap:10px; }
    .cart-free-ship-missing{ display:block; margin-top:4px; }
    .cart-free-ship-missing::before{ content:""; }
  }

  /* sticky CTA: prevent overlap with RODO banner */
  @media(max-width:760px){
    .sticky-cta{ padding:12px 16px; }
    .sticky-cta .sct-price{ display:none; }
  }

  /* hero-meta (tag + akapity + cytat) — ukryj na mobile, treść jest zbędna pod przyciskami */
  @media(max-width:880px){
    .hero-meta{ display:none; }
  }

  /* pgb captions — ukryj prawy napis na wąskich ekranach */
  @media(max-width:640px){
    .pgb-cap-r{ display:none; }
  }

  /* hero eyebrow — zmniejsz letter-spacing żeby nie łamało do 2 linii */
  @media(max-width:480px){
    .hero-eyebrow{ letter-spacing:.12em; }
  }
