@import"https://fonts.googleapis.com/css2?family=Montserrat:wght@600;700&family=Poppins:wght@300;400;500;600&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--dark: #020B18;--dark-mid: #0D1F3C;--dark-hover: #112244;--blue: #0F766E;--blue-light: #5EEAD4;--blue-pale: #F0FDFA;--white: #FFFFFF;--bg: #F4F7FC;--bg-card: #FFFFFF;--text: #1A2340;--text-sub: rgba(26,35,64,.55);--text-muted: rgba(26,35,64,.35);--border: rgba(26,35,64,.09);--border-dark: rgba(255,255,255,.08);--success: #10B981;--success-bg: #ECFDF5;--warning: #F59E0B;--warning-bg: #FFFBEB;--danger: #EF4444;--danger-bg: #FEF2F2;--info: #3B82F6;--info-bg: #EFF6FF;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--shadow-sm: 0 1px 4px rgba(26,35,64,.06);--shadow-md: 0 4px 16px rgba(26,35,64,.08);--shadow-lg: 0 8px 32px rgba(26,35,64,.12);--transition: .2s cubic-bezier(.4, 0, .2, 1);--sidebar-w: 240px;--header-h: 64px}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}body{font-family:Poppins,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;font-weight:400;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:Montserrat,sans-serif;font-weight:600;line-height:1.2}a{text-decoration:none;color:inherit}button{cursor:pointer;font-family:Poppins,sans-serif}input,textarea,select{font-family:Poppins,sans-serif}img{display:block;max-width:100%}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--blue)}.app-loading{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg)}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.page{padding:32px;max-width:1200px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;gap:16px}.page-title{font-size:22px;color:var(--text)}.page-subtitle{font-size:13px;color:var(--text-sub);margin-top:2px;font-weight:400}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}@media (max-width: 1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.page{padding:16px}.form-row{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start;gap:10px}.page-header>div:last-child{width:100%;display:flex;gap:8px;flex-wrap:wrap}.filter-bar{flex-direction:column;align-items:stretch}.search-wrap{max-width:100%}.filter-tabs{overflow-x:auto;flex-wrap:nowrap;padding-bottom:2px}.filter-tab{white-space:nowrap;flex-shrink:0}}@media (max-width: 640px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}.page{padding:16px}}@media (max-width: 430px){.page{padding:12px}.page-title{font-size:18px}.card{padding:16px}.data-table th,.data-table td{padding:10px 12px;font-size:12.5px}.action-btn{width:28px;height:28px}}@media (max-width: 390px){.page{padding:10px}.card{padding:14px}}.card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:24px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.card-title{font-size:15px;font-weight:600;color:var(--text)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:var(--text-muted)}.empty-state svg{margin-bottom:16px;opacity:.4}.empty-state p{font-size:14px;margin-bottom:20px}.filter-bar{display:flex;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap}.search-wrap{display:flex;align-items:center;gap:8px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:8px 12px;flex:1;min-width:200px;max-width:360px;color:var(--text-muted)}.search-wrap input{border:none;outline:none;background:transparent;font-size:13px;color:var(--text);width:100%}.search-wrap input::placeholder{color:var(--text-muted)}.filter-tabs{display:flex;gap:4px;flex-wrap:wrap}.filter-tab{padding:6px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);font-size:12.5px;font-weight:500;color:var(--text-sub);cursor:pointer;transition:var(--transition)}.filter-tab:hover{border-color:var(--blue);color:var(--blue)}.filter-tab.active{background:var(--blue);border-color:var(--blue);color:var(--white)}.table-card{padding:0;overflow:hidden}.data-table{width:100%;border-collapse:collapse}.data-table thead tr{border-bottom:1px solid var(--border)}.data-table th{padding:12px 16px;text-align:left;font-size:11.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.data-table td{padding:12px 16px;font-size:13.5px;border-bottom:1px solid var(--border);vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--bg)}.table-primary{font-weight:500;color:var(--text)}.table-muted{color:var(--text-muted);font-size:13px}.row-actions{display:flex;gap:4px;justify-content:flex-end}.action-btn{width:30px;height:30px;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition)}.action-btn:hover{background:var(--bg);color:var(--text);border-color:var(--blue)}.action-btn-danger:hover{background:var(--danger-bg)!important;color:var(--danger)!important;border-color:var(--danger)!important}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:12px;font-weight:600;color:var(--text-sub);text-transform:uppercase;letter-spacing:.04em}.form-input{padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);font-size:13.5px;color:var(--text);outline:none;transition:var(--transition);width:100%}.form-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-pale)}.form-select{padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);font-size:13.5px;color:var(--text);outline:none;transition:var(--transition);width:100%;cursor:pointer}.form-select:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-pale)}.form-hint{font-size:11.5px;color:var(--text-muted)}.payment-amount{font-weight:600;color:var(--text);font-family:Montserrat,sans-serif}.sidebar-hamburger{display:none;position:fixed;top:14px;left:14px;z-index:200;background:var(--dark);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);color:#fffc;padding:8px;cursor:pointer;align-items:center;justify-content:center}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:149}.sidebar{width:var(--sidebar-w);background:var(--dark);height:100vh;position:fixed;left:0;top:0;display:flex;flex-direction:column;z-index:150;border-right:1px solid rgba(255,255,255,.04);transition:transform .25s ease}.sidebar-logo{padding:24px 20px 20px;border-bottom:1px solid var(--border-dark);display:flex;flex-direction:column;gap:2px}.sidebar-logo-img{height:28px;width:auto;object-fit:contain;filter:brightness(0) invert(1)}.sidebar-logo-img--custom{filter:none;max-height:32px}.sidebar-custom-logo{height:32px;width:32px;object-fit:contain;border-radius:var(--radius-sm);flex-shrink:0}.sidebar-logo-sub{font-size:10px;font-weight:500;color:#ffffff59;letter-spacing:.08em;text-transform:uppercase}.sidebar-office{display:flex;align-items:center;gap:10px}.sidebar-office-icon{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--blue);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;font-family:Montserrat,sans-serif;flex-shrink:0}.sidebar-office-info{display:flex;flex-direction:column;gap:2px;min-width:0}.sidebar-office-name{font-size:13px;font-weight:600;color:var(--white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.sidebar-demo-badge{font-size:9px;font-weight:700;background:#f59e0b33;color:#fcd34d;padding:2px 6px;border-radius:20px;letter-spacing:.08em;border:1px solid rgba(245,158,11,.3)}.sidebar-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.sidebar-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);color:#ffffff8c;font-size:13.5px;font-weight:400;transition:var(--transition);text-decoration:none;position:relative}.sidebar-link:hover{background:#ffffff0f;color:#ffffffd9}.sidebar-link.active{background:var(--blue);color:var(--white);font-weight:500;box-shadow:0 2px 12px #1264f359}.sidebar-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:20px}.sidebar-label{flex:1}.sidebar-logout{margin:12px;padding:10px 12px;border-radius:var(--radius-sm);background:transparent;border:1px solid rgba(255,255,255,.08);color:#fff6;font-size:13px;font-weight:400;display:flex;align-items:center;gap:8px;transition:var(--transition);cursor:pointer}.sidebar-logout:hover{background:#ef44441f;border-color:#ef44444d;color:#ef4444}.toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:10px;z-index:9999;max-width:380px;pointer-events:none}.toast{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border);box-shadow:0 8px 24px #1a23401f,0 2px 8px #1a23400f;font-size:13px;animation:toastSlideIn .22s cubic-bezier(.34,1.56,.64,1);pointer-events:all;position:relative;overflow:hidden}.toast:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:3px 0 0 3px}.toast-success:before{background:var(--success)}.toast-error:before{background:var(--danger)}.toast-warning:before{background:var(--warning)}.toast-info:before{background:var(--blue)}@keyframes toastSlideIn{0%{opacity:0;transform:translate(16px) scale(.96)}to{opacity:1;transform:translate(0) scale(1)}}.toast-success .toast-icon{color:var(--success)}.toast-error .toast-icon{color:var(--danger)}.toast-warning .toast-icon{color:var(--warning)}.toast-info .toast-icon{color:var(--blue)}.toast-icon{flex-shrink:0;margin-top:2px}.toast-body{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.toast-type-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.toast-success .toast-type-label{color:var(--success)}.toast-error .toast-type-label{color:var(--danger)}.toast-warning .toast-type-label{color:var(--warning)}.toast-info .toast-type-label{color:var(--blue)}.toast-msg{color:var(--text);line-height:1.45;font-size:13px}.toast-close{background:none;border:none;color:var(--text-muted);padding:2px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;border-radius:4px;transition:var(--transition);margin-top:1px}.toast-close:hover{background:var(--bg);color:var(--text)}.sidebar-demo-footer{margin:12px;padding:10px 12px;border-radius:var(--radius-sm);background:#f59e0b14;border:1px solid rgba(245,158,11,.15);display:flex;align-items:center;gap:8px;font-size:12px;font-weight:500;color:#fcd34d}.sidebar-demo-footer-dot{width:6px;height:6px;border-radius:50%;background:#fcd34d;flex-shrink:0;animation:pulse 2s infinite}.sidebar-demo-env{border-right-color:#f59e0b26}@media (max-width: 768px){.sidebar-hamburger,.sidebar-overlay,.sidebar{display:none}.sidebar.sidebar-open{display:flex;transform:translate(0)}}.header{height:var(--header-h);background:var(--bg-card);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 32px;position:sticky;top:0;z-index:160;box-shadow:var(--shadow-sm)}.header-left{display:flex;flex-direction:column;gap:1px}.header-title{font-size:17px;font-weight:600;color:var(--text);font-family:Montserrat,sans-serif}.header-sub{font-size:12px;color:var(--text-muted);font-weight:400}.header-right{display:flex;align-items:center;gap:12px}.header-repo-badge{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;color:var(--text-sub);font-weight:500;transition:var(--transition);text-decoration:none}.header-repo-badge:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-pale)}.header-avatar{width:36px;height:36px;border-radius:50%;background:var(--blue-pale);border:1.5px solid var(--blue);display:flex;align-items:center;justify-content:center;color:var(--blue);cursor:pointer;transition:var(--transition)}.header-avatar:hover{background:var(--blue);color:var(--white)}.header-search{position:relative;flex:1;max-width:360px;margin:0 16px}.header-search-input-wrap{display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:0 10px;transition:var(--transition)}.header-search-input-wrap:focus-within{border-color:var(--blue);background:var(--bg-card);box-shadow:0 0 0 3px #1264f314}.header-search-icon{color:var(--text-muted);flex-shrink:0}.header-search-input{flex:1;border:none;background:transparent;font-size:13px;color:var(--text);padding:8px 0;outline:none}.header-search-input::placeholder{color:var(--text-muted)}.header-search-clear{background:none;border:none;padding:2px;color:var(--text-muted);display:flex;align-items:center;cursor:pointer;transition:color .15s;flex-shrink:0}.header-search-clear:hover{color:var(--text)}.header-search-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 8px 32px #1a234029,0 2px 8px #1a234014;z-index:9000;overflow:hidden;animation:searchDropIn .15s ease;min-width:280px}@keyframes searchDropIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.header-search-result{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;background:none;border:none;border-bottom:1px solid var(--border);text-align:left;cursor:pointer;transition:background .12s}.header-search-result:last-child{border-bottom:none}.header-search-result:hover{background:var(--bg)}.header-search-result-icon{font-size:14px;flex-shrink:0}.header-search-result-body{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}.header-search-result-label{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-search-empty{padding:16px 14px;font-size:13px;color:var(--text-muted);text-align:center}.header-search-result-sub{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-search-result-type{font-size:10.5px;font-weight:500;color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:2px 8px;flex-shrink:0}@media (max-width: 768px){.header{padding:0 14px;gap:8px;height:56px;flex-wrap:nowrap;overflow:hidden}.header-left{flex:1;min-width:0;overflow:hidden}.header-title{font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-sub,.header-search{display:none}.header-right{gap:8px;flex-shrink:0}}@media (max-width: 480px){.header{padding:0 12px}.header-title{font-size:14px}.header-avatar{width:32px;height:32px}}.bottom-nav-admin{display:none;position:fixed;bottom:0;left:0;right:0;z-index:300;background:var(--dark);border-top:1px solid rgba(255,255,255,.08);padding:0;padding-bottom:env(safe-area-inset-bottom,0px);box-shadow:0 -4px 20px #00000040}.bottom-nav-admin-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:10px 4px 8px;color:#fff6;font-size:10px;font-weight:400;font-family:Poppins,sans-serif;transition:color .2s ease;flex:1;text-align:center;text-decoration:none;letter-spacing:.01em;position:relative}.bottom-nav-admin-item.active{color:var(--blue)}.bottom-nav-admin-item.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:32px;height:2px;background:var(--blue);border-radius:0 0 2px 2px}.bottom-nav-admin-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .2s ease}.bottom-nav-admin-item.active .bottom-nav-admin-icon{transform:translateY(-1px)}.bottom-nav-admin-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:56px;line-height:1.2}@media (max-width: 768px){.bottom-nav-admin{display:flex;align-items:stretch}}.notif-permission-bar{display:flex;align-items:center;gap:10px;padding:10px 20px;background:var(--color-info-bg, #eff6ff);border-bottom:1px solid var(--color-info-border, #bfdbfe);color:var(--color-info-text, #1e40af);font-size:13px}.notif-permission-bar svg{flex-shrink:0;color:var(--color-info-text, #1e40af)}.notif-permission-bar span{flex:1}.notif-allow-btn{padding:4px 12px;background:var(--color-primary, #2563eb);color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:background .15s}.notif-allow-btn:hover{background:var(--color-primary-dark, #1d4ed8)}.notif-hearing-bar{display:flex;align-items:center;gap:10px;padding:10px 20px;border-bottom:1px solid transparent;font-size:13px}.notif-hearing-bar.notif-danger{background:#fef2f2;border-color:#fecaca;color:#991b1b}.notif-hearing-bar.notif-warning{background:#fffbeb;border-color:#fde68a;color:#92400e}.notif-hearing-info{flex:1}.notif-court{opacity:.75;font-size:12px}.notif-email-btn{display:flex;align-items:center;gap:5px;padding:4px 10px;background:transparent;border:1px solid currentColor;border-radius:6px;font-size:12px;font-weight:500;color:inherit;cursor:pointer;opacity:.8;transition:opacity .15s}.notif-email-btn:hover{opacity:1}.notif-dismiss-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:transparent;border:none;border-radius:4px;color:inherit;opacity:.5;cursor:pointer;transition:opacity .15s;flex-shrink:0}.notif-dismiss-btn:hover{opacity:1}.layout{display:flex;min-height:100vh;background:var(--bg)}.layout-main{flex:1;margin-left:var(--sidebar-w);display:flex;flex-direction:column;min-height:100vh;min-width:0}.layout-content{flex:1;overflow-y:auto}@media (max-width: 768px){.layout-main{margin-left:0;padding-bottom:calc(64px + env(safe-area-inset-bottom,0px))}.page{padding:16px}.table-card{overflow-x:auto;-webkit-overflow-scrolling:touch}.data-table{min-width:600px}.grid-3,.grid-2{grid-template-columns:1fr!important}.filter-bar{flex-direction:column;align-items:stretch}.search-wrap{max-width:100%}.page-header{flex-direction:column;align-items:flex-start;gap:12px}}@media (max-width: 480px){.header-repo-badge{display:none}.layout-main{padding-bottom:calc(68px + env(safe-area-inset-bottom,0px))}}.ob-demo-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:11px 20px;background:#ffffff0d;border:1.5px solid rgba(255,255,255,.15);border-radius:var(--radius-sm);color:#fffc;font-size:13.5px;font-weight:500;cursor:pointer;transition:var(--transition);margin-bottom:0}.ob-demo-btn:hover{background:#ffffff1a;border-color:#ffffff4d;color:var(--white)}.ob-demo-badge{font-size:10px;font-weight:600;background:#1264f34d;color:var(--blue-light);padding:2px 7px;border-radius:20px;letter-spacing:.05em;text-transform:uppercase}.ob-divider{display:flex;align-items:center;gap:12px;margin:20px 0 4px}.ob-divider:before,.ob-divider:after{content:"";flex:1;height:1px;background:#ffffff1a}.ob-divider span{font-size:11.5px;color:#ffffff4d;white-space:nowrap}.onboarding{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative;background:var(--dark)}.onboarding-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 60% at 20% 40%,rgba(18,100,243,.18) 0%,transparent 60%),radial-gradient(ellipse 60% 50% at 80% 70%,rgba(18,100,243,.1) 0%,transparent 60%);pointer-events:none}.onboarding-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-xl);padding:40px;width:100%;max-width:480px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:relative;z-index:1;box-shadow:0 24px 64px #0006}.onboarding-logo{display:flex;align-items:center;gap:10px;margin-bottom:28px}.onboarding-logo img{height:28px;width:auto;filter:brightness(0) invert(1)}.onboarding-logo span{font-size:11px;font-weight:500;color:#ffffff59;letter-spacing:.1em;text-transform:uppercase;padding:3px 8px;border:1px solid rgba(255,255,255,.12);border-radius:20px}.onboarding-header{margin-bottom:28px}.onboarding-header h1{font-size:22px;color:var(--white);margin-bottom:8px}.onboarding-header p{font-size:13px;color:#ffffff73;line-height:1.6}.onboarding-form{display:flex;flex-direction:column;gap:0}.ob-field{margin-bottom:18px}.ob-field label{display:block;font-size:12.5px;font-weight:500;color:#fff9;margin-bottom:7px}.ob-required{color:var(--danger);margin-left:3px}.ob-field input{width:100%;padding:10px 14px;background:#ffffff0f;border:1.5px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);color:var(--white);font-size:13.5px;outline:none;transition:var(--transition)}.ob-field input::placeholder{color:#ffffff40}.ob-field input:focus{border-color:var(--blue);background:#1264f314;box-shadow:0 0 0 3px #1264f326}.ob-input-wrap{position:relative}.ob-input-wrap input{padding-right:42px}.ob-eye{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:#ffffff59;cursor:pointer;display:flex;align-items:center;padding:4px;transition:var(--transition)}.ob-eye:hover{color:#ffffffb3}.ob-hint{font-size:11.5px;color:#ffffff4d;margin-top:5px;line-height:1.5}.ob-hint a{color:var(--blue-light);text-decoration:none}.ob-hint a:hover{text-decoration:underline}.ob-hint code{background:#ffffff14;padding:1px 5px;border-radius:4px;font-size:11px;color:#ffffff80}.ob-warning{background:#f59e0b14;border:1px solid rgba(245,158,11,.2);border-radius:var(--radius-sm);margin-bottom:20px;overflow:hidden}.ob-warning-toggle{width:100%;display:flex;align-items:center;gap:7px;padding:10px 14px;background:none;border:none;color:#f59e0bd9;font-size:12.5px;font-weight:500;cursor:pointer;text-align:left}.ob-warning-body{padding:0 14px 12px;display:flex;flex-direction:column;gap:6px}.ob-warning-body p{font-size:12px;color:#f59e0ba6;line-height:1.5}.ob-warning-body strong{color:#f59e0bd9}.ob-error{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#ef44441a;border:1px solid rgba(239,68,68,.25);border-radius:var(--radius-sm);color:#fca5a5;font-size:13px;margin-bottom:16px}.ob-btn{width:100%;padding:12px 20px;background:var(--blue);color:var(--white);border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:var(--transition);box-shadow:0 4px 16px #1264f359}.ob-btn:hover{background:#0f52d4;transform:translateY(-1px);box-shadow:0 6px 20px #1264f373}.ob-btn:active{transform:translateY(0)}.ob-loading{display:flex;flex-direction:column;align-items:center;gap:24px;padding:20px 0}.ob-spinner{width:44px;height:44px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--blue);border-radius:50%;animation:spin .7s linear infinite}.ob-log{width:100%;background:#0000004d;border-radius:var(--radius-sm);padding:14px 16px;display:flex;flex-direction:column;gap:6px}.ob-log p{font-size:12.5px;font-family:Courier New,monospace}.log-ok{color:#6ee7b7}.log-wait{color:#ffffff80}.log-item{color:#ffffff59;padding-left:12px}.demo-login{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;position:relative;background:var(--bg)}.demo-login-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 60% at 20% 10%,rgba(18,100,243,.07) 0%,transparent 60%),radial-gradient(ellipse 60% 50% at 80% 90%,rgba(16,185,129,.05) 0%,transparent 60%);pointer-events:none;z-index:0}.demo-login-card{position:relative;z-index:1;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg),0 0 0 1px #1264f30a;padding:48px 44px;width:100%;max-width:440px;display:flex;flex-direction:column;align-items:center;gap:0}.demo-login-logo{margin-bottom:32px}.demo-login-logo img{height:36px;width:auto;object-fit:contain}.demo-login-header{text-align:center;margin-bottom:32px}.demo-login-title{font-size:26px;font-weight:700;color:var(--text);font-family:Montserrat,sans-serif;letter-spacing:-.02em;margin-bottom:10px;line-height:1.2}.demo-login-sub{font-size:14.5px;color:var(--text-sub);line-height:1.55;font-weight:400}.demo-login-features{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;margin-bottom:32px}.demo-feature-item{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);transition:border-color .15s,background .15s}.demo-feature-item:hover{border-color:#1264f333;background:var(--blue-pale)}.demo-feature-icon{font-size:16px;flex-shrink:0}.demo-feature-text{font-size:12.5px;color:var(--text-sub);font-weight:400;line-height:1.3}.demo-login-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:15px 24px;background:var(--blue);color:var(--white);border:none;border-radius:var(--radius-md);font-size:15px;font-weight:600;font-family:Poppins,sans-serif;cursor:pointer;transition:background .2s,transform .15s,box-shadow .2s;box-shadow:0 4px 16px #1264f34d;margin-bottom:16px}.demo-login-btn:hover{background:#0d52d4;transform:translateY(-1px);box-shadow:0 6px 24px #1264f366}.demo-login-btn:active{transform:translateY(0);box-shadow:0 2px 8px #1264f340}.demo-login-note{font-size:12px;color:var(--text-muted);text-align:center;line-height:1.5}.demo-login-footer{position:relative;z-index:1;margin-top:32px;display:flex;align-items:center;gap:16px;font-size:12px;color:var(--text-muted)}.demo-login-footer a{color:var(--blue);text-decoration:none;font-weight:500}.demo-login-footer a:hover{text-decoration:underline}@media (max-width: 480px){.demo-login-card{padding:36px 24px}.demo-login-title{font-size:22px}.demo-login-features{grid-template-columns:1fr}}.stat-card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);padding:18px 20px;transition:var(--transition)}.stat-card:hover{border-color:var(--blue);box-shadow:0 0 0 3px #1264f30f}.stat-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.stat-card-info{flex:1;min-width:0}.stat-card-title{font-size:12px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.stat-card-value{font-size:26px;font-weight:700;color:var(--text);font-family:Montserrat,sans-serif;line-height:1;margin-bottom:4px}.stat-card-sub{font-size:12px;color:var(--text-muted)}.stat-card-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.7}.stat-card-blue .stat-card-icon{color:var(--blue)}.stat-card-green .stat-card-icon{color:var(--success)}.stat-card-orange .stat-card-icon{color:var(--warning)}.stat-card-red .stat-card-icon{color:var(--danger)}.stat-card-dark .stat-card-icon{color:var(--dark)}.stat-card-trend{display:flex;align-items:center;gap:4px;font-size:11.5px;font-weight:500;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.trend-up{color:var(--success)}.trend-down{color:var(--danger)}.badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:20px;font-size:11.5px;font-weight:500;white-space:nowrap;letter-spacing:.01em}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:#b45309}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-info{background:var(--info-bg);color:var(--info)}.badge-blue{background:var(--blue-pale);color:var(--blue)}.badge-neutral{background:#1a23400f;color:var(--text-sub)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:none;border-radius:var(--radius-sm);font-family:Poppins,sans-serif;font-weight:500;cursor:pointer;transition:var(--transition);white-space:nowrap;text-decoration:none}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-sm{padding:6px 12px;font-size:12.5px}.btn-md{padding:9px 18px;font-size:13.5px}.btn-lg{padding:12px 24px;font-size:15px}.btn-primary{background:var(--blue);color:var(--white);box-shadow:0 2px 8px #1264f340}.btn-primary:hover:not(:disabled){background:#0f52d4;box-shadow:0 4px 16px #1264f359;transform:translateY(-1px)}.btn-secondary{background:var(--bg);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--blue-pale);border-color:var(--blue);color:var(--blue)}.btn-ghost{background:transparent;color:var(--text-sub);border:1px solid transparent}.btn-ghost:hover:not(:disabled){background:var(--bg);color:var(--text)}.btn-danger{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(239,68,68,.2)}.btn-danger:hover:not(:disabled){background:var(--danger);color:var(--white)}.btn-dark{background:var(--dark);color:var(--white)}.btn-dark:hover:not(:disabled){background:var(--dark-mid)}.btn-icon{display:flex;align-items:center}.btn-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:currentColor;border-radius:50%;animation:spin .6s linear infinite}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a16288c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:overlayIn .2s ease}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg),0 0 0 1px var(--border);display:flex;flex-direction:column;max-height:90vh;width:100%;animation:modalIn .25s cubic-bezier(.34,1.56,.64,1)}@keyframes modalIn{0%{opacity:0;transform:scale(.94) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-sm{max-width:420px}.modal-md{max-width:560px}.modal-lg{max-width:720px}.modal-xl{max-width:900px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.modal-title{font-size:16px;font-weight:600;color:var(--text)}.modal-close{width:32px;height:32px;border-radius:var(--radius-sm);background:transparent;border:none;color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition)}.modal-close:hover{background:var(--bg);color:var(--text)}.modal-body{padding:24px;overflow-y:auto;flex:1}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:flex-end;gap:10px}.form-group{margin-bottom:18px}.form-label{display:block;font-size:12.5px;font-weight:500;color:var(--text-sub);margin-bottom:6px}.form-input,.form-select,.form-textarea{width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:13.5px;color:var(--text);background:var(--bg);transition:var(--transition);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--blue);background:var(--white);box-shadow:0 0 0 3px #1264f314}.form-textarea{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-hint{font-size:11.5px;color:var(--text-muted);margin-top:4px}.form-error{font-size:11.5px;color:var(--danger);margin-top:4px}@media (max-width: 600px){.modal-overlay{padding:0;align-items:flex-end}.modal{border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-height:92vh;animation:modalInMobile .3s cubic-bezier(.34,1.2,.64,1)}@keyframes modalInMobile{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.modal-sm,.modal-md,.modal-lg{max-width:100%}.form-row{grid-template-columns:1fr}.form-group[style*=grid-column]{grid-column:1!important}.modal-footer{flex-direction:column-reverse;gap:8px}.modal-footer button{width:100%;justify-content:center}}.dashboard{padding:32px}.quick-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:28px}.quick-action-btn{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);cursor:pointer;transition:var(--transition);text-align:left}.quick-action-btn:hover{border-color:var(--blue);background:var(--blue-pale)}.quick-action-btn:hover .quick-action-label{color:var(--blue)}.quick-action-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm);flex-shrink:0;background:var(--bg);color:var(--text-sub)}.quick-action-label{font-size:13px;font-weight:500;color:var(--text);line-height:1.3;transition:color .15s}.quick-action-blue .quick-action-icon{color:var(--blue)}.quick-action-green .quick-action-icon{color:var(--success)}.quick-action-orange .quick-action-icon{color:var(--warning)}.quick-action-purple .quick-action-icon{color:#7c3aed}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.hearing-badge-overdue{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(239,68,68,.2)}.hearing-list{display:flex;flex-direction:column;gap:12px}.hearing-item{display:flex;align-items:center;gap:14px;padding:12px;background:var(--bg);border-radius:var(--radius-md);border:1px solid var(--border);transition:var(--transition)}.hearing-item:hover{border-color:var(--blue);background:var(--blue-pale)}.hearing-date{display:flex;flex-direction:column;align-items:center;justify-content:center;width:44px;height:44px;background:var(--blue);border-radius:var(--radius-sm);flex-shrink:0}.hearing-day{font-size:16px;font-weight:700;color:var(--white);font-family:Montserrat,sans-serif;line-height:1}.hearing-month{font-size:10px;color:#ffffffbf;text-transform:uppercase;letter-spacing:.05em}.hearing-info{flex:1;min-width:0}.hearing-title{font-size:13.5px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hearing-court{font-size:12px;color:var(--text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-list{display:flex;flex-direction:column;gap:10px}.task-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--bg);border-radius:var(--radius-md);border:1px solid var(--border);transition:var(--transition)}.task-item:hover{border-color:var(--border);box-shadow:var(--shadow-sm)}.task-priority-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.priority-high{background:var(--danger)}.priority-medium{background:var(--warning)}.priority-low{background:var(--text-muted)}.task-info{flex:1;min-width:0}.task-title{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-due{font-size:11.5px;color:var(--text-muted);margin-top:2px}.activity-list{display:flex;flex-direction:column;gap:14px}.activity-item{display:flex;align-items:flex-start;gap:12px}.activity-icon{width:34px;height:34px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.activity-blue{background:var(--blue-pale)}.activity-green{background:var(--success-bg)}.activity-red{background:var(--danger-bg)}.activity-info{flex:1;min-width:0}.activity-desc{font-size:13px;color:var(--text);line-height:1.4}.activity-time{font-size:11.5px;color:var(--text-muted);margin-top:3px}.card-link-btn{background:none;border:none;color:var(--blue);font-size:12px;font-weight:500;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:var(--transition)}.card-link-btn:hover{background:var(--blue-pale)}.patient-avatar-sm{width:34px;height:34px;border-radius:50%;background:var(--blue-pale);color:var(--blue);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;flex-shrink:0}.overdue-list{display:flex;flex-direction:column;gap:10px}.overdue-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;background:var(--danger-bg);border-radius:var(--radius-md);border:1px solid rgba(239,68,68,.15)}.overdue-info{flex:1;min-width:0}.overdue-desc{font-size:13px;font-weight:500;color:var(--text)}.overdue-date{font-size:11.5px;color:var(--danger);margin-top:2px}.overdue-amount{font-size:14px;font-weight:600;color:var(--danger);white-space:nowrap;font-family:Montserrat,sans-serif}.dashboard-error-banner{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;background:var(--danger-bg);border:1px solid rgba(239,68,68,.25);border-radius:var(--radius-md);color:var(--danger);font-size:13px;margin-bottom:20px}.dashboard-error-banner svg{flex-shrink:0;margin-top:1px}.dashboard-error-banner strong{font-weight:600}@media (max-width: 1024px){.dashboard-grid{grid-template-columns:1fr}.quick-actions{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.dashboard{padding:16px}.quick-actions{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px}.quick-action-btn{padding:12px 10px;gap:8px}.quick-action-icon{width:32px;height:32px}.quick-action-label{font-size:12px}.hearing-item{padding:10px;gap:10px}.hearing-date{width:38px;height:38px}.hearing-day{font-size:14px}.overdue-item{flex-direction:column;align-items:flex-start;gap:8px}.overdue-amount{font-size:13px}}@media (max-width: 640px){.grid-4{grid-template-columns:1fr 1fr!important;gap:12px}.quick-actions{grid-template-columns:repeat(2,1fr);gap:8px}}@media (max-width: 430px){.dashboard{padding:12px}.quick-actions{grid-template-columns:repeat(2,1fr);gap:8px}.quick-action-btn{padding:10px 8px;flex-direction:column;align-items:center;text-align:center;gap:6px}.quick-action-label{font-size:11px}.hearing-title{font-size:12.5px}.activity-desc{font-size:12px}}@media (max-width: 390px){.grid-4{grid-template-columns:1fr!important}.quick-actions{grid-template-columns:1fr 1fr}}.patient-cell{display:flex;align-items:center;gap:10px}.patient-avatar{width:36px;height:36px;border-radius:50%;background:var(--blue-pale);color:var(--blue);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;flex-shrink:0}.patient-detail{display:flex;flex-direction:column;gap:20px}.patient-detail-header{display:flex;align-items:center;gap:16px;padding-bottom:20px;border-bottom:1px solid var(--border)}.patient-detail-avatar{width:56px;height:56px;border-radius:50%;background:var(--blue);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;flex-shrink:0}.patient-detail-name{font-size:18px;font-weight:600;color:var(--text);margin:0}.patient-detail-age{display:inline-flex;align-items:center;padding:2px 8px;background:var(--bg);border:1px solid var(--border);border-radius:20px;font-size:12px;color:var(--text-muted)}.patient-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.patient-detail-field{display:flex;flex-direction:column;gap:3px}.patient-detail-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.patient-detail-value{font-size:13.5px;color:var(--text)}.patient-detail-section{border-top:1px solid var(--border);padding-top:16px}.patient-detail-section-title{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 10px}.patient-detail-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 10px;background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border);margin-bottom:6px;font-size:13px;color:var(--text)}.patient-detail-row:last-child{margin-bottom:0}.action-btn-info{color:var(--blue)!important}.action-btn-info:hover{background:var(--blue-pale)!important}@media (max-width: 768px){.patient-detail-header{flex-wrap:wrap;gap:12px}.patient-detail-name{font-size:16px}.patient-detail-row{flex-wrap:wrap;gap:6px}}@media (max-width: 640px){.patient-detail-grid{grid-template-columns:1fr}}@media (max-width: 430px){.patient-detail-avatar{width:44px;height:44px;font-size:18px}.patient-detail-name{font-size:15px}.patient-avatar{width:30px;height:30px;font-size:12px}}.patient-cell-sm{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text)}.patient-avatar-xs{width:28px;height:28px;border-radius:50%;background:var(--blue-pale);color:var(--blue);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex-shrink:0}.appt-date{font-size:13px;color:var(--text-muted)}.appt-date-today{color:var(--blue);font-weight:600}.row-today{background:var(--blue-pale)!important}.status-select{font-size:12px;padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--text);cursor:pointer;outline:none;transition:var(--transition)}.status-select:hover,.status-select:focus{border-color:var(--blue)}@media (max-width: 768px){.patient-cell-sm{gap:6px;font-size:12.5px}.patient-avatar-xs{width:24px;height:24px;font-size:10px}.status-select{font-size:11px;padding:3px 6px;max-width:90px}.appt-date{font-size:12px}}@media (max-width: 430px){.status-select{max-width:80px;font-size:10.5px}}.treatment-type-tag{display:inline-flex;align-items:center;padding:3px 8px;background:var(--blue-pale);color:var(--blue);border-radius:20px;font-size:11.5px;font-weight:500;white-space:nowrap}.control-badge{display:inline-flex;align-items:center;padding:2px 6px;border-radius:20px;font-size:10.5px;font-weight:600;white-space:nowrap}.control-badge-overdue{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(239,68,68,.2)}.control-badge-today{background:var(--warning-bg);color:var(--warning);border:1px solid rgba(245,158,11,.2)}.control-badge-soon{background:var(--blue-pale);color:var(--blue);border:1px solid rgba(15,118,110,.15)}.action-btn-success{color:var(--success)!important}.action-btn-success:hover{background:var(--success-bg)!important}@media (max-width: 768px){.treatment-type-tag{font-size:10.5px;padding:2px 6px}.control-badge{font-size:9.5px;padding:1px 5px}}@media (max-width: 430px){.treatment-type-tag{font-size:10px;padding:2px 5px}}.cal-upcoming-alert{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;background:#f59e0b14;border:1px solid rgba(245,158,11,.25);border-radius:var(--radius-md);color:#92400e;font-size:13px;margin-bottom:20px;line-height:1.5}.cal-upcoming-alert svg{color:var(--warning);flex-shrink:0;margin-top:1px}.calendar-page{padding:32px}.calendar-layout{display:grid;grid-template-columns:1fr 320px;gap:20px;align-items:start}.calendar-card{padding:24px}.cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.cal-month-title{font-size:17px;font-weight:600;color:var(--text)}.cal-nav-btn{width:34px;height:34px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);color:var(--text-sub);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition)}.cal-nav-btn:hover{background:var(--blue-pale);border-color:var(--blue);color:var(--blue)}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.cal-header-row{margin-bottom:8px}.cal-day-name{text-align:center;font-size:11.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;padding:6px 0}.cal-cell{aspect-ratio:1;border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;transition:var(--transition);position:relative;padding:2px;border:1.5px solid transparent;min-height:44px}.cal-cell:hover{background:var(--bg);border-color:var(--border)}.cal-cell-empty{cursor:default}.cal-cell-empty:hover{background:transparent;border-color:transparent}.cal-day-num{font-size:13.5px;font-weight:400;color:var(--text);line-height:1}.cal-today .cal-day-num{background:var(--blue);color:var(--white);width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600}.cal-selected{background:var(--blue-pale);border-color:var(--blue)!important}.cal-selected .cal-day-num{color:var(--blue);font-weight:600}.cal-today.cal-selected .cal-day-num{background:var(--blue);color:var(--white)}.cal-dots{display:flex;gap:2px;flex-wrap:nowrap}.cal-dot{width:5px;height:5px;border-radius:50%;background:var(--blue);flex-shrink:0}.cal-urgency-label{font-size:9px;font-weight:700;padding:1px 5px;border-radius:20px;letter-spacing:.03em;white-space:nowrap;line-height:1.4}.cal-urgency-today{background:#ef444414}.cal-urgency-tomorrow{background:#f59e0b14}.cal-urgency-soon{background:#1264f30f}.cal-urgency-today .cal-dot{background:var(--danger)}.cal-urgency-tomorrow .cal-dot{background:var(--warning)}.hearing-urgency-badge{display:inline-flex;align-items:center;padding:2px 7px;border-radius:20px;font-size:10.5px;font-weight:600;white-space:nowrap}.hearing-badge-today{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(239,68,68,.2)}.hearing-badge-tomorrow{background:var(--warning-bg);color:var(--warning);border:1px solid rgba(245,158,11,.2)}.hearing-badge-soon{background:var(--blue-pale);color:var(--blue);border:1px solid rgba(18,100,243,.15)}.cal-legend{display:flex;align-items:center;gap:16px;margin-top:16px;padding-top:14px;border-top:1px solid var(--border);flex-wrap:wrap}.cal-legend-item{display:flex;align-items:center;gap:5px;font-size:11.5px;color:var(--text-sub)}.cal-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.calendar-sidebar{display:flex;flex-direction:column;gap:16px}.cal-detail-card{border:1.5px solid var(--blue);background:var(--blue-pale)}.cal-detail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.cal-detail-title{font-size:14px;font-weight:600;color:var(--blue)}.cal-add-btn{display:flex;align-items:center;gap:5px;padding:5px 10px;background:var(--blue);color:var(--white);border:none;border-radius:var(--radius-sm);font-size:12px;font-weight:500;cursor:pointer;transition:var(--transition)}.cal-add-btn:hover{opacity:.88}.cal-no-event-wrap{display:flex;flex-direction:column;align-items:center;gap:10px;padding:12px 0}.cal-no-event{font-size:13px;color:var(--text-muted);text-align:center}.cal-add-first-btn{background:none;border:1px dashed var(--blue);color:var(--blue);border-radius:var(--radius-sm);padding:6px 14px;font-size:12px;cursor:pointer;transition:var(--transition)}.cal-add-first-btn:hover{background:var(--blue);color:var(--white)}.cal-event-list{display:flex;flex-direction:column;gap:10px}.cal-event-item{display:flex;align-items:flex-start;gap:10px}.cal-event-item-clickable{cursor:pointer;padding:8px;border-radius:var(--radius-sm);transition:var(--transition);margin:0 -8px}.cal-event-item-clickable:hover{background:#1264f30f}.cal-event-dot{width:8px;height:8px;border-radius:50%;background:var(--blue);margin-top:4px;flex-shrink:0}.cal-event-title{font-size:13px;font-weight:500;color:var(--text);margin-bottom:2px}.cal-event-time{font-size:11.5px;color:var(--blue);margin-bottom:1px}.cal-event-court{font-size:11.5px;color:var(--text-sub)}.cal-event-no{font-size:11px;color:var(--text-muted)}.cal-event-type-badge{font-size:10.5px;font-weight:600;padding:2px 8px;border-radius:20px;white-space:nowrap;flex-shrink:0}.cal-count{width:22px;height:22px;border-radius:50%;background:var(--blue-pale);color:var(--blue);font-size:11.5px;font-weight:600;display:flex;align-items:center;justify-content:center}.cal-month-list{display:flex;flex-direction:column;gap:8px}.cal-month-item{display:flex;align-items:center;gap:10px;padding:10px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);border:1px solid transparent}.cal-month-item:hover{background:var(--bg);border-color:var(--border)}.cal-month-date{display:flex;flex-direction:column;align-items:center;width:36px;flex-shrink:0}.cal-month-day{font-size:18px;font-weight:700;color:var(--blue);font-family:Montserrat,sans-serif;line-height:1}.cal-month-weekday{font-size:10px;color:var(--text-muted);text-transform:uppercase}.cal-month-info{flex:1;min-width:0}.cal-month-title-text{font-size:12.5px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-month-court{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a16288c;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;animation:calOverlayIn .18s ease}@keyframes calOverlayIn{0%{opacity:0}to{opacity:1}}.cal-modal{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:0 24px 64px #0a162838,0 4px 16px #0a16281a;width:100%;max-width:480px;max-height:90vh;display:flex;flex-direction:column;animation:calModalIn .2s cubic-bezier(.34,1.56,.64,1)}@keyframes calModalIn{0%{opacity:0;transform:scale(.94) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.cal-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.cal-modal-title{font-size:16px;font-weight:600;color:var(--text)}.cal-modal-close{width:30px;height:30px;border-radius:var(--radius-sm);border:none;background:var(--bg);color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition)}.cal-modal-close:hover{background:var(--danger-bg);color:var(--danger)}.cal-modal-body{padding:20px 24px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.cal-modal-footer{display:flex;align-items:center;gap:10px;padding:16px 24px;border-top:1px solid var(--border)}.cal-form-group{display:flex;flex-direction:column;gap:6px}.cal-form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.cal-form-label{font-size:12.5px;font-weight:500;color:var(--text-sub)}.cal-required{color:var(--danger);margin-left:2px}.cal-form-input{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);font-size:13px;color:var(--text);font-family:Poppins,sans-serif;transition:var(--transition);outline:none}.cal-form-input:focus{border-color:var(--blue);background:var(--bg-card);box-shadow:0 0 0 3px #1264f314}.cal-form-textarea{resize:vertical;min-height:72px}.cal-form-error{font-size:12px;color:var(--danger);background:var(--danger-bg);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-sm);padding:8px 12px}.cal-type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.cal-type-btn{display:flex;flex-direction:column;align-items:center;gap:5px;padding:10px 6px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text-sub);font-size:11.5px;font-weight:500;cursor:pointer;transition:var(--transition)}.cal-type-btn:hover{border-color:var(--blue);color:var(--blue)}.cal-type-dot{width:10px;height:10px;border-radius:50%;background:var(--text-muted)}.cal-btn{padding:9px 18px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;transition:var(--transition);border:none;font-family:Poppins,sans-serif}.cal-btn:disabled{opacity:.6;cursor:not-allowed}.cal-btn-primary{background:var(--blue);color:var(--white)}.cal-btn-primary:hover:not(:disabled){opacity:.88}.cal-btn-ghost{background:var(--bg);color:var(--text-sub);border:1px solid var(--border)}.cal-btn-ghost:hover:not(:disabled){background:var(--border)}.cal-btn-danger{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(239,68,68,.2)}.cal-btn-danger:hover:not(:disabled){background:var(--danger);color:var(--white)}@media (max-width: 1024px){.calendar-layout{grid-template-columns:1fr}}@media (max-width: 768px){.calendar-page{padding:16px}.calendar-card{padding:14px}.cal-cell{padding:2px 1px;gap:2px;min-height:40px}.cal-day-num{font-size:12px}.cal-today .cal-day-num{width:24px;height:24px;font-size:12px}.cal-urgency-label{display:none}.cal-dots{gap:2px}.cal-dot{width:4px;height:4px}.cal-legend{gap:10px;overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px}.cal-legend-item{white-space:nowrap;font-size:11px;flex-shrink:0}.cal-month-item{padding:8px;gap:8px}.cal-month-day{font-size:15px}.cal-month-title-text{font-size:12px}.cal-detail-header{flex-wrap:wrap;gap:8px}.cal-modal-overlay{padding:0;align-items:flex-end}.cal-modal{max-width:100%;border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:92vh}@keyframes calModalIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.cal-type-grid{grid-template-columns:repeat(2,1fr)}.cal-form-row{grid-template-columns:1fr}.cal-modal-header{padding:16px 20px 12px}.cal-modal-body{padding:16px 20px;gap:14px}.cal-modal-footer{padding:12px 20px}.cal-upcoming-alert{font-size:12px;padding:10px 12px}}@media (max-width: 480px){.calendar-page,.calendar-card{padding:10px}.cal-grid{gap:2px}.cal-cell{min-height:36px}.cal-day-name{font-size:10px;padding:4px 0;letter-spacing:0}.cal-day-num{font-size:11px}.cal-today .cal-day-num{width:22px;height:22px;font-size:11px}.cal-dot{width:3px;height:3px}.cal-dots{gap:1px}.cal-nav-btn{width:30px;height:30px}.cal-month-title{font-size:15px}.hearing-urgency-badge{display:none}.cal-event-type-badge{font-size:9.5px;padding:1px 6px}.cal-modal-footer{flex-wrap:wrap;gap:8px}.cal-btn{padding:8px 14px;font-size:12.5px}.cal-month-item .cal-event-type-badge{display:none}}.payment-amount{font-size:14px;font-weight:600;color:var(--text);font-family:Montserrat,sans-serif}.action-btn-success:hover{background:var(--success-bg);color:var(--success)}@media (max-width: 768px){.payment-amount{font-size:13px}}@media (max-width: 430px){.payment-amount{font-size:12.5px}}.settings-page{padding:32px}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}.settings-connected-badge{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:var(--success);background:var(--success-bg);padding:4px 10px;border-radius:20px}.settings-dot{width:6px;height:6px;border-radius:50%;background:var(--success);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.settings-security-notice{display:flex;align-items:flex-start;gap:10px;padding:14px 16px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);font-size:13px;color:var(--text-sub);line-height:1.55;margin-bottom:20px}.settings-security-notice svg{flex-shrink:0;margin-top:2px;color:var(--text-muted)}.settings-security-main{margin:0 0 6px;color:var(--text-sub);font-size:13px;line-height:1.5}.settings-tech-toggle{display:inline-flex;align-items:center;gap:4px;background:none;border:none;padding:0;font-size:12px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:color .15s}.settings-tech-toggle:hover{color:var(--text)}.settings-tech-detail{margin:8px 0 0;font-size:12px;color:var(--text-muted);line-height:1.6;padding:10px 12px;background:var(--bg-card);border-radius:var(--radius-sm);border:1px solid var(--border)}.settings-tech-detail code{font-family:Courier New,monospace;font-size:11px;background:var(--bg);padding:1px 5px;border-radius:3px;border:1px solid var(--border);color:var(--blue)}.settings-conn-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px;background:var(--bg);border-radius:var(--radius-md);border:1px solid var(--border)}.settings-conn-info{display:flex;flex-direction:column;gap:4px}.settings-conn-status{display:flex;align-items:center;gap:8px}.settings-conn-dot{width:8px;height:8px;border-radius:50%;background:var(--success);flex-shrink:0}.settings-conn-label{font-size:13.5px;font-weight:500;color:var(--text)}.settings-conn-sub{font-size:12px;color:var(--text-muted);margin:0;padding-left:16px}.settings-desc{font-size:13.5px;color:var(--text-sub);line-height:1.6;margin-bottom:20px}.settings-backup-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}.settings-backup-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg);border-radius:var(--radius-md);border:1px solid var(--border);transition:border-color .15s}.settings-backup-item:hover{border-color:var(--blue)}.settings-backup-icon{font-size:15px;flex-shrink:0}.settings-backup-label{flex:1;font-size:13px;color:var(--text);font-weight:400}.settings-backup-status{font-size:12px;color:var(--success);font-weight:600}.settings-backup-note{font-size:11.5px;color:var(--text-muted);line-height:1.5;padding:10px 14px;background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border);margin:0}.settings-demo-info-card{display:flex;align-items:flex-start;gap:16px;grid-column:1 / -1;background:linear-gradient(135deg,#eff6ff,#f0fdf4);border:1px solid rgba(18,100,243,.12)}.settings-demo-info-icon{font-size:24px;flex-shrink:0;margin-top:2px}.settings-demo-info-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}.settings-demo-info-desc{font-size:13px;color:var(--text-sub);line-height:1.55}.settings-status-list{display:flex;flex-direction:column;gap:0;margin-bottom:24px;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.settings-status-item{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border-bottom:1px solid var(--border);background:var(--bg-card);transition:background .15s}.settings-status-item:last-child{border-bottom:none}.settings-status-item:hover{background:var(--bg)}.settings-status-left{display:flex;align-items:center;gap:10px}.settings-status-indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-ok{background:var(--success)}.status-warn{background:var(--warning)}.status-err{background:var(--danger)}.settings-status-label{font-size:13.5px;color:var(--text)}.settings-status-value{font-size:12.5px;color:var(--text-muted);font-weight:500}.status-ok-text{color:var(--success)!important}.status-warn-text{color:var(--warning)!important}.settings-about-footer{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--bg);border-radius:var(--radius-md);border:1px solid var(--border)}.settings-about-logo{height:28px;width:auto;opacity:.7;flex-shrink:0}.settings-about-name{font-size:13.5px;font-weight:600;color:var(--text);margin:0 0 2px}.settings-about-version{font-size:11.5px;color:var(--text-muted);margin:0}.settings-demo-note{font-size:12px;color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;margin-bottom:12px;text-align:center}.conn-modal-body{display:flex;flex-direction:column;gap:20px}.conn-modal-info{display:flex;flex-direction:column;gap:0;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.conn-modal-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--bg-card)}.conn-modal-row:last-child{border-bottom:none}.conn-modal-label{font-size:12px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.conn-modal-value{font-size:13px;color:var(--text);font-weight:500}.conn-mono{font-family:Courier New,monospace;font-size:12px;color:var(--text-sub)}.conn-modal-actions{display:flex;flex-direction:column;gap:8px}.conn-action-btn{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;color:var(--text-sub);width:100%}.conn-action-btn:hover{background:var(--bg)}.conn-action-danger{color:var(--danger);border-color:#ef444433}.conn-action-danger:hover{background:var(--danger-bg);border-color:#ef444459}.settings-branding-card{grid-column:1 / -1}.settings-branding-row{display:flex;align-items:center;gap:20px;padding:16px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:12px}.settings-branding-preview{width:72px;height:72px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.settings-branding-preview--favicon{width:48px;height:48px;border-radius:8px}.settings-branding-img{max-width:100%;max-height:100%;object-fit:contain}.settings-branding-favicon{width:28px;height:28px;object-fit:contain}.settings-branding-info{flex:1;display:flex;flex-direction:column;gap:4px}.settings-branding-label{font-size:13.5px;font-weight:600;color:var(--text);margin:0}.settings-branding-hint{font-size:12px;color:var(--text-muted);margin:0}.settings-branding-actions{display:flex;align-items:center;gap:8px;margin-top:6px}.settings-branding-upload-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--text-sub);font-size:12.5px;font-weight:500;cursor:pointer;transition:all .15s}.settings-branding-upload-btn:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-pale)}.settings-branding-reset-btn{padding:6px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-size:12px;cursor:pointer;transition:all .15s}.settings-branding-reset-btn:hover{border-color:var(--danger);color:var(--danger);background:var(--danger-bg)}.settings-branding-color-row{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:16px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:12px}.settings-branding-color-wrap{display:flex;align-items:center;gap:10px;flex-shrink:0}.settings-color-input{width:40px;height:40px;border:2px solid var(--border);border-radius:var(--radius-sm);padding:2px;cursor:pointer;background:none;flex-shrink:0}.settings-color-input::-webkit-color-swatch-wrapper{padding:0;border-radius:6px}.settings-color-input::-webkit-color-swatch{border:none;border-radius:6px}.settings-color-value{font-size:12px;font-family:Courier New,monospace;color:var(--text-sub);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 10px;min-width:80px;text-align:center}@media (max-width: 900px){.settings-grid{grid-template-columns:1fr}.settings-backup-grid{grid-template-columns:1fr 1fr}}@media (max-width: 768px){.settings-page{padding:16px}.settings-branding-row{flex-wrap:wrap;gap:14px}.settings-branding-color-row{flex-direction:column;align-items:flex-start;gap:12px}.settings-branding-color-wrap{width:100%;justify-content:flex-start}.settings-status-item{flex-direction:column;align-items:flex-start;gap:4px;padding:12px 14px}.settings-status-value{padding-left:18px}}@media (max-width: 480px){.settings-page{padding:12px}.settings-backup-grid{grid-template-columns:1fr}.settings-conn-row{flex-direction:column;align-items:flex-start}.settings-branding-preview{width:56px;height:56px}.settings-branding-actions{flex-wrap:wrap}}@media (max-width: 430px){.settings-page{padding:10px}.settings-branding-row,.settings-branding-color-row{padding:12px}.settings-color-value{min-width:70px;font-size:11px}}@media (max-width: 390px){.settings-backup-grid{grid-template-columns:1fr}.settings-branding-upload-btn,.settings-branding-reset-btn{font-size:11.5px;padding:5px 10px}}
