/* =========================================================================
   DriveMood — theme.css
   Design tokeny + komponenty podle handoffu (pixel-perfect, mobile-first).
   ========================================================================= */

/* ---------- Tokeny ---------- */
:root{
  --black:#0d0d0d;
  --red:#d71920;
  --red-hover:#b3141a;        /* CTA hover na světlém */
  --red-hover-dark:#ef2a32;   /* CTA hover na tmavém */
  --red-light:#ff5a64;        /* akcent na tmavém */
  --red-surface:#fdeaeb;
  --red-on-surface:#a8121a;
  --gray-dark:#2a2a2a;
  --white:#fff;
  --surface:#fafafa;
  --surface-2:#f6f6f6;
  --border:#ececec;
  --border-btn:#d9d9d9;
  --text-2:#5a5a5a;
  --text-2b:#3a3a3a;
  --text-3:#8c8c8c;
  --muted:#c0c0c0;
  --price-old:#b0b0b0;
  --green:#0f8a43;
  --hover-pill:#f1f1f1;
  --bundle-bg:#fef7f7;

  --font-head:'Saira Condensed',system-ui,sans-serif;
  --font-body:'Sora',system-ui,sans-serif;

  --r-pill:99px;
  --r-lg:22px;
  --r-card:18px;
  --r-md:16px;
  --r-sm:12px;
  --r-icon:12px;

  --sh-card:0 10px 30px rgba(13,13,13,.1);
  --sh-menu:0 30px 60px rgba(13,13,13,.18);
  --sh-toast:0 16px 40px rgba(13,13,13,.3);

  --pad-x:48px;         /* boční padding stránky (desktop) */
  --maxw:1440px;
}

/* ---------- Reset / základ ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--white);
  color:var(--black);
  font-family:var(--font-body);
  font-size:15px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
h1,h2,h3{font-family:var(--font-head);text-transform:uppercase;font-weight:700;margin:0;letter-spacing:.01em;line-height:1}

.dm-container{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad-x);padding-right:var(--pad-x)}
.dm-visually-hidden{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}

/* ---------- Tlačítka ---------- */
.dm-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:var(--r-pill);
  font-family:var(--font-body);font-weight:600;cursor:pointer;border:1.5px solid transparent;
  transition:background .15s ease,color .15s ease,border-color .15s ease;text-align:center;white-space:nowrap}
.dm-btn--primary{background:var(--red);color:var(--white);padding:17px 36px;font-size:15px}
.dm-btn--primary:hover{background:var(--red-hover)}
.dm-btn--outline{border-color:var(--border-btn);color:var(--black);padding:17px 32px;font-size:15px;background:transparent}
.dm-btn--outline:hover{border-color:var(--black)}
.dm-btn--sm{padding:8px 16px;font-size:13px}
.dm-btn--block{width:100%}

/* ---------- Top bar ---------- */
.dm-topbar{background:var(--black);color:var(--white);display:flex;justify-content:center;align-items:center;
  gap:34px;padding:10px;font-size:12.5px;text-align:center}
.dm-topbar .sep{opacity:.4}
.dm-topbar b{color:var(--red-light);font-variant-numeric:tabular-nums}

/* ---------- Header ---------- */
.dm-headwrap{position:relative;z-index:20}
.dm-header{display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:20px var(--pad-x);border-bottom:1px solid var(--border);background:var(--white);position:relative;z-index:2}
.dm-logo{font-family:var(--font-head);font-weight:700;font-size:27px;letter-spacing:.02em;text-transform:uppercase;cursor:pointer;line-height:1}
.dm-logo .accent{color:var(--red)}
.dm-logo--custom{display:inline-flex;align-items:center}
.dm-logo--custom img{max-height:40px;width:auto;display:block}

.dm-nav{display:flex;gap:8px;font-size:14px;font-weight:500}
/* Jen přímé položky navigace – NE odkazy uvnitř dropdownu (.dm-drop-link) */
.dm-nav > a,.dm-nav .dm-navitem{display:flex;align-items:center;gap:7px;padding:9px 16px;border-radius:var(--r-pill);
  cursor:pointer;color:var(--black);transition:background .15s ease,color .15s ease}
.dm-nav > a:hover,.dm-nav .dm-navitem:hover{background:var(--hover-pill)}
.dm-nav .caret{font-size:10px;color:var(--text-3)}
.dm-nav .is-active{background:var(--black);color:var(--white)}
.dm-nav .is-active .caret{color:rgba(255,255,255,.7)}
.dm-nav .is-sale{color:var(--red)}
.dm-nav .is-sale:hover{background:var(--red-surface)}

.dm-actions{display:flex;gap:14px;align-items:center}
.dm-iconbtn{position:relative;width:44px;height:44px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;border-radius:var(--r-icon);background:transparent;border:0;transition:background .15s ease}
.dm-iconbtn:hover{background:var(--hover-pill)}
.dm-iconbtn svg{stroke:var(--black)}
.dm-cart-badge{position:absolute;top:-3px;right:-3px;background:var(--red);color:var(--white);border-radius:var(--r-pill);
  min-width:17px;height:17px;display:inline-flex;align-items:center;justify-content:center;font-size:10.5px;
  font-weight:600;padding:0 4px;border:2px solid var(--white);font-variant-numeric:tabular-nums}
