/* style.css — stripped by skeleton script */
/* Only CSS custom properties and minimal base retained */

:root {
	--font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
	--font-serif: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif;
	--font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;

	--color-red-50: oklch(97.1% 0.013 17.38);
	--color-red-100: oklch(93.6% 0.032 17.717);
	--color-red-200: oklch(88.5% 0.062 18.334);
	--color-red-300: oklch(80.8% 0.114 19.571);
	--color-red-400: oklch(70.4% 0.191 22.216);
	--color-red-500: oklch(63.7% 0.237 25.331);
	--color-red-600: oklch(57.7% 0.245 27.325);
	--color-red-700: oklch(50.5% 0.213 27.518);
	--color-red-800: oklch(44.4% 0.177 26.899);
	--color-red-900: oklch(39.6% 0.141 25.723);
	--color-red-950: oklch(25.8% 0.092 26.042);
	--color-orange-50: oklch(98% 0.016 73.684);
	--color-orange-100: oklch(95.4% 0.038 75.164);
	--color-orange-200: oklch(90.1% 0.076 70.697);
	--color-orange-300: oklch(83.7% 0.128 66.29);
	--color-orange-400: oklch(75% 0.183 55.934);
	--color-orange-500: oklch(70.5% 0.213 47.604);
	--color-orange-600: oklch(64.6% 0.222 41.116);
	--color-orange-700: oklch(55.3% 0.195 38.402);
	--color-orange-800: oklch(47% 0.157 37.304);
	--color-orange-900: oklch(40.8% 0.123 38.172);
	--color-orange-950: oklch(26.6% 0.079 36.259);
	--color-amber-50: oklch(98.7% 0.022 95.277);
	--color-amber-100: oklch(96.2% 0.059 95.617);
	--color-amber-200: oklch(92.4% 0.12 95.746);
	--color-amber-300: oklch(87.9% 0.169 91.605);
	--color-amber-400: oklch(82.8% 0.189 84.429);
	--color-amber-500: oklch(76.9% 0.188 70.08);
	--color-amber-600: oklch(66.6% 0.179 58.318);
	--color-amber-700: oklch(55.5% 0.163 48.998);
	--color-amber-800: oklch(47.3% 0.137 46.201);
	--color-amber-900: oklch(41.4% 0.112 45.904);
	--color-amber-950: oklch(27.9% 0.077 45.635);
	--color-yellow-50: oklch(98.7% 0.026 102.212);
	--color-yellow-100: oklch(97.3% 0.071 103.193);
	--color-yellow-200: oklch(94.5% 0.129 101.54);
	--color-yellow-300: oklch(90.5% 0.182 98.111);
	--color-yellow-400: oklch(85.2% 0.199 91.936);
	--color-yellow-500: oklch(79.5% 0.184 86.047);
	--color-yellow-600: oklch(68.1% 0.162 75.834);
	--color-yellow-700: oklch(55.4% 0.135 66.442);
	--color-yellow-800: oklch(47.6% 0.114 61.907);
	--color-yellow-900: oklch(42.1% 0.095 57.708);
	--color-yellow-950: oklch(28.6% 0.066 53.813);
	--color-lime-50: oklch(98.6% 0.031 120.757);
	--color-lime-100: oklch(96.7% 0.067 122.328);
	--color-lime-200: oklch(93.8% 0.127 124.321);
	--color-lime-300: oklch(89.7% 0.196 126.665);
	--color-lime-400: oklch(84.1% 0.238 128.85);
	--color-lime-500: oklch(76.8% 0.233 130.85);
	--color-lime-600: oklch(64.8% 0.2 131.684);
	--color-lime-700: oklch(53.2% 0.157 131.589);
	--color-lime-800: oklch(45.3% 0.124 130.933);
	--color-lime-900: oklch(40.5% 0.101 131.063);
	--color-lime-950: oklch(27.4% 0.072 132.109);
	--color-green-50: oklch(98.2% 0.018 155.826);
	--color-green-100: oklch(96.2% 0.044 156.743);
	--color-green-200: oklch(92.5% 0.084 155.995);
	--color-green-300: oklch(87.1% 0.15 154.449);
	--color-green-400: oklch(79.2% 0.209 151.711);
	--color-green-500: oklch(72.3% 0.219 149.579);
	--color-green-600: oklch(62.7% 0.194 149.214);
	--color-green-700: oklch(52.7% 0.154 150.069);
	--color-green-800: oklch(44.8% 0.119 151.328);
	--color-green-900: oklch(39.3% 0.095 152.535);
	--color-green-950: oklch(26.6% 0.065 152.934);
	--color-emerald-50: oklch(97.9% 0.021 166.113);
	--color-emerald-100: oklch(95% 0.052 163.051);
	--color-emerald-200: oklch(90.5% 0.093 164.15);
	--color-emerald-300: oklch(84.5% 0.143 164.978);
	--color-emerald-400: oklch(76.5% 0.177 163.223);
	--color-emerald-500: oklch(69.6% 0.17 162.48);
	--color-emerald-600: oklch(59.6% 0.145 163.225);
	--color-emerald-700: oklch(50.8% 0.118 165.612);
	--color-emerald-800: oklch(43.2% 0.095 166.913);
	--color-emerald-900: oklch(37.8% 0.077 168.94);
	--color-emerald-950: oklch(26.2% 0.051 172.552);
	--color-teal-50: oklch(98.4% 0.014 180.72);
	--color-teal-100: oklch(95.3% 0.051 180.801);
	--color-teal-200: oklch(91% 0.096 180.426);
	--color-teal-300: oklch(85.5% 0.138 181.071);
	--color-teal-400: oklch(77.7% 0.152 181.912);
	--color-teal-500: oklch(70.4% 0.14 182.503);
	--color-teal-600: oklch(60% 0.118 184.704);
	--color-teal-700: oklch(51.1% 0.096 186.391);
	--color-teal-800: oklch(43.7% 0.078 188.216);
	--color-teal-900: oklch(38.6% 0.063 188.416);
	--color-teal-950: oklch(27.7% 0.046 192.524);
	--color-cyan-50: oklch(98.4% 0.019 200.873);
	--color-cyan-100: oklch(95.6% 0.045 203.388);
	--color-cyan-200: oklch(91.7% 0.08 205.041);
	--color-cyan-300: oklch(86.5% 0.127 207.078);
	--color-cyan-400: oklch(78.9% 0.154 211.53);
	--color-cyan-500: oklch(71.5% 0.143 215.221);
	--color-cyan-600: oklch(60.9% 0.126 221.723);
	--color-cyan-700: oklch(52% 0.105 223.128);
	--color-cyan-800: oklch(45% 0.085 224.283);
	--color-cyan-900: oklch(39.8% 0.07 227.392);
	--color-cyan-950: oklch(30.2% 0.056 229.695);
	--color-sky-50: oklch(97.7% 0.013 236.62);
	--color-sky-100: oklch(95.1% 0.026 236.824);
	--color-sky-200: oklch(90.1% 0.058 230.902);
	--color-sky-300: oklch(82.8% 0.111 230.318);
	--color-sky-400: oklch(74.6% 0.16 232.661);
	--color-sky-500: oklch(68.5% 0.169 237.323);
	--color-sky-600: oklch(58.8% 0.158 241.966);
	--color-sky-700: oklch(50% 0.134 242.749);
	--color-sky-800: oklch(44.3% 0.11 240.79);
	--color-sky-900: oklch(39.1% 0.09 240.876);
	--color-sky-950: oklch(29.3% 0.066 243.157);
	--color-blue-50: oklch(97% 0.014 254.604);
	--color-blue-100: oklch(93.2% 0.032 255.585);
	--color-blue-200: oklch(88.2% 0.059 254.128);
	--color-blue-300: oklch(80.9% 0.105 251.813);
	--color-blue-400: oklch(70.7% 0.165 254.624);
	--color-blue-500: oklch(62.3% 0.214 259.815);
	--color-blue-600: oklch(54.6% 0.245 262.881);
	--color-blue-700: oklch(48.8% 0.243 264.376);
	--color-blue-800: oklch(42.4% 0.199 265.638);
	--color-blue-900: oklch(37.9% 0.146 265.522);
	--color-blue-950: oklch(28.2% 0.091 267.935);
	--color-indigo-50: oklch(96.2% 0.018 272.314);
	--color-indigo-100: oklch(93% 0.034 272.788);
	--color-indigo-200: oklch(87% 0.065 274.039);
	--color-indigo-300: oklch(78.5% 0.115 274.713);
	--color-indigo-400: oklch(67.3% 0.182 276.935);
	--color-indigo-500: oklch(58.5% 0.233 277.117);
	--color-indigo-600: oklch(51.1% 0.262 276.966);
	--color-indigo-700: oklch(45.7% 0.24 277.023);
	--color-indigo-800: oklch(39.8% 0.195 277.366);
	--color-indigo-900: oklch(35.9% 0.144 278.697);
	--color-indigo-950: oklch(25.7% 0.09 281.288);
	--color-violet-50: oklch(96.9% 0.016 293.756);
	--color-violet-100: oklch(94.3% 0.029 294.588);
	--color-violet-200: oklch(89.4% 0.057 293.283);
	--color-violet-300: oklch(81.1% 0.111 293.571);
	--color-violet-400: oklch(70.2% 0.183 293.541);
	--color-violet-500: oklch(60.6% 0.25 292.717);
	--color-violet-600: oklch(54.1% 0.281 293.009);
	--color-violet-700: oklch(49.1% 0.27 292.581);
	--color-violet-800: oklch(43.2% 0.232 292.759);
	--color-violet-900: oklch(38% 0.189 293.745);
	--color-violet-950: oklch(28.3% 0.141 291.089);
	--color-purple-50: oklch(97.7% 0.014 308.299);
	--color-purple-100: oklch(94.6% 0.033 307.174);
	--color-purple-200: oklch(90.2% 0.063 306.703);
	--color-purple-300: oklch(82.7% 0.119 306.383);
	--color-purple-400: oklch(71.4% 0.203 305.504);
	--color-purple-500: oklch(62.7% 0.265 303.9);
	--color-purple-600: oklch(55.8% 0.288 302.321);
	--color-purple-700: oklch(49.6% 0.265 301.924);
	--color-purple-800: oklch(43.8% 0.218 303.724);
	--color-purple-900: oklch(38.1% 0.176 304.987);
	--color-purple-950: oklch(29.1% 0.149 302.717);
	--color-fuchsia-50: oklch(97.7% 0.017 320.058);
	--color-fuchsia-100: oklch(95.2% 0.037 318.852);
	--color-fuchsia-200: oklch(90.3% 0.076 319.62);
	--color-fuchsia-300: oklch(83.3% 0.145 321.434);
	--color-fuchsia-400: oklch(74% 0.238 322.16);
	--color-fuchsia-500: oklch(66.7% 0.295 322.15);
	--color-fuchsia-600: oklch(59.1% 0.293 322.896);
	--color-fuchsia-700: oklch(51.8% 0.253 323.949);
	--color-fuchsia-800: oklch(45.2% 0.211 324.591);
	--color-fuchsia-900: oklch(40.1% 0.17 325.612);
	--color-fuchsia-950: oklch(29.3% 0.136 325.661);
	--color-pink-50: oklch(97.1% 0.014 343.198);
	--color-pink-100: oklch(94.8% 0.028 342.258);
	--color-pink-200: oklch(89.9% 0.061 343.231);
	--color-pink-300: oklch(82.3% 0.12 346.018);
	--color-pink-400: oklch(71.8% 0.202 349.761);
	--color-pink-500: oklch(65.6% 0.241 354.308);
	--color-pink-600: oklch(59.2% 0.249 0.584);
	--color-pink-700: oklch(52.5% 0.223 3.958);
	--color-pink-800: oklch(45.9% 0.187 3.815);
	--color-pink-900: oklch(40.8% 0.153 2.432);
	--color-pink-950: oklch(28.4% 0.109 3.907);
	--color-rose-50: oklch(96.9% 0.015 12.422);
	--color-rose-100: oklch(94.1% 0.03 12.58);
	--color-rose-200: oklch(89.2% 0.058 10.001);
	--color-rose-300: oklch(81% 0.117 11.638);
	--color-rose-400: oklch(71.2% 0.194 13.428);
	--color-rose-500: oklch(64.5% 0.246 16.439);
	--color-rose-600: oklch(58.6% 0.253 17.585);
	--color-rose-700: oklch(51.4% 0.222 16.935);
	--color-rose-800: oklch(45.5% 0.188 13.697);
	--color-rose-900: oklch(41% 0.159 10.272);
	--color-rose-950: oklch(27.1% 0.105 12.094);
	--color-slate-50: oklch(98.4% 0.003 247.858);
	--color-slate-100: oklch(96.8% 0.007 247.896);
	--color-slate-200: oklch(92.9% 0.013 255.508);
	--color-slate-300: oklch(86.9% 0.022 252.894);
	--color-slate-400: oklch(70.4% 0.04 256.788);
	--color-slate-500: oklch(55.4% 0.046 257.417);
	--color-slate-600: oklch(44.6% 0.043 257.281);
	--color-slate-700: oklch(37.2% 0.044 257.287);
	--color-slate-800: oklch(27.9% 0.041 260.031);
	--color-slate-900: oklch(20.8% 0.042 265.755);
	--color-slate-950: oklch(12.9% 0.042 264.695);
	--color-gray-50: oklch(98.5% 0.002 247.839);
	--color-gray-100: oklch(96.7% 0.003 264.542);
	--color-gray-200: oklch(92.8% 0.006 264.531);
	--color-gray-300: oklch(87.2% 0.01 258.338);
	--color-gray-400: oklch(70.7% 0.022 261.325);
	--color-gray-500: oklch(55.1% 0.027 264.364);
	--color-gray-600: oklch(44.6% 0.03 256.802);
	--color-gray-700: oklch(37.3% 0.034 259.733);
	--color-gray-800: oklch(27.8% 0.033 256.848);
	--color-gray-900: oklch(21% 0.034 264.665);
	--color-gray-950: oklch(13% 0.028 261.692);
	--color-zinc-50: oklch(98.5% 0 0);
	--color-zinc-100: oklch(96.7% 0.001 286.375);
	--color-zinc-200: oklch(92% 0.004 286.32);
	--color-zinc-300: oklch(87.1% 0.006 286.286);
	--color-zinc-400: oklch(70.5% 0.015 286.067);
	--color-zinc-500: oklch(55.2% 0.016 285.938);
	--color-zinc-600: oklch(44.2% 0.017 285.786);
	--color-zinc-700: oklch(37% 0.013 285.805);
	--color-zinc-800: oklch(27.4% 0.006 286.033);
	--color-zinc-900: oklch(21% 0.006 285.885);
	--color-zinc-950: oklch(14.1% 0.005 285.823);
	--color-neutral-50: oklch(98.5% 0 0);
	--color-neutral-100: oklch(97% 0 0);
	--color-neutral-200: oklch(92.2% 0 0);
	--color-neutral-300: oklch(87% 0 0);
	--color-neutral-400: oklch(70.8% 0 0);
	--color-neutral-500: oklch(55.6% 0 0);
	--color-neutral-600: oklch(43.9% 0 0);
	--color-neutral-700: oklch(37.1% 0 0);
	--color-neutral-800: oklch(26.9% 0 0);
	--color-neutral-900: oklch(20.5% 0 0);
	--color-neutral-950: oklch(14.5% 0 0);
	--color-stone-50: oklch(98.5% 0.001 106.423);
	--color-stone-100: oklch(97% 0.001 106.424);
	--color-stone-200: oklch(92.3% 0.003 48.717);
	--color-stone-300: oklch(86.9% 0.005 56.366);
	--color-stone-400: oklch(70.9% 0.01 56.259);
	--color-stone-500: oklch(55.3% 0.013 58.071);
	--color-stone-600: oklch(44.4% 0.011 73.639);
	--color-stone-700: oklch(37.4% 0.01 67.558);
	--color-stone-800: oklch(26.8% 0.007 34.298);
	--color-stone-900: oklch(21.6% 0.006 56.043);
	--color-stone-950: oklch(14.7% 0.004 49.25);
	--color-mauve-50: oklch(98.5% 0 0);
	--color-mauve-100: oklch(96% 0.003 325.6);
	--color-mauve-200: oklch(92.2% 0.005 325.62);
	--color-mauve-300: oklch(86.5% 0.012 325.68);
	--color-mauve-400: oklch(71.1% 0.019 323.02);
	--color-mauve-500: oklch(54.2% 0.034 322.5);
	--color-mauve-600: oklch(43.5% 0.029 321.78);
	--color-mauve-700: oklch(36.4% 0.029 323.89);
	--color-mauve-800: oklch(26.3% 0.024 320.12);
	--color-mauve-900: oklch(21.2% 0.019 322.12);
	--color-mauve-950: oklch(14.5% 0.008 326);
	--color-olive-50: oklch(98.8% 0.003 106.5);
	--color-olive-100: oklch(96.6% 0.005 106.5);
	--color-olive-200: oklch(93% 0.007 106.5);
	--color-olive-300: oklch(88% 0.011 106.6);
	--color-olive-400: oklch(73.7% 0.021 106.9);
	--color-olive-500: oklch(58% 0.031 107.3);
	--color-olive-600: oklch(46.6% 0.025 107.3);
	--color-olive-700: oklch(39.4% 0.023 107.4);
	--color-olive-800: oklch(28.6% 0.016 107.4);
	--color-olive-900: oklch(22.8% 0.013 107.4);
	--color-olive-950: oklch(15.3% 0.006 107.1);
	--color-mist-50: oklch(98.7% 0.002 197.1);
	--color-mist-100: oklch(96.3% 0.002 197.1);
	--color-mist-200: oklch(92.5% 0.005 214.3);
	--color-mist-300: oklch(87.2% 0.007 219.6);
	--color-mist-400: oklch(72.3% 0.014 214.4);
	--color-mist-500: oklch(56% 0.021 213.5);
	--color-mist-600: oklch(45% 0.017 213.2);
	--color-mist-700: oklch(37.8% 0.015 216);
	--color-mist-800: oklch(27.5% 0.011 216.9);
	--color-mist-900: oklch(21.8% 0.008 223.9);
	--color-mist-950: oklch(14.8% 0.004 228.8);
	--color-taupe-50: oklch(98.6% 0.002 67.8);
	--color-taupe-100: oklch(96% 0.002 17.2);
	--color-taupe-200: oklch(92.2% 0.005 34.3);
	--color-taupe-300: oklch(86.8% 0.007 39.5);
	--color-taupe-400: oklch(71.4% 0.014 41.2);
	--color-taupe-500: oklch(54.7% 0.021 43.1);
	--color-taupe-600: oklch(43.8% 0.017 39.3);
	--color-taupe-700: oklch(36.7% 0.016 35.7);
	--color-taupe-800: oklch(26.8% 0.011 36.5);
	--color-taupe-900: oklch(21.4% 0.009 43.1);
	--color-taupe-950: oklch(14.7% 0.004 49.3);
	--color-black: #000;
	--color-white: #fff;
	--spacing: 0.25rem;
	--breakpoint-sm: 40rem;
	--breakpoint-md: 48rem;
	--breakpoint-lg: 64rem;
	--breakpoint-xl: 80rem;
	--breakpoint-2xl: 96rem;
	--container-3xs: 16rem;
	--container-2xs: 18rem;
	--container-xs: 20rem;
	--container-sm: 24rem;
	--container-md: 28rem;
	--container-lg: 32rem;
	--container-xl: 36rem;
	--container-2xl: 42rem;
	--container-3xl: 48rem;
	--container-4xl: 56rem;
	--container-5xl: 64rem;
	--container-6xl: 72rem;
	--container-7xl: 80rem;
	--text-xs: 0.75rem;
	--text-xs--line-height: calc(1 / 0.75);
	--text-sm: 0.875rem;
	--text-sm--line-height: calc(1.25 / 0.875);
	--text-base: 1rem;
	--text-base--line-height: calc(1.5 / 1);
	--text-lg: 1.125rem;
	--text-lg--line-height: calc(1.75 / 1.125);
	--text-xl: 1.25rem;
	--text-xl--line-height: calc(1.75 / 1.25);
	--text-2xl: 1.5rem;
	--text-2xl--line-height: calc(2 / 1.5);
	--text-3xl: 1.875rem;
	--text-3xl--line-height: calc(2.25 / 1.875);
	--text-4xl: 2.25rem;
	--text-4xl--line-height: calc(2.5 / 2.25);
	--text-5xl: 3rem;
	--text-5xl--line-height: 1;
	--text-6xl: 3.75rem;
	--text-6xl--line-height: 1;
	--text-7xl: 4.5rem;
	--text-7xl--line-height: 1;
	--text-8xl: 6rem;
	--text-8xl--line-height: 1;
	--text-9xl: 8rem;
	--text-9xl--line-height: 1;
	--font-weight-thin: 100;
	--font-weight-extralight: 200;
	--font-weight-light: 300;
	--font-weight-normal: 400;
	--font-weight-medium: 500;
	--font-weight-semibold: 600;
	--font-weight-bold: 700;
	--font-weight-extrabold: 800;
	--font-weight-black: 900;
	--tracking-tighter: -0.05em;
	--tracking-tight: -0.025em;
	--tracking-normal: 0em;
	--tracking-wide: 0.025em;
	--tracking-wider: 0.05em;
	--tracking-widest: 0.1em;
	--leading-tight: 1.25;
	--leading-snug: 1.375;
	--leading-normal: 1.5;
	--leading-relaxed: 1.625;
	--leading-loose: 2;
	--radius-xs: 0.125rem;
	--radius-sm: 0.25rem;
	--radius-md: 0.375rem;
	--radius-lg: 0.5rem;
	--radius-xl: 0.75rem;
	--radius-2xl: 1rem;
	--radius-3xl: 1.5rem;
	--radius-4xl: 2rem;
	--shadow-2xs: 0 1px rgb(0 0 0 / 0.05);
	--shadow-xs: 0 1px 2px 0 rgb(0 0 0 / 0.05);
	--shadow-sm: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
	--shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
	--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
	--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
	--shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / 0.25);
	--inset-shadow-2xs: inset 0 1px rgb(0 0 0 / 0.05);
	--inset-shadow-xs: inset 0 1px 1px rgb(0 0 0 / 0.05);
	--inset-shadow-sm: inset 0 2px 4px rgb(0 0 0 / 0.05);
	--drop-shadow-xs: 0 1px 1px rgb(0 0 0 / 0.05);
	--drop-shadow-sm: 0 1px 2px rgb(0 0 0 / 0.15);
	--drop-shadow-md: 0 3px 3px rgb(0 0 0 / 0.12);
	--drop-shadow-lg: 0 4px 4px rgb(0 0 0 / 0.15);
	--drop-shadow-xl: 0 9px 7px rgb(0 0 0 / 0.1);
	--drop-shadow-2xl: 0 25px 25px rgb(0 0 0 / 0.15);
	--text-shadow-2xs: 0px 1px 0px rgb(0 0 0 / 0.15);
	--text-shadow-xs: 0px 1px 1px rgb(0 0 0 / 0.2);
	--text-shadow-sm: 0px 1px 0px rgb(0 0 0 / 0.075), 0px 1px 1px rgb(0 0 0 / 0.075), 0px 2px 2px rgb(0 0 0 / 0.075);
	--text-shadow-md: 0px 1px 1px rgb(0 0 0 / 0.1), 0px 1px 2px rgb(0 0 0 / 0.1), 0px 2px 4px rgb(0 0 0 / 0.1);
	--text-shadow-lg: 0px 1px 2px rgb(0 0 0 / 0.1), 0px 3px 2px rgb(0 0 0 / 0.1), 0px 4px 8px rgb(0 0 0 / 0.1);
	--blur-xs: 4px;
	--blur-sm: 8px;
	--blur-md: 12px;
	--blur-lg: 16px;
	--blur-xl: 24px;
	--blur-2xl: 40px;
	--blur-3xl: 64px;
	--perspective-dramatic: 100px;
	--perspective-near: 300px;
	--perspective-normal: 500px;
	--perspective-midrange: 800px;
	--perspective-distant: 1200px;
	--aspect-video: 16 / 9;
	--ease-in: cubic-bezier(0.4, 0, 1, 1);
	--ease-out: cubic-bezier(0, 0, 0.2, 1);
	--ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
	--animate-spin: spin 1s linear infinite;
	--animate-ping: ping 1s cubic-bezier(0, 0, 0.2, 1) infinite;
	--animate-pulse: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
	--animate-bounce: bounce 1s infinite;

	@keyframes spin {
		to {
			transform: rotate(360deg);
		}
	}

	@keyframes ping {

		75%,
		100% {
			transform: scale(2);
			opacity: 0;
		}
	}

	@keyframes pulse {
		50% {
			opacity: 0.5;
		}
	}

	@keyframes bounce {

		0%,
		100% {
			transform: translateY(-25%);
			animation-timing-function: cubic-bezier(0.8, 0, 1, 1);
		}

		50% {
			transform: none;
			animation-timing-function: cubic-bezier(0, 0, 0.2, 1);
		}
	}
}

