/* ============================================
   WEB-SPECIFIC STYLES
   Public website styles (excluding admin)
   ============================================ */

/* ============================================
   RESPONSIVE TABLES (Public Pages)
   ============================================ */
.table-responsive-public {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin-bottom: 1rem;
  width: 100%;
}

.table-responsive-public table {
  min-width: 100%;
  width: 100%;
}

/* Mobile - Table optimizations */
@media (max-width: 768px) {
  .table-responsive-public {
    touch-action: pan-x;
    overscroll-behavior-x: contain;
  }

  .table-responsive-public table {
    font-size: 0.9rem;
  }

  .table-responsive-public th,
  .table-responsive-public td {
    padding: 0.5rem 0.75rem;
    white-space: nowrap;
  }
}

/* ============================================
   3. LAYOUT
   ============================================ */

/* --- Navbar --- */
/* Use more specific selectors to avoid !important */
body>header {
  margin: 0;
  padding: 0;
  position: relative;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
}

/* Navbar - fixed positioning requires specificity */
/* Best Practice Heights:
   - Desktop: 64px (Material Design standard, Google's recommendation) - FIXED
   - Mobile: 56px (optimal for touch targets, minimum 48px) - FIXED
   - Using fixed height instead of min-height to ensure exact 64px/56px
*/
body>header>nav.navbar-transparent,
.navbar-transparent {
  background: rgba(0, 0, 0, 0.4);
  backdrop-filter: var(--blur-md);
  -webkit-backdrop-filter: var(--blur-md);
  border-bottom: 1px solid var(--border-primary);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1050;
  width: 100%;
  max-width: 100%;
  margin: 0;
  padding: 0 !important;
  /* Remove padding to maintain exact height */
  height: 64px !important;
  /* Fixed height - Material Design standard for desktop */
  min-height: 64px !important;
  /* Fallback */
  display: flex;
  align-items: center;
}

/* Ensure no space above navbar - Use reset in base.css */
/* Removed redundant resets - handled in base.css */

/* Footer positioning */
body>footer {
  margin-top: auto;
  width: 100%;
  padding: 0.5rem 0;
}

footer p {
  margin: 0;
  font-size: 0.85rem;
  opacity: 0.9;
}

/* Body padding handled in base.css */

/* Main content area - ensures content starts below navbar and footer stays at bottom */
body:not(.admin-body)>main {
  padding-top: 0;
  margin-top: 0;
  flex: 1;
  display: flex;
  flex-direction: column;
}

/* Header resets - use specific selectors */
body>header {
  margin: 0;
  padding: 0;
  position: relative;
  top: 0;
}

/* Fix for Bootstrap container inside navbar - more specific selector */
.navbar-transparent>.container,
.navbar-transparent .container {
  margin: 0;
  padding: 0 1rem !important;
  /* Only horizontal padding */
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: 100%;
  width: 100%;
  height: 100%;
  /* Match navbar height */
}

/* Navbar collapse - align to right */
.navbar-transparent .navbar-collapse {
  flex-grow: 0;
  justify-content: flex-end;
}

.navbar-transparent .navbar-nav {
  margin-left: auto !important;
}

body:has(.home-background-overlay) .navbar-transparent {
  z-index: 1051 !important;
}

/* Typography Best Practices:
   - Desktop nav links: 16-18px (1rem-1.125rem) - optimal readability
   - Mobile nav links: 18-20px (1.125rem-1.25rem) - better for touch
   - Brand text: 17-20px (1.0625rem-1.25rem) - slightly larger for prominence
   - Line height: 1.4-1.7x for readability
*/
.navbar-transparent .navbar-brand {
  color: var(--color-text-white) !important;
  text-shadow: 0 2px 6px rgba(0, 0, 0, 0.6);
  font-weight: 500;
  font-size: 1.125rem !important;
  /* 18px - optimal for brand prominence */
  letter-spacing: -0.01em;
  /* Slight negative for modern look */
  line-height: 1.5;
}

/* Navbar Logo */
/* Logo size: 40-48px is optimal for 64px navbar
   Maintains good visual balance without overwhelming */
.navbar-logo {
  height: 40px !important;
  /* Optimal for 64px navbar */
  width: 40px !important;
  border-radius: 50%;
  object-fit: cover;
  transition: transform var(--transition-normal);
}

.navbar-logo:hover {
  transform: scale(1.05);
}

.navbar-brand .brand-text {
  font-size: 1.0625rem;
  /* 17px - slightly smaller than brand */
  font-weight: 500;
  letter-spacing: 0.01em;
  line-height: 1.5;
}

.navbar-transparent .nav-link {
  color: var(--color-text-white) !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.6);
  transition: var(--transition-normal);
  font-weight: 400;
  font-size: 1rem !important;
  /* 16px - best practice for desktop nav links */
  line-height: 1.5;
  letter-spacing: 0.01em;
  padding: 0.4rem 0.75rem !important;
}

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

.navbar-transparent .nav-link.active {
  color: var(--color-primary) !important;
  background: rgba(162, 87, 63, 0.2);
  border-radius: 4px;
}

.navbar-transparent .dropdown-menu {
  background: rgba(15, 25, 45, 0.95) !important;
  backdrop-filter: var(--blur-lg);
  border: 1px solid var(--border-primary);
  box-shadow: var(--shadow-md);
}

.navbar-transparent .dropdown-item {
  color: var(--color-text-white) !important;
  font-weight: 500;
}

.navbar-transparent .dropdown-item:hover {
  background: rgba(162, 87, 63, 0.3) !important;
}

.navbar-transparent .navbar-toggler {
  border-color: rgba(162, 87, 63, 0.5);
}

.navbar-transparent .navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(255, 255, 255, 1)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

/* --- Background Wrapper --- */
.home-background-wrapper {
  position: relative;
  min-height: 100vh;
  background-image: url('/images/home-background.png');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-attachment: fixed;
}

