: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{scrollbar-gutter:stable}html,body{scrollbar-gutter:stable;width:100%;min-height:100%;margin:0;padding:20px}*,:before,:after{box-sizing:border-box}.top-header,#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}.config-actions{flex-wrap:wrap;gap:10px;display:flex}.footer-right{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.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.35rem,2vw,1.8rem);line-height:1.3}.top-header-side{min-width:0}.top-header-side-right{justify-content:flex-end;display:flex}.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-shell{background:var(--bg-color);z-index:1000;position:fixed;inset:0}.auth-wrapper{flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:20px;display:flex}.auth-card{background:#fff;border:1px solid #f4f4f5;border-radius:12px;width:100%;max-width:380px;padding:32px 28px;box-shadow:0 8px 30px #0000000a}.auth-grid{flex-direction:column;gap:16px;display:flex}.auth-tabs{border-bottom:1px solid #e4e4e7;gap:0;margin-bottom:24px;display:flex}.auth-tab{color:#a1a1aa;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;border-radius:0;flex:1;margin-bottom:-1px;padding:10px 0;font-size:.95rem;font-weight:600;transition:all .2s}.auth-tab:hover{color:#52525b;background:0 0;border-color:#0000}.auth-tab-active{color:#18181b;background:0 0;border-bottom-color:#18181b}.auth-panel input,.auth-panel select{box-sizing:border-box;color:#18181b;background:#e9edf2;border:1px solid #0000;border-radius:6px;width:100%;padding:12px 14px;font-size:.95rem;transition:all .2s}.auth-panel input:focus,.auth-panel select:focus{background:#fff;border-color:#d4d4d8;outline:none;box-shadow:0 0 0 3px #d4d4d84d}.auth-actions{width:100%;margin-top:24px}.auth-hint{color:#71717a;margin-top:12px;font-size:.85rem;line-height:1.5}.auth-link-button{color:#2563eb;cursor:pointer;background:0 0;border:none;width:100%;margin-top:12px;padding:8px 0;font-size:.9rem;font-weight:600}.auth-link-button:hover{color:#1d4ed8;background:0 0}.auth-sub-actions{gap:12px;display:flex}.auth-sub-actions .auth-link-button{flex:1}.auth-actions .config-btn-primary{color:#fff;background:#16161a;border:none;border-radius:6px;justify-content:center;align-items:center;width:100%;padding:12px;font-size:1rem;font-weight:600;transition:background .2s;display:flex}.config-btn-primary:hover{color:#fff;background:#1a252f}.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-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:112px;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:18px 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:calc(100dvh - 40px);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-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-content{width:min(1100px,100vw - 40px);max-width:none;height:calc(100dvh - 40px);max-height:calc(100dvh - 40px);padding:20px 20px 0}.dir-modal-body{height:100%;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;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;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{flex:1;align-items:center;gap:15px;min-width:0;display:flex}.dir-name{white-space:nowrap;text-overflow:ellipsis;width:75px;font-size:1.1em;overflow:hidden}.dir-gender{color:#666;width:25px}.dir-age{color:#666;width:45px}.dir-meta{flex-shrink:0;align-items:center;gap:15px;display:flex}.dir-date{color:#aaa;font-size:.85em}.dir-badge{box-sizing:border-box;border-radius:12px;justify-content:center;align-items:center;gap:4px;width:85px;padding:3px 8px;font-size:.85em;font-weight:600;display:inline-flex}.badge-zero{color:#aaa;background:#f0f0f0}.badge-active{color:#16a085;background:#e8f6f3}.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){.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%}}.survey-manager-modal{width:min(1400px,100vw - 40px);max-width:none;height:calc(100dvh - 40px);max-height:calc(100dvh - 40px);padding:20px 20px 0}.survey-manager-body{padding-right:0}.survey-manager-head-row,.survey-manager-main{grid-template-columns:72px minmax(220px,1.4fr) minmax(260px,1.5fr) 120px 72px 72px;align-items:start;gap:12px;display:grid}.survey-manager-head-row{color:#909399;border-bottom:1px solid #eee;margin-bottom:10px;padding:0 12px 10px;font-size:.86rem;font-weight:700}.survey-manager-row{background:#fff;border:1px solid #eee;border-radius:10px;margin-bottom:12px;padding:12px}.survey-col{min-width:0}.drag-col{justify-content:center;align-items:center;display:flex}.name-col input,.survey-link-input,.survey-add-panel input,.rule-item select,.rule-item input{width:100%}.summary-col{color:#555;word-break:break-word;font-size:.92rem;line-height:1.45}.link-col,.switch-col,.action-col{justify-content:center;align-items:center;display:flex}.survey-row-expand{border-top:1px dashed #e6e6e6;margin-top:12px;padding-top:12px}.survey-link-edit{margin-bottom:12px}.survey-link-edit label{color:#666;margin-bottom:6px;font-size:.9rem;font-weight:600;display:block}.survey-rule-panel{background:#fafafa;border:1px solid #eee;border-radius:10px;padding:12px}.survey-rule-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;display:flex}.survey-rule-list{flex-direction:column;gap:10px;display:flex}.rule-item{grid-template-columns:120px 1fr auto;align-items:center;gap:10px;display:grid}.rule-value-block{min-width:0}.rule-check-grid{flex-wrap:wrap;gap:10px;display:flex}.rule-check-item{background:#fff;border:1px solid #e5e7eb;border-radius:8px;align-items:center;gap:6px;padding:6px 10px;display:inline-flex}.rule-value-age{grid-template-columns:90px 1fr;gap:10px;display:grid}.survey-add-panel{border-top:1px solid #eee;grid-template-columns:minmax(200px,1fr) minmax(260px,2fr) auto;align-items:center;gap:12px;margin-top:16px;padding:16px 0 0;display:grid}.survey-manager-footer{text-align:right}@media (width<=1100px){.survey-manager-head-row,.survey-manager-main{grid-template-columns:60px minmax(180px,1fr) minmax(180px,1fr) 100px 60px 60px}}@media (width<=900px){html,body{width:100%;margin:0;padding:0;overflow-x:hidden}body{box-sizing:border-box;display:block}body>h2,.auth-shell,.user-bar{width:100%;max-width:none}#appShell{width:100%}.top-header{box-sizing:border-box;grid-template-columns:1fr;gap:10px;width:100%;max-width:none;margin:0 0 12px;padding:14px 10px;display:grid}.top-header-title{text-align:center;color:var(--primary-color);margin:0;font-size:1.25rem;line-height:1.3}.top-header-side{display:none}.top-header-side-right{display:block}.user-bar{width:100%;margin-bottom:10px}.user-menu{justify-content:flex-end;width:100%;display:flex}.user-menu-toggle{width:100%}.user-menu-panel{width:min(320px,100vw - 20px)}#appShell>.patient-card,#appShell>.config-bar,#appShell>.grid-container,#appShell>.footer-controls{display:none!important}.mobile-app-shell{box-sizing:border-box;width:100%;max-width:none;padding:0;display:block!important}.auth-wrapper{box-sizing:border-box;padding:10px}.modal-content{box-sizing:border-box;width:100%;max-width:none}.auth-card,.mobile-card{box-sizing:border-box;background:#fff;border:1px solid #f4f4f5;border-radius:12px;margin:0 10px 16px;padding:20px 16px;box-shadow:0 8px 30px #0000000a}.auth-grid{grid-template-columns:1fr}.auth-actions .config-btn{width:100%}.auth-sub-actions{flex-direction:column;gap:4px}.card-header{flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:14px;display:flex}.mobile-field{flex-direction:column;margin-bottom:10px;display:flex}.mobile-field label{color:#666;margin-bottom:5px;font-size:.9rem;font-weight:600}.mobile-field select,.mobile-field input[type=text],.mobile-field input[type=number]{box-sizing:border-box;background:#fff;border:1px solid #ddd;border-radius:6px;width:100%;padding:11px 10px;font-size:1rem}.mobile-field select:focus,.mobile-field input:focus{border-color:var(--accent-color);outline:none;box-shadow:0 0 0 2px #3498db33}.mobile-gender-group{grid-template-columns:1fr 1fr;gap:10px;display:grid}.mobile-gender-option{cursor:pointer;color:#333;background:#fff;border:1px solid #dcdfe6;border-radius:8px;justify-content:center;align-items:center;min-height:44px;font-weight:600;display:flex}.mobile-gender-option input{margin-right:6px}.mobile-nav-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:4px;display:grid}.mobile-nav-row .btn-field-action{min-width:0;margin-top:0;padding-left:6px;padding-right:6px;font-size:.88rem}.mobile-progress{color:#333;word-break:break-word;margin-bottom:12px;font-size:.95rem}.mobile-actions-stack,.mobile-footer-stack{flex-direction:column;gap:10px;display:flex}.mobile-actions-stack .config-btn,.mobile-footer-stack>button{width:100%}.mobile-grid-container{box-sizing:border-box;grid-template-columns:1fr;gap:10px;width:100vw;margin:0 0 12px calc(50% - 50vw);padding:0 10px;display:grid}.mobile-grid-container .btn{box-sizing:border-box;width:100%;height:72px;min-height:72px}.mobile-app-shell .btn,.mobile-app-shell .btn-field-action,.mobile-app-shell .config-btn,.mobile-app-shell .export-excel-btn,.mobile-app-shell .export-html-btn,.mobile-app-shell .reset-btn{touch-action:manipulation;-webkit-tap-highlight-color:transparent}.btn-field-action,.start-btn,.btn-name-copy,.nav-btn-moved{box-sizing:border-box;width:100%;min-width:0;height:44px;margin-top:10px}.footer-controls,.config-bar,.grid-container{display:none!important}@media (width<=420px){.mobile-nav-row,.mobile-gender-group{grid-template-columns:1fr}.mobile-nav-row .btn-field-action{font-size:.95rem}}.dir-date,.badge-text{display:none!important}.dir-info{gap:8px}.dir-name{width:65px}.dir-badge{border-radius:12px;width:32px;padding:2px 0}.dir-modal-content,.survey-manager-modal{border-radius:12px;width:calc(100vw - 20px);height:calc(100dvh - 20px);max-height:calc(100dvh - 20px);margin:10px;padding:16px 16px 0}.survey-manager-head-row{display:none}.survey-manager-main{grid-template-columns:44px 1fr 44px;gap:10px}.summary-col,.link-col{grid-column:1/-1}.switch-col,.action-col{justify-content:flex-start}.rule-item{grid-template-columns:1fr}.rule-value-age{grid-template-columns:1fr 1fr}.survey-add-panel{grid-template-columns:1fr}}
