:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Helvetica Neue,Arial,sans-serif;line-height:1.5;font-weight:400;--bg-app: #f9fafb;--bg-surface: #ffffff;--border-subtle: #e5e7eb;--text-primary: #111827;--text-secondary: #6b7280;--accent: #2563eb;--accent-soft: rgba(37, 99, 235, .08);color-scheme:light;color:var(--text-primary);background-color:var(--bg-app)}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background-color:var(--bg-app)}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600}p{margin:0;color:var(--text-secondary)}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;font-size:14px;border-radius:6px;border:1px solid transparent;cursor:pointer;background:#fff}button:hover{background:#f3f4f6}.sidebar{width:260px;background:var(--bg-surface);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;padding:16px 14px;transition:transform .25s ease,box-shadow .25s ease}.sidebar--hidden{transform:translate(-100%);box-shadow:none}.sidebar__brand{display:flex;gap:10px;padding-bottom:14px;border-bottom:1px solid var(--border-subtle)}.sidebar__nav{flex:1;margin-top:14px}.sidebar__link{display:block;padding:8px 10px;border-radius:6px;font-size:14px}.sidebar__link:hover{background:#f3f4f6}.sidebar__link--active{background:var(--accent-soft);color:var(--accent);font-weight:600;position:relative}.sidebar__link--active:before{content:"";position:absolute;left:-6px;top:8px;bottom:8px;width:3px;background:var(--accent)}.sidebar__role{margin-top:4px;padding:2px 6px;font-size:10px;border-radius:999px;font-weight:600;background:var(--accent-soft);color:var(--accent)}.app-shell{display:flex;height:100%}.app-main{flex:1;display:flex;flex-direction:column;min-width:0}.app-header{height:56px;background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center}.app-header-inner{width:100%;padding:0 24px;display:flex;justify-content:space-between;align-items:center}.app-header-title{font-weight:700}.app-header-subtitle{font-size:11px;color:var(--text-secondary)}.breadcrumbs{display:flex;gap:6px;font-size:11px;color:var(--text-secondary)}.breadcrumbs span:after{content:"/";margin-left:6px}.breadcrumbs span:last-child{color:var(--text-primary);font-weight:600}.breadcrumbs span:last-child:after{content:""}.app-header-actions{display:flex;gap:8px}.app-header-actions button.primary{background:var(--accent);color:#fff}.app-content{flex:1;padding:24px;overflow-y:auto;position:relative;isolation:isolate}.app-content:before{content:"";position:absolute;inset:0;background-image:url(/laws-logo.jpeg);background-repeat:no-repeat;background-position:center;background-size:320px auto;opacity:.05;pointer-events:none;z-index:0}.app-content>*{position:relative;z-index:1}.chat-layout{display:flex;height:100%}.chat-layout__chat{flex:1;border-right:1px solid var(--border-subtle)}.chat-layout__context{width:420px;background:#fafafa}.status-pill{font-size:11px;padding:2px 8px;border-radius:999px;font-weight:600}.status-open{background:#22c55e26;color:#15803d}.status-closed{background:#6b728033;color:#374151}.admin-shell .app-header{background:#f8fafc}.admin-shell .sidebar__link--active{background:#0f172a14;color:#0f172a}.admin-shell .sidebar__link--active:before{background:#0f172a}@media(max-width:1024px){.sidebar{position:fixed;top:0;bottom:0;z-index:40;box-shadow:4px 0 12px #00000014}.chat-layout__context{display:none}}@media(max-width:640px){.app-header-inner{padding:0 16px}.breadcrumbs{display:none}.app-content{padding:16px}.app-content:before{background-size:220px auto;opacity:.04}}.ticket-panel{display:flex;flex-direction:column;height:100%;padding:12px;background:var(--color-surface, #ffffff);border-left:1px solid var(--color-border, #e5e7eb)}.ticket-panel-title{font-size:13px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--color-muted, #6b7280);margin-bottom:10px}.ticket-list{flex:1;overflow-y:auto;padding-right:4px}.ticket-list-item{padding:10px 12px;border-radius:8px;cursor:pointer;margin-bottom:6px;background:transparent;border:1px solid transparent;transition:background .15s ease,border-color .15s ease}.ticket-list-item:hover{background:var(--color-hover, #f9fafb);border-color:var(--color-border, #e5e7eb)}.ticket-list-item.active{background:var(--color-primary-soft, #eef2ff);border-color:var(--color-primary, #2563eb)}.ticket-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.ticket-row strong{font-size:14px;font-weight:600;color:var(--color-text, #111827);line-height:1.2}.ticket-meta{display:flex;justify-content:space-between;margin-top:4px;font-size:11px;color:var(--color-muted, #6b7280)}.status-pill{font-size:11px;padding:2px 8px;border-radius:999px;font-weight:600;text-transform:capitalize}.status-pill.open{background:#ecfeff;color:#0369a1}.status-pill.resolved,.status-pill.closed{background:#ecfdf5;color:#047857}.status-pill.awaiting{background:#fff7ed;color:#c2410c}.ticket-panel .muted{font-size:13px;color:var(--color-muted, #6b7280);padding:12px 4px}.ticket-search{padding:8px 10px;border-radius:6px;border:1px solid var(--color-border);font-size:13px;margin-bottom:10px}.ticket-group-label{font-size:11px;font-weight:700;color:var(--color-muted);text-transform:uppercase;margin:12px 0 6px}.ticket-preview{font-size:12px;color:var(--color-muted);margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ticket-list-item.disabled{opacity:.6;cursor:not-allowed}.ticket-skeleton{height:56px;border-radius:8px;background:linear-gradient(90deg,#f3f4f6 25%,#e5e7eb 37%,#f3f4f6 63%);background-size:400% 100%;animation:shimmer 1.4s ease infinite;margin-bottom:8px}@keyframes shimmer{0%{background-position:100% 0}to{background-position:0 0}}.sidebar__divider{height:1px;background:#ffffff1a;margin:14px 0}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:20px}.card{background:#fff;padding:20px;border-radius:10px;box-shadow:0 2px 6px #0000000d;margin-top:20px}.stat p{font-size:24px;font-weight:700}.analytics-table{width:100%;border-collapse:collapse}.analytics-table th,.analytics-table td{padding:10px;border-bottom:1px solid #eee}.citation-link{color:#1e40af;cursor:pointer;font-weight:600}.citation-link:hover{text-decoration:underline}.citation-box{border:1px solid #e5e7eb;padding:10px;margin-top:8px;border-radius:8px;background:#f9fafb}.citation-focus{animation:pulseHighlight 1.5s ease-in-out}@keyframes pulseHighlight{0%{background-color:#fff7ed}50%{background-color:#fde68a}to{background-color:#f9fafb}}mark{background-color:#fde047;padding:2px 4px;border-radius:4px}:root{--accent-strong: #1d4ed8;--danger: #dc2626;--shadow-soft: 0 18px 48px rgba(15, 23, 42, .08)}button,input,textarea,select{font:inherit}input,textarea,select{width:100%;border:1px solid var(--border-subtle);border-radius:10px;background:#fff;color:var(--text-primary);padding:12px 14px}input:focus,textarea:focus,select:focus{outline:none;border-color:#2563eb99;box-shadow:0 0 0 4px #2563eb1f}button{transition:background .2s ease,border-color .2s ease,transform .2s ease}.auth-page{min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(circle at top left,rgba(37,99,235,.08),transparent 34%),linear-gradient(180deg,#f8fbff,#f5f7fb)}.auth-card{width:100%;max-width:460px;background:#fffffff5;border:1px solid rgba(229,231,235,.9);border-radius:24px;box-shadow:var(--shadow-soft);padding:32px 24px;text-align:left}.auth-card--compact{max-width:420px}.auth-card__eyebrow{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}.auth-card__title{font-size:30px;line-height:1.1;margin-bottom:8px}.auth-card__subtitle{font-size:15px;color:var(--text-secondary)}.auth-card__section{margin-top:22px}.auth-card__section-title{font-size:16px;margin-bottom:14px}.auth-card__divider{position:relative;text-align:center;margin:24px 0 8px}.auth-card__divider:before{content:"";position:absolute;left:0;right:0;top:50%;border-top:1px solid var(--border-subtle);transform:translateY(-50%)}.auth-card__divider span{position:relative;z-index:1;display:inline-block;padding:0 12px;background:var(--bg-surface);color:var(--text-secondary);font-size:13px}.auth-input{margin-top:12px}.auth-button{width:100%;margin-top:14px;padding:12px 16px;font-weight:600;border-radius:10px}.auth-button--primary{background:var(--accent);color:#fff}.auth-button--primary:hover{background:var(--accent-strong)}.auth-button--primary:disabled{background:#93c5fd;cursor:not-allowed}.auth-button--ghost{background:#fff;border-color:var(--border-subtle);color:var(--text-primary)}.auth-link-button{width:100%;margin-top:8px;border:0;background:transparent;color:var(--danger);padding:10px 0 0}.auth-link-button:hover{background:transparent;text-decoration:underline}.auth-error{color:var(--danger);margin-top:16px;font-weight:500}.auth-muted{margin-top:16px;text-align:center}.auth-role-list{margin-top:20px}.auth-role-button{text-transform:none}@media(max-width:768px){.app-header{min-height:64px}.app-header-inner{padding:10px 16px;align-items:flex-start}.app-content{padding:16px}.grid{grid-template-columns:1fr}.card{margin-top:14px;padding:16px}}@media(max-width:640px){.auth-page{padding:16px;align-items:stretch}.auth-card{max-width:none;padding:24px 18px;border-radius:18px;margin:auto 0}.auth-card__title{font-size:26px}.auth-card__subtitle{font-size:14px}.auth-button,.auth-input{margin-top:12px}.app-header-title{font-size:15px}.app-header-subtitle{font-size:10px}}.app-header-left{min-width:0}.app-header-mobile-row{display:flex;align-items:flex-start;gap:12px}.app-header-menu{display:none;border:1px solid var(--border-subtle);background:#fff;border-radius:10px;min-width:40px;height:40px;font-size:18px;flex-shrink:0}.sidebar-backdrop,.sidebar__mobile-top{display:none}.sidebar__close{border:1px solid var(--border-subtle);background:#fff;border-radius:8px;padding:6px 10px}.sidebar__footer{padding-top:12px;border-top:1px solid var(--border-subtle)}.sidebar__logout{width:100%;padding:10px 12px;border-radius:8px;border:1px solid var(--border-subtle);background:#fff}.mobile-nav{display:none}.mobile-nav__link{flex:1;min-width:0;text-align:center;padding:10px 6px 8px;color:var(--text-secondary);display:flex;flex-direction:column;align-items:center;gap:3px;font-size:18px}.mobile-nav__link small{font-size:11px;line-height:1}.mobile-nav__link.active{color:var(--accent);font-weight:700}.chat-input-shell{position:sticky;bottom:0;z-index:30;padding-top:12px;margin-top:16px}.chat-input-bar{display:flex;gap:8px;align-items:center;background:#fffffff5;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid #ddd;border-radius:18px;padding:10px;box-shadow:0 8px 20px #0f172a14}.chat-input-field{flex:1;min-width:0;padding:10px 14px;border-radius:20px;border:1px solid #ccc;outline:none}.chat-input-send{flex-shrink:0;padding:10px 16px;border-radius:18px;border:none;background:#2563eb;color:#fff}@media(max-width:1024px){.chat-layout{flex-direction:column;min-height:100%}.chat-layout__chat{border-right:none;min-width:0}.chat-layout__context{display:none}}@media(max-width:768px){.app-header-menu{display:inline-flex;align-items:center;justify-content:center}.sidebar{position:fixed;top:0;bottom:0;left:0;width:min(84vw,320px);z-index:50;background:var(--bg-surface);box-shadow:4px 0 18px #0000001f;overflow-y:auto}.sidebar--hidden{transform:translate(-110%)}.sidebar--open{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;inset:0;z-index:45;background:#0f172a59;border:0;padding:0}.sidebar__mobile-top{display:flex;justify-content:space-between;align-items:center;padding:14px;border-bottom:1px solid var(--border-subtle);position:sticky;top:0;background:#fff;z-index:2}.app-shell{min-height:100%}.app-main{min-width:0}.app-header{min-height:68px}.app-header-inner{padding:10px 16px;align-items:flex-start}.app-content{padding:16px 16px 88px}.mobile-nav{position:fixed;left:0;right:0;bottom:0;z-index:60;display:flex;background:#fffffffa;border-top:1px solid var(--border-subtle);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.chat-input-shell{bottom:70px}}@media(max-width:640px){.app-header-title{font-size:16px;line-height:1.2}.app-header-subtitle{font-size:11px;line-height:1.35}.chat-input-bar{border-radius:16px;padding:8px}.chat-input-send{padding:10px 14px}}.page{width:100%;min-width:0}.page-subtitle{margin-top:8px}.stats-grid,.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-top:18px}.stat-card{background:#fff;border:1px solid var(--border-subtle);border-radius:14px;padding:18px;box-shadow:0 2px 8px #0f172a0a}.stat-card.highlight{background:#eff6ff}.card--action{display:flex;flex-direction:column;align-items:flex-start;gap:10px;cursor:pointer;text-align:left;border:1px solid var(--border-subtle);width:100%}.chat-page{max-width:900px;margin:0 auto;padding-bottom:16px}.chat-toolbar{margin-bottom:15px;padding:12px;background:#f8fafc;border-radius:8px;border:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}.chat-toolbar__button{padding:6px 10px;border-radius:6px;border:1px solid #ddd;cursor:pointer;background:#fff}.chat-banner{background:#eef6ff;padding:10px;margin-bottom:12px;border-radius:8px}.chat-primary-button{padding:10px 16px;border-radius:6px;background:#2563eb;color:#fff;border:none;cursor:pointer}.chat-success-button{padding:10px 16px;border-radius:6px;background:#16a34a;color:#fff;border:none;cursor:pointer}.chat-doc-panel{margin-bottom:16px;padding:14px;background:#f9fafb;border-radius:10px;border:1px solid #e5e7eb}.chat-upload-label{cursor:pointer;padding:8px 14px;background:#e5e7eb;border-radius:8px;display:inline-block;font-size:13px;font-weight:500}.chat-doc-toggle{display:flex;gap:8px;align-items:center}.chat-doc-count{margin-top:8px;color:green;font-size:12px}.chat-doc-list{margin-top:10px;display:grid;gap:8px}.chat-doc-item{display:flex;gap:8px;align-items:flex-start}.chat-error{color:red;margin-top:10px}.chat-messages{min-width:0}.chat-row{display:flex;margin-bottom:14px}.chat-row--user{justify-content:flex-end}.chat-row--bot{justify-content:flex-start}.chat-bubble{max-width:75%;padding:12px 16px;border-radius:16px;font-size:14px;line-height:1.7;min-width:0;overflow-wrap:anywhere;word-break:break-word}.chat-bubble--user{background:#dcfce7}.chat-bubble--bot{background:#f3f4f6}.chat-bubble__time{font-size:11px;color:#777;margin-top:6px;text-align:right}.chat-case-card{margin-top:12px;padding:14px;background:#fff;border-radius:12px;border:1px solid #e5e7eb;box-shadow:0 2px 6px #0000000d;font-size:13px}.chat-case-tabs{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap}.chat-case-tab{padding:6px 10px;border-radius:6px;border:none;cursor:pointer;font-size:12px}.decision-panel{margin-top:16px;padding:14px;border-radius:8px;background:#f9fafb;border:1px solid #e5e7eb;position:relative;z-index:20;pointer-events:auto}.decision-panel__actions{margin-top:10px;display:flex;gap:10px;flex-wrap:wrap}.lawyer-selector{margin-top:16px;padding:16px;border:1px solid #ddd;border-radius:8px;background:#fafafa}.lawyer-selector__notice{margin-top:10px;color:#b45309}.lawyer-card{margin-top:12px;padding:12px;border:1px solid #e5e7eb;border-radius:8px;background:#fff}.tickets-desktop-table{display:block}.tickets-mobile-list{display:none}.ticket-mobile-card{width:100%;text-align:left;background:#fff;border:1px solid var(--border-subtle);border-radius:12px;padding:14px;margin-top:12px}.ticket-mobile-card__top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.ticket-mobile-card__meta{display:grid;gap:6px;font-size:13px;color:var(--text-secondary)}.tickets-pagination{margin-top:20px;display:flex;align-items:center;flex-wrap:wrap;gap:8px}.document-list{padding-left:18px}.appointment-page{max-width:900px;margin:0 auto;padding:20px}.appointment-date-grid{display:flex;gap:10px;flex-wrap:wrap}.appointment-slot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px}.courtpaper-form{max-width:500px;width:100%}.courtpaper-grid{display:grid;grid-template-columns:1fr 120px;gap:10px;margin-top:10px}.courtpaper-items{margin-top:12px;display:grid;gap:8px}.courtpaper-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}.payment-page{padding:30px}@media(max-width:768px){.chat-bubble{max-width:100%}.tickets-desktop-table{display:none}.tickets-mobile-list{display:block}.appointment-page{padding:0}.courtpaper-grid{grid-template-columns:1fr}.payment-page{padding:16px}}@media(max-width:640px){.chat-toolbar{align-items:stretch}.chat-toolbar__button,.chat-primary-button,.chat-success-button{width:100%}.decision-panel__actions{flex-direction:column}.decision-panel__actions button{width:100%}.chat-case-tabs{flex-direction:column}.chat-case-tab{width:100%;text-align:left}.ticket-mobile-card__top{align-items:flex-start;flex-direction:column}}.sidebar--mobile-open,.sidebar--mobile-hidden{transform:none}.chat-layout__mobile-actions{display:none}.chat-layout__toggle{padding:10px 14px;border-radius:10px;border:1px solid var(--border-subtle);background:#fff;font-weight:600}.chat-context-backdrop,.ticket-panel__mobile-top{display:none}.ticket-panel__close{border:1px solid var(--border-subtle);background:#fff;border-radius:8px;padding:6px 10px}@media(max-width:768px){.sidebar{transform:translate(-110%)}.sidebar.sidebar--mobile-open{transform:translate(0)}.sidebar.sidebar--mobile-hidden{transform:translate(-110%)}.chat-layout{position:relative}.chat-layout__mobile-actions{display:block;margin-bottom:12px}.chat-layout__context{position:fixed;top:0;right:0;bottom:0;width:min(88vw,360px);z-index:55;background:#fafafa;border-left:1px solid var(--border-subtle);box-shadow:-6px 0 18px #0000001f;transform:translate(110%);transition:transform .25s ease;display:block}.chat-layout__context.chat-layout__context--open{transform:translate(0)}.chat-layout__context.chat-layout__context--closed{transform:translate(110%)}.chat-context-backdrop{display:block;position:fixed;inset:0;z-index:50;background:#0f172a59;border:0;padding:0}.ticket-panel{height:100%;padding:14px;border-left:0}.ticket-panel__mobile-top{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;position:sticky;top:0;background:#fafafa;z-index:2;padding-bottom:8px}.ticket-list{max-height:calc(100vh - 180px)}}
