/**
 * Auvira Theme - Layout
 * 
 * Containers, grids, header, footer, and page layout
 */

/* ==========================================================================
   CONTAINERS
   ========================================================================== */

.container {
  width: 100%;
  max-width: var(--content-width);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--space-4);
  padding-right: var(--space-4);
}

.container-narrow {
  max-width: var(--content-narrow);
}

.container-wide {
  max-width: var(--content-wide);
}

.container-fluid {
  max-width: 100%;
}

@media (min-width: 768px) {
  .container {
    padding-left: var(--space-6);
    padding-right: var(--space-6);
  }
}

@media (min-width: 1024px) {
  .container {
    padding-left: var(--space-8);
    padding-right: var(--space-8);
  }
}

/* ==========================================================================
   GRID
   ========================================================================== */

.grid {
  display: grid;
  gap: var(--space-6);
}

.grid-cols-1 { grid-template-columns: repeat(1, minmax(0, 1fr)); }
.grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

@media (min-width: 640px) {
  .sm\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .sm\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (min-width: 768px) {
  .md\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .md\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .md\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

@media (min-width: 1024px) {
  .lg\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .lg\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

/* ==========================================================================
   FLEXBOX UTILITIES
   ========================================================================== */

.flex { display: flex; }
.flex-col { flex-direction: column; }
.flex-wrap { flex-wrap: wrap; }
.items-center { align-items: center; }
.items-start { align-items: flex-start; }
.items-end { align-items: flex-end; }
.justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }
.justify-end { justify-content: flex-end; }
.gap-2 { gap: var(--space-2); }
.gap-4 { gap: var(--space-4); }
.gap-6 { gap: var(--space-6); }
.gap-8 { gap: var(--space-8); }

/* ==========================================================================
   SITE HEADER
   ========================================================================== */

.site-header {
  position: sticky;
  top: 0;
  z-index: var(--z-sticky);
  background-color: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  display: flex;
  align-items: center;
  min-height: 80px;
}

.site-header > .container {
  display: flex;
  align-items: center;
  width: 100%;
}

.site-header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}

/* Logo */
.site-logo-link {
  display: flex;
  align-items: center;
}

.site-logo {
  height: 65px;
  width: auto;
}

.site-logo-text {
  font-family: var(--font-logo);
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
  color: var(--color-primary);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}

/* Navigation */
.site-nav {
  display: none;
}

@media (min-width: 768px) {
  .site-nav {
    display: flex;
    align-items: center;
    gap: var(--space-8);
  }
}

.site-nav-list {
  display: flex;
  align-items: center;
  gap: var(--space-6);
  margin: 0;
  padding: 0;
}

.site-nav-list li {
  display: flex;
  align-items: center;
}

.site-nav-link {
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--color-text-secondary);
  transition: var(--transition-colors);
}

.site-nav-link:hover,
.site-nav-link.is-active {
  color: var(--color-primary);
}

/* Mobile Menu Toggle */
.mobile-menu-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  color: var(--color-text-primary);
}

@media (min-width: 768px) {
  .mobile-menu-toggle {
    display: none;
  }
}

/* Mobile Menu */
.mobile-menu {
  position: fixed;
  top: var(--header-height);
  left: 0;
  right: 0;
  bottom: 0;
  background-color: var(--color-surface);
  padding: var(--space-6);
  transform: translateX(100%);
  transition: transform var(--transition-slow);
  z-index: var(--z-fixed);
  overflow-y: auto;
}

.mobile-menu.is-open {
  transform: translateX(0);
}

.mobile-menu-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.mobile-menu-link {
  display: block;
  padding: var(--space-3) 0;
  font-size: var(--text-lg);
  font-weight: var(--font-medium);
  color: var(--color-text-primary);
  border-bottom: 1px solid var(--color-border);
}

/* ==========================================================================
   SITE FOOTER
   ========================================================================== */

