/* tw-lite.css — minimal Tailwind-like utilities used by index.html (no JS runtime) */
:root{
  --tw-purple-600:#9333ea; --tw-purple-700:#7e22ce;
  --tw-gray-100:#f3f4f6; --tw-gray-200:#e5e7eb; --tw-gray-50:#f9fafb;
  --tw-green-50:#f0fdf4; --tw-green-100:#dcfce7; --tw-green-200:#bbf7d0;
  --tw-blue-100:#dbeafe; --tw-yellow-100:#fef9c3; --tw-red-100:#fee2e2;
}

/* Base reset */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%; scrollbar-gutter: stable}
body{margin:0}
img{max-width:100%;height:auto}
input,select,textarea,button{font:inherit}
/* Layout */
.container{width:100%; margin-left:auto; margin-right:auto; padding-left:1rem; padding-right:1rem;}
@media(min-width:640px){.container{max-width:640px}}
@media(min-width:768px){.container{max-width:768px}}
@media(min-width:1024px){.container{max-width:1024px}}
@media(min-width:1280px){.container{max-width:1280px}}

.block{display:block}
.hidden{display:none}
.flex{display:flex}
.grid{display:grid}
.inline-flex{display:inline-flex}
.flex-col{flex-direction:column}
.flex-row{flex-direction:row}
.flex-wrap{flex-wrap:wrap}
.flex-grow{flex-grow:1}
.flex-shrink-0{flex-shrink:0}
.items-center{align-items:center}
.items-start{align-items:flex-start}
.items-end{align-items:flex-end}
.justify-between{justify-content:space-between}
.justify-center{justify-content:center}
.gap-2{gap:.5rem}
.gap-3{gap:.75rem}
.gap-4{gap:1rem}
.gap-6{gap:1.5rem}
.gap-8{gap:2rem}
.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\:flex-row{flex-direction:row}}
@media(min-width:768px){
  .md\:hidden{display:none}
  .md\:block{display:block}
  .md\:flex{display:flex}
  .md\:flex-row{flex-direction:row}
  .md\:items-center{align-items:center}
  .md\:gap-6{gap:1.5rem}
  .md\:gap-8{gap:2rem}
  .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))}
}
.mx-auto{margin-left:auto;margin-right:auto}

/* Spacing */
.p-4{padding:1rem}
.p-6{padding:1.5rem}
.p-8{padding:2rem}
.px-3{padding-left:.75rem;padding-right:.75rem}
.px-4{padding-left:1rem;padding-right:1rem}
.px-6{padding-left:1.5rem;padding-right:1.5rem}
.py-1{padding-top:.25rem;padding-bottom:.25rem}
.py-2{padding-top:.5rem;padding-bottom:.5rem}
.py-3{padding-top:.75rem;padding-bottom:.75rem}
.py-4{padding-top:1rem;padding-bottom:1rem}
.py-6{padding-top:1.5rem;padding-bottom:1.5rem}
.py-8{padding-top:2rem;padding-bottom:2rem}
.py-10{padding-top:2.5rem;padding-bottom:2.5rem}
.py-12{padding-top:3rem;padding-bottom:3rem}
.py-16{padding-top:4rem;padding-bottom:4rem}
.py-20{padding-top:5rem;padding-bottom:5rem}
.pt-6{padding-top:1.5rem}
.pb-6{padding-bottom:1.5rem}
.mt-2{margin-top:.5rem}
.mt-3{margin-top:.75rem}
.mt-4{margin-top:1rem}
.mt-6{margin-top:1.5rem}
.mb-1{margin-bottom:.25rem}
.mb-2{margin-bottom:.5rem}
.mb-3{margin-bottom:.75rem}
.mb-4{margin-bottom:1rem}
.mb-6{margin-bottom:1.5rem}
.mb-8{margin-bottom:2rem}
.mb-10{margin-bottom:2.5rem}
.mb-12{margin-bottom:3rem}
.mb-16{margin-bottom:4rem}
.-mt-10{margin-top:-2.5rem}
@media(min-width:768px){
  .md\:p-6{padding:1.5rem}
  .md\:p-8{padding:2rem}
  .md\:py-12{padding-top:3rem;padding-bottom:3rem}
  .md\:py-16{padding-top:4rem;padding-bottom:4rem}
  .md\:py-20{padding-top:5rem;padding-bottom:5rem}
  .md\:mb-6{margin-bottom:1.5rem}
  .md\:mb-8{margin-bottom:2rem}
  .md\:mb-12{margin-bottom:3rem}
  .md\:mb-16{margin-bottom:4rem}
}
.space-y-2 > :not([hidden]) ~ :not([hidden]){margin-top:.5rem}