/* Homepage background wrapper styles moved to home.css */

.home-background-overlay {
  position: fixed;
  inset: 0;
  background: rgba(255, 255, 255, 0.05);
  z-index: -1;
  pointer-events: none;
}

/* --- Section Layout (General Pages - No Scroll Snap) --- */
/* For non-homepage pages, sections should start below navbar */
/* --- Section Layout (General Pages - No Scroll Snap) --- */
/* For non-homepage pages, sections should start below navbar */
body:not(:has(.home-background-wrapper.has-hero)) .home-section {
  position: relative;
  min-height: calc(100vh - var(--navbar-height));
  width: 100%;
  z-index: 10;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 0;
  padding-top: 80px;
  margin-top: 0;
  box-sizing: border-box;
  overflow-x: hidden;
}

body:not(:has(.home-background-wrapper.has-hero)) .home-section .container,
body:not(:has(.home-background-wrapper.has-hero)) .home-section .container-fluid {
  max-width: 100%;
  padding: var(--section-padding) 1rem;
  padding-top: var(--section-padding);
  position: relative;
  z-index: 1;
  background: transparent;
}

.home-section .row,
.home-section .col-md-8 {
  background: transparent !important;
}

/* Section backgrounds - transparent by default */
.section-full,
.about-section-full,
.categories-section-full,
.products-section-full,
.contact-section-full {
  background: transparent;
}

/* Container transparency for public pages */
.container:not([class*="admin"]) {
  background: transparent;
}

.container:not([class*="admin"]) .row,
.container:not([class*="admin"]) .col-md-4,
.container:not([class*="admin"]) .col-md-6,
.container:not([class*="admin"]) .col-md-8,
.container:not([class*="admin"]) .col-md-12,
.container:not([class*="admin"]) .card-body,
.container:not([class*="admin"]) .card-footer,
.container:not([class*="admin"]) .card-header {
  background: transparent;
}

/* ============================================
   4. COMPONENTS
   ============================================ */

/* --- Buttons (Bootstrap Override) --- */
.btn-primary {
  --bs-btn-color: var(--color-text-light);
  --bs-btn-bg: var(--color-primary);
  --bs-btn-border-color: var(--color-primary);
  --bs-btn-hover-color: var(--color-text-light);
  --bs-btn-hover-bg: var(--color-primary-hover);
  --bs-btn-hover-border-color: var(--color-primary-hover);
  --bs-btn-focus-shadow-rgb: var(--color-primary-rgb);
  --bs-btn-active-color: var(--color-text-light);
  --bs-btn-active-bg: var(--color-primary-active);
  --bs-btn-active-border-color: var(--color-primary-active);
  --bs-btn-disabled-color: var(--color-text-light);
  --bs-btn-disabled-bg: var(--color-primary);
  --bs-btn-disabled-border-color: var(--color-primary);
}

.btn-secondary {
  --bs-btn-color: var(--color-text-light);
  --bs-btn-bg: var(--color-secondary);
  --bs-btn-border-color: var(--color-secondary);
  --bs-btn-hover-color: var(--color-text-light);
  --bs-btn-hover-bg: var(--color-secondary-hover);
  --bs-btn-hover-border-color: var(--color-secondary-hover);
  --bs-btn-focus-shadow-rgb: var(--color-secondary-rgb);
  --bs-btn-active-color: var(--color-text-light);
  --bs-btn-active-bg: var(--color-secondary-hover);
  --bs-btn-active-border-color: var(--color-secondary-hover);
  --bs-btn-disabled-color: var(--color-text-light);
  --bs-btn-disabled-bg: var(--color-secondary);
  --bs-btn-disabled-border-color: var(--color-secondary);
}

.btn-outline-primary {
  --bs-btn-color: var(--color-primary);
  --bs-btn-border-color: var(--color-primary);
  --bs-btn-hover-color: var(--color-text-light);
  --bs-btn-hover-bg: var(--color-primary);
  --bs-btn-hover-border-color: var(--color-primary);
  --bs-btn-focus-shadow-rgb: var(--color-primary-rgb);
  --bs-btn-active-color: var(--color-text-light);
  --bs-btn-active-bg: var(--color-primary);
  --bs-btn-active-border-color: var(--color-primary);
  --bs-btn-disabled-color: var(--color-primary);
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: var(--color-primary);
}

.btn-outline-secondary {
  --bs-btn-color: var(--color-secondary);
  --bs-btn-border-color: var(--color-secondary);
  --bs-btn-hover-color: var(--color-text-light);
  --bs-btn-hover-bg: var(--color-secondary);
  --bs-btn-hover-border-color: var(--color-secondary);
  --bs-btn-focus-shadow-rgb: var(--color-secondary-rgb);
  --bs-btn-active-color: var(--color-text-light);
  --bs-btn-active-bg: var(--color-secondary);
  --bs-btn-active-border-color: var(--color-secondary);
  --bs-btn-disabled-color: var(--color-secondary);
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: var(--color-secondary);
}

.btn:focus,
.btn:active:focus,
.btn-link.nav-link:focus {
  box-shadow: 0 0 0 0.1rem var(--color-text-light), 0 0 0 0.25rem rgba(var(--color-primary-rgb), 0.5);
}

/* Glass cards */
.glass-card,
.section-card,
.contact-card {
  background: var(--bg-dark);
  backdrop-filter: var(--blur-md);
  -webkit-backdrop-filter: var(--blur-md);
  border-radius: var(--card-radius-xl);
  border: 1px solid var(--border-light);
  box-shadow: var(--shadow-lg);
  transition: transform var(--transition-normal), box-shadow var(--transition-normal);
}

.glass-card:hover,
.section-card:hover,
.contact-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-xl);
}

/* Disable hover animation for full-width section cards */
.section-card.section-card-full:hover,
.contact-card.section-card-full:hover {
  transform: none;
  box-shadow: var(--shadow-lg);
}