.site-footer {
  background-color: var(--color-charcoal);
  color: var(--color-text-inverse);
  padding: var(--space-16) 0 var(--space-8);
}

.footer-grid {
  display: grid;
  gap: var(--space-10);
}

@media (min-width: 768px) {
  .footer-grid {
    grid-template-columns: 2fr 1fr 1fr 1fr;
  }
}

.footer-brand {
  max-width: 300px;
}

.footer-logo {
  height: 50px;
  width: auto;
  margin-bottom: var(--space-4);
}

.footer-tagline {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
}

.footer-heading {
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-white);
  margin-bottom: var(--space-4);
}

.footer-links {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.footer-link {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  transition: var(--transition-colors);
}

.footer-link:hover {
  color: var(--color-white);
}

.footer-bottom {
  margin-top: var(--space-12);
  padding-top: var(--space-8);
  border-top: 1px solid var(--color-dark-grey);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

@media (min-width: 768px) {
  .footer-bottom {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
  }
}

.footer-copyright {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

.footer-legal {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
}

.footer-legal-link {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  transition: var(--transition-colors);
}

.footer-legal-link:hover {
  color: var(--color-white);
}

/* ==========================================================================
   MAIN CONTENT
   ========================================================================== */

.site-main {
  min-height: calc(100vh - var(--header-height) - 200px);
}

/* ==========================================================================
   SECTIONS
   ========================================================================== */

.section {
  padding: var(--space-16) 0;
}

.section-sm {
  padding: var(--space-10) 0;
}

.section-lg {
  padding: var(--space-24) 0;
}

.section-header {
  text-align: center;
  max-width: var(--content-narrow);
  margin: 0 auto var(--space-12);
}

.section-title {
  margin-bottom: var(--space-4);
}

.section-subtitle {
  font-size: var(--text-lg);
  color: var(--color-text-secondary);
}

/* Section Backgrounds */
.section-light {
  background-color: var(--color-off-white);
}

.section-dark {
  background-color: var(--color-charcoal);
  color: var(--color-text-inverse);
}

.section-primary {
  background-color: var(--color-primary);
  color: var(--color-text-inverse);
}

.section-gradient {
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--color-primary) 10%, transparent),
    color-mix(in srgb, var(--color-secondary) 10%, transparent)
  );
}

/* ==========================================================================
   HERO SECTION
   ========================================================================== */

.hero {
  position: relative;
  padding: var(--space-20) 0;
  min-height: 60vh;
  display: flex;
  align-items: center;
}

.hero-content {
  max-width: 640px;
}

.hero-title {
  font-size: var(--text-5xl);
  margin-bottom: var(--space-6);
}

.hero-subtitle {
  font-size: var(--text-xl);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-8);
  line-height: var(--leading-relaxed);
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
}

@media (min-width: 768px) {
  .hero {
    padding: var(--space-24) 0;
    min-height: 70vh;
  }
  
  .hero-title {
    font-size: var(--text-6xl);
  }
}

/* Centered Hero */
.hero-centered {
  text-align: center;
}

.hero-centered .hero-content {
  max-width: 800px;
  margin: 0 auto;
}

.hero-centered .hero-actions {
  justify-content: center;
}

/* ==========================================================================
   PAGE TEMPLATES
   ========================================================================== */

/* Content Page */
.page-content {
  padding: var(--space-12) 0;
}

.page-header {
  text-align: center;
  margin-bottom: var(--space-12);
}

.page-title {
  margin-bottom: var(--space-4);
}

.page-description {
  font-size: var(--text-lg);
  color: var(--color-text-secondary);
  max-width: var(--content-narrow);
  margin: 0 auto;
}

/* ==========================================================================
   LEGAL PAGES (Privacy, Terms, etc.)
   ========================================================================== */

.legal-page {
  padding: var(--space-12) 0 var(--space-16);
}