/* ============================================================
   spacing.css  —  Tailwind-compatible spacing tokens
   Based on --spacing: 0.25rem (from theme.css)
   Usage: padding: var(--p-4);  margin: var(--m-2);
   ============================================================ */

:root {
	/* ── TYPOGRAPHY EXTENSIONS ── */
	/* --text-2xs: sub-xs size untuk chip label, badge, status terkecil (10px @ 16px root)  */
	/* Pattern mengikuti Tailwind v4: --text-X dan --text-X--line-height berpasangan         */
	--text-2xs: 0.625rem;
	/*  10px  */
	--text-2xs--line-height: calc(1 / 0.625);
	/*  1.6   */

	/* ── PADDING ── */
	--p-0: calc(var(--spacing) * 0);
	/*  0px   */
	--p-1: calc(var(--spacing) * 1);
	/*  4px   */
	--p-2: calc(var(--spacing) * 2);
	/*  8px   */
	--p-3: calc(var(--spacing) * 3);
	/*  12px  */
	--p-4: calc(var(--spacing) * 4);
	/*  16px  */
	--p-5: calc(var(--spacing) * 5);
	/*  20px  */
	--p-6: calc(var(--spacing) * 6);
	/*  24px  */
	--p-7: calc(var(--spacing) * 7);
	/*  28px  */
	--p-8: calc(var(--spacing) * 8);
	/*  32px  */
	--p-9: calc(var(--spacing) * 9);
	/*  36px  */
	--p-10: calc(var(--spacing) * 10);
	/*  40px  */
	--p-11: calc(var(--spacing) * 11);
	/*  44px  */
	--p-12: calc(var(--spacing) * 12);
	/*  48px  */
	--p-14: calc(var(--spacing) * 14);
	/*  56px  */
	--p-16: calc(var(--spacing) * 16);
	/*  64px  */
	--p-20: calc(var(--spacing) * 20);
	/*  80px  */
	--p-24: calc(var(--spacing) * 24);
	/*  96px  */
	--p-28: calc(var(--spacing) * 28);
	/*  112px */
	--p-32: calc(var(--spacing) * 32);
	/*  128px */
	--p-36: calc(var(--spacing) * 36);
	/*  144px */
	--p-40: calc(var(--spacing) * 40);
	/*  160px */
	--p-44: calc(var(--spacing) * 44);
	/*  176px */
	--p-48: calc(var(--spacing) * 48);
	/*  192px */
	--p-52: calc(var(--spacing) * 52);
	/*  208px */
	--p-56: calc(var(--spacing) * 56);
	/*  224px */
	--p-60: calc(var(--spacing) * 60);
	/*  240px */
	--p-64: calc(var(--spacing) * 64);
	/*  256px */
	--p-72: calc(var(--spacing) * 72);
	/*  288px */
	--p-80: calc(var(--spacing) * 80);
	/*  320px */
	--p-96: calc(var(--spacing) * 96);
	/*  384px */

	/* ── MARGIN ── */
	--m-0: calc(var(--spacing) * 0);
	/*  0px   */
	--m-1: calc(var(--spacing) * 1);
	/*  4px   */
	--m-2: calc(var(--spacing) * 2);
	/*  8px   */
	--m-3: calc(var(--spacing) * 3);
	/*  12px  */
	--m-4: calc(var(--spacing) * 4);
	/*  16px  */
	--m-5: calc(var(--spacing) * 5);
	/*  20px  */
	--m-6: calc(var(--spacing) * 6);
	/*  24px  */
	--m-7: calc(var(--spacing) * 7);
	/*  28px  */
	--m-8: calc(var(--spacing) * 8);
	/*  32px  */
	--m-9: calc(var(--spacing) * 9);
	/*  36px  */
	--m-10: calc(var(--spacing) * 10);
	/*  40px  */
	--m-11: calc(var(--spacing) * 11);
	/*  44px  */
	--m-12: calc(var(--spacing) * 12);
	/*  48px  */
	--m-14: calc(var(--spacing) * 14);
	/*  56px  */
	--m-16: calc(var(--spacing) * 16);
	/*  64px  */
	--m-20: calc(var(--spacing) * 20);
	/*  80px  */
	--m-24: calc(var(--spacing) * 24);
	/*  96px  */
	--m-28: calc(var(--spacing) * 28);
	/*  112px */
	--m-32: calc(var(--spacing) * 32);
	/*  128px */
	--m-36: calc(var(--spacing) * 36);
	/*  144px */
	--m-40: calc(var(--spacing) * 40);
	/*  160px */
	--m-44: calc(var(--spacing) * 44);
	/*  176px */
	--m-48: calc(var(--spacing) * 48);
	/*  192px */
	--m-52: calc(var(--spacing) * 52);
	/*  208px */
	--m-56: calc(var(--spacing) * 56);
	/*  224px */
	--m-60: calc(var(--spacing) * 60);
	/*  240px */
	--m-64: calc(var(--spacing) * 64);
	/*  256px */
	--m-72: calc(var(--spacing) * 72);
	/*  288px */
	--m-80: calc(var(--spacing) * 80);
	/*  320px */
	--m-96: calc(var(--spacing) * 96);
	/*  384px */

	/* ── GAP / SIZE ALIASES (same scale, semantic names) ── */
	--gap-0: calc(var(--spacing) * 0);
	--gap-1: calc(var(--spacing) * 1);
	--gap-2: calc(var(--spacing) * 2);
	--gap-3: calc(var(--spacing) * 3);
	--gap-4: calc(var(--spacing) * 4);
	--gap-5: calc(var(--spacing) * 5);
	--gap-6: calc(var(--spacing) * 6);
	--gap-7: calc(var(--spacing) * 7);
	--gap-8: calc(var(--spacing) * 8);
	--gap-10: calc(var(--spacing) * 10);
	--gap-12: calc(var(--spacing) * 12);
	--gap-14: calc(var(--spacing) * 14);
	--gap-16: calc(var(--spacing) * 16);
	--gap-20: calc(var(--spacing) * 20);

	/* ── SIZE (width / height shorthands) ── */
	--size-1: calc(var(--spacing) * 1);
	/*  4px  */
	--size-2: calc(var(--spacing) * 2);
	/*  8px  */
	--size-3: calc(var(--spacing) * 3);
	/*  12px */
	--size-4: calc(var(--spacing) * 4);
	/*  16px */
	--size-5: calc(var(--spacing) * 5);
	/*  20px */
	--size-6: calc(var(--spacing) * 6);
	/*  24px */
	--size-7: calc(var(--spacing) * 7);
	/*  28px */
	--size-8: calc(var(--spacing) * 8);
	/*  32px */
	--size-9: calc(var(--spacing) * 9);
	/*  36px */
	--size-10: calc(var(--spacing) * 10);
	/*  40px */
	--size-12: calc(var(--spacing) * 12);
	/*  48px */
	--size-14: calc(var(--spacing) * 14);
	/*  56px */
	--size-16: calc(var(--spacing) * 16);
	/*  64px */
	--size-18: calc(var(--spacing) * 18);
	/*  72px */
	--size-20: calc(var(--spacing) * 20);
	/*  80px */
	--size-24: calc(var(--spacing) * 24);
	/*  96px */
}

