/* Minimal CSS for complex styles that can't be handled by Tailwind */

/* Prevent horizontal overflow on mobile */
html, body {
   overflow-x: hidden;
   max-width: 100%;
}

/* Smooth scrolling with reduced motion support */
@media (prefers-reduced-motion: no-preference) {
   html {
      scroll-behavior: smooth;
   }
}

@media (prefers-reduced-motion: reduce) {
   html {
      scroll-behavior: auto;
   }
}

/* Skip link for keyboard navigation accessibility */
.skip-link {
   position: absolute;
   left: -9999px;
   width: 1px;
   height: 1px;
   overflow: hidden;
   clip: rect(0, 0, 0, 0);
   z-index: 999;
}

.skip-link:focus {
   left: 16px;
   top: 16px;
   width: auto;
   height: auto;
   overflow: visible;
   clip: auto;
   background-color: #ff7a59;
   color: white;
   padding: 8px 16px;
   border-radius: 4px;
   box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
   text-decoration: none;
   font-weight: 500;
}

.cookie-backdrop {
   position: fixed;
   inset: 0;
   background-color: rgba(0, 0, 0, 0.5);
   backdrop-filter: blur(4px);
   z-index: 999;
   opacity: 0;
   pointer-events: none;
   visibility: hidden;
   display: none;
   transition: opacity 0.3s ease-in-out, visibility 0.3s ease-in-out;
}

.cookie-backdrop.show {
   display: block;
   opacity: 1;
   pointer-events: auto;
   visibility: visible;
}

.cookie-banner {
   position: fixed;
   bottom: 0;
   left: 0;
   right: 0;
   z-index: 1000;
   background-color: white;
   box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.15);
   transform: translateY(100%);
   opacity: 0;
   pointer-events: none;
   visibility: hidden;
   display: none;
   transition: transform 0.3s ease-in-out, opacity 0.3s ease-in-out, visibility 0.3s ease-in-out;
}

.cookie-banner.show {
   display: block;
   transform: translateY(0);
   opacity: 1;
   pointer-events: auto;
   visibility: visible;
}

#cookie-banner-container:empty {
   display: none;
}

.cookie-banner-container {
   max-width: 1200px;
   margin: 0 auto;
   padding: 16px;
}

@media (min-width: 640px) {
   .cookie-banner-container {
      padding: 20px;
   }
}

.cookie-banner-content {
   display: flex;
   flex-direction: column;
   gap: 12px;
   align-items: flex-start;
}

@media (min-width: 768px) {
   .cookie-banner-content {
      flex-direction: row;
      align-items: center;
      gap: 20px;
   }
}

.cookie-banner-logo {
   height: 40px;
   width: auto;
   object-fit: contain;
   flex-shrink: 0;
   margin: 0;
}

@media (min-width: 640px) {
   .cookie-banner-logo {
      height: 50px;
   }
}

.cookie-banner-text {
   flex: 1;
   color: #4a5568;
   font-size: 0.875rem;
   line-height: 1.5;
   margin: 0;
}

@media (min-width: 640px) {
   .cookie-banner-text {
      font-size: 0.95rem;
      line-height: 1.6;
   }
}

.cookie-banner-buttons {
   display: flex;
   flex-wrap: wrap;
   gap: 8px;
   flex-shrink: 0;
   width: 100%;
}

@media (min-width: 640px) {
   .cookie-banner-buttons {
      gap: 12px;
      width: auto;
   }
}

.cookie-btn {
   padding: 10px 16px;
   border-radius: 6px;
   font-size: 0.875rem;
   font-weight: 500;
   cursor: pointer;
   transition: all 0.2s;
   border: none;
   min-height: 44px;
   min-width: auto;
   display: inline-flex;
   align-items: center;
   justify-content: center;
   text-decoration: none;
   white-space: nowrap;
   pointer-events: auto;
   position: relative;
   z-index: 1;
}

@media (min-width: 640px) {
   .cookie-btn {
      padding: 10px 20px;
      font-size: 0.95rem;
      min-width: 120px;
   }
}

.cookie-btn-primary {
   background-color: #ff7a59;
   color: white;
}

.cookie-btn-primary:hover {
   background-color: #e6694a;
}

.cookie-btn-secondary {
   background-color: white;
   color: #1a202c;
   border: 2px solid #e2e8f0;
}

.cookie-btn-secondary:hover {
   background-color: #e2e8f0;
   border-color: #4a5568;
}

.cookie-btn-link {
   background-color: transparent;
   color: #ff7a59;
   text-decoration: underline;
   min-width: auto;
}

.cookie-btn-link:hover {
   color: #e6694a;
}

.cookie-btn:focus {
   outline: 2px solid #ff7a59;
   outline-offset: 2px;
}

/* Cookie Modal Styles */
.cookie-modal {
   position: fixed;
   inset: 0;
   z-index: 2000;
   display: none;
   align-items: center;
   justify-content: center;
   padding: 20px;
   opacity: 0;
   pointer-events: none;
   visibility: hidden;
   transition: opacity 0.3s ease-in-out, visibility 0.3s ease-in-out;
}

.cookie-modal.show {
   display: flex;
   opacity: 1;
   pointer-events: auto;
   visibility: visible;
}

