/* PDFMASTER - Production Tailwind CSS (handcrafted from used utility classes)
   Generated to replace cdn.tailwindcss.com
   Includes all utility classes used across all HTML files + custom retro colors */

/* ===== CSS Reset (Tailwind Preflight) ===== */
*,::after,::before{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}
::after,::before{--tw-content:''}
html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal}
body{margin:0;line-height:inherit}
hr{height:0;color:inherit;border-top-width:1px}
abbr:where([title]){text-decoration:underline dotted}
h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}
a{color:inherit;text-decoration:inherit}
b,strong{font-weight:bolder}
code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:1em}
small{font-size:80%}
sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}
sub{bottom:-.25em}
sup{top:-.5em}
table{text-indent:0;border-color:inherit;border-collapse:collapse}
button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}
button,select{text-transform:none}
[type=button],[type=reset],[type=submit],button{-webkit-appearance:button;background-color:transparent;background-image:none}
:-moz-focusring{outline:auto}
:-moz-ui-invalid{box-shadow:none}
progress{vertical-align:baseline}
::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}
[type=search]{-webkit-appearance:textfield;outline-offset:-2px}
::-webkit-search-decoration{-webkit-appearance:none}
::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}
summary{display:list-item}
blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}
fieldset{margin:0;padding:0}
legend{padding:0}
menu,ol,ul{list-style:none;margin:0;padding:0}
dialog{padding:0}
textarea{resize:vertical}
input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}
[role=button],button{cursor:pointer}
:disabled{cursor:default}
audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}
img,video{max-width:100%;height:auto}
[hidden]{display:none}

/* ===== Custom Retro Color Variables ===== */
:root{
  --retro-bg:#B8D8BA;
  --retro-panel:#F5F0E1;
  --retro-dark:#2D2D2D;
  --retro-accent:#5B7B5E;
  --retro-warm:#E8DCC8;
  --retro-gold:#C9B97A;
  --retro-cream:#FAF6ED;
  --retro-border:#3D3D3D;
  --retro-title:#4A6B4D;
}

/* ===== Layout & Display ===== */
.block{display:block}
.inline-block{display:inline-block}
.inline-flex{display:inline-flex}
.flex{display:flex}
.grid{display:grid}
.hidden{display:none}
.relative{position:relative}
.absolute{position:absolute}
.fixed{position:fixed}
.sticky{position:sticky}
.inset-0{inset:0}
.top-0{top:0}
.right-0{right:0}
.bottom-0{bottom:0}
.left-0{left:0}
.-top-1{top:-0.25rem}
.-top-0\.5{top:-0.125rem}
.-right-1{right:-0.25rem}
.-right-0\.5{right:-0.125rem}
.z-10{z-index:10}
.z-35{z-index:35}
.z-40{z-index:40}
.z-50{z-index:50}
.z-\[60\]{z-index:60}

/* ===== Flexbox ===== */
.flex-col{flex-direction:column}
.flex-row{flex-direction:row}
.flex-wrap{flex-wrap:wrap}
.flex-1{flex:1 1 0%}
.items-center{align-items:center}
.items-start{align-items:flex-start}
.justify-center{justify-content:center}
.justify-between{justify-content:space-between}
.justify-end{justify-content:flex-end}
.gap-0\.5{gap:0.125rem}
.gap-1{gap:0.25rem}
.gap-1\.5{gap:0.375rem}
.gap-2{gap:0.5rem}
.gap-2\.5{gap:0.625rem}
.gap-3{gap:0.75rem}
.gap-4{gap:1rem}
.gap-5{gap:1.25rem}
.gap-6{gap:1.5rem}
.shrink-0{flex-shrink:0}
.grow{flex-grow:1}