/* ============================================================
   style.css  —  Global tokens, layout shell, typography,
                 buttons, skeleton, responsive rules.
   Load order: preflight → style → theme/*.css → components
   
   NOTE: Palette tokens (--bg, --surface, --border, --text,
         --accent, --green, etc.) now live in css/theme/*.css
         for whitelabel switching from admin panel.
   ============================================================ */

:root {
	/* ── Layout ── */
	--sidebar-w: var(--size-16);
	--sidebar-w-exp: var(--size-60);
	--header-h: var(--size-15);
	--tabbar-h: var(--size-15);

	/* Extra tokens not in spacing.css */
	--size-15: calc(var(--spacing) * 15);
	/* 60px  */
	--size-60: calc(var(--spacing) * 60);
	/* 240px */
	--p-18: calc(var(--spacing) * 18);
	/* 72px  */
	--size-11: calc(var(--spacing) * 11);
	/* 44px */
}

/* ── Material Symbols global config ── */
.material-symbols-rounded {
	font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
	font-size: var(--text-xl);
	line-height: var(--text-xl--line-height);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	vertical-align: middle;
	user-select: none;
	flex-shrink: 0;
}

/* Filled variant for active states */
.active .material-symbols-rounded {
	font-variation-settings: 'FILL' 1, 'wght' 500, 'GRAD' 0, 'opsz' 24;
}


