.eno-rec-page {
  --lop-guide-bg: #1a1410;
  --lop-guide-bg2: #221a14;
  --lop-guide-panel: rgba(26, 20, 16, .88);
  --lop-guide-panel2: rgba(42, 32, 24, .76);
  --lop-guide-line: rgba(201, 168, 76, .20);
  --lop-guide-line-strong: rgba(201, 168, 76, .46);
  --lop-guide-teal: #c9a84c;
  --lop-guide-teal-soft: #daba5e;
  position: relative;
  z-index: 1;
  background:
    radial-gradient(circle at 18% 18%, rgba(201,168,76,.08), transparent 28%),
    linear-gradient(135deg, #1a1410 0%, #221a14 44%, #100c09 100%);
  color: var(--text-l);
}

body.page-enotria {
  --cursor-gold: #c9a84c;
  --cursor-gold-l: #daba5e;
  --cursor-gold-d: #7a5b23;
}

.lop-guides-page.eno-rec-page {
  background:
    radial-gradient(circle at 18% 18%, rgba(201,168,76,.08), transparent 28%),
    linear-gradient(135deg, var(--lop-guide-bg) 0%, var(--lop-guide-bg2) 44%, #100c09 100%);
}

.eno-rec-hero {
  position: relative;
  min-height: clamp(560px, 72vh, 760px);
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  padding: 150px 0 clamp(58px, 8vw, 104px);
}

.eno-rec-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.eno-rec-hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
  filter: brightness(.34) contrast(1.16) saturate(.78);
  transform: scale(1.04);
}

.eno-rec-hero__bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(26,20,16,.56) 0%, rgba(26,20,16,.14) 30%, rgba(26,20,16,.58) 65%, rgba(26,20,16,.98) 100%),
    radial-gradient(circle at 70% 35%, rgba(201,168,76,.12), transparent 38%),
    linear-gradient(90deg, rgba(16,12,9,.82) 0%, transparent 50%, rgba(16,12,9,.42) 100%);
}

.eno-rec-hero__inner {
  position: relative;
  z-index: 1;
}

.eno-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  max-width: 920px;
  margin: 0 0 22px;
  color: rgba(236,224,200,.72);
  font-size: 12px;
  line-height: 1.35;
}

.eno-breadcrumb a {
  color: rgba(236,224,200,.82);
  text-decoration: none;
}

.eno-breadcrumb a:hover,
.eno-bread-current {
  color: var(--lop-guide-teal-soft);
}

.eno-rec-title {
  max-width: 960px;
  margin: 12px 0 14px;
  color: var(--white);
  font-family: var(--ff-d);
  font-size: clamp(34px, 5vw, 62px);
  line-height: 1.02;
  font-weight: 900;
  letter-spacing: 0;
  overflow-wrap: break-word;
  hyphens: auto;
}

.eno-rec-lead {
  max-width: 720px;
  color: var(--text);
  font-size: clamp(14px, 1vw, 17px);
  line-height: 1.62;
  opacity: .9;
}

.lop-guides-page.eno-rec-page .pill-tag {
  border-color: rgba(201,168,76,.35);
  color: var(--lop-guide-teal-soft);
  background: rgba(201,168,76,.07);
}

.eno-rec-section,
.eno-rec-faq,
.eno-rec-next {
  position: relative;
  z-index: 1;
  padding: clamp(42px, 5vw, 72px) 0;
}

.eno-rec-index {
  padding-top: clamp(74px, 7vw, 108px);
}

.eno-rec-page > .sec-sep {
  position: relative;
  z-index: 4;
  display: block;
  height: 0;
  width: 100%;
  margin: 0;
  overflow: visible;
  pointer-events: none;
}

.eno-rec-page > .sec-sep svg {
  display: block;
  width: min(1680px, 96vw);
  height: 128px;
  position: absolute;
  left: 50%;
  top: 0;
  margin: -64px 0 0;
  transform: translateX(-50%);
}