/* Legal Header */
.legal-header {
  text-align: center;
  margin-bottom: var(--space-10);
  padding-bottom: var(--space-8);
  border-bottom: 1px solid var(--color-border);
}

.legal-title {
  font-family: var(--font-heading);
  font-size: var(--text-4xl);
  font-weight: var(--font-bold);
  color: var(--color-text-primary);
  margin-bottom: var(--space-3);
}

.legal-updated {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin: 0;
}

/* Legal Content */
.legal-content {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--color-text-primary);
}

/* Legal page intro box */
.legal-intro {
  background: var(--color-off-white);
  border: 1px solid var(--color-border);
  border-left: 4px solid var(--brand-primary, var(--color-primary));
  border-radius: var(--radius-md);
  padding: var(--space-6);
  margin-bottom: var(--space-10);
}

.legal-intro p {
  margin: 0;
  color: var(--color-text-secondary);
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
}

/* Legal Sections */
.legal-sections {
  margin-bottom: var(--space-12);
}

.legal-section {
  margin-bottom: var(--space-10);
}

.legal-section:last-child {
  margin-bottom: 0;
}

.legal-section h2 {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: var(--font-semibold);
  color: var(--brand-primary, var(--color-primary));
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-border);
}

.legal-section-content {
  color: var(--color-text-secondary);
}

.legal-section-content p {
  margin-bottom: var(--space-4);
}

.legal-section-content p:last-child {
  margin-bottom: 0;
}

.legal-section-content ul,
.legal-section-content ol {
  margin-bottom: var(--space-4);
  padding-left: var(--space-6);
}

.legal-section-content li {
  margin-bottom: var(--space-2);
  line-height: var(--leading-relaxed);
}

.legal-section-content strong {
  color: var(--color-text-primary);
}

.legal-section-content a {
  color: var(--brand-primary, var(--color-secondary));
  text-decoration: underline;
  text-underline-offset: 2px;
}

.legal-section-content a:hover {
  color: var(--brand-secondary, var(--color-primary));
}

/* Legal Footer */
.legal-footer {
  margin-top: var(--space-12);
  padding-top: var(--space-8);
  border-top: 1px solid var(--color-border);
  text-align: center;
}

.legal-company {
  font-weight: var(--font-semibold);
  color: var(--color-text-primary);
  margin-bottom: var(--space-2);
}

.legal-contact {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  margin: 0;
}

.legal-contact a {
  color: var(--brand-primary, var(--color-secondary));
}

/* Legacy support for entry-content */
.legal-page .entry-content {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--color-text-primary);
}

.legal-page .entry-content h2 {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: var(--font-semibold);
  color: var(--brand-primary, var(--color-primary));
  margin-top: var(--space-10);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-border);
}

.legal-page .entry-content h2:first-child {
  margin-top: 0;
}

.legal-page .entry-content h3 {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: var(--font-medium);
  color: var(--color-text-primary);
  margin-top: var(--space-8);
  margin-bottom: var(--space-3);
}

.legal-page .entry-content p {
  margin-bottom: var(--space-4);
}

.legal-page .entry-content ul,
.legal-page .entry-content ol {
  margin-bottom: var(--space-4);
  padding-left: var(--space-6);
}

.legal-page .entry-content li {
  margin-bottom: var(--space-2);
  line-height: var(--leading-relaxed);
}

.legal-page .entry-content strong {
  color: var(--color-text-primary);
}

.legal-page .entry-content a {
  color: var(--brand-primary, var(--color-secondary));
  text-decoration: underline;
  text-underline-offset: 2px;
}

.legal-page .entry-content a:hover {
  color: var(--brand-secondary, var(--color-primary));
}

/* Data table for legal pages */
.legal-table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--space-6) 0;
  font-size: var(--text-sm);
}

.legal-table th,
.legal-table td {
  padding: var(--space-3) var(--space-4);
  text-align: left;
  border-bottom: 1px solid var(--color-border);
}