/* Size */
.h-10{height:2.5rem}
.h-12{height:3rem}
.h-16{height:4rem}
.w-44{width:11rem}
@media(min-width:768px){.md\:h-12{height:3rem}.md\:w-44{width:11rem}}

/* Position */
.sticky{position:sticky}
.top-0{top:0}
.z-10{z-index:10}

/* Typography */
.text-xs{font-size:.75rem;line-height:1rem}
.text-sm{font-size:.875rem;line-height:1.25rem}
.text-base{font-size:1rem;line-height:1.5rem}
.text-lg{font-size:1.125rem;line-height:1.75rem}
.text-xl{font-size:1.25rem;line-height:1.75rem}
.text-2xl{font-size:1.5rem;line-height:2rem}
.text-3xl{font-size:1.875rem;line-height:2.25rem}
.text-4xl{font-size:2.25rem;line-height:2.5rem}
.text-5xl{font-size:3rem;line-height:1}
.text-6xl{font-size:3.75rem;line-height:1}
@media(min-width:768px){
  .md\:text-base{font-size:1rem;line-height:1.5rem}
  .md\:text-lg{font-size:1.125rem;line-height:1.75rem}
  .md\:text-xl{font-size:1.25rem;line-height:1.75rem}
  .md\:text-3xl{font-size:1.875rem;line-height:2.25rem}
  .md\:text-4xl{font-size:2.25rem;line-height:2.5rem}
  .md\:text-5xl{font-size:3rem;line-height:1}
}
@media(min-width:1024px){
  .lg\:text-2xl{font-size:1.5rem;line-height:2rem}
  .lg\:text-6xl{font-size:3.75rem;line-height:1}
}
.font-bold{font-weight:700}
.font-semibold{font-weight:600}
.leading-none{line-height:1}
.text-center{text-align:center}

/* Colors */
.text-white{color:#fff}
.text-black{color:#000}
.text-purple-600{color:var(--tw-purple-600)}
.text-green-800{color:#166534}
.bg-white{background-color:#fff}
.bg-white\/10{background-color:rgba(255,255,255,.10)}
.bg-white\/20{background-color:rgba(255,255,255,.20)}
.bg-purple-600{background-color:var(--tw-purple-600)}
.bg-gray-100{background-color:var(--tw-gray-100)}
.bg-green-50{background-color:var(--tw-green-50)}
.bg-green-100{background-color:var(--tw-green-100)}
.bg-blue-100{background-color:var(--tw-blue-100)}
.bg-yellow-100{background-color:var(--tw-yellow-100)}
.bg-red-100{background-color:var(--tw-red-100)}
.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-purple-600),var(--tw-purple-700))}
.border{border-width:1px;border-style:solid;border-color:var(--tw-gray-200)}
.border-b{border-bottom-width:1px;border-bottom-style:solid;border-color:var(--tw-gray-200)}
.border-t{border-top-width:1px;border-top-style:solid;border-color:var(--tw-gray-200)}
.border-purple-600{border-color:var(--tw-purple-600)}
.border-green-200{border-color:var(--tw-green-200)}

/* Radius / shadow */
.rounded-lg{border-radius:.5rem}
.rounded-2xl{border-radius:1rem}
.rounded-full{border-radius:9999px}
.shadow{box-shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06)}
.shadow-sm{box-shadow:0 1px 2px rgba(0,0,0,.08)}
.shadow-xl{box-shadow:0 20px 25px rgba(0,0,0,.15),0 10px 10px rgba(0,0,0,.06)}

/* Links / lists */
.hover\:underline:hover{text-decoration:underline}
.hover\:no-underline:hover{text-decoration:none}
.underline{text-decoration:underline}
.list-disc{list-style-type:disc}
.list-inside{list-style-position:inside}