/* ── ROOT / BODY ─────────────────────────────────────────── */
html {
	background: var(--bg);
	font-size: 16px;
	/* CRITICAL: prevent iOS Safari from expanding viewport
       when child content overflows horizontally */
	overflow-x: clip;
}

body {
	font-family: 'Inter', ui-sans-serif, system-ui, sans-serif;
	background: var(--bg);
	color: var(--text);
	overflow-x: clip;
	-webkit-font-smoothing: antialiased;
	font-size: var(--text-sm);
	line-height: var(--text-sm--line-height);
	/* Contain horizontal overflow on iOS */
	width: 100%;
	min-width: 0;
}


/* ── SCROLLBAR ───────────────────────────────────────────── */
::-webkit-scrollbar {
	width: 4px;
	height: 4px;
}

::-webkit-scrollbar-track {
	background: transparent;
}

::-webkit-scrollbar-thumb {
	background: var(--surface2);
	border-radius: var(--radius-lg);
}

::-webkit-scrollbar-thumb:hover {
	background: var(--surface3);
}


/* ── TYPOGRAPHY UTILITIES ────────────────────────────────── */
.text-xs {
	font-size: var(--text-xs);
	line-height: var(--text-xs--line-height);
}

.text-sm {
	font-size: var(--text-sm);
	line-height: var(--text-sm--line-height);
}