.eno-rec-page .sep-line,
.eno-rec-page .sep-flourish,
.eno-rec-page .sep-sword,
.eno-rec-page .sep-cross,
.eno-rec-page .sep-ring-outer,
.eno-rec-page .sep-ring-inner {
  stroke: rgba(201,168,76,.42);
}

.eno-rec-page .sep-dot,
.eno-rec-page .sep-diamond,
.eno-rec-page .sep-sword-fill {
  fill: rgba(218,186,94,.9);
}

.eno-rec-head {
  max-width: 780px;
  margin: 0 auto 26px;
  text-align: center;
}

.eno-rec-head h2,
.eno-rec-faq h2 {
  margin: 12px 0 10px;
  color: var(--white);
  font-family: var(--ff-d);
  font-size: clamp(32px, 4vw, 50px);
  line-height: 1.05;
  letter-spacing: 0;
}

.eno-rec-intro {
  max-width: 980px;
  margin: 0 auto 28px;
  columns: 2 360px;
  column-gap: clamp(28px, 5vw, 70px);
  color: var(--text-l);
  font-size: clamp(15px, 1vw, 17px);
  line-height: 1.75;
}

.eno-rec-intro p {
  margin: 0 0 16px;
  break-inside: avoid;
}

.eno-rec-card {
  min-height: 190px;
}

.eno-rec-calc {
  border: 1px solid rgba(201,168,76,.18);
  border-radius: 14px;
  margin: 0 0 24px;
  padding: 18px 22px;
  background:
    radial-gradient(circle at 12% 0%, rgba(201,168,76,.08), transparent 42%),
    linear-gradient(145deg, rgba(42,32,24,.92), rgba(16,12,9,.96));
  box-shadow: 0 12px 36px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.04);
}

.eno-rec-calc-head {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 14px;
}

.eno-rec-calc-head p {
  margin: 0;
  color: rgba(236,224,200,.78);
  font-size: 13px;
  line-height: 1.6;
}

.eno-rec-calc-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.eno-rec-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}

