/* =========================
   Blue Moon Tattoo - Moody Type System
   Headings: Bodoni Moda (Didone)
   Body/UI: Inter
   ========================= */

/* Google Fonts (CSS import) */
@import url('https://fonts.googleapis.com/css2?family=Bodoni+Moda:opsz,wght@6..96,400;6..96,600;6..96,700&family=Inter:wght@300;400;500;600&display=swap');

:root{
  --bm-bg: #07070b;                 /* deeper black */
  --bm-bg-2: #0b0b12;               /* panel black */
  --bm-panel: rgba(255,255,255,0.035);
  --bm-border: rgba(255,255,255,0.11);

  --bm-text: rgba(255,255,255,0.92);
  --bm-muted: rgba(255,255,255,0.62);

  /* Purple accent to match logo */
  --bm-accent: #5a36c9;
  --bm-accent-soft: rgba(90,54,201,0.22);

  --bm-radius: 1.25rem;

  --bm-font-display: "Bodoni Moda", serif;
  --bm-font-body: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

/* Base */
html { scroll-behavior: smooth; }
body{
  font-family: var(--bm-font-body);
  background: var(--bm-bg);
  color: var(--bm-text);
  overflow-x: hidden;
}

/* Moody atmosphere: subtle light blooms + smoke + grain */
body::before{
  content:"";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background:
    radial-gradient(1200px 700px at 12% 18%, rgba(90,54,201,0.18), transparent 62%),
    radial-gradient(900px 600px at 85% 12%, rgba(255,255,255,0.05), transparent 60%),
    radial-gradient(800px 500px at 70% 80%, rgba(90,54,201,0.10), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,0.15), rgba(0,0,0,0.65));
  opacity: 1;
}
body::after{
  /* Grain layer (pure CSS) */
  content:"";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background-image:
    repeating-linear-gradient(0deg,
      rgba(255,255,255,0.02) 0px,
      rgba(255,255,255,0.02) 1px,
      rgba(0,0,0,0) 2px,
      rgba(0,0,0,0) 4px
    );
  opacity: 0.10;
  mix-blend-mode: overlay;
}

/* Ensure your main content sits above atmos layers */
nav, main, footer { position: relative; z-index: 1; }

img { max-width: 100%; height: auto; }

/* Typography */
h1, h2, h3, h4, h5, h6,
.display-1, .display-2, .display-3, .display-4, .display-5, .display-6{
  font-family: var(--bm-font-display);
  letter-spacing: 0.02em;
  text-transform: none;
}

h1, .display-4, .display-5{
  text-shadow: 0 10px 35px rgba(0,0,0,0.55);
}

.lead{
  font-weight: 400;
  color: rgba(255,255,255,0.78);
}

.text-white-50 { color: var(--bm-muted) !important; }
.text-white-75 { color: rgba(255,255,255,0.78) !important; }
.border-white-10 { border-color: var(--bm-border) !important; }
.letterspace { letter-spacing: .18em; }

/* Links */
a { text-underline-offset: 0.18em; }
a:hover { text-decoration-thickness: 2px; }

