  --container:1160px;
}
html{-webkit-font-smoothing:antialiased;scroll-behavior:smooth;overflow-x:hidden;}
body{font-family:'DM Sans',Arial,sans-serif;color:var(--c-text);background:#F6EFEB;overflow-x:hidden;}
a{color:var(--c-accent);text-decoration:none;}
h1,h2,h3,h4,h5,h6,.t-title,.t-name,.t-section__title{font-family:'Cormorant Garamond',Georgia,serif;font-weight:300;color:var(--c-text);line-height:1.08;letter-spacing:-0.02em;}
.t-descr,.t-text,.t-text_sm,.t-text_xs{font-family:'DM Sans',Arial,sans-serif;font-weight:300;color:var(--c-text-soft);}

/* HEADER — прозрачный */
.t228,.t456,.t450,.t389,.t314,.t398,.t399,.t333,.t179{background:transparent!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;border-bottom:none!important;box-shadow:none!important;}

/* HEADER — при скролле frosted */
.t-menu_fixed-shown{background:rgba(253,250,248,0.93)!important;backdrop-filter:blur(22px) saturate(1.5)!important;-webkit-backdrop-filter:blur(22px) saturate(1.5)!important;box-shadow:0 1px 0 rgba(123,45,78,0.10),0 4px 24px rgba(30,15,20,0.07)!important;}

/* Nav links */
.t-menu__link-item{font-family:'DM Sans',Arial,sans-serif!important;font-size:10.5px!important;font-weight:500!important;letter-spacing:0.09em!important;text-transform:uppercase!important;color:rgba(255,238,225,0.82)!important;}
.t-menu__link-item:hover{color:#fff!important;opacity:1!important;}
.t-menu_fixed-shown .t-menu__link-item{color:rgba(26,13,18,0.55)!important;}
.t-menu_fixed-shown .t-menu__link-item:hover{color:#7B2D4E!important;}

/* Logo */
.t-menu__logo img,.t228 .t-menu__logo-wrapper img,.t456 .t-menu__logo-img{filter:brightness(0) invert(1) drop-shadow(0 1px 8px rgba(0,0,0,0.28))!important;width:160px!important;height:auto!important;}
.t-menu_fixed-shown .t-menu__logo img,.t-menu_fixed-shown .t-menu__logo-wrapper img{filter:none!important;}

/* Buttons */
.t-btn,.t-submit,a.t-btn{background:linear-gradient(135deg,#7B2D4E 0%,#591c36 100%)!important;border:none!important;color:#fff!important;font-family:'DM Sans',Arial,sans-serif!important;font-size:11px!important;font-weight:600!important;letter-spacing:0.08em!important;text-transform:uppercase!important;border-radius:50px!important;box-shadow:0 6px 20px rgba(123,45,78,0.36)!important;padding:11px 26px!important;transition:transform .2s,box-shadow .2s!important;}
.t-btn:hover,.t-submit:hover,a.t-btn:hover{transform:translateY(-2px)!important;box-shadow:0 10px 28px rgba(123,45,78,0.46)!important;}

/* Forms */
.t-input,.t-inputtextarea,.t-select{border:1px solid rgba(123,45,78,0.15)!important;background:rgba(255,255,255,0.90)!important;color:var(--c-text)!important;border-radius:14px!important;}
.t-input:focus,.t-inputtextarea:focus{border-color:rgba(123,45,78,0.40)!important;box-shadow:0 0 0 4px rgba(123,45,78,0.08)!important;outline:none!important;}

/* Zero Block safe */
.t396,.t396__artboard,.t396__carrier,.t396__filter,.t396__elem,.t396__elem .tn-atom{box-sizing:border-box;}

@media(max-width:640px){.t-btn,.t-submit,a.t-btn{width:auto!important;max-width:none!important;}}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto;}*,*:before,*:after{animation:none!important;transition:none!important;}}

/* ===================================================
   CROCUS BEAUTY STUDIO — Global Smoothness CSS
   Вставить в Tilda: Настройки сайта → Ещё → CSS
   =================================================== */

/* 1. Плавный скролл на всём сайте */
html {
  scroll-behavior: smooth;
}

/* 2. Базовые переходы для Tilda-блоков */
.t-rec,
.t-rec > .t-container,
[class*="tn-atom"],
[class*="tn-elem"] {
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !important;
}

/* 3. Ссылки — плавный ховер */
a {
  transition: color .25s ease, opacity .25s ease !important;
}

/* 4. Кнопки Tilda — плавный ховер */
.t-btn,
.t-submit,
[class*="t-btn"] {
  transition: background .3s ease, box-shadow .3s ease, transform .2s ease, filter .2s ease !important;
}

.t-btn:hover,
.t-submit:hover,
[class*="t-btn"]:hover {
  transform: translateY(-2px);
  filter: brightness(1.04);
}

/* 5. Картинки — плавное появление при загрузке */
img {
  transition: opacity .4s ease !important;
}

/* 6. Анимации появления Tilda — чуть медленнее и плавнее */
.t-animate,
[data-animate-style] {
  transition-duration: .7s !important;
  transition-timing-function: cubic-bezier(0.22, 0.61, 0.36, 1) !important;
}

/* 7. Убираем резкие outline в Firefox/Chrome на кликах */
*:focus:not(:focus-visible) {
  outline: none !important;
}

/* 8. Карточки / тайлы — плавный подъём */
.t-store__card,
.t-tiles__col,
.t-cards__col {
  transition: transform .28s ease, box-shadow .28s ease !important;
}

.t-store__card:hover,
.t-tiles__col:hover,
.t-cards__col:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 32px rgba(30,10,20,0.10) !important;
}

/* ═══════════════════════════════════════════════════════════
   /BUCHEN PAGE — Gutschein + Booking Landing
   Стили применяются только внутри #cb-page / #cb-escape
   ═══════════════════════════════════════════════════════════ */
/* ── Вырываемся из Tilda-контейнера ── */
  #cb-escape {
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    width: 100vw;
    max-width: 100vw;
    overflow-x: hidden;
  }

  /* ── Скрываем FAB — виджет встроен inline (только /buchen) ── */
  #cb-page #crocus-fab-wrap,
  #cb-page #crocus-fab-mobile,
  #cb-page #crocus-backdrop {
    display: none !important;
  }

  /* ── Модал встраиваем как обычный блок (только /buchen) ── */
  #cb-page #crocus-modal {
    position: static !important;
    transform: none !important;
    visibility: visible !important;
    width: 100% !important;
    min-width: unset !important;
    max-width: 480px !important;
    height: 680px !important;
    min-height: 680px !important;
    max-height: 680px !important;
    border-radius: 20px !important;
    box-shadow: 0 0 60px rgba(123,45,78,.18), 0 2px 40px rgba(0,0,0,.6) !important;
    border: 1px solid rgba(123,45,78,.25) !important;
    overflow: hidden !important;
    flex-shrink: 0;
  }
  #cb-page #crocus-modal.open { transform: none !important; }
  #cb-page #crocus-body { overflow-y: auto !important; height: auto !important; flex: 1 !important; padding-bottom: 40px !important; }
  #cb-page #crocus-close { display: none !important; }

  /* ── Calendar compact ── */
  #cb-page #crocus-modal .cw-cal-nav { padding: 8px 11px !important; }
  #cb-page #crocus-modal .cw-cal-nav span { font-size: 13px !important; }
  #cb-page #crocus-modal .cw-cal-grid { gap: 1px !important; padding: 5px 6px 7px !important; }
  #cb-page #crocus-modal .cw-day { font-size: 11px !important; }
  #cb-page #crocus-modal .cw-calendar { margin-top: 2px !important; }

  /* ════════════════════════════════════════
     PAGE LAYOUT
  ════════════════════════════════════════ */
  #cb-page {
    min-height: 100vh;
    background:
      radial-gradient(ellipse at 50% -10%, rgba(123,45,78,.28) 0%, transparent 60%),
      radial-gradient(ellipse at 80% 80%, rgba(201,168,124,.06) 0%, transparent 50%),
      #0e0408;
    font-family: 'DM Sans', Arial, sans-serif;
    color: #fdfaf8;
    padding: 0 0 80px;
  }

  /* ── Header ── */
  #cb-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 44px 20px 0;
  }
  #cb-logo {
    height: 46px;
    width: auto;
    margin-bottom: 10px;
    filter: brightness(0) invert(1) sepia(1) saturate(2.5) hue-rotate(290deg) brightness(1.3);
  }
  #cb-tagline {
    font-size: 10px;
    letter-spacing: 3.5px;
    text-transform: uppercase;
    color: rgba(255,200,220,.38);
    margin-bottom: 48px;
  }

  /* ── Section titles ── */
  .cb-section-label {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    font-size: 10px;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: rgba(201,168,124,.55);
    margin-bottom: 10px;
  }
  .cb-section-label::before {
    content: '';
    display: block;
    width: 18px;
    height: 1px;
    background: rgba(201,168,124,.35);
  }

  /* ════════════════════════════════════════
     HERO SPLIT — Gutschein | Buchen
  ════════════════════════════════════════ */
  #cb-hero {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 24px;
  }

  /* Left — Gutschein ── */
  #cb-gift-col {
    padding: 0 32px 0 0;
    border-right: 1px solid rgba(255,255,255,.06);
    display: flex;
    flex-direction: column;
  }

  /* Right — Buchen ── */
  #cb-book-col {
    padding: 0 0 0 32px;
    display: flex;
    flex-direction: column;
  }

  /* ── Widget anchor ── */
  #cb-widget-anchor {
    display: flex;
    justify-content: center;
  }

  /* ── Gift visual ── */
  #cb-gift-visual {
    position: relative;
    border-radius: 18px;
    overflow: hidden;
    margin-bottom: 24px;
    cursor: pointer;
    flex-shrink: 0;
  }
  #cb-gift-visual img {
    width: 100%;
    height: 260px;
    object-fit: cover;
    object-position: center 40%;
    display: block;
    transition: transform .5s ease;
  }
  #cb-gift-visual:hover img { transform: scale(1.04); }
  #cb-gift-visual-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(14,4,8,.85) 0%, rgba(14,4,8,.1) 60%);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 20px;
  }
  #cb-gift-visual-title {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 26px;
    font-weight: 300;
    color: #fdfaf8;
    line-height: 1.2;
    margin-bottom: 6px;
  }
  #cb-gift-visual-sub {
    font-size: 11px;
    color: rgba(253,250,248,.5);
    letter-spacing: .02em;
  }

  /* ── Gift nominals ── */
  #cb-gift-nominals {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 8px;
    margin-bottom: 20px;
  }
  .cb-nominal {
    background: rgba(201,168,124,.05);
    border: 1px solid rgba(201,168,124,.18);
    border-radius: 12px;
    padding: 12px 6px 10px;
    text-align: center;
    cursor: pointer;
    transition: all .22s;
    -webkit-tap-highlight-color: transparent;
  }
  .cb-nominal:hover {
    border-color: rgba(201,168,124,.5);
    background: rgba(201,168,124,.1);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(201,168,124,.12);
  }
  .cb-nominal-val {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 20px;
    font-weight: 300;
    color: #c9a87c;
    display: block;
    line-height: 1;
    margin-bottom: 3px;
  }
  .cb-nominal-label {
    font-size: 9px;
    color: rgba(253,250,248,.32);
    letter-spacing: .04em;
    text-transform: uppercase;
    display: block;
  }

  /* ── Gift info strip ── */
  #cb-gift-info {
    background: rgba(201,168,124,.05);
    border: 1px solid rgba(201,168,124,.14);
    border-radius: 12px;
    padding: 13px 15px;
    margin-bottom: 20px;
  }
  #cb-gift-info ul {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 7px;
  }
  #cb-gift-info li {
    font-size: 11.5px;
    color: rgba(253,250,248,.5);
    display: flex;
    align-items: flex-start;
    gap: 8px;
    line-height: 1.5;
  }
  #cb-gift-info li::before {
    content: '✓';
    color: #c9a87c;
    font-size: 10px;
    margin-top: 2px;
    flex-shrink: 0;
  }

  /* ── CTA Button ── */
  .cb-btn-primary {
    width: 100%;
    padding: 14px 20px;
    border-radius: 14px;
    border: none;
    cursor: pointer;
    font-family: 'DM Sans', Arial, sans-serif;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: .02em;
    transition: all .22s;
    -webkit-tap-highlight-color: transparent;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
  }
  .cb-btn-gift {
    background: linear-gradient(135deg, #c9a87c 0%, #b8936a 100%);
    color: #0e0408;
    box-shadow: 0 4px 20px rgba(201,168,124,.25);
  }
  .cb-btn-gift:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 28px rgba(201,168,124,.35);
  }
  .cb-btn-book {
    background: linear-gradient(135deg, rgba(123,45,78,.9) 0%, rgba(90,30,55,.9) 100%);
    color: #fdfaf8;
    box-shadow: 0 4px 20px rgba(123,45,78,.25);
  }
  .cb-btn-book:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 28px rgba(123,45,78,.35);
  }

  /* ── Book col ── */
  #cb-book-intro {
    margin-bottom: 20px;
  }
  #cb-book-title {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 30px;
    font-weight: 300;
    color: #fdfaf8;
    line-height: 1.2;
    margin-bottom: 8px;
  }
  #cb-book-sub {
    font-size: 12px;
    color: rgba(253,250,248,.4);
    line-height: 1.6;
  }

  /* ── Services quick preview ── */
  #cb-services {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 20px;
  }
  .cb-svc-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 11px 14px;
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.07);
    border-radius: 12px;
    cursor: pointer;
    transition: all .2s;
    -webkit-tap-highlight-color: transparent;
  }
  .cb-svc-row:hover {
    border-color: rgba(123,45,78,.4);
    background: rgba(123,45,78,.06);
  }
  .cb-svc-name {
    font-size: 13px;
    font-weight: 500;
    color: #fdfaf8;
  }
  .cb-svc-meta {
    display: flex;
    align-items: center;
    gap: 10px;
  }
  .cb-svc-price {
    font-size: 12px;
    color: #c9a87c;
    font-weight: 500;
  }
  .cb-svc-arrow {
    font-size: 16px;
    color: rgba(255,255,255,.2);
  }

  /* ════════════════════════════════════════
     WHY CROCUS STRIP
  ════════════════════════════════════════ */
  #cb-why {
    max-width: 1100px;
    margin: 60px auto 0;
    padding: 0 24px;
  }
  #cb-why-header {
    text-align: center;
    margin-bottom: 28px;
  }
  #cb-why-title {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 32px;
    font-weight: 300;
    color: #fdfaf8;
    margin-bottom: 8px;
  }
  #cb-why-sub {
    font-size: 12px;
    color: rgba(253,250,248,.35);
  }
  #cb-why-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
  }
  .cb-why-card {
    background: rgba(255,255,255,.025);
    border: 1px solid rgba(255,255,255,.07);
    border-radius: 16px;
    padding: 20px 18px;
    transition: border-color .2s;
  }
  .cb-why-card:hover {
    border-color: rgba(201,168,124,.25);
  }
  .cb-why-icon {
    font-size: 24px;
    margin-bottom: 10px;
    display: block;
  }
  .cb-why-heading {
    font-size: 13px;
    font-weight: 600;
    color: #fdfaf8;
    margin-bottom: 5px;
  }
  .cb-why-text {
    font-size: 11px;
    color: rgba(253,250,248,.38);
    line-height: 1.65;
  }

  /* ════════════════════════════════════════
     MASTERS ROW
  ════════════════════════════════════════ */
  #cb-masters {
    max-width: 1100px;
    margin: 56px auto 0;
    padding: 0 24px;
  }
  #cb-masters-header {
    text-align: center;
    margin-bottom: 24px;
  }
  #cb-masters-title {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 28px;
    font-weight: 300;
    color: #fdfaf8;
    margin-bottom: 6px;
  }
  #cb-masters-sub {
    font-size: 11.5px;
    color: rgba(253,250,248,.35);
  }
  #cb-masters-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
  }
  .cb-master-card {
    background: rgba(255,255,255,.025);
    border: 1px solid rgba(255,255,255,.07);
    border-radius: 16px;
    overflow: hidden;
    cursor: pointer;
    transition: all .22s;
    -webkit-tap-highlight-color: transparent;
  }
  .cb-master-card:hover {
    border-color: rgba(123,45,78,.4);
    transform: translateY(-3px);
    box-shadow: 0 10px 30px rgba(0,0,0,.3);
  }
  .cb-master-img {
    width: 100%;
    height: 160px;
    object-fit: cover;
    object-position: top;
    display: block;
  }
  .cb-master-body {
    padding: 13px 14px 15px;
  }
  .cb-master-name {
    font-size: 14px;
    font-weight: 600;
    color: #fdfaf8;
    margin-bottom: 3px;
  }
  .cb-master-spec {
    font-size: 11px;
    color: rgba(253,250,248,.38);
    margin-bottom: 10px;
    line-height: 1.5;
  }
  .cb-master-btn {
    width: 100%;
    padding: 8px;
    background: rgba(123,45,78,.15);
    border: 1px solid rgba(123,45,78,.3);
    border-radius: 8px;
    color: rgba(253,250,248,.75);
    font-family: 'DM Sans', Arial, sans-serif;
    font-size: 11px;
    font-weight: 500;
    cursor: pointer;
    transition: all .2s;
  }
  .cb-master-card:hover .cb-master-btn {
    background: rgba(123,45,78,.3);
    border-color: rgba(123,45,78,.55);
    color: #fdfaf8;
  }

  /* ════════════════════════════════════════
     FAQ
  ════════════════════════════════════════ */
  #cb-faq {
    max-width: 680px;
    margin: 56px auto 0;
    padding: 0 24px;
  }
  #cb-faq-header {
    text-align: center;
    margin-bottom: 24px;
  }
  #cb-faq-title {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 28px;
    font-weight: 300;
    color: #fdfaf8;
  }
  .cb-faq-item {
    border-bottom: 1px solid rgba(255,255,255,.07);
  }
  .cb-faq-q {
    width: 100%;
    background: none;
    border: none;
    color: #fdfaf8;
    font-family: 'DM Sans', Arial, sans-serif;
    font-size: 13px;
    font-weight: 500;
    text-align: left;
    padding: 16px 0;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    -webkit-tap-highlight-color: transparent;
  }
  .cb-faq-q:hover { color: #c9a87c; }
  .cb-faq-arrow {
    font-size: 16px;
    color: rgba(201,168,124,.5);
    transition: transform .22s;
    flex-shrink: 0;
  }
  .cb-faq-item.open .cb-faq-arrow { transform: rotate(90deg); }
  .cb-faq-a {
    font-size: 12px;
    color: rgba(253,250,248,.45);
    line-height: 1.7;
    max-height: 0;
    overflow: hidden;
    transition: max-height .3s ease, padding .3s ease;
  }
  .cb-faq-item.open .cb-faq-a {
    max-height: 200px;
    padding-bottom: 16px;
  }

  /* ════════════════════════════════════════
     FOOTER
  ════════════════════════════════════════ */
  #cb-footer {
    max-width: 1100px;
    margin: 60px auto 0;
    padding: 28px 24px 0;
    border-top: 1px solid rgba(255,255,255,.06);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 16px;
  }
  #cb-footer-left {
    display: flex;
    flex-direction: column;
    gap: 4px;
  }
  #cb-footer-name {
    font-size: 13px;
    font-weight: 600;
    color: rgba(253,250,248,.7);
  }
  #cb-footer-addr {
    font-size: 11px;
    color: rgba(253,250,248,.28);
  }
  #cb-footer-links {
    display: flex;
    align-items: center;
    gap: 20px;
  }
  #cb-footer-links a {
    font-size: 12px;
    color: rgba(253,250,248,.35);
    text-decoration: none;
    transition: color .15s;
  }
  #cb-footer-links a:hover { color: #c9a87c; }

  /* ════════════════════════════════════════
     RESPONSIVE
  ════════════════════════════════════════ */
  @media (max-width: 860px) {
    #cb-hero {
      grid-template-columns: 1fr;
      padding: 0 16px;
    }
    #cb-gift-col {
      padding: 0 0 36px 0;
      border-right: none;
      border-bottom: 1px solid rgba(255,255,255,.06);
    }
    #cb-book-col { padding: 32px 0 0; }
    #cb-why-grid { grid-template-columns: repeat(2, 1fr); }
    #cb-masters-row { grid-template-columns: repeat(2, 1fr); }
    #cb-why, #cb-masters, #cb-faq, #cb-footer { padding: 0 16px; }
  }
  @media (max-width: 480px) {
    #cb-gift-nominals { grid-template-columns: repeat(2, 1fr); }
    #cb-why-grid { grid-template-columns: 1fr; }
    #cb-masters-row { grid-template-columns: repeat(2, 1fr); }
    #cb-master-img { height: 130px; }
    #cb-why-title, #cb-masters-title { font-size: 24px; }
    #cb-page #crocus-modal {
      border-radius: 16px !important;
    }
  }

  /* ── Sticky nav ── */
  #cb-nav {
    position: sticky;
    top: 0;
    z-index: 999;
    background: rgba(14,4,8,.88);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(255,255,255,.06);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    padding: 0 20px;
    height: 48px;
  }
  .cb-nav-link {
    font-family: 'DM Sans', Arial, sans-serif;
    font-size: 11px;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: rgba(253,250,248,.38);
    text-decoration: none;
    padding: 0 16px;
    height: 48px;
    display: flex;
    align-items: center;
    border-bottom: 2px solid transparent;
    transition: color .2s, border-color .2s;
    cursor: pointer;
    white-space: nowrap;
  }
  .cb-nav-link:hover, .cb-nav-link.active {
    color: #c9a87c;
    border-bottom-color: rgba(201,168,124,.5);
  }
  .cb-nav-sep {
    width: 1px;
    height: 14px;
    background: rgba(255,255,255,.08);
    flex-shrink: 0;
  }
  @media (max-width: 600px) {
    #cb-nav { gap: 0; overflow-x: auto; justify-content: flex-start; scrollbar-width: none; }
    #cb-nav::-webkit-scrollbar { display: none; }
    .cb-nav-link { padding: 0 12px; font-size: 10px; }
    .cb-nav-sep { display: none; }
  }