/* =====================================================
   THEME 23 — TATTOO & PIERCING — DARK EDGY AESTHETIC
   ===================================================== */
:root { --t23-primary:       #E8383A; --t23-primary-dark:  #C02022; --t23-secondary:     #0A0A0A; --t23-secondary-mid: #111111; --t23-surface:       #1A1A1A; --t23-surface-mid:   #222222; --t23-light-bg:      #F0EEEB; --t23-white:         #FFFFFF; --t23-text-dark:     #0A0A0A; --t23-text-mid:      #555555; --t23-text-light:    #888888; --t23-border:        rgba(232,56,58,0.18); --t23-border-dark:   rgba(255,255,255,0.08); --t23-shadow-sm:     0 4px 16px rgba(0,0,0,0.25); --t23-shadow-md:     0 8px 32px rgba(0,0,0,0.35); --t23-shadow-lg:     0 20px 60px rgba(0,0,0,0.50); --t23-radius-sm:     4px; --t23-radius-md:     10px; --t23-radius-lg:     18px; --t23-radius-pill:   999px; --t23-font-display:  "Bebas Neue", sans-serif; --t23-font-body:     "Raleway", sans-serif; }
/* =====================================================
   HERO SECTION
   ===================================================== */
.theme23-hero { position: relative; width: 100%; height: 100vh; min-height: 540px; overflow: hidden; }
.theme23-hero .bg-video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: grayscale(30%) contrast(1.1); }
.theme23-hero .video-overlay { position: absolute; inset: 0; background: linear-gradient(
    180deg,
    rgba(10,10,10,0.85) 0%,
    rgba(10,10,10,0.70) 50%,
    rgba(10,10,10,0.96) 100%
  ); display: flex; align-items: center; justify-content: center; text-align: center; padding: 20px; }
.hero-content { color: var(--t23-white); max-width: 900px; animation: heroReveal23 0.9s cubic-bezier(0.22,1,0.36,1) both; }
@keyframes heroReveal23 {
 from { opacity: 0; transform: scale(0.96); }
to { opacity: 1; transform: scale(1); }
 }
.hero-badges { display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; margin-bottom: 20px; align-items: center; }
.hero-badge { font-family: var(--t23-font-body); font-size: 0.72rem; font-weight: 600; letter-spacing: 2px; color: rgba(255,255,255,0.65); text-transform: uppercase; }
.hero-badge.sep { color: var(--t23-primary); font-size: 0.6rem; }
.hero-content h1 { font-family: var(--t23-font-display); font-size: clamp(4rem, 12vw, 9rem); font-weight: 400; letter-spacing: 6px; text-transform: uppercase; line-height: 0.92; margin: 0 0 16px; text-shadow: 0 0 60px rgba(232,56,58,0.25); }
.hero-tagline { font-family: var(--t23-font-body); font-size: clamp(0.8rem, 1.8vw, 0.95rem); font-weight: 400; color: rgba(255,255,255,0.50); margin: 0 0 36px; letter-spacing: 4px; text-transform: uppercase; }
.hero-scroll { position: absolute; bottom: 32px; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: 6px; color: rgba(255,255,255,0.30); font-size: 0.6rem; letter-spacing: 2px; text-transform: uppercase; animation: scrollBounce23 2s ease-in-out infinite; }
.hero-scroll svg { width: 18px; height: 18px; stroke: var(--t23-primary); }
@keyframes scrollBounce23 {
 0%, 100% { transform: translateX(-50%) translateY(0); }
50% { transform: translateX(-50%) translateY(8px); }
 }
/* =====================================================
   SHARED SECTION STYLES
   ===================================================== */
