:root{--primary:#2563eb;--primary-light:#3b82f6;--primary-dark:#1d4ed8;--success:#16a34a;--warning:#d97706;--danger:#dc2626;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--radius:12px;--radius-sm:8px;--shadow:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-md:0 4px 6px #00000012, 0 2px 4px #0000000f;--shadow-lg:0 10px 15px #0000001a, 0 4px 6px #0000000d;--safe-bottom:env(safe-area-inset-bottom,0px)}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px}body{background:var(--gray-50);color:var(--gray-800);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans SC,sans-serif;line-height:1.6}.app-shell{flex-direction:column;min-height:100dvh;display:flex}.app-header{z-index:100;background:var(--primary);color:#fff;align-items:center;gap:12px;min-height:48px;padding:12px 16px;display:flex;position:sticky;top:0}.app-header h1{flex:1;font-size:18px;font-weight:600}.app-content{padding:12px 16px;padding-bottom:calc(72px + var(--safe-bottom));flex:1;overflow-y:auto}.app-bottom-nav{z-index:100;border-top:1px solid var(--gray-200);padding-bottom:var(--safe-bottom);background:#fff;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item{color:var(--gray-400);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;padding:6px 0;font-size:10px;text-decoration:none;transition:color .15s;display:flex}.nav-item svg{width:22px;height:22px}.nav-item.active{color:var(--primary);font-weight:600}.nav-item:active{opacity:.7}.card{border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;margin-bottom:12px;padding:16px}.card-title{color:var(--gray-800);margin-bottom:12px;font-size:16px;font-weight:600}.btn{border-radius:var(--radius-sm);cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;justify-content:center;align-items:center;gap:6px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .15s;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-outline{border:1px solid var(--gray-300);color:var(--gray-600);background:0 0}.btn-sm{padding:6px 12px;font-size:12px}.btn-block{width:100%}.form-group{margin-bottom:12px}.form-label{color:var(--gray-600);margin-bottom:4px;font-size:13px;font-weight:500;display:block}.form-input,.form-select,.form-textarea{border:1px solid var(--gray-300);border-radius:var(--radius-sm);width:100%;color:var(--gray-800);background:#fff;padding:10px 12px;font-family:inherit;font-size:15px;transition:border-color .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2563eb1a}.form-textarea{resize:vertical;min-height:80px}.form-row{grid-template-columns:1fr 1fr;gap:8px;display:grid}.form-row-3{grid-template-columns:1fr 1fr 1fr;gap:8px;display:grid}.stats-grid{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px;display:grid}.stat-card{border-radius:var(--radius);box-shadow:var(--shadow);text-align:center;background:#fff;padding:14px}.stat-value{color:var(--gray-900);font-size:22px;font-weight:700}.stat-label{color:var(--gray-500);margin-top:2px;font-size:12px}.phase-list{list-style:none}.phase-item{border-bottom:1px solid var(--gray-100);align-items:flex-start;gap:12px;padding:12px 0;display:flex;position:relative}.phase-item:last-child{border-bottom:none}.phase-dot{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;margin-top:2px;font-size:12px;display:flex}.phase-dot.done{background:var(--success)}.phase-dot.active{background:var(--primary);box-shadow:0 0 0 4px #2563eb33}.phase-dot.pending{background:var(--gray-300)}.phase-info{flex:1}.phase-name{font-size:15px;font-weight:600}.phase-meta{color:var(--gray-500);margin-top:2px;font-size:12px}.progress-bar{background:var(--gray-200);border-radius:4px;height:8px;margin-top:6px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--primary), var(--primary-light));border-radius:4px;height:100%;transition:width .3s}.list-item{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;gap:8px;padding:12px 0;display:flex}.list-item:last-child{border-bottom:none}.list-item-main{flex:1;min-width:0}.list-item-title{font-size:15px;font-weight:500}.list-item-sub{color:var(--gray-500);font-size:12px}.list-item-right{text-align:right;flex-shrink:0}.tag{border-radius:4px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.tag-blue{color:#1d4ed8;background:#dbeafe}.tag-green{color:#15803d;background:#dcfce7}.tag-yellow{color:#b45309;background:#fef3c7}.tag-red{color:#b91c1c;background:#fee2e2}.tag-gray{background:var(--gray-100);color:var(--gray-600)}.modal-overlay{z-index:200;background:#0006;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.modal-sheet{border-radius:var(--radius) var(--radius) 0 0;background:#fff;width:100%;max-width:500px;max-height:85vh;padding:20px;animation:.25s slideUp;overflow-y:auto}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.modal-title{font-size:18px;font-weight:600}.modal-close{color:var(--gray-400);cursor:pointer;background:0 0;border:none;padding:4px;font-size:24px}.empty-state{text-align:center;color:var(--gray-400);padding:40px 20px}.empty-state svg{opacity:.5;width:64px;height:64px;margin-bottom:12px}.empty-state p{font-size:14px}.text-right{text-align:right}.text-center{text-align:center}.text-sm{font-size:13px}.text-xs{font-size:12px}.text-muted{color:var(--gray-500)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.font-bold{font-weight:600}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.flex-between{justify-content:space-between;align-items:center;display:flex}.gap-2{gap:8px}.flex{align-items:center;display:flex}.flex-wrap{flex-wrap:wrap}