.text-base {
	font-size: var(--text-base);
	line-height: var(--text-base--line-height);
}

.text-lg {
	font-size: var(--text-lg);
	line-height: var(--text-lg--line-height);
}

.text-xl {
	font-size: var(--text-xl);
	line-height: var(--text-xl--line-height);
}

.text-2xl {
	font-size: var(--text-2xl);
	line-height: var(--text-2xl--line-height);
}

.text-3xl {
	font-size: var(--text-3xl);
	line-height: var(--text-3xl--line-height);
}

.text-4xl {
	font-size: var(--text-4xl);
	line-height: var(--text-4xl--line-height);
}

.text-5xl {
	font-size: var(--text-5xl);
	line-height: var(--text-5xl--line-height);
}

.text-6xl {
	font-size: var(--text-6xl);
	line-height: var(--text-6xl--line-height);
}


/* ── LAYOUT SHELL ────────────────────────────────────────── */
#root {
	display: flex;
	min-height: 100vh;
	flex-direction: row;
	/* Contain ALL horizontal overflow — prevents iOS viewport expansion */
	width: 100%;
	max-width: 100vw;
	overflow-x: clip;
}

.body {
	margin-left: var(--sidebar-w);
	padding-top: var(--header-h);
	/* Kompensasi header fixed */
	flex: 1;
	display: flex;
	flex-direction: column;
	min-height: 100vh;
	transition: margin-left 0.28s cubic-bezier(0.4, 0, 0.2, 1);
	/* Allow flex child to shrink below content width */
	min-width: 0;
	overflow-x: hidden;
}

