:root{--primary-50: oklch(.97 .014 262);--primary-100: oklch(.93 .03 262);--primary-200: oklch(.87 .06 262);--primary-300: oklch(.78 .1 262);--primary-400: oklch(.68 .15 262);--primary-500: oklch(.59 .2 262);--primary-600: oklch(.52 .19 262);--primary-700: oklch(.45 .16 262);--primary-800: oklch(.38 .13 262);--primary-900: oklch(.33 .1 262);--primary-950: oklch(.24 .07 262);--accent-50: oklch(.97 .014 200);--accent-100: oklch(.93 .03 200);--accent-200: oklch(.87 .06 200);--accent-300: oklch(.78 .1 200);--accent-400: oklch(.68 .15 200);--accent-500: oklch(.59 .2 200);--accent-600: oklch(.52 .19 200);--accent-700: oklch(.45 .16 200);--accent-800: oklch(.38 .13 200);--accent-900: oklch(.33 .1 200);--accent-950: oklch(.24 .07 200);--bg: oklch(.985 0 0);--bg-secondary: oklch(.96 .005 262);--bg-tertiary: oklch(.93 .008 262);--bg-hover: oklch(.9 .01 262);--fg: oklch(.145 0 0);--fg-secondary: oklch(.45 .015 262);--fg-tertiary: oklch(.55 .01 262);--card: oklch(1 0 0);--card-fg: oklch(.145 0 0);--border-color: oklch(.91 .008 262);--border-light: oklch(.94 .005 262);--surface: oklch(.98 .003 262);--surface-raised: oklch(.96 .005 262);--muted: oklch(.96 .005 262);--muted-fg: oklch(.45 .015 262);--ring: var(--primary-500);--destructive: oklch(.55 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.6 .19 155);--warning: oklch(.7 .17 70)}:root.dark{--bg: oklch(.13 .005 262);--bg-secondary: oklch(.16 .008 262);--bg-tertiary: oklch(.19 .01 262);--bg-hover: oklch(.22 .012 262);--fg: oklch(.93 0 0);--fg-secondary: oklch(.65 .01 262);--fg-tertiary: oklch(.5 .01 262);--card: oklch(.17 .008 262);--card-fg: oklch(.93 0 0);--border-color: oklch(.26 .015 262);--border-light: oklch(.2 .01 262);--surface: oklch(.15 .006 262);--surface-raised: oklch(.19 .01 262);--muted: oklch(.2 .008 262);--muted-fg: oklch(.65 .01 262);--destructive: oklch(.65 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.7 .19 155);--warning: oklch(.75 .17 70)}[data-theme=ocean]{--primary-50: oklch(.97 .014 230);--primary-100: oklch(.93 .03 230);--primary-200: oklch(.87 .06 230);--primary-300: oklch(.78 .1 230);--primary-400: oklch(.68 .15 230);--primary-500: oklch(.59 .2 230);--primary-600: oklch(.52 .19 230);--primary-700: oklch(.45 .16 230);--primary-800: oklch(.38 .13 230);--primary-900: oklch(.33 .1 230);--primary-950: oklch(.24 .07 230);--accent-50: oklch(.97 .014 180);--accent-100: oklch(.93 .03 180);--accent-200: oklch(.87 .06 180);--accent-300: oklch(.78 .1 180);--accent-400: oklch(.68 .15 180);--accent-500: oklch(.59 .2 180);--accent-600: oklch(.52 .19 180);--accent-700: oklch(.45 .16 180);--accent-800: oklch(.38 .13 180);--accent-900: oklch(.33 .1 180);--accent-950: oklch(.24 .07 180);--bg: oklch(.985 0 0);--bg-secondary: oklch(.96 .005 230);--bg-tertiary: oklch(.93 .008 230);--bg-hover: oklch(.9 .01 230);--fg: oklch(.145 0 0);--fg-secondary: oklch(.45 .015 230);--fg-tertiary: oklch(.55 .01 230);--card: oklch(1 0 0);--card-fg: oklch(.145 0 0);--border-color: oklch(.91 .008 230);--border-light: oklch(.94 .005 230);--surface: oklch(.98 .003 230);--surface-raised: oklch(.96 .005 230);--muted: oklch(.96 .005 230);--muted-fg: oklch(.45 .015 230);--ring: var(--primary-500);--destructive: oklch(.55 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.6 .19 155);--warning: oklch(.7 .17 70)}[data-theme=ocean].dark{--bg: oklch(.13 .005 230);--bg-secondary: oklch(.16 .008 230);--bg-tertiary: oklch(.19 .01 230);--bg-hover: oklch(.22 .012 230);--fg: oklch(.93 0 0);--fg-secondary: oklch(.65 .01 230);--fg-tertiary: oklch(.5 .01 230);--card: oklch(.17 .008 230);--card-fg: oklch(.93 0 0);--border-color: oklch(.26 .015 230);--border-light: oklch(.2 .01 230);--surface: oklch(.15 .006 230);--surface-raised: oklch(.19 .01 230);--muted: oklch(.2 .008 230);--muted-fg: oklch(.65 .01 230);--destructive: oklch(.65 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.7 .19 155);--warning: oklch(.75 .17 70)}[data-theme=forest]{--primary-50: oklch(.97 .014 155);--primary-100: oklch(.93 .03 155);--primary-200: oklch(.87 .06 155);--primary-300: oklch(.78 .1 155);--primary-400: oklch(.68 .15 155);--primary-500: oklch(.59 .2 155);--primary-600: oklch(.52 .19 155);--primary-700: oklch(.45 .16 155);--primary-800: oklch(.38 .13 155);--primary-900: oklch(.33 .1 155);--primary-950: oklch(.24 .07 155);--accent-50: oklch(.97 .014 90);--accent-100: oklch(.93 .03 90);--accent-200: oklch(.87 .06 90);--accent-300: oklch(.78 .1 90);--accent-400: oklch(.68 .15 90);--accent-500: oklch(.59 .2 90);--accent-600: oklch(.52 .19 90);--accent-700: oklch(.45 .16 90);--accent-800: oklch(.38 .13 90);--accent-900: oklch(.33 .1 90);--accent-950: oklch(.24 .07 90);--bg: oklch(.985 0 0);--bg-secondary: oklch(.96 .005 155);--bg-tertiary: oklch(.93 .008 155);--bg-hover: oklch(.9 .01 155);--fg: oklch(.145 0 0);--fg-secondary: oklch(.45 .015 155);--fg-tertiary: oklch(.55 .01 155);--card: oklch(1 0 0);--card-fg: oklch(.145 0 0);--border-color: oklch(.91 .008 155);--border-light: oklch(.94 .005 155);--surface: oklch(.98 .003 155);--surface-raised: oklch(.96 .005 155);--muted: oklch(.96 .005 155);--muted-fg: oklch(.45 .015 155);--ring: var(--primary-500);--destructive: oklch(.55 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.6 .19 155);--warning: oklch(.7 .17 70)}[data-theme=forest].dark{--bg: oklch(.13 .005 155);--bg-secondary: oklch(.16 .008 155);--bg-tertiary: oklch(.19 .01 155);--bg-hover: oklch(.22 .012 155);--fg: oklch(.93 0 0);--fg-secondary: oklch(.65 .01 155);--fg-tertiary: oklch(.5 .01 155);--card: oklch(.17 .008 155);--card-fg: oklch(.93 0 0);--border-color: oklch(.26 .015 155);--border-light: oklch(.2 .01 155);--surface: oklch(.15 .006 155);--surface-raised: oklch(.19 .01 155);--muted: oklch(.2 .008 155);--muted-fg: oklch(.65 .01 155);--destructive: oklch(.65 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.7 .19 155);--warning: oklch(.75 .17 70)}[data-theme=sunset]{--primary-50: oklch(.97 .014 35);--primary-100: oklch(.93 .03 35);--primary-200: oklch(.87 .06 35);--primary-300: oklch(.78 .1 35);--primary-400: oklch(.68 .15 35);--primary-500: oklch(.59 .2 35);--primary-600: oklch(.52 .19 35);--primary-700: oklch(.45 .16 35);--primary-800: oklch(.38 .13 35);--primary-900: oklch(.33 .1 35);--primary-950: oklch(.24 .07 35);--accent-50: oklch(.97 .014 0);--accent-100: oklch(.93 .03 0);--accent-200: oklch(.87 .06 0);--accent-300: oklch(.78 .1 0);--accent-400: oklch(.68 .15 0);--accent-500: oklch(.59 .2 0);--accent-600: oklch(.52 .19 0);--accent-700: oklch(.45 .16 0);--accent-800: oklch(.38 .13 0);--accent-900: oklch(.33 .1 0);--accent-950: oklch(.24 .07 0);--bg: oklch(.985 0 0);--bg-secondary: oklch(.96 .005 35);--bg-tertiary: oklch(.93 .008 35);--bg-hover: oklch(.9 .01 35);--fg: oklch(.145 0 0);--fg-secondary: oklch(.45 .015 35);--fg-tertiary: oklch(.55 .01 35);--card: oklch(1 0 0);--card-fg: oklch(.145 0 0);--border-color: oklch(.91 .008 35);--border-light: oklch(.94 .005 35);--surface: oklch(.98 .003 35);--surface-raised: oklch(.96 .005 35);--muted: oklch(.96 .005 35);--muted-fg: oklch(.45 .015 35);--ring: var(--primary-500);--destructive: oklch(.55 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.6 .19 155);--warning: oklch(.7 .17 70)}[data-theme=sunset].dark{--bg: oklch(.13 .005 35);--bg-secondary: oklch(.16 .008 35);--bg-tertiary: oklch(.19 .01 35);--bg-hover: oklch(.22 .012 35);--fg: oklch(.93 0 0);--fg-secondary: oklch(.65 .01 35);--fg-tertiary: oklch(.5 .01 35);--card: oklch(.17 .008 35);--card-fg: oklch(.93 0 0);--border-color: oklch(.26 .015 35);--border-light: oklch(.2 .01 35);--surface: oklch(.15 .006 35);--surface-raised: oklch(.19 .01 35);--muted: oklch(.2 .008 35);--muted-fg: oklch(.65 .01 35);--destructive: oklch(.65 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.7 .19 155);--warning: oklch(.75 .17 70)}[data-theme=rose]{--primary-50: oklch(.97 .014 350);--primary-100: oklch(.93 .03 350);--primary-200: oklch(.87 .06 350);--primary-300: oklch(.78 .1 350);--primary-400: oklch(.68 .15 350);--primary-500: oklch(.59 .2 350);--primary-600: oklch(.52 .19 350);--primary-700: oklch(.45 .16 350);--primary-800: oklch(.38 .13 350);--primary-900: oklch(.33 .1 350);--primary-950: oklch(.24 .07 350);--accent-50: oklch(.97 .014 300);--accent-100: oklch(.93 .03 300);--accent-200: oklch(.87 .06 300);--accent-300: oklch(.78 .1 300);--accent-400: oklch(.68 .15 300);--accent-500: oklch(.59 .2 300);--accent-600: oklch(.52 .19 300);--accent-700: oklch(.45 .16 300);--accent-800: oklch(.38 .13 300);--accent-900: oklch(.33 .1 300);--accent-950: oklch(.24 .07 300);--bg: oklch(.985 0 0);--bg-secondary: oklch(.96 .005 350);--bg-tertiary: oklch(.93 .008 350);--bg-hover: oklch(.9 .01 350);--fg: oklch(.145 0 0);--fg-secondary: oklch(.45 .015 350);--fg-tertiary: oklch(.55 .01 350);--card: oklch(1 0 0);--card-fg: oklch(.145 0 0);--border-color: oklch(.91 .008 350);--border-light: oklch(.94 .005 350);--surface: oklch(.98 .003 350);--surface-raised: oklch(.96 .005 350);--muted: oklch(.96 .005 350);--muted-fg: oklch(.45 .015 350);--ring: var(--primary-500);--destructive: oklch(.55 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.6 .19 155);--warning: oklch(.7 .17 70)}[data-theme=rose].dark{--bg: oklch(.13 .005 350);--bg-secondary: oklch(.16 .008 350);--bg-tertiary: oklch(.19 .01 350);--bg-hover: oklch(.22 .012 350);--fg: oklch(.93 0 0);--fg-secondary: oklch(.65 .01 350);--fg-tertiary: oklch(.5 .01 350);--card: oklch(.17 .008 350);--card-fg: oklch(.93 0 0);--border-color: oklch(.26 .015 350);--border-light: oklch(.2 .01 350);--surface: oklch(.15 .006 350);--surface-raised: oklch(.19 .01 350);--muted: oklch(.2 .008 350);--muted-fg: oklch(.65 .01 350);--destructive: oklch(.65 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.7 .19 155);--warning: oklch(.75 .17 70)}[data-theme=lavender]{--primary-50: oklch(.97 .014 290);--primary-100: oklch(.93 .03 290);--primary-200: oklch(.87 .06 290);--primary-300: oklch(.78 .1 290);--primary-400: oklch(.68 .15 290);--primary-500: oklch(.59 .2 290);--primary-600: oklch(.52 .19 290);--primary-700: oklch(.45 .16 290);--primary-800: oklch(.38 .13 290);--primary-900: oklch(.33 .1 290);--primary-950: oklch(.24 .07 290);--accent-50: oklch(.97 .014 330);--accent-100: oklch(.93 .03 330);--accent-200: oklch(.87 .06 330);--accent-300: oklch(.78 .1 330);--accent-400: oklch(.68 .15 330);--accent-500: oklch(.59 .2 330);--accent-600: oklch(.52 .19 330);--accent-700: oklch(.45 .16 330);--accent-800: oklch(.38 .13 330);--accent-900: oklch(.33 .1 330);--accent-950: oklch(.24 .07 330);--bg: oklch(.985 0 0);--bg-secondary: oklch(.96 .005 290);--bg-tertiary: oklch(.93 .008 290);--bg-hover: oklch(.9 .01 290);--fg: oklch(.145 0 0);--fg-secondary: oklch(.45 .015 290);--fg-tertiary: oklch(.55 .01 290);--card: oklch(1 0 0);--card-fg: oklch(.145 0 0);--border-color: oklch(.91 .008 290);--border-light: oklch(.94 .005 290);--surface: oklch(.98 .003 290);--surface-raised: oklch(.96 .005 290);--muted: oklch(.96 .005 290);--muted-fg: oklch(.45 .015 290);--ring: var(--primary-500);--destructive: oklch(.55 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.6 .19 155);--warning: oklch(.7 .17 70)}[data-theme=lavender].dark{--bg: oklch(.13 .005 290);--bg-secondary: oklch(.16 .008 290);--bg-tertiary: oklch(.19 .01 290);--bg-hover: oklch(.22 .012 290);--fg: oklch(.93 0 0);--fg-secondary: oklch(.65 .01 290);--fg-tertiary: oklch(.5 .01 290);--card: oklch(.17 .008 290);--card-fg: oklch(.93 0 0);--border-color: oklch(.26 .015 290);--border-light: oklch(.2 .01 290);--surface: oklch(.15 .006 290);--surface-raised: oklch(.19 .01 290);--muted: oklch(.2 .008 290);--muted-fg: oklch(.65 .01 290);--destructive: oklch(.65 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.7 .19 155);--warning: oklch(.75 .17 70)}[data-theme=slate]{--primary-50: oklch(.97 .014 230);--primary-100: oklch(.93 .03 230);--primary-200: oklch(.87 .06 230);--primary-300: oklch(.78 .1 230);--primary-400: oklch(.68 .15 230);--primary-500: oklch(.59 .2 230);--primary-600: oklch(.52 .19 230);--primary-700: oklch(.45 .16 230);--primary-800: oklch(.38 .13 230);--primary-900: oklch(.33 .1 230);--primary-950: oklch(.24 .07 230);--accent-50: oklch(.97 .014 210);--accent-100: oklch(.93 .03 210);--accent-200: oklch(.87 .06 210);--accent-300: oklch(.78 .1 210);--accent-400: oklch(.68 .15 210);--accent-500: oklch(.59 .2 210);--accent-600: oklch(.52 .19 210);--accent-700: oklch(.45 .16 210);--accent-800: oklch(.38 .13 210);--accent-900: oklch(.33 .1 210);--accent-950: oklch(.24 .07 210);--bg: oklch(.985 0 0);--bg-secondary: oklch(.96 .005 230);--bg-tertiary: oklch(.93 .008 230);--bg-hover: oklch(.9 .01 230);--fg: oklch(.145 0 0);--fg-secondary: oklch(.45 .015 230);--fg-tertiary: oklch(.55 .01 230);--card: oklch(1 0 0);--card-fg: oklch(.145 0 0);--border-color: oklch(.91 .008 230);--border-light: oklch(.94 .005 230);--surface: oklch(.98 .003 230);--surface-raised: oklch(.96 .005 230);--muted: oklch(.96 .005 230);--muted-fg: oklch(.45 .015 230);--ring: var(--primary-500);--destructive: oklch(.55 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.6 .19 155);--warning: oklch(.7 .17 70)}[data-theme=slate].dark{--bg: oklch(.13 .005 230);--bg-secondary: oklch(.16 .008 230);--bg-tertiary: oklch(.19 .01 230);--bg-hover: oklch(.22 .012 230);--fg: oklch(.93 0 0);--fg-secondary: oklch(.65 .01 230);--fg-tertiary: oklch(.5 .01 230);--card: oklch(.17 .008 230);--card-fg: oklch(.93 0 0);--border-color: oklch(.26 .015 230);--border-light: oklch(.2 .01 230);--surface: oklch(.15 .006 230);--surface-raised: oklch(.19 .01 230);--muted: oklch(.2 .008 230);--muted-fg: oklch(.65 .01 230);--destructive: oklch(.65 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.7 .19 155);--warning: oklch(.75 .17 70)}[data-theme=midnight]{--primary-50: oklch(.97 .014 265);--primary-100: oklch(.93 .03 265);--primary-200: oklch(.87 .06 265);--primary-300: oklch(.78 .1 265);--primary-400: oklch(.68 .15 265);--primary-500: oklch(.59 .2 265);--primary-600: oklch(.52 .19 265);--primary-700: oklch(.45 .16 265);--primary-800: oklch(.38 .13 265);--primary-900: oklch(.33 .1 265);--primary-950: oklch(.24 .07 265);--accent-50: oklch(.97 .014 220);--accent-100: oklch(.93 .03 220);--accent-200: oklch(.87 .06 220);--accent-300: oklch(.78 .1 220);--accent-400: oklch(.68 .15 220);--accent-500: oklch(.59 .2 220);--accent-600: oklch(.52 .19 220);--accent-700: oklch(.45 .16 220);--accent-800: oklch(.38 .13 220);--accent-900: oklch(.33 .1 220);--accent-950: oklch(.24 .07 220);--bg: oklch(.985 0 0);--bg-secondary: oklch(.96 .005 265);--bg-tertiary: oklch(.93 .008 265);--bg-hover: oklch(.9 .01 265);--fg: oklch(.145 0 0);--fg-secondary: oklch(.45 .015 265);--fg-tertiary: oklch(.55 .01 265);--card: oklch(1 0 0);--card-fg: oklch(.145 0 0);--border-color: oklch(.91 .008 265);--border-light: oklch(.94 .005 265);--surface: oklch(.98 .003 265);--surface-raised: oklch(.96 .005 265);--muted: oklch(.96 .005 265);--muted-fg: oklch(.45 .015 265);--ring: var(--primary-500);--destructive: oklch(.55 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.6 .19 155);--warning: oklch(.7 .17 70)}[data-theme=midnight].dark{--bg: oklch(.13 .005 265);--bg-secondary: oklch(.16 .008 265);--bg-tertiary: oklch(.19 .01 265);--bg-hover: oklch(.22 .012 265);--fg: oklch(.93 0 0);--fg-secondary: oklch(.65 .01 265);--fg-tertiary: oklch(.5 .01 265);--card: oklch(.17 .008 265);--card-fg: oklch(.93 0 0);--border-color: oklch(.26 .015 265);--border-light: oklch(.2 .01 265);--surface: oklch(.15 .006 265);--surface-raised: oklch(.19 .01 265);--muted: oklch(.2 .008 265);--muted-fg: oklch(.65 .01 265);--destructive: oklch(.65 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.7 .19 155);--warning: oklch(.75 .17 70)}[data-theme=sand]{--primary-50: oklch(.97 .014 70);--primary-100: oklch(.93 .03 70);--primary-200: oklch(.87 .06 70);--primary-300: oklch(.78 .1 70);--primary-400: oklch(.68 .15 70);--primary-500: oklch(.59 .2 70);--primary-600: oklch(.52 .19 70);--primary-700: oklch(.45 .16 70);--primary-800: oklch(.38 .13 70);--primary-900: oklch(.33 .1 70);--primary-950: oklch(.24 .07 70);--accent-50: oklch(.97 .014 40);--accent-100: oklch(.93 .03 40);--accent-200: oklch(.87 .06 40);--accent-300: oklch(.78 .1 40);--accent-400: oklch(.68 .15 40);--accent-500: oklch(.59 .2 40);--accent-600: oklch(.52 .19 40);--accent-700: oklch(.45 .16 40);--accent-800: oklch(.38 .13 40);--accent-900: oklch(.33 .1 40);--accent-950: oklch(.24 .07 40);--bg: oklch(.985 0 0);--bg-secondary: oklch(.96 .005 70);--bg-tertiary: oklch(.93 .008 70);--bg-hover: oklch(.9 .01 70);--fg: oklch(.145 0 0);--fg-secondary: oklch(.45 .015 70);--fg-tertiary: oklch(.55 .01 70);--card: oklch(1 0 0);--card-fg: oklch(.145 0 0);--border-color: oklch(.91 .008 70);--border-light: oklch(.94 .005 70);--surface: oklch(.98 .003 70);--surface-raised: oklch(.96 .005 70);--muted: oklch(.96 .005 70);--muted-fg: oklch(.45 .015 70);--ring: var(--primary-500);--destructive: oklch(.55 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.6 .19 155);--warning: oklch(.7 .17 70)}[data-theme=sand].dark{--bg: oklch(.13 .005 70);--bg-secondary: oklch(.16 .008 70);--bg-tertiary: oklch(.19 .01 70);--bg-hover: oklch(.22 .012 70);--fg: oklch(.93 0 0);--fg-secondary: oklch(.65 .01 70);--fg-tertiary: oklch(.5 .01 70);--card: oklch(.17 .008 70);--card-fg: oklch(.93 0 0);--border-color: oklch(.26 .015 70);--border-light: oklch(.2 .01 70);--surface: oklch(.15 .006 70);--surface-raised: oklch(.19 .01 70);--muted: oklch(.2 .008 70);--muted-fg: oklch(.65 .01 70);--destructive: oklch(.65 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.7 .19 155);--warning: oklch(.75 .17 70)}[data-theme=linear]{--primary-50: oklch(.97 .014 270);--primary-100: oklch(.93 .03 270);--primary-200: oklch(.87 .06 270);--primary-300: oklch(.78 .1 270);--primary-400: oklch(.68 .15 270);--primary-500: oklch(.59 .2 270);--primary-600: oklch(.52 .19 270);--primary-700: oklch(.45 .16 270);--primary-800: oklch(.38 .13 270);--primary-900: oklch(.33 .1 270);--primary-950: oklch(.24 .07 270);--accent-50: oklch(.97 .014 300);--accent-100: oklch(.93 .03 300);--accent-200: oklch(.87 .06 300);--accent-300: oklch(.78 .1 300);--accent-400: oklch(.68 .15 300);--accent-500: oklch(.59 .2 300);--accent-600: oklch(.52 .19 300);--accent-700: oklch(.45 .16 300);--accent-800: oklch(.38 .13 300);--accent-900: oklch(.33 .1 300);--accent-950: oklch(.24 .07 300);--bg: oklch(.985 0 0);--bg-secondary: oklch(.96 .005 270);--bg-tertiary: oklch(.93 .008 270);--bg-hover: oklch(.9 .01 270);--fg: oklch(.145 0 0);--fg-secondary: oklch(.45 .015 270);--fg-tertiary: oklch(.55 .01 270);--card: oklch(1 0 0);--card-fg: oklch(.145 0 0);--border-color: oklch(.91 .008 270);--border-light: oklch(.94 .005 270);--surface: oklch(.98 .003 270);--surface-raised: oklch(.96 .005 270);--muted: oklch(.96 .005 270);--muted-fg: oklch(.45 .015 270);--ring: var(--primary-500);--destructive: oklch(.55 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.6 .19 155);--warning: oklch(.7 .17 70)}[data-theme=linear].dark{--bg: oklch(.13 .005 270);--bg-secondary: oklch(.16 .008 270);--bg-tertiary: oklch(.19 .01 270);--bg-hover: oklch(.22 .012 270);--fg: oklch(.93 0 0);--fg-secondary: oklch(.65 .01 270);--fg-tertiary: oklch(.5 .01 270);--card: oklch(.17 .008 270);--card-fg: oklch(.93 0 0);--border-color: oklch(.26 .015 270);--border-light: oklch(.2 .01 270);--surface: oklch(.15 .006 270);--surface-raised: oklch(.19 .01 270);--muted: oklch(.2 .008 270);--muted-fg: oklch(.65 .01 270);--destructive: oklch(.65 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.7 .19 155);--warning: oklch(.75 .17 70)}[data-theme=notion]{--primary-50: oklch(.97 .014 50);--primary-100: oklch(.93 .03 50);--primary-200: oklch(.87 .06 50);--primary-300: oklch(.78 .1 50);--primary-400: oklch(.68 .15 50);--primary-500: oklch(.59 .2 50);--primary-600: oklch(.52 .19 50);--primary-700: oklch(.45 .16 50);--primary-800: oklch(.38 .13 50);--primary-900: oklch(.33 .1 50);--primary-950: oklch(.24 .07 50);--accent-50: oklch(.97 .014 225);--accent-100: oklch(.93 .03 225);--accent-200: oklch(.87 .06 225);--accent-300: oklch(.78 .1 225);--accent-400: oklch(.68 .15 225);--accent-500: oklch(.59 .2 225);--accent-600: oklch(.52 .19 225);--accent-700: oklch(.45 .16 225);--accent-800: oklch(.38 .13 225);--accent-900: oklch(.33 .1 225);--accent-950: oklch(.24 .07 225);--bg: oklch(.985 0 0);--bg-secondary: oklch(.96 .005 50);--bg-tertiary: oklch(.93 .008 50);--bg-hover: oklch(.9 .01 50);--fg: oklch(.145 0 0);--fg-secondary: oklch(.45 .015 50);--fg-tertiary: oklch(.55 .01 50);--card: oklch(1 0 0);--card-fg: oklch(.145 0 0);--border-color: oklch(.91 .008 50);--border-light: oklch(.94 .005 50);--surface: oklch(.98 .003 50);--surface-raised: oklch(.96 .005 50);--muted: oklch(.96 .005 50);--muted-fg: oklch(.45 .015 50);--ring: var(--primary-500);--destructive: oklch(.55 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.6 .19 155);--warning: oklch(.7 .17 70)}[data-theme=notion].dark{--bg: oklch(.13 .005 50);--bg-secondary: oklch(.16 .008 50);--bg-tertiary: oklch(.19 .01 50);--bg-hover: oklch(.22 .012 50);--fg: oklch(.93 0 0);--fg-secondary: oklch(.65 .01 50);--fg-tertiary: oklch(.5 .01 50);--card: oklch(.17 .008 50);--card-fg: oklch(.93 0 0);--border-color: oklch(.26 .015 50);--border-light: oklch(.2 .01 50);--surface: oklch(.15 .006 50);--surface-raised: oklch(.19 .01 50);--muted: oklch(.2 .008 50);--muted-fg: oklch(.65 .01 50);--destructive: oklch(.65 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.7 .19 155);--warning: oklch(.75 .17 70)}[data-theme=aubergine]{--primary-50: oklch(.97 .014 320);--primary-100: oklch(.93 .03 320);--primary-200: oklch(.87 .06 320);--primary-300: oklch(.78 .1 320);--primary-400: oklch(.68 .15 320);--primary-500: oklch(.59 .2 320);--primary-600: oklch(.52 .19 320);--primary-700: oklch(.45 .16 320);--primary-800: oklch(.38 .13 320);--primary-900: oklch(.33 .1 320);--primary-950: oklch(.24 .07 320);--accent-50: oklch(.97 .014 280);--accent-100: oklch(.93 .03 280);--accent-200: oklch(.87 .06 280);--accent-300: oklch(.78 .1 280);--accent-400: oklch(.68 .15 280);--accent-500: oklch(.59 .2 280);--accent-600: oklch(.52 .19 280);--accent-700: oklch(.45 .16 280);--accent-800: oklch(.38 .13 280);--accent-900: oklch(.33 .1 280);--accent-950: oklch(.24 .07 280);--bg: oklch(.985 0 0);--bg-secondary: oklch(.96 .005 320);--bg-tertiary: oklch(.93 .008 320);--bg-hover: oklch(.9 .01 320);--fg: oklch(.145 0 0);--fg-secondary: oklch(.45 .015 320);--fg-tertiary: oklch(.55 .01 320);--card: oklch(1 0 0);--card-fg: oklch(.145 0 0);--border-color: oklch(.91 .008 320);--border-light: oklch(.94 .005 320);--surface: oklch(.98 .003 320);--surface-raised: oklch(.96 .005 320);--muted: oklch(.96 .005 320);--muted-fg: oklch(.45 .015 320);--ring: var(--primary-500);--destructive: oklch(.55 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.6 .19 155);--warning: oklch(.7 .17 70)}[data-theme=aubergine].dark{--bg: oklch(.13 .005 320);--bg-secondary: oklch(.16 .008 320);--bg-tertiary: oklch(.19 .01 320);--bg-hover: oklch(.22 .012 320);--fg: oklch(.93 0 0);--fg-secondary: oklch(.65 .01 320);--fg-tertiary: oklch(.5 .01 320);--card: oklch(.17 .008 320);--card-fg: oklch(.93 0 0);--border-color: oklch(.26 .015 320);--border-light: oklch(.2 .01 320);--surface: oklch(.15 .006 320);--surface-raised: oklch(.19 .01 320);--muted: oklch(.2 .008 320);--muted-fg: oklch(.65 .01 320);--destructive: oklch(.65 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.7 .19 155);--warning: oklch(.75 .17 70)}[data-theme=mono]{--primary-50: oklch(.97 0 0);--primary-100: oklch(.93 0 0);--primary-200: oklch(.87 0 0);--primary-300: oklch(.78 0 0);--primary-400: oklch(.68 0 0);--primary-500: oklch(.59 0 0);--primary-600: oklch(.52 0 0);--primary-700: oklch(.45 0 0);--primary-800: oklch(.38 0 0);--primary-900: oklch(.33 0 0);--primary-950: oklch(.24 0 0);--accent-50: oklch(.97 0 0);--accent-100: oklch(.93 0 0);--accent-200: oklch(.87 0 0);--accent-300: oklch(.78 0 0);--accent-400: oklch(.68 0 0);--accent-500: oklch(.59 0 0);--accent-600: oklch(.52 0 0);--accent-700: oklch(.45 0 0);--accent-800: oklch(.38 0 0);--accent-900: oklch(.33 0 0);--accent-950: oklch(.24 0 0);--bg: oklch(.985 0 0);--bg-secondary: oklch(.96 0 0);--bg-tertiary: oklch(.93 0 0);--bg-hover: oklch(.9 0 0);--fg: oklch(.145 0 0);--fg-secondary: oklch(.45 0 0);--fg-tertiary: oklch(.55 0 0);--card: oklch(1 0 0);--card-fg: oklch(.145 0 0);--border-color: oklch(.91 0 0);--border-light: oklch(.94 0 0);--surface: oklch(.98 0 0);--surface-raised: oklch(.96 0 0);--muted: oklch(.96 0 0);--muted-fg: oklch(.45 0 0);--ring: var(--primary-500);--destructive: oklch(.55 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.6 .19 155);--warning: oklch(.7 .17 70)}[data-theme=mono].dark{--bg: oklch(.13 0 0);--bg-secondary: oklch(.16 0 0);--bg-tertiary: oklch(.19 0 0);--bg-hover: oklch(.22 0 0);--fg: oklch(.93 0 0);--fg-secondary: oklch(.65 0 0);--fg-tertiary: oklch(.5 0 0);--card: oklch(.17 0 0);--card-fg: oklch(.93 0 0);--border-color: oklch(.26 0 0);--border-light: oklch(.2 0 0);--surface: oklch(.15 0 0);--surface-raised: oklch(.19 0 0);--muted: oklch(.2 0 0);--muted-fg: oklch(.65 0 0);--destructive: oklch(.65 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.7 .19 155);--warning: oklch(.75 .17 70)}[data-theme=emerald]{--primary-50: oklch(.97 .014 165);--primary-100: oklch(.93 .03 165);--primary-200: oklch(.87 .06 165);--primary-300: oklch(.78 .1 165);--primary-400: oklch(.68 .15 165);--primary-500: oklch(.59 .2 165);--primary-600: oklch(.52 .19 165);--primary-700: oklch(.45 .16 165);--primary-800: oklch(.38 .13 165);--primary-900: oklch(.33 .1 165);--primary-950: oklch(.24 .07 165);--accent-50: oklch(.97 .014 110);--accent-100: oklch(.93 .03 110);--accent-200: oklch(.87 .06 110);--accent-300: oklch(.78 .1 110);--accent-400: oklch(.68 .15 110);--accent-500: oklch(.59 .2 110);--accent-600: oklch(.52 .19 110);--accent-700: oklch(.45 .16 110);--accent-800: oklch(.38 .13 110);--accent-900: oklch(.33 .1 110);--accent-950: oklch(.24 .07 110);--bg: oklch(.985 0 0);--bg-secondary: oklch(.96 .005 165);--bg-tertiary: oklch(.93 .008 165);--bg-hover: oklch(.9 .01 165);--fg: oklch(.145 0 0);--fg-secondary: oklch(.45 .015 165);--fg-tertiary: oklch(.55 .01 165);--card: oklch(1 0 0);--card-fg: oklch(.145 0 0);--border-color: oklch(.91 .008 165);--border-light: oklch(.94 .005 165);--surface: oklch(.98 .003 165);--surface-raised: oklch(.96 .005 165);--muted: oklch(.96 .005 165);--muted-fg: oklch(.45 .015 165);--ring: var(--primary-500);--destructive: oklch(.55 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.6 .19 155);--warning: oklch(.7 .17 70)}[data-theme=emerald].dark{--bg: oklch(.13 .005 165);--bg-secondary: oklch(.16 .008 165);--bg-tertiary: oklch(.19 .01 165);--bg-hover: oklch(.22 .012 165);--fg: oklch(.93 0 0);--fg-secondary: oklch(.65 .01 165);--fg-tertiary: oklch(.5 .01 165);--card: oklch(.17 .008 165);--card-fg: oklch(.93 0 0);--border-color: oklch(.26 .015 165);--border-light: oklch(.2 .01 165);--surface: oklch(.15 .006 165);--surface-raised: oklch(.19 .01 165);--muted: oklch(.2 .008 165);--muted-fg: oklch(.65 .01 165);--destructive: oklch(.65 .22 27);--destructive-fg: oklch(.98 0 0);--success: oklch(.7 .19 155);--warning: oklch(.75 .17 70)}:root{--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--header-height: 64px;--input-height: 64px;--sidebar-width: 380px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background-color:var(--bg);color:var(--fg);line-height:1.5;min-height:100vh;min-height:100dvh;overflow:hidden}#root{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}a{color:var(--primary-500);text-decoration:none}a:hover{color:var(--primary-400)}button{cursor:pointer;font-family:inherit;border:none;background:none;font-size:inherit;color:inherit}input,textarea{font-family:inherit;font-size:inherit;color:inherit;background:none;border:none;outline:none}ul,ol{list-style:none}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--fg-tertiary)}.app{display:flex;flex-direction:column;height:100vh;height:100dvh}.app-content{flex:1;display:flex;overflow:hidden}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:24px;background:var(--bg)}.auth-card{background:var(--surface);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:48px 40px;width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.auth-logo{text-align:center;margin-bottom:8px}.auth-logo h1{font-size:28px;font-weight:700;color:var(--fg);letter-spacing:-.5px}.auth-logo .logo-accent{color:var(--primary-500)}.auth-tagline{text-align:center;color:var(--fg-secondary);font-size:14px;margin-bottom:40px}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-size:13px;font-weight:500;color:var(--fg-secondary);text-transform:uppercase;letter-spacing:.5px}.form-input{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:14px 16px;font-size:16px;color:var(--fg);transition:border-color .2s,box-shadow .2s;-webkit-appearance:none}.form-input:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-200)}.form-input::placeholder{color:var(--fg-tertiary)}.form-input-otp{text-align:center;font-size:24px;letter-spacing:8px;font-weight:600}.form-hint{font-size:12px;color:var(--fg-tertiary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border-radius:var(--radius-md);font-size:15px;font-weight:600;transition:all .2s;white-space:nowrap}.btn-primary{background:var(--primary-500);color:#fff}.btn-primary:hover{background:var(--primary-400);box-shadow:0 4px 16px var(--primary-300)}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.btn-secondary{background:var(--bg-tertiary);color:var(--fg);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-hover)}.btn-danger{background:var(--destructive);color:#fff}.btn-danger:hover{background:#ff6b7a}.btn-ghost{color:var(--fg-secondary);padding:8px 12px}.btn-ghost:hover{color:var(--fg);background:var(--bg-hover);border-radius:var(--radius-sm)}.btn-full{width:100%}.btn-sm{padding:8px 16px;font-size:13px}.spinner{width:20px;height:20px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-text{color:var(--destructive);font-size:13px;text-align:center}.success-text{color:var(--success);font-size:13px;text-align:center}.chat-layout{display:flex;height:100vh;height:100dvh;width:100%}.sidebar{width:var(--sidebar-width);max-width:100%;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 20px;border-bottom:1px solid var(--border-color);flex-shrink:0}.sidebar-title{font-size:20px;font-weight:700;letter-spacing:-.3px}.sidebar-actions{display:flex;align-items:center;gap:8px}.icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--fg-secondary);transition:all .15s;font-size:18px}.icon-btn:hover{background:var(--bg-hover);color:var(--fg)}.sidebar-search{padding:12px 16px;border-bottom:1px solid var(--border-light)}.search-input-wrapper{position:relative}.search-input{width:100%;background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius-full);padding:10px 16px 10px 40px;font-size:14px;color:var(--fg);transition:border-color .2s}.search-input:focus{border-color:var(--primary-500)}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--fg-tertiary);font-size:14px}.conversation-list{flex:1;overflow-y:auto;overflow-x:hidden}.conversation-item{display:flex;align-items:center;gap:12px;padding:14px 20px;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--border-light)}.conversation-item:hover{background:var(--bg-hover)}.conversation-item.active{background:var(--bg-hover);border-left:3px solid var(--primary-500);padding-left:17px}.conversation-avatar{width:48px;height:48px;border-radius:50%;background:var(--primary-200);color:var(--primary-500);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;flex-shrink:0;text-transform:uppercase}.conversation-info{flex:1;min-width:0}.conversation-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.conversation-name{font-size:15px;font-weight:600;color:var(--fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversation-time{font-size:12px;color:var(--fg-tertiary);flex-shrink:0;margin-left:8px}.conversation-preview{font-size:13px;color:var(--fg-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:4px}.unread-badge{background:var(--primary-500);color:#fff;font-size:11px;font-weight:700;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 6px;flex-shrink:0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;padding:48px;text-align:center;color:var(--fg-tertiary)}.empty-icon{font-size:64px;margin-bottom:16px;opacity:.3}.empty-title{font-size:18px;font-weight:600;color:var(--fg-secondary);margin-bottom:8px}.empty-desc{font-size:14px;max-width:280px;line-height:1.6}.chat-panel{flex:1;display:flex;flex-direction:column;background:var(--bg);min-width:0}.chat-header{height:var(--header-height);display:flex;align-items:center;gap:12px;padding:0 20px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.chat-header-back{display:none;width:36px;height:36px;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--fg-secondary);font-size:20px;margin-right:4px}.chat-header-info{flex:1;min-width:0}.chat-header-name{font-size:16px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-header-status{font-size:12px;color:var(--fg-tertiary);display:flex;align-items:center;gap:4px}.encryption-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:2px 8px;border-radius:var(--radius-full);font-weight:500}.encryption-badge.secure{background:#e0f5e6;color:var(--success)}.encryption-badge.insecure{background:oklch(.95 .03 27);color:var(--destructive)}.lock-icon{font-size:10px}.messages-area{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:4px}.message-group{display:flex;flex-direction:column;gap:2px}.message-row{display:flex;align-items:flex-end;gap:8px}.message-row.outgoing{flex-direction:row-reverse}.message-bubble{max-width:70%;padding:10px 14px;border-radius:var(--radius-lg);font-size:14px;line-height:1.45;word-wrap:break-word;position:relative}.message-bubble.outgoing{background:var(--primary-500);color:#fff;border-bottom-right-radius:4px}.message-bubble.incoming{background:var(--surface-raised);color:var(--fg);border-bottom-left-radius:4px}.message-meta{display:flex;align-items:center;justify-content:flex-end;gap:4px;margin-top:4px}.message-time{font-size:11px;opacity:.65}.message-status{font-size:12px;opacity:.65}.message-encryption{font-size:10px;opacity:.5}.message-date-divider{text-align:center;padding:16px 0 8px}.message-date-divider span{background:var(--surface-raised);color:var(--fg-tertiary);font-size:12px;font-weight:500;padding:4px 12px;border-radius:var(--radius-full)}.message-input-area{padding:12px 16px;border-top:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.message-input-wrapper{display:flex;align-items:flex-end;gap:8px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:8px 12px;transition:border-color .2s}.message-input-wrapper:focus-within{border-color:var(--primary-500)}.message-textarea{flex:1;resize:none;min-height:24px;max-height:120px;padding:4px 0;font-size:14px;line-height:1.4;color:var(--fg);background:transparent}.message-textarea::placeholder{color:var(--fg-tertiary)}.send-btn{width:36px;height:36px;border-radius:50%;background:var(--primary-500);color:#fff;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0;font-size:16px}.send-btn:hover{background:var(--primary-400);transform:scale(1.05)}.send-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;padding:24px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.modal{background:var(--surface);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:32px;width:100%;max-width:400px;box-shadow:var(--shadow-lg)}.modal-title{font-size:18px;font-weight:700;margin-bottom:8px}.modal-desc{font-size:13px;color:var(--fg-secondary);margin-bottom:24px}.modal-actions{display:flex;gap:12px;margin-top:24px}.modal-actions .btn{flex:1}.user-info{padding:16px 20px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;gap:12px}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary-500),#9b59b6);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;text-transform:uppercase}.user-details{flex:1;min-width:0}.user-name{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-id{font-size:11px;color:var(--fg-tertiary);font-family:monospace}.key-gen{text-align:center;padding:40px 0}.key-gen-icon{font-size:48px;margin-bottom:16px;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}.key-gen-text{color:var(--fg-secondary);font-size:14px}.key-gen-status{color:var(--primary-500);font-size:13px;margin-top:8px;font-weight:500}.steps{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:32px}.step-dot{width:8px;height:8px;border-radius:50%;background:var(--border-color);transition:all .3s}.step-dot.active{background:var(--primary-500);width:24px;border-radius:4px}.step-dot.completed{background:var(--success)}@media(max-width:768px){.sidebar{width:100%}.chat-layout.chat-open .sidebar{display:none}.chat-layout:not(.chat-open) .chat-panel{display:none}.chat-header-back{display:flex}.message-bubble{max-width:85%}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .2s ease-out}@keyframes slideInLeft{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.message-row.incoming .message-bubble{animation:slideInLeft .15s ease-out}.message-row.outgoing .message-bubble{animation:slideInRight .15s ease-out}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.text-center{text-align:center}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.theme-picker-title{font-size:13px;font-weight:600;color:var(--fg-secondary);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.theme-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.theme-swatch{display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 8px;border-radius:var(--radius-md);border:2px solid transparent;background:var(--surface);cursor:pointer;transition:all .15s}.theme-swatch:hover{background:var(--bg-hover)}.theme-swatch.active{border-color:var(--primary-500);background:var(--primary-200)}.swatch-colors{display:flex;gap:4px}.swatch-primary,.swatch-accent{width:20px;height:20px;border-radius:50%;border:1px solid var(--border-color)}.swatch-name{font-size:11px;color:var(--fg-secondary);white-space:nowrap}.mode-toggle{display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:var(--radius-md);background:var(--surface);color:var(--fg);font-size:13px;cursor:pointer;transition:all .15s;border:1px solid var(--border-color)}.mode-toggle:hover{background:var(--bg-hover)}.mode-label{font-weight:500}.emoji-picker{position:absolute;bottom:100%;left:0;width:320px;max-height:360px;background:var(--surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden;z-index:50}.emoji-search{padding:8px;border-bottom:1px solid var(--border-light)}.emoji-categories{display:flex;gap:2px;padding:4px 8px;border-bottom:1px solid var(--border-light);overflow-x:auto}.emoji-cat-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:18px;border-radius:var(--radius-sm);cursor:pointer;flex-shrink:0}.emoji-cat-btn:hover{background:var(--bg-hover)}.emoji-cat-btn.active{background:var(--primary-200)}.emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:2px;padding:8px;overflow-y:auto;flex:1}.emoji-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:22px;border-radius:var(--radius-sm);cursor:pointer}.emoji-btn:hover{background:var(--bg-hover)}.message-actions-overlay{position:fixed;inset:0;z-index:60}.message-actions-menu{position:fixed;z-index:61;background:var(--surface);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:140px;padding:4px}.message-action-item{display:block;width:100%;text-align:left;padding:10px 16px;font-size:14px;color:var(--fg);border-radius:var(--radius-sm);cursor:pointer}.message-action-item:hover{background:var(--bg-hover)}.message-action-item.destructive{color:var(--destructive)}.message-action-item.destructive:hover{background:oklch(.95 .03 27)}.typing-indicator{display:flex;align-items:center;padding:4px 16px 8px;font-size:13px;color:var(--fg-secondary)}.typing-name{font-weight:600;color:var(--primary-500)}.typing-text{margin-right:2px}.typing-dots{display:inline-flex;gap:3px;margin-left:4px}.typing-dot{width:4px;height:4px;border-radius:50%;background:var(--fg-tertiary);animation:typingBounce 1.4s infinite}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-4px)}}.online-dot{position:absolute;bottom:0;right:0;width:12px;height:12px;border-radius:50%;background:var(--success);border:2px solid var(--bg-secondary)}.msg-status{font-size:14px;margin-left:4px}.msg-status.sent,.msg-status.delivered{color:var(--fg-tertiary)}.msg-status.read{color:var(--primary-400)}
