/* Tailwind Utility Classes - Auto-generated for ephongthuy.net */
/* This file provides all Tailwind utility classes used by 2979+ content pages */

/* === PREVENT HORIZONTAL OVERFLOW === */
html,body{overflow-x:hidden;max-width:100vw}
*,*::before,*::after{box-sizing:border-box}

/* === GLOBAL LINK RESET === */
a{text-decoration:none}
a:visited{color:inherit}
footer a,footer a:link,footer a:visited,footer a:active{color:#9ca3af !important;text-decoration:none !important}
footer a:hover{color:#60a5fa !important;text-decoration:none !important}
footer h3{color:#fff !important}
footer ul{list-style:disc;padding-left:1.25rem}
footer li{color:#9ca3af}
footer li::marker{color:#4b5563}
.hover\:text-blue-400:hover{color:#60a5fa !important}
.hover\:bg-red-600:hover{background-color:#dc2626 !important}
.hover\:bg-blue-600:hover{background-color:#2563eb !important}
header a,header a:visited,header button{color:inherit;text-decoration:none}
.nav-link,.nav-link:visited{color:#374151 !important;text-decoration:none}
.nav-link:hover{color:#2563eb !important}
.dropdown-item,.dropdown-item:visited{color:#374151 !important;text-decoration:none}
.dropdown-item:hover{color:#2563eb !important;background:#f3f4f6}

/* === FAQ ACCORDION === */
.faq-item{border:1px solid #e5e7eb;border-radius:.75rem;overflow:hidden;transition:box-shadow .2s}
.faq-item+.faq-item{margin-top:.75rem}
.faq-item[open]{box-shadow:0 2px 8px rgba(0,0,0,.08)}
.faq-item summary{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;cursor:pointer;font-weight:700;font-size:1.05rem;color:#111827;list-style:none;-webkit-user-select:none;user-select:none;transition:background .15s}
.faq-item summary:hover{background:#f9fafb}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::marker{display:none;content:''}
.faq-item summary::after{content:'+';font-size:1.5rem;font-weight:300;color:#6b7280;transition:transform .2s;flex-shrink:0;margin-left:1rem}
.faq-item[open] summary::after{content:'\2212'}
.faq-item .faq-answer{padding:0 1.25rem 1rem;color:#374151;line-height:1.7;font-size:.95rem;animation:faqOpen .25s ease}
@keyframes faqOpen{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}

/* === LAYOUT === */
.container{width:100%;margin-right:auto;margin-left:auto;padding-right:1rem;padding-left: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;padding-right:2rem;padding-left:2rem}}
@media(min-width:1280px){.container{max-width:1280px}}

.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}

/* === POSITIONING === */
.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}
.top-0{top:0}.right-0{right:0}.bottom-0{bottom:0}.left-0{left:0}
.inset-0{top:0;right:0;bottom:0;left:0}
.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}

/* === FLEXBOX === */
.flex-1{flex:1 1 0%}.flex-auto{flex:1 1 auto}.flex-none{flex:none}
.flex-row{flex-direction:row}.flex-col{flex-direction:column}
.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}
.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}
.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}
.self-start{align-self:flex-start}.self-center{align-self:center}.self-end{align-self:flex-end}
.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}
.space-y-1>:not([hidden])~:not([hidden]){margin-top:.25rem}.space-y-2>:not([hidden])~:not([hidden]){margin-top:.5rem}.space-y-3>:not([hidden])~:not([hidden]){margin-top:.75rem}.space-y-4>:not([hidden])~:not([hidden]){margin-top:1rem}.space-y-6>:not([hidden])~:not([hidden]){margin-top:1.5rem}
.space-x-2>:not([hidden])~:not([hidden]){margin-left:.5rem}.space-x-4>:not([hidden])~:not([hidden]){margin-left:1rem}

/* === GRID === */
.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))}.grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}

/* === SIZING === */
.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-8{width:2rem}.w-10{width:2.5rem}.w-12{width:3rem}.w-16{width:4rem}.w-20{width:5rem}.w-auto{width:auto}.w-full{width:100%}.w-64{width:16rem}.w-72{width:18rem}
.h-0{height:0}.h-0\.5{height:.125rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-8{height:2rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-16{height:4rem}.h-20{height:5rem}.h-48{height:12rem}.h-auto{height:auto}
.min-h-screen{min-height:100vh}
.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-w-5xl{max-width:64rem}.max-w-none{max-width:none}

/* === SPACING === */
.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}
.px-2{padding-left:.5rem;padding-right:.5rem}.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}.px-8{padding-left:2rem;padding-right:2rem}
.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-12{padding-top:3rem;padding-bottom:3rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-20{padding-top:5rem;padding-bottom:5rem}
.pt-4{padding-top:1rem}.pt-8{padding-top:2rem}.pb-4{padding-bottom:1rem}.pb-8{padding-bottom:2rem}
.m-0{margin:0}.mx-auto{margin-left:auto;margin-right:auto}
.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mt-12{margin-top:3rem}.mt-16{margin-top:4rem}
.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-16{margin-bottom:4rem}
.ml-1{margin-left:.25rem}.ml-2{margin-left:.5rem}.ml-auto{margin-left:auto}
.mr-2{margin-right:.5rem}

/* === 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.25}.text-6xl{font-size:3.75rem;line-height:1.25}
.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-extrabold{font-weight:800}
.font-sans{font-family:Inter,ui-sans-serif,system-ui,-apple-system,sans-serif}
.italic{font-style:italic}
.leading-tight{line-height:1.25}.leading-relaxed{line-height:1.625}.leading-loose{line-height:2}
.tracking-tight{letter-spacing:-.025em}.tracking-wide{letter-spacing:.025em}
.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}
.underline{text-decoration-line:underline}.no-underline{text-decoration-line:none}
.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.whitespace-nowrap{white-space:nowrap}

/* === COLORS === */
.text-white{color:#fff}.text-black{color:#000}
.text-gray-50{color:#f9fafb}.text-gray-100{color:#f3f4f6}.text-gray-200{color:#e5e7eb}.text-gray-300{color:#d1d5db}.text-gray-400{color:#9ca3af}.text-gray-500{color:#6b7280}.text-gray-600{color:#4b5563}.text-gray-700{color:#374151}.text-gray-800{color:#1f2937}.text-gray-900{color:#111827}
.text-blue-400{color:#60a5fa}.text-blue-500{color:#3b82f6}.text-blue-600{color:#2563eb}.text-blue-700{color:#1d4ed8}
.text-sky-500{color:#0ea5e9}.text-sky-600{color:#0284c7}.text-sky-700{color:#0369a1}
.text-amber-500{color:#f59e0b}.text-amber-600{color:#d97706}.text-amber-700{color:#b45309}
.text-emerald-500{color:#10b981}.text-emerald-600{color:#059669}
.text-red-500{color:#ef4444}.text-red-600{color:#dc2626}
.text-green-500{color:#22c55e}.text-green-600{color:#16a34a}
.text-yellow-500{color:#eab308}.text-yellow-600{color:#ca8a04}

.bg-white{background-color:#fff}.bg-black{background-color:#000}
.bg-gray-50{background-color:#f9fafb}.bg-gray-100{background-color:#f3f4f6}.bg-gray-200{background-color:#e5e7eb}.bg-gray-800{background-color:#1f2937}.bg-gray-900{background-color:#111827}
.bg-blue-50{background-color:#eff6ff}.bg-blue-500{background-color:#3b82f6}.bg-blue-600{background-color:#2563eb}.bg-blue-700{background-color:#1d4ed8}
.bg-sky-50{background-color:#f0f9ff}.bg-sky-500{background-color:#0ea5e9}.bg-sky-600{background-color:#0284c7}
.bg-amber-50{background-color:#fffbeb}.bg-amber-500{background-color:#f59e0b}.bg-amber-600{background-color:#d97706}
.bg-emerald-50{background-color:#ecfdf5}
.bg-green-50{background-color:#f0fdf4}.bg-green-100{background-color:#dcfce7}
.bg-red-50{background-color:#fef2f2}
.bg-yellow-50{background-color:#fefce8}
.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}
.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}
.from-blue-50{--tw-gradient-from:#eff6ff;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to,rgba(239,246,255,0))}
.from-sky-50{--tw-gradient-from:#f0f9ff;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to,rgba(240,249,255,0))}
.to-amber-50{--tw-gradient-to:#fffbeb}

/* === BORDERS === */
.border{border-width:1px}.border-0{border-width:0}.border-2{border-width:2px}
.border-t{border-top-width:1px}.border-b{border-bottom-width:1px}
.border-gray-100{border-color:#f3f4f6}.border-gray-200{border-color:#e5e7eb}.border-gray-300{border-color:#d1d5db}
.border-blue-200{border-color:#bfdbfe}.border-blue-600{border-color:#2563eb}
.rounded{border-radius:.25rem}.rounded-md{border-radius:.375rem}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}

/* === EFFECTS === */
.shadow{box-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1)}.shadow-sm{box-shadow:0 1px 2px 0 rgba(0,0,0,.05)}.shadow-md{box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1)}.shadow-lg{box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1)}
.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.opacity-100{opacity:1}
.overflow-hidden{overflow:hidden}.overflow-x-hidden{overflow-x:hidden}.overflow-auto{overflow:auto}
.backdrop-blur-md{backdrop-filter:blur(12px)}

/* === TRANSFORMS & TRANSITIONS === */
.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}
.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}
.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}
.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}
.duration-150{transition-duration:150ms}.duration-200{transition-duration:200ms}.duration-300{transition-duration:300ms}
.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}
.transform{transform:translate(var(--tw-translate-x,0),var(--tw-translate-y,0)) rotate(var(--tw-rotate,0)) skewX(var(--tw-skew-x,0)) skewY(var(--tw-skew-y,0)) scaleX(var(--tw-scale-x,1)) scaleY(var(--tw-scale-y,1))}
.cursor-pointer{cursor:pointer}

/* === HOVER STATES === */
.hover\:bg-gray-100:hover{background-color:#f3f4f6}
.hover\:bg-blue-50:hover{background-color:#eff6ff}
.hover\:bg-blue-600:hover{background-color:#2563eb}
.hover\:bg-blue-700:hover{background-color:#1d4ed8}
.hover\:bg-sky-50:hover{background-color:#f0f9ff}
.hover\:bg-white:hover{background-color:#fff}
.hover\:text-blue-400:hover{color:#60a5fa}
.hover\:text-blue-600:hover{color:#2563eb}
.hover\:text-blue-700:hover{color:#1d4ed8}
.hover\:text-gray-700:hover{color:#374151}
.hover\:text-gray-900:hover{color:#111827}
.hover\:text-white:hover{color:#fff}
.hover\:shadow-lg:hover{box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1)}
.hover\:shadow-md:hover{box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1)}
.hover\:-translate-y-1:hover{transform:translateY(-.25rem)}
.hover\:-translate-y-2:hover{transform:translateY(-.5rem)}
.hover\:scale-105:hover{transform:scale(1.05)}
.hover\:scale-110:hover{transform:scale(1.1)}
.hover\:underline:hover{text-decoration-line:underline}

/* === FOCUS STATES === */
.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}
.focus\:ring-2:focus{box-shadow:0 0 0 2px var(--tw-ring-color,#3b82f6)}
.focus\:ring-blue-500:focus{--tw-ring-color:#3b82f6}

/* === RESPONSIVE === */
@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))}
  .sm\:flex-row{flex-direction:row}
  .sm\:text-lg{font-size:1.125rem}
}
@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-row{flex-direction:row}
  .md\:text-xl{font-size:1.25rem}
}
@media(min-width:1024px){
  .lg\:flex{display:flex}
  .lg\:hidden{display:none}
  .lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
  .lg\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}
  .lg\:gap-8{gap:2rem}
  .lg\:px-8{padding-left:2rem;padding-right:2rem}
  .lg\:py-20{padding-top:5rem;padding-bottom:5rem}
  .lg\:h-12{height:3rem}.lg\:h-20{height:5rem}
  .lg\:text-2xl{font-size:1.5rem;line-height:2rem}.lg\:text-3xl{font-size:1.875rem;line-height:2.25rem}.lg\:text-4xl{font-size:2.25rem;line-height:2.75rem}.lg\:text-5xl{font-size:3rem;line-height:1.25}.lg\:text-6xl{font-size:3.75rem;line-height:1.25}
}

/* === OBJECT FIT === */
.object-cover{object-fit:cover}.object-contain{object-fit:contain}

/* === INTERACTIVITY === */
.select-none{user-select:none}.pointer-events-none{pointer-events:none}

/* === BACKDROP === */
.bg-white\/95{background-color:rgba(255,255,255,.95)}
.bg-black\/50{background-color:rgba(0,0,0,.5)}

/* === NAV DROPDOWN === */
.nav-dropdown{position:relative;display:inline-flex;align-items:center}
.nav-dropdown .dropdown-menu{position:absolute;top:100%;left:0;z-index:50;min-width:220px;padding:.5rem;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 10px 15px -3px rgba(0,0,0,.1);opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .3s ease}
.nav-dropdown .dropdown-menu::before{content:'';position:absolute;top:-20px;left:0;right:0;height:20px;background:transparent}
.dropdown-menu-wide{min-width:420px !important}
.nav-dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:.5rem;color:#374151;font-size:.875rem;text-decoration:none;transition:background .15s}
.dropdown-item:hover{background:#f3f4f6}
.nav-link{display:inline-flex;align-items:center;gap:.25rem;padding:.5rem .75rem;border-radius:.5rem;color:#374151;font-size:.875rem;font-weight:500;text-decoration:none;background:none;border:none;cursor:pointer;transition:color .15s}
.nav-link:hover{color:#2563eb}

/* === MOBILE MENU === */
.mobile-menu-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;border:none;background:none;color:#374151;font-size:.875rem;font-weight:500;text-decoration:none;cursor:pointer;border-radius:.5rem}
.mobile-menu-item:hover{background:#f3f4f6}
.mobile-submenu{display:none;padding:.25rem 0 .25rem 1.5rem}
.mobile-submenu.active{display:block}
.mobile-submenu a{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;color:#4b5563;font-size:.875rem;text-decoration:none;border-radius:.375rem}
.mobile-submenu a:hover{background:#f3f4f6;color:#2563eb}

/* === SIDEBAR & CONTENT COMPONENTS === */
.sidebar-card{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:1.5rem;margin-bottom:1.5rem}
.search-input{width:100%;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem;outline:none;transition:border-color .15s}
.search-input:focus{border-color:#2563eb;box-shadow:0 0 0 2px rgba(37,99,235,.2)}
.button{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border-radius:.5rem;font-weight:600;text-decoration:none;transition:all .15s;cursor:pointer;border:none}
.card{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:1.5rem}
.content-prose{line-height:1.75;color:#374151}
.content-prose h2{font-size:1.5rem;font-weight:700;margin:2rem 0 1rem;color:#111827}
.content-prose h3{font-size:1.25rem;font-weight:600;margin:1.5rem 0 .75rem;color:#1f2937}
.content-prose p{margin-bottom:1rem}
.content-prose ul{list-style:disc;padding-left:1.5rem;margin-bottom:1rem}
.content-prose li{margin-bottom:.5rem}
.content-prose a{color:#2563eb;text-decoration:none}
.content-prose a:hover{color:#1d4ed8;text-decoration:underline}
.content-prose img{max-width:100%;height:auto;border-radius:.5rem;margin:1rem 0}
.zodiac-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem;margin:.75rem 0}
.zodiac-item{display:flex;align-items:center;justify-content:center;padding:.5rem;border-radius:.5rem;text-decoration:none;transition:all .15s}

/* === ADDITIONAL COLORS === */
.bg-red-100{background-color:#fee2e2}.bg-red-200{background-color:#fecaca}
.bg-green-100{background-color:#dcfce7}.bg-green-200{background-color:#bbf7d0}
.bg-yellow-100{background-color:#fef9c3}.bg-yellow-200{background-color:#fef08a}
.bg-blue-100{background-color:#dbeafe}.bg-blue-200{background-color:#bfdbfe}
.bg-orange-100{background-color:#ffedd5}.bg-orange-200{background-color:#fed7aa}
.bg-pink-100{background-color:#fce7f3}.bg-pink-200{background-color:#fbcfe8}
.bg-purple-100{background-color:#f3e8ff}.bg-purple-200{background-color:#e9d5ff}
.bg-purple-600{background-color:#9333ea}.bg-purple-700{background-color:#7e22ce}
.bg-indigo-100{background-color:#e0e7ff}.bg-indigo-200{background-color:#c7d2fe}
.bg-cyan-100{background-color:#cffafe}.bg-cyan-200{background-color:#a5f3fc}
.bg-teal-100{background-color:#ccfbf1}.bg-teal-200{background-color:#99f6e4}
.bg-amber-100{background-color:#fef3c7}.bg-amber-200{background-color:#fde68a}.bg-amber-700{background-color:#b45309}
.hover\:bg-red-200:hover{background-color:#fecaca}
.hover\:bg-green-200:hover{background-color:#bbf7d0}
.hover\:bg-yellow-200:hover{background-color:#fef08a}
.hover\:bg-blue-200:hover{background-color:#bfdbfe}
.hover\:bg-orange-200:hover{background-color:#fed7aa}
.hover\:bg-pink-200:hover{background-color:#fbcfe8}
.hover\:bg-purple-200:hover{background-color:#e9d5ff}
.hover\:bg-purple-700:hover{background-color:#7e22ce}
.hover\:bg-indigo-200:hover{background-color:#c7d2fe}
.hover\:bg-cyan-200:hover{background-color:#a5f3fc}
.hover\:bg-teal-200:hover{background-color:#99f6e4}
.hover\:bg-amber-700:hover{background-color:#b45309}
.hover\:bg-gray-200:hover{background-color:#e5e7eb}

/* === GRADIENTS === */
.from-cyan-50{--tw-gradient-from:#ecfeff;--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to,rgba(236,254,255,0))}
.to-cyan-50{--tw-gradient-to:#ecfeff}
.to-blue-50{--tw-gradient-to:#eff6ff}

/* === MISC === */
.order-1{order:1}.order-2{order:2}
.brightness-0{filter:brightness(0)}.invert{filter:invert(1)}
.brightness-0.invert{filter:brightness(0) invert(1)}
.group:hover .group-hover\:translate-x-1{transform:translateX(.25rem)}
.transition-shadow{transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}
.hover\:shadow-lg:hover{box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1)}
.max-h-\[80vh\]{max-height:80vh}
.overflow-y-auto{overflow-y:auto}
.my-8{margin-top:2rem;margin-bottom:2rem}

/* === GRID COLS 12 === */
.grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}
.col-span-4{grid-column:span 4/span 4}.col-span-8{grid-column:span 8/span 8}
@media(min-width:1024px){
  .lg\:col-span-4{grid-column:span 4/span 4}
  .lg\:col-span-8{grid-column:span 8/span 8}
  .lg\:col-span-12{grid-column:span 12/span 12}
  .lg\:grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}
  .lg\:order-1{order:1}.lg\:order-2{order:2}
  .lg\:py-16{padding-top:4rem;padding-bottom:4rem}
}
