*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #F5F5F7;--surface: #FFFFFF;--fg: #1D1D1F;--muted: #6E6E73;--border: #D2D2D7;--accent: #629FCA;--accent-light: rgba(98,159,202,.12);--accent-hover: #4E8BB6;--sidebar-bg: #1C1C1E;--sidebar-text: rgba(255,255,255,.85);--sidebar-muted: rgba(255,255,255,.4);--success: #34C759;--warning: #FF9500;--danger: #FF3B30;--font: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", "Helvetica Neue", Arial, sans-serif;--radius-sm: 8px;--radius: 12px;--radius-lg: 16px;--shadow: 0 1px 6px rgba(0,0,0,.06);--shadow-modal: 0 24px 64px rgba(0,0,0,.18);--sidebar-w: 240px;--header-h: 56px}body{font-family:var(--font);background:var(--bg);color:var(--fg);min-height:100vh;display:flex}#root{display:flex;width:100%}.sidebar{width:var(--sidebar-w);min-height:100vh;background:var(--sidebar-bg);display:flex;flex-direction:column;position:fixed;top:0;left:0;z-index:100}.sidebar-logo{padding:22px 18px 18px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(255,255,255,.06)}.logo-mark{width:30px;height:30px;background:var(--accent);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:15px;font-weight:700;flex-shrink:0}.logo-text{color:#fff;font-size:15px;font-weight:600;letter-spacing:-.01em}.logo-sub{color:var(--sidebar-muted);font-size:10px;margin-top:1px}.sidebar-nav{flex:1;padding:14px 10px}.nav-label{color:var(--sidebar-muted);font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:0 8px;margin:12px 0 4px}.nav-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:var(--radius-sm);color:var(--sidebar-text);cursor:pointer;font-size:13px;font-weight:400;transition:background .12s,color .12s;margin-bottom:2px;-webkit-user-select:none;user-select:none;text-decoration:none}.nav-item:hover{background:#ffffff12;color:#fff}.nav-item.active{background:#629fca38;color:var(--accent)}.nav-item.active .nav-icon svg{stroke:var(--accent)}.nav-icon{opacity:.6;flex-shrink:0;display:flex;align-items:center;transition:opacity .12s}.nav-item.active .nav-icon{opacity:1}.nav-item:hover .nav-icon{opacity:.85}.nav-badge{margin-left:auto;background:var(--danger);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px;min-width:16px;text-align:center}.sidebar-footer{padding:14px;border-top:1px solid rgba(255,255,255,.06)}.doctor-card{display:flex;align-items:center;gap:10px;padding:7px 8px;border-radius:var(--radius-sm)}.doctor-avatar{width:30px;height:30px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:700;flex-shrink:0}.doctor-name{color:#fff;font-size:12.5px;font-weight:500}.doctor-role{color:var(--sidebar-muted);font-size:10.5px}.main-content{margin-left:var(--sidebar-w);flex:1;min-height:100vh;display:flex;flex-direction:column}.top-header{min-height:var(--header-h);background:#ffffffe0;backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--border);display:flex;align-items:center;flex-wrap:wrap;padding:10px 24px;gap:10px;position:sticky;top:0;z-index:50}.header-left-group{display:flex;align-items:center;gap:10px;flex:1;min-width:240px}.header-left-group .header-title{flex:0 0 auto}.header-title{font-size:16px;font-weight:600;letter-spacing:-.01em;flex:1;min-width:80px;white-space:nowrap}.header-search{display:flex;align-items:center;gap:7px;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:6px 11px;flex:1 1 300px;max-width:360px;min-width:120px}.header-search input{border:none;background:transparent;font-family:var(--font);font-size:13px;color:var(--fg);outline:none;width:100%;min-width:0}.header-search input::placeholder{color:var(--muted)}.icon-btn{width:34px;height:34px;border-radius:8px;border:1px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--fg);transition:background .12s;position:relative;flex-shrink:0}.icon-btn:hover{background:var(--bg)}.page-body{flex:1;padding:24px;overflow-y:auto}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;transition:box-shadow .15s,border-color .15s}.stat-card:hover{box-shadow:0 4px 16px #00000012}.stat-label{font-size:10.5px;color:var(--muted);font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-bottom:8px}.stat-value{font-size:28px;font-weight:700;letter-spacing:-.03em;line-height:1.1}.stat-sub{font-size:11.5px;color:var(--muted);margin-top:5px;line-height:1.4}.c-accent{color:var(--accent)}.c-warn{color:var(--warning)}.c-success{color:var(--success)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.card-header{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;border-bottom:1px solid var(--border)}.card-title{font-size:14px;font-weight:600;letter-spacing:-.01em}.table-toolbar{display:flex;align-items:center;justify-content:space-between;padding:14px 20px}.date-range-filters{display:flex;align-items:center;gap:8px}.mobile-date-filter,.mobile-card-list{display:none}.mobile-search{display:none;align-items:center;gap:7px;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:7px 12px;margin-bottom:12px}.mobile-search input{border:none;background:transparent;font-family:var(--font);font-size:13px;color:var(--fg);outline:none;width:100%}.mobile-search input::placeholder{color:var(--muted)}.m-card{padding:11px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}.m-card:last-child{border-bottom:none}.m-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.m-card-title{font-weight:600;font-size:13.5px;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.m-card-sub{font-size:12px;color:var(--muted);margin-top:3px;line-height:1.4}.m-card-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:8px}.m-card-meta{font-size:12px;color:var(--muted)}table{width:100%;border-collapse:collapse}thead th{background:var(--bg);padding:9px 14px;text-align:left;font-size:11px;font-weight:600;color:var(--muted);letter-spacing:.05em;text-transform:uppercase;border-bottom:1px solid var(--border)}tbody td{padding:12px 14px;font-size:13.5px;border-bottom:1px solid var(--border);vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--bg)}.patients-row{cursor:pointer}.action-btns{display:flex;gap:5px}.patient-name-cell{display:flex;align-items:center;gap:9px}.pt-avatar{width:30px;height:30px;border-radius:50%;background:var(--accent-light);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}.pt-name{font-weight:500;font-size:13.5px}.pt-dob{font-size:11px;color:var(--muted)}.badge{display:inline-flex;align-items:center;padding:2px 7px;border-radius:5px;font-size:11px;font-weight:600}.badge-success{background:#34c7591a;color:var(--success)}.badge-warning{background:#ff95001a;color:var(--warning)}.badge-danger{background:#ff3b301a;color:var(--danger)}.badge-info{background:var(--accent-light);color:var(--accent)}.badge-gray{background:#6e6e731a;color:var(--muted)}.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:var(--radius-sm);font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;transition:all .12s;border:none}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:transparent;color:var(--fg);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg)}.btn-danger{background:transparent;color:var(--danger);border:1px solid transparent}.btn-danger:hover{background:#ff3b3014}.btn-sm{padding:4px 9px;font-size:12px}.btn-ghost{background:transparent;color:var(--accent);border:none;padding:4px 8px;font-size:12px;font-weight:500;cursor:pointer;font-family:var(--font)}.notif-item{display:flex;align-items:center;gap:11px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 12px;cursor:pointer;transition:border-color .12s}.notif-item:hover{border-color:var(--accent)}.notif-avatar{width:30px;height:30px;border-radius:50%;background:var(--accent-light);display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:11px;font-weight:700;flex-shrink:0}.notif-name{font-size:13px;font-weight:500}.notif-detail{font-size:11.5px;color:var(--muted)}.notif-tag{margin-left:auto;font-size:10.5px;font-weight:600;padding:2px 8px;border-radius:6px}.patient-header{background:var(--surface);border-bottom:1px solid var(--border)}.patient-header-top{display:flex;align-items:center;gap:14px;padding:18px 26px 16px;flex-wrap:wrap}.pt-big-avatar{width:52px;height:52px;border-radius:50%;background:var(--accent-light);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;flex-shrink:0}.pt-full-name{font-size:18px;font-weight:700;letter-spacing:-.02em;margin-bottom:3px}.pt-meta{display:flex;gap:14px;flex-wrap:wrap}.pt-meta-item{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--muted)}.pt-header-actions{display:flex;gap:8px;flex-shrink:0;margin-left:auto}.tabs{display:flex;gap:0;border-bottom:1px solid var(--border);padding:0 26px;overflow-x:auto}.tab{padding:11px 14px;font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;transition:all .12s;white-space:nowrap;margin-bottom:-1px}.tab:hover{color:var(--fg)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-content{padding:22px 26px}.overview-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.info-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px}.info-section-title{font-size:10.5px;font-weight:700;color:var(--muted);letter-spacing:.07em;text-transform:uppercase;margin-bottom:12px}.info-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid var(--border);font-size:13px}.info-row:last-child{border-bottom:none}.info-label{color:var(--muted)}.info-value{font-weight:500}.dental-map-layout{display:flex;gap:16px;align-items:flex-start}.dental-map-wrap{flex:1;min-width:0;max-width:560px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px}.dental-map-detail{width:320px;flex-shrink:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;min-height:200px}.dental-map-legend{display:flex;gap:14px;margin-bottom:12px;flex-wrap:wrap;align-items:center}.legend-item{display:flex;align-items:center;gap:5px;font-size:11.5px;color:var(--muted)}.legend-dot{width:11px;height:11px;border-radius:3px}.tooth-detail-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.tooth-detail-title{font-size:15px;font-weight:600}.proc-row{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}.proc-row:last-child{border-bottom:none}.proc-tooth-badge{background:var(--accent-light);color:var(--accent);font-size:10.5px;font-weight:700;padding:2px 7px;border-radius:5px;flex-shrink:0;min-width:34px;text-align:center}.proc-info{flex:1}.proc-name{font-size:13.5px;font-weight:500}.proc-meta{font-size:11.5px;color:var(--muted);margin-top:2px}.proc-status{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.file-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px}.file-card{border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;transition:border-color .12s}.file-card:hover{border-color:var(--accent)}.file-thumb{height:88px;background:var(--bg);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:32px}.file-name{padding:7px 8px;font-size:11.5px;font-weight:500;border-top:1px solid var(--border)}.file-date{font-size:10.5px;color:var(--muted);padding:0 8px 7px}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:28px;text-align:center;color:var(--muted);cursor:pointer;transition:border-color .12s;margin-bottom:16px}.upload-zone:hover{border-color:var(--accent);color:var(--accent)}.upload-zone-active{border-color:var(--accent);background:#629fca0f;color:var(--accent)}.notes-list{display:flex;flex-direction:column;gap:10px}.note-item{display:flex;gap:12px;align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 14px;border-left:3px solid var(--accent)}.note-avatar{width:32px;height:32px;border-radius:50%;flex-shrink:0;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;letter-spacing:.03em}.note-body{flex:1;min-width:0}.note-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px;gap:8px}.note-author{font-size:12.5px;font-weight:600;color:var(--fg)}.note-date{font-size:11.5px;color:var(--muted);white-space:nowrap}.note-text{font-size:13px;line-height:1.6;color:var(--fg);white-space:pre-wrap}.cal-two-col{display:flex;gap:20px;align-items:flex-start}.cal-list-col{flex:1;min-width:0;max-width:680px;order:1}.cal-grid-col{width:272px;flex-shrink:0;order:2;align-self:flex-start;position:sticky;top:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 10px}.cal-mini-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.cal-mini-label{font-size:13.5px;font-weight:700;letter-spacing:-.01em}.cal-mini-arrow{width:26px;height:26px;border-radius:6px;border:1px solid var(--border);background:var(--bg);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s;color:var(--fg)}.cal-mini-arrow:hover{background:var(--border)}.cal-mini-btns{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:6px}.cal-mini-today-btn{font-size:11.5px!important;padding:3px 10px!important}.cal-mini-view-btn{padding:3px 10px;font-size:11.5px;font-weight:500;cursor:pointer;background:var(--surface);border:none;font-family:var(--font);color:var(--fg);transition:background .1s}.cal-mini-view-btn:hover{background:var(--bg)}.cal-mini-view-btn.active{background:var(--accent);color:#fff;font-weight:600}.cal-mini-daynames{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:2px}.cal-mini-dayname{text-align:center;font-size:9.5px;font-weight:600;color:var(--muted);letter-spacing:.04em;padding:2px 0 4px}.cal-mini-week{display:grid;grid-template-columns:repeat(7,1fr)}.cal-mini-day{display:flex;flex-direction:column;align-items:center;padding:2px 0;cursor:pointer;border-radius:6px;transition:background .1s}.cal-mini-day:hover{background:#629fca12}.cal-mini-day-other{opacity:.3}.cal-mini-num{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:400;color:var(--fg)}.cal-mini-num-today{background:var(--accent);color:#fff;font-weight:700}.cal-mini-num-sel{background:#629fca2e;color:var(--accent);font-weight:600}.cal-mini-dots{display:flex;gap:2px;margin-top:1px;height:5px}.cal-mini-dot{width:4px;height:4px;border-radius:50%;background:var(--accent);flex-shrink:0}.cal-week-view{border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background:var(--surface);margin-top:4px}.cal-week-head{display:flex;border-bottom:1px solid var(--border);background:var(--surface)}.cal-time-gutter{width:36px;flex-shrink:0}.cal-week-day-head{flex:1;padding:5px 2px;text-align:center;cursor:pointer;border-left:1px solid var(--border);transition:background .1s;min-width:0}.cal-week-day-head:hover{background:#629fca0f}.cal-wdh-today{background:#629fca14}.cal-wdh-selected{background:#629fca24}.cal-wdh-name{display:block;font-size:9px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.cal-wdh-num{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;font-size:11px;font-weight:500}.cal-wdh-num-today{background:var(--accent);color:#fff;font-weight:700}.cal-week-grid{display:flex;overflow-y:auto;max-height:280px}.cal-time-col{width:36px;flex-shrink:0}.cal-time-cell{display:flex;align-items:flex-start;justify-content:flex-end;padding:2px 4px 0 0;font-size:9px;color:var(--muted);font-weight:500;border-bottom:1px solid var(--border)}.cal-week-col{flex:1;position:relative;border-left:1px solid var(--border);cursor:pointer;min-width:0}.cal-week-col:hover{background:#629fca08}.cal-grid-cell{position:absolute;left:0;right:0;border-bottom:1px solid var(--border);pointer-events:none}.cal-appt-block{position:absolute;left:1px;right:1px;border-radius:3px;padding:1px 3px;overflow:hidden;cursor:pointer;z-index:1;transition:opacity .1s}.cal-appt-block:hover{opacity:.8}.cal-appt-block-scheduled{background:#629fca38;border-left:2px solid var(--accent)}.cal-appt-block-completed{background:#34c75933;border-left:2px solid var(--success)}.cal-appt-block-cancelled{background:#6e6e731f;border-left:2px solid var(--muted);opacity:.55}.cal-appt-block-name{font-size:9px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--fg)}.cal-appt-list{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.cal-appt-list-head{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border)}.cal-list-date-header{padding:4px 14px 3px;font-size:10px;font-weight:700;color:var(--muted);letter-spacing:.07em;text-transform:uppercase;background:var(--bg);border-bottom:1px solid var(--border);border-top:1px solid var(--border)}.cal-list-row{display:flex;align-items:center;gap:8px;padding:5px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}.cal-list-row:hover{background:var(--bg)}.cal-list-row-last{border-bottom:none}.cal-list-time{font-size:12px;font-weight:600;color:var(--accent);width:40px;flex-shrink:0}.cal-list-status{font-size:10.5px;font-weight:600;padding:2px 7px;border-radius:5px;flex-shrink:0}.cal-list-status-scheduled{background:#629fca1f;color:var(--accent)}.cal-list-status-completed{background:#34c7591f;color:#1a7a34}.cal-list-status-cancelled{background:#6e6e731a;color:var(--muted)}.appt-view-row{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.appt-view-label{font-size:12px;color:var(--muted);font-weight:500;flex-shrink:0;padding-top:1px}.appt-view-value{font-size:13px;font-weight:500;text-align:right}@media (max-width: 900px){.cal-two-col{flex-direction:column}.cal-list-col{order:2}.cal-grid-col{order:1;width:100%;position:static}}@media (max-width: 640px){.cal-week-view{overflow-x:auto}.cal-week-grid{max-height:260px}}@media (max-width: 768px){.cal-two-col{flex-direction:column}.cal-list-col{order:2}.cal-grid-col{order:1;width:100%;position:static}}@media (max-width: 640px){.cal-week-view{overflow-x:auto}.cal-week-grid{max-height:300px}.cal-week-col,.cal-week-day-head{min-width:40px}}.dash-stats{grid-template-columns:repeat(3,1fr)}.dash-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-top:16px}.dash-grid .card-header{padding:13px 16px}.settings-list{display:flex;flex-direction:column}.settings-row{display:flex;align-items:center;gap:10px;padding:9px 14px;border-bottom:1px solid var(--border);font-size:13px}.settings-row:last-child{border-bottom:none}.settings-row-name{flex:1;min-width:0;word-break:break-word}.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;align-items:start;max-width:1100px}.settings-grid .card-header{padding:11px 14px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000061;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);touch-action:none;overscroll-behavior:none}.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-modal);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;touch-action:pan-y;position:relative}.modal-lg{max-width:640px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border)}.modal-title{font-size:16px;font-weight:600;letter-spacing:-.01em}.modal-body{padding:22px;overflow-x:hidden}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 22px;border-top:1px solid var(--border)}.close-btn{width:26px;height:26px;border-radius:50%;background:var(--bg);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);font-size:14px}.form-group{margin-bottom:14px}.form-label{display:block;font-size:12.5px;font-weight:500;color:var(--fg);margin-bottom:5px}.form-input,.form-select,.form-textarea{width:100%;padding:8px 11px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:13px;color:var(--fg);background:var(--surface);outline:none;transition:border-color .12s}@supports (-webkit-touch-callout: none){.form-input,.form-select,.form-textarea{font-size:16px}}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent)}.form-textarea{min-height:80px;resize:vertical}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.form-sub{font-size:11px;color:var(--muted);margin-top:3px}.chip-row{display:flex;flex-wrap:wrap;gap:6px}.chip{padding:5px 13px;border-radius:20px;border:1px solid var(--border);font-size:12.5px;cursor:pointer;transition:all .12s;background:var(--surface);font-family:var(--font)}.chip.active{background:var(--accent);border-color:var(--accent);color:#fff}.back-btn{display:inline-flex;align-items:center;gap:5px;font-size:13.5px;color:var(--accent);cursor:pointer;padding:5px 0;font-weight:500;background:none;border:none;font-family:var(--font)}.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.section-title{font-size:14px;font-weight:600}.empty-state{text-align:center;padding:44px 24px;color:var(--muted)}.empty-state-icon{font-size:36px;margin-bottom:10px}.empty-state-text{font-size:14px;font-weight:500;margin-bottom:4px;color:var(--fg)}.empty-state-sub{font-size:12.5px}.divider{height:1px;background:var(--border);margin:16px 0}.treatment-area{width:100%;min-height:180px;padding:12px;border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font);font-size:13.5px;line-height:1.6;resize:vertical;outline:none}.treatment-area:focus{border-color:var(--accent)}.tag{display:inline-flex;align-items:center;padding:2px 7px;border-radius:5px;font-size:11px;font-weight:600;background:var(--accent-light);color:var(--accent)}.mobile-header{display:none;align-items:center;gap:12px;height:52px;padding:0 16px;background:var(--sidebar-bg);position:sticky;top:0;z-index:90;flex-shrink:0}.hamburger-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:#ffffff14;border:none;border-radius:8px;cursor:pointer;color:#fff;flex-shrink:0}.hamburger-btn:hover{background:#ffffff24}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:150;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}@media (max-width: 1024px){.sidebar{width:58px;overflow:hidden}.logo-text,.logo-sub,.nav-item span:not(.nav-badge):not(.nav-icon),.doctor-name,.doctor-role,.nav-label{display:none}.nav-item{justify-content:center;padding:10px 0;position:relative}.nav-icon{opacity:1;color:#fff}.nav-badge{position:absolute;top:6px;right:7px;width:8px;height:8px;border-radius:50%;padding:0;min-width:unset;font-size:0}.main-content{margin-left:58px}.stats-row{grid-template-columns:1fr 1fr}.dash-stats{grid-template-columns:repeat(3,1fr)}.overview-grid{grid-template-columns:1fr}.settings-grid{grid-template-columns:1fr 1fr}.patient-header-top{padding:14px 18px 12px}.tab-content{padding:16px 18px}.tabs{padding:0 18px}.dental-map-layout{flex-direction:column}.dental-map-wrap{max-width:100%}.dental-map-detail{width:100%}}@media (max-width: 640px){.mobile-header{display:flex}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-w);height:100vh;z-index:200;overflow:hidden;transform:translate(-100%);transition:transform .25s ease}.sidebar.sidebar-open{transform:translate(0)}.sidebar.sidebar-open .logo-text,.sidebar.sidebar-open .logo-sub,.sidebar.sidebar-open .nav-item span:not(.nav-badge),.sidebar.sidebar-open .doctor-name,.sidebar.sidebar-open .doctor-role,.sidebar.sidebar-open .nav-label{display:block}.sidebar.sidebar-open .nav-item{justify-content:flex-start;padding:8px 10px;gap:9px}.sidebar.sidebar-open .nav-badge{position:static;width:auto;height:auto;font-size:10px;padding:1px 6px;min-width:16px}.main-content{margin-left:0;padding-top:0;overflow-x:clip;max-width:100vw}.top-header{padding:9px 14px;position:sticky;top:52px}.header-search{display:none}.mobile-search{display:flex}.page-body{padding:12px}.stats-row{grid-template-columns:1fr 1fr;gap:10px}.dash-stats{grid-template-columns:1fr 1fr}.dash-grid{grid-template-columns:1fr;gap:12px}.stat-card{padding:14px}.stat-value{font-size:22px}.settings-grid{grid-template-columns:1fr}.settings-card-doctors{order:1}.settings-card-procedures{order:2}.settings-card-materials{order:3}.settings-card-procedures .settings-list,.settings-card-materials .settings-list{max-height:380px;overflow-y:auto;-webkit-overflow-scrolling:touch}.overview-grid,.form-row{grid-template-columns:1fr}.dental-map-layout{flex-direction:column}.dental-map-wrap{max-width:100%}.dental-map-detail{width:100%}.card{overflow:hidden}.card>table,.card>div>table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;min-width:0}table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;min-width:0}.table-has-cards{overflow:hidden}.table-has-cards table{display:none!important}.mobile-card-list{display:flex;flex-direction:column}.table-toolbar{flex-wrap:wrap;gap:8px;padding:10px 14px}.table-toolbar>div{flex-wrap:wrap;width:100%}.table-toolbar select{flex:1;min-width:100px}.date-range-filters{display:none}.mobile-date-filter{display:block;flex:1}.desktop-only{display:none!important}.patient-header{overflow:hidden}.patient-header-top{flex-wrap:wrap;padding:12px 14px 10px;gap:8px}.back-btn{flex:0 0 100%}.pt-header-divider{display:none}.pt-big-avatar{width:42px;height:42px;font-size:15px}.pt-full-name{font-size:15px;overflow-wrap:break-word;word-break:break-word}.pt-meta{flex-direction:column;gap:3px}.pt-meta-item{font-size:11.5px;min-width:0;overflow-wrap:break-word;word-break:break-word}.pt-header-actions{flex:0 0 100%;margin-left:0;justify-content:flex-start;gap:6px}.pt-header-actions .icon-btn{flex:0 0 34px}.pt-header-actions .btn{flex:1;justify-content:center;font-size:12px;padding:6px 8px}.tabs{padding:0 14px;scrollbar-width:none;-webkit-mask-image:linear-gradient(to right,black 85%,transparent 100%);mask-image:linear-gradient(to right,black 85%,transparent 100%)}.tabs::-webkit-scrollbar{display:none}.tabs{touch-action:pan-x}.tab-content{padding:14px;overscroll-behavior-y:contain}.tab{padding:10px 11px;font-size:12px}.info-row{flex-direction:column;align-items:flex-start;gap:1px;padding:8px 0}.info-label{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.info-value{font-size:13.5px}.dental-map-wrap{padding:10px}.dental-map-detail{padding:12px}.dental-map-wrap,.dental-map-detail{overflow-x:auto}.proc-row{flex-wrap:wrap;gap:6px 10px}.proc-status{flex:0 0 100%;flex-direction:row;align-items:center;justify-content:flex-start;gap:8px;padding-left:44px}.modal-overlay{padding:12px;align-items:center;overscroll-behavior:none}.modal{border-radius:var(--radius-lg);max-width:calc(100vw - 24px);width:100%;max-height:88vh}.modal-header{padding:14px 16px}.modal-body{padding:16px}.modal-footer{padding:12px 16px}.tooth-detail-head{flex-wrap:wrap;gap:8px}}.login-screen{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:36px 40px;width:100%;max-width:380px;box-shadow:0 4px 32px #00000012}.login-brand{display:flex;justify-content:center;margin-bottom:32px}