.legal-table th {
  background: var(--color-off-white);
  font-weight: var(--font-semibold);
  color: var(--color-text-primary);
}

.legal-table tr:last-child td {
  border-bottom: none;
}

/* ==========================================================================
   POLICY PAGES (Returns, Shipping, etc.)
   ========================================================================== */

.policy-page {
  padding: var(--space-12) 0 var(--space-16);
}

/* Policy Header */
.policy-header {
  text-align: center;
  margin-bottom: var(--space-10);
}

.policy-icon {
  font-size: 3rem;
  margin-bottom: var(--space-4);
}

.policy-title {
  font-family: var(--font-heading);
  font-size: var(--text-4xl);
  font-weight: var(--font-bold);
  color: var(--color-text-primary);
  margin-bottom: var(--space-3);
}

.policy-subtitle {
  font-size: var(--text-lg);
  color: var(--color-text-secondary);
  margin: 0;
}

/* Policy Highlight Box */
.policy-highlight {
  background: linear-gradient(135deg, 
    rgba(var(--brand-primary-rgb, 30, 58, 95), 0.05) 0%, 
    rgba(var(--brand-primary-rgb, 30, 58, 95), 0.1) 100%
  );
  border: 1px solid var(--brand-primary, var(--color-primary));
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  margin-bottom: var(--space-10);
  text-align: center;
}

.policy-highlight p {
  margin: 0;
  font-size: var(--text-lg);
  font-weight: var(--font-medium);
  color: var(--brand-primary, var(--color-primary));
}

/* Policy Content */
.policy-content {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--color-text-primary);
}

/* Policy Sections */
.policy-sections {
  margin-bottom: var(--space-12);
}

.policy-section {
  margin-bottom: var(--space-10);
  padding-bottom: var(--space-8);
  border-bottom: 1px solid var(--color-border);
}

.policy-section:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: none;
}

.policy-section h2 {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: var(--font-semibold);
  color: var(--color-text-primary);
  margin-bottom: var(--space-4);
}

.policy-section-content {
  color: var(--color-text-secondary);
}

.policy-section-content p {
  margin-bottom: var(--space-4);
}

.policy-section-content p:last-child {
  margin-bottom: 0;
}

.policy-section-content ul,
.policy-section-content ol {
  margin-bottom: var(--space-4);
  padding-left: var(--space-6);
}

.policy-section-content li {
  margin-bottom: var(--space-2);
  line-height: var(--leading-relaxed);
}

.policy-section-content strong {
  color: var(--color-text-primary);
}

.policy-section-content a {
  color: var(--brand-primary, var(--color-secondary));
  text-decoration: underline;
  text-underline-offset: 2px;
}

.policy-section-content a:hover {
  color: var(--brand-secondary, var(--color-primary));
}

/* Policy CTA */
.policy-cta {
  background: var(--color-off-white);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  text-align: center;
  margin-bottom: var(--space-10);
}

.policy-cta p {
  font-size: var(--text-lg);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-4);
}

.policy-cta .btn {
  margin-top: var(--space-2);
}

/* Policy Footer */
.policy-footer {
  text-align: center;
  padding-top: var(--space-8);
  border-top: 1px solid var(--color-border);
}

.policy-footer p {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  margin: 0;
}

.policy-footer a {
  color: var(--brand-primary, var(--color-secondary));
}

/* ==========================================================================
   FAQ PAGE
   ========================================================================== */

.faq-page {
  padding: var(--space-12) 0 var(--space-16);
}

/* FAQ Header */
.faq-header {
  text-align: center;
  margin-bottom: var(--space-12);
}

.faq-title {
  font-family: var(--font-heading);
  font-size: var(--text-4xl);
  font-weight: var(--font-bold);
  color: var(--color-text-primary);
  margin-bottom: var(--space-3);
}

.faq-subtitle {
  font-size: var(--text-lg);
  color: var(--color-text-secondary);
  margin: 0;
}

