/* ============================================================
   Design tokens — derived from restincloud.it brand identity
   ============================================================ */
:root {
  --rc-bordeaux:        #7f1f29;   /* primary brand color */
  --rc-bordeaux-dark:   #5e151d;   /* deep variant for gradients/hover */
  --rc-bordeaux-soft:   #9a3540;   /* lighter accent */
  --rc-brass:           #c2a35a;   /* warm memorial accent (candlelight) */
  --rc-brass-soft:      #e7d9b4;
  --rc-ink:             #221d1e;   /* primary text */
  --rc-muted:           #8a807c;   /* secondary text */
  --rc-line:            #ece5e1;   /* hairline dividers */
  --rc-bg:              #faf7f5;   /* warm off-white page background */
  --rc-card:            #ffffff;
  --rc-shadow:          0 18px 40px -24px rgba(94, 21, 29, .35);
  --rc-radius:          16px;
}

* { box-sizing: border-box; }

body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  color: var(--rc-ink);
  background: var(--rc-bg);
  margin: 0;
  -webkit-font-smoothing: antialiased;
  scroll-behavior: smooth;
}

.font-display { font-family: 'Cormorant Garamond', Georgia, serif; }

a { text-decoration: none; }

::selection { background: var(--rc-brass-soft); color: var(--rc-bordeaux-dark); }

/* ---------- Eyebrow / section heading helpers ---------- */
.eyebrow {
  font-size: .72rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--rc-bordeaux);
}
.section-title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-weight: 600;
  color: var(--rc-ink);
  letter-spacing: .2px;
}
.brass-rule {
  width: 56px; height: 3px; border: 0;
  background: linear-gradient(90deg, var(--rc-brass), var(--rc-brass-soft));
  border-radius: 3px; opacity: 1;
}

/* ============================================================
   Header / navbar
   ============================================================ */
.rc-navbar {
  background: rgba(250, 247, 245, .88);
  backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid var(--rc-line);
}
.rc-brand {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-weight: 600;
  font-size: 1.6rem;
  color: var(--rc-bordeaux);
  letter-spacing: .3px;
  line-height: 1;
}
.rc-brand .dot { color: var(--rc-brass); }
.rc-brand small {
  display: block;
  font-family: 'Inter', sans-serif;
  font-size: .58rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--rc-muted);
  margin-top: 3px;
  font-weight: 600;
}
.navbar-nav .nav-link {
  color: var(--rc-ink);
  font-weight: 500;
  font-size: .92rem;
  padding: .5rem .9rem;
  position: relative;
}
.navbar-nav .nav-link::after {
  content: ""; position: absolute; left: .9rem; right: .9rem; bottom: .35rem;
  height: 2px; background: var(--rc-bordeaux);
  transform: scaleX(0); transform-origin: left; transition: transform .25s ease;
}
.navbar-nav .nav-link:hover::after,
.navbar-nav .nav-link.active::after { transform: scaleX(1); }
.navbar-nav .nav-link:hover { color: var(--rc-bordeaux); }

