@font-face {
  font-family: "TonsoresMordis";
  src: url("../fonts/tonsores/mordis.otf") format("opentype"),
       url("../fonts/tonsores/mordis.ttf") format("truetype");
  font-display: swap;
}
@font-face {
  font-family: "TonsoresGrift";
  src: url("../fonts/tonsores/grift-regular.woff2") format("woff2"),
       url("../fonts/tonsores/grift.ttf") format("truetype");
  font-weight: 400;
  font-display: swap;
}
@font-face {
  font-family: "TonsoresGrift";
  src: url("../fonts/tonsores/grift-semibold.woff2") format("woff2"),
       url("../fonts/tonsores/grift-semibold.ttf") format("truetype");
  font-weight: 600;
  font-display: swap;
}
@font-face {
  font-family: "TonsoresGrift";
  src: url("../fonts/tonsores/grift-bold.woff2") format("woff2"),
       url("../fonts/tonsores/grift-bold.ttf") format("truetype");
  font-weight: 800;
  font-display: swap;
}
:root {
  --ts-font-base: "TonsoresGrift", Arial, Helvetica, sans-serif;
  --ts-font-display: var(--ts-font-base);
  --title-font: var(--ts-font-base);
  --body-font: var(--ts-font-base);
  --main-font: var(--ts-font-base);
}
.container,
.container-lg,
.container-md,
.container-sm,
.container-xl,
.container-xxl {
  max-width: 1600px !important;
  width: 100%;
  padding-left: 30px !important;
  padding-right: 30px !important;
}
html,
body,
body.dark-scheme,
#wrapper,
#content,
p,
span,
small,
strong,
em,
li,
a,
button,
input,
select,
textarea,
label,
legend,
blockquote,
figcaption,
.lead,
.btn-main,
.menu-item,
#mainmenu a,
.shop-card,
.shop-card h3,
.shop-card p,
.shop-card span,
.service-meta,
.d-title,
.d-content,
.de_count,
.de-box-a,
.de-box-a h4,
.tonsores-wide-story,
.tonsores-wide-story h2,
.tonsores-wide-story p,
.tonsores-wide-story-copy,
.section-kicker,
.shop-eyebrow,
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--ts-font-base) !important;
  font-style: normal !important;
}

body,
p,
li,
a,
button,
input,
select,
textarea,
label,
.lead,
.hero-copy,
.tonsores-wide-story p,
.shop-card p {
  font-weight: 400;
  letter-spacing: 0 !important;
  line-height: 1.5;
}

h1,
h2,
h3,
h4,
h5,
h6,
.tonsores-hero .top-center h1.id-color,
.shop-feature h2,
#servicios h2,
#horarios h2,
.tonsores-wide-story h2,
.shop-card h3,
.de-box-a h4 {
  font-weight: 800 !important;
  letter-spacing: 0 !important;
}

.btn-main,
#mainmenu a,
.menu-item,
.hero-eyebrow,
.shop-eyebrow,
.section-kicker,
.service-meta,
.d-title,
.d-content {
  letter-spacing: 0 !important;
}