.section-card,
.contact-card {
  padding: 3rem 2rem;
  max-width: 100%;
  margin: 0 auto;
}

/* Section card full width variant */
.section-card.section-card-full,
.contact-card.section-card-full {
  padding: var(--space-xl) var(--space-lg);
  border-radius: 0;
  max-width: 100%;
  width: 100%;
}

/* Full width contact-card in homepage sections */
.home-background-wrapper.has-hero .contact-section-full {
  width: 100%;
  max-width: 100%;
  padding: 0;
  margin: 0;
}

.home-background-wrapper.has-hero .contact-section-full .container-fluid {
  width: 100%;
  max-width: 100%;
  margin: 0;
  padding: 0;
}

.home-background-wrapper.has-hero .contact-section-full .row {
  width: 100%;
  max-width: 100%;
  margin: 0;
  padding: 0;
}

.home-background-wrapper.has-hero .contact-section-full .col-12 {
  width: 100%;
  max-width: 100%;
  margin: 0;
  padding: 0;
}

/* Full-width contact card centering on homepage - handled by .section-card-full */
.home-background-wrapper.has-hero .contact-section-full .contact-card {
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* Center content inside full-width contact-card */
.home-background-wrapper.has-hero .contact-section-full .contact-card>* {
  width: 100%;
  max-width: 100%;
}

.home-background-wrapper.has-hero .contact-section-full .contact-card .contact-info-section {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}

.glass-card .card-body,
.section-card .card-body,
.contact-card .card-body {
  background: rgba(20, 28, 40, 0.45) !important;
  backdrop-filter: var(--blur-md);
  -webkit-backdrop-filter: var(--blur-md);
}

/* Glass box for text elements */
.glass-box {
  position: relative;
  display: inline-block;
  padding: 2rem 3rem;
  border-radius: var(--card-radius-lg);
  background: var(--bg-overlay);
  backdrop-filter: var(--blur-lg);
  -webkit-backdrop-filter: var(--blur-lg);
  box-shadow: var(--shadow-lg);
  z-index: 1;
  max-width: 90%;
  box-sizing: border-box;
}

/* Category cards */
.category-card {
  width: 320px;
  height: auto;
  min-height: 500px;
  display: flex;
  flex-direction: column;
  background: var(--bg-dark-strong);
  border: 1px solid var(--border-primary);
  border-radius: var(--card-radius);
  overflow: hidden;
  backdrop-filter: var(--blur-md);
  -webkit-backdrop-filter: var(--blur-md);
  transition: transform var(--transition-normal), box-shadow var(--transition-normal);
  box-shadow: var(--shadow-md);
}

.category-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.3);
  border-color: rgba(162, 87, 63, 0.5);
}

.category-card-image {
  width: 100%;
  height: 180px;
  object-fit: cover;
  flex-shrink: 0;
  aspect-ratio: 16 / 9;
}

.category-card-image-placeholder {
  width: 100%;
  height: 180px;
  background: linear-gradient(135deg, rgba(162, 87, 63, 0.3) 0%, rgba(44, 62, 80, 0.5) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.category-card-image-placeholder::before {
  content: "x";
  font-size: 3rem;
  opacity: 0.5;
}

.category-card .card-body {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  padding: var(--card-padding);
  background: var(--bg-dark);
  backdrop-filter: var(--blur-md);
  -webkit-backdrop-filter: var(--blur-md);
  overflow: hidden;
  border-top: 2px solid var(--border-primary);
}

/* Category card titles - higher specificity to override .contact-card .card-title */
.category-card .card-title,
.category-card h3.card-title,
.contact-card .category-card .card-title {
  font-size: clamp(1.25rem, 2.5vw, 1.5rem); /* 1.25x larger: 1rem*1.25=1.25rem, 1.2rem*1.25=1.5rem */
  font-weight: 600;
  text-align: left;
  color: var(--color-text-white);
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
  line-height: 1.3;
}

/* Category Products List */
.category-products-list {
  max-height: 200px;
  overflow-y: auto;
  padding-right: 0.5rem;
}

.category-products-list ul {
  font-size: var(--font-size-xs);
}

.category-products-list::-webkit-scrollbar {
  width: 4px;
}

.category-products-list::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 2px;
}

.category-products-list::-webkit-scrollbar-thumb {
  background: rgba(162, 87, 63, 0.5);
  border-radius: 2px;
}

.category-products-list::-webkit-scrollbar-thumb:hover {
  background: rgba(162, 87, 63, 0.7);
}

.category-products-list ul li a {
  transition: all var(--transition-fast);
  display: block;
  color: rgba(255, 255, 255, 0.95) !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);
  font-weight: 500;
}

.category-products-list ul li a:hover {
  color: var(--color-primary) !important;
  padding-left: 0.5rem;
}

/* Category list items - replaces inline styles */
.small-list {
  font-size: var(--font-size-xs);
}

.category-list-link {
  color: rgba(255, 255, 255, 0.9);
  text-decoration: none;
  transition: all var(--transition-fast);
  font-size: 0.9375rem; /* 1.25x larger than default (0.75rem * 1.25 = 0.9375rem) */
}

.category-list-link:hover {
  color: var(--color-primary);
}

.category-list-icon {
  font-size: 0.8rem;
}

.category-empty-text {
  font-size: 0.8rem;
  font-style: italic;
  color: rgba(255, 255, 255, 0.5);
}

/* Products categories horizontal scroll - single wrapper + track */
.products-categories-scroll {
  display: flex;
  justify-content: center;
  overflow-x: auto;
  overflow-y: hidden;
  padding: 1rem 0;
  width: 100%;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  -ms-overflow-style: none;
  scroll-behavior: smooth;
}

.products-categories-scroll::-webkit-scrollbar {
  display: none;
}