#root.sidebar-open .body {
	margin-left: var(--sidebar-w-exp);
}

.main {
	padding: var(--p-4);
	/* consistent p-4 baseline */
	padding-bottom: var(--p-20);
	/* Prevent children from breaking out */
	min-width: 0;
	overflow-x: hidden;
}

/* ── ACCESSIBILITY ───────────────────────────────────────── */
.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip-path: inset(50%);
	white-space: nowrap;
	border-width: 0;
}

.not-sr-only {
	position: static;
	width: auto;
	height: auto;
	padding: 0;
	margin: 0;
	overflow: visible;
	clip-path: none;
	white-space: normal;
}

/* ── SKELETON SHIMMER ────────────────────────────────────── */
@keyframes shimmer {
	0% {
		background-position: 200% 50%;
	}

	100% {
		background-position: -200% 50%;
	}
}

.skeleton {
	background: linear-gradient(90deg,
			var(--surface) 25%,
			var(--surface2) 50%,
			var(--surface) 75%);
	background-size: 400% 100%;
	animation: shimmer 1.8s ease-in-out infinite;
	border-radius: var(--radius-lg);
}

/* ── RESPONSIVE ──────────────────────────────────────────── */

/* ---- XL: ≤ 1280px ---- */
@media (max-width: 1280px) {

	.game-grid,
	.rtp-grid,
	.game-rec-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}
}