.eno-rec-field > span {
  color: var(--gold);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.eno-rec-field select,
.eno-rec-field input {
  width: 100%;
  min-height: 52px;
  box-sizing: border-box;
  border: 1px solid rgba(201,168,76,.28);
  border-radius: 9px;
  background: linear-gradient(145deg, #221a14, #100c09);
  color: #ece0c8;
  padding: 0 16px;
  font-family: var(--ff);
  font-size: 14px;
  font-weight: 700;
}

.eno-rec-field input {
  appearance: textfield;
}

.eno-rec-field input::-webkit-outer-spin-button,
.eno-rec-field input::-webkit-inner-spin-button {
  appearance: none;
  margin: 0;
}

.eno-rec-native-select {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.eno-rec-select {
  position: relative;
  display: block;
  width: 100%;
}

.eno-rec-select-trigger {
  position: relative;
  width: 100%;
  min-height: 52px;
  box-sizing: border-box;
  border: 1px solid rgba(201,168,76,.28);
  border-radius: 9px;
  background: linear-gradient(145deg, #221a14, #100c09);
  color: #ece0c8;
  padding: 0 42px 0 16px;
  font-family: var(--ff);
  font-size: 14px;
  font-weight: 700;
  text-align: left;
  cursor: pointer;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03), 0 3px 10px rgba(0,0,0,.4);
}

.eno-rec-select-trigger::after {
  content: "";
  position: absolute;
  right: 14px;
  top: 50%;
  width: 14px;
  height: 14px;
  transform: translateY(-50%);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%23daba5e' stroke-width='2.5' viewBox='0 0 24 24'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-size: 14px;
  background-repeat: no-repeat;
  transition: transform .2s ease;
}

.eno-rec-select.is-open .eno-rec-select-trigger::after {
  transform: translateY(-50%) rotate(180deg);
}

.eno-rec-select-trigger:hover,
.eno-rec-select-trigger:focus {
  border-color: rgba(218,186,94,.72);
  box-shadow: 0 0 0 2px rgba(201,168,76,.14), inset 0 1px 0 rgba(255,255,255,.04);
}

.eno-rec-select-panel {
  position: absolute;
  left: 0;
  top: calc(100% + 6px);
  width: 100%;
  display: none;
  z-index: 99990;
  max-height: 360px;
  overflow-y: auto;
  padding: 4px;
  border: 1px solid rgba(201,168,76,.32);
  border-radius: 10px;
  background: linear-gradient(180deg, #2a2018 0%, #14100c 100%);
  box-shadow: 0 8px 32px rgba(0,0,0,.6), 0 0 20px rgba(201,168,76,.10);
}

.eno-rec-select.is-open .eno-rec-select-panel {
  display: block;
}

.eno-rec-select-option {
  display: block;
  width: 100%;
  padding: 8px 12px;
  border: 0;
  border-radius: 6px;
  background: transparent;
  color: #d8caa8;
  font-family: var(--ff);
  font-size: 13px;
  text-align: left;
  cursor: pointer;
}

.eno-rec-select-option:hover {
  background: rgba(201,168,76,.12);
  color: #ece0c8;
}

.eno-rec-select-option.is-selected {
  background: rgba(201,168,76,.25);
  color: var(--gold-l);
  font-weight: 700;
}

@media (pointer: fine) {
  html.sg-custom-cursor .eno-rec-select-panel,
  html.sg-custom-cursor .eno-rec-select-panel *,
  html.sg-custom-cursor .eno-rec-select-trigger {
    cursor: none !important;
  }
}

.eno-rec-table-wrap {
  overflow-x: visible;
  border: 1px solid rgba(201,168,76,.2);
  border-radius: 6px;
  background: rgba(16,12,9,.92);
  box-shadow: 0 22px 70px rgba(0,0,0,.26);
}

.eno-rec-table {
  width: 100%;
  min-width: 0;
  border-collapse: collapse;
}

.eno-rec-table th,
.eno-rec-table td {
  padding: 12px 14px;
  border-bottom: 1px solid rgba(255,255,255,.07);
  color: var(--text);
  font-size: 14px;
  text-align: left;
  vertical-align: top;
}

.eno-rec-table thead th {
  background: rgba(201,168,76,.08);
  color: var(--gold);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.eno-rec-table tbody th {
  color: var(--white);
  font-weight: 800;
}

.eno-rec-table tbody tr:hover {
  background: rgba(201,168,76,.055);
  box-shadow: inset 3px 0 0 rgba(201,168,76,.62);
}

.eno-rec-table a {
  color: var(--white);
  text-decoration: underline;
  text-decoration-color: rgba(201,168,76,.35);
  text-underline-offset: 4px;
}

.eno-rec-table a:hover {
  color: var(--gold-l);
}

.eno-rec-table small,
.eno-rec-muted {
  color: rgba(216,202,168,.58);
  font-size: 12px;
  line-height: 1.35;
}

.eno-rec-faq h2 {
  margin-bottom: 24px;
  text-align: center;
}

.eno-rec-faq-grid,
.eno-rec-next-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.eno-rec-faq article,
.eno-rec-next-grid a {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(201,168,76,.2);
  border-radius: 6px;
  background:
    linear-gradient(145deg, rgba(42,32,24,.78), rgba(16,12,9,.92)),
    linear-gradient(90deg, rgba(201,168,76,.05), transparent);
  padding: 20px;
  color: inherit;
  text-decoration: none;
  box-shadow: 0 18px 46px rgba(0,0,0,.22);
}

.eno-rec-faq h3 {
  margin-bottom: 12px;
  color: var(--white);
  font-size: 18px;
}

.eno-rec-faq p {
  color: var(--text);
  line-height: 1.7;
}

.eno-rec-next-grid span {
  color: var(--gold);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
}

.eno-rec-next-grid strong {
  display: block;
  margin-top: 8px;
  color: var(--white);
  font-size: 20px;
}

@media (max-width: 900px) {
  .eno-rec-calc-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .eno-rec-faq-grid,
  .eno-rec-next-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .eno-rec-calc-grid {
    grid-template-columns: 1fr;
  }

  .eno-rec-page > .sec-sep svg {
    width: 118vw;
    height: 96px;
    margin-top: -48px;
  }
}
