:root{--primary-color:#2c3e50;--accent-color:#3498db;--accent-hover:#2980b9;--success-color:#27ae60;--danger-color:#e74c3c;--bg-color:#f4f6f9;--card-bg:#fff;--border-color:#dcdfe6;--text-color:#333;--muted-color:#666;--completed-color:#95a5a6;--shadow-sm:0 2px 8px #0000000d;--shadow-md:0 4px 15px #0000000f;--shadow-lg:0 10px 25px #00000029;--radius-sm:6px;--radius-md:10px;--radius-lg:12px}body{background:var(--bg-color);color:var(--text-color);flex-direction:column;align-items:center;padding:20px;font-family:Segoe UI,Microsoft YaHei,sans-serif;display:flex}html,body{width:100%;min-height:100%;margin:0}*,:before,:after{box-sizing:border-box}body{padding:20px}.top-header,.auth-shell{width:100%;max-width:1000px}#appShell{flex-direction:column;align-items:center;width:100%;display:flex}#appShell>.patient-card,#appShell>.config-bar,#appShell>.grid-container,#appShell>.footer-controls{width:100%;max-width:1000px;margin-left:auto;margin-right:auto}.mobile-app-shell{display:none!important}.footer-right{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}body>h2,.top-header{border-radius:var(--radius-lg);width:100%;max-width:1000px;box-shadow:var(--shadow-md);background:#fff;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;margin:0 0 16px;padding:16px 18px;display:grid}.top-header-title{color:var(--primary-color);text-align:center;margin:0;font-size:clamp(1.8rem,2.6vw,2.4rem);line-height:1.3}.top-header-side{min-width:0}.top-header-side-right{justify-content:flex-end;display:flex}#appShell{width:100%}.auth-shell,.patient-card,.config-bar,.grid-container,.footer-controls{width:100%;max-width:1000px}@media (orientation:landscape){.mobile-app-shell{display:none!important}}select,input[type=text],input[type=number],input[type=password]{border-radius:var(--radius-sm);width:100%;color:var(--text-color);background:#fff;border:1px solid #ddd;padding:10px 12px;font-size:1rem;transition:border-color .2s,box-shadow .2s,background-color .2s}select:focus,input:focus{border-color:var(--accent-color);outline:none;box-shadow:0 0 0 2px #3498db33}.auth-card{background:var(--card-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border-left:5px solid var(--accent-color);padding:25px}.auth-tabs{gap:10px;margin-bottom:18px;display:flex}.auth-tab{border:1px solid var(--border-color);color:#606266;cursor:pointer;background:#fff;border-radius:8px;padding:10px 18px;font-weight:600;transition:all .2s}.auth-tab:hover{color:var(--accent-color);background:#ecf5ff;border-color:#c6e2ff}.auth-tab-active{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.auth-panel{width:100%}.auth-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:15px;display:grid}.auth-actions{justify-content:flex-end;margin-top:18px;display:flex}.auth-hint{color:var(--muted-color);background:#f8fafc;border:1px solid #e5e9f2;border-radius:8px;margin-top:14px;padding:12px 14px;font-size:.92rem;line-height:1.7}.user-bar{box-shadow:none;background:0 0;border-radius:0;width:auto;max-width:none;margin:0;padding:0;display:block}.user-menu{justify-content:flex-end;width:auto;display:flex;position:relative}.user-menu-toggle{min-width:120px}.user-menu-panel{width:320px;max-width:min(320px,100vw - 40px);box-shadow:var(--shadow-lg);z-index:1200;background:#fff;border:1px solid #e7ebf0;border-radius:12px;padding:14px;position:absolute;top:calc(100% + 10px);right:0}.user-menu-title{color:var(--primary-color);margin-bottom:12px;font-size:.95rem;font-weight:700}#userBarText{color:var(--text-color);word-break:break-all;font-size:.95rem}.user-meta-item{border-bottom:1px solid #f0f2f5;justify-content:space-between;align-items:flex-start;gap:12px;padding:8px 0;display:flex}.user-meta-item:last-child{border-bottom:none}.user-meta-label{color:#909399;flex:none;font-size:.88rem}.user-meta-value{text-align:right;color:var(--text-color);font-weight:600}.user-meta-empty{color:#909399}.user-logout-btn{width:100%;margin-top:12px}.patient-card{background:var(--card-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border-left:5px solid var(--accent-color);margin-bottom:20px;padding:25px}.card-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.card-title{color:var(--primary-color);margin:0;font-size:1.2rem;font-weight:700}.form-grid{grid-template-columns:repeat(4,minmax(0,1fr));align-items:start;gap:15px;display:grid}.form-group{flex-direction:column;min-width:0;display:flex}.form-group label{color:var(--muted-color);margin-bottom:5px;font-size:.9rem;font-weight:600}.radio-group{align-items:center;gap:16px;min-height:42px;padding:0 2px;display:flex}.radio-group label{cursor:pointer;color:var(--text-color);align-items:center;margin:0;font-weight:400;display:flex}.radio-group input{margin-right:5px}.config-bar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:15px;display:flex}.config-actions{flex-wrap:wrap;gap:10px;display:flex}.config-btn,.export-excel-btn,.export-html-btn,.reset-btn{border-radius:var(--radius-sm);cursor:pointer;min-height:40px;padding:8px 15px;font-size:.9rem;font-weight:600;transition:all .2s}.config-btn{color:#555;background:0 0;border:1px solid #ccc}.config-btn:hover{color:#333;background:#e9ecef}.config-btn-primary{background:var(--primary-color);color:#fff;border:none}.config-btn-primary:hover{background:#1a252f}.btn-field-action{border-radius:var(--radius-sm);cursor:pointer;box-sizing:border-box;white-space:nowrap;justify-content:center;align-items:center;gap:6px;width:100%;height:42px;margin-top:8px;font-size:.95rem;font-weight:600;transition:all .2s;display:flex}.start-btn,.btn-id-action{background:var(--accent-color);color:#fff;border:none}.start-btn:hover,.btn-id-action:hover{background:var(--accent-hover)}.btn-id-action.disabled,.start-btn.disabled{opacity:.95;pointer-events:auto!important;cursor:copy!important;background:#95a5a6!important}.start-btn.disabled:active{transform:scale(.98)}.btn-name-copy{color:#555;border:1px solid var(--border-color);background:#f0f2f5}.btn-name-copy:hover{color:#333;background:#e6e8eb;border-color:#c0c4cc}.btn-name-copy:active{transform:scale(.98)}.nav-btn-moved{border:1px solid var(--border-color);color:#606266;background:#fff}.nav-btn-moved:hover{color:var(--accent-color);background:#ecf5ff;border-color:#c6e2ff}.nav-btn-moved:disabled{color:#c0c4cc;cursor:not-allowed;background:#f5f7fa;border-color:#e4e7ed}.spacer-btn{visibility:hidden;width:100%;height:42px;margin-top:8px}.grid-container{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:15px;min-height:200px;margin-bottom:30px;display:grid}.btn{min-height:80px;color:var(--primary-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);text-align:center;cursor:pointer;background:#fff;border:2px solid #0000;justify-content:center;align-items:center;padding:15px 12px;font-weight:600;text-decoration:none;transition:all .2s;display:flex;position:relative;overflow:hidden}.btn span{line-clamp:2;-webkit-line-clamp:2;word-break:break-word;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.btn:hover{box-shadow:var(--shadow-md);border-color:var(--accent-color);color:var(--accent-color);transform:translateY(-2px)}.btn.completed{color:var(--completed-color);box-shadow:none;background:#e9ecef;border-color:#e9ecef}.btn.completed:hover{color:var(--completed-color);transform:none}.btn.completed:after{content:"✓";color:var(--completed-color);opacity:.6;font-size:18px;position:absolute;top:5px;right:8px}.footer-controls{border-top:2px solid #e0e0e0;flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;padding-top:20px;display:flex}.footer-right{flex-wrap:wrap;gap:10px;display:flex}.export-excel-btn{background:var(--success-color);color:#fff;border:none}.export-excel-btn:hover{filter:brightness(.95)}.export-html-btn{color:#fff;background:#8e44ad;border:none}.export-html-btn:hover{filter:brightness(.95)}.reset-btn{background:var(--danger-color);color:#fff;border:none}.reset-btn:hover{filter:brightness(.95)}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:20px;display:none;position:fixed;inset:0}.modal-content{border-radius:var(--radius-lg);width:90%;max-width:500px;max-height:85vh;box-shadow:var(--shadow-lg);background:#fff;flex-direction:column;padding:25px;display:flex}.modal-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:15px;display:flex}.modal-body{flex-grow:1;padding-right:5px;overflow-y:auto}.modal-footer{text-align:right;border-top:1px solid #eee;margin-top:20px;padding-top:15px}.sortable-list{margin:0;padding:0;list-style:none}.sortable-item{-webkit-user-select:none;user-select:none;background:#fff;border:1px solid #eee;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;padding:12px;transition:background .2s;display:flex}.sortable-item.dragging{opacity:.5;background:#f0f0f0;border:2px dashed #ccc}.drag-handle{cursor:grab;color:#aaa;margin-right:6px;padding:0 4px;font-size:20px}.item-name{color:#333;text-align:left;flex:1;min-width:0;font-weight:500}.switch{flex-shrink:0;width:40px;height:24px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.slider{cursor:pointer;background:#ccc;border-radius:24px;transition:all .4s;position:absolute;inset:0}.slider:before{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:all .4s;position:absolute;bottom:3px;left:3px}input:checked+.slider{background:var(--accent-color)}input:checked+.slider:before{transform:translate(16px)}.sortable-ghost{opacity:.4;background:#e0e0e0;border-radius:10px}.sortable-drag{cursor:grabbing}.sortable-chosen{background:#fff}.sortable-fallback{opacity:.9;cursor:grabbing;pointer-events:none;background:#fff;transform:scale(1.02);box-shadow:0 10px 20px #0003;z-index:9999!important}.admin-list{max-height:400px;margin:0;padding:0;list-style:none;overflow-y:auto}.admin-row{background:#fff;border-bottom:1px solid #eee;align-items:center;gap:10px;padding:10px;display:flex}.admin-row:last-child{border-bottom:none}.admin-input-sm{flex:1}.admin-input-lg{flex:3}.icon-btn{cursor:pointer;background:0 0;border:1px solid #0000;border-radius:4px;padding:6px 8px;font-size:1.1rem}.icon-btn:hover{background:#f0f0f0;border-color:#ccc}.btn-save{color:#27ae60}.btn-del{color:#e74c3c}.btn-add{background:var(--accent-color);color:#fff;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:none;padding:8px 20px;font-weight:600}.btn-add:hover{background:var(--accent-hover)}.add-row{background:#f9f9f9;border-top:2px solid #eee;align-items:center;gap:10px;padding:15px;display:flex}.dir-modal-body{max-height:60vh;padding:0;overflow-y:auto}.dir-search-box{z-index:10;background:#fff;border-bottom:1px solid #eee;padding:15px;position:sticky;top:0}.dir-search-input{border:2px solid var(--accent-color);border-radius:var(--radius-sm);width:100%;padding:10px 12px;font-size:1rem}.dir-list{margin:0;padding:0;list-style:none}.dir-item{cursor:pointer;border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;gap:12px;padding:12px 15px;transition:background .1s;display:flex}.dir-item:hover{background:#f0f8ff}.dir-item.active{background:#e8f6f3;border-left:4px solid #16a085}.dir-info{align-items:center;gap:10px;min-width:0;display:flex}.dir-tag{color:#666;white-space:nowrap;background:#eee;border-radius:4px;padding:2px 6px;font-size:.8em}.dir-tag.id{color:#2980b9;background:#e8f4f8;font-weight:700}.toast{color:#fff;opacity:0;pointer-events:none;z-index:9999;text-align:center;background:#000000d1;border-radius:20px;max-width:min(90vw,420px);padding:10px 20px;font-size:.9rem;transition:opacity .3s;position:fixed;top:20px;left:50%;transform:translate(-50%)}@media (width<=900px){.form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.config-bar{flex-direction:column;align-items:stretch}.config-actions{justify-content:flex-start}}@media (width<=680px){.auth-tabs,.footer-right{flex-direction:column;align-items:stretch}.auth-actions{justify-content:stretch}.auth-actions .config-btn,.config-actions .config-btn,.footer-right>button{width:100%}.card-header{flex-direction:column;align-items:flex-start}.form-grid{grid-template-columns:1fr}.admin-row,.add-row{flex-wrap:wrap}.admin-input-sm,.admin-input-lg,.btn-add{flex:none;width:100%}}
