/* ═══════════════════════════════════════════════
   VerdoRoş – Shared Styles
═══════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600;700&family=Outfit:wght@300;400;500;600&display=swap');

:root {
  --red-deep:   #8b1a1a;
  --red-mid:    #b92b2b;
  --red-bright: #d94040;
  --red-light:  #f2c4c4;
  --red-pale:   #fdf0f0;
  --cream:      #fffaf8;
  --white:      #ffffff;
  --charcoal:   #1c1c1c;
  --text-soft:  #5a3a3a;
  --border:     #f0dede;
  --gold:       #c9975b;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
  font-family: 'Outfit', sans-serif;
  background: var(--cream);
  color: var(--charcoal);
  overflow-x: hidden;
}
h1,h2,h3,h4,h5 { font-family: 'Cormorant Garamond', serif; font-weight: 600; }

/* ── TOPBAR ── */
.topbar {
  background: var(--red-deep);
  color: rgba(255,255,255,.85);
  font-size: .76rem;
  letter-spacing: .05em;
  padding: 7px 0;
}
.topbar a { color: var(--red-light); text-decoration: none; transition: color .2s; }
.topbar a:hover { color: #fff; }

/* ── NAVBAR ── */
.navbar {
  background: var(--white);
  border-bottom: 2px solid var(--border);
  padding: 0;
  position: sticky;
  top: 0;
  z-index: 1040;
  transition: box-shadow .3s;
}
.navbar.scrolled { box-shadow: 0 4px 28px rgba(139,26,26,.12); }

.navbar-brand {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.7rem;
  font-weight: 700;
  color: var(--red-deep) !important;
  padding: 16px 0;
  letter-spacing: .02em;
  text-decoration: none;
}
.navbar-brand em { font-style: normal; color: var(--gold); }

.brand-logo {
  display: block;
  width: auto;
  max-width: 100%;
}

.brand-logo-nav {
  height: 125px;
}

.brand-logo-footer {
  height: 64px;
}

.brand-logo-offcanvas {
  height: 40px;
}

.navbar-nav > .nav-item > .nav-link {
  font-size: .88rem;
  font-weight: 500;
  color: var(--charcoal) !important;
  padding: 24px 16px !important;
  letter-spacing: .04em;
  text-transform: uppercase;
  position: relative;
  transition: color .2s;
}
.navbar-nav > .nav-item > .nav-link::before {
  content: '';
  position: absolute;
  bottom: 0; left: 16px; right: 16px;
  height: 3px;
  background: var(--red-bright);
  transform: scaleX(0);
  transition: transform .25s cubic-bezier(.4,0,.2,1);
  border-radius: 2px 2px 0 0;
}
.navbar-nav > .nav-item:hover > .nav-link::before,
.navbar-nav > .nav-item.show > .nav-link::before { transform: scaleX(1); }
.navbar-nav > .nav-item > .nav-link:hover,
.navbar-nav > .nav-item.show > .nav-link { color: var(--red-mid) !important; }

.dropdown-menu {
  border: none;
  border-top: 3px solid var(--red-bright);
  border-radius: 0 0 14px 14px;
  box-shadow: 0 12px 40px rgba(139,26,26,.14);
  background: var(--white);
  padding: 10px 0;
  min-width: 210px;
  margin-top: 0 !important;
  animation: dropIn .2s ease;
}
@keyframes dropIn {
  from { opacity:0; transform:translateY(-8px); }
  to   { opacity:1; transform:translateY(0); }
}
.dropdown-item {
  font-size: .86rem;
  padding: 10px 22px;
  color: var(--text-soft);
  display: flex;
  align-items: center;
  gap: 10px;
  transition: background .18s, color .18s, padding-left .18s;
  letter-spacing: .02em;
}
.dropdown-item i { font-size: 1rem; color: var(--red-mid); }
.dropdown-item:hover { background: var(--red-pale); color: var(--red-deep); padding-left: 28px; }
.dropdown-divider { border-color: var(--border); margin: 6px 0; }

.nav-icon-btn {
  background: none; border: none;
  font-size: 1.2rem;
  color: var(--red-deep);
  padding: 7px 9px;
  border-radius: 50%;
  transition: background .2s, color .2s;
  cursor: pointer;
}
.nav-icon-btn:hover { background: var(--red-pale); color: var(--red-bright); }

.btn-contact {
  background: var(--red-bright);
  color: #fff !important;
  border: none;
  border-radius: 50px;
  padding: 9px 22px;
  font-size: .82rem;
  font-weight: 500;
  letter-spacing: .05em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background .2s, transform .2s;
  display: inline-block;
}
.btn-contact:hover { background: var(--red-deep); transform: translateY(-1px); color: #fff; }

/* ── OFFCANVAS ── */
.offcanvas {
  width: 290px !important;
  background: var(--cream);
}
.offcanvas-header {
  border-bottom: 1px solid var(--border);
  padding: 22px 24px;
}
.offcanvas-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.4rem;
  color: var(--red-deep);
}
.offcanvas-title em { font-style: normal; color: var(--gold); }
.offcanvas-body { padding: 8px 0 24px; }

.ofc-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: var(--charcoal);
  font-size: .9rem;
  font-weight: 500;
  letter-spacing: .04em;
  text-transform: uppercase;
  padding: 13px 24px;
  border-bottom: 1px solid var(--border);
  text-decoration: none;
  cursor: pointer;
  transition: background .2s, color .2s;
}
.ofc-link:hover { background: var(--red-pale); color: var(--red-deep); }
.ofc-link i.arrow { transition: transform .25s; font-size: .8rem; }
.ofc-link.open i.arrow { transform: rotate(90deg); }