/* ===== 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))}

/* ===== Sizing ===== */
.w-3{width:0.75rem}
.w-5{width:1.25rem}
.w-6{width:1.5rem}
.w-10{width:2.5rem}
.w-12{width:3rem}
.w-14{width:3.5rem}
.w-16{width:4rem}
.w-20{width:5rem}
.w-40{width:10rem}
.w-60{width:15rem}
.w-72{width:18rem}
.w-80{width:20rem}
.w-96{width:24rem}
.w-full{width:100%}
.w-px{width:1px}
.w-\[2\.5px\]{width:2.5px}
.w-\[76px\]{width:76px}
.h-1\.5{height:0.375rem}
.h-3{height:0.75rem}
.h-5{height:1.25rem}
.h-6{height:1.5rem}
.h-10{height:2.5rem}
.h-12{height:3rem}
.h-14{height:3.5rem}
.h-16{height:4rem}
.h-20{height:5rem}
.h-full{height:100%}
.h-screen{height:100vh}
.h-\[52px\]{height:52px}
.min-h-0{min-height:0}
.min-h-screen{min-height:100vh}
.min-h-\[180px\]{min-height:180px}
.min-w-0{min-width:0}
.min-w-\[200px\]{min-width:200px}
.max-w-xs{max-width:20rem}
.max-w-sm{max-width:24rem}
.max-w-lg{max-width:32rem}
.max-w-xl{max-width:36rem}
.max-w-2xl{max-width:42rem}
.max-w-3xl{max-width:48rem}
.max-w-4xl{max-width:56rem}
.max-h-\[200px\]{max-height:200px}

/* ===== Spacing ===== */
.p-0{padding:0}
.p-2{padding:0.5rem}
.p-2\.5{padding:0.625rem}
.p-3{padding:0.75rem}
.p-4{padding:1rem}
.p-5{padding:1.25rem}
.p-6{padding:1.5rem}
.p-10{padding:2.5rem}
.px-1{padding-left:0.25rem;padding-right:0.25rem}
.px-1\.5{padding-left:0.375rem;padding-right:0.375rem}
.px-2{padding-left:0.5rem;padding-right:0.5rem}
.px-2\.5{padding-left:0.625rem;padding-right:0.625rem}
.px-3{padding-left:0.75rem;padding-right:0.75rem}
.px-4{padding-left:1rem;padding-right:1rem}
.px-5{padding-left:1.25rem;padding-right:1.25rem}
.px-6{padding-left:1.5rem;padding-right:1.5rem}
.px-8{padding-left:2rem;padding-right:2rem}
.py-0\.5{padding-top:0.125rem;padding-bottom:0.125rem}
.py-1{padding-top:0.25rem;padding-bottom:0.25rem}
.py-1\.5{padding-top:0.375rem;padding-bottom:0.375rem}
.py-2{padding-top:0.5rem;padding-bottom:0.5rem}
.py-2\.5{padding-top:0.625rem;padding-bottom:0.625rem}
.py-3{padding-top:0.75rem;padding-bottom:0.75rem}
.py-4{padding-top:1rem;padding-bottom:1rem}
.py-10{padding-top:2.5rem;padding-bottom:2.5rem}
.pt-2{padding-top:0.5rem}
.pt-4{padding-top:1rem}
.pb-3{padding-bottom:0.75rem}
.pl-4{padding-left:1rem}
.m-0{margin:0}
.mx-1{margin-left:0.25rem;margin-right:0.25rem}
.mx-auto{margin-left:auto;margin-right:auto}
.mb-1{margin-bottom:0.25rem}
.mb-2{margin-bottom:0.5rem}
.mb-3{margin-bottom:0.75rem}
.mb-4{margin-bottom:1rem}
.mb-5{margin-bottom:1.25rem}
.mb-6{margin-bottom:1.5rem}
.mr-1{margin-right:0.25rem}
.mr-1\.5{margin-right:0.375rem}
.mr-2{margin-right:0.5rem}
.ml-1{margin-left:0.25rem}
.ml-2{margin-left:0.25rem}
.ml-4{margin-left:1rem}
.ml-auto{margin-left:auto}
.mt-1{margin-top:0.25rem}
.mt-2{margin-top:0.5rem}
.mt-4{margin-top:1rem}
.mt-6{margin-top:1.5rem}
.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(0.25rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(0.25rem*var(--tw-space-y-reverse))}
.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(0.5rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(0.5rem*var(--tw-space-y-reverse))}
.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(0.75rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(0.75rem*var(--tw-space-y-reverse))}
.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem*var(--tw-space-y-reverse))}