.dm-cart-badge[data-count="0"]{display:none}

.dm-burger{display:none}

/* ---------- Mega menu / dropdown ---------- */
.dm-mega,.dm-dropdown{position:absolute;top:100%;background:var(--white);border:1px solid var(--border);
  box-shadow:var(--sh-menu);opacity:0;visibility:hidden;transform:translateY(6px);
  transition:opacity .16s ease,transform .16s ease,visibility .16s;z-index:1}
/* Neviditelný hover-bridge přes mezeru mezi položkou a panelem (jinak myš propadne) */
.dm-mega::before,.dm-dropdown::before{content:"";position:absolute;left:0;right:0;top:-12px;height:12px}
.dm-menuhost{position:relative}
.dm-menuhost:hover .dm-mega,.dm-menuhost:hover .dm-dropdown,
.dm-mega:hover,.dm-dropdown:hover{opacity:1;visibility:visible;transform:translateY(0)}
.dm-menuhost:hover > .dm-navitem{background:var(--black);color:var(--white)}
.dm-menuhost:hover > .dm-navitem .caret{color:rgba(255,255,255,.7)}

.dm-mega{left:var(--pad-x);right:var(--pad-x);border-radius:0 0 var(--r-lg) var(--r-lg);
  display:grid;grid-template-columns:1fr 1fr 1fr 1.3fr;overflow:hidden}
.dm-mega-col{padding:32px 12px 32px 36px;display:flex;flex-direction:column;gap:4px}
.dm-mega-col+.dm-mega-col{padding-left:12px}
.dm-mega-title{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3);margin-bottom:10px}
.dm-mega-link{font-size:14.5px;font-weight:500;padding:8px 12px;border-radius:10px;margin-left:-12px;cursor:pointer;
  transition:background .12s ease,color .12s ease}
.dm-mega-link:hover{background:var(--surface-2);color:var(--red)}
.dm-mega-all{font-size:14px;font-weight:600;color:var(--red);margin-top:12px;cursor:pointer}
.dm-mega-promo{padding:28px;display:flex;flex-direction:column;justify-content:flex-end;gap:8px;position:relative;
  overflow:hidden;min-height:300px;background:linear-gradient(140deg,var(--gray-dark),var(--black))}
.dm-mega-promo .ring{position:absolute;top:-50px;right:-50px;width:220px;height:220px;border-radius:50%;border:2px solid rgba(215,25,32,.5)}
.dm-mega-promo .badge{position:absolute;top:18px;left:24px;background:var(--red);color:var(--white);border-radius:var(--r-pill);font-size:11px;font-weight:600;padding:5px 11px}
.dm-mega-promo .kicker{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--red-light)}
.dm-mega-promo .title{font-size:22px;font-weight:700;color:var(--white);letter-spacing:-.02em}

.dm-dropdown{width:300px;border-radius:var(--r-md);padding:14px;display:flex;flex-direction:column;gap:2px;left:50%;transform:translateX(-50%) translateY(6px)}
.dm-menuhost:hover .dm-dropdown{transform:translateX(-50%) translateY(0)}
.dm-dropdown .dm-mega-title{padding:8px 12px 10px;margin:0}
.dm-drop-link{font-size:14.5px;font-weight:500;padding:10px 12px;border-radius:10px;display:flex;justify-content:space-between;
  align-items:center;cursor:pointer;transition:background .12s ease,color .12s ease}
.dm-drop-link:hover{background:var(--surface-2);color:var(--red)}
.dm-drop-link .count{color:var(--muted);font-size:12px}
.dm-dropdown .dm-drop-all{color:var(--red);font-weight:600}
.dm-drop-divider{height:1px;background:var(--border);margin:8px 4px}

/* ---------- Sekce / nadpisy ---------- */
.dm-section{padding-top:60px;padding-bottom:24px}
.dm-section-head{display:flex;justify-content:space-between;align-items:baseline;gap:20px;margin-bottom:24px}
.dm-section-head h2{font-size:38px}
.dm-section-link{font-size:14px;font-weight:600;color:var(--red);cursor:pointer;white-space:nowrap}
.dm-kicker{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3)}

/* ---------- Hero ---------- */
.dm-hero{padding:56px var(--pad-x) 30px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:20px}
.dm-badge-pill{display:inline-flex;align-items:center;gap:8px;background:var(--red-surface);color:var(--red-on-surface);
  border-radius:var(--r-pill);padding:8px 18px;font-size:13px;font-weight:600}