/* ---- LG / Tablet landscape: ≤ 1024px ---- */
@media (max-width: 1024px) {
	.sidebar {
		display: none;
	}

	/* Sidebar hidden → reset margin regardless of .sidebar-open */
	.body,
	#root.sidebar-open .body {
		margin-left: 0;
	}

	.header-nav {
		display: none;
	}

	.game-grid,
	.rtp-grid,
	.game-rec-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

/* ---- MD / Tablet portrait: ≤ 768px ---- */
@media (max-width: 768px) {

	.game-grid,
	.rtp-grid,
	.game-rec-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: var(--gap-2);
	}

	/* Section headers tighter */
	.section-header {
		margin-bottom: var(--m-3);
	}

	.section-title {
		font-size: var(--text-sm);
	}
}

/* ---- SM / Mobile: ≤ 640px ---- */
@media (max-width: 640px) {
	.main {
		padding: var(--p-3);
		/* Bottom padding: tabbar height + safe area */
		padding-bottom: calc(var(--p-18) + env(safe-area-inset-bottom, 0px));
	}

	.header-search {
		display: none;
	}

	/* Show mobile tabbar */
	.tabbar {
		display: flex;
	}

	/* Touch devices: always show add-to-cart & wishlist buttons */
	.game-add-btn,
	.game-wishlist {
		opacity: 1;
	}

	/* Compact section-link button on mobile */
	.section-link {
		padding: calc(var(--spacing) * 1) var(--p-2);
		font-size: var(--text-xs);
	}
}

