@charset "UTF-8";@layer theme,base,components,utilities;@layer theme{@theme default{ --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% .013 17.38); --color-red-100: oklch(93.6% .032 17.717); --color-red-200: oklch(88.5% .062 18.334); --color-red-300: oklch(80.8% .114 19.571); --color-red-400: oklch(70.4% .191 22.216); --color-red-500: oklch(63.7% .237 25.331); --color-red-600: oklch(57.7% .245 27.325); --color-red-700: oklch(50.5% .213 27.518); --color-red-800: oklch(44.4% .177 26.899); --color-red-900: oklch(39.6% .141 25.723); --color-red-950: oklch(25.8% .092 26.042); --color-orange-50: oklch(98% .016 73.684); --color-orange-100: oklch(95.4% .038 75.164); --color-orange-200: oklch(90.1% .076 70.697); --color-orange-300: oklch(83.7% .128 66.29); --color-orange-400: oklch(75% .183 55.934); --color-orange-500: oklch(70.5% .213 47.604); --color-orange-600: oklch(64.6% .222 41.116); --color-orange-700: oklch(55.3% .195 38.402); --color-orange-800: oklch(47% .157 37.304); --color-orange-900: oklch(40.8% .123 38.172); --color-orange-950: oklch(26.6% .079 36.259); --color-amber-50: oklch(98.7% .022 95.277); --color-amber-100: oklch(96.2% .059 95.617); --color-amber-200: oklch(92.4% .12 95.746); --color-amber-300: oklch(87.9% .169 91.605); --color-amber-400: oklch(82.8% .189 84.429); --color-amber-500: oklch(76.9% .188 70.08); --color-amber-600: oklch(66.6% .179 58.318); --color-amber-700: oklch(55.5% .163 48.998); --color-amber-800: oklch(47.3% .137 46.201); --color-amber-900: oklch(41.4% .112 45.904); --color-amber-950: oklch(27.9% .077 45.635); --color-yellow-50: oklch(98.7% .026 102.212); --color-yellow-100: oklch(97.3% .071 103.193); --color-yellow-200: oklch(94.5% .129 101.54); --color-yellow-300: oklch(90.5% .182 98.111); --color-yellow-400: oklch(85.2% .199 91.936); --color-yellow-500: oklch(79.5% .184 86.047); --color-yellow-600: oklch(68.1% .162 75.834); --color-yellow-700: oklch(55.4% .135 66.442); --color-yellow-800: oklch(47.6% .114 61.907); --color-yellow-900: oklch(42.1% .095 57.708); --color-yellow-950: oklch(28.6% .066 53.813); --color-lime-50: oklch(98.6% .031 120.757); --color-lime-100: oklch(96.7% .067 122.328); --color-lime-200: oklch(93.8% .127 124.321); --color-lime-300: oklch(89.7% .196 126.665); --color-lime-400: oklch(84.1% .238 128.85); --color-lime-500: oklch(76.8% .233 130.85); --color-lime-600: oklch(64.8% .2 131.684); --color-lime-700: oklch(53.2% .157 131.589); --color-lime-800: oklch(45.3% .124 130.933); --color-lime-900: oklch(40.5% .101 131.063); --color-lime-950: oklch(27.4% .072 132.109); --color-green-50: oklch(98.2% .018 155.826); --color-green-100: oklch(96.2% .044 156.743); --color-green-200: oklch(92.5% .084 155.995); --color-green-300: oklch(87.1% .15 154.449); --color-green-400: oklch(79.2% .209 151.711); --color-green-500: oklch(72.3% .219 149.579); --color-green-600: oklch(62.7% .194 149.214); --color-green-700: oklch(52.7% .154 150.069); --color-green-800: oklch(44.8% .119 151.328); --color-green-900: oklch(39.3% .095 152.535); --color-green-950: oklch(26.6% .065 152.934); --color-emerald-50: oklch(97.9% .021 166.113); --color-emerald-100: oklch(95% .052 163.051); --color-emerald-200: oklch(90.5% .093 164.15); --color-emerald-300: oklch(84.5% .143 164.978); --color-emerald-400: oklch(76.5% .177 163.223); --color-emerald-500: oklch(69.6% .17 162.48); --color-emerald-600: oklch(59.6% .145 163.225); --color-emerald-700: oklch(50.8% .118 165.612); --color-emerald-800: oklch(43.2% .095 166.913); --color-emerald-900: oklch(37.8% .077 168.94); --color-emerald-950: oklch(26.2% .051 172.552); --color-teal-50: oklch(98.4% .014 180.72); --color-teal-100: oklch(95.3% .051 180.801); --color-teal-200: oklch(91% .096 180.426); --color-teal-300: oklch(85.5% .138 181.071); --color-teal-400: oklch(77.7% .152 181.912); --color-teal-500: oklch(70.4% .14 182.503); --color-teal-600: oklch(60% .118 184.704); --color-teal-700: oklch(51.1% .096 186.391); --color-teal-800: oklch(43.7% .078 188.216); --color-teal-900: oklch(38.6% .063 188.416); --color-teal-950: oklch(27.7% .046 192.524); --color-cyan-50: oklch(98.4% .019 200.873); --color-cyan-100: oklch(95.6% .045 203.388); --color-cyan-200: oklch(91.7% .08 205.041); --color-cyan-300: oklch(86.5% .127 207.078); --color-cyan-400: oklch(78.9% .154 211.53); --color-cyan-500: oklch(71.5% .143 215.221); --color-cyan-600: oklch(60.9% .126 221.723); --color-cyan-700: oklch(52% .105 223.128); --color-cyan-800: oklch(45% .085 224.283); --color-cyan-900: oklch(39.8% .07 227.392); --color-cyan-950: oklch(30.2% .056 229.695); --color-sky-50: oklch(97.7% .013 236.62); --color-sky-100: oklch(95.1% .026 236.824); --color-sky-200: oklch(90.1% .058 230.902); --color-sky-300: oklch(82.8% .111 230.318); --color-sky-400: oklch(74.6% .16 232.661); --color-sky-500: oklch(68.5% .169 237.323); --color-sky-600: oklch(58.8% .158 241.966); --color-sky-700: oklch(50% .134 242.749); --color-sky-800: oklch(44.3% .11 240.79); --color-sky-900: oklch(39.1% .09 240.876); --color-sky-950: oklch(29.3% .066 243.157); --color-blue-50: oklch(97% .014 254.604); --color-blue-100: oklch(93.2% .032 255.585); --color-blue-200: oklch(88.2% .059 254.128); --color-blue-300: oklch(80.9% .105 251.813); --color-blue-400: oklch(70.7% .165 254.624); --color-blue-500: oklch(62.3% .214 259.815); --color-blue-600: oklch(54.6% .245 262.881); --color-blue-700: oklch(48.8% .243 264.376); --color-blue-800: oklch(42.4% .199 265.638); --color-blue-900: oklch(37.9% .146 265.522); --color-blue-950: oklch(28.2% .091 267.935); --color-indigo-50: oklch(96.2% .018 272.314); --color-indigo-100: oklch(93% .034 272.788); --color-indigo-200: oklch(87% .065 274.039); --color-indigo-300: oklch(78.5% .115 274.713); --color-indigo-400: oklch(67.3% .182 276.935); --color-indigo-500: oklch(58.5% .233 277.117); --color-indigo-600: oklch(51.1% .262 276.966); --color-indigo-700: oklch(45.7% .24 277.023); --color-indigo-800: oklch(39.8% .195 277.366); --color-indigo-900: oklch(35.9% .144 278.697); --color-indigo-950: oklch(25.7% .09 281.288); --color-violet-50: oklch(96.9% .016 293.756); --color-violet-100: oklch(94.3% .029 294.588); --color-violet-200: oklch(89.4% .057 293.283); --color-violet-300: oklch(81.1% .111 293.571); --color-violet-400: oklch(70.2% .183 293.541); --color-violet-500: oklch(60.6% .25 292.717); --color-violet-600: oklch(54.1% .281 293.009); --color-violet-700: oklch(49.1% .27 292.581); --color-violet-800: oklch(43.2% .232 292.759); --color-violet-900: oklch(38% .189 293.745); --color-violet-950: oklch(28.3% .141 291.089); --color-purple-50: oklch(97.7% .014 308.299); --color-purple-100: oklch(94.6% .033 307.174); --color-purple-200: oklch(90.2% .063 306.703); --color-purple-300: oklch(82.7% .119 306.383); --color-purple-400: oklch(71.4% .203 305.504); --color-purple-500: oklch(62.7% .265 303.9); --color-purple-600: oklch(55.8% .288 302.321); --color-purple-700: oklch(49.6% .265 301.924); --color-purple-800: oklch(43.8% .218 303.724); --color-purple-900: oklch(38.1% .176 304.987); --color-purple-950: oklch(29.1% .149 302.717); --color-fuchsia-50: oklch(97.7% .017 320.058); --color-fuchsia-100: oklch(95.2% .037 318.852); --color-fuchsia-200: oklch(90.3% .076 319.62); --color-fuchsia-300: oklch(83.3% .145 321.434); --color-fuchsia-400: oklch(74% .238 322.16); --color-fuchsia-500: oklch(66.7% .295 322.15); --color-fuchsia-600: oklch(59.1% .293 322.896); --color-fuchsia-700: oklch(51.8% .253 323.949); --color-fuchsia-800: oklch(45.2% .211 324.591); --color-fuchsia-900: oklch(40.1% .17 325.612); --color-fuchsia-950: oklch(29.3% .136 325.661); --color-pink-50: oklch(97.1% .014 343.198); --color-pink-100: oklch(94.8% .028 342.258); --color-pink-200: oklch(89.9% .061 343.231); --color-pink-300: oklch(82.3% .12 346.018); --color-pink-400: oklch(71.8% .202 349.761); --color-pink-500: oklch(65.6% .241 354.308); --color-pink-600: oklch(59.2% .249 .584); --color-pink-700: oklch(52.5% .223 3.958); --color-pink-800: oklch(45.9% .187 3.815); --color-pink-900: oklch(40.8% .153 2.432); --color-pink-950: oklch(28.4% .109 3.907); --color-rose-50: oklch(96.9% .015 12.422); --color-rose-100: oklch(94.1% .03 12.58); --color-rose-200: oklch(89.2% .058 10.001); --color-rose-300: oklch(81% .117 11.638); --color-rose-400: oklch(71.2% .194 13.428); --color-rose-500: oklch(64.5% .246 16.439); --color-rose-600: oklch(58.6% .253 17.585); --color-rose-700: oklch(51.4% .222 16.935); --color-rose-800: oklch(45.5% .188 13.697); --color-rose-900: oklch(41% .159 10.272); --color-rose-950: oklch(27.1% .105 12.094); --color-slate-50: oklch(98.4% .003 247.858); --color-slate-100: oklch(96.8% .007 247.896); --color-slate-200: oklch(92.9% .013 255.508); --color-slate-300: oklch(86.9% .022 252.894); --color-slate-400: oklch(70.4% .04 256.788); --color-slate-500: oklch(55.4% .046 257.417); --color-slate-600: oklch(44.6% .043 257.281); --color-slate-700: oklch(37.2% .044 257.287); --color-slate-800: oklch(27.9% .041 260.031); --color-slate-900: oklch(20.8% .042 265.755); --color-slate-950: oklch(12.9% .042 264.695); --color-gray-50: oklch(98.5% .002 247.839); --color-gray-100: oklch(96.7% .003 264.542); --color-gray-200: oklch(92.8% .006 264.531); --color-gray-300: oklch(87.2% .01 258.338); --color-gray-400: oklch(70.7% .022 261.325); --color-gray-500: oklch(55.1% .027 264.364); --color-gray-600: oklch(44.6% .03 256.802); --color-gray-700: oklch(37.3% .034 259.733); --color-gray-800: oklch(27.8% .033 256.848); --color-gray-900: oklch(21% .034 264.665); --color-gray-950: oklch(13% .028 261.692); --color-zinc-50: oklch(98.5% 0 0); --color-zinc-100: oklch(96.7% .001 286.375); --color-zinc-200: oklch(92% .004 286.32); --color-zinc-300: oklch(87.1% .006 286.286); --color-zinc-400: oklch(70.5% .015 286.067); --color-zinc-500: oklch(55.2% .016 285.938); --color-zinc-600: oklch(44.2% .017 285.786); --color-zinc-700: oklch(37% .013 285.805); --color-zinc-800: oklch(27.4% .006 286.033); --color-zinc-900: oklch(21% .006 285.885); --color-zinc-950: oklch(14.1% .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% .001 106.423); --color-stone-100: oklch(97% .001 106.424); --color-stone-200: oklch(92.3% .003 48.717); --color-stone-300: oklch(86.9% .005 56.366); --color-stone-400: oklch(70.9% .01 56.259); --color-stone-500: oklch(55.3% .013 58.071); --color-stone-600: oklch(44.4% .011 73.639); --color-stone-700: oklch(37.4% .01 67.558); --color-stone-800: oklch(26.8% .007 34.298); --color-stone-900: oklch(21.6% .006 56.043); --color-stone-950: oklch(14.7% .004 49.25); --color-mauve-50: oklch(98.5% 0 0); --color-mauve-100: oklch(96% .003 325.6); --color-mauve-200: oklch(92.2% .005 325.62); --color-mauve-300: oklch(86.5% .012 325.68); --color-mauve-400: oklch(71.1% .019 323.02); --color-mauve-500: oklch(54.2% .034 322.5); --color-mauve-600: oklch(43.5% .029 321.78); --color-mauve-700: oklch(36.4% .029 323.89); --color-mauve-800: oklch(26.3% .024 320.12); --color-mauve-900: oklch(21.2% .019 322.12); --color-mauve-950: oklch(14.5% .008 326); --color-olive-50: oklch(98.8% .003 106.5); --color-olive-100: oklch(96.6% .005 106.5); --color-olive-200: oklch(93% .007 106.5); --color-olive-300: oklch(88% .011 106.6); --color-olive-400: oklch(73.7% .021 106.9); --color-olive-500: oklch(58% .031 107.3); --color-olive-600: oklch(46.6% .025 107.3); --color-olive-700: oklch(39.4% .023 107.4); --color-olive-800: oklch(28.6% .016 107.4); --color-olive-900: oklch(22.8% .013 107.4); --color-olive-950: oklch(15.3% .006 107.1); --color-mist-50: oklch(98.7% .002 197.1); --color-mist-100: oklch(96.3% .002 197.1); --color-mist-200: oklch(92.5% .005 214.3); --color-mist-300: oklch(87.2% .007 219.6); --color-mist-400: oklch(72.3% .014 214.4); --color-mist-500: oklch(56% .021 213.5); --color-mist-600: oklch(45% .017 213.2); --color-mist-700: oklch(37.8% .015 216); --color-mist-800: oklch(27.5% .011 216.9); --color-mist-900: oklch(21.8% .008 223.9); --color-mist-950: oklch(14.8% .004 228.8); --color-taupe-50: oklch(98.6% .002 67.8); --color-taupe-100: oklch(96% .002 17.2); --color-taupe-200: oklch(92.2% .005 34.3); --color-taupe-300: oklch(86.8% .007 39.5); --color-taupe-400: oklch(71.4% .014 41.2); --color-taupe-500: oklch(54.7% .021 43.1); --color-taupe-600: oklch(43.8% .017 39.3); --color-taupe-700: oklch(36.7% .016 35.7); --color-taupe-800: oklch(26.8% .011 36.5); --color-taupe-900: oklch(21.4% .009 43.1); --color-taupe-950: oklch(14.7% .004 49.3); --color-black: #000; --color-white: #fff; --spacing: .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: .75rem; --text-xs--line-height: calc(1 / .75); --text-sm: .875rem; --text-sm--line-height: calc(1.25 / .875); --text-base: 1rem; --text-base--line-height: 1.5 ; --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: 1.2 ; --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: -.05em; --tracking-tight: -.025em; --tracking-normal: 0em; --tracking-wide: .025em; --tracking-wider: .05em; --tracking-widest: .1em; --leading-tight: 1.25; --leading-snug: 1.375; --leading-normal: 1.5; --leading-relaxed: 1.625; --leading-loose: 2; --radius-xs: .125rem; --radius-sm: .25rem; --radius-md: .375rem; --radius-lg: .5rem; --radius-xl: .75rem; --radius-2xl: 1rem; --radius-3xl: 1.5rem; --radius-4xl: 2rem; --shadow-2xs: 0 1px rgb(0 0 0 / .05); --shadow-xs: 0 1px 2px 0 rgb(0 0 0 / .05); --shadow-sm: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1); --shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1); --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1); --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1); --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / .25); --inset-shadow-2xs: inset 0 1px rgb(0 0 0 / .05); --inset-shadow-xs: inset 0 1px 1px rgb(0 0 0 / .05); --inset-shadow-sm: inset 0 2px 4px rgb(0 0 0 / .05); --drop-shadow-xs: 0 1px 1px rgb(0 0 0 / .05); --drop-shadow-sm: 0 1px 2px rgb(0 0 0 / .15); --drop-shadow-md: 0 3px 3px rgb(0 0 0 / .12); --drop-shadow-lg: 0 4px 4px rgb(0 0 0 / .15); --drop-shadow-xl: 0 9px 7px rgb(0 0 0 / .1); --drop-shadow-2xl: 0 25px 25px rgb(0 0 0 / .15); --text-shadow-2xs: 0px 1px 0px rgb(0 0 0 / .15); --text-shadow-xs: 0px 1px 1px rgb(0 0 0 / .2); --text-shadow-sm: 0px 1px 0px rgb(0 0 0 / .075), 0px 1px 1px rgb(0 0 0 / .075), 0px 2px 2px rgb(0 0 0 / .075); --text-shadow-md: 0px 1px 1px rgb(0 0 0 / .1), 0px 1px 2px rgb(0 0 0 / .1), 0px 2px 4px rgb(0 0 0 / .1); --text-shadow-lg: 0px 1px 2px rgb(0 0 0 / .1), 0px 3px 2px rgb(0 0 0 / .1), 0px 4px 8px rgb(0 0 0 / .1); --ease-in: cubic-bezier(.4, 0, 1, 1); --ease-out: cubic-bezier(0, 0, .2, 1); --ease-in-out: cubic-bezier(.4, 0, .2, 1); --animate-spin: spin 1s linear infinite; --animate-ping: ping 1s cubic-bezier(0, 0, .2, 1) infinite; --animate-pulse: pulse 2s cubic-bezier(.4, 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: .5; } } @keyframes bounce { 0%, 100% { transform: translateY(-25%); animation-timing-function: cubic-bezier(.8, 0, 1, 1); } 50% { transform: none; animation-timing-function: cubic-bezier(0, 0, .2, 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; --default-transition-duration: .15s; --default-transition-timing-function: cubic-bezier(.4, 0, .2, 1); --default-font-family: --theme(--font-sans, initial); --default-font-feature-settings: --theme( --font-sans--font-feature-settings, initial ); --default-font-variation-settings: --theme( --font-sans--font-variation-settings, initial ); --default-mono-font-family: --theme(--font-mono, initial); --default-mono-font-feature-settings: --theme( --font-mono--font-feature-settings, initial ); --default-mono-font-variation-settings: --theme( --font-mono--font-variation-settings, initial ); }@theme default inline reference{ --blur: 8px; --shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1); --shadow-inner: inset 0 2px 4px 0 rgb(0 0 0 / .05); --drop-shadow: 0 1px 2px rgb(0 0 0 / .1), 0 1px 1px rgb(0 0 0 / .06); --radius: .25rem; --max-width-prose: 65ch; }}@layer base{*,:after,:before,::backdrop,::file-selector-button{box-sizing:border-box;margin:0;padding:0;border:0 solid}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:--theme(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:--theme(--default-font-feature-settings,normal);font-variation-settings:--theme(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:--theme(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:--theme(--default-mono-font-feature-settings,normal);font-variation-settings:--theme(--default-mono-font-variation-settings,normal);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}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea,::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;border-radius:0;background-color:transparent;opacity:1}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not (-webkit-appearance: -apple-pay-button)) or (contain-intrinsic-size: 1px){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field,::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]),::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{@tailwind utilities;}@font-face{font-family:MuseoSans;src:url(/assets/MuseoSans_300-webfont-wg0-3rz8.woff2) format("woff2"),url(/assets/MuseoSans_300-webfont-BkfOxvlz.woff) format("woff");font-weight:300;font-style:normal;font-display:swap}@font-face{font-family:MuseoSans;src:url(/assets/MuseoSans_300_Italic-webfont-B-2m7yek.woff2) format("woff2"),url(/assets/MuseoSans_300_Italic-webfont-BOtXelre.woff) format("woff");font-weight:300;font-style:italic;font-display:swap}@font-face{font-family:MuseoSans;src:url(/assets/MuseoSans_500-webfont-onIAkwpa.woff2) format("woff2"),url(/assets/MuseoSans_500-webfont-B63qBi-F.woff) format("woff");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:MuseoSans;src:url(/assets/MuseoSans_500_Italic-webfont-DwCpeMQH.woff2) format("woff2"),url(/assets/MuseoSans_500_Italic-webfont-BKxu1MD8.woff) format("woff");font-weight:500;font-style:italic;font-display:swap}@font-face{font-family:MuseoSans;src:url(/assets/MuseoSans_700-webfont-DxKPwhsy.woff2) format("woff2"),url(/assets/MuseoSans_700-webfont-nMIs7ak8.woff) format("woff");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:MuseoSans;src:url(/assets/MuseoSans_700_Italic-webfont-_uYTpz-n.woff2) format("woff2"),url(/assets/MuseoSans_700_Italic-webfont-C19ZeSuZ.woff) format("woff");font-weight:700;font-style:italic;font-display:swap}@font-face{font-family:MuseoSans;src:url(/assets/MuseoSans_900-webfont-DwiHHb1G.woff2) format("woff2"),url(/assets/MuseoSans_900-webfont-MHfSzPU0.woff) format("woff");font-weight:900;font-style:normal;font-display:swap}@font-face{font-family:MuseoSans;src:url(/assets/MuseoSans_900_Italic-webfont-gvql3igD.woff2) format("woff2"),url(/assets/MuseoSans_900_Italic-webfont-xnovKw_u.woff) format("woff");font-weight:900;font-style:italic;font-display:swap}:root{--color-nacht-paars: #56355b;--color-nacht-paars-80: #785e7c;--color-avond-paars: #d2bbd5;--color-avond-paars-80: #dbc9dd;--color-ochtend-blauw: #9dbde2;--color-ochtend-blauw-80: #b0cae8;--color-lente-groen: #9dcab9;--color-lente-groen-80: #b0d5c7;--color-lente-groen-40: #d8eae3;--color-ijzer: #535353;--color-primary: var(--color-nacht-paars);--color-primary-hover: var(--color-nacht-paars-80);--color-accent: var(--color-lente-groen);--color-accent-hover: var(--color-lente-groen-80);--color-accent-subtle: var(--color-lente-groen-40);--color-surface: #ffffff;--color-surface-alt: #f9f8fa;--color-border: #eae7ec;--color-text: var(--color-ijzer);--color-text-heading: var(--color-nacht-paars);--color-text-muted: #918a94;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 2px 8px rgba(0, 0, 0, .06);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .1);--shadow-hover: 0 4px 12px rgba(0, 0, 0, .08);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-base: .2s ease;--topbar-height: 4.5rem}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:MuseoSans,system-ui,-apple-system,sans-serif;font-weight:500;font-size:.95rem;color:var(--color-text);background:var(--color-surface-alt);letter-spacing:.01em;-webkit-font-smoothing:antialiased}a{text-decoration:none;color:inherit}h1,h2,h3,h4,h5,h6{font-weight:900;color:var(--color-text-heading)}.page-enter-active{transition:opacity .15s ease-in}.page-leave-active{transition:opacity .1s ease-out}.page-enter-from,.page-leave-to{opacity:0}.fade-enter-active{transition:opacity .15s ease-in}.fade-leave-active{transition:opacity .1s ease-out}.fade-enter-from,.fade-leave-to{opacity:0}.stagger-in>*{opacity:0;transform:translateY(.75rem);animation:stagger-fade-in .35s ease forwards}.stagger-in>*:nth-child(1){animation-delay:0s}.stagger-in>*:nth-child(2){animation-delay:.04s}.stagger-in>*:nth-child(3){animation-delay:.08s}.stagger-in>*:nth-child(4){animation-delay:.12s}.stagger-in>*:nth-child(5){animation-delay:.16s}.stagger-in>*:nth-child(6){animation-delay:.2s}.stagger-in>*:nth-child(7){animation-delay:.24s}.stagger-in>*:nth-child(8){animation-delay:.28s}.stagger-in>*:nth-child(9){animation-delay:.32s}.stagger-in>*:nth-child(10){animation-delay:.36s}.stagger-in>*:nth-child(11){animation-delay:.4s}.stagger-in>*:nth-child(12){animation-delay:.44s}.stagger-in>*:nth-child(13){animation-delay:.48s}.stagger-in>*:nth-child(14){animation-delay:.52s}.stagger-in>*:nth-child(15){animation-delay:.56s}.stagger-in>*:nth-child(16){animation-delay:.6s}.stagger-in>*:nth-child(17){animation-delay:.64s}.stagger-in>*:nth-child(18){animation-delay:.68s}.stagger-in>*:nth-child(19){animation-delay:.72s}.stagger-in>*:nth-child(20){animation-delay:.76s}body.is-dragging,body.is-dragging *{cursor:grabbing!important}body.is-dragging.is-drag-blocked,body.is-dragging.is-drag-blocked *{cursor:not-allowed!important}@keyframes stagger-fade-in{to{opacity:1;transform:translateY(0)}}.topbar{position:fixed;top:0;left:0;right:0;height:var(--topbar-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;padding:0 2rem;z-index:40}.topbar:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--color-lente-groen) 0%,var(--color-ochtend-blauw) 50%,var(--color-avond-paars) 100%)}.topbar__brand{flex-shrink:0;display:flex;align-items:center;gap:.625rem;height:100%;margin-right:2rem;text-decoration:none;transition:opacity var(--transition-fast)}.topbar__brand:hover{opacity:.8}.topbar__mark{height:2.75rem;width:auto;flex-shrink:0}.topbar__wordmark{height:2.5rem;width:auto;flex-shrink:0}.topbar__separator{width:1px;height:1.75rem;background:var(--color-border);margin-right:1.75rem;flex-shrink:0}.topbar__nav{display:flex;align-items:center;gap:.25rem;height:100%}.topbar__link{position:relative;display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:var(--radius-md);color:var(--color-text-muted);font-size:.8125rem;font-weight:500;text-decoration:none;white-space:nowrap;transition:color var(--transition-fast),background var(--transition-fast)}.topbar__link:hover{color:var(--color-nacht-paars);background:var(--color-surface-alt)}.topbar__link--active{color:var(--color-nacht-paars);font-weight:700}.topbar__link--active:after{content:"";position:absolute;bottom:-.625rem;left:.75rem;right:.75rem;height:2px;background:var(--color-lente-groen);border-radius:1px}.topbar__link-icon{width:1.125rem;height:1.125rem;flex-shrink:0}.topbar__right{flex-shrink:0;margin-left:auto}.account{position:relative}.account__trigger{display:flex;align-items:center;gap:.5rem;padding:.3125rem .625rem .3125rem .3125rem;border:1px solid transparent;border-radius:var(--radius-full);background:none;cursor:pointer;font-family:inherit;transition:background var(--transition-fast),border-color var(--transition-fast)}.account__trigger:hover{background:var(--color-surface-alt);border-color:var(--color-border)}.account__avatar{width:2rem;height:2rem;border-radius:var(--radius-full);background:var(--color-lente-groen);color:var(--color-nacht-paars);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.6875rem;flex-shrink:0}.account__name{font-size:.8125rem;font-weight:600;color:var(--color-text)}.account__chevron{width:.75rem;height:.75rem;color:var(--color-text-muted);transition:transform var(--transition-fast);flex-shrink:0}.account__chevron--open{transform:rotate(180deg)}.account__dropdown{position:absolute;top:100%;right:0;padding-top:.5rem;width:15rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;z-index:50}.account__header{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--color-surface-alt);border-bottom:1px solid var(--color-border)}.account__header-avatar{width:2.5rem;height:2.5rem;border-radius:var(--radius-full);background:var(--color-lente-groen);color:var(--color-nacht-paars);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;flex-shrink:0}.account__header-info{display:flex;flex-direction:column;gap:.125rem;min-width:0}.account__header-name{font-size:.8125rem;font-weight:700;color:var(--color-nacht-paars);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.account__header-role{font-size:.6875rem;color:var(--color-text-muted);text-transform:capitalize}.account__menu{padding:.375rem}.account__item{display:flex;align-items:center;gap:.625rem;width:100%;padding:.5rem .75rem;border:none;border-radius:var(--radius-sm);background:none;font-family:inherit;font-size:.8125rem;font-weight:500;color:var(--color-text);cursor:pointer;text-decoration:none;transition:background var(--transition-fast),color var(--transition-fast)}.account__item svg{width:1rem;height:1rem;flex-shrink:0;color:var(--color-text-muted);transition:color var(--transition-fast)}.account__item:hover{background:var(--color-surface-alt);color:var(--color-nacht-paars)}.account__item:hover svg{color:var(--color-nacht-paars)}.account__item--danger{color:#b91c1c}.account__item--danger svg{color:#b91c1c}.account__item--danger:hover{background:#fef2f2;color:#991b1b}.account__item--danger:hover svg{color:#991b1b}.account__divider{height:1px;background:var(--color-border);margin:.25rem .5rem}.dropdown-enter-active{transition:opacity .12s ease,transform .12s ease}.dropdown-leave-active{transition:opacity .08s ease}.dropdown-enter-from,.dropdown-leave-to{opacity:0;transform:translateY(-4px)}.layout{min-height:100vh;background:var(--color-surface-alt);display:flex}.layout__main{flex:1;margin-top:var(--topbar-height);padding-bottom:2rem}.page-content{padding:0 2.5rem}.page-banner{position:relative;background:var(--color-surface);border-bottom:1px solid var(--color-border);margin-bottom:1.5rem;padding:.75rem 2.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.page-banner__text{display:flex;align-items:baseline;gap:.625rem}.page-banner__title{font-size:.9375rem;font-weight:900;color:var(--color-nacht-paars);letter-spacing:-.01em}.page-banner__subtitle{font-size:.6875rem;color:var(--color-text-muted)}.page-banner__subtitle:before{content:"—";margin-right:.5rem}.page-banner:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--color-lente-groen) 0%,var(--color-ochtend-blauw) 100%)}.scroll-top{position:fixed;z-index:1000;right:2rem;bottom:2rem;width:2.75rem;height:2.75rem;display:flex;align-items:center;justify-content:center;background:var(--color-surface);color:var(--color-nacht-paars);border:1px solid var(--color-avond-paars);border-radius:var(--radius-full);box-shadow:var(--shadow-md);cursor:pointer;transition:all var(--transition-fast)}.scroll-top svg{width:1.25rem;height:1.25rem}.scroll-top:hover{background:var(--color-nacht-paars);color:#fff;border-color:var(--color-nacht-paars);box-shadow:var(--shadow-hover)}.scroll-top-enter-active,.scroll-top-leave-active{transition:opacity .2s ease,transform .2s ease}.scroll-top-enter-from,.scroll-top-leave-to{opacity:0;transform:translateY(.5rem)}.error-screen{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:2rem}.error-screen__card{text-align:center;max-width:24rem}.error-screen__title{font-size:1.25rem;font-weight:700;color:var(--color-text-heading);margin-bottom:.5rem}.error-screen__message{font-size:.875rem;color:var(--color-text-muted);margin-bottom:1.5rem}.error-screen__button{background:var(--color-primary);color:var(--color-surface);border:none;padding:.625rem 1.5rem;border-radius:var(--radius-md);font-weight:700;font-size:.875rem;cursor:pointer;transition:opacity var(--transition-fast)}.error-screen__button:hover{opacity:.9}.detail-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:2rem;background:#00000080}@media(max-width:640px){.detail-modal{padding:0;align-items:flex-end}}.detail-modal__panel{position:relative;display:flex;flex-direction:column;width:100%;max-width:42rem;height:calc(100vh - 4rem);max-height:calc(100vh - 4rem);background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:0 25px 50px -12px #00000040;overflow:hidden}@media(max-width:640px){.detail-modal__panel{height:95vh;max-height:95vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0}}.detail-modal__hero{position:relative;width:100%;height:14rem;flex-shrink:0;overflow:hidden;background:var(--color-nacht-paars)}@media(max-width:640px){.detail-modal__hero{height:11rem}}.detail-modal__hero-img{width:100%;height:100%;object-fit:cover;display:block}.detail-modal__hero-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-nacht-paars),var(--color-avond-paars-80, #5a3d7a))}.detail-modal__hero-placeholder svg{width:3rem;height:3rem;color:#ffffff4d}.detail-modal__hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#000000b3,#0000004d 40%,#0000000d);pointer-events:none}.detail-modal__hero-content{position:absolute;bottom:0;left:0;right:0;padding:1.25rem 1.5rem;z-index:1}.detail-modal__hero-badge{display:inline-block;font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#ffffffe6;background:#ffffff2e;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:.25rem .625rem;border-radius:var(--radius-full);margin-bottom:.5rem}.detail-modal__hero-title{font-size:1.375rem;font-weight:900;color:#fff;line-height:1.25;letter-spacing:-.01em;margin:0;text-shadow:0 1px 3px rgba(0,0,0,.3)}@media(max-width:640px){.detail-modal__hero-title{font-size:1.125rem}}.detail-modal__close{position:absolute;top:.75rem;right:.75rem;z-index:2;display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:none;border-radius:var(--radius-full);background:#00000059;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;cursor:pointer;transition:background var(--transition-fast)}.detail-modal__close svg{width:1rem;height:1rem}.detail-modal__close:hover{background:#0000008c}.detail-modal__sticky-bar{flex-shrink:0;display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1rem 1.5rem;border-bottom:1px solid var(--color-border);background:var(--color-surface);box-shadow:0 1px 3px #0000000a}.detail-modal__sticky-bar .detail-modal__meta{flex-direction:column;align-items:flex-end;gap:.25rem;margin-left:auto}.detail-modal__body{flex:1;overflow-y:auto;padding:1.25rem 1.5rem;overscroll-behavior:contain}.detail-modal__body::-webkit-scrollbar{width:4px}.detail-modal__body::-webkit-scrollbar-track{background:transparent}.detail-modal__body::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.detail-modal__body::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.detail-modal__action-bar{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.detail-modal__cta{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.8125rem;font-weight:700;font-family:inherit;color:#fff;background:var(--color-nacht-paars);border:none;border-radius:var(--radius-sm);text-decoration:none;cursor:pointer;transition:opacity var(--transition-fast),transform var(--transition-fast)}.detail-modal__cta svg{width:.875rem;height:.875rem;flex-shrink:0}.detail-modal__cta:hover{opacity:.9;transform:translateY(-1px)}.detail-modal__external-note{display:inline-flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--color-text-muted);background:var(--color-accent-subtle);padding:.375rem .75rem;border-radius:var(--radius-sm);border:1px solid var(--color-lente-groen-40)}.detail-modal__external-note svg{width:.875rem;height:.875rem;flex-shrink:0;color:var(--color-nacht-paars)}.detail-modal__meta{display:flex;flex-wrap:wrap;gap:.5rem}.detail-modal__meta-pill{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:var(--color-surface-alt);border-radius:var(--radius-full);font-size:.75rem}.detail-modal__meta-label{font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em;font-size:.625rem}.detail-modal__meta-value{font-weight:500;color:var(--color-text)}.detail-modal__section{padding-top:1.25rem;margin-top:1.25rem;border-top:1px solid var(--color-border)}.detail-modal__section:first-child{padding-top:0;margin-top:0;border-top:none}.detail-modal__section-title{font-size:.6875rem;font-weight:900;color:var(--color-nacht-paars);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.detail-modal__text{font-size:.8125rem;color:var(--color-text);line-height:1.7}.detail-modal__text p{margin-bottom:.625rem}.detail-modal__text p:last-child{margin-bottom:0}.detail-modal__text a{color:var(--color-nacht-paars);text-decoration:underline}.detail-modal__text a:hover{opacity:.7}.detail-modal__topic-group:not(:first-child){margin-top:1rem}.detail-modal__topic-header{display:flex;align-items:center;gap:.5rem;font-size:.78rem;font-weight:700;color:var(--color-text);margin-bottom:.625rem}.detail-modal__topic-header svg{width:1rem;height:1rem;color:var(--color-nacht-paars);flex-shrink:0}.detail-modal__topics{display:flex;flex-direction:column;gap:.5rem}.detail-modal__topic{display:flex;align-items:baseline;gap:.625rem;padding:.5rem .75rem;background:var(--color-surface-alt);border-radius:var(--radius-sm);border-left:3px solid var(--color-lente-groen-80)}@media(max-width:480px){.detail-modal__topic{flex-direction:column;gap:.375rem}}.detail-modal__topic-name{font-size:.8125rem;font-weight:700;color:var(--color-text);white-space:nowrap;flex-shrink:0}.detail-modal__topic-tags{display:flex;flex-wrap:wrap;gap:.25rem}.detail-modal__tag{display:inline-block;font-size:.6875rem;font-weight:500;color:var(--color-text-muted);background:var(--color-surface);padding:.125rem .5rem;border-radius:var(--radius-full);border:1px solid var(--color-border)}.detail-modal__tree{display:flex;flex-direction:column;gap:.375rem}.detail-modal__tree-root{background:var(--color-surface-alt);border-radius:var(--radius-sm);padding:.625rem .75rem;border:1px solid var(--color-border)}.detail-modal__tree-root:not(:last-child){margin-bottom:.25rem}.detail-modal__tree-branch{padding-left:1rem;margin-top:.25rem;position:relative}.detail-modal__tree-branch:before{content:"";position:absolute;left:.375rem;top:0;bottom:0;width:1px;background:var(--color-border)}.detail-modal__tree-label{display:block;padding:.1875rem 0;position:relative}.detail-modal__tree-label:before{content:"";position:absolute;left:-.625rem;top:50%;width:.375rem;height:1px;background:var(--color-border)}.detail-modal__tree-label--l1{font-size:.8125rem;font-weight:700;color:var(--color-text);padding-bottom:.25rem}.detail-modal__tree-label--l1:before{display:none}.detail-modal__tree-label--l2{font-size:.75rem;font-weight:600;color:var(--color-nacht-paars)}.detail-modal__tree-label--l3{font-size:.72rem;font-weight:500;color:var(--color-text)}.detail-modal__tree-leaves{padding-left:1rem;margin:.125rem 0 .25rem;position:relative}.detail-modal__tree-leaves:before{content:"";position:absolute;left:.375rem;top:0;bottom:0;width:1px;background:var(--color-border)}.detail-modal__tree-leaf{display:block;font-size:.6875rem;color:var(--color-text-muted);padding:.0625rem 0;position:relative}.detail-modal__tree-leaf:before{content:"";position:absolute;left:-.625rem;top:50%;width:.375rem;height:1px;background:var(--color-border)}.detail-modal__empty{padding:2rem 0;text-align:center;font-size:.8125rem;color:var(--color-text-muted)}.detail-modal__footer{display:flex;padding:.75rem 1.5rem;border-top:1px solid var(--color-border);flex-shrink:0;background:var(--color-surface-alt)}.detail-modal__footer-btn{display:inline-flex;align-items:center;gap:.375rem;font-size:.8125rem;font-weight:600;font-family:inherit;color:var(--color-text-muted);background:none;border:none;cursor:pointer;padding:.375rem 0;transition:color var(--transition-fast)}.detail-modal__footer-btn svg{width:.875rem;height:.875rem}.detail-modal__footer-btn:hover{color:var(--color-nacht-paars)}@keyframes loader-spin{to{transform:rotate(360deg)}}@keyframes loader-pulse{0%,to{opacity:.4}50%{opacity:1}}@keyframes loader-fade-in{0%{opacity:0}to{opacity:1}}.loader-ring{display:inline-block;width:44px;height:44px;border:3px solid var(--color-lente-groen-40, #d8eae3);border-top-color:var(--color-nacht-paars);border-radius:50%;animation:loader-spin .8s linear infinite}.loader-ring--sm{width:18px;height:18px;border-width:2px;animation-duration:.75s}.loader-ring--lg{width:48px;height:48px}.loader-text{font-size:.8125rem;font-weight:500;color:var(--color-avond-paars, #785e7c);letter-spacing:.04em;animation:loader-pulse 1.5s ease-in-out infinite}.loader{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:3rem 1rem;animation:loader-fade-in .2s ease-out}.loader--inline{flex-direction:row;padding:1.5rem}.loader--fullscreen{min-height:100vh}.loader--fullpage{min-height:calc(100vh - var(--topbar-height, 0px) - 6rem)}.page-loading-overlay{position:fixed;top:var(--topbar-height, 0);left:0;right:0;bottom:0;z-index:100;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;background:#ffffffb3;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:loader-fade-in .15s ease-out;pointer-events:all}.class-mgmt{display:flex;flex-direction:column;gap:2rem}.class-mgmt__section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.class-mgmt__section-title{font-size:.9375rem;font-weight:900;color:var(--color-nacht-paars)}.class-mgmt__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(20rem,1fr));gap:1rem}.class-mgmt__add-btn,.class-mgmt__join-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.4375rem .875rem;font-size:.75rem;font-weight:700;font-family:inherit;color:#fff;background:var(--color-nacht-paars);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.class-mgmt__add-btn svg,.class-mgmt__join-btn svg{width:.875rem;height:.875rem}.class-mgmt__add-btn:hover,.class-mgmt__join-btn:hover{opacity:.88;box-shadow:var(--shadow-sm)}.class-mgmt__join-btn{background:var(--color-lente-groen);color:var(--color-nacht-paars)}.class-tile--joined{border-left-color:var(--color-lente-groen);cursor:default}.class-tile__desc{font-size:.75rem;color:var(--color-text-muted);margin-bottom:.5rem;line-height:1.4}.class-tile__pill--code{font-family:monospace;letter-spacing:.08em;font-size:.625rem}.class-tile__leave{display:inline-block;margin-top:.5rem;font-size:.6875rem;font-weight:600;font-family:inherit;color:var(--color-text-muted);background:none;border:none;cursor:pointer;padding:0;text-decoration:underline;transition:color var(--transition-fast)}.class-tile__leave:hover{color:#dc2626}.class-modal{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:0 20px 60px #0000004d;width:440px;max-width:95vw;overflow:hidden}.class-modal__overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#00000073;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:1rem}.class-modal__header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:#ebf5f1;border-bottom:1px solid var(--color-border)}.class-modal__title{font-size:1rem;font-weight:900;color:var(--color-nacht-paars)}.class-modal__close{background:none;border:none;cursor:pointer;padding:.375rem;color:var(--color-text-muted);border-radius:var(--radius-sm)}.class-modal__close svg{width:1.125rem;height:1.125rem}.class-modal__close:hover{background:#0000000f;color:var(--color-text)}.class-modal__body{padding:1.25rem}.class-modal__field{margin-bottom:1rem}.class-modal__label{display:block;font-size:.75rem;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.375rem}.class-modal__input,.class-modal__textarea{width:100%;font-size:.8125rem;font-family:inherit;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);transition:border-color var(--transition-fast)}.class-modal__input:focus,.class-modal__textarea:focus{outline:none;border-color:var(--color-nacht-paars);box-shadow:0 0 0 3px #56355b14}.class-modal__input--code{font-family:monospace;font-size:1.25rem;font-weight:700;text-align:center;letter-spacing:.15em;text-transform:uppercase}.class-modal__textarea{resize:vertical;min-height:3rem}.class-modal__error{font-size:.8125rem;color:#dc2626;margin-bottom:.75rem}.class-modal__success{font-size:.8125rem;color:#16a34a;margin-bottom:.75rem}.class-modal__actions{display:flex;gap:.5rem;justify-content:flex-end}.class-modal__cancel{background:var(--color-surface-alt);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-family:inherit;font-weight:600;font-size:.8125rem;padding:.5rem 1rem;cursor:pointer;transition:all var(--transition-fast)}.class-modal__cancel:hover{background:var(--color-border)}.class-modal__cancel:disabled{opacity:.5;cursor:not-allowed}.class-modal__submit{background:var(--color-nacht-paars);color:#fff;border:none;border-radius:var(--radius-sm);font-family:inherit;font-weight:600;font-size:.8125rem;padding:.5rem 1rem;cursor:pointer;transition:all var(--transition-fast)}.class-modal__submit:hover{opacity:.88}.class-modal__submit:disabled{opacity:.5;cursor:not-allowed}.class-detail__back{display:inline-flex;align-items:center;gap:.25rem;background:none;border:none;font-family:inherit;font-size:.8125rem;font-weight:600;color:var(--color-nacht-paars);cursor:pointer;padding:.25rem 0;margin-bottom:1.5rem}.class-detail__back svg{width:.875rem;height:.875rem}.class-detail__back:hover{opacity:.7}.class-detail__card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:1rem}.class-detail__card-top{display:flex;justify-content:space-between;align-items:flex-start;padding:1.25rem}.class-detail__name{font-size:1.125rem;font-weight:900;color:var(--color-nacht-paars)}.class-detail__desc{font-size:.8125rem;color:var(--color-text-muted);margin-top:.25rem}.class-detail__meta{display:flex;gap:.75rem;margin-top:.5rem;font-size:.6875rem;color:var(--color-text-muted)}.class-detail__actions{display:flex;gap:.375rem;flex-shrink:0}.class-detail__action-btn{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;padding:0;transition:all var(--transition-fast)}.class-detail__action-btn svg{width:.875rem;height:.875rem}.class-detail__action-btn:hover{border-color:var(--color-nacht-paars);color:var(--color-nacht-paars)}.class-detail__action-btn--danger:hover{border-color:#dc2626;color:#dc2626;background:#fee2e2}.class-detail__edit-form{flex:1;display:flex;flex-direction:column;gap:.5rem}.class-detail__edit-actions{display:flex;gap:.5rem;justify-content:flex-end}.class-detail__invite{border-top:1px solid var(--color-border);padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.75rem}.class-detail__invite-label{display:flex;align-items:center;gap:.375rem;font-size:.6875rem;font-weight:700;color:var(--color-text-heading)}.class-detail__invite-label svg{width:.875rem;height:.875rem;color:var(--color-text-muted)}.class-detail__invite-field{display:flex;align-items:stretch;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;background:var(--color-surface-alt);transition:border-color var(--transition-fast)}.class-detail__invite-field:hover{border-color:var(--color-avond-paars)}.class-detail__invite-url{flex:1;font-family:monospace;font-size:.75rem;color:var(--color-nacht-paars);padding:.625rem .875rem;line-height:1.4;word-break:break-all;display:flex;align-items:center;-webkit-user-select:all;user-select:all}.class-detail__invite-copy{display:inline-flex;align-items:center;gap:.375rem;font-size:.75rem;font-weight:700;font-family:inherit;white-space:nowrap;background:var(--color-nacht-paars);color:#fff;border:none;padding:.625rem 1rem;cursor:pointer;transition:all var(--transition-fast)}.class-detail__invite-copy svg{width:.875rem;height:.875rem}.class-detail__invite-copy:hover{background:var(--color-nacht-paars);opacity:.9}.class-detail__invite-copy--done{background:#16a34a}.class-detail__invite-copy--done:hover{background:#16a34a;opacity:1}.class-detail__invite-hint{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.class-detail__invite-hint span{font-size:.6875rem;color:var(--color-text-muted)}.class-detail__invite-regen{display:inline-flex;align-items:center;gap:.25rem;font-size:.625rem;font-weight:600;font-family:inherit;color:var(--color-text-muted);background:none;border:none;cursor:pointer;padding:0;transition:color var(--transition-fast);white-space:nowrap}.class-detail__invite-regen svg{width:.75rem;height:.75rem}.class-detail__invite-regen:hover{color:var(--color-nacht-paars)}.class-detail__section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.25rem;margin-bottom:1rem}.class-detail__section-title{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:900;color:var(--color-nacht-paars);margin-bottom:.75rem}.class-detail__section-title svg{width:1rem;height:1rem;color:var(--color-text-muted)}.class-detail__empty{font-size:.8125rem;color:var(--color-text-muted)}.class-detail__ll-list{display:flex;flex-direction:column;gap:.375rem}.class-detail__ll-item{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.625rem .75rem;background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-family:inherit;text-align:left;cursor:pointer;transition:all var(--transition-fast)}.class-detail__ll-item svg{width:.875rem;height:.875rem;color:var(--color-text-muted);flex-shrink:0}.class-detail__ll-item:hover{border-color:var(--color-avond-paars);background:var(--color-surface)}.class-detail__ll-info{display:flex;flex-direction:column;gap:.125rem}.class-detail__ll-name{font-size:.8125rem;font-weight:700;color:var(--color-text)}.class-detail__ll-meta{font-size:.6875rem;color:var(--color-text-muted)}.class-detail__member-list{display:flex;flex-direction:column;gap:.375rem}.class-detail__member{display:flex;align-items:center;background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.class-detail__member:hover{background:var(--color-surface);border-color:var(--color-avond-paars)}.class-detail__member:hover .class-detail__member-remove{opacity:1}.class-detail__member-main{display:flex;align-items:center;gap:.75rem;padding:.625rem .75rem;flex:1;min-width:0}.class-detail__member-avatar{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:var(--color-avond-paars);color:var(--color-nacht-paars);font-weight:900;font-size:.75rem;border-radius:var(--radius-full);flex-shrink:0}.class-detail__member-info{display:flex;flex-direction:column;gap:.0625rem;flex:1;min-width:0}.class-detail__member-name{font-size:.8125rem;font-weight:700;color:var(--color-text)}.class-detail__member-date{font-size:.6875rem;color:var(--color-text-muted)}.class-detail__member-remove{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;margin-right:.375rem;background:none;border:none;cursor:pointer;padding:0;color:var(--color-text-muted);border-radius:var(--radius-sm);opacity:0;transition:all var(--transition-fast);flex-shrink:0}.class-detail__member-remove svg{width:.875rem;height:.875rem}.class-detail__member-remove:hover{color:#dc2626;background:#fee2e2}.student-view__header{display:flex;align-items:center;gap:.75rem}.sv-leerlijn{margin-bottom:2rem}.sv-leerlijn__header{display:flex;align-items:center;gap:.5rem;margin-bottom:1.25rem;flex-wrap:wrap}.sv-leerlijn__title{font-size:1rem;font-weight:900;color:var(--color-nacht-paars)}.sv-leerlijn__badge{display:inline-flex;padding:.125rem .5rem;font-size:.625rem;font-weight:700;border-radius:var(--radius-full);background:var(--color-avond-paars);color:var(--color-nacht-paars)}.sv-leerlijn__badge--muted{background:var(--color-surface-alt);color:var(--color-text-muted)}.sv-jaar{margin-bottom:1.5rem}.sv-jaar__label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:900;color:var(--color-nacht-paars);margin-bottom:.75rem}.sv-jaar__num{display:flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;border-radius:var(--radius-full);background:var(--color-nacht-paars);color:#fff;font-size:.6875rem;font-weight:900;flex-shrink:0}.sv-jaar__kwartalen{display:grid;grid-template-columns:repeat(4,1fr);gap:.625rem}.sv-kwartaal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.sv-kwartaal__header{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;background:var(--color-surface-alt);border-bottom:1px solid var(--color-border)}.sv-kwartaal__badge{display:inline-flex;align-items:center;justify-content:center;padding:.125rem .375rem;border-radius:var(--radius-sm);background:var(--color-nacht-paars);color:#fff;font-size:.5625rem;font-weight:900;flex-shrink:0}.sv-kwartaal__title{font-size:.6875rem;font-weight:700;color:var(--color-text-heading)}.sv-kwartaal__count{font-size:.5625rem;color:var(--color-text-muted);margin-left:auto}.sv-kwartaal__content{display:flex;flex-direction:column}.sv-kwartaal__empty{display:flex;align-items:center;justify-content:center;padding:1.25rem .625rem;font-size:.6875rem;color:var(--color-text-muted)}.sv-module{display:flex;align-items:center;gap:.625rem;width:100%;padding:.5rem .75rem;font-family:inherit;text-align:left;background:none;border:none;cursor:pointer;transition:background var(--transition-fast)}.sv-module+.sv-module{border-top:1px solid var(--color-border)}.sv-module:hover{background:var(--color-surface-alt)}.sv-module--examen .sv-module__img{border-color:#dc2626}.sv-module__img{width:2.25rem;height:2.25rem;border-radius:var(--radius-sm);overflow:hidden;background:var(--color-surface-alt);border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;font-size:.625rem;font-weight:900;color:var(--color-text-muted);flex-shrink:0}.sv-module__img img{width:100%;height:100%;object-fit:cover}.sv-module__info{flex:1;min-width:0;display:flex;flex-direction:column}.sv-module__title{font-size:.75rem;font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sv-module__cat{font-size:.625rem;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sv-module__exam{font-size:.5625rem;font-weight:700;color:#dc2626;background:#fee2e2;padding:.125rem .375rem;border-radius:var(--radius-full);flex-shrink:0}.sv-modal{display:flex;flex-direction:column}.sv-modal__hero{display:flex;align-items:center;gap:1rem;padding:1.25rem;border-bottom:1px solid var(--color-border)}.sv-modal__hero-img{width:4rem;height:4rem;border-radius:var(--radius-md);overflow:hidden;background:var(--color-surface-alt);border:1px solid var(--color-border);flex-shrink:0}.sv-modal__hero-img img{width:100%;height:100%;object-fit:cover}.sv-modal__hero-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:900;color:var(--color-text-muted)}.sv-modal__hero-info{flex:1;min-width:0}.sv-modal__hero-title{font-size:.9375rem;font-weight:900;color:var(--color-nacht-paars);line-height:1.3;margin-bottom:.375rem}.sv-modal__hero-tags{display:flex;gap:.25rem;flex-wrap:wrap}.sv-modal__tag{display:inline-flex;padding:.125rem .5rem;font-size:.5625rem;font-weight:700;border-radius:var(--radius-full);background:var(--color-surface-alt);color:var(--color-text-muted)}.sv-modal__tag--exam{background:#fee2e2;color:#dc2626}.sv-modal__section{padding:1rem 1.25rem;border-bottom:1px solid var(--color-border)}.sv-modal__label{display:block;font-size:.625rem;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.5rem}.sv-modal__student{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;font-weight:700;color:var(--color-text)}.sv-modal__stats{display:flex;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;margin-bottom:.75rem}.sv-modal__stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:.125rem;padding:.75rem .5rem}.sv-modal__stat:not(:last-child){border-right:1px solid var(--color-border)}.sv-modal__stat-val{font-size:1rem;font-weight:900;color:var(--color-nacht-paars)}.sv-modal__stat-lbl{font-size:.5625rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em}.sv-modal__no-data{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:var(--color-surface-alt);border-radius:var(--radius-sm);color:var(--color-text-muted);font-size:.75rem}.sv-modal__no-data svg{width:1rem;height:1rem;opacity:.4;flex-shrink:0}.sv-modal__actions{display:flex;gap:.5rem;padding:1rem 1.25rem}.sv-modal__action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.375rem;padding:.5rem .875rem;font-size:.75rem;font-weight:700;font-family:inherit;color:#fff;background:var(--color-nacht-paars);border:none;border-radius:var(--radius-sm);text-decoration:none;cursor:pointer;transition:all var(--transition-fast)}.sv-modal__action-btn svg{width:.875rem;height:.875rem}.sv-modal__action-btn:hover{opacity:.88}.sv-modal__action-btn--secondary{background:none;color:var(--color-text-muted);border:1px solid var(--color-border)}.sv-modal__action-btn--secondary:hover{background:var(--color-surface-alt);opacity:1}.login{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-surface-alt);position:relative}.login__card{position:relative;z-index:1;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:3rem 2.5rem 2.5rem;width:100%;max-width:24rem;text-align:center;box-shadow:var(--shadow-lg)}.login__logo-img{width:16rem;height:auto;margin:0 auto 2rem;display:block}.login__subtitle{font-size:.875rem;color:var(--color-text-muted);margin-bottom:2rem}.login__button{width:100%;padding:.8125rem 1.5rem;background:var(--color-nacht-paars);color:#fff;border:none;border-radius:var(--radius-md);font-family:inherit;font-size:.875rem;font-weight:700;cursor:pointer;transition:background var(--transition-base),box-shadow var(--transition-base);letter-spacing:.01em}.login__button:hover{background:var(--color-nacht-paars-80);box-shadow:var(--shadow-md)}.login__decoration{position:fixed;bottom:-6rem;right:-4rem;width:28rem;height:auto;opacity:.06;pointer-events:none;-webkit-user-select:none;user-select:none}.login__accent{position:fixed;bottom:0;left:0;right:0;height:3px;background:var(--color-lente-groen)}.dashboard__toggle{display:inline-flex;background:var(--color-surface-alt);border-radius:var(--radius-md);padding:.1875rem;gap:.125rem}.dashboard__toggle-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;font-size:.6875rem;font-weight:700;font-family:inherit;color:var(--color-text-muted);background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.dashboard__toggle-btn svg{width:.75rem;height:.75rem}.dashboard__toggle-btn:hover{color:var(--color-nacht-paars)}.dashboard__toggle-btn--active{background:var(--color-surface);color:var(--color-nacht-paars);box-shadow:var(--shadow-sm)}.dashboard__breadcrumb{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem;font-size:.8125rem;color:var(--color-text-muted)}.dashboard__breadcrumb button{display:inline-flex;align-items:center;gap:.25rem;background:none;border:none;font-family:inherit;font-size:.8125rem;font-weight:600;color:var(--color-nacht-paars);cursor:pointer;padding:.25rem 0}.dashboard__breadcrumb button svg{width:.875rem;height:.875rem}.dashboard__breadcrumb button:hover{opacity:.7}.dashboard__breadcrumb span:before{content:"/";margin-right:.5rem;color:var(--color-border)}.dashboard__breadcrumb span:first-of-type:before{content:none}.dashboard__error{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.5rem;text-align:center}.dashboard__error p{font-size:.8125rem;color:var(--color-text-muted);margin-bottom:.75rem}.dashboard__error button{font-size:.8125rem;font-weight:700;font-family:inherit;color:var(--color-nacht-paars);background:none;border:1px solid var(--color-nacht-paars);border-radius:var(--radius-sm);padding:.375rem 1rem;cursor:pointer}.dashboard__error button:hover{background:var(--color-nacht-paars);color:#fff}.dashboard__empty{font-size:.8125rem;color:var(--color-text-muted);padding:2rem;text-align:center}.dashboard__profile-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.5rem;max-width:28rem}.dashboard__card-title{font-size:.9375rem;font-weight:700;color:var(--color-text-heading);margin-bottom:1rem}.dashboard__profile-list{display:flex;flex-direction:column;gap:.625rem}.dashboard__profile-row{display:flex;justify-content:space-between;align-items:baseline;padding-bottom:.625rem;border-bottom:1px solid var(--color-border)}.dashboard__profile-row:last-child{border-bottom:none;padding-bottom:0}.dashboard__profile-row dt{font-size:.8125rem;font-weight:500;color:var(--color-text-muted)}.dashboard__profile-row dd{font-size:.8125rem;font-weight:700;color:var(--color-text)}.dashboard__role-badge{text-transform:capitalize;color:var(--color-primary)!important}.dashboard__section-title{font-size:.875rem;font-weight:700;color:var(--color-text-heading);margin-bottom:.75rem}.dashboard__student-view{display:flex;flex-direction:column;gap:1.5rem}.dashboard__module-picker{margin-top:1rem}.dashboard__hint{font-size:.8125rem;color:var(--color-text-muted);margin-bottom:.5rem}.dashboard__module-tags{display:flex;flex-wrap:wrap;gap:.375rem}.dashboard__student-progress{display:flex;flex-direction:column;gap:1.5rem}.class-tile{position:relative;background:var(--color-surface);border:1px solid var(--color-border);border-left:4px solid var(--color-lente-groen);border-radius:var(--radius-md);padding:2rem 1.25rem 1.25rem;cursor:pointer;transition:all var(--transition-fast);text-align:left;font-family:inherit}.class-tile:hover{border-color:var(--color-nacht-paars);border-left-color:var(--color-nacht-paars);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.class-tile__badge{position:absolute;top:.5rem;right:.75rem;font-size:.5625rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:.125rem .5rem;border-radius:var(--radius-full);background:var(--color-ochtend-blauw);color:#fff}.class-tile__badge--org{background:var(--color-lente-groen);color:var(--color-nacht-paars)}.class-tile__badge--joined{background:var(--color-accent-subtle);color:var(--color-primary)}.class-tile__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.class-tile__header>svg{width:1rem;height:1rem;color:var(--color-text-muted);flex-shrink:0;opacity:.5;transition:opacity var(--transition-fast)}.class-tile:hover .class-tile__header>svg{opacity:1}.class-tile__name{font-size:1.125rem;font-weight:900;color:var(--color-nacht-paars);line-height:1.2}.class-tile__desc{font-size:.6875rem;color:var(--color-text-muted);margin-bottom:.625rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.class-tile--all{border-left:4px solid;border-image:linear-gradient(to bottom,var(--color-lente-groen),var(--color-ochtend-blauw)) 1;opacity:.85}.class-tile--all .class-tile__name{color:var(--color-text)}.class-tile--all:hover{border-image:none;border-left-color:var(--color-nacht-paars)}.class-tile--managed{border-left-color:var(--color-ochtend-blauw)}.class-tile--joined{border-left-color:var(--color-avond-paars, var(--color-accent-subtle));cursor:default}.class-tile--joined:hover{transform:none;box-shadow:var(--shadow-sm)}.class-tile__stats{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:.625rem}.class-tile__pill{display:inline-flex;align-items:center;gap:.3rem;font-size:.6875rem;font-weight:600;color:var(--color-text-muted);background:var(--color-surface-alt);padding:.1875rem .5rem;border-radius:var(--radius-full);line-height:1.2}.class-tile__pill--code{font-family:monospace;letter-spacing:.08em;font-size:.5625rem}.class-tile__pill--score{font-weight:900}.class-tile__pill-ico{width:.6875rem;height:.6875rem;flex-shrink:0}.class-tile__score-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--color-border)}.class-tile__score-dot.score--good{background:#64b34d}.class-tile__score-dot.score--ok{background:#d4a520}.class-tile__score-dot.score--low{background:#e05555}.module-tag{background:var(--color-accent-subtle);color:var(--color-primary);font-size:.8125rem;font-weight:700;font-family:inherit;padding:.375rem .875rem;border-radius:var(--radius-full);border:2px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.module-tag:hover{background:var(--color-accent);color:var(--color-surface)}.module-tag--active{border-color:var(--color-primary);background:var(--color-primary);color:var(--color-surface)}.student-list{display:flex;flex-direction:column;gap:.375rem}.student-list__item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);font-family:inherit;text-align:left}.student-list__item>svg{width:.875rem;height:.875rem;color:var(--color-text-muted);flex-shrink:0}.student-list__item:hover{border-color:var(--color-nacht-paars);background:var(--color-surface-alt)}.student-list__info{display:flex;align-items:center;gap:.75rem}.student-list__avatar{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:50%;background:var(--color-avond-paars, var(--color-accent-subtle));color:#fff;font-size:.75rem;font-weight:900;flex-shrink:0}.student-list__text{display:flex;flex-direction:column;gap:.125rem}.student-list__name{font-size:.8125rem;font-weight:700;color:var(--color-text)}.student-list__email{font-size:.6875rem;color:var(--color-text-muted)}.progress-module{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.25rem}.progress-module__title{font-size:.875rem;font-weight:900;color:var(--color-nacht-paars);margin-bottom:.75rem}.progress-module__grid{display:flex;flex-direction:column;gap:.625rem}.progress-opdracht{padding:.625rem .75rem;background:var(--color-surface-alt);border-radius:var(--radius-sm)}.progress-opdracht__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.375rem}.progress-opdracht__name{font-size:.8125rem;font-weight:600;color:var(--color-text)}.progress-opdracht__score{font-size:.875rem;font-weight:900}.progress-opdracht__score--none{color:var(--color-text-muted)}.progress-opdracht__score-pill{display:inline-flex;align-items:center;font-size:.75rem;font-weight:900;padding:.125rem .5rem;border-radius:var(--radius-full);background:var(--color-surface)}.progress-opdracht__score-pill.score--good{color:#3a8a3a;background:#eaf7ea}.progress-opdracht__score-pill.score--ok{color:#92400e;background:#fef3c7}.progress-opdracht__score-pill.score--low{color:#991b1b;background:#fee2e2}.progress-opdracht__score-pill--none{color:var(--color-text-muted)}.progress-opdracht__bar{height:6px;background:var(--color-border);border-radius:var(--radius-full);overflow:hidden;margin-bottom:.375rem}.progress-opdracht__fill{height:100%;border-radius:var(--radius-full);transition:width .4s ease;background:var(--color-border)}.progress-opdracht__fill.score--good{background:#64b34d}.progress-opdracht__fill.score--ok{background:#f0c030}.progress-opdracht__fill.score--low{background:#e05555}.progress-opdracht__meta{display:flex;justify-content:space-between;font-size:.6875rem}.progress-opdracht__status{font-weight:600;color:var(--color-text-muted)}.progress-opdracht__status--done{color:#64b34d}.progress-opdracht__date{color:var(--color-text-muted)}.score--good{color:#64b34d}.score--ok{color:#d4a520}.score--low{color:#e05555}.join-class{display:flex;justify-content:center;padding:4rem 1rem}.join-class__result{display:flex;flex-direction:column;align-items:center;gap:.75rem;text-align:center}.join-class__result>svg{width:3rem;height:3rem}.join-class__result p{font-size:1rem;font-weight:700;color:var(--color-text)}.join-class__result--success>svg{color:#16a34a}.join-class__result--error>svg{color:#dc2626}.join-class__redirect{font-size:.8125rem;color:var(--color-text-muted)}.join-class__back{font-size:.8125rem;font-weight:600;font-family:inherit;color:var(--color-nacht-paars);background:none;border:1px solid var(--color-nacht-paars);border-radius:var(--radius-sm);padding:.5rem 1rem;cursor:pointer;margin-top:.5rem}.join-class__back:hover{background:var(--color-nacht-paars);color:#fff}.dash-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(18rem,1fr));gap:1rem}.dash-card{display:flex;flex-direction:column;background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;transition:all var(--transition-base);min-height:14rem}.dash-card:hover{box-shadow:0 8px 24px #56355b1f;transform:translateY(-3px);border-color:var(--color-nacht-paars)}.dash-card--clickable{cursor:pointer}.dash-card--add{align-items:center;justify-content:center;gap:.75rem;border:2px dashed var(--color-border);cursor:pointer;font-family:inherit;color:var(--color-text-muted);min-height:10rem}.dash-card--add svg{width:2rem;height:2rem;color:var(--color-border);transition:color var(--transition-fast)}.dash-card--add span{font-size:.8125rem;font-weight:700}.dash-card--add:hover{border-color:var(--color-nacht-paars);color:var(--color-nacht-paars);background:#d2bbd50f;box-shadow:none;transform:none}.dash-card--add:hover svg{color:var(--color-nacht-paars)}.dash-card--all{border-style:dashed;border-color:var(--color-avond-paars)}.dash-card__top{padding:1.5rem 1.25rem 1.25rem;flex:1;cursor:pointer;display:flex;flex-direction:column}.dash-card__header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.375rem}.dash-card__title{font-size:1rem;font-weight:900;color:var(--color-nacht-paars);line-height:1.3}.dash-card__badge{display:inline-flex;padding:.125rem .5rem;font-size:.5625rem;font-weight:700;color:var(--color-nacht-paars);background:var(--color-avond-paars);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;flex-shrink:0}.dash-card__badge--org{background:#9dbde259}.dash-card__badge--joined{background:#9dcab959}.dash-card__desc{font-size:.75rem;color:var(--color-text-muted);line-height:1.6;margin-bottom:.75rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.dash-card__info-row{display:flex;gap:1rem;margin-top:auto;padding-top:1rem}.dash-card__info-item{display:flex;align-items:center;gap:.5rem;flex:1}.dash-card__info-item>svg{width:1.125rem;height:1.125rem;color:var(--color-avond-paars);flex-shrink:0}.dash-card__info-item>div{display:flex;flex-direction:column}.dash-card__info-num{font-size:1rem;font-weight:900;color:var(--color-nacht-paars);line-height:1.2}.dash-card__info-code{font-size:.6875rem;font-weight:700;font-family:monospace;color:var(--color-nacht-paars);letter-spacing:.05em;line-height:1.2}.dash-card__info-label{font-size:.5625rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em}.dash-card__meta{display:flex;flex-wrap:wrap;gap:.75rem;font-size:.6875rem;color:var(--color-text-muted);margin-top:auto;padding-top:.75rem}.dash-card__meta span{display:inline-flex;align-items:center;gap:.25rem}.dash-card__meta svg{width:.75rem;height:.75rem}.dash-card__score{display:inline-block;width:.5rem;height:.5rem;border-radius:var(--radius-full)}.dash-card__invite{border-top:1px solid var(--color-border);padding:.625rem 1.25rem}.dash-card__invite-btn{display:flex;align-items:center;justify-content:center;gap:.375rem;width:100%;padding:.4375rem;font-size:.6875rem;font-weight:700;font-family:inherit;color:var(--color-nacht-paars);background:var(--color-accent-subtle);border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.dash-card__invite-btn svg{width:.8125rem;height:.8125rem}.dash-card__invite-btn:hover{border-color:var(--color-nacht-paars);background:var(--color-avond-paars)}.monitor__controls{display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-end;margin-bottom:1rem;padding:.875rem 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.monitor__control-group{display:flex;flex-direction:column;gap:.25rem}.monitor__label{font-size:.625rem;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.monitor__select,.monitor__input{font-size:.8125rem;font-family:inherit;padding:.4375rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);min-width:10rem;transition:border-color var(--transition-fast)}.monitor__select:focus,.monitor__input:focus{outline:none;border-color:var(--color-nacht-paars);box-shadow:0 0 0 3px #56355b14}.monitor__select:disabled,.monitor__input:disabled{opacity:.5;cursor:not-allowed}.monitor__refresh{display:inline-flex;align-items:center;gap:.375rem;padding:.4375rem 1rem;font-size:.8125rem;font-weight:700;font-family:inherit;color:#fff;background:var(--color-nacht-paars);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.monitor__refresh svg{width:.875rem;height:.875rem}.monitor__refresh:hover{opacity:.88;box-shadow:var(--shadow-sm)}.monitor__refresh:disabled{opacity:.4;cursor:not-allowed}.monitor__bar{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.5rem;padding:0 .25rem;flex-wrap:wrap}.monitor__bar-stats{display:flex;gap:1rem}.monitor__bar-stat{font-size:.6875rem;font-weight:600;color:var(--color-text-muted)}.monitor__bar-legend{display:flex;gap:.875rem}.monitor__bar-legend-item{display:inline-flex;align-items:center;gap:.3rem;font-size:.6875rem;color:var(--color-text-muted)}.monitor__swatch{display:inline-block;width:10px;height:10px;border-radius:3px}.monitor__swatch--good{background:var(--color-lente-groen)}.monitor__swatch--ok{background:#f0c030}.monitor__swatch--low{background:#e07070}.monitor__card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.monitor__scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.monitor__scroll::-webkit-scrollbar{height:5px}.monitor__scroll::-webkit-scrollbar-track{background:transparent}.monitor__scroll::-webkit-scrollbar-thumb{background:var(--color-avond-paars);border-radius:3px}.monitor__scroll::-webkit-scrollbar-thumb:hover{background:var(--color-nacht-paars)}.monitor__table{border-collapse:separate;border-spacing:0;width:max-content}.monitor__th-name{position:sticky;left:0;z-index:3;background:var(--color-surface-alt);max-width:220px;padding:.625rem .75rem;vertical-align:middle;font-size:.625rem;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;text-align:left;white-space:nowrap;border-bottom:2px solid var(--color-border)}.monitor__th-col{min-width:6rem;max-width:10rem;padding:.625rem .5rem;vertical-align:middle;background:var(--color-surface-alt);border-bottom:2px solid var(--color-border);font-size:.6875rem;font-weight:600;color:var(--color-nacht-paars);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.monitor__row:nth-child(2n) .monitor__td-name,.monitor__row:nth-child(2n) .monitor__td-cell{background:var(--color-surface-alt)}.monitor__row:nth-child(2n) .monitor__td-name{background:var(--color-surface-alt)}.monitor__row:hover .monitor__td-name,.monitor__row:hover .monitor__td-cell{background:#56355b0a}.monitor__td-name{position:sticky;left:0;z-index:2;background:var(--color-surface);max-width:220px;padding:0 .75rem;height:38px;font-size:.75rem;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left;border-bottom:1px solid rgba(0,0,0,.04);transition:background var(--transition-fast)}.monitor__td-cell{min-width:6rem;max-width:10rem;height:38px;padding:3px .5rem;border-bottom:1px solid rgba(0,0,0,.04);vertical-align:middle;text-align:center;background:var(--color-surface);transition:background var(--transition-fast)}.monitor__td-cell--active{cursor:pointer}.monitor__cell{display:flex;align-items:center;justify-content:center;width:100%;height:100%;border-radius:var(--radius-sm);transition:all .15s ease;background:transparent}.monitor__td-cell--active .monitor__cell:hover{transform:scale(1.1);box-shadow:var(--shadow-md)}.monitor__cell--selected{outline:2px solid var(--color-nacht-paars);outline-offset:1px;box-shadow:var(--shadow-md)}.monitor__cell.cell--good{background:var(--color-lente-groen)}.monitor__cell.cell--ok{background:#f5d76e}.monitor__cell.cell--low{background:#f0a0a0}.monitor__cell-val{font-size:.6875rem;font-weight:700;color:#333;line-height:1}.monitor__cell-ico{width:15px;height:15px}.monitor__cell-ico--done{color:#2d6e2d}.monitor__cell-ico--wip{color:#999}.result-modal{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:0 20px 60px #0000004d;width:680px;max-width:95vw;max-height:85vh;overflow-y:auto;position:relative}.result-modal__overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#00000073;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:1rem}.result-modal__header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:#ebf5f1;border-bottom:1px solid var(--color-border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;position:sticky;top:0;z-index:1}.result-modal__header-actions{display:flex;align-items:center;gap:.5rem}.result-modal__title{font-size:1rem;font-weight:900;color:var(--color-nacht-paars)}.result-modal__delete-btn{display:inline-flex;align-items:center;gap:.375rem;background:#fee2e2;color:#dc2626;border:1px solid #fecaca;border-radius:var(--radius-sm);font-family:inherit;font-weight:600;font-size:.6875rem;padding:.375rem .75rem;cursor:pointer;transition:all var(--transition-fast)}.result-modal__delete-btn svg{width:.875rem;height:.875rem}.result-modal__delete-btn:hover{background:#fecaca;border-color:#fca5a5}.result-modal__delete-confirm{padding:1rem 1.25rem;border-bottom:1px solid var(--color-border);background:#fffbeb}.result-modal__delete-warning{display:flex;align-items:flex-start;gap:.625rem;margin-bottom:.875rem;font-size:.8125rem;color:#92400e;line-height:1.5}.result-modal__delete-warning svg{width:1.125rem;height:1.125rem;flex-shrink:0;color:#b45309;margin-top:.125rem}.result-modal__delete-warning strong{color:#78350f}.result-modal__delete-actions{display:flex;gap:.5rem;justify-content:flex-end}.result-modal__delete-cancel{background:var(--color-surface-alt);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-family:inherit;font-weight:600;font-size:.8125rem;padding:.5rem 1rem;cursor:pointer;transition:all var(--transition-fast)}.result-modal__delete-cancel:hover{background:var(--color-border)}.result-modal__delete-cancel:disabled{opacity:.5;cursor:not-allowed}.result-modal__delete-confirm-btn{background:#dc2626;color:#fff;border:none;border-radius:var(--radius-sm);font-family:inherit;font-weight:600;font-size:.8125rem;padding:.5rem 1rem;cursor:pointer;transition:all var(--transition-fast)}.result-modal__delete-confirm-btn:hover{background:#b91c1c}.result-modal__delete-confirm-btn:disabled{opacity:.6;cursor:not-allowed}.result-modal__close{background:none;border:none;cursor:pointer;padding:.375rem;color:var(--color-text-muted);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.result-modal__close svg{width:1.125rem;height:1.125rem}.result-modal__close:hover{background:#0000000f;color:var(--color-text)}.result-modal__loading{display:flex;align-items:center;gap:.75rem;padding:2.5rem;justify-content:center;font-size:.8125rem;color:var(--color-text-muted)}.result-modal__info{border-bottom:1px solid var(--color-border)}.result-modal__info-table{width:100%;border-collapse:collapse}.result-modal__info-table th,.result-modal__info-table td{padding:.5rem 1.25rem;font-size:.8125rem;text-align:left;border-bottom:1px solid var(--color-border)}.result-modal__info-table th{font-weight:600;color:var(--color-text-muted);width:7rem;white-space:nowrap}.result-modal__info-table td{color:var(--color-text)}.result-modal__info-table tr:last-child th,.result-modal__info-table tr:last-child td{border-bottom:none}.result-modal__score-badge{font-weight:900;font-size:.9375rem}.result-modal__questions{padding:.5rem 0}.result-modal__question{margin:0 1rem .75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.result-modal__question:first-child{margin-top:.75rem}.result-modal__question-title{padding:.75rem 1rem;font-size:.8125rem;font-weight:600;color:var(--color-text);background:var(--color-surface-alt);border-bottom:1px solid var(--color-border);line-height:1.5}.result-modal__question-attempts{padding:0}.result-modal__chevron{width:.875rem;height:.875rem;flex-shrink:0;color:var(--color-text-muted);transition:transform var(--transition-fast)}.result-modal__attempt-toggle--open .result-modal__chevron{transform:rotate(90deg)}.result-modal__attempt{border-bottom:1px solid var(--color-border)}.result-modal__attempt:last-child{border-bottom:none}.result-modal__attempt-toggle{display:flex;align-items:center;gap:.5rem;width:100%;padding:.625rem 1rem;background:none;border:none;font-family:inherit;font-size:.8125rem;font-weight:600;text-align:left;cursor:pointer;color:var(--color-text);transition:background var(--transition-fast)}.result-modal__attempt-toggle:hover,.result-modal__attempt-toggle--open{background:#56355b08}.result-modal__attempt-detail{padding:0 1rem .75rem}.result-modal__choices{display:flex;flex-direction:column;gap:.25rem}.result-modal__choice{display:flex;align-items:center;gap:.5rem;padding:.375rem .5rem;border-radius:var(--radius-sm);font-size:.8125rem;border:1px solid transparent;background:var(--color-surface)}.result-modal__choice--correct{background:#eaf7ea;border-color:#b4ddb4}.result-modal__choice--wrong{background:#fdeeed;border-color:#f0b8b4}.result-modal__choice--missed{background:#fff8e6;border-color:#edd9a0}.result-modal__choice-indicator{width:18px;height:18px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.result-modal__choice-indicator svg{width:16px;height:16px}.result-modal__choice--correct .result-modal__choice-indicator svg{color:#3a8a3a}.result-modal__choice--wrong .result-modal__choice-indicator svg{color:#c0392b}.result-modal__choice--missed .result-modal__choice-indicator svg{color:#d4a520}.result-modal__choice-dot{width:8px;height:8px;border-radius:50%;background:var(--color-border)}.result-modal__match-table{width:100%;border-collapse:collapse;font-size:.8125rem}.result-modal__match-table th{padding:.375rem .5rem;font-weight:600;color:var(--color-text-muted);text-align:left;border-bottom:1px solid var(--color-border);font-size:.6875rem;text-transform:uppercase;letter-spacing:.03em}.result-modal__match-table td{padding:.375rem .5rem;border-bottom:1px solid var(--color-border)}.result-modal__match-table td:last-child{width:24px;text-align:center}.result-modal__match--correct td{background:#f0faf0}.result-modal__match--wrong td{background:#fef5f4}.result-modal__check{width:16px;height:16px;color:#3a8a3a}.result-modal__cross{width:16px;height:16px;color:#c0392b}.result-modal__fillin{display:flex;flex-direction:column;gap:.375rem}.result-modal__fillin-row{display:grid;grid-template-columns:auto 1fr;gap:.25rem .5rem;padding:.375rem .5rem;border-radius:var(--radius-sm);font-size:.8125rem;background:var(--color-surface);border:1px solid var(--color-border)}.result-modal__fillin-row--correct{background:#f0faf0;border-color:#b4ddb4}.result-modal__fillin-row--wrong{background:#fef5f4;border-color:#f0b8b4}.result-modal__fillin-label{font-weight:600;color:var(--color-text-muted);font-size:.6875rem}.result-modal__fillin-value{color:var(--color-text)}.result-modal__other{font-size:.8125rem;padding:.375rem 0}.result-modal__other-label{font-weight:600;color:var(--color-text-muted);margin-right:.375rem}.result-modal__attempts-summary{padding:1rem 1.25rem}.result-modal__section-title{font-size:.875rem;font-weight:700;color:var(--color-text-heading);margin-bottom:.75rem}.result-modal__attempt-row{display:flex;align-items:center;gap:.75rem;padding:.5rem .625rem;border-bottom:1px solid var(--color-border);font-size:.8125rem}.result-modal__attempt-row:last-child{border-bottom:none}.result-modal__attempt-num{width:1.5rem;font-weight:900;color:var(--color-nacht-paars);text-align:center}.result-modal__attempt-score{font-weight:900}.result-modal__attempt-badge{font-size:.6875rem;font-weight:600;color:var(--color-text-muted);padding:.125rem .5rem;border-radius:var(--radius-full);background:var(--color-surface-alt)}.result-modal__attempt-badge--done{color:#3a8a3a;background:#eaf7ea}.result-modal__attempt-duration{font-size:.6875rem;color:var(--color-text-muted);font-style:italic}.result-modal__attempt-date{margin-left:auto;font-size:.6875rem;color:var(--color-text-muted)}.modal-enter-active{transition:opacity .2s ease}.modal-enter-active .result-modal{transition:transform .2s ease,opacity .2s ease}.modal-leave-active{transition:opacity .15s ease}.modal-leave-active .result-modal{transition:transform .15s ease,opacity .15s ease}.modal-enter-from{opacity:0}.modal-enter-from .result-modal{transform:scale(.95) translateY(10px);opacity:0}.modal-leave-to{opacity:0}.modal-leave-to .result-modal{transform:scale(.97);opacity:0}.catalogus-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.catalogus-header__title{font-size:1.375rem;font-weight:900;color:var(--color-nacht-paars);letter-spacing:-.01em}.catalogus-search{margin-bottom:1rem}.catalogus-search__field{display:flex;align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.catalogus-search__field:focus-within{border-color:var(--color-nacht-paars);box-shadow:0 0 0 3px #56355b14}.catalogus-search__icon{width:1.125rem;height:1.125rem;margin-left:.875rem;color:var(--color-text-muted);flex-shrink:0}.catalogus-search__input{flex:1;border:none;outline:none;padding:.75rem;font-size:.875rem;background:transparent;color:var(--color-text);font-family:inherit}.catalogus-search__input::placeholder{color:var(--color-text-muted)}.catalogus-search__clear{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:none;background:none;cursor:pointer;color:var(--color-text-muted);padding:0;flex-shrink:0}.catalogus-search__clear svg{width:.875rem;height:.875rem}.catalogus-search__clear:hover{color:var(--color-text)}.catalogus-search__submit{padding:.75rem 1.25rem;background:var(--color-nacht-paars);color:var(--color-surface);border:none;font-size:.8125rem;font-weight:700;cursor:pointer;transition:background-color var(--transition-fast);font-family:inherit}.catalogus-search__submit:hover{background:var(--color-nacht-paars);opacity:.9}.active-filters{display:flex;flex-direction:column;gap:.375rem;margin-bottom:1rem}.active-filters__area{display:flex;flex-direction:column;gap:.125rem}.active-filters__area-tags{display:flex;flex-wrap:wrap;gap:.375rem;max-height:20rem;overflow:hidden;transition:max-height .3s ease-in-out}.active-filters__area-tags--collapsed{max-height:1.75rem}.active-filters__divider{display:flex;align-items:center;gap:.75rem}.active-filters__divider:before,.active-filters__divider:after{content:"";flex:1;border-top:1px dashed var(--color-border)}.active-filters__expand{display:inline-flex;align-items:center;gap:.25rem;flex-shrink:0;font-size:.6875rem;font-weight:500;color:var(--color-text-muted);border:none;background:none;cursor:pointer;padding:.25rem 0;font-family:inherit;white-space:nowrap}.active-filters__expand:hover{color:var(--color-nacht-paars)}.active-filters__expand-icon{width:.75rem;height:.75rem;transition:transform .2s ease}.active-filters__expand-icon--flipped{transform:rotate(180deg)}.active-filters__other{display:flex;flex-wrap:wrap;gap:.375rem;padding:.125rem 0}.active-filters__tag{display:inline-flex;align-items:center;gap:.375rem;font-size:.75rem;font-weight:600;padding:.25rem .5rem .25rem .625rem;border-radius:var(--radius-full);transition:opacity .15s ease}.active-filters__tag:hover{opacity:.85}.active-filters__tag--area{background:var(--color-lente-groen-80);color:var(--color-nacht-paars)}.active-filters__tag--other{background:var(--color-avond-paars-80);color:var(--color-nacht-paars)}.active-filters__tag--search{background:var(--color-nacht-paars);color:var(--color-surface)}.active-filters__tag-text{max-width:12rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.active-filters__tag-remove{display:flex;align-items:center;border:none;background:none;cursor:pointer;padding:0;color:inherit;opacity:.6}.active-filters__tag-remove svg{width:.6875rem;height:.6875rem}.active-filters__tag-remove:hover{opacity:1}.catalogus-layout{display:grid;grid-template-columns:17rem 1fr;gap:1.25rem;align-items:start}@media(max-width:768px){.catalogus-layout{grid-template-columns:1fr}}.catalogus-layout__sidebar{position:sticky;top:calc(var(--topbar-height) + 1rem);max-height:calc(100vh - var(--topbar-height) - 2rem);display:flex;flex-direction:column}.catalogus-layout__content{min-width:0}.catalogus-filters{display:flex;flex-direction:column;min-height:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.catalogus-filters__header{display:flex;justify-content:space-between;align-items:center;padding:.625rem .875rem;border-bottom:1px solid var(--color-border);flex-shrink:0}.catalogus-filters__title{font-size:.75rem;font-weight:900;color:var(--color-nacht-paars);text-transform:uppercase;letter-spacing:.04em}.catalogus-filters__actions{display:flex;align-items:center;gap:.5rem}.catalogus-filters__action{display:inline-flex;align-items:center;gap:.25rem;font-size:.6875rem;color:var(--color-text-muted);border:none;background:none;cursor:pointer;padding:.125rem 0;font-family:inherit;white-space:nowrap}.catalogus-filters__action svg{width:.6875rem;height:.6875rem}.catalogus-filters__action:hover{color:var(--color-primary)}.catalogus-filters__list{overflow-y:auto;padding:0 .625rem;overscroll-behavior:contain}.catalogus-filters__list::-webkit-scrollbar{width:3px}.catalogus-filters__list::-webkit-scrollbar-track{background:transparent}.catalogus-filters__list::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.catalogus-filters__list::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.catalogus-filter:not(:last-child){border-bottom:1px solid var(--color-border)}.catalogus-filter__header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.5rem .25rem;border:none;background:none;cursor:pointer;text-align:left;font-family:inherit;border-radius:var(--radius-sm);transition:background-color var(--transition-fast)}.catalogus-filter__header:hover{background:var(--color-surface-alt)}.catalogus-filter__header--open .catalogus-filter__chevron{transform:rotate(180deg)}.catalogus-filter__label{font-size:.78rem;font-weight:700;color:var(--color-text-heading)}.catalogus-filter__chevron{width:.875rem;height:.875rem;color:var(--color-text-muted);transition:transform var(--transition-fast);flex-shrink:0}.catalogus-filter__body{padding:0 .25rem .5rem}.catalogus-filter__item{padding:.125rem 0}.catalogus-filter__children{margin-left:1rem;padding-left:.5rem;border-left:1px solid var(--color-border)}.catalogus-filter__children .catalogus-filter__check{font-size:.7rem;color:var(--color-text-muted)}.catalogus-filter__children .catalogus-filter__item{padding:.0625rem 0}.catalogus-filter__check{display:flex;align-items:flex-start;gap:.375rem;cursor:pointer;font-size:.78rem;color:var(--color-text);line-height:1.4}.catalogus-filter__check input{margin-top:.2rem;accent-color:var(--color-nacht-paars);flex-shrink:0;width:.8125rem;height:.8125rem}.catalogus-filter__check-label{display:inline}.catalogus-filter__count{font-size:.625rem;color:var(--color-text-muted);font-weight:400;white-space:nowrap}.catalogus-filter__count:before{content:"("}.catalogus-filter__count:after{content:")"}.catalogus-filter__more{display:block;width:100%;margin-top:.25rem;padding:.25rem 0;border:none;background:none;cursor:pointer;font-size:.6875rem;color:var(--color-nacht-paars);font-weight:600;text-align:left;font-family:inherit}.catalogus-filter__more:hover{text-decoration:underline}.catalogus-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:.875rem;padding-bottom:.625rem;border-bottom:1px solid var(--color-border)}.catalogus-meta__text{font-size:.8125rem;color:var(--color-text-muted)}.catalogus-meta__text strong{color:var(--color-text)}.catalogus-meta__sort{font-size:.78rem;padding:.375rem .625rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);cursor:pointer;font-family:inherit}.catalogus-meta__sort:hover{border-color:var(--color-nacht-paars)}.catalogus-suggestions{font-size:.8125rem;color:var(--color-text-muted);margin-bottom:.875rem;padding:.5rem .75rem;background:var(--color-accent-subtle);border-radius:var(--radius-sm);border:1px solid var(--color-lente-groen-40)}.catalogus-suggestions__label{font-weight:600}.catalogus-suggestions__link{color:var(--color-nacht-paars);font-weight:700;border:none;background:none;cursor:pointer;text-decoration:underline;padding:0;font-family:inherit;font-size:inherit}.catalogus-suggestions__link:hover{opacity:.7}.catalogus-products{display:flex;flex-direction:column;gap:.75rem}.product-card{position:relative;display:grid;grid-template-columns:14rem 1fr;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;transition:box-shadow var(--transition-base),border-color var(--transition-base),transform var(--transition-base)}.product-card:hover{border-color:var(--color-nacht-paars);box-shadow:var(--shadow-md);transform:translateY(-1px)}.product-card--highlight{border-color:var(--color-lente-groen);box-shadow:inset 0 0 0 1px var(--color-lente-groen)}.product-card__image-link{position:relative;display:block;overflow:hidden;background:var(--color-surface-alt)}.product-card__image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.product-card:hover .product-card__image{transform:scale(1.04)}.product-card__image--placeholder{display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);height:100%}.product-card__image--placeholder svg{width:2rem;height:2rem;opacity:.3}.product-card__bookmark{position:absolute;top:.625rem;right:.625rem;z-index:2;display:flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;background:none;border:none;border-radius:var(--radius-full);cursor:pointer;color:var(--color-text-muted);transition:all var(--transition-fast)}.product-card__bookmark svg{width:1.25rem;height:1.25rem;fill:none;transition:fill var(--transition-fast),color var(--transition-fast),transform var(--transition-fast)}.product-card__bookmark:hover{color:#f59e0b}.product-card__bookmark:hover svg{fill:#f59e0b26;transform:scale(1.15)}.product-card__bookmark--active{color:#f59e0b}.product-card__bookmark--active svg{fill:#f59e0b}.product-card__bookmark--active:hover{color:#d97706}.product-card__bookmark--active:hover svg{fill:#d97706}.product-card__badge{position:absolute;top:.5rem;left:.5rem;z-index:1;font-size:.5625rem;font-weight:700;color:var(--color-surface);background:var(--color-lente-groen);padding:.125rem .5rem;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.03em;box-shadow:0 1px 3px #00000026}.product-card__body{display:flex;flex-direction:column;padding:1rem 1.125rem;min-width:0;gap:.25rem}.product-card__meta{display:flex;align-items:center;gap:.375rem;font-size:.625rem;font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em}.product-card__category{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.product-card__date{white-space:nowrap}.product-card__date:before{content:"·";margin-right:.375rem}.product-card__title{font-size:1rem;font-weight:900;color:var(--color-nacht-paars);line-height:1.3;letter-spacing:-.01em}.product-card__title a{color:inherit;text-decoration:none;transition:opacity var(--transition-fast)}.product-card__title a:hover{opacity:.75}.product-card__description{font-size:.78rem;color:var(--color-text-muted);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:auto}.product-card__actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-top:.375rem;padding-top:.5rem;border-top:1px solid var(--color-border)}.product-card__btn{display:inline-flex;align-items:center;gap:.25rem;font-size:.6875rem;font-weight:700;padding:.375rem .875rem;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);border:none;text-decoration:none;font-family:inherit}.product-card__btn--primary{background:var(--color-nacht-paars);color:var(--color-surface)}.product-card__btn--primary:hover{opacity:.88}.product-card__btn--secondary{background:transparent;color:var(--color-nacht-paars);border:1px solid var(--color-nacht-paars)}.product-card__btn--secondary:hover{background:var(--color-nacht-paars);color:var(--color-surface)}.product-card__external-icon{width:.625rem;height:.625rem}@media(max-width:640px){.product-card{grid-template-columns:1fr}.product-card__image-link{height:10rem}}.catalogus-pagination{display:flex;justify-content:center;align-items:center;gap:.25rem;margin-top:1.25rem;padding-top:.875rem;border-top:1px solid var(--color-border)}.catalogus-pagination__btn{display:flex;align-items:center;justify-content:center;min-width:1.875rem;height:1.875rem;padding:0 .375rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);font-size:.78rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);font-family:inherit}.catalogus-pagination__btn svg{width:.875rem;height:.875rem}.catalogus-pagination__btn:hover:not(:disabled){border-color:var(--color-nacht-paars);color:var(--color-nacht-paars)}.catalogus-pagination__btn--active{background:var(--color-nacht-paars);border-color:var(--color-nacht-paars);color:var(--color-surface);font-weight:700}.catalogus-pagination__btn:disabled{opacity:.3;cursor:default}.catalogus-pagination__ellipsis{display:flex;align-items:center;justify-content:center;min-width:1.875rem;height:1.875rem;font-size:.78rem;color:var(--color-text-muted)}.catalogus-error{text-align:center;padding:3rem 1rem;color:var(--color-text-muted);font-size:.8125rem}.catalogus-error__retry{margin-top:.75rem;background:var(--color-nacht-paars);color:var(--color-surface);border:none;padding:.5rem 1.25rem;border-radius:var(--radius-sm);font-weight:700;font-size:.78rem;cursor:pointer;font-family:inherit;transition:opacity var(--transition-fast)}.catalogus-error__retry:hover{opacity:.9}.catalogus-empty{text-align:center;padding:4rem 0;color:var(--color-text-muted);font-size:.8125rem}.favorieten__empty{text-align:center;padding:4rem 0;color:var(--color-text-muted);font-size:.875rem;line-height:1.6}.favorieten__link{color:var(--color-nacht-paars);font-weight:700;text-decoration:underline;text-underline-offset:2px}.favorieten__link:hover{opacity:.7}.favorieten__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(16rem,1fr));gap:1.25rem}.favorieten__card{position:relative;display:flex;flex-direction:column;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;transition:box-shadow var(--transition-base),border-color var(--transition-base),transform var(--transition-base)}.favorieten__card:hover{border-color:var(--color-nacht-paars);box-shadow:var(--shadow-md);transform:translateY(-1px)}.favorieten__card-image{aspect-ratio:16/9;overflow:hidden;background:var(--color-surface-alt)}.favorieten__card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.favorieten__card:hover .favorieten__card-image img{transform:scale(1.04)}.favorieten__card-placeholder{display:flex;align-items:center;justify-content:center;height:100%;color:var(--color-text-muted)}.favorieten__card-placeholder svg{width:2rem;height:2rem;opacity:.3}.favorieten__card-body{display:flex;flex-direction:column;gap:.25rem;padding:.875rem 1rem 0;flex:1}.favorieten__card-category{font-size:.625rem;font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.favorieten__card-title{font-size:.875rem;font-weight:900;color:var(--color-nacht-paars);line-height:1.3}.favorieten__card-title button{all:unset;cursor:pointer;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.favorieten__card-title button:hover{opacity:.75}.favorieten__card-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;padding:.75rem 1rem;margin-top:auto;border-top:1px solid var(--color-border)}.product-card__bookmark--visible{opacity:1;transform:scale(1)}.product-card__btn--add-ll{margin-left:auto;background:var(--color-nacht-paars);color:#fff}.product-card__btn--add-ll svg{width:.8125rem;height:.8125rem;flex-shrink:0}.product-card__btn--add-ll .product-card__btn-icon-hover,.product-card__btn--add-ll .product-card__btn-text-hover{display:none}.product-card__btn--add-ll:hover:not(:disabled):not(.product-card__btn--added){opacity:.88}.product-card__btn--add-ll.product-card__btn--added{background:var(--color-surface-alt);color:var(--color-text-muted);border:1px solid var(--color-border)}.product-card__btn--add-ll.product-card__btn--added .product-card__btn-icon-default{color:var(--color-lente-groen)}.product-card__btn--add-ll.product-card__btn--added:hover{border-color:#dc2626;background:#fef2f2;color:#dc2626}.product-card__btn--add-ll.product-card__btn--added:hover .product-card__btn-icon-default,.product-card__btn--add-ll.product-card__btn--added:hover .product-card__btn-text-default{display:none}.product-card__btn--add-ll.product-card__btn--added:hover .product-card__btn-icon-hover,.product-card__btn--add-ll.product-card__btn--added:hover .product-card__btn-text-hover{display:inline}.product-card__btn--add-ll.product-card__btn--adding{cursor:wait;opacity:.7}.product-card__btn-spinner{animation:ll-spin .6s linear infinite}.ll-bar{position:fixed;bottom:1.25rem;left:50%;transform:translate(-50%);z-index:900;width:100%;max-width:48rem;padding:0 1rem;pointer-events:none}.ll-bar__card{pointer-events:auto;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 4px 24px #0000001f}.ll-bar__top{display:flex;align-items:center;justify-content:space-between;padding:.625rem .875rem;background:var(--color-surface-alt);border-bottom:1px solid var(--color-border);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.ll-bar__leerlijn{display:flex;align-items:center;gap:.5rem;min-width:0}.ll-bar__leerlijn-icon{width:1rem;height:1rem;color:var(--color-nacht-paars);flex-shrink:0}.ll-bar__leerlijn-name{font-size:.8125rem;font-weight:900;color:var(--color-nacht-paars);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ll-bar__leerlijn-niveau{font-size:.625rem;font-weight:700;color:var(--color-nacht-paars);background:var(--color-avond-paars);padding:.0625rem .375rem;border-radius:var(--radius-full);white-space:nowrap;flex-shrink:0}.ll-bar__top-actions{display:flex;align-items:center;gap:.375rem;flex-shrink:0}.ll-bar__back-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;font-size:.8125rem;font-weight:700;font-family:inherit;color:var(--color-nacht-paars);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.ll-bar__back-btn svg{width:.875rem;height:.875rem}.ll-bar__back-btn:hover{border-color:var(--color-nacht-paars)}.ll-bar__close-btn{display:flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;background:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;padding:0;transition:all var(--transition-fast)}.ll-bar__close-btn svg{width:.875rem;height:.875rem}.ll-bar__close-btn:hover{border-color:var(--color-text-muted);color:var(--color-text)}.ll-bar__controls{display:flex;align-items:center;gap:1rem;padding:.75rem .875rem}.ll-bar__field{display:flex;align-items:center;gap:.5rem}.ll-bar__label{font-size:.75rem;font-weight:700;color:var(--color-text)}.ll-bar__seg{display:flex;background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:3px}.ll-bar__seg-btn{display:flex;align-items:center;justify-content:center;height:1.75rem;padding:0 .625rem;font-size:.75rem;font-weight:700;font-family:inherit;color:var(--color-text-muted);background:none;border:none;border-radius:calc(var(--radius-sm) - 2px);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.ll-bar__seg-btn:hover:not(.ll-bar__seg-btn--on){color:var(--color-text);background:#ffffff80}.ll-bar__seg-btn--on{background:var(--color-surface);color:var(--color-nacht-paars);box-shadow:0 1px 3px #0000001a}.ll-bar__modules-wrap{position:relative;flex-shrink:0}.ll-bar__modules-btn{display:inline-flex;align-items:center;gap:.375rem;height:calc(1.75rem + 8px);padding:0 .75rem;font-size:.75rem;font-weight:700;font-family:inherit;color:var(--color-text);background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.ll-bar__modules-btn:hover{border-color:var(--color-nacht-paars);color:var(--color-nacht-paars)}.ll-bar__modules-num{font-weight:900;font-size:.875rem;color:var(--color-nacht-paars)}.ll-bar__modules-chevron{width:.75rem;height:.75rem;color:var(--color-text-muted);margin-left:.125rem;transition:transform var(--transition-fast)}.ll-bar__modules-chevron--open{transform:rotate(180deg)}.ll-bar__dropdown{position:absolute;bottom:calc(100% + .5rem);left:0;width:22rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);overflow:hidden}.ll-bar__dropdown-head{display:flex;justify-content:space-between;align-items:center;padding:.625rem .75rem;background:var(--color-surface-alt);border-bottom:1px solid var(--color-border);font-size:.75rem;font-weight:700;color:var(--color-nacht-paars)}.ll-bar__dropdown-head span{font-weight:600;color:var(--color-text-muted)}.ll-bar__dropdown-list{max-height:18rem;overflow-y:auto}.ll-bar__dropdown-row{display:flex;align-items:center;gap:.625rem;padding:.5rem .75rem}.ll-bar__dropdown-row+.ll-bar__dropdown-row{border-top:1px solid var(--color-border)}.ll-bar__dropdown-img{width:2.25rem;height:2.25rem;border-radius:var(--radius-sm);background:var(--color-surface-alt);border:1px solid var(--color-border);overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.625rem;font-weight:900;color:var(--color-text-muted)}.ll-bar__dropdown-img img{width:100%;height:100%;object-fit:cover}.ll-bar__dropdown-text{flex:1;min-width:0;display:flex;flex-direction:column}.ll-bar__dropdown-name{font-size:.8125rem;font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ll-bar__dropdown-meta{font-size:.6875rem;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ll-bar__dropdown-badge{font-size:.5625rem;font-weight:700;color:#dc2626;background:#fee2e2;padding:.125rem .375rem;border-radius:var(--radius-full);flex-shrink:0}.ll-bar__dropdown-remove{display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;background:none;border:none;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;padding:0;flex-shrink:0;opacity:0;transition:all var(--transition-fast)}.ll-bar__dropdown-remove svg{width:.75rem;height:.75rem}.ll-bar__dropdown-remove:hover{color:#dc2626;background:#fee2e2}.ll-bar__dropdown-row:hover .ll-bar__dropdown-remove{opacity:1}.ll-bar__dropdown-none{padding:1.5rem 1rem;font-size:.8125rem;color:var(--color-text-muted);text-align:center}.ll-dropdown-enter-active{transition:opacity .15s ease,transform .15s ease}.ll-dropdown-leave-active{transition:opacity .1s ease,transform .1s ease}.ll-dropdown-enter-from,.ll-dropdown-leave-to{opacity:0;transform:translateY(.5rem)}.selection-bar-enter-active{transition:bottom .3s cubic-bezier(.22,1,.36,1),opacity .2s ease}.selection-bar-leave-active{transition:bottom .15s ease-in,opacity .1s ease}.selection-bar-enter-from,.selection-bar-leave-to{bottom:-8rem!important;opacity:0}body:has(.ll-bar) .page-content{padding-bottom:8rem}.settings{max-width:40rem}.settings__header{margin-bottom:1.5rem}.settings__title{font-size:1.25rem;font-weight:900;color:var(--color-text-heading)}.settings__card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem}.settings__card+.settings__card{margin-top:1rem}.settings__section-title{font-size:.875rem;font-weight:700;color:var(--color-text-heading);margin-bottom:1rem}.settings__description{font-size:.8125rem;color:var(--color-text-muted);margin-bottom:1rem}.settings__list{display:flex;flex-direction:column;gap:.75rem}.settings__row{display:flex;align-items:baseline;gap:1rem}.settings__row dt{flex-shrink:0;width:5rem;font-size:.75rem;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em}.settings__row dd{font-size:.875rem;color:var(--color-text);font-weight:500}.settings__tags{display:flex;flex-wrap:wrap;gap:.375rem}.settings__tag{display:inline-block;font-size:.75rem;font-weight:500;padding:.25rem .75rem;background:var(--color-accent-subtle);color:var(--color-primary);border-radius:var(--radius-full);border:1px solid var(--color-lente-groen-40)}.settings__empty{font-size:.8125rem;color:var(--color-text-muted)}.ll-breadcrumb__link{background:none;border:none;font:inherit;color:var(--color-text-muted);cursor:pointer;padding:0;transition:color var(--transition-fast)}.ll-breadcrumb__link:hover{color:var(--color-nacht-paars)}.ll-breadcrumb__sep{color:var(--color-text-muted);margin:0 .25rem}.ll__empty{text-align:center;color:var(--color-text-muted);font-size:.875rem;padding:3rem 1rem}.ll__retry{margin-top:.75rem;display:inline-flex;align-items:center;padding:.4375rem .875rem;font-size:.75rem;font-weight:700;font-family:inherit;color:var(--color-nacht-paars);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer}.ll-modal--danger{background:#fee2e2!important}.ll-modal--danger .class-modal__title{color:#dc2626}.ll-modal--danger-btn{background:#dc2626!important}.ll-modal--danger-btn:hover{background:#b91c1c!important}.ll-modal__text{font-size:.8125rem;color:var(--color-text);margin-bottom:.5rem}.ll-modal__subtext{font-size:.75rem;color:var(--color-text-muted);margin-bottom:1rem}.ll-modal__row{display:flex;gap:1rem}.ll-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(18rem,1fr));gap:1rem}.ll-card{display:flex;flex-direction:column;background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);overflow:hidden;min-height:14rem}.ll-card:hover{box-shadow:0 8px 24px #56355b1f;transform:translateY(-3px);border-color:var(--color-nacht-paars)}.ll-card--add{align-items:center;justify-content:center;gap:.75rem;border:2px dashed var(--color-border);color:var(--color-text-muted);font-family:inherit;overflow:visible}.ll-card--add svg{width:2rem;height:2rem;color:var(--color-border);transition:color var(--transition-fast)}.ll-card--add span{font-size:.8125rem;font-weight:700}.ll-card--add:hover{border-color:var(--color-nacht-paars);color:var(--color-nacht-paars);background:#d2bbd50f;box-shadow:none;transform:none}.ll-card--add:hover svg{color:var(--color-nacht-paars)}.ll-card__top{position:relative;padding:1.5rem 1.25rem 1.25rem;flex:1;display:flex;flex-direction:column}.ll-card__title{font-size:1rem;font-weight:900;color:var(--color-nacht-paars);line-height:1.3;margin-bottom:.5rem}.ll-card__tags{display:flex;flex-wrap:wrap;gap:.25rem;margin-bottom:.75rem}.ll-card__tag{display:inline-flex;padding:.125rem .5rem;font-size:.5625rem;font-weight:700;color:var(--color-text-muted);background:var(--color-surface-alt);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.03em}.ll-card__tag--niveau{color:var(--color-nacht-paars);background:var(--color-avond-paars)}.ll-card__desc{font-size:.75rem;color:var(--color-text-muted);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:auto}.ll-card__bottom{display:flex;border-top:1px solid var(--color-border)}.ll-card__stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:1rem .5rem}.ll-card__stat:not(:last-child){border-right:1px solid var(--color-border)}.ll-card__stat-num{font-size:1.25rem;font-weight:900;color:var(--color-nacht-paars);line-height:1}.ll-card__stat-label{font-size:.5625rem;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.ll-detail__card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:1.5rem}.ll-detail__top{display:flex;justify-content:space-between;align-items:flex-start;padding:1.25rem}.ll-detail__actions{display:flex;gap:.375rem;flex-shrink:0}.ll-detail__action-btn{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;padding:0;transition:all var(--transition-fast)}.ll-detail__action-btn svg{width:.875rem;height:.875rem}.ll-detail__action-btn:hover{border-color:var(--color-nacht-paars);color:var(--color-nacht-paars)}.ll-detail__action-btn--danger:hover{border-color:#dc2626;color:#dc2626;background:#fee2e2}.ll-detail__edit-form{flex:1;display:flex;flex-direction:column;gap:.75rem}.ll-detail__edit-actions{display:flex;justify-content:flex-end;gap:.5rem}.ll-detail__badges{display:flex;gap:.375rem;flex-wrap:wrap;margin-bottom:.5rem}.ll-detail__badge{display:inline-flex;padding:.1875rem .625rem;font-size:.6875rem;font-weight:700;border-radius:var(--radius-full)}.ll-detail__badge--niveau{background:var(--color-avond-paars);color:var(--color-nacht-paars)}.ll-detail__badge--meta{background:var(--color-surface-alt);color:var(--color-text-muted)}.ll-detail__desc{font-size:.8125rem;color:var(--color-text-muted);line-height:1.5}.ll-detail__klassen-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:1.5rem}.ll-detail__klassen-top{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--color-border)}.ll-detail__klassen-title{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:900;color:var(--color-nacht-paars)}.ll-detail__klassen-title svg{width:1rem;height:1rem;color:var(--color-text-muted)}.ll-detail__klassen-add-wrap,.ll-detail__klassen-btn-wrap{position:relative}.ll-detail__klassen-btn-wrap:hover .ll-detail__klassen-btn-tooltip{opacity:1;visibility:visible;transform:translateY(0)}.ll-detail__klassen-btn-tooltip{position:absolute;top:calc(100% + .5rem);right:0;z-index:50;opacity:0;visibility:hidden;transform:translateY(-.25rem);transition:all .15s ease;pointer-events:none;background:var(--color-surface);color:var(--color-text-muted);font-size:.75rem;font-weight:600;padding:.5rem .75rem;border-radius:var(--radius-sm);border:1px solid var(--color-border);box-shadow:0 8px 24px #0000001a;white-space:nowrap}.ll-detail__klassen-btn-tooltip:before{content:"";position:absolute;bottom:100%;right:1rem;border:5px solid transparent;border-bottom-color:var(--color-border)}.ll-detail__klassen-btn-tooltip:after{content:"";position:absolute;bottom:100%;right:1rem;border:4px solid transparent;border-bottom-color:var(--color-surface);margin-right:1px}.ll-detail__klassen-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;font-size:.6875rem;font-weight:700;font-family:inherit;color:#fff;background:var(--color-nacht-paars);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.ll-detail__klassen-btn svg{width:.75rem;height:.75rem}.ll-detail__klassen-btn:hover{opacity:.88}.ll-detail__klassen-btn:disabled{opacity:.4;cursor:not-allowed}.ll-detail__klassen-dropdown{position:absolute;top:calc(100% + .375rem);right:0;z-index:100;min-width:18rem;max-height:16rem;overflow-y:auto;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 12px 32px #00000026;padding:.375rem}.ll-detail__klassen-option{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.625rem .75rem;font-family:inherit;text-align:left;background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.ll-detail__klassen-option svg{width:.875rem;height:.875rem;color:var(--color-text-muted);flex-shrink:0;opacity:0;transition:opacity var(--transition-fast)}.ll-detail__klassen-option:hover{background:var(--color-accent-subtle)}.ll-detail__klassen-option:hover svg{opacity:1;color:var(--color-nacht-paars)}.ll-detail__klassen-option-info{display:flex;flex-direction:column;gap:.0625rem}.ll-detail__klassen-option-name{font-size:.8125rem;font-weight:700;color:var(--color-text)}.ll-detail__klassen-option-meta{font-size:.6875rem;color:var(--color-text-muted)}.ll-detail__klassen-list{padding:.5rem}.ll-detail__klassen-item{display:flex;justify-content:space-between;align-items:center;padding:.625rem .75rem;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.ll-detail__klassen-item:hover{background:var(--color-surface-alt)}.ll-detail__klassen-item:hover .ll-detail__klassen-item-remove{opacity:1}.ll-detail__klassen-item-info{display:flex;flex-direction:column;gap:.0625rem}.ll-detail__klassen-item-name{font-size:.8125rem;font-weight:700;color:var(--color-text)}.ll-detail__klassen-item-meta{font-size:.6875rem;color:var(--color-text-muted)}.ll-detail__klassen-item-remove{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;font-size:.625rem;font-weight:600;font-family:inherit;color:var(--color-text-muted);background:none;border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;opacity:0;transition:all var(--transition-fast)}.ll-detail__klassen-item-remove svg{width:.625rem;height:.625rem}.ll-detail__klassen-item-remove:hover{color:#dc2626;border-color:#fecaca;background:#fee2e2}.ll-detail__klassen-empty{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1.5rem;font-size:.8125rem;color:var(--color-text-muted)}.ll-detail__klassen-empty svg{width:1.25rem;height:1.25rem;opacity:.4}.ll-detail__section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.ll-detail__section-title{font-size:.9375rem;font-weight:900;color:var(--color-nacht-paars)}.ll-detail__section-title span{font-weight:500;color:var(--color-text-muted)}.ll-toolbar{display:flex;justify-content:flex-end;margin-bottom:1.25rem}.ll-tabs{display:flex;gap:2px;background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:2px}.ll-tabs__btn{display:inline-flex;align-items:center;gap:.3125rem;padding:.3125rem .75rem;font-size:.6875rem;font-weight:700;font-family:inherit;color:var(--color-text-muted);background:none;border:none;border-radius:calc(var(--radius-sm) - 2px);cursor:pointer;transition:all var(--transition-fast)}.ll-tabs__btn svg{width:.8125rem;height:.8125rem}.ll-tabs__btn:hover:not(.ll-tabs__btn--on){color:var(--color-text)}.ll-tabs__btn--on{background:var(--color-surface);color:var(--color-nacht-paars);box-shadow:0 1px 3px #0000001a}.ll-kerntaken{display:flex;flex-direction:column;gap:1rem}.ll-kerntaken__groep{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.ll-kerntaken__groep--overig .ll-kerntaken__header{background:var(--color-surface-alt)}.ll-kerntaken__groep--overig .ll-kerntaken__naam{color:var(--color-text-muted)}.ll-kerntaken__header{display:flex;align-items:flex-start;gap:.625rem;padding:.875rem 1rem;border-bottom:1px solid var(--color-border)}.ll-kerntaken__header>svg{width:1rem;height:1rem;color:var(--color-nacht-paars);flex-shrink:0;margin-top:.125rem}.ll-kerntaken__info{display:flex;flex-direction:column;gap:.0625rem;min-width:0}.ll-kerntaken__naam{font-size:.8125rem;font-weight:900;color:var(--color-nacht-paars);line-height:1.3}.ll-kerntaken__count{font-size:.6875rem;color:var(--color-text-muted)}.ll-kerntaken__modules{display:flex;flex-direction:column}.ll-kerntaken__module{display:flex;align-items:center;gap:.625rem;padding:.5rem 1rem}.ll-kerntaken__module+.ll-kerntaken__module{border-top:1px solid var(--color-border)}.ll-kerntaken__module-img{width:2.25rem;height:2.25rem;border-radius:var(--radius-sm);background:var(--color-surface-alt);border:1px solid var(--color-border);overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.625rem;font-weight:900;color:var(--color-text-muted)}.ll-kerntaken__module-img img{width:100%;height:100%;object-fit:cover}.ll-kerntaken__module-text{flex:1;min-width:0;display:flex;flex-direction:column}.ll-kerntaken__module-title{font-size:.8125rem;font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ll-kerntaken__module-meta{font-size:.6875rem;color:var(--color-text-muted)}.ll-kerntaken__module-exam{font-size:.5625rem;font-weight:700;color:#dc2626;background:#fee2e2;padding:.125rem .375rem;border-radius:var(--radius-full);flex-shrink:0}.ll-timeline{display:flex;flex-direction:column;gap:2.5rem}.ll-jaar__header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem}.ll-jaar__number{display:flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;border-radius:var(--radius-full);background:var(--color-nacht-paars);color:#fff;font-weight:900;font-size:.875rem;flex-shrink:0}.ll-jaar__title{font-size:1rem;font-weight:900;color:var(--color-nacht-paars);line-height:1.2}.ll-jaar__sub{font-size:.6875rem;color:var(--color-text-muted)}.ll-jaar__content{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;align-items:start}.ll-kwartaal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.ll-kwartaal__header{display:flex;justify-content:space-between;align-items:center;padding:.75rem .875rem;background:var(--color-surface-alt);border-bottom:1px solid var(--color-border)}.ll-kwartaal__label{display:flex;align-items:center;gap:.375rem;font-size:.75rem;font-weight:700;color:var(--color-text-heading);min-width:0}.ll-kwartaal__badge{display:inline-flex;align-items:center;justify-content:center;width:1.375rem;height:1.375rem;border-radius:var(--radius-sm);background:var(--color-nacht-paars);color:#fff;font-size:.5625rem;font-weight:900;flex-shrink:0}.ll-kwartaal__modules{display:grid;grid-template-columns:repeat(4,1fr);gap:.375rem;padding:.5rem .75rem 0;align-content:start}.ll-kwartaal__add{display:flex;align-items:center;justify-content:center;gap:.375rem;width:calc(100% - 1.5rem);margin:.5rem .75rem .75rem;padding:.5rem;font-size:.6875rem;font-weight:700;font-family:inherit;color:var(--color-text-muted);background:none;border:1.5px dashed var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.ll-kwartaal__add svg{width:.875rem;height:.875rem;transition:transform var(--transition-fast)}.ll-kwartaal__add span{transition:color var(--transition-fast)}.ll-kwartaal__add:hover{color:var(--color-nacht-paars);border-color:var(--color-avond-paars);background:#d2bbd514}.ll-kwartaal__add:hover svg{transform:scale(1.15)}.ll-kwartaal__add:active{transform:scale(.98)}.ll-kt__module{position:relative;cursor:grab}.ll-kt__module:active{cursor:grabbing}.ll-kt__module--examen .ll-kt__module-block{border:2px solid #dc2626}.ll-kt__module--dragging{opacity:.15}.ll-kt__module--dragging .ll-kt__module-block{transform:scale(.9)!important;box-shadow:none!important}.ll-kt__module--drop-left:before,.ll-kt__module--drop-right:before{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:calc(var(--radius-md) + 3px);border:2px dashed var(--color-nacht-paars);background:#56355b0f;z-index:10;animation:ll-drop-pulse 1s ease infinite}.ll-kt__module-block{display:flex;align-items:center;justify-content:center;width:100%;aspect-ratio:1;border-radius:var(--radius-md);background:var(--color-surface-alt);border:1px solid var(--color-border);cursor:grab}.ll-kt__module-block:active{cursor:grabbing}.ll-kt__module-block{font-weight:900;font-size:1rem;color:var(--color-text-muted);overflow:hidden;transition:all var(--transition-fast)}.ll-kt__module-block img{width:100%;height:100%;object-fit:cover;pointer-events:none}.ll-kt__module-block span{pointer-events:none}.ll-kt__module:hover:not(.ll-kt__module--dragging):not(.ll-kt__module--drop-left):not(.ll-kt__module--drop-right) .ll-kt__module-block{box-shadow:0 4px 12px #56355b26;transform:translateY(-2px);border-color:var(--color-avond-paars)}.ll-kt__module-badge{position:absolute;bottom:-.1875rem;left:50%;transform:translate(-50%);display:flex;align-items:center;justify-content:center;width:1rem;height:1rem;font-size:.5rem;font-weight:900;color:#fff;background:#dc2626;border:2px solid var(--color-surface);border-radius:var(--radius-full);pointer-events:none;z-index:1}.ll-kt__module-tooltip{position:fixed;z-index:9999;opacity:0;visibility:hidden;transition:opacity .15s ease,visibility .15s ease;pointer-events:none;background:var(--color-surface);color:var(--color-text);padding:.625rem .875rem;border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:0 8px 24px #0000001f;white-space:nowrap;max-width:20rem;display:flex;flex-direction:column;gap:.25rem}.ll-kt__module-tooltip strong{font-size:.8125rem;font-weight:700;color:var(--color-nacht-paars);overflow:hidden;text-overflow:ellipsis}.ll-kt__module-tooltip span{font-size:.6875rem;color:var(--color-text-muted)}.ll-kt__module-tooltip--visible{opacity:1;visibility:visible}.ll-kt__module-tooltip--exam{color:#dc2626!important;font-weight:700;font-size:.625rem}.ll-kt__module-x{position:absolute;top:-.375rem;right:-.375rem;display:none;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;background:#dc2626;color:#fff;border:2px solid var(--color-surface);border-radius:var(--radius-full);cursor:pointer;padding:0;z-index:2}.ll-kt__module-x svg{width:.5625rem;height:.5625rem}.ll-kt__module:hover .ll-kt__module-x{display:flex}.ll-drag-ghost{position:fixed;z-index:9999;width:2.5rem;height:2.5rem;border-radius:var(--radius-md);background:var(--color-surface);border:2px solid var(--color-nacht-paars);box-shadow:0 8px 24px #56355b40;display:none;align-items:center;justify-content:center;pointer-events:none;overflow:hidden;opacity:.9;transition:opacity .1s ease,border-color .1s ease,filter .1s ease}.ll-drag-ghost img{width:100%;height:100%;object-fit:cover}.ll-drag-ghost span{font-weight:900;font-size:.875rem;color:var(--color-nacht-paars)}.ll-drag-ghost--blocked{opacity:.4;border-color:var(--color-border);filter:grayscale(1)}@keyframes ll-spin{to{transform:rotate(360deg)}}@keyframes ll-drop-pulse{0%,to{opacity:1}50%{opacity:.5}}
