*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}html{-moz-text-size-adjust:none;-webkit-text-size-adjust:none;text-size-adjust:none}html{font-size:16px;scroll-behavior:smooth}body{min-height:100vh;line-height:var(--leading-normal, 1.5);font-family:var(--font-sans, system-ui, sans-serif);font-size:var(--text-base, 1rem);color:var(--color-text, #1c2024);background-color:var(--color-background, #fcfcfd);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}ul,ol{list-style:none}a:not([class]){text-decoration-skip-ink:auto;color:var(--color-primary, #0090ff)}img,picture,video,canvas{display:block;max-width:100%;height:auto}svg{max-width:100%;flex-shrink:0}svg[width][height]{min-width:1em;min-height:1em}input,button,textarea,select{font:inherit;color:inherit}button{cursor:pointer;background:none;border:none}textarea{resize:vertical}table{border-collapse:collapse;border-spacing:0}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}#root{isolation:isolate;min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:var(--font-semibold, 600);line-height:var(--leading-tight, 1.25);color:var(--color-text, #1c2024)}h1{font-size:var(--text-3xl, 1.875rem)}h2{font-size:var(--text-2xl, 1.5rem)}h3{font-size:var(--text-xl, 1.25rem)}h4{font-size:var(--text-lg, 1.125rem)}h5,h6{font-size:var(--text-base, 1rem)}p{color:var(--color-text-secondary, #60646c)}small{font-size:var(--text-sm, .875rem);color:var(--color-text-muted, #8b8d98)}strong{font-weight:var(--font-semibold, 600)}code{font-family:var(--font-mono, monospace);font-size:.9em;background:var(--color-surface, white);padding:.1em .3em;border-radius:var(--radius-sm, .25rem)}:focus{outline:none}:focus-visible{outline:2px solid var(--color-focus, #5eb1ef);outline-offset:2px}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{box-shadow:var(--focus-ring, 0 0 0 2px white, 0 0 0 4px #5eb1ef)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}::selection{background-color:var(--color-primary-subtle, #e6f4fe);color:var(--color-primary-text, #0d74ce)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-background, #fcfcfd)}::-webkit-scrollbar-thumb{background:var(--slate-7, #cdced6);border-radius:var(--radius-full, 9999px)}::-webkit-scrollbar-thumb:hover{background:var(--slate-8, #b9bbc6)}:root{color-scheme:light dark;--blue-1: #fbfdff;--blue-2: #f4faff;--blue-3: #e6f4fe;--blue-4: #d5efff;--blue-5: #c2e5ff;--blue-6: #acd8fc;--blue-7: #8ec8f6;--blue-8: #5eb1ef;--blue-9: #0090ff;--blue-10: #0588f0;--blue-11: #0d74ce;--blue-12: #113264;--orange-1: #fefcfb;--orange-2: #fff7ed;--orange-3: #ffefd6;--orange-4: #ffdfb5;--orange-5: #ffd19a;--orange-6: #ffc182;--orange-7: #f5ae73;--orange-8: #ec9455;--orange-9: #f76b15;--orange-10: #ef5f00;--orange-11: #cc4e00;--orange-12: #582d1d;--violet-1: #fdfcfe;--violet-2: #faf8ff;--violet-3: #f4f0fe;--violet-4: #ebe4ff;--violet-5: #e1d9ff;--violet-6: #d4cafe;--violet-7: #c2b5f5;--violet-8: #aa99ec;--violet-9: #6e56cf;--violet-10: #654dc4;--violet-11: #6550b9;--violet-12: #2f265f;--cyan-1: #fafdfe;--cyan-2: #f2fafb;--cyan-3: #def7f9;--cyan-4: #caf1f6;--cyan-5: #b5e9f0;--cyan-6: #9ddde7;--cyan-7: #7dcedc;--cyan-8: #3db9cf;--cyan-9: #00a2c7;--cyan-10: #0797b9;--cyan-11: #107d98;--cyan-12: #0d3c48;--pink-1: #fffcfe;--pink-2: #fef7fb;--pink-3: #fee9f5;--pink-4: #fbdcef;--pink-5: #f6cee7;--pink-6: #efbfdd;--pink-7: #e7acd0;--pink-8: #dd93c2;--pink-9: #d6409f;--pink-10: #cf3897;--pink-11: #c2298a;--pink-12: #651249;--bronze-1: #fdfcfc;--bronze-2: #fdf7f5;--bronze-3: #f6edea;--bronze-4: #efe4df;--bronze-5: #e7d9d3;--bronze-6: #dfcdc5;--bronze-7: #d3bcb3;--bronze-8: #c2a499;--bronze-9: #a18072;--bronze-10: #957468;--bronze-11: #7d5e54;--bronze-12: #43302b;--gold-1: #fdfdfc;--gold-2: #faf9f2;--gold-3: #f2f0e7;--gold-4: #eae6db;--gold-5: #e1dccf;--gold-6: #d8d0bf;--gold-7: #cbc0aa;--gold-8: #b9a88d;--gold-9: #978365;--gold-10: #8c7a5e;--gold-11: #71624b;--gold-12: #3b352b;--sky-1: #f9feff;--sky-2: #f1fafd;--sky-3: #e1f6fd;--sky-4: #d1f0fa;--sky-5: #bee7f5;--sky-6: #a9daed;--sky-7: #8dcae3;--sky-8: #60b3d7;--sky-9: #7ce2fe;--sky-10: #74daf8;--sky-11: #00749e;--sky-12: #1d3e56;--mint-1: #f9fefd;--mint-2: #f2fbf9;--mint-3: #ddf9f2;--mint-4: #c8f4e9;--mint-5: #b3ecde;--mint-6: #9ce0d0;--mint-7: #7ecfbd;--mint-8: #4cbba5;--mint-9: #86ead4;--mint-10: #7de0cb;--mint-11: #027864;--mint-12: #16433c;--lime-1: #fcfdfa;--lime-2: #f8faf3;--lime-3: #eef6d6;--lime-4: #e2f0bd;--lime-5: #d3e7a6;--lime-6: #c2da91;--lime-7: #abc978;--lime-8: #8db654;--lime-9: #bdee63;--lime-10: #b0e64c;--lime-11: #5c7c2f;--lime-12: #37401c;--amber-1: #fefdfb;--amber-2: #fefbe9;--amber-3: #fff7c2;--amber-4: #ffee9c;--amber-5: #fbe577;--amber-6: #f3d673;--amber-7: #e9c162;--amber-8: #e2a336;--amber-9: #ffc53d;--amber-10: #ffba18;--amber-11: #ab6400;--amber-12: #4f3422;--red-1: #fffcfc;--red-2: #fff7f7;--red-3: #feebec;--red-4: #ffdbdc;--red-5: #ffcdce;--red-6: #fdbdbe;--red-7: #f4a9aa;--red-8: #eb8e90;--red-9: #e5484d;--red-10: #dc3e42;--red-11: #ce2c31;--red-12: #641723;--yellow-1: #fdfdf9;--yellow-2: #fefce9;--yellow-3: #fffab8;--yellow-4: #fff394;--yellow-5: #ffe770;--yellow-6: #f3d768;--yellow-7: #e4c767;--yellow-8: #d5ae39;--yellow-9: #ffe629;--yellow-10: #ffdc00;--yellow-11: #9e6c00;--yellow-12: #473b1f;--green-1: #fbfefc;--green-2: #f4fbf6;--green-3: #e6f6eb;--green-4: #d6f1df;--green-5: #c4e8d1;--green-6: #adddc0;--green-7: #8eceaa;--green-8: #5bb98b;--green-9: #30a46c;--green-10: #2b9a66;--green-11: #218358;--green-12: #193b2d;--slate-1: #fcfcfd;--slate-2: #f9f9fb;--slate-3: #f0f0f3;--slate-4: #e8e8ec;--slate-5: #e0e1e6;--slate-6: #d9d9e0;--slate-7: #cdced6;--slate-8: #b9bbc6;--slate-9: #8b8d98;--slate-10: #80838d;--slate-11: #60646c;--slate-12: #1c2024;--gray-1: #fcfcfc;--gray-2: #f9f9f9;--gray-3: #f0f0f0;--gray-4: #e8e8e8;--gray-5: #e0e0e0;--gray-6: #d9d9d9;--gray-7: #cecece;--gray-8: #bbbbbb;--gray-9: #8d8d8d;--gray-10: #838383;--gray-11: #646464;--gray-12: #202020;--mauve-1: #fdfcfd;--mauve-2: #faf9fb;--mauve-3: #f2eff3;--mauve-4: #eae7ec;--mauve-5: #e3dfe6;--mauve-6: #dbd8e0;--mauve-7: #d0cdd7;--mauve-8: #bcbac7;--mauve-9: #8e8c99;--mauve-10: #84828e;--mauve-11: #65636d;--mauve-12: #211f26;--sage-1: #fbfdfc;--sage-2: #f7f9f8;--sage-3: #eef1f0;--sage-4: #e6e9e8;--sage-5: #dfe2e0;--sage-6: #d7dad9;--sage-7: #cbcfcd;--sage-8: #b8bcba;--sage-9: #868e8b;--sage-10: #7c8481;--sage-11: #5f6563;--sage-12: #1a211e;--olive-1: #fcfdfc;--olive-2: #f8faf8;--olive-3: #eff1ef;--olive-4: #e7e9e7;--olive-5: #dfe2df;--olive-6: #d7dad7;--olive-7: #cccfcc;--olive-8: #b9bcb8;--olive-9: #898e87;--olive-10: #7f847d;--olive-11: #60655f;--olive-12: #1d211c;--sand-1: #fdfdfc;--sand-2: #f9f9f8;--sand-3: #f1f0ef;--sand-4: #e9e8e6;--sand-5: #e2e1de;--sand-6: #dad9d6;--sand-7: #cfceca;--sand-8: #bcbbb5;--sand-9: #8d8d86;--sand-10: #82827c;--sand-11: #63635e;--sand-12: #21201c}:root{--color-primary: var(--blue-9);--color-primary-hover: var(--blue-10);--color-primary-active: var(--blue-11);--color-primary-subtle: var(--blue-3);--color-primary-text: var(--blue-11);--color-primary-contrast: white;--color-success: var(--green-9);--color-success-subtle: var(--green-3);--color-success-text: var(--green-11);--color-warning: var(--yellow-9);--color-warning-subtle: var(--yellow-3);--color-warning-text: var(--yellow-11);--color-error: var(--red-9);--color-error-subtle: var(--red-3);--color-error-text: var(--red-11);--color-background: var(--slate-1);--color-surface: white;--color-surface-raised: var(--slate-2);--color-surface-overlay: white;--color-surface-hover: var(--slate-3);--color-surface-active: var(--slate-4);--color-surface-selected: var(--slate-5);--color-border: var(--slate-6);--color-border-subtle: var(--slate-4);--color-border-strong: var(--slate-8);--color-border-input: var(--slate-7);--color-text: var(--slate-12);--color-text-secondary: var(--slate-11);--color-text-muted: var(--slate-9);--color-text-inverse: white;--color-focus: var(--blue-8);--focus-ring: 0 0 0 2px var(--color-background), 0 0 0 4px var(--color-focus);--space-0: 0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--radius-none: 0;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--font-sans: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.75;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--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);--transition-fast: .1s ease;--transition-normal: .15s ease;--transition-slow: .3s ease;--touch-target-min: 44px}[data-theme=orange]{--color-primary: var(--orange-9);--color-primary-hover: var(--orange-10);--color-primary-active: var(--orange-11);--color-primary-subtle: var(--orange-3);--color-primary-text: var(--orange-11);--color-focus: var(--orange-8);--color-primary-contrast: white}[data-theme=violet]{--color-primary: var(--violet-9);--color-primary-hover: var(--violet-10);--color-primary-active: var(--violet-11);--color-primary-subtle: var(--violet-3);--color-primary-text: var(--violet-11);--color-focus: var(--violet-8);--color-primary-contrast: white}[data-theme=cyan]{--color-primary: var(--cyan-9);--color-primary-hover: var(--cyan-10);--color-primary-active: var(--cyan-11);--color-primary-subtle: var(--cyan-3);--color-primary-text: var(--cyan-11);--color-focus: var(--cyan-8);--color-primary-contrast: white}[data-theme=pink]{--color-primary: var(--pink-9);--color-primary-hover: var(--pink-10);--color-primary-active: var(--pink-11);--color-primary-subtle: var(--pink-3);--color-primary-text: var(--pink-11);--color-focus: var(--pink-8);--color-primary-contrast: white}[data-theme=bronze]{--color-primary: var(--bronze-9);--color-primary-hover: var(--bronze-10);--color-primary-active: var(--bronze-11);--color-primary-subtle: var(--bronze-3);--color-primary-text: var(--bronze-11);--color-focus: var(--bronze-8);--color-primary-contrast: white}[data-theme=gold]{--color-primary: var(--gold-9);--color-primary-hover: var(--gold-10);--color-primary-active: var(--gold-11);--color-primary-subtle: var(--gold-3);--color-primary-text: var(--gold-11);--color-focus: var(--gold-8);--color-primary-contrast: white}[data-theme=sky]{--color-primary: var(--sky-9);--color-primary-hover: var(--sky-10);--color-primary-active: var(--sky-11);--color-primary-subtle: var(--sky-3);--color-primary-text: var(--sky-11);--color-focus: var(--sky-8);--color-primary-contrast: var(--sky-12)}[data-theme=mint]{--color-primary: var(--mint-9);--color-primary-hover: var(--mint-10);--color-primary-active: var(--mint-11);--color-primary-subtle: var(--mint-3);--color-primary-text: var(--mint-11);--color-focus: var(--mint-8);--color-primary-contrast: var(--mint-12)}[data-theme=lime]{--color-primary: var(--lime-9);--color-primary-hover: var(--lime-10);--color-primary-active: var(--lime-11);--color-primary-subtle: var(--lime-3);--color-primary-text: var(--lime-11);--color-focus: var(--lime-8);--color-primary-contrast: var(--lime-12)}[data-theme=amber]{--color-primary: var(--amber-9);--color-primary-hover: var(--amber-10);--color-primary-active: var(--amber-11);--color-primary-subtle: var(--amber-3);--color-primary-text: var(--amber-11);--color-focus: var(--amber-8);--color-primary-contrast: var(--amber-12)}[data-neutral=gray]{--color-background: var(--gray-1);--color-surface: white;--color-surface-raised: var(--gray-2);--color-surface-overlay: white;--color-surface-hover: var(--gray-3);--color-surface-active: var(--gray-4);--color-surface-selected: var(--gray-5);--color-border: var(--gray-6);--color-border-subtle: var(--gray-4);--color-border-strong: var(--gray-8);--color-border-input: var(--gray-7);--color-text: var(--gray-12);--color-text-secondary: var(--gray-11);--color-text-muted: var(--gray-9)}[data-neutral=mauve]{--color-background: var(--mauve-1);--color-surface: white;--color-surface-raised: var(--mauve-2);--color-surface-overlay: white;--color-surface-hover: var(--mauve-3);--color-surface-active: var(--mauve-4);--color-surface-selected: var(--mauve-5);--color-border: var(--mauve-6);--color-border-subtle: var(--mauve-4);--color-border-strong: var(--mauve-8);--color-border-input: var(--mauve-7);--color-text: var(--mauve-12);--color-text-secondary: var(--mauve-11);--color-text-muted: var(--mauve-9)}[data-neutral=sage]{--color-background: var(--sage-1);--color-surface: white;--color-surface-raised: var(--sage-2);--color-surface-overlay: white;--color-surface-hover: var(--sage-3);--color-surface-active: var(--sage-4);--color-surface-selected: var(--sage-5);--color-border: var(--sage-6);--color-border-subtle: var(--sage-4);--color-border-strong: var(--sage-8);--color-border-input: var(--sage-7);--color-text: var(--sage-12);--color-text-secondary: var(--sage-11);--color-text-muted: var(--sage-9)}[data-neutral=olive]{--color-background: var(--olive-1);--color-surface: white;--color-surface-raised: var(--olive-2);--color-surface-overlay: white;--color-surface-hover: var(--olive-3);--color-surface-active: var(--olive-4);--color-surface-selected: var(--olive-5);--color-border: var(--olive-6);--color-border-subtle: var(--olive-4);--color-border-strong: var(--olive-8);--color-border-input: var(--olive-7);--color-text: var(--olive-12);--color-text-secondary: var(--olive-11);--color-text-muted: var(--olive-9)}[data-neutral=sand]{--color-background: var(--sand-1);--color-surface: white;--color-surface-raised: var(--sand-2);--color-surface-overlay: white;--color-surface-hover: var(--sand-3);--color-surface-active: var(--sand-4);--color-surface-selected: var(--sand-5);--color-border: var(--sand-6);--color-border-subtle: var(--sand-4);--color-border-strong: var(--sand-8);--color-border-input: var(--sand-7);--color-text: var(--sand-12);--color-text-secondary: var(--sand-11);--color-text-muted: var(--sand-9)}@media(prefers-color-scheme:dark){:root{--blue-1: #0d1520;--blue-2: #111927;--blue-3: #0d2847;--blue-4: #003362;--blue-5: #004074;--blue-6: #104d87;--blue-7: #205d9e;--blue-8: #2870bd;--blue-9: #0090ff;--blue-10: #3b9eff;--blue-11: #70b8ff;--blue-12: #c2e6ff;--orange-1: #17120e;--orange-2: #1e160f;--orange-3: #331e0b;--orange-4: #462100;--orange-5: #562800;--orange-6: #66350c;--orange-7: #7e451d;--orange-8: #a35829;--orange-9: #f76b15;--orange-10: #ff801f;--orange-11: #ffa057;--orange-12: #ffe0c2;--violet-1: #14121f;--violet-2: #1b1525;--violet-3: #291f43;--violet-4: #33255b;--violet-5: #3c2e69;--violet-6: #473876;--violet-7: #56468b;--violet-8: #6958ad;--violet-9: #6e56cf;--violet-10: #7d66d9;--violet-11: #baa7ff;--violet-12: #e2ddfe;--cyan-1: #0b161a;--cyan-2: #101b20;--cyan-3: #082c36;--cyan-4: #003848;--cyan-5: #004558;--cyan-6: #045468;--cyan-7: #12677e;--cyan-8: #11809c;--cyan-9: #00a2c7;--cyan-10: #23afd0;--cyan-11: #4ccce6;--cyan-12: #b6ecf7;--pink-1: #191117;--pink-2: #21121d;--pink-3: #37172f;--pink-4: #4b143d;--pink-5: #591c47;--pink-6: #692955;--pink-7: #833869;--pink-8: #a84885;--pink-9: #d6409f;--pink-10: #de51a8;--pink-11: #ff8dcc;--pink-12: #fdd1ea;--bronze-1: #141110;--bronze-2: #1c1917;--bronze-3: #262220;--bronze-4: #302a27;--bronze-5: #3b3330;--bronze-6: #493e3a;--bronze-7: #5a4c47;--bronze-8: #6f5f58;--bronze-9: #a18072;--bronze-10: #ae8c7e;--bronze-11: #d4b3a5;--bronze-12: #ede0d9;--gold-1: #121211;--gold-2: #1b1a17;--gold-3: #24231f;--gold-4: #2d2b26;--gold-5: #38352e;--gold-6: #444039;--gold-7: #544f46;--gold-8: #696256;--gold-9: #978365;--gold-10: #a39073;--gold-11: #cbb99f;--gold-12: #e8e2d9;--sky-1: #0d141f;--sky-2: #111a27;--sky-3: #112840;--sky-4: #113555;--sky-5: #154467;--sky-6: #1b537b;--sky-7: #1f6692;--sky-8: #197cae;--sky-9: #7ce2fe;--sky-10: #a8eeff;--sky-11: #75c7f0;--sky-12: #c2f3ff;--mint-1: #0e1515;--mint-2: #0f1b1b;--mint-3: #092c2b;--mint-4: #003a38;--mint-5: #004744;--mint-6: #105650;--mint-7: #1e685f;--mint-8: #277f70;--mint-9: #86ead4;--mint-10: #a8f5e5;--mint-11: #58d5ba;--mint-12: #c4f5e1;--lime-1: #11130c;--lime-2: #151a10;--lime-3: #1f2917;--lime-4: #29371d;--lime-5: #334423;--lime-6: #3d522a;--lime-7: #496231;--lime-8: #577538;--lime-9: #bdee63;--lime-10: #d4ff70;--lime-11: #bde56c;--lime-12: #e3f7ba;--amber-1: #16120c;--amber-2: #1d180f;--amber-3: #302008;--amber-4: #3f2700;--amber-5: #4d3000;--amber-6: #5c3d05;--amber-7: #714f19;--amber-8: #8f6424;--amber-9: #ffc53d;--amber-10: #ffd60a;--amber-11: #ffca16;--amber-12: #ffe7b3;--red-1: #191111;--red-2: #201314;--red-3: #3b1219;--red-4: #500f1c;--red-5: #611623;--red-6: #72232d;--red-7: #8c333a;--red-8: #b54548;--red-9: #e5484d;--red-10: #ec5d5e;--red-11: #ff9592;--red-12: #ffd1d9;--yellow-1: #14120b;--yellow-2: #1b180f;--yellow-3: #2d2305;--yellow-4: #362b00;--yellow-5: #433500;--yellow-6: #524202;--yellow-7: #665417;--yellow-8: #836a21;--yellow-9: #ffe629;--yellow-10: #ffff57;--yellow-11: #f5e147;--yellow-12: #f6eeb4;--green-1: #0e1512;--green-2: #121b17;--green-3: #132d21;--green-4: #113b29;--green-5: #174933;--green-6: #20573e;--green-7: #28684a;--green-8: #2f7c57;--green-9: #30a46c;--green-10: #33b074;--green-11: #3dd68c;--green-12: #b1f1cb;--slate-1: #111113;--slate-2: #18191b;--slate-3: #212225;--slate-4: #272a2d;--slate-5: #2e3135;--slate-6: #363a3f;--slate-7: #43484e;--slate-8: #5a6169;--slate-9: #696e77;--slate-10: #777b84;--slate-11: #b0b4ba;--slate-12: #edeef0;--gray-1: #111111;--gray-2: #191919;--gray-3: #222222;--gray-4: #2a2a2a;--gray-5: #313131;--gray-6: #3a3a3a;--gray-7: #484848;--gray-8: #606060;--gray-9: #6e6e6e;--gray-10: #7b7b7b;--gray-11: #b4b4b4;--gray-12: #eeeeee;--mauve-1: #121113;--mauve-2: #1a191b;--mauve-3: #232225;--mauve-4: #2b292d;--mauve-5: #323035;--mauve-6: #3c393f;--mauve-7: #49474e;--mauve-8: #625f69;--mauve-9: #6f6d78;--mauve-10: #7c7a85;--mauve-11: #b5b2bc;--mauve-12: #eeeef0;--sage-1: #101211;--sage-2: #171918;--sage-3: #202221;--sage-4: #272a29;--sage-5: #2e3130;--sage-6: #373b39;--sage-7: #444947;--sage-8: #5b625f;--sage-9: #63706b;--sage-10: #717d79;--sage-11: #adb5b2;--sage-12: #eceeed;--olive-1: #111210;--olive-2: #181917;--olive-3: #212220;--olive-4: #282a27;--olive-5: #2f312e;--olive-6: #383a36;--olive-7: #454843;--olive-8: #5c625b;--olive-9: #687066;--olive-10: #767d74;--olive-11: #afb5ad;--olive-12: #eceeec;--sand-1: #111110;--sand-2: #191918;--sand-3: #222221;--sand-4: #2a2a28;--sand-5: #31312e;--sand-6: #3b3a37;--sand-7: #494844;--sand-8: #62605b;--sand-9: #6f6d66;--sand-10: #7c7b74;--sand-11: #b5b3ad;--sand-12: #eeeeec;--color-background: var(--slate-1);--color-surface: var(--slate-2);--color-surface-raised: var(--slate-3);--color-surface-overlay: var(--slate-4);--color-surface-hover: var(--slate-4);--color-surface-active: var(--slate-5);--color-surface-selected: var(--slate-5);--color-border: var(--slate-6);--color-border-subtle: var(--slate-4);--color-border-strong: var(--slate-8);--color-border-input: var(--slate-7);--color-text: var(--slate-12);--color-text-secondary: var(--slate-11);--color-text-muted: var(--slate-10);--color-text-inverse: var(--slate-1);--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .3);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .4), 0 2px 4px -2px rgb(0 0 0 / .3);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .5), 0 4px 6px -4px rgb(0 0 0 / .4)}[data-neutral=gray]{--color-background: var(--gray-1);--color-surface: var(--gray-2);--color-surface-raised: var(--gray-3);--color-surface-overlay: var(--gray-4);--color-surface-hover: var(--gray-4);--color-surface-active: var(--gray-5);--color-surface-selected: var(--gray-5);--color-border: var(--gray-6);--color-border-subtle: var(--gray-4);--color-border-strong: var(--gray-8);--color-border-input: var(--gray-7);--color-text: var(--gray-12);--color-text-secondary: var(--gray-11);--color-text-muted: var(--gray-10);--color-text-inverse: var(--gray-1)}[data-neutral=mauve]{--color-background: var(--mauve-1);--color-surface: var(--mauve-2);--color-surface-raised: var(--mauve-3);--color-surface-overlay: var(--mauve-4);--color-surface-hover: var(--mauve-4);--color-surface-active: var(--mauve-5);--color-surface-selected: var(--mauve-5);--color-border: var(--mauve-6);--color-border-subtle: var(--mauve-4);--color-border-strong: var(--mauve-8);--color-border-input: var(--mauve-7);--color-text: var(--mauve-12);--color-text-secondary: var(--mauve-11);--color-text-muted: var(--mauve-10);--color-text-inverse: var(--mauve-1)}[data-neutral=sage]{--color-background: var(--sage-1);--color-surface: var(--sage-2);--color-surface-raised: var(--sage-3);--color-surface-overlay: var(--sage-4);--color-surface-hover: var(--sage-4);--color-surface-active: var(--sage-5);--color-surface-selected: var(--sage-5);--color-border: var(--sage-6);--color-border-subtle: var(--sage-4);--color-border-strong: var(--sage-8);--color-border-input: var(--sage-7);--color-text: var(--sage-12);--color-text-secondary: var(--sage-11);--color-text-muted: var(--sage-10);--color-text-inverse: var(--sage-1)}[data-neutral=olive]{--color-background: var(--olive-1);--color-surface: var(--olive-2);--color-surface-raised: var(--olive-3);--color-surface-overlay: var(--olive-4);--color-surface-hover: var(--olive-4);--color-surface-active: var(--olive-5);--color-surface-selected: var(--olive-5);--color-border: var(--olive-6);--color-border-subtle: var(--olive-4);--color-border-strong: var(--olive-8);--color-border-input: var(--olive-7);--color-text: var(--olive-12);--color-text-secondary: var(--olive-11);--color-text-muted: var(--olive-10);--color-text-inverse: var(--olive-1)}[data-neutral=sand]{--color-background: var(--sand-1);--color-surface: var(--sand-2);--color-surface-raised: var(--sand-3);--color-surface-overlay: var(--sand-4);--color-surface-hover: var(--sand-4);--color-surface-active: var(--sand-5);--color-surface-selected: var(--sand-5);--color-border: var(--sand-6);--color-border-subtle: var(--sand-4);--color-border-strong: var(--sand-8);--color-border-input: var(--sand-7);--color-text: var(--sand-12);--color-text-secondary: var(--sand-11);--color-text-muted: var(--sand-10);--color-text-inverse: var(--sand-1)}[data-theme=sky]{--color-primary-contrast: var(--sky-1)}[data-theme=mint]{--color-primary-contrast: var(--mint-1)}[data-theme=lime]{--color-primary-contrast: var(--lime-1)}[data-theme=amber]{--color-primary-contrast: var(--amber-1)}}.auth-input{display:block;width:100%;padding:var(--space-2) var(--space-3);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.auth-input:focus{outline:none;border-color:var(--color-focus);box-shadow:var(--focus-ring)}.auth-input::placeholder{color:var(--color-text-muted)}.auth-input:disabled{opacity:.6;cursor:not-allowed}.auth-label{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text);margin-bottom:var(--space-1)}.auth-checkbox-row{display:flex;align-items:center;gap:var(--space-2);padding-top:var(--space-1)}.auth-checkbox{width:1rem;height:1rem;accent-color:var(--color-primary);cursor:pointer;flex-shrink:0}.auth-checkbox-label{font-size:var(--text-sm);color:var(--color-text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.auth-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-base);font-weight:var(--font-medium);line-height:var(--leading-normal);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast),transform var(--transition-fast);min-height:var(--touch-target-min)}.auth-btn:disabled{opacity:.6;cursor:not-allowed}.auth-btn:active:not(:disabled){transform:scale(.98)}.auth-btn-primary{background-color:var(--color-primary);color:var(--color-primary-contrast);border:none}.auth-btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover)}.auth-btn-primary:active:not(:disabled){background-color:var(--color-primary-active)}.auth-btn-secondary{background-color:transparent;color:var(--color-text);border:1px solid var(--color-border)}.auth-btn-secondary:hover:not(:disabled){background-color:var(--color-surface-raised);border-color:var(--color-border-strong)}.auth-btn-full{width:100%}.auth-error{padding:var(--space-3) var(--space-4);background-color:var(--color-error-subtle);color:var(--color-error-text);border-radius:var(--radius-md);border-left:3px solid var(--color-error);font-size:var(--text-sm);line-height:var(--leading-relaxed)}.auth-success{padding:var(--space-4);background-color:var(--color-success-subtle);color:var(--color-success-text);border-radius:var(--radius-md);border-left:3px solid var(--color-success);font-size:var(--text-sm);line-height:var(--leading-relaxed)}.auth-info{font-size:var(--text-xs);color:var(--color-text-muted);text-align:center}.auth-form{display:flex;flex-direction:column;gap:var(--space-4)}.auth-form-disabled{pointer-events:none;opacity:.7}.auth-header{text-align:center}.auth-header-icon{width:3rem;height:3rem;margin:0 auto var(--space-2);color:var(--color-primary)}.auth-header-title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--color-text);margin:0}.auth-header-subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.auth-divider{display:flex;align-items:center;gap:var(--space-3);margin:var(--space-4) 0;color:var(--color-text-muted);font-size:var(--text-sm)}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background-color:var(--color-border)}.auth-spinner{width:1rem;height:1rem;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:auth-spin .6s linear infinite}@keyframes auth-spin{to{transform:rotate(360deg)}}.auth-passkey-list{display:flex;flex-direction:column;gap:var(--space-3)}.auth-passkey-loading,.auth-passkey-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-6);text-align:center;color:var(--color-text-secondary)}.auth-passkey-empty-hint{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}.auth-passkey-items{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-2)}.auth-passkey-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3);background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast)}.auth-passkey-item:hover{border-color:var(--color-border-strong)}.auth-passkey-info{display:flex;align-items:center;gap:var(--space-3);flex:1;min-width:0}.auth-passkey-icon{width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;background:var(--color-surface);border-radius:var(--radius-md);color:var(--color-text-secondary);flex-shrink:0}.auth-passkey-icon:before{content:"";width:1.25rem;height:1.25rem;background:currentColor;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'%3E%3Cpath d='M21 2l-2 2m-7.61 7.61a5.5 5.5 0 1 1-7.778 7.778 5.5 5.5 0 0 1 7.777-7.777zm0 0L15.5 7.5m0 0l3 3L22 7l-3-3m-3.5 3.5L19 4'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'%3E%3Cpath d='M21 2l-2 2m-7.61 7.61a5.5 5.5 0 1 1-7.778 7.778 5.5 5.5 0 0 1 7.777-7.777zm0 0L15.5 7.5m0 0l3 3L22 7l-3-3m-3.5 3.5L19 4'/%3E%3C/svg%3E")}.auth-passkey-icon[data-transport=phone]:before{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'%3E%3Crect x='5' y='2' width='14' height='20' rx='2' ry='2'/%3E%3Cline x1='12' y1='18' x2='12.01' y2='18'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'%3E%3Crect x='5' y='2' width='14' height='20' rx='2' ry='2'/%3E%3Cline x1='12' y1='18' x2='12.01' y2='18'/%3E%3C/svg%3E")}.auth-passkey-icon[data-transport=device]:before{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'%3E%3Crect x='2' y='3' width='20' height='14' rx='2' ry='2'/%3E%3Cline x1='8' y1='21' x2='16' y2='21'/%3E%3Cline x1='12' y1='17' x2='12' y2='21'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'%3E%3Crect x='2' y='3' width='20' height='14' rx='2' ry='2'/%3E%3Cline x1='8' y1='21' x2='16' y2='21'/%3E%3Cline x1='12' y1='17' x2='12' y2='21'/%3E%3C/svg%3E")}.auth-passkey-icon[data-transport=usb]:before{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'%3E%3Cellipse cx='12' cy='5' rx='3' ry='2'/%3E%3Cpath d='M12 22V7'/%3E%3Cpath d='M7 10l5-3 5 3'/%3E%3Cpath d='M7 14a5 5 0 0 0 10 0'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'%3E%3Cellipse cx='12' cy='5' rx='3' ry='2'/%3E%3Cpath d='M12 22V7'/%3E%3Cpath d='M7 10l5-3 5 3'/%3E%3Cpath d='M7 14a5 5 0 0 0 10 0'/%3E%3C/svg%3E")}.auth-passkey-details{display:flex;flex-direction:column;gap:var(--space-0-5);min-width:0}.auth-passkey-name{font-weight:var(--font-medium);color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.auth-passkey-meta{font-size:var(--text-xs);color:var(--color-text-muted)}.auth-passkey-actions{display:flex;gap:var(--space-2);flex-shrink:0}.auth-passkey-edit{display:flex;flex-direction:column;gap:var(--space-2);width:100%}.auth-passkey-edit-actions{display:flex;gap:var(--space-2)}.auth-passkey-register{display:flex;flex-direction:column;gap:var(--space-3)}.auth-passkey-naming{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-4);background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-md)}.auth-passkey-naming-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text);margin:0}.auth-passkey-naming-hint{font-size:var(--text-sm);color:var(--color-text-secondary);margin:0}.auth-passkey-naming-actions{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-2)}.auth-btn-sm{padding:var(--space-1) var(--space-2);font-size:var(--text-sm);min-height:auto}.auth-btn-danger{background-color:var(--color-error);color:#fff;border:none}.auth-btn-danger:hover:not(:disabled){opacity:.9}@media(max-width:480px){.auth-passkey-item{flex-direction:column;align-items:stretch;padding:var(--space-4);gap:var(--space-4);box-shadow:0 1px 3px #00000014}.auth-passkey-info{flex-direction:column;align-items:flex-start;text-align:left}.auth-passkey-icon{width:3rem;height:3rem}.auth-passkey-actions{flex-direction:column;width:100%}.auth-passkey-actions .auth-btn{width:100%;justify-content:center}.auth-passkey-naming-actions{gap:var(--space-3)}}.auth-totp-setup{display:flex;flex-direction:column;gap:var(--space-6)}.auth-totp-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-8);text-align:center;color:var(--color-text-secondary)}.auth-spinner-lg{width:2rem;height:2rem}.auth-totp-step{display:flex;flex-direction:column;gap:var(--space-4)}.auth-totp-step-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text);margin:0}.auth-totp-step-instructions{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:var(--leading-relaxed);margin:0}.auth-totp-qr{display:flex;justify-content:center;padding:var(--space-4);background:#fff;border-radius:var(--radius-lg);border:1px solid var(--color-border);margin:var(--space-2) auto;max-width:232px}.auth-totp-qr svg{display:block;width:200px;height:200px}.auth-totp-secret{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3);background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-md)}.auth-totp-secret-code{font-family:var(--font-mono);font-size:var(--text-sm);letter-spacing:.1em;word-break:break-all;-webkit-user-select:all;user-select:all;cursor:text;padding:var(--space-2);background:var(--color-surface);border-radius:var(--radius-sm);text-align:center}.auth-backup-codes{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-2);padding:var(--space-4);background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-md)}.auth-backup-code{font-family:var(--font-mono);font-size:var(--text-sm);padding:var(--space-2);background:var(--color-surface);border-radius:var(--radius-sm);text-align:center;-webkit-user-select:all;user-select:all;cursor:text}.auth-totp-confirm{padding-top:var(--space-2)}.auth-totp-buttons{display:flex;gap:var(--space-3);justify-content:flex-end;padding-top:var(--space-2)}.auth-totp-buttons .auth-btn{min-width:100px}.auth-code-input{font-family:var(--font-mono);font-size:var(--text-xl);letter-spacing:.3em;text-align:center;padding:var(--space-3) var(--space-4)}.auth-code-input::placeholder{letter-spacing:.3em;opacity:.4}.auth-totp-success-step{text-align:center;padding:var(--space-6) var(--space-4)}.auth-success-icon{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--color-success);margin-bottom:var(--space-4)}.auth-totp-error-state{display:flex;flex-direction:column;gap:var(--space-4);align-items:center;padding:var(--space-4)}.auth-totp-verify{display:flex;flex-direction:column;gap:var(--space-6)}.auth-totp-code-input{display:flex;flex-direction:column;gap:var(--space-2)}.auth-totp-mode-toggle{display:block;width:100%;text-align:center;font-size:var(--text-sm);color:var(--color-primary);background:none;border:none;padding:var(--space-2);cursor:pointer;text-decoration:underline;transition:opacity var(--transition-fast)}.auth-totp-mode-toggle:hover{opacity:.8}.auth-totp-mode-toggle:disabled{opacity:.5;cursor:not-allowed}.auth-warning{padding:var(--space-3) var(--space-4);background-color:var(--color-warning-subtle);color:var(--color-warning-text);border-radius:var(--radius-md);border-left:3px solid var(--color-warning);font-size:var(--text-sm);line-height:var(--leading-relaxed)}.auth-link{color:var(--color-primary);background:none;border:none;padding:0;font-size:inherit;cursor:pointer;text-decoration:underline}.auth-link:hover{opacity:.8}@media(max-width:480px){.auth-backup-codes{grid-template-columns:1fr}.auth-totp-buttons{flex-direction:column}.auth-totp-buttons .auth-btn{width:100%}.auth-code-input{font-size:var(--text-lg);letter-spacing:.2em}}.uk-shell{height:100vh;display:flex;flex-direction:column;background:var(--color-background);overflow:hidden}.uk-shell__main{flex:1;display:flex;overflow:hidden;transition:margin-left var(--transition-sidebar)}.uk-shell__content{flex:1;overflow-y:auto;padding:var(--space-6);display:flex;flex-direction:column;min-height:0}.uk-shell__content--full-height{overflow:hidden;padding:0}.uk-shell__content-inner{flex:1;min-height:0;display:flex;flex-direction:column}.uk-shell__footer{flex-shrink:0;margin-top:auto;margin-left:calc(-1 * var(--space-6));margin-right:calc(-1 * var(--space-6));margin-bottom:calc(-1 * var(--space-6))}@media(min-width:768px){.uk-shell__main{margin-left:var(--sidebar-width, 240px)}.uk-shell__main--collapsed{margin-left:var(--sidebar-collapsed-width, 64px)}}@media(max-width:767px){.uk-shell__content{padding:var(--space-4)}.uk-shell__footer{margin-left:calc(-1 * var(--space-4));margin-right:calc(-1 * var(--space-4));margin-bottom:calc(-1 * var(--space-4))}}.uk-drawer__overlay{position:fixed;inset:0;z-index:var(--z-drawer-backdrop, 200)}.uk-drawer__backdrop{position:absolute;inset:0;background:#00000080;animation:uk-drawer-fade-in .2s ease}@keyframes uk-drawer-fade-in{0%{opacity:0}to{opacity:1}}.uk-drawer{position:absolute;top:0;left:0;width:280px;max-width:85vw;height:100%;background:var(--color-surface);box-shadow:var(--shadow-lg);z-index:var(--z-drawer, 210);display:flex;flex-direction:column;animation:uk-drawer-slide-in .2s ease}@keyframes uk-drawer-slide-in{0%{transform:translate(-100%)}to{transform:translate(0)}}.uk-drawer__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);border-bottom:1px solid var(--color-border-subtle);background:var(--color-primary-subtle)}.uk-drawer__title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-primary-text)}.uk-drawer__close{display:flex;align-items:center;justify-content:center;width:var(--touch-target-min);height:var(--touch-target-min);padding:0;background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-primary-text);cursor:pointer;transition:background var(--transition-fast)}.uk-drawer__close:hover{background:#0000000d}.uk-drawer__close:focus-visible{outline:none;box-shadow:var(--focus-ring)}.uk-drawer__nav{flex:1;display:flex;flex-direction:column;padding:var(--space-3);gap:var(--space-1);overflow-y:auto}.uk-drawer__nav-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);min-height:var(--touch-target-min);background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--text-base);font-weight:var(--font-medium);text-align:left;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.uk-drawer__nav-item:hover{background:var(--slate-2, rgba(0, 0, 0, .05));color:var(--color-text)}.uk-drawer__nav-item:focus-visible{outline:none;box-shadow:var(--focus-ring)}.uk-drawer__nav-item--active{background:var(--color-primary-subtle);color:var(--color-primary-text)}.uk-drawer__divider{height:1px;background:var(--color-border-subtle);margin:var(--space-2) var(--space-3)}.uk-drawer__user-section{border-top:1px solid var(--color-border-subtle);padding:var(--space-4)}.uk-drawer__user-info{display:flex;flex-direction:column;gap:var(--space-1);margin-bottom:var(--space-4)}.uk-drawer__user-name{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text)}.uk-drawer__user-role{font-size:var(--text-xs);color:var(--color-primary-text);font-weight:var(--font-medium)}.uk-drawer__user-email{font-size:var(--text-xs);color:var(--color-text-muted)}.uk-drawer__logout{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);min-height:var(--touch-target-min);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.uk-drawer__logout:hover{background:var(--slate-2, rgba(0, 0, 0, .05));border-color:var(--color-border-strong, var(--color-border))}.uk-drawer__logout:focus-visible{outline:none;box-shadow:var(--focus-ring)}.uk-sidebar{display:none;flex-direction:column;width:var(--sidebar-width, 240px);height:calc(100vh - var(--topbar-height, 56px));background:var(--color-surface);border-right:1px solid var(--color-border-subtle);position:fixed;top:var(--topbar-height, 56px);left:0;z-index:var(--z-sidebar, 90);transition:width var(--transition-sidebar, .2s ease);overflow:hidden}@media(min-width:768px){.uk-sidebar{display:flex}}.uk-sidebar--collapsed{width:var(--sidebar-collapsed-width, 64px)}.uk-sidebar__nav{flex:1;display:flex;flex-direction:column;padding:var(--space-3);gap:var(--space-1)}.uk-sidebar__nav-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);min-height:var(--touch-target-min);background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);text-align:left;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);white-space:nowrap;overflow:hidden}.uk-sidebar--collapsed .uk-sidebar__nav-item{justify-content:center;padding:var(--space-3)}.uk-sidebar__nav-item:hover{background:var(--slate-2, rgba(0, 0, 0, .05));color:var(--color-text)}.uk-sidebar__nav-item:focus-visible{outline:none;box-shadow:var(--focus-ring)}.uk-sidebar__nav-item--active{background:var(--color-primary-subtle);color:var(--color-primary-text)}.uk-sidebar__nav-item--active:hover{background:var(--color-primary-subtle)}.uk-sidebar__nav-icon{flex-shrink:0}.uk-sidebar__nav-label{opacity:1;transition:opacity var(--transition-fast)}.uk-sidebar--collapsed .uk-sidebar__nav-label{opacity:0;width:0}.uk-sidebar__divider{height:1px;background:var(--color-border-subtle);margin:var(--space-2) var(--space-3)}.uk-slide-panel__overlay{position:fixed;inset:0;z-index:var(--z-modal, 200);display:flex;justify-content:flex-end}.uk-slide-panel__backdrop{position:absolute;inset:0;background:#00000080;animation:uk-backdrop-fade-in .2s ease-out}.uk-slide-panel__backdrop--closing{animation:uk-backdrop-fade-out .2s ease-in forwards}@keyframes uk-backdrop-fade-in{0%{opacity:0}to{opacity:1}}@keyframes uk-backdrop-fade-out{0%{opacity:1}to{opacity:0}}.uk-slide-panel{display:flex;flex-direction:column;background:var(--color-surface);overflow:hidden}.uk-slide-panel--desktop{flex-shrink:0;border-left:1px solid var(--color-border-subtle);height:100%}.uk-slide-panel--desktop.uk-slide-panel--left{border-left:none;border-right:1px solid var(--color-border-subtle)}.uk-slide-panel--mobile{position:relative;width:100%;max-width:100%;height:100%;box-shadow:var(--shadow-xl, -4px 0 24px rgba(0, 0, 0, .15))}.uk-slide-panel--mobile.uk-slide-panel--right{animation:uk-panel-slide-in-right .2s ease-out}.uk-slide-panel--mobile.uk-slide-panel--right.uk-slide-panel--closing{animation:uk-panel-slide-out-right .2s ease-in forwards}.uk-slide-panel--mobile.uk-slide-panel--left{animation:uk-panel-slide-in-left .2s ease-out}.uk-slide-panel--mobile.uk-slide-panel--left.uk-slide-panel--closing{animation:uk-panel-slide-out-left .2s ease-in forwards}@keyframes uk-panel-slide-in-right{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes uk-panel-slide-out-right{0%{transform:translate(0)}to{transform:translate(100%)}}@keyframes uk-panel-slide-in-left{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes uk-panel-slide-out-left{0%{transform:translate(0)}to{transform:translate(-100%)}}.uk-slide-panel__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-subtle);background:var(--slate-2, var(--color-surface));flex-shrink:0}.uk-slide-panel__title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.uk-slide-panel__close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;margin:calc(-1 * var(--space-1));margin-left:var(--space-2);border:none;background:transparent;color:var(--color-text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);flex-shrink:0}.uk-slide-panel__close:hover{background:var(--slate-3, rgba(0, 0, 0, .05));color:var(--color-text)}.uk-slide-panel__close:focus-visible{outline:none;box-shadow:var(--focus-ring)}.uk-slide-panel__content{flex:1;overflow-y:auto;padding:var(--space-4);-webkit-overflow-scrolling:touch}.uk-slide-panel--mobile .uk-slide-panel__content{padding-bottom:calc(var(--space-4) + env(safe-area-inset-bottom,0))}@media(prefers-reduced-motion:reduce){.uk-slide-panel__backdrop,.uk-slide-panel--mobile{animation:none}}.uk-topbar{display:flex;align-items:center;justify-content:space-between;height:var(--topbar-height, 56px);padding:0 var(--space-4);background:var(--color-primary-subtle);border-bottom:1px solid var(--color-border-subtle);position:sticky;top:0;z-index:var(--z-topbar, 100)}.uk-topbar__left{display:flex;align-items:center;gap:var(--space-3)}.uk-topbar__right{display:flex;align-items:center}.uk-topbar__hamburger{display:flex;align-items:center;justify-content:center;width:var(--touch-target-min);height:var(--touch-target-min);padding:0;background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-primary-text);cursor:pointer;transition:background var(--transition-fast)}.uk-topbar__hamburger:hover{background:#0000000d}.uk-topbar__hamburger:focus-visible{outline:none;box-shadow:var(--focus-ring)}@media(min-width:768px){.uk-topbar__hamburger{display:none}}.uk-topbar__collapse-toggle{display:none;align-items:center;justify-content:center;width:var(--touch-target-min);height:var(--touch-target-min);padding:0;background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-primary-text);cursor:pointer;transition:background var(--transition-fast)}.uk-topbar__collapse-toggle:hover{background:#0000000d}.uk-topbar__collapse-toggle:focus-visible{outline:none;box-shadow:var(--focus-ring)}@media(min-width:768px){.uk-topbar__collapse-toggle{display:flex}}.uk-topbar__title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-primary-text)}.uk-topbar__right{display:none}@media(min-width:768px){.uk-topbar__right{display:flex}}.uk-user-menu{position:relative}.uk-user-menu__trigger{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-primary-text);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;min-height:var(--touch-target-min);transition:background var(--transition-fast)}.uk-user-menu__trigger:hover{background:#0000000d}.uk-user-menu__trigger:focus-visible{outline:none;box-shadow:var(--focus-ring)}.uk-user-menu__email{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:480px){.uk-user-menu__email{display:none}}.uk-user-menu__chevron{transition:transform var(--transition-fast)}.uk-user-menu__chevron--rotated{transform:rotate(180deg)}.uk-user-menu__dropdown{position:absolute;top:calc(100% + var(--space-2));right:0;min-width:200px;background:var(--color-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown, 150);overflow:hidden}.uk-user-menu__user-info{padding:var(--space-3) var(--space-4)}.uk-user-menu__name{display:block;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text)}.uk-user-menu__role{display:block;font-size:var(--text-xs);color:var(--color-text-secondary);margin-top:var(--space-1)}.uk-user-menu__divider{height:1px;background:var(--color-border-subtle)}.uk-user-menu__item{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);background:transparent;border:none;font-size:var(--text-sm);color:var(--color-text);cursor:pointer;text-align:left;transition:background var(--transition-fast)}.uk-user-menu__item:hover{background:var(--slate-2, rgba(0, 0, 0, .05))}.uk-user-menu__item:focus-visible{outline:none;background:var(--slate-2, rgba(0, 0, 0, .05))}.uk-user-menu__item--danger{color:var(--red-11, #cd2b31)}.uk-user-menu__item--danger:hover{background:var(--red-3, rgba(205, 43, 49, .1))}.uk-alert-dialog__content{display:flex;gap:var(--space-4);margin-bottom:var(--space-6)}.uk-alert-dialog__icon{flex-shrink:0;width:24px;height:24px}.uk-alert-dialog__body{flex:1;min-width:0}.uk-alert-dialog__message{margin:0;font-size:var(--text-base);color:var(--color-text-secondary);line-height:1.5}.uk-alert-dialog__custom-content{color:var(--color-text-secondary);line-height:1.5}.uk-alert-dialog__actions{display:flex;justify-content:flex-end}.uk-alert-dialog--info .uk-alert-dialog__icon{color:var(--blue-9, #0090ff)}.uk-alert-dialog--success .uk-alert-dialog__icon{color:var(--green-9, #30a46c)}.uk-alert-dialog--warning .uk-alert-dialog__icon{color:var(--amber-9, #ffb224)}.uk-alert-dialog--error .uk-alert-dialog__icon{color:var(--red-9, #e5484d)}@media(max-width:480px){.uk-alert-dialog__actions>*{width:100%}}.uk-button{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);min-height:var(--touch-target-min);min-width:var(--touch-target-min);padding:var(--space-2) var(--space-4);font-family:var(--font-sans);font-size:var(--text-base);font-weight:var(--font-medium);line-height:1;text-decoration:none;white-space:nowrap;border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast)}.uk-button:focus-visible{outline:none;box-shadow:var(--focus-ring)}.uk-button:disabled,.uk-button[aria-disabled=true]{opacity:.5;cursor:not-allowed;pointer-events:none}.uk-button--solid{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--color-primary-contrast)}.uk-button--solid:hover:not(:disabled){background-color:var(--color-primary-hover);border-color:var(--color-primary-hover)}.uk-button--solid:active:not(:disabled){background-color:var(--color-primary-active);border-color:var(--color-primary-active)}.uk-button--outline{background-color:transparent;border-color:var(--color-primary);color:var(--color-primary)}.uk-button--outline:hover:not(:disabled){background-color:var(--color-primary-subtle)}.uk-button--outline:active:not(:disabled){background-color:var(--color-primary);color:var(--color-primary-contrast)}.uk-button--ghost{background-color:transparent;border-color:transparent;color:var(--color-primary)}.uk-button--ghost:hover:not(:disabled){background-color:var(--color-primary-subtle)}.uk-button--ghost:active:not(:disabled){background-color:var(--color-primary);color:var(--color-primary-contrast)}.uk-button--sm{min-height:var(--touch-target-min);padding:var(--space-1) var(--space-3);font-size:var(--text-sm);border-radius:var(--radius-sm)}.uk-button--md{min-height:var(--touch-target-min);padding:var(--space-2) var(--space-4);font-size:var(--text-base)}.uk-button--lg{min-height:52px;padding:var(--space-3) var(--space-6);font-size:var(--text-lg);border-radius:var(--radius-lg)}.uk-button--full-width{width:100%}.uk-button--icon-only{padding:var(--space-2)}.uk-button--icon-only.uk-button--sm{padding:var(--space-1)}.uk-button--icon-only.uk-button--lg{padding:var(--space-3)}.uk-button--loading{position:relative;color:transparent;pointer-events:none}.uk-button--loading:after{content:"";position:absolute;width:1em;height:1em;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:uk-button-spin .6s linear infinite}.uk-button--solid.uk-button--loading:after{border-color:var(--color-primary-contrast);border-right-color:transparent}.uk-button--outline.uk-button--loading:after,.uk-button--ghost.uk-button--loading:after{border-color:var(--color-primary);border-right-color:transparent}@keyframes uk-button-spin{to{transform:rotate(360deg)}}.uk-card{background-color:var(--color-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);overflow:hidden}.uk-card--elevated{border-color:transparent;box-shadow:var(--shadow-md)}.uk-card--interactive{cursor:pointer;transition:box-shadow var(--transition-normal),border-color var(--transition-normal),transform var(--transition-normal)}.uk-card--interactive:hover{border-color:var(--color-border);box-shadow:var(--shadow-lg)}.uk-card--interactive:active{transform:scale(.99)}.uk-card--interactive:focus-visible{outline:none;box-shadow:var(--focus-ring)}.uk-card__header{padding:var(--space-4) var(--space-4) var(--space-2);border-bottom:1px solid var(--color-border-subtle)}.uk-card__header:last-child{border-bottom:none;padding-bottom:var(--space-4)}.uk-card__body{padding:var(--space-4)}.uk-card__footer{padding:var(--space-2) var(--space-4) var(--space-4);border-top:1px solid var(--color-border-subtle)}.uk-card__footer:first-child{border-top:none;padding-top:var(--space-4)}.uk-card--no-padding .uk-card__header,.uk-card--no-padding .uk-card__body,.uk-card--no-padding .uk-card__footer{padding:0}.uk-card--compact .uk-card__header{padding:var(--space-3) var(--space-3) var(--space-1)}.uk-card--compact .uk-card__body{padding:var(--space-3)}.uk-card--compact .uk-card__footer{padding:var(--space-1) var(--space-3) var(--space-3)}.uk-card__title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text);margin:0}.uk-card__description{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-1)}.uk-card__actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-2)}.uk-card__actions--start{justify-content:flex-start}.uk-card__actions--space-between{justify-content:space-between}.uk-confirm-dialog__message{margin:0 0 var(--space-6);font-size:var(--text-base);color:var(--color-text-secondary);line-height:1.5}.uk-confirm-dialog__custom-content{margin-bottom:var(--space-6)}.uk-confirm-dialog__actions{display:flex;justify-content:flex-end;gap:var(--space-3)}.uk-confirm-dialog__danger-button{--color-primary: var(--red-9, #e5484d);--color-primary-hover: var(--red-10, #dc3d43);--color-primary-active: var(--red-11, #cd2b31);--color-primary-contrast: white}@media(max-width:480px){.uk-confirm-dialog__actions{flex-direction:column-reverse}.uk-confirm-dialog__actions>*{width:100%}}.uk-dialog__overlay{position:fixed;inset:0;z-index:var(--z-modal, 1000);display:flex;align-items:center;justify-content:center;padding:var(--space-4)}.uk-dialog__backdrop{position:absolute;inset:0;background:#00000080;animation:uk-dialog-fade-in .15s ease}@keyframes uk-dialog-fade-in{0%{opacity:0}to{opacity:1}}.uk-dialog{position:relative;width:100%;background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;max-height:calc(100vh - var(--space-8));animation:uk-dialog-scale-in .15s ease}@keyframes uk-dialog-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.uk-dialog--sm{max-width:400px}.uk-dialog--md{max-width:480px}.uk-dialog--lg{max-width:640px}.uk-dialog--xl{max-width:800px}.uk-dialog--full{max-width:none;width:calc(100% - var(--space-8));height:calc(100% - var(--space-8));max-height:none}.uk-dialog__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border-subtle);flex-shrink:0}.uk-dialog__title{margin:0;font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text)}.uk-dialog__close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;margin-left:auto;padding:0;border:none;background:transparent;color:var(--color-text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.uk-dialog__close:hover:not(:disabled){background:var(--slate-3, rgba(0, 0, 0, .05));color:var(--color-text)}.uk-dialog__close:focus-visible{outline:none;box-shadow:var(--focus-ring)}.uk-dialog__close:disabled{opacity:.5;cursor:not-allowed}.uk-dialog__content{flex:1;padding:var(--space-6);overflow-y:auto}.uk-dialog:not(:has(.uk-dialog__header)) .uk-dialog__content{padding-top:var(--space-6)}@media(max-width:480px){.uk-dialog__overlay{padding:var(--space-2)}.uk-dialog--sm,.uk-dialog--md,.uk-dialog--lg,.uk-dialog--xl{max-width:none}.uk-dialog__header{padding:var(--space-3) var(--space-4)}.uk-dialog__content{padding:var(--space-4)}}.uk-tabs{width:100%}.uk-tabs__list{display:flex;gap:var(--space-1);border-bottom:1px solid var(--color-border-subtle);overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-webkit-overflow-scrolling:touch}.uk-tabs__list::-webkit-scrollbar{display:none}.uk-tabs__tab{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);min-height:var(--touch-target-min);background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;color:var(--color-text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);white-space:nowrap;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast),background var(--transition-fast)}.uk-tabs__tab:hover:not(:disabled){color:var(--color-text);background:var(--color-surface-hover, rgba(0, 0, 0, .03))}.uk-tabs__tab:focus-visible{outline:none;box-shadow:var(--focus-ring-inset, inset 0 0 0 2px var(--color-primary-7))}.uk-tabs__tab--active{color:var(--color-primary-text);border-bottom-color:var(--color-primary-9)}.uk-tabs__tab--active:hover{color:var(--color-primary-text)}.uk-tabs__tab--disabled{opacity:.5;cursor:not-allowed}.uk-tabs__icon{flex-shrink:0}.uk-tabs--sm .uk-tabs__tab{padding:var(--space-2) var(--space-3);font-size:var(--text-xs);min-height:36px}.uk-tabs--sm .uk-tabs__list{gap:0}.uk-tabs__panel{padding-top:var(--space-4)}@media(max-width:640px){.uk-tabs__list{gap:0}.uk-tabs__tab{padding:var(--space-2) var(--space-3);flex-shrink:0}}html{height:100%;overflow:hidden;overscroll-behavior:none}body{height:100%;margin:0;overflow:hidden;overscroll-behavior:none;background-color:var(--color-bg-muted)}#root{height:100%;overflow:hidden}:root{--color-bg: var(--color-background, var(--slate-1));--color-bg-surface: var(--color-surface, white);--color-bg-muted: var(--color-surface-raised, var(--slate-2));--color-accent-3: var(--blue-3);--color-accent-4: var(--blue-4);--color-accent-5: var(--blue-5);--color-accent-7: var(--blue-7);--color-accent-8: var(--blue-8);--color-accent-9: var(--blue-9);--color-accent-11: var(--blue-11)}[data-theme=orange]{--color-accent-3: var(--orange-3);--color-accent-4: var(--orange-4);--color-accent-5: var(--orange-5);--color-accent-7: var(--orange-7);--color-accent-8: var(--orange-8);--color-accent-9: var(--orange-9);--color-accent-11: var(--orange-11)}[data-theme=violet]{--color-accent-3: var(--violet-3);--color-accent-4: var(--violet-4);--color-accent-5: var(--violet-5);--color-accent-7: var(--violet-7);--color-accent-8: var(--violet-8);--color-accent-9: var(--violet-9);--color-accent-11: var(--violet-11)}[data-theme=cyan]{--color-accent-3: var(--cyan-3);--color-accent-4: var(--cyan-4);--color-accent-5: var(--cyan-5);--color-accent-7: var(--cyan-7);--color-accent-8: var(--cyan-8);--color-accent-9: var(--cyan-9);--color-accent-11: var(--cyan-11)}[data-theme=pink]{--color-accent-3: var(--pink-3);--color-accent-4: var(--pink-4);--color-accent-5: var(--pink-5);--color-accent-7: var(--pink-7);--color-accent-8: var(--pink-8);--color-accent-9: var(--pink-9);--color-accent-11: var(--pink-11)}[data-theme=bronze]{--color-accent-3: var(--bronze-3);--color-accent-4: var(--bronze-4);--color-accent-5: var(--bronze-5);--color-accent-7: var(--bronze-7);--color-accent-8: var(--bronze-8);--color-accent-9: var(--bronze-9);--color-accent-11: var(--bronze-11)}[data-theme=gold]{--color-accent-3: var(--gold-3);--color-accent-4: var(--gold-4);--color-accent-5: var(--gold-5);--color-accent-7: var(--gold-7);--color-accent-8: var(--gold-8);--color-accent-9: var(--gold-9);--color-accent-11: var(--gold-11)}[data-theme=sky]{--color-accent-3: var(--sky-3);--color-accent-4: var(--sky-4);--color-accent-5: var(--sky-5);--color-accent-7: var(--sky-7);--color-accent-8: var(--sky-8);--color-accent-9: var(--sky-9);--color-accent-11: var(--sky-11)}[data-theme=mint]{--color-accent-3: var(--mint-3);--color-accent-4: var(--mint-4);--color-accent-5: var(--mint-5);--color-accent-7: var(--mint-7);--color-accent-8: var(--mint-8);--color-accent-9: var(--mint-9);--color-accent-11: var(--mint-11)}[data-theme=lime]{--color-accent-3: var(--lime-3);--color-accent-4: var(--lime-4);--color-accent-5: var(--lime-5);--color-accent-7: var(--lime-7);--color-accent-8: var(--lime-8);--color-accent-9: var(--lime-9);--color-accent-11: var(--lime-11)}[data-theme=amber]{--color-accent-3: var(--amber-3);--color-accent-4: var(--amber-4);--color-accent-5: var(--amber-5);--color-accent-7: var(--amber-7);--color-accent-8: var(--amber-8);--color-accent-9: var(--amber-9);--color-accent-11: var(--amber-11)}[data-theme=blue]{--color-primary: var(--blue-9);--color-primary-hover: var(--blue-10);--color-primary-active: var(--blue-11);--color-primary-subtle: var(--blue-3);--color-primary-text: var(--blue-11);--color-primary-contrast: white;--color-focus: var(--blue-8);--color-accent-3: var(--blue-3);--color-accent-4: var(--blue-4);--color-accent-5: var(--blue-5);--color-accent-7: var(--blue-7);--color-accent-8: var(--blue-8);--color-accent-9: var(--blue-9);--color-accent-11: var(--blue-11)}[data-neutral=slate]{--color-background: var(--slate-1);--color-border: var(--slate-6);--color-border-subtle: var(--slate-4);--color-border-strong: var(--slate-8);--color-text: var(--slate-12);--color-text-secondary: var(--slate-11);--color-text-muted: var(--slate-9)}[data-color-mode=dark]{color-scheme:dark}[data-color-mode=light]{color-scheme:light}@media(prefers-color-scheme:dark){:root:not([data-color-mode]){color-scheme:dark}:root{--color-bg: var(--color-background);--color-bg-surface: var(--color-surface);--color-bg-muted: var(--color-surface-raised)}[data-neutral=slate]{--color-background: var(--slate-1);--color-border: var(--slate-6);--color-border-subtle: var(--slate-4);--color-border-strong: var(--slate-8);--color-text: var(--slate-12);--color-text-secondary: var(--slate-11);--color-text-muted: var(--slate-10)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);min-height:var(--touch-target-min);padding:var(--space-2) var(--space-4);font-size:var(--text-base);font-weight:var(--font-medium);line-height:var(--leading-none);border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--solid{background-color:var(--color-primary);color:var(--color-primary-contrast);border:1px solid transparent}.btn--solid:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn--solid:active:not(:disabled){background-color:var(--color-primary-active)}.btn--soft{background-color:var(--color-accent-3);color:var(--color-accent-11);border:1px solid transparent}.btn--soft:hover:not(:disabled){background-color:var(--color-accent-4)}.btn--soft:active:not(:disabled){background-color:var(--color-accent-5)}.btn--outline{background-color:transparent;color:var(--color-accent-11);border:1px solid var(--color-accent-7)}.btn--outline:hover:not(:disabled){background-color:var(--color-accent-2);border-color:var(--color-accent-8)}.btn--outline:active:not(:disabled){background-color:var(--color-accent-3)}.btn--ghost{background-color:transparent;color:var(--color-accent-11);border:1px solid transparent}.btn--ghost:hover:not(:disabled){background-color:var(--color-accent-3)}.btn--ghost:active:not(:disabled){background-color:var(--color-accent-4)}.btn--sm{min-height:32px;padding:var(--space-1) var(--space-3);font-size:var(--text-sm)}.btn--lg{min-height:52px;padding:var(--space-3) var(--space-6);font-size:var(--text-lg)}.btn--full{width:100%}.btn--success{background:var(--color-success-3);color:var(--color-success-11);border:1px solid var(--color-success-7)}.btn--danger{background:var(--color-error-3);color:var(--color-error-11);border:1px solid var(--color-error-7)}.btn--danger:hover:not(:disabled){background:var(--color-error-4)}.btn--icon{padding:var(--space-2);min-height:auto}.input-group{display:flex;flex-direction:column;gap:var(--space-1);width:100%}.input-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text)}.input-label strong{text-decoration:underline;text-underline-offset:2px}.input-label--required:after{content:" *";color:var(--color-error)}.input{display:block;width:100%;min-height:var(--touch-target-min);padding:var(--space-2) var(--space-3);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text);background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.input::placeholder{color:var(--color-text-muted)}.input:hover:not(:disabled):not(:focus){border-color:var(--color-border-strong)}.input:focus{outline:none;border-color:var(--color-accent-8);box-shadow:0 0 0 3px var(--color-accent-4)}.input:disabled{opacity:.5;cursor:not-allowed;background-color:var(--color-bg-muted)}.input--error{border-color:var(--color-error)}.input--error:focus{border-color:var(--color-error);box-shadow:0 0 0 3px var(--color-error-subtle)}.input-hint{font-size:var(--text-xs);color:var(--color-text-tertiary);margin-top:var(--space-1)}.input-error{font-size:var(--text-sm);color:var(--color-error-text)}.select{display:block;width:100%;min-height:var(--touch-target-min);padding:var(--space-2) var(--space-3);padding-right:var(--space-8);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text);background-color:var(--color-bg-surface);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2360646c' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;appearance:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.select:hover:not(:disabled):not(:focus){border-color:var(--color-border-strong)}.select:focus{outline:none;border-color:var(--color-accent-8);box-shadow:0 0 0 3px var(--color-accent-4)}.select.input--error{border-color:var(--color-error)}.select.input--error:focus{border-color:var(--color-error);box-shadow:0 0 0 3px var(--color-error-subtle)}.slider{-webkit-appearance:none;appearance:none;width:100%;height:6px;background:var(--color-surface-active);border-radius:var(--radius-full);cursor:pointer}.slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;background:var(--color-primary);border-radius:var(--radius-full);cursor:pointer;transition:transform var(--transition-fast)}.slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.slider::-moz-range-thumb{width:20px;height:20px;background:var(--color-primary);border:none;border-radius:var(--radius-full);cursor:pointer}.swatch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(40px,1fr));gap:var(--space-2)}.swatch{width:40px;height:40px;border-radius:var(--radius-md);cursor:pointer;border:2px solid transparent;transition:transform var(--transition-fast),border-color var(--transition-fast)}.swatch:hover{transform:scale(1.1)}.swatch--selected{border-color:var(--color-text);box-shadow:var(--shadow-md)}.checkbox-group{display:flex;flex-direction:column;gap:var(--space-1)}.checkbox-label{display:flex;align-items:flex-start;gap:var(--space-2);cursor:pointer;font-size:var(--text-base);color:var(--color-text)}.checkbox{width:20px;height:20px;margin-top:2px;accent-color:var(--color-primary);cursor:pointer;flex-shrink:0}.checkbox-text{flex:1}.checkbox-hint{font-size:var(--text-sm);color:var(--color-text-secondary);margin-left:28px}.custom-select{position:relative;width:100%}.custom-select__trigger{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);width:100%;min-height:var(--touch-target-min);padding:var(--space-2) var(--space-3);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text);background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.custom-select__trigger:hover:not(:disabled){border-color:var(--color-border-strong)}.custom-select__trigger:focus{outline:none;border-color:var(--color-accent-8);box-shadow:0 0 0 3px var(--color-accent-4)}.custom-select__trigger:disabled{opacity:.5;cursor:not-allowed;background-color:var(--color-bg-muted)}.custom-select--error .custom-select__trigger{border-color:var(--color-error)}.custom-select--error .custom-select__trigger:focus{border-color:var(--color-error);box-shadow:0 0 0 3px var(--color-error-subtle)}.custom-select--open .custom-select__trigger{border-color:var(--color-accent-8);box-shadow:0 0 0 3px var(--color-accent-4)}.custom-select__value{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.custom-select__value--placeholder{color:var(--color-text-muted)}.custom-select__icons{display:flex;align-items:center;gap:var(--space-1);flex-shrink:0;color:var(--color-text-secondary)}.custom-select__clear{display:flex;align-items:center;justify-content:center;width:18px;height:18px;padding:0;color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition-fast),background-color var(--transition-fast)}.custom-select__clear:hover{color:var(--color-text);background-color:var(--color-surface-active)}.custom-select__chevron{transition:transform var(--transition-fast)}.custom-select__chevron--open{transform:rotate(180deg)}.custom-select__dropdown{position:absolute;top:calc(100% + var(--space-1));left:0;right:0;z-index:50;background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);overflow:hidden;animation:customSelectFadeIn .15s ease-out}@keyframes customSelectFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.custom-select__search{position:relative;display:flex;align-items:center;padding:var(--space-2);border-bottom:1px solid var(--color-border-subtle)}.custom-select__search-icon{position:absolute;left:var(--space-3);color:var(--color-text-muted);pointer-events:none}.custom-select__search-input{width:100%;padding:var(--space-2) var(--space-3);padding-left:calc(var(--space-3) + 14px + var(--space-2));padding-right:var(--space-8);font-size:var(--text-sm);color:var(--color-text);background-color:var(--color-bg-muted);border:1px solid transparent;border-radius:var(--radius-sm);transition:border-color var(--transition-fast)}.custom-select__search-input::placeholder{color:var(--color-text-muted)}.custom-select__search-input:focus{outline:none;border-color:var(--color-accent-7);background-color:var(--color-bg-surface)}.custom-select__search-clear{position:absolute;right:var(--space-3);display:flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;color:var(--color-text-muted);background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:color var(--transition-fast),background-color var(--transition-fast)}.custom-select__search-clear:hover{color:var(--color-text);background-color:var(--color-surface-active)}.custom-select__list{max-height:240px;margin:0;padding:var(--space-1);overflow-y:auto;list-style:none}.custom-select__option{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--color-text);border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--transition-fast)}.custom-select__option:hover{background-color:var(--color-surface-hover)}.custom-select__option--highlighted{background-color:var(--color-accent-4);outline:2px solid var(--color-accent-8);outline-offset:-2px}.custom-select__option--selected{color:var(--color-accent-11);background-color:var(--color-accent-3)}.custom-select__option--selected:hover{background-color:var(--color-accent-4)}.custom-select__option--selected.custom-select__option--highlighted{background-color:var(--color-accent-5);outline:2px solid var(--color-accent-9);outline-offset:-2px}.custom-select__option-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.custom-select__option-check{flex-shrink:0;color:var(--color-accent-9)}.custom-select__no-results{padding:var(--space-4) var(--space-3);font-size:var(--text-sm);color:var(--color-text-muted);text-align:center}@media(max-width:1024px){.builder{grid-template-columns:1fr}.builder__sidebar,.builder__config{display:none}}@media(max-width:768px){.wizard-upload{grid-template-columns:1fr}.wizard-table-container{overflow-x:auto}.wizard-stats{flex-direction:column}.role-switcher{flex-direction:column;left:var(--space-4);right:var(--space-4);transform:none}.admin-nav{margin-left:0;padding-left:0;border-left:none;padding-top:var(--space-2);border-top:1px solid var(--color-border)}}.form-group{display:flex;flex-direction:column;gap:var(--space-1)}.form-group label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text)}.form-group input,.form-group select{padding:var(--space-2) var(--space-3);font-size:var(--text-base);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);transition:border-color var(--transition-fast)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-accent-8)}.form-group input:disabled,.form-group select:disabled{opacity:.6;cursor:not-allowed}.form-hint{font-size:var(--text-xs);color:var(--color-text-muted);margin:var(--space-1) 0 0}.form-hint code{font-family:var(--font-mono);background:var(--color-surface-hover);padding:0 var(--space-1);border-radius:var(--radius-sm)}.form-fieldset{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);margin:0}.form-fieldset legend{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-secondary);padding:0 var(--space-2)}.form-row{display:flex;flex-direction:row;flex-wrap:nowrap;gap:var(--space-3);align-items:flex-start;margin-bottom:var(--space-3)}.form-row:last-child{margin-bottom:0}.form-row>.form-field,.form-row>.input-group{margin-bottom:0}.form-row>.form-field--flex-1{flex:1;min-width:0}.form-row>.form-field--flex-2{flex:2;min-width:0}.form-section{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);margin:0;margin-bottom:var(--space-3);width:100%;box-sizing:border-box}.form-section__legend{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-secondary);padding:0 var(--space-2)}.form-field{display:flex;flex-direction:column;gap:var(--space-1);margin-bottom:var(--space-3)}.form-field:last-child{margin-bottom:0}.form-field label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text)}.form-field input,.form-field select,.form-field textarea{width:100%;min-height:var(--touch-target-min);padding:var(--space-2) var(--space-3);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text);background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-field input::placeholder,.form-field textarea::placeholder{color:var(--color-text-muted)}.form-field input:hover:not(:disabled):not(:focus),.form-field select:hover:not(:disabled):not(:focus),.form-field textarea:hover:not(:disabled):not(:focus){border-color:var(--color-border-strong)}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:var(--color-accent-8);box-shadow:0 0 0 3px var(--color-accent-4)}.form-field input:disabled,.form-field select:disabled,.form-field textarea:disabled{opacity:.5;cursor:not-allowed;background-color:var(--color-bg-muted)}.form-field--flex-1{flex:1}.form-field--flex-2{flex:2}.checkbox-inline{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;margin-bottom:var(--space-1)}.checkbox-inline input[type=checkbox]{width:1rem;height:1rem;cursor:pointer}.form-hint{font-size:var(--text-xs);color:var(--color-text-tertiary);margin:0}.form-stack{display:flex;flex-direction:column;width:100%}.form-actions{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-3)}.card{background-color:var(--color-bg-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-surface);padding:var(--space-6)}.card--elevated{box-shadow:var(--shadow-md);border-color:transparent}.card__title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text);margin-bottom:var(--space-2)}.card__description{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-4)}.stat-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-4);margin-bottom:var(--space-6)}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2)}.stat-card__label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary)}.stat-card__label svg{flex-shrink:0}.stat-card__value{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--color-text)}.stat-card__sub{font-size:var(--text-xs);color:var(--color-text-muted)}.stat-card--warning{border-color:var(--color-warning-7);background:var(--color-warning-2)}.stat-card--warning .stat-card__label,.stat-card--warning .stat-card__value{color:var(--color-warning-11)}.stat-card--info{border-color:var(--color-info-7);background:var(--color-info-2)}.stat-card--info .stat-card__label,.stat-card--info .stat-card__value{color:var(--color-info-11)}.stat-card--success{border-color:var(--color-success-7);background:var(--color-success-2)}.stat-card--success .stat-card__label,.stat-card--success .stat-card__value{color:var(--color-success-11)}.action-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-4)}.action-card{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.action-card:hover{border-color:var(--color-accent-7);background:var(--color-accent-2)}.action-card__content{display:flex;align-items:center;gap:var(--space-4)}.action-card__content svg{color:var(--color-accent-9);flex-shrink:0}.action-card__content h4{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text);margin:0}.action-card__content p{font-size:var(--text-sm);color:var(--color-text-secondary);margin:var(--space-1) 0 0}.action-card>svg{color:var(--color-text-muted);flex-shrink:0}.formular-card{display:flex;align-items:center;width:100%;padding:var(--space-3) var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast);text-align:left}.formular-card:hover{background:var(--color-accent-2);border-color:var(--color-accent-6)}.formular-card:focus-visible{outline:none;box-shadow:var(--focus-ring)}.formular-card--selected{background:var(--color-accent-3);border-color:var(--color-accent-7)}.formular-card__main{display:flex;align-items:center;gap:var(--space-3);width:100%}.formular-card__icon{color:var(--color-text-muted);flex-shrink:0}.formular-card__content{flex:1;min-width:0}.formular-card__name{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text)}.formular-card__meta{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-1);font-size:var(--text-xs);color:var(--color-text-secondary)}.formular-card__chevron{color:var(--color-text-muted);flex-shrink:0}.student-card{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.student-card:hover{border-color:var(--color-accent-7);background:var(--color-accent-2)}.student-card--selected{border-color:var(--color-accent-8);background:var(--color-accent-3)}.student-card--sperrvermerk{border-color:var(--color-warning-6);background:var(--color-warning-2)}.student-card--sperrvermerk:hover{background:var(--color-warning-3)}.student-card__checkbox{flex-shrink:0;margin-top:var(--space-1)}.student-card__main{display:flex;align-items:center;gap:var(--space-3);flex:1;min-width:0}.student-card__content{flex:1;min-width:0}.student-card__name{display:flex;align-items:center;gap:var(--space-2);font-weight:var(--font-medium);color:var(--color-text)}.student-card__meta{display:flex;flex-wrap:wrap;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-1)}.student-card__badges{display:flex;flex-wrap:wrap;gap:var(--space-1);margin-top:var(--space-2)}.student-card__chevron{color:var(--color-text-muted);flex-shrink:0}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--space-4)}.stack{display:flex;flex-direction:column;gap:var(--space-4)}.stack--sm{gap:var(--space-2)}.stack--lg{gap:var(--space-6)}.row{display:flex;flex-wrap:wrap;gap:var(--space-4);align-items:center}.grid{display:grid;gap:var(--space-4)}.grid--2{grid-template-columns:repeat(2,1fr)}.grid--3{grid-template-columns:repeat(3,1fr)}@media(max-width:768px){.grid--2,.grid--3{grid-template-columns:1fr}}.view-content{max-width:1200px;margin:0 auto}.view-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-6);flex-wrap:wrap}.view-header .view-title{margin-bottom:0}.view-header__actions{display:flex;align-items:center;gap:var(--space-2)}.view-title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text);margin:0}.view-subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin:var(--space-1) 0 0}.text-success{color:var(--color-success-11)}.text-warning{color:var(--color-warning-11)}.form-runner{max-width:800px;margin:0 auto;padding:var(--space-6)}.form-runner--loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--color-text-secondary)}.form-runner__header{position:relative;display:flex;flex-direction:row;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border)}.form-runner__header>.status-indicator{position:absolute;top:0;right:0}.form-runner__title-group{flex:1;min-width:0}.form-runner__title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text);margin:0 0 var(--space-1) 0}.form-runner__subtitle{font-size:var(--text-base);color:var(--color-text-secondary);margin:0}.form-runner__blocks{display:flex;flex-direction:column;gap:var(--space-6)}.form-runner__footer{display:flex;justify-content:space-between;gap:var(--space-3);margin-top:var(--space-8);padding-top:var(--space-6);border-top:1px solid var(--color-border)}.form-runner__back{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-secondary);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.form-runner__back:hover{background:var(--color-surface-raised);border-color:var(--color-border);color:var(--color-text-primary)}.form-runner__back:active{background:var(--color-surface-hover)}.form-runner__progress{height:4px;background:var(--color-surface-active);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--space-4)}.form-runner__progress-bar{height:100%;background:var(--color-accent-9);border-radius:var(--radius-full);transition:width .3s ease}.save-status{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);border-radius:var(--radius-md);white-space:nowrap}.save-status__dot{width:8px;height:8px;border-radius:var(--radius-full);flex-shrink:0}.save-status--idle{background-color:var(--color-surface-hover);color:var(--color-text-secondary)}.save-status--idle .save-status__dot{background-color:var(--color-border-strong)}.save-status--dirty{background-color:var(--color-warning-subtle);color:var(--color-warning-text)}.save-status--dirty .save-status__dot{background-color:var(--color-warning)}.save-status--saving{background-color:var(--color-accent-3);color:var(--color-accent-11)}.save-status--saving .save-status__dot{background-color:var(--color-accent-9);animation:pulse 1s ease-in-out infinite}.save-status--saved{background-color:var(--color-success-subtle);color:var(--color-success-text)}.save-status--saved .save-status__dot{background-color:var(--color-success)}.save-status--error{background-color:var(--color-error-subtle);color:var(--color-error-text)}.save-status--error .save-status__dot{background-color:var(--color-error)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.status-indicator{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-sm);color:var(--color-text-secondary)}.status-indicator__dot{width:8px;height:8px;border-radius:var(--radius-full);flex-shrink:0;background-color:var(--color-border-strong)}.status-indicator__text{white-space:nowrap}.status-indicator--pending .status-indicator__dot{background-color:var(--color-warning)}.status-indicator--saving .status-indicator__dot{background-color:var(--color-accent-9);animation:pulse 1s ease-in-out infinite}.status-indicator--offline{color:var(--color-warning-text)}.status-indicator--offline .status-indicator__dot{background-color:var(--color-warning)}.status-indicator--error{color:var(--color-error-text)}.status-indicator--error .status-indicator__dot{background-color:var(--color-error)}.sync-status{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);border-radius:var(--radius-md);white-space:nowrap}.sync-status__icon{flex-shrink:0}.sync-status__badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 var(--space-1);font-size:var(--text-xs);font-weight:var(--font-semibold);border-radius:var(--radius-full);background:currentColor;color:#fff}.sync-status--synced{background-color:var(--color-success-subtle);color:var(--color-success-text)}.sync-status--syncing{background-color:var(--color-accent-3);color:var(--color-accent-11)}.sync-status--syncing .sync-status__icon{animation:pulse 1s ease-in-out infinite}.sync-status--pending{background-color:var(--color-warning-subtle);color:var(--color-warning-text)}.sync-status--offline{background-color:var(--color-surface-hover);color:var(--color-text-secondary)}.sync-status--error{background-color:var(--color-error-subtle);color:var(--color-error-text)}.form-runner__status-group{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}@media(max-width:768px){.form-runner{padding:var(--space-4)}.form-runner__header{flex-direction:column;gap:var(--space-3)}.form-runner__title-group{width:100%}.form-runner__title{font-size:var(--text-xl)}.form-runner__subtitle{font-size:var(--text-sm)}.form-runner__footer{flex-wrap:wrap}}@media(max-width:480px){.form-runner{padding:var(--space-3)}.form-runner__title{font-size:var(--text-lg)}.form-runner__back span{display:none}}.form-block{background-color:var(--color-bg-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-surface);padding:var(--space-6)}.form-block--custom{border-style:dashed}.form-block__header{margin-bottom:var(--space-5)}.form-block__title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text);margin:0 0 var(--space-1) 0}.form-block__description{font-size:var(--text-sm);color:var(--color-text-secondary);margin:0}.form-block__hint{font-size:var(--text-sm);margin:var(--space-2) 0 0 0}.form-block__hint--required{display:inline-flex;align-items:center;gap:var(--space-1);color:var(--color-warning-text);background-color:var(--color-warning-subtle);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}.form-block__content{display:flex;flex-direction:column;gap:var(--space-4)}.form-grid{display:grid;gap:var(--space-4)}.form-grid--2col{grid-template-columns:1fr 1fr}.form-grid--3col{grid-template-columns:1fr 1fr 1fr}@media(max-width:640px){.form-grid--2col,.form-grid--3col{grid-template-columns:1fr}}.info-block{padding:var(--space-4);background-color:var(--color-info-subtle);border:1px solid var(--color-info-border);border-radius:var(--radius-md);border-left:4px solid var(--color-info)}.info-block__title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text);margin:0 0 var(--space-2) 0}.info-block__content{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:var(--leading-relaxed)}.info-block__content p{margin:0 0 var(--space-2) 0}.info-block__content p:last-child{margin-bottom:0}.info-block__content strong{color:var(--color-text);font-weight:var(--font-semibold)}.info-block__hint{font-size:var(--text-xs);color:var(--color-text-tertiary);margin:var(--space-2) 0 0 0;font-style:italic}.validation-summary{background-color:var(--color-error-subtle);border:1px solid var(--color-error);border-radius:var(--radius-md);padding:var(--space-4);margin-bottom:var(--space-6)}.validation-summary__title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-error-text);margin:0 0 var(--space-2) 0}.validation-summary__list{margin:0;padding-left:var(--space-5)}.validation-summary__item{font-size:var(--text-sm);color:var(--color-error-text);margin-bottom:var(--space-1)}.validation-summary__item:last-child{margin-bottom:0}.view-toggle{position:fixed;top:var(--space-4);right:var(--space-4);z-index:100;display:flex;gap:var(--space-1);padding:var(--space-1);background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.builder{display:grid;grid-template-columns:280px 1fr 300px;min-height:100vh;background-color:var(--color-bg-muted)}.builder__sidebar{background-color:var(--color-bg-surface);border-right:1px solid var(--color-border);padding:var(--space-4);overflow-y:auto}.builder__sidebar-header{padding-bottom:var(--space-4);margin-bottom:var(--space-4);border-bottom:1px solid var(--color-border)}.builder__sidebar-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text);margin:0}.builder__blocks-section{margin-bottom:var(--space-6)}.builder__blocks-category{font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin:0 0 var(--space-3) 0}.builder-block-item{display:flex;align-items:flex-start;gap:var(--space-3);width:100%;padding:var(--space-3);margin-bottom:var(--space-2);background-color:var(--color-bg-muted);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:all var(--transition-fast)}.builder-block-item:hover{border-color:var(--color-accent-7);background-color:var(--color-accent-2)}.builder-block-item__icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);flex-shrink:0}.builder-block-item__icon--system{background-color:var(--color-surface-active);color:var(--color-text-secondary)}.builder-block-item__icon--custom{background-color:var(--color-accent-3);color:var(--color-accent-11)}.builder-block-item__content{flex:1;min-width:0}.builder-block-item__name{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text);margin-bottom:var(--space-1)}.builder-block-item__desc{display:block;font-size:var(--text-xs);color:var(--color-text-secondary);line-height:var(--leading-snug)}.builder-block-item__add{color:var(--color-accent-9);flex-shrink:0;opacity:0;transition:opacity var(--transition-fast)}.builder-block-item:hover .builder-block-item__add{opacity:1}.builder__main{padding:var(--space-6);overflow-y:auto}.builder__canvas-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.builder__canvas-title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--color-text);margin:0}.builder__canvas-actions{display:flex;gap:var(--space-2)}.builder__canvas{min-height:400px;background-color:var(--color-bg-surface);border:2px dashed var(--color-border);border-radius:var(--radius-surface);padding:var(--space-4)}.builder__canvas-empty{display:flex;align-items:center;justify-content:center;height:300px;color:var(--color-text-secondary);font-size:var(--text-base)}.builder__canvas-blocks{display:flex;flex-direction:column;gap:var(--space-3)}.canvas-block{position:relative;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);padding-left:calc(var(--space-4) + 3px);background-color:var(--color-bg-muted);border:1px solid var(--color-border);border-radius:var(--radius-surface);cursor:pointer;transition:all var(--transition-fast);overflow:hidden}.canvas-block:before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background-color:var(--canvas-block-accent, var(--color-border-strong))}.canvas-block:hover{border-color:var(--color-accent-7)}.canvas-block--selected{border-color:var(--color-accent-9);box-shadow:0 0 0 3px var(--color-accent-4)}.canvas-block--system{--canvas-block-accent: var(--color-border-strong)}.canvas-block--custom{--canvas-block-accent: var(--color-accent-9)}.canvas-block__drag{color:var(--color-text-secondary);cursor:grab}.canvas-block__content{flex:1}.canvas-block__name{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-base);font-weight:var(--font-medium);color:var(--color-text)}.canvas-block__lock{color:var(--color-text-muted)}.canvas-block__type{display:block;font-size:var(--text-xs);color:var(--color-text-secondary);margin-top:var(--space-1)}.canvas-block__remove{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.canvas-block__remove:hover{background-color:var(--color-error-subtle);color:var(--color-error)}.builder__config{background-color:var(--color-bg-surface);border-left:1px solid var(--color-border);padding:var(--space-4);overflow-y:auto}.builder-config{padding:var(--space-4)}.builder-config--empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;color:var(--color-text-secondary);text-align:center}.builder-config--empty p{margin-top:var(--space-2);font-size:var(--text-sm)}.builder-config__title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text);margin:0 0 var(--space-4) 0}.builder-config__hint{font-size:var(--text-sm);color:var(--color-text-secondary);background-color:var(--color-surface-hover);padding:var(--space-3);border-radius:var(--radius-md);line-height:var(--leading-relaxed)}.builder-config__field{margin-bottom:var(--space-4)}.builder-json{margin-top:var(--space-6);background-color:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-surface);padding:var(--space-4)}.builder-json__title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-secondary);margin:0 0 var(--space-3) 0}.builder-json__code{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text);background-color:var(--color-background);padding:var(--space-3);border-radius:var(--radius-md);overflow-x:auto;margin:0}.builder-section{margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--color-border-subtle)}.builder-section__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-4)}.builder-section__title{display:flex;align-items:center;gap:var(--space-2);color:var(--color-text-secondary)}.builder-section__title h2{margin:0;font-size:var(--text-base);font-weight:var(--font-medium);color:var(--color-text-secondary)}.builder-section__content{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.schuljahr-card{display:flex;align-items:center;padding:var(--space-3) var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.schuljahr-card:hover{border-color:var(--color-accent-7);background:var(--color-accent-2)}.schuljahr-card--selected{border-color:var(--color-accent-8);background:var(--color-accent-3)}.schuljahr-card__main{display:flex;align-items:center;gap:var(--space-3);flex:1}.schuljahr-card__content{flex:1;min-width:0}.schuljahr-card__name{font-weight:var(--font-medium);color:var(--color-text)}.schuljahr-card__meta{display:flex;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-muted)}.schuljahr-card__chevron{color:var(--color-text-muted);flex-shrink:0}.schuljahr-cell{display:flex;flex-direction:column;gap:var(--space-1)}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-6);flex-wrap:wrap}.toolbar__info{display:flex;align-items:center;gap:var(--space-2)}.search-box{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);min-width:200px}.search-box input{flex:1;border:none;background:transparent;font-size:var(--text-sm);color:var(--color-text)}.search-box input::placeholder{color:var(--color-text-muted)}.search-box input:focus{outline:none}.search-box svg{color:var(--color-text-muted);flex-shrink:0}.table-wrapper{display:none;overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface)}@media(min-width:768px){.table-wrapper{display:block}}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:var(--space-3) var(--space-4);text-align:left;border-bottom:1px solid var(--color-border)}.table th{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-secondary);background:var(--color-surface-raised)}.table tbody tr:last-child td{border-bottom:none}.table-row--clickable{cursor:pointer;transition:background-color var(--transition-fast)}.card-list{display:flex;flex-direction:column;gap:var(--space-2)}@media(min-width:768px){.card-list{display:none}}.table-wrapper{overflow-x:auto;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.data-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.data-table th{padding:var(--space-3) var(--space-4);text-align:left;font-weight:var(--font-medium);color:var(--color-text-secondary);background:var(--color-surface-raised);border-bottom:1px solid var(--color-border);white-space:nowrap}.data-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-subtle);vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.table-row--clickable{cursor:pointer;transition:background var(--transition-fast)}.table-row--clickable:hover{background:var(--color-accent-2)}.table-row--selected{background:var(--color-accent-3)}.table-row--selected:hover{background:var(--color-accent-4)}@media(max-width:767px){.table-wrapper{display:none}}.table td.table-cell--checkbox,.table th.table-cell--checkbox{width:48px;padding-left:var(--space-3);padding-right:var(--space-2)}.table-checkbox{width:18px;height:18px;cursor:pointer;accent-color:var(--color-accent-9)}.panel-form{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-4)}.panel-form__actions{display:flex;justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-4);border-top:1px solid var(--color-border)}.panel-form__divider{height:1px;background:var(--color-border);margin:var(--space-4) 0}.panel-form__section{padding:var(--space-3) 0}.panel-form__section h4{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text);margin:0 0 var(--space-2)}.panel-content{padding:var(--space-4)}.panel-section{padding:var(--space-4) 0;border-bottom:1px solid var(--color-border)}.panel-section:first-child{padding-top:0}.panel-section:last-child{border-bottom:none}.panel-section__title,.panel-section-title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-secondary);margin:0 0 var(--space-3)}.detail-header{display:flex;flex-wrap:wrap;gap:var(--space-2)}.detail-list{display:flex;flex-direction:column;gap:var(--space-2);margin:0}.detail-list__item{display:flex;flex-direction:column;gap:var(--space-1)}.detail-list__item dt{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:var(--font-medium)}.detail-list__item dd{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text);margin:0}.detail-list__item dd svg{color:var(--color-text-muted);flex-shrink:0}.invitation-code-box{background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4)}.invitation-code-box__code{display:flex;flex-direction:column;gap:var(--space-1)}.invitation-code-box__label{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:var(--font-medium)}.invitation-code-box__value{display:flex;align-items:center;gap:var(--space-2)}.invitation-code-box__value code{font-family:var(--font-mono);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text);background:var(--color-surface);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);letter-spacing:.1em}.invitation-code-box__meta{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-2)}.invitation-code-box__actions{display:flex;gap:var(--space-2);margin-top:var(--space-3)}.timeline{display:flex;flex-direction:column;gap:var(--space-3);position:relative;padding-left:var(--space-4)}.timeline:before{content:"";position:absolute;left:5px;top:6px;bottom:6px;width:2px;background:var(--color-border)}.timeline__item{display:flex;align-items:flex-start;gap:var(--space-3);position:relative}.timeline__marker{position:absolute;left:calc(-1 * var(--space-4) - 1px);top:4px;width:12px;height:12px;border-radius:50%;background:var(--color-surface-active);border:2px solid var(--color-surface);z-index:1}.timeline__item--done .timeline__marker{background:var(--color-success-9)}.timeline__content{flex:1;min-width:0}.timeline__title{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text)}.timeline__item--done .timeline__title{color:var(--color-success-11)}.timeline__date{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-1)}.filter-bar{display:flex;flex-wrap:wrap;align-items:flex-end;gap:var(--space-4);margin-bottom:var(--space-4);padding:var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.filter-bar__filters{display:flex;flex-wrap:wrap;gap:var(--space-2);flex:1}.filter-bar__actions{display:flex;gap:var(--space-2);margin-left:auto}.filter-group{display:flex;flex-direction:column;gap:var(--space-1);min-width:140px}.filter-group label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.filter-group select{padding:var(--space-2) var(--space-3);padding-right:var(--space-8);font-size:var(--text-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-2) center}.filter-group select:hover{border-color:var(--color-border-hover)}.filter-group select:focus{outline:none;border-color:var(--color-accent-7);box-shadow:0 0 0 2px var(--color-accent-a3)}.filter-checkbox{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--color-text-secondary);cursor:pointer;border:1px solid transparent;border-radius:var(--radius-md);transition:all .15s ease;white-space:nowrap}.filter-checkbox:hover{background:var(--color-surface-hover);color:var(--color-text)}.filter-checkbox:has(input:checked){background:var(--color-accent-a2);color:var(--color-accent-11);border-color:var(--color-accent-a5)}.filter-checkbox input{display:none}.filter-search{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);flex:1;min-width:180px;max-width:300px}.filter-search svg{flex-shrink:0;color:var(--color-text-tertiary)}.filter-search input{flex:1;border:none;background:transparent;font-size:var(--text-sm);color:var(--color-text);outline:none;box-shadow:none;min-width:0}.filter-search input:focus{outline:none;border:none;box-shadow:none}.filter-search input::placeholder{color:var(--color-text-tertiary)}.filter-search:focus-within{border-color:var(--color-accent-7);box-shadow:0 0 0 2px var(--color-accent-a3)}@media(max-width:640px){.filter-bar{flex-direction:column;align-items:stretch}.filter-group{min-width:100%}.filter-search{max-width:none}}.stats-bar{display:flex;flex-wrap:wrap;gap:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--color-surface-raised);border-radius:var(--radius-md);margin-bottom:var(--space-4)}.stats-bar__item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary)}.stats-bar__value{font-weight:var(--font-semibold);color:var(--color-text)}.stats-bar__label{color:inherit}.stats-bar__item--muted,.stats-bar__item--muted .stats-bar__value{color:var(--color-text-tertiary)}.stats-bar__item--info,.stats-bar__item--info .stats-bar__value{color:var(--color-accent-11)}.stats-bar__item--warning,.stats-bar__item--warning .stats-bar__value{color:var(--color-warning-11)}.stats-bar__item--success,.stats-bar__item--success .stats-bar__value{color:var(--color-success-11)}.stats-bar__item--danger,.stats-bar__item--danger .stats-bar__value{color:var(--color-danger-11)}.bulk-actions{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-bottom:var(--space-5)}.info-banner,.warning-banner{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);margin-bottom:var(--space-6)}.info-banner{background:var(--color-info-2);border:1px solid var(--color-info-6);color:var(--color-info-11)}.info-banner svg{flex-shrink:0}.warning-banner{background:var(--color-warning-2);border:1px solid var(--color-warning-6);color:var(--color-warning-11)}.warning-banner svg{flex-shrink:0}.warning-banner .btn{margin-left:auto;flex-shrink:0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-8) var(--space-4);background:var(--color-surface-raised);border:1px dashed var(--color-border);border-radius:var(--radius-lg)}.empty-state svg{margin-bottom:var(--space-4)}.empty-state h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text);margin:0 0 var(--space-2)}.empty-state p{font-size:var(--text-sm);margin:0}.status-dot{display:inline-block;width:10px;height:10px;border-radius:50%;flex-shrink:0}.status-dot--success{background:var(--color-success-9)}.status-dot--warning{background:var(--color-warning-9)}.status-dot--danger{background:var(--color-error-9)}.status-dot--neutral{background:var(--color-border-strong)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);font-size:var(--text-xs);font-weight:var(--font-medium);border-radius:var(--radius-full);white-space:nowrap}.badge--success{background:var(--color-success-3);color:var(--color-success-11)}.badge--warning{background:var(--color-warning-3);color:var(--color-warning-11)}.badge--danger{background:var(--color-error-3);color:var(--color-error-11)}.badge--neutral{background:var(--color-surface-active);color:var(--color-text-secondary)}.badge--subtle{background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary)}.error-box{padding:var(--space-4);background:var(--color-error-2);border:1px solid var(--color-error-6);border-radius:var(--radius-md);color:var(--color-error-11)}.error-box p{margin:0 0 var(--space-3)}.error-message{padding:var(--space-3);background:var(--color-error-2);border:1px solid var(--color-error-6);border-radius:var(--radius-md);color:var(--color-error-11);font-size:var(--text-sm)}.info-banner--compact{padding:var(--space-2) var(--space-3);margin-bottom:0}.badge--primary{background:var(--color-accent-3);color:var(--color-accent-11)}.badge--info{background:var(--color-info-3);color:var(--color-info-11)}.warning-banner--compact{padding:var(--space-2) var(--space-3);margin-bottom:0;align-items:flex-start}.warning-banner--compact strong{display:block;margin-bottom:var(--space-1)}.warning-banner--compact p{font-size:var(--text-sm);margin:0;line-height:var(--leading-snug)}.success-banner{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);margin-bottom:var(--space-6);background:var(--color-success-2);border:1px solid var(--color-success-6);color:var(--color-success-11)}.success-banner svg{flex-shrink:0}.success-banner--compact{padding:var(--space-2) var(--space-3);margin-bottom:0;align-items:flex-start}.success-banner--compact strong{display:block;margin-bottom:var(--space-1)}.success-banner--compact p{font-size:var(--text-sm);margin:0;line-height:var(--leading-snug)}.wizard{max-width:1000px;margin:0 auto;padding:var(--space-8) var(--space-6)}.wizard__header{text-align:center;margin-bottom:var(--space-8)}.wizard__title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text);margin:0 0 var(--space-2) 0}.wizard__subtitle{font-size:var(--text-base);color:var(--color-text-secondary);margin:0}.wizard__school-year{font-size:var(--text-sm);color:var(--color-text-secondary);margin:var(--space-2) 0 0 0}.wizard__school-year strong{color:var(--color-accent)}.wizard-steps{display:flex;align-items:center;justify-content:center;gap:var(--space-2);margin-bottom:var(--space-8)}.wizard-step{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background-color:var(--color-surface-hover);border-radius:var(--radius-full);color:var(--color-text-secondary);transition:all var(--transition-fast)}.wizard-step--active{background-color:var(--color-primary);color:var(--color-primary-contrast)}.wizard-step--done{background-color:var(--color-success-9);color:#fff}.wizard-step__num{display:flex;align-items:center;justify-content:center;width:24px;height:24px;font-size:var(--text-sm);font-weight:var(--font-semibold);background-color:#fff3;border-radius:var(--radius-full)}.wizard-step__label{font-size:var(--text-sm);font-weight:var(--font-medium)}.wizard-step__line{width:40px;height:2px;background-color:var(--color-border)}.wizard-upload{display:grid;grid-template-columns:1fr auto;gap:var(--space-6);align-items:start}.wizard-upload__dropzone{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12);background-color:var(--color-bg-surface);border:2px dashed var(--color-border);border-radius:var(--radius-surface);text-align:center;cursor:pointer;transition:all var(--transition-fast)}.wizard-upload__dropzone:hover{border-color:var(--color-accent-7);background-color:var(--color-accent-2)}.wizard-upload__icon{color:var(--color-accent-9);margin-bottom:var(--space-4)}.wizard-upload__title{font-size:var(--text-lg);font-weight:var(--font-medium);color:var(--color-text);margin:0 0 var(--space-2) 0}.wizard-upload__subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin:0}.wizard-upload__input{position:absolute;inset:0;opacity:0;cursor:pointer}.wizard-upload__processing{display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.wizard-upload__spinner{width:48px;height:48px;border:3px solid var(--color-accent-4);border-top-color:var(--color-accent-9);border-radius:var(--radius-full);animation:spin 1s linear infinite}.wizard-upload__info{background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-surface);padding:var(--space-4)}.wizard-upload__info h4{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text);margin:0 0 var(--space-3) 0}.wizard-upload__info ul{list-style:none;padding:0;margin:0}.wizard-upload__info li{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary);padding:var(--space-2) 0}.wizard-alert{display:flex;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-surface);margin-bottom:var(--space-6)}.wizard-alert--critical,.wizard-alert--error{background-color:var(--color-error-subtle);border:1px solid var(--color-error);color:var(--color-error-text)}.wizard-alert--warning{background-color:var(--color-warning-subtle);border:1px solid var(--color-warning);color:var(--color-warning-text)}.wizard-alert__content ul{margin:var(--space-2) 0 0 0;padding-left:var(--space-4);font-size:var(--text-sm)}.wizard-alert__content strong{display:block;margin-bottom:var(--space-1)}.wizard-alert__content p{margin:0;font-size:var(--text-sm)}.wizard-encoding{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-4);background-color:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-surface);margin-bottom:var(--space-4)}.wizard-encoding__label{font-size:var(--text-sm);color:var(--color-text-secondary)}.wizard-encoding__label strong{color:var(--color-text);font-family:var(--font-mono)}.wizard-stats{display:flex;gap:var(--space-4);margin-bottom:var(--space-6)}.wizard-stat{display:flex;align-items:center;gap:var(--space-3);flex:1;padding:var(--space-4);background-color:var(--color-bg-surface);border-radius:var(--radius-surface);border:1px solid var(--color-border)}.wizard-stat--ok{border-left:3px solid var(--color-success)}.wizard-stat--blocked{border-left:3px solid var(--color-error)}.wizard-stat__value{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text)}.wizard-stat__label{font-size:var(--text-sm);color:var(--color-text-secondary)}.wizard-table-container{background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-surface);overflow:hidden;margin-bottom:var(--space-6)}.wizard-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.wizard-table th{padding:var(--space-3) var(--space-4);text-align:left;font-weight:var(--font-semibold);color:var(--color-text-secondary);background-color:var(--color-surface-raised);border-bottom:1px solid var(--color-border)}.wizard-table td{padding:var(--space-3) var(--space-4);color:var(--color-text);border-bottom:1px solid var(--color-border-subtle)}.wizard-table tr:last-child td{border-bottom:none}.wizard-table__row--blocked{background-color:var(--color-error-subtle)}.wizard-table__row--blocked td{color:var(--color-error-text)}.wizard-badge{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-full)}.wizard-badge--ok{background-color:var(--color-success-subtle);color:var(--color-success)}.wizard-badge--warning{background-color:var(--color-warning-subtle);color:var(--color-warning)}.wizard-badge--blocked{background-color:var(--color-error-subtle);color:var(--color-error)}.wizard-sperrvermerk{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-error)}.wizard-sperrvermerk--nein{color:var(--color-text-secondary);font-weight:var(--font-normal)}.wizard-actions{display:flex;justify-content:space-between;gap:var(--space-4)}.wizard-content--centered{display:flex;justify-content:center}.wizard-success{text-align:center;padding:var(--space-8)}.wizard-success__icon{color:var(--color-success);margin-bottom:var(--space-4)}.wizard-success__title{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text);margin:0 0 var(--space-2) 0}.wizard-success__text{font-size:var(--text-base);color:var(--color-text-secondary);margin:0 0 var(--space-4) 0}.wizard-success__hint{font-size:var(--text-sm);color:var(--color-text-muted);margin:0 0 var(--space-6) 0}.wizard-success__actions{display:flex;justify-content:center;gap:var(--space-4)}.login-container{display:flex;align-items:center;justify-content:center;flex:1;min-height:100vh;min-height:100dvh;padding:var(--space-4)}.parent-shell__content .login-container{min-height:0}.login-card{width:100%;max-width:420px;background-color:var(--color-bg-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-surface);padding:var(--space-8);box-shadow:var(--shadow-lg)}.login-card--wide{max-width:520px}.login-header{text-align:center;margin-bottom:var(--space-6)}.login-header h1{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text);margin:var(--space-4) 0 var(--space-2)}.login-icon{color:var(--color-accent-9)}.login-icon--success{color:var(--color-success)}.login-subtitle{font-size:var(--text-base);color:var(--color-text-secondary);margin:0}.login-footer{margin-top:var(--space-6);padding-top:var(--space-4);border-top:1px solid var(--color-border-subtle);text-align:center;font-size:var(--text-sm);color:var(--color-text-secondary)}.login-footer a{color:var(--color-accent-11);text-decoration:underline}.login-footer a:hover{color:var(--color-accent-12)}.login-divider{display:flex;align-items:center;gap:var(--space-4);margin:var(--space-6) 0;color:var(--color-text-secondary);font-size:var(--text-sm)}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--color-border-subtle)}.login-card .auth-success,.login-card .auth-error{margin-top:var(--space-4)}.login-card .auth-info{margin-top:var(--space-3)}.auth-hint{font-size:var(--text-sm);color:var(--color-text-secondary)}.role-switcher{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background-color:color-mix(in srgb,var(--color-bg) 80%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--color-border)}.role-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);font-weight:var(--font-medium);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);background-color:transparent;color:var(--color-text-secondary)}.role-btn:hover{color:var(--color-text);background-color:var(--color-surface-active)}.role-btn--active{background-color:var(--color-accent-9);color:#fff}.admin-nav{display:flex;gap:var(--space-1);margin-left:var(--space-3);padding-left:var(--space-3);border-left:1px solid var(--color-border)}.admin-info{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--color-text-secondary);background-color:var(--color-surface-hover);border-radius:var(--radius-md)}.admin-passkey-view{min-height:100vh;background-color:var(--color-bg-muted)}.admin-passkey-header{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background-color:var(--color-bg-surface);border-bottom:1px solid var(--color-border)}.admin-passkey-header .back-button{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--color-text-secondary);background:none;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast)}.admin-passkey-header .back-button:hover{background-color:var(--color-surface-hover)}.admin-passkey-header .header-title{display:flex;align-items:center;gap:var(--space-3)}.admin-passkey-header .header-title h1{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--color-text);margin:0}.admin-passkey-header .header-title svg{color:var(--color-accent-9)}.admin-passkey-main{max-width:600px;margin:0 auto;padding:var(--space-6) var(--space-4)}.admin-passkey-intro{font-size:var(--text-base);color:var(--color-text-secondary);line-height:var(--leading-relaxed);margin:0 0 var(--space-6)}.admin-passkey-list{margin-bottom:var(--space-6)}.admin-passkey-register{padding-top:var(--space-4);border-top:1px solid var(--color-border)}.brand-grid{display:grid;gap:var(--space-6)}@media(min-width:768px){.brand-grid{grid-template-columns:1fr 1fr;align-items:start}}.parent-data-preview{display:flex;flex-direction:column;gap:var(--space-4);margin-top:var(--space-3);padding:var(--space-3);background:var(--color-bg-muted);border-radius:var(--radius-md);max-height:400px;overflow-y:auto}.parent-data-section{display:flex;flex-direction:column;gap:var(--space-2)}.parent-data-section__title{font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin:0;padding-bottom:var(--space-1);border-bottom:1px solid var(--color-border)}.parent-data-list{display:flex;flex-direction:column;gap:var(--space-1);margin:0}.parent-data-list__item{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2);font-size:var(--text-sm)}.parent-data-list__item dt{color:var(--color-text-secondary);overflow-wrap:break-word}.parent-data-list__item dd{margin:0;color:var(--color-text);text-align:right;overflow-wrap:break-word}.review-layout{display:flex;flex-direction:column;flex:1;min-height:0}.review-layout__list{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.review-layout__content{flex:1;overflow-y:auto;min-height:0}@media(min-width:1024px){.review-layout--split{display:grid;grid-template-columns:280px 1fr}.review-layout--split .review-layout__list{border-right:1px solid var(--color-border)}.review-layout__detail{overflow:hidden;background:var(--color-bg)}.review-layout__backdrop{display:none}}@media(max-width:1023px){.review-layout__detail{position:fixed;inset:0;z-index:200;background:var(--color-bg);overflow:hidden}.review-layout__backdrop{position:fixed;inset:0;z-index:199;background:#00000080}.review-layout--split .review-layout__list{display:none}}.review-compact-list{display:flex;flex-direction:column}.review-compact-list__item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);cursor:pointer;border-bottom:1px solid var(--color-border);transition:background-color var(--transition-fast)}.review-compact-list__item:hover{background-color:var(--color-surface-hover)}.review-compact-list__item--selected{background-color:var(--color-accent-3)}.review-compact-list__item strong{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.review-detail{display:flex;flex-direction:column;height:100%;min-height:0}.review-detail__header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);border-bottom:1px solid var(--color-border);background:var(--color-bg);flex-shrink:0}.review-detail__back{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-2);background:none;border:none;color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.review-detail__back:hover{background:var(--color-surface-active);color:var(--color-text)}@media(min-width:1024px){.review-detail__back-text{display:none}}@media(max-width:1023px){.review-detail__close{display:none}}.review-detail__title{flex:1;display:flex;align-items:center;gap:var(--space-3);min-width:0}.review-detail__title h2{font-size:var(--text-lg);font-weight:var(--font-semibold);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.review-detail__close{padding:var(--space-2);background:none;border:none;color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.review-detail__close:hover{background:var(--color-surface-active);color:var(--color-text)}.review-detail__nav{display:flex;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);background:var(--color-surface-raised);flex-shrink:0}.review-detail__content{flex:1;overflow-y:auto;padding:var(--space-4);min-height:0}.review-detail__meta-grid{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-6)}@media(min-width:768px){.review-detail__meta-grid{display:grid;grid-template-columns:1fr 1fr;align-items:start}}.review-detail__section{margin-bottom:var(--space-6)}.review-detail__meta-grid .review-detail__section{margin-bottom:0}.review-detail__section--card{padding:var(--space-4);background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.review-detail__section--card h3{margin-top:0}.review-detail__section h3{font-size:var(--text-base);font-weight:var(--font-semibold);margin:0 0 var(--space-3) 0;color:var(--color-text)}.review-detail__data{display:flex;flex-direction:column;gap:var(--space-2)}.review-detail__row{display:flex;gap:var(--space-3);padding:var(--space-2) 0;border-bottom:1px solid var(--color-border)}.review-detail__row dt{flex:0 0 120px;font-size:var(--text-sm);color:var(--color-text-secondary)}.review-detail__row dd{flex:1;font-size:var(--text-sm);margin:0}.review-detail__sources{display:flex;flex-direction:column;gap:var(--space-2)}.review-detail__source{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);background:var(--color-surface-raised);color:var(--color-text-secondary)}.review-detail__source svg{opacity:.4}.review-detail__source--available{background:var(--color-green-2);color:var(--color-green-11)}.review-detail__source--available svg{opacity:1}.review-detail__source span:first-of-type{flex:1}.review-detail__source-date{font-size:var(--text-xs);color:var(--color-text-tertiary)}.review-detail__edit-btn{margin-top:var(--space-3);align-self:flex-start}.review-detail__asv-warning{display:flex;gap:var(--space-3);padding:var(--space-4);background:var(--color-warning-subtle);border:1px solid var(--color-warning-text);border-radius:var(--radius-lg);color:var(--color-warning-text)}.review-detail__asv-warning>svg{flex-shrink:0;margin-top:2px}.review-detail__asv-warning-content{display:flex;flex-direction:column;gap:var(--space-2)}.review-detail__asv-warning-content strong{font-weight:600}.review-detail__asv-missing{margin:0;padding-left:var(--space-4);font-size:var(--font-size-sm)}.review-detail__asv-missing li{margin:var(--space-1) 0}.review-detail__asv-warning .btn{align-self:flex-start;margin-top:var(--space-1)}.review-detail__asv-warning--inline{margin-top:var(--space-4)}.review-detail__section--placeholder{margin-top:var(--space-6)}.placeholder-box{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-8);border:2px dashed var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface-raised);text-align:center}.placeholder-box svg{color:var(--color-text-tertiary)}.placeholder-box h4{margin:0;font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text-secondary)}.placeholder-box p{margin:0;font-size:var(--text-sm);color:var(--color-text-tertiary);max-width:400px}.review-detail__footer{display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);padding:var(--space-4);border-top:1px solid var(--color-border);background:var(--color-bg);flex-shrink:0}.review-detail__auto-save{display:flex;align-items:center;gap:var(--space-2);color:var(--color-text-muted);font-size:var(--text-sm)}.review-detail__footer-actions{display:flex;align-items:center;gap:var(--space-3);margin-left:auto}.review-detail__conflict-hint{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);color:var(--color-warning-text);background:var(--color-warning-subtle);font-size:var(--text-sm);font-weight:var(--font-medium)}.review-layout--split .filter-bar{padding:var(--space-2) var(--space-3);margin:0;border-radius:0;border:none;border-bottom:1px solid var(--color-border);background:var(--color-bg)}.review-layout--split .filter-bar .filter-search{flex:1}.review-layout--split .filter-bar .filter-group{min-width:auto}.review-layout--split .filter-bar .filter-group select{padding:var(--space-1) var(--space-2);font-size:var(--text-xs)}.review-detail__loading,.review-detail__error,.review-detail__approved,.review-detail__no-parent{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-6);text-align:center;color:var(--color-text-secondary)}.review-detail__no-parent .review-detail__asv-warning{align-self:stretch;text-align:left}.review-detail__loading{flex-direction:row}.review-detail__error{color:var(--color-red-11)}.review-detail__approved-icon,.review-detail__no-parent-icon{color:var(--color-border-strong)}.review-detail__approved h4,.review-detail__no-parent h4{margin:0;color:var(--color-text-primary)}.review-detail__approved p,.review-detail__no-parent p{margin:0;max-width:400px}.review-detail__save-error{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);background:var(--color-red-2);border:1px solid var(--color-red-6);border-radius:var(--radius-md);color:var(--color-red-11);font-size:var(--text-sm)}.address-autocomplete{position:relative;width:100%}.address-autocomplete__input-wrapper{position:relative;display:flex;align-items:center}.address-autocomplete__input{width:100%;min-height:var(--touch-target-min);padding:var(--space-2) var(--space-3);padding-right:calc(var(--space-3) + 16px + var(--space-2));font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text);background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.address-autocomplete__input::placeholder{color:var(--color-text-muted)}.address-autocomplete__input:hover:not(:disabled){border-color:var(--color-border-strong)}.address-autocomplete__input:focus{outline:none;border-color:var(--color-accent-8);box-shadow:0 0 0 3px var(--color-accent-4)}.address-autocomplete__input:disabled{opacity:.5;cursor:not-allowed;background-color:var(--color-bg-muted)}.address-autocomplete--error .address-autocomplete__input{border-color:var(--color-error)}.address-autocomplete--error .address-autocomplete__input:focus{box-shadow:0 0 0 3px var(--color-error-subtle)}.address-autocomplete--open .address-autocomplete__input{border-bottom-left-radius:0;border-bottom-right-radius:0}.address-autocomplete__loader{position:absolute;right:var(--space-3);color:var(--color-text-tertiary);animation:address-autocomplete-spin 1s linear infinite}@keyframes address-autocomplete-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.address-autocomplete__dropdown{position:absolute;top:100%;left:0;right:0;z-index:50;background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-top:none;border-bottom-left-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md);box-shadow:var(--shadow-lg);overflow:hidden}.address-autocomplete__list{list-style:none;margin:0;padding:0;max-height:280px;overflow-y:auto;overscroll-behavior:contain}.address-autocomplete__option{display:flex;flex-direction:column;gap:2px;padding:var(--space-2) var(--space-3);cursor:pointer;transition:background-color var(--transition-fast)}.address-autocomplete__option:hover{background-color:var(--color-bg-hover)}.address-autocomplete__option--highlighted{background-color:var(--color-accent-4)}.address-autocomplete__option--highlighted:hover{background-color:var(--color-accent-5)}.address-autocomplete__option-street{font-size:var(--text-base);font-weight:var(--font-medium);color:var(--color-text-primary)}.address-autocomplete__option-location{font-size:var(--text-sm);color:var(--color-text-secondary)}.address-autocomplete__search-error{display:flex;align-items:center;gap:var(--space-1);margin-top:var(--space-1);padding:var(--space-1) var(--space-2);font-size:var(--text-xs);color:var(--color-warning-11);background-color:var(--color-warning-3);border-radius:var(--radius-sm)}.empty-state--compact{padding:var(--space-4);background:transparent;border:none}.empty-state--compact svg{margin-bottom:var(--space-2);color:var(--color-text-muted)}.empty-state--compact p{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-3)}.spin{animation:spin 1s linear infinite}.table-row--sperrvermerk{background:var(--color-warning-2)}.table-row--sperrvermerk:hover{background:var(--color-warning-3)}.dashboard-mission-control{max-width:900px}.dashboard-header{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-6)}.dashboard-header__info{margin-bottom:var(--space-6)}.dashboard-header__info h1{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text);margin:0 0 var(--space-2)}.dashboard-header__period{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary)}.phase-progress{display:flex;align-items:flex-start;gap:0}.phase-step{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);flex:0 0 auto;min-width:70px}.phase-step__indicator{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:var(--color-surface-hover);color:var(--color-text-muted);z-index:1}.phase-step__label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-muted);text-align:center}.phase-step__line{flex:1;height:2px;min-width:20px;background:var(--color-border);margin-top:15px}.phase-step__line--completed{background:var(--color-success-9)}.phase-step--completed .phase-step__indicator{background:var(--color-success-9);color:#fff}.phase-step--completed .phase-step__label{color:var(--color-success-11)}.phase-step--current .phase-step__indicator{background:var(--color-primary);color:var(--color-primary-contrast);box-shadow:0 0 0 4px var(--color-accent-4)}.phase-step--current .phase-step__current-icon{fill:currentColor}.phase-step--current .phase-step__label{color:var(--color-text);font-weight:var(--font-semibold)}.phase-step--pending .phase-step__indicator{background:var(--color-surface-hover);color:var(--color-text-muted)}.next-action-box{background:var(--color-accent-2);border:1px solid var(--color-accent-6);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-6)}.next-action-box__header{margin-bottom:var(--space-2)}.next-action-box__label{font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-accent-11)}.next-action-box__content{display:flex;align-items:center;gap:var(--space-4)}.next-action-box__icon{color:var(--color-accent-9);flex-shrink:0}.next-action-box__text{flex:1;font-size:var(--text-base);color:var(--color-text)}.next-action-box__text strong{font-weight:var(--font-semibold)}.checklist-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--space-6);overflow:hidden}.checklist-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);background:var(--color-surface-raised);cursor:pointer;-webkit-user-select:none;user-select:none}.checklist-header:hover{background:var(--color-surface-hover)}.checklist-header h3{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text);margin:0}.checklist-progress{font-size:var(--text-sm);font-weight:var(--font-normal);color:var(--color-text-secondary)}.checklist{list-style:none;margin:0;padding:0}.checklist-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-top:1px solid var(--color-border-subtle);transition:background-color var(--transition-fast)}.checklist-item:hover{background:var(--color-surface-raised)}.checklist-item__indicator{display:flex;align-items:center;justify-content:center;width:20px;height:20px;flex-shrink:0;color:var(--color-text-muted)}.checklist-item__checkbox{width:18px;height:18px;cursor:pointer;accent-color:var(--color-accent-9);flex-shrink:0}.checklist-item__icon{color:var(--color-text-muted);flex-shrink:0}.checklist-item__label{flex:1;font-size:var(--text-sm);color:var(--color-text)}.checklist-item__detail{font-size:var(--text-sm);color:var(--color-text-muted)}.checklist-item--completed .checklist-item__indicator{color:var(--color-success-9)}.checklist-item--completed .checklist-item__label{color:var(--color-text-secondary)}.checklist-item--in-progress .checklist-item__indicator{color:var(--color-accent-9)}.checklist-item--in-progress .checklist-item__progress-icon{fill:currentColor}.checklist-item--in-progress .checklist-item__label{font-weight:var(--font-medium)}.stats-bar__divider{width:1px;height:20px;background:var(--color-border)}.stats-bar__item--info,.stats-bar__item--info strong{color:var(--color-info-11)}.stats-bar__item--success,.stats-bar__item--success strong{color:var(--color-success-11)}.btn--xs{min-height:26px;padding:var(--space-1) var(--space-2);font-size:var(--text-xs)}@media(max-width:900px){.phase-progress{gap:var(--space-1)}.phase-step{min-width:50px}.phase-step__indicator{width:24px;height:24px}.phase-step__indicator svg{width:14px;height:14px}.phase-step__label{font-size:var(--text-xs)}.phase-step__line{margin-top:11px;min-width:8px}}@media(max-width:768px){.phase-progress{flex-wrap:wrap;justify-content:center;gap:var(--space-2)}.phase-step{flex-direction:row;gap:var(--space-1);min-width:auto;padding:var(--space-1) var(--space-2);background:var(--color-surface-hover);border-radius:var(--radius-full)}.phase-step--current{background:var(--color-accent-3)}.phase-step--completed{background:var(--color-success-3)}.phase-step__indicator{width:16px;height:16px}.phase-step__indicator svg{width:12px;height:12px}.phase-step__label{font-size:var(--text-xs)}.phase-step__line{display:none}}@media(max-width:540px){.phase-progress{flex-direction:column;align-items:stretch;gap:var(--space-1)}.phase-step{justify-content:flex-start;border-radius:var(--radius-md);padding:var(--space-2)}.next-action-box__content{flex-wrap:wrap}.next-action-box__content .btn{width:100%;margin-top:var(--space-2)}.stats-bar{flex-direction:column;gap:var(--space-2)}.stats-bar__divider{display:none}}.onboarding-view{max-width:600px;margin:0 auto;padding:var(--space-8) var(--space-4)}.onboarding-header{text-align:center;margin-bottom:var(--space-8)}.onboarding-icon{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;border-radius:var(--radius-full);background:var(--color-primary-subtle);color:var(--color-primary-9);margin-bottom:var(--space-4)}.onboarding-header h1{font-size:var(--text-2xl);font-weight:var(--font-semibold);margin-bottom:var(--space-2)}.onboarding-steps{background:var(--color-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-6)}.onboarding-steps__title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-lg);font-weight:var(--font-semibold);margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border-subtle)}.onboarding-checklist{display:flex;flex-direction:column;gap:var(--space-3)}.onboarding-step{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);transition:background var(--transition-fast)}.onboarding-step--current{background:var(--color-primary-subtle)}.onboarding-step__number{flex-shrink:0;color:var(--color-text-muted)}.onboarding-step--done .onboarding-step__number{color:var(--color-success-9)}.onboarding-step--current .onboarding-step__number{color:var(--color-primary-9)}.onboarding-step__content{flex:1;display:flex;flex-direction:column;gap:var(--space-1)}.onboarding-step__content strong{font-weight:var(--font-medium)}.onboarding-step--done .onboarding-step__content strong{color:var(--color-text-muted);text-decoration:line-through}.onboarding-step .btn{flex-shrink:0;align-self:center}.onboarding-hint{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary);text-align:center;justify-content:center}.link-button{background:none;border:none;padding:0;color:var(--color-primary-text);font-size:inherit;font-weight:var(--font-medium);cursor:pointer;text-decoration:underline}.link-button:hover{color:var(--color-primary-9)}@media(max-width:540px){.onboarding-view{padding:var(--space-4) var(--space-3)}.onboarding-header h1{font-size:var(--text-xl)}.onboarding-step{flex-direction:column}.onboarding-step .btn{width:100%;margin-top:var(--space-2)}}.task-status{display:flex;flex-direction:column;gap:var(--space-4)}.task-status__body{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-4);text-align:center}.task-status__body p{margin:0;color:var(--color-text-secondary)}.task-status__body--error svg{color:var(--color-danger-9)}.task-status__body--error p{color:var(--color-danger-text)}.task-status__body--success svg{color:var(--color-success-9)}.task-status__body--success p{color:var(--color-text)}.task-status__body--progress svg{color:var(--color-accent-9)}.task-status__footer{display:flex;justify-content:flex-end;gap:var(--space-2);padding-top:var(--space-4);border-top:1px solid var(--color-border-subtle)}.progress-bar{width:100%;height:8px;background-color:var(--color-surface-active);border-radius:var(--radius-full);overflow:hidden}.progress-bar__fill{height:100%;background-color:var(--color-accent-9);border-radius:var(--radius-full);transition:width .3s ease}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinning{animation:spin 1s linear infinite}.document-groups{display:flex;flex-direction:column;gap:var(--space-6)}.document-group{background:var(--color-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-4)}.document-group__title{display:flex;align-items:center;gap:var(--space-2);margin:0 0 var(--space-4);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text)}.document-group__count{font-weight:var(--font-normal);color:var(--color-text-secondary);font-size:var(--text-sm)}.document-list{display:flex;flex-direction:column;gap:var(--space-3)}.document-task{padding:var(--space-3);background:var(--color-surface-raised);border-radius:var(--radius-md)}.document-task__header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary)}.document-task__files{display:flex;flex-direction:column;gap:var(--space-2)}.document-file{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);text-decoration:none;color:var(--color-text);transition:border-color .15s,background .15s}.document-file:hover{border-color:var(--color-accent-7);background:var(--color-accent-2)}.document-file__name{flex:1;font-weight:var(--font-medium);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.document-file__size{font-size:var(--text-sm);color:var(--color-text-secondary)}.document-file__download{color:var(--color-accent-9);opacity:0;transition:opacity .15s}.document-file:hover .document-file__download{opacity:1}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12) var(--space-4);text-align:center}.empty-state__icon{color:var(--color-border-strong);margin-bottom:var(--space-4)}.empty-state h2{margin:0 0 var(--space-2);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text)}.empty-state p{margin:0;max-width:400px}.address-selection{display:flex;flex-direction:column;gap:var(--space-2)}.address-option{display:block;width:100%;padding:var(--space-3);text-align:left;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.address-option:hover:not(:disabled){border-color:var(--color-primary);background:var(--color-accent-2)}.address-option:disabled{opacity:.6;cursor:not-allowed}.address-option__header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-1)}.address-option__header strong{font-size:var(--text-sm);color:var(--color-text)}.address-option__badge{font-size:var(--text-xs);padding:2px 6px;background:var(--color-accent-3);color:var(--color-accent-11);border-radius:var(--radius-sm);white-space:nowrap}.address-option__address{font-size:var(--text-sm);color:var(--color-text-secondary)}.address-option--blocked{position:relative;cursor:default;background:var(--color-surface-raised);border-color:var(--color-warning-6)}.address-option--blocked:hover{border-color:var(--color-warning-6);background:var(--color-surface-raised)}.address-option--blocked .address-option__header{justify-content:space-between;margin-bottom:var(--space-2)}.address-option__badge--blocked{display:inline-flex;align-items:center;gap:4px;background:var(--color-warning-3);color:var(--color-warning-11)}.address-option__content{transition:filter .2s ease}.address-option__content--blurred{filter:blur(6px);-webkit-user-select:none;user-select:none}.address-option__blur-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-1);color:var(--color-text-secondary);font-size:var(--text-sm);cursor:pointer;background:transparent;pointer-events:none}.address-option--blocked:has(.address-option__blur-overlay){cursor:pointer}.address-option__blur-overlay span{font-size:var(--text-xs);opacity:.8}.invitation-flow{display:flex;align-items:center;gap:var(--space-2)}.invitation-flow__arrow{color:var(--color-text-secondary);flex-shrink:0}.check-results-banner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--color-warning-3);border:1px solid var(--color-warning-6);border-radius:var(--radius-md);margin-bottom:var(--space-4)}.check-results-banner--success{background:var(--color-success-3);border-color:var(--color-success-6)}.check-results-banner__content{display:flex;align-items:flex-start;gap:var(--space-3);color:var(--color-warning-11)}.check-results-banner--success .check-results-banner__content{color:var(--color-success-11)}.check-results-banner__content strong{display:block;margin-bottom:var(--space-1)}.check-results-banner__content p{font-size:var(--text-sm);margin:0;opacity:.9}.issue-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;font-size:var(--text-xs);font-weight:500;background:var(--color-warning-3);color:var(--color-warning-11);border-radius:var(--radius-sm)}.student-card__issues,.student-issues{display:flex;flex-wrap:wrap;gap:var(--space-1);margin-top:var(--space-1)}.student-card--has-issues{border-left:3px solid var(--color-warning-9)}.student-name-cell{display:flex;flex-direction:column;gap:var(--space-1)}.btn--success{background:var(--color-success-3);color:var(--color-success-11);border-color:var(--color-success-6)}.btn--success:hover:not(:disabled){background:var(--color-success-4)}.dashboard{width:100%;max-width:600px;margin:0 auto;padding:var(--space-4);box-sizing:border-box}.dashboard--loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:var(--space-4);color:var(--color-text-secondary)}.dashboard__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-6)}.dashboard__title-group{display:flex;flex-direction:column;gap:var(--space-1)}.dashboard__title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--color-text-primary);margin:0}.dashboard__subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin:0}.dashboard-sync{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium)}.dashboard-sync--synced{background:var(--color-success-3);color:var(--color-success-11)}.dashboard-sync--syncing{background:var(--color-accent-3);color:var(--color-accent-11)}.dashboard-sync--pending{background:var(--color-warning-3);color:var(--color-warning-11)}.dashboard-sync--offline{background:var(--color-surface-hover);color:var(--color-text-secondary)}.dashboard-sync__badge{background:currentColor;color:#fff;border-radius:var(--radius-full);padding:0 var(--space-2);font-size:var(--text-xs);min-width:18px;text-align:center}.progress-section{margin-bottom:var(--space-6)}.progress-section__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.progress-section__label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-primary)}.progress-section__value{font-size:var(--text-sm);color:var(--color-text-secondary)}.progress-section__bar{height:8px;background:var(--color-surface-active);border-radius:var(--radius-full);overflow:hidden}.progress-section__fill{height:100%;background:var(--color-primary);border-radius:var(--radius-full);transition:width var(--transition-normal)}.dashboard__sections{display:flex;flex-direction:column;gap:var(--space-3)}.section-card{display:flex;align-items:center;gap:var(--space-4);width:100%;padding:var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:left}.section-card:hover{background:var(--color-surface-raised);border-color:var(--color-border)}.section-card:active{background:var(--color-surface-hover)}.section-card--complete{border-color:var(--color-success-6)}.section-card--complete:hover{border-color:var(--color-success-7)}.section-card--partial{border-color:var(--color-warning-6)}.section-card--partial:hover{border-color:var(--color-warning-7)}.section-card__icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--color-accent-3);color:var(--color-accent-11);border-radius:var(--radius-md);flex-shrink:0}.section-card--complete .section-card__icon{background:var(--color-success-3);color:var(--color-success-11)}.section-card--partial .section-card__icon{background:var(--color-warning-3);color:var(--color-warning-11)}.section-card__content{flex:1;min-width:0}.section-card__title{font-size:var(--text-base);font-weight:var(--font-medium);color:var(--color-text-primary);margin:0 0 var(--space-1) 0}.section-card__description{font-size:var(--text-sm);color:var(--color-text-secondary);margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.section-card__actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.section-card__status-icon--empty{color:var(--color-border-strong)}.section-card__status-icon--partial{color:var(--color-warning-9);fill:var(--color-warning-9)}.section-card__status-icon--complete{color:var(--color-success-9)}.section-card__chevron{color:var(--color-border-strong)}.documents-section{margin-top:var(--space-6);padding:var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.documents-section__title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text-primary);margin:0 0 var(--space-2) 0}.documents-section__hint{font-size:var(--text-sm);color:var(--color-text-secondary);margin:0 0 var(--space-4) 0}.documents-section__upload{display:flex;gap:var(--space-3);margin-bottom:var(--space-4)}.upload-button{display:flex;align-items:center;justify-content:center;gap:var(--space-2);flex:1;min-height:48px;padding:var(--space-3) var(--space-4);background:var(--color-primary);color:var(--color-primary-contrast);border:none;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:background var(--transition-fast)}.upload-button:hover{background:var(--color-primary-hover)}.upload-button:active{background:var(--color-primary-active)}.upload-button--secondary{background:var(--color-surface-hover);color:var(--color-text-primary)}.upload-button--secondary:hover{background:var(--color-surface-active)}.upload-button--secondary:active{background:var(--color-surface-selected)}.upload-button__input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media(max-width:480px){.documents-section__upload{flex-direction:column}}.documents-section__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-2)}.document-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--color-surface-raised);border-radius:var(--radius-md)}.document-item__icon{color:var(--color-text-secondary);flex-shrink:0}.document-item__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-1)}.document-item__name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.document-item__meta{font-size:var(--text-xs);color:var(--color-text-secondary)}.document-item__remove{display:flex;align-items:center;justify-content:center;min-width:36px;min-height:36px;padding:0;background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.document-item__remove:hover{background:var(--color-error-3);color:var(--color-error-9)}.dashboard__footer{margin-top:var(--space-6);padding-top:var(--space-4);border-top:1px solid var(--color-border)}.dashboard__hint{font-size:var(--text-sm);color:var(--color-text-secondary);text-align:center;margin:0}@media(max-width:480px){.dashboard{padding:var(--space-2)}.dashboard__header{flex-direction:column;align-items:flex-start;gap:var(--space-2)}}.section-nav{display:flex;gap:var(--space-2);overflow-x:auto;padding:var(--space-2) 0;margin-bottom:var(--space-4);border-bottom:1px solid var(--color-border);scrollbar-width:thin}.section-nav-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border:none;background:transparent;color:var(--color-text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;border-radius:var(--radius-md);white-space:nowrap;transition:background var(--transition-fast),color var(--transition-fast)}.section-nav-item:hover{background:var(--color-surface-active)}.section-nav-item--active{background:var(--color-accent-3);color:var(--color-accent-11)}.section-nav-icon{flex-shrink:0}.section-nav-icon--complete{color:var(--color-success)}.section-nav-icon--errors{color:var(--color-error)}.section-nav-icon--pending{color:var(--color-text-tertiary)}.section-nav-label{display:none}@media(min-width:640px){.section-nav-label{display:inline}}.section-blocks{display:flex;flex-direction:column;gap:var(--space-6)}.block{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5)}.block-header{margin-bottom:var(--space-4)}.block-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text-primary);margin:0 0 var(--space-1) 0}.block-description{font-size:var(--text-sm);color:var(--color-text-secondary);margin:0}.block-fields{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--space-4)}.block-field{min-width:0}@media(max-width:639px){.block-fields{grid-template-columns:1fr}.block-field{grid-column:1!important}}.validation-summary__groups{display:flex;flex-direction:column;gap:var(--space-3)}.validation-summary__group{padding-left:var(--space-4);border-left:2px solid var(--color-error-6)}.validation-summary__section-title{display:block;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-error-11);background:none;border:none;padding:0;margin:0 0 var(--space-2) 0;cursor:pointer;text-align:left}.validation-summary__section-title:hover{text-decoration:underline}.radio-group{display:flex;flex-direction:column;gap:var(--space-2)}.radio-label{display:flex;align-items:flex-start;gap:var(--space-2);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-md);transition:background var(--transition-fast)}.radio-label:hover{background:var(--color-surface-hover)}.radio{flex-shrink:0;width:1.125rem;height:1.125rem;margin-top:.125rem;accent-color:var(--color-primary)}.radio-text{font-size:var(--text-base);color:var(--color-text-primary)}.radio-hint{display:block;font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.checkbox-label{display:flex;align-items:flex-start;gap:var(--space-2);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-md);transition:background var(--transition-fast)}.checkbox-label:hover{background:var(--color-surface-hover)}.checkbox{flex-shrink:0;width:1.125rem;height:1.125rem;margin-top:.125rem;accent-color:var(--color-primary)}.checkbox-text{font-size:var(--text-base);color:var(--color-text-primary)}.checkbox-hint{display:block;font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-1);margin-left:calc(20px + var(--space-2))}.submit-success{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-8) var(--space-4)}.submit-success__icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;border-radius:50%;background:var(--color-success-3);color:var(--color-success-11);margin-bottom:var(--space-4)}.submit-success__title{font-size:var(--text-xl);font-weight:var(--weight-semibold);color:var(--color-success-11);margin:0 0 var(--space-2)}.submit-success__message{font-size:var(--text-base);color:var(--color-text-primary);margin:0 0 var(--space-4);max-width:400px}.submit-success__hint{font-size:var(--text-sm);color:var(--color-text-secondary);margin:0}.submit-success__download{margin-top:var(--space-6)}.submit-expired{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-8) var(--space-4)}.submit-expired__icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;border-radius:50%;background:var(--color-warning-3);color:var(--color-warning-11);margin-bottom:var(--space-4)}.submit-expired__title{font-size:var(--text-xl);font-weight:var(--weight-semibold);color:var(--color-warning-11);margin:0 0 var(--space-2)}.submit-expired__message{font-size:var(--text-base);color:var(--color-text-primary);margin:0 0 var(--space-4);max-width:400px}.submit-expired__hint{font-size:var(--text-sm);color:var(--color-text-secondary);margin:0}.submit-confirm{display:flex;flex-direction:column;gap:var(--space-4)}.submit-confirm__success{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);background:var(--color-success-3);border-radius:var(--radius-md);color:var(--color-success-11);font-weight:var(--weight-medium)}.submit-confirm__success svg{flex-shrink:0}.submit-confirm__warning{display:flex;gap:var(--space-3);padding:var(--space-4);background:var(--color-warning-3);border:1px solid var(--color-warning-6);border-radius:var(--radius-md)}.submit-confirm__warning svg{flex-shrink:0;color:var(--color-warning-11);margin-top:2px}.submit-confirm__warning strong{display:block;color:var(--color-warning-11);margin-bottom:var(--space-1)}.submit-confirm__warning p{margin:0;font-size:var(--text-sm);color:var(--color-text-primary);line-height:1.5}.submit-confirm__checkbox{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:var(--color-surface-raised);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--transition-fast),background var(--transition-fast)}.submit-confirm__checkbox:hover{background:var(--color-surface-hover);border-color:var(--color-border-input)}.submit-confirm__checkbox:has(input:checked){background:var(--color-primary-3);border-color:var(--color-primary-7)}.submit-confirm__checkbox input{flex-shrink:0;width:1.25rem;height:1.25rem;margin-top:2px;accent-color:var(--color-primary)}.submit-confirm__checkbox span{font-size:var(--text-base);color:var(--color-text-primary);line-height:1.5}.submit-confirm__checkbox strong{color:var(--color-primary-11)}.parent-shell{display:flex;flex-direction:column;height:100vh;height:100dvh;background:var(--color-background);overflow:hidden}.parent-shell__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background:var(--neutral-2);border-bottom:1px solid var(--neutral-6);flex-shrink:0;touch-action:manipulation}.parent-shell__brand{display:flex;align-items:center;gap:var(--space-2);font-weight:600;color:var(--neutral-12)}.parent-shell__brand svg{color:var(--accent-9)}.parent-shell__logout{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);background:none;border:1px solid var(--neutral-7);border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:var(--neutral-11);cursor:pointer;transition:all .15s ease}.parent-shell__logout:hover{background:var(--neutral-3);border-color:var(--neutral-8);color:var(--neutral-12)}.parent-shell__logout:focus-visible{outline:2px solid var(--accent-8);outline-offset:2px}.parent-shell__content{flex:1;display:flex;flex-direction:column;width:100%;max-width:100%;overflow-x:hidden;overflow-y:auto;overscroll-behavior-y:contain;min-height:0;background-color:var(--color-bg-muted)}@media(max-width:640px){.parent-shell__header{padding:var(--space-2) var(--space-3)}.parent-shell__brand span{font-size:var(--font-size-sm)}}.site-footer{padding:var(--space-3) var(--space-4);text-align:center;border-top:1px solid var(--neutral-6);background:var(--neutral-2);flex-shrink:0;touch-action:manipulation}.site-footer__links{display:flex;align-items:center;justify-content:center;gap:var(--space-2);flex-wrap:wrap}.site-footer__link{background:none;border:none;padding:var(--space-1) var(--space-2);font-size:var(--font-size-sm);color:var(--neutral-11);cursor:pointer;text-decoration:none;transition:color .15s ease}.site-footer__link:hover{color:var(--accent-11);text-decoration:underline}.site-footer__link:focus-visible{outline:2px solid var(--accent-8);outline-offset:2px;border-radius:var(--radius-sm)}.site-footer__separator{color:var(--neutral-8);font-size:var(--font-size-sm);-webkit-user-select:none;user-select:none}.legal-page{max-width:48rem;margin:0 auto;padding:var(--space-4)}.legal-page__header{margin-bottom:var(--space-6)}.legal-page__content{background:var(--neutral-1);border:1px solid var(--neutral-6);border-radius:var(--radius-lg);padding:var(--space-6)}.legal-page__content h1{font-size:var(--font-size-2xl);font-weight:600;color:var(--neutral-12);margin:0 0 var(--space-2) 0}.legal-page__subtitle{color:var(--neutral-11);font-size:var(--font-size-sm);margin:0 0 var(--space-6) 0}.legal-section{margin-bottom:var(--space-6)}.legal-section:last-of-type{margin-bottom:var(--space-4)}.legal-section h2{font-size:var(--font-size-lg);font-weight:600;color:var(--neutral-12);margin:0 0 var(--space-3) 0;padding-bottom:var(--space-2);border-bottom:1px solid var(--neutral-6)}.legal-section h3{font-size:var(--font-size-base);font-weight:600;color:var(--neutral-12);margin:var(--space-4) 0 var(--space-2) 0}.legal-section p{color:var(--neutral-11);line-height:1.6;margin:0 0 var(--space-3) 0}.legal-section p:last-child{margin-bottom:0}.legal-section address{font-style:normal;color:var(--neutral-11);line-height:1.6}.legal-section a{color:var(--accent-11);text-decoration:none}.legal-section a:hover{text-decoration:underline}.legal-section dl{margin:0}.legal-section dt{font-weight:500;color:var(--neutral-12);margin-bottom:var(--space-1)}.legal-section dd{margin:0 0 var(--space-3) 0;color:var(--neutral-11)}.legal-page__date{font-size:var(--font-size-sm);color:var(--neutral-10);margin-top:var(--space-6);padding-top:var(--space-4);border-top:1px solid var(--neutral-6)}.legal-page__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12);color:var(--neutral-11);gap:var(--space-3)}.legal-page__error{padding:var(--space-6);text-align:center;color:var(--red-11)}@media(max-width:640px){.legal-page{padding:var(--space-3)}.legal-page__content{padding:var(--space-4)}.legal-page__content h1{font-size:var(--font-size-xl)}}.flex{display:flex}.inline-flex{display:inline-flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.items-baseline{align-items:baseline}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.self-start{align-self:flex-start}.self-center{align-self:center}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-5{margin-top:var(--space-5)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-5{margin-bottom:var(--space-5)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.ml-1{margin-left:var(--space-1)}.ml-2{margin-left:var(--space-2)}.ml-3{margin-left:var(--space-3)}.ml-4{margin-left:var(--space-4)}.mr-1{margin-right:var(--space-1)}.mr-2{margin-right:var(--space-2)}.mr-3{margin-right:var(--space-3)}.mr-4{margin-right:var(--space-4)}.mx-auto{margin-left:auto;margin-right:auto}.my-2{margin-top:var(--space-2);margin-bottom:var(--space-2)}.my-4{margin-top:var(--space-4);margin-bottom:var(--space-4)}.my-6{margin-top:var(--space-6);margin-bottom:var(--space-6)}.p-1{padding:var(--space-1)}.p-2{padding:var(--space-2)}.p-3{padding:var(--space-3)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}.px-2{padding-left:var(--space-2);padding-right:var(--space-2)}.px-3{padding-left:var(--space-3);padding-right:var(--space-3)}.px-4{padding-left:var(--space-4);padding-right:var(--space-4)}.py-2{padding-top:var(--space-2);padding-bottom:var(--space-2)}.py-3{padding-top:var(--space-3);padding-bottom:var(--space-3)}.py-4{padding-top:var(--space-4);padding-bottom:var(--space-4)}.w-full{width:100%}.max-w-sm{max-width:400px}.max-w-md{max-width:600px}.max-w-lg{max-width:800px}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-3xl{font-size:var(--text-3xl)}.font-normal{font-weight:var(--font-normal)}.font-medium{font-weight:var(--font-medium)}.font-semibold{font-weight:var(--font-semibold)}.font-bold{font-weight:var(--font-bold)}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-primary{color:var(--color-text)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}.text-accent{color:var(--color-accent-11)}.text-success{color:var(--color-success-text)}.text-warning{color:var(--color-warning-text)}.text-error{color:var(--color-error-text)}.font-mono{font-family:var(--font-mono)}.uppercase{text-transform:uppercase}.tracking-wide{letter-spacing:.05em}.leading-tight{line-height:var(--leading-tight)}.leading-normal{line-height:var(--leading-normal)}.leading-relaxed{line-height:var(--leading-relaxed)}.whitespace-nowrap{white-space:nowrap}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.border{border:1px solid var(--color-border)}.border-b{border-bottom:1px solid var(--color-border)}.border-t{border-top:1px solid var(--color-border)}.rounded{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-full{border-radius:var(--radius-full)}.bg-surface{background-color:var(--color-bg-surface)}.bg-muted{background-color:var(--color-bg-muted)}.bg-accent-subtle{background-color:var(--color-accent-3)}.bg-success-subtle{background-color:var(--color-success-subtle)}.bg-warning-subtle{background-color:var(--color-warning-subtle)}.bg-error-subtle{background-color:var(--color-error-subtle)}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:none;border:none;border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.icon-btn:hover{background-color:var(--color-surface-active);color:var(--color-text)}.icon-btn:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px}.icon-btn--edge-left{margin-left:calc(-1 * var(--space-2))}.link-btn{background:none;border:none;color:var(--color-primary);cursor:pointer;text-decoration:underline;font-size:inherit;padding:0}.link-btn:hover{color:var(--color-primary-hover)}.divider{display:flex;align-items:center;gap:var(--space-3);color:var(--color-text-secondary)}.divider:before,.divider:after{content:"";flex:1;height:1px;background-color:var(--color-border)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);font-size:var(--text-sm);font-weight:var(--font-medium);border-radius:var(--radius-sm)}.badge--success{background-color:var(--color-success-subtle);color:var(--color-success-text)}.badge--warning{background-color:var(--color-warning-subtle);color:var(--color-warning-text)}.badge--error{background-color:var(--color-error-subtle);color:var(--color-error-text)}.badge--neutral{background-color:var(--color-surface-hover);color:var(--color-text-secondary)}.spinner{width:2rem;height:2rem;border:3px solid var(--color-accent-4);border-top-color:var(--color-accent-9);border-radius:var(--radius-full);animation:spin 1s linear infinite}.icon-spin{animation:spin 1s linear infinite;color:var(--color-accent-9)}@keyframes spin{to{transform:rotate(360deg)}}.view-loading{min-height:200px}.view-loading__spinner{display:flex;justify-content:center;align-items:center;padding:var(--space-8) 0}.color-scale{display:flex;gap:2px}.color-scale__step{flex:1;height:48px;display:flex;align-items:center;justify-content:center;font-size:var(--text-xs)}.color-scale__step:first-child{border-radius:var(--radius-md) 0 0 var(--radius-md)}.color-scale__step:last-child{border-radius:0 var(--radius-md) var(--radius-md) 0}.status-card{padding:var(--space-4);border-radius:var(--radius-md);text-align:center}.status-card__indicator{width:24px;height:24px;border-radius:var(--radius-full);margin:0 auto var(--space-2)}.status-card--success{background-color:var(--color-success-subtle)}.status-card--success .status-card__indicator{background-color:var(--color-success)}.status-card--success .status-card__label{color:var(--color-success-text);font-weight:var(--font-medium)}.status-card--warning{background-color:var(--color-warning-subtle)}.status-card--warning .status-card__indicator{background-color:var(--color-warning)}.status-card--warning .status-card__label{color:var(--color-warning-text);font-weight:var(--font-medium)}.status-card--error{background-color:var(--color-error-subtle)}.status-card--error .status-card__indicator{background-color:var(--color-error)}.status-card--error .status-card__label{color:var(--color-error-text);font-weight:var(--font-medium)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