.btn-bordeaux {
  background: var(--rc-bordeaux);
  color: #fff;
  border: 0;
  font-weight: 600;
  border-radius: 999px;
  padding: .55rem 1.3rem;
  transition: transform .2s ease, background .2s ease, box-shadow .2s ease;
}
.btn-bordeaux:hover {
  background: var(--rc-bordeaux-dark);
  color: #fff;
  transform: translateY(-1px);
  box-shadow: var(--rc-shadow);
}
.btn-outline-bordeaux {
  border: 1.5px solid var(--rc-bordeaux);
  color: var(--rc-bordeaux);
  background: transparent;
  font-weight: 600;
  border-radius: 999px;
  padding: .55rem 1.3rem;
  transition: all .2s ease;
}
.btn-outline-bordeaux:hover { background: var(--rc-bordeaux); color: #fff; }

/* ============================================================
   Hero + search
   ============================================================ */
.rc-hero {
  position: relative;
  padding: 4.5rem 0 3rem;
  background:
    radial-gradient(1200px 500px at 80% -10%, rgba(127,31,41,.10), transparent 60%),
    radial-gradient(800px 400px at 0% 110%, rgba(194,163,90,.10), transparent 60%);
}
.rc-hero h1 {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-weight: 600;
  font-size: clamp(2.4rem, 5vw, 3.9rem);
  line-height: 1.05;
  color: var(--rc-ink);
  letter-spacing: .2px;
}
.rc-hero h1 .accent { color: var(--rc-bordeaux); font-style: italic; }
.rc-hero p.lead {
  color: var(--rc-muted);
  font-size: 1.08rem;
  max-width: 620px;
}

.search-card {
  background: var(--rc-card);
  border: 1px solid var(--rc-line);
  border-radius: var(--rc-radius);
  box-shadow: var(--rc-shadow);
  padding: .6rem;
}
.search-card .form-control,
.search-card .form-select {
  border: 0;
  box-shadow: none !important;
  font-size: .95rem;
  padding: .8rem .9rem;
}
.search-card .input-cell { border-right: 1px solid var(--rc-line); }
.search-card .input-cell:last-of-type { border-right: 0; }
.search-icon { color: var(--rc-bordeaux); }

.hero-stats { color: var(--rc-muted); font-size: .85rem; }
.hero-stats strong { color: var(--rc-bordeaux); font-weight: 700; }

/* ============================================================
   Obituary cards
   ============================================================ */
.obit-card {
  background: var(--rc-card);
  border: 1px solid var(--rc-line);
  border-radius: var(--rc-radius);
  overflow: hidden;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  height: 100%;
  display: flex;
  flex-direction: column;
}
.obit-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--rc-shadow);
  border-color: var(--rc-brass-soft);
}
.obit-portrait {
  position: relative;
  aspect-ratio: 4 / 3;
  background: linear-gradient(160deg, #efe9e6, #e4dbd6);
  display: flex; align-items: flex-end; justify-content: center;
  overflow: hidden;
}
.obit-portrait img.portrait-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  top: 0; left: 0;
}
.obit-portrait .monogram {
  font-family: 'Cormorant Garamond', serif;
  font-size: 3.4rem;
  color: var(--rc-bordeaux);
  opacity: .55;
  align-self: center;
  font-weight: 500;
  z-index: 1;
}
.obit-portrait .ribbon {
  position: absolute; top: 12px; left: 12px;
  background: rgba(34,29,30,.78);
  color: #fff; font-size: .68rem; font-weight: 600;
  letter-spacing: .08em; text-transform: uppercase;
  padding: .25rem .6rem; border-radius: 999px;
  backdrop-filter: blur(4px);
  z-index: 2;
}
.obit-portrait .candle {
  position: absolute; bottom: 10px; right: 12px;
  color: var(--rc-brass); font-size: 1.1rem;
  filter: drop-shadow(0 0 6px rgba(194,163,90,.7));
  z-index: 2;
}
.obit-body { padding: 1.1rem 1.2rem 1.3rem; display: flex; flex-direction: column; flex: 1; }
.obit-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.5rem; font-weight: 600; line-height: 1.1;
  color: var(--rc-ink); margin-bottom: .15rem;
}
.obit-dates {
  font-size: .85rem; color: var(--rc-muted); font-weight: 500;
  display: flex; align-items: center; gap: .4rem; margin-bottom: .6rem;
}
.obit-dates .sep { color: var(--rc-brass); }
.obit-place {
  font-size: .82rem; color: var(--rc-muted);
  display: flex; align-items: center; gap: .35rem; margin-bottom: .9rem;
}
.obit-place i { color: var(--rc-bordeaux); }
.obit-agency {
  margin-top: auto;
  border-top: 1px dashed var(--rc-line);
  padding-top: .75rem;
  display: flex; align-items: center; justify-content: space-between; gap: .5rem;
}
.obit-agency .label { font-size: .7rem; text-transform: uppercase; letter-spacing: .1em; color: var(--rc-muted); }
.obit-agency .name { font-size: .82rem; font-weight: 600; color: var(--rc-bordeaux); }
.obit-link { font-size: .82rem; font-weight: 600; color: var(--rc-bordeaux); white-space: nowrap; }
.obit-link:hover { color: var(--rc-bordeaux-dark); }

/* ============================================================
   Slider (scroll-snap track)
   ============================================================ */