/* FAQ Categories */
.faq-category {
  margin-bottom: var(--space-12);
}

.faq-category:last-child {
  margin-bottom: 0;
}

.faq-category-title {
  font-family: var(--font-heading);
  font-size: var(--text-2xl);
  font-weight: var(--font-semibold);
  color: var(--brand-primary, var(--color-primary));
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-border);
}

/* FAQ Accordion */
.faq-accordion {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.faq-item {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: all var(--transition-base);
}

.faq-item:hover {
  border-color: var(--brand-primary, var(--color-primary));
}

.faq-item[open] {
  border-color: var(--brand-primary, var(--color-primary));
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

.faq-question {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) var(--space-6);
  cursor: pointer;
  font-weight: var(--font-medium);
  color: var(--color-text-primary);
  list-style: none;
}

.faq-question::-webkit-details-marker {
  display: none;
}

.faq-question span:first-child {
  flex: 1;
}

.faq-toggle {
  font-size: var(--text-xl);
  font-weight: var(--font-light);
  color: var(--brand-primary, var(--color-primary));
  transition: transform var(--transition-base);
}

.faq-item[open] .faq-toggle {
  transform: rotate(45deg);
}

.faq-answer {
  padding: var(--space-5) var(--space-6) var(--space-5);
  color: var(--color-text-secondary);
  line-height: var(--leading-relaxed);
}

.faq-answer p {
  margin-bottom: var(--space-3);
}

.faq-answer p:last-child {
  margin-bottom: 0;
}

.faq-answer ul,
.faq-answer ol {
  margin-bottom: var(--space-3);
  padding-left: var(--space-6);
}

.faq-answer li {
  margin-bottom: var(--space-2);
}

.faq-answer a {
  color: var(--brand-primary, var(--color-secondary));
  text-decoration: underline;
  text-underline-offset: 2px;
}

.faq-answer a:hover {
  color: var(--brand-secondary, var(--color-primary));
}

/* FAQ Footer / Contact */
.faq-footer {
  margin-top: var(--space-12);
  padding-top: var(--space-10);
  border-top: 1px solid var(--color-border);
}

.faq-contact {
  text-align: center;
  background: var(--color-off-white);
  border-radius: var(--radius-lg);
  padding: var(--space-10);
}

.faq-contact h3 {
  font-family: var(--font-heading);
  font-size: var(--text-2xl);
  font-weight: var(--font-semibold);
  color: var(--color-text-primary);
  margin-bottom: var(--space-2);
}

.faq-contact p {
  color: var(--color-text-secondary);
  margin-bottom: var(--space-6);
}

/* ==========================================================================
   CONTACT PAGE
   ========================================================================== */

.contact-page {
  padding: var(--space-12) 0 var(--space-16);
}

/* Contact Header */
.contact-header {
  text-align: center;
  margin-bottom: var(--space-10);
}

.contact-title {
  font-family: var(--font-heading);
  font-size: var(--text-4xl);
  font-weight: var(--font-bold);
  color: var(--color-text-primary);
  margin-bottom: var(--space-3);
}

.contact-subtitle {
  font-size: var(--text-lg);
  color: var(--color-text-secondary);
  margin: 0;
}

/* Contact Grid */
.contact-grid {
  display: grid;
  gap: var(--space-10);
}

@media (min-width: 768px) {
  .contact-grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-12);
  }
}

/* Contact Info */
.contact-info {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

.contact-info-item {
  display: flex;
  gap: var(--space-4);
}

.contact-info-icon {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--brand-primary, var(--color-primary));
  color: var(--color-white);
  border-radius: var(--radius-md);
  font-size: var(--text-xl);
  flex-shrink: 0;
}

.contact-info-icon svg {
  width: 24px;
  height: 24px;
  stroke: white;
}

.contact-info-content h3 {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  color: var(--color-text-primary);
  margin-bottom: var(--space-1);
}

.contact-info-content p {
  color: var(--color-text-secondary);
  margin: 0;
}