/* Navbar */
.navbar{
  background: rgba(6,6,10,0.70) !important;
  backdrop-filter: blur(12px);
}
.navbar .nav-link{
  color: rgba(255,255,255,0.78) !important;
  font-weight: 500;
}
.navbar .nav-link:hover{ color: rgba(255,255,255,0.96) !important; }
.navbar .nav-link.active{ color: #fff !important; }

/* Dropdown */
.dropdown-menu{
  border: 1px solid var(--bm-border);
  background: rgba(0,0,0,0.92) !important;
  backdrop-filter: blur(10px);
}
.dropdown-item:hover{ background: rgba(255,255,255,0.07); }

/* Buttons */
.btn{
  border-radius: 999px;
  padding-left: 1.1rem;
  padding-right: 1.1rem;
  font-weight: 600;
  letter-spacing: 0.01em;
}
.btn-primary{
  background: var(--bm-accent) !important;
  border-color: var(--bm-accent) !important;
  box-shadow: 0 14px 40px rgba(90,54,201,0.26);
}
.btn-primary:hover{
  filter: brightness(1.09);
  box-shadow: 0 18px 55px rgba(90,54,201,0.33);
}
.btn-outline-light{
  border-color: rgba(255,255,255,0.35) !important;
}
.btn-outline-light:hover{
  background: rgba(255,255,255,0.10) !important;
  border-color: rgba(255,255,255,0.50) !important;
}

/* Cards / Panels */
.card{
  border: 1px solid var(--bm-border) !important;
  background: rgba(0,0,0,0.40) !important;
  box-shadow: 0 20px 70px rgba(0,0,0,0.40);
}
.rounded-4 { border-radius: var(--bm-radius) !important; }

/* Hover lift */
.hover-lift{
  transition: transform .20s ease, box-shadow .20s ease, border-color .20s ease;
}
.hover-lift:hover{
  transform: translateY(-2px);
  border-color: rgba(255,255,255,0.18) !important;
  box-shadow: 0 28px 90px rgba(0,0,0,0.50);
}

/* Forms */
.form-control, .form-select{
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid var(--bm-border) !important;
  color: var(--bm-text) !important;
  border-radius: 1rem;
}
.form-control::placeholder{ color: rgba(255,255,255,0.45); }
.form-control:focus, .form-select:focus{
  box-shadow: 0 0 0 0.25rem rgba(90,54,201,0.25) !important;
  border-color: rgba(90,54,201,0.55) !important;
}
.form-label{ color: rgba(255,255,255,0.80); }

/* Portfolio thumbs */
.thumb{
  display:block;
  aspect-ratio: 1 / 1;
  border-radius: var(--bm-radius);
  overflow: hidden;
  border: 1px solid var(--bm-border);
  background: rgba(255,255,255,0.03);
}
.thumb img{
  width:100%;
  height:100%;
  object-fit: cover;
  transition: transform .25s ease, opacity .25s ease;
  opacity: .92;
  filter: contrast(1.05) saturate(0.96);
}
.thumb:hover img{
  transform: scale(1.06);
  opacity: 1;
}

/* Fullscreen carousel hero (responsive, no scroll) */
.hero-carousel{ overflow: hidden; }
.hero-carousel .carousel,
.hero-carousel .carousel-inner,
.hero-carousel .carousel-item{
  height: 100dvh;  /* dynamic viewport height */
  height: 100svh;  /* fallback */
  height: 100vh;   /* fallback */
  min-height: 520px;
}
.hero-carousel .hero-img{
  height: 100%;
  width: 100%;
  object-fit: cover;
  filter: contrast(1.06) saturate(0.92);
}
.hero-carousel .carousel-overlay{
  position: absolute;
  inset: 0;
  background:
    radial-gradient(1000px 650px at 18% 35%, rgba(90,54,201,0.26), transparent 62%),
    linear-gradient(90deg, rgba(0,0,0,0.78), rgba(0,0,0,0.22) 48%, rgba(0,0,0,0.70));
}
.hero-carousel .carousel-caption{
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  padding: 0;
  text-align: left;
}

/* Footer */
footer{ color: rgba(255,255,255,0.70); }
footer a{ color: rgba(255,255,255,0.78); }
footer a:hover{ color: rgba(255,255,255,0.96); }

/* Accessibility */
:focus-visible{
  outline: 2px solid rgba(90,54,201,0.9);
  outline-offset: 2px;
}

/* =========================
   Navbar typography refinement
   ========================= */

.navbar .nav-link{
  font-family: var(--bm-font-body);
  font-weight: 400;                 /* lighter */
  letter-spacing: 0.18em;           /* stylised tracking */
  text-transform: uppercase;        /* classic tattoo signage */
  font-size: 0.75rem;               /* slightly smaller = more refined */
  color: rgba(255,255,255,0.68) !important;
  transition: color .2s ease, opacity .2s ease;
}

.navbar .nav-link:hover{
  color: rgba(255,255,255,0.92) !important;
}

.navbar .nav-link.active{
  color: #fff !important;
}

/* Dropdown inherits same feel */
.dropdown-menu .dropdown-item{
  font-weight: 400;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-size: 0.7rem;
  color: rgba(255,255,255,0.78);
}
.dropdown-menu .dropdown-item:hover{
  color: #fff;
}

/* Brand stays bold so it anchors the nav */
.navbar-brand span{
  font-family: var(--bm-font-display);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: none;
}

/* Dark accordion styling */
.accordion-dark .accordion-item{
  background: rgba(0,0,0,0.40);
  border: 1px solid var(--bm-border);
  border-radius: 1rem;
  overflow: hidden;
  margin-bottom: .75rem;
}
.accordion-dark .accordion-button{
  background: rgba(255,255,255,0.03);
  color: rgba(255,255,255,0.88);
  font-weight: 500;
}
.accordion-dark .accordion-button:not(.collapsed){
  background: rgba(90,54,201,0.12);
  color: #fff;
}
.accordion-dark .accordion-button:focus{
  box-shadow: 0 0 0 0.25rem rgba(90,54,201,0.20);
}
.accordion-dark .accordion-body{
  background: rgba(0,0,0,0.30);
}

/* --- Carousel interaction fixes --- */

/* Allow clicks to pass through the overlay */
.carousel-overlay {
  pointer-events: none;
}

/* Ensure controls sit above everything */
.carousel-control-prev,
.carousel-control-next,
.carousel-indicators {
  z-index: 10;
}

/* Ensure captions are clickable */
.carousel-caption {
  z-index: 9;
  pointer-events: auto;
}

/* Prevent images from stealing clicks */
.hero-img {
  pointer-events: none;
}
