@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/montserrat-cyrillic-ext-400-normal-Xqov12YL.woff2) format("woff2"),url(/assets/montserrat-cyrillic-ext-400-normal-DRPPeomZ.woff) format("woff");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/montserrat-cyrillic-400-normal-BPq32Q8K.woff2) format("woff2"),url(/assets/montserrat-cyrillic-400-normal-jEs4Tk-Z.woff) format("woff");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/montserrat-vietnamese-400-normal-D4oHqQTd.woff2) format("woff2"),url(/assets/montserrat-vietnamese-400-normal-BeEscFYY.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/montserrat-latin-ext-400-normal-B8bwfy6Y.woff2) format("woff2"),url(/assets/montserrat-latin-ext-400-normal-BffdBkAA.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/montserrat-latin-400-normal-BLhwKU8k.woff2) format("woff2"),url(/assets/montserrat-latin-400-normal-xItZbAXg.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/montserrat-cyrillic-ext-500-normal-11xBT7e1.woff2) format("woff2"),url(/assets/montserrat-cyrillic-ext-500-normal-DOzfAZ45.woff) format("woff");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/montserrat-cyrillic-500-normal-T0SG181k.woff2) format("woff2"),url(/assets/montserrat-cyrillic-500-normal-CyGtXmN9.woff) format("woff");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/montserrat-vietnamese-500-normal-NT-t8RG1.woff2) format("woff2"),url(/assets/montserrat-vietnamese-500-normal-DpeZlV_K.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/montserrat-latin-ext-500-normal-BKtbrd6n.woff2) format("woff2"),url(/assets/montserrat-latin-ext-500-normal-DWPqqZgs.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/montserrat-latin-500-normal-DRFEGfly.woff2) format("woff2"),url(/assets/montserrat-latin-500-normal-Dok2oTci.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/montserrat-cyrillic-ext-600-normal-BtBW-rpm.woff2) format("woff2"),url(/assets/montserrat-cyrillic-ext-600-normal-wReYPmz2.woff) format("woff");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/montserrat-cyrillic-600-normal-CQEPC0hM.woff2) format("woff2"),url(/assets/montserrat-cyrillic-600-normal-DUglwBrH.woff) format("woff");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/montserrat-vietnamese-600-normal-DKe6qT_E.woff2) format("woff2"),url(/assets/montserrat-vietnamese-600-normal-SJ-HTWuM.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/montserrat-latin-ext-600-normal-DSkTqI9L.woff2) format("woff2"),url(/assets/montserrat-latin-ext-600-normal-CSDhkhgS.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/montserrat-latin-600-normal-UVxSCcoG.woff2) format("woff2"),url(/assets/montserrat-latin-600-normal-CdhFl4lI.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/montserrat-cyrillic-ext-700-normal-MyDreaeu.woff2) format("woff2"),url(/assets/montserrat-cyrillic-ext-700-normal-D-Mk2xRJ.woff) format("woff");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/montserrat-cyrillic-700-normal-D-Pqjtdp.woff2) format("woff2"),url(/assets/montserrat-cyrillic-700-normal-BvLYcGP1.woff) format("woff");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/montserrat-vietnamese-700-normal-C0x1De3p.woff2) format("woff2"),url(/assets/montserrat-vietnamese-700-normal-DnwGT2D9.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/montserrat-latin-ext-700-normal-BOP2Nhf0.woff2) format("woff2"),url(/assets/montserrat-latin-ext-700-normal-DdDFr05Z.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/montserrat-latin-700-normal-BdjcYUrC.woff2) format("woff2"),url(/assets/montserrat-latin-700-normal-BWkrl476.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/montserrat-cyrillic-ext-800-normal-GOAQXnVZ.woff2) format("woff2"),url(/assets/montserrat-cyrillic-ext-800-normal-mB3PmEeV.woff) format("woff");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/montserrat-cyrillic-800-normal-DDmpGQGC.woff2) format("woff2"),url(/assets/montserrat-cyrillic-800-normal-B_mUCQ9O.woff) format("woff");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/montserrat-vietnamese-800-normal-BDwqwvSG.woff2) format("woff2"),url(/assets/montserrat-vietnamese-800-normal-Chy8GRiB.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/montserrat-latin-ext-800-normal-BBvmbyWk.woff2) format("woff2"),url(/assets/montserrat-latin-ext-800-normal-Wjq_OapB.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Montserrat;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/montserrat-latin-800-normal-axpkC1rd.woff2) format("woff2"),url(/assets/montserrat-latin-800-normal-C3dfDxXV.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:"DM Serif Display";font-style:normal;font-display:swap;font-weight:400;src:url(/assets/dm-serif-display-latin-ext-400-normal-p18AlW_x.woff2) format("woff2"),url(/assets/dm-serif-display-latin-ext-400-normal-B1toqZab.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:"DM Serif Display";font-style:normal;font-display:swap;font-weight:400;src:url(/assets/dm-serif-display-latin-400-normal-C5_t9oOD.woff2) format("woff2"),url(/assets/dm-serif-display-latin-400-normal-_kVFYEpx.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:"DM Serif Display";font-style:italic;font-display:swap;font-weight:400;src:url(/assets/dm-serif-display-latin-ext-400-italic-DiLdooSn.woff2) format("woff2"),url(/assets/dm-serif-display-latin-ext-400-italic-D6UvgSoX.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:"DM Serif Display";font-style:italic;font-display:swap;font-weight:400;src:url(/assets/dm-serif-display-latin-400-italic-DpcbibHm.woff2) format("woff2"),url(/assets/dm-serif-display-latin-400-italic-BgxzcTJK.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--mi-navy-dark: #0d1f4a;--mi-navy: #1A3B8B;--mi-navy-light: #2d5aa8;--mi-navy-lighter: #5a7ec4;--mi-navy-lightest: #e8eef9;--action-blue-dark: #1e40af;--action-blue: #1b50c4;--action-blue-light: #60a5fa;--action-blue-lighter: #93c5fd;--action-blue-lightest: #dbeafe;--surface-blue-50: #eff6ff;--learning-purple-dark: #5b21b6;--learning-purple: #6d28d9;--learning-purple-light: #a78bfa;--learning-purple-lighter: #c4b5fd;--learning-purple-lightest: #ede9fe;--learning-blue-dark: #1d4ed8;--learning-blue: #3B82F6;--learning-blue-light: #60a5fa;--learning-blue-lighter: #93c5fd;--learning-blue-lightest: #dbeafe;--surface-white: #FFFFFF;--surface-gray-50: #F9FAFB;--surface-gray-100: #F3F4F6;--surface-gray-200: #E5E7EB;--surface-gray-300: #D1D5DB;--surface-gray-400: #6B7280;--text-primary: #1F2937;--text-secondary: #374151;--text-tertiary: #4B5563;--text-disabled: #D1D5DB;--text-on-dark: #FFFFFF;--text-on-dark-secondary: rgba(255, 255, 255, .85);--border-color: #E5E7EB;--border-light: #F3F4F6;--border-default: #E5E7EB;--border-dark: #D1D5DB;--bg-primary: var(--surface-white);--bg-secondary: var(--surface-gray-50);--bg-tertiary: var(--surface-gray-100);--surface-secondary: var(--surface-gray-50);--success: var(--success-green);--success-bg: var(--success-green-bg);--success-main: var(--success-green);--success-dark: var(--success-green-dark);--warning: var(--pending-amber);--warning-bg: var(--warning-amber-bg);--warning-main: var(--pending-amber);--warning-dark: var(--warning-amber-dark);--error: var(--alert-red);--error-bg: var(--error-red-bg);--error-main: var(--alert-red);--error-dark: var(--error-red-dark);--success-green-dark: #14532d;--success-green: #166534;--success-green-light: #4ade80;--success-green-bg: #f0fdf4;--warning-amber-dark: #78350f;--pending-amber: #92400e;--warning-amber-light: #fbbf24;--warning-amber-bg: #fffbeb;--error-red-dark: #7f1d1d;--alert-red: #991b1b;--status-error: #991b1b;--error-red-light: #f87171;--error-red-bg: #fef2f2;--info-blue-dark: #0c4a6e;--info-blue: #075985;--info-blue-light: #38bdf8;--info-blue-bg: #f0f9ff;--accent-orange-dark: #9a3412;--accent-orange: #c2410c;--accent-orange-light: #fb923c;--accent-orange-bg: #fed7aa;--accent-bronze: #9a3412;--accent-teal-dark: #115e59;--accent-teal: #0f766e;--accent-teal-light: #2dd4bf;--accent-teal-bg: #ccfbf1;--accent-indigo-dark: #4f46e5;--accent-indigo: #6366f1;--accent-indigo-light: #818cf8;--accent-indigo-bg: #e0e7ff;--accent-pink-dark: #db2777;--accent-pink: #ec4899;--accent-pink-light: #f472b6;--accent-pink-bg: #fce7f3;--overlay-light: rgba(0, 0, 0, .1);--overlay-medium: rgba(0, 0, 0, .3);--overlay-dark: rgba(0, 0, 0, .6);--overlay-backdrop: rgba(26, 59, 139, .95);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 24px;--radius-full: 9999px;--space-half: 2px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--font-family-primary: "Montserrat", -apple-system, BlinkMacSystemFont, "PingFang SC", "Microsoft YaHei", "Noto Sans SC", "Segoe UI", Roboto, sans-serif;--font-family-display: "DM Serif Display", Georgia, serif;--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;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--font-extrabold: 800;--font-weight-normal: var(--font-normal);--font-weight-medium: var(--font-medium);--font-weight-semibold: var(--font-semibold);--font-weight-bold: var(--font-bold);--font-size-xs: var(--text-xs);--font-size-sm: var(--text-sm);--font-size-base: var(--text-base);--font-size-lg: var(--text-lg);--font-size-xl: var(--text-xl);--font-size-2xl: var(--text-2xl);--font-size-3xl: var(--text-3xl);--font-size-4xl: var(--text-4xl);--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.625;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-normal: .3s ease;--transition-slow: .5s ease;--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-overlay: 300;--z-modal: 400;--z-toast: 500;--breakpoint-mobile: 480px;--breakpoint-tablet: 768px;--breakpoint-desktop: 1024px;--breakpoint-wide: 1280px;--touch-target-min: 44px;--touch-target-comfortable: 48px;--container-sm: 640px;--container-md: 768px;--container-lg: 1024px;--container-xl: 1280px;--grid-gap-mobile: var(--space-3);--grid-gap-tablet: var(--space-4);--grid-gap-desktop: var(--space-5)}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family-primary);color:var(--text-primary);background-color:var(--surface-gray-50);line-height:var(--leading-normal);min-height:100vh}@supports (height: 100dvh){body{min-height:100dvh}}#root{min-height:100vh;display:flex;flex-direction:column}.safe-area-top{padding-top:env(safe-area-inset-top,0)}.safe-area-bottom{padding-bottom:env(safe-area-inset-bottom,0)}.scrollbar-hide{-ms-overflow-style:none;scrollbar-width:none}.scrollbar-hide::-webkit-scrollbar{display:none}.grid-responsive{display:grid;gap:var(--grid-gap-mobile);grid-template-columns:1fr}@media(min-width:480px){.grid-responsive{grid-template-columns:repeat(2,1fr);gap:var(--grid-gap-tablet)}}@media(min-width:768px){.grid-responsive{grid-template-columns:repeat(3,1fr);gap:var(--grid-gap-desktop)}}@media(min-width:1024px){.grid-responsive{grid-template-columns:repeat(4,1fr)}}.grid-stats{display:grid;gap:var(--space-3);grid-template-columns:1fr}@media(min-width:480px){.grid-stats{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.grid-stats{grid-template-columns:repeat(3,1fr)}}.grid-cards{display:grid;gap:var(--space-4);grid-template-columns:1fr}@media(min-width:640px){.grid-cards{grid-template-columns:repeat(2,1fr)}}.flex-responsive{display:flex;flex-direction:column;gap:var(--space-3)}@media(min-width:480px){.flex-responsive{flex-direction:row;flex-wrap:wrap}}.flex-stack{display:flex;flex-direction:column;gap:var(--space-3)}.scroll-x{display:flex;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;gap:var(--space-2);padding-bottom:var(--space-2)}.scroll-x::-webkit-scrollbar{display:none}.hide-mobile{display:none}@media(min-width:480px){.hide-mobile{display:block}}@media(min-width:480px){.show-mobile-only{display:none}}.hide-tablet-down{display:none}@media(min-width:768px){.hide-tablet-down{display:block}}@media(min-width:768px){.show-tablet-down-only{display:none}}.p-responsive{padding:var(--space-3)}@media(min-width:480px){.p-responsive{padding:var(--space-4)}}@media(min-width:768px){.p-responsive{padding:var(--space-6)}}.m-responsive{margin:var(--space-3)}@media(min-width:480px){.m-responsive{margin:var(--space-4)}}.text-responsive-lg{font-size:var(--text-lg)}@media(min-width:480px){.text-responsive-lg{font-size:var(--text-xl)}}@media(min-width:768px){.text-responsive-lg{font-size:var(--text-2xl)}}.text-responsive-xl{font-size:var(--text-xl)}@media(min-width:480px){.text-responsive-xl{font-size:var(--text-2xl)}}@media(min-width:768px){.text-responsive-xl{font-size:var(--text-3xl)}}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.touch-target{min-height:var(--touch-target-min);min-width:var(--touch-target-min)}.touch-target-lg{min-height:var(--touch-target-comfortable);min-width:var(--touch-target-comfortable)}.touch-expand:before{content:"";position:absolute;inset:-8px}@media(orientation:portrait){.hide-portrait{display:none!important}}@media(orientation:landscape){.hide-landscape{display:none!important}}@media(orientation:landscape)and (max-height:500px){.shrink-landscape{padding-top:var(--space-2);padding-bottom:var(--space-2)}.scroll-landscape{max-height:calc(100vh - 100px);overflow-y:auto}}.page-wrapper{min-height:100%;padding:var(--space-4);padding-bottom:calc(var(--space-8) + 60px)}@media(min-width:480px){.page-wrapper{padding:var(--space-5);padding-bottom:calc(var(--space-8) + 60px)}}@media(min-width:768px){.page-wrapper{padding:var(--space-6);padding-bottom:calc(var(--space-8) + 60px)}}.page-wrapper-compact{min-height:100%;padding:var(--space-3);padding-bottom:calc(var(--space-6) + 60px)}@media(min-width:768px){.page-wrapper-compact{padding:var(--space-4);padding-bottom:calc(var(--space-6) + 60px)}}.container{width:100%;max-width:var(--container-lg);margin-left:auto;margin-right:auto;padding-left:var(--space-4);padding-right:var(--space-4)}@media(min-width:768px){.container{padding-left:var(--space-6);padding-right:var(--space-6)}}.container-fluid{width:100%;padding-left:var(--space-3);padding-right:var(--space-3)}@media(min-width:768px){.container-fluid{max-width:var(--container-xl);margin-left:auto;margin-right:auto;padding-left:var(--space-6);padding-right:var(--space-6)}}.card-responsive{border-radius:0;margin-left:calc(-1 * var(--space-4));margin-right:calc(-1 * var(--space-4));padding:var(--space-4)}@media(min-width:480px){.card-responsive{border-radius:var(--radius-lg);margin-left:0;margin-right:0}}.table-responsive-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}@media(max-width:479px){.table-stack-mobile{display:block}.table-stack-mobile thead{display:none}.table-stack-mobile tbody{display:flex;flex-direction:column;gap:var(--space-3)}.table-stack-mobile tr{display:flex;flex-direction:column;background:var(--surface-white);border-radius:var(--radius-md);padding:var(--space-3);box-shadow:var(--shadow-sm)}.table-stack-mobile td{display:flex;justify-content:space-between;padding:var(--space-2) 0;border-bottom:1px solid var(--surface-gray-100)}.table-stack-mobile td:last-child{border-bottom:none}.table-stack-mobile td:before{content:attr(data-label);font-weight:var(--font-medium);color:var(--text-secondary)}}.aspect-video{aspect-ratio:16 / 9}.aspect-square{aspect-ratio:1 / 1}.aspect-portrait{aspect-ratio:3 / 4}.safe-area-inset-top{padding-top:env(safe-area-inset-top,0)}.safe-area-inset-bottom{padding-bottom:env(safe-area-inset-bottom,0)}.safe-area-inset-left{padding-left:env(safe-area-inset-left,0)}.safe-area-inset-right{padding-right:env(safe-area-inset-right,0)}.safe-area-inset-x{padding-left:env(safe-area-inset-left,0);padding-right:env(safe-area-inset-right,0)}.safe-area-inset-y{padding-top:env(safe-area-inset-top,0);padding-bottom:env(safe-area-inset-bottom,0)}:root{color-scheme:light;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:var(--action-blue);text-decoration:inherit}a:hover{color:var(--action-blue-dark)}body{margin:0;min-width:320px;min-height:100vh;width:100%;font-family:var(--font-family-primary);color:var(--text-primary);background-color:var(--surface-gray-50);line-height:var(--leading-normal)}#root{width:100%;min-height:100vh}h1{font-size:var(--text-4xl);line-height:var(--leading-tight);font-weight:var(--font-bold);color:var(--text-primary)}h2{font-size:var(--text-2xl);line-height:var(--leading-tight);font-weight:var(--font-bold);color:var(--text-primary)}h3{font-size:var(--text-xl);line-height:var(--leading-tight);font-weight:var(--font-semibold);color:var(--text-primary)}button{border-radius:var(--radius-md);border:1px solid transparent;padding:var(--space-2) var(--space-4);font-size:var(--text-base);font-weight:var(--font-medium);font-family:var(--font-family-primary);background-color:var(--surface-gray-100);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast)}button:hover{background-color:var(--surface-gray-200)}button:focus-visible{outline:3px solid var(--action-blue);outline-offset:2px}.skip-to-main{position:absolute;top:-100%;left:50%;transform:translate(-50%);z-index:10000;padding:12px 24px;background:var(--mi-navy);color:#fff;font-size:var(--text-sm);font-weight:var(--font-semibold);border-radius:0 0 var(--radius-md) var(--radius-md);text-decoration:none;transition:top var(--transition-fast)}.skip-to-main:focus{top:0;outline:3px solid var(--action-blue);outline-offset:2px}a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{outline:3px solid var(--action-blue);outline-offset:2px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@media print{.header,.sidebar,.bottom-nav,.toast-container,.modal-overlay,.skip-to-main,.notification-center,.language-toggle,.header-lang-toggle{display:none!important}main,.page-content{margin:0;padding:0}body{background:#fff;color:#000;font-size:12pt;line-height:1.5}a[href]:after{content:" (" attr(href) ")";font-size:.8em;color:#333}.card,table,.data-table{page-break-inside:avoid}}@media(forced-colors:active){*{forced-color-adjust:auto}button,.btn{border:1px solid ButtonText}a{color:LinkText}:focus-visible{outline:3px solid Highlight}.badge,.status-badge{border:1px solid currentColor}}@media(prefers-contrast:more){:root{--text-secondary: #1F2937;--text-tertiary: #374151;--border-default: #1F2937;--border-color: #1F2937;--surface-gray-200: #9CA3AF}}[data-a11y-reduced-motion=true] *,[data-a11y-reduced-motion=true] *:before,[data-a11y-reduced-motion=true] *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}[data-a11y-high-contrast=true]{--text-secondary: #111827;--text-tertiary: #1F2937;--border-default: #111827;--border-color: #111827;--surface-gray-200: #6B7280;--surface-gray-300: #4B5563}[data-a11y-enhanced-focus=true] :focus-visible{outline:4px solid var(--alert-red)!important;outline-offset:4px!important;box-shadow:0 0 0 6px #991b1b4d!important}:root{--a11y-nav-icon-scale: 1;--a11y-page-icon-scale: 1}.icon,.btn svg,.btn img,.page-header-icon,.stats-icon,.stat-card-icon,.section-icon,.quick-action-icon,.role-action-icon,.input-action-btn img,.cm-section-icon{zoom:var(--a11y-page-icon-scale)}header .header-back-btn img,header .header-a11y-btn svg,header .header-avatar-chevron,header .user-dropdown-item img,header .icon,.bottom-nav-icon,.bottom-nav-icon img,.bottom-nav-icon svg,.more-menu-icon,.more-menu-icon img,.more-menu-icon svg,.sidebar-icon,.nav-icon{zoom:var(--a11y-nav-icon-scale)}[data-a11y-dyslexic-font=true]{--font-family-primary: "OpenDyslexic", "Montserrat", -apple-system, BlinkMacSystemFont, "PingFang SC", "Microsoft YaHei", "Noto Sans SC", sans-serif}:root{--min-target: 44px}button,input[type=button],input[type=submit],input[type=reset],[role=button]{min-height:var(--min-target);min-width:var(--min-target)}input:not([type=hidden]):not([type=checkbox]):not([type=radio]),select,textarea{min-height:var(--min-target)}.toast-close,.modal-close-btn{min-width:var(--min-target);min-height:var(--min-target)}.form-error-summary{border:2px solid var(--alert-red, #991b1b);padding:1rem;margin-bottom:1rem;background:var(--error-red-bg, #fef2f2);border-radius:var(--radius-md, 8px)}.form-error-summary__title{margin:0 0 .5rem;font-size:var(--text-base, 1rem);font-weight:var(--font-semibold, 600);color:var(--alert-red, #991b1b)}.form-error-summary__list{margin:0;padding-left:1.25rem}.form-error-summary__list a{color:var(--alert-red, #991b1b);text-decoration:underline}.form-error-summary__list a:focus-visible{outline:2px solid var(--alert-red, #991b1b);outline-offset:2px}.field{margin-block:.75rem}.field__label{display:inline-block;font-weight:var(--font-medium, 500);margin-bottom:.25rem}.required-indicator{color:var(--alert-red, #991b1b);margin-left:.125rem}.field__hint{color:var(--text-secondary, #4B5563);font-size:var(--text-sm, .875rem);margin-bottom:.25rem}.field__error{color:var(--alert-red, #991b1b);font-size:var(--text-sm, .875rem);margin-top:.25rem}.field--error input,.field--error select,.field--error textarea{border-color:var(--alert-red, #991b1b)}@media screen and (max-width:320px){body{overflow-x:hidden}.grid,.flex-row,.stats-grid,.dashboard-grid{display:flex!important;flex-direction:column!important}.grid>*,.flex-row>*,.stats-grid>*,.dashboard-grid>*{width:100%!important}.data-table-wrapper,.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}p,h1,h2,h3,h4,h5,h6,li,td,th,span,label{overflow-wrap:break-word;word-break:break-word;-webkit-hyphens:auto;hyphens:auto}}@media(forced-colors:active){input,select,textarea{border:2px solid ButtonText}.a11y-switch-slider{border:2px solid ButtonText;background:Field}.a11y-switch input:checked+.a11y-switch-slider{background:Highlight;border-color:HighlightText}.toast,.modal-container{border:2px solid CanvasText}svg{forced-color-adjust:auto}}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(180deg,#fff,#f8faff);display:flex;justify-content:space-around;align-items:flex-end;padding:12px 8px 16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px));box-shadow:0 -8px 32px #6366f11f,0 -2px 8px #0000000a;z-index:var(--z-sticky);border-top:2px solid transparent;border-image:linear-gradient(90deg,#f472b6,#a78bfa,#60a5fa,#34d399,#fbbf24) 1;isolation:isolate}html:not([data-a11y-nav-background-theme=none]) .bottom-nav:before{content:"";position:absolute;inset:0;background-repeat:repeat-x;background-size:auto 100%;background-position:center;opacity:.08;pointer-events:none;z-index:-1}html[data-a11y-nav-background-theme=education] .bottom-nav:before{background-image:url(/backgrounds/nav-education.svg)}html[data-a11y-nav-background-theme=geometric] .bottom-nav:before{background-image:url(/backgrounds/nav-geometric.svg)}html[data-a11y-nav-background-theme=nature] .bottom-nav:before{background-image:url(/backgrounds/nav-nature.svg)}html[data-a11y-nav-background-theme=creative] .bottom-nav:before{background-image:url(/backgrounds/nav-creative.svg)}html[data-a11y-nav-background-theme=space] .bottom-nav:before{background-image:url(/backgrounds/nav-space.svg)}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 8px;text-decoration:none;color:var(--text-tertiary);transition:all .3s cubic-bezier(.34,1.56,.64,1);min-width:56px;border-radius:16px;position:relative}.bottom-nav-item:hover{color:var(--text-secondary);transform:translateY(-2px)}.bottom-nav-item:active{transform:scale(.9) translateY(0)}.bottom-nav-item.active{transform:translateY(-4px)}.bottom-nav-item:nth-child(1).active{color:#ec4899}.bottom-nav-item:nth-child(2).active{color:#8b5cf6}.bottom-nav-item:nth-child(3).active{color:var(--action-blue)}.bottom-nav-item:nth-child(4).active{color:#10b981}.bottom-nav-item:nth-child(5).active{color:var(--pending-amber)}.bottom-nav-icon{display:flex;align-items:center;justify-content:center;width:52px;height:36px;padding:6px;border-radius:14px;transition:all .3s cubic-bezier(.34,1.56,.64,1);position:relative;background:transparent}.bottom-nav-item:nth-child(1).active .bottom-nav-icon{background:linear-gradient(135deg,#fce7f3,#fbcfe8);box-shadow:0 4px 12px #ec489940}.bottom-nav-item:nth-child(2).active .bottom-nav-icon{background:linear-gradient(135deg,#ede9fe,#ddd6fe);box-shadow:0 4px 12px #8b5cf640}.bottom-nav-item:nth-child(3).active .bottom-nav-icon{background:linear-gradient(135deg,#dbeafe,#bfdbfe);box-shadow:0 4px 12px #3b82f640}.bottom-nav-item:nth-child(4).active .bottom-nav-icon{background:linear-gradient(135deg,#d1fae5,#a7f3d0);box-shadow:0 4px 12px #10b98140}.bottom-nav-item:nth-child(5).active .bottom-nav-icon{background:linear-gradient(135deg,#fef3c7,#fde68a);box-shadow:0 4px 12px #f59e0b40}.bottom-nav-icon svg{width:24px;height:24px;transition:all .3s cubic-bezier(.34,1.56,.64,1);stroke-width:2.2}.bottom-nav-item.active .bottom-nav-icon svg{transform:scale(1.15);stroke-width:2.5}.bottom-nav-icon .nav-recraft-icon{width:28px;height:28px;object-fit:contain;transition:all .3s cubic-bezier(.34,1.56,.64,1);filter:grayscale(.6) opacity(.55)}.bottom-nav-item.active .bottom-nav-icon .nav-recraft-icon{filter:none;transform:scale(1.15)}@keyframes bounce-in{0%{transform:scale(.8) translateY(0)}50%{transform:scale(1.1) translateY(-6px)}to{transform:scale(1) translateY(-4px)}}.bottom-nav-item.active{animation:bounce-in .4s cubic-bezier(.34,1.56,.64,1)}.bottom-nav-item.active:after{content:"";position:absolute;bottom:-2px;left:50%;transform:translate(-50%);width:6px;height:6px;border-radius:50%;animation:pop-in .3s cubic-bezier(.34,1.56,.64,1)}.bottom-nav-item:nth-child(1).active:after{background:#ec4899}.bottom-nav-item:nth-child(2).active:after{background:#8b5cf6}.bottom-nav-item:nth-child(3).active:after{background:#3b82f6}.bottom-nav-item:nth-child(4).active:after{background:#10b981}.bottom-nav-item:nth-child(5).active:after{background:#f59e0b}@keyframes pop-in{0%{transform:translate(-50%) scale(0)}to{transform:translate(-50%) scale(1)}}.bottom-nav-label{font-size:.6875rem;font-weight:600;letter-spacing:.01em;transition:all .3s ease;text-transform:capitalize}.bottom-nav-item.active .bottom-nav-label{font-weight:700;font-size:.71875rem}@media(orientation:landscape)and (max-height:500px){.bottom-nav{padding:8px 4px 10px;padding-bottom:calc(10px + env(safe-area-inset-bottom,0px))}.bottom-nav-item{padding:4px 6px;gap:2px;min-width:48px}.bottom-nav-item.active{transform:translateY(-2px)}.bottom-nav-icon{width:44px;height:28px;border-radius:10px}.bottom-nav-icon svg{width:20px;height:20px}.bottom-nav-icon .nav-recraft-icon{width:22px;height:22px}.bottom-nav-label{font-size:.5625rem}.bottom-nav-item.active:after{width:4px;height:4px;bottom:-1px}}@media(max-width:320px){.bottom-nav-item{padding:4px;min-width:48px;gap:3px}.bottom-nav-icon{width:44px;height:30px;border-radius:10px}.bottom-nav-icon svg{width:20px;height:20px}.bottom-nav-icon .nav-recraft-icon{width:22px;height:22px}.bottom-nav-label{font-size:.5625rem}}@media(min-width:375px){.bottom-nav-item{min-width:60px}.bottom-nav-icon{width:56px;height:38px;border-radius:14px}.bottom-nav-icon svg{width:26px;height:26px}.bottom-nav-icon .nav-recraft-icon{width:30px;height:30px}.bottom-nav-label{font-size:.75rem}}@media(min-width:414px){.bottom-nav{padding:14px 12px 18px;padding-bottom:calc(18px + env(safe-area-inset-bottom,0px))}.bottom-nav-item{min-width:68px;gap:6px}.bottom-nav-icon{width:60px;height:40px;border-radius:16px}.bottom-nav-icon svg{width:28px;height:28px}.bottom-nav-icon .nav-recraft-icon{width:32px;height:32px}.bottom-nav-label{font-size:.75rem}.bottom-nav-item.active:after{width:8px;height:8px}}@supports (padding-bottom: env(safe-area-inset-bottom)){.bottom-nav{padding-bottom:calc(16px + env(safe-area-inset-bottom,0px))}}@media(prefers-reduced-motion:reduce){.bottom-nav-item,.bottom-nav-icon,.bottom-nav-icon svg,.bottom-nav-label{transition:none;animation:none}.bottom-nav-item:hover,.bottom-nav-item:active,.bottom-nav-item.active{transform:none}.bottom-nav-item.active .bottom-nav-icon svg{transform:none}.bottom-nav-item.active:after{animation:none}}.bottom-nav-more-overlay{position:fixed;inset:0;background:#0000004d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:calc(var(--z-sticky) + 1);animation:fade-in .2s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.bottom-nav-more-menu{position:fixed;bottom:calc(80px + env(safe-area-inset-bottom,0px));right:16px;background:linear-gradient(180deg,#fff,#f8faff);box-shadow:0 8px 32px #6366f133,0 4px 12px #0000001a;padding:8px;min-width:180px;animation:slide-up .25s cubic-bezier(.34,1.56,.64,1);border:2px solid transparent;border-image:linear-gradient(135deg,#f472b6,#a78bfa,#60a5fa) 1;border-radius:20px;border:2px solid rgba(139,92,246,.2)}@keyframes slide-up{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.more-menu-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;border:none;background:transparent;border-radius:14px;cursor:pointer;transition:all .2s ease;color:var(--text-secondary);font-size:.875rem;font-weight:500}.more-menu-item:hover{background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:#475569}.more-menu-item:active{transform:scale(.98)}.more-menu-item.active{background:linear-gradient(135deg,#ede9fe,#ddd6fe);color:#7c3aed}.more-menu-icon{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:12px;background:#f1f5f9;transition:all .2s ease}.more-menu-item:hover .more-menu-icon{background:#e2e8f0}.more-menu-item.active .more-menu-icon{background:linear-gradient(135deg,#a78bfa,#8b5cf6);color:#fff}.more-menu-icon svg{width:24px;height:24px}.more-menu-icon .nav-recraft-icon{width:28px;height:28px;object-fit:contain;transition:all .2s ease}.more-menu-item.active .more-menu-icon .nav-recraft-icon{filter:brightness(0) invert(1)}.more-menu-label{flex:1;text-align:left}.more-menu-active-indicator{display:flex;align-items:center;justify-content:center;color:#7c3aed}.bottom-nav-item{border:none;background:transparent;cursor:pointer;font-family:inherit}@media(max-width:320px){.bottom-nav-more-menu{right:8px;min-width:160px}.more-menu-item{padding:10px 12px;gap:10px;font-size:.8125rem}.more-menu-icon{width:36px;height:36px}.more-menu-icon svg{width:20px;height:20px}}@media(min-width:414px){.bottom-nav-more-menu{min-width:200px;right:20px}.more-menu-item{padding:14px 18px;font-size:.9375rem}}.more-menu-group-header{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);padding:12px 16px 6px;margin-top:4px;border-top:1px solid #e2e8f0}.more-menu-group-header:first-child{margin-top:0;padding-top:8px;border-top:none}.bottom-nav-more-menu{max-height:calc(100vh - 148px - env(safe-area-inset-bottom,0px));top:68px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(139,92,246,.3) transparent}.bottom-nav-more-menu::-webkit-scrollbar{width:6px}.bottom-nav-more-menu::-webkit-scrollbar-track{background:transparent}.bottom-nav-more-menu::-webkit-scrollbar-thumb{background:#8b5cf64d;border-radius:3px}.bottom-nav-more-menu::-webkit-scrollbar-thumb:hover{background:#8b5cf680}@media(max-width:320px){.more-menu-group-header{font-size:.625rem;padding:10px 12px 4px}}@media(min-width:414px){.more-menu-group-header{font-size:.75rem;padding:14px 18px 8px}}.notification-center{position:relative}.notification-bell-btn{position:relative;background:none;border:none;color:var(--text-on-dark);padding:var(--space-2);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);transition:background var(--transition-fast)}.notification-bell-btn:hover{background:#ffffff1a}.notification-bell-wrapper{position:relative}.notification-badge-dot{position:absolute;top:2px;right:2px;width:8px;height:8px;background:var(--alert-red);border-radius:var(--radius-full);animation:pulse-notification 2s infinite}.notification-count-badge{position:absolute;top:-2px;right:-2px;min-width:18px;height:18px;padding:0 var(--space-1);background:var(--alert-red);color:#fff;font-size:.6875rem;font-weight:var(--font-bold);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}@keyframes pulse-notification{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.8}}.notification-panel{position:absolute;top:calc(100% + var(--space-2));right:0;width:380px;max-height:80vh;background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);overflow:hidden;z-index:var(--z-overlay);display:flex;flex-direction:column;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.notification-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);border-bottom:1px solid var(--border-color)}.notification-panel-header h2{margin:0;font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary)}.notification-close-btn{background:none;border:none;color:var(--text-secondary);padding:var(--space-1);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition-fast)}.notification-close-btn:hover{background:var(--surface-gray-100);color:var(--text-primary)}.notification-filter-tabs{display:flex;gap:var(--space-1);padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border-color);overflow-x:auto}.notification-filter-tab{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:none;border:none;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:all var(--transition-fast)}.notification-filter-tab:hover{background:var(--surface-gray-100);color:var(--text-primary)}.notification-filter-tab.active{background:var(--mi-navy);color:#fff}.filter-count{min-width:20px;height:20px;padding:0 6px;background:#0000001a;border-radius:var(--radius-full);font-size:.6875rem;display:flex;align-items:center;justify-content:center}.notification-filter-tab.active .filter-count{background:#fff3}.notification-list{flex:1;overflow-y:auto;max-height:calc(80vh - 120px)}.notification-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8);color:var(--text-secondary)}.notification-empty svg{opacity:.4;margin-bottom:var(--space-3)}.notification-empty p{margin:0;font-size:var(--text-sm)}.notification-item{display:flex;gap:var(--space-3);padding:var(--space-3) var(--space-4);cursor:pointer;transition:background var(--transition-fast);position:relative;border-bottom:1px solid var(--border-color)}.notification-item:hover{background:var(--surface-gray-50)}.notification-item.selected{background:var(--action-blue-lightest)}.notification-item.unread{background:var(--surface-blue-50)}.notification-item.unread:hover{background:var(--action-blue-lightest)}.notification-item-avatar{width:40px;height:40px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:var(--font-semibold);font-size:var(--text-sm);color:#fff;flex-shrink:0}.notification-item-content{flex:1;min-width:0}.notification-item-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-1);flex-wrap:wrap}.notification-sender{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary)}.notification-role-tag{font-size:var(--text-xs);font-weight:var(--font-medium);padding:2px 6px;background:var(--surface-gray-100);border-radius:var(--radius-sm)}.notification-priority-badge{font-size:.625rem;font-weight:var(--font-bold);padding:2px 6px;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.5px}.notification-item-title{margin:0 0 var(--space-1) 0;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);line-height:1.3}.notification-item-preview{margin:0;font-size:var(--text-xs);color:var(--text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notification-item-footer{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-2)}.notification-time{font-size:var(--text-xs);color:var(--text-tertiary)}.notification-reply-count{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--text-secondary)}.notification-unread-indicator{position:absolute;left:var(--space-1);top:50%;transform:translateY(-50%);width:6px;height:6px;background:var(--action-blue);border-radius:var(--radius-full)}.notification-detail{display:flex;flex-direction:column;height:100%;max-height:calc(80vh - 60px)}.notification-detail-header{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-color)}.notification-back-btn{display:flex;align-items:center;gap:var(--space-1);background:none;border:none;color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;padding:var(--space-1) var(--space-2);margin:calc(-1 * var(--space-1)) calc(-1 * var(--space-2));border-radius:var(--radius-md);transition:all var(--transition-fast)}.notification-back-btn:hover{background:var(--surface-gray-100);color:var(--text-primary)}.notification-detail-content{flex:1;overflow-y:auto;padding:var(--space-4)}.notification-detail-sender{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.notification-detail-avatar{width:44px;height:44px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:var(--font-semibold);color:#fff}.notification-detail-sender-info{flex:1;display:flex;flex-direction:column;gap:2px}.notification-detail-name{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary)}.notification-detail-role{font-size:var(--text-xs);font-weight:var(--font-medium)}.notification-detail-time{font-size:var(--text-xs);color:var(--text-tertiary)}.notification-detail-title{display:flex;align-items:center;gap:var(--space-2);margin:0 0 var(--space-3) 0;font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);line-height:1.3}.notification-detail-message{margin:0;font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6;white-space:pre-wrap}.notification-replies{margin-top:var(--space-5);padding-top:var(--space-4);border-top:1px solid var(--border-color)}.notification-replies-title{display:flex;align-items:center;gap:var(--space-2);margin:0 0 var(--space-3) 0;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary)}.notification-replies-list{display:flex;flex-direction:column;gap:var(--space-3)}.notification-reply{display:flex;gap:var(--space-2)}.notification-reply.own-reply{flex-direction:row-reverse}.reply-avatar{width:32px;height:32px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:var(--font-medium);font-size:var(--text-xs);color:#fff;flex-shrink:0}.reply-content{flex:1;background:var(--surface-gray-100);border-radius:var(--radius-lg);padding:var(--space-2) var(--space-3)}.notification-reply.own-reply .reply-content{background:var(--action-blue-lightest)}.reply-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-1);flex-wrap:wrap}.reply-name{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-primary)}.reply-role{font-size:.625rem;font-weight:var(--font-medium)}.reply-time{font-size:.625rem;color:var(--text-tertiary);margin-left:auto}.reply-message{margin:0;font-size:var(--text-sm);color:var(--text-secondary);line-height:1.4}.notification-reply-input{display:flex;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-top:1px solid var(--border-color);background:var(--surface-gray-50)}.notification-reply-input textarea{flex:1;padding:var(--space-2) var(--space-3);border:1px solid var(--border-color);border-radius:var(--radius-lg);font-size:var(--text-sm);font-family:inherit;resize:none;transition:border-color var(--transition-fast)}.notification-reply-input textarea:focus-visible{outline:3px solid var(--action-blue, #2563EB);outline-offset:2px}.notification-reply-input textarea:focus{border-color:var(--action-blue)}.notification-reply-input textarea::placeholder{color:var(--text-tertiary)}.notification-send-btn{width:40px;height:40px;border:none;border-radius:var(--radius-lg);background:var(--mi-navy);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0}.notification-send-btn:hover:not(:disabled){background:var(--mi-navy-dark)}.notification-send-btn:disabled{opacity:.5;cursor:not-allowed}.sending-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:var(--radius-full);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.notification-list,.notification-detail-content{scrollbar-width:thin;scrollbar-color:var(--mi-navy) var(--surface-gray-100)}.notification-list::-webkit-scrollbar,.notification-detail-content::-webkit-scrollbar{width:6px}.notification-list::-webkit-scrollbar-track,.notification-detail-content::-webkit-scrollbar-track{background:var(--surface-gray-100);border-radius:var(--radius-full)}.notification-list::-webkit-scrollbar-thumb,.notification-detail-content::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--mi-navy) 0%,var(--action-blue) 100%);border-radius:var(--radius-full)}.notification-list::-webkit-scrollbar-thumb:hover,.notification-detail-content::-webkit-scrollbar-thumb:hover{background:var(--mi-navy)}@media(max-width:480px){.notification-panel{position:fixed;inset:0;width:100%;max-height:100vh;border-radius:0}.notification-panel-header{padding-top:calc(var(--space-4) + env(safe-area-inset-top))}.notification-list{max-height:calc(100vh - 180px)}.notification-detail{max-height:calc(100vh - 60px)}.notification-reply-input{padding-bottom:calc(var(--space-3) + env(safe-area-inset-bottom))}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-family:var(--font-family-primary);font-size:var(--text-base);font-weight:var(--font-semibold);line-height:1;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-decoration:none;white-space:nowrap}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-secondary{background:var(--mi-navy);color:var(--text-on-dark)}.btn-secondary:hover:not(:disabled){background:var(--mi-navy-dark)}.btn-outline{background:transparent;color:var(--action-blue);border:2px solid var(--action-blue)}.btn-outline:hover:not(:disabled){background:var(--action-blue-lightest)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--surface-gray-100);color:var(--text-primary)}.btn-success{background:var(--success-green);color:var(--text-on-dark)}.btn-success:hover:not(:disabled){background:var(--success-green-dark)}.btn-small{padding:var(--space-2) var(--space-3);font-size:var(--text-sm)}.btn-medium{padding:var(--space-3) var(--space-5);font-size:var(--text-base)}.btn-large{padding:var(--space-4) var(--space-6);font-size:var(--text-lg)}.btn-full{width:100%}.btn-disabled,.btn:disabled{opacity:.5;cursor:not-allowed}.btn-loading{cursor:wait}.btn-icon{display:flex;align-items:center;justify-content:center}.btn-icon svg{width:20px;height:20px}.btn-spinner{display:flex;align-items:center;justify-content:center}.btn-spinner svg{width:20px;height:20px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.card{background:var(--surface-white);border-radius:var(--radius-lg);overflow:hidden}.card-elevated{box-shadow:var(--shadow-md)}.card-outlined{border:1px solid var(--surface-gray-200)}.card-filled{background:var(--surface-gray-100)}.card-padding-none{padding:0}.card-padding-small{padding:var(--space-3)}.card-padding-medium{padding:var(--space-4)}.card-padding-large{padding:var(--space-6)}.card-clickable{cursor:pointer;transition:all var(--transition-fast)}.card-clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.card-clickable:active{transform:translateY(0)}.card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3)}.card-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.card-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin:var(--space-1) 0 0 0}.card-content{margin-top:var(--space-3)}.card-footer{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-4);padding-top:var(--space-3);border-top:1px solid var(--surface-gray-100)}.input-wrapper{display:flex;flex-direction:column;gap:var(--space-1)}.input-full{width:100%}.input-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}.input-required{color:var(--alert-red);margin-left:var(--space-1)}.input-container{position:relative;display:flex;align-items:center}.input-field{width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-family-primary);font-size:var(--text-base);color:var(--text-primary);background:var(--surface-white);border:2px solid var(--surface-gray-300);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.input-field:focus-visible{outline:3px solid var(--action-blue, #2563EB);outline-offset:2px}.input-field::placeholder{color:var(--text-tertiary)}.input-field:hover:not(:disabled){border-color:var(--surface-gray-400)}.input-field:focus{border-color:var(--action-blue);box-shadow:0 0 0 3px var(--action-blue-lightest)}.input-small .input-field{padding:var(--space-2) var(--space-3);font-size:var(--text-sm)}.input-large .input-field{padding:var(--space-4) var(--space-5);font-size:var(--text-lg)}.input-with-icon-left .input-field{padding-left:calc(var(--space-4) + 24px + var(--space-2))}.input-with-icon-right .input-field{padding-right:calc(var(--space-4) + 24px + var(--space-2))}.input-icon{position:absolute;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);pointer-events:none}.input-icon-left{left:var(--space-4)}.input-icon-right{right:var(--space-4)}.input-icon svg{width:20px;height:20px}.input-password-toggle{position:absolute;right:var(--space-3);background:none;border:none;padding:var(--space-2);color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:color var(--transition-fast)}.input-password-toggle:hover{color:var(--text-secondary)}.input-error .input-field{border-color:var(--alert-red)}.input-error .input-field:focus{border-color:var(--alert-red);box-shadow:0 0 0 3px var(--error-red-bg)}.input-disabled .input-field{background:var(--surface-gray-100);color:var(--text-disabled);cursor:not-allowed}.input-helper{font-size:var(--text-xs);color:var(--text-secondary)}.input-helper-error{color:var(--alert-red)}.badge{display:inline-flex;align-items:center;justify-content:center;font-weight:var(--font-semibold);border-radius:var(--radius-full);white-space:nowrap}.badge-small{padding:var(--space-1) var(--space-2);font-size:.625rem}.badge-medium{padding:var(--space-1) var(--space-3);font-size:var(--text-xs)}.badge-large{padding:var(--space-2) var(--space-4);font-size:var(--text-sm)}.badge-default{background:var(--surface-gray-200);color:var(--text-secondary)}.badge-primary{background:var(--action-blue-lightest);color:var(--action-blue-dark)}.badge-secondary{background:var(--mi-navy-lightest);color:var(--mi-navy)}.badge-success{background:var(--success-green-bg);color:var(--success-green-dark)}.badge-warning{background:var(--warning-amber-bg);color:var(--warning-amber-dark)}.badge-error{background:var(--error-red-bg);color:var(--error-red-dark)}.badge-info{background:var(--info-blue-bg);color:var(--info-blue-dark)}.badge-purple{background:var(--learning-purple-lightest);color:var(--learning-purple-dark)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8);text-align:center}.empty-state-icon{width:80px;height:80px;margin-bottom:var(--space-4);color:var(--text-tertiary);opacity:.5}.empty-state-icon svg{width:100%;height:100%}.empty-state-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-2) 0}.empty-state-description{font-size:var(--text-sm);color:var(--text-secondary);margin:0;max-width:280px}.empty-state-action{margin-top:var(--space-4)}.loading{display:flex;align-items:center;justify-content:center}.loading-spinner{animation:rotate 2s linear infinite}.loading-small .loading-spinner{width:20px;height:20px}.loading-medium .loading-spinner{width:32px;height:32px}.loading-large .loading-spinner{width:48px;height:48px}.loading-circle{stroke:var(--action-blue);stroke-linecap:round;animation:dash 1.5s ease-in-out infinite}@keyframes rotate{to{transform:rotate(360deg)}}@keyframes dash{0%{stroke-dasharray:1,150;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35}to{stroke-dasharray:90,150;stroke-dashoffset:-124}}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:var(--space-4)}.loading-message{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.skeleton{background:linear-gradient(90deg,var(--surface-gray-200) 25%,var(--surface-gray-100) 50%,var(--surface-gray-200) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.skeleton-text{border-radius:var(--radius-sm)}.skeleton-circular{border-radius:var(--radius-full)}.skeleton-rectangular{border-radius:var(--radius-md)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.orientation-overlay{position:fixed;inset:0;background:var(--overlay-backdrop);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--space-4)}.orientation-content{text-align:center;color:var(--text-on-dark);max-width:300px}.orientation-icon{width:80px;height:80px;margin:0 auto var(--space-4);background:#ffffff1a;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;animation:rotate-hint 2s ease-in-out infinite}@keyframes rotate-hint{0%,to{transform:rotate(0)}25%{transform:rotate(-20deg)}75%{transform:rotate(20deg)}}.orientation-title{font-size:var(--text-xl);font-weight:var(--font-bold);margin:0 0 var(--space-2) 0}.orientation-message{font-size:var(--text-base);opacity:.9;margin:0 0 var(--space-6) 0;line-height:var(--leading-relaxed)}.orientation-dismiss{background:transparent;border:2px solid rgba(255,255,255,.3);color:var(--text-on-dark);padding:var(--space-3) var(--space-6);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast)}.orientation-dismiss:hover{background:#ffffff1a;border-color:#ffffff80}.data-table-container{width:100%}.data-table-search{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);background:var(--surface-white);border:1px solid var(--surface-gray-200);border-radius:var(--radius-lg);margin-bottom:var(--space-4)}.data-table-search svg{color:var(--text-tertiary);flex-shrink:0}.data-table-search-input{flex:1;border:none;font-size:var(--text-base);color:var(--text-primary);background:transparent}.data-table-search-input:focus-visible{outline:3px solid var(--action-blue, #2563EB);outline-offset:2px}.data-table-search-input::placeholder{color:var(--text-tertiary)}.data-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--surface-gray-200);border-radius:var(--radius-lg);background:var(--surface-white)}.data-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.data-table th{text-align:left;padding:var(--space-3) var(--space-4);font-weight:var(--font-semibold);color:var(--text-secondary);background:var(--surface-gray-50);border-bottom:1px solid var(--surface-gray-200);white-space:nowrap}.data-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.data-table th.sortable:hover{background:var(--surface-gray-100)}.th-content{display:flex;align-items:center;gap:var(--space-2)}.sort-indicator{font-size:var(--text-xs);color:var(--action-blue)}.data-table td{padding:var(--space-3) var(--space-4);color:var(--text-primary);border-bottom:1px solid var(--surface-gray-100)}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr.clickable{cursor:pointer}.data-table tbody tr.clickable:hover{background:var(--surface-gray-50)}.empty-row{text-align:center;color:var(--text-secondary);padding:var(--space-8)!important}.actions-column{width:100px;text-align:center}.actions-cell{text-align:center}.actions-wrapper{display:flex;gap:var(--space-2);justify-content:center}.action-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background-color:var(--surface-white, #ffffff)!important;border:1px solid var(--surface-gray-200);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);padding:0}.action-btn svg{color:inherit;stroke:currentColor}.action-btn:hover{background-color:var(--surface-gray-100)!important;color:var(--text-primary)}.action-btn.edit{color:var(--action-blue);border-color:var(--action-blue-light, #93c5fd);background-color:var(--action-blue-lightest, #eff6ff)!important}.action-btn.edit:hover{background-color:var(--action-blue-light, #bfdbfe)!important;border-color:var(--action-blue);color:var(--action-blue)}.action-btn.delete{color:var(--alert-red);border-color:var(--alert-red-light, #fca5a5);background-color:var(--alert-red-lightest, #fef2f2)!important}.action-btn.delete:hover{background-color:var(--alert-red-light, #fecaca)!important;border-color:var(--alert-red);color:var(--alert-red)}.action-btn.view{color:var(--mi-navy);border-color:var(--mi-navy-light, #a5b4fc);background-color:var(--mi-navy-lightest, #eef2ff)!important}.action-btn.view:hover{background-color:var(--mi-navy-light, #c7d2fe)!important;border-color:var(--mi-navy);color:var(--mi-navy)}.data-table-pagination{display:flex;align-items:center;justify-content:space-between;margin-top:var(--space-4);padding:var(--space-2) 0}.pagination-info{font-size:var(--text-sm);color:var(--text-secondary)}.pagination-controls{display:flex;align-items:center;gap:var(--space-2)}.pagination-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--surface-white);border:1px solid var(--surface-gray-200);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-size:var(--text-base)}.pagination-btn:hover:not(:disabled){background:var(--surface-gray-100);color:var(--text-primary)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-current{font-size:var(--text-sm);color:var(--text-secondary);padding:0 var(--space-2)}@media(max-width:767px){.data-table-pagination{flex-direction:column;gap:var(--space-3);align-items:stretch}.pagination-info{text-align:center}.pagination-controls{justify-content:center}.data-table-wrapper{border:none;background:transparent;overflow-x:visible}.data-table{display:block}.data-table thead{display:none}.data-table tbody{display:flex;flex-direction:column;gap:var(--space-3)}.data-table tbody tr{display:flex;flex-direction:column;background:var(--surface-white);border:1px solid var(--surface-gray-200);border-radius:var(--radius-lg);padding:var(--space-3)}.data-table td{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) 0;border-bottom:1px solid var(--surface-gray-100)}.data-table td:first-child{border-bottom:1px solid var(--surface-gray-200);padding-bottom:var(--space-3);margin-bottom:var(--space-1)}.data-table td:last-child{border-bottom:none}.data-table td:before{content:attr(data-label);font-weight:var(--font-medium);color:var(--text-secondary);font-size:var(--text-xs);flex-shrink:0;margin-right:var(--space-3)}.data-table td:first-child:before{display:none}.actions-wrapper{width:100%;justify-content:flex-end;padding-top:var(--space-2)}.action-btn{width:36px;height:36px}.student-cell{width:100%}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:var(--space-4);z-index:var(--z-modal);animation:fadeIn .2s ease}.modal-container{background:var(--surface-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-height:calc(100vh - var(--space-8));display:flex;flex-direction:column;animation:slideUp .2s ease}.modal-container:focus-visible{outline:3px solid var(--action-blue, #2563EB);outline-offset:2px}.modal-small{width:100%;max-width:400px}.modal-medium{width:100%;max-width:560px}.modal-large{width:100%;max-width:720px}.modal-fullscreen{width:calc(100% - var(--space-4));max-width:none;height:calc(100vh - var(--space-8));margin:var(--space-4)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--surface-gray-200);flex-shrink:0}.modal-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.modal-close-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.modal-close-btn:hover{background:var(--surface-gray-100);color:var(--text-primary)}.modal-body{padding:var(--space-5);overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-top:1px solid var(--surface-gray-200);flex-shrink:0}.confirm-modal-message{font-size:var(--text-base);color:var(--text-secondary);margin:0;line-height:1.6}.confirm-modal-actions{display:flex;gap:var(--space-3);width:100%}.confirm-modal-actions .btn{flex:1}.modal-footer .btn,.confirm-modal-actions .btn{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-medium);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);border:none}.btn-primary{background:var(--action-blue);color:var(--text-on-dark)}.btn-primary:hover:not(:disabled){background:var(--action-blue-dark)}.btn-secondary{background:var(--surface-gray-100);color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background:var(--surface-gray-200)}.btn-danger{background:var(--alert-red);color:var(--text-on-dark)}.btn-danger:hover:not(:disabled){background:var(--error-red-dark)}.btn:disabled{opacity:.6;cursor:not-allowed}.modal-body .form-group{margin-bottom:var(--space-4)}.modal-body .form-group:last-child{margin-bottom:0}.modal-body .form-label{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);margin-bottom:var(--space-2)}.modal-body .form-input,.modal-body .form-select,.modal-body .form-textarea{width:100%;padding:var(--space-3);font-size:var(--text-base);border:2px solid var(--surface-gray-300);border-radius:var(--radius-lg);background:var(--surface-white);transition:border-color var(--transition-fast)}.modal-body .form-input:focus-visible,.modal-body .form-select:focus-visible,.modal-body .form-textarea:focus-visible{outline:3px solid var(--action-blue, #2563EB);outline-offset:2px}.modal-body .form-input:focus,.modal-body .form-select:focus,.modal-body .form-textarea:focus{border-color:var(--action-blue)}.modal-body .form-textarea{resize:vertical;min-height:100px}.modal-body .form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}@media(max-width:479px){.modal-overlay{padding:var(--space-3);align-items:flex-end}.modal-container{max-height:calc(100vh - var(--space-6));border-bottom-left-radius:0;border-bottom-right-radius:0;margin-bottom:0}.modal-small,.modal-medium,.modal-large{max-width:100%}.modal-header{padding:var(--space-3) var(--space-4)}.modal-body{padding:var(--space-4)}.modal-footer{padding:var(--space-3) var(--space-4);padding-bottom:calc(var(--space-3) + env(safe-area-inset-bottom,0px))}.confirm-modal-actions{flex-direction:column-reverse}.modal-body .form-row{grid-template-columns:1fr;gap:var(--space-3)}}.time-filter{display:flex;align-items:center;gap:var(--space-3)}.time-filter-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary);white-space:nowrap}.time-filter-select{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.time-filter-dropdown{position:relative;min-width:180px}.time-filter-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);padding:var(--space-3);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);background:var(--surface-white);border:2px solid var(--surface-gray-300);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.time-filter-trigger:hover{border-color:var(--surface-gray-400)}.time-filter-trigger:focus{border-color:var(--action-blue)}.time-filter-trigger:focus-visible{outline:3px solid var(--action-blue, #2563EB);outline-offset:2px}.time-filter-trigger svg{color:var(--text-secondary);transition:transform var(--transition-fast)}.time-filter-trigger svg.rotated{transform:rotate(180deg)}.time-filter-overlay{position:fixed;inset:0;z-index:250}.time-filter-menu{position:absolute;top:calc(100% + var(--space-1));right:0;min-width:100%;width:max-content;max-width:280px;background:var(--surface-white);border:1px solid var(--surface-gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:251;overflow:hidden;animation:dropdownFadeIn .15s ease}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.time-filter-option{width:100%;display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--text-primary);background:transparent;border:none;cursor:pointer;transition:background var(--transition-fast)}.time-filter-option:hover{background:var(--surface-gray-50)}.time-filter-option.selected{color:var(--action-blue);background:var(--action-blue-lightest)}.time-filter-option svg{color:var(--action-blue)}.time-filter-buttons{flex-wrap:wrap}.time-filter-btn-group{display:flex;gap:var(--space-2);flex-wrap:wrap}.time-filter-btn{padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary);background:var(--surface-white);border:1px solid var(--surface-gray-200);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.time-filter-btn:hover{border-color:var(--action-blue);color:var(--action-blue)}.time-filter-btn.active{background:var(--mi-navy);border-color:var(--mi-navy);color:var(--text-on-dark)}.time-filter-chips{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.time-filter-chip-group{display:flex;gap:var(--space-2);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:var(--space-1)}.time-filter-chip-group::-webkit-scrollbar{display:none}.time-filter-chip{padding:var(--space-2) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--text-secondary);background:var(--surface-white);border:1px solid var(--surface-gray-200);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.time-filter-chip:hover{border-color:var(--action-blue);color:var(--action-blue)}.time-filter-chip.active{background:var(--action-blue);border-color:var(--action-blue);color:var(--text-on-dark)}.time-filter-custom{padding:var(--space-3);border-top:1px solid var(--surface-gray-200);background:var(--surface-gray-50)}.custom-date-row{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-2)}.custom-date-row label{font-size:var(--text-sm);color:var(--text-secondary);min-width:40px}.custom-date-input{flex:1;padding:var(--space-2);font-size:var(--text-sm);border:1px solid var(--surface-gray-300);border-radius:var(--radius-md);background:var(--surface-white)}.custom-date-input:focus{border-color:var(--action-blue)}.custom-date-input:focus-visible{outline:3px solid var(--action-blue, #2563EB);outline-offset:2px}.custom-apply-btn{width:100%;padding:var(--space-2) var(--space-4);margin-top:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-on-dark);background:var(--mi-navy);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.custom-apply-btn:hover{background:var(--mi-navy-dark)}@media(max-width:479px){.time-filter-buttons{flex-direction:column;align-items:stretch}.time-filter-btn-group{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:var(--space-1)}.time-filter-btn-group::-webkit-scrollbar{display:none}.time-filter-dropdown{width:100%}}.export-button-wrapper{position:relative;display:inline-flex}.export-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);cursor:pointer;transition:all .15s ease}.export-btn:hover{background:var(--bg-secondary);border-color:var(--text-tertiary)}.export-btn:disabled{opacity:.6;cursor:not-allowed}.export-btn-icon{padding:var(--space-2);width:36px;height:36px;justify-content:center}.export-btn-icon svg{color:var(--text-secondary)}.export-btn-icon:hover svg{color:var(--text-primary)}.export-btn .chevron{transition:transform .2s ease}.export-btn .chevron.open{transform:rotate(180deg)}.export-overlay{position:fixed;inset:0;z-index:99}.export-menu{position:absolute;top:100%;right:0;margin-top:var(--space-1);min-width:160px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:100;overflow:hidden}.export-option{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);background:none;border:none;font-size:var(--text-sm);color:var(--text-primary);cursor:pointer;transition:background .15s ease;text-align:left}.export-option:hover{background:var(--bg-secondary)}.export-option:disabled{opacity:.6;cursor:not-allowed}.export-option svg{color:var(--text-secondary);flex-shrink:0}.export-option:first-child{border-bottom:1px solid var(--border-color)}.toast-container{position:fixed;top:env(safe-area-inset-top,16px);right:16px;z-index:10000;display:flex;flex-direction:column;gap:8px;max-width:380px;width:calc(100% - 32px);pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:10px;font-size:.875rem;font-weight:500;box-shadow:0 4px 12px #00000026;animation:toast-slide-in .25s ease-out;pointer-events:auto}.toast-success{background:var(--success-green-bg, #f0fdf4);color:var(--success-green-dark, #14532d);border-left:4px solid var(--success-green, #166534)}.toast-error{background:var(--error-red-bg, #fef2f2);color:var(--error-red-dark, #7f1d1d);border-left:4px solid var(--alert-red, #991b1b)}.toast-warning{background:var(--warning-amber-bg, #fffbeb);color:var(--warning-amber-dark, #78350f);border-left:4px solid var(--pending-amber, #92400e)}.toast-info{background:var(--info-blue-bg, #f0f9ff);color:var(--action-blue-dark, #1e40af);border-left:4px solid var(--action-blue, #1b50c4)}.toast-icon{flex-shrink:0;font-size:1rem;line-height:1}.toast-message{flex:1;line-height:1.4}.toast-close{flex-shrink:0;background:none;border:none;font-size:1.125rem;cursor:pointer;opacity:.5;padding:0 4px;line-height:1;color:inherit}.toast-close:hover{opacity:1}.toast-close:focus-visible{outline:3px solid currentColor;outline-offset:2px;border-radius:4px}@keyframes toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media(prefers-reduced-motion:reduce){.toast{animation:none}}[data-a11y-pause-animations=true] .toast{animation:none}.language-switcher{position:relative;display:inline-flex;align-items:center}.language-select{appearance:none;background:var(--surface-white);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:var(--space-2) var(--space-8) var(--space-2) var(--space-3);font-size:var(--text-sm);font-family:var(--font-family-primary);color:var(--text-primary);cursor:pointer;min-width:100px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.language-select:hover{border-color:var(--action-blue)}.language-select:focus{border-color:var(--action-blue);box-shadow:0 0 0 3px var(--action-blue-lightest)}.language-select:focus-visible{outline:3px solid var(--action-blue, #2563EB);outline-offset:2px}.language-icon{position:absolute;right:var(--space-2);pointer-events:none;color:var(--text-secondary)}.language-toggle{display:inline-flex;align-items:center;gap:var(--space-1);background:transparent;border:none;padding:var(--space-2) var(--space-3);font-size:var(--text-sm);font-family:var(--font-family-primary);cursor:pointer;border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.language-toggle:hover{background:var(--surface-gray-100)}.lang-option{color:var(--text-tertiary);font-weight:var(--font-medium);transition:color var(--transition-fast)}.lang-option.active{color:var(--action-blue);font-weight:var(--font-semibold)}.lang-divider{color:var(--text-tertiary)}.language-buttons{display:inline-flex;gap:var(--space-2)}.lang-btn{display:inline-flex;align-items:center;gap:var(--space-1);background:var(--surface-white);border:1px solid var(--border-default);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);font-family:var(--font-family-primary);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.lang-btn:hover{border-color:var(--action-blue);background:var(--surface-blue-50)}.lang-btn.active{background:var(--action-blue);border-color:var(--action-blue);color:#fff}.lang-flag{font-size:var(--text-base)}.lang-label{font-weight:var(--font-medium)}.language-switcher.compact .language-select{padding:var(--space-1) var(--space-6) var(--space-1) var(--space-2);min-width:auto;font-size:var(--text-xs)}.language-toggle.compact{padding:var(--space-1) var(--space-2);font-size:var(--text-xs)}.language-switcher.dark .language-select{background:#ffffff1a;border-color:#fff3;color:#fff}.language-toggle.dark .lang-option{color:#fff9}.language-toggle.dark .lang-option.active{color:#fff}.language-toggle.dark .lang-divider{color:#fff6}.a11y-panel{display:flex;flex-direction:column;gap:1.25rem;padding:.25rem 0}.a11y-panel-desc{color:var(--text-secondary);font-size:var(--text-sm);line-height:var(--leading-normal);margin:0}.a11y-section{border:1px solid var(--border-default);border-radius:var(--radius-md);padding:1rem;margin:0}.a11y-section-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);padding:0 .5rem}.a11y-control{display:flex;flex-direction:column;gap:.25rem}.a11y-control+.a11y-control{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-light)}.a11y-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);cursor:pointer}.a11y-description{font-size:.8125rem;color:var(--text-secondary);line-height:var(--leading-normal);display:block}.a11y-toggle-row{flex-direction:row;align-items:center;justify-content:space-between;gap:1rem}.a11y-toggle-info{display:flex;flex-direction:column;gap:.125rem;flex:1;min-width:0}.a11y-switch{position:relative;display:inline-flex;width:3rem;height:1.5rem;flex-shrink:0;cursor:pointer}.a11y-switch input{opacity:0;width:0;height:0;position:absolute}.a11y-switch-slider{position:absolute;inset:0;background:var(--surface-gray-300);border-radius:var(--radius-full);transition:background var(--transition-fast)}.a11y-switch-slider:before{content:"";position:absolute;top:.1875rem;left:.1875rem;width:1.125rem;height:1.125rem;background:#fff;border-radius:var(--radius-full);box-shadow:var(--shadow-sm);transition:transform var(--transition-fast)}.a11y-switch input:checked+.a11y-switch-slider{background:var(--action-blue)}.a11y-switch input:checked+.a11y-switch-slider:before{transform:translate(1.5rem)}.a11y-switch input:focus-visible+.a11y-switch-slider{outline:3px solid var(--action-blue);outline-offset:2px}.a11y-range-row{display:flex;align-items:center;gap:.75rem;margin-top:.5rem}.a11y-range{flex:1;height:.375rem;appearance:none;-webkit-appearance:none;background:var(--surface-gray-200);border-radius:var(--radius-full);outline:none;cursor:pointer}.a11y-range::-webkit-slider-thumb{appearance:none;-webkit-appearance:none;width:1.25rem;height:1.25rem;background:var(--action-blue);border-radius:var(--radius-full);border:2px solid white;box-shadow:var(--shadow-sm);cursor:pointer}.a11y-range::-moz-range-thumb{width:1.25rem;height:1.25rem;background:var(--action-blue);border-radius:var(--radius-full);border:2px solid white;box-shadow:var(--shadow-sm);cursor:pointer}.a11y-range:focus-visible{outline:3px solid var(--action-blue);outline-offset:2px}.a11y-range-value{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--action-blue);min-width:3rem;text-align:right}.a11y-icon-preview{display:flex;gap:.75rem;margin-top:.5rem;padding:.75rem;background:var(--surface-gray-50);border-radius:var(--radius-sm);color:var(--text-secondary);border:1px dashed var(--border-default)}.a11y-preview{margin:.5rem 0 0;padding:.75rem;background:var(--surface-gray-50);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-normal);border:1px dashed var(--border-default)}.a11y-radio-group{display:flex;gap:.5rem;margin-top:.5rem}.a11y-radio-option{flex:1;display:flex;align-items:center;gap:.5rem;padding:.625rem .75rem;border:2px solid var(--border-default);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--transition-fast)}.a11y-radio-option.active{border-color:var(--action-blue);background:var(--action-blue-lightest)}.a11y-radio-option input[type=radio]{accent-color:var(--action-blue);width:1rem;height:1rem;flex-shrink:0}.a11y-radio-option input[type=radio]:focus-visible{outline:3px solid var(--action-blue);outline-offset:2px}.a11y-radio-label{display:flex;flex-direction:column;gap:.125rem;min-width:0}.a11y-radio-label strong{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}.a11y-radio-label span{font-size:.75rem;color:var(--text-secondary)}.a11y-focus-demo{margin-top:.75rem;padding:.5rem 1rem;background:var(--surface-gray-100);border:1px solid var(--border-default);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;text-align:center}.a11y-focus-demo:hover{background:var(--surface-gray-200)}.a11y-focus-demo:focus-visible,.a11y-focus-demo-active{outline:3px solid var(--action-blue);outline-offset:2px}[data-a11y-enhanced-focus=true] .a11y-focus-demo:focus-visible,[data-a11y-enhanced-focus=true] .a11y-focus-demo-active{outline:4px solid var(--alert-red);outline-offset:4px;box-shadow:0 0 0 6px #991b1b4d}.a11y-actions{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding-top:.5rem;border-top:1px solid var(--border-default)}.a11y-contrast-indicator{font-size:.8125rem}.a11y-contrast-badge{padding:.25rem .625rem;border-radius:var(--radius-full);font-weight:var(--font-medium)}.a11y-contrast-badge.pass{background:var(--success-green-bg);color:var(--success-green)}.a11y-contrast-badge.fail{background:var(--error-red-bg);color:var(--alert-red)}.a11y-reset-btn{padding:.5rem 1.25rem;background:var(--surface-gray-100);border:1px solid var(--border-default);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);cursor:pointer;transition:background var(--transition-fast)}.a11y-reset-btn:hover{background:var(--surface-gray-200)}.a11y-reset-btn:focus-visible{outline:3px solid var(--action-blue);outline-offset:2px}.a11y-radio-group--vertical{flex-direction:column}[data-a11y-pause-animations=true] *,[data-a11y-pause-animations=true] *:before,[data-a11y-pause-animations=true] *:after{animation:none!important;transition-duration:0s!important}[data-a11y-pause-animations=true] *:focus-visible{transition-duration:0s!important;outline-style:solid!important}.a11y-theme-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-top:.5rem}.a11y-theme-card{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.375rem;border:2px solid var(--border-default);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--transition-fast),background var(--transition-fast)}.a11y-theme-card:hover{border-color:var(--action-blue-light);background:var(--surface-gray-50)}.a11y-theme-card.active{border-color:var(--action-blue);background:var(--action-blue-lightest)}.a11y-theme-card input[type=radio]{position:absolute;opacity:0;width:0;height:0}.a11y-theme-preview{width:100%;height:48px;border-radius:4px;overflow:hidden;background:var(--surface-gray-50);display:flex;align-items:center;justify-content:center}.a11y-theme-preview--wide{height:32px}.a11y-theme-img{width:100%;height:100%;object-fit:cover}.a11y-theme-none{width:24px;height:2px;background:var(--surface-gray-300);border-radius:1px}.a11y-theme-name{font-size:.6875rem;font-weight:var(--font-medium);color:var(--text-secondary);text-align:center}.a11y-theme-card.active .a11y-theme-name{color:var(--action-blue);font-weight:var(--font-semibold)}@media(max-width:479px){.a11y-radio-group{flex-direction:column}}.breadcrumb-nav{padding:.5rem 0;margin-bottom:.5rem}.breadcrumb-list{display:flex;flex-wrap:wrap;align-items:center;gap:0;list-style:none;margin:0;padding:0;font-size:var(--text-sm, .875rem);line-height:var(--leading-normal, 1.5)}.breadcrumb-item{display:flex;align-items:center}.breadcrumb-link{color:var(--action-blue, #1b50c4);text-decoration:none;padding:.125rem .25rem;border-radius:var(--radius-sm, 4px);min-height:24px;display:inline-flex;align-items:center}.breadcrumb-link:hover{text-decoration:underline;background:var(--action-blue-lightest, #eff6ff)}.breadcrumb-link:focus-visible{outline:2px solid var(--action-blue, #1b50c4);outline-offset:2px}.breadcrumb-separator{margin:0 .375rem;color:var(--text-muted, #9CA3AF);-webkit-user-select:none;user-select:none}.breadcrumb-current{color:var(--text-primary, #1F2937);font-weight:600;padding:.125rem .25rem}.glossary-wrapper{position:relative;display:inline}.glossary-trigger{cursor:help;border-bottom:1.5px dotted var(--action-blue, #1b50c4);color:inherit;background:none;padding:0;font:inherit;text-decoration:none}.glossary-trigger--abbreviation{font-variant:small-caps;letter-spacing:.03em}.glossary-trigger:hover,.glossary-trigger:focus-visible{border-bottom-style:solid;background:var(--action-blue-lightest, #eff6ff);border-radius:2px}.glossary-trigger:focus-visible{outline:2px solid var(--action-blue, #1b50c4);outline-offset:2px}.glossary-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);z-index:1000;display:flex;flex-direction:column;gap:.25rem;min-width:180px;max-width:320px;padding:.75rem 1rem;background:var(--surface-primary, #ffffff);color:var(--text-primary, #1F2937);border:1px solid var(--border-default, #D1D5DB);border-radius:var(--radius-md, 8px);box-shadow:0 4px 12px #00000026;font-size:var(--text-sm, .875rem);line-height:var(--leading-normal, 1.5);text-align:start;white-space:normal}.glossary-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--surface-primary, #ffffff)}.glossary-tooltip:before{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:7px solid transparent;border-top-color:var(--border-default, #D1D5DB)}.glossary-tooltip-label{font-size:var(--text-xs, .75rem);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted, #6B7280)}.glossary-tooltip-term{font-weight:700;color:var(--text-primary, #1F2937)}.glossary-tooltip-definition{color:var(--text-secondary, #4B5563)}@media(prefers-reduced-motion:reduce){.glossary-tooltip{animation:none}}@media(forced-colors:active){.glossary-trigger{border-bottom-color:LinkText}.glossary-tooltip{border:2px solid CanvasText}}.reading-toggle__controls{display:inline-flex;gap:0;margin-bottom:var(--space-3);border:1px solid var(--surface-gray-200);border-radius:var(--radius-md);overflow:hidden}.reading-toggle__btn{padding:var(--space-2) var(--space-3);background:var(--surface-white);border:none;border-right:1px solid var(--surface-gray-200);color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;display:inline-flex;align-items:center;gap:var(--space-1);transition:all var(--transition-fast);min-height:var(--min-target)}.reading-toggle__btn:last-child{border-right:none}.reading-toggle__btn:hover{background:var(--surface-gray-100)}.reading-toggle__btn.is-active{background:var(--mi-navy);color:var(--text-on-dark)}.reading-toggle__badge{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;background:#ffffff40;border-radius:var(--radius-full);font-size:var(--text-xs);line-height:1}.reading-toggle__content{margin-top:var(--space-2)}.reading-toggle__simplified{position:relative;padding:var(--space-3);background:var(--info-blue-bg, #eff6ff);border:1px solid var(--action-blue);border-radius:var(--radius-md);border-left:4px solid var(--action-blue)}@media(max-width:479px){.reading-toggle__controls{width:100%}.reading-toggle__btn{flex:1;justify-content:center}}@media(forced-colors:active){.reading-toggle__btn.is-active{background:Highlight;color:HighlightText}.reading-toggle__simplified{border:2px solid LinkText}}.ctx-help{display:inline-block;position:relative}.ctx-help__btn{display:inline-flex;align-items:center;justify-content:center;width:var(--min-target);height:var(--min-target);padding:0;background:transparent;border:1px solid var(--surface-gray-200);border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.ctx-help__btn:hover{background:var(--surface-gray-100);color:var(--action-blue);border-color:var(--action-blue)}.ctx-help__btn.is-open{background:var(--action-blue);color:#fff;border-color:var(--action-blue)}.ctx-help__panel{margin-top:var(--space-2);padding:var(--space-3);background:var(--info-blue-bg, #eff6ff);border:1px solid var(--action-blue);border-left:4px solid var(--action-blue);border-radius:var(--radius-md)}.ctx-help__panel[hidden]{display:none}.ctx-help__text{margin:0 0 var(--space-2) 0;font-size:var(--text-sm);color:var(--text-primary);line-height:var(--leading-normal)}.ctx-help__text:last-child{margin-bottom:0}.ctx-help__example{margin-top:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--surface-white);border:1px solid var(--surface-gray-200);border-radius:var(--radius-sm)}.ctx-help__example-label{display:block;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-1)}.ctx-help__example-text{margin:0;font-size:var(--text-sm);color:var(--text-primary);font-style:italic}.ctx-help__link{display:inline-block;margin-top:var(--space-2);font-size:var(--text-sm);color:var(--action-blue);text-decoration:underline}.ctx-help__link:hover{color:var(--action-blue-dark)}@media(forced-colors:active){.ctx-help__btn{border:1px solid ButtonText}.ctx-help__btn.is-open{background:Highlight;color:HighlightText}.ctx-help__panel{border:2px solid LinkText}.ctx-help__example{border:1px solid CanvasText}}.header{background:var(--mi-navy);color:var(--text-on-dark);position:sticky;top:0;z-index:calc(var(--z-sticky) + 2)}.header-content{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);min-height:56px}.header-left{display:flex;align-items:center;gap:var(--space-3)}.header-back-btn{background:none;border:none;color:var(--text-on-dark);padding:var(--space-2);margin:calc(-1 * var(--space-2));cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);transition:background var(--transition-fast)}.header-back-btn:hover{background:#ffffff1a}.header-title{font-size:var(--text-lg);font-weight:var(--font-semibold);margin:0;color:var(--text-on-dark)}.header-logo{height:36px;width:auto;object-fit:contain;border-radius:var(--radius-sm)}.header-right{display:flex;align-items:center;gap:var(--space-3)}.header-user{display:flex;align-items:center;gap:var(--space-2);position:relative}.header-avatar-btn{display:flex;align-items:center;gap:var(--space-1);background:none;border:none;cursor:pointer;padding:var(--space-1);margin:calc(-1 * var(--space-1));border-radius:var(--radius-lg);transition:background var(--transition-fast)}.header-avatar-btn:hover{background:#ffffff1a}.header-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--action-blue);display:flex;align-items:center;justify-content:center;font-weight:var(--font-semibold);font-size:var(--text-sm);color:#fff}.header-avatar-img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-full)}.header-avatar-chevron{transition:transform var(--transition-fast);opacity:.8}.header-avatar-chevron.open{transform:rotate(180deg)}.user-dropdown-menu{position:absolute;top:calc(100% + var(--space-2));right:0;min-width:240px;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);animation:dropdownFadeIn .15s ease-out;overflow:hidden}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.user-dropdown-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--surface-gray-50);border-bottom:1px solid var(--surface-gray-100)}.user-dropdown-avatar{width:44px;height:44px;border-radius:var(--radius-full);background:var(--mi-navy);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:var(--font-bold);font-size:var(--text-lg)}.user-dropdown-info{display:flex;flex-direction:column;gap:var(--space-1)}.user-dropdown-name{font-weight:var(--font-semibold);font-size:var(--text-base);color:var(--text-primary)}.user-dropdown-role{font-size:var(--text-sm);color:var(--text-secondary);text-transform:capitalize}.user-dropdown-divider{height:1px;background:var(--surface-gray-100);margin:var(--space-2) 0}.user-dropdown-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);background:none;border:none;cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);text-align:left;transition:background var(--transition-fast)}.user-dropdown-item:hover{background:var(--surface-gray-50)}.user-dropdown-item svg{color:var(--text-secondary);flex-shrink:0}.user-dropdown-item:hover svg{color:var(--mi-navy)}.user-dropdown-item.logout{color:var(--alert-red)}.user-dropdown-item.logout svg{color:var(--alert-red)}.user-dropdown-item.logout:hover{background:var(--error-red-bg)}.header-a11y-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-on-dark);padding:var(--space-2);margin:calc(-1 * var(--space-1));cursor:pointer;border-radius:var(--radius-full);transition:background var(--transition-fast)}.header-a11y-btn:hover{background:#ffffff1a}.header-a11y-btn:focus-visible{outline:3px solid white;outline-offset:2px}.header-lang-toggle{color:var(--text-on-dark)}.header-lang-toggle .lang-option{color:#fff9}.header-lang-toggle .lang-option.active{color:#fff}.header-lang-toggle .lang-divider{color:#fff6}.header-lang-toggle:hover{background:#ffffff1a}.app-layout{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;background-color:var(--surface-gray-50);isolation:isolate}html:not([data-a11y-background-theme=none]) .app-layout:before{content:"";position:fixed;inset:0;background-repeat:repeat;background-size:600px 600px;opacity:.04;pointer-events:none;z-index:-1}html[data-a11y-background-theme=education] .app-layout:before{background-image:url(/backgrounds/education-pattern.svg)}html[data-a11y-background-theme=geometric] .app-layout:before{background-image:url(/backgrounds/geometric-pattern.svg)}html[data-a11y-background-theme=nature] .app-layout:before{background-image:url(/backgrounds/nature-pattern.svg)}html[data-a11y-background-theme=creative] .app-layout:before{background-image:url(/backgrounds/creative-pattern.svg)}html[data-a11y-background-theme=space] .app-layout:before{background-image:url(/backgrounds/space-pattern.svg)}.app-main{flex:1;padding-bottom:calc(70px + env(safe-area-inset-bottom,0px));overflow-y:auto;-webkit-overflow-scrolling:touch}@media(orientation:landscape)and (max-height:500px){.app-main{padding-bottom:calc(56px + env(safe-area-inset-bottom,0px))}}@media(min-width:768px){.app-main{max-width:1200px;margin:0 auto;width:100%;padding-left:var(--space-4);padding-right:var(--space-4)}}.app-layout{padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-4);background:linear-gradient(135deg,var(--mi-navy-dark) 0%,var(--mi-navy) 50%,var(--mi-navy-light) 100%)}.auth-container{width:100%;max-width:400px;background:var(--surface-white);border-radius:var(--radius-2xl);padding:var(--space-8);box-shadow:var(--shadow-2xl)}.auth-header{text-align:center;margin-bottom:var(--space-6)}.auth-logo{width:80px;height:80px;margin:0 auto var(--space-4)}.auth-logo img{width:100%;height:100%;border-radius:var(--radius-lg);object-fit:cover}.auth-title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--mi-navy);margin:0 0 var(--space-2) 0}.auth-subtitle{font-size:var(--text-base);color:var(--text-secondary);margin:0}.auth-form{display:flex;flex-direction:column;gap:var(--space-4)}.auth-error{background:var(--error-red-bg);color:var(--error-red-dark);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);text-align:center}.auth-footer{margin-top:var(--space-6);text-align:center}.auth-footer p{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.auth-link{color:var(--action-blue);font-weight:var(--font-semibold);text-decoration:none}.auth-link:hover{text-decoration:underline}.auth-demo{margin-top:var(--space-6);padding-top:var(--space-4);border-top:1px solid var(--surface-gray-200)}.auth-demo-title{font-size:var(--text-xs);color:var(--text-tertiary);text-align:center;margin:0 0 var(--space-3) 0;text-transform:uppercase;letter-spacing:.5px}.auth-demo-accounts{display:flex;flex-wrap:wrap;gap:var(--space-2);justify-content:center}.auth-demo-btn{padding:var(--space-2) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--text-secondary);background:var(--surface-gray-100);border:1px solid var(--surface-gray-200);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast)}.auth-demo-btn:hover{background:var(--action-blue-lightest);border-color:var(--action-blue);color:var(--action-blue)}.auth-demo-subtitle{font-size:var(--text-xs);color:var(--text-tertiary);text-align:center;margin:var(--space-4) 0 var(--space-2) 0;text-transform:uppercase;letter-spacing:.5px;opacity:.7}.auth-demo-btn.coming-soon{background:var(--surface-gray-50);border-color:var(--surface-gray-200);color:var(--text-tertiary);opacity:.7}.auth-demo-btn.coming-soon:hover{background:var(--warning-yellow-bg);border-color:var(--warning-yellow);color:var(--warning-yellow-dark);opacity:1}.under-dev-modal{text-align:center;padding:var(--space-4) 0}.under-dev-icon{width:80px;height:80px;margin:0 auto var(--space-4);background:linear-gradient(135deg,var(--mi-blue-lightest) 0%,var(--action-blue-lightest) 100%);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}.under-dev-icon svg{stroke:var(--action-blue)}.under-dev-title{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--mi-navy);margin:0 0 var(--space-3) 0}.under-dev-message{font-size:var(--text-base);color:var(--text-secondary);margin:0 0 var(--space-2) 0;line-height:1.5}.under-dev-submessage{font-size:var(--text-sm);color:var(--text-tertiary);margin:0 0 var(--space-6) 0}@media(max-width:480px){.auth-container{padding:var(--space-6)}}.app{min-height:100vh;display:flex;flex-direction:column}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.p-4{padding:var(--space-4)}.mt-4{margin-top:var(--space-4)}.mb-4{margin-bottom:var(--space-4)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.animate-fade-in{animation:fadeIn .3s ease}.animate-slide-up{animation:slideUp .3s ease}.animate-slide-in{animation:slideIn .3s ease}:focus-visible{outline:3px solid var(--action-blue);outline-offset:2px}button,a{-webkit-tap-highlight-color:transparent}html{scroll-behavior:smooth}::selection{background:var(--action-blue-lightest);color:var(--mi-navy)}