.contact-info-content a {
  color: var(--color-text-secondary);
  text-decoration: none;
}

.contact-info-content a:hover {
  color: var(--brand-primary, var(--color-secondary));
}

/* Contact Form */
.contact-form-wrapper {
  background: var(--color-off-white);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
}

.contact-form-title {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: var(--font-semibold);
  color: var(--color-text-primary);
  margin-bottom: var(--space-6);
}

/* Style Contact Form 7 */
.contact-form-wrapper .wpcf7-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

/* Hide br tags that CF7 adds */
.contact-form-wrapper .wpcf7-form br {
  display: none;
}

.contact-form-wrapper .wpcf7-form p {
  margin: 0;
}

.contact-form-wrapper .wpcf7-form label {
  display: block;
  font-weight: var(--font-medium);
  color: var(--color-text-primary);
  margin-bottom: var(--space-2);
}

.contact-form-wrapper .wpcf7-form input[type="text"],
.contact-form-wrapper .wpcf7-form input[type="email"],
.contact-form-wrapper .wpcf7-form textarea {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-base);
  color: var(--color-text-primary);
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  transition: all var(--transition-base);
}

.contact-form-wrapper .wpcf7-form input[type="text"]:focus,
.contact-form-wrapper .wpcf7-form input[type="email"]:focus,
.contact-form-wrapper .wpcf7-form textarea:focus {
  outline: none;
  border-color: var(--brand-primary, var(--color-primary));
  box-shadow: 0 0 0 3px rgba(var(--brand-primary-rgb, 30, 58, 95), 0.1);
}

.contact-form-wrapper .wpcf7-form textarea {
  height: 150px !important;
  min-height: 150px !important;
  max-height: 300px;
  resize: vertical;
}

.contact-form-wrapper .wpcf7-form input[type="submit"] {
  align-self: flex-start;
  padding: var(--space-3) var(--space-8);
  font-size: var(--text-base);
  font-weight: var(--font-semibold);
  color: var(--color-white);
  background: var(--brand-primary, var(--color-primary));
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition-base);
}

.contact-form-wrapper .wpcf7-form input[type="submit"]:hover {
  background: var(--brand-secondary, var(--color-secondary));
  transform: translateY(-2px);
}

.contact-form-wrapper .wpcf7-response-output {
  margin-top: var(--space-4);
  padding: var(--space-4);
  border-radius: var(--radius-md);
}

/* ==========================================================================
   ORDER TRACKING PAGE
   ========================================================================== */

.tracking-page {
  padding: var(--space-12) 0 var(--space-16);
}

/* Tracking Header */
.tracking-header {
  text-align: center;
  margin-bottom: var(--space-10);
}

.tracking-title {
  font-family: var(--font-heading);
  font-size: var(--text-4xl);
  font-weight: var(--font-bold);
  color: var(--color-text-primary);
  margin-bottom: var(--space-3);
}

.tracking-subtitle {
  font-size: var(--text-lg);
  color: var(--color-text-secondary);
  margin: 0;
}

/* Tracking Content - ParcelPanel container */
.tracking-content {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  min-height: 400px;
}

/* ParcelPanel overrides for brand styling */
.tracking-content .pp-tracking-form {
  max-width: 100%;
}

.tracking-content .pp-tracking-form input[type="text"] {
  border-color: var(--color-border);
  border-radius: var(--radius-md);
}

.tracking-content .pp-tracking-form input[type="text"]:focus {
  border-color: var(--brand-primary, var(--color-primary));
}

.tracking-content .pp-tracking-form button,
.tracking-content .pp-tracking-form input[type="submit"] {
  background: var(--brand-primary, var(--color-primary)) !important;
  border-radius: var(--radius-md);
}

.tracking-help {
  text-align: center;
  margin-top: var(--space-8);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-border);
}

.tracking-help p {
  color: var(--color-text-secondary);
  margin-bottom: var(--space-2);
}