.cookie-modal-overlay {
   position: absolute;
   inset: 0;
   background-color: rgba(0, 0, 0, 0.5);
   backdrop-filter: blur(8px);
   pointer-events: none;
}

.cookie-modal-content {
   position: relative;
   background-color: white;
   border-radius: 12px;
   max-width: 600px;
   width: calc(100% - 40px);
   max-height: 90vh;
   display: flex;
   flex-direction: column;
   box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
   z-index: 10;
   margin: 20px;
   pointer-events: auto;
}

@media (min-width: 640px) {
   .cookie-modal-content {
      width: 100%;
      margin: 0;
   }
}

.cookie-modal-header {
   display: flex;
   justify-content: space-between;
   align-items: center;
   padding: 20px;
   border-bottom: 1px solid #e2e8f0;
   pointer-events: auto;
}

@media (min-width: 640px) {
   .cookie-modal-header {
      padding: 24px;
   }
}

.cookie-modal-title {
   font-size: 1.5rem;
   font-weight: 600;
   color: #1a202c;
   margin: 0;
}

.cookie-modal-close {
   background: transparent;
   border: none;
   font-size: 1.5rem;
   color: #4a5568;
   cursor: pointer;
   padding: 8px;
   border-radius: 4px;
   min-width: 44px;
   min-height: 44px;
   display: flex;
   align-items: center;
   justify-content: center;
   transition: all 0.2s;
}

.cookie-modal-close:hover {
   background-color: #e2e8f0;
   color: #1a202c;
}

.cookie-modal-body {
   padding: 20px;
   overflow-y: auto;
   flex: 1;
   pointer-events: auto;
}

@media (min-width: 640px) {
   .cookie-modal-body {
      padding: 24px;
   }
}

.cookie-setting-item {
   padding: 16px 0;
   border-bottom: 1px solid #e2e8f0;
}

@media (min-width: 640px) {
   .cookie-setting-item {
      padding: 20px 0;
   }
}

.cookie-setting-item:last-child {
   border-bottom: none;
}

.cookie-setting-header {
   display: flex;
   justify-content: space-between;
   align-items: center;
   margin-bottom: 8px;
}

.cookie-setting-title {
   font-size: 1rem;
   font-weight: 600;
   color: #1a202c;
   margin: 0;
}

@media (min-width: 640px) {
   .cookie-setting-title {
      font-size: 1.1rem;
   }
}

.cookie-setting-description {
   font-size: 0.8125rem;
   color: #4a5568;
   line-height: 1.5;
   margin: 0;
}

@media (min-width: 640px) {
   .cookie-setting-description {
      font-size: 0.875rem;
      line-height: 1.6;
   }
}

/* Cookie toggle switch with pseudo-element animation */
.cookie-toggle {
   position: relative;
   display: inline-block;
   width: 50px;
   height: 28px;
   flex-shrink: 0;
   pointer-events: auto;
   z-index: 1;
}

.cookie-toggle input {
   opacity: 0;
   width: 0;
   height: 0;
}

.cookie-toggle-slider {
   position: absolute;
   cursor: pointer;
   top: 0;
   left: 0;
   right: 0;
   bottom: 0;
   background-color: #cbd5e0;
   transition: 0.3s;
   border-radius: 28px;
}

.cookie-toggle-slider:before {
   position: absolute;
   content: "";
   height: 20px;
   width: 20px;
   left: 4px;
   bottom: 4px;
   background-color: white;
   transition: 0.3s;
   border-radius: 50%;
}

.cookie-toggle input:checked + .cookie-toggle-slider {
   background-color: #ff7a59;
}

.cookie-toggle input:checked + .cookie-toggle-slider:before {
   transform: translateX(22px);
}

.cookie-toggle input:disabled + .cookie-toggle-slider {
   background-color: #e2e8f0;
   cursor: not-allowed;
   opacity: 0.6;
}

.cookie-toggle input:focus + .cookie-toggle-slider {
   box-shadow: 0 0 0 3px rgba(255, 122, 89, 0.3);
}

.cookie-modal-footer {
   padding: 20px;
   border-top: 1px solid #e2e8f0;
   display: flex;
   justify-content: flex-end;
   gap: 12px;
   flex-shrink: 0;
   pointer-events: auto;
}

@media (min-width: 640px) {
   .cookie-modal-footer {
      padding: 24px;
   }
}

.cookie-modal-footer .cookie-btn {
   width: 100%;
}

@media (min-width: 640px) {
   .cookie-modal-footer .cookie-btn {
      width: auto;
   }
}

body {
   font-family: 'DM Sans', Arial, sans-serif;
}

/* Hero text shadows for practice.html */
.hero-text-shadow {
   text-shadow: 2px 2px 8px rgba(0, 0, 0, 0.5);
}

.hero-text-shadow-subtle {
   text-shadow: 1px 1px 6px rgba(0, 0, 0, 0.5);
}

.hero-text-shadow-light {
   text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.5);
}

.hero-text-shadow-button {
   text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.3);
}

/* Improve contrast ratio for accessibility - WCAG AA compliant */
/* Override text-grayNut to use darker color (rgb(75 85 99) = gray-600) */
/* This provides ~6.2:1 contrast ratio on white background (WCAG AAA for normal text) */
.text-grayNut {
   --tw-text-opacity: 1;
   color: rgb(75 85 99 / var(--tw-text-opacity, 1)) !important;
}