:root{--color-background: #f8f7f4;--color-surface: #ffffff;--color-text: #1a1a1a;--color-text-secondary: #5a5a5a;--color-text-muted: #9a9a9a;--color-primary: #1a1a2e;--color-primary-light: #2d2d4a;--color-accent: #c9a96e;--color-border: #e0ddd8;--color-border-light: #edeae5;--color-success: #2e7d32;--color-warning: #f9a825;--color-error: #c62828;--color-primary-alpha-10: rgba(26, 26, 46, .1);--color-primary-alpha-05: rgba(26, 26, 46, .05);--color-accent-alpha-15: rgba(201, 169, 110, .15);--color-success-alpha-15: rgba(46, 125, 50, .15);--color-warning-alpha-15: rgba(249, 168, 37, .15);--color-error-alpha-15: rgba(198, 40, 40, .15);--color-overlay: rgba(0, 0, 0, .45);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-xxl: 48px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;--font-size-h1: 28px;--font-size-h2: 22px;--font-size-h3: 18px;--font-size-body: 16px;--font-size-body-small: 14px;--font-size-caption: 12px;--font-size-label: 13px;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.2;--line-height-normal: 1.5;--line-height-relaxed: 1.65;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 2px 8px rgba(0, 0, 0, .08);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .12);--shadow-xl: 0 8px 32px rgba(0, 0, 0, .16);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease;--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-overlay: 300;--z-modal: 400;--z-toast: 500;--bottom-nav-height: 64px;--sidebar-width: 240px;--max-content-width: 1200px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}body{font-family:var(--font-family);font-size:var(--font-size-body);font-weight:var(--font-weight-regular);line-height:var(--line-height-normal);color:var(--color-text);background-color:var(--color-background);min-height:100dvh;overflow-x:hidden}img,svg{display:block;max-width:100%}a{color:inherit;text-decoration:none}button{font:inherit;color:inherit;cursor:pointer;border:none;background:none}input,textarea,select{font:inherit;color:inherit}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight)}h1,.text-h1{font-size:var(--font-size-h1);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);letter-spacing:-.02em}h2,.text-h2{font-size:var(--font-size-h2);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);letter-spacing:-.01em}h3,.text-h3{font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight)}.text-body{font-size:var(--font-size-body);font-weight:var(--font-weight-regular);line-height:var(--line-height-normal)}.text-body-small{font-size:var(--font-size-body-small);font-weight:var(--font-weight-regular);line-height:var(--line-height-normal)}.text-caption{font-size:var(--font-size-caption);font-weight:var(--font-weight-regular);line-height:var(--line-height-normal)}.text-label{font-size:var(--font-size-label);font-weight:var(--font-weight-medium);line-height:var(--line-height-normal);letter-spacing:.01em}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}.text-accent{color:var(--color-accent)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.text-center{text-align:center}.text-right{text-align:right}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.app-layout{display:flex;flex-direction:column;min-height:100dvh}.app-main{flex:1;padding-bottom:var(--bottom-nav-height);width:100%;max-width:var(--max-content-width);margin:0 auto}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--bottom-nav-height);background:var(--color-surface);border-top:1px solid var(--color-border-light);display:flex;align-items:center;justify-content:space-around;padding-bottom:env(safe-area-inset-bottom,0);z-index:var(--z-sticky);box-shadow:0 -2px 8px #0000000a}.nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:11px;font-weight:var(--font-weight-medium);color:var(--color-text-muted);transition:color var(--transition-fast);-webkit-tap-highlight-color:transparent;min-width:56px}.nav-item:hover{color:var(--color-text-secondary)}.nav-item.active{color:var(--color-accent)}.nav-item.active svg{stroke-width:2.2}.page-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-md) var(--space-sm);gap:var(--space-md)}.page-header-left{display:flex;align-items:center;gap:var(--space-sm);min-width:0}.page-title{font-size:var(--font-size-h2);font-weight:var(--font-weight-bold);color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.page-subtitle{font-size:var(--font-size-body-small);color:var(--color-text-muted);margin-top:2px}.page-header-right{flex-shrink:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:10px var(--space-md);border-radius:var(--radius-md);font-size:var(--font-size-body-small);font-weight:var(--font-weight-semibold);line-height:1;white-space:nowrap;cursor:pointer;transition:all var(--transition-fast);border:1px solid transparent;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:active:not(:disabled){transform:scale(.97)}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover:not(:disabled){background:var(--color-primary-light);border-color:var(--color-primary-light)}.btn-secondary{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-background);border-color:var(--color-text-muted)}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--color-primary-alpha-05)}.btn-danger{background:var(--color-error);color:#fff;border-color:var(--color-error)}.btn-danger:hover:not(:disabled){background:#b71c1c;border-color:#b71c1c}.btn-accent{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.btn-accent:hover:not(:disabled){background:#b8943e;border-color:#b8943e}.btn-icon{padding:var(--space-sm);border-radius:var(--radius-sm);display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px}.btn-sm{padding:6px 12px;font-size:var(--font-size-caption);border-radius:var(--radius-sm)}.btn-lg{padding:14px var(--space-lg);font-size:var(--font-size-body)}.btn-block{width:100%}.form-group{display:flex;flex-direction:column;gap:var(--space-xs)}.form-label{font-size:var(--font-size-label);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.form-input,.form-select,.form-textarea{width:100%;padding:10px var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);font-size:var(--font-size-body);color:var(--color-text);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-muted)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-alpha-15)}.form-input.error,.form-select.error,.form-textarea.error{border-color:var(--color-error);box-shadow:0 0 0 3px var(--color-error-alpha-15)}.form-textarea{min-height:100px;resize:vertical}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239a9a9a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.form-hint{font-size:var(--font-size-caption);color:var(--color-text-muted)}.form-error{font-size:var(--font-size-caption);color:var(--color-error)}.form-row{display:flex;gap:var(--space-md)}.form-row>.form-group{flex:1}.form-check{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer}.form-check input[type=checkbox],.form-check input[type=radio]{width:18px;height:18px;accent-color:var(--color-accent);cursor:pointer}.card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:var(--space-md);transition:box-shadow var(--transition-fast)}.card:hover{box-shadow:var(--shadow-sm)}.card-clickable{cursor:pointer}.card-clickable:hover{box-shadow:var(--shadow-md)}.card-clickable:active{transform:scale(.99)}.stat-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-xs)}.stat-label{font-size:var(--font-size-caption);font-weight:var(--font-weight-medium);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.stat-value{font-size:var(--font-size-h1);font-weight:var(--font-weight-bold);color:var(--color-text);line-height:1}.stat-subtitle{font-size:var(--font-size-caption);color:var(--color-text-secondary)}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-full);font-size:var(--font-size-caption);font-weight:var(--font-weight-medium);line-height:1.4;white-space:nowrap}.badge-default{background:var(--color-primary-alpha-10);color:var(--color-primary)}.badge-success{background:var(--color-success-alpha-15);color:var(--color-success)}.badge-warning{background:var(--color-warning-alpha-15);color:#8a6d00}.badge-error{background:var(--color-error-alpha-15);color:var(--color-error)}.badge-accent{background:var(--color-accent-alpha-15);color:#8a6d20}.chip{display:inline-flex;align-items:center;gap:var(--space-xs);padding:4px 12px;border-radius:var(--radius-full);font-size:var(--font-size-body-small);font-weight:var(--font-weight-medium);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.chip:hover{border-color:var(--color-text-muted);background:var(--color-background)}.chip.active,.chip-active{border-color:var(--color-accent);background:var(--color-accent-alpha-15);color:var(--color-text)}.chip-sm{padding:2px 8px;font-size:var(--font-size-caption)}.item-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md);padding:0 var(--space-md)}.item-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:box-shadow var(--transition-fast),transform var(--transition-fast)}.item-card:hover{box-shadow:var(--shadow-md)}.item-card:active{transform:scale(.98)}.item-card-image{aspect-ratio:3 / 4;background:var(--color-border-light);display:flex;align-items:center;justify-content:center;overflow:hidden}.item-card-image img{width:100%;height:100%;object-fit:cover}.item-card-image .placeholder-icon{color:var(--color-text-muted);opacity:.4}.item-card-body{padding:var(--space-sm) var(--space-sm) var(--space-md)}.item-card-name{font-size:var(--font-size-body-small);font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-card-meta{font-size:var(--font-size-caption);color:var(--color-text-muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-overlay);display:flex;align-items:flex-end;justify-content:center;z-index:var(--z-modal);animation:fadeIn var(--transition-normal) ease}.modal{background:var(--color-surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:540px;max-height:85dvh;overflow-y:auto;animation:slideUp var(--transition-normal) ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-md) var(--space-sm);position:sticky;top:0;background:var(--color-surface);border-bottom:1px solid var(--color-border-light);z-index:1}.modal-header h2{font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold)}.modal-body{padding:var(--space-md)}.modal-footer{display:flex;gap:var(--space-sm);padding:var(--space-md);border-top:1px solid var(--color-border-light);justify-content:flex-end}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-xxl) var(--space-lg);gap:var(--space-sm)}.empty-state-icon{color:var(--color-text-muted);opacity:.5;margin-bottom:var(--space-sm)}.empty-state h3{font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold);color:var(--color-text)}.empty-state p{font-size:var(--font-size-body-small);color:var(--color-text-muted);max-width:280px}.empty-state-action{margin-top:var(--space-md)}.loading-container{display:flex;align-items:center;justify-content:center;padding:var(--space-xxl) 0;width:100%}.spinner{width:32px;height:32px;border:3px solid var(--color-border-light);border-top-color:var(--color-accent);border-radius:50%;animation:spin .7s linear infinite}.spinner-sm{width:18px;height:18px;border-width:2px}.spinner-lg{width:48px;height:48px;border-width:4px}.skeleton{background:linear-gradient(90deg,var(--color-border-light) 25%,var(--color-background) 50%,var(--color-border-light) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.skeleton-text{height:14px;width:80%;margin-bottom:var(--space-sm)}.skeleton-title{height:20px;width:60%;margin-bottom:var(--space-sm)}.skeleton-image{aspect-ratio:3 / 4;width:100%}.toast-container{position:fixed;top:var(--space-md);left:50%;transform:translate(-50%);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-sm);width:calc(100% - var(--space-xl));max-width:400px;pointer-events:none}.toast{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:var(--color-primary);color:#fff;font-size:var(--font-size-body-small);font-weight:var(--font-weight-medium);box-shadow:var(--shadow-lg);pointer-events:auto;animation:slideDown var(--transition-normal) ease,fadeOut var(--transition-normal) ease 2.8s forwards}.toast-success{background:var(--color-success)}.toast-error{background:var(--color-error)}.toast-warning{background:#e68a00;color:#fff}.toast-close{margin-left:auto;padding:var(--space-xs);opacity:.7;cursor:pointer;color:#fff;background:none;border:none}.toast-close:hover{opacity:1}.search-bar{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.search-bar:focus-within{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-alpha-15)}.search-bar svg{color:var(--color-text-muted);flex-shrink:0}.search-bar input{flex:1;border:none;background:transparent;outline:none;font-size:var(--font-size-body-small)}.search-bar input::placeholder{color:var(--color-text-muted)}.filter-bar{display:flex;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.filter-bar::-webkit-scrollbar{display:none}.section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-md) var(--space-sm)}.section-title{font-size:var(--font-size-h3);font-weight:var(--font-weight-semibold);color:var(--color-text)}.section-link{font-size:var(--font-size-body-small);font-weight:var(--font-weight-medium);color:var(--color-accent)}.divider{height:1px;background:var(--color-border-light);margin:var(--space-md) 0;border:none}.divider-thick{height:8px;background:var(--color-background)}.upload-zone{border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--space-xl);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-sm);text-align:center;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);background:var(--color-primary-alpha-05)}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--color-accent);background:var(--color-accent-alpha-15);color:var(--color-text-secondary)}.upload-zone p{font-size:var(--font-size-body-small)}.image-preview-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-sm)}.image-preview{position:relative;aspect-ratio:1;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--color-border-light)}.image-preview img{width:100%;height:100%;object-fit:cover}.image-preview-remove{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:50%;background:#0009;color:#fff;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer}.photo-upload-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--space-sm)}.photo-upload-item{position:relative;aspect-ratio:1;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--color-border-light)}.photo-upload-thumb{width:100%;height:100%;object-fit:cover}.photo-remove-btn{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:50%;background:#0009;color:#fff;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer}.photo-upload-add{display:flex;flex-direction:column;gap:var(--space-xs);justify-content:center;align-items:center;min-height:100px;border:2px dashed var(--color-border);border-radius:var(--radius-md);padding:var(--space-sm)}.intake-capture,.intake-analyzing,.intake-review{display:flex;flex-direction:column;gap:var(--space-md)}.intake-upload-zone{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);padding:var(--space-xl);border:2px dashed var(--color-border);border-radius:var(--radius-lg);text-align:center}.intake-buttons{display:flex;gap:var(--space-sm)}.intake-preview{border-radius:var(--radius-lg);overflow:hidden;max-height:300px}.intake-preview-img{width:100%;height:100%;object-fit:contain;max-height:300px}.intake-loading{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-xl) 0}.intake-loading-text{font-weight:600}.spinner-icon{animation:spin 1s linear infinite}.intake-review-header{display:flex;justify-content:space-between;align-items:center}.intake-review-title{display:flex;align-items:center;gap:var(--space-sm);font-weight:600}.intake-fields{display:flex;flex-direction:column;gap:var(--space-sm)}.intake-actions{display:flex;gap:var(--space-sm);justify-content:flex-end;padding-top:var(--space-md)}.list-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border-bottom:1px solid var(--color-border-light);transition:background var(--transition-fast)}.list-item:last-child{border-bottom:none}.list-item:hover{background:var(--color-primary-alpha-05)}.list-item-content{flex:1;min-width:0}.list-item-title{font-size:var(--font-size-body);font-weight:var(--font-weight-medium);color:var(--color-text)}.list-item-subtitle{font-size:var(--font-size-body-small);color:var(--color-text-muted)}.list-item-icon{width:40px;height:40px;border-radius:var(--radius-md);background:var(--color-primary-alpha-05);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);flex-shrink:0}.p-0{padding:0}.p-xs{padding:var(--space-xs)}.p-sm{padding:var(--space-sm)}.p-md{padding:var(--space-md)}.p-lg{padding:var(--space-lg)}.p-xl{padding:var(--space-xl)}.px-md{padding-left:var(--space-md);padding-right:var(--space-md)}.px-lg{padding-left:var(--space-lg);padding-right:var(--space-lg)}.py-sm{padding-top:var(--space-sm);padding-bottom:var(--space-sm)}.py-md{padding-top:var(--space-md);padding-bottom:var(--space-md)}.py-lg{padding-top:var(--space-lg);padding-bottom:var(--space-lg)}.m-0{margin:0}.mt-xs{margin-top:var(--space-xs)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mt-xl{margin-top:var(--space-xl)}.mb-xs{margin-bottom:var(--space-xs)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.mb-xl{margin-bottom:var(--space-xl)}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.flex-row{display:flex;flex-direction:row}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.self-end{align-self:flex-end}.hidden{display:none}.block{display:block}.inline{display:inline}.relative{position:relative}.absolute{position:absolute}.overflow-hidden{overflow:hidden}.w-full{width:100%}.h-full{height:100%}.rounded-full{border-radius:var(--radius-full)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md);padding:0 var(--space-md)}.tab-bar{display:flex;border-bottom:1px solid var(--color-border-light);padding:0 var(--space-md);overflow-x:auto;scrollbar-width:none}.tab-bar::-webkit-scrollbar{display:none}.tab-item{padding:var(--space-sm) var(--space-md);font-size:var(--font-size-body-small);font-weight:var(--font-weight-medium);color:var(--color-text-muted);border-bottom:2px solid transparent;white-space:nowrap;cursor:pointer;transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent}.tab-item:hover{color:var(--color-text-secondary)}.tab-item.active{color:var(--color-text);border-bottom-color:var(--color-accent)}.progress-bar{height:6px;background:var(--color-border-light);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;background:var(--color-accent);border-radius:var(--radius-full);transition:width var(--transition-slow)}.progress-bar-success .progress-bar-fill{background:var(--color-success)}.avatar{width:40px;height:40px;border-radius:var(--radius-full);overflow:hidden;background:var(--color-border-light);display:flex;align-items:center;justify-content:center;flex-shrink:0}.avatar img{width:100%;height:100%;object-fit:cover}.avatar-sm{width:28px;height:28px}.avatar-lg{width:56px;height:56px}.fab{position:fixed;bottom:calc(var(--bottom-nav-height) + var(--space-md));right:var(--space-md);width:56px;height:56px;border-radius:var(--radius-full);background:var(--color-accent);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);border:none;cursor:pointer;z-index:var(--z-dropdown);transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent}.fab:hover{background:#b8943e;box-shadow:var(--shadow-xl);transform:scale(1.05)}.fab:active{transform:scale(.95)}.confirm-bar{display:flex;gap:var(--space-sm);padding:var(--space-md);background:var(--color-surface);border-top:1px solid var(--color-border-light);position:sticky;bottom:var(--bottom-nav-height)}.confirm-bar .btn{flex:1}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.animate-fade-in{animation:fadeIn var(--transition-normal) ease}.animate-slide-up{animation:slideUp var(--transition-normal) ease}.animate-scale-in{animation:scaleIn var(--transition-normal) ease}@media(min-width:640px){.item-grid{grid-template-columns:repeat(3,1fr)}.stat-grid{grid-template-columns:repeat(4,1fr)}.modal{border-radius:var(--radius-xl);max-width:540px;margin:auto}.modal-overlay{align-items:center;padding:var(--space-lg)}.image-preview-grid{grid-template-columns:repeat(4,1fr)}}@media(min-width:1024px){.app-layout{flex-direction:row}.bottom-nav{position:fixed;top:0;left:0;bottom:0;right:auto;width:var(--sidebar-width);height:100dvh;flex-direction:column;justify-content:flex-start;align-items:stretch;padding:var(--space-lg) var(--space-sm);gap:var(--space-xs);border-top:none;border-right:1px solid var(--color-border-light);box-shadow:none}.nav-item{flex-direction:row;justify-content:flex-start;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--font-size-body-small);min-width:auto}.nav-item.active{background:var(--color-accent-alpha-15)}.app-main{margin-left:var(--sidebar-width);padding-bottom:0}.fab{bottom:var(--space-lg)}.confirm-bar{bottom:0}.item-grid{grid-template-columns:repeat(4,1fr)}.image-preview-grid{grid-template-columns:repeat(5,1fr)}}@media(min-width:1400px){.item-grid{grid-template-columns:repeat(5,1fr)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}html{scroll-behavior:auto}}@supports (padding: env(safe-area-inset-bottom)){.bottom-nav{padding-bottom:env(safe-area-inset-bottom);height:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom))}.app-main{padding-bottom:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom))}.fab{bottom:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom) + var(--space-md))}}
