/* ─────────────────────────────────────────────────────────────
   WuClock — Hand-compiled Tailwind utilities
   Replaces the 3 MB Tailwind Play CDN with ~12 KB of static CSS
   containing only the classes the site actually uses.
   ───────────────────────────────────────────────────────────── */

*, ::before, ::after { box-sizing: border-box; border: 0 solid #e5e7eb; }
*, ::before, ::after { --tw-content: ''; }

html { line-height: 1.5; -webkit-text-size-adjust: 100%; tab-size: 4;
  font-family: ui-sans-serif, system-ui, sans-serif; }
body { margin: 0; line-height: inherit; }
h1, h2, h3, h4, h5, h6 { font-size: inherit; font-weight: inherit; margin: 0; }
p, ul, ol { margin: 0; padding: 0; }
ul, ol { list-style: none; }
button { background-color: transparent; background-image: none; padding: 0;
  font-family: inherit; font-size: 100%; font-weight: inherit; line-height: inherit;
  color: inherit; margin: 0; text-transform: none; cursor: pointer; }
button, [type='button'] { -webkit-appearance: button; }
a { color: inherit; text-decoration: inherit; }
img, svg, video { display: block; vertical-align: middle; max-width: 100%; height: auto; }
[hidden] { display: none; }

/* Custom font families used in tailwind.config */
.font-heading { font-family: "Instrument Serif", serif; }
.font-body    { font-family: "Barlow", sans-serif; }

/* Display */
.block { display: block; }
.flex { display: flex; }
.inline-flex { display: inline-flex; }
.grid { display: grid; }
.hidden { display: none; }

/* Position */
.relative { position: relative; }
.absolute { position: absolute; }
.fixed { position: fixed; }

.inset-0 { inset: 0; }
.top-0 { top: 0; }
.top-4 { top: 1rem; }
.top-1\/2 { top: 50%; }
.top-full { top: 100%; }
.left-0 { left: 0; }
.left-1\/2 { left: 50%; }
.right-0 { right: 0; }
.right-4 { right: 1rem; }

/* z-index */
.z-0 { z-index: 0; }
.z-10 { z-index: 10; }
.z-\[100\] { z-index: 100; }

/* Flex / grid */
.flex-1 { flex: 1 1 0%; }
.flex-col { flex-direction: column; }
.flex-wrap { flex-wrap: wrap; }
.shrink-0 { flex-shrink: 0; }
.items-baseline { align-items: baseline; }
.items-center { align-items: center; }
.items-start  { align-items: flex-start; }
.items-stretch { align-items: stretch; }
.self-start { align-self: flex-start; }
.self-stretch { align-self: stretch; }
.justify-around { justify-content: space-around; }
.justify-between { justify-content: space-between; }
.justify-center { justify-content: center; }
.justify-self-center { justify-self: center; }
.grid-cols-1 { grid-template-columns: repeat(1, minmax(0, 1fr)); }
.grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }

/* Gap */
.gap-1   { gap: 0.25rem; }
.gap-1\.5 { gap: 0.375rem; }
.gap-2   { gap: 0.5rem; }
.gap-3   { gap: 0.75rem; }
.gap-4   { gap: 1rem; }
.gap-6   { gap: 1.5rem; }
.gap-10  { gap: 2.5rem; }
.gap-12  { gap: 3rem; }

/* Width / height */
.w-px   { width: 1px; }
.w-4    { width: 1rem; }
.w-5    { width: 1.25rem; }
.w-9    { width: 2.25rem; }
.w-10   { width: 2.5rem; }
.w-11   { width: 2.75rem; }
.w-auto { width: auto; }
.w-full { width: 100%; }
.w-\[220px\] { width: 220px; }

.h-4    { height: 1rem; }
.h-5    { height: 1.25rem; }
.h-9    { height: 2.25rem; }
.h-10   { height: 2.5rem; }
.h-11   { height: 2.75rem; }
.h-20   { height: 5rem; }
.h-28   { height: 7rem; }
.h-full   { height: 100%; }
.h-screen { height: 100vh; }
.min-h-screen { min-height: 100vh; }
.min-h-\[440px\] { min-height: 440px; }