.products-categories-track {
  display: flex;
  flex-wrap: nowrap;
  gap: 1rem;
  align-items: stretch;
  padding-left: 1rem;
  padding-right: 1rem;
  min-width: min-content;
  margin: 0 auto;
}

.products-categories-track > .category-card {
  flex-shrink: 0;
}

/* Products section: horizontal padding for "View All Products" and content */
.home-background-wrapper.has-hero #products .contact-card,
.home-background-wrapper.has-hero #products .section-card-full {
  padding-left: 1rem;
  padding-right: 1rem;
}

@media (max-width: 768px) {
  .products-categories-scroll {
    justify-content: flex-start;
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
    scrollbar-width: thin;
    -ms-overflow-style: auto;
  }

  .products-categories-scroll::-webkit-scrollbar {
    display: block;
    height: 6px;
  }

  .products-categories-scroll::-webkit-scrollbar-track {
    background: rgba(0, 0, 0, 0.2);
    border-radius: 3px;
  }

  .products-categories-scroll::-webkit-scrollbar-thumb {
    background: var(--color-primary);
    border-radius: 3px;
  }

  .products-categories-track {
    margin: 0;
    gap: 0.75rem;
  }
}

@media (max-width: 576px) {
  .products-categories-scroll {
    padding: 0.5rem 0;
  }

  .products-categories-scroll::-webkit-scrollbar {
    height: 5px;
  }

  .products-categories-track {
    gap: 0.5rem;
  }
}

/* --- Forms --- */
.form-control:focus,
.form-check-input:focus {
  box-shadow: 0 0 0 0.1rem var(--color-text-light), 0 0 0 0.25rem rgba(var(--color-primary-rgb), 0.5);
}

.form-floating>.form-control-plaintext::placeholder,
.form-floating>.form-control::placeholder {
  color: var(--bs-secondary-color);
  text-align: end;
}

.form-floating>.form-control-plaintext:focus::placeholder,
.form-floating>.form-control:focus::placeholder {
  text-align: start;
}

/* Form controls */
.container:not([class*="admin"]) .form-control {
  background: var(--bg-glass);
  border-color: var(--border-primary);
  backdrop-filter: var(--blur-sm);
}

.container:not([class*="admin"]) .form-control:focus {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(162, 87, 63, 0.5);
}

/* Alerts */
.container:not([class*="admin"]) .alert {
  background: rgba(162, 87, 63, 0.1);
  border-color: var(--border-primary);
  backdrop-filter: var(--blur-sm);
  color: var(--color-text-white);
}

.container:not([class*="admin"]) .alert-success {
  background: rgba(40, 167, 69, 0.2);
  border-color: rgba(40, 167, 69, 0.4);
  color: var(--color-text-white);
}

/* Product list */
.product-list {
  list-style: none;
  padding: 2rem;
  margin: 0;
  background: rgba(20, 28, 40, 0.6);
  backdrop-filter: var(--blur-md);
  -webkit-backdrop-filter: var(--blur-md);
  border-radius: var(--card-radius);
  border: 1px solid var(--border-primary);
  box-shadow: var(--shadow-md);
}

.product-list-item {
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--border-divider);
}

.product-list-item:last-child {
  border-bottom: none;
}

.product-list-item::before {
  content: ">";
  color: rgba(255, 255, 255, 0.8);
  margin-right: 1rem;
  font-weight: bold;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5);
}

.product-link {
  color: var(--color-text-white);
  text-decoration: none;
  font-size: 1.1rem;
  display: block;
  transition: color var(--transition-normal), padding-left var(--transition-normal);
  text-shadow: var(--shadow-text);
  font-weight: 500;
}

.product-link:hover {
  color: var(--color-primary);
  padding-left: 0.5rem;
  text-decoration: none;
}

/* ============================================
   5. PAGE SECTIONS
   ============================================ */

/* Hero Section styles moved to home.css (homepage only) */

/* Section titles use shared/sections.css - only override specific cases */
.about-section-full h2,
.categories-section-full h3,
.products-section-full h2,
.contact-section-full h2 {
  font-size: var(--font-size-5xl);
}

.section-title-lg,
.contact-section-full h3 {
  font-size: var(--font-size-3xl);
}

.section-title-md,
.contact-section-full h4 {
  font-size: var(--font-size-2xl);
}

/* Section text - extends shared styles */
.section-text,
.about-section-full p,
.about-section-full .lead {
  font-size: var(--font-size-xl);
  color: rgba(255, 255, 255, 0.75);
  line-height: 1.8;
}

/* About section glass box */
.about-section-full h2,
.about-section-full p,
.about-section-full .lead {
  position: relative;
  display: inline-block;
  padding: 2rem 3rem;
  border-radius: var(--card-radius-lg);
  background: var(--bg-overlay);
  backdrop-filter: var(--blur-lg);
  -webkit-backdrop-filter: var(--blur-lg);
  box-shadow: var(--shadow-lg);
  max-width: 90%;
}

.about-section-full h2 {
  margin: 0 auto 2rem auto;
}

.about-section-full .container {
  position: relative;
  padding: 0;
  background: transparent;
  text-align: center;
}

.about-section-full .row {
  background: transparent;
}

.about-section-full .col-md-8 {
  text-align: center;
}

/* --- Home Section Text Colors --- */
.home-section:not(.hero-section-full) h1,
.home-section:not(.hero-section-full) h2,
.home-section:not(.hero-section-full) h3,
.home-section:not(.hero-section-full) h4,
.home-section:not(.hero-section-full) h5,
.home-section:not(.hero-section-full) h6,
.home-section:not(.hero-section-full) p,
.home-section:not(.hero-section-full) .lead,
.home-section:not(.hero-section-full) label,
.home-section:not(.hero-section-full) .form-label {
  color: var(--color-text-white) !important;
}

/* Categories and Products sections - card styling */
.categories-section-full .card-title,
.categories-section-full .card-body,
.categories-section-full .card-body h5,
.products-section-full .card-title,
.products-section-full .card-body,
.products-section-full .card-body h5 {
  color: var(--color-text-white);
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
}

