/* ============================================================
   LUMINA DENTAL STUDIO — PREMIUM DESIGN SYSTEM (WP ENQUEUED)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bodoni+Moda:ital,opsz,wght@0,6..96,400;0,6..96,500;0,6..96,600;0,6..96,700;1,6..96,400&family=Jost:wght@300;400;500;600;700&display=swap');

:root {
  --primary: #0F1D2F;          /* Deep Calming Navy */
  --primary-rgb: 15, 29, 47;
  --accent: #C5A880;           /* Muted Gold Accent */
  --accent-hover: #B4966C;
  --bg-pearl: #FAF9F6;         /* Pearl Off-White Background */
  --bg-card: #FFFFFF;
  --text-main: #1C2B3A;        /* Dark Slate Body Text */
  --text-muted: #64748B;       /* Secondary Muted Text */
  --font-serif: 'Bodoni Moda', Georgia, serif;
  --font-sans: 'Jost', 'Helvetica Neue', Arial, sans-serif;
  --transition-fluid: all 0.4s cubic-bezier(0.25, 1, 0.5, 1);
  --transition-normal: all 0.3s ease-in-out;
}

/* Base Styles */
html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
}

body.lumina-template {
  font-family: var(--font-sans);
  background-color: var(--bg-pearl);
  color: var(--text-main);
  line-height: 1.6;
  overflow-x: hidden;
}

.lumina-template h1, 
.lumina-template h2, 
.lumina-template h3, 
.lumina-template h4 {
  font-family: var(--font-serif);
  font-weight: 500;
  color: var(--primary);
  line-height: 1.15;
}

/* Liquid Glass Cards */
.glass-card {
  background: rgba(255, 255, 255, 0.7);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255, 255, 255, 0.6);
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.02);
  transition: var(--transition-fluid);
}

.glass-card:hover {
  transform: translateY(-6px);
  background: rgba(255, 255, 255, 0.85);
  border-color: rgba(197, 168, 128, 0.4); /* Muted Gold border fade-in */
  box-shadow: 0 20px 40px rgba(15, 29, 47, 0.05);
}

/* Interactive Navigation Underline */
.nav-link {
  position: relative;
  font-family: var(--font-sans);
  font-weight: 400;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-size: 0.8rem;
  color: var(--text-main);
  transition: var(--transition-normal);
}

.nav-link::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 0;
  height: 1px;
  background-color: var(--accent);
  transition: var(--transition-fluid);
}

.nav-link:hover {
  color: var(--accent);
}

.nav-link:hover::after {
  width: 100%;
}

/* Scrolled Sticky Header */
header.scrolled {
  background: rgba(250, 249, 246, 0.9);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.02);
  border-bottom: 1px solid rgba(197, 168, 128, 0.15);
}

/* Elegant Buttons */
.btn-premium {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.85rem 2.2rem;
  font-family: var(--font-sans);
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  border-radius: 4px;
  overflow: hidden;
  transition: var(--transition-fluid);
  z-index: 1;
}

.btn-premium-solid {
  background-color: var(--accent);
  color: #FFFFFF;
  border: 1px solid var(--accent);
}

.btn-premium-solid::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: var(--primary);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 0.4s cubic-bezier(0.25, 1, 0.5, 1);
  z-index: -1;
}

.btn-premium-solid:hover {
  color: #FFFFFF;
  border-color: var(--primary);
}

.btn-premium-solid:hover::before {
  transform: scaleX(1);
  transform-origin: left;
}

.btn-premium-outline {
  background-color: transparent;
  color: var(--primary);
  border: 1px solid rgba(15, 29, 47, 0.2);
}

.btn-premium-outline:hover {
  background-color: var(--primary);
  color: #FFFFFF;
  border-color: var(--primary);
}

/* Custom Checkmarks */
.experience-list li {
  position: relative;
  padding-left: 2rem;
}

.experience-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.35rem;
  width: 1.1rem;
  height: 1.1rem;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23C5A880' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
}

