@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;}@custom-variant dark (&:where(.dark,.dark *));@theme{ --color-primary: #1550d8; --color-primary-light: #2563eb; --color-accent: #4c1d95; --color-bg-light: #f3f4ff; --color-bg-dark: #020617; --color-card-light: #ffffff; --color-card-dark: #1E293B; --color-text-dark: #0f172a; --color-text-light: #e2e8f0; --color-border-light: #e2e8f0; --color-border-dark: #334155; }html,body{width:100%;max-width:100%;overflow-x:hidden}:root{--color-primary: #1550d8;--color-primary-light: #2563eb;--color-accent: #4c1d95;--color-bg-light: #f3f4ff;--color-bg-dark: #020617;--color-card-light: #ffffff;--color-card-dark: #1E293B;--color-text-dark: #0f172a;--color-text-light: #e2e8f0;--color-border-light: #e2e8f0;--color-border-dark: #334155;--font-heading: "Playfair Display", serif;--font-body: "Inter", sans-serif;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--radius-md: .5rem;--radius-lg: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1)}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--color-bg-light);color:var(--color-text-dark);font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.dark body{background-color:var(--color-bg-dark);color:var(--color-text-light)}#root{min-height:100vh;display:flex;flex-direction:column}.app-main{flex:1;width:100%;max-width:1120px;margin:0 auto;padding:4.5rem 1.25rem 4.75rem;display:flex;flex-direction:column;gap:1.5rem;box-sizing:border-box}@media(max-width:640px){.app-main{padding:4.25rem 1rem 4.75rem}}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.card{background-color:var(--color-card-light);border-radius:1.25rem;box-shadow:0 18px 45px #0f172a14;border:1px solid #cbd5e1;padding:0}.dark .card{background-color:var(--color-card-dark);border-color:var(--color-border-dark)}.card-header{padding:1.25rem 1.5rem .6rem}.card-title{font-family:var(--font-heading);font-size:1rem;font-weight:600;color:#0f172a;margin:0}.card-description{margin:.35rem 0 0;font-size:.78rem;color:#6b7280}.card-content{padding:.75rem 1.5rem 1.35rem}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:all .2s;border:0;font-family:var(--font-body)}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover{opacity:.9}.btn-outline{background-color:transparent;border:1px solid var(--color-border-light);color:var(--color-text-dark)}.dark .btn-outline{border-color:var(--color-border-dark);color:var(--color-text-light)}.btn-ghost{background-color:transparent;color:#4b5563}.btn-ghost:hover{background-color:#e5e7eb}.btn-subtle{background-color:#fff;color:#111827;box-shadow:var(--shadow-sm)}.btn-subtle:hover{background-color:#f3f4f6}.grid{display:grid;gap:var(--spacing-lg)}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}@media(max-width:768px){.grid-cols-3,.grid-cols-2{grid-template-columns:1fr}}.top-nav{position:fixed;top:0;left:0;right:0;z-index:40;border-bottom:1px solid rgba(148,163,184,.4);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:linear-gradient(to right,#dbeafef5,#bfdbfefa);box-shadow:0 12px 30px #0f172a2e}.top-nav-inner{max-width:1120px;margin:0 auto;padding:.75rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.top-nav-brand{display:flex;align-items:center;gap:.75rem;text-decoration:none}input:not([type=checkbox]):not([type=radio]):not([type=range]),textarea{background-color:#0000000d!important;color:inherit;border:1px solid rgba(0,0,0,.1);padding:.5rem;border-radius:.5rem}input:not([type=checkbox]):not([type=radio]):not([type=range]):focus,textarea:focus{background-color:#00000014!important;outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #2563eb33}.dark input:not([type=checkbox]):not([type=radio]):not([type=range]),.dark textarea{background-color:#1e293b80!important;color:#f9fafb;border-color:#ffffff1a}.dark input:not([type=checkbox]):not([type=radio]):not([type=range]):focus,.dark textarea:focus{background-color:#1e293bcc!important;border-color:var(--color-primary)}@keyframes pulse-opacity{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.95)}}.top-nav-logo{width:2.25rem;height:2.25rem;border-radius:.9rem;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2563eb1a,#4f46e51a);color:var(--color-primary);animation:pulse-opacity 2s infinite ease-in-out}.top-nav-logo svg{width:1.3rem;height:1.3rem;fill:currentColor}.top-nav-text{display:flex;flex-direction:column}.top-nav-title{font-family:var(--font-heading);font-size:1.05rem;font-weight:600;color:#020617}.top-nav-subtitle{font-size:.8rem;color:#4b5563}.top-nav-right{display:flex;align-items:center;gap:1.5rem}.top-nav-links{display:flex;align-items:center;gap:.6rem;font-size:.82rem}.top-nav-link{padding:.45rem .9rem;border-radius:999px;text-decoration:none;color:#4b5563}.top-nav-link:hover{background:#e5e7eb}.top-nav-link-active{background:#111827;color:#f9fafb}.dark .top-nav{background:linear-gradient(to right,#0f172af5,#0f172aeb);border-bottom-color:#0f172af2}.dark .top-nav-link{color:#e5e7eb}.dark .top-nav-link:hover{background:#1e40af59}.dark .top-nav-link-active{background:#1e40afcc;color:#f9fafb}.top-nav-controls{display:flex;align-items:center;gap:.75rem}.top-nav-logout{border-radius:999px;border:1px solid rgba(148,163,184,.7);padding:.35rem .9rem;font-size:.7rem;background:#ffffffe0;color:#0f172a}.top-nav-logout:hover{background:#f9fafb}.dark .top-nav-logout{border-color:#64748b;background:#0f172ae6;color:#e5e7eb}.dark .top-nav-logout:hover{background:#0f172abf}@media(max-width:768px){.top-nav-inner{padding-inline:1rem}.top-nav-links{display:none}.mobile-nav{display:block}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at top left,#e0f2fe,#f9fafb);padding:2rem 1.25rem}.auth-shell{width:100%;max-width:1120px;border-radius:1.5rem;background:#fff;box-shadow:0 24px 80px #0f172a40;overflow:hidden}.auth-browser-bar{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;background:#020617;color:#e5e7eb}.auth-browser-dots{display:inline-flex;gap:.4rem}.auth-browser-dots span{width:.6rem;height:.6rem;border-radius:999px;background:#4b5563}.auth-browser-title{font-size:.8rem;letter-spacing:.08em;text-transform:uppercase}.auth-body{display:flex;flex-direction:row}.auth-panel{flex:1}.auth-panel-form{padding:2.5rem 2.75rem}.auth-brand{display:flex;align-items:center;gap:1rem;margin-bottom:1.75rem}.auth-logo{width:3rem;height:3rem;border-radius:1.25rem;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2563eb,#4f46e5);color:#fff;font-size:1.5rem}.auth-heading{font-family:var(--font-heading);font-size:1.5rem;margin:0;color:var(--color-text-dark)}.auth-subheading{margin:.25rem 0 0;font-size:.9rem;color:#6b7280}.auth-card{margin-top:.75rem;border-radius:1.25rem}.auth-card-title{font-size:1.25rem}.auth-card-description{font-size:.9rem}.auth-card-body{display:flex;flex-direction:column;gap:1.5rem}.auth-google-btn{width:100%;padding:.9rem 1.25rem;border-radius:999px;font-size:.9rem;font-weight:500;border:1px solid var(--color-border-light);background:#fff;color:#111827;display:inline-flex;align-items:center;justify-content:center;gap:.6rem}.auth-google-btn span{font-weight:500}.dark .auth-google-btn{background:#f9fafb;color:#111827}.auth-google-btn svg{width:1rem;height:1rem}.auth-google-icon{display:inline-flex}.auth-divider{position:relative;text-align:center;font-size:.75rem;color:#9ca3af}.dark .auth-divider{color:#e5e7eb}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-field{display:flex;flex-direction:column;gap:.4rem}.auth-label-row{display:flex;justify-content:space-between;align-items:center}.auth-label{font-size:.85rem;font-weight:500;color:#020617}.auth-link-button{border:none;background:transparent;padding:0;font-size:.75rem;font-weight:500;color:var(--color-primary);cursor:pointer}.auth-input,.tracker-input,.tracker-textarea{width:100%;border-radius:1rem;border:1px solid var(--color-border-light);padding:.7rem .9rem;font-size:.9rem;outline:none;background:var(--color-bg-light);color:#0f172a;box-sizing:border-box}.auth-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #14532d26}.auth-input::placeholder{color:#9ca3af}.auth-password-wrapper{position:relative;display:flex;align-items:center;width:100%}.auth-password-wrapper .auth-input{padding-right:3rem}.auth-password-toggle{position:absolute;right:.9rem;padding:.1rem 0;border:0;background:transparent;font-size:.75rem;font-weight:500;color:#6b7280;cursor:pointer}.auth-password-toggle:hover{color:var(--color-primary)}.dark .auth-input,.dark .tracker-input,.dark .tracker-textarea{background:#0f172ae6;border-color:#334155;color:#e5e7eb}.dark .auth-label{color:#e5e7eb}.dark .auth-input::placeholder{color:#64748b}.dark .auth-password-toggle{color:#e5e7eb}.auth-error{padding:.75rem .9rem;border-radius:.75rem;font-size:.8rem;background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.auth-submit-btn{width:100%;padding:.95rem 1.25rem;border-radius:999px;font-size:.95rem;font-weight:600;background:#1550d8;color:#fff;border:0}.auth-submit-btn:disabled{opacity:.7;cursor:default}.auth-card-footer{display:flex;justify-content:center;align-items:center;gap:.4rem;padding:.9rem 1.5rem 1.4rem;font-size:.85rem;color:#6b7280}.auth-link{font-weight:500;color:var(--color-primary);text-decoration:none}.auth-link:hover{text-decoration:underline}.auth-panel-preview{background:radial-gradient(circle at top,#0f172a,#020617);display:flex;align-items:center;justify-content:center;padding:2.5rem 2rem}.auth-phone{width:260px;border-radius:2rem;padding:.9rem;background:#020617;box-shadow:0 28px 80px #0f172ab3;transform:rotate(-12deg)}.auth-phone-notch{height:.5rem;width:6rem;border-radius:999px;margin:0 auto .6rem;background:#020617}.auth-phone-screen{border-radius:1.5rem;padding:1.25rem 1.1rem 1.1rem;background:radial-gradient(circle at top left,#1d4ed8,#020617 55%);color:#e5e7eb}.auth-phone-header{display:flex;justify-content:space-between;align-items:center;font-size:.7rem;margin-bottom:1rem}.auth-phone-logo{display:inline-flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;border-radius:999px;background:#0f172acc}.auth-phone-brand{font-weight:500}.auth-phone-title{font-size:1.1rem;margin:0 0 .45rem}.auth-phone-text{font-size:.75rem;margin:0 0 1rem;color:#cbd5f5}.auth-phone-cta{width:100%;margin-bottom:1rem;padding:.6rem .8rem;border-radius:999px;background:#f9fafb;color:#111827;font-size:.8rem;font-weight:600;border:0}.auth-phone-stats{display:flex;justify-content:space-between;gap:.75rem;font-size:.7rem}.auth-phone-stat-label{display:block;color:#9ca3af;margin-bottom:.15rem}.auth-phone-stat-value{font-weight:600;color:#f9fafb}@media(max-width:900px){.auth-shell{border-radius:1.25rem}.auth-body{flex-direction:column-reverse}.auth-panel-form{padding:1.75rem 1.5rem 2rem}.auth-panel-preview{padding:1.75rem 1.5rem}.auth-phone{transform:none;margin-bottom:.5rem}}.dashboard-page{display:flex;flex-direction:column;gap:1.5rem;padding-bottom:4.5rem}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1.25rem}.dashboard-title{font-family:var(--font-heading);font-size:2rem;margin:0;color:#020617}.dashboard-subtitle{margin:.35rem 0 0;font-size:1rem;color:#4b5563}.dashboard-header-right{display:flex;align-items:center;gap:.75rem}.dashboard-day-pill{padding:.4rem .9rem;border-radius:999px;background:#fffc;border:1px solid #e5e7eb;font-size:.8rem;color:#4b5563}.dashboard-grid-primary{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1.2fr);gap:1.5rem}.dashboard-grid-secondary{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1.2fr) minmax(0,1.1fr);gap:1.5rem}.dashboard-hero-card{position:relative;overflow:hidden;background:var(--color-card-light);color:var(--color-text-dark);border:1px solid var(--color-border-light);box-shadow:0 4px 6px -1px #0000001a}.dark .dashboard-hero-card{background:radial-gradient(circle at top,#2563eb,#1e293b);color:#f9fafb;border:0;box-shadow:0 20px 60px #2563eb73}.dashboard-hero-pattern{position:absolute;inset:0;opacity:.14;display:flex;justify-content:flex-end;align-items:flex-start;padding:1.5rem}.dashboard-hero-pattern svg{width:9rem;height:9rem;fill:currentColor}.dashboard-hero-content{position:relative;z-index:1;padding:1.75rem 1.6rem 1.6rem;display:flex;flex-direction:column;gap:1.5rem}.dashboard-hero-layout{display:flex;gap:1.75rem;align-items:stretch}.dashboard-hero-top{display:flex;flex-direction:column;gap:1rem}.dashboard-hero-pill{display:inline-block;padding:.3rem .9rem;border-radius:999px;background:#0f172a66;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase}.dashboard-hero-title{margin:0;font-family:var(--font-heading);font-size:2.4rem}.dashboard-hero-text{margin:.4rem 0 0;max-width:360px;font-size:.9rem;color:var(--color-text-dark);opacity:.9}.dark .dashboard-hero-text{color:#e2e8f0e6}.dashboard-hero-progress{display:flex;flex-direction:column;gap:.8rem}.dashboard-hero-progress-header{display:flex;justify-content:space-between;font-size:.8rem;color:var(--color-text-dark);opacity:.95}.dark .dashboard-hero-progress-header{color:#e2e8f0f2}.dashboard-hero-day-selector{display:flex;align-items:center;justify-content:flex-end;gap:.25rem;flex-wrap:wrap;row-gap:.5rem;padding:0 1.6rem .5rem}.dashboard-hero-day-label{font-size:.8rem;color:var(--color-text-dark);opacity:.9}.dark .dashboard-hero-day-label{color:#e2e8f0e6}.dashboard-hero-day-select{min-width:120px;border-radius:1rem;border:1px solid var(--color-border-light);padding:.35rem .75rem;font-size:.8rem;background:var(--color-bg-light);color:#0f172a}.dark .dashboard-hero-day-select{background:#0f172ae6;border-color:#334155;color:#e5e7eb}.dashboard-hero-progress-bar{height:.55rem;border-radius:999px;background:#0f172a73;overflow:hidden}.dashboard-hero-progress-bar div{height:100%;border-radius:999px;background:linear-gradient(90deg,#a855f7,#f97316);transition:width .4s ease}.dashboard-hero-cta{margin-top:.4rem;align-self:flex-start;padding:.7rem 1.3rem;border-radius:999px;background:var(--color-primary);color:#fff;font-size:.85rem;font-weight:600;border:none}.dark .dashboard-hero-cta{background:#f9fafb;color:#1d4ed8}.dashboard-hero-stats{display:flex;gap:1rem;margin-top:.8rem}.dashboard-hero-stat{padding:.6rem .8rem;border-radius:.85rem;background:var(--color-bg-light);border:1px solid #cbd5e1}.dark .dashboard-hero-stat{background:#0f172a73;border:none}.dashboard-hero-stat-label{display:block;font-size:.7rem;color:var(--color-text-dark);opacity:.8}.dark .dashboard-hero-stat-label{color:#d1d5dbe6}.dashboard-hero-stat-value{display:block;font-size:1.1rem;font-weight:600}.dashboard-hero-phone{display:flex;align-items:center;justify-content:center}.dashboard-hero-phone .auth-phone{transform:rotate(-8deg)}@media(max-width:900px){.dashboard-hero-layout{flex-direction:column}.dashboard-hero-phone .auth-phone{transform:none;max-width:260px;margin:0 auto .5rem}}.dashboard-hero-card .card-title,.dashboard-hero-card .card-description{color:var(--color-text-dark)}.dark .dashboard-hero-card .card-title,.dark .dashboard-hero-card .card-description{color:#e5e7eb}.dashboard-prayer-card{background:var(--color-bg-light)}.dark .dashboard-prayer-card{background:var(--color-card-dark)}.dashboard-prayer-content{padding-top:0}.dashboard-weekly-card{grid-column:span 1}.dashboard-quran-card{display:flex;flex-direction:column;justify-content:space-between}.dashboard-quran-content{display:flex;flex-direction:column;align-items:center;gap:.75rem}.dashboard-quran-ring{position:relative;width:7rem;height:7rem}.dashboard-quran-ring svg{width:100%;height:100%;transform:rotate(-90deg)}.dashboard-quran-circle-bg{stroke:#cbd5e1}.dashboard-quran-circle-fg{stroke:url(#dashboardQuranGradient);stroke:#facc15;transition:stroke-dashoffset .6s ease}.dashboard-quran-ring-center{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.dashboard-quran-percent{font-size:1.35rem;font-weight:700;color:#1e293b}.dark .dashboard-quran-percent{color:#f1f5f9}.dashboard-quran-caption{font-size:.8rem;color:#6b7280}.dark .dashboard-quran-caption{color:#94a3b8}@media(max-width:640px){.dashboard-title{font-size:1.5rem;white-space:nowrap}}.dashboard-salah-card{display:flex;flex-direction:column;justify-content:space-between}.dashboard-salah-content{display:flex;flex-direction:column;gap:.4rem}.dashboard-salah-main{display:flex;align-items:baseline;gap:.4rem}.dashboard-salah-count{font-size:2rem;font-weight:700;color:#4c1d95}.dark .dashboard-salah-count{color:#a78bfa}.dashboard-salah-label{font-size:.85rem;color:#6b7280}.dark .dashboard-salah-label{color:#94a3b8}.dashboard-salah-caption{font-size:.78rem;color:#9ca3af}.dashboard-inspiration-card{border-left:4px solid #4c1d95;background:#f9fafb}.dark .dashboard-inspiration-card{border-left-color:#a78bfa;background:var(--color-card-dark)}.dashboard-qibla-card{display:flex;flex-direction:column;justify-content:space-between}.qibla-widget{display:flex;flex-direction:column;gap:.75rem}.qibla-text{margin:0;font-size:.85rem;color:#4b5563}.dark .qibla-text{color:#cbd5e1}.qibla-button{align-self:flex-start;padding-inline:1.25rem}.qibla-compass-button{align-self:flex-start;margin-top:.25rem;font-size:.75rem;color:#1d4ed8;background:transparent;border:none;padding:0;cursor:pointer}.qibla-result{display:flex;align-items:center;gap:1rem}.qibla-compass{width:72px;height:72px;border-radius:999px;border:2px dashed rgba(148,163,184,.8);display:flex;align-items:center;justify-content:center;position:relative}.qibla-compass-label{position:absolute;font-size:.6rem;font-weight:600;color:#6b7280}.qibla-compass-label-n{top:4px}.qibla-compass-label-e{right:6px}.qibla-compass-label-s{bottom:4px}.qibla-compass-label-w{left:6px}.qibla-arrow{width:2px;height:26px;border-radius:999px;background:linear-gradient(to bottom,#1550d8,#f97316);transform-origin:center bottom}.qibla-details{font-size:.8rem;color:#4b5563;display:flex;flex-direction:column;gap:.25rem}.qibla-angle{font-size:.9rem}.qibla-location{color:#6b7280}.qibla-note{color:#9ca3af}.qibla-hint{margin:0;margin-top:.5rem;font-size:.8rem;color:#6b7280}.qibla-error{margin:.25rem 0 0;font-size:.8rem;color:#b91c1c}.dashboard-inspiration-header{display:flex;align-items:center;gap:.4rem;padding-bottom:.4rem}.dashboard-inspiration-icon{font-size:1.25rem}.dashboard-error{margin-top:.75rem;padding:.75rem 1rem;border-radius:.75rem;background:#fef2f2;color:#b91c1c;font-size:.85rem;border:1px solid #fecaca;text-align:center}@media(max-width:1024px){.dashboard-grid-secondary{grid-template-columns:minmax(0,1.8fr) minmax(0,1.2fr)}}@media(max-width:900px){.dashboard-page{padding-bottom:4.75rem}.dashboard-header{flex-direction:column}.dashboard-grid-primary,.dashboard-grid-secondary{grid-template-columns:minmax(0,1fr)}}.mobile-nav{position:fixed;left:0;right:0;bottom:0;z-index:40;padding:.35rem .85rem calc(.35rem + env(safe-area-inset-bottom));background:linear-gradient(to right,var(--color-primary),var(--color-primary-light));display:none}.mobile-nav-inner{max-width:640px;margin:0 auto;display:flex;justify-content:space-between;gap:.5rem}.mobile-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.15rem;padding:.45rem .5rem;border-radius:999px;text-decoration:none;color:#e2e8f0d9;font-size:.68rem}.mobile-nav-item-active{background:#0f172a59;color:#f9fafb}.mobile-nav-icon{width:1.2rem;height:1.2rem;display:inline-flex}.mobile-nav-label{letter-spacing:.05em;text-transform:uppercase}.mobile-nav-icon svg{width:100%;height:100%;fill:currentColor;stroke:currentColor;stroke-width:1.5}.calendar-page{display:flex;flex-direction:column;gap:1.5rem}.calendar-header{display:flex;flex-direction:column;gap:.3rem}.calendar-title{font-family:var(--font-heading);font-size:1.7rem;margin:0;color:#0f172a}.calendar-subtitle{margin:0;font-size:.9rem;color:#6b7280}.calendar-grid{display:flex;flex-direction:column;gap:.5rem}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:.25rem;margin-bottom:.25rem}.calendar-weekday{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:#9ca3af;text-align:center}.calendar-weeks{display:flex;flex-direction:column;gap:.3rem}.calendar-week{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:.25rem}.calendar-cell{min-height:3rem;border-radius:.9rem;padding:.3rem .35rem;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:.1rem;font-size:.7rem;background:#eef2ff;overflow:hidden}.calendar-cell-fasted{box-shadow:0 0 0 2px #059669}.calendar-cell-fasted .calendar-cell-ramadan:after{content:" · Fasted";font-weight:500}@media(max-width:640px){.calendar-cell-fasted .calendar-cell-ramadan:after{content:" · Fast"}}@media(max-width:480px){.calendar-cell-fasted .calendar-cell-ramadan:after{content:" ✓"}}.calendar-cell-date{font-weight:600;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.calendar-cell-month{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#0f172a}.calendar-cell-ramadan{font-size:.7rem;color:#4b5563;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;display:block}.calendar-cell-outside{background:transparent}.calendar-cell-empty{background:#e5edff}.calendar-cell-light{background:#e0f2fe}.calendar-cell-partial{background:#bfdbfe}.calendar-cell-full{background:#2563eb;color:#f9fafb}.calendar-cell-full .calendar-cell-date,.calendar-cell-full .calendar-cell-ramadan,.calendar-cell-full .calendar-cell-month{color:#f9fafb}.calendar-empty{font-size:.9rem;color:#6b7280}.calendar-loading{display:flex;align-items:center;justify-content:center;padding:1.5rem 0}.calendar-spinner{width:2rem;height:2rem;border-radius:999px;border:2px solid var(--color-primary);border-top-color:transparent;animation:spin .9s linear infinite}.calendar-error{margin-top:.75rem;font-size:.8rem;color:#b91c1c}@keyframes spin{to{transform:rotate(360deg)}}.quran-page{display:flex;flex-direction:column;gap:1.5rem}.quran-header{display:flex;flex-direction:column;gap:.3rem}.quran-controls{display:flex;align-items:center;gap:1rem;margin-top:.5rem;flex-wrap:wrap}.quran-title{font-family:var(--font-heading);font-size:1.7rem;margin:0;color:#0f172a}.quran-subtitle{margin:0;font-size:.9rem;color:#6b7280}.quran-grid{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);gap:1.5rem}.quran-empty{font-size:.85rem;color:#6b7280}.quran-goal-text{font-size:.9rem;color:#4b5563;margin-bottom:.75rem}.quran-goal-button{margin-top:.25rem}.quran-reader-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.75rem}.quran-reader-info{display:flex;flex-direction:column;gap:.15rem}.quran-reader-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:#9ca3af}.quran-reader-value{font-size:.9rem;font-weight:500;color:#111827}.dark .quran-reader-value{color:#e5e7eb}.quran-reader-controls{display:flex;gap:.5rem}.quran-reader-loading{display:flex;align-items:center;justify-content:center;padding:1.5rem 0}.quran-reader-spinner{width:2rem;height:2rem;border-radius:999px;border:2px solid var(--color-primary);border-top-color:transparent;animation:spin .9s linear infinite}.quran-reader-error{margin:.5rem 0 0;font-size:.85rem;color:#b91c1c}.quran-verses{margin-top:.5rem;max-height:420px;overflow-y:auto;padding-right:.25rem;display:flex;flex-direction:column;gap:.6rem}.quran-verse{display:flex;gap:.75rem}.quran-verse-active{background:#eff6ff;border-radius:.75rem;padding:.4rem .6rem}.quran-verse-meta{min-width:3.4rem;padding-top:.2rem;display:flex;flex-direction:column;gap:.25rem}.quran-verse-number{display:inline-flex;align-items:center;justify-content:center;width:1.6rem;height:1.6rem;border-radius:999px;background:#e5e7eb;font-size:.75rem;font-weight:600;color:#111827}.dark .quran-verse-number{background:#334155;color:#f1f5f9}.quran-verse-audio{display:inline-flex;align-items:center;justify-content:center;padding:.15rem .75rem;border-radius:999px;border:1px solid #cbd5f5;background:#eef2ff;color:#1e293b;font-size:.7rem;cursor:pointer}.quran-verse-audio:hover{background:#e0e7ff}.dark .quran-verse-audio{border-color:#4b5563;background:#020617;color:#e5e7eb}.dark .quran-verse-audio:hover{background:#111827}.quran-verse-text{flex:1;display:flex;flex-direction:column;gap:.2rem}.dark .quran-verse-active{background:#1e40af59}.dark .quran-surah-select{background:#0f172ae6;border-color:#334155;color:#e5e7eb}.quran-surah-select{margin-top:.25rem;border-radius:999px;border:1px solid var(--color-border-light);padding:.25rem .75rem;font-size:.8rem;background:#f9fafb;color:#111827}.quran-verse-ar{margin:0;font-size:1rem;line-height:1.7;text-align:right}.quran-verse-en{margin:0;font-size:.85rem;color:#4b5563}@media(max-width:900px){.quran-grid{grid-template-columns:minmax(0,1fr)}}.dark .card-title{color:#f9fafb}.dark .card-description{color:#e5e7eb}.dark .top-nav-title{color:#f9fafb}.dark .top-nav-subtitle{color:#e5e7eb}.dark .dashboard-title{color:#f9fafb}.dark .dashboard-subtitle{color:#e5e7eb}.dark .calendar-title{color:#f9fafb}.dark .calendar-subtitle{color:#e5e7eb}.dark .calendar-cell-date{color:#0f172a}.dark .calendar-cell-ramadan{color:#4b5563}.dark .quran-title{color:#f9fafb}.dark .quran-subtitle,.dark .quran-empty,.dark .quran-goal-text{color:#e5e7eb}.tracker-page{display:flex;flex-direction:column;gap:1.5rem}.tracker-header{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;flex-wrap:wrap}.tracker-title{font-family:var(--font-heading);font-size:1.6rem;margin:0;color:#020617}.tracker-subtitle{margin:.25rem 0 0;font-size:.9rem;color:#6b7280}.dark .tracker-title{color:#f9fafb}.dark .tracker-subtitle{color:#e5e7eb}.tracker-date-nav{display:inline-flex;align-items:center;gap:.5rem;font-size:.75rem;color:#6b7280}.tracker-date-pill{padding:.35rem .9rem;border-radius:999px;background:#e5e7eb;color:#111827;font-weight:500}.dark .tracker-date-pill{background:#0f172ad9;color:#e5e7eb}.tracker-loading{min-height:40vh;display:flex;align-items:center;justify-content:center}.tracker-spinner{width:2.5rem;height:2.5rem;border-radius:999px;border:2px solid var(--color-primary);border-top-color:transparent;animation:spin .9s linear infinite}@media(max-width:768px){.mobile-nav{display:block}}@media(max-width:480px){.calendar-weekdays,.calendar-week{gap:.15rem}.calendar-cell{min-height:2.5rem;padding:.2rem;border-radius:.6rem}.calendar-cell-date{font-size:.65rem}.calendar-cell-ramadan{font-size:.6rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-main{padding-inline:.75rem}.dashboard-grid-primary,.dashboard-grid-secondary{gap:1rem}}.qibla-modal-overlay{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;background-color:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .3s ease-out}.qibla-modal-content{position:relative;width:100%;max-width:400px;padding:2rem;display:flex;flex-direction:column;align-items:center;color:#fff}.qibla-modal-close{position:absolute;top:1rem;right:1rem;background:#ffffff1a;border:none;color:#fff;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s;z-index:60}.qibla-modal-close:hover{background:#fff3}.qibla-info{text-align:center;margin-bottom:2rem}.qibla-info h2{font-size:1.5rem;font-weight:600;margin:0 0 .5rem;font-family:var(--font-heading)}.qibla-info p{color:#ffffffb3;margin:0;font-size:.9rem}.compass-container{position:relative;width:300px;height:300px;border-radius:50%;background:linear-gradient(145deg,#1e293b,#0f172a);box-shadow:0 0 0 10px #334155,0 0 0 20px #1e293b,0 20px 50px #00000080,inset 0 0 20px #00000080;display:flex;align-items:center;justify-content:center;margin:2rem 0}.compass-indicator-top{position:absolute;top:-30px;left:50%;transform:translate(-50%);width:4px;height:20px;background-color:#ef4444;border-radius:2px;z-index:10;box-shadow:0 0 10px #ef444480}.compass-dial{position:relative;width:90%;height:90%;border-radius:50%;transition:transform .1s linear;will-change:transform}.compass-mark{position:absolute;top:0;left:50%;transform-origin:50% 135px;width:2px;height:10px;background-color:#ffffff4d}.compass-mark.major{height:15px;width:3px;background-color:#fff9}.compass-direction{position:absolute;font-weight:700;font-size:1.2rem;color:#fff;transform-origin:center}.dir-n{top:20px;left:50%;transform:translate(-50%);color:#ef4444}.dir-e{right:20px;top:50%;transform:translateY(-50%)}.dir-s{bottom:20px;left:50%;transform:translate(-50%)}.dir-w{left:20px;top:50%;transform:translateY(-50%)}.qibla-pointer-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.qibla-icon-wrapper{position:absolute;top:15%;left:50%;transform-origin:50% 135px;display:flex;flex-direction:column;align-items:center}.qibla-icon{width:32px;height:32px;background:linear-gradient(45deg,#000,#333);border:1px solid #fbbf24;position:relative;box-shadow:0 0 15px #fbbf2466}.qibla-icon:before{content:"";position:absolute;top:6px;left:0;right:0;height:4px;background-color:#fbbf24}.qibla-pointer-arrow{width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:10px solid #fbbf24;margin-bottom:4px}.compass-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:12px;height:12px;background-color:#ef4444;border-radius:50%;border:2px solid white;z-index:20}.permission-btn{background:#2563eb;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:2rem;font-weight:600;cursor:pointer;margin-top:1rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.calibration-msg{position:absolute;bottom:-40px;width:100%;text-align:center;color:#ffffff80;font-size:.8rem;animation:pulse 2s infinite}@keyframes pulse{0%{opacity:.5}50%{opacity:.8}to{opacity:.5}}.digital-tasbeeh-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem}.digital-tasbeeh-device{position:relative;width:280px;height:480px;background-color:#1d4ed8;border-radius:3rem;box-shadow:0 20px 50px -12px #00000080,inset 0 2px 4px #fff3,inset -4px -4px 8px #0003;border:6px solid #1e40af;display:flex;flex-direction:column;align-items:center;padding:1.5rem;-webkit-user-select:none;user-select:none;overflow:hidden}.digital-tasbeeh-texture{position:absolute;top:20%;bottom:20%;width:4px;background:repeating-linear-gradient(to bottom,rgba(0,0,0,.1),rgba(0,0,0,.1) 2px,transparent 2px,transparent 4px)}.texture-left{left:4px}.texture-right{right:4px}.digital-tasbeeh-header{width:100%;display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:0 .5rem}.digital-tasbeeh-brand{font-size:.7rem;font-weight:700;letter-spacing:.05em;color:#ffffff80;text-transform:uppercase}.digital-tasbeeh-model{font-size:.6rem;color:#ffffff4d}.digital-tasbeeh-screen-container{width:100%;background-color:#111827;border-radius:1rem;padding:1rem;margin-bottom:2rem;box-shadow:inset 0 2px 10px #00000080,0 1px 1px #ffffff1a;border:2px solid #374151;position:relative}.digital-tasbeeh-screen{background-color:#1f2937;border-radius:.5rem;padding:.2rem .5rem;font-family:Courier New,Courier,monospace;color:#e5e7eb;text-align:right;min-height:80px;display:flex;flex-direction:column;justify-content:space-between;box-shadow:inset 0 0 10px #00000080}.screen-label{font-size:.6rem;text-transform:uppercase;color:#6b7280;text-align:left}.screen-count{font-size:2.5rem;line-height:1;letter-spacing:2px;font-weight:700;color:#e5e7eb;text-shadow:0 0 5px rgba(229,231,235,.3)}.screen-target{font-size:.7rem;color:#9ca3af;display:flex;justify-content:space-between}.led-indicator{width:8px;height:8px;border-radius:50%;background-color:#374151;margin-right:4px;display:inline-block;box-shadow:inset 0 1px 2px #00000080}.led-on{background-color:#10b981;box-shadow:0 0 5px #10b981}.digital-tasbeeh-controls{flex:1;width:100%;display:flex;flex-direction:column;align-items:center;position:relative}.reset-btn-wrapper{position:absolute;top:-10px;right:10px}.reset-btn{width:24px;height:24px;border-radius:50%;background-color:#ef4444;border:none;box-shadow:0 2px 4px #0000004d,inset 0 1px 2px #ffffff4d;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .1s}.reset-btn:active{transform:translateY(1px);box-shadow:inset 0 2px 4px #0006}.reset-icon{width:12px;height:12px;color:#fff}.main-btn{width:140px;height:140px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#2563eb);border:6px solid #1d4ed8;box-shadow:0 10px 25px #0006,inset 0 2px 4px #ffffff4d;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .1s ease-out;margin-top:2rem;outline:none;position:relative}.main-btn:active,.main-btn.pressed{transform:scale(.95) translateY(4px);box-shadow:inset 0 8px 20px #0006}.main-btn-inner{width:120px;height:120px;border-radius:50%;background-color:#3b82f61a;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none}.device-footer{margin-top:auto;font-size:.6rem;color:#fff3;text-align:center;padding-top:1rem}@media(max-width:350px){.digital-tasbeeh-device{width:100%;height:auto;aspect-ratio:280/480;border-width:4px;border-radius:2rem}.main-btn{width:100px;height:100px;margin-top:1.5rem;border-width:4px}.main-btn-inner{width:80px;height:80px}.digital-tasbeeh-screen-container{padding:.75rem;margin-bottom:1.5rem}.screen-count{font-size:2rem}}.tasbeeh-page-container{min-height:calc(100vh - 4rem);padding:1.5rem 1rem 6rem;display:flex;flex-direction:column;align-items:center;gap:2rem;background-color:var(--color-bg-light)}.dark .tasbeeh-page-container{background-color:var(--color-bg-dark)}.tasbeeh-header{text-align:center;margin-bottom:1rem}.tasbeeh-title{font-family:var(--font-heading);font-size:2rem;font-weight:700;color:var(--color-text-dark);margin:0}.tasbeeh-subtitle{color:#6b7280;font-size:.9rem;margin-top:.25rem}.dark .tasbeeh-title{color:var(--color-text-light)}.dark .tasbeeh-subtitle{color:#9ca3af}.streak-container{display:flex;gap:2rem;margin-bottom:1rem}.streak-item{display:flex;flex-direction:column;align-items:center}.streak-value{font-size:1.5rem;font-weight:700;color:var(--color-primary)}.streak-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#6b7280}.dark .streak-label{color:#9ca3af}.tasbeeh-controls-section{width:100%;max-width:400px;background-color:var(--color-card-light);border-radius:1.5rem;padding:1.5rem;box-shadow:0 4px 6px -1px #0000001a;border:1px solid var(--color-border-light)}.dark .tasbeeh-controls-section{background-color:var(--color-card-dark);border-color:var(--color-border-dark)}.control-group{margin-bottom:1.5rem}.control-label{display:block;font-size:.9rem;font-weight:600;margin-bottom:.75rem;color:var(--color-text-dark)}.dark .control-label{color:var(--color-text-light)}.target-presets{display:flex;gap:.5rem;margin-bottom:.75rem}.target-btn{flex:1;padding:.5rem;border-radius:.5rem;border:1px solid var(--color-border-light);background-color:transparent;color:var(--color-text-dark);font-size:.9rem;cursor:pointer;transition:all .2s}.dark .target-btn{border-color:var(--color-border-dark);color:var(--color-text-light)}.target-btn:hover{background-color:#0000000d}.target-btn.active{background-color:var(--color-primary);color:#fff;border-color:var(--color-primary)}.custom-target-input{width:100%;padding:.75rem;border-radius:.75rem;border:1px solid var(--color-border-light);background-color:var(--color-bg-light);color:var(--color-text-dark);font-size:.9rem}.dark .custom-target-input{background-color:#0f172a80;border-color:var(--color-border-dark);color:var(--color-text-light)}.modal-overlay{position:fixed;inset:0;background-color:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:50;padding:1rem}.modal-content{background-color:var(--color-card-light);border-radius:1.5rem;padding:1.5rem;width:100%;max-width:320px;box-shadow:0 20px 25px -5px #0000001a;text-align:center}.dark .modal-content{background-color:var(--color-card-dark);color:var(--color-text-light)}.modal-title{font-size:1.25rem;font-weight:700;margin-bottom:.5rem;color:var(--color-text-dark)}.dark .modal-title{color:var(--color-text-light)}.modal-text{font-size:.9rem;color:#6b7280;margin-bottom:1.5rem}.dark .modal-text{color:#9ca3af}.modal-actions{display:flex;gap:.75rem}.modal-btn{flex:1;padding:.75rem;border-radius:.75rem;font-weight:600;font-size:.9rem;cursor:pointer;border:none}.modal-btn-cancel{background-color:#f3f4f6;color:#374151}.dark .modal-btn-cancel{background-color:#374151;color:#e5e7eb}.modal-btn-confirm{background-color:#ef4444;color:#fff}