.categories-section-full .btn-outline-primary {
  border-color: rgba(162, 87, 63, 0.6);
  color: var(--color-text-white);
  background: rgba(162, 87, 63, 0.2);
  font-weight: 500;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5);
  transition: var(--transition-normal);
}

.categories-section-full .btn-outline-primary:hover {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-text-white);
  transform: translateX(3px);
  box-shadow: 0 4px 8px rgba(var(--color-primary-rgb), 0.3);
}

/* --- Contact Section --- */
.contact-section-full .form-control {
  background: var(--bg-glass) !important;
  border-color: var(--border-primary);
  backdrop-filter: var(--blur-sm);
  color: var(--color-text-white);
}

.contact-section-full .form-control:focus {
  background: rgba(255, 255, 255, 0.08) !important;
  border-color: rgba(162, 87, 63, 0.5);
  color: var(--color-text-white);
}

.contact-section-full .form-control::placeholder {
  color: var(--color-text-muted);
}

.contact-section-full dt,
.contact-section-full dd {
  color: var(--color-text-white) !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5);
}

/* Contact Form Validation */
.contact-section-full .form-control.is-invalid {
  border-color: #dc3545;
  background-image: none;
}

.contact-section-full .form-control.is-valid {
  border-color: #198754;
  background-image: none;
}

.contact-section-full .invalid-feedback {
  display: none;
  color: #ff6b6b;
  font-size: 0.85rem;
  margin-top: 0.25rem;
}

.contact-section-full .form-control.is-invalid~.invalid-feedback {
  display: block;
}

.contact-section-full .form-message {
  border-radius: var(--card-radius);
  padding: 0.75rem 1rem;
  font-size: 0.9rem;
}

.contact-section-full .form-message.alert-success {
  background: rgba(25, 135, 84, 0.2);
  border: 1px solid rgba(25, 135, 84, 0.5);
  color: #75d9a3;
}

.contact-section-full .form-message.alert-danger {
  background: rgba(220, 53, 69, 0.2);
  border: 1px solid rgba(220, 53, 69, 0.5);
  color: #ff6b6b;
}

/* Contact card titles */
.section-card .card-title,
.contact-card .card-title {
  font-size: 2.75rem;
  font-weight: 700;
  color: var(--color-text-white);
  margin-bottom: 0.5rem;
  text-shadow: var(--shadow-text);
}

.contact-card .lead {
  font-size: 1.1rem;
  color: rgba(255, 255, 255, 0.85);
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
}

/* Contact info section */
.contact-info-section h3,
.contact-form-section h3 {
  font-size: 1.75rem;
  font-weight: 600;
  color: var(--color-text-white);
  margin-bottom: 1.5rem;
  padding-bottom: 0.75rem;
  border-bottom: 2px solid var(--border-primary);
  text-shadow: var(--shadow-text);
}

.contact-info-section h4 {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--color-text-white);
  margin-bottom: 1rem;
  text-shadow: var(--shadow-text);
}

.contact-info-section dt {
  font-weight: 600;
  color: rgba(255, 255, 255, 0.9);
  font-size: 0.9rem;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
  margin-bottom: 0.25rem;
}

.contact-info-section dd {
  color: var(--color-text-white);
  font-size: 1rem;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
  margin-bottom: 1rem;
  padding-left: 0.5rem;
}

.contact-info-section a {
  color: var(--color-primary);
  text-decoration: none;
  transition: var(--transition-normal);
}

.contact-info-section a:hover {
  color: var(--color-primary-hover);
  text-decoration: underline;
}

.contact-map {
  width: 100%;
  height: 300px;
  border-radius: var(--card-radius);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  border: 1px solid var(--border-primary);
}

/* Small map variant for homepage contact section */
.contact-map-small {
  width: 100%;
  height: 150px;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

/* Contact Form */
.contact-form-section .form-label {
  color: var(--color-text-white) !important;
  font-weight: 500;
  margin-bottom: 0.5rem;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
}

.contact-form-section .form-control {
  border: 1px solid var(--border-primary);
  border-radius: 8px;
  padding: 0.75rem 1rem;
  transition: border-color var(--transition-normal), box-shadow var(--transition-normal);
  background: var(--bg-glass) !important;
  color: var(--color-text-white);
  backdrop-filter: var(--blur-sm);
}

.contact-form-section .form-control:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 0.2rem rgba(var(--color-primary-rgb), 0.15);
  background: rgba(255, 255, 255, 0.08) !important;
  color: var(--color-text-white);
}

.contact-form-section .form-control::placeholder {
  color: var(--color-text-muted);
}

.contact-form-section .btn-primary {
  padding: 0.875rem 2rem;
  font-weight: 600;
  border-radius: 10px;
  transition: var(--transition-normal);
  font-size: 1.05rem;
  letter-spacing: 0.5px;
}

.contact-form-section .btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(var(--color-primary-rgb), 0.4);
}

/* About page title */
.about-page-title {
  font-size: var(--font-size-4xl);
  font-weight: 700;
  color: var(--color-text-white);
  text-shadow: var(--shadow-text);
  margin-bottom: 1rem;
}

.about-section-card {
  background: var(--bg-glass);
  border: 1px solid var(--border-primary);
  border-radius: var(--card-radius-lg);
  backdrop-filter: var(--blur-sm);
  transition: transform var(--transition-normal), box-shadow var(--transition-normal);
}

.about-section-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.2);
}

.about-section-card h2,
.about-section-card h3 {
  color: var(--color-text-white);
  text-shadow: var(--shadow-text);
  font-weight: 600;
}

.about-section-card h2 {
  font-size: var(--font-size-2xl);
}

.about-section-card h3 {
  font-size: 1.75rem;
}

.about-icon {
  font-size: var(--font-size-2xl);
  color: var(--color-primary);
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
}