/* Custom Map Placeholder styling */
.map-container {
  position: relative;
  overflow: hidden;
  border-radius: 6px;
  filter: grayscale(1) contrast(1.1) invert(0.05);
  transition: var(--transition-fluid);
}

.map-container:hover {
  filter: grayscale(0.2) contrast(1) invert(0);
}

/* Scrollbar customization */
::-webkit-scrollbar {
  width: 8px;
}
::-webkit-scrollbar-track {
  background: var(--bg-pearl);
}
::-webkit-scrollbar-thumb {
  background: #E2E8F0;
  border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
  background: var(--accent);
}

/* WP Pagination styling */
.lumina-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
}
.lumina-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 9999px;
  border: 1px solid rgba(15, 29, 47, 0.1);
  font-family: var(--font-sans);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--primary);
  transition: var(--transition-normal);
}
.lumina-pagination .page-numbers:hover {
  background-color: var(--accent);
  color: #FFFFFF;
  border-color: var(--accent);
}
.lumina-pagination .page-numbers.current {
  background-color: var(--primary);
  color: #FFFFFF;
  border-color: var(--primary);
}
.lumina-pagination .page-numbers.prev,
.lumina-pagination .page-numbers.next {
  width: auto;
  padding: 0 1.25rem;
  border-radius: 9999px;
}

/* Adjust header position when WP Admin Bar is present */
.admin-bar header#main-header {
  top: 32px;
}
@media (max-width: 782px) {
  .admin-bar header#main-header {
    top: 46px;
  }
}

/* WP Custom Menu Style Mapping (for ul / li output) */
#main-nav ul {
  display: flex;
  align-items: center;
  gap: 2rem; /* equivalent to gap-8 */
  list-style: none;
  margin: 0;
  padding: 0;
}

#main-nav li a {
  position: relative;
  font-family: var(--font-sans);
  font-weight: 400;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-size: 0.8rem;
  color: var(--text-main);
  transition: var(--transition-normal);
}

#main-nav li a::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 0;
  height: 1px;
  background-color: var(--accent);
  transition: var(--transition-fluid);
}

#main-nav li a:hover {
  color: var(--accent);
}

#main-nav li a:hover::after {
  width: 100%;
}

/* Active WP Menu Item Highlight */
#main-nav li.current-menu-item a {
  color: var(--accent);
}

#main-nav li.current-menu-item a::after {
  width: 100%;
}

/* Mobile drawer WP Custom Menu Style Mapping */
#mobile-menu-links ul {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

#mobile-menu-links li a {
  font-family: var(--font-serif);
  font-size: 1.5rem;
  color: var(--bg-pearl);
  letter-spacing: 0.05em;
  transition: color var(--transition-normal);
}

#mobile-menu-links li a:hover,
#mobile-menu-links li.current-menu-item a {
  color: var(--accent);
}

/* ============================================================
   LUMINA SINGLE POST TYPOGRAPHY & COMMENTS STYLE MAPPING
   ============================================================ */

.lumina-article-content {
  font-family: var(--font-sans);
  color: var(--text-main);
  line-height: 1.8;
  font-weight: 300;
}

.lumina-article-content p {
  margin-bottom: 1.5rem;
  font-size: 1.05rem;
}

.lumina-article-content h1,
.lumina-article-content h2,
.lumina-article-content h3,
.lumina-article-content h4,
.lumina-article-content h5,
.lumina-article-content h6 {
  font-family: var(--font-serif);
  color: var(--primary);
  font-weight: 500;
  margin-top: 2.5rem;
  margin-bottom: 1rem;
  line-height: 1.25;
}

.lumina-article-content h1 { font-size: 2.25rem; }
.lumina-article-content h2 { font-size: 1.85rem; border-bottom: 1px solid rgba(15, 29, 47, 0.08); padding-bottom: 0.5rem; }
.lumina-article-content h3 { font-size: 1.5rem; }
.lumina-article-content h4 { font-size: 1.25rem; }

.lumina-article-content a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 4px;
  font-weight: 500;
  transition: color var(--transition-normal);
}