.slider-wrap { position: relative; }
.slider-track {
  display: flex; gap: 1.25rem;
  overflow-x: auto; scroll-snap-type: x mandatory;
  padding: .5rem .25rem 1.5rem; margin: 0 -.25rem;
  scrollbar-width: none;
}
.slider-track::-webkit-scrollbar { display: none; }
.slider-track > .slide {
  scroll-snap-align: start;
  flex: 0 0 100%;
}
@media (min-width: 576px) {
  .slider-track > .slide {
    flex: 0 0 calc(50% - 0.625rem);
  }
}
@media (min-width: 992px) {
  .slider-track > .slide {
    flex: 0 0 calc(33.333% - 0.833rem);
  }
}
.slider-btn {
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--rc-card); border: 1px solid var(--rc-line);
  color: var(--rc-bordeaux); display: inline-flex; align-items: center; justify-content: center;
  box-shadow: var(--rc-shadow); transition: all .2s ease; cursor: pointer;
}
.slider-btn:hover { background: var(--rc-bordeaux); color: #fff; border-color: var(--rc-bordeaux); }

/* ============================================================
   Archive grid + empty state
   ============================================================ */
.filter-chip {
  border: 1px solid var(--rc-line); background: #fff; color: var(--rc-ink);
  border-radius: 999px; padding: .35rem .9rem; font-size: .82rem; font-weight: 500;
  cursor: pointer; transition: all .2s ease;
}
.filter-chip:hover { border-color: var(--rc-bordeaux); color: var(--rc-bordeaux); }
.filter-chip.active { background: var(--rc-bordeaux); color: #fff; border-color: var(--rc-bordeaux); }
.empty-state {
  text-align: center; padding: 3rem 1rem; color: var(--rc-muted);
}
.empty-state i { font-size: 2.4rem; color: var(--rc-brass); }

/* ============================================================
   Agency CTA section
   ============================================================ */
.rc-cta {
  position: relative; overflow: hidden;
  background: linear-gradient(135deg, var(--rc-bordeaux), var(--rc-bordeaux-dark));
  color: #fff; border-radius: 26px;
  box-shadow: var(--rc-shadow);
}
.rc-cta::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(500px 240px at 88% 0%, rgba(194,163,90,.28), transparent 60%),
    radial-gradient(400px 220px at 0% 100%, rgba(255,255,255,.08), transparent 60%);
  pointer-events: none;
}
.rc-cta h2 {
  font-family: 'Cormorant Garamond', serif; font-weight: 600;
  font-size: clamp(1.9rem, 3.5vw, 2.8rem); line-height: 1.08;
}
.rc-cta .cta-tick { color: var(--rc-brass-soft); }
.rc-cta .powered {
  font-size: .78rem; letter-spacing: .12em; text-transform: uppercase;
  color: rgba(255,255,255,.7);
}
.btn-brass {
  background: var(--rc-brass); color: #2a1d05; border: 0; font-weight: 700;
  border-radius: 999px; padding: .7rem 1.6rem; transition: all .2s ease;
}
.btn-brass:hover { background: var(--rc-brass-soft); transform: translateY(-1px); box-shadow: 0 12px 26px -12px rgba(0,0,0,.5); }
.btn-ghost-light {
  background: transparent; color: #fff; border: 1.5px solid rgba(255,255,255,.6);
  border-radius: 999px; padding: .7rem 1.6rem; font-weight: 600; transition: all .2s ease;
}
.btn-ghost-light:hover { background: rgba(255,255,255,.12); border-color: #fff; color: #fff; }

/* ============================================================
   Chi Siamo
   ============================================================ */
.value-card {
  background: var(--rc-card); border: 1px solid var(--rc-line);
  border-radius: var(--rc-radius); padding: 1.6rem; height: 100%;
  transition: transform .25s ease, box-shadow .25s ease;
}
.value-card:hover { transform: translateY(-3px); box-shadow: var(--rc-shadow); }
.value-icon {
  width: 48px; height: 48px; border-radius: 12px;
  background: rgba(127,31,41,.08); color: var(--rc-bordeaux);
  display: inline-flex; align-items: center; justify-content: center; font-size: 1.4rem;
  margin-bottom: 1rem;
}

/* ============================================================
   Footer
   ============================================================ */
.rc-footer { background: #1c1718; color: rgba(255,255,255,.75); }
.rc-footer a { color: rgba(255,255,255,.7); transition: color .2s ease; }
.rc-footer a:hover { color: #fff; }
.rc-footer .footer-brand {
  font-family: 'Cormorant Garamond', serif; font-weight: 600; font-size: 1.5rem; color: #fff;
}
.rc-footer .footer-brand .dot { color: var(--rc-brass); }
.rc-footer .foot-title { font-size: .78rem; text-transform: uppercase; letter-spacing: .14em; color: var(--rc-brass); font-weight: 600; }
.rc-footer .social i {
  width: 38px; height: 38px; border-radius: 10px; border: 1px solid rgba(255,255,255,.15);
  display: inline-flex; align-items: center; justify-content: center; transition: all .2s ease;
}
.rc-footer .social a:hover i { background: var(--rc-bordeaux); border-color: var(--rc-bordeaux); }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.1); font-size: .82rem; color: rgba(255,255,255,.5); }

/* ---------- Reveal-on-scroll animation ---------- */
@media (prefers-reduced-motion: no-preference) {
  .reveal { opacity: 0; transform: translateY(18px); transition: opacity .6s ease, transform .6s ease; }
  .reveal.in { opacity: 1; transform: none; }
}
