:root{--bg: #f7f8fa;--surface: #ffffff;--surface-2: #f1f2f5;--border: #e4e6eb;--border-strong: #d4d7dd;--text: #1f2328;--text-2: #3a4049;--muted: #6b7280;--muted-2: #9aa0a6;--accent: #7a2432;--accent-hover: #631d29;--accent-contrast: #ffffff;--accent-soft: rgba(122, 36, 50, .08);--accent-border: rgba(122, 36, 50, .18);--focus: #7a2432;--focus-ring: rgba(122, 36, 50, .22);--danger: #b42318;--danger-bg: #fef3f2;--danger-border: #fecdca;--success: #067647;--success-bg: #ecfdf3;--success-border: #abefc6;--warning: #b54708;--warning-bg: #fffaeb;--warning-border: #fedf89;--info: #175cd3;--info-bg: #eff8ff;--info-border: #b2ddff;--radius-sm: 6px;--radius: 10px;--radius-lg: 14px;--shadow-sm: 0 1px 2px rgba(17, 24, 39, .04), 0 1px 1px rgba(17, 24, 39, .03);--shadow: 0 4px 14px rgba(17, 24, 39, .06);--shadow-lg: 0 10px 30px rgba(17, 24, 39, .08);--sidebar-w: 248px;--sidebar-w-collapsed: 72px;--header-h: 64px;color-scheme:light;font-family:Inter,Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,Helvetica Neue,Arial,sans-serif;font-feature-settings:"cv02","cv03","cv04","cv11";color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}html{overflow-x:clip}body{background:var(--bg);min-height:100vh;min-height:100dvh;font-size:14px;line-height:1.45;overflow-x:clip}#root{min-height:100%;overflow-x:clip}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit;font-size:inherit}input,button,textarea,select{font-family:inherit}h1,h2,h3{margin:0;font-weight:600;color:var(--text)}.auth-shell{min-height:100vh;min-height:100dvh;display:grid;place-items:center;padding:calc(24px + env(safe-area-inset-top,0px)) 24px calc(24px + env(safe-area-inset-bottom,0px));background:radial-gradient(1200px 500px at 10% -10%,rgba(122,36,50,.07),transparent 60%),radial-gradient(900px 500px at 110% 110%,rgba(122,36,50,.05),transparent 60%),var(--bg)}.auth-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow)}.auth-brand{text-align:center;margin-bottom:24px}.auth-brand h1{margin:12px 0 4px;font-size:20px;letter-spacing:-.01em}.auth-brand p{margin:0;color:var(--muted);font-size:13px}.auth-logo-img{display:block;height:52px;width:auto;margin:0 auto}.auth-form{display:flex;flex-direction:column;gap:14px}.field{display:flex;flex-direction:column;gap:6px;font-size:12.5px;color:var(--text-2);font-weight:500}.field input{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:10px 12px;font-size:14px;color:var(--text);outline:none;transition:border-color .15s ease,box-shadow .15s ease}.field input:focus{border-color:var(--focus);box-shadow:0 0 0 3px var(--focus-ring)}.auth-error{background:var(--danger-bg);border:1px solid var(--danger-border);color:var(--danger);padding:9px 12px;border-radius:var(--radius-sm);font-size:13px}.auth-footer{margin-top:20px;text-align:center;color:var(--muted-2);font-size:12px}.primary-button{background:var(--accent);color:var(--accent-contrast);font-weight:600;border:1px solid var(--accent);border-radius:var(--radius-sm);padding:10px 14px;font-size:14px;transition:background .15s ease,transform .05s ease}.primary-button:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.primary-button:active:not(:disabled){transform:translateY(1px)}.primary-button:disabled{opacity:.65;cursor:not-allowed}.app-shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh;transition:grid-template-columns .2s ease}.app-shell--collapsed{grid-template-columns:var(--sidebar-w-collapsed) 1fr}.app-main{min-width:0;display:flex;flex-direction:column;background:var(--bg);overflow-x:clip;width:100%}.sidebar{position:sticky;top:0;height:100vh;height:100dvh;max-height:100dvh;display:flex;flex-direction:column;overflow:hidden;background:var(--surface);border-right:1px solid var(--border)}.sidebar__brand{display:flex;align-items:center;gap:10px;padding:18px 16px;border-bottom:1px solid var(--border);height:var(--header-h);flex-shrink:0}.sidebar__logo{flex:0 0 auto;width:36px;height:36px;display:grid;place-items:center;overflow:hidden}.sidebar__logo-img{display:block;width:34px;height:auto;max-height:30px;object-fit:contain;object-position:left center}.sidebar__brand-text{flex:1;min-width:0;overflow:hidden}.sidebar__brand-title{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__brand-sub{font-size:11px;color:var(--accent);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.sidebar__nav{flex:1;min-height:0;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;padding:12px 10px;display:flex;flex-direction:column;gap:2px}.sidebar__section{padding:14px 8px 6px}.sidebar__section-title{font-size:11px;font-weight:600;color:var(--muted-2);text-transform:uppercase;letter-spacing:.08em}.sidebar__item{display:flex;align-items:center;gap:12px;height:38px;padding:0 10px;border-radius:var(--radius-sm);color:var(--text-2);font-size:13.5px;transition:background .12s ease,color .12s ease;white-space:nowrap;overflow:hidden}.sidebar__item:hover{background:var(--surface-2);color:var(--text)}.sidebar__item.is-active{background:var(--accent);color:var(--accent-contrast);font-weight:500}.sidebar__item.is-active:hover{background:var(--accent-hover);color:var(--accent-contrast)}.sidebar__icon{flex:0 0 auto;width:20px;display:grid;place-items:center;color:inherit}.sidebar__label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.sidebar__footer{flex-shrink:0;padding:12px 10px;padding-bottom:max(12px,env(safe-area-inset-bottom,0px));border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px;background:var(--surface)}.sidebar__user{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:var(--radius-sm);min-width:0}.sidebar__avatar{width:32px;height:32px;border-radius:50%;background:var(--surface-2);color:var(--text);display:grid;place-items:center;font-weight:600;font-size:12px;flex:0 0 auto;border:1px solid var(--border)}.sidebar__user-meta{min-width:0;overflow:hidden}.sidebar__user-name{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__user-role{font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.sidebar__logout{display:flex;align-items:center;gap:12px;height:36px;padding:0 10px;border-radius:var(--radius-sm);background:transparent;border:none;color:var(--text-2);text-align:left;font-size:13.5px;transition:background .12s ease,color .12s ease;overflow:hidden;white-space:nowrap}.sidebar__logout:hover{background:var(--surface-2);color:var(--danger)}.sidebar--collapsed .sidebar__brand-text,.sidebar--collapsed .sidebar__section-title,.sidebar--collapsed .sidebar__label,.sidebar--collapsed .sidebar__user-meta{display:none}.sidebar--collapsed .sidebar__brand{justify-content:center;padding:18px 8px}.sidebar--collapsed .sidebar__logo-img{width:28px;max-height:26px;object-position:center}.sidebar--collapsed .sidebar__item,.sidebar--collapsed .sidebar__logout{justify-content:center;padding:0;width:40px;margin:0 auto;gap:0}.sidebar--collapsed .sidebar__user{justify-content:center;padding:6px 0}.sidebar--collapsed .sidebar__section{padding:6px 0;display:none}.app-header{position:sticky;top:0;z-index:5;min-height:calc(var(--header-h) + env(safe-area-inset-top,0px));display:flex;align-items:center;justify-content:space-between;padding:env(safe-area-inset-top,0px) 24px 0;background:var(--surface);border-bottom:1px solid var(--border)}.app-header__left{display:flex;align-items:center;gap:14px;min-width:0}.app-header__menu{display:grid;flex-shrink:0}.app-header__titles{min-width:0}.app-header__title{font-size:16px;font-weight:600;letter-spacing:-.01em}.app-header__subtitle{margin:2px 0 0;color:var(--muted);font-size:12.5px}.app-header__right{display:flex;align-items:center;gap:10px;min-width:0}.view-mode-switch{display:inline-flex;align-items:center;gap:8px;height:36px;padding:0 14px 0 6px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text-2);font-size:13px;font-weight:500;white-space:nowrap;flex-shrink:0;box-shadow:var(--shadow-sm);transition:background .15s ease,border-color .15s ease,color .15s ease,box-shadow .15s ease,transform .05s ease}.view-mode-switch:hover{background:var(--surface-2);border-color:var(--border-strong);color:var(--text);box-shadow:var(--shadow)}.view-mode-switch:active{transform:translateY(1px)}.view-mode-switch__icon{display:grid;place-items:center;width:26px;height:26px;border-radius:999px;flex-shrink:0}.view-mode-switch--mobile .view-mode-switch__icon{background:var(--accent-soft);color:var(--accent);border:1px solid var(--accent-border)}.view-mode-switch--desktop .view-mode-switch__icon{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}.view-mode-switch__label{line-height:1}@media(max-width:900px){.view-mode-switch__label{display:none}.view-mode-switch{padding:0;width:36px;height:36px;justify-content:center}}.icon-button{background:transparent;border:1px solid var(--border);color:var(--text-2);border-radius:var(--radius-sm);width:32px;height:32px;display:grid;place-items:center;transition:background .12s ease,border-color .12s ease,color .12s ease}.icon-button:hover{background:var(--surface-2);border-color:var(--border-strong);color:var(--text)}.search{display:flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 10px;color:var(--muted);min-width:240px;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.search:focus-within{background:var(--surface);border-color:var(--focus);box-shadow:0 0 0 3px var(--focus-ring)}.search input{background:transparent;border:none;outline:none;color:var(--text);font-size:13.5px;width:100%}.search input::placeholder{color:var(--muted-2)}.page{padding:24px;max-width:1280px;width:100%;margin:0 auto;display:flex;flex-direction:column;gap:20px}.cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px}.stat-card__label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.06em;font-weight:600}.stat-card__value{margin-top:8px;font-size:22px;font-weight:600;letter-spacing:-.01em;color:var(--text)}.stat-card__hint{margin-top:4px;color:var(--muted);font-size:12.5px}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px}.panel__header{display:flex;align-items:center;gap:14px;margin-bottom:14px}.panel__header h2{font-size:15px;font-weight:600}.panel__header p{margin:2px 0 0;color:var(--muted);font-size:12.5px}.panel__header-icon{flex:0 0 auto;width:36px;height:36px;border-radius:8px;background:var(--surface-2);color:var(--text);display:grid;place-items:center;border:1px solid var(--border)}.modules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.module-tile{display:flex;flex-direction:column;gap:6px;padding:14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);transition:border-color .15s ease,background .15s ease,transform .05s ease}.module-tile:hover{border-color:var(--border-strong);background:var(--surface-2)}.module-tile:active{transform:translateY(1px)}.module-tile__icon{width:34px;height:34px;border-radius:8px;background:var(--surface-2);border:1px solid var(--border);color:var(--text);display:grid;place-items:center;margin-bottom:4px}.module-tile__name{font-weight:500;font-size:13.5px}.module-tile__desc{font-size:12px;color:var(--muted)}.empty{padding:22px;border:1px dashed var(--border-strong);border-radius:var(--radius);background:var(--surface-2);color:var(--muted);font-size:13px;text-align:center}.panel--flush{padding:0;overflow:hidden}.panel--flush .toolbar{padding:12px 16px;border-bottom:1px solid var(--border)}.panel__tabsbar{border-bottom:1px solid var(--border);padding:8px 10px 0;background:var(--surface)}.toolbar{display:flex;align-items:center;gap:12px;justify-content:space-between;flex-wrap:wrap}.toolbar__left,.toolbar__right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.muted-text{color:var(--muted);font-size:12.5px}.search--inline{min-width:0}.filter-select{height:34px;padding:0 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-size:13.5px;min-width:160px}.filter-select:focus{outline:none;border-color:var(--focus);box-shadow:0 0 0 3px var(--focus-ring)}.tabs{display:flex;gap:2px;overflow-x:auto}.tabs__item{background:transparent;border:none;color:var(--muted);font-size:13px;font-weight:500;padding:10px 14px;border-bottom:2px solid transparent;border-radius:0;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;transition:color .12s ease,border-color .12s ease,background .12s ease}.tabs__item:hover{color:var(--text);background:var(--surface-2)}.tabs__item.is-active{color:var(--focus);border-bottom-color:var(--focus)}.tabs__count{background:var(--surface-2);color:var(--text-2);border-radius:999px;padding:0 7px;font-size:11px;font-weight:600;line-height:18px;min-width:18px;text-align:center}.tabs__item.is-active .tabs__count{background:var(--info-bg);color:var(--info)}.table-wrap{overflow:auto;max-width:100%}.table-wrap--sticky thead th{position:sticky;top:0;z-index:1}.data-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px;color:var(--text)}.data-table thead th{text-align:left;background:var(--surface-2);color:var(--muted);font-weight:600;font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;padding:10px 12px;border-bottom:1px solid var(--border);white-space:nowrap}.data-table tbody td{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr.is-clickable{cursor:pointer;transition:background .1s ease}.data-table tbody tr.is-clickable:hover{background:var(--surface-2)}.data-table tbody tr.is-selected,.data-table tbody tr.is-selected:hover{background:var(--info-bg)}.data-table tbody tr.row--warn{background:var(--danger-bg)}.data-table tbody tr.row--warn:hover{background:#fce7e4}.data-table__info{text-align:center;padding:32px 12px!important;color:var(--muted)}.th-sort{background:transparent;border:none;padding:0;color:inherit;font:inherit;letter-spacing:inherit;text-transform:inherit;cursor:pointer;transition:color .12s ease}.th-sort:hover{color:var(--text)}.diff--negative{color:var(--danger);font-weight:600}.diff--positive{color:var(--success)}.status-badge{display:inline-flex;align-items:center;padding:2px 10px;font-size:11.5px;font-weight:600;border-radius:999px;border:1px solid transparent;line-height:18px;white-space:nowrap}.status-badge--neutral{background:var(--surface-2);color:var(--text-2);border-color:var(--border)}.status-badge--success{background:var(--success-bg);color:var(--success);border-color:var(--success-border)}.status-badge--warning{background:var(--warning-bg);color:var(--warning);border-color:var(--warning-border)}.status-badge--danger{background:var(--danger-bg);color:var(--danger);border-color:var(--danger-border)}.status-badge--info{background:var(--info-bg);color:var(--info);border-color:var(--info-border)}.kv-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px 24px}.kv{min-width:0}.kv__label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600;margin-bottom:2px}.kv__value{font-size:13.5px;color:var(--text);word-break:break-word}.breadcrumbs{display:flex;align-items:center;font-size:12.5px;color:var(--muted)}.breadcrumbs__link{display:inline-flex;align-items:center;gap:4px;color:var(--muted);transition:color .12s ease}.breadcrumbs__link:hover{color:var(--text)}.report-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}.report-card{display:flex;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;color:var(--text);transition:border-color .15s ease,transform .1s ease,box-shadow .15s ease}.report-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.report-card__icon{flex:0 0 auto;width:40px;height:40px;border-radius:10px;display:grid;place-items:center;background:var(--surface-2);color:var(--text-2);border:1px solid var(--border)}.report-card__body h3{font-size:14.5px;margin-bottom:4px}.report-card__body p{margin:0;color:var(--muted);font-size:12.5px;line-height:1.5}.report-card--blue .report-card__icon{background:var(--info-bg);color:var(--info);border-color:var(--info-border)}.report-card--green .report-card__icon{background:var(--success-bg);color:var(--success);border-color:var(--success-border)}.report-card--yellow .report-card__icon{background:var(--warning-bg);color:var(--warning);border-color:var(--warning-border)}.checkbox{display:inline-flex;align-items:center;gap:6px;color:var(--text-2);font-size:12.5px;-webkit-user-select:none;user-select:none}.checkbox input{accent-color:var(--focus)}.link{background:transparent;border:none;color:var(--focus);padding:0;margin-left:8px;font-size:13px;cursor:pointer}.primary-button[disabled]{cursor:not-allowed;opacity:.5}@media(max-width:768px){:root{--sidebar-w: 240px}.app-shell{grid-template-columns:1fr}.sidebar-backdrop{position:fixed;inset:0;z-index:15;border:none;padding:0;margin:0;background:#0f172a73;cursor:pointer}.sidebar{position:fixed;left:0;top:0;bottom:0;z-index:20;width:min(var(--sidebar-w),86vw);height:100dvh;max-height:100dvh;transform:translate(0);transition:transform .2s ease;box-shadow:var(--shadow-lg);padding-top:env(safe-area-inset-top,0px)}.sidebar__brand{height:auto;min-height:56px;padding:14px 12px}.sidebar__nav{padding:8px 8px 10px}.sidebar__item{height:44px;font-size:14px}.sidebar__footer{padding:10px 8px;padding-bottom:max(14px,env(safe-area-inset-bottom,0px))}.sidebar__logout{height:44px}.app-shell--collapsed .sidebar{transform:translate(-100%)}.app-shell--collapsed{grid-template-columns:1fr}.app-header{z-index:25;min-height:calc(56px + env(safe-area-inset-top,0px));padding:env(safe-area-inset-top,0px) 12px 0;gap:8px}.app-header__left{gap:8px;flex:1;min-width:0}.app-header__right{flex-shrink:0;gap:8px}.app-header__titles{flex:1;min-width:0}.app-header__title{font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-header__subtitle,.app-header .search{display:none}.app-header__menu{display:grid}.page{padding:12px;gap:14px}.cards-grid{grid-template-columns:1fr}.panel__header p{display:none}.panel--flush .toolbar{padding:10px 12px}.toolbar{flex-direction:column;align-items:stretch;gap:10px}.toolbar__left,.toolbar__right{width:100%}.toolbar__left .search,.toolbar__left .search--inline{width:100%;max-width:100%;min-width:0}.toolbar__right{justify-content:space-between}.toolbar__right .primary-button{flex:1}.search{min-width:0;flex:1}.filter-select{width:100%;min-width:0}.kv-grid{grid-template-columns:1fr}}.mobile-shell{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;background:var(--bg)}.mobile-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:calc(10px + env(safe-area-inset-top,0px)) 14px 10px;border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:10}.mobile-header__brand{font-weight:600;font-size:15px;flex-shrink:0}.mobile-header__actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.mobile-header .view-mode-switch{width:36px;height:36px;padding:0;justify-content:center}.mobile-header .view-mode-switch__label{display:none}.mobile-main{flex:1;overflow:auto;padding-bottom:72px}.mobile-bottom-nav{position:fixed;left:0;right:0;bottom:0;display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--border);background:var(--surface);padding-bottom:env(safe-area-inset-bottom,0);z-index:20}.mobile-bottom-nav__item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:10px 8px;color:var(--muted);font-size:11px;text-decoration:none}.mobile-bottom-nav__item.is-active{color:var(--text);font-weight:600}.mobile-page{padding:14px;display:flex;flex-direction:column;gap:12px}.mobile-page__title{font-size:20px;margin:0 0 4px}.mobile-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.mobile-card--compact{padding:12px 16px}.mobile-card--flush{padding:0;overflow:hidden}.mobile-field{display:flex;flex-direction:column;gap:6px;margin-top:12px}.mobile-field__label{font-size:12px;color:var(--muted);font-weight:500}.mobile-input{width:100%;min-height:44px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);font-size:16px}.mobile-input--lg{min-height:52px;font-size:18px}.mobile-actions{display:flex;gap:10px;margin-top:16px}.mobile-actions--stack{flex-direction:column}.mobile-btn{min-height:48px;padding:0 16px;border-radius:var(--radius-sm);border:1px solid var(--border);font-size:15px;font-weight:500}.mobile-btn--block{width:100%}.mobile-btn--primary{background:var(--accent);color:var(--accent-contrast);border-color:var(--accent)}.mobile-btn--secondary{background:var(--surface-2);color:var(--text)}.mobile-btn--ghost{background:transparent}.mobile-btn:disabled{opacity:.45}.mobile-hint{font-size:13px;color:var(--muted);margin:8px 0 0}.mobile-hint--warn{color:#b45309}.mobile-selected-company{margin-top:10px;font-size:13px;font-weight:500}.mobile-menu-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.mobile-menu-tile{display:flex;flex-direction:column;align-items:flex-start;gap:6px;min-height:120px;padding:16px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);text-align:left}.mobile-menu-tile--muted{opacity:.55}.mobile-menu-tile__title{font-size:16px;font-weight:600}.mobile-menu-tile__desc{font-size:12px;color:var(--muted)}.mobile-raf-badge{display:flex;align-items:baseline;gap:8px;font-size:14px}.mobile-raf-badge strong{font-size:20px}.mobile-link-btn{margin-top:8px;padding:0;border:none;background:none;color:var(--muted);font-size:13px;text-decoration:underline}.mobile-modal{position:fixed;inset:0;z-index:50;display:flex;align-items:flex-end}.mobile-modal__backdrop{position:absolute;inset:0;background:#00000073}.mobile-modal__sheet{position:relative;width:100%;max-height:85vh;overflow:auto;background:var(--surface);border-radius:16px 16px 0 0;padding:16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0))}.mobile-modal--fullscreen{align-items:stretch}.mobile-modal__sheet--fullscreen{max-height:none;height:100%;height:100dvh;border-radius:0;display:flex;flex-direction:column;overflow:hidden;padding-top:calc(12px + env(safe-area-inset-top,0));padding-bottom:calc(16px + env(safe-area-inset-bottom,0))}.mobile-modal__body{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;gap:4px}.mobile-modal__sheet--fullscreen .mobile-results{flex:1;min-height:120px;overflow-y:auto}.mobile-search-row--stack{flex-direction:column}.mobile-search-row--stack .mobile-btn{width:100%}.mobile-modal__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.mobile-modal__header h2{font-size:17px}.mobile-modal__close{border:none;background:none;font-size:14px;color:var(--muted)}.mobile-search-row{display:flex;gap:8px}.mobile-search-row .mobile-input{flex:1}.mobile-results{margin-top:12px;display:flex;flex-direction:column;gap:8px}.mobile-result-row{display:flex;flex-direction:column;align-items:flex-start;gap:4px;width:100%;padding:12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);text-align:left}.mobile-result-row__name{font-weight:500}.mobile-result-row__meta{font-size:12px;color:var(--muted)}.barcode-scanner{width:100%;min-height:240px;overflow:hidden;border-radius:var(--radius-sm)}.mobile-list{list-style:none;margin:0;padding:0}.mobile-list__item{display:grid;grid-template-columns:1fr auto;gap:4px 12px;padding:14px 16px;border-bottom:1px solid var(--border);width:100%;text-align:left}.mobile-list__item--clickable{border:none;background:var(--surface);cursor:pointer}.mobile-list__item--clickable:active{background:var(--surface-2)}.mobile-list__title{grid-column:1 / -1;font-weight:500}.mobile-list__meta{font-size:12px;color:var(--muted)}.mobile-list__qty{font-size:18px;font-weight:600;align-self:center}.toast-host{position:fixed;left:50%;bottom:calc(72px + env(safe-area-inset-bottom,0));transform:translate(-50%);z-index:60;max-width:calc(100% - 32px);padding:12px 16px;border-radius:999px;background:#111827eb;color:#fff;font-size:14px;box-shadow:var(--shadow-lg)}@media(min-width:769px){.mobile-shell{max-width:480px;margin:0 auto;border-left:1px solid var(--border);border-right:1px solid var(--border)}}.pwa-install{position:fixed;left:12px;right:12px;bottom:calc(12px + env(safe-area-inset-bottom,0));z-index:70;max-width:480px;margin:0 auto}.pwa-install__content{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-lg)}.pwa-install__text{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px;font-size:13px;color:var(--text-2)}.pwa-install__text strong{color:var(--text);font-size:14px}.pwa-install__actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.pwa-install__btn{display:inline-flex;align-items:center;gap:6px;height:36px;padding:0 12px;border:none;border-radius:var(--radius-sm);background:var(--accent);color:var(--accent-contrast);font-size:13px;font-weight:500;white-space:nowrap}.pwa-install__close{display:grid;place-items:center;width:36px;height:36px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);color:var(--text-2)}@media(max-width:768px){.pwa-install{bottom:calc(72px + env(safe-area-inset-bottom,0))}}