.section-title { font-family: var(--t23-font-display); font-size: clamp(2rem, 5vw, 3.5rem); font-weight: 400; color: var(--t23-text-dark); margin: 0 0 10px; letter-spacing: 3px; text-transform: uppercase; }
.section-subtitle { font-family: var(--t23-font-body); font-size: 0.95rem; color: var(--t23-text-light); margin: 0 0 48px; letter-spacing: 0.5px; }
.section-header { text-align: center; margin-bottom: 48px; }
.section-header .t23-label { display: inline-block; color: var(--t23-primary); font-family: var(--t23-font-body); font-size: 0.65rem; font-weight: 700; letter-spacing: 4px; text-transform: uppercase; padding: 5px 0; margin-bottom: 12px; position: relative; border-bottom: 1px solid var(--t23-primary); padding-bottom: 6px; }
/* =====================================================
   CONTACT CARDS
   ===================================================== */
.contact-cards-theme23 { background: var(--t23-secondary); padding: 50px 32px; gap: 16px; }
.contact-cards-theme23 .contact-card { background: var(--t23-surface); border: 1px solid var(--t23-border-dark); border-radius: var(--t23-radius-md); padding: 36px 20px 28px; text-align: center; box-shadow: none; transition: transform 0.28s ease, border-color 0.28s ease; text-decoration: none; position: relative; overflow: hidden; }
.contact-cards-theme23 .contact-card::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: var(--t23-primary); transform: scaleX(0); transition: transform 0.3s ease; }
.contact-cards-theme23 .contact-card:hover { transform: translateY(-6px); border-color: rgba(232,56,58,0.35); }
.contact-cards-theme23 .contact-card:hover::before { transform: scaleX(1); }
.contact-cards-theme23 .card-icon-wrap { width: 58px; height: 58px; background: rgba(232,56,58,0.08); border-radius: var(--t23-radius-sm); display: flex; align-items: center; justify-content: center; margin: 0 auto 16px; transition: background 0.3s; }
.contact-cards-theme23 .contact-card:hover .card-icon-wrap { background: rgba(232,56,58,0.18); }
.contact-cards-theme23 .contact-card img { width: 28px; height: 28px; object-fit: contain; }
.contact-cards-theme23 .contact-card p { font-family: var(--t23-font-body); font-size: 0.8rem; font-weight: 700; color: rgba(255,255,255,0.75); margin: 0; letter-spacing: 1.5px; text-transform: uppercase; }
/* =====================================================
   POSTER SECTION
   ===================================================== */
.theme23-poster { background: var(--t23-secondary-mid); padding: 80px 48px; position: relative; overflow: hidden; opacity: 0; transform: translateY(40px); animation: fadeUp 1.6s cubic-bezier(0.22,1,0.36,1) forwards; animation-play-state: paused; }
.theme23-poster::before { content: "INK"; position: absolute; right: -20px; bottom: -30px; font-family: var(--t23-font-display); font-size: 18rem; color: rgba(255,255,255,0.025); pointer-events: none; letter-spacing: 10px; }
.poster-content { max-width: 1100px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 60px; position: relative; z-index: 1; }
.poster-left { flex: 1; }
.poster-tag { font-family: var(--t23-font-body); font-size: 0.65rem; font-weight: 700; letter-spacing: 4px; color: var(--t23-primary); margin-bottom: 16px; text-transform: uppercase; }
.poster-name { font-family: var(--t23-font-display); font-size: clamp(2.8rem, 6vw, 5rem); color: var(--t23-white); font-weight: 400; letter-spacing: 4px; margin: 0 0 6px; text-transform: uppercase; line-height: 0.95; }
.poster-designation { font-size: 0.95rem; font-weight: 400; color: rgba(255,255,255,0.40); margin: 0 0 24px; letter-spacing: 1px; }
.poster-divider { width: 40px; height: 3px; background: var(--t23-primary); margin: 0 0 28px; }
.poster-contact { display: flex; align-items: center; gap: 12px; margin: 0 0 12px; font-size: 0.98rem; }
.poster-contact i { color: var(--t23-primary); width: 18px; }
.poster-contact a { color: rgba(255,255,255,0.78); font-weight: 400; text-decoration: none; transition: color 0.2s; }
.poster-contact a:hover { color: var(--t23-primary); }
.poster-location { margin-top: 28px; padding-top: 22px; border-top: 1px solid rgba(255,255,255,0.07); }
.poster-location-heading { font-size: 0.62rem; font-weight: 700; letter-spacing: 3.5px; text-transform: uppercase; color: var(--t23-primary); margin: 0 0 10px; opacity: 0.85; }
.poster-location p { font-size: 0.9rem; color: rgba(255,255,255,0.60); margin: 0 0 4px; line-height: 1.6; }
.poster-right { flex: 0 0 auto; }
.specialty-list { display: flex; flex-direction: column; gap: 0; }
.specialty-row { display: flex; align-items: center; gap: 18px; padding: 14px 0; border-bottom: 1px solid rgba(255,255,255,0.06); transition: all 0.25s ease; cursor: default; }
.specialty-row:first-child { border-top: 1px solid rgba(255,255,255,0.06); }
.specialty-row:hover { padding-left: 8px; border-bottom-color: rgba(232,56,58,0.3); }
.s-num { font-family: var(--t23-font-display); font-size: 0.8rem; color: var(--t23-primary); letter-spacing: 1px; min-width: 24px; }
.s-name { font-family: var(--t23-font-body); font-size: 1rem; font-weight: 600; color: rgba(255,255,255,0.80); letter-spacing: 0.5px; text-transform: uppercase; }
/* =====================================================
   SERVICES SECTION
   ===================================================== */
