.tooth-cell{position:relative;width:56px;height:68px;border:2px solid #93c5fd;border-radius:8px;background:#fff;display:flex;flex-direction:column;overflow:hidden;-webkit-user-select:none;user-select:none;box-shadow:0 1px 3px #0000000f;transition:border-color .15s,box-shadow .15s}.tooth-cell.has-positive{border-color:#f87171;box-shadow:0 2px 6px #ef444433}.tooth-cell.tooth-missing{background:#f1f5f9;border-color:#cbd5e1;opacity:.55;cursor:pointer;align-items:center;justify-content:center;gap:2px;flex-direction:column}.tooth-cell.tooth-missing .tooth-number{color:#94a3b8;font-size:12px;font-weight:700}.missing-mark{font-size:13px;color:#94a3b8;font-weight:700;line-height:1}.tooth-number{font-size:11px;font-weight:800;color:#1e40af;line-height:1;pointer-events:none;white-space:nowrap}.quad-surface{background:#f8fafc;border:none;cursor:pointer;font-size:9px;font-weight:700;color:#94a3b8;display:flex;align-items:center;justify-content:center;padding:0;transition:background .1s,color .1s;line-height:1}.quad-surface:hover{background:#fef2f2;color:#ef4444}.quad-surface.active{background:#ef4444;color:#fff}.quad-surface.active:hover{background:#dc2626}.quad-buccal{width:100%;height:18px;border-bottom:1px solid #e2e8f0;border-radius:0}.quad-buccal.active{border-bottom-color:#b91c1c}.quad-middle{flex:1;display:flex;align-items:center;justify-content:space-between}.quad-mesial{width:16px;height:100%;border-right:1px solid #e2e8f0;flex-shrink:0}.quad-mesial.active{border-right-color:#b91c1c}.quad-distal{width:16px;height:100%;border-left:1px solid #e2e8f0;flex-shrink:0}.quad-distal.active{border-left-color:#b91c1c}.quad-lingual{width:100%;height:18px;border-top:1px solid #e2e8f0;border-radius:0}.quad-lingual.active{border-top-color:#b91c1c}.tooth-status-badge{position:absolute;top:2px;right:2px;font-size:8px;font-weight:800;color:#b45309;background:#fef3c7;border:1px solid #f59e0b;border-radius:3px;padding:0 2px;line-height:1.4;pointer-events:none;z-index:1}.dental-chart-card{background:#fff;border-radius:16px;border:1px solid #bfdbfe;padding:24px;box-shadow:0 2px 12px #2563eb14}.chart-title{font-size:17px;font-weight:700;color:#1e40af;display:flex;align-items:center;gap:8px;margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid #dbeafe}.chart-title-icon{font-size:20px}.chart-side-labels{display:flex;justify-content:space-between;padding:0 8px;margin-bottom:6px}.side-label{font-size:12px;font-weight:600;color:#64748b;letter-spacing:.02em}.jaw-section{margin:4px 0}.jaw-label{font-size:12px;font-weight:600;color:#3b82f6;text-align:center;letter-spacing:.05em}.upper-label{margin-bottom:8px}.lower-label{margin-top:8px}.tooth-row{display:flex;align-items:center;justify-content:center;gap:0}.quadrant{display:flex;gap:4px;padding:0 8px}.center-divider{display:flex;align-items:center;justify-content:center;width:16px;flex-shrink:0}.center-line{width:2px;height:64px;background:linear-gradient(to bottom,#93c5fd,#2563eb,#93c5fd);border-radius:2px}.horizontal-divider{height:2px;background:linear-gradient(to right,transparent,#93c5fd,#2563eb,#93c5fd,transparent);border-radius:2px;margin:12px 8px}.chart-legend{display:flex;gap:24px;justify-content:center;margin-top:20px;padding-top:16px;border-top:1px solid #e2e8f0;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:8px;font-size:13px;color:#475569}.legend-box{width:24px;height:24px;border-radius:6px;border:2px solid;flex-shrink:0}.legend-box.normal{background:#fff;border-color:#93c5fd}.legend-box.pcr-positive{background:#fef2f2;border-color:#ef4444}.legend-box.missing{background:#f1f5f9;border-color:#cbd5e1;opacity:.6}.deciduous-row-label{font-size:11px;font-weight:700;color:#9333ea;text-align:center;margin:4px 0 2px;letter-spacing:.05em}.quadrant-end{justify-content:flex-end}.center-line-short{height:40px}.chart-actions{display:flex;justify-content:center;gap:8px;margin-top:16px}.btn-fill-interdental{padding:8px 20px;background:#eff6ff;color:#1d4ed8;border:1.5px solid #93c5fd;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.btn-fill-interdental:hover{background:#dbeafe;border-color:#3b82f6}.btn-reset-pcr{padding:8px 20px;background:#fff5f5;color:#dc2626;border:1.5px solid #fca5a5;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.btn-reset-pcr:hover{background:#fee2e2;border-color:#ef4444}.chart-tip{text-align:center;font-size:12px;color:#94a3b8;margin-top:12px;padding:8px;background:#f8fafc;border-radius:8px}.patient-info-card{background:#fff;border-radius:16px;border:1px solid #bfdbfe;padding:20px 24px;box-shadow:0 2px 12px #2563eb14}.card-title{font-size:16px;font-weight:700;color:#1e40af;display:flex;align-items:center;gap:8px;margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid #dbeafe}.info-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px 16px}.info-field{display:flex;flex-direction:column;gap:4px}.info-field.full-width{grid-column:1 / -1}.info-field label{font-size:12px;font-weight:600;color:#475569;letter-spacing:.03em}.info-field input,.info-field textarea{border:1.5px solid #bfdbfe;border-radius:8px;padding:8px 12px;font-size:14px;color:#1e293b;background:#f8fafc;outline:none;transition:border-color .15s,box-shadow .15s;resize:vertical}.info-field input:focus,.info-field textarea:focus{border-color:#2563eb;background:#fff;box-shadow:0 0 0 3px #2563eb1a}.info-field input::placeholder,.info-field textarea::placeholder{color:#cbd5e1}.autocomplete-wrap{position:relative}.ac-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1.5px solid #bfdbfe;border-radius:10px;box-shadow:0 8px 24px #2563eb26;z-index:200;overflow:hidden}.ac-item{display:flex;align-items:center;gap:10px;padding:9px 14px;cursor:pointer;transition:background .1s}.ac-item:hover{background:#eff6ff}.ac-item+.ac-item{border-top:1px solid #f1f5f9}.ac-id{font-size:12px;font-family:monospace;font-weight:600;color:#2563eb;background:#eff6ff;padding:2px 7px;border-radius:5px;white-space:nowrap}.ac-name{font-size:14px;font-weight:500;color:#1e293b}.pi-register-bar{display:flex;align-items:center;gap:12px;margin-top:14px;padding:10px 16px;background:#fefce8;border:1.5px solid #fde68a;border-radius:10px}.pi-register-hint{font-size:13px;color:#92400e;flex:1}.pi-btn-register{background:#f59e0b;color:#fff;border:none;padding:7px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}.pi-btn-register:hover{background:#d97706;transform:translateY(-1px)}.patient-manager{display:flex;flex-direction:column;gap:16px}.pm-toolbar{display:flex;gap:12px;align-items:center}.pm-search{flex:1;border:1.5px solid #bfdbfe;border-radius:10px;padding:10px 16px;font-size:14px;color:#1e293b;background:#fff;outline:none;transition:border-color .15s,box-shadow .15s}.pm-search:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.pm-search::placeholder{color:#cbd5e1}.pm-btn-new{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;padding:10px 20px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap;box-shadow:0 2px 8px #2563eb4d}.pm-btn-new:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af);transform:translateY(-1px)}.pm-form{background:#eff6ff;border:1.5px solid #bfdbfe;border-radius:12px;padding:16px 20px}.pm-form-fields{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}.pm-form-field{display:flex;flex-direction:column;gap:4px;flex:1;min-width:160px}.pm-form-field label{font-size:12px;font-weight:600;color:#475569}.pm-form-field input{border:1.5px solid #bfdbfe;border-radius:8px;padding:8px 12px;font-size:14px;color:#1e293b;background:#fff;outline:none;transition:border-color .15s}.pm-form-field input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.pm-btn-add{background:#16a34a;color:#fff;border:none;padding:9px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap;align-self:flex-end}.pm-btn-add:hover:not(:disabled){background:#15803d;transform:translateY(-1px)}.pm-btn-add:disabled{opacity:.5;cursor:not-allowed}.pm-list{background:#fff;border:1px solid #bfdbfe;border-radius:14px;overflow:hidden;box-shadow:0 2px 12px #2563eb0f}.pm-list-header{display:grid;grid-template-columns:120px 1fr 140px 200px;gap:12px;padding:10px 20px;background:#eff6ff;border-bottom:1px solid #bfdbfe;font-size:12px;font-weight:600;color:#475569}.pm-actions-col{text-align:right}.pm-row{display:grid;grid-template-columns:120px 1fr 140px 200px;gap:12px;padding:12px 20px;border-bottom:1px solid #f1f5f9;align-items:center;transition:background .1s}.pm-row:last-of-type{border-bottom:none}.pm-row:hover{background:#f8fafc}.pm-cell{font-size:14px;color:#1e293b}.pm-id{font-family:monospace;font-weight:600;color:#2563eb}.pm-name{font-weight:600}.pm-date{font-size:13px;color:#64748b}.pm-actions{display:flex;gap:8px;justify-content:flex-end}.pm-btn-exam{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;padding:6px 14px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.pm-btn-exam:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af);transform:translateY(-1px)}.pm-btn-delete{background:#fff;color:#94a3b8;border:1.5px solid #e2e8f0;padding:6px 10px;border-radius:8px;font-size:14px;cursor:pointer;transition:all .15s}.pm-btn-delete:hover{background:#fef2f2;border-color:#ef4444;color:#ef4444}.pm-count{padding:8px 20px;font-size:12px;color:#94a3b8;background:#f8fafc;border-top:1px solid #f1f5f9;text-align:right}.pm-empty{text-align:center;padding:60px 24px;color:#94a3b8;background:#fff;border:1px solid #bfdbfe;border-radius:14px}.pm-empty-icon{font-size:56px;margin-bottom:16px}.pm-empty p{font-size:16px;font-weight:500;margin-bottom:6px}.pm-empty-sub{font-size:13px!important;font-weight:400!important;color:#cbd5e1!important}@media (max-width: 700px){.pm-list-header,.pm-row{grid-template-columns:100px 1fr 120px}.pm-list-header .pm-actions-col,.pm-row .pm-actions{grid-column:1 / -1;justify-content:flex-start}}.pcr-summary-card{background:#fff;border-radius:16px;border:1px solid #bfdbfe;padding:20px 24px;box-shadow:0 2px 12px #2563eb14}.pcr-main{display:flex;align-items:flex-start;gap:28px;flex-wrap:wrap}.pcr-circle{width:100px;height:100px;border-radius:50%;border:5px solid;display:flex;align-items:center;justify-content:center;flex-direction:column;flex-shrink:0;transition:border-color .3s;background:#f8fafc}.pcr-percent{font-size:32px;font-weight:800;line-height:1;transition:color .3s}.pcr-unit{font-size:14px;font-weight:600;line-height:1}.pcr-details{display:flex;flex-direction:column;gap:8px;min-width:140px}.pcr-label-badge{color:#fff;font-size:13px;font-weight:700;padding:4px 14px;border-radius:20px;display:inline-block;width:fit-content;transition:background .3s}.pcr-stat{display:flex;align-items:center;gap:8px}.stat-label{font-size:12px;color:#64748b;min-width:70px}.stat-value{font-size:15px;font-weight:700;color:#1e293b}.pcr-bar-section{flex:1;min-width:200px}.pcr-bar-label{font-size:12px;font-weight:600;color:#64748b;margin-bottom:6px}.pcr-bar-track{width:100%;height:20px;background:#f1f5f9;border-radius:10px;overflow:hidden;border:1px solid #e2e8f0}.pcr-bar-fill{height:100%;border-radius:10px;transition:width .4s ease,background .3s;min-width:4px}.pcr-bar-scale{display:flex;justify-content:space-between;font-size:11px;color:#94a3b8;margin-top:4px}.pcr-guide{display:flex;gap:12px;font-size:11px;margin-top:8px;flex-wrap:wrap}.pcr-actions{display:flex;gap:12px;margin-top:20px;padding-top:16px;border-top:1px solid #e2e8f0}.perio-chart-wrapper{background:#fff;border-radius:12px;padding:20px;box-shadow:0 1px 4px #0000000f;border:1px solid #e2e8f0}.perio-chart-scroll{overflow-x:auto;padding-bottom:8px}.perio-chart{min-width:1260px;display:flex;flex-direction:column;gap:0}.perio-jaw-section{display:flex;flex-direction:column;gap:2px}.perio-jaw-label{font-size:11px;font-weight:700;letter-spacing:.08em;padding:2px 0 4px;color:#64748b;text-transform:uppercase}.perio-jaw-label-upper{color:#2563eb}.perio-jaw-label-lower{color:#16a34a}.jaw-divider{height:6px;margin:6px 0;background:linear-gradient(90deg,#bfdbfe,#93c5fd,#bfdbfe);border-radius:3px}.perio-row{display:flex;align-items:center;gap:0;min-height:28px}.row-label{width:64px;min-width:64px;font-size:10px;font-weight:600;color:#64748b;text-align:right;padding-right:8px;white-space:nowrap}.teeth-display{display:flex;align-items:center;gap:3px}.jaw-midline{width:20px;min-width:20px;height:100%;border-left:2px dashed #93c5fd;border-right:2px dashed #93c5fd;margin:0 1px}.perio-cell{width:70px;min-width:70px;display:flex;flex-direction:row;align-items:center;justify-content:center}.perio-triple{gap:2px}.perio-single{justify-content:center}.pd-input{width:22px;height:24px;text-align:center;font-size:11px;font-weight:600;border:1px solid #cbd5e1;border-radius:3px;background:#f1f5f9;color:#475569;padding:0;outline:none;transition:background .1s,border-color .1s;-moz-appearance:textfield}.pd-input::-webkit-inner-spin-button,.pd-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.pd-input::placeholder{color:#cbd5e1;font-size:9px}.pd-input:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.pd-input:disabled{background:#f1f5f9;color:#cbd5e1;border-color:#e2e8f0;cursor:not-allowed}.pd-normal{background:#fff;border-color:#86efac;color:#166534}.pd-warning{background:#fef9c3;border-color:#ca8a04;color:#92400e}.pd-deep{background:#fee2e2;border-color:#f87171;color:#991b1b;font-weight:800}.bop-dot{width:22px;height:22px;border-radius:50%;border:1.5px solid #94a3b8;background:transparent;cursor:pointer;padding:0;transition:background .1s,border-color .1s,transform .1s;flex-shrink:0}.bop-dot:hover:not(:disabled){border-color:#ef4444;transform:scale(1.1)}.bop-dot:disabled{border-color:#e2e8f0;cursor:not-allowed}.bop-dot.bop-s1{background:#ef4444;border-color:#dc2626}.bop-dot.bop-s3{background:#fef08a;border-color:#ca8a04}.bop-dot.bop-s4{background-color:#fef08a;border-color:#dc2626;background-image:repeating-linear-gradient(45deg,rgba(220,38,38,.55) 0px,rgba(220,38,38,.55) 2px,transparent 2px,transparent 6px),repeating-linear-gradient(-45deg,rgba(220,38,38,.55) 0px,rgba(220,38,38,.55) 2px,transparent 2px,transparent 6px)}.single-btn{width:36px;height:24px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;border:1px solid #cbd5e1;border-radius:4px;background:#f8fafc;color:#334155;cursor:pointer;padding:0;transition:background .1s,border-color .1s}.single-btn:hover:not(:disabled){background:#dbeafe;border-color:#93c5fd}.single-btn:disabled,.cell-disabled{background:#f1f5f9;color:#cbd5e1;border-color:#e2e8f0;cursor:not-allowed}.cell-inactive{background:transparent;border-color:transparent;color:#cbd5e1;cursor:default}.furcation-btn.furcation-grade-0{background:#f8fafc;color:#94a3b8}.furcation-btn.furcation-grade-1{background:#fef3c7;border-color:#d97706;color:#92400e}.furcation-btn.furcation-grade-2{background:#fed7aa;border-color:#ea580c;color:#7c2d12}.furcation-btn.furcation-grade-3{background:#fee2e2;border-color:#dc2626;color:#7f1d1d}.perio-num-cell{background:#eff6ff;border-radius:4px;height:28px}.perio-num{font-size:11px;font-weight:700;color:#1e40af;letter-spacing:-.02em}.perio-missing .perio-num{color:#94a3b8;text-decoration:line-through}.perio-missing{background:#f8fafc}.perio-keypad-area{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:14px 20px;display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:8px}.perio-keypad-top{display:flex;align-items:center;justify-content:space-between;width:100%;gap:12px}.perio-keypad-hint{font-size:12px;color:#64748b;flex:1}.perio-dir-btn{font-size:12px;font-weight:600;color:#2563eb;background:#eff6ff;border:1.5px solid #bfdbfe;border-radius:8px;padding:5px 12px;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all .1s}.perio-dir-btn:hover{background:#dbeafe;border-color:#93c5fd}.perio-dir-active{background:#2563eb;color:#fff;border-color:#1d4ed8}.perio-keypad{display:flex;flex-direction:row;flex-wrap:nowrap;align-items:center;gap:5px}.perio-key{height:40px;min-width:36px;padding:0 6px;font-size:15px;font-weight:700;color:#1e293b;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .1s;box-shadow:0 2px 4px #0000000f;display:flex;align-items:center;justify-content:center;flex-shrink:0}.perio-key:hover{background:#eff6ff;border-color:#93c5fd;transform:translateY(-1px);box-shadow:0 4px 8px #2563eb26}.perio-key:active{transform:translateY(0);background:#dbeafe}.perio-key-nav{font-size:14px;color:#2563eb;background:#eff6ff;border-color:#bfdbfe;min-width:40px}.perio-key-clear{font-size:12px;font-weight:700;color:#ef4444;background:#fef2f2;border-color:#fecaca;min-width:44px}.perio-key-fill{font-size:11px;font-weight:700;color:#7c3aed;background:#f5f3ff;border-color:#c4b5fd;min-width:50px}.perio-key-fill:hover{background:#ede9fe;border-color:#a78bfa}.perio-key-fill-active{color:#fff;background:#7c3aed;border-color:#6d28d9}.perio-key-fill-active:hover{background:#6d28d9}.perio-key-reset{font-size:11px;font-weight:700;color:#fff;background:#ef4444;border-color:#dc2626;min-width:54px}.perio-key-reset:hover{background:#dc2626}.perio-key-bop-reset{font-size:11px;font-weight:700;color:#fff;background:#f97316;border-color:#ea580c;min-width:54px}.perio-key-bop-reset:hover{background:#ea580c}.perio-legend{display:flex;align-items:center;gap:24px;margin-top:16px;padding-top:12px;border-top:1px solid #e2e8f0;flex-wrap:wrap}.legend-group{display:flex;align-items:center;gap:8px}.legend-title{font-size:11px;font-weight:700;color:#64748b}.legend-item{font-size:10px;font-weight:600;padding:2px 8px;border-radius:3px;border:1px solid}.pd-normal-sample{background:#fff;border-color:#86efac;color:#166534}.pd-warning-sample{background:#fef9c3;border-color:#ca8a04;color:#92400e}.pd-deep-sample{background:#fee2e2;border-color:#f87171;color:#991b1b}.bop-legend-neg,.bop-legend-pos{width:16px;height:16px;cursor:default;pointer-events:none}.legend-text{font-size:11px;color:#64748b}.perio-bop-actions{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:10px;padding:12px 16px;margin-top:8px}.perio-bop-actions-label{font-size:12px;font-weight:700;color:#15803d;margin-bottom:10px}.perio-bop-actions-grid{display:grid;grid-template-columns:max-content repeat(3,auto);gap:6px 8px;align-items:center}.perio-bop-group-label{font-size:12px;font-weight:600;color:#374151;padding-right:8px;white-space:nowrap}.perio-bop-btn{padding:5px 12px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;border:1.5px solid;transition:background .15s,border-color .15s;white-space:nowrap}.perio-bop-btn-all{background:#fff;color:#15803d;border-color:#86efac}.perio-bop-btn-all:hover{background:#dcfce7;border-color:#22c55e}.perio-bop-btn-buccal{background:#eff6ff;color:#1d4ed8;border-color:#93c5fd}.perio-bop-btn-buccal:hover{background:#dbeafe;border-color:#3b82f6}.perio-bop-btn-lingual{background:#faf5ff;color:#7e22ce;border-color:#d8b4fe}.perio-bop-btn-lingual:hover{background:#f3e8ff;border-color:#a855f7}.perio-stats{background:#fff;border-radius:12px;padding:20px 24px;box-shadow:0 1px 4px #0000000f;border:1px solid #e2e8f0}.perio-stats-title{font-size:15px;font-weight:700;color:#1e40af;margin:0 0 16px}.perio-stats-grid{display:flex;gap:12px;flex-wrap:wrap}.stat-card{flex:1;min-width:110px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:12px 16px;text-align:center}.stat-label{font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.stat-value{font-size:28px;font-weight:800;color:#1e293b;line-height:1;margin-bottom:4px}.stat-detail{font-size:11px;color:#94a3b8}.saved-records-empty{text-align:center;padding:60px 24px;color:#94a3b8}.empty-icon{font-size:56px;margin-bottom:16px}.saved-records-empty p{font-size:16px;font-weight:500;margin-bottom:6px}.empty-sub{font-size:13px!important;font-weight:400!important;color:#cbd5e1!important}.saved-records{display:flex;flex-direction:column;gap:16px}.records-header{display:flex;align-items:center;gap:12px}.records-search{flex:1;border:1.5px solid #bfdbfe;border-radius:10px;padding:9px 16px;font-size:14px;color:#1e293b;background:#fff;outline:none;transition:border-color .15s,box-shadow .15s}.records-search:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.records-search::placeholder{color:#cbd5e1}.records-count{font-size:13px;color:#64748b;background:#f1f5f9;padding:4px 12px;border-radius:20px;white-space:nowrap}.records-list{display:flex;flex-direction:column;gap:12px}.record-card{background:#fff;border-radius:14px;border:1px solid #bfdbfe;padding:16px 20px;box-shadow:0 1px 6px #2563eb0f;transition:box-shadow .15s}.record-card:hover{box-shadow:0 4px 16px #2563eb1f}.record-main{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:14px}.record-info{flex:1;display:flex;flex-direction:column;gap:6px}.record-patient{display:flex;align-items:center;gap:10px}.record-name{font-size:16px;font-weight:700;color:#1e293b}.record-id{font-size:12px;color:#64748b;background:#f1f5f9;padding:2px 8px;border-radius:6px}.record-date{font-size:13px;color:#64748b}.record-notes{font-size:12px;color:#94a3b8;white-space:pre-wrap;max-width:400px}.record-pcr{text-align:right;flex-shrink:0}.record-pcr-value{font-size:28px;font-weight:800;line-height:1}.record-pcr-badge{color:#fff;font-size:11px;font-weight:700;padding:2px 10px;border-radius:20px;display:inline-block;margin:4px 0}.record-pcr-detail{font-size:12px;color:#94a3b8}.record-actions{display:flex;gap:10px;border-top:1px solid #e2e8f0;padding-top:12px}.btn-load{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;padding:7px 18px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.btn-load:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af);transform:translateY(-1px)}.btn-delete{background:#fff;color:#94a3b8;border:1.5px solid #e2e8f0;padding:7px 18px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.btn-delete:hover{background:#fef2f2;border-color:#ef4444;color:#ef4444}.patient-group{border-radius:14px;border:1px solid #bfdbfe;overflow:hidden;box-shadow:0 1px 6px #2563eb0f}.patient-group-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:#eff6ff;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s;gap:12px}.patient-group-header:hover{background:#dbeafe}.patient-group-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.patient-group-toggle{font-size:14px;color:#2563eb;width:16px;flex-shrink:0}.patient-group-identity{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.patient-group-name{font-size:15px;font-weight:700;color:#1e293b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.patient-group-id{font-size:12px;color:#64748b;background:#e2e8f0;padding:2px 8px;border-radius:6px;flex-shrink:0}.patient-group-count{font-size:12px;color:#2563eb;background:#bfdbfe;padding:2px 8px;border-radius:20px;flex-shrink:0;font-weight:600}.patient-group-right{display:flex;align-items:center;gap:12px;flex-shrink:0}.patient-group-latest{font-size:12px;color:#64748b}.patient-group-pcr{font-size:14px;font-weight:700}.patient-group-records{display:flex;flex-direction:column;gap:0;background:#fff}.patient-group-records .record-card{border-radius:0;border:none;border-top:1px solid #e2e8f0;box-shadow:none;padding:12px 20px}.patient-group-records .record-card:hover{background:#f8fafc;box-shadow:none}.sperio-wrapper{background:#fff;border-radius:16px;border:1px solid #bfdbfe;padding:20px 24px;box-shadow:0 2px 12px #2563eb14;display:flex;flex-direction:column;gap:16px;max-width:960px;margin:0 auto;width:100%}.sperio-stats-bar{display:flex;gap:12px;flex-wrap:wrap}.sperio-stat{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:10px 16px;display:flex;flex-direction:column;align-items:center;min-width:80px;flex:1}.sperio-stat-label{font-size:11px;font-weight:600;color:#64748b;margin-bottom:2px}.sperio-stat-value{font-size:22px;font-weight:800;color:#1e293b;line-height:1.1}.sperio-stat-sub{font-size:11px;color:#94a3b8;margin-top:2px}.sperio-chart-scroll{overflow-x:auto;padding-bottom:4px}.sperio-chart{min-width:820px;display:flex;flex-direction:column;gap:0}.sperio-jaw{display:flex;flex-direction:column;gap:2px}.sperio-jaw-label{font-size:11px;font-weight:700;letter-spacing:.08em;padding:2px 0 4px;text-transform:uppercase}.sperio-jaw-upper{color:#2563eb}.sperio-jaw-lower{color:#16a34a}.sperio-jaw-divider{height:5px;margin:6px 0;background:linear-gradient(90deg,#bfdbfe,#93c5fd,#bfdbfe);border-radius:3px}.sperio-row{display:flex;align-items:center;min-height:28px}.sperio-row-label{width:56px;min-width:56px;font-size:10px;font-weight:600;color:#64748b;text-align:right;padding-right:8px;white-space:nowrap}.sperio-teeth{display:flex;align-items:center;gap:3px}.sperio-midline{width:18px;min-width:18px;border-left:2px dashed #93c5fd;border-right:2px dashed #93c5fd;align-self:stretch;margin:0 1px}.sperio-cell{width:44px;min-width:44px;display:flex;align-items:center;justify-content:center}.sperio-pd-input{width:38px;height:26px;text-align:center;font-size:13px;font-weight:700;border:1.5px solid #cbd5e1;border-radius:5px;background:#f8fafc;color:#475569;padding:0;outline:none;transition:border-color .1s,background .1s,box-shadow .1s;cursor:text}.sperio-pd-input:focus{border-color:#3b82f6;background:#eff6ff;box-shadow:0 0 0 3px #3b82f633}.sperio-pd-input::placeholder{color:#cbd5e1;font-size:10px}.spd-normal{background:#f0fdf4;border-color:#86efac;color:#166534}.spd-warning{background:#fefce8;border-color:#fde047;color:#92400e}.spd-deep{background:#fef2f2;border-color:#f87171;color:#991b1b;font-weight:800}.spd-normal:focus{border-color:#22c55e}.spd-warning:focus{border-color:#eab308}.spd-deep:focus{border-color:#ef4444}.sperio-bop{width:24px;height:24px;border-radius:50%;border:1.5px solid #94a3b8;background:transparent;cursor:pointer;padding:0;transition:background .1s,border-color .1s,transform .1s;flex-shrink:0;display:block}.sperio-bop:hover:not(:disabled){border-color:#ef4444;transform:scale(1.15)}.sperio-bop:disabled{border-color:#e2e8f0;cursor:not-allowed}.sperio-bop.sperio-bop-s1{background:#ef4444;border-color:#dc2626}.sperio-bop.sperio-bop-s3{background:#fef08a;border-color:#ca8a04}.sperio-bop.sperio-bop-s4{background-color:#fef08a;border-color:#dc2626;background-image:repeating-linear-gradient(45deg,rgba(220,38,38,.55) 0px,rgba(220,38,38,.55) 2px,transparent 2px,transparent 6px),repeating-linear-gradient(-45deg,rgba(220,38,38,.55) 0px,rgba(220,38,38,.55) 2px,transparent 2px,transparent 6px)}.sperio-single-btn{width:34px;height:24px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;border:1px solid #cbd5e1;border-radius:5px;background:#f8fafc;color:#334155;cursor:pointer;padding:0;transition:background .1s}.sperio-single-btn:hover:not(:disabled):not(.sperio-inactive){background:#dbeafe;border-color:#93c5fd}.sperio-btn-disabled{background:#f1f5f9;color:#cbd5e1;border-color:#e2e8f0;cursor:not-allowed}.sperio-inactive{background:transparent;border-color:transparent;color:#cbd5e1;cursor:default}.sperio-fur-0{background:#f8fafc;color:#94a3b8}.sperio-fur-1{background:#fef3c7;border-color:#d97706;color:#92400e}.sperio-fur-2{background:#fed7aa;border-color:#ea580c;color:#7c2d12}.sperio-fur-3{background:#fee2e2;border-color:#dc2626;color:#7f1d1d}.sperio-num-cell{background:#eff6ff;border-radius:4px;height:26px}.sperio-num{font-size:11px;font-weight:700;color:#1e40af;letter-spacing:-.02em}.sperio-num-missing .sperio-num{color:#94a3b8;text-decoration:line-through}.sperio-num-missing{background:#f8fafc}.sperio-cell-na{font-size:11px;color:#cbd5e1}.sperio-keypad-area{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:14px 20px;display:flex;flex-direction:column;align-items:center;gap:12px}.sperio-keypad-top{display:flex;align-items:center;justify-content:space-between;width:100%;gap:12px}.sperio-keypad-hint{font-size:12px;color:#64748b;flex:1}.sperio-dir-btn{font-size:12px;font-weight:600;color:#2563eb;background:#eff6ff;border:1.5px solid #bfdbfe;border-radius:8px;padding:5px 12px;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all .1s}.sperio-dir-btn:hover{background:#dbeafe;border-color:#93c5fd}.sperio-dir-active{background:#2563eb;color:#fff;border-color:#1d4ed8}.sperio-keypad{display:flex;flex-direction:row;flex-wrap:nowrap;align-items:center;gap:5px}.sperio-key{height:40px;min-width:36px;padding:0 6px;font-size:15px;font-weight:700;color:#1e293b;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .1s;box-shadow:0 2px 4px #0000000f;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sperio-key:hover{background:#eff6ff;border-color:#93c5fd;transform:translateY(-1px);box-shadow:0 4px 8px #2563eb26}.sperio-key:active{transform:translateY(0);background:#dbeafe}.sperio-key-nav{font-size:14px;color:#2563eb;background:#eff6ff;border-color:#bfdbfe;min-width:40px}.sperio-key-clear{font-size:12px;font-weight:700;color:#ef4444;background:#fef2f2;border-color:#fecaca;min-width:44px}.sperio-key-fill{font-size:11px;font-weight:700;color:#7c3aed;background:#f5f3ff;border-color:#c4b5fd;min-width:50px}.sperio-key-fill:hover{background:#ede9fe;border-color:#a78bfa}.sperio-key-fill-active{color:#fff;background:#7c3aed;border-color:#6d28d9}.sperio-key-fill-active:hover{background:#6d28d9}.sperio-key-reset{font-size:11px;font-weight:700;color:#fff;background:#ef4444;border-color:#dc2626;min-width:54px}.sperio-key-reset:hover{background:#dc2626}.sperio-key-bop-reset{font-size:11px;font-weight:700;color:#fff;background:#f97316;border-color:#ea580c;min-width:54px}.sperio-key-bop-reset:hover{background:#ea580c}.sperio-legend{display:flex;gap:20px;align-items:center;flex-wrap:wrap;justify-content:center}.sperio-legend-group{display:flex;align-items:center;gap:6px}.sperio-legend-label{font-size:11px;font-weight:700;color:#64748b}.sperio-legend-item{font-size:10px;font-weight:600;padding:2px 8px;border-radius:4px;border:1px solid}.sperio-legend-text{font-size:11px;color:#64748b}.sperio-bop-legend{width:16px;height:16px;cursor:default;pointer-events:none}.sperio-bop-actions{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:10px;padding:12px 16px}.sperio-bop-actions-label{font-size:12px;font-weight:700;color:#15803d;margin-bottom:8px}.sperio-bop-actions-row{display:flex;gap:8px;flex-wrap:wrap}.sperio-bop-btn{padding:6px 14px;background:#fff;color:#15803d;border:1.5px solid #86efac;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.sperio-bop-btn:hover{background:#dcfce7;border-color:#22c55e}.st-card{background:#fff;border-radius:16px;border:1px solid #bfdbfe;padding:24px;box-shadow:0 2px 12px #2563eb14;position:relative}.st-title{font-size:17px;font-weight:700;color:#1e40af;display:flex;align-items:center;gap:8px;margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid #dbeafe}.st-deciduous-label{font-size:11px;font-weight:700;color:#9333ea;text-align:center;margin:2px 0;letter-spacing:.05em}.st-side-labels{display:flex;justify-content:space-between;font-size:12px;color:#64748b;font-weight:600;padding:0 8px;margin-bottom:4px}.st-jaw-label{font-size:12px;font-weight:600;color:#3b82f6;text-align:center;margin:4px 0;letter-spacing:.05em}.st-row{display:flex;align-items:center;justify-content:center;gap:4px;padding:4px 0}.st-midline{width:2px;height:56px;background:linear-gradient(to bottom,#93c5fd,#2563eb,#93c5fd);border-radius:2px;flex-shrink:0}.st-jaw-divider{height:2px;background:linear-gradient(to right,transparent,#93c5fd,#2563eb,#93c5fd,transparent);border-radius:2px;margin:10px 8px}.st-wrapper{position:relative;display:flex;flex-direction:column;align-items:center}.st-wrapper.has-bridge:before{content:"";position:absolute;top:0;left:6px;right:6px;height:5px;background:#f59e0b;border-radius:3px;z-index:2}.st-wrapper.has-bridge.bridge-left:before{left:-4px;border-top-left-radius:0;border-bottom-left-radius:0}.st-wrapper.has-bridge.bridge-right:before{right:-4px;border-top-right-radius:0;border-bottom-right-radius:0}.st-cell{width:42px;height:50px;border-radius:8px;border:2px solid;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:transform .12s,box-shadow .12s;position:relative;-webkit-user-select:none;user-select:none;gap:3px}.st-cell:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026;z-index:10}.st-cell-selected{box-shadow:0 0 0 3px #2563eb73!important;z-index:20;transform:translateY(-2px)}.st-symbol{font-size:13px;font-weight:800;line-height:1;min-height:14px}.st-num{font-size:12px;font-weight:700;line-height:1}.st-picker{position:absolute;top:calc(100% + 6px);left:50%;transform:translate(-50%);z-index:200;background:#fff;border:1.5px solid #bfdbfe;border-radius:12px;padding:10px 12px;box-shadow:0 8px 28px #0000002e;width:280px;min-width:280px}.st-picker-title{font-size:12px;font-weight:700;color:#1e40af;text-align:center;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid #e2e8f0}.st-picker-group{margin-bottom:6px}.st-picker-group-label{font-size:10px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}.st-picker-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.st-picker-btn{padding:5px 4px;border-radius:6px;border:1.5px solid;font-size:11px;font-weight:700;cursor:pointer;text-align:center;display:flex;align-items:center;justify-content:center;gap:3px;transition:opacity .12s,transform .1s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.st-picker-btn:hover{opacity:.8;transform:scale(1.04)}.st-picker-active{outline:2.5px solid #2563eb;outline-offset:1px}.st-picker-symbol{font-size:10px;font-weight:800;flex-shrink:0}.st-legend-section{display:flex;flex-direction:column;gap:10px;margin-top:20px;padding-top:14px;border-top:1px solid #e2e8f0}.st-legend-group{display:flex;align-items:flex-start;gap:8px}.st-legend-group-label{font-size:11px;font-weight:700;color:#94a3b8;white-space:nowrap;min-width:72px;padding-top:2px}.st-legend-items{display:flex;flex-wrap:wrap;gap:6px 14px}.st-legend-item{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:600}.st-legend-box{width:20px;height:20px;border-radius:4px;border:2px solid;flex-shrink:0;display:flex;align-items:center;justify-content:center}.st-batch-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:14px}.st-batch-btn{padding:6px 14px;border-radius:8px;border:1.5px solid;font-size:12px;font-weight:700;cursor:pointer;transition:opacity .15s}.st-batch-btn:hover{opacity:.75}.st-batch-deciduous{background:#f3e8ff;border-color:#a855f7;color:#7e22ce}.st-batch-permanent{background:#f3f4f6;border-color:#9ca3af;color:#374151}.st-tip{text-align:center;font-size:12px;color:#94a3b8;margin-top:10px;padding:7px;background:#f8fafc;border-radius:8px}.app{min-height:100vh;display:flex;flex-direction:column;background:#eff6ff}.app-header{background:linear-gradient(135deg,#1e40af,#2563eb 60%,#3b82f6);box-shadow:0 2px 16px #1e40af4d}.header-inner{max-width:1400px;margin:0 auto;padding:14px 24px;display:flex;justify-content:space-between;align-items:center}.header-brand{display:flex;align-items:center;gap:14px}.header-logo{font-size:36px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.header-title{font-size:22px;font-weight:800;color:#fff;letter-spacing:.02em;line-height:1.2}.header-sub{font-size:12px;color:#bfdbfe;letter-spacing:.08em}.header-date{font-size:13px;color:#bfdbfe;background:#ffffff1a;padding:6px 14px;border-radius:20px;border:1px solid rgba(255,255,255,.2)}.app-nav{background:#fff;border-bottom:2px solid #dbeafe;box-shadow:0 2px 8px #2563eb0f;position:sticky;top:0;z-index:100}.nav-inner{max-width:1400px;margin:0 auto;padding:0 24px;display:flex;gap:4px}.nav-tab{position:relative;padding:14px 24px;font-size:14px;font-weight:600;color:#64748b;background:transparent;border:none;border-bottom:3px solid transparent;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:6px;margin-bottom:-2px}.nav-tab:hover{color:#2563eb;background:#eff6ff}.nav-tab.active{color:#2563eb;border-bottom-color:#2563eb;background:#eff6ff}.nav-badge{background:#2563eb;color:#fff;font-size:11px;font-weight:700;padding:2px 7px;border-radius:20px;min-width:20px;text-align:center}.app-main{flex:1;padding:24px}.main-inner{max-width:1400px;margin:0 auto}.exam-layout{display:flex;flex-direction:column;gap:20px}.exam-actions{display:flex;gap:12px;padding:16px 20px;background:#fff;border:1px solid #bfdbfe;border-radius:14px;box-shadow:0 2px 8px #2563eb0f}.btn-save{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;padding:10px 24px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;box-shadow:0 2px 8px #2563eb4d}.btn-save:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb66}.btn-save:active{transform:translateY(0)}.btn-clear{background:#fff;color:#64748b;border:1.5px solid #cbd5e1;padding:10px 24px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}.btn-clear:hover{background:#fef2f2;border-color:#ef4444;color:#ef4444}.exam-mode-bar{display:flex;gap:8px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:12px;padding:6px}.exam-mode-btn{flex:1;padding:10px 16px;border:none;border-radius:8px;font-size:14px;font-weight:600;color:#64748b;background:transparent;cursor:pointer;transition:all .15s}.exam-mode-btn:hover{background:#fff;color:#2563eb}.exam-mode-btn.active{background:#fff;color:#2563eb;box-shadow:0 2px 8px #2563eb1f}.exam-section-label{display:flex;align-items:center;gap:10px;font-size:15px;font-weight:700;color:#1e40af;padding:10px 0 4px;border-bottom:2px solid #dbeafe}.exam-section-icon{font-size:18px}.app-footer{background:#1e40af;padding:12px 24px;text-align:center}.app-footer p{color:#bfdbfe;font-size:12px}.toast{position:fixed;bottom:32px;left:50%;transform:translate(-50%);background:#1e293b;color:#fff;padding:12px 28px;border-radius:12px;font-size:14px;font-weight:600;box-shadow:0 8px 24px #0003;z-index:1000;animation:toastIn .25s ease}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media (max-width: 900px){.app-main{padding:16px}.header-inner{padding:12px 16px}.header-title{font-size:18px}.header-date{display:none}}.prev-record-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 18px;background:#fffbeb;border:1.5px solid #fcd34d;border-radius:12px;flex-wrap:wrap}.prev-record-info{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.prev-record-label{font-size:13px;font-weight:700;color:#92400e}.prev-record-date{font-size:13px;color:#78350f}.prev-record-pcr{font-size:13px;font-weight:600;color:#b45309;background:#fef3c7;padding:2px 10px;border-radius:20px}.btn-load-prev{padding:7px 16px;background:#f59e0b;color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s;white-space:nowrap}.btn-load-prev:hover{background:#d97706}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:Segoe UI,Yu Gothic UI,Meiryo UI,Hiragino Sans,Noto Sans JP,sans-serif;background-color:#eff6ff;color:#1e293b;min-height:100vh;-webkit-font-smoothing:antialiased}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit}