.tracking-help a {
  color: var(--brand-primary, var(--color-secondary));
}

/* ==========================================================================
   WOOCOMMERCE ACCOUNT PAGES
   ========================================================================== */

/* Account Wrapper */
.woocommerce-account-wrapper {
  padding: var(--space-4) 0;
}

/* Brand Header */
.account-brand-header {
  text-align: center;
  padding: var(--space-6);
  margin-bottom: var(--space-8);
  border-radius: var(--radius-lg);
}

/* Account Navigation */
.woocommerce-MyAccount-navigation {
  background: var(--color-off-white);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  margin-bottom: var(--space-8);
}

.woocommerce-MyAccount-navigation ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.woocommerce-MyAccount-navigation li {
  margin: 0;
}

.woocommerce-MyAccount-navigation li a {
  display: block;
  padding: var(--space-3) var(--space-5);
  color: var(--color-text-secondary);
  text-decoration: none;
  border-radius: var(--radius-md);
  transition: all var(--transition-base);
  font-weight: var(--font-medium);
}

.woocommerce-MyAccount-navigation li a:hover {
  background: var(--color-white);
  color: var(--brand-primary, var(--color-primary));
}

.woocommerce-MyAccount-navigation li.is-active a {
  background: var(--brand-primary, var(--color-primary));
  color: var(--color-white);
}

/* Account Content */
.woocommerce-MyAccount-content {
  min-height: 300px;
}

.woocommerce-MyAccount-content h2,
.woocommerce-MyAccount-content h3 {
  font-family: var(--font-heading);
  color: var(--color-text-primary);
  margin-bottom: var(--space-4);
}

.woocommerce-MyAccount-content p {
  color: var(--color-text-secondary);
  line-height: var(--leading-relaxed);
}

.woocommerce-MyAccount-content a {
  color: var(--brand-primary, var(--color-secondary));
}

/* Orders Table */
.woocommerce-orders-table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: var(--space-6);
}

.woocommerce-orders-table th,
.woocommerce-orders-table td {
  padding: var(--space-3) var(--space-4);
  text-align: left;
  border-bottom: 1px solid var(--color-border);
}

.woocommerce-orders-table th {
  background: var(--color-off-white);
  font-weight: var(--font-semibold);
  color: var(--color-text-primary);
}

.woocommerce-orders-table tbody tr:hover {
  background: var(--color-off-white);
}

/* Addresses */
.woocommerce-Addresses {
  display: grid;
  gap: var(--space-6);
}

@media (min-width: 768px) {
  .woocommerce-Addresses {
    grid-template-columns: 1fr 1fr;
  }
}

.woocommerce-Address {
  background: var(--color-off-white);
  border-radius: var(--radius-md);
  padding: var(--space-5);
}

.woocommerce-Address-title {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-3);
}

.woocommerce-Address-title h3 {
  margin: 0;
  font-size: var(--text-lg);
}

.woocommerce-Address-title a {
  font-size: var(--text-sm);
}

/* Form Styling */
.woocommerce-EditAccountForm,
.woocommerce-address-fields {
  max-width: 600px;
}

.woocommerce-form-row {
  margin-bottom: var(--space-4);
}

.woocommerce-form-row label {
  display: block;
  font-weight: var(--font-medium);
  color: var(--color-text-primary);
  margin-bottom: var(--space-2);
}

.woocommerce-form-row input[type="text"],
.woocommerce-form-row input[type="email"],
.woocommerce-form-row input[type="password"],
.woocommerce-form-row input[type="tel"],
.woocommerce-form-row select {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-base);
  color: var(--color-text-primary);
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  transition: all var(--transition-base);
}

.woocommerce-form-row input:focus,
.woocommerce-form-row select:focus {
  outline: none;
  border-color: var(--brand-primary, var(--color-primary));
  box-shadow: 0 0 0 3px rgba(var(--brand-primary-rgb, 30, 58, 95), 0.1);
}