.dm-hero h1{font-size:76px;letter-spacing:.005em;line-height:.98;max-width:860px;text-wrap:balance}
.dm-hero p{margin:0;font-size:17px;font-weight:300;line-height:1.65;color:var(--text-2);max-width:560px}
.dm-hero-cta{display:flex;gap:14px;margin-top:6px;flex-wrap:wrap;justify-content:center}
.dm-hero-benefits{display:flex;align-items:center;gap:14px;margin-top:10px;font-size:13px;font-weight:600;color:var(--text-3);flex-wrap:wrap;justify-content:center}
.dm-hero-benefits .dash{width:56px;height:2px;background:repeating-linear-gradient(90deg,#cfcfcf 0 10px,transparent 10px 18px)}
.dm-hero-benefits .dot{color:#cfcfcf}

/* ---------- Bento ---------- */
.dm-bento{padding:34px var(--pad-x) 20px;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:18px}
.dm-bento-card{border-radius:var(--r-lg);padding:30px;display:flex;flex-direction:column;justify-content:flex-end;
  gap:6px;position:relative;overflow:hidden}
.dm-bento-card--lg{grid-column:auto;min-height:340px;padding:34px;gap:8px;background:linear-gradient(140deg,var(--gray-dark),var(--black))}
.dm-bento-card--light{background:linear-gradient(150deg,#f3f3f3,#dcdcdc)}
.dm-bento-card--dark{background:linear-gradient(150deg,#3a3a3a,#2a2a2a)}
.dm-bento-card .ring{position:absolute;border-radius:50%}
.dm-bento-card .ring--red{top:-60px;right:-60px;width:280px;height:280px;border:2px solid rgba(215,25,32,.5)}
.dm-bento-card .ring--white{top:0;right:40px;width:180px;height:180px;border:2px solid rgba(255,255,255,.12)}
.dm-bento-card .ring--soft{top:20px;left:30px;width:90px;height:90px;background:rgba(255,255,255,.7)}
.dm-bento-card .kicker{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}
.dm-bento-card .kicker--redlight{color:var(--red-light)}
.dm-bento-card .kicker--red{color:var(--red)}
.dm-bento-card .title{font-size:22px;font-weight:700;letter-spacing:-.02em}
.dm-bento-card--lg .title{font-size:30px;color:var(--white)}
.dm-bento-card .title--white{color:var(--white)}
.dm-bento-card .title--black{color:var(--black)}
.dm-bento-card .link{font-size:13.5px;font-weight:600;text-decoration:underline;cursor:pointer}
.dm-bento-card .pill-cta{display:inline-flex;width:fit-content;background:var(--red);color:var(--white);border-radius:var(--r-pill);
  padding:11px 22px;font-size:13.5px;font-weight:600;margin-top:6px;cursor:pointer;transition:background .15s ease}
.dm-bento-card .pill-cta:hover{background:var(--red-hover-dark)}

/* ---------- Produktová karta (sdílené) ---------- */
.dm-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.dm-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-card);padding:14px;
  display:flex;flex-direction:column;gap:12px;transition:box-shadow .18s ease}
.dm-card:hover{box-shadow:var(--sh-card)}
.dm-card-media{position:relative;aspect-ratio:1/1;border-radius:var(--r-sm);overflow:hidden;background:var(--surface);
  display:flex;align-items:center;justify-content:center}
.dm-card-media img{width:100%;height:100%;object-fit:cover}
.dm-card-badge{position:absolute;top:10px;left:10px;background:var(--red);color:var(--white);border-radius:var(--r-pill);
  font-size:11px;font-weight:600;padding:5px 11px;z-index:1}
.dm-card-body{display:flex;flex-direction:column;gap:4px;padding:0 4px 4px}
.dm-card-meta{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--text-3)}
.dm-card-title{font-size:15px;font-weight:600;color:var(--black)}
.dm-card-foot{display:flex;justify-content:space-between;align-items:center;margin-top:6px;gap:8px}
.dm-price{display:flex;align-items:baseline;gap:8px}
.dm-price .amount{font-size:16px;font-weight:700}
.dm-price del{font-size:12.5px;color:var(--price-old);text-decoration:line-through}
.dm-price ins{text-decoration:none}
.dm-addbtn{border:1.5px solid var(--border-btn);border-radius:var(--r-pill);padding:8px 16px;font-size:13px;
  font-weight:600;cursor:pointer;background:transparent;color:var(--black);transition:background .15s,color .15s,border-color .15s;white-space:nowrap}
.dm-addbtn:hover{background:var(--red);color:var(--white);border-color:var(--red)}
.dm-addbtn.loading{opacity:.6;pointer-events:none}
.dm-addbtn.added{background:var(--green);border-color:var(--green);color:#fff}

/* ---------- Kvíz banner ---------- */
.dm-quiz{margin:0 var(--pad-x);border-radius:var(--r-lg);background:var(--black);color:var(--white);
  padding:44px 48px;display:flex;justify-content:space-between;align-items:center;gap:40px}
.dm-quiz-text{display:flex;flex-direction:column;gap:10px;max-width:460px}
.dm-quiz-text .kicker{color:var(--red-light)}
.dm-quiz-text .title{font-size:28px;font-weight:700;letter-spacing:-.02em;line-height:1.2;font-family:var(--font-body)}
.dm-quiz-chips{display:flex;gap:12px;font-size:14px;font-weight:600;flex-wrap:wrap}
.dm-quiz-chip{border:1.5px solid rgba(255,255,255,.3);border-radius:var(--r-pill);padding:13px 22px;cursor:pointer;transition:border-color .15s,color .15s}
.dm-quiz-chip:hover{border-color:var(--red-light);color:var(--red-light)}
.dm-quiz-go{background:var(--red);border-radius:var(--r-pill);padding:13px 26px;cursor:pointer;color:#fff;transition:background .15s}
.dm-quiz-go:hover{background:var(--red-hover-dark)}

/* ---------- Recenze ---------- */
.dm-reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.dm-review{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-card);padding:26px;display:flex;flex-direction:column;gap:12px}
.dm-stars{color:var(--red);font-size:15px;letter-spacing:2px}
.dm-review-text{font-size:14.5px;line-height:1.65;color:var(--text-2b)}
.dm-review-author{font-size:13px;font-weight:600;color:var(--text-3)}

/* ---------- Footer ---------- */
.dm-footer{border-top:1px solid var(--border);padding:34px var(--pad-x);display:flex;justify-content:space-between;
  align-items:center;gap:20px;font-size:13px;color:var(--text-3);flex-wrap:wrap}
.dm-footer .brand{font-family:var(--font-head);font-weight:700;color:var(--black);font-size:17px;text-transform:uppercase}
.dm-footer .brand .accent{color:var(--red)}
.dm-footer nav{display:flex;gap:24px;flex-wrap:wrap}
.dm-footer nav a:hover{color:var(--black)}

/* ---------- Breadcrumb ---------- */
.dm-breadcrumb{padding:24px var(--pad-x) 0;display:flex;gap:8px;font-size:13px;color:var(--text-3);flex-wrap:wrap}
.dm-breadcrumb a:hover{color:var(--black)}
.dm-breadcrumb .current{color:var(--black);font-weight:600}

/* ---------- Shop / archiv ---------- */
.dm-shop-head{padding:28px var(--pad-x) 0;display:flex;flex-direction:column;gap:16px}
.dm-shop-titlerow{display:flex;justify-content:space-between;align-items:flex-end;gap:30px}
.dm-shop-head h1{font-size:50px;letter-spacing:.01em}
.dm-shop-head p{margin:0;font-size:15px;font-weight:300;color:var(--text-2);max-width:560px}
.dm-shop-count{font-size:13.5px;color:var(--text-3);white-space:nowrap}

.dm-filterbar{padding:22px var(--pad-x);display:flex;justify-content:space-between;align-items:center;gap:20px;
  border-bottom:1px solid var(--border);position:sticky;top:0;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);z-index:10}
.dm-chips{display:flex;gap:8px;flex-wrap:wrap}
.dm-chip{padding:9px 18px;border-radius:var(--r-pill);font-size:13.5px;font-weight:600;cursor:pointer;
  border:1.5px solid var(--border-btn);background:var(--white);color:var(--black);transition:all .15s}
.dm-chip:hover{border-color:var(--black)}
.dm-chip.is-active{background:var(--black);color:var(--white);border-color:var(--black)}
.dm-filter-tools{display:flex;gap:10px;align-items:center;font-size:13.5px;font-weight:500;color:var(--text-2);white-space:nowrap}
.dm-orderby-wrap{display:flex;align-items:center;gap:8px;border:1.5px solid var(--border-btn);border-radius:var(--r-pill);padding:9px 16px}
.dm-orderby-wrap select{border:0;background:transparent;font:inherit;color:inherit;cursor:pointer;outline:none}

.dm-shop-grid{padding:28px var(--pad-x) 0}
.dm-upsell-row{padding:18px var(--pad-x) 0;display:grid;grid-template-columns:1fr 1fr;gap:18px}
.dm-upsell{border-radius:var(--r-card);padding:30px 34px;display:flex;justify-content:space-between;align-items:center;gap:24px;position:relative;overflow:hidden}
.dm-upsell--dark{background:linear-gradient(140deg,var(--gray-dark),var(--black));color:#fff}
.dm-upsell--soft{background:var(--red-surface)}
.dm-upsell .ring{position:absolute;border-radius:50%}
.dm-upsell--dark .ring{top:-50px;right:-50px;width:220px;height:220px;border:2px solid rgba(215,25,32,.5)}
.dm-upsell--soft .ring{top:-40px;right:-40px;width:180px;height:180px;background:rgba(255,255,255,.6)}
.dm-upsell .kicker{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase}
.dm-upsell--dark .kicker{color:var(--red-light)}
.dm-upsell--soft .kicker{color:var(--red-on-surface)}
.dm-upsell .title{font-size:21px;font-weight:700;letter-spacing:-.02em}
.dm-upsell--soft .title{color:var(--black)}
.dm-progress{width:220px;max-width:100%;height:6px;border-radius:var(--r-pill);background:rgba(215,25,32,.15);overflow:hidden;margin-top:4px}
.dm-progress > span{display:block;height:100%;border-radius:var(--r-pill);background:var(--red)}

.dm-pagination{padding:36px var(--pad-x) 60px;font-size:14px;font-weight:600}
.dm-pagination .woocommerce-pagination{display:flex;justify-content:center}
.dm-pagination ul.page-numbers{display:flex;justify-content:center;align-items:center;gap:8px;list-style:none;margin:0;padding:0;border:0}
.dm-pagination ul.page-numbers li{margin:0;border:0}
/* Jen odkazy/čísla, ne obalový <ul class="page-numbers"> */
.dm-pagination a.page-numbers,.dm-pagination span.page-numbers{width:42px;height:42px;border-radius:var(--r-pill);
  display:flex;align-items:center;justify-content:center;transition:background .15s;text-decoration:none;color:var(--black)}
.dm-pagination a.page-numbers:hover{background:var(--hover-pill)}
.dm-pagination span.page-numbers.current{background:var(--black);color:var(--white)}
.dm-pagination a.page-numbers.next,.dm-pagination a.page-numbers.prev{width:auto;padding:0 20px;border:1.5px solid var(--border-btn)}
.dm-pagination a.page-numbers.next:hover,.dm-pagination a.page-numbers.prev:hover{border-color:var(--black);background:transparent}

/* ---------- Single produkt ---------- */
.dm-product{padding:26px var(--pad-x) 60px;display:grid;grid-template-columns:1.05fr 1fr;gap:52px;align-items:start}
.dm-gallery{display:flex;flex-direction:column;gap:14px;position:sticky;top:20px}
.dm-gallery-main{position:relative;aspect-ratio:1/1;border-radius:var(--r-lg);overflow:hidden;background:var(--surface)}
.dm-gallery-main img{width:100%;height:100%;object-fit:cover}
.dm-gallery-badge{position:absolute;top:18px;left:18px;background:var(--red);color:#fff;border-radius:var(--r-pill);font-size:12px;font-weight:600;padding:6px 14px;z-index:1}
.dm-gallery-rating{position:absolute;top:18px;right:18px;background:rgba(255,255,255,.9);color:var(--black);border-radius:var(--r-pill);font-size:12px;font-weight:600;padding:6px 14px;z-index:1}
.dm-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.dm-thumb{aspect-ratio:1/1;border-radius:14px;overflow:hidden;cursor:pointer;border:2px solid transparent;background:var(--surface)}
.dm-thumb.is-active{border-color:var(--black)}
.dm-thumb img{width:100%;height:100%;object-fit:cover}

.dm-summary{display:flex;flex-direction:column;gap:22px}
.dm-summary-head{display:flex;flex-direction:column;gap:8px}
.dm-summary-head .kicker{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3)}
.dm-summary-head h1{font-size:54px;letter-spacing:.005em;line-height:.98}
.dm-rating-row{display:flex;align-items:center;gap:10px;font-size:13.5px}
.dm-rating-row .stars{color:var(--red);letter-spacing:2px}
.dm-rating-row .link{color:var(--text-3);text-decoration:underline;cursor:pointer}

.dm-pricebox{display:flex;justify-content:space-between;align-items:center;gap:20px;padding:16px 20px;
  border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);flex-wrap:wrap}
.dm-pricebox .price{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}
.dm-pricebox .price .now{font-family:var(--font-head);font-size:38px;font-weight:700;line-height:1}
.dm-pricebox .price del{font-size:15px;color:var(--price-old);text-decoration:line-through}
.dm-pricebox .price .save{background:var(--red);color:#fff;border-radius:var(--r-pill);font-size:12px;font-weight:700;padding:4px 10px}
.dm-avail{display:flex;flex-direction:column;align-items:flex-end;gap:3px;text-align:right}
.dm-avail .in-stock{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--green)}
.dm-avail .in-stock .dot{width:8px;height:8px;border-radius:var(--r-pill);background:var(--green)}
.dm-avail .eta{font-size:12px;color:var(--text-3)}

.dm-desc{margin:0;font-size:15px;font-weight:300;line-height:1.7;color:var(--text-2b)}
.dm-notes{display:flex;gap:8px;flex-wrap:wrap}
.dm-note{border:1.5px solid var(--border);background:var(--surface);border-radius:var(--r-pill);padding:8px 16px;font-size:13px;font-weight:500}

.dm-metrics{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.dm-metric{border:1px solid var(--border);border-radius:var(--r-md);padding:18px 20px;display:flex;flex-direction:column;gap:10px}
.dm-metric-head{display:flex;justify-content:space-between;align-items:baseline}
.dm-metric-head .label{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3)}
.dm-metric-head .val{font-size:13px;font-weight:600}
.dm-scale{display:flex;gap:5px}
.dm-scale span{flex:1;height:8px;border-radius:var(--r-pill);background:var(--border)}
.dm-scale span.on{background:var(--red)}
.dm-metric .note{font-size:12px;color:var(--text-3)}
.dm-metric .big{display:flex;align-items:baseline;gap:3px;font-family:var(--font-head);font-size:30px;font-weight:700;line-height:1}
.dm-metric .big small{font-size:15px;color:var(--text-3);font-weight:600;margin-left:2px}

.dm-swatches-label{font-size:13px;font-weight:600}
.dm-swatches-label .muted{color:var(--text-3);font-weight:500}
.dm-swatches{display:flex;gap:10px;flex-wrap:wrap}
.dm-swatch{flex:1;min-width:80px;border:2px solid var(--border);border-radius:14px;padding:12px 10px;display:flex;
  flex-direction:column;align-items:center;gap:8px;cursor:pointer;background:var(--white);transition:border-color .15s,background .15s}
.dm-swatch.is-active{border-color:var(--black);background:var(--surface)}
.dm-swatch .dot{width:34px;height:34px;border-radius:var(--r-pill)}
.dm-swatch .name{font-size:12.5px;font-weight:600;text-align:center}

.dm-bundles{display:flex;flex-direction:column;gap:10px}
.dm-bundle{display:flex;align-items:center;gap:14px;border:2px solid var(--border);border-radius:var(--r-md);
  padding:14px 18px;cursor:pointer;background:var(--white);position:relative;transition:border-color .15s,background .15s}
.dm-bundle.is-active{border-color:var(--red);background:var(--bundle-bg)}
.dm-bundle .radio{width:20px;height:20px;border-radius:var(--r-pill);border:2px solid var(--border-btn);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.dm-bundle.is-active .radio{border-color:var(--red)}
.dm-bundle .radio i{width:10px;height:10px;border-radius:var(--r-pill);background:transparent;display:block}
.dm-bundle.is-active .radio i{background:var(--red)}
.dm-bundle .info{display:flex;flex-direction:column;flex:1}
.dm-bundle .info .label{font-size:14px;font-weight:600}
.dm-bundle .info .sub{font-size:12.5px;color:var(--text-3)}
.dm-bundle .b-price{display:flex;align-items:baseline;gap:8px}
.dm-bundle .b-price .now{font-size:16px;font-weight:700}
.dm-bundle .b-price del{font-size:12.5px;color:var(--price-old);text-decoration:line-through}
.dm-bundle .tag{position:absolute;top:-10px;right:14px;background:var(--red);color:#fff;border-radius:var(--r-pill);
  font-size:10.5px;font-weight:700;padding:3px 10px;letter-spacing:.06em;text-transform:uppercase}

.dm-cta-row{display:flex;gap:12px}
.dm-cta-add{flex:1;background:var(--red);color:#fff;border-radius:var(--r-pill);padding:18px;font-size:15.5px;font-weight:600;
  text-align:center;cursor:pointer;border:0;transition:background .15s}
.dm-cta-add:hover{background:var(--red-hover)}
.dm-wishlist{width:58px;height:58px;border:1.5px solid var(--border-btn);border-radius:var(--r-pill);display:flex;
  align-items:center;justify-content:center;cursor:pointer;background:transparent;transition:border-color .15s;flex-shrink:0}
.dm-wishlist:hover{border-color:var(--red)}
.dm-trust{display:flex;gap:20px;font-size:12.5px;color:var(--text-3);justify-content:center;flex-wrap:wrap}

/* mobilní sticky lišta na produktu */
.dm-sticky-buy{display:none}

/* pyramida vůně */
.dm-pyramid{margin:0 var(--pad-x) 60px;border-radius:var(--r-lg);background:var(--black);color:#fff;padding:48px;
  display:grid;grid-template-columns:1fr 1.4fr;gap:48px;align-items:center}
.dm-pyramid .kicker{color:var(--red-light)}
.dm-pyramid h2{font-size:40px;margin:0}
.dm-pyramid p{margin:0;font-size:14.5px;font-weight:300;line-height:1.7;color:#b8b8b8}
.dm-timeline{display:flex;flex-direction:column;gap:2px}
.dm-timeline-row{display:grid;grid-template-columns:110px 1fr;gap:18px;padding:18px 22px;border-radius:14px;
  background:#161616;border:1px solid var(--gray-dark);align-items:center}
.dm-timeline-row:nth-child(2){margin-left:24px}
.dm-timeline-row:nth-child(3){margin-left:48px}
.dm-timeline-row .time{font-family:var(--font-head);font-size:17px;font-weight:700;text-transform:uppercase;color:var(--red-light)}
.dm-timeline-row .t-title{font-size:14.5px;font-weight:600}
.dm-timeline-row .t-sub{font-size:13px;color:var(--text-3)}

/* ---------- Cart drawer (off-canvas) ---------- */
.dm-drawer-overlay{position:fixed;inset:0;background:rgba(13,13,13,.4);opacity:0;visibility:hidden;
  transition:opacity .25s ease,visibility .25s;z-index:90}
.dm-drawer-overlay.open{opacity:1;visibility:visible}
.dm-drawer{position:fixed;top:0;right:0;height:100%;width:420px;max-width:92vw;background:var(--white);
  box-shadow:var(--sh-menu);transform:translateX(100%);transition:transform .28s cubic-bezier(.4,0,.2,1);
  z-index:91;display:flex;flex-direction:column}
.dm-drawer.open{transform:translateX(0)}
.dm-drawer-head{display:flex;justify-content:space-between;align-items:center;padding:22px 24px;border-bottom:1px solid var(--border)}
.dm-drawer-head h3{font-size:22px}
.dm-drawer-close{width:40px;height:40px;border-radius:var(--r-icon);border:0;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center}
.dm-drawer-close:hover{background:var(--hover-pill)}
.dm-drawer-body{flex:1;overflow-y:auto;padding:8px 24px}
.dm-drawer-foot{border-top:1px solid var(--border);padding:20px 24px;display:flex;flex-direction:column;gap:12px}
.dm-drawer-subtotal{display:flex;justify-content:space-between;align-items:baseline;font-size:15px}
.dm-drawer-subtotal .amount{font-family:var(--font-head);font-size:26px;font-weight:700}
.dm-drawer-empty{padding:48px 0;text-align:center;color:var(--text-3);font-size:14px}
.dm-freeship-msg{font-size:12.5px;color:var(--text-2);text-align:center}

/* ---------- Toast ---------- */
.dm-toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(12px);opacity:0;
  background:var(--black);color:#fff;border-radius:var(--r-pill);padding:14px 26px;font-size:14px;font-weight:600;
  box-shadow:var(--sh-toast);display:flex;align-items:center;gap:10px;z-index:100;pointer-events:none;
  transition:opacity .25s ease,transform .25s ease}
.dm-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.dm-toast .check{width:22px;height:22px;border-radius:var(--r-pill);background:var(--red);display:inline-flex;align-items:center;justify-content:center;font-size:12px}

/* ---------- Loader ---------- */
.dm-spin{width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:dm-rotate .7s linear infinite;display:inline-block}
@keyframes dm-rotate{to{transform:rotate(360deg)}}

/* =========================================================================
   WooCommerce override – necháváme WC CSS a jen ho přepisujeme naším designem.
   Selektory mají .woocommerce prefix (body.woocommerce), ať přebijí WC baseline.
   ========================================================================= */

/* --- Produktová mřížka (archiv + related + upsell) --- */
.woocommerce ul.products,
ul.products{
  display:grid !important;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  list-style:none;
  margin:0;
  padding:28px var(--pad-x) 0;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after{content:none !important;display:none !important} /* zruší WC clearfix */
.woocommerce ul.products li.product,
ul.products li.product{
  width:auto !important;
  margin:0 !important;
  float:none !important;
  clear:none !important;
  padding:0 !important;
  text-align:left;
}
.woocommerce ul.products li.product::before{content:none !important}
.dm-card-cell .dm-card{height:100%}
/* Related/upsell uvnitř .dm-container už mají boční padding – nezdvojovat */
.dm-container ul.products{padding-left:0;padding-right:0}
/* Nadpisy sekcí related / upsell */
.woocommerce .related > h2,
.woocommerce .upsells > h2,
.woocommerce .cross-sells > h2{
  font-family:var(--font-head);text-transform:uppercase;font-size:32px;margin:0 0 24px;letter-spacing:.01em}

/* --- Single layout: neutralizace WC floatů, ať vládne náš .dm-product grid --- */
.woocommerce div.product.dm-product{float:none}
.dm-product .woocommerce-product-gallery,
.dm-product .images{width:100% !important;float:none !important;margin:0 !important;opacity:1 !important}
.dm-product .summary,
.dm-product .entry-summary{width:auto !important;float:none !important;margin:0 !important;clear:none !important}
.dm-product::before,.dm-product::after{content:none !important;display:none !important}
/* WC gallery uvnitř našeho sloupce – ať drží 1:1 radius jako v handoffu */
.dm-gallery .woocommerce-product-gallery__image img{border-radius:var(--r-lg)}
.dm-gallery .flex-control-thumbs{margin-top:12px;display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.dm-gallery .flex-control-thumbs li{width:auto;margin:0}
.dm-gallery .flex-control-thumbs img{border-radius:14px;opacity:.6}
.dm-gallery .flex-control-thumbs img.flex-active,
.dm-gallery .flex-control-thumbs img:hover{opacity:1}

/* --- Řazení v archivu (native woocommerce_catalog_ordering) --- */
.dm-filter-tools .woocommerce-ordering{margin:0}
.dm-filter-tools .woocommerce-ordering select{
  min-height:44px;border:1.5px solid var(--border-btn);border-radius:var(--r-pill);
  padding:0 16px;font-family:var(--font-body);font-size:13.5px;font-weight:500;background:#fff;cursor:pointer}

/* --- Sale flash badge (single + karta) --- */
.woocommerce span.onsale{
  background:var(--red);color:#fff;border-radius:var(--r-pill);font-size:12px;font-weight:600;
  padding:6px 14px;min-height:0;min-width:0;line-height:1.2;top:18px;left:18px;margin:0}

/* --- Single: add-to-cart form (nativní, jen styl) --- */
.woocommerce div.product form.cart{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin:6px 0 0}
.woocommerce div.product form.cart .quantity{margin:0}
.woocommerce .quantity input.qty{
  width:72px;height:56px;border:1.5px solid var(--border-btn);border-radius:var(--r-pill);
  text-align:center;font-family:var(--font-body);font-size:15px;font-weight:600;background:#fff}
.woocommerce div.product form.cart .button,
.woocommerce div.product .single_add_to_cart_button{
  flex:1;min-width:200px;background:var(--red);color:#fff;border:0;border-radius:var(--r-pill);
  padding:18px 24px;font-family:var(--font-body);font-size:15.5px;font-weight:600;text-transform:none;
  letter-spacing:0;transition:background .15s;cursor:pointer;box-shadow:none}
.woocommerce div.product form.cart .button:hover,
.woocommerce div.product .single_add_to_cart_button:hover{background:var(--red-hover)}

/* Variace (variable product) */
.woocommerce div.product form.cart .variations{width:100%;margin:0 0 6px;border:0}
.woocommerce div.product form.cart .variations td,
.woocommerce div.product form.cart .variations th{padding:6px 0;border:0;vertical-align:middle}
.woocommerce div.product form.cart .variations th.label{font-weight:600;font-size:13px;padding-right:12px}
.woocommerce div.product form.cart .variations select{
  min-height:48px;border:1.5px solid var(--border-btn);border-radius:var(--r-md);padding:0 14px;
  font-family:var(--font-body);font-size:14px;background:#fff}
.woocommerce div.product .woocommerce-variation-price .price{font-family:var(--font-head);font-size:28px;font-weight:700}
.woocommerce div.product .woocommerce-variation-add-to-cart{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.woocommerce a.reset_variations{font-size:12.5px;color:var(--text-3)}

/* Cena – barvy do našich tokenů */
.woocommerce div.product p.price,
.woocommerce div.product span.price{color:var(--black)}
.woocommerce div.product p.price del,
.woocommerce .dm-price del{opacity:1;color:var(--price-old)}
.woocommerce div.product p.price ins,
.dm-price ins{background:none;font-weight:700}

/* --- Produktové taby + recenze --- */
.woocommerce div.product .woocommerce-tabs{margin-top:40px}
.woocommerce div.product .woocommerce-tabs ul.tabs{padding:0;margin:0 0 24px;display:flex;gap:8px;flex-wrap:wrap;border-bottom:1px solid var(--border)}
.woocommerce div.product .woocommerce-tabs ul.tabs::before{display:none}
.woocommerce div.product .woocommerce-tabs ul.tabs li{
  background:transparent;border:0;border-radius:var(--r-pill);margin:0;padding:0}
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after{display:none;content:none;border:0}
.woocommerce div.product .woocommerce-tabs ul.tabs li a{
  padding:10px 18px;font-family:var(--font-body);font-weight:600;font-size:14px;color:var(--text-3);display:block}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a{color:var(--black)}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active{background:var(--hover-pill)}
.woocommerce #reviews h2,
.woocommerce div.product .woocommerce-Tabs-panel h2{font-family:var(--font-head);text-transform:uppercase;font-size:28px}
.woocommerce #reviews #comments ol.commentlist li{margin:0 0 20px}
.woocommerce #review_form .comment-form input,
.woocommerce #review_form .comment-form textarea{
  border:1.5px solid var(--border-btn);border-radius:var(--r-md);padding:12px 14px;font-family:var(--font-body)}
.woocommerce #respond input#submit,
.woocommerce #review_form #respond .form-submit input{
  background:var(--red);color:#fff;border-radius:var(--r-pill);padding:14px 28px;font-weight:600;border:0}
.woocommerce .star-rating span{color:var(--red)}

/* --- WooCommerce hlášky (notices) mimo Blocks pokladnu --- */
.woocommerce-message,.woocommerce-info,.woocommerce-error{
  border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface);
  border-top-color:var(--red);font-family:var(--font-body)}
.woocommerce-message{border-top-color:var(--green)}
.woocommerce-message .button,.woocommerce-info .button{
  background:var(--red);color:#fff;border-radius:var(--r-pill);border:0}

/* =========================================================================
   Responzivita
   ========================================================================= */
@media (max-width:1100px){
  .dm-hero h1{font-size:60px}
  .dm-product{grid-template-columns:1fr;gap:32px}
  .dm-gallery{position:static}
  .dm-pyramid{grid-template-columns:1fr;gap:28px;padding:36px}
  .dm-mega{grid-template-columns:1fr 1fr}
  .dm-mega-promo{grid-column:1 / -1;min-height:200px}
}
@media (max-width:900px){
  :root{--pad-x:20px}
  .dm-topbar{gap:16px;font-size:11.5px;flex-wrap:wrap;padding:8px 16px}
  .dm-nav{display:none}
  /* Mobilní rozbalené menu – čistě přes třídu .is-open (žádné inline styly z JS). */
  .dm-nav.is-open{
    display:flex;flex-direction:column;gap:4px;
    position:absolute;top:100%;left:0;right:0;
    background:var(--white);padding:12px 20px;
    border-bottom:1px solid var(--border);box-shadow:var(--sh-menu);z-index:15}
  .dm-nav.is-open a,.dm-nav.is-open .dm-navitem{width:100%;padding:12px 14px}
  .dm-burger{display:flex}
  .dm-bento{grid-template-columns:1fr}
  .dm-grid,.woocommerce ul.products,ul.products{grid-template-columns:repeat(2,1fr) !important}
  .dm-reviews{grid-template-columns:1fr}
  .dm-quiz{flex-direction:column;align-items:flex-start;padding:32px}
  .dm-upsell-row{grid-template-columns:1fr}
  .dm-hero h1{font-size:44px}
  .dm-hero{padding-top:40px}
  .dm-section-head h2{font-size:30px}
  .dm-shop-head h1{font-size:36px}
  .dm-summary-head h1{font-size:40px}
  .dm-pyramid h2{font-size:30px}
  .dm-metrics{grid-template-columns:1fr}
  /* mobilní sticky nákupní lišta na produktu */
  .dm-sticky-buy{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:80;background:var(--white);
    border-top:1px solid var(--border);padding:12px 16px;gap:12px;align-items:center;box-shadow:0 -6px 20px rgba(13,13,13,.08)}
  .dm-sticky-buy .s-price{font-family:var(--font-head);font-size:26px;font-weight:700;white-space:nowrap}
  .dm-sticky-buy .dm-cta-add{padding:15px}
  body.single-product{padding-bottom:76px}
}
@media (max-width:520px){
  .dm-grid,.woocommerce ul.products,ul.products{grid-template-columns:repeat(2,1fr) !important;gap:12px}
  .dm-topbar{gap:12px;font-size:11.5px;flex-wrap:wrap}
  .dm-hero h1{font-size:36px}
  .dm-quiz-chips{width:100%}
  .dm-footer{flex-direction:column;align-items:flex-start;gap:16px}
  .dm-mega{grid-template-columns:1fr}
  .dm-mega-promo{display:none}
}