/* ---- XS / Small mobile: ≤ 374px ---- */
@media (max-width: 374px) {
	html {
		font-size: 14px;
		/* Scale everything down slightly */
	}

	.main {
		padding: var(--p-2);
		padding-bottom: calc(var(--p-18) + env(safe-area-inset-bottom, 0px));
	}
}

/* ── Icon utilities ─────────────────────────────────────── */
.icon-sm     { font-size: 0.85rem }
.icon-base   { font-size: 1rem }
.icon-md     { font-size: 1.1rem }

.icon-red    { color: var(--red) }
.icon-green  { color: var(--green) }
.icon-accent { color: var(--accent) }
.icon-orange { color: var(--orange) }
.icon-gold   { color: var(--gold) }
.icon-text3  { color: var(--text3) }

/* ── Layout utilities ───────────────────────────────────── */
.mt-0         { margin-top: 0 }
.mb-sm        { margin-bottom: 0.5rem }
.mb-lg        { margin-bottom: 1.5rem }
.text-right   { text-align: right }
.pos-relative { position: relative }
.font-normal  { font-weight: 400 }

/* ── Provider "All" icon box (game filter) ──────────────── */
.gf-provider-all-icon {
    width: 36px;
    height: 36px;
    border-radius: 0.4rem;
    background: color-mix(in oklch, var(--accent) 10%, transparent);
    display: flex;
    align-items: center;
    justify-content: center;
}

/* ── SAFE AREA (notched phones) ─────────────────────────── */
@supports (padding-bottom: env(safe-area-inset-bottom)) {
	.tabbar {
		padding-bottom: env(safe-area-inset-bottom, 0px);
		height: calc(var(--tabbar-h) + env(safe-area-inset-bottom, 0px));
	}
}