.ofc-submenu { display: none; background: #fff; padding: 4px 0; }
.ofc-submenu a {
  display: block;
  color: var(--text-soft);
  font-size: .83rem;
  padding: 10px 24px 10px 40px;
  text-decoration: none;
  border-bottom: 1px solid var(--border);
  transition: color .2s, background .2s;
}
.ofc-submenu a:hover { color: var(--red-deep); background: var(--red-pale); }

/* ── PAGE HERO (breadcrumb banner) ── */
.page-hero {
  background: var(--red-deep);
  padding: 64px 0 52px;
  position: relative;
  overflow: hidden;
}
.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: .15;
}
.page-hero-inner { position: relative; z-index: 1; }
.page-hero .eyebrow {
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--red-light);
  display: block;
  margin-bottom: 8px;
}
.page-hero h1 {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(2rem,4vw,3.2rem);
  color: #fff;
  line-height: 1.15;
  margin-bottom: 14px;
}
.breadcrumb { background: none; padding: 0; margin: 0; }
.breadcrumb-item a { color: var(--red-light); text-decoration: none; font-size: .83rem; }
.breadcrumb-item.active { color: rgba(255,255,255,.6); font-size: .83rem; }
.breadcrumb-item+.breadcrumb-item::before { color: rgba(255,255,255,.35); }

/* ── SECTION UTILS ── */
.sec { padding: 90px 0; }
.sec-sm { padding: 64px 0; }
.bg-pale { background: var(--red-pale); }
.bg-white { background: var(--white); }

.eyebrow {
  display: inline-block;
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--red-mid);
  margin-bottom: 10px;
}
.sec-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.8rem,3.5vw,2.8rem);
  color: var(--red-deep);
  line-height: 1.2;
}
.sec-sub {
  color: var(--text-soft);
  font-size: .95rem;
  line-height: 1.75;
  max-width: 540px;
}

/* ── BACK TO TOP ── */
#backTop {
  position: fixed;
  bottom: 30px; right: 30px;
  width: 44px; height: 44px;
  background: var(--red-bright);
  color: #fff;
  border: none;
  border-radius: 50%;
  font-size: 1rem;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 16px rgba(185,43,43,.4);
  opacity: 0;
  transform: translateY(12px);
  transition: opacity .3s, transform .3s;
  z-index: 999;
}
#backTop.show { opacity: 1; transform: translateY(0); }
#backTop:hover { background: var(--red-deep); }

/* ── FOOTER ── */
footer {
  background: #130f0f;
  color: rgba(255,255,255,.65);
  padding: 70px 0 0;
}
.footer-brand { font-family: 'Cormorant Garamond', serif; font-size: 1.6rem; color: #fff; }
.footer-brand em { font-style: normal; color: var(--gold); }
.footer-desc { font-size: .85rem; line-height: 1.75; max-width: 250px; }
.footer-h { font-family: 'Cormorant Garamond', serif; font-size: 1rem; color: #fff; margin-bottom: 18px; letter-spacing: .04em; }
.footer-links { list-style: none; padding: 0; }
.footer-links li { margin-bottom: 10px; }
.footer-links a { color: rgba(255,255,255,.55); text-decoration: none; font-size: .85rem; transition: color .2s; }
.footer-links a:hover { color: var(--red-light); }
.social-btn {
  width: 36px; height: 36px;
  background: rgba(255,255,255,.07);
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.7);
  text-decoration: none;
  font-size: .95rem;
  transition: background .2s, color .2s;
  margin-right: 6px;
}
.social-btn:hover { background: var(--red-bright); color: #fff; }
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.08);
  padding: 20px 0;
  margin-top: 52px;
  font-size: .78rem;
  color: rgba(255,255,255,.3);
}

/* ── SCROLL REVEAL ── */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .55s ease, transform .55s ease;
}
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ── RESPONSIVE ── */
@media (max-width: 575px) {
  .sec { padding: 60px 0; }
}

/* navbar layout override */
.navbar .container {
  display: flex;
  flex-direction: column;
}

.nav-top-row {
  position: relative;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 18px 0 14px;
}

.nav-mobile-toggle {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
}

.nav-bottom-row {
  position: relative;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 28px;
}

.nav-bottom-row::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  width: 100vw;
  height: 1px;
  background: var(--border);
  transform: translateX(-50%);
}

.nav-cta-wrap {
  display: flex;
  align-items: center;
}

.navbar-nav {
  align-items: center;
}

.navbar-brand {
  font-size: 2rem;
  padding: 0;
}

.navbar-nav > .nav-item > .nav-link {
  padding: 18px 16px !important;
}

@media (max-width: 991px) {
  .nav-top-row {
    padding: 14px 0;
    min-height: 78px;
  }

  .navbar-brand {
    font-size: 1.8rem;
  }

  .brand-logo-nav {
    height: 60px;
  }
}