/* Effects */
.transition{transition:all .2s ease}
.backdrop-blur{backdrop-filter:blur(12px)}
.backdrop-blur-sm{backdrop-filter:blur(6px)}
.divide-y > :not([hidden]) ~ :not([hidden]){border-top:1px solid var(--tw-gray-200)}
.cursor-pointer{cursor:pointer}

/* Interactive states (minimal) */
.hover\:bg-purple-50:hover{background-color:#faf5ff}
.hover\:bg-purple-700:hover{background-color:var(--tw-purple-700)}
.hover\:bg-tertiary:hover{background-color:var(--tw-gray-100)}
.hover\:shadow:hover{box-shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06)}
.hover\:shadow-xl:hover{box-shadow:0 20px 25px rgba(0,0,0,.15),0 10px 10px rgba(0,0,0,.06)}
.hover\:text-purple-600:hover{color:var(--tw-purple-600)}
.hover\:text-white:hover{color:#fff}

/* Focus rings */
.focus\:outline-none:focus{outline:0}
.focus\:ring-2:focus{box-shadow:0 0 0 2px rgba(147,51,234,.35)}
.focus\:ring-purple-500:focus{box-shadow:0 0 0 2px rgba(168,85,247,.45)}
.focus\:ring-white\/50:focus{box-shadow:0 0 0 2px rgba(255,255,255,.50)}

/* Special: class used to make <option> text readable */
.\[\&\>option\]\:text-black > option{color:#000}

/* picture default */
picture{display:inline-block}
picture img{display:block}

/* spacing utility */
.space-x-6 > :not([hidden]) ~ :not([hidden]){ margin-left: 1.5rem; }

/* ui-fixes: missing utilities used in templates */
.w-full{width:100%}
.w-auto{width:auto}
.min-w-0{min-width:0}
.text-left{text-align:left}
.no-underline{text-decoration:none}
.opacity-90{opacity:.9}
.p-5{padding:1.25rem}
.mt-8{margin-top:2rem}
.mt-10{margin-top:2.5rem}
.mt-12{margin-top:3rem}
.mb-10{margin-bottom:2.5rem} /* already exists in file, keep harmless */
.h-6{height:1.5rem}
.h-8{height:2rem}
.w-8{width:2rem}
.rounded-xl{border-radius:.75rem}
.max-w-2xl{max-width:42rem}
.max-w-3xl{max-width:48rem}
.max-w-4xl{max-width:56rem}
.space-y-1 > :not([hidden]) ~ :not([hidden]){margin-top:.25rem}
.text-gray-400{color:#9ca3af}
.text-green-700{color:#15803d}
.text-yellow-800{color:#854d0e}
.text-red-800{color:#991b1b}

/* ui-fixes: minimal responsive variants (md/lg) used in templates */
@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))}
  .md\:flex{display:flex}
  .md\:block{display:block}
  .md\:hidden{display:none}
  .md\:flex-row{flex-direction:row}
  .md\:items-center{align-items:center}
  .md\:gap-6{gap:1.5rem}
  .md\:gap-8{gap:2rem}
  .md\:p-6{padding:1.5rem}
  .md\:p-8{padding:2rem}
  .md\:py-12{padding-top:3rem;padding-bottom:3rem}
  .md\:py-16{padding-top:4rem;padding-bottom:4rem}
  .md\:py-20{padding-top:5rem;padding-bottom:5rem}
  .md\:mb-6{margin-bottom:1.5rem}
  .md\:mb-8{margin-bottom:2rem}
  .md\:mb-12{margin-bottom:3rem}
  .md\:mb-16{margin-bottom:4rem}
  .md\:text-base{font-size:1rem;line-height:1.5rem}
  .md\:text-lg{font-size:1.125rem;line-height:1.75rem}
  .md\:text-xl{font-size:1.25rem;line-height:1.75rem}
  .md\:text-3xl{font-size:1.875rem;line-height:2.25rem}
  .md\:text-4xl{font-size:2.25rem;line-height:2.5rem}
  .md\:text-5xl{font-size:3rem;line-height:1}
  .md\:h-12{height:3rem}
  .md\:w-44{width:11rem}
}
@media (min-width: 1024px){
  .lg\:text-2xl{font-size:1.5rem;line-height:2rem}
  .lg\:text-6xl{font-size:3.75rem;line-height:1}
}

/* Prevent header layout shift (font swap) */
body > header, body > header *{font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;}