.about-text {
  color: var(--color-text-white) !important;
  font-size: 1.1rem;
  line-height: 1.8;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
  margin-bottom: 0;
}

/* --- Product Detail Page --- */
.product-detail-image-wrapper {
  transition: transform var(--transition-normal), box-shadow var(--transition-normal);
}

.product-detail-image-wrapper:hover {
  transform: scale(1.02);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.4) !important;
}

/* Breadcrumb */
.home-section .breadcrumb {
  background: transparent;
  padding: 0;
  margin-bottom: 1.5rem;
}

.home-section .breadcrumb-item a {
  transition: opacity var(--transition-fast), color var(--transition-fast);
}

.home-section .breadcrumb-item a:hover {
  opacity: 1;
  color: var(--color-primary);
}

/* --- Generic Cards (Public Pages) --- */
.container:not([class*="admin"]) .card,
.home-section .card {
  background: var(--bg-glass) !important;
  backdrop-filter: var(--blur-sm);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border-primary);
}

/* General headings for public pages */
.container:not([class*="admin"]) h1:not(.hero-section-full h1) {
  font-size: var(--font-size-4xl);
  font-weight: 700;
  color: var(--color-text-white);
}

.container:not([class*="admin"]) h2:not(.hero-section-full h2) {
  font-size: 2.25rem;
  font-weight: 600;
  color: var(--color-text-white);
}

.home-content h2,
.home-content h3,
.home-content p {
  color: var(--color-text-white);
  text-shadow: var(--shadow-text);
}

/* ============================================
   6. UTILITIES
   ============================================ */
.section-card-full {
  border-radius: 0 !important;
}

/* ============================================
   7. RESPONSIVE BREAKPOINTS
   ============================================ */

/* Tablet - 992px */
@media (max-width: 992px) {

  /* Section titles - responsive sizes */
  .about-section-full h2,
  .categories-section-full h3,
  .products-section-full h2,
  .contact-section-full h2 {
    font-size: var(--font-size-4xl);
  }

  .section-title-lg,
  .contact-section-full h3 {
    font-size: 2.25rem;
  }

  .section-title-md,
  .contact-section-full h4 {
    font-size: 1.75rem;
  }

  /* Section text */
  .section-text,
  .about-section-full p,
  .about-section-full .lead {
    font-size: var(--font-size-lg);
  }

  /* Glass box padding */
  .glass-box,
  .about-section-full h2,
  .about-section-full p,
  .about-section-full .lead {
    padding: 1.75rem 2.5rem;
  }

  /* Navbar */
  .navbar-transparent .navbar-brand {
    font-size: 1rem;
  }

  .navbar-transparent .nav-link {
    font-size: 1rem;
  }

  /* Navbar collapse - add background when menu is open (tablet and below) */
  .navbar-transparent .navbar-collapse.show,
  .navbar-transparent .navbar-collapse.collapsing {
    background: rgba(15, 25, 45, 0.98) !important;
    backdrop-filter: var(--blur-lg);
    -webkit-backdrop-filter: var(--blur-lg);
    border-radius: 0 0 8px 8px;
    margin-top: 0.5rem;
    padding: 1rem !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
  }

  .navbar-transparent .navbar-collapse .navbar-nav {
    width: 100%;
  }

  .navbar-transparent .navbar-collapse .nav-item {
    margin-bottom: 0.25rem;
  }

  /* Contact card */
  .contact-card .card-body {
    padding: 2.5rem;
  }
}

