:root{--green: #0B8441;--green-dark: #076E35;--green-light: #E8F5EE;--green-mid: #C3E6D3;--orange: #DD842F;--orange-dark: #B86A1F;--orange-light: #FDF0E6;--orange-mid: #F5C89A;--white: #FFFFFF;--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;--text: #1A1A2E;--success: #10B981;--danger: #EF4444;--warning: #F59E0B;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 12px rgba(0,0,0,.1), 0 2px 4px rgba(0,0,0,.06);--shadow-lg: 0 10px 24px rgba(0,0,0,.12), 0 4px 8px rgba(0,0,0,.06);--nav-height: 68px;--top-bar-height: 60px;--font: "Inter", system-ui, -apple-system, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:var(--font);background:var(--gray-50);color:var(--text);line-height:1.5;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}#root{min-height:100vh;display:flex;flex-direction:column}h1{font-size:1.75rem;font-weight:700;line-height:1.2}h2{font-size:1.375rem;font-weight:700;line-height:1.3}h3{font-size:1.125rem;font-weight:600;line-height:1.4}h4{font-size:1rem;font-weight:600}p{font-size:.9375rem;color:var(--gray-600)}.page-wrapper{display:flex;flex-direction:column;min-height:100vh}.page-content{flex:1;padding-bottom:var(--nav-height);overflow-y:auto}.page-content.no-nav{padding-bottom:0}.container{max-width:480px;margin:0 auto;padding:0 16px}.section{padding:20px 0}.card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.card-body{padding:16px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font);font-size:.9375rem;font-weight:600;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all .18s ease;min-height:52px;padding:0 24px;text-decoration:none;white-space:nowrap;-webkit-appearance:none}.btn:active{transform:scale(.97)}.btn-primary{background:var(--green);color:var(--white)}.btn-primary:hover{background:var(--green-dark)}.btn-secondary{background:var(--white);color:var(--green);border:2px solid var(--green)}.btn-secondary:hover{background:var(--green-light)}.btn-accent{background:var(--orange);color:var(--white)}.btn-accent:hover{background:var(--orange-dark)}.btn-ghost{background:transparent;color:var(--gray-600)}.btn-ghost:hover{background:var(--gray-100)}.btn-sm{min-height:38px;font-size:.875rem;padding:0 16px}.btn-lg{min-height:56px;font-size:1rem;padding:0 32px}.btn-full{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-label{font-size:.875rem;font-weight:600;color:var(--gray-700)}.form-input{font-family:var(--font);font-size:1rem;padding:14px 16px;border:1.5px solid var(--gray-200);border-radius:var(--radius-md);background:var(--white);color:var(--text);transition:border-color .15s;outline:none;width:100%}.form-input:focus{border-color:var(--green)}.form-input::placeholder{color:var(--gray-400)}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%236B7280' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px}.tag{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;font-weight:600;padding:4px 10px;border-radius:var(--radius-full)}.tag-green{background:var(--green-light);color:var(--green)}.tag-orange{background:var(--orange-light);color:var(--orange-dark)}.tag-gray{background:var(--gray-100);color:var(--gray-600)}.tag-success{background:#d1fae5;color:#065f46}.tag-danger{background:#fee2e2;color:#991b1b}.progress-bar-wrap{background:var(--gray-200);border-radius:var(--radius-full);overflow:hidden;height:8px}.progress-bar-fill{height:100%;border-radius:var(--radius-full);background:var(--green);transition:width .5s ease}.progress-bar-fill.orange{background:var(--orange)}.progress-bar-fill.striped{background:repeating-linear-gradient(45deg,var(--green),var(--green) 10px,var(--green-dark) 10px,var(--green-dark) 20px)}.avatar{display:flex;align-items:center;justify-content:center;border-radius:50%;font-weight:700;color:var(--white);background:var(--green);flex-shrink:0}.avatar-sm{width:36px;height:36px;font-size:.875rem}.avatar-md{width:48px;height:48px;font-size:1.1rem}.avatar-lg{width:64px;height:64px;font-size:1.4rem}.avatar-xl{width:80px;height:80px;font-size:1.75rem}.divider{height:1px;background:var(--gray-200);margin:12px 0}.chips-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}.chips-row::-webkit-scrollbar{display:none}.chip{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius-full);font-size:.8125rem;font-weight:600;border:1.5px solid var(--gray-200);background:var(--white);color:var(--gray-600);cursor:pointer;white-space:nowrap;transition:all .15s;flex-shrink:0}.chip.active{background:var(--green);border-color:var(--green);color:var(--white)}.chip:active{transform:scale(.97)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px 24px;text-align:center;color:var(--gray-500)}.empty-state svg{opacity:.4}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.fade-in{animation:fadeIn .3s ease forwards}.spin{animation:spin 1s linear infinite}.skeleton{background:linear-gradient(90deg,var(--gray-200) 25%,var(--gray-100) 50%,var(--gray-200) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:var(--radius-sm)}.text-green{color:var(--green)}.text-orange{color:var(--orange)}.text-muted{color:var(--gray-500)}.text-bold{font-weight:700}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.375rem}.gap-4{gap:4px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.flex{display:flex}.flex-col{flex-direction:column}.flex-center{align-items:center;justify-content:center}.items-center{align-items:center}.justify-between{justify-content:space-between}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.w-full{width:100%}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.p-16{padding:16px}.p-20{padding:20px}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scroll-x{overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}.scroll-x::-webkit-scrollbar{display:none}.toast-container{position:fixed;bottom:calc(var(--nav-height) + 12px);left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;width:calc(100% - 32px);max-width:420px}.toast{background:var(--gray-900);color:var(--white);padding:12px 16px;border-radius:var(--radius-lg);font-size:.875rem;font-weight:500;box-shadow:var(--shadow-lg);animation:fadeIn .25s ease;pointer-events:auto;display:flex;align-items:center;gap:10px}.toast.success{background:var(--green)}.toast.error{background:var(--danger)}.toast.warning{background:var(--orange)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000;display:flex;align-items:flex-end;justify-content:center;padding:0;animation:fadeIn .2s ease}.modal-sheet{background:var(--white);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;padding:20px;padding-bottom:calc(20px + env(safe-area-inset-bottom))}.modal-handle{width:40px;height:4px;background:var(--gray-300);border-radius:var(--radius-full);margin:0 auto 16px}@supports (padding-bottom: env(safe-area-inset-bottom)){.page-content{padding-bottom:calc(var(--nav-height) + env(safe-area-inset-bottom))}}@media (min-width: 600px){.container{padding:0 24px}h1{font-size:2rem}}
