@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@500;600;700&display=swap";html,body,#root{color:#1a1d2e!important;background-color:#f5f6fa!important}:root{--bg:#f5f6fa;--bg-card:#fff;--bg-card-hover:#f8f9fc;--bg-elevated:#f0f1f5;--border:#e2e5f0;--border-light:#eceef5;--text:#1a1d2e;--text-secondary:#5c6078;--text-muted:#9196ab;--accent:#4f46e5;--accent-soft:#4f46e514;--accent-hover:#6366f1;--green:#10b981;--green-soft:#10b98114;--amber:#f59e0b;--amber-soft:#f59e0b14;--red:#ef4444;--red-soft:#ef444414;--blue:#3b82f6;--blue-soft:#3b82f614;--font:"Inter", -apple-system, sans-serif;--font-display:"Outfit", sans-serif;--radius:12px;--radius-sm:8px;--shadow-sm:0 1px 2px #0000000a;--shadow:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 12px #0000000f;--shadow-lg:0 10px 40px #00000014}*{box-sizing:border-box;margin:0;padding:0}body,#root{font-family:var(--font);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;background:var(--bg)!important}.auth-page{background:linear-gradient(135deg,#f5f6fa 0%,#e8eaff 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-container{width:100%;max-width:420px}.auth-brand{text-align:center;margin-bottom:36px}.auth-brand h1{font-family:var(--font-display);color:var(--text);justify-content:center;align-items:center;gap:12px;font-size:32px;font-weight:700;display:flex}.auth-brand h1 svg{width:36px;height:36px;color:var(--accent)}.auth-brand p{color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;margin-top:6px;font-size:12px;font-weight:500}.auth-card{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-lg);border-radius:16px;padding:36px}.auth-card h2{font-family:var(--font-display);text-align:center;color:var(--text);margin-bottom:4px;font-size:22px;font-weight:700}.auth-card .subtitle{color:var(--text-muted);text-align:center;margin-bottom:28px;font-size:14px}.auth-error{background:var(--red-soft);color:var(--red);border-radius:var(--radius-sm);border:1px solid #ef444426;margin-bottom:16px;padding:12px 16px;font-size:13px}.auth-success{background:var(--green-soft);color:var(--green);border-radius:var(--radius-sm);border:1px solid #10b98126;margin-bottom:16px;padding:12px 16px;font-size:13px}.auth-switch{text-align:center;color:var(--text-secondary);margin-top:20px;font-size:13px}.auth-switch button{color:var(--accent);cursor:pointer;font-family:var(--font);background:0 0;border:none;font-size:13px;font-weight:600}.auth-switch button:hover{color:var(--accent-hover)}.setup-options{flex-direction:column;gap:12px;margin-bottom:20px;display:flex}.setup-option{background:var(--bg);border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;font-family:var(--font);color:var(--text);padding:22px;transition:all .2s}.setup-option:hover{border-color:var(--accent);background:var(--accent-soft);box-shadow:var(--shadow-md);transform:translateY(-1px)}.setup-option h3{align-items:center;gap:10px;margin-bottom:4px;font-size:15px;font-weight:600;display:flex}.setup-option h3 svg{width:20px;height:20px;color:var(--accent)}.setup-option p{color:var(--text-secondary);font-size:13px}.or-divider{color:var(--text-muted);align-items:center;gap:16px;margin:20px 0;font-size:12px;display:flex}.or-divider:before,.or-divider:after{content:"";background:var(--border);flex:1;height:1px}.invite-code-box{background:var(--accent-soft);border:2px dashed var(--accent);border-radius:var(--radius);text-align:center;margin:16px 0;padding:24px}.invite-code-box .code{letter-spacing:6px;color:var(--accent);margin:10px 0;font-family:Courier New,monospace;font-size:32px;font-weight:700}.invite-code-box .label{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;font-size:11px;font-weight:600}.copy-btn{background:var(--accent);border-radius:var(--radius-sm);color:#fff;font-family:var(--font);cursor:pointer;border:none;align-items:center;gap:6px;margin-top:10px;padding:8px 16px;font-size:12px;font-weight:600;transition:all .15s;display:inline-flex}.copy-btn:hover{background:var(--accent-hover)}.copy-btn svg{width:14px;height:14px}.app{min-height:100vh;display:flex}.sidebar{background:var(--bg-card);border-right:1px solid var(--border);flex-direction:column;width:260px;min-width:260px;display:flex}.sidebar-brand{border-bottom:1px solid var(--border);padding:28px 24px 24px}.sidebar-brand h1{font-family:var(--font-display);color:var(--text);align-items:center;gap:10px;font-size:22px;font-weight:700;display:flex}.sidebar-brand h1 .brand-icon{width:30px;height:30px;color:var(--accent)}.sidebar-brand p{color:var(--text-muted);letter-spacing:1px;text-transform:uppercase;margin-top:3px;font-size:10px;font-weight:600}.sidebar-brand .firm-name{color:var(--accent);margin-top:4px;font-size:12px;font-weight:600}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:16px 12px;display:flex}.nav-item{border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:10px 14px;font-size:14px;font-weight:500;transition:all .15s;display:flex}.nav-item:hover{background:var(--bg);color:var(--text)}.nav-item.active{background:var(--accent-soft);color:var(--accent);font-weight:600}.nav-item svg{flex-shrink:0;width:19px;height:19px}.nav-badge{background:var(--accent-soft);color:var(--accent);border-radius:10px;margin-left:auto;padding:2px 9px;font-size:11px;font-weight:700}.sidebar-footer{border-top:1px solid var(--border);padding:16px 12px}.sidebar-footer .user-email{color:var(--text-muted);text-overflow:ellipsis;margin-bottom:4px;padding:0 14px;font-size:12px;overflow:hidden}.sidebar-footer .user-role{color:var(--accent);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;padding:0 14px;font-size:10px;font-weight:700}.main{background:var(--bg);flex-direction:column;flex:1;min-width:0;display:flex;overflow-y:auto}.topbar{border-bottom:1px solid var(--border);background:var(--bg-card);z-index:10;box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;gap:16px;padding:18px 32px;display:flex;position:sticky;top:0}.topbar h2{font-family:var(--font-display);color:var(--text);font-size:22px;font-weight:700}.search-box{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:8px;width:240px;padding:9px 14px;transition:border-color .15s;display:flex}.search-box:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.search-box svg{width:16px;height:16px;color:var(--text-muted)}.search-box input{color:var(--text);font-family:var(--font);background:0 0;border:none;outline:none;width:100%;font-size:13px}.search-box input::placeholder{color:var(--text-muted)}.lang-switcher{position:relative}.lang-btn{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font);color:var(--text);align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.lang-btn:hover{border-color:var(--accent)}.lang-btn .flag{font-size:16px}.lang-dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:50;min-width:170px;margin-top:6px;position:absolute;top:100%;right:0;overflow:hidden}.lang-option{cursor:pointer;color:var(--text-secondary);text-align:left;width:100%;font-size:13px;font-family:var(--font);background:0 0;border:none;align-items:center;gap:10px;padding:10px 16px;font-weight:500;transition:all .1s;display:flex}.lang-option:hover{background:var(--bg);color:var(--text)}.lang-option.active{background:var(--accent-soft);color:var(--accent);font-weight:600}.lang-option .flag{font-size:16px}.content{flex:1;padding:28px 32px}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:22px;transition:all .2s}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-card .label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px;font-size:11px;font-weight:600}.stat-card .value{font-size:30px;font-weight:700;font-family:var(--font-display);color:var(--text)}.stat-card .sub{color:var(--text-secondary);margin-top:6px;font-size:12px;font-weight:500}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.card-header h3{color:var(--text);font-size:15px;font-weight:600}.card-body{padding:0}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}thead th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;text-align:left;border-bottom:1px solid var(--border);background:var(--bg);padding:12px 18px;font-size:11px;font-weight:700}tbody td{border-bottom:1px solid var(--border-light);vertical-align:middle;color:var(--text);padding:14px 18px;font-size:13.5px}tbody tr{transition:background .1s}tbody tr:hover{background:var(--bg-card-hover)}tbody tr:last-child td{border-bottom:none}.badge{border-radius:20px;align-items:center;padding:4px 12px;font-size:11px;font-weight:600;display:inline-flex}.badge-green{background:var(--green-soft);color:var(--green);border:1px solid #10b98126}.badge-amber{background:var(--amber-soft);color:var(--amber);border:1px solid #f59e0b26}.badge-red{background:var(--red-soft);color:var(--red);border:1px solid #ef444426}.badge-blue{background:var(--blue-soft);color:var(--blue);border:1px solid #3b82f626}.badge-purple{background:var(--accent-soft);color:var(--accent);border:1px solid #4f46e526}.btn{border-radius:var(--radius-sm);font-family:var(--font);cursor:pointer;border:1px solid var(--border);background:var(--bg-card);color:var(--text);box-shadow:var(--shadow-sm);align-items:center;gap:6px;padding:9px 18px;font-size:13px;font-weight:600;transition:all .15s;display:inline-flex}.btn:hover{background:var(--bg)}.btn svg{width:15px;height:15px}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 1px 3px #4f46e54d}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #4f46e540}.btn-sm{padding:6px 12px;font-size:12px}.btn-icon{cursor:pointer;color:var(--text-muted);border-radius:var(--radius-sm);background:0 0;border:none;align-items:center;padding:7px;transition:all .15s;display:flex}.btn-icon:hover{color:var(--text);background:var(--bg)}.btn-icon svg{width:16px;height:16px}.btn-danger{color:var(--red)}.btn-danger:hover{background:var(--red-soft);color:var(--red)}.btn-full{justify-content:center;width:100%;padding:12px;font-size:14px}.btn-danger-solid{background:var(--red);border-color:var(--red);color:#fff}.btn-danger-solid:hover{background:#dc2626}.actions-cell{gap:2px;display:flex}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0000004d;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border);width:100%;max-width:540px;max-height:85vh;box-shadow:var(--shadow-lg);border-radius:16px;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:22px 26px;display:flex}.modal-header h3{font-size:17px;font-weight:700;font-family:var(--font-display)}.modal-body{padding:26px}.modal-footer{border-top:1px solid var(--border);background:var(--bg);justify-content:flex-end;gap:10px;padding:18px 26px;display:flex}.confirm-overlay{z-index:150;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0000004d;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.confirm-box{background:var(--bg-card);border:1px solid var(--border);text-align:center;width:100%;max-width:400px;box-shadow:var(--shadow-lg);border-radius:16px;padding:32px}.confirm-box h3{margin-bottom:8px;font-size:17px;font-weight:700}.confirm-box p{color:var(--text-secondary);margin-bottom:24px;font-size:14px}.confirm-actions{justify-content:center;gap:10px;display:flex}.toast-container{z-index:200;flex-direction:column;gap:8px;display:flex;position:fixed;top:20px;right:20px}.toast{border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);max-width:360px;padding:14px 22px;font-size:13px;font-weight:600;animation:.3s slideIn}.toast-success{background:var(--green);color:#fff}.toast-error{background:var(--red);color:#fff}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.form-group{margin-bottom:20px}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px;margin-bottom:7px;font-size:12px;font-weight:700;display:block}.form-group input,.form-group select,.form-group textarea{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);font-family:var(--font);outline:none;padding:11px 14px;font-size:14px;transition:all .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.form-group textarea{resize:vertical;min-height:80px}.form-group select{cursor:pointer}.form-row,.dash-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.upcoming-item{border-bottom:1px solid var(--border-light);align-items:flex-start;gap:14px;padding:16px 22px;display:flex}.upcoming-item:last-child{border-bottom:none}.upcoming-date{background:var(--accent-soft);border-radius:var(--radius-sm);text-align:center;min-width:52px;padding:8px 12px}.upcoming-date .day{color:var(--accent);font-size:20px;font-weight:700;line-height:1.2}.upcoming-date .month{color:var(--accent);text-transform:uppercase;font-size:10px;font-weight:700}.upcoming-info h4{color:var(--text);font-size:14px;font-weight:600}.upcoming-info p{color:var(--text-secondary);margin-top:3px;font-size:12px}.task-item{border-bottom:1px solid var(--border-light);align-items:center;gap:12px;padding:14px 22px;display:flex}.task-item:last-child{border-bottom:none}.task-checkbox{border:2px solid var(--border);cursor:pointer;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;transition:all .15s;display:flex}.task-checkbox:hover{border-color:var(--accent)}.task-checkbox.done{background:var(--green);border-color:var(--green)}.task-checkbox.done:after{content:"✓";color:#fff;font-size:12px;font-weight:700}.task-info{flex:1;min-width:0}.task-info h4{color:var(--text);font-size:13.5px;font-weight:500}.task-info p{color:var(--text-secondary);margin-top:2px;font-size:12px}.cal-header{align-items:center;gap:16px;margin-bottom:20px;display:flex}.cal-header h3{font-family:var(--font-display);min-width:200px;color:var(--text);font-size:20px;font-weight:700}.cal-grid{background:var(--border);border:1px solid var(--border);border-radius:var(--radius);grid-template-columns:repeat(7,1fr);gap:1px;display:grid;overflow:hidden}.cal-day-header{background:var(--bg);text-align:center;color:var(--text-muted);text-transform:uppercase;padding:12px;font-size:11px;font-weight:700}.cal-cell{background:var(--bg-card);min-height:110px;padding:8px}.cal-cell.other-month{background:var(--bg-card-hover)}.cal-cell.today{background:var(--accent-soft)}.cal-cell .day-num{color:var(--text-secondary);margin-bottom:4px;font-size:13px;font-weight:600}.cal-cell.today .day-num{color:var(--accent);font-weight:700}.cal-event{cursor:default;white-space:nowrap;text-overflow:ellipsis;border-radius:5px;margin-bottom:3px;padding:3px 7px;font-size:10.5px;font-weight:600;overflow:hidden}.cal-event.Court{background:var(--red-soft);color:var(--red)}.cal-event.Meeting{background:var(--blue-soft);color:var(--blue)}.cal-event.Deadline{background:var(--amber-soft);color:var(--amber)}.cal-event.Deposition{background:var(--accent-soft);color:var(--accent)}.empty-state{text-align:center;color:var(--text-muted);padding:48px;font-size:14px;font-weight:500}.priority-dot{border-radius:50%;width:8px;height:8px;margin-right:6px;display:inline-block}.priority-dot.High{background:var(--red)}.priority-dot.Medium{background:var(--amber)}.priority-dot.Low{background:var(--green)}.case-detail-header{justify-content:space-between;align-items:flex-start;margin-bottom:24px;display:flex}.case-detail-header .back-btn{color:var(--text-secondary);cursor:pointer;font-family:var(--font);background:0 0;border:none;align-items:center;gap:6px;margin-bottom:12px;padding:6px 0;font-size:13px;font-weight:600;display:flex}.case-detail-header .back-btn:hover{color:var(--accent)}.case-detail-header .back-btn svg{width:18px;height:18px}.case-detail-title h2{font-family:var(--font-display);margin-bottom:6px;font-size:24px;font-weight:700}.case-detail-title .case-meta{color:var(--text-secondary);flex-wrap:wrap;gap:16px;font-size:13px;font-weight:500;display:flex}.tabs{border-bottom:2px solid var(--border);gap:0;margin-bottom:24px;display:flex}.tab{color:var(--text-muted);cursor:pointer;font-size:14px;font-weight:600;font-family:var(--font);background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:8px;margin-bottom:-2px;padding:14px 22px;transition:all .15s;display:flex}.tab svg{width:16px;height:16px}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius);text-align:center;cursor:pointer;background:var(--bg-card);padding:48px;transition:all .2s}.drop-zone:hover,.drop-zone.dragging{border-color:var(--accent);background:var(--accent-soft)}.drop-zone svg{width:40px;height:40px;color:var(--text-muted);margin-bottom:14px}.drop-zone p{color:var(--text-secondary);margin-bottom:4px;font-size:15px;font-weight:500}.drop-zone .hint{color:var(--text-muted);font-size:12px}.doc-item{border-bottom:1px solid var(--border-light);align-items:center;gap:14px;padding:16px 22px;transition:background .1s;display:flex}.doc-item:hover{background:var(--bg-card-hover)}.doc-item:last-child{border-bottom:none}.doc-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex}.doc-icon svg{width:20px;height:20px}.doc-icon.pdf{background:var(--red-soft);color:var(--red)}.doc-icon.doc{background:var(--blue-soft);color:var(--blue)}.doc-icon.img{background:var(--green-soft);color:var(--green)}.doc-icon.other{background:var(--accent-soft);color:var(--accent)}.doc-info{flex:1;min-width:0}.doc-info h4{white-space:nowrap;text-overflow:ellipsis;color:var(--text);font-size:14px;font-weight:600;overflow:hidden}.doc-info p{color:var(--text-muted);margin-top:2px;font-size:12px}.note-input-area{margin-bottom:24px}.note-input-area textarea{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);font-family:var(--font);resize:vertical;min-height:90px;box-shadow:var(--shadow-sm);outline:none;padding:14px 18px;font-size:14px;transition:all .15s}.note-input-area textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.note-input-actions{justify-content:space-between;align-items:center;margin-top:10px;display:flex}.note-input-actions .privacy-toggle{color:var(--text-muted);cursor:pointer;align-items:center;gap:6px;font-size:13px;font-weight:500;display:flex}.note-input-actions .privacy-toggle svg{width:14px;height:14px}.note-item{border-bottom:1px solid var(--border-light);gap:14px;padding:18px 0;display:flex}.note-item:last-child{border-bottom:none}.note-avatar{background:var(--accent-soft);width:34px;height:34px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;font-size:13px;font-weight:700;display:flex}.note-content{flex:1}.note-header{align-items:center;gap:8px;margin-bottom:6px;display:flex}.note-header .author{color:var(--text);font-size:13px;font-weight:600}.note-header .time{color:var(--text-muted);font-size:12px}.note-header .private-badge{color:var(--amber);align-items:center;gap:3px;font-size:11px;font-weight:600;display:flex}.note-header .private-badge svg{width:12px;height:12px}.note-text{color:var(--text-secondary);white-space:pre-wrap;font-size:14px;line-height:1.6}.note-type-badge{border-radius:10px;margin-bottom:6px;padding:3px 10px;font-size:10px;font-weight:700;display:inline-block}.note-type-badge.activity{background:var(--blue-soft);color:var(--blue)}.note-type-badge.note{background:var(--accent-soft);color:var(--accent)}.member-card{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:16px 22px;display:flex}.member-card:last-child{border-bottom:none}.member-info{align-items:center;gap:14px;display:flex}.member-avatar{background:var(--accent-soft);width:40px;height:40px;color:var(--accent);border-radius:50%;justify-content:center;align-items:center;font-size:16px;font-weight:700;display:flex}.member-details h4{color:var(--text);font-size:14px;font-weight:600}.member-details p{color:var(--text-muted);margin-top:2px;font-size:12px}.loading-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=900px){.sidebar{width:68px;min-width:68px}.sidebar-brand h1 span,.sidebar-brand p,.sidebar-brand .firm-name,.nav-item span,.nav-badge,.sidebar-footer .user-email,.sidebar-footer .user-role{display:none}.sidebar-brand{padding:20px 12px}.sidebar-brand h1{justify-content:center}.nav-item{justify-content:center;padding:12px}.stats-grid{grid-template-columns:repeat(2,1fr)}.dash-grid{grid-template-columns:1fr}.topbar{padding:16px 20px}.content{padding:20px}.search-box{width:180px}}