i.fa,
i[class^="fa-"],
i[class*=" fa-"],
.fa,
.fab,
.far,
.fas {
  font-family: FontAwesome !important;
}
#de-loader {
  display: none !important;
}
#wrapper,
#content,
body.dark-scheme {
  background: #0d0d0d !important;
}
#content > section:not(.tonsores-hero),
#servicios,
#horarios,
section[aria-label="franja servicios"],
footer {
  background-color: transparent !important;
}
#logo a { display: inline-flex; align-items: center; min-height: 72px; }
#logo img.logo-main { width: auto; height: 73px; object-fit: contain; object-position: center; }
#logo img.logo-mobile { width: auto; height: 57px; object-fit: contain; object-position: center; }
.menu_side_area { display: flex; align-items: center; gap: 10px; }
.menu_side_area .btn-main { margin-left: 0; }
.menu_side_area .btn-book { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.25); color: #fff; }
.btn-shop, .btn-shop-feature { background: #e58b3b !important; color: #111 !important; }
.footer-logo { width: 112px; height: auto; }
.tonsores-hero {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 720px;
  height: 88vh;
  overflow: hidden;
  background: #090909;
}
.tonsores-hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(circle at 50% 48%, rgba(0,0,0,.08), rgba(0,0,0,.48) 58%, rgba(0,0,0,.82)),
    linear-gradient(180deg, rgba(0,0,0,.45), rgba(0,0,0,.16) 42%, rgba(0,0,0,.88)),
    url("../images/background/tonsores-shop-background.png") center / cover no-repeat;
}
.tonsores-hero .de-gradient-edge-bottom {
  z-index: 4;
}
.tonsores-hero .top-center h1.id-color {
  font-family: var(--ts-font-base);
  color: #f0a23f !important;
  display: inline-block;
  font-size: clamp(58px, 7.4vw, 118px);
  line-height: .86;
  font-weight: 900;
  letter-spacing: 0;
  margin: 0 auto 20px;
  text-shadow: 0 5px 30px rgba(0,0,0,.95), 0 0 24px rgba(229,139,59,.35);
  transform: scaleX(.94);
  transform-origin: center;
  opacity: 1;
}
.tonsores-hero .top-center {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 6;
  width: min(1040px, calc(100% - 60px));
  transform: translate(-50%, -50%);
  text-align: center;
}
.tonsores-hero-outline {
  position: absolute;
  top: 50%;
  left: 0;
  z-index: 2;
  width: 100%;
  opacity: .58;
  overflow: hidden;
  transform: translateY(-50%);
  pointer-events: none;
}
.tonsores-hero-outline-track {
  display: inline-flex;
  align-items: center;
  width: max-content;
  animation: tonsores-outline-marquee 31s linear infinite;
  will-change: transform;
}
.tonsores-hero-outline-track span {
  display: inline-block;
  font-family: var(--ts-font-base);
  color: transparent;
  font-weight: 900;
  font-size: clamp(104px, 14vw, 224px);
  line-height: .78;
  letter-spacing: 0;
  padding-right: .08em;
  text-shadow: 0 8px 32px rgba(0,0,0,.55);
  -webkit-text-stroke: 3.5px rgba(240,162,63,.9);
  text-stroke: 3.5px rgba(240,162,63,.9);
  text-transform: uppercase;
  transform: scaleX(.92);
  transform-origin: center;
  white-space: nowrap;
}
@keyframes tonsores-outline-marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-33.333%); }
}
.hero-eyebrow {
  display: inline-block;
  margin-bottom: 18px;
  color: #f0a23f;
  font-family: var(--ts-font-base);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0 !important;
  text-transform: uppercase;
}
.hero-copy {
  width: min(780px, 100%);
  margin: 0 auto 28px;
  color: #f7f1e8;
  font-size: clamp(18px, 1.5vw, 24px);
  line-height: 1.45;
}
.hero-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
}
.tonsores-intro {
  padding: 70px 0;
  background: #0f0f0f;
  border-top: 1px solid rgba(229,139,59,.18);
  border-bottom: 1px solid rgba(229,139,59,.18);
}
.section-kicker {
  display: inline-block;
  margin-bottom: 14px;
  color: #e58b3b;
  font-family: var(--ts-font-display);
  text-transform: uppercase;
  letter-spacing: 0 !important;
  font-size: 15px;
}
.tonsores-intro .lead.big {
  max-width: 1120px;
  margin: 0;
  font-size: clamp(30px, 3vw, 54px);
  line-height: 1.18;
  font-weight: 600;
  color: #f7f1e8;
}
.intro-location {
  margin: 0;
  color: #d7c2ad;
  font-size: 20px;
  line-height: 1.35;
}
.shop-feature { padding: 108px 0 104px; background: transparent !important; border-top: 0 !important; border-bottom: 0 !important; }
.shop-eyebrow { display: inline-block; color: #e58b3b; text-transform: uppercase; letter-spacing: 0 !important; font-size: 13px; margin-bottom: 14px; font-weight: 800; }
@media (min-width: 992px) {
  .shop-feature .row.align-items-end > .col-lg-7 {
    flex: 0 0 78%;
    max-width: 78%;
  }
  .shop-feature .row.align-items-end > .col-lg-5 {
    flex: 0 0 22%;
    max-width: 22%;
  }
}
.shop-feature h2,
#servicios h2,
#horarios h2,
.tonsores-wide-story h2 {
  font-family: var(--ts-font-base);
  font-weight: 800;
}
.shop-feature h2 {
  max-width: min(1320px, 76vw);
  margin: 0 0 20px;
  color: #f7f1e8;
  font-family: var(--ts-font-base) !important;
  font-size: clamp(58px, 5vw, 90px) !important;
  font-weight: 900 !important;
  line-height: .88 !important;
  letter-spacing: 0 !important;
  transform: scaleX(.94);
  transform-origin: left center;
}
.shop-feature p { color: #d6d0c8; max-width: 720px; }
.shop-grid { margin-top: 34px; }
.shop-card { display: block; min-height: 100%; background: #181818; border: 1px solid rgba(229,139,59,.22); color: #fff; text-decoration: none; padding-bottom: 22px; transition: transform .25s ease, border-color .25s ease; }
.shop-card:hover { transform: translateY(-4px) rotateX(var(--tilt-x, 0deg)) rotateY(var(--tilt-y, 0deg)); border-color: rgba(229,139,59,.65); color: #fff; }
.shop-card img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; display: block; margin-bottom: 20px; }
.shop-card span { display: inline-block; margin: 0 20px 10px; color: #111; background: #e58b3b; font-weight: 800; padding: 6px 10px; }
.shop-card h3 { font-size: 20px; margin: 0 20px 8px; }
.shop-card p { font-size: 14px; line-height: 1.55; margin: 0 20px; color: #cfc6bc; }
.service-meta { color: #c8893b; margin-top: -8px; font-size: 14px; }
.de-separator,
.d-deco,
.d-deco-1,
.d-deco-2 {
  display: none !important;
}
.tonsores-wide-story {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  min-height: 640px;
  margin: 72px 0;
  background: transparent !important;
  overflow: hidden;
}
.tonsores-wide-story-media {
  min-height: 640px;
}
.tonsores-wide-story-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.tonsores-wide-story-cutout {
  position: relative;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  background: transparent !important;
  overflow: hidden;
}
.tonsores-wide-story-cutout::before {
  content: "TONSORES";
  position: absolute;
  left: 50%;
  top: 48%;
  transform: translate(-50%, -50%) scaleX(.92);
  color: transparent;
  font-family: var(--ts-font-base);
  font-size: clamp(110px, 12vw, 220px);
  font-weight: 900;
  line-height: .8;
  -webkit-text-stroke: 2px rgba(240,162,63,.28);
  text-stroke: 2px rgba(240,162,63,.28);
  white-space: nowrap;
}
.tonsores-wide-story-cutout img {
  position: relative;
  z-index: 1;
  width: min(520px, 82%);
  height: auto;
  max-height: 660px;
  object-fit: contain;
  object-position: center bottom;
  filter: drop-shadow(0 28px 48px rgba(0,0,0,.72));
}
.tonsores-wide-story-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 24px;
  padding: clamp(48px, 6vw, 100px) 30px;
  max-width: 720px;
}
.tonsores-wide-story-copy h2 {
  margin: 0;
  font-family: var(--ts-font-base) !important;
  font-size: clamp(56px, 5.8vw, 104px) !important;
  font-weight: 900 !important;
  line-height: .84 !important;
  letter-spacing: 0 !important;
  color: #f7f1e8;
  transform: scaleX(.9);
  transform-origin: left center;
}
.tonsores-wide-story-copy p {
  margin: 0 0 10px;
  color: #d6d0c8;
  font-size: 20px;
  line-height: 1.55;
}
.tonsores-notice { display: block; margin-bottom: 24px; padding: 16px 18px; border-radius: 6px; }
.tonsores-notice[hidden] { display: none; }
.has-modern-js .js-reveal { opacity: 0; transform: translateY(22px); transition: opacity .6s cubic-bezier(0.16, 1, 0.3, 1), transform .6s cubic-bezier(0.16, 1, 0.3, 1); }
.has-modern-js .js-reveal.is-visible { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) {
  .shop-card,
  .has-modern-js .js-reveal { transition: none !important; transform: none !important; }
}
.success.tonsores-notice { background: rgba(46, 204, 113, .16); color: #9ff5c0; border: 1px solid rgba(46, 204, 113, .35); }
.error.tonsores-notice { background: rgba(231, 76, 60, .16); color: #ffb7ad; border: 1px solid rgba(231, 76, 60, .35); }
#tonsores_booking_form .form-control { margin-bottom: 0; }
#tonsores_booking_form textarea.form-control { min-height: 159px; }
.social-icons a[aria-label*="Instagram"] { text-decoration: none; }
#servicios,
#horarios {
  padding-top: 126px !important;
  padding-bottom: 116px !important;
  background: transparent !important;
  border-top: 0 !important;
  border-bottom: 0 !important;
}

section[aria-label="franja servicios"] {
  padding-top: 58px !important;
  padding-bottom: 58px !important;
  background: transparent !important;
  border-top: 0 !important;
  border-bottom: 0 !important;
}

#servicios h2,
#horarios h2 {
  display: inline-block;
  margin: 0 0 54px !important;
  color: #f0a23f !important;
  font-family: var(--ts-font-base) !important;
  font-size: clamp(44px, 4.2vw, 72px) !important;
  font-weight: 900 !important;
  line-height: .9 !important;
  letter-spacing: 0 !important;
  text-transform: uppercase;
  transform: scaleX(.94);
  transform-origin: center;
}

.de-gradient-edge-top,
.de-gradient-edge-bottom {
  display: none !important;
}

.de-marquee-list {
  align-items: center !important;
}

.de-marquee-list .d-item-txt {
  font-family: var(--ts-font-base) !important;
  color: #f0a23f !important;
  font-size: clamp(34px, 4vw, 72px) !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  text-transform: uppercase;
  letter-spacing: 0 !important;
  transform: scaleX(.94);
  transform-origin: center;
  padding-right: 0 !important;
}

.de-marquee-list .d-item-txt:nth-child(odd) {
  color: #f0a23f !important;
}

.de-marquee-list .d-item-block {
  width: 44px !important;
  height: 2px !important;
  margin: 0 26px !important;
  background: rgba(240, 162, 63, .8) !important;
  transform: translateY(-8px) !important;
}

@media (max-width: 767px) {
  .container,
  .container-lg,
  .container-md,
  .container-sm,
  .container-xl,
  .container-xxl {
    padding-left: 30px !important;
    padding-right: 30px !important;
  }
  #logo a { min-height: 56px; }
  #logo img.logo-main { width: auto; height: 57px; }
  .top-center h1 { font-size: 42px; line-height: 1.05; }
  .lead.big { font-size: 20px; line-height: 1.55; }
  .menu_side_area { gap: 6px; }
  .menu_side_area .btn-main { display: inline-block; padding: 8px 11px; font-size: 11px; }
  .tonsores-intro { padding: 54px 0; }
  .tonsores-intro .lead.big { font-size: 30px; }
  .tonsores-hero {
    display: block;
    min-height: 700px;
    height: auto;
    padding: 124px 0 58px;
  }
  .tonsores-hero .top-center {
    position: relative;
    top: auto;
    left: auto;
    transform: none;
    width: calc(100% - 60px);
    margin: 0 auto;
  }
  .tonsores-hero .top-center h1.id-color {
    font-size: 48px;
  }
  .tonsores-hero-outline {
    opacity: .34;
    top: 52%;
  }
  .tonsores-hero-outline-track {
    animation-duration: 28s;
  }
  .tonsores-hero-outline-track span {
    font-size: 86px;
  }
  .shop-feature { padding: 82px 0 76px; }
  .shop-feature h2,
  .tonsores-wide-story-copy h2,
  #servicios h2,
  #horarios h2 {
    font-size: 48px !important;
    line-height: .9 !important;
    transform: scaleX(.94);
  }
  .tonsores-wide-story {
    grid-template-columns: 1fr;
    min-height: auto;
    margin: 54px 0;
  }
  .tonsores-wide-story-media {
    min-height: 340px;
  }
  .tonsores-wide-story-cutout {
    min-height: 560px;
  }
  .tonsores-wide-story-cutout img {
    width: min(320px, 88%);
    max-height: 540px;
  }
  .tonsores-wide-story-copy {
    padding: 62px 30px 72px;
  }
  #servicios,
  #horarios,
  section[aria-label="franja servicios"] {
    padding-top: 84px !important;
    padding-bottom: 80px !important;
  }
}