/* Buttons */
.woocommerce-Button,
.woocommerce button.button {
  display: inline-block;
  padding: var(--space-3) var(--space-6);
  font-size: var(--text-base);
  font-weight: var(--font-semibold);
  color: var(--color-white);
  background: var(--brand-primary, var(--color-primary));
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition-base);
  text-decoration: none;
}

.woocommerce-Button:hover,
.woocommerce button.button:hover {
  background: var(--brand-secondary, var(--color-secondary));
  transform: translateY(-2px);
  color: var(--color-white);
}

/* View Order */
.woocommerce-order-details {
  margin-bottom: var(--space-8);
}

.woocommerce-order-details__title {
  font-family: var(--font-heading);
  color: var(--color-text-primary);
  margin-bottom: var(--space-4);
}

/* Messages */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  padding: var(--space-4);
  margin-bottom: var(--space-6);
  border-radius: var(--radius-md);
}

.woocommerce-message {
  background: #d4edda;
  border: 1px solid #c3e6cb;
  color: #155724;
}

.woocommerce-info {
  background: #d1ecf1;
  border: 1px solid #bee5eb;
  color: #0c5460;
}

.woocommerce-error {
  background: #f8d7da;
  border: 1px solid #f5c6cb;
  color: #721c24;
  list-style: none;
  padding-left: var(--space-4);
}

/* Dashboard Greeting */
.woocommerce-MyAccount-content > p:first-child {
  font-size: var(--text-lg);
  margin-bottom: var(--space-6);
}

/* Responsive Navigation */
@media (max-width: 767px) {
  .woocommerce-MyAccount-navigation ul {
    flex-direction: column;
    gap: var(--space-1);
  }
  
  .woocommerce-MyAccount-navigation li a {
    padding: var(--space-3) var(--space-4);
  }
}

/* ==========================================================================
   SPACING UTILITIES
   ========================================================================== */

.mt-0 { margin-top: 0; }
.mt-4 { margin-top: var(--space-4); }
.mt-6 { margin-top: var(--space-6); }
.mt-8 { margin-top: var(--space-8); }
.mt-12 { margin-top: var(--space-12); }

.mb-0 { margin-bottom: 0; }
.mb-4 { margin-bottom: var(--space-4); }
.mb-6 { margin-bottom: var(--space-6); }
.mb-8 { margin-bottom: var(--space-8); }
.mb-12 { margin-bottom: var(--space-12); }

.py-4 { padding-top: var(--space-4); padding-bottom: var(--space-4); }
.py-8 { padding-top: var(--space-8); padding-bottom: var(--space-8); }
.py-12 { padding-top: var(--space-12); padding-bottom: var(--space-12); }
.py-16 { padding-top: var(--space-16); padding-bottom: var(--space-16); }

/* ==========================================================================
   TEXT UTILITIES
   ========================================================================== */

.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }

.text-primary { color: var(--color-primary); }
.text-secondary { color: var(--color-text-secondary); }
.text-accent { color: var(--color-accent); }
.text-white { color: var(--color-white); }

/* ==========================================================================
   DISPLAY UTILITIES
   ========================================================================== */

.hidden { display: none; }
.block { display: block; }
.inline-block { display: inline-block; }

@media (min-width: 768px) {
  .md\:hidden { display: none; }
  .md\:block { display: block; }
  .md\:flex { display: flex; }
}

@media (min-width: 1024px) {
  .lg\:hidden { display: none; }
  .lg\:block { display: block; }
  .lg\:flex { display: flex; }
}

/* Testimonials grid - skip 2-column layout, go straight to 1 column */
@media (max-width: 960px) {
  .testimonials-grid {
    grid-template-columns: 1fr !important;
  }
}

/* Hide mini-testimonials when they would stack to 1 column */
@media (max-width: 620px) {
  .more-testimonials {
    display: none !important;
  }
}
