@import"https://fonts.googleapis.com/css2?family=Cinzel:wght@400;500;600;700&family=Inter:wght@300;400;500;600&display=swap";@import"https://fonts.googleapis.com/css2?family=Merriweather:wght@300;400;700&display=swap";@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-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%;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{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;}:root{--deep-background: #0C0E12;--light-text: #E4E8EB;--stormlight-glow: #7FE0EB;--sapphire-blue: #266DD3;--neutral-base: #CFCFCF;--highlight: #A7FFF6;--cursor-x: 50vw;--cursor-y: 50vh;--cursor-opacity: 1;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.7;font-weight:400;color:var(--light-text);background:var(--deep-background);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;padding:0;min-height:100vh;background:#0c0e12;color:#e4e8eb;position:relative;cursor:none}body,button,a,.social-link,.project-link,button:hover,a:hover,.social-link:hover,.project-link:hover{cursor:none!important}body:after{content:"";position:fixed;left:var(--cursor-x);top:var(--cursor-y);width:20px;height:20px;background:radial-gradient(circle,rgba(127,224,235,.6) 0%,rgba(127,224,235,.2) 50%,transparent 70%);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:all .1s ease-out;mix-blend-mode:screen;opacity:1}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 20% 30%,rgba(127,224,235,.08) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(38,109,211,.06) 0%,transparent 50%),radial-gradient(circle at 40% 80%,rgba(167,255,246,.04) 0%,transparent 50%);pointer-events:none;z-index:1}.portfolio-container{min-height:100vh;display:flex;justify-content:center;padding:2rem 1rem;position:relative;z-index:2}.portfolio-content{width:100%;max-width:900px;background:#0c0e12e6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:3rem;margin:auto;position:relative;z-index:20;border:1px solid #266DD3;border-radius:16px;box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #7fe0eb33;overflow:hidden}.portfolio-content:before{content:"";position:absolute;inset:-1px;background:linear-gradient(45deg,#7fe0eb1a,#266dd314,#a7fff60f,#266dd314,#7fe0eb1a);border-radius:16px;z-index:-1}.portfolio-content:after{display:none}@keyframes subtle-glow{0%,to{opacity:.5}50%{opacity:.8}}@keyframes windspren-float{0%,to{transform:translateY(0) rotate(0)}33%{transform:translateY(-10px) rotate(1deg)}66%{transform:translateY(5px) rotate(-1deg)}}@keyframes stormlight-drift{0%{transform:translate(-200px) translateY(-100px)}to{transform:translate(200px) translateY(100px)}}.header-section{text-align:left;margin-bottom:4rem;padding-bottom:2rem;border-bottom:1px solid #266DD3;position:relative}.header-section:after{content:"✦";position:absolute;bottom:-21px;left:50%;transform:translate(-50%);background:none;padding:0;color:#7fe0eb;font-size:1.5rem;animation:star-pulse 3s ease-in-out infinite;filter:drop-shadow(0 0 8px #7FE0EB);text-shadow:0 0 15px #7FE0EB,0 0 25px rgba(127,224,235,.5)}@keyframes star-pulse{0%,to{opacity:.6;transform:translate(-50%) scale(1);filter:drop-shadow(0 0 8px #7FE0EB)}50%{opacity:1;transform:translate(-50%) scale(1.2);filter:drop-shadow(0 0 15px #7FE0EB) drop-shadow(0 0 25px rgba(127,224,235,.7))}}@keyframes stormlight-pulse{0%{filter:brightness(1) drop-shadow(0 0 5px rgba(127,224,235,.3))}to{filter:brightness(1.2) drop-shadow(0 0 15px rgba(127,224,235,.6))}}.header-content{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.header-section h1{font-size:3.5rem;font-weight:700;color:#e4e8eb;margin:0;letter-spacing:-.025em;flex:1;font-family:Cinzel,serif;background:linear-gradient(90deg,#7fe0eb,#a7fff6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:stormlight-pulse 3s ease-in-out infinite alternate;position:relative}.header-section h1:after{content:"";position:absolute;bottom:-5px;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,#7FE0EB,#266DD3,#A7FFF6,transparent);animation:underline-glow 3s ease-in-out infinite}@keyframes underline-glow{0%,to{opacity:.3}50%{opacity:.8}}.social-links{display:flex;gap:1rem;align-items:center;margin-top:0}.social-link{display:flex;align-items:center;justify-content:center;width:44px;height:44px;color:#cfcfcf;transition:all .3s ease;text-decoration:none;border:1px solid #266DD3;border-radius:12px;background:#cfcfcf0d}.social-link:hover{color:#7fe0eb;border-color:#7fe0eb;background:#7fe0eb1a;transform:translateY(-2px);box-shadow:0 0 15px #7fe0eb66}.social-icon{width:22px;height:22px}.tagline{font-size:1.25rem;font-weight:500;color:#7fe0eb;margin:0 0 1.5rem;letter-spacing:.01em}.intro{text-align:left;font-size:1.1rem;color:#e4e8eb;line-height:1.7;max-width:650px;margin:0;font-weight:400}h2{font-size:2rem;font-weight:600;color:#e4e8eb;margin:0 0 2rem;text-align:left;letter-spacing:-.01em;position:relative}h2:before{content:"";position:absolute;left:-20px;top:50%;transform:translateY(-50%);width:4px;height:24px;background:linear-gradient(180deg,#7fe0eb,#266dd3);border-radius:2px}h2:after{content:"";position:absolute;right:-30px;top:50%;transform:translateY(-50%);width:20px;height:20px;background:radial-gradient(circle,#A7FFF6 0%,transparent 70%);border-radius:50%;animation:gem-pulse 2s ease-in-out infinite alternate}@keyframes gem-pulse{0%{opacity:.5;box-shadow:0 0 5px #a7fff6}to{opacity:1;box-shadow:0 0 15px #a7fff6,0 0 25px #a7fff64d}}.projects-section{margin-bottom:4rem}.projects-grid{display:grid;gap:2rem;margin-top:2rem}.project-card{background:#cfcfcf14;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #266DD3;padding:2rem;transition:all .3s ease;border-radius:12px;position:relative;overflow:hidden}.project-card:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(127,224,235,.1),rgba(167,255,246,.08),rgba(127,224,235,.1),transparent);transition:left .6s ease}.project-card:hover:before{left:100%}.project-card:hover{border-color:#7fe0eb;transform:translateY(-4px);box-shadow:0 20px 40px -12px #7fe0eb4d,0 0 0 1px #a7fff633,inset 0 1px #a7fff61a}.project-card h3{font-size:1.5rem;font-weight:600;color:#e4e8eb;margin:0 0 1rem}.project-card p{color:#e4e8eb;margin:0 0 1.5rem;line-height:1.6;font-weight:400;opacity:.9}.tech-stack{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.tech-tag{background:#7fe0eb26;color:#e4e8eb;padding:.25rem .75rem;font-size:.875rem;font-weight:500;border:1px solid #266DD3;border-radius:6px;transition:all .2s ease}.tech-tag:nth-child(4n+1){background:#7fe0eb26;border-color:#7fe0eb}.tech-tag:nth-child(4n+2){background:#266dd326;border-color:#266dd3}.tech-tag:nth-child(4n+3){background:#a7fff626;border-color:#a7fff6}.tech-tag:nth-child(4n+4){background:#cfcfcf26;border-color:#cfcfcf}.tech-tag:hover{background:#7fe0eb40;border-color:#7fe0eb}.experience-section{margin:3rem 0}.experience-list{display:flex;flex-direction:column;gap:2rem}.experience-item{background:#0c0e1299;border:1px solid rgba(38,109,211,.3);border-radius:12px;padding:2rem;position:relative;transition:all .3s ease;overflow:hidden}.experience-item:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(127,224,235,.2),rgba(167,255,246,.15),rgba(127,224,235,.2),transparent);transition:left .6s ease;z-index:1}.experience-item:hover:before{left:100%}.experience-item:hover{transform:translateY(-8px);border-color:#7fe0eb99;box-shadow:0 20px 40px #0000004d,0 0 20px #7fe0eb33,inset 0 1px #a7fff61a}.experience-header,.experience-item p{position:relative;z-index:2}.experience-header{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.experience-item h3{font-size:1.5rem;font-weight:600;color:#e4e8eb;margin:0;transition:color .3s ease}.experience-item:hover h3{color:#a7fff6}.company{font-size:1.1rem;font-weight:500;color:#7fe0eb;transition:color .3s ease}.experience-item:hover .company{color:#a7fff6}.period{font-size:.9rem;color:#266dd3;font-weight:500;transition:color .3s ease}.experience-item:hover .period{color:#7fe0eb}.experience-item p{color:#cfcfcf;line-height:1.6;margin:0;transition:color .3s ease}.experience-item:hover p{color:#e4e8eb}@media(max-width:768px){.experience-item{padding:1.5rem}.experience-item h3{font-size:1.3rem}.company{font-size:1rem}}@media(max-width:480px){.experience-item{padding:1rem}.experience-item h3{font-size:1.2rem}.company{font-size:.9rem}.period{font-size:.8rem}}.experience-section,.technologies-section{margin-bottom:4rem}.experience-item,.tech-categories{background:#cfcfcf14;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #266DD3;padding:2rem;border-radius:12px;margin-top:2rem}.experience-header h3,.tech-category h3{font-size:1.25rem;font-weight:600;color:#e4e8eb;margin:0}.company{font-weight:500;color:#7fe0eb;font-size:1rem}.period{color:#cfcfcf;font-size:.875rem;font-weight:400;font-style:italic}.experience-item p{color:#e4e8eb;line-height:1.6;margin:0;font-weight:400;opacity:.9}.tech-category{margin-bottom:2rem;border-bottom:1px solid #266DD3;padding-bottom:1.5rem}.language-toggle{position:fixed;top:2rem;right:4rem;background:#cfcfcf1a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid #266DD3;color:#e4e8eb;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .3s ease;z-index:1000}.language-toggle:hover{background:#7fe0eb33;border-color:#7fe0eb;transform:translateY(-1px);box-shadow:0 0 15px #7fe0eb66}.navigate-bookshelf{position:fixed;top:2rem;left:2rem;background:#8b5e3ce6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid #8b5e3c;color:#fdf6e3;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:500;font-family:Merriweather,serif;transition:all .3s ease;z-index:1000}.navigate-bookshelf:hover{background:#6b4a2ff2;border-color:#d4af37;transform:translateY(-1px);box-shadow:0 0 15px #d4af3766}.beer-background{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:10;overflow:hidden}.bouncing-beer{position:absolute;top:-100px;animation:modern-float 8s linear infinite;opacity:.8;-webkit-user-select:none;user-select:none;z-index:15;filter:hue-rotate(180deg) saturate(.8)}@keyframes modern-float{0%{top:-100px;transform:rotate(0) translate(0);opacity:0}10%{opacity:.8}90%{opacity:.8}to{top:calc(100vh + 100px);transform:rotate(360deg) translate(50px);opacity:0}}.german-flag-background{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:5;overflow:hidden}.waving-flag{position:absolute;animation:gentle-drift 5s ease-in-out infinite;opacity:.3;filter:hue-rotate(180deg) saturate(.6)}@keyframes gentle-drift{0%,to{transform:scale(1) rotate(0)}50%{transform:scale(1.05) rotate(1deg)}}.super-german-toggle{top:2rem;right:8rem;background:#a7fff626;border:1px solid #A7FFF6;color:#e4e8eb;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.super-german-toggle:hover{background:#a7fff640;border-color:#a7fff6;box-shadow:0 0 15px #a7fff666}@media(max-width:768px){.portfolio-content{padding:2rem 1.5rem;margin:1rem;border-radius:12px}.header-content{flex-direction:column-reverse;align-items:flex-start;gap:1.5rem}.social-links{align-self:flex-start;margin-top:0;margin-bottom:0}.header-section h1{font-size:2.5rem;flex:none}h2:after{right:-15px;width:16px;height:16px}h2:before{left:-15px;width:3px;height:20px}.header-section:after{bottom:-20px}.language-toggle{top:1rem;right:1rem;padding:.5rem 1rem;font-size:.8rem}.super-german-toggle{top:3.5rem;right:1rem}.navigate-bookshelf{top:1.5rem;left:1.5rem;padding:.6rem 1.25rem;font-size:.8rem}}@media(max-width:480px)and (pointer:coarse){body{cursor:default!important}body:after,.cursor-glow{display:none!important}}@media(max-width:480px){.portfolio-content{padding:1.5rem 1rem}.header-content{flex-direction:column-reverse;align-items:flex-start;gap:1rem}.social-links{gap:.75rem}.social-link{width:40px;height:40px}.social-icon{width:20px;height:20px}.header-section h1{font-size:2rem}.navigate-bookshelf{top:1rem;left:1rem;padding:.5rem 1rem;font-size:.75rem}h2{font-size:1.5rem}h2:after{right:-10px;width:14px;height:14px}h2:before{left:-10px;width:2px;height:16px}.header-section:after{bottom:-20px}}:root{--deep-background: #0C0E12;--light-text: #E4E8EB;--stormlight-glow: #7FE0EB;--sapphire-blue: #266DD3;--neutral-base: #CFCFCF;--highlight: #A7FFF6;--cursor-x: 50vw;--cursor-y: 50vh;--cursor-opacity: 1;--bookshelf-brown: #8b5e3c;--bookshelf-dark-brown: #5a3d2b;--bookshelf-cream: #fdf6e3;--bookshelf-gold: #d4af37}*{cursor:none!important}.cursor-glow{position:fixed;left:var(--cursor-x);top:var(--cursor-y);width:150px;height:150px;background:radial-gradient(circle,rgba(167,255,246,.15) 0%,rgba(127,224,235,.08) 40%,transparent 70%);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:all .3s ease-out;mix-blend-mode:screen;opacity:1}@media(max-width:768px){.cursor-glow{width:120px;height:120px}}@media(max-width:480px){.cursor-glow{width:100px;height:100px}}.bookshelf-page{font-family:Merriweather,serif;background:var(--deep-background);color:var(--light-text);min-height:100vh;padding:20px;position:relative}.bookshelf-page:before{content:"";position:fixed;top:0;left:0;width:100vw;height:100vh;background:radial-gradient(circle at 20% 30%,rgba(127,224,235,.03) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(38,109,211,.02) 0%,transparent 50%),radial-gradient(circle at 40% 80%,rgba(167,255,246,.02) 0%,transparent 30%);pointer-events:none;z-index:1}.bookshelf-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:0 1rem}.bookshelf-header h1{font-size:2.5rem;font-weight:700;color:var(--bookshelf-cream);text-shadow:0 0 20px rgba(212,175,55,.4);margin:0;position:absolute;left:50%;transform:translate(-50%)}.back-button{background:#8b5e3ce6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--bookshelf-brown);color:var(--bookshelf-cream);padding:12px 20px;border-radius:8px;font-family:Merriweather,serif;font-size:1rem;transition:all .3s ease;position:relative;z-index:3}.back-button:hover{background:#6b4a2ff2;border-color:var(--bookshelf-gold);transform:translateY(-2px);box-shadow:0 0 15px #d4af3766}.loading{text-align:center;font-size:1.2rem;color:var(--stormlight-glow);padding:40px;text-shadow:0 0 10px rgba(127,224,235,.5);position:relative;z-index:2}.shelves-container{max-width:1200px;margin:0 auto;padding:0 20px;position:relative;z-index:2}.shelf-section{margin-bottom:50px}.shelf-title{font-size:1.8rem;color:var(--light-text);margin-bottom:20px;padding-left:20px;border-left:4px solid var(--stormlight-glow);text-shadow:0 0 10px rgba(127,224,235,.3)}.empty-shelf{text-align:center;color:var(--neutral-base);font-style:italic;padding:40px;background:#7fe0eb0d;border-radius:8px;border:2px dashed rgba(127,224,235,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.bookshelf-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;padding:40px;background:linear-gradient(to bottom,#8b5e3c4d,#5a3d2b33);border-radius:12px;box-shadow:0 8px 16px #0006;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(127,224,235,.1);max-width:1200px;margin:0 auto}.books{position:relative;display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:25px;padding:20px 20px 0;margin-bottom:40px;justify-items:center}.book-cover{width:110px;height:165px;object-fit:cover;border-radius:2px;margin:0 auto 12px;display:block;box-shadow:0 2px 8px #00000080,0 0 0 1px #ffffff1a,inset 0 1px #fff3;transition:all .3s ease;position:relative}.book-cover:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 0%,rgba(255,255,255,.05) 50%,transparent 100%),repeating-linear-gradient(90deg,transparent 0px,rgba(255,255,255,.02) 1px,transparent 2px,transparent 4px);border-radius:2px;pointer-events:none}.book-card:hover .book-cover{transform:translateY(-2px);box-shadow:0 4px 16px #7fe0eb33,0 2px 8px #00000080,0 0 0 1px #7fe0eb4d,inset 0 1px #ffffff4d}.book-info{padding:4px 8px 8px;display:flex;flex-direction:column;gap:6px;align-items:center}.book-title{font-family:Merriweather,serif;font-size:.85rem;font-weight:600;color:var(--light-text);text-align:center;line-height:1.2;margin:0;max-width:100%;word-wrap:break-word;text-shadow:0 1px 3px rgba(0,0,0,.7);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.book-rating{display:flex;justify-content:center;gap:2px;margin:4px 0}.star{color:gold;font-size:1.1rem;text-shadow:0 0 4px rgba(255,215,0,.6);filter:drop-shadow(0 0 2px rgba(255,215,0,.8))}.category{margin-bottom:60px;position:relative}.books:after{content:"";position:absolute;bottom:-25px;left:-10px;right:-10px;height:20px;background:linear-gradient(90deg,#8b5e3ce6,#654321,#8b5e3ce6,#a07b4acc,#8b5e3ce6,#654321,#8b5e3ce6,#a07b4acc,#8b5e3ce6,#654321,#8b5e3ce6),linear-gradient(to bottom,#8b5e3cf2,#654321);border-radius:6px;box-shadow:0 6px 12px #0009,inset 0 2px 4px #d4af374d,inset 0 -2px 4px #321e0fcc,inset 2px 0 4px #321e0f99,inset -2px 0 4px #321e0f99;z-index:1}.books:before{content:"";position:absolute;bottom:-25px;left:-10px;right:-10px;height:20px;background:repeating-linear-gradient(90deg,transparent 0px,rgba(50,30,15,.2) 1px,transparent 2px,transparent 8px,rgba(50,30,15,.1) 9px,transparent 10px,transparent 20px),radial-gradient(ellipse at 25% 30%,rgba(50,30,15,.3) 0%,transparent 3%),radial-gradient(ellipse at 75% 70%,rgba(50,30,15,.2) 0%,transparent 4%);border-radius:6px;pointer-events:none;z-index:2}.category:before{content:"";position:absolute;bottom:-40px;left:50%;transform:translate(-50%);width:25px;height:35px;background:linear-gradient(135deg,#503219e6,#3c230f,#28190af2);border-radius:4px;box-shadow:2px 2px 6px #000000b3,inset 1px 1px 2px #7850284d;z-index:1}.category:after{display:none}.book-card{background:linear-gradient(to right,#0c0e12f2,#14191ee6 5%,#191e23e6 95%,#0c0e12f2);border:1px solid rgba(127,224,235,.2);border-radius:3px;padding:8px;text-align:center;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:140px;height:auto;position:relative;transform:translateY(0);z-index:3;box-shadow:2px 0 8px #0006,0 2px 4px #0000004d,inset 1px 0 #ffffff1a;border-left:3px solid rgba(127,224,235,.3);filter:drop-shadow(0 25px 8px rgba(80,50,25,.4))}.book-card:hover{transform:translateY(-12px) rotateY(-2deg);box-shadow:4px 0 15px #7fe0eb26,0 12px 25px #00000080,inset 1px 0 #7fe0eb33;border-color:#7fe0eb66;border-left-color:#7fe0eb99;background:linear-gradient(to right,#0c0e12fa,#14191ef2 5%,#191e23f2 95%,#0c0e12fa);filter:drop-shadow(0 35px 16px rgba(80,50,25,.6))}.book-card:after{content:"";position:absolute;bottom:-25px;left:50%;transform:translate(-50%);width:70%;height:6px;background:radial-gradient(ellipse,rgba(80,50,25,.6) 0%,rgba(60,35,15,.4) 50%,transparent 100%);border-radius:50%;transition:all .3s ease;z-index:2}.book-card:hover:after{width:80%;height:10px;bottom:-35px;opacity:.8;background:radial-gradient(ellipse,rgba(80,50,25,.8) 0%,rgba(60,35,15,.6) 50%,transparent 100%)}.no-books{grid-column:1 / -1;text-align:center;color:var(--light-text);font-style:italic;font-size:1.1rem;padding:60px 40px 40px;background:#7fe0eb0d;border-radius:8px 8px 0 0;border:2px dashed rgba(127,224,235,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);margin-bottom:0;text-shadow:0 1px 3px rgba(0,0,0,.5);justify-self:stretch}.book-tags{display:none!important}.book-modal-overlay{position:fixed;inset:0;background:#0c0e12e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:modalFadeIn .3s ease-out}.book-modal-overlay .cursor-glow{display:none!important}@keyframes modalFadeIn{0%{opacity:0;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px)}to{opacity:1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}}.book-modal{background:linear-gradient(135deg,#14191ef2,#191e23f2,#0c0e12f2);border:2px solid rgba(127,224,235,.3);border-radius:16px;padding:30px;max-width:600px;width:100%;max-height:80vh;overflow-y:auto;position:relative;box-shadow:0 20px 40px #0009,0 0 0 1px #7fe0eb1a,inset 0 1px #ffffff1a;animation:modalSlideIn .4s ease-out}@keyframes modalSlideIn{0%{transform:translateY(50px) scale(.9);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.book-modal-close{position:absolute;top:10px;right:15px;background:#7fe0eb33;border:1px solid rgba(127,224,235,.4);color:var(--stormlight-glow);width:35px;height:35px;border-radius:50%;font-size:1.2rem;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .3s ease;line-height:1;padding:0;text-align:center}.book-modal-close:hover{background:#7fe0eb4d;border-color:#7fe0eb99;transform:rotate(90deg)}.book-modal-content{display:flex;gap:25px;align-items:flex-start}.book-modal-cover{width:180px;height:270px;object-fit:cover;border-radius:8px;box-shadow:0 8px 24px #0009,0 0 0 1px #ffffff1a,inset 0 1px #fff3;flex-shrink:0}.book-modal-info{flex:1;display:flex;flex-direction:column;gap:12px}.book-modal-title{font-family:Merriweather,serif;font-size:1.8rem;font-weight:700;color:var(--light-text);margin:0;line-height:1.3;text-shadow:0 2px 4px rgba(0,0,0,.5)}.book-modal-title:after{display:none!important}.book-modal-author{font-size:1.1rem;color:var(--stormlight-glow);font-style:italic;margin:0;text-shadow:0 0 8px rgba(127,224,235,.4)}.book-modal-pages{color:var(--neutral-base);font-size:.95rem;font-style:italic;margin:0;text-shadow:0 1px 2px rgba(0,0,0,.3)}.book-modal-rating{display:flex;align-items:center;gap:8px}.book-modal-rating .star{color:gold;font-size:1.4rem;text-shadow:0 0 6px rgba(255,215,0,.8);filter:drop-shadow(0 0 3px rgba(255,215,0,.6))}.rating-text{color:var(--neutral-base);font-size:.9rem;margin-left:5px}.book-modal-divider{height:1px;background:linear-gradient(to right,transparent 0%,rgba(127,224,235,.3) 50%,transparent 100%);margin:8px 0}.book-modal-description{color:var(--light-text);line-height:1.6;font-size:1rem;background:#7fe0eb0d;padding:15px;border-radius:8px;border-left:3px solid var(--stormlight-glow);margin:10px 0;max-height:300px;overflow-y:auto}.book-modal-description p{margin:0 0 1em}.book-modal-description p:last-child{margin-bottom:0}.book-modal-genres{display:flex;flex-wrap:wrap;gap:8px}.book-modal-genres h4{width:100%;color:var(--stormlight-glow);font-size:1rem;margin:0 0 5px;text-shadow:0 0 6px rgba(127,224,235,.4)}.genre-tag{background:linear-gradient(135deg,#7fe0eb33,#7fe0eb4d);color:var(--stormlight-glow);padding:8px 15px;border-radius:20px;font-size:.85rem;font-weight:500;border:1px solid rgba(127,224,235,.4);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);text-shadow:0 0 8px rgba(127,224,235,.5);box-shadow:0 2px 6px #0000004d,inset 0 1px 1px #fff3;transition:all .3s ease}.genre-tag:hover{transform:translateY(-2px);box-shadow:0 4px 12px #7fe0eb4d,0 2px 6px #0000004d,inset 0 1px 1px #ffffff4d}@media(max-width:768px){.book-cover{width:90px;height:135px}.book-card{width:115px;padding:6px}.book-title{font-size:.75rem}.books{grid-template-columns:repeat(auto-fit,minmax(115px,1fr));gap:20px}.books:after,.books:before{height:18px;bottom:-22px}.category:before{width:20px;height:30px;bottom:-35px}.back-button{padding:10px 16px;font-size:.9rem;border-radius:6px}.bookshelf-header h1{font-size:2.2rem}}@media(max-width:480px){.book-cover{width:75px;height:112px}.book-card{width:95px;padding:5px}.book-title{font-size:.7rem;line-height:1.1}.books{grid-template-columns:repeat(auto-fit,minmax(95px,1fr));gap:15px}.book-info{padding:3px 4px 6px;gap:4px}.star{font-size:.9rem}.books:after,.books:before{height:16px;bottom:-20px}.category:before{width:18px;height:25px;bottom:-32px}.back-button{padding:8px 12px;font-size:.8rem;border-radius:5px}.bookshelf-header{flex-direction:column;gap:15px;align-items:flex-start;margin-bottom:1.5rem}.bookshelf-header h1{position:static;transform:none;left:auto;font-size:2rem;text-align:left;width:100%;margin-bottom:0}.book-modal-overlay{padding:20px 10px 10px;align-items:flex-start}.book-modal{padding:20px;max-height:90vh;border-radius:12px}.book-modal-content{flex-direction:column;gap:20px;align-items:center;text-align:center}.book-modal-cover{width:140px;height:210px}.book-modal-title{font-size:1.4rem}.book-modal-author{font-size:1rem}.book-modal-close{width:40px;height:40px;font-size:1.4rem;top:10px;right:15px}.book-modal-rating .star{font-size:1.2rem}.book-modal-description{padding:12px;font-size:.9rem;max-height:200px}.genre-tag{padding:6px 12px;font-size:.8rem}}@media(max-width:480px){.book-modal-overlay{padding:10px 5px 5px}.book-modal{padding:15px;max-height:95vh;border-radius:8px}.book-modal-content{gap:15px}.book-modal-cover{width:120px;height:180px}.book-modal-title{font-size:1.2rem;line-height:1.2}.book-modal-author{font-size:.9rem}.book-modal-pages{font-size:.85rem}.book-modal-close{width:35px;height:35px;font-size:1.2rem;top:8px;right:10px}.book-modal-rating .star{font-size:1.1rem}.rating-text{font-size:.8rem}.book-modal-description{padding:10px;font-size:.85rem;max-height:150px}.book-modal-genres h4{font-size:.9rem}.genre-tag{padding:5px 10px;font-size:.75rem}}