.max-w-2xl { max-width: 42rem; }
.max-w-3xl { max-width: 48rem; }
.max-w-md  { max-width: 28rem; }
.max-w-xl  { max-width: 36rem; }
.max-w-xs  { max-width: 20rem; }
.max-w-\[34ch\] { max-width: 34ch; }
.max-w-\[560px\] { max-width: 560px; }

.aspect-square { aspect-ratio: 1 / 1; }

/* Spacing */
.p-3   { padding: 0.75rem; }
.p-5   { padding: 1.25rem; }
.p-7   { padding: 1.75rem; }
.p-8   { padding: 2rem; }

.px-1\.5 { padding-left: 0.375rem; padding-right: 0.375rem; }
.px-3 { padding-left: 0.75rem; padding-right: 0.75rem; }
.px-3\.5 { padding-left: 0.875rem; padding-right: 0.875rem; }
.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-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-6 { padding-top: 1.5rem; padding-bottom: 1.5rem; }
.py-28 { padding-top: 7rem; padding-bottom: 7rem; }

.pl-1 { padding-left: 0.25rem; }
.pr-3 { padding-right: 0.75rem; }
.pt-8 { padding-top: 2rem; }
.pt-20 { padding-top: 5rem; }
.pt-24 { padding-top: 6rem; }
.pb-8 { padding-bottom: 2rem; }
.pb-10 { padding-bottom: 2.5rem; }
.pb-24 { padding-bottom: 6rem; }

.mt-1 { margin-top: 0.25rem; }
.mt-2 { margin-top: 0.5rem; }
.mt-3 { margin-top: 0.75rem; }
.mt-4 { margin-top: 1rem; }
.mt-5 { margin-top: 1.25rem; }
.mt-6 { margin-top: 1.5rem; }
.mt-7 { margin-top: 1.75rem; }
.mt-8 { margin-top: 2rem; }
.mt-10 { margin-top: 2.5rem; }
.mt-12 { margin-top: 3rem; }
.mt-14 { margin-top: 3.5rem; }
.mt-16 { margin-top: 4rem; }
.mt-auto { margin-top: auto; }
.mb-6 { margin-bottom: 1.5rem; }
.mb-8 { margin-bottom: 2rem; }
.mb-auto { margin-bottom: auto; }
.ml-1 { margin-left: 0.25rem; }
.ml-auto { margin-left: auto; }
.mx-2 { margin-left: 0.5rem; margin-right: 0.5rem; }

.col-span-2 { grid-column: span 2 / span 2; }
.scroll-mt-24 { scroll-margin-top: 6rem; }

/* Typography */
.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-2xl   { font-size: 1.5rem; line-height: 2rem; }
.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; }
.text-\[10px\] { font-size: 10px; }
.text-\[11px\] { font-size: 11px; }
.text-\[15px\] { font-size: 15px; }

.font-light    { font-weight: 300; }
.font-medium   { font-weight: 500; }
.font-semibold { font-weight: 600; }

.italic { font-style: italic; }
.uppercase { text-transform: uppercase; }
.text-center { text-align: center; }
.text-left { text-align: left; }
.leading-none { line-height: 1; }
.leading-tight { line-height: 1.25; }
.leading-snug { line-height: 1.375; }
.leading-relaxed { line-height: 1.625; }

.whitespace-nowrap { white-space: nowrap; }