/* ===== Typography ===== */
.text-\[7px\]{font-size:7px}
.text-\[8px\]{font-size:8px}
.text-\[9px\]{font-size:9px}
.text-\[10px\]{font-size:10px}
.text-\[11px\]{font-size:11px}
.text-xs{font-size:0.75rem;line-height:1rem}
.text-sm{font-size:0.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}
.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace}
.font-medium{font-weight:500}
.font-semibold{font-weight:600}
.font-bold{font-weight:700}
.font-extrabold{font-weight:800}
.uppercase{text-transform:uppercase}
.lowercase{text-transform:lowercase}
.capitalize{text-transform:capitalize}
.tracking-wider{letter-spacing:0.05em}
.tracking-wide{letter-spacing:0.025em}
.leading-tight{line-height:1.25}
.leading-relaxed{line-height:1.625}
.leading-snug{line-height:1.375}
.text-center{text-align:center}
.text-left{text-align:left}
.text-right{text-align:right}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.no-underline{text-decoration-line:none}
.underline{text-decoration-line:underline}
.list-disc{list-style-type:disc}
.list-decimal{list-style-type:decimal}

/* ===== Text Colors ===== */
.text-white{color:#fff}
.text-black{color:#000}
.text-gray-400{color:#9ca3af}
.text-gray-500{color:#6b7280}
.text-gray-600{color:#4b5563}
.text-gray-700{color:#374151}
.text-red-500{color:#ef4444}
.text-red-700{color:#b91c1c}
.text-green-500{color:#22c55e}
.text-green-600{color:#16a34a}
.text-blue-500{color:#3b82f6}
.text-blue-600{color:#2563eb}
.text-purple-500{color:#a855f7}
.text-purple-600{color:#9333ea}
.text-orange-500{color:#f97316}
.text-orange-600{color:#ea580c}
.text-pink-500{color:#ec4899}
.text-pink-600{color:#db2777}
.text-indigo-500{color:#6366f1}
.text-indigo-600{color:#4f46e5}
.text-cyan-500{color:#06b6d4}
.text-cyan-600{color:#0891b2}
.text-amber-500{color:#f59e0b}
.text-yellow-600{color:#ca8a04}
.text-retro-dark{color:#2D2D2D}
.text-retro-accent{color:#5B7B5E}
.text-retro-title{color:#4A6B4D}

/* ===== Background Colors ===== */
.bg-white{background-color:#fff}
.bg-black{background-color:#000}
.bg-transparent{background-color:transparent}
.bg-gray-100{background-color:#f3f4f6}
.bg-gray-200{background-color:#e5e7eb}
.bg-gray-50{background-color:#f9fafb}
.bg-red-100{background-color:#fee2e2}
.bg-red-200{background-color:#fecaca}
.bg-red-300{background-color:#fca5a5}
.bg-red-500{background-color:#ef4444}
.bg-green-100{background-color:#dcfce7}
.bg-green-200{background-color:#bbf7d0}
.bg-green-600{background-color:#16a34a}
.bg-blue-100{background-color:#dbeafe}
.bg-blue-500{background-color:#3b82f6}
.bg-purple-100{background-color:#f3e8ff}
.bg-purple-500{background-color:#a855f7}
.bg-orange-100{background-color:#ffedd5}
.bg-orange-500{background-color:#f97316}
.bg-pink-100{background-color:#fce7f3}
.bg-pink-500{background-color:#ec4899}
.bg-indigo-100{background-color:#e0e7ff}
.bg-indigo-500{background-color:#6366f1}
.bg-cyan-100{background-color:#cffafe}
.bg-cyan-500{background-color:#06b6d4}
.bg-amber-100{background-color:#fef3c7}
.bg-amber-500{background-color:#f59e0b}
.bg-yellow-100{background-color:#fef9c3}
.bg-retro-bg{background-color:#B8D8BA}
.bg-retro-panel{background-color:#F5F0E1}
.bg-retro-dark{background-color:#2D2D2D}
.bg-retro-accent{background-color:#5B7B5E}
.bg-retro-warm{background-color:#E8DCC8}
.bg-retro-gold{background-color:#C9B97A}
.bg-retro-cream{background-color:#FAF6ED}
.bg-retro-border{background-color:#3D3D3D}
.bg-retro-title{background-color:#4A6B4D}
/* Opacity variants */
.bg-retro-bg\/30{background-color:rgba(184,216,186,0.3)}
.bg-retro-bg\/40{background-color:rgba(184,216,186,0.4)}
.bg-retro-bg\/60{background-color:rgba(184,216,186,0.6)}
.bg-retro-gold\/20{background-color:rgba(201,185,122,0.2)}
.bg-retro-gold\/30{background-color:rgba(201,185,122,0.3)}
.bg-retro-gold\/40{background-color:rgba(201,185,122,0.4)}
.bg-retro-warm\/50{background-color:rgba(232,220,200,0.5)}
.bg-retro-accent\/20{background-color:rgba(91,123,94,0.2)}
.bg-black\/30{background-color:rgba(0,0,0,0.3)}
.bg-\[\#3B82F6\]{background-color:#3B82F6}
.bg-\[\#EF4444\]{background-color:#EF4444}
.bg-\[\#F97316\]{background-color:#F97316}
.bg-\[\#22C55E\]{background-color:#22C55E}
.bg-\[\#A855F7\]{background-color:#A855F7}
.bg-\[\#6366F1\]{background-color:#6366F1}
.bg-\[\#06B6D4\]{background-color:#06B6D4}
.bg-\[\#EC4899\]{background-color:#EC4899}
.bg-\[\#F59E0B\]{background-color:#F59E0B}

/* ===== Border ===== */
.border{border-width:1px}
.border-2{border-width:2px}
.border-\[2\.5px\]{border-width:2.5px}
.border-b{border-bottom-width:1px}
.border-b-2{border-bottom-width:2px}
.border-b-\[2\.5px\]{border-bottom-width:2.5px}
.border-t-2{border-top-width:2px}
.border-t-\[2\.5px\]{border-top-width:2.5px}
.border-r-\[2\.5px\]{border-right-width:2.5px}
.border-l-2{border-left-width:2px}
.border-dashed{border-style:dashed}
.border-solid{border-style:solid}
.border-gray-200{border-color:#e5e7eb}
.border-gray-300{border-color:#d1d5db}
.border-retro-border{border-color:#3D3D3D}
.border-retro-border\/20{border-color:rgba(61,61,61,0.2)}
.border-retro-border\/30{border-color:rgba(61,61,61,0.3)}

/* ===== Border Radius ===== */
.rounded{border-radius:0.25rem}
.rounded-md{border-radius:0.375rem}
.rounded-lg{border-radius:0.5rem}
.rounded-xl{border-radius:0.75rem}
.rounded-2xl{border-radius:1rem}
.rounded-full{border-radius:9999px}
.rounded-r{border-top-right-radius:0.25rem;border-bottom-right-radius:0.25rem}
.rounded-t-\[9px\]{border-top-left-radius:9px;border-top-right-radius:9px}

/* ===== Shadow ===== */
.shadow-sm{box-shadow:0 1px 2px 0 rgba(0,0,0,0.05)}
.shadow{box-shadow:0 1px 3px 0 rgba(0,0,0,0.1),0 1px 2px -1px rgba(0,0,0,0.1)}
.shadow-md{box-shadow:0 4px 6px -1px rgba(0,0,0,0.1),0 2px 4px -2px rgba(0,0,0,0.1)}
.shadow-lg{box-shadow:0 10px 15px -3px rgba(0,0,0,0.1),0 4px 6px -4px rgba(0,0,0,0.1)}
.shadow-\[3px_3px_0px_rgba\(0\2c 0\2c 0\2c 0\.1\)\]{box-shadow:3px 3px 0px rgba(0,0,0,0.1)}
.shadow-\[3px_3px_0px_rgba\(0\2c 0\2c 0\2c 0\.15\)\]{box-shadow:3px 3px 0px rgba(0,0,0,0.15)}
.shadow-\[4px_4px_0px_rgba\(0\2c 0\2c 0\2c 0\.15\)\]{box-shadow:4px 4px 0px rgba(0,0,0,0.15)}
.shadow-\[5px_5px_0px_rgba\(0\2c 0\2c 0\2c 0\.15\)\]{box-shadow:5px 5px 0px rgba(0,0,0,0.15)}

/* ===== Overflow ===== */
.overflow-hidden{overflow:hidden}
.overflow-y-auto{overflow-y:auto}
.overflow-x-auto{overflow-x:auto}

/* ===== Object Fit ===== */
.object-cover{object-fit:cover}
.object-contain{object-fit:contain}

/* ===== Aspect Ratio ===== */
.aspect-video{aspect-ratio:16/9}
.aspect-square{aspect-ratio:1/1}
.aspect-\[3\/4\]{aspect-ratio:3/4}

/* ===== Opacity ===== */
.opacity-0{opacity:0}
.opacity-50{opacity:0.5}
.opacity-75{opacity:0.75}

/* ===== Cursor ===== */
.cursor-pointer{cursor:pointer}
.cursor-grab{cursor:grab}
.cursor-default{cursor:default}
.cursor-not-allowed{cursor:not-allowed}

/* ===== Pointer Events ===== */
.pointer-events-none{pointer-events:none}

/* ===== User Select ===== */
.select-none{user-select:none}

/* ===== 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-opacity{transition-property:opacity;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}

/* ===== Transform ===== */
.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}

/* ===== Hover States ===== */
.hover\:underline:hover{text-decoration-line:underline}
.hover\:bg-red-200:hover{background-color:#fecaca}
.hover\:bg-gray-100:hover{background-color:#f3f4f6}
.hover\:bg-retro-warm:hover{background-color:#E8DCC8}
.hover\:text-retro-accent:hover{color:#5B7B5E}
.hover\:opacity-80:hover{opacity:0.8}

/* ===== Important Overrides (!) ===== */
.\!w-5{width:1.25rem!important}
.\!w-6{width:1.5rem!important}
.\!w-7{width:1.75rem!important}
.\!h-5{height:1.25rem!important}
.\!h-6{height:1.5rem!important}
.\!h-7{height:1.75rem!important}
.\!py-1\.5{padding-top:0.375rem!important;padding-bottom:0.375rem!important}
.\!cursor-default{cursor:default!important}

/* ===== Responsive: sm (min-width: 640px) ===== */
@media(min-width:640px){
  .sm\:flex{display:flex}
  .sm\:hidden{display:none}
  .sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .sm\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
  .sm\:p-8{padding:2rem}
  .sm\:p-10{padding:2.5rem}
  .sm\:text-2xl{font-size:1.5rem;line-height:2rem}
  .sm\:text-3xl{font-size:1.875rem;line-height:2.25rem}
  .sm\:text-xl{font-size:1.25rem;line-height:1.75rem}
}

/* ===== Responsive: md (min-width: 768px) ===== */
@media(min-width:768px){
  .md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
  .md\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}
}

/* ===== Responsive: lg (min-width: 1024px) ===== */
@media(min-width:1024px){
  .lg\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}
}
