@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial}}}@layer theme{:root,:host{--font-sans:"DM Sans", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--color-red-50:#fef2f2;--color-red-500:#fb2c36;--color-red-700:#bf000f;--color-yellow-500:#edb200;--color-yellow-700:#a36100;--color-green-500:#00c758;--color-green-700:#008138;--color-blue-50:#eff6ff;--color-blue-700:#1447e6;--color-gray-100:#f3f4f6;--color-white:#fff;--spacing:.25rem;--radius-sm:.5rem;--radius-md:.625rem;--radius-lg:1rem;--radius-xl:1.25rem;--radius-2xl:1.5rem;--animate-spin:spin 1s linear infinite;--animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-primary:#568f73;--color-primary-hover:#467c61;--color-primary-light:#e6f0eb;--color-primary-gradient:linear-gradient(135deg, #467c61 0%, #609f80 100%);--color-status-ok:#30a661;--color-status-ok-bg:#eaf6ef;--color-status-warning:#d6931f;--color-status-warning-bg:#f9f2e7;--color-status-critical:#c43131;--color-status-critical-bg:#f9ecec;--color-surface:#fbfaf9;--color-surface-secondary:#f9f7f6;--color-surface-tertiary:#f0edea;--color-surface-elevated:#e9e6e2;--color-border:#e5e0dc;--color-border-strong:#cec7c0;--color-text-primary:#272e35;--color-text-secondary:#606b76;--color-text-muted:#8b949c;--color-rose-light:#f4ebed;--color-petrol:#275768;--color-gold:#cfab59;--color-gold-light:#f4eee1;--color-camera-bg:#000;--color-viewfinder:#fff;--color-success-bg:#edf7f1;--font-heading:"DM Serif Display", Georgia, "Times New Roman", serif;--font-accent:"Caveat", cursive;--spacing-page:1.25rem;--radius-full:9999px}@supports (color:lab(0% 0 0)){:root,:host{--color-red-50:lab(96.5005% 4.18508 1.52328);--color-red-500:lab(55.4814% 75.0732 48.8528);--color-red-700:lab(40.4273% 67.2623 53.7441);--color-yellow-500:lab(76.3898% 14.5258 98.4589);--color-yellow-700:lab(47.8202% 25.2426 66.5015);--color-green-500:lab(70.5521% -66.5147 45.8073);--color-green-700:lab(47.0329% -47.0239 31.4788);--color-blue-50:lab(96.492% -1.14644 -5.11479);--color-blue-700:lab(36.9089% 35.0961 -85.6872);--color-gray-100:lab(96.1596% -.0823438 -1.13575)}}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.contents{display:contents}.flex{display:flex}.hidden{display:none}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-pulse{animation:var(--animate-pulse)}.animate-spin{animation:var(--animate-spin)}.items-center{align-items:center}.gap-2{gap:calc(var(--spacing) * 2)}.rounded-md{border-radius:var(--radius-md)}.border{border-style:var(--tw-border-style);border-width:1px}.bg-blue-50{background-color:var(--color-blue-50)}.bg-green-500{background-color:var(--color-green-500)}.bg-red-50{background-color:var(--color-red-50)}.bg-red-500{background-color:var(--color-red-500)}.bg-yellow-500{background-color:var(--color-yellow-500)}.p-3{padding:calc(var(--spacing) * 3)}.text-blue-700{color:var(--color-blue-700)}.text-green-700{color:var(--color-green-700)}.text-red-700{color:var(--color-red-700)}.text-white{color:var(--color-white)}.text-yellow-700{color:var(--color-yellow-700)}.underline{text-decoration-line:underline}.opacity-30{opacity:.3}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.disabled\:animate-pulse:disabled{animation:var(--animate-pulse)}.disabled\:bg-gray-100:disabled{background-color:var(--color-gray-100)}.disabled\:opacity-50:disabled{opacity:.5}}:root{--color-primary:#568f73;--color-primary-hover:#467c61;--color-primary-light:#e6f0eb;--color-primary-gradient:linear-gradient(135deg, #467c61 0%, #609f80 100%);--color-status-ok:#30a661;--color-status-ok-bg:#eaf6ef;--color-status-warning:#d6931f;--color-status-warning-bg:#f9f2e7;--color-status-critical:#c43131;--color-status-critical-bg:#f9ecec;--color-surface:#fbfaf9;--color-surface-secondary:#f9f7f6;--color-surface-tertiary:#f0edea;--color-surface-elevated:#e9e6e2;--color-border:#e5e0dc;--color-border-strong:#cec7c0;--color-text-primary:#272e35;--color-text-secondary:#606b76;--color-text-muted:#8b949c;--color-rose:#cda2a9;--color-rose-light:#f4ebed;--color-petrol:#275768;--color-gold:#cfab59;--color-gold-light:#f4eee1;--color-camera-bg:#000;--color-viewfinder:#fff;--color-success-bg:#edf7f1;--font-heading:"DM Serif Display", Georgia, "Times New Roman", serif;--font-sans:"DM Sans", system-ui, -apple-system, sans-serif;--font-accent:"Caveat", cursive;--font-mono:"JetBrains Mono", "Fira Code", monospace;--spacing-page:1.25rem;--radius-sm:.5rem;--radius-md:.625rem;--radius-lg:1rem;--radius-xl:1.25rem;--radius-2xl:1.5rem;--radius-full:9999px}*,:before,:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light only;font-size:16px}body{font-family:var(--font-sans);color:var(--color-text-primary);background-color:var(--color-surface-secondary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;letter-spacing:-.005em;min-height:100dvh;margin:0;padding:0;line-height:1.6}h1,.heading-1{font-family:var(--font-heading);letter-spacing:-.01em;font-weight:400}h2,.heading-2{font-family:var(--font-heading);font-weight:400}.accent-text{font-family:var(--font-accent)}@keyframes pageEnter{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.page-enter{animation:.3s ease-out pageEnter}.hidden{display:none!important}body:after{content:"";pointer-events:none;z-index:-1;opacity:.15;background:radial-gradient(70% 50% at 15% 25%,#e3ede8 0%,#0000 65%),radial-gradient(50% 40% at 80% 70%,#f1e9eb 0%,#0000 60%),radial-gradient(45% 35% at 55% 15%,#f3f0e7 0%,#0000 55%);animation:55s ease-in-out infinite breathe;position:fixed;inset:0}body:before{content:"";pointer-events:none;z-index:-2;opacity:.85;background-image:url(/illustrations/Baggrund_landingPage.jpeg);background-position:50%;background-repeat:no-repeat;background-size:cover;background-attachment:fixed;animation:30s ease-in-out infinite alternate ambientBgMove;position:fixed;inset:-5%}@keyframes ambientBgMove{0%{transform:scale(1)translate(0)}50%{transform:scale(1.03)translate(-1%,2%)}to{transform:scale(1.05)translate(1%,-1%)}}@keyframes breathe{0%,to{opacity:.28;transform:scale(1)translate(0)}20%{opacity:.42;transform:scale(1.06)translate(3%,-2%)}40%{opacity:.32;transform:scale(1.03)translate(-1%,3%)}60%{opacity:.38;transform:scale(1.05)translate(-3%,-1%)}80%{opacity:.44;transform:scale(1.07)translate(2%,1%)}}@keyframes bloomIn{0%{opacity:0;filter:blur(2px);transform:translateY(18px)scale(.96)rotate(.5deg)}60%{opacity:.85;filter:blur();transform:translateY(-2px)scale(1.005)rotate(-.1deg)}to{opacity:1;filter:blur();transform:translateY(0)scale(1)rotate(0)}}.bloom-item{animation:.6s cubic-bezier(.23,1,.32,1) both bloomIn;animation-delay:calc(var(--stagger-index,0) * 80ms)}@keyframes warmGlow{0%,to{box-shadow:0 4px 14px #5a9a6e33}50%{box-shadow:0 6px 28px #5a9a6e73,0 0 0 3px #5a9a6e14}}.camera-overlay{z-index:50;background-color:var(--color-camera-bg);position:fixed;inset:0}.camera-feed-container{flex-direction:column;width:100%;height:100%;display:flex;position:relative}.camera-video{object-fit:cover;width:100%;height:100%}.viewfinder{pointer-events:none;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.viewfinder-frame{border-radius:var(--radius-lg);border:2px solid #ffffff4d;width:280px;height:180px;position:relative}.viewfinder-corner{border-color:var(--color-viewfinder);border-style:solid;width:24px;height:24px;position:absolute}.viewfinder-corner-tl{border-top-left-radius:var(--radius-lg);border-width:3px 0 0 3px;top:-2px;left:-2px}.viewfinder-corner-tr{border-top-right-radius:var(--radius-lg);border-width:3px 3px 0 0;top:-2px;right:-2px}.viewfinder-corner-bl{border-bottom-left-radius:var(--radius-lg);border-width:0 0 3px 3px;bottom:-2px;left:-2px}.viewfinder-corner-br{border-bottom-right-radius:var(--radius-lg);border-width:0 3px 3px 0;bottom:-2px;right:-2px}.viewfinder-hint{color:#fffc;text-align:center;text-shadow:0 1px 3px #0009;margin-top:1rem;font-size:.875rem}.scanning-overlay{background:#0009;flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex;position:absolute;inset:0}.scanning-spinner{border:3px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:48px;height:48px;animation:.8s linear infinite spin}.scanning-text{color:#fff;font-size:1.125rem;font-weight:500}@keyframes spin{to{transform:rotate(360deg)}}.camera-controls{padding:1.5rem var(--spacing-page);background:linear-gradient(#0000,#000000b3);justify-content:space-around;align-items:center;display:flex;position:absolute;bottom:0;left:0;right:0}.camera-btn{border-radius:var(--radius-lg);cursor:pointer;border:none;flex-direction:column;align-items:center;gap:.25rem;min-width:64px;min-height:64px;padding:.75rem;font-size:.75rem;font-weight:500;transition:transform .15s,opacity .15s;display:flex}.camera-btn:active{transform:scale(.95)}.camera-btn:disabled{opacity:.5;cursor:not-allowed}.camera-btn-secondary{color:#fff;background:#ffffff26}.camera-btn-capture{background:var(--color-primary);color:#fff;border-radius:50%;min-width:80px;min-height:80px;font-size:.875rem;box-shadow:0 4px 14px #5a9a6e4d}.camera-btn-capture:hover:not(:disabled){background:var(--color-primary-hover)}.camera-fallback{height:100%;padding:var(--spacing-page);background:var(--color-surface);flex-direction:column;justify-content:center;align-items:center;display:flex}.camera-error-banner{background:var(--color-status-critical-bg);color:var(--color-status-critical);border-radius:var(--radius-md);text-align:center;width:100%;max-width:400px;margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.875rem}.camera-fallback-content{text-align:center;flex-direction:column;align-items:center;gap:1rem;display:flex}.camera-fallback-icon{color:var(--color-text-muted)}.camera-fallback-title{color:var(--color-text-primary);margin:0;font-size:1.25rem;font-weight:600}.camera-fallback-description{color:var(--color-text-secondary);margin:0}.camera-btn-upload-large{background:var(--color-primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;align-items:center;gap:.5rem;min-height:48px;padding:.875rem 1.5rem;font-size:1rem;font-weight:500;transition:background-color .15s;display:flex}.camera-btn-upload-large:hover{background:var(--color-primary-hover)}.camera-btn-back{border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;background:0 0;min-height:44px;padding:.5rem 1rem;font-size:.875rem}.review-btn-primary:hover:not(:disabled),.success-btn-primary:hover,.confirm-btn-primary:hover:not(:disabled),.review-screen{background:var(--color-surface);flex-direction:column;min-height:100dvh;display:flex}.review-header{padding:1rem var(--spacing-page);border-bottom:1px solid var(--color-border);background:var(--color-surface);z-index:10;align-items:center;gap:.75rem;display:flex;position:sticky;top:0}.review-back-btn{color:var(--color-primary);cursor:pointer;background:0 0;border:none;align-items:center;gap:.25rem;min-width:44px;min-height:44px;padding:.5rem;font-size:.875rem;display:flex}.review-title{margin:0;font-size:1.125rem;font-weight:600}.review-warning-banner{padding:.75rem var(--spacing-page);background:var(--color-status-warning-bg);color:var(--color-status-warning);align-items:flex-start;gap:.5rem;font-size:.875rem;line-height:1.4;display:flex}.review-warning-banner svg{flex-shrink:0;margin-top:.125rem}.review-warning-banner p{margin:0}.review-form{padding:1rem var(--spacing-page);flex-direction:column;flex:1;gap:1.25rem;display:flex;overflow-y:auto}.form-group{flex-direction:column;gap:.375rem;display:flex}.form-label{color:var(--color-text-primary);font-size:.875rem;font-weight:600}.form-input-wrapper{position:relative}.form-input{border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text-primary);background:var(--color-surface);min-height:48px;padding:.75rem 2.5rem .75rem .75rem;font-size:1rem;transition:border-color .15s,box-shadow .15s}.form-input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #5a9a6e1f}.form-input-error{border-color:var(--color-status-critical)}.form-input-error:focus{box-shadow:0 0 0 3px #dc26261a}.form-input-icon{color:var(--color-text-muted);pointer-events:none;position:absolute;top:50%;right:.75rem;transform:translateY(-50%)}.form-select-wrapper{flex-direction:column;gap:.25rem;display:flex}.form-select{border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text-primary);background:var(--color-surface);cursor:pointer;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='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;min-height:48px;padding:.75rem 2.5rem .75rem .75rem;font-size:1rem}.form-select:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #5a9a6e1f}.form-textarea{border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text-primary);background:var(--color-surface);resize:vertical;min-height:64px;padding:.75rem;font-family:inherit;font-size:1rem}.form-textarea:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #5a9a6e1f}.form-hint{color:var(--color-text-muted);font-size:.75rem}.quantity-control{border:1px solid var(--color-border);border-radius:var(--radius-md);align-items:center;gap:0;width:fit-content;display:flex;overflow:hidden}.quantity-btn{background:var(--color-surface-tertiary);width:48px;height:48px;color:var(--color-text-primary);cursor:pointer;border:none;justify-content:center;align-items:center;transition:background-color .15s;display:flex}.quantity-btn:hover:not(:disabled){background:var(--color-border)}.quantity-btn:disabled{opacity:.4;cursor:not-allowed}.quantity-input{border:none;border-left:1px solid var(--color-border);border-right:1px solid var(--color-border);text-align:center;width:64px;height:48px;color:var(--color-text-primary);background:var(--color-surface);font-size:1.125rem;font-weight:600}.quantity-input:focus{background:var(--color-primary-light);outline:none}.review-ocr-info{border-top:1px solid var(--color-border);flex-direction:column;gap:.5rem;margin-top:.5rem;padding-top:1rem;display:flex}.ocr-confidence{align-items:center;gap:.75rem;display:flex}.confidence-badge{border-radius:9999px;padding:.25rem .625rem;font-size:.75rem;font-weight:600}.confidence-high{background:var(--color-status-ok-bg);color:var(--color-status-ok)}.confidence-medium{background:var(--color-status-warning-bg);color:var(--color-status-warning)}.confidence-low{background:var(--color-status-critical-bg);color:var(--color-status-critical)}.processing-time{color:var(--color-text-muted);font-size:.75rem}.toggle-raw-text{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;align-items:center;gap:.375rem;padding:.375rem 0;font-size:.75rem;display:flex}.toggle-raw-text:hover{color:var(--color-text-secondary)}.raw-text-display{background:var(--color-surface-tertiary);border-radius:var(--radius-md);font-family:var(--font-mono);color:var(--color-text-secondary);white-space:pre-wrap;word-break:break-all;max-height:120px;padding:.75rem;font-size:.75rem;overflow-y:auto}.review-actions{padding:1rem var(--spacing-page);border-top:1px solid var(--color-border);background:var(--color-surface);gap:.75rem;display:flex;position:sticky;bottom:0}.review-btn{border-radius:var(--radius-md);cursor:pointer;border:none;flex:1;justify-content:center;align-items:center;gap:.5rem;min-height:52px;padding:.875rem 1rem;font-size:1rem;font-weight:600;transition:background-color .15s,transform .1s;display:flex}.review-btn:active:not(:disabled){transform:scale(.98)}.review-btn:disabled{opacity:.5;cursor:not-allowed}.review-btn-primary{background:var(--color-primary);color:#fff}.review-btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.review-btn-secondary{background:var(--color-surface-tertiary);color:var(--color-text-secondary);border:1px solid var(--color-border)}.review-btn-secondary:hover{background:var(--color-border)}.scan-menu{min-height:100dvh;padding:2rem var(--spacing-page);background:var(--color-surface-secondary);flex-direction:column;display:flex}.scan-menu-header{margin-bottom:2rem}.scan-menu-title{color:var(--color-text-primary);margin:0 0 .5rem;font-size:1.5rem;font-weight:700}.scan-menu-subtitle{color:var(--color-text-secondary);margin:0;font-size:1rem;line-height:1.5}.scan-menu-options{flex-direction:column;flex:1;gap:1rem;display:flex}.scan-option-card{border-radius:var(--radius-xl);cursor:pointer;text-align:left;border:none;align-items:flex-start;gap:1rem;min-height:88px;padding:1.25rem;transition:transform .15s,box-shadow .15s;display:flex}.scan-option-card:active{transform:scale(.98)}.scan-option-primary{background:var(--color-primary);color:#fff;box-shadow:0 4px 14px #5a9a6e40}.scan-option-primary:hover{box-shadow:0 6px 20px #5a9a6e4d}.scan-option-secondary{background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border);box-shadow:0 1px 3px #0000000d}.scan-option-secondary:hover{box-shadow:0 4px 12px #00000014}.scan-option-icon{border-radius:var(--radius-lg);background:#ffffff26;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.scan-option-secondary .scan-option-icon{background:var(--color-surface-tertiary);color:var(--color-primary)}.scan-option-text h2{margin:0 0 .25rem;font-size:1.125rem;font-weight:600}.scan-option-text p{opacity:.85;margin:0;font-size:.875rem;line-height:1.4}.scan-option-primary .scan-option-text p{color:#ffffffd9}.scan-option-secondary .scan-option-text p{color:var(--color-text-secondary)}.scan-adapter-status{color:var(--color-text-muted);align-items:center;gap:.5rem;margin-top:2rem;padding:.75rem;font-size:.75rem;display:flex}.adapter-dot{border-radius:50%;width:8px;height:8px}.adapter-ready{background:var(--color-status-ok)}.adapter-loading{background:var(--color-status-warning);animation:1.5s ease-in-out infinite pulse}@keyframes pulse{50%{opacity:.5}}.scan-success{min-height:100dvh;padding:var(--spacing-page);background:var(--color-success-bg);justify-content:center;align-items:center;display:flex}.success-content{text-align:center;flex-direction:column;align-items:center;gap:1rem;max-width:360px;display:flex}.success-icon{background:var(--color-status-ok);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;animation:.4s cubic-bezier(.34,1.56,.64,1) scaleIn;display:flex}@keyframes scaleIn{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.success-title{color:var(--color-text-primary);margin:0;font-size:1.5rem;font-weight:700}.success-description{color:var(--color-text-secondary);margin:0}.success-actions{flex-direction:column;gap:.75rem;width:100%;margin-top:1rem;display:flex}.success-btn{border-radius:var(--radius-md);cursor:pointer;border:none;justify-content:center;align-items:center;gap:.5rem;min-height:52px;padding:.875rem 1rem;font-size:1rem;font-weight:600;text-decoration:none;transition:background-color .15s;display:flex}.success-btn-primary{background:var(--color-primary);color:#fff}.success-btn-primary:hover{background:var(--color-primary-hover)}.success-btn-secondary{background:var(--color-surface);color:var(--color-text-secondary);border:1px solid var(--color-border)}.scan-loading{flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:100dvh;display:flex}.scan-loading-spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.scan-loading p{color:var(--color-text-secondary);font-size:.875rem}@media (min-width:640px){.scan-menu{max-width:540px;margin:0 auto;padding:3rem 2rem}.review-form{max-width:540px;margin:0 auto}.review-actions{max-width:540px;margin:0 auto;padding-left:0;padding-right:0}.viewfinder-frame{width:360px;height:240px}.dashboard{max-width:100%;padding:2rem}.summary-cards{grid-template-columns:repeat(4,1fr)}.detail-page{max-width:640px;margin:0 auto}}@media (min-width:1024px){.bottom-nav{border-top:none;border-right:1px solid var(--color-border);flex-direction:column;align-items:stretch;gap:.25rem;width:240px;padding:1.5rem .75rem;position:fixed;inset:0 auto 0 0;overflow-y:auto;box-shadow:4px 0 24px #1e191408}.bottom-nav-item{border-radius:var(--radius-md);flex-direction:row;flex:none;justify-content:flex-start;gap:.75rem;min-height:48px;padding:.75rem 1rem;font-size:.9375rem;transition:background .2s ease-out,color .2s ease-out}.bottom-nav-item:hover{background:var(--color-surface-tertiary);color:var(--color-text-primary)}.bottom-nav-active{background:var(--color-primary-light);color:var(--color-primary);font-weight:600}.app-main{margin-left:240px;padding-bottom:0}.dashboard{max-width:1000px;padding:2rem 2.5rem}.scan-menu{max-width:600px}.product-list-items{grid-template-columns:repeat(2,1fr);gap:.75rem;display:grid}.detail-page{max-width:720px}}@media (min-width:1440px){.dashboard{max-width:1200px;padding:2.5rem 3rem}.dashboard-title{font-size:2rem}.product-list-items{grid-template-columns:repeat(3,1fr);gap:1rem}.summary-cards{gap:1rem}.detail-page{max-width:800px}}.app-main{padding-bottom:72px}.dashboard-retry-btn:hover,.dashboard-header{z-index:1;justify-content:space-between;align-items:flex-start;display:flex;position:relative}.dashboard-welcome{font-family:var(--font-heading);color:var(--color-text-primary);letter-spacing:-.015em;margin:0;font-size:2rem;font-weight:400;line-height:1.2}.dashboard-title{font-family:var(--font-heading);color:var(--color-text-primary);letter-spacing:-.01em;margin:0;font-size:1.75rem;font-weight:400}.dashboard-subtitle{color:var(--color-text-muted);letter-spacing:.005em;margin:.35rem 0 0;font-size:.875rem;font-weight:400}.dashboard-loading{flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:60dvh;display:flex}.dashboard-loading p{color:var(--color-text-secondary);font-size:.875rem}.dashboard-error{min-height:60dvh;padding:var(--spacing-page);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex}.dashboard-error-text{color:var(--color-status-critical);font-size:.875rem}.dashboard-retry-btn{background:var(--color-primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;min-height:44px;padding:.75rem 1.5rem;font-size:.875rem;font-weight:600}.summary-cards{grid-template-columns:repeat(2,1fr);gap:.75rem;display:grid}.summary-card{border-radius:var(--radius-lg);border:1px solid var(--color-border);-webkit-backdrop-filter:blur(12px);cursor:pointer;text-align:left;background:#fbfaf9b3;align-items:center;gap:.75rem;min-height:72px;padding:1rem;transition:box-shadow .25s ease-out,transform .2s ease-out;display:flex;box-shadow:0 1px 4px #1e19140a}.summary-card:hover{transform:translateY(-1px);box-shadow:0 4px 16px #1e19140f}.summary-card:active{transform:scale(.97)}.summary-card-active{box-shadow:0 0 0 2px var(--color-primary), 0 4px 16px #5a9a6e26}.summary-card-icon{border-radius:var(--radius-lg);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.summary-card-neutral .summary-card-icon{background:var(--color-surface-tertiary);color:var(--color-primary)}.summary-card-warning .summary-card-icon{background:var(--color-status-warning-bg);color:var(--color-status-warning)}.summary-card-critical .summary-card-icon{background:var(--color-status-critical-bg);color:var(--color-status-critical)}.summary-card-content{flex-direction:column;display:flex}.summary-card-count{color:var(--color-text-primary);letter-spacing:-.02em;font-size:1.375rem;font-weight:700;line-height:1.2}.summary-card-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.6875rem;font-weight:500;line-height:1.3}.search-filter{gap:.5rem;display:flex}.search-input-wrapper{flex:1;position:relative}.search-icon{color:var(--color-text-muted);pointer-events:none;position:absolute;top:50%;left:.75rem;transform:translateY(-50%)}.search-input{border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text-primary);background:var(--color-surface);min-height:44px;padding:.625rem 2.25rem .625rem 2.5rem;font-size:.875rem}.search-input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #5a9a6e1f}.search-input::placeholder{color:var(--color-text-muted)}.search-clear{background:var(--color-surface-tertiary);width:24px;height:24px;color:var(--color-text-muted);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;right:.5rem;transform:translateY(-50%)}.category-select{border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);background:var(--color-surface);cursor:pointer;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='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right .5rem center;background-repeat:no-repeat;min-width:0;max-width:130px;min-height:44px;padding:.625rem 2rem .625rem .75rem;font-size:.875rem}.product-list{flex-direction:column;gap:.5rem;display:flex}.product-list-header{justify-content:space-between;align-items:center;display:flex}.product-list-count{color:var(--color-text-muted);font-size:.75rem}.product-list-items{flex-direction:column;gap:.5rem;display:flex}.product-card{-webkit-backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:inherit;background:#fbfaf9bf;gap:0;min-height:88px;text-decoration:none;transition:box-shadow .25s ease-out,transform .2s ease-out;display:flex;overflow:hidden;box-shadow:0 1px 4px #1e19140a}.product-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #1e19140f}.product-card:active{transform:scale(.98)}.product-card-indicator{flex-shrink:0;width:5px}.product-indicator-ok{background:var(--color-status-ok)}.product-indicator-warning{background:var(--color-status-warning)}.product-indicator-critical{background:var(--color-status-critical)}.product-card-body{flex-direction:column;flex:1;gap:.5rem;min-width:0;padding:1rem;display:flex}.product-card-header{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.product-card-name{color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;letter-spacing:-.01em;margin:0;font-size:1rem;font-weight:600;overflow:hidden}.product-card-details{flex-direction:column;gap:.25rem;display:flex}.product-detail{color:var(--color-text-secondary);align-items:center;gap:.375rem;font-size:.8125rem;display:flex}.product-detail svg{color:var(--color-text-muted);flex-shrink:0}.product-low-stock-hint{color:var(--color-status-warning);font-weight:600}.product-empty-hint{color:var(--color-status-critical);font-weight:600}.product-category-tag{border-radius:var(--radius-full);background:var(--color-surface-tertiary);width:fit-content;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;padding:.1875rem .625rem;font-size:.6875rem;font-weight:500;display:inline-block}.status-badge{border-radius:var(--radius-full);white-space:nowrap;text-transform:uppercase;letter-spacing:.04em;flex-shrink:0;align-items:center;padding:.1875rem .625rem;font-size:.6875rem;font-weight:600;display:inline-flex}.status-badge-ok{background:var(--color-status-ok-bg);color:var(--color-status-ok)}.status-badge-warning{background:var(--color-status-warning-bg);color:var(--color-status-warning)}.status-badge-critical{background:var(--color-status-critical-bg);color:var(--color-status-critical)}.empty-state{text-align:center;color:var(--color-text-muted);flex-direction:column;align-items:center;gap:.5rem;padding:2.5rem 1rem;animation:.4s ease-out pageEnter;display:flex}.empty-state-title{font-family:var(--font-heading);color:var(--color-text-secondary);margin:0;font-size:1.125rem;font-weight:400}.empty-state-text{color:var(--color-text-muted);max-width:300px;margin:0;font-size:1rem;line-height:1.5}.detail-page{background:var(--color-surface);flex-direction:column;min-height:100dvh;display:flex}.detail-header{padding:.75rem var(--spacing-page);border-bottom:1px solid var(--color-border);background:var(--color-surface);z-index:10;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.detail-header-actions{gap:.375rem;display:flex}.detail-action-btn{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;align-items:center;gap:.25rem;min-height:40px;padding:.5rem .75rem;font-size:.8125rem;transition:background-color .15s;display:flex}.detail-action-btn:hover{background:var(--color-surface-tertiary)}.detail-action-destructive{color:var(--color-status-critical);border-color:var(--color-status-critical-bg)}.detail-action-destructive:hover{background:var(--color-status-critical-bg)}.detail-content{padding:1.25rem var(--spacing-page);flex-direction:column;flex:1;gap:1.25rem;display:flex}.detail-title-row{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.detail-title{margin:0;font-size:1.375rem;font-weight:700}.detail-fields{flex-direction:column;gap:1rem;display:flex}.detail-field{border-bottom:1px solid var(--color-border);flex-direction:column;gap:.25rem;padding-bottom:.75rem;display:flex}.detail-field:last-child{border-bottom:none}.detail-field-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.02em;align-items:center;gap:.375rem;font-size:.75rem;font-weight:600;display:flex}.detail-field-label svg{flex-shrink:0}.detail-field-value{color:var(--color-text-primary);font-size:1rem;font-weight:500}.detail-field-value-group{align-items:center;gap:.5rem;display:flex}.detail-expiry-label{border-radius:9999px;padding:.125rem .5rem;font-size:.75rem;font-weight:600}.detail-expiry-ok{background:var(--color-status-ok-bg);color:var(--color-status-ok)}.detail-expiry-warning{background:var(--color-status-warning-bg);color:var(--color-status-warning)}.detail-expiry-critical{background:var(--color-status-critical-bg);color:var(--color-status-critical)}.detail-quantity-control{flex-direction:column;gap:.375rem;display:flex}.detail-min-quantity{color:var(--color-text-muted);font-size:.75rem}.detail-notes{white-space:pre-wrap;font-weight:400;line-height:1.5}.detail-meta{color:var(--color-text-muted);border-top:1px solid var(--color-border);flex-direction:column;gap:.125rem;padding-top:1rem;font-size:.6875rem;display:flex}.quantity-display{width:64px;height:48px;color:var(--color-text-primary);border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);justify-content:center;align-items:center;font-size:1.125rem;font-weight:600;display:flex}.confirm-overlay{z-index:60;padding:var(--spacing-page);background:#0006;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confirm-dialog{background:var(--color-surface);border-radius:var(--radius-xl);text-align:center;flex-direction:column;align-items:center;gap:.75rem;width:100%;max-width:340px;padding:1.5rem;animation:.2s cubic-bezier(.34,1.56,.64,1) scaleIn;display:flex;box-shadow:0 20px 60px #00000026}.confirm-icon{border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.confirm-icon-destructive{background:var(--color-status-critical-bg);color:var(--color-status-critical)}.confirm-title{margin:0;font-size:1.125rem;font-weight:600}.confirm-message{color:var(--color-text-secondary);margin:0;font-size:.875rem;line-height:1.5}.confirm-actions{gap:.5rem;width:100%;margin-top:.5rem;display:flex}.confirm-btn{border-radius:var(--radius-md);cursor:pointer;border:none;flex:1;min-height:44px;padding:.75rem 1rem;font-size:.875rem;font-weight:600;transition:background-color .15s}.confirm-btn:disabled{opacity:.5;cursor:not-allowed}.confirm-btn-cancel{background:var(--color-surface-tertiary);color:var(--color-text-secondary)}.confirm-btn-cancel:hover:not(:disabled){background:var(--color-border)}.confirm-btn-primary{background:var(--color-primary);color:#fff}.confirm-btn-destructive{background:var(--color-status-critical);color:#fff}.confirm-btn-destructive:hover:not(:disabled){background:#ab2b2b}.dashboard-user-section{align-items:center;gap:.5rem;display:flex}.dashboard-user-name{color:var(--color-text-secondary);font-size:.8125rem;font-weight:500;display:none}@media (min-width:640px){.dashboard-user-name{display:inline}}.dashboard-logout-btn{border-radius:var(--radius-lg);background:var(--color-surface-tertiary);width:40px;height:40px;color:var(--color-text-muted);cursor:pointer;border:none;justify-content:center;align-items:center;transition:background .2s,color .2s;display:flex}.dashboard-logout-btn:hover{background:var(--color-status-critical-bg);color:var(--color-status-critical)}.audit-log-list{flex-direction:column;gap:1rem;display:flex}.audit-log-filters{flex-wrap:wrap;gap:.75rem;display:flex}.audit-filter-group{color:var(--color-text-muted);align-items:center;gap:.5rem;display:flex}.audit-log-count{color:var(--color-text-muted);font-size:.8125rem}.audit-entries{flex-direction:column;gap:0;display:flex}.audit-entry{background:var(--color-surface);border:1px solid var(--color-border);border-bottom:none;gap:.75rem;padding:.875rem 1rem;transition:background .15s;display:flex}.audit-entry:first-child{border-radius:var(--radius-lg) var(--radius-lg) 0 0}.audit-entry:last-child{border-bottom:1px solid var(--color-border);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.audit-entry:only-child{border-bottom:1px solid var(--color-border);border-radius:var(--radius-lg)}.audit-entry:hover{background:var(--color-surface-secondary)}.audit-entry-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;margin-top:.125rem;display:flex}.audit-action-created{background:var(--color-status-ok-bg);color:var(--color-status-ok)}.audit-action-updated{background:var(--color-primary-light);color:var(--color-primary)}.audit-action-deleted{background:var(--color-status-critical-bg);color:var(--color-status-critical)}.audit-action-used{background:var(--color-status-warning-bg);color:var(--color-status-warning)}.audit-entry-content{flex:1;min-width:0}.audit-entry-header{align-items:baseline;gap:.5rem;display:flex}.audit-entry-action{color:var(--color-text-primary);font-size:.875rem;font-weight:600}.audit-entry-table{color:var(--color-text-secondary);font-size:.8125rem}.audit-entry-changes{flex-direction:column;gap:.125rem;margin-top:.375rem;display:flex}.audit-entry-change{color:var(--color-text-secondary);font-size:.8125rem;font-family:var(--font-mono);background:var(--color-surface-secondary);border-radius:var(--radius-sm);padding:.125rem .375rem;display:inline-block}.audit-entry-meta{gap:.75rem;margin-top:.375rem;display:flex}.audit-entry-actor,.audit-entry-time{color:var(--color-text-muted);font-size:.75rem}.audit-load-more{background:var(--color-surface-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-primary);cursor:pointer;text-align:center;min-height:44px;padding:.75rem 1rem;font-size:.875rem;font-weight:500;transition:background .15s;display:block}.audit-load-more:hover{background:var(--color-surface-tertiary)}.search-clear{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;align-items:center;padding:.25rem;display:flex;position:absolute;top:50%;right:.75rem;transform:translateY(-50%)}.search-input-wrapper{flex:1;min-width:200px;position:relative}.fab-group{z-index:40;align-items:center;gap:.75rem;display:flex;position:fixed;bottom:88px;left:50%;transform:translate(-50%)}.scan-fab{border-radius:var(--radius-full);background:var(--color-primary);color:#fff;cursor:pointer;border:none;align-items:center;gap:.375rem;min-width:48px;height:48px;padding:0 1rem;font-size:.875rem;font-weight:600;transition:transform .15s,box-shadow .15s;animation:.4s ease-out both scan-fab-entrance;display:flex;box-shadow:0 4px 14px #5a9a6e59,0 2px 6px #0000001a}.scan-fab:hover{transform:scale(1.05);box-shadow:0 6px 20px #5a9a6e73,0 3px 10px #0000001f}.scan-fab:active{transform:scale(.96)}@keyframes scan-fab-entrance{0%{opacity:0;transform:scale(.8)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.admin-save-btn:hover:not(:disabled),.btn-primary:hover:not(:disabled),.admin-page{padding:1.5rem var(--spacing-page);flex-direction:column;gap:1.5rem;display:flex}.admin-header{align-items:flex-start;gap:.75rem;display:flex}.admin-back-btn{border-radius:var(--radius-lg);background:var(--color-surface-tertiary);width:44px;height:44px;color:var(--color-text-muted);cursor:pointer;border:none;flex-shrink:0;justify-content:center;align-items:center;margin-top:.125rem;transition:background .2s,color .2s;display:flex}.admin-back-btn:hover{background:var(--color-surface-elevated);color:var(--color-text-primary)}.admin-header-content{flex:1}.admin-header-title-row{align-items:center;gap:.5rem;display:flex}.admin-header-icon{color:var(--color-primary)}.admin-header-title{color:var(--color-text-primary);letter-spacing:-.02em;margin:0;font-size:1.5rem;font-weight:700}.admin-header-subtitle{color:var(--color-text-muted);margin:.25rem 0 0;font-size:.875rem;font-weight:500}.admin-loading,.admin-loading-content{flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:40dvh;display:flex}.admin-loading p,.admin-loading-content p{color:var(--color-text-muted);font-size:.875rem}.admin-error{background:var(--color-status-critical-bg);border-radius:var(--radius-xl);text-align:center;padding:1rem}.admin-error p{color:var(--color-status-critical);margin:0 0 .75rem;font-size:.875rem}.admin-success-banner{background:var(--color-status-ok-bg);border-radius:var(--radius-xl);text-align:center;padding:1rem}.admin-success-banner p{color:var(--color-status-ok);margin:0 0 .75rem;font-size:.875rem;font-weight:500}.admin-retry-btn{background:var(--color-primary);color:#fff;border-radius:var(--radius-full);cursor:pointer;border:none;min-height:44px;padding:.75rem 1.5rem;font-size:.875rem;font-weight:600}.admin-content{flex-direction:column;gap:1.5rem;display:flex}.admin-stats-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;display:grid}.admin-stat-card{border-radius:var(--radius-2xl);background:var(--color-surface);align-items:center;gap:.75rem;min-height:72px;padding:1rem;display:flex;box-shadow:0 1px 4px #1e19140a}.admin-stat-icon{border-radius:var(--radius-lg);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.admin-stat-primary .admin-stat-icon{background:var(--color-primary-light);color:var(--color-primary)}.admin-stat-info .admin-stat-icon{background:var(--color-surface-tertiary);color:var(--color-primary)}.admin-stat-warning .admin-stat-icon{background:var(--color-status-warning-bg);color:var(--color-status-warning)}.admin-stat-muted .admin-stat-icon{background:var(--color-surface-tertiary);color:var(--color-text-muted)}.admin-stat-content{flex-direction:column;display:flex}.admin-stat-value{color:var(--color-text-primary);letter-spacing:-.02em;font-size:1.25rem;font-weight:700;line-height:1.2}.admin-stat-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.6875rem;font-weight:500}.admin-section{background:var(--color-surface);border-radius:var(--radius-2xl);padding:1.5rem;box-shadow:0 1px 4px #1e19140a}.admin-section-header{align-items:center;gap:.625rem;margin-bottom:1.25rem;display:flex}.admin-section-icon{color:var(--color-primary)}.admin-section-title{color:var(--color-text-primary);letter-spacing:-.01em;margin:0;font-size:1.125rem;font-weight:600}.admin-settings-form{flex-direction:column;gap:1rem;display:flex}.admin-settings-form .form-input{background:var(--color-surface-tertiary);border-radius:var(--radius-lg);border:none;min-height:48px;padding:.875rem 1rem;font-size:1rem;transition:background .2s,box-shadow .2s}.admin-settings-form .form-input:focus{background:var(--color-surface);box-shadow:0 0 0 2px var(--color-primary);outline:none}.admin-form-row{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}@media (max-width:480px){.admin-form-row{grid-template-columns:1fr}}.admin-warning-days-control{align-items:center;gap:.75rem;display:flex}.admin-range-slider{height:6px;accent-color:var(--color-primary);cursor:pointer;flex:1}.admin-warning-days-value{color:var(--color-text-primary);min-width:56px;font-size:.9375rem;font-weight:600}.admin-form-actions{align-items:center;gap:1rem;margin-top:.5rem;display:flex}.admin-save-btn{background:var(--color-primary-gradient);color:#fff;border-radius:var(--radius-full);cursor:pointer;border:none;align-items:center;gap:.5rem;min-height:48px;padding:.875rem 1.5rem;font-size:.9375rem;font-weight:600;transition:transform .15s,box-shadow .2s;display:flex;box-shadow:0 4px 14px #5a9a6e33}.admin-save-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #5a9a6e4d}.admin-save-btn:disabled{opacity:.5;cursor:not-allowed}.admin-save-message{border-radius:var(--radius-full);padding:.5rem 1rem;font-size:.875rem;font-weight:500}.admin-save-success{background:var(--color-status-ok-bg);color:var(--color-status-ok)}.admin-save-error{background:var(--color-status-critical-bg);color:var(--color-status-critical)}.admin-user-list{flex-direction:column;gap:.5rem;display:flex}.admin-user-card{background:var(--color-surface-secondary);border-radius:var(--radius-xl);align-items:center;gap:.75rem;padding:1rem;transition:background .2s;display:flex}.admin-user-card:hover{background:var(--color-surface-tertiary)}.admin-user-avatar{border-radius:var(--radius-lg);background:var(--color-primary-light);width:40px;height:40px;color:var(--color-primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.admin-user-info{flex-direction:column;flex:1;gap:.125rem;min-width:0;display:flex}.admin-user-name-row{align-items:center;gap:.5rem;display:flex}.admin-user-name{color:var(--color-text-primary);font-size:.9375rem;font-weight:600}.admin-role-badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;padding:.125rem .5rem;font-size:.625rem;font-weight:600}.admin-role-admin{background:var(--color-primary-light);color:var(--color-primary)}.admin-role-staff{background:var(--color-surface-tertiary);color:var(--color-text-muted)}.admin-user-email{color:var(--color-text-secondary);font-size:.8125rem}.admin-user-date{color:var(--color-text-muted);font-size:.6875rem}.admin-empty-text{color:var(--color-text-muted);text-align:center;padding:1.5rem 0;font-size:.875rem}@media (min-width:640px){.admin-page{max-width:100%}.admin-stats-grid{grid-template-columns:repeat(4,1fr)}}@media (min-width:1024px){.admin-page{max-width:1000px}.admin-user-list{grid-template-columns:repeat(2,1fr);gap:.75rem;display:grid}}@media (min-width:1440px){.admin-page{max-width:1200px}}.global-admin-page{max-width:100%}@media (min-width:1024px){.global-admin-page{max-width:1000px}}@media (min-width:1440px){.global-admin-page{max-width:1200px}}.global-stats{grid-template-columns:repeat(3,1fr);gap:.75rem;display:grid}.global-stat-card{border-radius:var(--radius-2xl);background:var(--color-surface);color:var(--color-primary);align-items:center;gap:.75rem;padding:1rem;display:flex;box-shadow:0 1px 4px #1e19140a}.global-stat-active{color:var(--color-status-ok)}.global-stat-value{color:var(--color-text-primary);letter-spacing:-.02em;font-size:1.5rem;font-weight:700;line-height:1}.global-stat-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.6875rem;font-weight:500}.global-stat-card>div{flex-direction:column;gap:.125rem;display:flex}.global-tabs{background:var(--color-surface-secondary);border-radius:var(--radius-full);gap:.25rem;padding:.25rem;display:flex}.global-tab{border-radius:var(--radius-full);color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:.5rem;min-height:44px;padding:.75rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s;display:flex}.global-tab:hover{color:var(--color-text-primary)}.global-tab-active{background:var(--color-surface);color:var(--color-primary);font-weight:600;box-shadow:0 1px 4px #1e19140f}.global-create-btn{border:2px dashed var(--color-border);border-radius:var(--radius-xl);width:100%;color:var(--color-primary);cursor:pointer;background:0 0;align-items:center;gap:.5rem;min-height:48px;padding:.875rem 1.25rem;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.global-create-btn:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.global-create-form{-webkit-backdrop-filter:blur(16px);border-radius:var(--radius-2xl);background:#fbfaf9d9;border:1px solid #fff6;flex-direction:column;gap:1rem;padding:1.5rem;display:flex;box-shadow:0 4px 20px #1e191414}.global-create-title{color:var(--color-text-primary);margin:0;font-size:1.125rem;font-weight:600}.global-create-form-row{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}@media (max-width:480px){.global-create-form-row{grid-template-columns:1fr}}.global-submit-btn{background:var(--color-primary-gradient);color:#fff;border-radius:var(--radius-full);cursor:pointer;border:none;justify-content:center;align-items:center;gap:.5rem;min-height:48px;padding:.875rem 1.5rem;font-size:.9375rem;font-weight:600;transition:transform .15s,box-shadow .2s;display:flex;box-shadow:0 4px 14px #5a9a6e33}.global-submit-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #5a9a6e4d}.global-submit-btn:disabled{opacity:.5;cursor:not-allowed}.global-section{flex-direction:column;gap:.75rem;display:flex}.global-list{flex-direction:column;gap:.5rem;display:flex}.global-card{-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-2xl);background:#fbfaf9d9;border:1px solid #fff6;flex-direction:column;gap:.75rem;padding:1.25rem;transition:all .2s ease-out;display:flex;box-shadow:0 2px 10px #1e19140d}.global-card:hover{box-shadow:0 4px 12px #1e19140f}.global-card-inactive{opacity:.65}.global-card-main{align-items:flex-start;gap:.75rem;display:flex}.global-card-info{flex-direction:column;flex:1;gap:.25rem;min-width:0;display:flex}.global-card-title-row{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.global-card-name{color:var(--color-text-primary);margin:0;font-size:1rem;font-weight:600}.global-card-detail{color:var(--color-text-secondary);margin:0;font-size:.8125rem}.global-card-meta{color:var(--color-text-muted);margin:0;font-size:.6875rem}.global-status-badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;padding:.125rem .5rem;font-size:.625rem;font-weight:600}.global-status-active{background:var(--color-status-ok-bg);color:var(--color-status-ok)}.global-status-inactive{background:var(--color-status-critical-bg);color:var(--color-status-critical)}.global-role-badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;padding:.125rem .5rem;font-size:.625rem;font-weight:600}.global-role-global_admin{background:var(--color-gold-light);color:var(--color-gold)}.global-role-clinic_admin{background:var(--color-primary-light);color:var(--color-primary)}.global-role-staff{background:var(--color-surface-tertiary);color:var(--color-text-muted)}.global-card-actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.global-action-btn{border:1px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;background:var(--color-surface);min-height:36px;padding:.5rem 1rem;font-size:.8125rem;font-weight:500;transition:all .2s}.global-action-deactivate{color:var(--color-status-critical);border-color:var(--color-status-critical)}.global-action-deactivate:hover{background:var(--color-status-critical-bg)}.global-action-activate{color:var(--color-status-ok);border-color:var(--color-status-ok)}.global-action-activate:hover{background:var(--color-status-ok-bg)}.global-role-select{border-radius:var(--radius-lg);max-width:140px;min-height:36px;padding:.375rem .75rem;font-size:.8125rem}.global-filter-row{align-items:center;gap:.75rem;display:flex}.global-filter-select{max-width:280px;font-size:.875rem}@media (max-width:480px){.global-stats{grid-template-columns:1fr}.global-filter-row{flex-direction:column;align-items:flex-start}.global-filter-select{width:100%;max-width:100%}}.admin-user-inactive{opacity:.6}.admin-status-badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;padding:.0625rem .375rem;font-size:.5625rem;font-weight:600}.admin-status-inactive{background:var(--color-status-critical-bg);color:var(--color-status-critical)}.admin-role-global{background:var(--color-gold-light);color:var(--color-gold)}.admin-user-actions{flex-shrink:0;align-items:center;gap:.375rem;display:flex}.admin-role-select{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);max-width:110px;min-height:32px;padding:.25rem .5rem;font-size:.75rem}.admin-toggle-btn{border:1px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;background:var(--color-surface);min-height:32px;padding:.25rem .625rem;font-size:.6875rem;font-weight:500;transition:all .2s}.admin-toggle-deactivate{color:var(--color-status-critical);border-color:var(--color-status-critical)}.admin-toggle-deactivate:hover{background:var(--color-status-critical-bg)}.admin-toggle-activate{color:var(--color-status-ok);border-color:var(--color-status-ok)}.admin-toggle-activate:hover{background:var(--color-status-ok-bg)}@media (max-width:480px){.admin-user-card{flex-wrap:wrap}.admin-user-actions{justify-content:flex-end;width:100%}}.admin-feedback-panel{animation:.3s ease-out pageEnter}.quick-out-fab:hover,.scan-fab:hover,.quick-out-confirm-btn:hover:not(:disabled){animation:2s ease-in-out infinite warmGlow;transform:translateY(-1px)scale(1.01)}@media (prefers-reduced-motion:reduce){body:after,body:before{opacity:.2;animation:none}.bloom-item{opacity:1;filter:none;animation:none;transform:none}.login-submit-btn:hover:not(:disabled),.review-btn-primary:hover:not(:disabled),.success-btn-primary:hover,.confirm-btn-primary:hover:not(:disabled),.dashboard-retry-btn:hover,.quick-out-fab:hover,.scan-fab:hover,.admin-save-btn:hover:not(:disabled),.btn-primary:hover:not(:disabled),.quick-out-confirm-btn:hover:not(:disabled){animation:none}}.quick-out-fab{border-radius:var(--radius-full);background:var(--color-status-critical);color:#fff;cursor:pointer;border:none;align-items:center;gap:.375rem;min-width:48px;height:48px;padding:0 1rem;font-size:.875rem;font-weight:600;transition:transform .15s,box-shadow .15s;animation:2.5s ease-in-out infinite fab-pulse;display:flex;box-shadow:0 4px 14px #ba1a1a59,0 2px 6px #0000001f}.quick-out-fab:hover{transform:scale(1.05);box-shadow:0 6px 20px #ba1a1a73,0 3px 10px #00000026}.quick-out-fab:active{transform:scale(.97)}@keyframes fab-pulse{0%,to{box-shadow:0 4px 14px #ba1a1a59,0 2px 6px #0000001f}50%{box-shadow:0 4px 14px #ba1a1a59,0 2px 6px #0000001f,0 0 0 6px #ba1a1a1f}}@media (max-width:380px){.scan-fab span,.quick-out-fab span{display:none}.scan-fab,.quick-out-fab{justify-content:center;width:48px;padding:0}}.quick-out-modal{z-index:55;background:var(--color-surface);flex-direction:column;animation:.25s ease-out quickout-slide-up;display:flex;position:fixed;inset:0}@keyframes quickout-slide-up{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.quick-out-header{padding:.875rem var(--spacing-page);border-bottom:1px solid var(--color-border);background:var(--color-surface);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.quick-out-title{color:var(--color-text-primary);margin:0;font-size:1.25rem;font-weight:700}.quick-out-close-btn{border-radius:var(--radius-md);background:var(--color-surface-tertiary);width:44px;height:44px;color:var(--color-text-secondary);cursor:pointer;border:none;justify-content:center;align-items:center;transition:background-color .15s;display:flex}.quick-out-close-btn:hover{background:var(--color-surface-elevated)}.quick-out-tabs{padding:0 var(--spacing-page);border-bottom:1px solid var(--color-border);background:var(--color-surface);flex-shrink:0;gap:0;display:flex}.quick-out-tab{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;justify-content:center;align-items:center;gap:.5rem;min-height:48px;padding:.75rem 0;font-size:.9375rem;font-weight:500;transition:color .15s,border-color .15s;display:flex}.quick-out-tab:hover{color:var(--color-text-secondary)}.quick-out-tab-active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.quick-out-content{-webkit-overflow-scrolling:touch;flex:1;overflow-y:auto}.speed-search{flex-direction:column;height:100%;display:flex}.speed-search-input-wrapper{padding:.75rem var(--spacing-page);background:var(--color-surface);border-bottom:1px solid var(--color-border);flex-shrink:0;position:relative}.speed-search-icon{left:calc(var(--spacing-page) + .75rem);color:var(--color-text-muted);pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.speed-search-input{border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);width:100%;color:var(--color-text-primary);background:var(--color-surface-tertiary);min-height:48px;padding:.75rem .75rem .75rem 2.75rem;font-size:1rem;transition:border-color .15s,box-shadow .15s}.speed-search-input:focus{border-color:var(--color-primary);background:var(--color-surface);outline:none;box-shadow:0 0 0 3px #5a9a6e1f}.speed-search-input::placeholder{color:var(--color-text-muted)}.speed-search-list{padding:.5rem var(--spacing-page);flex:1;overflow-y:auto}.speed-search-empty{color:var(--color-text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:3rem 1rem;display:flex}.speed-search-empty p{margin:0;font-size:.9375rem}.speed-search-item{border-radius:var(--radius-lg);background:var(--color-surface);border:1px solid var(--color-border);align-items:center;gap:.75rem;margin-bottom:.5rem;padding:.75rem;transition:box-shadow .15s;display:flex}.speed-search-item:hover{box-shadow:0 2px 8px #0000000f}.speed-search-item-info{flex-direction:column;flex:1;gap:.25rem;min-width:0;display:flex}.speed-search-item-name{color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.9375rem;font-weight:600;overflow:hidden}.speed-search-item-meta{color:var(--color-text-muted);flex-wrap:wrap;align-items:center;gap:.625rem;font-size:.75rem;display:flex}.speed-search-item-lot{font-family:var(--font-mono);background:var(--color-surface-tertiary);border-radius:var(--radius-sm);padding:.125rem .375rem;font-size:.6875rem}.speed-search-item-exp{align-items:center;gap:.25rem;display:flex}.speed-search-item-qty{color:var(--color-text-secondary);font-weight:600}.speed-search-deduct-btn{border-radius:var(--radius-lg);background:var(--color-status-critical);color:#fff;cursor:pointer;border:none;flex-shrink:0;justify-content:center;align-items:center;gap:.125rem;width:56px;height:56px;font-size:1rem;font-weight:700;transition:transform .1s,background-color .15s;display:flex}.speed-search-deduct-btn:hover:not(:disabled){background:#ab2b2b}.speed-search-deduct-btn:active:not(:disabled){transform:scale(.92)}.speed-search-deduct-btn:disabled{opacity:.5;cursor:not-allowed}.quick-out-success-toast{z-index:60;background:#16a34af2;justify-content:center;align-items:center;animation:.2s ease-out toast-fade-in;display:flex;position:fixed;inset:0}@keyframes toast-fade-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.quick-out-success-content{text-align:center;flex-direction:column;align-items:center;gap:1rem;padding:2rem;display:flex}.quick-out-success-icon{color:#fff;animation:.3s ease-out .1s both toast-check}@keyframes toast-check{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.quick-out-success-text{color:#fff;margin:0;font-size:1.25rem;font-weight:500;line-height:1.4}.quick-out-success-text strong{font-weight:700}.scan-deduct{flex-direction:column;height:100%;display:flex}.scan-deduct-camera{background:var(--color-camera-bg);flex-direction:column;flex:1;display:flex;position:relative}.scan-deduct-video{object-fit:cover;flex:1;width:100%}.scan-deduct-controls{padding:1.5rem var(--spacing-page);background:linear-gradient(#0000,#000000b3);justify-content:space-around;align-items:center;display:flex;position:absolute;bottom:0;left:0;right:0}.scan-deduct-error{top:1rem;left:var(--spacing-page);right:var(--spacing-page);border-radius:var(--radius-md);color:#fff;background:#ba1a1ae6;align-items:center;gap:.5rem;padding:.75rem 1rem;font-size:.875rem;font-weight:500;animation:.2s ease-out toast-fade-in;display:flex;position:absolute}.scan-deduct-fallback{padding:2rem var(--spacing-page);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex}.scan-deduct-fallback-content{flex-direction:column;align-items:center;gap:1rem;display:flex}.scan-deduct-fallback-content h2{color:var(--color-text-primary);margin:0;font-size:1.125rem;font-weight:600}.scan-deduct-fallback-content p{color:var(--color-text-secondary);margin:0;font-size:.9375rem}.scan-deduct-fallback-icon{color:var(--color-text-muted)}@media (min-width:1024px){.product-list-items,.admin-user-list,.audit-log-list{grid-template-columns:repeat(2,1fr);gap:.75rem;display:grid}}@media (min-width:1440px){.product-list-items{grid-template-columns:repeat(3,1fr);gap:1rem;display:grid}}.notification-panel-wrapper{position:relative}.notification-bell-btn{border-radius:var(--radius-lg);background:var(--color-surface-tertiary);width:40px;height:40px;color:var(--color-text-muted);cursor:pointer;border:none;justify-content:center;align-items:center;transition:background .2s,color .2s;display:flex;position:relative}.notification-bell-btn:hover{background:var(--color-surface-elevated);color:var(--color-text-primary)}.notification-badge{color:#fff;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:.6875rem;font-weight:700;line-height:1;display:flex;position:absolute;top:-4px;right:-4px;box-shadow:0 2px 6px #00000026}.notification-badge-critical{background:var(--color-status-critical)}.notification-badge-warning{background:var(--color-status-warning)}.notification-dropdown{-webkit-backdrop-filter:blur(16px);border-radius:var(--radius-2xl);z-index:100;background:#fffffff2;border:none;width:340px;max-height:420px;animation:.2s ease-out notification-slide-in;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 12px 40px #1e191414}@keyframes notification-slide-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.notification-dropdown-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:.875rem 1rem;display:flex}.notification-dropdown-title{color:var(--color-text-primary);font-size:.9375rem;font-weight:600}.notification-close-btn{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;display:flex}.notification-close-btn:hover{background:var(--color-surface-tertiary);color:var(--color-text-primary)}.notification-empty{color:var(--color-text-muted);flex-direction:column;align-items:center;gap:.5rem;padding:2rem 1rem;font-size:.875rem;display:flex}.notification-list{max-height:350px;overflow-y:auto}.notification-item{border:none;border-bottom:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;text-align:left;gap:.75rem;width:100%;min-height:44px;padding:.75rem 1rem;transition:background .15s;display:flex}.notification-item:last-child{border-bottom:none}.notification-item:hover{background:var(--color-surface-secondary)}.notification-item-critical{border-left:3px solid var(--color-status-critical)}.notification-item-warning{border-left:3px solid var(--color-status-warning)}.notification-item-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;margin-top:.125rem;display:flex}.notification-icon-expired,.notification-icon-out_of_stock{background:var(--color-status-critical-bg);color:var(--color-status-critical)}.notification-icon-expiring_soon,.notification-icon-low_stock{background:var(--color-status-warning-bg);color:var(--color-status-warning)}.notification-item-content{flex-direction:column;flex:1;gap:.125rem;min-width:0;display:flex}.notification-item-type{text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);font-size:.6875rem;font-weight:600}.notification-item-title{color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:600;overflow:hidden}.notification-item-message{color:var(--color-text-secondary);font-size:.75rem}.feedback-page{padding:0 var(--spacing-page) 6rem;max-width:800px;margin:0 auto;animation:.3s ease-out pageEnter}.feedback-header{align-items:flex-start;gap:.75rem;padding:1.25rem 0 1rem;display:flex}.feedback-header-content{flex:1}.feedback-header-title-row{align-items:center;gap:.5rem;display:flex}.feedback-header-icon{color:var(--color-gold)}.feedback-header-title{font-family:var(--font-heading);color:var(--color-text-primary);margin:0;font-size:1.5rem;font-weight:400}.feedback-header-subtitle{color:var(--color-text-secondary);margin:.25rem 0 0;font-size:.875rem}.feedback-submit-btn{background:var(--color-primary-gradient);color:#fff;border-radius:var(--radius-lg);width:100%;font-family:var(--font-sans);cursor:pointer;border:none;align-items:center;gap:.5rem;min-height:48px;margin-bottom:1rem;padding:.875rem 1.25rem;font-size:.9375rem;font-weight:500;transition:transform .15s,box-shadow .15s;display:flex}.feedback-submit-btn:hover{transform:translateY(-1px);box-shadow:0 4px 14px #5a9a6e4d}.feedback-filter-bar{-webkit-overflow-scrolling:touch;scrollbar-width:none;align-items:center;gap:.5rem;margin-bottom:.75rem;padding:.75rem 0;display:flex;overflow-x:auto}.feedback-filter-bar::-webkit-scrollbar{display:none}.feedback-filter-icon{color:var(--color-text-muted);flex-shrink:0}.feedback-filter-chips{flex-shrink:0;gap:.375rem;display:flex}.feedback-filter-chip{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;white-space:nowrap;align-items:center;min-height:36px;padding:.375rem .875rem;font-size:.8125rem;font-weight:500;transition:all .2s;display:inline-flex}.feedback-filter-chip:hover{background:var(--color-surface-tertiary);color:var(--color-text-primary)}.feedback-filter-chip-active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.feedback-filter-chip-active:hover{background:var(--color-primary-hover);color:#fff}.feedback-list{flex-direction:column;gap:.75rem;display:flex}.feedback-card{background:var(--color-surface);border-radius:var(--radius-xl);padding:1.125rem 1.25rem;transition:box-shadow .2s,transform .2s;box-shadow:0 1px 4px #0000000a,0 2px 12px #00000005}.feedback-card:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000000f,0 4px 20px #00000008}.feedback-card-header{justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.5rem;display:flex}.feedback-card-title{font-family:var(--font-heading);color:var(--color-text-primary);flex:1;margin:0;font-size:1.0625rem;font-weight:400;line-height:1.3}.feedback-card-description{color:var(--color-text-secondary);margin:0 0 .625rem;font-size:.875rem;line-height:1.5}.feedback-status-badge{border-radius:var(--radius-full);letter-spacing:.01em;white-space:nowrap;flex-shrink:0;align-items:center;padding:.25rem .625rem;font-size:.75rem;font-weight:600;display:inline-flex}.feedback-status-pending{background:var(--color-gold-light);color:#93701f}.feedback-status-approved{background:var(--color-primary-light);color:#36634d}.feedback-status-rejected{background:var(--color-rose-light);color:#8a424e}.feedback-status-implemented{background:var(--color-status-ok-bg);color:#246b41}.feedback-card-tags{flex-wrap:wrap;gap:.25rem;margin-bottom:.5rem;display:flex}.feedback-tag{background:var(--color-surface-tertiary);border-radius:var(--radius-full);color:var(--color-text-muted);padding:.125rem .5rem;font-size:.6875rem;font-weight:500;display:inline-flex}.feedback-card-estimates{gap:.375rem;margin-bottom:.5rem;display:flex}.feedback-estimate-chip{border-radius:var(--radius-full);align-items:center;padding:.1875rem .5rem;font-size:.6875rem;font-weight:600;display:inline-flex}.feedback-estimate-hours{color:#3e5974;background:#e9edf2}.feedback-estimate-let{background:var(--color-status-ok-bg);color:#246b41}.feedback-estimate-middel{background:var(--color-status-warning-bg);color:#93691f}.feedback-estimate-svær{background:var(--color-status-critical-bg);color:#913030}.feedback-admin-response{background:var(--color-gold-light);border-radius:var(--radius-md);margin-bottom:.5rem;padding:.625rem .75rem}.feedback-admin-response-header{color:#8a6d28;align-items:center;gap:.375rem;margin-bottom:.25rem;font-size:.75rem;font-weight:600;display:flex}.feedback-admin-response-text{color:var(--color-text-secondary);margin:0;font-size:.8125rem;line-height:1.4}.feedback-card-footer{justify-content:flex-end;align-items:center;display:flex}.feedback-card-date{color:var(--color-text-muted);align-items:center;gap:.25rem;font-size:.75rem;display:inline-flex}.feedback-empty{text-align:center;padding:3rem 1.5rem}.feedback-empty-icon{color:var(--color-gold);opacity:.6;margin-bottom:.75rem}.feedback-empty-title{font-family:var(--font-heading);color:var(--color-text-primary);margin:0 0 .25rem;font-size:1.125rem;font-weight:400}.feedback-empty-text{color:var(--color-text-muted);margin:0;font-size:.875rem}.feedback-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#00000073;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.feedback-modal{background:var(--color-surface);border-radius:var(--radius-2xl);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #00000026,0 2px 8px #0000000d}.feedback-modal-header{justify-content:space-between;align-items:center;padding:1.25rem 1.25rem 0;display:flex}.feedback-modal-title-row{align-items:center;gap:.5rem;display:flex}.feedback-modal-icon{color:var(--color-gold)}.feedback-modal-title{font-family:var(--font-heading);margin:0;font-size:1.25rem;font-weight:400}.feedback-modal-close{background:var(--color-surface-tertiary);width:36px;height:36px;color:var(--color-text-secondary);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;transition:background-color .15s;display:flex}.feedback-modal-close:hover{background:var(--color-surface-elevated)}.feedback-modal-description{color:var(--color-text-secondary);margin:0;padding:.75rem 1.25rem 0;font-size:.875rem;line-height:1.5}.feedback-modal-error{background:var(--color-status-critical-bg);color:var(--color-status-critical);border-radius:var(--radius-md);margin:.75rem 1.25rem 0;padding:.625rem .75rem;font-size:.8125rem}.feedback-modal-error p{margin:0}.feedback-modal-form{flex-direction:column;gap:1rem;padding:1rem 1.25rem 1.25rem;display:flex}.feedback-modal-actions{justify-content:flex-end;gap:.75rem;padding-top:.5rem;display:flex}.feedback-modal-cancel-btn{border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;background:0 0;align-items:center;min-height:44px;padding:.625rem 1.25rem;font-size:.875rem;transition:background-color .15s;display:flex}.feedback-modal-cancel-btn:hover{background:var(--color-surface-tertiary)}.feedback-modal-submit-btn{background:var(--color-primary-gradient);color:#fff;border-radius:var(--radius-md);font-family:var(--font-sans);cursor:pointer;border:none;align-items:center;gap:.375rem;min-height:44px;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;transition:transform .15s,box-shadow .15s;display:flex}.feedback-modal-submit-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 14px #5a9a6e4d}.feedback-modal-submit-btn:disabled{opacity:.5;cursor:not-allowed}.feedback-admin-sort{align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.feedback-admin-list{flex-direction:column;gap:.5rem;display:flex}.feedback-admin-card{background:var(--color-surface);border-radius:var(--radius-lg);transition:box-shadow .2s;overflow:hidden;box-shadow:0 1px 3px #0000000a}.feedback-admin-card:hover{box-shadow:0 2px 8px #0000000f}.feedback-admin-card-expanded{box-shadow:0 2px 12px #00000014}.feedback-admin-card-header{cursor:pointer;text-align:left;width:100%;font-family:var(--font-sans);min-height:48px;color:var(--color-text-primary);background:0 0;border:none;justify-content:space-between;align-items:center;gap:.75rem;padding:.875rem 1rem;display:flex}.feedback-admin-card-header:hover{background:var(--color-surface-secondary)}.feedback-admin-card-summary{flex:1;align-items:center;gap:.625rem;min-width:0;display:flex}.feedback-admin-card-title{white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.9375rem;font-weight:500;overflow:hidden}.feedback-admin-card-meta{color:var(--color-text-muted);flex-shrink:0;align-items:center;gap:.375rem;display:flex}.feedback-admin-card-body{border-top:1px solid var(--color-border);flex-direction:column;gap:.75rem;padding:.75rem 1rem 1rem;display:flex}.feedback-admin-description{color:var(--color-text-secondary);font-size:.8125rem;line-height:1.5}.feedback-admin-description strong{color:var(--color-text-primary);margin-bottom:.25rem;display:block}.feedback-admin-description p{margin:0}.feedback-admin-actions{justify-content:flex-end;gap:.5rem;padding-top:.5rem;display:flex}.feedback-admin-ai-btn{background:var(--color-surface-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-sans);color:var(--color-petrol);cursor:pointer;align-items:center;gap:.375rem;min-height:40px;padding:.5rem .875rem;font-size:.8125rem;font-weight:500;transition:all .15s;display:flex}.feedback-admin-ai-btn:hover:not(:disabled){border-color:var(--color-petrol);background:#e3eef2}.feedback-admin-ai-btn:disabled{opacity:.5;cursor:not-allowed}.feedback-admin-save-btn{background:var(--color-primary-gradient);color:#fff;border-radius:var(--radius-md);font-family:var(--font-sans);cursor:pointer;border:none;align-items:center;gap:.375rem;min-height:40px;padding:.5rem 1rem;font-size:.8125rem;font-weight:500;transition:all .15s;display:flex}.feedback-admin-save-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 14px #5a9a6e4d}.feedback-admin-save-btn:disabled{opacity:.5;cursor:not-allowed}@media (min-width:768px){.feedback-page{padding:0 2rem 4rem}.feedback-header-title{font-size:1.75rem}.feedback-submit-btn{width:auto;display:inline-flex}}@media (min-width:1024px){.feedback-list{grid-template-columns:repeat(2,1fr);gap:.75rem;display:grid}.feedback-page{max-width:960px}}.feedback-status-in-progress{color:var(--color-botanical-navy,#2c3e50);background:#2c3e501a;border:1px solid #2c3e5033}.feedback-priority-chip{letter-spacing:.03em;border-radius:9999px;align-items:center;gap:.25rem;padding:.125rem .5rem;font-size:.6875rem;font-weight:600;display:inline-flex}.feedback-priority-1{color:#b71c1c;background:#b71c1c1f}.feedback-priority-2{color:#e67e22;background:#e67e221f}.feedback-priority-3{color:var(--color-botanical-sage,#5a9a6e);background:#5a9a6e1f}.feedback-priority-4{color:#7f8c8d;background:#2c3e5014}.feedback-priority-5{color:#95a5a6;background:#2c3e500d}.feedback-agent-info{border-radius:var(--radius-md,10px);background:#2c3e500a;border:1px dashed #2c3e5026;margin-top:.5rem;padding:.75rem 1rem;font-size:.8125rem}.feedback-agent-info-header{color:var(--color-botanical-navy,#2c3e50);align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.feedback-agent-analysis{color:var(--color-text-secondary,#666);white-space:pre-wrap;margin:.25rem 0;font-size:.8125rem;line-height:1.5}.feedback-agent-link{color:var(--color-botanical-sage,#5a9a6e);text-underline-offset:3px;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.feedback-agent-link:hover{color:var(--color-botanical-navy,#2c3e50);text-decoration-style:solid}.bottom-nav{background:var(--color-surface);border-top:1px solid var(--color-border);z-index:40;padding-bottom:env(safe-area-inset-bottom);align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 24px #1e19140a}.bottom-nav-item{min-height:56px;color:var(--color-text-muted);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.25rem;padding:.625rem 0;font-size:.75rem;font-weight:500;text-decoration:none;transition:color .25s ease-out;display:flex}.bottom-nav-item:hover{color:var(--color-text-secondary)}.bottom-nav-active{color:var(--color-primary);font-weight:700}.bottom-nav-item.logout-btn{cursor:pointer;background:0 0;border:none;font-family:inherit}.bottom-nav-item.logout-btn:hover{color:var(--color-status-critical);background:var(--color-status-critical-bg)}.nav-brand{display:none}@media (min-width:1024px){.nav-brand{border-bottom:1px solid var(--color-border);align-items:center;gap:.625rem;margin-bottom:.5rem;padding:.5rem 1rem 1.5rem;display:flex}.nav-brand-icon{background:var(--color-primary-gradient);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.nav-brand-text{font-family:var(--font-heading);color:var(--color-text-primary);letter-spacing:-.01em;font-size:1.125rem;font-weight:400}}.dashboard{padding:1.5rem var(--spacing-page);flex-direction:column;gap:1.5rem;display:flex;position:relative}.dashboard:before{content:"";pointer-events:none;opacity:.22;z-index:0;background-image:url(/illustrations/botanical-corner-tl.svg);background-repeat:no-repeat;background-size:contain;width:280px;height:280px;position:absolute;top:-30px;left:-20px}@media (prefers-reduced-motion:reduce){.dashboard:before{display:none}}.login-page{min-height:100dvh;padding:var(--spacing-page);background:0 0;flex-direction:column;justify-content:center;align-items:center;animation:.4s ease-out pageEnter;display:flex;position:relative}.login-card{-webkit-backdrop-filter:blur(20px);border:1px solid var(--color-border);border-radius:var(--radius-2xl);background:#fbfaf9bf;width:100%;max-width:420px;padding:1rem 2rem 2.5rem;position:relative;overflow:hidden;box-shadow:0 8px 32px #1e19140f}.login-card:before{content:"";pointer-events:none;opacity:.55;z-index:0;background-image:url(/illustrations/botanical-corner-tl.svg);background-repeat:no-repeat;background-size:contain;width:240px;height:240px;position:absolute;top:-20px;left:-20px}.login-card:after{content:"";pointer-events:none;opacity:.45;z-index:0;background-image:url(/illustrations/botanical-corner-br.svg);background-repeat:no-repeat;background-size:contain;width:200px;height:200px;position:absolute;bottom:-20px;right:-20px}.login-hero-illustration{text-align:center;z-index:1;max-width:220px;margin:-.5rem auto .5rem;position:relative}.login-hero-img{mix-blend-mode:multiply;opacity:.92;filter:saturate(.9);max-width:100%;height:auto;transition:opacity .3s ease-out}.login-header{text-align:center;z-index:1;margin-bottom:2rem;position:relative}.login-logo{background:var(--color-primary-gradient);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:1rem;display:inline-flex;box-shadow:0 4px 14px #5a9a6e40}.login-title{font-family:var(--font-heading);color:var(--color-text-primary);letter-spacing:-.01em;margin-bottom:.375rem;font-size:1.75rem;font-weight:400}.login-subtitle{font-family:var(--font-accent);color:var(--color-text-muted);font-size:1.125rem;font-weight:400}.login-error{background:var(--color-status-critical-bg);color:var(--color-status-critical);border-radius:var(--radius-lg);z-index:1;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem;display:flex;position:relative}.login-form{z-index:1;flex-direction:column;gap:1.25rem;display:flex;position:relative}.login-form .form-label{color:var(--color-text-secondary);letter-spacing:.01em;font-size:.8125rem;font-weight:500}.login-form .form-input{background:var(--color-surface-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);min-height:52px;padding:.875rem 1rem;font-size:1rem;transition:border-color .25s ease-out,box-shadow .25s ease-out}.login-form .form-input:focus{background:var(--color-surface);border-color:var(--color-primary);box-shadow:0 0 0 3px #5a9a6e1f}.login-password-wrapper{position:relative}.login-password-toggle{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:.25rem;display:flex;position:absolute;top:50%;right:.75rem;transform:translateY(-50%)}.login-submit-btn{background:var(--color-primary-gradient);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;justify-content:center;align-items:center;gap:.5rem;min-height:52px;margin-top:.5rem;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;transition:transform .2s ease-out,box-shadow .25s ease-out;display:flex;box-shadow:0 4px 14px #5a9a6e33}.login-submit-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #5a9a6e4d}.login-submit-btn:active:not(:disabled){transform:scale(.97)}.login-submit-btn:disabled{opacity:.5;cursor:not-allowed}.login-mock-section{z-index:1;border-top:none;margin-top:2rem;padding-top:1.5rem;position:relative}.login-mock-section:before{content:"";background:linear-gradient(90deg, transparent, var(--color-border-strong), transparent);height:1px;position:absolute;top:0;left:20%;right:20%}.login-mock-label{color:var(--color-text-muted);text-align:center;margin-bottom:.75rem;font-size:.75rem;font-weight:500}.login-mock-users{flex-direction:column;gap:.5rem;display:flex}.login-mock-user-btn{background:var(--color-surface-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;justify-content:space-between;align-items:center;width:100%;min-height:48px;padding:.875rem 1rem;transition:background .25s ease-out,box-shadow .25s ease-out,transform .2s ease-out;display:flex}.login-mock-user-btn:hover{background:var(--color-surface-elevated);transform:translateY(-1px);box-shadow:0 2px 8px #1e19140f}.login-mock-name{color:var(--color-text-primary);font-size:.875rem;font-weight:600}.login-mock-role{font-family:var(--font-accent);color:var(--color-text-muted);font-size:.875rem}.login-loading{justify-content:center;align-items:center;min-height:100dvh;display:flex}.login-footer{text-align:center;color:var(--color-text-muted);margin-top:2rem;font-size:.75rem;position:relative}.login-footer-brand{letter-spacing:.04em;font-weight:600}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}