.theme23-services { padding: 90px 32px; background: var(--t23-light-bg); text-align: center; }
.theme23-services .section-title { color: var(--t23-text-dark); }
.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px; max-width: 1100px; margin: 0 auto 56px; }
.service-item { position: relative; overflow: hidden; cursor: pointer; aspect-ratio: 1; }
.service-item img { width: 100%; height: 100%; object-fit: cover; display: block; filter: grayscale(20%); transition: transform 0.5s ease, filter 0.5s ease; }
.service-item:hover img { transform: scale(1.08); filter: grayscale(0%); }
.service-item::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(10,10,10,0.90) 0%, transparent 55%); pointer-events: none; opacity: 0; transition: opacity 0.35s ease; }
.service-item:hover::after { opacity: 1; }
.service-label { position: absolute; bottom: 18px; left: 0; right: 0; text-align: center; font-family: var(--t23-font-display); font-size: 1.2rem; color: var(--t23-white); letter-spacing: 3px; text-transform: uppercase; opacity: 0; transform: translateY(8px); transition: all 0.35s ease; z-index: 2; }
.service-item:hover .service-label { opacity: 1; transform: translateY(0); }
.services-save { text-align: center; }
/* =====================================================
   MAP SECTION
   ===================================================== */
.theme23-map { padding: 90px 32px; background: var(--t23-secondary); text-align: center; }
.theme23-map .section-title { color: var(--t23-white); }
.theme23-map .section-subtitle { color: rgba(255,255,255,0.35); }
.theme23-map .t23-label { color: var(--t23-primary); }
.theme23-map .map-wrapper { max-width: 920px; margin: 0 auto; border-radius: var(--t23-radius-md); overflow: hidden; box-shadow: var(--t23-shadow-lg); border: 1px solid rgba(232,56,58,0.20); }
.theme23-map .map-wrapper iframe { width: 100%; height: 420px; border: 0; display: block; }
/* =====================================================
   PAYMENT SECTION
   ===================================================== */
.theme23-payment { padding: 90px 32px; background: var(--t23-surface); text-align: center; }
.theme23-payment .section-title { color: var(--t23-white); }
.theme23-payment .section-subtitle { color: rgba(255,255,255,0.35); }
.theme23-payment .upi-id { display: inline-block; background: rgba(232,56,58,0.08); border: 1px solid rgba(232,56,58,0.25); border-radius: var(--t23-radius-sm); padding: 10px 28px; font-size: 1rem; font-weight: 600; color: rgba(255,255,255,0.75); margin-bottom: 48px; }
.theme23-payment .upi-id strong { color: var(--t23-primary); }
.theme23-payment .payment-icons { display: flex; justify-content: center; gap: 20px; flex-wrap: wrap; }
.theme23-payment .payment-icons a { display: flex; align-items: center; justify-content: center; background: var(--t23-secondary-mid); border: 1px solid rgba(255,255,255,0.10); border-radius: var(--t23-radius-md); padding: 20px 28px; transition: transform 0.28s, border-color 0.28s; }
.theme23-payment .payment-icons a:hover { transform: translateY(-6px); border-color: rgba(232,56,58,0.40); }
.theme23-payment .payment-icons img { width: 80px; height: auto; display: block; }
/* =====================================================
   SOCIAL SECTION
   ===================================================== */
