@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--primary-50:#f0fdf4;--primary-100:#dcfce7;--primary-200:#bbf7d0;--primary-300:#86efac;--primary-400:#4ade80;--primary-500:#22c55e;--primary-600:#16a34a;--primary-700:#15803d;--primary-800:#166534;--primary-900:#14532d;--primary-950:#052e16;--secondary-50:#eff6ff;--secondary-100:#dbeafe;--secondary-200:#bfdbfe;--secondary-300:#93c5fd;--secondary-400:#60a5fa;--secondary-500:#3b82f6;--secondary-600:#2563eb;--secondary-700:#1d4ed8;--secondary-800:#1e40af;--secondary-900:#1e3a8a;--gray-25:#fcfcfd;--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;--gray-950:#030712;--success-50:#f0fdf4;--success-100:#dcfce7;--success-500:#22c55e;--success-600:#16a34a;--success-700:#15803d;--warning-50:#fffbeb;--warning-100:#fef3c7;--warning-500:#f59e0b;--warning-600:#d97706;--warning-700:#b45309;--error-50:#fef2f2;--error-100:#fee2e2;--error-500:#ef4444;--error-600:#dc2626;--error-700:#b91c1c;--info-50:#eff6ff;--info-100:#dbeafe;--info-500:#3b82f6;--info-600:#2563eb;--info-700:#1d4ed8;--shadow-xs:0 1px 2px 0 #0000000d;--shadow-sm:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--shadow-2xl:0 25px 50px -12px #00000040;--shadow-card:0 1px 3px 0 #0000000f,0 1px 2px 0 #0000000a;--shadow-card-hover:0 4px 12px 0 #00000014,0 2px 4px 0 #0000000a;--radius-sm:6px;--radius-md:8px;--radius-lg:10px;--radius-xl:12px;--radius-2xl:16px;--radius-3xl:24px;--radius-full:9999px;--border-primary:var(--gray-200);--border-secondary:var(--gray-100);--font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;--text-xs:.75rem;--text-sm:.8125rem;--text-base:.875rem;--text-md:.9375rem;--text-lg:1rem;--text-xl:1.125rem;--text-2xl:1.25rem;--text-3xl:1.5rem;--text-4xl:1.75rem;--text-5xl:2.25rem;--text-6xl:2.625rem;--leading-tight:1.25;--leading-snug:1.375;--leading-normal:1.5;--leading-relaxed:1.625;--leading-loose:2;--space-0:0;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--transition-fast:.15s ease;--transition-normal:.2s ease;--transition-slow:.3s ease;--transition-smooth:.2s cubic-bezier(.4,0,.2,1);--max-width-content:1200px;--max-width-form:680px;--sidebar-width:260px;--header-height:64px;--button-height:44px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-size:16px}body{font-family:var(--font-family);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--gray-900);background:var(--gray-50);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.container{width:100%;max-width:var(--max-width-content);padding:0 var(--space-6);margin:0 auto}.container-narrow{width:100%;max-width:var(--max-width-form);padding:0 var(--space-6);margin:0 auto}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:var(--leading-tight);color:var(--gray-900)}h1{font-size:var(--text-5xl)}h2{font-size:var(--text-4xl)}h3{font-size:var(--text-3xl)}h4{font-size:var(--text-2xl)}h5{font-size:var(--text-xl)}h6{font-size:var(--text-lg)}p{color:var(--gray-600);line-height:var(--leading-relaxed)}a{color:inherit;text-decoration:none}.btn{justify-content:center;align-items:center;gap:var(--space-2);height:var(--button-height);padding:0 var(--space-5);font-family:var(--font-family);font-size:var(--text-base);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-smooth);white-space:nowrap;border:1px solid #0000;font-weight:500;line-height:1;text-decoration:none;display:inline-flex}.btn:focus-visible{outline:2px solid var(--primary-500);outline-offset:2px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary-600);color:#fff;border-color:var(--primary-600)}.btn-primary:hover:not(:disabled){background:var(--primary-700);border-color:var(--primary-700)}.btn-primary:active:not(:disabled){background:var(--primary-800)}.btn-secondary{color:var(--gray-700);border-color:var(--gray-300);background:#fff}.btn-secondary:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-400);color:var(--gray-900)}.btn-outline{color:var(--primary-600);border-color:var(--primary-600);background:0 0}.btn-outline:hover:not(:disabled){background:var(--primary-50)}.btn-ghost{color:var(--gray-600);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){background:var(--gray-100);color:var(--gray-900)}.btn-sm{height:36px;padding:0 var(--space-4);font-size:var(--text-sm)}.btn-lg{height:52px;padding:0 var(--space-8);font-size:var(--text-lg)}.btn-icon{width:var(--button-height);padding:0}.btn-icon.btn-sm{width:36px}.card{border:1px solid var(--border-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);transition:box-shadow var(--transition-smooth);background:#fff}.card-hover:hover{box-shadow:var(--shadow-card-hover)}.card-header{padding:var(--space-5)var(--space-6);border-bottom:1px solid var(--border-secondary)}.card-body{padding:var(--space-6)}.card-footer{padding:var(--space-5)var(--space-6);border-top:1px solid var(--border-secondary);background:var(--gray-50);border-radius:0 0 var(--radius-xl)var(--radius-xl)}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-label{font-size:var(--text-sm);color:var(--gray-700);font-weight:500}.form-label-required:after{content:" *";color:var(--error-500)}.form-input,.form-select,.form-textarea{width:100%;height:var(--button-height);padding:0 var(--space-4);font-family:var(--font-family);font-size:var(--text-base);color:var(--gray-900);border:1px solid var(--gray-300);border-radius:var(--radius-lg);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);background:#fff}.form-input::placeholder,.form-textarea::placeholder{color:var(--gray-400)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100);outline:none}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background:var(--gray-100);cursor:not-allowed}.form-textarea{height:auto;min-height:120px;padding:var(--space-3)var(--space-4);resize:vertical}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3)center;padding-right:var(--space-10);cursor:pointer;background-size:18px}.form-helper{font-size:var(--text-sm);color:var(--gray-500)}.form-error{font-size:var(--text-sm);color:var(--error-600)}.badge{align-items:center;gap:var(--space-1);padding:var(--space-1)var(--space-3);font-size:var(--text-xs);border-radius:var(--radius-full);font-weight:500;line-height:1.5;display:inline-flex}.badge-success{background:var(--success-100);color:var(--success-700)}.badge-warning{background:var(--warning-100);color:var(--warning-700)}.badge-error{background:var(--error-100);color:var(--error-700)}.badge-info{background:var(--info-100);color:var(--info-700)}.badge-neutral{background:var(--gray-100);color:var(--gray-700)}.section{padding:var(--space-20)0}.section-sm{padding:var(--space-12)0}.section-header{text-align:center;max-width:640px;margin:0 auto var(--space-12)}.section-title{font-size:var(--text-4xl);color:var(--gray-900);margin-bottom:var(--space-4);font-weight:700}.section-subtitle{font-size:var(--text-lg);color:var(--gray-500);line-height:var(--leading-relaxed)}.table-container{border:1px solid var(--border-primary);border-radius:var(--radius-xl);overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:var(--text-base)}.table th,.table td{padding:var(--space-4)var(--space-5);text-align:left;border-bottom:1px solid var(--border-secondary)}.table th{color:var(--gray-600);background:var(--gray-50);font-weight:500;font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.05em}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover{background:var(--gray-50)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-fadeIn{animation:.4s ease-out forwards fadeIn}.animate-slideInUp{animation:.5s ease-out forwards slideInUp}.animate-slideInRight{animation:.5s ease-out forwards slideInRight}.animate-pulse{animation:2s ease-in-out infinite pulse}.animate-spin{animation:1s linear infinite spin}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-primary{color:var(--primary-600)}.text-secondary{color:var(--secondary-600)}.text-success{color:var(--success-600)}.text-warning{color:var(--warning-600)}.text-error{color:var(--error-600)}.text-muted{color:var(--gray-500)}.text-dark{color:var(--gray-900)}.flex{display:flex}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.w-full{width:100%}.h-full{height:100%}.min-h-screen{min-height:100vh}.bg-white{background:#fff}.bg-gray-50{background:var(--gray-50)}.bg-gray-100{background:var(--gray-100)}.bg-primary{background:var(--primary-600)}.rounded{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-full{border-radius:var(--radius-full)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}@media (max-width:1280px){:root{--sidebar-width:240px}}@media (max-width:1024px){.grid-cols-4,.grid-cols-3{grid-template-columns:repeat(2,1fr)}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}.section{padding:var(--space-16)0}.section-title{font-size:var(--text-3xl)}}@media (max-width:768px){.container{padding:0 var(--space-4)}.grid-cols-4,.grid-cols-3,.grid-cols-2{grid-template-columns:1fr}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}.section{padding:var(--space-12)0}.section-title{font-size:var(--text-2xl)}.btn,.form-input,.form-select,.form-textarea{min-height:48px}.form-input,.form-select,.form-textarea{font-size:16px}}@media (max-width:480px){.container{padding:0 var(--space-3)}h1{font-size:var(--text-2xl)}h2{font-size:var(--text-xl)}.section{padding:var(--space-10)0}.section-title{font-size:var(--text-xl)}}.hide-mobile{display:block}.show-mobile{display:none}@media (max-width:768px){.hide-mobile{display:none!important}.show-mobile{display:block!important}}@supports (padding-bottom:env(safe-area-inset-bottom)){.safe-bottom{padding-bottom:env(safe-area-inset-bottom)}}
