:root{
  /* INK z černých linek loga */
  --ink:        #110F13;
  --ink-2:      #212024;

  /* texty */
  --muted:      #6D676B;
  --muted-2:    #9D8D92;

  /* pozadí (z šedobílého kruhu v logu) */
  --bg:         #F1F0F1;  /* hlavní */
  --bg-dark:    #E6E1E3;  /* okrajový tón */
  --bg-light:   #FDFEFE;  /* highlight */

  /* plochy */
  --surface:    #FFFFFF;
  --surface-2:  #F8F8F8;

  /* linky */
  --border:     #DDD5D8;

  /* ROSE (z růže v logu) */
  --rose:       #AF314D;  /* primary */
  --rose-dark:  #90283F;  /* hover/active */
  --rose-tint:  #E7D3D8;  /* jemný podklad */
  --rose-tint-2:#E0C0C8;  /* výraznější tint */

  /* stíny / radius */
  --shadow:     0 10px 24px rgba(17,15,19,.10);
  --radius:     18px;
}

.site{
  background: var(--bg);
  color: var(--ink);
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

.tc-header{
  background: rgba(240,239,240,.85);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(10px);
}

.catcard, .pcard, .promo-pill, .searchbox{
  background: var(--surface);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}

.caticon{
  background: var(--rose-tint);
  color: var(--rose-dark);
}

.site{
  background: var(--bg);
  color: var(--ink);
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

.section-title{
  font-family: "Cormorant Garamond", serif;
  font-weight: 700;
  letter-spacing: .2px;
}

/* topbar */
.topbar{
  background: rgba(255,255,255,.6);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(8px);
}
.toplink{
  color: var(--muted);
  text-decoration: none;
}
.toplink:hover{ color: var(--ink); }

.text-muted-2{ color: var(--muted); }

.badge18{
  font-size: 12px;
  padding: 4px 10px;
  border-radius: 999px;
  background: var(--rose-tint);
  color: var(--rose-dark);
  border: 1px solid rgba(178,87,87,.25);
}

/* header */
.header{
  background: rgba(247,244,245,.85);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(10px);
}
.brand-logo{ width: 28px; height: 28px; border-radius: 8px; }
.brand-text{ font-weight: 700; color: var(--ink); }

.navlink{
  color: var(--muted);
  text-decoration: none;
  font-weight: 500;
}
.navlink:hover{ color: var(--ink); }

.btn-rose{
  background: var(--rose);
  border: 1px solid var(--rose);
  color: #fff;
  border-radius: 999px;
  font-weight: 600;
}
.btn-rose:hover{
  background: var(--rose-dark);
  border-color: var(--rose-dark);
  color: #fff;
}

.btn-outline-rose{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .45rem;

  padding: 10px 16px;
  border-radius: 999px;

  background: transparent;
  color: var(--rose-dark);
  border: 1px solid rgba(175,49,77,.45);

  font-weight: 700;
  text-decoration: none;

  transition: background-color .15s ease, border-color .15s ease, color .15s ease, transform .15s ease, box-shadow .15s ease;
}

.btn-outline-rose:hover{
  background: var(--rose-tint);
  border-color: rgba(175,49,77,.55);
  color: var(--rose-dark);
  box-shadow: 0 10px 18px rgba(17,15,19,.08);
  transform: translateY(-1px);
}

.btn-outline-rose:active{
  transform: translateY(0);
  background: var(--rose-tint-2);
  border-color: rgba(175,49,77,.65);
  box-shadow: none;
}

.btn-outline-rose:focus,
.btn-outline-rose:focus-visible{
  outline: none;
  box-shadow: 0 0 0 4px rgba(175,49,77,.18);
}

.btn-outline-rose:disabled,
.btn-outline-rose.disabled{
  opacity: .55;
  cursor: not-allowed;
  box-shadow: none;
  transform: none;
}

/* když to používáš na <button> v BS */
button.btn-outline-rose{
  appearance: none;
  -webkit-appearance: none;
}


/* search */
.searchbox{
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0px 20px 0px 20px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 999px;
  box-shadow: var(--shadow);
}
.searchicon{ opacity: .6; }
.searchinput{
  border: 0 !important;
  box-shadow: none !important;
  padding: 8px 0;
}
.searchbtn{ padding: 10px 14px; }

/* promo */
.promo-pill{
  display:flex;
  align-items:center;
  gap:10px;
  padding: 12px 14px;
  border-radius: 999px;
  background: var(--surface);
  border: 1px solid var(--border);
  text-decoration: none;
  color: var(--ink);
  box-shadow: var(--shadow);
}
.promo-badge{
  font-weight: 800;
  color: var(--rose-dark);
  background: var(--rose-tint);
  border: 1px solid rgba(178,87,87,.25);
  padding: 4px 10px;
  border-radius: 999px;
}

/* category cards */
.catcard{
  display:flex;
  align-items:center;
  gap:14px;
  padding: 18px 18px;
  border-radius: var(--radius);
  background: var(--surface);
  border: 1px solid var(--border);
  text-decoration: none;
  color: var(--ink);
  box-shadow: var(--shadow);
  min-height: 84px;
}
.catcard:hover{
  border-color: rgba(178,87,87,.35);
  transform: translateY(-1px);
  transition: .15s ease;
}
.caticon{
  width: 44px; height: 44px;
  display:grid; place-items:center;
  border-radius: 14px;
  background: var(--rose-tint);
  color: var(--rose-dark);
  font-size: 20px;
}
.catname{ font-weight: 700; }

/* product cards */
.pcard{
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 12px;
  height: 100%;
  display:flex;
  flex-direction:column;
  gap: 8px;
}
.pimg{
  position: relative;
  border-radius: 14px;
  background: var(--surface-2);
  border: 1px solid var(--border);
  height: 120px;
  display:grid;
  place-items:center;
  overflow:hidden;
}
.ph{
  width: 64px; height: 40px;
  border-radius: 10px;
  background: rgba(178,87,87,.10);
  border: 1px dashed rgba(178,87,87,.35);
  color: var(--rose-dark);
  display:grid; place-items:center;
  font-weight: 800;
  letter-spacing: .8px;
}
.discount{
  position:absolute;
  top: 10px; left: 10px;
  background: var(--rose);
  color: #fff;
  font-weight: 800;
  font-size: 12px;
  padding: 4px 8px;
  border-radius: 10px;
}
.ptitle{
  font-weight: 700;
  line-height: 1.2;
  min-height: 2.4em;
}
.prating{
  color: #C38A7B;
  font-size: 13px;
}
.pprice{
  font-weight: 900;
  font-size: 16px;
  margin-top: 2px;
}
.link-more{
  color: var(--rose-dark);
  text-decoration: none;
  font-weight: 700;
}
.link-more:hover{ text-decoration: underline; }

/* footer */
.footer{
  border-top: 1px solid var(--border);
  background: rgba(255,255,255,.55);
}


.tc-logo-main {
    font-weight: 800;
    font-size: 1.4rem;
    letter-spacing: 0.05em;
}

.tc-logo-sub {
    font-weight: 600;
    margin-left: 0.1rem;
}

.tc-hero {
    background: linear-gradient(135deg, #ffffff 0%, #eef4ff 100%);
}

.tc-hero .lead {
    max-width: 40rem;
}

.tc-main {
    min-height: 60vh;
}

@media (min-width: 1400px) {
    .container, .container-lg, .container-md, .container-sm, .container-xl, .container-xxl {
        max-width: 1620px;
    }
}

.tc-footer {
    background-color: #ffffff;
}


/* AGE GATE – vzhled podle :root proměnných z templates.css */
.age-gate[hidden] { display: none !important; }

.age-gate{
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: grid;
  place-items: center;
}

.age-gate__backdrop{
  position: absolute;
  inset: 0;
  /* zatmavení do ink tónu */
  background: rgba(17, 15, 19, .93); /* = --ink v RGBA */
  backdrop-filter: blur(6px);
}

.age-gate__dialog{
  position: relative;
  width: min(520px, calc(100vw - 32px));
  background: var(--surface);
  color: var(--ink);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 22px 20px;
  box-shadow: var(--shadow);
  max-height: calc(100vh - 32px);
overflow: auto;
}

/* jemnej “rose” proužek nahoře */
.age-gate__dialog::before{
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 6px;
  border-radius: calc(var(--radius) - 2px) calc(var(--radius) - 2px) 0 0;
  background: linear-gradient(90deg, var(--rose), var(--rose-dark));
}

.age-gate__title{
  margin: 0 0 8px;
  font-size: 1.25rem;
  line-height: 1.2;
}

.age-gate__desc{
  margin: 0 0 16px;
  color: var(--muted);
}

.age-gate__actions{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.age-gate__btn{
  appearance: none;
  border-radius: 12px;
  padding: 10px 14px;
  cursor: pointer;
  font-weight: 700;
  border: 1px solid var(--border);
  transition: transform .06s ease, background-color .12s ease, border-color .12s ease, color .12s ease;
}

.age-gate__btn:active{
  transform: translateY(1px);
}

.age-gate__btn--yes,
.age-gate__btn--no{
  background: var(--surface);
  color: var(--rose);
  border-color: var(--rose-tint-2);
}

.age-gate__btn--yes:hover,
.age-gate__btn--no:hover{
  background: var(--rose-tint);
  border-color: var(--rose-tint-2);
  color: var(--rose-dark);
}

.age-gate__btn:focus{
  outline: 3px solid var(--rose-tint-2);
  outline-offset: 2px;
}

.age-gate__fineprint{
  margin: 14px 0 0;
  font-size: .85rem;
  color: var(--muted-2);
}