.contact-social-section-theme23 { padding: 90px 32px; background: var(--t23-secondary); text-align: center; }
.contact-social-section-theme23 .section-title { color: var(--t23-white); }
.contact-social-section-theme23 .section-subtitle { color: rgba(255,255,255,0.35); margin-bottom: 0; }
.contact-social-section-theme23 .social-cards { display: flex; justify-content: center; gap: 16px; flex-wrap: wrap; margin-top: 36px; }
.contact-social-section-theme23 .social-card { width: 84px; height: 84px; background: var(--t23-surface); border: 1px solid rgba(255,255,255,0.08); border-radius: var(--t23-radius-sm); display: flex; justify-content: center; align-items: center; transition: all 0.28s ease; text-decoration: none; }
.contact-social-section-theme23 .social-card:hover { border-color: var(--t23-primary); transform: translateY(-6px) rotate(-2deg); box-shadow: 0 0 24px rgba(232,56,58,0.25); }
.contact-social-section-theme23 .social-card img { width: 40px; height: 40px; object-fit: contain; }
/* =====================================================
   BUTTON — THEME 23
   ===================================================== */
.btn-Know-theme23 { background: var(--t23-primary); color: var(--t23-white); box-shadow: 0 4px 20px rgba(232,56,58,0.35); font-family: var(--t23-font-display); font-size: 1.15rem; font-weight: 400; letter-spacing: 3px; text-transform: uppercase; display: inline-flex; align-items: center; gap: 10px; padding: 0.85rem 2.8rem; border-radius: var(--t23-radius-sm); text-decoration: none; cursor: pointer; border: none; transition: all 0.25s ease; }
.btn-Know-theme23:hover,
.btn-Know-theme23:focus { background: var(--t23-primary-dark); color: var(--t23-white); box-shadow: 0 8px 28px rgba(232,56,58,0.45); transform: translateY(-3px); }
/* =====================================================
   SLIDER
   ===================================================== */
.banner .slide-bg::before { background: linear-gradient(to bottom, rgba(10,10,10,0.78) 0%, rgba(10,10,10,0.60) 100%); }
.slide-content h2 { font-family: var(--t23-font-display); font-size: clamp(2.5rem, 6vw, 4rem); font-weight: 400; color: var(--t23-white); letter-spacing: 4px; text-transform: uppercase; }
.slide-content p { font-size: clamp(0.9rem, 2vw, 1.1rem); color: rgba(255,255,255,0.65); margin-bottom: 28px; letter-spacing: 1px; }
/* =====================================================
   RESPONSIVE
   ===================================================== */
@media (max-width: 992px) {
 .poster-content { flex-direction: column; text-align: center; gap: 40px; }
.poster-divider { margin: 0 auto 28px; }
.poster-contact { justify-content: center; }
.poster-location { text-align: center; }
.specialty-list { width: 100%; }
.specialty-row { justify-content: center; }
.services-grid { grid-template-columns: repeat(3, 1fr); }
.contact-cards-theme23 { padding: 44px 20px; }
 }
@media (max-width: 576px) {
 .theme23-hero { height: 100svh; min-height: 480px; }
.hero-content h1 { font-size: 4rem; letter-spacing: 3px; }
.contact-cards-theme23 { padding: 36px 14px; gap: 10px; }
.theme23-poster { padding: 52px 20px; }
.theme23-poster::before { display: none; }
.services-grid { grid-template-columns: repeat(3, 1fr); gap: 3px; }
.theme23-map .map-wrapper iframe { height: 260px; }
.section-title { font-size: 2rem; }
 }
@media (max-width: 380px) {
 .services-grid { grid-template-columns: repeat(2, 1fr); }
 }