/* Mobile - 768px */
@media (max-width: 768px) {

  /* Navbar responsive adjustments */
  :root {
    --navbar-height: 56px;
    /* Mobile - best practice for touch targets */
  }

  body>header>nav.navbar-transparent,
  .navbar-transparent {
    height: 56px !important;
    /* Fixed height for mobile - best practice */
    min-height: 56px !important;
    /* Fallback */
  }

  .navbar-logo {
    height: 32px !important;
    width: 32px !important;
  }

  .navbar-transparent .navbar-brand {
    font-size: 1.0625rem !important;
    /* 17px - slightly smaller for mobile */
    line-height: 1.4;
  }

  .navbar-brand .brand-text {
    font-size: 1rem;
    /* 16px */
    line-height: 1.4;
  }

  .navbar-transparent .nav-link {
    font-size: 1rem !important;
    /* 16px - maintain readability on mobile (best practice: 18-20px, but 16px is acceptable) */
    line-height: 1.4;
    padding: 0.3rem 0.5rem !important;
  }

  /* Mobile navbar collapse - add background when menu is open */
  .navbar-transparent .navbar-collapse.show,
  .navbar-transparent .navbar-collapse.collapsing {
    background: rgba(15, 25, 45, 0.98) !important;
    backdrop-filter: var(--blur-lg);
    -webkit-backdrop-filter: var(--blur-lg);
    border-radius: 0 0 8px 8px;
    margin-top: 0.5rem;
    padding: 1rem !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
    transition: all var(--transition-normal);
  }

  .navbar-transparent .navbar-collapse .navbar-nav {
    width: 100%;
  }

  .navbar-transparent .navbar-collapse .nav-item {
    margin-bottom: 0.25rem;
  }

  /* Mobile Navbar - Touch-friendly improvements */
  .navbar-transparent .navbar-toggler {
    padding: 0.5rem;
    min-width: var(--touch-target-min);
    min-height: var(--touch-target-min);
    border-radius: 4px;
    transition: background-color var(--transition-fast);
  }

  .navbar-transparent .navbar-toggler:active {
    background-color: rgba(255, 255, 255, 0.1);
  }

  /* Mobile Nav Links - Enhanced touch targets */
  .navbar-transparent .navbar-collapse .nav-link {
    padding: 0.75rem 1rem !important;
    /* Increased padding for better touch targets */
    min-height: var(--touch-target-min);
    display: flex;
    align-items: center;
    border-radius: 4px;
    transition: background-color var(--transition-fast), color var(--transition-fast);
  }

  .navbar-transparent .navbar-collapse .nav-link:active {
    background-color: rgba(162, 87, 63, 0.2);
  }

  /* Mobile Dropdown - Touch-friendly */
  .navbar-transparent .dropdown-toggle {
    min-height: var(--touch-target-min);
    padding: 0.75rem 1rem !important;
  }

  .navbar-transparent .dropdown-menu {
    margin-top: 0.5rem;
    border-radius: 8px;
    min-width: 100%;
  }

  .navbar-transparent .dropdown-item {
    padding: 0.75rem 1rem !important;
    min-height: var(--touch-target-min);
    display: flex;
    align-items: center;
    transition: background-color var(--transition-fast);
  }

  .navbar-transparent .dropdown-item:active {
    background-color: rgba(162, 87, 63, 0.4) !important;
  }

  /* Section Titles */
  .section-title,
  .about-section-full h2,
  .categories-section-full h3,
  .products-section-full h2,
  .contact-section-full h2 {
    font-size: var(--font-size-3xl) !important;
  }

  .section-title-lg,
  .contact-section-full h3 {
    font-size: var(--font-size-2xl) !important;
  }

  .section-title-md,
  .contact-section-full h4 {
    font-size: var(--font-size-xl) !important;
  }

  /* Homepage Section Main Titles - handled by typography.css */
  /* Homepage Section Subtitles - handled by typography.css */

  /* Section Text */
  .section-text,
  .about-section-full p,
  .about-section-full .lead {
    font-size: 1.1rem !important;
  }

  /* Glass Box */
  .glass-box,
  .about-section-full h2,
  .about-section-full p,
  .about-section-full .lead {
    padding: 1.5rem 2rem !important;
  }

  /* Section/Contact Card */
  .section-card,
  .contact-card {
    padding: 2rem 1.5rem;
    border-radius: 15px;
  }

  /* Disable hover effects on touch devices */
  @media (hover: none) and (pointer: coarse) {

    .glass-card:hover,
    .section-card:hover,
    .contact-card:hover,
    .category-card:hover {
      transform: none;
      box-shadow: var(--shadow-lg);
    }
  }

  /* Section card full width variant - mobile */
  .section-card.section-card-full,
  .contact-card.section-card-full {
    padding: var(--space-lg) var(--space-sm);
    border-radius: 0;
  }

  /* Category Card */
  .category-card {
    width: 280px !important;
    height: 450px !important;
  }

  .category-card-image,
  .category-card-image-placeholder {
    height: 150px;
  }

  .category-card .card-title,
  .category-card h3.card-title,
  .contact-card .category-card .card-title {
    font-size: 1.375rem; /* 1.25x larger: 1.1rem * 1.25 = 1.375rem */
    text-align: left;
  }

  .category-products-list {
    max-height: 150px;
  }

  .category-products-list ul {
    font-size: 0.875rem; /* 1.25x larger: 0.7rem * 1.25 = 0.875rem */
  }
  
  /* Mobile: Category list links - 1.25x larger */
  .category-list-link {
    font-size: 0.875rem; /* 1.25x larger for mobile */
  }

  /* Navbar */
  .navbar-transparent .navbar-brand {
    font-size: 0.95rem !important;
  }

  .navbar-transparent .nav-link {
    font-size: 0.95rem !important;
  }

  /* Contact */
  .contact-card .card-body {
    padding: 2rem !important;
  }

  .contact-card .card-title {
    font-size: 2.25rem;
  }

  .contact-card .lead {
    font-size: 1rem;
  }

  .contact-info-section h3,
  .contact-form-section h3 {
    font-size: 1.5rem;
  }

  .contact-info-section dt,
  .contact-info-section dd {
    font-size: 0.9rem;
  }

  .contact-form-section .btn-primary {
    padding: 0.75rem 1.5rem;
    font-size: 1rem;
  }

  /* Form Inputs - Mobile Touch Targets */
  .form-control,
  .form-select,
  input[type="text"],
  input[type="email"],
  input[type="tel"],
  input[type="number"],
  textarea,
  select {
    min-height: var(--touch-target-min);
    font-size: 1rem;
    /* Prevents zoom on iOS when focusing inputs */
    padding: 0.75rem 1rem;
    line-height: 1.5;
  }

  .form-control:focus,
  .form-select:focus {
    font-size: 1rem;
    /* Prevents zoom on iOS */
  }

  .form-label {
    font-size: 1rem;
    margin-bottom: 0.5rem;
    font-weight: 500;
  }

  /* Buttons - Touch Target Optimization */
  .btn,
  button:not(.navbar-toggler),
  input[type="button"],
  input[type="submit"],
  input[type="reset"],
  .btn-primary,
  .btn-secondary,
  .btn-outline-primary,
  .btn-outline-secondary {
    min-height: var(--touch-target-min);
    padding: 0.75rem 1.5rem;
    font-size: 1rem;
    line-height: 1.5;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all var(--transition-fast);
  }

  .btn-sm {
    min-height: var(--touch-target-min);
    padding: 0.6rem 1.25rem;
    font-size: 0.95rem;
  }

  /* Icon buttons - ensure minimum touch target */
  .btn i,
  button i {
    font-size: 1.1rem;
  }

  /* About */
  .about-page-title {
    font-size: 2.25rem;
  }

  .about-section-card h2 {
    font-size: 1.75rem;
  }

  .about-section-card h3 {
    font-size: 1.5rem;
  }

  .about-icon {
    font-size: 1.5rem;
  }

  .about-text {
    font-size: 1rem;
  }

  .about-section-card .card-body {
    padding: 2rem !important;
  }

  /* Footer - Mobile Optimization */
  footer {
    padding: 0.75rem 0 !important;
  }

  footer p {
    font-size: 0.8rem !important;
    line-height: 1.4;
  }

  /* General Headings */
  .container:not([class*="admin"]) h1 {
    font-size: 2.25rem;
  }

  .container:not([class*="admin"]) h2 {
    font-size: 1.75rem;
  }
}

