:root{--primary-50: #eff6ff;--primary-100: #dbeafe;--primary-200: #bfdbfe;--primary-300: #93c5fd;--primary-400: #60a5fa;--primary-500: #3b82f6;--primary-600: #2563eb;--primary-700: #1d4ed8;--primary-800: #1e40af;--primary-900: #1e3a8a;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--red-50: #fef2f2;--red-100: #fee2e2;--red-200: #fecaca;--red-300: #fca5a5;--red-400: #f87171;--red-500: #ef4444;--red-600: #dc2626;--red-700: #b91c1c;--red-800: #991b1b;--red-900: #7f1d1d;--green-50: #f0fdf4;--green-100: #dcfce7;--green-200: #bbf7d0;--green-300: #86efac;--green-400: #4ade80;--green-500: #22c55e;--green-600: #16a34a;--green-700: #15803d;--green-800: #166534;--green-900: #14532d;--yellow-50: #fefce8;--yellow-100: #fef9c3;--yellow-200: #fef08a;--yellow-300: #fde047;--yellow-400: #facc15;--yellow-500: #eab308;--yellow-600: #ca8a04;--yellow-700: #a16207;--yellow-800: #854d0e;--yellow-900: #713f12;--blue-50: #eff6ff;--blue-100: #dbeafe;--blue-200: #bfdbfe;--blue-300: #93c5fd;--blue-400: #60a5fa;--blue-500: #3b82f6;--blue-600: #2563eb;--blue-700: #1d4ed8;--blue-800: #1e40af;--blue-900: #1e3a8a;--orange-50: #fff7ed;--orange-100: #ffedd5;--orange-200: #fed7aa;--orange-500: #f97316;--orange-600: #ea580c;--orange-700: #c2410c;--orange-800: #9a3412;--purple-50: #faf5ff;--purple-100: #f3e8ff;--purple-500: #a855f7;--purple-600: #9333ea;--spacing-0: 0;--spacing-1: .25rem;--spacing-2: .5rem;--spacing-3: .75rem;--spacing-4: 1rem;--spacing-5: 1.25rem;--spacing-6: 1.5rem;--spacing-8: 2rem;--spacing-10: 2.5rem;--spacing-12: 3rem;--spacing-16: 4rem;--spacing-20: 5rem;--radius-none: 0;--radius-sm: .125rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: .75rem;--radius-2xl: 1rem;--radius-3xl: 1.5rem;--radius-full: 9999px;--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;--text-5xl: 3rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--leading-none: 1;--leading-tight: 1.25;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--leading-loose: 2;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / .25);--sidebar-width: 260px;--sidebar-width-collapsed: 80px;--header-height: 64px;--mobile-header-height: 56px;--transition-fast: .15s;--transition-normal: .2s;--transition-slow: .3s;--z-dropdown: 10;--z-sticky: 20;--z-fixed: 30;--z-overlay: 40;--z-modal: 50;--z-popover: 60;--z-tooltip: 70}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:var(--leading-normal);color:var(--gray-900);background-color:var(--gray-50);min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:var(--font-semibold);line-height:var(--leading-tight);color:var(--gray-900)}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}h5{font-size:var(--text-base)}h6{font-size:var(--text-sm)}p{margin:0;color:var(--gray-600)}a{color:var(--primary-600);text-decoration:none}a:hover{color:var(--primary-700);text-decoration:underline}ul,ol{list-style:none}img,svg{display:block;max-width:100%;height:auto}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none}button:disabled{cursor:not-allowed}input,textarea,select{font-family:inherit;font-size:inherit}table{border-collapse:collapse;width:100%}:focus-visible{outline:2px solid var(--primary-500);outline-offset:2px}::selection{background-color:var(--primary-100);color:var(--primary-900)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--gray-100);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}*{scrollbar-width:thin;scrollbar-color:var(--gray-300) var(--gray-100)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.flex-1{flex:1 1 0%}.flex-auto{flex:1 1 auto}.flex-shrink-0{flex-shrink:0}.flex-grow{flex-grow:1}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.self-start{align-self:flex-start}.self-center{align-self:center}.self-end{align-self:flex-end}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.gap-0{gap:0}.gap-1{gap:var(--spacing-1)}.gap-2{gap:var(--spacing-2)}.gap-3{gap:var(--spacing-3)}.gap-4{gap:var(--spacing-4)}.gap-5{gap:var(--spacing-5)}.gap-6{gap:var(--spacing-6)}.gap-8{gap:var(--spacing-8)}.space-y-1>*+*{margin-top:var(--spacing-1)}.space-y-2>*+*{margin-top:var(--spacing-2)}.space-y-3>*+*{margin-top:var(--spacing-3)}.space-y-4>*+*{margin-top:var(--spacing-4)}.space-y-6>*+*{margin-top:var(--spacing-6)}.space-y-8>*+*{margin-top:var(--spacing-8)}.space-x-1>*+*{margin-left:var(--spacing-1)}.space-x-2>*+*{margin-left:var(--spacing-2)}.space-x-3>*+*{margin-left:var(--spacing-3)}.space-x-4>*+*{margin-left:var(--spacing-4)}.p-0{padding:0}.p-1{padding:var(--spacing-1)}.p-2{padding:var(--spacing-2)}.p-3{padding:var(--spacing-3)}.p-4{padding:var(--spacing-4)}.p-5{padding:var(--spacing-5)}.p-6{padding:var(--spacing-6)}.p-8{padding:var(--spacing-8)}.px-1{padding-left:var(--spacing-1);padding-right:var(--spacing-1)}.px-2{padding-left:var(--spacing-2);padding-right:var(--spacing-2)}.px-3{padding-left:var(--spacing-3);padding-right:var(--spacing-3)}.px-4{padding-left:var(--spacing-4);padding-right:var(--spacing-4)}.px-5{padding-left:var(--spacing-5);padding-right:var(--spacing-5)}.px-6{padding-left:var(--spacing-6);padding-right:var(--spacing-6)}.px-8{padding-left:var(--spacing-8);padding-right:var(--spacing-8)}.py-1{padding-top:var(--spacing-1);padding-bottom:var(--spacing-1)}.py-2{padding-top:var(--spacing-2);padding-bottom:var(--spacing-2)}.py-3{padding-top:var(--spacing-3);padding-bottom:var(--spacing-3)}.py-4{padding-top:var(--spacing-4);padding-bottom:var(--spacing-4)}.py-5{padding-top:var(--spacing-5);padding-bottom:var(--spacing-5)}.py-6{padding-top:var(--spacing-6);padding-bottom:var(--spacing-6)}.py-8{padding-top:var(--spacing-8);padding-bottom:var(--spacing-8)}.py-12{padding-top:var(--spacing-12);padding-bottom:var(--spacing-12)}.pt-1{padding-top:var(--spacing-1)}.pt-2{padding-top:var(--spacing-2)}.pt-4{padding-top:var(--spacing-4)}.pt-6{padding-top:var(--spacing-6)}.pb-1{padding-bottom:var(--spacing-1)}.pb-2{padding-bottom:var(--spacing-2)}.pb-4{padding-bottom:var(--spacing-4)}.pb-6{padding-bottom:var(--spacing-6)}.pl-2{padding-left:var(--spacing-2)}.pl-4{padding-left:var(--spacing-4)}.pr-2{padding-right:var(--spacing-2)}.pr-4{padding-right:var(--spacing-4)}.m-0{margin:0}.m-1{margin:var(--spacing-1)}.m-2{margin:var(--spacing-2)}.m-4{margin:var(--spacing-4)}.m-auto{margin:auto}.mx-auto{margin-left:auto;margin-right:auto}.my-auto{margin-top:auto;margin-bottom:auto}.mt-0{margin-top:0}.mt-1{margin-top:var(--spacing-1)}.mt-2{margin-top:var(--spacing-2)}.mt-3{margin-top:var(--spacing-3)}.mt-4{margin-top:var(--spacing-4)}.mt-6{margin-top:var(--spacing-6)}.mt-8{margin-top:var(--spacing-8)}.mb-0{margin-bottom:0}.mb-1{margin-bottom:var(--spacing-1)}.mb-2{margin-bottom:var(--spacing-2)}.mb-3{margin-bottom:var(--spacing-3)}.mb-4{margin-bottom:var(--spacing-4)}.mb-6{margin-bottom:var(--spacing-6)}.mb-8{margin-bottom:var(--spacing-8)}.ml-1{margin-left:var(--spacing-1)}.ml-2{margin-left:var(--spacing-2)}.ml-4{margin-left:var(--spacing-4)}.ml-auto{margin-left:auto}.mr-1{margin-right:var(--spacing-1)}.mr-2{margin-right:var(--spacing-2)}.mr-4{margin-right:var(--spacing-4)}.mr-auto{margin-right:auto}.w-full{width:100%}.w-auto{width:auto}.w-screen{width:100vw}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-8{width:2rem}.w-10{width:2.5rem}.w-12{width:3rem}.h-full{height:100%}.h-auto{height:auto}.h-screen{height:100vh}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-8{height:2rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-64{height:16rem}.min-h-screen{min-height:100vh}.min-w-0{min-width:0}.max-w-full{max-width:100%}.max-w-sm{max-width:24rem}.max-w-md{max-width:28rem}.max-w-lg{max-width:32rem}.max-w-xl{max-width:36rem}.max-w-2xl{max-width:42rem}.max-w-4xl{max-width:56rem}.text-xs{font-size:var(--text-xs);line-height:1rem}.text-sm{font-size:var(--text-sm);line-height:1.25rem}.text-base{font-size:var(--text-base);line-height:1.5rem}.text-lg{font-size:var(--text-lg);line-height:1.75rem}.text-xl{font-size:var(--text-xl);line-height:1.75rem}.text-2xl{font-size:var(--text-2xl);line-height:2rem}.text-3xl{font-size:var(--text-3xl);line-height:2.25rem}.text-4xl{font-size:var(--text-4xl);line-height:2.5rem}.font-normal{font-weight:var(--font-normal)}.font-medium{font-weight:var(--font-medium)}.font-semibold{font-weight:var(--font-semibold)}.font-bold{font-weight:var(--font-bold)}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.leading-none{line-height:1}.leading-tight{line-height:1.25}.leading-normal{line-height:1.5}.leading-relaxed{line-height:1.625}.tracking-tight{letter-spacing:-.025em}.tracking-normal{letter-spacing:0}.tracking-wide{letter-spacing:.025em}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.break-words{word-wrap:break-word;overflow-wrap:break-word}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-line{white-space:pre-line}.text-white{color:#fff}.text-black{color:#000}.text-transparent{color:transparent}.text-gray-400{color:var(--gray-400)}.text-gray-500{color:var(--gray-500)}.text-gray-600{color:var(--gray-600)}.text-gray-700{color:var(--gray-700)}.text-gray-800{color:var(--gray-800)}.text-gray-900{color:var(--gray-900)}.text-red-500{color:var(--red-500)}.text-red-600{color:var(--red-600)}.text-red-700{color:var(--red-700)}.text-red-800{color:var(--red-800)}.text-green-500{color:var(--green-500)}.text-green-600{color:var(--green-600)}.text-green-700{color:var(--green-700)}.text-green-800{color:var(--green-800)}.text-blue-500{color:var(--blue-500)}.text-blue-600{color:var(--blue-600)}.text-blue-700{color:var(--blue-700)}.text-blue-800{color:var(--blue-800)}.text-yellow-500{color:var(--yellow-500)}.text-yellow-600{color:var(--yellow-600)}.text-yellow-800{color:var(--yellow-800)}.text-orange-600{color:var(--orange-600)}.text-orange-800{color:var(--orange-800)}.text-purple-600{color:var(--purple-600)}.text-primary-600{color:var(--primary-600)}.text-primary-700{color:var(--primary-700)}.bg-white{background-color:#fff}.bg-black{background-color:#000}.bg-transparent{background-color:transparent}.bg-gray-50{background-color:var(--gray-50)}.bg-gray-100{background-color:var(--gray-100)}.bg-gray-200{background-color:var(--gray-200)}.bg-gray-300{background-color:var(--gray-300)}.bg-gray-400{background-color:var(--gray-400)}.bg-gray-500{background-color:var(--gray-500)}.bg-red-50{background-color:var(--red-50)}.bg-red-100{background-color:var(--red-100)}.bg-red-500{background-color:var(--red-500)}.bg-red-600{background-color:var(--red-600)}.bg-green-50{background-color:var(--green-50)}.bg-green-100{background-color:var(--green-100)}.bg-green-500{background-color:var(--green-500)}.bg-green-600{background-color:var(--green-600)}.bg-blue-50{background-color:var(--blue-50)}.bg-blue-100{background-color:var(--blue-100)}.bg-blue-500{background-color:var(--blue-500)}.bg-blue-600{background-color:var(--blue-600)}.bg-yellow-50{background-color:var(--yellow-50)}.bg-yellow-100{background-color:var(--yellow-100)}.bg-yellow-500{background-color:var(--yellow-500)}.bg-orange-100{background-color:var(--orange-100)}.bg-purple-100{background-color:var(--purple-100)}.bg-primary-50{background-color:var(--primary-50)}.bg-primary-100{background-color:var(--primary-100)}.bg-primary-500{background-color:var(--primary-500)}.bg-primary-600{background-color:var(--primary-600)}.bg-primary-700{background-color:var(--primary-700)}.border{border:1px solid var(--gray-200)}.border-0{border:none}.border-2{border-width:2px}.border-t{border-top:1px solid var(--gray-200)}.border-b{border-bottom:1px solid var(--gray-200)}.border-l{border-left:1px solid var(--gray-200)}.border-r{border-right:1px solid var(--gray-200)}.border-l-4{border-left-width:4px;border-left-style:solid}.border-gray-100{border-color:var(--gray-100)}.border-gray-200{border-color:var(--gray-200)}.border-gray-300{border-color:var(--gray-300)}.border-gray-400{border-color:var(--gray-400)}.border-gray-600{border-color:var(--gray-600)}.border-red-200{border-color:var(--red-200)}.border-red-500{border-color:var(--red-500)}.border-green-200{border-color:var(--green-200)}.border-green-500{border-color:var(--green-500)}.border-blue-200{border-color:var(--blue-200)}.border-blue-500{border-color:var(--blue-500)}.border-yellow-200{border-color:var(--yellow-200)}.border-primary-500{border-color:var(--primary-500)}.border-primary-600{border-color:var(--primary-600)}.border-transparent{border-color:transparent}.rounded-none{border-radius:0}.rounded-sm{border-radius:var(--radius-sm)}.rounded,.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-3xl{border-radius:var(--radius-3xl)}.rounded-full{border-radius:var(--radius-full)}.shadow-none{box-shadow:none}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow{box-shadow:var(--shadow)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.shadow-2xl{box-shadow:var(--shadow-2xl)}.static{position:static}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.inset-0{inset:0}.top-0{top:0}.right-0{right:0}.bottom-0{bottom:0}.left-0{left:0}.z-0{z-index:0}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-visible{overflow:visible}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.overflow-x-hidden{overflow-x:hidden}.overflow-y-hidden{overflow-y:hidden}.cursor-auto{cursor:auto}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.cursor-wait{cursor:wait}.opacity-0{opacity:0}.opacity-25{opacity:.25}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.opacity-100{opacity:1}.visible{visibility:visible}.invisible{visibility:hidden}.transition-none{transition:none}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:var(--transition-normal)}.transition-colors{transition-property:color,background-color,border-color;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:var(--transition-normal)}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:var(--transition-normal)}.transform{transform:translate(0)}.scale-100{transform:scale(1)}.scale-105{transform:scale(1.05)}.rotate-180{transform:rotate(180deg)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,to{transform:translateY(-25%);animation-timing-function:cubic-bezier(.8,0,1,1)}50%{transform:translateY(0);animation-timing-function:cubic-bezier(0,0,.2,1)}}.animate-spin{animation:spin 1s linear infinite}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.animate-bounce{animation:bounce 1s infinite}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.select-none{-webkit-user-select:none;user-select:none}.select-text{-webkit-user-select:text;user-select:text}.select-all{-webkit-user-select:all;user-select:all}.object-cover{object-fit:cover}.object-contain{object-fit:contain}.object-fill{object-fit:fill}.hover\:bg-gray-50:hover{background-color:var(--gray-50)}.hover\:bg-gray-100:hover{background-color:var(--gray-100)}.hover\:bg-gray-200:hover{background-color:var(--gray-200)}.hover\:bg-primary-50:hover{background-color:var(--primary-50)}.hover\:bg-primary-700:hover{background-color:var(--primary-700)}.hover\:bg-red-700:hover{background-color:var(--red-700)}.hover\:bg-green-700:hover{background-color:var(--green-700)}.hover\:text-gray-700:hover{color:var(--gray-700)}.hover\:text-gray-900:hover{color:var(--gray-900)}.hover\:text-primary-700:hover{color:var(--primary-700)}.hover\:shadow-md:hover{box-shadow:var(--shadow-md)}.hover\:shadow-lg:hover{box-shadow:var(--shadow-lg)}.focus\:outline-none:focus{outline:none}.focus\:ring-2:focus{box-shadow:0 0 0 2px var(--primary-500)}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}@media print{.print\:hidden{display:none!important}}.main-layout{display:flex;min-height:100vh;width:100%}.main-content-wrapper{flex:1;display:flex;flex-direction:column;min-width:0;margin-left:0;transition:margin-left .3s ease}@media(min-width:1024px){.main-content-wrapper{margin-left:var(--sidebar-width)}}.main-content{flex:1;padding:var(--spacing-4);overflow-x:hidden;width:100%;max-width:100%;background-color:var(--gray-50)}@media(min-width:768px){.main-content{padding:var(--spacing-6)}}@media(min-width:1024px){.main-content{padding:var(--spacing-8)}}.sidebar{position:fixed;top:0;left:0;height:100vh;width:var(--sidebar-width);background-color:#fff;border-right:1px solid var(--gray-200);color:var(--gray-900);z-index:var(--z-overlay);transform:translate(-100%);transition:transform .3s ease;display:flex;flex-direction:column;overflow-y:auto}.sidebar-open{transform:translate(0)}@media(min-width:1024px){.sidebar{transform:translate(0)}}.sidebar-overlay{position:fixed;inset:0;background-color:#00000080;z-index:var(--z-fixed);opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.sidebar-overlay-visible{opacity:1;visibility:visible}@media(min-width:1024px){.sidebar-overlay{display:none}}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-4);border-bottom:1px solid var(--gray-200)}.sidebar-logo{display:flex;align-items:center;gap:var(--spacing-3)}.sidebar-logo-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-logo-icon .sidebar-logo-3d{filter:drop-shadow(0 2px 4px rgba(59,130,246,.3));transition:transform .2s ease}.sidebar-logo:hover .sidebar-logo-3d{transform:scale(1.05)}.sidebar-logo-text{display:flex;flex-direction:column}.sidebar-logo-text h1{font-size:var(--text-xl);font-weight:700;color:var(--gray-900);margin:0;line-height:1.2}.sidebar-logo-text p{font-size:var(--text-xs);color:var(--gray-500);margin:0}.sidebar-close-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:var(--gray-100);border-radius:var(--radius-md);color:var(--gray-600);cursor:pointer;transition:background-color .2s ease}.sidebar-close-btn:hover{background:var(--gray-200);color:var(--gray-900)}@media(min-width:1024px){.sidebar-close-btn{display:none}}.sidebar-nav{flex:1;padding:var(--spacing-4);display:flex;flex-direction:column;gap:var(--spacing-1)}.sidebar-nav-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-lg);color:var(--gray-600);text-decoration:none;font-size:var(--text-sm);font-weight:500;transition:all .2s ease}.sidebar-nav-item:hover{background:var(--gray-100);color:var(--gray-900);text-decoration:none}.sidebar-nav-item.active{background:var(--primary-50);color:var(--primary-600)}.sidebar-nav-item span{color:inherit}.header{position:sticky;top:0;z-index:var(--z-sticky);display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-3) var(--spacing-4);background-color:#fff;border-bottom:1px solid var(--gray-200);height:var(--mobile-header-height);gap:var(--spacing-2)}@media(min-width:768px){.header{padding:var(--spacing-4) var(--spacing-6);height:var(--header-height);gap:var(--spacing-4)}}.header-left{display:flex;align-items:center;gap:var(--spacing-3);min-width:0}.header-title{font-size:var(--text-lg);font-weight:600;color:var(--gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:none}@media(min-width:640px){.header-title{display:block}}.mobile-menu-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:var(--gray-100);border-radius:var(--radius-md);color:var(--gray-700);cursor:pointer;transition:background-color .2s ease;flex-shrink:0}.mobile-menu-btn:hover{background:var(--gray-200)}@media(min-width:1024px){.mobile-menu-btn{display:none}}.header-actions{display:flex;align-items:center;gap:var(--spacing-2);flex-shrink:0}@media(min-width:768px){.header-actions{gap:var(--spacing-3)}}.user-menu{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2);background:var(--gray-50);border-radius:var(--radius-lg)}.user-info{display:none}@media(min-width:640px){.user-info{display:flex;flex-direction:column;align-items:flex-start}}.user-name{font-size:var(--text-sm);font-weight:500;color:var(--gray-900);margin:0;white-space:nowrap}.btn-text-mobile-hidden{display:none}@media(min-width:640px){.btn-text-mobile-hidden{display:inline}}.page-header{display:flex;flex-direction:column;gap:var(--spacing-4);margin-bottom:var(--spacing-6)}@media(min-width:640px){.page-header{flex-direction:row;align-items:center;justify-content:space-between}}.page-header-title{font-size:var(--text-xl);font-weight:700;color:var(--gray-900);margin:0}@media(min-width:768px){.page-header-title{font-size:var(--text-2xl)}}@media(min-width:1024px){.page-header-title{font-size:var(--text-3xl)}}.page-header-actions{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}@media(min-width:640px){.page-header-actions{gap:var(--spacing-3);flex-wrap:nowrap}}.mobile-full-width{width:100%}@media(min-width:640px){.mobile-full-width{width:auto}}@media(min-width:640px){.sm\:hidden{display:none}.sm\:block{display:block}.sm\:flex{display:flex}.sm\:inline{display:inline}.sm\:inline-flex{display:inline-flex}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}.sm\:justify-between{justify-content:space-between}.sm\:gap-4{gap:var(--spacing-4)}.sm\:p-4{padding:var(--spacing-4)}.sm\:w-auto{width:auto}.sm\:text-sm{font-size:var(--text-sm)}.sm\:text-base{font-size:var(--text-base)}}@media(min-width:768px){.md\:hidden{display:none}.md\:block{display:block}.md\:flex{display:flex}.md\:inline-flex{display:inline-flex}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:flex-row{flex-direction:row}.md\:items-center{align-items:center}.md\:justify-between{justify-content:space-between}.md\:gap-4{gap:var(--spacing-4)}.md\:gap-6{gap:var(--spacing-6)}.md\:p-6{padding:var(--spacing-6)}.md\:space-y-0>*+*{margin-top:0}.md\:space-y-6>*+*{margin-top:var(--spacing-6)}.md\:text-base{font-size:var(--text-base)}.md\:text-lg{font-size:var(--text-lg)}.md\:text-xl{font-size:var(--text-xl)}.md\:text-2xl{font-size:var(--text-2xl)}}@media(min-width:1024px){.lg\:hidden{display:none}.lg\:block{display:block}.lg\:flex{display:flex}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:gap-6{gap:var(--spacing-6)}.lg\:gap-8{gap:var(--spacing-8)}.lg\:p-8{padding:var(--spacing-8)}.lg\:text-xl{font-size:var(--text-xl)}.lg\:text-2xl{font-size:var(--text-2xl)}.lg\:text-3xl{font-size:var(--text-3xl)}}@media(min-width:1280px){.xl\:hidden{display:none}.xl\:block{display:block}.xl\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.xl\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.xl\:gap-8{gap:var(--spacing-8)}}@media print{.sidebar,.sidebar-overlay,.header,.mobile-menu-btn,.no-print{display:none!important}.main-content-wrapper{margin-left:0!important}.main-content{padding:0!important}body{background:#fff!important}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-4);font-size:var(--text-sm);font-weight:500;border-radius:var(--radius-lg);border:1px solid transparent;cursor:pointer;transition:all .2s ease;white-space:nowrap;text-decoration:none;font-family:inherit}.btn:focus{outline:2px solid var(--primary-500);outline-offset:2px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:var(--spacing-1) var(--spacing-2);font-size:var(--text-xs)}.btn-md{padding:var(--spacing-2) var(--spacing-4);font-size:var(--text-sm)}.btn-lg{padding:var(--spacing-3) var(--spacing-6);font-size:var(--text-base)}.btn-primary{background-color:var(--primary-600);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--primary-700)}.btn-secondary{background-color:var(--gray-600);color:#fff}.btn-secondary:hover:not(:disabled){background-color:var(--gray-700)}.btn-success{background-color:var(--green-600);color:#fff}.btn-success:hover:not(:disabled){background-color:var(--green-700)}.btn-danger{background-color:var(--red-600);color:#fff}.btn-danger:hover:not(:disabled){background-color:var(--red-700)}.btn-warning{background-color:var(--yellow-500);color:#fff}.btn-warning:hover:not(:disabled){background-color:var(--yellow-600)}.btn-outline{background-color:#fff;border-color:var(--gray-300);color:var(--gray-700)}.btn-outline:hover:not(:disabled){background-color:var(--gray-50);border-color:var(--gray-400)}.btn-ghost{background-color:transparent;color:var(--gray-600)}.btn-ghost:hover:not(:disabled){background-color:var(--gray-100);color:var(--gray-900)}.card{background-color:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow);border:1px solid var(--gray-200);overflow:hidden}.card-header{padding:var(--spacing-4) var(--spacing-6);border-bottom:1px solid var(--gray-200);display:flex;align-items:center;justify-content:space-between}.card-title{font-size:var(--text-lg);font-weight:600;color:var(--gray-900);margin:0}.card-body{padding:var(--spacing-6)}.card-footer{padding:var(--spacing-4) var(--spacing-6);border-top:1px solid var(--gray-200);background-color:var(--gray-50)}.form-group{margin-bottom:var(--spacing-4)}.form-label{display:block;font-size:var(--text-sm);font-weight:500;color:var(--gray-700);margin-bottom:var(--spacing-1)}.form-label-required:after{content:" *";color:var(--red-500)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--spacing-2) var(--spacing-3);font-size:var(--text-sm);border:1px solid var(--gray-300);border-radius:var(--radius-lg);background-color:#fff;color:var(--gray-900);transition:border-color .2s ease,box-shadow .2s ease}@media(min-width:768px){.form-input,.form-select,.form-textarea{padding:var(--spacing-3) var(--spacing-4);font-size:var(--text-base)}}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f61a}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background-color:var(--gray-100);cursor:not-allowed}.form-input:read-only{background-color:var(--gray-50)}.form-input::placeholder{color:var(--gray-400)}.form-input-error{border-color:var(--red-500)}.form-input-error:focus{box-shadow:0 0 0 3px #ef44441a}.form-error{font-size:var(--text-xs);color:var(--red-500);margin-top:var(--spacing-1)}.form-helper{font-size:var(--text-xs);color:var(--gray-500);margin-top:var(--spacing-1)}.form-grid{display:grid;gap:var(--spacing-4)}.form-grid-2{grid-template-columns:1fr}@media(min-width:640px){.form-grid-2{grid-template-columns:repeat(2,1fr)}}.form-grid-3{grid-template-columns:1fr}@media(min-width:768px){.form-grid-3{grid-template-columns:repeat(3,1fr)}}.form-actions{display:flex;flex-direction:column-reverse;gap:var(--spacing-3);margin-top:var(--spacing-6);padding-top:var(--spacing-4);border-top:1px solid var(--gray-200)}@media(min-width:640px){.form-actions{flex-direction:row;justify-content:flex-end}}.input-wrapper{position:relative;width:100%}.input-icon{position:absolute;left:var(--spacing-3);top:50%;transform:translateY(-50%);color:var(--gray-400);pointer-events:none}.input-with-icon{padding-left:2.5rem}.badge{display:inline-flex;align-items:center;padding:var(--spacing-1) var(--spacing-2);font-size:var(--text-xs);font-weight:500;border-radius:var(--radius-full);white-space:nowrap;text-transform:uppercase;letter-spacing:.025em}.badge-sm{padding:.125rem var(--spacing-2);font-size:.625rem}.badge-default{background-color:var(--gray-100);color:var(--gray-700)}.badge-success{background-color:var(--green-100);color:var(--green-700)}.badge-warning{background-color:var(--yellow-100);color:var(--yellow-700)}.badge-danger{background-color:var(--red-100);color:var(--red-700)}.badge-info{background-color:var(--blue-100);color:var(--blue-700)}.alert{display:flex;align-items:flex-start;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-lg);margin-bottom:var(--spacing-4);border:1px solid}.alert-success{background-color:var(--green-50);border-color:var(--green-200);color:var(--green-700)}.alert-error{background-color:var(--red-50);border-color:var(--red-200);color:var(--red-700)}.alert-warning{background-color:var(--yellow-50);border-color:var(--yellow-200);color:var(--yellow-700)}.alert-info{background-color:var(--blue-50);border-color:var(--blue-200);color:var(--blue-700)}.table-container{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-lg);box-shadow:var(--shadow)}.table{width:100%;min-width:600px;border-collapse:collapse;background-color:#fff}.table th,.table td{padding:var(--spacing-3) var(--spacing-4);text-align:left;border-bottom:1px solid var(--gray-200)}.table th{font-size:var(--text-xs);font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;background-color:var(--gray-50)}.table td{font-size:var(--text-sm);color:var(--gray-900)}.table tbody tr:hover{background-color:var(--gray-50)}.table tbody tr:last-child td{border-bottom:none}.modal-overlay{position:fixed;inset:0;background-color:#00000080;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:var(--spacing-4)}.modal{background-color:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:500px;max-height:calc(100vh - 2rem);overflow-y:auto}.modal-lg{max-width:800px}.modal-xl{max-width:1000px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-4) var(--spacing-6);border-bottom:1px solid var(--gray-200)}.modal-title{font-size:var(--text-lg);font-weight:600;color:var(--gray-900);margin:0}.modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:var(--gray-100);border-radius:var(--radius-md);color:var(--gray-500);cursor:pointer;transition:background-color .2s ease}.modal-close:hover{background:var(--gray-200);color:var(--gray-700)}.modal-body{padding:var(--spacing-6)}.modal-footer{display:flex;flex-direction:column-reverse;gap:var(--spacing-3);padding:var(--spacing-4) var(--spacing-6);border-top:1px solid var(--gray-200)}@media(min-width:640px){.modal-footer{flex-direction:row;justify-content:flex-end}}.pagination{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-3);margin-top:var(--spacing-4);padding-top:var(--spacing-4);border-top:1px solid var(--gray-200)}@media(min-width:640px){.pagination{flex-direction:row;justify-content:space-between}}.pagination-info{font-size:var(--text-sm);color:var(--gray-600);text-align:center}.pagination-controls{display:flex;gap:var(--spacing-2)}.loading-spinner{display:inline-flex;align-items:center;justify-content:center}.loading-spinner-sm{width:16px;height:16px}.loading-spinner-md{width:24px;height:24px}.loading-spinner-lg{width:48px;height:48px}.spinner{border:3px solid var(--gray-200);border-top-color:var(--primary-600);border-radius:50%;animation:spin .8s linear infinite}.spinner-sm{width:16px;height:16px;border-width:2px}.spinner-md{width:24px;height:24px}.spinner-lg{width:48px;height:48px;border-width:4px}.tabs{display:flex;flex-wrap:wrap;gap:var(--spacing-2);padding:var(--spacing-2);background:var(--gray-100);border-radius:var(--radius-xl);margin-bottom:var(--spacing-4)}.tabs-list{display:flex;flex-wrap:wrap;gap:var(--spacing-1);border-bottom:1px solid var(--gray-200);margin-bottom:var(--spacing-4)}.tab-btn{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-4);font-size:var(--text-sm);font-weight:500;color:var(--gray-600);background:transparent;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease;white-space:nowrap;position:relative}.tab-btn:hover{color:var(--primary-600);background:#3b82f614}.tab-btn.active{color:var(--primary-700);background:#fff;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.tab-btn svg{width:18px;height:18px;transition:transform .2s ease}.tab-btn:hover svg{transform:scale(1.1)}.tab-btn.active svg{color:var(--primary-600)}.tab-btn .tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;font-size:11px;font-weight:600;color:#fff;background:var(--primary-500);border-radius:9999px;margin-left:var(--spacing-1)}.tab-btn.active .tab-badge{background:var(--primary-600)}.tab-button{padding:var(--spacing-2) var(--spacing-4);font-size:var(--text-sm);font-weight:500;color:var(--gray-600);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all .2s ease;white-space:nowrap}.tab-button:hover{color:var(--primary-600)}.tab-button.active{color:var(--primary-600);border-bottom-color:var(--primary-600)}.tab-panel{display:none}.tab-panel.active{display:block}@media(max-width:640px){.tabs{gap:var(--spacing-1);padding:var(--spacing-1)}.tab-btn{padding:var(--spacing-2) var(--spacing-3);font-size:var(--text-xs)}.tab-btn svg{width:16px;height:16px}}.dropdown{position:relative;display:inline-block}.dropdown-menu{position:absolute;top:100%;right:0;min-width:180px;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);margin-top:var(--spacing-1);padding:var(--spacing-1)}.dropdown-item{display:flex;align-items:center;gap:var(--spacing-2);width:100%;padding:var(--spacing-2) var(--spacing-3);font-size:var(--text-sm);color:var(--gray-700);background:none;border:none;border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:background-color .2s ease}.dropdown-item:hover{background-color:var(--gray-100)}.dropdown-item-danger{color:var(--red-600)}.dropdown-item-danger:hover{background-color:var(--red-50)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-8) var(--spacing-4);text-align:center}.empty-state-icon{width:64px;height:64px;margin-bottom:var(--spacing-4);color:var(--gray-300)}.empty-state-title{font-size:var(--text-lg);font-weight:600;color:var(--gray-900);margin-bottom:var(--spacing-2)}.empty-state-description{font-size:var(--text-sm);color:var(--gray-500);max-width:400px}.tooltip{position:relative;display:inline-block}.tooltip-content{position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:var(--spacing-1) var(--spacing-2);background:var(--gray-900);color:#fff;font-size:var(--text-xs);border-radius:var(--radius-md);white-space:nowrap;z-index:var(--z-tooltip);margin-bottom:var(--spacing-1);opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease}.tooltip:hover .tooltip-content{opacity:1;visibility:visible}.stats-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:var(--spacing-3)}@media(min-width:480px){.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--spacing-4)}}@media(min-width:1024px){.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--spacing-6)}}.avatar{display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);overflow:hidden;background-color:var(--gray-200);color:var(--gray-600);font-weight:500}.avatar-sm{width:32px;height:32px;font-size:var(--text-xs)}.avatar-md{width:40px;height:40px;font-size:var(--text-sm)}.avatar-lg{width:48px;height:48px;font-size:var(--text-base)}.avatar-xl{width:64px;height:64px;font-size:var(--text-lg)}.avatar img{width:100%;height:100%;object-fit:cover}.login-page-split{min-height:100vh;display:flex;flex-direction:column}@media(min-width:1024px){.login-page-split{flex-direction:row}}.login-brand-section{position:relative;display:none;flex:1;background-color:#e8f4fc;background-image:url(/images/login-illustration.jpg);background-size:cover;background-position:center center;background-repeat:no-repeat;min-height:300px}@media(min-width:1024px){.login-brand-section{display:flex;align-items:center;justify-content:flex-end;min-height:100vh;padding-right:var(--spacing-8)}}.login-brand-overlay{display:none}.login-brand-content{position:relative;z-index:10;padding:var(--spacing-8);color:var(--gray-900);max-width:480px;text-align:right}.login-brand-logo{width:72px;height:72px;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-6);margin-left:auto;border:1px solid rgba(255,255,255,.5);box-shadow:0 4px 12px #0000001a;color:var(--primary-600)}.login-brand-title{font-size:var(--text-3xl);font-weight:700;margin:0 0 var(--spacing-3);line-height:1.2}.login-brand-tagline{font-size:var(--text-lg);color:var(--gray-600);margin:0 0 var(--spacing-8);line-height:1.6}.login-brand-features{display:flex;flex-direction:column;gap:var(--spacing-4)}.login-feature-item{display:flex;align-items:flex-start;gap:var(--spacing-3);flex-direction:row-reverse}.login-feature-icon{width:40px;height:40px;background:#ffffffe6;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--primary-600);box-shadow:0 2px 8px #0000001a}.login-feature-text{display:flex;flex-direction:column;gap:2px}.login-feature-title{font-weight:600;font-size:var(--text-base)}.login-feature-desc{font-size:var(--text-sm);color:var(--gray-600)}.login-form-section{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-6);background:linear-gradient(180deg,var(--gray-50) 0%,white 100%);min-height:100vh}@media(min-width:1024px){.login-form-section{max-width:560px;padding:var(--spacing-8)}}.login-form-container{width:100%;max-width:400px}.login-form-header{text-align:center;margin-bottom:var(--spacing-8)}.login-form-logo{width:56px;height:56px;display:flex;align-items:center;justify-content:center;margin:0 auto var(--spacing-4)}.login-form-logo .logo-3d{transition:transform .3s ease,filter .3s ease;filter:drop-shadow(0 4px 12px rgba(59,130,246,.3))}.login-form-logo:hover .logo-3d{transform:scale(1.08) translateY(-2px);filter:drop-shadow(0 8px 20px rgba(59,130,246,.4))}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.login-form-logo .logo-3d{animation:logoFloat 3s ease-in-out infinite}.login-form-logo:hover .logo-3d{animation:none}.login-form-title{font-size:var(--text-2xl);font-weight:700;color:var(--gray-900);margin:0 0 var(--spacing-2)}@media(min-width:640px){.login-form-title{font-size:var(--text-3xl)}}.login-form-subtitle{font-size:var(--text-base);color:var(--gray-500);margin:0}.login-form{display:flex;flex-direction:column;gap:var(--spacing-5)}.login-form-group{width:100%}.login-form-label{display:block;font-size:var(--text-sm);font-weight:500;color:var(--gray-700);margin-bottom:var(--spacing-2)}.login-input-wrapper{position:relative;width:100%}.login-input-icon-left{position:absolute;left:var(--spacing-4);top:50%;transform:translateY(-50%);color:var(--gray-400);pointer-events:none;display:flex;align-items:center;justify-content:center}.login-input{width:100%;padding:var(--spacing-3) var(--spacing-4);padding-left:3rem;font-size:var(--text-base);border:1px solid var(--gray-300);border-radius:var(--radius-lg);background-color:#fff;transition:all .2s ease;color:var(--gray-900)}.login-input-password{padding-right:3rem}.login-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f626}.login-input::placeholder{color:var(--gray-400)}.login-password-toggle{position:absolute;right:var(--spacing-3);top:50%;transform:translateY(-50%);background:none;border:none;color:var(--gray-400);cursor:pointer;padding:var(--spacing-1);display:flex;align-items:center;justify-content:center;transition:color .2s ease;border-radius:var(--radius-md)}.login-password-toggle:hover{color:var(--gray-600);background:var(--gray-100)}.login-form-options{display:flex;justify-content:space-between;align-items:center;font-size:var(--text-sm)}.login-checkbox-label{display:flex;align-items:center;gap:var(--spacing-2);color:var(--gray-600);cursor:pointer;-webkit-user-select:none;user-select:none}.login-checkbox{width:16px;height:16px;accent-color:var(--primary-600);cursor:pointer}.login-forgot-link{background:none;border:none;color:var(--primary-600);font-weight:500;cursor:pointer;transition:color .2s ease;font-size:var(--text-sm)}.login-forgot-link:hover{color:var(--primary-700);text-decoration:underline}.login-submit-button{width:100%;padding:var(--spacing-3) var(--spacing-4);font-size:var(--text-base);font-weight:600;color:#fff;background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-700) 100%);border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease;margin-top:var(--spacing-2);display:flex;align-items:center;justify-content:center;gap:var(--spacing-2);box-shadow:0 2px 4px #2563eb33}.login-submit-button:hover:not(:disabled){background:linear-gradient(135deg,var(--primary-700) 0%,var(--primary-800) 100%);box-shadow:0 4px 12px #2563eb59;transform:translateY(-1px)}.login-submit-button:active:not(:disabled){transform:translateY(0)}.login-submit-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.login-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:login-spin .8s linear infinite}@keyframes login-spin{to{transform:rotate(360deg)}}.login-footer-text{text-align:center;font-size:var(--text-xs);color:var(--gray-400);margin-top:var(--spacing-8)}.login-back-link{display:inline-flex;align-items:center;gap:var(--spacing-2);color:var(--primary-600);font-weight:500;font-size:var(--text-sm);background:none;border:none;cursor:pointer;margin-bottom:var(--spacing-6);transition:color .2s ease}.login-back-link:hover{color:var(--primary-700)}.login-form-logo-success{background:linear-gradient(135deg,#10b981,#059669)}.login-form-logo-error{background:linear-gradient(135deg,#ef4444,#dc2626)}.login-info-box{padding:var(--spacing-4);background-color:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-xl);margin-top:var(--spacing-6)}.login-info-box p{font-size:var(--text-sm);color:var(--gray-600);text-align:center;line-height:1.5;margin:0}.login-info-box-success{background-color:#ecfdf5;border-color:#a7f3d0}.login-info-box-success p{color:#065f46}.login-info-box-info{background-color:#eff6ff;border-color:#bfdbfe}.login-info-box-info p{color:#1e40af}.login-link{background:none;border:none;color:var(--primary-600);font-weight:600;cursor:pointer;transition:color .2s ease}.login-link:hover{color:var(--primary-700);text-decoration:underline}.login-success-content{display:flex;flex-direction:column;gap:var(--spacing-4)}.login-success-content .login-info-box{margin-top:0}.login-success-content .login-submit-button{margin-top:var(--spacing-2)}.login-secondary-button{width:100%;padding:var(--spacing-3) var(--spacing-4);font-size:var(--text-base);font-weight:600;color:var(--primary-600);background:transparent;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease}.login-secondary-button:hover{color:var(--primary-700);background:var(--gray-50)}.login-loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-12) 0;gap:var(--spacing-4)}.login-loading-state p{color:var(--gray-600);font-size:var(--text-base)}.login-password-requirements{padding:var(--spacing-4);background-color:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-xl)}.login-password-requirements-title{font-size:var(--text-xs);font-weight:600;color:var(--gray-700);margin:0 0 var(--spacing-2)}.login-password-requirements-list{display:flex;flex-direction:column;gap:var(--spacing-1)}.login-password-requirement{display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--text-xs);color:var(--gray-500)}.login-password-requirement.valid{color:#059669}.login-password-requirement-dot{width:6px;height:6px;border-radius:50%;background-color:var(--gray-400);flex-shrink:0}.login-password-requirement.valid .login-password-requirement-dot{background-color:#059669}.login-info-box-warning{background-color:#fefce8;border-color:#fde047}.login-info-box-warning p{color:#854d0e}.login-form-email{font-size:var(--text-sm);color:var(--gray-600);margin-top:var(--spacing-2)}.appointment-calendar{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow);overflow:hidden}.calendar-header-controls{display:flex;flex-direction:column;gap:var(--spacing-3);padding:var(--spacing-4);border-bottom:1px solid var(--gray-200)}@media(min-width:768px){.calendar-header-controls{flex-direction:row;justify-content:space-between;align-items:center}}.calendar-week-view{overflow-x:auto;-webkit-overflow-scrolling:touch}.calendar-week-header{display:flex;min-width:700px;background:var(--gray-50);border-bottom:1px solid var(--gray-200)}.calendar-time-column{width:60px;flex-shrink:0;padding:var(--spacing-3);display:flex;align-items:center;justify-content:center}.calendar-day-header{flex:1;min-width:90px;padding:var(--spacing-2);text-align:center;border-left:1px solid var(--gray-200)}.calendar-day-header.is-today{background:var(--primary-50)}.calendar-day-header .day-name{font-size:var(--text-xs);font-weight:500;color:var(--gray-500);text-transform:uppercase}.calendar-day-header .day-number{font-size:var(--text-lg);font-weight:600;color:var(--gray-900)}.calendar-week-body{min-width:700px}.doctor-schedule{display:flex;border-bottom:1px solid var(--gray-200)}.doctor-info{width:60px;flex-shrink:0;padding:var(--spacing-2);background:var(--gray-50);display:flex;flex-direction:column;justify-content:center}.time-slots-grid{display:flex;flex:1}.day-column{flex:1;min-width:90px;border-left:1px solid var(--gray-200)}.time-slot{min-height:40px;padding:var(--spacing-1);border-bottom:1px solid var(--gray-100);cursor:pointer;transition:background-color .2s ease}.time-slot.available-slot:hover{background-color:var(--primary-50)}.time-slot.past-slot{background-color:var(--gray-50);cursor:not-allowed}.time-slot.has-appointment,.time-slot.readonly-has-appointment{cursor:pointer}.time-slot.readonly-empty{cursor:default}.appointment-chip{padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-md);border:1px solid;font-size:var(--text-xs)}.appointment-time{font-weight:600}.appointment-patient{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.available-indicator{font-size:var(--text-xs);color:var(--gray-400);padding:var(--spacing-1)}.calendar-legend-extended{display:flex;flex-wrap:wrap;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-4);border-top:1px solid var(--gray-200);background:var(--gray-50);align-items:center}.legend-title{font-size:var(--text-xs);font-weight:600;color:var(--gray-600);margin-right:var(--spacing-2)}.legend-items{display:flex;flex-wrap:wrap;gap:var(--spacing-3)}.legend-item{display:flex;align-items:center;gap:var(--spacing-1);font-size:var(--text-xs);color:var(--gray-600)}.legend-box{width:12px;height:12px;border-radius:var(--radius-sm)}.available-box{background:var(--primary-100);border:1px solid var(--primary-300)}.scheduled-box{background:var(--gray-100);border:1px solid var(--gray-300)}.confirmed-box{background:var(--blue-100);border:1px solid var(--blue-500)}.in-progress-box{background:var(--orange-100);border:1px solid var(--orange-600)}.completed-box{background:var(--green-100);border:1px solid var(--green-600)}.cancelled-box{background:var(--red-100);border:1px solid var(--red-600)}.dashboard-stats{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:var(--spacing-4);margin-bottom:var(--spacing-6)}@media(min-width:640px){.dashboard-stats{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1024px){.dashboard-stats{grid-template-columns:repeat(4,minmax(0,1fr))}}.stat-card{background:#fff;border-radius:var(--radius-xl);padding:var(--spacing-5);box-shadow:var(--shadow);border:1px solid var(--gray-100);display:flex;align-items:center;gap:var(--spacing-4);transition:box-shadow .2s ease}.stat-card:hover{box-shadow:var(--shadow-md)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-content{flex:1;min-width:0}.stat-label{font-size:var(--text-sm);color:var(--gray-500);margin-bottom:var(--spacing-1)}.stat-value{font-size:var(--text-2xl);font-weight:700;color:var(--gray-900)}.patient-list-filters{display:flex;flex-direction:column;gap:var(--spacing-3);margin-bottom:var(--spacing-4)}@media(min-width:640px){.patient-list-filters{flex-direction:row;align-items:center;justify-content:space-between}}.search-box{position:relative;width:100%;max-width:300px}.search-input{width:100%;padding:var(--spacing-2) var(--spacing-3);padding-left:2.5rem;border:1px solid var(--gray-300);border-radius:var(--radius-lg);font-size:var(--text-sm)}.search-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f61a}.search-icon{position:absolute;left:var(--spacing-3);top:50%;transform:translateY(-50%);color:var(--gray-400)}.form-page{max-width:800px;margin:0 auto}.form-section{margin-bottom:var(--spacing-8)}.form-section-title{font-size:var(--text-lg);font-weight:600;color:var(--gray-900);margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-2);border-bottom:2px solid var(--primary-500)}.detail-page{display:grid;gap:var(--spacing-6)}@media(min-width:1024px){.detail-page{grid-template-columns:1fr 300px}}.detail-main{min-width:0}.detail-sidebar{display:flex;flex-direction:column;gap:var(--spacing-4)}.detail-card{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow);overflow:hidden}.detail-card-header{padding:var(--spacing-4);background:var(--gray-50);border-bottom:1px solid var(--gray-200);font-weight:600;color:var(--gray-900)}.detail-card-body{padding:var(--spacing-4)}.detail-row{display:flex;justify-content:space-between;padding:var(--spacing-2) 0;border-bottom:1px solid var(--gray-100)}.detail-row:last-child{border-bottom:none}.detail-label{color:var(--gray-500);font-size:var(--text-sm)}.detail-value{color:var(--gray-900);font-weight:500;text-align:right}.action-buttons{display:flex;gap:var(--spacing-2);align-items:center}.action-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;background:var(--gray-100);color:var(--gray-600)}.action-btn:hover{background:var(--gray-200);color:var(--gray-900)}.action-btn-primary{background:var(--primary-100);color:var(--primary-600)}.action-btn-primary:hover{background:var(--primary-200);color:var(--primary-700)}.action-btn-success{background:var(--green-100);color:var(--green-600)}.action-btn-success:hover{background:var(--green-200);color:var(--green-700)}.action-btn-danger{background:var(--red-100);color:var(--red-600)}.action-btn-danger:hover{background:var(--red-200);color:var(--red-700)}.not-found-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-4);background:var(--gray-50)}.not-found-content{text-align:center;max-width:400px}.not-found-icon{font-size:6rem;margin-bottom:var(--spacing-4)}.not-found-title{font-size:var(--text-3xl);font-weight:700;color:var(--gray-900);margin-bottom:var(--spacing-2)}.not-found-message{font-size:var(--text-base);color:var(--gray-500);margin-bottom:var(--spacing-6)}#root{min-height:100vh}