/* Colors — text */
.text-white         { color: rgb(255 255 255); }
.text-black         { color: rgb(0 0 0); }
.text-white\/90     { color: rgb(255 255 255 / 0.9); }
.text-white\/85     { color: rgb(255 255 255 / 0.85); }
.text-white\/80     { color: rgb(255 255 255 / 0.8); }
.text-white\/70     { color: rgb(255 255 255 / 0.7); }
.text-white\/65     { color: rgb(255 255 255 / 0.65); }
.text-white\/60     { color: rgb(255 255 255 / 0.6); }
.text-white\/55     { color: rgb(255 255 255 / 0.55); }
.text-white\/45     { color: rgb(255 255 255 / 0.45); }
.text-white\/40     { color: rgb(255 255 255 / 0.4); }
.text-white\/35     { color: rgb(255 255 255 / 0.35); }
.text-white\/20     { color: rgb(255 255 255 / 0.2); }
.text-\[\#D4A852\]  { color: #D4A852; }

/* Colors — background */
.bg-black { background-color: rgb(0 0 0); }
.bg-white { background-color: rgb(255 255 255); }

/* Borders */
.border-t { border-top-width: 1px; }
.border-white\/10 { border-color: rgb(255 255 255 / 0.1); }

.rounded-full { border-radius: 9999px; }
.rounded-2xl  { border-radius: 1rem; }
.rounded-3xl  { border-radius: 1.5rem; }

/* Object */
.object-cover { object-fit: cover; }
.object-top   { object-position: top; }

/* Overflow */
.overflow-hidden { overflow: hidden; }

/* Pointer / interaction */
.pointer-events-none { pointer-events: none; }
.cursor-pointer      { cursor: pointer; }
.select-none         { user-select: none; }

/* Transforms */
.-translate-x-1\/2 { --tw-translate-x: -50%; 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)); }
.-translate-y-1\/2 { --tw-translate-y: -50%; 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)); }
.-translate-x-1\/2.-translate-y-1\/2 { transform: translate(-50%, -50%); }

/* Transitions */
.transition-colors {
  transition-property: color, background-color, border-color, fill, stroke;
  transition-duration: 150ms;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

/* Group hover (used in nav-button hover effects) */
.group:hover .group-hover\:text-white\/80 { color: rgb(255 255 255 / 0.8); }

/* Hover states */
.hover\:bg-white\/5:hover    { background-color: rgb(255 255 255 / 0.05); }
.hover\:bg-white\/90:hover   { background-color: rgb(255 255 255 / 0.9); }
.hover\:text-white:hover     { color: rgb(255 255 255); }
.hover\:text-white\/80:hover { color: rgb(255 255 255 / 0.8); }

/* ────────── Responsive: sm (640px) ────────── */
@media (min-width: 640px) {
  .sm\:flex-row { flex-direction: row; }
}

/* ────────── Responsive: md (768px) ────────── */
@media (min-width: 768px) {
  .md\:block      { display: block; }
  .md\:flex       { display: flex; }
  .md\:hidden     { display: none; }
  .md\:flex-row   { flex-direction: row; }
  .md\:gap-0      { gap: 0; }
  .md\:gap-12     { gap: 3rem; }
  .md\:gap-16     { gap: 4rem; }
  .md\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .md\:grid-cols-5 { grid-template-columns: repeat(5, minmax(0, 1fr)); }
  .md\:items-center { align-items: center; }
  .md\:p-9        { padding: 2.25rem; }
  .md\:p-10       { padding: 2.5rem; }
  .md\:px-16      { padding-left: 4rem; padding-right: 4rem; }
  .md\:py-5       { padding-top: 1.25rem; padding-bottom: 1.25rem; }
  .md\:py-36      { padding-top: 9rem; padding-bottom: 9rem; }
  .md\:text-3xl   { font-size: 1.875rem; line-height: 2.25rem; }
  .md\:text-6xl   { font-size: 3.75rem; line-height: 1; }
  .md\:text-7xl   { font-size: 4.5rem; line-height: 1; }
  .md\:text-base  { font-size: 1rem; line-height: 1.5rem; }
  .md\:text-lg    { font-size: 1.125rem; line-height: 1.75rem; }
}

/* ────────── Responsive: lg (1024px) ────────── */
@media (min-width: 1024px) {
  .lg\:gap-14         { gap: 3.5rem; }
  .lg\:grid-cols-\[1\.05fr_0\.95fr\] { grid-template-columns: 1.05fr 0.95fr; }
  .lg\:px-16          { padding-left: 4rem; padding-right: 4rem; }
  .lg\:px-20          { padding-left: 5rem; padding-right: 5rem; }
  .lg\:text-\[5\.5rem\] { font-size: 5.5rem; line-height: 1; }
  .lg\:text-\[6rem\]    { font-size: 6rem; line-height: 1; }
}