/* Small Mobile - 576px */
@media (max-width: 576px) {

  /* Small Mobile Navbar - Extra compact */
  .navbar-transparent .navbar-brand {
    font-size: 0.95rem !important;
  }

  .navbar-transparent .navbar-toggler {
    padding: 0.4rem;
  }

  .navbar-transparent .navbar-collapse .nav-link {
    padding: 0.6rem 0.75rem !important;
    font-size: 0.95rem !important;
  }

  /* Section titles */
  .about-section-full h2,
  .categories-section-full h3,
  .products-section-full h2,
  .contact-section-full h2 {
    font-size: var(--font-size-2xl);
  }

  .section-title-lg,
  .contact-section-full h3 {
    font-size: 1.75rem;
  }

  .section-title-md,
  .contact-section-full h4 {
    font-size: var(--font-size-lg);
  }

  /* Section text */
  .section-text,
  .about-section-full p,
  .about-section-full .lead {
    font-size: 1rem;
  }

  /* Section card full width variant - small mobile */
  .section-card.section-card-full,
  .contact-card.section-card-full {
    padding: var(--space-md) var(--space-xs);
  }

  /* Small Mobile Cards - Optimized padding */
  .glass-card,
  .section-card:not(.section-card-full),
  .contact-card:not(.section-card-full) {
    padding: 1.5rem 1rem;
  }

  /* Glass box */
  .glass-box,
  .about-section-full h2,
  .about-section-full p,
  .about-section-full .lead {
    padding: 1.25rem 1.5rem;
  }

  /* Category card */
  .category-card {
    width: 260px;
    height: 420px;
  }

  .category-card-image,
  .category-card-image-placeholder {
    height: 130px;
  }

  /* Small Mobile Footer */
  footer {
    padding: 0.5rem 0 !important;
  }

  footer p {
    font-size: 0.75rem !important;
  }

  /* Small Mobile Buttons - Extra touch-friendly */
  .btn,
  button:not(.navbar-toggler),
  .btn-primary,
  .btn-secondary {
    min-height: var(--touch-target-comfortable);
    padding: 0.7rem 1.25rem;
    font-size: 0.95rem;
  }

  .btn-sm {
    min-height: var(--touch-target-min);
    padding: 0.55rem 1rem;
  }
}

/* ============================================
   8. ACCESSIBILITY & PERFORMANCE
   ============================================ */

/* --- Focus Visible (Keyboard Navigation) --- */
:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.btn:focus-visible,
.nav-link:focus-visible,
.form-control:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
  box-shadow: 0 0 0 4px rgba(var(--color-primary-rgb), 0.25);
}

/* Hide focus for mouse users */
:focus:not(:focus-visible) {
  outline: none;
}

/* --- Reduced Motion (Accessibility) --- */
@media (prefers-reduced-motion: reduce) {

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }

  html {
    scroll-behavior: auto;
  }

  .category-card:hover,
  .glass-card:hover,
  .section-card:hover,
  .contact-card:hover,
  .about-section-card:hover,
  .product-detail-image-wrapper:hover {
    transform: none;
  }
}

/* --- Selection Styles --- */
::selection {
  background: var(--color-primary);
  color: var(--color-text-white);
}

::-moz-selection {
  background: var(--color-primary);
  color: var(--color-text-white);
}

/* --- Performance Optimizations --- */
.category-card,
.glass-card,
.section-card,
.contact-card,
.navbar-transparent {
  will-change: transform;
}

.home-section {
  contain: layout style;
}

.category-card-image,
.navbar-logo {
  contain: layout;
}

/* Mobile Performance Optimizations */
@media (max-width: 768px) {

  /* Reduce will-change on mobile for better performance */
  .category-card,
  .glass-card,
  .section-card,
  .contact-card {
    will-change: auto;
  }

  /* Optimize animations on mobile */
  @media (prefers-reduced-motion: no-preference) {

    .category-card:hover,
    .glass-card:hover,
    .section-card:hover,
    .contact-card:hover {
      transition: transform 0.2s ease, box-shadow 0.2s ease;
    }
  }

  /* Contain layout for better mobile performance */
  .products-categories-scroll {
    contain: layout style;
  }

  .products-grid-container {
    contain: layout;
  }
}

/* --- Skip Link (Accessibility) --- */
.skip-link {
  position: absolute;
  top: -40px;
  left: 0;
  background: var(--color-primary);
  color: var(--color-text-white);
  padding: 8px 16px;
  z-index: 9999;
  text-decoration: none;
  font-weight: 600;
  border-radius: 0 0 var(--card-radius) 0;
  transition: top var(--transition-fast);
}

.skip-link:focus {
  top: 0;
}

/* ============================================
   9. PRINT STYLES
   ============================================ */
@media print {

  /* Hide unnecessary elements */
  .navbar-transparent,
  .home-background-overlay,
  .btn,
  .products-categories-scroll,
  footer,
  .skip-link {
    display: none !important;
  }

  /* Reset backgrounds */
  body,
  .home-background-wrapper,
  .home-section,
  .glass-card,
  .section-card,
  .contact-card,
  .category-card {
    background: white !important;
    color: black !important;
  }

  /* Reset text colors */
  h1,
  h2,
  h3,
  h4,
  h5,
  h6,
  p,
  span,
  a,
  li,
  dt,
  dd {
    color: black !important;
    text-shadow: none !important;
  }

  /* Links */
  a[href]::after {
    content: " (" attr(href) ")";
    font-size: 0.8em;
    color: #666;
  }

  /* Page breaks */
  .home-section {
    page-break-inside: avoid;
    height: auto !important;
    min-height: auto !important;
  }

  /* Remove shadows and effects */
  * {
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }
}