.lumina-article-content a:hover {
  color: var(--accent-hover);
}

.lumina-article-content blockquote {
  border-left: 3px solid var(--accent);
  padding-left: 1.5rem;
  margin: 2rem 0;
  font-style: italic;
  font-family: var(--font-serif);
  font-size: 1.2rem;
  color: var(--primary);
  background: rgba(197, 168, 128, 0.04);
  padding-top: 1rem;
  padding-bottom: 1rem;
  padding-right: 1.5rem;
  border-radius: 0 8px 8px 0;
}

.lumina-article-content ul,
.lumina-article-content ol {
  margin-bottom: 1.5rem;
  padding-left: 1.5rem;
}

.lumina-article-content ul {
  list-style-type: disc;
}

.lumina-article-content ol {
  list-style-type: decimal;
}

.lumina-article-content li {
  margin-bottom: 0.5rem;
  padding-left: 0.25rem;
}

.lumina-article-content img {
  border-radius: 12px;
  box-shadow: 0 10px 25px rgba(15, 29, 47, 0.04);
  margin: 2.5rem auto;
  max-width: 100%;
  height: auto;
}

.lumina-article-content figure {
  margin: 2.5rem 0;
  text-align: center;
}

.lumina-article-content figure img {
  margin: 0 auto;
}

.lumina-article-content figcaption {
  font-size: 0.8rem;
  color: var(--text-muted);
  margin-top: 0.75rem;
  font-style: italic;
}

.lumina-article-content pre,
.lumina-article-content code {
  font-family: monospace;
  background-color: rgba(15, 29, 47, 0.04);
  padding: 0.2rem 0.4rem;
  border-radius: 4px;
  font-size: 0.9em;
}

.lumina-article-content pre {
  padding: 1rem;
  overflow-x: auto;
  margin-bottom: 1.5rem;
}

.lumina-article-content pre code {
  padding: 0;
  background-color: transparent;
}

/* Comments section styling rules */
#comments-section .comment-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

#comments-section .comment {
  margin-top: 1.5rem;
  margin-bottom: 1.5rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid rgba(15, 29, 47, 0.05);
}

#comments-section .comment-body {
  display: flex;
  gap: 1.25rem;
}

#comments-section .comment-avatar img {
  border-radius: 9999px;
  width: 44px;
  height: 44px;
}

#comments-section .comment-meta {
  font-size: 0.75rem;
  color: var(--text-muted);
  margin-bottom: 0.5rem;
}

#comments-section .comment-author {
  font-weight: 600;
  color: var(--primary);
  font-size: 0.9rem;
}

#comments-section .comment-content {
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--text-main);
  font-weight: 300;
}

#respond {
  margin-top: 3rem;
  padding: 2.5rem;
  background: rgba(255, 255, 255, 0.55);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.6);
  border-radius: 16px;
}

#respond #reply-title {
  font-family: var(--font-serif);
  font-size: 1.5rem;
  color: var(--primary);
  margin-bottom: 1.5rem;
}

#respond label {
  display: block;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-muted);
  margin-bottom: 0.5rem;
}

#respond input[type="text"],
#respond input[type="email"],
#respond textarea {
  width: 100%;
  padding: 0.75rem 1rem;
  background-color: var(--bg-pearl);
  border: 1px solid rgba(15, 29, 47, 0.1);
  border-radius: 6px;
  font-family: var(--font-sans);
  color: var(--text-main);
  outline: none;
  transition: var(--transition-normal);
}

#respond input[type="text"]:focus,
#respond input[type="email"]:focus,
#respond textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(197, 168, 128, 0.15);
}

#respond input[type="submit"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.85rem 2.2rem;
  font-family: var(--font-sans);
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  border-radius: 4px;
  background-color: var(--accent);
  color: #FFFFFF;
  border: 1px solid var(--accent);
  cursor: pointer;
  transition: var(--transition-fluid);
}

#respond input[type="submit"]:hover {
  background-color: var(--primary);
  border-color: var(--primary);
}

